pdfTeX Users Manual
pdfTeX Users Manual
pdfTeX Users Manual
users manual
Hn Th Thnh Sebastian Rahtz Hans Hagen Hartmut Henkel
Contents
1 2 3 4 5 6 7 8 Introduction About PDF Getting started Macro packages supporting PDFTEX Setting up fonts Formal syntax specication PDFTEX primitives Graphics and color 9 Character translation
Abbreviations Examples of HZ and protruding Additional PDF keys Colophon GNU Free Documentation License
1 Introduction
The main purpose of the pdfTEX project is to create and maintain an extension of TEX that can produce pdf directly from TEX source les and improve/enhance the result of TEX typesetting with the help of pdf. When pdf output is not selected, pdfTEX produces normal dvi output, otherwise it generates pdf output that looks identical to the dvi output. An important aspect of this project is to investigate alternative justication algorithms (e. g. a font expansion algorithm akin to the hz micro--typography algorithm by Prof. Hermann Zapf), optionally making use of Multiple Master fonts. pdfTEX is based on the original TEX sources and Web2c, and has been successfully compiled on Unix, Win32 and MSDos systems. It is under active development, with new features trickling in. Great care is taken to keep new pdfTEX versions backward compatible with earlier ones. For some years there has been a moderate successor to TEX available, called -TEX. Because mainstream macro packages A such as L TEX have started supporting this welcome extension, the -TEX functionality has also been integrated into the pdfTEX code. For a while (TEX Live 2004 and 2005) pdfTEX therefore came in two avours: the -TEX enabled pdfeTEX engine and the standard one, pdfTEX. The ability to produce both pdf and dvi output made pdfeTEX the primary TEX engine in these distributions. Since pdfTEX version 1.40 now the -TEX extensions are part already of the pdfTEX engine, so there is no need anymore to ship pdfeTEX. The -TEX functionality of pdfTEX can be disabled if not required. Other extensions are MLTEX and encTEX; these are also included in the current pdfTEX code. content The pdfTEX user manual exit
pdfTEX is maintained by Hn Th Thnh, Martin Schrder, Hans Hagen, Taco Hoekwater, Hartmut Henkel, and others. The pdfTEX homepage is http://www.pdftex.org. Please send pdfTEX comments and bug reports to the mailing list [email protected]. We thank all readers who send us corrections and suggestions. We also wish to express the hope that pdfTEX will be of as much use to you as it is to us. Since pdfTEX is still being improved and extended, we suggest you to keep track of updates.
2 About PDF
The cover of this manual lists an almost minimal pdf le generated by pdfTEX, with the corresponding source le on the next page. Unless compression is enabled, such a pdf le is rather verbose and readable. The rst line species the
content
exit
version used; currently pdfTEX produces level 1.4 output by default. pdf viewers are supposed to silently skip over all elements they cannot handle. A pdf le consists of objects. These objects can be recognized by their number and keywords:
because a lot of kerning takes place; in our example the 80 moves the text (elcome) left towards the letter (W) by 80/1000 of the font size. pdf viewers in search mode simply ignore the kerning information in these text streams. When a document is searched, the search engine reconstructs the text from these (string) snippets. Every /Page object points also to a /Resources object (no. 1) that gives all ingredients needed to assemble the page. In our example only a /Font object (no. 4) is referenced, which in turn tells that the text is typeset in /Font /Times-Roman. The /Font object points also to a /Widths array (object no. 7) that tells for each character by how much the viewer must move forward horizontally after typesetting a glyph. More details about the font can be found in the /FontDescriptor object (no. 8); if a font le is embedded, this object points to the font program stream. But as the Times-Roman font used for our example is one of the 14 so--called standard fonts that should always be present in any pdf viewer and therefore need not be embedded in the pdf le, it is left out here for brevity. However, when we use for instance a Computer Modern Roman font, we have to make sure that this font is later available to the pdf viewer, and the best way to do this is to embed the font. Its highly recommended nowadays to embed even the standard fonts, as modern viewers often dont use the original 14 standard fonts anymore, but instead approximate them by instances of built--in Multiple Master fonts (e. g. the Adobe Reader 7 approximates the Times-Roman variants by the Minion font). So you never really know how it looks exactly at the viewer side unless you embed every font. In this simple le we dont specify in what way the le should be opened, for instance full screen or clipped. A closer look at the page object no. 2 (/Type /Page) shows that a mediabox (/MediaBox) is part of the page description. A mediabox acts like the (high-resolution) bounding box in a PostScript le. pdfTEX users can add dictionary stuff to page objects by the \pdfpageattr primitive. Although in most cases macro packages will shield users from these internals, pdfTEX provides access to many of the entries described here, either automatically by translating the TEX data structures into pdf ones, or manually by pushing entries to the catalog, page, info or self created objects. One can for instance create an object by using \pdfobj after which \pdflastobj returns the number. So
general this rather direct way of pushing objects in the pdf les by primitives like \pdfobj is not very useful, and only makes sense when implementing, say, ll--in eld support or annotation content reuse. We will come to that later. For those who want to learn more about the gory pdf details, the best bet is to read the PDF Reference. As of the time of writing you can download this book as a big pdf le from Adobes PDF Technology Center, http://www.adobe.com /devnet/pdf/pdf reference.html or get the heavy paper version. Those who, after this introduction, feel unsure how to proceed, are advised to read on but skip section 7. Before we come to that section, we will describe how to get started with pdfTEX.
3 Getting started
This section describes the steps needed to get pdfTEX running on a system where pdfTEX is not yet installed. Nowadays virtually all TEX distributions have pdfTEX as a component, such as TEX Live, teTEX, XEmTEX, MikTeX, proTEXt, and CMacTEX. The ready to run TEX Live distribution comes with pdfTEX versions for many Unix, Win32, and Mac OS X systems; more information can be found at http://www.tug.org/tex-live/. teTEX by Thomas Esser is a source distribution with an automated compilation process for Unix systems; see http://www.tug.org/teTeX/. For Win32 systems there are also three separate distributions that contain pdfTEX, all in ctan:systems/win32: XEmTEX by Fabrice Popineau, MikTeX by Christian Schenk, and proTEXt (based on MikTeX) by Thomas Feuerstack. So when you use any of these distributions, you dont need to bother with the pdfTEX installation procedure in the next sections. If there is no precompiled pdfTEX binary for your system, or the version coming with a distribution is not the current one and you would like to try out a fresh pdfTEX immediately, you will need to build pdfTEX from sources; read on. You should already have a working TEX system, e. g. TEX Live or teTEX, into which the freshly compiled pdfTEX will be integrated. Note that the installation description in this manual is Web2c--specic.
developers homepage http://sarovar.org/projects/pdftex/, where you also nd bug tracking information, and the manual sources. Download the pdfTEX archive from there. The pdfTEX sources can also be found at their canonical place in the CTAN network, ctan:systems/pdftex. Separate pdfTEX binaries for various systems might also be available, check out the subdirectories below ctan:systems.
3.2 Compiling
The compilation is expected to be easy on Unix--like systems and can be described best by example. Assuming that the le pdftex.zip is downloaded to some working directory, e. g. $HOME/pdftex, on a Unix system the following steps are needed to compile pdfTEX:
content
exit
Dont forget to do a texconfig-sys init afterwards, so that all formats are regenerated system-wide with the fresh pdftex binary.
TEXMFOUTPUT TEXINPUTS TEXFORMATS TEXPOOL ENCFONTS TEXFONTMAPS TFMFONTS VFFONTS T1FONTS TTFONTS OPENTYPEFONTS PKFONTS
TEXMFOUTPUT
Normally, pdfTEX puts its output les in the current directory. If any output le cannot be opened there, it tries to open it in the directory specied in the environment variable TEXMFOUTPUT. There is no default value for that variable. For example, if you type pdftex paper and the current directory is not writable, if TEXMFOUTPUT has the value /tmp, pdfTEX attempts to create /tmp/paper.log (and /tmp/paper.pdf, if any output is produced.) This variable species where pdfTEX nds its input les. Image les are considered input les and searched for along this path. Search path for format (.fmt) les. Search path for pool (.pool) les. Search path for encoding (.enc) les. Search path for font map (.map) les. Search path for font metric (.tfm) les. Search path for virtual font (.vf) les. Virtual fonts are fonts made up of other fonts. Because pdfTEX produces the nal output code, it must consult those les. Search path for Type 1 font les (.pfa and .pfb). These outline (vector) fonts are to be preferred over bitmap pk fonts. In most cases Type 1 fonts are used and this variable tells pdfTEX where to nd them.
TTFFONTS, OPEN- Search paths for TrueType (.ttf) and OpenType (.otf) font les. Like Type 1 fonts, TrueType and TYPEFONTS OpenType fonts are also outlines. PKFONTS
Search path for packed (bitmap) font (.pk) les. Unfortunately bitmap fonts are still displayed poorly by some pdf viewers, so when possible one should use outline fonts. When no outline is available, pdfTEX tries to locate a suitable pk font (or invoke a process that generates it).
content
exit
content
exit
internal name
type integer integer integer integer integer integer integer token reg. integer integer integer integer integer dimension dimension dimension dimension dimension dimension dimension text
default 0 0 9 0 4 72 0 empty 0 0 4 0 0 1 in 1 in 0 pt 0 pt 0 pt 0 pt 0 pt
comment dvi off best no object streams max. dpi 72 dpi mode set in mktex.cnf
\pdfoutput \pdfadjustspacing \pdfcompresslevel \pdfobjcompresslevel \pdfdecimaldigits \pdfimageresolution \pdfpkresolution \pdfpkmode \pdfuniqueresname \pdfprotrudechars \pdfminorversion \pdfforcepagebox \pdfinclusionerrorlevel \pdfhorigin \pdfvorigin \pdfpagewidth \pdfpageheight \pdflinkmargin \pdfdestmargin \pdfthreadmargin \pdfmapfile
Table 2
pdf 1.4
% Set pdfTeX parameters for pdf mode (replacing pdftex.cfg file). % Thomas Esser, 2004. public domain. \pdfoutput=1 \pdfpagewidth=210 true mm \pdfpageheight=297 true mm \pdfpkresolution=600 \endinput
Figure 1
% Thomas Esser, 1998, 2004. public domain. \ifx\pdfoutput\undefined \else \ifx\pdfoutput\relax \else \input pdftexconfig \pdfoutput=0 \fi \fi \input etex.src \dump \endinput
Figure 2
format le then inherits this setting, so that a later call to pdfTEX with this format starts in the preselected mode (which still can be overrun then). A format le can be read in only by the engine that has generated it; a format incompatible with an engine leads to a fatal error. It is customary to package the conguration and macro le input into a .ini le. E. g., the le etex.ini in gure 2 is for generating an -TEX format with dvi output (it contains a few comparisons to be safe also for TEX engines). A similar A le pdflatex.ini can be used for generating a L TEX format with pdf output; refer to gure 3. One can see how the content The pdfTEX user manual exit
\ifx\pdfoutput\undefined \else \ifx\pdfoutput\relax \else \input pdftexconfig \pdfoutput=1 \fi \fi \scrollmode \input latex.ltx \endinput
Figure 3
primitive \pdfoutput is used to override the output mode set by le pdftexconfig.tex. The corresponding pdfTEX calls for format generation are:
texexec --make en
for an English format, or
texexec --make en de
for an English and German one. Most users will simply say:
pdftex samplepdf
If the installation is ok, this run should produce a le called samplepdf.pdf. The le samplepdf.tex is also a good place to look for how to use pdfTEXs primitives.
content
exit
TEXMFCNF is not set correctly and so pdfTEX cannot nd texmf.cnf, or TEXPOOL in texmf.cnf doesnt contain a path to the pool le pdftex.pool.
You have to increase POOLSIZE. pdfTEX cannot nd texmf.cnf, or the value of pool_size specied in texmf.cnf is not large enough and must be increased. If pool_size is not specied in texmf.cnf then you can add something like
pool_size=500000
I cant find the format file pdftex.fmt!
content
exit
When you have installed new fonts, and your pdf viewer complains about missing fonts, you should take a look at the log le produced by pdfTEX. Missing fonts, map les, encoding vectors as well as missing characters (glyphs) are reported there. Normally the page content takes one object. This means that one seldomly nds more than a few hundred objects in a simple le. This pdfTEX manual for instance uses approx. 750 objects. In more complex applications this number can grow quite rapidly, especially when one uses a lot of widget annotations, shared annotations or other shared things. In any case pdfTEXs internal object table size will automatically grow to the required size (the parameter obj_tab_size for manual control of the object table size is now obsolete and ignored).
\pdfoutput=1 \let\special\message
or, if this leads to confusion,
content
exit
Currently all mainstream macro packages offer pdfTEX support, with automatic detection of pdfTEX as engine. So there is normally no need to turn on pdfTEX support explicitly.
A For L TEX users, Sebastian Rahtz and Heiko Oberdieks hyperref package has substantial support for pdfTEX and provides access to most of its features. In the simplest and most common case, the user merely needs to load hyperref, and all cross--references will be converted to pdf hypertext links. pdf output is automatically selected, compression is turned on, and the page size is set up correctly. Bookmarks are created to match the table of contents. A The standard L TEX graphics, graphicx, and color packages also have automatic pdfTEX support, which allow use of color, text rotation, and graphics inclusion commands.
The ConTEXt macro package by Hans Hagen has very full support for pdfTEX in its generalized hypertext features. Support for pdfTEX is implemented as a special driver, and is invoked by typing \setupoutput[pdftex] or feeding TEXexec with the --pdf option. pdf from Texinfo documents can be created by running pdfTEX on the Texinfo le, instead of TEX. Alternatively, run the shell command texi2pdf instead of texi2dvi. A small modication of webmac.tex, called pdfwebmac.tex, allows production of hyperlinked pdf versions of the program code written in web. Some nice samples of pdfTEX output can be found at http://www.pdftex.org, http://www.pragma-ade.com, and http://www.tug.org/texshowcase.
5 Setting up fonts
pdfTEX can work with Type 1 and TrueType fonts (and to some extent also with OpenType fonts). Font les should be available and embedded for all fonts used in the document. It is possible to use METAFONT--generated fonts in pdfTEX but it is strongly recommended not to use these fonts if an equivalent is available in Type 1 or TrueType format, if only because bitmap Type 3 fonts render very poorly in (older versions of) Adobe Reader. Given the free availability of Type 1 versions of all the Computer Modern fonts, and the ability to use standard PostScript fonts, there is rarely a need to use bitmap fonts in pdfTEX. content The pdfTEX user manual exit
content
exit
Second, if a font le is not to be embedded into the pdf output (fontle eld missing), then the basename eld will be copied to the /BaseFont and /FontName dictionary entries in the pdf le, so that the PostScript font name will be known to the consumer application (e. g. viewer). It is highly recommended to always use the basename eld (but strictly speaking its optional). fontags specify some characteristics of the font. The following description of these ags is taken, with slight modication, from the PDF Reference (the section on font descriptor ags). Viewers can adapt their rendering to these ags, especially when they substitute a non-embedded font by some own approximation. The value of the ags key in a font descriptor is a 32--bit integer that contains a collection of boolean attributes. These attributes are true if the corresponding bit is set to 1. Table 3 species the meanings of the bits, with bit 1 being the least signicant. Reserved bits must be set to zero. bit position 1 2 3 4 5 6 7 816 17 18 19 2032 Table 3 semantics Fixed--width font Serif font Symbolic font Script font Reserved Uses the Adobe Standard Roman Character Set Italic Reserved All--cap font Small--cap font Force bold at small text sizes Reserved The meaning of ags in the font descriptor.
All characters in a xed--width font have the same width, while characters in a proportional font have different widths. Characters in a serif font have short strokes drawn at an angle on the top and bottom of character content The pdfTEX user manual exit
stems, while sans serif fonts do not have such strokes. A symbolic font contains symbols rather than letters and numbers. Characters in a script font resemble cursive handwriting. An all--cap font, which is typically used for display purposes such as titles or headlines, contains no lowercase letters. It differs from a small--cap font in that characters in the latter, while also capital letters, have been sized and their proportions adjusted so that they have the same size and stroke weight as lowercase characters in the same typeface family. Bit 6 in the ags eld indicates that the fonts character set conforms to the Adobe Standard Roman Character Set, or a subset of that, and that it uses the standard names for those characters. Finally, bit 19 is used to determine whether or not bold characters are drawn with extra pixels even at very small text sizes. Typically, when characters are drawn at small sizes on very low resolution devices such as display screens, features of bold characters may appear only one pixel wide. Because this is the minimum feature width on a pixel--based device, ordinary non--bold characters also appear with one--pixel wide features, and thus cannot be distinguished from bold characters. If bit 19 is set, features of bold characters may be thickened at small text sizes. If the fontags eld is not given, pdfTEX treats it as being 4, a symbolic font. If you do not know the correct value, it is best not to specify it at all, as specifying a bad value of font ags may cause troubles in viewers. On the other hand this option is not absolutely useless because it provides backward compatibility with older map les (see the fontle description below). instructions can be used to manipulate fonts similar to the way dvips does. Currently only the keywords SlantFont and ExtendFont are interpreted, other instructions (as ReEncodeFont with parameters, see encoding below) are just ignored. The permitted SlantFont range is 1..1; for ExtendFont its 2..2. The block of special instruction must be enclosed by double quotes ". special encodingle species the name of the le containing the external encoding vector to be used for the font. The encoding le must have name extension .enc, and the full le name including this extension must be given with preceding < character. The format of the encoding vector is identical to that used by dvips. If no encoding is specied, the fonts built--in default encoding is used. The encodingle eld may be omitted if you are sure that the font resource has the correct built--in encoding. In general this option is highly recommended, and it is required when subsetting a TrueType font. content The pdfTEX user manual exit
fontle sets the name of the font le to be embedded into the pdf output for a given TEX font (the tfmname fontle mapping is the most prominent use of the pdftex.map le). The font le name must belong to a Type 1 or TrueType font le. If the fontle eld is missing, no font embedding can take place; in case the basename eld does not contain one of the 14 standard font names also a warning will be given. Not embedding a font into a pdf le might be troublesome, as it requires that the font or some similar looking replacement font is available within the pdf viewer, so that it can render the glyphs with its own font version. The font le name should be preceded by one or two special characters, which tells how to handle the font le: If the font le name is preceded by a < character, the font le will be only partially embedded into the pdf le (subsetted), meaning that only used glyphs are going into the pdf le. This is the most common use and is strongly recommended for any font, as it ensures the portability and reduces the size of the pdf output. Subsetted fonts are included in such a way that name and cache clashes are minimized. If the font le name is preceded by a double <<, the font le will be included entirely all glyphs of the font are embedded, including even the ones that are not used in the document. Apart from causing large size pdf output, this option may cause troubles with TrueType fonts, so it is normally not recommended for Type1 or TrueType fonts. But this is currently the only mode that allows the use of OpenType fonts. This mode might also be useful in case the font is atypical and can not be subsetted well by pdfTEX. Beware: some font vendors forbid full font inclusion. The case that no special character precedes the font le name is deprecated since pdfTEX version 1.40.0. These font les are now completely ignored, and a corresponding warning is given. You achieve exactly the same pdf result if you just remove the font le name from the map entry. Then the glyph widths that go into the pdf le are extracted from the tfm le, and a font descriptor object is created that contains approximations of the font metrics for the selected font. This option is useful only as fallback when you do not want to embed the font (e. g. due to font license restrictions), but wish to use the font metrics and let the pdf viewer generate instances that look close to the used font in case the font resource is not installed on the system where the pdf output will be viewed or printed. To use this feature, the font ags must be specied, and it must have the bit 6 set on, which means that only fonts with the Adobe Standard Roman Character Set can be simulated. The only exception is the case of a Symbolic font, which is not very useful.
content
exit
When one suffers from invalid lookups, for instance when pdfTEX tries to open a .pfa le instead of a .pfb one, one can add the sufx to the lename. In this respect, pdfTEX completely relies on the kpathsea libraries. If a used font is not present in the map les, rst pdfTEX will look for a source with sufx .pgc, which is a so--called pgc source (pdf Glyph Container) 1. If no pgc source is available, pdfTEX will try to use pk fonts as dvi drivers do, creating pk fonts on--the--y if needed. Lines containing nothing apart from tfmname stand for scalable Type 3 fonts. For scalable fonts as Type 1, TrueType and scalable Type 3 font, all the fonts loaded from a tfm at various sizes will be included only once in the pdf output. Thus if a font, lets say csr10, is described in one of the map les, then it will be treated as scalable. As a result the font source for csr10 will be included only once for csr10, csr10 at 12pt etc. So pdfTEX tries to do its best to avoid multiple embedding of identical font sources. Thus vector pgc fonts should be specied as scalable Type 3 in map les like:
csr10
It doesnt hurt much if a scalable Type 3 font is not given in map les, except that the font source will be embedded into the pdf le multiple times for various sizes, which causes a much larger pdf output. On the other hand if a font in the map les is dened as scalable Type 3 font and its pgc source is not scalable or not available, pdfTEX will use pk fonts instead; the pdf output is still valid but some fonts may look ugly because of the scaled bitmap. To summarize this rather confusing story, we include some example lines. The most common way is to embed only a glyph subset from a font like this, with re--encoding:
content
exit
psyro StandardSymL ".167 SlantFont" <usyr.pfb pcrr8rn Courier ".85 ExtendFont" <8r.enc <pcrr8a.pfb
Entirely embed a font into the pdf le without and with re--encoding:
content
exit
A TrueType le can be recognized by its sufx ttf. The optional encoding species the encoding, which is the same as the encoding vector used in map les for pdfTEX and dvips. If the encoding is not given, all the glyphs of the afm output will be mapped to /.notdef. ttf2afm writes the output afm to standard output. If we need to know which glyphs are available in the font, we can run ttf2afm without encoding to get all glyph names. The resulting afm le can be used to generate a tfm one by applying afm2tfm. To use a new TrueType font the minimal steps may look like below. We suppose that test.map is used.
ttf2afm -e 8r.enc -o times.afm times.ttf afm2tfm times.afm -T 8r.enc echo "times TimesNewRomanPSMT <8r.enc <times.ttf" >>test.map
There are a few limitations with TrueType fonts in comparison with Type 1 fonts: a. The special effects SlantFont/ExtendFont cannot be used. b. To subset a TrueType font, the font must be specied as re--encoded, therefore an encoding vector must be given. c. TrueType fonts coming with embedded pdf les are kept untouched; they are not replaced by local ones.
Integer registers
\pdfoutput (integer) \pdfminorversion (integer) \pdfcompresslevel (integer) \pdfobjcompresslevel (integer) \pdfdecimaldigits (integer)
content The pdfTEX user manual exit
\pdfimageresolution (integer) \pdfpkresolution (integer) \pdftracingfonts (integer) \pdfuniqueresname (integer) \pdfadjustspacing (integer) \pdfprotrudechars (integer) \efcode font 8-bit number (integer) \lpcode font 8-bit number (integer) \rpcode font 8-bit number (integer) \pdfforcepagebox (integer) \pdfoptionalwaysusepdfpagebox (integer) \pdfinclusionerrorlevel (integer) \pdfoptionpdfinclusionerrorlevel (integer) \pdfimagehicolor (integer) \pdfimageapplygamma (integer) \pdfgamma (integer) \pdfimagegamma (integer) \pdfdraftmode (integer)
Dimen registers
\pdfhorigin (dimen) \pdfvorigin (dimen) \pdfpagewidth (dimen) \pdfpageheight (dimen) \pdflinkmargin (dimen) \pdfdestmargin (dimen) \pdfthreadmargin (dimen) \pdfpxdimen (dimen)
content The pdfTEX user manual exit
Token registers
\pdfpagesattr (tokens) \pdfpageattr (tokens) \pdfpageresources (tokens) \pdfpkmode (tokens)
Expandable commands
\pdftexrevision (expandable) \pdftexbanner (expandable) \pdfcreationdate (expandable) \pdfpageref page number (expandable) \pdfxformname object number (expandable) \pdffontname font (expandable) \pdffontobjnum font (expandable) \pdffontsize font (expandable) \pdfincludechars font general text (expandable) \leftmarginkern box number (expandable) \rightmarginkern box number (expandable) \pdfescapestring general text (expandable) \pdfescapename general text (expandable) \pdfescapehex general text (expandable) \pdfunescapehex general text (expandable) \ifpdfprimitive control sequence (expandable) \ifpdfabsnum number (expandable) \ifpdfabsdim dimen (expandable) \pdfuniformdeviate number (expandable) \pdfnormaldeviate (expandable)
content The pdfTEX user manual exit
\pdfmdfivesum [le] general text (expandable) \pdffilemoddate general text (expandable) \pdffilesize general text (expandable) \pdffiledump [offset number ] [length number ] general text (expandable) \pdfcolorstackinit [page] [direct] general text (expandable)
Read--only integers
\pdftexversion (read--only integer) \pdflastobj (read--only integer) \pdflastxform (read--only integer) \pdflastximage (read--only integer) \pdflastximagepages (read--only integer) \pdflastannot (read--only integer) \pdflastlink (read--only integer) \pdflastxpos (read--only integer) \pdflastypos (read--only integer) \pdflastdemerits (read--only integer) \pdfelapsedtime (read--only integer) \pdfrandomseed (read--only integer) \pdfshellescape (read--only integer)
General commands
\pdfobj object type spec (h, v, m) \pdfrefobj object number (h, v, m) \pdfxform [ xform attr spec ] box number (h, v, m) \pdfrefxform object number (h, v, m)
content The pdfTEX user manual exit
\pdfximage [ image attr spec ] general text (h, v, m) \pdfrefximage object number (h, v, m) \pdfannot annot type spec (h, v, m) \pdfstartlink [ rule spec ] [ attr spec ] action spec (h, m) \pdfendlink (h, m) \pdfoutline outline spec (h, v, m) \pdfdest dest spec (h, v, m) \pdfthread thread spec (h, v, m) \pdfstartthread thread spec (v, m) \pdfendthread (v, m) \pdfsavepos (h, v, m) \pdfinfo general text \pdfcatalog general text [ open-action spec ] \pdfnames general text \pdfmapfile map spec \pdfmapline map spec \pdffontattr font general text \pdftrailer general text \pdffontexpand font expand spec \vadjust [ pre spec ] ller { vertical mode material } (h, m) \quitvmode \pdfliteral [ pditeral spec ] general text (h, v, m) \special pdfspecial spec \pdfresettimer \pdfsetrandomseed number \pdfnoligatures font \pdfprimitive control sequence \pdfcolorstack stack number stack action general text \pdfsetmatrix
content The pdfTEX user manual exit
\pdfsave \pdfrestore
pdf box spec mediabox | cropbox | bleedbox | trimbox | artbox map spec { [ map modier ] balanced text } map modier + | = | numid num number nameid name general text newwindow spec newwindow | nonewwindow dest spec numid dest type | nameid dest type dest type xyz [ zoom number ] | fitr rule spec | fitbh | fitbv | fitb | fith | fitv | fit thread spec [ rule spec ] [ attr spec ] id spec id spec numid | nameid le spec file general text page spec page number expand spec stretch shrink step [ autoexpand ] stretch number shrink number step number pre spec pre pditeral spec direct | page pdfspecial spec { [ pdfspecial id [ pdfspecial modier ] ] balanced text } pdfspecial id pdf: | PDF: pdfspecial modier direct: stack action set | push | pop | current A general text is expanded immediately, like \special in traditional TEX, unless explicitly mentioned otherwise. Some of the object and image related primitives can be prexed by \immediate. More about that in the next sections.
content
exit
7 PDFTEX primitives
Here follows a short description of the primitives added by pdfTEX to the original TEX engine (other extensions by MLTEX and encTEX are not listed). One way to learn more about how to use these new primitives is to have a look at the le samplepdf.tex in the pdfTEX distribution. Note that if the output is dvi then the pdfTEX specic dimension parameters are not used at all. However some pdfTEX integer parameters can affect the dvi as well as pdf output (currently \pdfoutput and \pdfadjustspacing). General warning: many of these new primitives, for example \pdfdest and \pdfoutline, write their arguments directly to the pdf output le (when producing pdf), as pdf string constants. This means that you (or, more likely, the macros you write) must escape characters as necessary (namely \, (, and ). Otherwise, an invalid pdf le may result. The hyperref and Texinfo packages have code which may serve as a starting point for implementing this, although it will certainly need to be adapted to any particular situation.
\ifx\pdfoutput\undefined \csname newcount\endcsname\pdfoutput \fi \ifcase\pdfoutput DVI CODE \else PDF CODE \fi
content
exit
A Using the ifpdf.sty le, which works with both L TEX and plain TEX, is a cleaner way of doing this. Historically, the simple test \ifx\pdfoutput\undefined was dened; but nowadays, the pdfTEX engine is used in distributions also A for non-pdf formats (e. g. L TEX), so \pdfoutput may be dened even when the output format is dvi.
\pdfminorversion (integer)
This primitive sets the pdf version of the generated le and the latest allowed pdf version of included pdfs. E. g., \pdfminorversion=3 tells pdfTEX to set the pdf version to 1.3 and allows only included pdf les with versions numbers up to 1.3. The default for \pdfminorversion is 4, producing les with pdf version 1.4. If specied, this primitive must appear before any data is to be written to the generated pdf le, so you should put it at the very start of your les. The command has been introduced in pdfTEX 1.30.0 as a shortened synonym of \pdfoptionpdfminorversion command, that is obsolete by now.
\pdfcompresslevel (integer)
This integer parameter species the level of stream compression (text, in--line graphics, and embedded png images (only if they are un- and re--compressed during the embedding process); all done by the zlib library). Zero means no compression, 1 means fastest, 9 means best, 2..8 means something in between. A value outside this range will be adjusted to the nearest meaningful value. This parameter is read each time pdfTEX starts a stream. Setting \pdfcompresslevel=0 is great for pdf stream debugging.
\pdfobjcompresslevel (integer)
This integer parameter controls the compression of non-stream objects. In the pdf-1.4 specication these objects still had to go into the pdf le as clear text, uncompressed. The pdf-1.5 specication now allows to collect non-stream objects as compressed objects into object stream objects (/Type /ObjStm, see pdf Ref. 5th ed., sect. 3.4.6). At the pdf le end instead of the object table then an /XRef cross-reference stream is written out. This results in considerably smaller pdf les, particularly if lots of annotations and links are used. The primitive has been introduced in pdfTEX 1.40.0. The writing of compressed objects is enabled by setting \pdfobjcompresslevel to a value between 1 and 3; its disabled by value 0 (default). Enabling requires that also \pdfminorversion > 4. If \pdfobjcompresslevel > 0, but \pdfminorversion < 5, a warning is given and object stream writing is disabled. The \pdfobjcompresslevel value is clipped to the range 0..3. Using values outside this range is not recommended (for future extension). content The pdfTEX user manual exit
The \pdfobjcompresslevel settings have the following effects: When set to 0, no object streams are generated at all. When set to 1, all non-stream objects are compressed with the exception of any objects coming with embedded pdf les (paranoid mode, to avoid yet unknown problems), and also the /Info dictionary is not compressed for clear-text legibility. When set to 2, also all non-stream objects coming with embedded pdf les are compressed, but the /Info dictionary is still not compressed. Finally, when set to 3, all non-stream objects are compressed, including the /Info dictionary (this means that the /Info cant be read as clear text any more). If object streams are to be used, currently \pdfobjcompresslevel=2 is recommended, Caveat: pdf les generated with object streams enabled cant be read with (old) pdf viewers that dont understand pdf-1.5 les. For widest distribution and unknown audience, dont activate object stream writing. The pdf-1.5 standard describes also a hybrid object compression mode that gives some backward compatibility, but this is currently not implemented, as pdf-1.5 seems to be rather quickly adopted by modern pdf viewers. Also not implemented is the optional /Extends key.
\pdfdecimaldigits (integer)
This integer parameter species the numeric accuracy of real coordinates as written to the pdf le. It gives the maximal number of decimal digits after the decimal point. Valid values are in range 0..4. A higher value means more precise output, but also results in a larger le size and more time to display or print. In most cases the optimal value is 2. This parameter does not inuence the precision of numbers used in raw pdf code, like that used in \pdfliteral and annotation action specications; also multiplication items (e. g. scaling factors) are not affected and are always output with best precision. This parameter is read when pdfTEX writes a real number to the pdf output. When including huge METAPOST images using supp-pdf.tex, one can limit the accuracy to two digits by typing: \twodigitMPoutput.
\pdfhorigin (dimension)
This parameter can be used to set the horizontal offset the output box from the top left corner of the page. A value of 1 inch corresponds to the normal TEX offset. This parameter is read when pdfTEX starts shipping out a page to the pdf output. For standard purposes, this parameter should always be kept at 1 true inch. If you want to shift text on the page, use TEXs own \hoffset primitive. To avoid surprises, after global magnication has been changed by the \mag primitive, content The pdfTEX user manual exit
the \pdfhorigin parameter should still be 1 true inch, e. g. by typing \pdfhorigin=1 true in after issuing the \mag command. Or, you can preadjust the \pdfhorigin value before typing \mag, so that its value after the \mag command ends up at 1 true inch again.
\pdfvorigin (dimension)
This parameter is the vertical companion of \pdfhorigin, and the notes above regarding \mag and true dimensions apply. Also keep in mind that the TEX coordinate system starts in the top left corner (downward), while pdf coordinates start at the bottom left corner (upward).
\pdfpagewidth (dimension)
This dimension parameter species the page width of the pdf output (the screen, the paper, etc.). pdfTEX reads this parameter when it starts shipping out a page. After magnication has been changed by the \mag primitive, check that this parameter reects the wished true page width. If the value is set to zero, the page width is calculated as wbox being shipped out + 2 (horigin + \hoffset). When part of the page falls off the paper or screen, you can be rather sure that this parameter is set wrong.
\pdfpageheight (dimension)
Similar to the previous item, this dimension parameter species the page height of the pdf output. If set to zero, the page height will be calculated analogously to the above. After magnication has been changed by the \mag primitive, check that this parameter reects the wished true page height.
content
exit
(defaults to current date including time zone info), /ModDate, /Creator (defaults to TeX), /Producer (defaults to pdfTeX-1.40.0), /Title, /Subject, and /Keywords.
/CreationDate and /ModDate are expressed in the form D:YYYYMMDDhhmmssTZ.., where YYYY is the year, MM is the month, DD is the day, hh is the hour, mm is the minutes, ss is the seconds, and TZ.. is an optional string denoting the
time zone. An example of this format is shown below. For details please refer to the PDF Reference. Multiple appearances of \pdfinfo will be concatenated. In general, if a key is given more than once, one may expect that the rst appearance will be used. Be aware however, that this behaviour is viewer dependent. Except expansion, pdfTEX does not perform any further operations on general text provided by the user. An example of the use of \pdfinfo is:
(example.pdf) (TeX) (pdfTeX 1.40.0) (Tom and Jerry) (D:20061226154343+0100) (D:20061226155343+0100) (Example) (mouse, cat) }
value
meaning neither outline nor thumbnails visible outline visible thumbnails visible full--screen mode Supported /PageMode values.
7.3 Fonts
\pdfpkresolution (integer)
This integer parameter species the default resolution of embedded pk fonts and is read when pdfTEX embeds a pk font during nishing the pdf output. As bitmap fonts are still rendered poorly by some pdf viewers, it is best to use Type 1 fonts when available.
\pdffontexpand font
stretch
shrink
step [ autoexpand ]
This extension to TEXs font denitions controls a pdfTEX automatism called font expansion. We describe this by an example:
The 30 20 10 means this: hey TEX, when line breaking is going badly, you may stretch the glyphs from this font as much as 3 % or shrink them as much as 2 %. For practical reasons pdfTEX uses discrete expansion steps, in this example, 1 %. Roughly spoken, the trick is as follows. Consider a text typeset in triple column mode. When TEX cannot break a line in the appropriate way, the unbreakable parts of the word will stick into the margin. When pdfTEX notes this, it will try to scale (shrink) the glyphs in that line using xed steps, until the line ts. When lines are too spacy, the opposite happens: pdfTEX starts scaling (stretching) the glyphs until the white space gaps is acceptable. This glyph stretching and shrinking is called font expansion. To enable font expansion, dont forget to set \pdfadjustspacing to a value greater than zero. There are two different modes for font expansion: First, if the autoexpand option is there which is the recommended mode only a single map entry is needed for all expanded font versions, using the name of the unexpanded tfm le (tfmname). No expanded tfmname versions need to mentioned (they are ignored), as pdfTEX generates expanded copies of the unexpanded tfm data structures and keeps them in its memory. Since pdfTEX 1.40.0 the autoexpand mode happens within the page stream by modication of the text matrix (pdf operator Tm), and not anymore on font le level, giving the advantage that it now works not only with Type1 but also with TrueType and OpenType fonts (and even without embedding a font le; but thats not recommended). In this mode pdfTEX requires only unexpanded font les. Second, if the autoexpand option is missing, setting up font expansion gets more tedious, as there must be map entries for tfm les in all required expansion values. The expanded tfmname variants are constructed by adding the font expansion value to the tfmname of the base font, e. g. there must be a map entry with tfmname sometfm+10 for 1 % stretch or sometfm-15 for 1.5 % shrink. This also means, that for each expanded font variant a tfm le with properly expanded metrics must exist. Having several map entries for the various expansion values of a font requires to provide for each expansion value an individually crafted font le with expanded glyphs. Depending on how these glyphs are generated, this might give slightly better glyph forms than the rather simple glyph stretching used in autoexpand mode. The drawback is that several font les will be embedded in the pdf output for each expanded font, leading to signicantly larger pdf les than in autoexpand mode. For moderate expansion values going without autoexpand mode is not worth the trouble. The font expansion mechanism is inspired by an optimization rst introduced by Prof. Hermann Zapf, which in itself goes back to optimizations used in the early days of typesetting: use different glyphs to optimize the grayness of a page. content The pdfTEX user manual exit
So, there are many, slightly different as, es, etc. For practical reasons pdfTEX does not use such huge glyph collections; it uses horizontal scaling instead. This is sub--optimal, and for many fonts, possibly offensive to the design. But, when using pdf, its not illogical: pdf viewers use so--called Multiple Master fonts when no fonts are embedded and/or can be found on the target system. Such fonts are designed to adapt their design to the different scaling parameters. It is up to the user to determine to what extent mixing slightly remastered fonts can be used without violating the design. Think of an O: when geometrically stretched, the vertical part of the glyph becomes thicker, and looks incompatible with an unscaled original. With a Multiple Master situation, one can stretch while keeping this thickness compatible.
\pdfadjustspacing (integer)
This primitive provides a switch for enabling font expansion. By default, \pdfadjustspacing is set to 0; then font expansion is disabled, so that the pdfTEX output is identical to that from the original TEX engine. Font expansion can be activated in two modes. When \pdfadjustspacing is set to 1, font expansion is applied after TEXs normal paragraph breaking routines have broken the paragraph into lines. In this case, line breaks are identical to standard TEX behaviour. When set to 2, the width changes that are the result of stretching and shrinking are taken into account while the paragraph is broken into lines. In this case, line breaks are likely to be different from those of standard TEX. In fact, paragraphs may even become longer or shorter. Both alternatives require a collection of tfm les that are related to the stretch and shrink settings for the \pdffontexpand primitive, unless this is given with the autoexpand option.
\efcode\somefontA=800 \efcode\somefontO=0
content The pdfTEX user manual exit
Here an A may stretch or shrink only by 80 % of the current expansion value for that font, and expansion for the O is disabled. The actual expansion is still bound to the steps as dened by \pdffontexpand primitive, otherwise one would end up with more possible font inclusions than would be comfortable.
\pdfprotrudechars (integer)
Yet another way of optimizing paragraph breaking is to let certain characters move into the margin (character protrusion). When \pdfprotrudechars=1, the glyphs qualied as such will make this move when applicable, without changing the line-breaking. When \pdfprotrudechars=2 (or greater), character protrusion will be taken into account while considering breakpoints, so line-breaking might be changed. This qualication and the amount of shift are set by the primitives \rpcode and \lpcode. Character protrusion is disabled when \pdfprotrudechars=0 (or negative). If you want to protrude some item other than a character (e. g. a \hbox), you can do so by padding the item with an invisible zero--width character, for which protrusion is activated.
\rpcode\somefont,=200 \rpcode\somefont-=150
Here the comma may shift by 0.2 em into the margin and the hyphen by 0.15 em. All these small bits and pieces will help pdfTEX to give you better paragraphs (use \rpcode judiciously; dont overdo it). Remark: old versions of pdfTEX use the character width as measure. This was changed to a proportion of the em-width after Hn Th Thnh nished his masters thesis.
\pdffontattr font
general text
This primitive inserts the general text to the /Font dictionary. The text must conform to the specications as laid down in the PDF Reference, otherwise the document can be invalid.
content
exit
\pdfincludechars font
general text
This command causes pdfTEX to treat the characters in general text as if they were used with font , which means that the corresponding glyphs will be embedded into the font resources in the pdf output. Nothing is appended to the list being built.
\pdfuniqueresname (integer)
When this primitive is assigned a positive number, pdf resource names will be made reasonably unique by appending a random string consisting of six ascii characters.
default map le pdftex.map will be read by pdfTEX. There is a companion primitive \pdfmapline that allows to scan single map lines; its map line argument has the same syntax as the map lines from a map le. Both primitives can be used concurrently. The \pdfmapfile primitive is fast for reading external bulk font map information (many map lines collected in a map le), whereas the \pdfmapline allows to put the font map information for individual TEX fonts right into the TEX source or a style le. In any case the map line information is scanned by pdfTEX, and in the most common case the data are put into a fresh internal map entry data structure, which is then consulted once a font is called. Normally there is no need for the pdfTEX user to bother about the \pdfmapfile or \pdfmapline primitives, as the main TEX distributions provide nice helper tools that automatically assemble the default font map le. Prominent tool examples are the scripts updmap and updmap-sys coming with TEX Live and teTEX. If your map le isnt in the current directory (or a standard system directory), you will need to set the TEXFONTMAPS variable (in Web2c) or give an explicit path so that it will be found. When the \pdfmapfile or \pdfmapline primitive is read by pdfTEX, the argument (map le or map line) will be processed immediately, and the internal map entry database is updated. The operation mode of the \pdfmapfile and \pdfmapline primitives is selected by an optional modier character (+, =, -) in front of the tfmname eld. This modier denes how the individual map lines are going to be handled, and how a collision between an already registered map entry and a newer one is resolved; either ignoring a later entry, or replacing or deleting an existing entry. But in any case, map entries of fonts already in use are kept untouched. Here are two examples:
blocking cases. This should be mostly compatible with the traditional behaviour. If you want to add support for a new font through an additional font map le while keeping all the existing mappings, dont use the primitive versions without modier, but instead type either \pdfmapfile{+myfont.map} or \pdfmapfile{=myfont.map}, as described below.
\pdfmapfile {+foo.map} reads the le foo.map; duplicate later map entries within the le are ignored and a warning
is issued.
\pdfmapfile {=foo.map} reads the le foo.map; matching map entries in the database are replaced by new entries from foo.map (if they arent already in use). \pdfmapfile {-foo.map} reads the le foo.map; matching map entries are deleted from the database (if not yet in
use). If you want to use a base map le name other than pdftex.map, or change its processing options through a pdfTEX format, you can do this by appending the \pdfmapfile command to the \everyjob{} token list for the -ini run, e. g.:
\everyjob\expandafter{\the\everyjob\pdfmapfile{+myspecial.map}} \dump
This would always read the le myspecial.map after the default pdftex.map le.
\pdfmapline {} like \pdfmapfile {} blocks reading of the default map le, if it comes early enough in the TEX input.
The primitive has been introduced in pdfTEX 1.20a.
content
exit
\pdftracingfonts (integer)
This integer parameter species the level of verbosity for info about expanded fonts given in the log, e. g. when \tracingoutput=1. If \pdftracingfonts=0, which is the default, the log shows the actual non-zero signed expansion value for each expanded letter within brackets, e. g.:
...\xivtt (+20) t
If \pdftracingfonts=1, also the name of the tfm le is listed, together with the font size, e. g.:
...\xivtt ([email protected]) t
Setting \pdftracingfonts to a value other than 0 or 1 is not recommended, to allow future extensions. The primitive has been introduced in pdfTEX 1.30.0.
\pdfmovechars (integer)
Since pdfTEX version 1.30.0 the primitive \pdfmovechars is obsolete, and its use merely leads to a warning. (This primitive specied whether pdfTEX should try to move characters in range 0..31 to higher slots; its sole purpose was to remedy certain bugs of early pdf viewers.)
\pdfpkmode (tokens)
The \pdfpkmode is a token register that sets the METAFONT mode for pixel font generation. The contents of this register is dumped into the format, so one can (optionally) preset it e. g. in pdftexconfig.tex. The primitive has been introduced in pdfTEX 1.30.0.
\pdfnoligatures font
This diables all ligatures in the loaded font font . The primitive has been introduced in pdfTEX 1.30.0.
When however object type spec is given as attr spec stream , the object will be created as a stream with contents general text and additional attributes in attr spec . When object type spec is given as attr spec file , then the general text will be treated as a le name and its contents will be copied into the stream contents. When object type spec is given as reserveobjnum, just a new object number is reserved. The number of the reserved object is accessible via \pdflastobj. The object can later be lled with contents by \pdfobj useobjnum number { balanced text }. But the reserved object number can already be be used before by other objects, which provides a forward--referencing mechanism. The object is kept in memory and will be written to the pdf output only when its number is referred to by \pdfrefobj or when \pdfobj is preceded by \immediate. Nothing is appended to the list being built. The number of the most recently created object is accessible via \pdflastobj.
content
exit
% rotate all pages by 90 degrees % the crop size of all pages (in bp)
This is similar to \pdfpagesattr, but has priority over it. It can be used to override any attribute given by \pdfpagesattr for individual pages. The token list is expanded when pdfTEX ships out a page. The contents are added to the attributes of the current page.
a separate layer, are positioned absolutely, and have dedicated housekeeping. \pdfxform makes the box void, as \box does. When attr spec is given, the text will be written as additional attribute into the form XObject dictionary. The resources spec is similar, but the text will be added to the resources dictionary of the form XObject. The text given by attr spec or resources spec is written before other entries of the form dictionary and/or the resources dictionary and takes priority over later ones.
\pdfximage [ rule spec ] [ attr spec ] [ page spec ] [ colorspace spec ] [ pdf box spec ] general text
This command creates an image object. The dimensions of the image can be controlled via rule spec . The default values are zero for depth and running for height and width. If all of them are given, the image will be scaled to t the specied values. If some (but not all) are given, the rest will be set to a value corresponding to the remaining ones so as to make the image size to yield the same proportion of width : (height + depth) as the original image size, where depth is treated as zero. If none are given then the image will take its natural size. An image inserted at its natural size often has a resolution of \pdfimageresolution (see below) given in dots per inch in the output le, but some images may contain data specifying the image resolution, and in such a case the image will be scaled to the correct resolution. The dimensions of an image can be accessed by enclosing the \pdfrefximage command to a box and checking the dimensions of the box:
\setbox0=\hbox{\pdfximage{somefile.png}\pdfrefximage\pdflastximage}
Now we can use \wd0 and \ht0 to question the natural size of the image as determined by pdfTEX. When dimensions are specied before the {somefile.png}, the graphic is scaled to t these. Note that, unlike the e. g. \input primitive, the lename is supplied between braces. The image type is specied by the extension of the given le name: .png stands for png image, .jpg (or .jpeg) for jpeg, .jbig2 (preferred, but .jb2 works also) for jbig2, and .pdf for pdf le. But once pdfTEX has opened the le, it checks the le type rst by looking to the magic number at the le start, which gets precedence over the le name extension. This gives a certain degree of fault tolerance, if the le name extension is stated wrongly. Similarly to \pdfxform, the optional text given by attr spec will be written as additional attributes of the image before other keys of the image dictionary. One should be aware, that slightly different type of pdf object is created while including png, jpeg, or jbig2 bitmaps and pdf images. While working with pdf or jbig2 images, page spec allows to decide which page of the document is to be included; the page spec is irrelevant for the other two image formats. Starting from pdfTEX 1.11 one may also decide in the pdf image case, which page box of the image is to be treated as a nal bounding box. If pdf box spec is present, it overrides the default behaviour specied by the \pdfforcepagebox parameter. This option is irrelevant for non--pdf inclusions.
content
exit
Starting from pdfTEX 1.21, \pdfximage command supports colorspace keyword followed by an object number (user-dened colorspace for the image being included). This feature works for jpeg images only. pngs are rgb palettes, jbig2 s are bitonal, and pdf images have always self--contained color space information.
\pdfrefximage integer
The image is kept in memory and will be written to the pdf output only when its number is referred to by \pdfrefximage or \pdfximage is preceded by \immediate. Nothing is appended to the list being built.
\pdfrefximage appends a whatsit node to the list being built. When the whatsit node is searched at shipout time,
pdfTEX will write the image with number integer to the pdf output if it has not been written yet. \pdflastximage (read--only integer) The number of the most recently created XObject image is accessible via \pdflastximage.
\pdfimageresolution (integer)
The integer \pdfimageresolution parameter (unit: dots per inch, dpi) is a last resort value, used only for bitmap (jpeg, png, jbig2) images, but not for pdfs. The priorities are as follows: Often one image dimension (width or height) is stated explicitely in the TEX le. Then the image is properly scaled so that the aspect ratio is kept. If both image dimensions are given, the image will be stretched accordingly, whereby the aspect ratio might get distorted. Only if no image dimension is given in the TEX le, the image size will be calculated from its width and height in pixels, using the x and y resolution values normally contained in the image le. If one of these resolution values is missing or weird (either < 0 or > 65535), the \pdfimageresolution value will be used for both x and y resolution, when calculating the image size. And if the \pdfimageresolution is zero, nally a default resolution of 72 dpi would be taken. The \pdfimageresolution is read when pdfTEX creates an image via \pdfximage. The given value is clipped to the range 0..65535 [dpi]. Currently this parameter is used particularily for calculating the dimensions of jpeg images in exif format (unless at least one dimension is stated explicitely); the resolution values coming with exif les are currently ignored. content The pdfTEX user manual exit
\pdfforcepagebox (integer)
When pdf les are included, the command \pdfximage allows the selection of which pdf page box to use in the optional eld image attr spec . The integer primitive \pdfforcepagebox allows to globally override this choice by giving them one of the following values: (1) media box, (2) crop box, (3) bleed box, (4) trim box, and (5) artbox. The command is available starting from pdfTEX 1.30.0, as a shortened synonym of obsolete \pdfoptionalwaysusepdfpagebox instruction.
\pdfinclusionerrorlevel (integer)
This controls the behaviour of pdfTEX when a pdf le is included that has a newer version than the one specied by this primitive: If it is set to 0, pdfTEX gives only a warning; if its 1, pdfTEX raises an error. The command has been introduced in pdfTEX 1.30.0 as a shortened synonym of \pdfoptionpdfinclusionerrorlevel, that is now obsolete.
\pdfimagehicolor (integer)
This primitive, when set to 1, enables embedding of png images with 16 bit wide color channels at their full color resolution. As such an embedding mode is dened only from pdf version 1.5 onwards, the \pdfimagehicolor functionality is automatically disabled in pdfTEX if \pdfminorversion < 5; then each 16 bit color channel is reduced to a width of 8 bit by stripping the lower 8 bits before embedding. The same stripping happens when \pdfimagehicolor is set to 0. For \pdfminorversion 5 the default value of \pdfimagehicolor is 1. If specied, the parameter must appear before any data is written to the pdf output. The primitive has been introduced in pdfTEX 1.30.0.
\pdfimageapplygamma (integer)
This primitive, when set to 1, enables gamma correction while embedding png images, taking the values of the primitives \pdfgamma as well as the gamma value embedded in the png image into account. When \pdfimageapplygamma is set to 0, no gamma correction is performed. If specied, the parameter must appear before any data is written to the pdf output. The primitive has been introduced in pdfTEX 1.30.0.
\pdfgamma (integer)
This primitive denes the device gamma for pdfTEX. Values are in promilles (same as for \mag). The default value of this primitive is 1000, dening a device gamma value of 1.0. content The pdfTEX user manual exit
When \pdfimageapplygamma is set to 1, then whenever a png image is included, pdfTEX applies a gamma correction. This correction is based on the value of the \pdfgamma primitive and the assumed device gamma that is derived from the value embedded in the actual image. If no embedded value can be found in the png image, then the value of \pdfimagegamma is used instead. If specied, the parameter must appear before any data is written to the pdf output. The primitive has been introduced in pdfTEX 1.30.0.
\pdfimagegamma (integer)
This primitive gives a default assumed gamma value for png images. Values are in promilles (same as for \pdfamma). The default value of this primitive is 2200, implying an assumed gamma value of 2.2. When pdfTEX is applying gamma corrections, images that do not have an embedded assumed gamma value are assumed to have been created for a device with a gamma of 2.2. Experiments show that this default setting is correct for a large number of images; however, if your images come out too dark, you probably want to set \pdfimagegamma to a lower value, like 1000. If specied, the parameter must appear before any data is written to the pdf output. The primitive has been introduced in pdfTEX 1.30.0.
\pdfpxdimen (dimen)
While working with bitmap graphics or typesetting electronic documents, it might be convenient to base dimensions on pixels rather than TEXs standard units like pt or em. For this purpose, pdfTEX provides an extra unit called px that takes the dimension given to the \pdfpxdimen primitive. In example, to make the unit px corresponding to 96 dpi pixel density (then 1 px = 72/96 bp), one can do the following calculation:
7.8 Annotations
pdf 1.4 provides four basic kinds of annotations: hyperlinks, general navigation text clips (notes) movies sound fragments
The rst type differs from the other three in that there is a designated area involved on which one can click, or when moved over some action occurs. pdfTEX is able to calculate this area, as we will see later. All annotations can be supported using the next two general annotation primitives.
content
exit
Additional attributes, which are explained in great detail in the PDF Reference, can be given via attr spec . Typically, the attributes specify the color and thickness of any border around the link. Thus /C [0.9 0 0] /Border [0 0 2] species a color (in rgb) of dark red, and a border thickness of 2 points. While all graphics and text in a pdf document have relative positions, annotations have internally hard--coded absolute positions. Again this is for the sake of speed optimization. The main disadvantage is that these annotations do not obey transformations issued by \pdfliterals. The action spec species the action that should be performed when the hyperlink is activated while the useraction spec performs a user--dened action. A typical use of the latter is to specify a url, like /S /URI /URI (http://www.tug.org/), or a named action like /S /Named /N /NextPage. A goto-action spec performs a GoTo action. Here numid and nameid specify the destination identier (see below). The page spec species the page number of the destination, in this case the zoom factor is given by general text . A destination can be performed in another pdf le by specifying le spec , in which case newwindow spec species whether the le should be opened in a new window. A le spec can be either a (string) or a dictionary. The default behaviour of the newwindow spec depends on the browser setting. A thread-action spec performs an article thread reading. The thread identier is similar to the destination identier. A thread can be performed in another pdf le by specifying a le spec .
\pdfendlink
This primitive ends a link started with \pdfstartlink. All text between \pdfstartlink and \pdfendlink will be treated as part of this link. pdfTEX may break the result across lines (or pages), in which case it will make several links with the same content.
\pdflinkmargin (dimension)
This dimension parameter species the margin of the box representing a hyperlink and is read when a page containing hyperlinks is shipped out. content The pdfTEX user manual exit
\pdfdestmargin (dimension)
Margin added to the dimensions of the rectangle around the destinations.
7.10 Bookmarks
\pdfoutline [ attr spec ] action spec [ count integer ] general text
This primitive creates an outline (or bookmark) entry. The rst parameter species the action to be taken, and is the same as that allowed for \pdfstartlink. The count species the number of direct subentries under this entry; specify 0 or omit it if this entry has no subentries. If the number is negative, then all subentries will be closed and the absolute value of this number species the number of subentries. The text is what will be shown in the outline window. Note that this is limited to characters in the pdf Document Encoding vector. The outline is written to the pdf output immediately.
\pdfendthread
This ends an article thread started before by \pdfstartthread. content The pdfTEX user manual exit
\pdfthreadmargin (dimension)
Species a margin to be added to the dimensions of a bead within an article thread.
content
exit
7.13 Strings
\pdfescapestring general text
Starting from version 1.30.0, pdfTEX provides a mechanism for converting a general text into pdf string. Many characters that may be needed inside such a text (especially parenthesis), have a special meaning inside a pdf string object and thus, cant be used literally. The primitive replaces each special pdf character by its literal representation by inserting a backslash before that character. Some characters (e. g. space) are also converted into 3--digit octal number. In example, \pdfescapestring{Text (1)} will be expanded to Text\040\(1\). This ensures a literal interpretation of the text by the pdf viewer. The primitive has been introduced in pdfTEX 1.30.0.
content
exit
7.14 Numbers
\ifpdfabsnum number
The primitive works as normal \ifnum condition check, except that it compares absolute values of numbers. Although it seems to be a trivial shortcut for a couple of \ifnum x<0 tests, as a primitive it is more friendly in usage and works a bit faster. The primitive has been introduced in pdfTEX 1.40.0.
\ifpdfabsdim dimen
Like \ifpdfabsnum, the primitive works as normal \ifdim condition check, except that it compares absolute values of dimensions. The primitive has been introduced in pdfTEX 1.40.0.
\pdfnormaldeviate (expandable)
The commands generates a random integer value with a mean of 0 and a unit of 65 536, e. g. 463. This primitive expands to a list of tokens. The primitive has been introduced in pdfTEX 1.30.0.
\pdfsetrandomseed number
This sets the random seed (\pdfrandomseed) to a specic value, allowing you to re-play sequences of semi-randoms at a later moment. The primitive has been introduced in pdfTEX 1.30.0.
content
exit
7.15 Timekeeping
\pdfelapsedtime (read--only integer)
The command expands to a number that represents the time elapsed from the moment of run start. The elapsed time is returned in scaled seconds, that means seconds divided by 65536, e. g. pdfTEX has run for 964856 scaled seconds when this paragraph was typeset. Obviously, the command will never return a value greater than the highest number available in TEX: if the time exceeds 32767 seconds, the constant value 231 1 will be returned. The primitive has been introduced in pdfTEX 1.30.0.
\pdfresettimer
The command resets the internal timer so that \pdfelapsedtime starts returning micro--time from 0 again. The primitive has been introduced in pdfTEX 1.30.0.
7.16 Files
\pdffilemoddate general text (expandable)
Expands to the modication date of le general text in the same format as for \pdfcreationdate, e. g. its D:20070101165908+0100 for the source of this manual. The primitive has been introduced in pdfTEX 1.30.0.
content
exit
7.17 Colourstack
\pdfcolorstackinit [page] [direct] general text (expandable)
The primitive has been introduced in pdfTEX 1.40.0.
stack action
general text
The primitive has been introduced in pdfTEX 1.40.0. The primitive has been introduced in pdfTEX 1.40.0.
\pdfsave
The primitive has been introduced in pdfTEX 1.40.0.
\pdfrestore
The primitive has been introduced in pdfTEX 1.40.0.
7.18 Miscellaneous
\vadjust [ pre spec ] ller { vertical mode material }
The \vadjust implementation of pdfTEX adds an optional qualier pre spec (which is the string pre) to the original TEX primitive with the same name. As long as there is no pre given, \vadjust behaves exactly as the original (see the TEXbook, p. 281); it appends an adjustment item created from vertical mode material to the current list after the content The pdfTEX user manual exit
line in which \vadjust appears. However with the qualier pre, the adjustment item is put before the line in which \vadjust pre appears.
\quitvmode
The primitive instructs pdfTEX to quit the vertical mode and start typesetting a paragraph. \quitvmode has the same effect as \leavevmode denition from plain macro package. Note however, that \leavevmode may conict with \everypar tokens list. No such risk while using \quitvmode instead. The primitive has been introduced in pdfTEX 1.21a.
\pdfsavepos
This primitive marks the current absolute (x, y) position on the media, with the reference point in the lower left corner. It is active only during page shipout, when the page is nally assembled. The position coordinates can then be retrieved by the \pdflastxpos and \pdflastypos primitives, and e. g. written out to some auxiliary le. The coordinates can be used only after the current \shipout has been nalized, therefore normally two pdfTEX runs are required to utilize these primitives. Starting with pdfTEX 1.40.0, this mechanism can be used also while running in dvi mode.
\pdftexrevision (expandable)
Returns the revision letter of pdfTEX, e. g. for pdfTEX version 1.40.0 used to produce this document, it returns the letter 0.
content
exit
\pdftexbanner (expandable)
Returns the pdfTEX banner message, e. g. for the version used here: This is pdfTeX, Version 3.141592-1.40.02.2 (Web2C 7.5.6) kpathsea version 3.5.6. The primitive has been introduced in pdfTEX 1.20a.
\pdfcreationdate (expandable)
Expands to the date string pdfTEX uses in the info dictionary of the document, e. g. for this le D:20070101174053+0100. The primitive has been introduced in pdfTEX 1.30.0.
\pdfdraftmode (integer)
When set to 1 (or switched on by the commandline switch -draftmode) pdfTEX doesnt write the output pdf and doesnt actually read any images but does everything else (including writing auxiliary les), thus speeding up compilations when you know you need an extra run but dont care about the output, e.g. just to get the bibTEX references right. The primitive has been introduced in pdfTEX 1.40.0.
content
exit
fast copying, as it requires calculations with individual pixels. Whether the fast copy mode is used for a png image can be seen from the log le, which then shows the string (PNG copy) after the png le name. The jpeg format is normally used in lossy mode; then its ideal for embedding photos; its not recommended for crisp images from synthetic sources with a limited amount of colors. The jbig2 format works only for bitonal (black and white) pixel images like scanned line and text documents, but for these it has typically a much higher compression ratio than the other two pixel image formats. The jbig2 format is part of the pdf standard since version 1.5; native jbig2 image inclusion is available in pdfTEX since version 1.40.0. A jbig2 le might contain many images, which gives an even better compression ratio than with a single image per le, as jbig2 encoders can exploit similarities between bit patterns over several images. Encoders for jbig2 can operate in lossy as well as lossless modes. Only recently a free jbig2 encoder has been written and made available, see http://www.imperialviolet.org/jbig2.html. Other options for graphics in pdfTEX are:
A L TEX picture mode Since this is implemented simply in terms of font characters, it works in exactly the same way as usual.
Xy--pic
If the PostScript back--end is not requested, Xy--pic uses its own Type 1 fonts, and needs no special attention.
tpic The tpic \special commands (used in some macro packages) can be redened to produce literal pdf, using some macros written by Hans Hagen. METAPOST Although the output of METAPOST is PostScript, it is in a highly simplied form, and a METAPOST to pdf conversion (mptopdf, written by Hans Hagen and Tanmoy Bhattacharya) is implemented as a set of macros which reads METAPOST output and supports all of its features. For new work, the METAPOST route is highly recommended. For the future, Adobe has announced that they will dene a specication for encapsulated pdf. The inclusion of raw PostScript commands a technique utilized by for instance the pstricks package cannot directly be supported. Although pdf is direct a descendant of PostScript, it lacks any programming language commands, and cannot deal with arbitrary PostScript. content The pdfTEX user manual exit
9 Character translation
Characters that are input to pdfTEX are subject to optional TEX character translation (tcx) under control of a tcx le. The tcx maps the input character codes (e. g. from \input or \read) to the character codes as seen by pdfTEX. This mapping takes place before the characters enter pdfTEXs mouth. If no tcx le is read, the input characters enter pdfTEX directly; no mapping is done. tcx les consist of lines each containing one or two integer numbers in the range 0..255, either in decimal or hex notation. A comment sign % in a tcx line starts a comment until the end of line. The rst number in each line is for matching the input character code, the second, optional number is the corresponding TEX character code. If a line contains only one number, characters with this code enter pdfTEX unchanged; no mapping is done. tcx mapping also inuences pdfTEX output streams for \message and \write. Without tcx mapping, only characters that are within the range 32..126 are agged as printable, meaning that these characters are output directly by \message and \write primitives. Characters outside the range 32..126 are instead output in escaped form, e. g. as ^^A for a character with code 0x01. When a character code is mentioned in the 2nd column of the tcx le, or as the only value in a line, it is agged as printable. During \message and \write, output characters are mapped in reverse direction: they are looked up in the 2nd column of the tcx le and the corresponding values from the 1st column are output. Again, if a pdfTEX character code is found as the only number in a line, no mapping is done. Mentioning a character code as the only number on a line has the sole purpose to ag this code printable; remember that character within the range 32..126 are printable anyway. The characters output into the pdf le, e. g. by \pdfliteral or \special primitives, are not subject to tcx output remapping. Beware: Character translation interferes with the encTEX primitives; to avoid surprises, dont use encTEX and tcx mapping at the same time. Further details about tcx le loading can be found in the teTEX manual.
Abbreviations
In this document we used a few abbreviations. For convenience we mention their meaning here.
content
exit
afm ascii bibTEX CMacTEX ConTEXt dvi encTEX eps epstopdf -TEX exif Ghostscript hz jbig jbig2 jpeg A L TEX Mac OS X md5 METAFONT METAPOST MikTeX MLTEX mptopdf MSDos pdf pdfeTEX pdfTEX Perl content
Adobe Font Metrics American Standard Code for Information Interchange Handles bibliographies Macintosh Web2c distribution general purpose macro package native TEX Device Independent le format encTEX extension to TEX Encapsulated PostScript eps to pdf conversion tool an extension to TEX Exchangeable Image File format (JPEG le variant) ps and pdf language interpreter Hermann Zapf optimization Joint Bi-level Image Experts Group Joint Bi-level Image Experts Group Joint Photographic Experts Group general purpose macro package Macintosh operating system version 10 MD5 message-digest algorithm graphic programming environment, bitmap output graphic programming environment, vector output Win32 distribution MLTEX extension to TEX METAPOST to pdf conversion tool Microsoft DOS platform (Intel) Portable Document Format -TEX extension producing pdf output TEX extension producing pdf output Perl programming environment The pdfTEX user manual exit
pgc pk png PostScript proTEXt PStoPDF rgb tcx tds teTEX TEX TEXexec Texinfo TEX Live TEXutil tfm Unix url web Web2c Win32 XEmTEX
pdf Glyph Container Packed bitmap font Portable Network Graphics PostScript Win32 Web2c distribution based on MikTeX PostScript to pdf converter (on top of GhostScript) Red Green Blue color specication TEX Character Translation TEX Directory Standard TEX distribution for Unix (based on Web2c) typographic language and program ConTEXt command line interface generate typeset documentation from info pages TEX-Live distribution (multiple platform) ConTEXt utility tool TEX Font Metrics Unix platform Uniform Resource Locator literate programming environment ofcial multi--platform web environment Microsoft Windows platform Win32 Web2c distribution
Normal
We thrive in information--thick worlds because of our marvelous and everyday capacity to select, edit, single out, structure, highlight, group, pair, merge, harmonize, synthesize, focus, organize, condense, reduce, boil down, choose, categorize, catalog, classify, list, abstract, scan, look into, idealize, isolate, discriminate, distinguish, screen, pigeonhole, pick over, sort, integrate, blend, inspect, lter, lump, skip, smooth, chunk, average, approximate, cluster, aggregate, outline, summarize, itemize, review, dip into, ip through, browse, glance into, leaf through, skim, rene, enumerate, glean, synopsize, winnow the wheat from the chaff and separate the sheep from the goats. We thrive in information--thick worlds because of our marvelous and everyday capacity to select, edit, single out, structure, highlight, group, pair, merge, harmonize, synthesize, focus, organize, condense, reduce, boil down, choose, categorize, catalog, classify, list, abstract, scan, look into, idealize, isolate, discriminate, distinguish, screen, pigeonhole, pick over, sort, integrate, blend, inspect, lter, lump, skip, smooth, chunk, average, approximate, cluster, aggregate, outline, summarize, itemize, review, dip into, ip through, browse, glance into, leaf through, skim, rene, enumerate, glean, synopsize, winnow the wheat from the chaff and separate the sheep from the goats.
HZ
We thrive in information--thick worlds because of our marvelous and everyday capacity to select, edit, single out, structure, highlight, group, pair, merge, harmonize, synthesize, focus, organize, condense, reduce, boil down, choose, categorize, catalog, classify, list, abstract, scan, look into, idealize, isolate, discriminate, distinguish, screen, pigeonhole, pick over, sort, integrate, blend, inspect, lter, lump, skip, smooth, chunk, average, approximate, cluster, aggregate, outline, summarize, itemize, review, dip into, ip through, browse, glance into, leaf through, skim, rene, enumerate, glean, synopsize, winnow the wheat from the chaff and separate the sheep from the goats. We thrive in information--thick worlds because of our marvelous and everyday capacity to select, edit, single out, structure, highlight, group, pair, merge, harmonize, synthesize, focus, organize, condense, reduce, boil down, choose, categorize, catalog, classify, list, abstract, scan, look content into, idealize, isolate, discriminate, distinguish, screen, pigeonhole, pick over, sort, integrate, blend, inspect, lter, lump, skip, smooth, chunk, average, approximate, cluster, aggregate, outline, summarize, itemize, review, dip into, ip through, browse, glance into, leaf through, skim, reexit
Protruding
We thrive in information--thick worlds because of our marvelous and everyday capacity to select, edit, single out, structure, highlight, group, pair, merge, harmonize, synthesize, focus, organize, condense, reduce, boil down, choose, categorize, catalog, classify, list, abstract, scan, look into, idealize, isolate, discriminate, distinguish, screen, pigeonhole, pick over, sort, integrate, blend, inspect, lter, lump, skip, smooth, chunk, average, approximate, cluster, aggregate, outline, summarize, itemize, review, dip into, ip through, browse, glance into, leaf through, skim, rene, enumerate, glean, synopsize, winnow the wheat from the chaff and separate the sheep from the goats. We thrive in information--thick worlds because of our marvelous and everyday capacity to select, edit, single out, structure, highlight, group, pair, merge, harmonize, synthesize, focus, organize, condense, reduce, boil down, choose, categorize, catalog, classify, list, abstract, scan, look into, idealize, isolate, discriminate, distinguish, screen, pigeonhole, pick over, sort, integrate, blend, inspect, lter, lump, skip, smooth, chunk, average, approximate, cluster, aggregate, outline, summarize, itemize, review, dip into, ip through, browse, glance into, leaf through, skim, rene, enumerate, glean, synopsize, winnow the wheat from the chaff and separate the sheep from the goats.
Both
We thrive in information--thick worlds because of our marvelous and everyday capacity to select, edit, single out, structure, highlight, group, pair, merge, harmonize, synthesize, focus, organize, condense, reduce, boil down, choose, categorize, catalog, classify, list, abstract, scan, look into, idealize, isolate, discriminate, distinguish, screen, pigeonhole, pick over, sort, integrate, blend, inspect, lter, lump, skip, smooth, chunk, average, approximate, cluster, aggregate, outline, summarize, itemize, review, dip into, ip through, browse, glance into, leaf through, skim, rene, enumerate, glean, synopsize, winnow the wheat from the chaff and separate the sheep from the goats. We thrive in information--thick worlds because of our marvelous and everyday capacity to select, edit, single out, structure, highlight, group, pair, merge, harmonize, synthecontent size, focus, organize, condense, reduce, boil down, choose, categorize, catalog, classify, list, abstract, scan, look into, idealize, isolate, discriminate, distinguish, screen, pigeonexit
hole, pick over, sort, integrate, blend, inspect, lter, lump, skip, smooth, chunk, average, approximate, cluster, aggregate, outline, summarize, itemize, review, dip into, ip
through, browse, glance into, leaf through, skim, rene, enumerate, glean, synopsize, winnow the wheat from the chaff and separate the sheep from the goats.
key
type
meaning
PTEX.FileName string The name of the included le as seen by pdfTEX. PTEX.InfoDict dictionary The document information dictionary of the included pdf (an indirect object). PTEX.PageNumber integer The page number of the included le.
The PDF Reference says: Although viewer applications can store custom metadata in the document information dictionary, it is inappropriate to store private content or structural information there; such information should be stored in the document catalog instead. Although it would seem more natural to put this infomation in the document information dictionary, we have to obey the rules laid down in the PDF Reference. The following key ends up in the document catalog.
key
type
meaning
PTEX.Fullbanner string The full version of the binary that produced the le as displayed by pdftex -version, e. g. This is pdfTeX, Version 3.141592-1.40.0-2.2 (Web2C 7.5.6) kpathsea version 3.5.6. This is necessary because the string in the Producer key in the info dictionary is rather short, e. g. pdfTeX-1.40.0.
content The pdfTEX user manual exit
Colophon
This manual is typeset in ConTEXt. One can generate an A4 version from the source code by typing:
texexec
Given that the A4 version is typeset, one can generate an A5 booklet by typing:
content
exit
Preamble
The purpose of this License is to make a manual, textbook, or other functional and useful document free in the sense of freedom: to assure everyone the effective freedom to copy and redistribute it, with or without modifying it, either commercially or noncommercially. Secondarily, this License preserves for the author and publisher a way to get credit for their work, while not being considered responsible for modications made by others.
This License applies to any manual or other work, in any medium, that contains a notice placed by the copyright holder saying it can be distributed under the terms of this License. Such a notice grants a world-wide, royalty-free license, unlimited in duration, to use that work under the conditions stated herein. The Document, below, refers to any such manual or work. Any member of the public is a licensee, and is addressed as you. You accept the license if you copy, modify or distribute the work in a way This License is a kind of copyleft, which means that requiring permission under copyright law. derivative works of the document must themselves be free in the same sense. It complements the GNU General Pub- A Modied Version of the Document means any work lic License, which is a copyleft license designed for free containing the Document or a portion of it, either copied software. verbatim, or with modications and/or translated into another language. content The pdfTEX user manual exit
A Secondary Section is a named appendix or a frontmatter section of the Document that deals exclusively with the relationship of the publishers or authors of the Document to the Documents overall subject (or to related matters) and contains nothing that could fall directly within that overall subject. (Thus, if the Document is in part a textbook of mathematics, a Secondary Section may not explain any mathematics.) The relationship could be a matter of historical connection with the subject or with related matters, or of legal, commercial, philosophical, ethical or political position regarding them. The Invariant Sections are certain Secondary Sections whose titles are designated, as being those of Invariant Sections, in the notice that says that the Document is released under this License. If a section does not t the above denition of Secondary then it is not allowed to be designated as Invariant. The Document may contain zero Invariant Sections. If the Document does not identify any Invariant Sections then there are none.
the document straightforwardly with generic text editors or (for images composed of pixels) generic paint programs or (for drawings) some widely available drawing editor, and that is suitable for input to text formatters or for automatic translation to a variety of formats suitable for input to text formatters. A copy made in an otherwise Transparent le format whose markup, or absence of markup, has been arranged to thwart or discourage subsequent modication by pdf viewers is not Transparent. An image format is not Transparent if used for any substantial amount of text. A copy that is not Transparent is called Opaque.
Examples of suitable formats for Transparent copies include plain ASCII without markup, Texinfo input format, LaTeX input format, SGML or XML using a publicly available DTD, and standard-conforming simple HTML, PostScript or pdf designed for human modication. Examples of transparent image formats include PNG, XCF and JPG. Opaque formats include proprietary formats that can be read and edited only by proprietary word processors, SGML or XML for which the DTD and/or processing tools The Cover Texts are certain short passages of text that are not generally available, and the machine-generated are listed, as Front-Cover Texts or Back-Cover Texts, in the HTML, PostScript or pdf produced by some word procesnotice that says that the Document is released under this sors for output purposes only. License. A Front-Cover Text may be at most 5 words, and a Back-Cover Text may be at most 25 words. The Title Page means, for a printed book, the title page itself, plus such following pages as are needed to hold, A Transparent copy of the Document means a machine- legibly, the material this License requires to appear in the readable copy, represented in a format whose specication title page. For works in formats which do not have any title is available to the general public, that is suitable for revising page as such, Title Page means the text near the most content The pdfTEX user manual exit
prominent appearance of the works title, preceding the copies you make or distribute. However, you may accept beginning of the body of the text. compensation in exchange for copies. If you distribute a large enough number of copies you must also follow the A section Entitled XYZ means a named subunit of the conditions in section 3. Document whose title either is precisely XYZ or contains XYZ in parentheses following text that translates XYZ in You may also lend copies, under the same conditions stated another language. (Here XYZ stands for a specic section above, and you may publicly display copies. name mentioned below, such as Acknowledgements, Dedications, Endorsements, or History.) To Pre- COPYING IN QUANTITY serve the Title of such a section when you modify the Document means that it remains a section Entitled XYZ If you publish printed copies (or copies in media that comaccording to this denition. monly have printed covers) of the Document, numbering more than 100, and the Documents license notice requires Cover Texts, you must enclose the copies in covers that carry, clearly and legibly, all these Cover Texts: Front-Cover Texts on the front cover, and Back-Cover Texts on the back cover. Both covers must also clearly and legibly identify you as the publisher of these copies. The front cover must present the full title with all words of the title equally prominent and visible. You may add other material on the covers in addition. Copying with changes limited to the covers, as long as they preserve the title of the Document and satisfy VERBATIM COPYING these conditions, can be treated as verbatim copying in You may copy and distribute the Document in any medium, other respects. either commercially or noncommercially, provided that this License, the copyright notices, and the license notice saying If the required texts for either cover are too voluminous to this License applies to the Document are reproduced in all t legibly, you should put the rst ones listed (as many as copies, and that you add no other conditions whatsoever to t reasonably) on the actual cover, and continue the rest those of this License. You may not use technical measures onto adjacent pages. to obstruct or control the reading or further copying of the content The pdfTEX user manual exit The Document may include Warranty Disclaimers next to the notice which states that this License applies to the Document. These Warranty Disclaimers are considered to be included by reference in this License, but only as regards disclaiming warranties: any other implication that these Warranty Disclaimers may have is void and has no effect on the meaning of this License.
If you publish or distribute Opaque copies of the Doc- A. Use in the Title Page (and on the covers, if any) a title ument numbering more than 100, you must either indistinct from that of the Document, and from those of clude a machine-readable Transparent copy along with previous versions (which should, if there were any, be each Opaque copy, or state in or with each Opaque copy listed in the History section of the Document). You may a computer-network location from which the general use the same title as a previous version if the original network-using public has access to download using publicpublisher of that version gives permission. standard network protocols a complete Transparent copy B. List on the Title Page, as authors, one or more persons or of the Document, free of added material. If you use the latentities responsible for authorship of the modications ter option, you must take reasonably prudent steps, when in the Modied Version, together with at least ve of the principal authors of the Document (all of its principal you begin distribution of Opaque copies in quantity, to ensure that this Transparent copy will remain thus accessible authors, if it has fewer than ve), unless they release at the stated location until at least one year after the last you from this requirement. time you distribute an Opaque copy (directly or through C. State on the Title page the name of the publisher of the your agents or retailers) of that edition to the public. Modied Version, as the publisher. D. Preserve all the copyright notices of the Document. It is requested, but not required, that you contact the au- E. Add an appropriate copyright notice for your modicathors of the Document well before redistributing any large tions adjacent to the other copyright notices. number of copies, to give them a chance to provide you F. Include, immediately after the copyright notices, a liwith an updated version of the Document. cense notice giving the public permission to use the Modied Version under the terms of this License, in the form shown in the Addendum below. MODIFICATIONS G. Preserve in that license notice the full lists of Invariant Sections and required Cover Texts given in the DocuYou may copy and distribute a Modied Version of the ments license notice. Document under the conditions of sections 2 and 3 above, H. Include an unaltered copy of this License. provided that you release the Modied Version under precisely this License, with the Modied Version lling the role I. Preserve the section Entitled History, Preserve its Title, and add to it an item stating at least the title, year, of the Document, thus licensing distribution and modicanew authors, and publisher of the Modied Version as tion of the Modied Version to whoever possesses a copy given on the Title Page. If there is no section Entitled of it. In addition, you must do these things in the Modied History in the Document, create one stating the title, Version: content The pdfTEX user manual exit
J.
K.
L.
M. N.
O.
year, authors, and publisher of the Document as given on its Title Page, then add an item describing the Modied Version as stated in the previous sentence. Preserve the network location, if any, given in the Document for public access to a Transparent copy of the Document, and likewise the network locations given in the Document for previous versions it was based on. These may be placed in the History section. You may omit a network location for a work that was published at least four years before the Document itself, or if the original publisher of the version it refers to gives permission. For any section Entitled Acknowledgements or Dedications, Preserve the Title of the section, and preserve in the section all the substance and tone of each of the contributor acknowledgements and/or dedications given therein. Preserve all the Invariant Sections of the Document, unaltered in their text and in their titles. Section numbers or the equivalent are not considered part of the section titles. Delete any section Entitled Endorsements. Such a section may not be included in the Modied Version. Do not retitle any existing section to be Entitled Endorsements or to conict in title with any Invariant Section. Preserve any Warranty Disclaimers.
tain no material copied from the Document, you may at your option designate some or all of these sections as invariant. To do this, add their titles to the list of Invariant Sections in the Modied Versions license notice. These titles must be distinct from any other section titles. You may add a section Entitled Endorsements, provided it contains nothing but endorsements of your Modied Version by various partiesfor example, statements of peer review or that the text has been approved by an organization as the authoritative denition of a standard. You may add a passage of up to ve words as a FrontCover Text, and a passage of up to 25 words as a BackCover Text, to the end of the list of Cover Texts in the Modied Version. Only one passage of Front-Cover Text and one of Back-Cover Text may be added by (or through arrangements made by) any one entity. If the Document already includes a cover text for the same cover, previously added by you or by arrangement made by the same entity you are acting on behalf of, you may not add another; but you may replace the old one, on explicit permission from the previous publisher that added the old one. The author(s) and publisher(s) of the Document do not by this License give permission to use their names for publicity for or to assert or imply endorsement of any Modied Version.
If the Modied Version includes new front-matter sections or appendices that qualify as Secondary Sections and concontent The pdfTEX user manual
exit
COMBINING DOCUMENTS
You may combine the Document with other documents released under this License, under the terms dened in section 4 above for modied versions, provided that you include in the combination all of the Invariant Sections of all of the original documents, unmodied, and list them all as Invariant Sections of your combined work in its license notice, and that you preserve all their Warranty Disclaimers. The combined work need only contain one copy of this License, and multiple identical Invariant Sections may be replaced with a single copy. If there are multiple Invariant Sections with the same name but different contents, make the title of each such section unique by adding at the end of it, in parentheses, the name of the original author or publisher of that section if known, or else a unique number. Make the same adjustment to the section titles in the list of Invariant Sections in the license notice of the combined work.
COLLECTIONS OF DOCUMENTS
You may make a collection consisting of the Document and other documents released under this License, and replace the individual copies of this License in the various documents with a single copy that is included in the collection, provided that you follow the rules of this License for verbatim copying of each of the documents in all other respects. You may extract a single document from such a collection, and distribute it individually under this License, provided you insert a copy of this License into the extracted document, and follow this License in all other respects regarding verbatim copying of that document.
A compilation of the Document or its derivatives with other separate and independent documents or works, in or on In the combination, you must combine any sections Enti- a volume of a storage or distribution medium, is called an tled History in the various original documents, forming aggregate if the copyright resulting from the compilation one section Entitled History; likewise combine any sec- is not used to limit the legal rights of the compilations tions Entitled Acknowledgements, and any sections En- users beyond what the individual works permit. When the titled Dedications. You must delete all sections Entitled Document is included in an aggregate, this License does Endorsements. not apply to the other works in the aggregate which are not themselves derivative works of the Document. content The pdfTEX user manual exit
If the Cover Text requirement of section 3 is applicable to these copies of the Document, then if the Document is less than one half of the entire aggregate, the Documents Cover Texts may be placed on covers that bracket the Document within the aggregate, or the electronic equivalent of covers if the Document is in electronic form. Otherwise they must appear on printed covers that bracket the whole aggregate.
TERMINATION
You may not copy, modify, sublicense, or distribute the Document except as expressly provided for under this License. Any other attempt to copy, modify, sublicense or distribute the Document is void, and will automatically terminate your rights under this License. However, parties who have received copies, or rights, from you under this License will not have their licenses terminated so long as such parties remain in full compliance.
TRANSLATION
Translation is considered a kind of modication, so you may distribute translations of the Document under the terms of section 4. Replacing Invariant Sections with translations requires special permission from their copyright holders, but you may include translations of some or all Invariant Sections in addition to the original versions of these Invariant Sections. You may include a translation of this License, and all the license notices in the Document, and any Warranty Disclaimers, provided that you also include the original English version of this License and the original versions of those notices and disclaimers. In case of a disagreement between the translation and the original version of this License or a notice or disclaimer, the original version will prevail.
Each version of the License is given a distinguishing version number. If the Document species that a particular numbered version of this License or any later version applies to it, you have the option of following the terms and conditions either of that specied version or of any later version that has been published (not as a draft) by the If a section in the Document is Entitled Acknowledge- Free Software Foundation. If the Document does not speciments, Dedications, or History, the requirement (sec- fy a version number of this License, you may choose any tion 4) to Preserve its Title (section 1) will typically require version ever published (not as a draft) by the Free Software changing the actual title. Foundation. content The pdfTEX user manual exit
content
exit