% interface=english modes=letter,screen output=pdftex % $Id: pdftex-t.tex,v 1.582 2005/01/06 13:35:51 hahe Exp hahe $ % The number of lines on the titlepage depends on the kind of % \PDF\ code that \PDFTEX\ generates. \setvariables[pdftex][titlepagelines=63] %D We use a multi purpose style (using modes) that enable us %D to generate an A4, letter and screen version. %D %D Default A4 size manual: %D %D texexec --result pdftex-a.pdf pdftex-t %D %D Letter size manual: %D %D texexec --mode=letter --result=pdftex-l.pdf pdftex-t %D %D Booklet (given that A4 document is available): %D %D texexec --pdfarrange --paper=a5a4 --print=up --addempty=1,2 --result=pdftex-b.pdf pdftex-a %D %D Screen version %D %D texexec --mode=screen pdftex-t %D This is the \PDFTEX\ manual, so it makes sense to force \PDF\ output here. \setupoutput [pdftex] %D First we define ourselves some abbreviations, if only to force %D consistency and to save typing. We use real small capitals, not pseudo %D ones. \setupsynonyms [abbreviation] [textstyle=smallcaps, style=smallcaps, location=left, width=broad, sample=\POSTSCRIPT] \setupcapitals [title=no] \def\eTeX{{$\varepsilon$}-\kern-.125em\TeX} \abbreviation [AFM] {afm} {Adobe Font Metrics} \abbreviation [AMIGA] {Amiga} {Amiga hardware platform} \abbreviation [AMIWEB] {AmiWeb2c} {\AMIGA\ distribution} \abbreviation [ASCII] {ascii} {American Standard Code for Information Interchange} \abbreviation [CMACTEX] {CMac\TeX} {\MAC\ \WEBC\ distribution} \abbreviation [CONTEXT] {\ConTeXt} {general purpose macro package} \abbreviation [CTAN] {CTAN} {global \TEX\ archive server} \abbreviation [DJGPP] {djgpp} {DJ Delorie's \GNU\ Programming Platform} \abbreviation [DVI] {dvi} {native \TEX\ Device Independent file format} \abbreviation [ENCTEX] {enc\TeX} {enc\TeX\ extension to \TEX} \abbreviation [EPSTOPDF] {epstopdf} {\EPS\ to \PDF\ conversion tool} \abbreviation [EPS] {eps} {Encapsulated PostScript} \abbreviation [ETEX] {\eTeX} {an extension to \TEX} \abbreviation [EXIF] {exif} {Exchangeable Image File format (JPEG file variant)} \abbreviation [FPTEX] {fp\TeX} {\WIN\ \WEBC\ distribution} \abbreviation [GNU] {gnu} {GNU's Not Unix} \abbreviation [HZ] {hz} {Hermann Zapf optimization} \abbreviation [JPEG] {jpeg} {Joint Photographic Expert Group} \abbreviation [LATEX] {\LaTeX} {general purpose macro package} \abbreviation [MAC] {Macintosh} {Macintosh hardware platform} \abbreviation [MACOSX] {Mac\,OS\,X} {Macintosh operating system version 10} \abbreviation [METAFONT] {\MetaFont} {graphic programming environment, bitmap output} \abbreviation [METAPOST] {\MetaPost} {graphic programming environment, vector output} \abbreviation [MIKTEX] {MikTeX} {\WIN\ distribution} \abbreviation [MLTEX] {ML\TeX} {ML\TeX\ extension to \TEX} \abbreviation [MPTOPDF] {mptopdf} {\METAPOST\ to \PDF\ conversion tool} \abbreviation [MSDOS] {MSDos} {Microsoft DOS platform (Intel)} \abbreviation [PDFETEX] {pdfe\TeX} {\ETEX\ extension producing \PDF\ output} \abbreviation [PDFLATEX] {pdf\LaTeX} {\TEX\ extension producing \PDF\ output (\LATEX\ format loaded)} \abbreviation [PDFTEX] {pdf\TeX} {\TEX\ extension producing \PDF\ output} \abbreviation [PDF] {pdf} {Portable Document Format} \abbreviation [PERL] {Perl} {Perl programming environment} \abbreviation [PFA] {PFA} {Adobe PostScript Font format (ASCII)} \abbreviation [PFB] {PFB} {Adobe PostScript Font format (Binary)} \abbreviation [PGC] {pgc} {\PDF\ Glyph Container} \abbreviation [PK] {pk} {Packed bitmap font} \abbreviation [PNG] {png} {Portable Network Graphics} \abbreviation [POSTSCRIPT] {PostScript} {PostScript} \abbreviation [PSTOPDF] {PStoPDF} {PostScript to \PDF\ converter (on top of GhostScript)} \abbreviation [RGB] {rgb} {Red Green Blue color specification} \abbreviation [TCX] {tcx} {\TEX\ Character Translation} \abbreviation [TDS] {tds} {\TEX\ Directory Standard} \abbreviation [TETEX] {te\TeX} {\TEX\ distribution for \UNIX\ (based on \WEBC)} \abbreviation [TEXEXEC] {\TeX exec} {\CONTEXT\ command line interface} \abbreviation [TEXINFO] {Texinfo} {generate typeset documentation from info pages} \abbreviation [TEXUTIL] {\TeX util} {\CONTEXT\ utility tool} \abbreviation [TEX] {\TeX} {typographic language and program} \abbreviation [TEXLIVE] {\TeX\ Live} {\TeX-Live distribution (multiple platform)} \abbreviation [TFM] {tfm} {\TEX\ Font Metrics} \abbreviation [TIF] {tiff} {Tagged Interchange File format} \abbreviation [TUG] {tug} {\TEX\ Users Group} \abbreviation [UNIX] {Unix} {Unix platform} \abbreviation [URL] {url} {Uniform Resource Locator} \abbreviation [WEBC] {Web2c} {official multi||platform \WEB\ environment} \abbreviation [WEB] {web} {literate programming environment} \abbreviation [WIN] {Win32} {Microsoft Windows platform} \abbreviation [ZIP] {zip} {compressed file format} %D It makes sense to predefine the name of the author of \PDFTEX, doesn't it? \def\THANH{H\`an Th\^e\llap{\raise 0.5ex\hbox{\'{}}} Th\`anh} %D Because they are subjected to changes and spoil the visual appearance of %D the \TEX\ source, \URL's are defined here. \useURL [ptex_org] [http://www.pdftex.org] % links to ptex_examples \useURL [ptex_ctan] [ctan:systems/pdftex] \useURL [ptex_devel] [http://pdftex.sarovar.org/current/] \useURL [ptex_sarovar] [http://sarovar.org/projects/pdftex/] %\useURL [ptex_examples] [http://www.tug.org/applications/pdftex/] \useURL [tetex] [http://www.tug.org/teTeX/] \useURL [texlive] [http://www.tug.org/tex-live/] \useURL [ctan_systems] [ctan:systems] \useURL [win32] [ctan:systems/win32] \useURL [amiga] [ctan:systems/amiga/amiweb2c/] \useURL [fabrice] [mailto:popineau@supelec.fr] \useURL [thomas] [mailto:te@dbs.uni-hannover.de] \useURL [andreas] [mailto:andreas.scherer@pobox.com] \useURL [christian] [mailto:cschenk@berlin.snafu.de] \useURL [context] [http://www.pragma-ade.com] % where the bug reports should go: \useURL [ptex_bugs] [mailto:pdftex@tug.org] [] [pdftex@tug.org] % anything else pdftex related: \useURL [ptex_list] [mailto:pdftex@tug.org] [] [pdftex@tug.org] \useURL [sebastian] [mailto:s.rahtz@elsevier.co.uk] [] [s.rahtz@elsevier.co.uk] \useURL [sebastian] [mailto:sebastian.rahtz@computing-services.oxford.ac.uk] [] [sebastian.rahtz@computing-services.oxford.ac.uk] \useURL [thanh] [mailto:thanh@informatics.muni.cz] [] [thanh@informatics.muni.cz] \useURL [thanh] [mailto:hanthethanh@myrealbox.com] [] [hanthethanh@myrealbox.com] \useURL [martin] [mailto:ms@artcom-gmbh.de] [] [ms@artcom-gmbh.de] \useURL [hans] [mailto:pragma@wxs.nl] [] [pragma@wxs.nl] \useURL [hartmut] [mailto:hartmut_henkel@gmx.de] [] [hartmut\_henkel@gmx.de] %D The primitive definitions are specified a bit fuzzy using the next set of %D commands. Some day I'll write some proper macros to deal with this. \def\Sugar #1{\unskip\unskip\unskip\kern.25em{#1}\kern.25em\ignorespaces} \def\Something#1{\Sugar{\mathematics{\langle\hbox{#1}\rangle}}} \def\Lbrace {\Sugar{\tttf\leftargument}} \def\Rbrace {\Sugar{\tttf\rightargument}} \def\Or {\Sugar{\mathematics{\vert}}} \def\Optional #1{\Sugar{\mathematics{[\hbox{#1}]}}} \def\Means {\Sugar{\mathematics{\rightarrow}}} \def\Tex #1{\Sugar{\type{#1}}} \def\Literal #1{\Sugar{\type{#1}}} \def\Syntax #1{\strut\kern-.25em{#1}\kern-.25em} \def\Next {\crlf\hbox to 2em{}\nobreak} \def\Whatever #1{\Sugar{\mathematics{(\hbox{#1})}}} % hyphenates \def\Something#1{\Sugar{\mathematics{\langle}\prewordbreak{#1}\prewordbreak\mathematics{\rangle}}} %D We typeset the \URL's in a monospaced font. \setupurl [style=type] %D The basic layout is pretty simple. Because we want non european readers to %D read the whole text as well, a letter size based alternative is offered %D too. Mode switching is taken care of at the command line when running %D \TEXEXEC. \startmode[letter] \setuppapersize [letter][letter] \stopmode \setuplayout [topspace=1.5cm, backspace=2.5cm, leftmargin=2.5cm, width=middle, footer=1.5cm, header=1.5cm, height=middle] %D For the moment we use the description mechanism to typeset keywords etc. %D Well, I should have used capitals. \definedescription [description] [location=serried, width=broad] \definedescription [PathDescription] [location=left, sample=TEXPSHEADERS, width=broad, headstyle=type] \definehead [pdftexprimitive] [subsubsection] \setuphead [pdftexprimitive] [style=, before=\blank, after=\blank, numbercommand=\SubSub] %D This is typically a document where we want to save pages, %D so we don't start any matter (part) on a new page. \setupsectionblock [frontpart] [page=] \setupsectionblock [bodypart] [page=] \setupsectionblock [backpart] [page=] %D The \type{\SubSub} command is rather simple and generates a triangle. %D This makes the primitives stand out a bit more. \def\SubSub#1{\mathematics{\blacktriangleright}} %D But, for non Lucida users, the next one is more safe: \def\SubSub#1{\goforwardcharacter} %D I could have said: %D %D \starttyping %D \setupsection[section-5][previousnumber=no,bodypartconversion=empty] %D \setuplabeltext[subsubsection=\mathematics{\blacktriangleright}] %D \stoptyping %D %D but this is less clear. %D We use white space, but not too much. \setupwhitespace [medium] \setupblank [medium] %D Verbatim things get a small margin. \setuptyping [margin=standard] %D Due to the lots of verbatim we will be a bit more tolerant in breaking %D paragraphs into lines. \setuptolerance [verytolerant,stretch] %D We put the chapter and section numbers in the margin and use bold fonts. \setupheads [alternative=margin] \setuphead [section] [style=\bfb] \setuphead [subsection] [style=\bfa] %D The small table of contents is limited to section titles and is fully %D interactive. \setuplist [section] [criterium=all, interaction=all, width=2em, aligntitle=yes, alternative=a] %D Ah, this manual is in english! \mainlanguage [en] %D We use Palatino fonts, because they look so well on the screen. The %D version generated at \PRAGMA\ uses Optima Nova instead. Both fonts are %D designed by Hermann Zapf. \setupfonthandling [hz] [min=85,max=85,step=5] \setupalign [hz,hanging] \startnotmode[atpragma] \setupfontsynonym [Serif] [handling=quality] \setupfontsynonym [SerifBold] [handling=quality] \setupfontsynonym [SerifSlanted] [handling=quality] \setupfontsynonym [SerifItalic] [handling=quality] \setupfontsynonym [SerifBoldSlanted] [handling=quality] \setupfontsynonym [SerifBoldItalic] [handling=quality] %setupfontsynonym [Mono] [handling=quality] % sloooow % We use adobe metrics instead of urw metrics because tetex only % ships the former. Beware, these metrics differ! \usetypescript [adobekb] [\defaultencoding] \usetypescript [palatino][\defaultencoding] \setupbodyfont [palatino,10pt] \definefontsynonym[TitleFont][SerifBold] \stopnotmode \startmode[atpragma] \usetypescriptfile[type-ghz] \setupfontsynonym [Sans] [handling=quality] \setupfontsynonym [SansBold] [handling=quality] \setupfontsynonym [SansSlanted] [handling=quality] \setupfontsynonym [SansItalic] [handling=quality] \setupfontsynonym [SansBoldSlanted] [handling=quality] \setupfontsynonym [SansBoldItalic] [handling=quality] %setupfontsynonym [Mono] [handling=quality] % sloooow \definetypeface[optima][ss][sans][optima-nova] [default][encoding=\defaultencoding] \definetypeface[optima][tt][mono][latin-modern][default][encoding=\defaultencoding,rscale=1.1] \setupbodyfont[optima,10pt,ss] \definefontsynonym[TitleFont][SansBold] \stopmode %D This document is mildly interactive. Yes, Thanh's name will end up ok in %D the document information data. \setupinteraction [state=start, style=normal, color=, page=yes, openaction=firstpage, title=the pdfTeX users manual, author={H\`an Th\^e Th\`anh, Sebastian Rahtz, Hans Hagen, Hartmut Henkel}] \setupinteractionscreen % still needed? \startnotmode[screen] \setupinteractionscreen [option=bookmark] \stopnotmode %D Some headers and footers will complete the layout. \setupheadertexts [The pdf\TeX\ user manual] \setupfootertexts [pagenumber] %D For Tobias Burnus, who loves bookmarks, I've enabled them. \placebookmarks [section,subsection,pdftexprimitive] %D Let's also define a screen layout: \startmode[screen] \environment pdftex-i \stopmode %D We auto-cross link the paper and screen version: \startnotmode[screen] %\coupledocument % [screenversion] % [pdftex-s] % [section,subsection,subsubsection,pdftexprimitive] % [the screen version] \setuphead [section,subsection,subsubsection,pdftexprimitive] [file=screenversion] \setuplist [section] [alternative=c] \stopnotmode %D The text starts here! \starttext %D Being lazy, I don't split the file, so paper and screen get %D mixed in one document. \startmode[screen] \getbuffer[screen] \stopmode \startnotmode[screen] %D But first we typeset the title page. It has a background. This %D background, showing a piece of \PDF\ code, will be referred to %D later on. %D We can use more modern \CONTEXT\ features, but for the moment %D stick to the old style and methods. \NormalizeFontWidth \TitleFont {\hskip.5mm The pdf\TeX\ user manual} % \hskip is fake offset \paperheight {TitleFont} \setupbackgrounds [page] [background={title,joke,names,content}] \defineoverlay [title] [\hbox to \paperwidth {\hfill \TitleFont\setstrut \rotate{The pdf\TeX\ user manual}% \hskip.5cm}] % \dp\strutbox}] % \defineoverlay % [joke] % [\hbox to \paperwidth % {\TitleFont\setstrut % \dimen0=\overlaywidth % \advance\dimen0 by -\ht\strutbox % \advance\dimen0 by -\dp\strutbox % \advance\dimen0 by -1cm % \dimen2=\overlayheight % \advance\dimen2 by -1cm % \hskip.5cm\expanded{\externalfigure % [pdftex-z.pdf] % [width=\the\dimen0,height=\the\dimen2]}% % \hfill}] % \defineoverlay % [names] % [\vbox to \paperheight % {\dontcomplain % \TitleFont\setstrut % \setbox0=\hbox{\TeX}% % \hsize\paperwidth % \rightskip\ht0 % \advance\rightskip\dp\strutbox % \advance\rightskip\dp\strutbox % \bfa \setupinterlinespace % \vfill % \hfill \THANH \endgraf % \hfill Sebastian Rahtz \endgraf % \hfill Hans Hagen % \hfill Hartmut Henkel % \vskip 1ex % \hfill \currentdate % \vskip 2ex}] \defineoverlay [content] [\overlaybutton{contents}] % title page \definelayout [titlepage] [backspace=.5cm, cutspace=3.5cm, topspace=.5cm, bottomspace=.5cm, header=0pt, footer=0pt, lines=\getvariable{pdftex}{titlepagelines}, grid=yes, width=middle] \definecolumnset [titlepage] [n=2,distance=0.5cm] \start \chardef\fontdigits=2 \switchtobodyfont[10pt,tt] \setupinterlinespace[line=\dimexpr((\paperheight-1cm)/\getvariable{pdftex}{titlepagelines})] \setuptyping[margin=,color=] \setuplayout[titlepage] \startcolumnset[titlepage] \typefile{pdftex-t.txt} \stopcolumnset \page \setuplayout \stop % \startstandardmakeup % % %D The titlepage is generated using the background overlay mechanism. This % %D saves me the trouble of determining funny skips and alignments. So no text % %D goes here. % % \stopstandardmakeup \setupbackgrounds [page] [background=] %D The inside title page is as follows. \startstandardmakeup[footerstate=none] \dontcomplain \setupalign[left] \start \bfd The pdf\TeX\ user manual \bfa \setupinterlinespace \vskip4ex \leavevmode \THANH\par \leavevmode Sebastian Rahtz\par \leavevmode Hans Hagen\par \leavevmode Hartmut Henkel\par \vskip2ex \currentdate \stop \vfill \startlines The title page of this manual represents the plain \TeX\ coded text ``Welcome to pdf\TeX !'' \stoplines \blank[2*big] \setuptyping[after=] \starttyping \pdfoutput=1 \pdfcompresslevel=0 \font\tenrm=ptmr8r \tenrm Welcome to pdf\TeX! \bye \stoptyping \stopstandardmakeup %D So far for non screen mode. \stopnotmode %D We start with a small table of contents, typeset in double column format. \startfrontmatter \subject[contents]{Contents} \startcolumns[distance=3em] \placelist[section] \stopcolumns \stopfrontmatter %D And here it is: the main piece of text. \startbodymatter %*********************************************************************** \section{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 files 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 justification 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 \WEBC, and has been successfully compiled on \UNIX, \WIN\ 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 \quote {moderate} successor to \TEX\ available, called \ETEX. Because mainstream macro packages such as \LATEX\ have started supporting this welcome extension, \PDFTEX\ also is available as \PDFETEX. Although in this document we will speak of \PDFTEX, we advise users to use \PDFETEX\ when available. That way they get the best of all worlds and are ready for the future. Starting with \TEXLIVE\ 2004, that future has arrived: \PDFETEX\ is now the primary \TEX\ engine. Other extensions to \PDFTEX\ are \MLTEX\ and \ENCTEX; recent \PDFTEX\ engines have these often included. \PDFTEX\ is maintained by \THANH, Martin Schr\"oder, Hartmut Henkel, Hans Hagen and others. The \PDFTEX\ homepage is \from [ptex_org]. Please send \PDFTEX\ comments and bug reports to the mailing list \from [ptex_bugs]. 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. %*********************************************************************** \subsection{About this manual} This manual revision tries to keep track with the recent \PDFTEX\ development up to version 1.20b. Main text updates were done regarding the new configuration scheme, font mapping, and new or updated primitives. The primary repository for the manual and its sources is at \from[ptex_sarovar]. Copies in \PDF\ format can also be found at the CTAN network in directory \from[ptex_ctan]. Thanks to Karl Berry for proof reading and submitting a long changes list. New errors might have slipped in afterwards by the editor. Please send questions or suggestions by email to \from[ptex_bugs]. %*********************************************************************** \subsection{Legal Notice} Copyright \copyright\ 1996||2005 \THANH. Permission is granted to copy, distribute and/or modify this document under the terms of the GNU Free Documentation License, Version 1.2 or any later version published by the Free Software Foundation; with no Invariant Sections, no Front-Cover Texts, and no Back-Cover Texts. A copy of the license is included in the section entitled ``GNU Free Documentation License''. %*********************************************************************** \section{About \PDF} The cover of this manual lists an almost minimal \PDF\ file generated by \PDFTEX, with the corresponding source file on the next page. Unless compression is enabled, such a \PDF\ file is rather verbose and readable. The first line specifies the version used; currently \PDFTEX\ produces level 1.4 output. Viewers are supposed to silently skip over all elements they cannot handle. A \PDF\ file consist of objects. These objects can be recognized by their number and keywords: \starttyping 8 0 obj << /Type /Catalog /Pages 6 0 R >> endobj \stoptyping Here \typ{8 0 obj ... endobj} is the object capsule. The first number is the object number. Later we will see that \PDFTEX\ gives access to this number. One can for instance create an object by using \type{\pdfobj} after which \type{\pdflastobj} returns the number. So \starttyping \pdfobj{/Type /Catalog /Pages 6 0 R} \stoptyping inserts an object into the file, while \type{\pdflastobj} returns the number \PDFTEX\ assigned to this object. The sequence \type{6 0 R} is an object reference, a pointer to another object (no.~6). The second number (here a zero) is currently not used in \PDFTEX; it is the version number of the object. It is for instance used by \PDF\ editors, when they replace objects by new ones. The version numbers permit a roll||back. (An example of a graphic editor that uses \PDF\ as storage format is Adobe's Illustrator.) In general this rather direct way of pushing objects in the files is not very useful, and only makes sense when implementing, say, fill||in field support or annotation content reuse. We will come to that later. Unless such direct objects are part of something larger, they will end up as isolated entities, not doing any harm but not doing any good either. When a viewer opens a \PDF\ file, it first goes to the end of the file. There it finds the keyword \type{startxref}, the signal where to look for the so called \quote {object cross reference table}. This table provides fast access to the objects that make up the file. The actual starting point of the file is defined after the \type{trailer}. The \type{/Root} entry points to the catalog. In this catalog the viewer can find the page list. In our example we have only one page. The trailer also holds an \type{/Info} entry, which tells a bit more about the document. Just follow the thread: \startnarrower \type{/Root} $\longrightarrow$ object~8 $\longrightarrow$ \type{/Pages} $\longrightarrow$ object~6 $\longrightarrow$ \type{/Kids} $\longrightarrow$ object~2 $\longrightarrow$ page content \stopnarrower As soon as we add annotations, a fancy word for hyperlinks and the like, some more entries are present in the catalog. We invite users to take a look at the \PDF\ code of this file to get an impression of that. The page content is a stream of drawing operations. Such a stream can be compressed, where the level of compression can be set with \type {\pdfcompresslevel}. Let's take a closer look at this stream. First there is a transformation matrix, six numbers followed by \type{cm}. As in \POSTSCRIPT, the operator comes after the operands. Between \type{BT} and \type{ET} comes the text. A font switch can be recognized as \type{/F..}. The actual text goes between \type{()} so that it creates a \POSTSCRIPT\ string. When one analyzes a file produced by a less sophisticated typesetting engine, whole sequences of words can be recognized. In \PDF\ files generated by \PDFTEX\ however, the words comes out rather fragmented, mainly because a lot of kerning takes place. \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. This one page example uses an Adobe Times||Roman font. This is one of the 14 so||called standard fonts that are always present in the viewer application, and therefore need not be embedded in the \PDF\ file. However, when we use for instance Computer Modern Roman, we have to make sure that this font is available, and the best way to do this is to embed it. Just let your eyes follow the object thread and see how a font is described. The only thing removed from this example is the (partially) embedded glyph description file, which for the 14 standard fonts is not needed. In this simple file, we don't specify in what way the file should be opened, for instance full screen or clipped. A closer look at the page object (\typ{/Type /Page}) shows that a mediabox is part of the page description. A mediabox acts like the bounding box in a \POSTSCRIPT\ file. \PDFTEX\ users have access to this object by \type{\pdfpageattr}. 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. Those who, after this introduction, feel unsure how to proceed, are advised to read on but skip \in{section}[primitives]. Before we come to that section, we will describe how to get started with \PDFTEX. %*********************************************************************** \section{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 \TEXLIVE, \TETEX, \FPTEX, \MIKTEX, and \CMACTEX. The ready to run \TEXLIVE\ distribution comes with \PDFTEX\ versions for many \UNIX\, \WIN, and \MACOSX\ systems; more information can be found at \from[texlive]. \TETEX\ by Thomas Esser is a source distribution with an automated compilation process for \UNIX\ systems; see \from[tetex]. For \WIN\ systems there are also two separate distributions that contain \PDFTEX, both in \from[win32]: \FPTEX\ by Fabrice Popineau and \MIKTEX\ by Christian Schenk. So when you use any of these distributions, you don't need to bother with the \PDFTEX\ installation procedure in the next sections. If there is no precompiled binary of \PDFTEX\ 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.\ \TETEX, into which the freshly compiled \PDFTEX\ will be integrated. Note that the installation description in this manual is \WEBC||specific. %*********************************************************************** \subsection{Getting sources and binaries} The latest sources of \PDFTEX\ are currently distributed for compilation on \UNIX\ systems (including Linux), and \WIN\ systems (Windows 95, 98, NT, 2000, XP). The primary location where one can fetch the latest released code is at the developers' homepage \from[ptex_sarovar], where you also find bug tracking information, and the manual sources. Download the \PDFTEX\ tarball from the directory: \startnarrower \from[ptex_devel] \stopnarrower The \PDFTEX\ sources can also be found at their canonical place in the CTAN network, \from[ptex_ctan]. Separate \PDFTEX\ binaries for various systems might also be available, check out the subdirectories below \from[ctan_systems]. %*********************************************************************** \subsection{Compiling} The compilation is expected to be easy on \UNIX||like systems and can be described best by example. Assuming that the file \filename {pdftex.tar.bz2} is downloaded to some working directory, e.\,g.\ \filename {\$HOME/pdftex}, on a \UNIX\ system the following steps are needed to compile \PDFTEX: \starttyping cd $HOME/pdftex bzip2 -d pdftex-1.20b.tar.bz2 | tar xvf - cd pdftex-1.20b ./Build \stoptyping The binaries \filename{pdftex} and \filename{pdfetex} are then built in the subdirectory \filename{build/texk/web2c}. Apart from the binaries \PDFTEX\ and \PDFETEX\, the compilation also produces a few other files which are needed for running both \PDFTEX\ versions: \description {\filename{pdftex.pool}, \filename{pdfetex.pool}} The pool files, needed for creating formats, located in \filename {build/texk/web2c} %*********************************************************************** \subsection{Placing files} The next step is to put the freshly compiled binaries and pool files into their proper places within the \TDS\ structure of the \TEX\ system. Put the files \filename{pdftex} and \filename{pdfetex} into the directory (e.\,g.\ for a typical \TETEX\ system) \filename{/usr/local/teTeX/bin/i686-pc-linux-gnu}, and the pool files into \filename{/usr/local/teTeX/share/texmf/web2}. Don't forget to do a \filename{texconfig init} afterwards, so that all formats are regenerated with the fresh binaries. %*********************************************************************** \subsection{Setting search paths} \WEBC||based programs, including \PDFTEX, use the \WEBC\ run||time configuration file called \filename {texmf.cnf}. The location of this file is the appropriate position within the \TDS\ tree relative to the place of the \PDFTEX\ binary; on a \TETEX\ system, file \filename{texmf.cnf} typically is located either in directory \filename{texmf/web2c} or \filename{texmf-local/web2c}. The path to file \filename{texmf.cnf} can also be set up by the environment variable \type{TEXMFCNF}. Next you might need to edit \filename {texmf.cnf} so that \PDFTEX\ can find all necessary files, but the \filename{texmf.cnf} files coming with the major \TEX\ distributions should already be set up for normal use. You might check into the file \filename{texmf.cnf} to see where the various bits and pieces are going. \PDFTEX\ uses the search path variables shown in \in{table}[tbl:spathvar]. \startbuffer \starttabulate[|l|l|] \HL \NC \bf used for \NC \bf texmf.cnf \NC\NR \HL \NC output files \NC \type{TEXMFOUTPUT} \NC\NR \NC input files, images \NC \type{TEXINPUTS} \NC\NR \NC format files \NC \type{TEXFORMATS} \NC\NR \NC text pool files \NC \type{TEXPOOL} \NC\NR \NC encoding files \NC \type{ENCFONTS} \NC\NR \NC font map files \NC \type{TEXFONTMAPS} \NC\NR \NC \TFM\ files \NC \type{TFMFONTS} \NC\NR \NC virtual fonts \NC \type{VFFONTS} \NC\NR \NC type1 fonts \NC \type{T1FONTS} \NC\NR \NC TrueType fonts \NC \type{TTFONTS} \NC\NR \NC pixel fonts \NC \type{PKFONTS} \NC\NR \HL \stoptabulate \stopbuffer \placetable[here][tbl:spathvar] {The \WEBC\ variables.} {\getbuffer} \PathDescription {TEXMFOUTPUT} Normally, \PDFTEX\ puts its output files in the current directory. If any output file cannot be opened there, it tries to open it in the directory specified in the environment variable \type{TEXMFOUTPUT}. There is no default value for that variable. For example, if you type \type{pdfetex paper} and the current directory is not writable, if \type{TEXMFOUTPUT} has the value \type{/tmp}, \PDFTEX\ attempts to create \type{/tmp/paper.log} (and \type{/tmp/paper.pdf}, if any output is produced.) \PathDescription {TEXINPUTS} This variable specifies where \PDFTEX\ finds its input files. Image files are considered input files and searched for along this path. \PathDescription {TEXFORMATS} Search path for format (\type{.fmt}) files. \PathDescription {TEXPOOL} Search path for pool (\type{.pool}) files. \PathDescription {ENCFONTS} Search path for encoding (\type{.enc}) files. \PathDescription {TEXFONTMAPS} Search path for font map (\type{.map}) files. \PathDescription {TFMFONTS} Search path for font metric (\type{.tfm}) files. \PathDescription {VFFONTS} Search path for virtual font (\type{.vf}) files. Virtual fonts are fonts made up of other fonts. Because \PDFTEX\ produces the final output code, it must consult those files. \PathDescription {T1FONTS} Search path for Type~1 font files (\type{.pfa} and \type{.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 find them. \PathDescription {TTFFONTS} Search path for TrueType font (\type{.ttf}) files. Like Type~1 fonts, TrueType fonts are also outlines. \PathDescription {PKFONTS} Search path for packed (bitmap) font (\type{.pk}) files. 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). %*********************************************************************** \subsection[cfg]{The \PDFTEX\ configuration} One has to keep in mind that, as opposed to \TEX\ with its \DVI\ output, the \PDFTEX\ program does not require a separate postprocessing stage to transform the \TEX\ input into a \PDF\ file. As a consequence, all data needed for building a ready \PDF\ page must be available during the \PDFTEX\ run, in particular information on media dimensions and offsets, graphics files for embedding, and font information (font files, encodings). When \TEX\ builds a page, it places items relative to the top left page corner (the \DVI\ reference point). Separate \DVI\ postprocessors allow specifying the paper size (e.\,g.\ \quote {A4} or \quote{letter}), so that this reference point is moved to the correct position on the paper, and the text ends up at the right place. In \PDF, the paper dimensions are part of the page definition, and \PDFTEX\ therefore requires that they be defined at the beginning of the \PDFTEX\ run. As with pages described by \POSTSCRIPT, the \PDF\ reference point is in the lower||left corner. Formerly, these dimensions and other \PDFTEX\ parameters were read in from a configuration file named \filename{pdftex.cfg}, which had a special (non-\TEX) format, at the start of processing. Nowadays such a file is ignored by \PDFTEX. Instead, the page dimensions and offsets, as well as all other parameters, can be set by \PDFTEX\ primitives during the \PDFTEX\ format building process, so that the settings are dumped into the fresh format and consequently will be used when \PDFTEX\ is later called with that format. All settings can still be overridden during a \PDFTEX\ run by using the same primitives. This new configuration concept is a more unified approach, as it avoids the configuration file with a special format. A list of \PDFTEX\ primitives relevant for setting up the \PDFTEX\ engine is given in \in{table}[tbl:configparms]. These are described in detail within later sections. \in{Figure}[in:pdftexconfig] shows a recent configuration file (\type{pdftexconfig.tex}) in \TEX\ format, using the primitives from \in{table}[tbl:configparms], which typically is read in during the format building process. It enables \PDF\ output, sets a high compression level for reducing \PDF\ file size, sets item placement precision, paper dimensions, and offsets, sets the default pixel density for \PK\ font inclusion, and sets the \PDF\ version number to appear in the \PDF\ file. The default values are chosen so that \PDFTEX\ often can be used (e.\,g.\ in \type{-ini} mode) even without setting any parameters. \startbuffer \starttabulate[|l|l|l|l|l|] \HL \NC \bf internal name \NC \bf type \NC \bf default \NC \bf comment \NC \NR \HL \NC \type{\pdfoutput} \NC integer \NC 0 \NC \DVI \NC\NR \NC \type{\pdfadjustspacing} \NC integer \NC 0 \NC off \NC\NR \NC \type{\pdfcompresslevel} \NC integer \NC 9 \NC best \NC\NR \NC \type{\pdfdecimaldigits} \NC integer \NC 4 \NC max. \NC\NR \NC \type{\pdfmovechars} \NC integer \NC 0 \NC off \NC\NR \NC \type{\pdfimageresolution} \NC integer \NC 72 \NC dpi \NC\NR \NC \type{\pdfpkresolution} \NC integer \NC 0 \NC 72\,dpi \NC\NR \NC \type{\pdfuniqueresname} \NC integer \NC 0 \NC \NC\NR \NC \type{\pdfprotrudechars} \NC integer \NC 0 \NC \NC\NR \NC \type{\pdfoptionpdfminorversion} \NC integer \NC 4 \NC \PDF\ 1.4 \NC\NR \NC \type{\pdfoptionalwaysusepdfpagebox} \NC integer \NC 0 \NC \NC\NR \NC \type{\pdfoptionpdfinclusionerrorlevel} \NC integer \NC 0 \NC \NC\NR %----------------------------------------------------------------------- \NC \type{\pdfhorigin} \NC dimension \NC 1\,in \NC \NC\NR \NC \type{\pdfvorigin} \NC dimension \NC 1\,in \NC \NC\NR \NC \type{\pdfpagewidth} \NC dimension \NC 0\,pt \NC \NC\NR \NC \type{\pdfpageheight} \NC dimension \NC 0\,pt \NC \NC\NR \NC \type{\pdflinkmargin} \NC dimension \NC 0\,pt \NC \NC\NR \NC \type{\pdfdestmargin} \NC dimension \NC 0\,pt \NC \NC\NR \NC \type{\pdfthreadmargin} \NC dimension \NC 0\,pt \NC \NC\NR \NC \type{\pdfmapfile} \NC text \NC \filename{pdftex.map} \NC\NR \HL \stoptabulate \stopbuffer \placetable[here][tbl:configparms] {The set of \PDFTEX\ configuration parameters.} {\getbuffer} \startbuffer \tx\setupinterlinespace \startframedtext \starttyping % Set pdfTeX parameters for pdf mode % (replacing pdftex.cfg file). % Thomas Esser, 2004. public domain. \pdfoutput=1 \pdfcompresslevel=9 \pdfdecimaldigits=3 \pdfpagewidth=210 true mm \pdfpageheight=297 true mm \pdfhorigin=1 true in \pdfvorigin=1 true in \pdfpkresolution=1200 \pdfoptionpdfminorversion=4 \endinput \stoptyping \stopframedtext \stopbuffer \placefigure[here][in:pdftexconfig] {A typical configuration file (\filename{pdftexconfig.tex}).} {\getbuffer} Independent of whether such a configuration file is read or not, the first action in a \PDFTEX\ run is that the program reads the global \WEBC\ configuration file (\filename{texmf.cnf}), which is common to all programs in the \WEB2C\ system. This file mainly defines file search paths, the memory layout (e.\,g.\ pool and hash size), and other general parameters. %*********************************************************************** \subsection{Creating format files} \startbuffer \tx\setupinterlinespace \startframedtext \starttyping % 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 \stoptyping \stopframedtext \stopbuffer \placefigure[here][in:etexini] {File \type{etex.ini} for \ETEX\ format with \DVI\ output.} {\getbuffer} \startbuffer \tx\setupinterlinespace \startframedtext \starttyping \ifx\pdfoutput\undefined \else \ifx\pdfoutput\relax \else \input pdftexconfig \pdfoutput=1 \fi \fi \scrollmode \input latex.ltx \endinput \stoptyping \stopframedtext \stopbuffer \placefigure[here][in:pdflatexini] {File \type{pdflatex.ini} for \LATEX\ format with \PDF\ output.} {\getbuffer} Both \PDFTEX\ and \PDFETEX\ engines allow building formats for \DVI\ and \PDF\ output in the same way as the classical \TEX\ engine does for \DVI. Format generation is enabled by the \type{-ini} option. The default mode (\DVI\ or \PDF) can be chosen either on the command line by setting the option \type{-output-format} to \type{dvi} or \type{pdf}, or by setting the \type{\pdfoutput} parameter. The format file 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 file can be read in only by the engine that has generated it; a format incompatible with an engine leads to a fatal error. Often the \PDFTEX\ program is a mere link to the \PDFETEX\ engine; then also a \PDFTEX\ call generates an extended format. It is customary to package the configuration and macro file input into a \type{.ini} file. E.\,g., the file \type{etex.ini} in \in{figure}[in:etexini] is for generating an \ETEX\ format with \DVI\ output (it contains a few comparisons to be safe also for \TEX\ engines). A similar file \type{pdflatex.ini} can be used for generating a \LATEX\ format with \PDF\ output; refer to \in{figure}[in:pdflatexini]. One can see how the primitive \type{\pdfoutput} is used to override the output mode set by file \type{pdftexconfig.tex}. The corresponding \PDFTEX\ calls for format generation are: \starttyping pdfetex -ini *etex.ini pdftex -ini pdflatex.ini \stoptyping These calls produce format files \filename{etex.fmt} and \filename{pdflatex.fmt}, as the default format file name is taken from the input file name. You can overrule this with the \type{-jobname} option. The asterisk (\type{*}) in the first example line tells the \PDFETEX\ engine to go into extended \type{-ini} mode. Otherwise, it stays in non||extended mode. So, if you want a \PDFLATEX\ format with \PDF\ output and \ETEX\ extensions available (format file \filename{pdfelatex.fmt}), you would need to type e.\,g.: \starttyping pdfetex -ini -jobname=pdfelatex *pdflatex.ini \stoptyping In \CONTEXT\ the generation depends on the interface used. A format using the English user interface is generated with \starttyping pdfetex -ini cont-en \stoptyping When properly set up, one can also use the \CONTEXT\ command line interface \TEXEXEC\ to generate one or more formats, like: \starttyping texexec --make en \stoptyping for an English format, or \starttyping texexec --make en de \stoptyping for an English and German one. Most users will simply say: \starttyping texexec --make --all [--alone] \stoptyping and so generate the \TEX\ and \METAPOST\ related formats that \CONTEXT\ needs. Whatever macro package used, the formats should be placed in the \type {TEXFORMATS} path. \subsection{Testing the installation} When everything is set up, you can test the installation. In the distribution there is a plain \TEX\ test file \filename {example.tex}. Process this file by typing: \starttyping pdftex example \stoptyping If the installation is ok, this run should produce a file called \filename {example.pdf}. The file \filename {example.tex} is also a good place to look for how to use \PDFTEX's new primitives. %*********************************************************************** \subsection{Common problems} The most common problem with installations is that \PDFTEX\ complains that something cannot be found. In such cases make sure that \type{TEXMFCNF} is set correctly, so \PDFTEX\ can find \filename {texmf.cnf}. The next best place to look|/|edit is the file \type{texmf.cnf}. When still in deep trouble, set \type{KPATHSEA_DEBUG=255} before running \PDFTEX\ or run \PDFTEX\ with option \type{-k 255}. This will cause \PDFTEX\ to write a lot of debugging information that can be useful to trace problems. More options can be found in the \WEBC\ documentation. Variables in \filename {texmf.cnf} can be overwritten by environment variables. Here are some of the most common problems you can encounter when getting started: \startitemize \head \type{I can't read pdftex.pool; bad path?} \type{TEXMFCNF} is not set correctly and so \PDFTEX\ cannot find \type{texmf.cnf}, or \type{TEXPOOL} in \filename {texmf.cnf} doesn't contain a path to the pool file \filename {pdftex.pool} or \type{pdfetex.pool} when you use \PDFETEX. \head \type{You have to increase POOLSIZE.} \PDFTEX\ cannot find \filename {texmf.cnf}, or the value of \type {pool_size} specified in \filename {texmf.cnf} is not large enough and must be increased. If \type{pool_size} is not specified in \filename {texmf.cnf} then you can add something like \starttyping pool_size = 500000 \stoptyping \head \type{I can't find the format file `pdftex.fmt'!} \crlf \type{I can't find the format file `pdflatex.fmt'!} The format file is not created (see above how to do that) or is not properly placed. Make sure that \type{TEXFORMATS} in \filename {texmf.cnf} contains the path to \filename {pdftex.fmt} or \filename {pdflatex.fmt}. \head \type{---! xx.fmt was written by tex} \crlf \type{Fatal format file error; I'm stymied} This appears e.\,g.\ if you forgot to regenerate the \type{.fmt} files after installing a new version of the \PDFTEX\ binary and \filename {pdftex.pool}. The first line tells by which engine the offending format was generated. \head \type{TEX.POOL doesn't match; TANGLE me again!} \crlf \type{TEX.POOL doesn't match; TANGLE me again (or fix the path).} This might appear if you forgot to install the proper \filename {pdftex.pool} when installing a new version of the \PDFTEX\ binary. E.\,g.\ under \TETEX\ then run \type{texconfig init}. \item \PDFTEX\ cannot find one or more map files (\type{*.map}), encoding vectors (\type{*.enc}), virtual fonts, Type~1 fonts, TrueType fonts or some image file. Make sure that the required file exists and the corresponding variable in \filename {texmf.cnf} contains a path to the file. See above which variables \PDFTEX\ needs apart from the ones \TEX\ uses. When you have installed new fonts, and your \PDF\ viewer complains about missing fonts, you should take a look at the log file produced by \PDFTEX. Missing fonts, map files, encoding vectors as well as missing characters (glyphs) are reported there. \stopitemize Normally the page content takes one object. This means that one seldom finds more than a few hundred objects in a simple file. This document for instance uses about 650 objects. In demanding applications this number can grow quite rapidly, especially when one uses a lot of widget annotations, shared annotations or other shared things. In these situations in \filename {texmf.cnf} one can enlarge \PDFTEX 's internal object table by adding a line in \filename {texmf.cnf}, for instance: \starttyping obj_tab_size = 400000 \stoptyping %*********************************************************************** \section{Macro packages supporting \PDFTEX} As \PDFTEX\ generates the final \PDF\ output without help of a postprocessor, macro packages that take care of these \PDF\ features have to be set up properly. Typical tasks are handling color, graphics, hyperlink support, threading, font||inclusion, as well as page imposition and manipulation. All these \PDF||specific tasks can be commanded by \PDFTEX's own primitives (a few also by a \PDFTEX||specific \type{\special{pdf: ...}} primitive). Any other \type{\special{}} commands, like the ones defined for various \DVI\ postprocessors, are simply ignored by \PDFTEX\ when in \PDF\ output mode; a warning is given only for non||empty \type{\special{}} commands. When a macro package already written for classical \TEX\ with \DVI\ output is to be modified for use with \PDFTEX, it is very helpful to get some insight to what extent \PDFTEX||specific support is needed. This info can be gathered e.\,g.\ by outputting the various \type{\special} commands as \type{\message}. Simply type \starttyping \pdfoutput=1 \let\special\message \stoptyping or, if this leads to confusion, \starttyping \pdfoutput=1 \def\special#1{\write16{special: #1}} \stoptyping and see what happens. As soon as one \quote {special} message turns up, one knows for sure that some kind of \PDFTEX\ specific support is needed, and often the message itself gives a indication of what is needed. 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. \startitemize \item For \LATEX\ users, Sebastian Rahtz's and Heiko Oberdiek's \type {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 \type{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. \item The standard \LATEX\ \type{graphics}, \type{graphicx}, and \type{color} packages also have automatic \pdfTeX\ support, which allow use of color, text rotation, and graphics inclusion commands. \item 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 \type{\setupoutput[pdftex]} or feeding \TEXEXEC\ with the \type{--pdf} option. \item \PDF\ from \TEXINFO\ documents can be created by running \PDFTEX\ on the \TEXINFO\ file, instead of \TEX. Alternatively, run the shell command \type{texi2pdf} instead of \type{texi2dvi}. \item A small modification of \filename {webmac.tex}, called \filename {pdfwebmac.tex}, allows production of hyperlinked \PDF\ versions of the program code written in \WEB. \stopitemize Some nice samples of \PDFTEX\ output can be found at \from[ptex_org] and \from[context]. %*********************************************************************** \section{Setting up fonts} \PDFTEX\ can work with Type~1 and TrueType fonts, but a source must be available for all fonts used in the document, except for the 14 standard fonts supplied by the \PDF\ reader (Times, Helvetica, Courier, Symbol and Dingbats). 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) Acrobat 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. %*********************************************************************** \subsection[mapfile]{Map files} Font map files provide the connection between \TEX\ \TFM\ font files and the outline font file names. They contain also information about re||encoding arrays, partial downloading, and character transformation parameters (like SlantFont and ExtendFont). Those map files were first created for \DVI\ postprocessors. But, as \PDFTEX\ in \PDF\ output mode includes all \PDF\ processing steps, it also needs to know about font mapping, and therefore reads in one or more map files. Map files are not read in when \PDFTEX\ is in \DVI\ mode. Pixel fonts can be used without being listed in the map file. By default, \PDFTEX\ reads the map file \filename{pdftex.map}. In \WEBC, map files are searched for using the \type{TEXFONTMAPS} config file value and environment variable. By default, the current directory and various system directories are searched. Within the map file, each font is listed on an individual line. The syntax of each line is upward||compatible with \type{dvips} map files and can contain the following (some are optional) fields: {\em tfmname}, {\em basename}, {\em fontflags}, {\em special}, {\em encodingfile}, and {\em fontfile}; explanations follow. It is mandatory that {\em tfmname} is the first field. If a {\em basename} is given, it must be the second field. Similarly if {\em fontflags} is given it must be the third field (if {\em basename} is present) or the second field (if {\em basename} is left out). It is possible to mix the positions of {\em special}, {\em encodingfile}, and {\em fontfile}, however the first three fields must be given in fixed order. \startdescription {tfmname} sets the name of the \TFM\ file for a font --- the name \TEX\ sees. This name must always be given. \stopdescription \startdescription {basename} sets the base (\POSTSCRIPT) font name. The {\em basename} field is checked against the BaseName entry of fonts coming with embedded \PDF\ files. If there is a match, the font will be removed from the embedded file, and a local font is opened, which will contain the glyphs from the embedded file. This collecting mechanism helps keeping the resulting \PDF\ file size small, if many files with similar fonts are to be embedded. Therefore it is recommended always to set the {\em basename} field. If a {\em basename} field is given, also a {\em fontfile} field must be there, unless the {\em basename} matches one of the 14 standard font names; then the {\em fontfile} field is optional. If the {\em fontfile} name is given, this font will be embedded (depending on flags, see below). If the {\em fontfile} name for a standard font is missing, the font will be quietly left out, which is fine, as \PDF\ viewers will later render the text with their own versions of the font. \stopdescription \startdescription {fontflags} specify some characteristics of the font. The following description of these flags is taken, with slight modification, from the \PDF\ Reference Manual (the section on font descriptor flags). Viewers can adapt their rendering to these flags, especially when they substitute a replacements for not embedded fonts. \startnarrower The value of the flags 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. \in{Table}[flags] specifies the meanings of the bits, with bit~1 being the least significant. Reserved bits must be set to zero. \startbuffer \starttabulate[|c|l|] \HL \NC \bf bit position \NC \bf semantics \NC\NR \HL \NC 1 \NC Fixed||width font \NC\NR \NC 2 \NC Serif font \NC\NR \NC 3 \NC Symbolic font \NC\NR \NC 4 \NC Script font \NC\NR \NC 5 \NC Reserved \NC\NR \NC 6 \NC Uses the Adobe Standard Roman Character Set \NC\NR \NC 7 \NC Italic \NC\NR \NC 8--16 \NC Reserved \NC\NR \NC 17 \NC All||cap font \NC\NR \NC 18 \NC Small||cap font \NC\NR \NC 19 \NC Force bold at small text sizes \NC\NR \NC 20--32 \NC Reserved \NC\NR \HL \stoptabulate \stopbuffer \placetable [here][flags] {The meaning of flags in the font descriptor.} {\getbuffer} All characters in a {\em fixed||width} font have the same width, while characters in a proportional font have different widths. Characters in a {\em serif font} have short strokes drawn at an angle on the top and bottom of character stems, while sans serif fonts do not have such strokes. A {\em symbolic font} contains symbols rather than letters and numbers. Characters in a {\em script font} resemble cursive handwriting. An {\em all||cap} font, which is typically used for display purposes such as titles or headlines, contains no lowercase letters. It differs from a {\em 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 flags field indicates that the font's 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. \stopnarrower If the font flags are 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 flags may cause troubles in viewers. On the other hand this option is not absolutely useless because it provides backward compatibility with older map files (see the {\em fontfile} description below). \stopdescription \startdescription {special} instructions can be used to manipulate fonts similar to the way \type{dvips} does. Currently only the keywords \type{SlantFont} and \type{ExtendFont} are interpreted, other instructions (as \type{ReEncodeFont} with parameters, see {\em encoding} below) are just ignored. The permitted \type{SlantFont} range is $-$1..1; for \type{ExtendFont} it's $-$2..2. The block of {\em special} instruction must be enclosed by double quotes `"'. \stopdescription \startdescription {encoding} specifies the name of the file containing the external encoding vector to be used for the font. The file name may be preceded by a \type{<}, but the effect is the same. The format of the encoding vector is identical to that used by \type{dvips}. If no encoding is specified, the font's built||in default encoding is used. It may be omitted if you are sure that the font resource has the correct built||in encoding. In general this option is highly preferred and is {\em required} when subsetting a TrueType font. \stopdescription \startdescription {fontfile} sets the name of the font source file. This must be a Type~1 or TrueType font file. The font file name can be preceded by one or two special characters, which says how the font file should be handled. \startitemize \item If the font file name is preceded by a \type{<} the font file will be partially downloaded, meaning that only used glyphs (characters) are embedded to the font. This is the most common use and is {\em strongly recommended} for any font, as it ensures the portability and reduces the size of the \PDF\ output. Partial fonts are included in such a way that name and cache clashes are minimized. \item If the font file name is preceded by a double \type{<<}, the font file will be included entirely --- all glyphs of the font are embedded, including 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 not recommended. It might be useful in case the font is atypical and can not be subsetted well by \PDFTEX. {\em Beware: some font vendors forbid full font inclusion.} \item If nothing precedes the font file name, the font file is read but nothing is embedded, only the font parameters are extracted to generate the so||called font descriptor, which is used by the \PDF\ reader to simulate the font if needed. This option is useful only when you do not want to embed the font (i.\,e.~to reduce the output size), but wish to use the font metrics and let the \PDF\ reader 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 flags {\em must} be specified, 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. \item If the font file name is preceded by a \type{!}, the font is not read at all, and is assumed to be available on the system. This option can be used to create \PDF\ files which do not contain embedded fonts. The \PDF\ output then works only on systems where the resource of the used font is available. It's not very useful for document exchange, as the \PDF\ is not \quote{portable} at all. On the other hand it is very useful when you wish to speed up running of \PDFTEX\ during interactive work, and only in a final version embed all used fonts. Don't over||estimate gain in speed and when distributing files, always embed the fonts! This feature requires the \PDF\ reader to have access to installed fonts on the system. This has been tested on Win95 and \UNIX\ (Solaris). \stopitemize When one suffers from invalid lookups, for instance when \PDFTEX\ tries to open a \type{.pfa} file instead of a \type{.pfb} one, one can add the suffix to the filename. In this respect, \PDFTEX\ completely relies on the \type{kpathsea} libraries. \stopdescription %HE Huh? pgc? If a used font is not present in the map files, first \PDFTEX\ will look for a source with suffix \type{.pgc}, which is a so||called \PGC\ source (\PDF\ Glyph Container) \footnote {This is a text file containing a \PDF\ Type~3 font, created by \METAPOST\ using some utilities by Hans Hagen. In general \PGC\ files can contain whatever allowed in \PDF\ page description, which may be used to support fonts that are not available in \METAFONT. \PGC\ fonts are not widely useful, as vector Type~3 fonts are not displayed very well in older versions of Acrobat Reader, but may be more useful when better Type~3 font handling is more common.}. If no \PGC\ source is available, \PDFTEX\ will try to use \PK~fonts as \DVI\ drivers do, creating \PK~fonts on||the||fly if needed. Lines containing nothing apart from {\em 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, let's say \type{csr10}, is described in one of the map files, then it will be treated as scalable. As a result the font source for csr10 will be included only once for \type{csr10}, \type{csr10 at 12pt} etc. So \PDFTEX\ tries to do its best to avoid multiple downloading of identical font sources. Thus vector \PGC\ fonts should be specified as scalable Type~3 in map files like: \starttyping csr10 \stoptyping It doesn't hurt much if a scalable Type~3 font is not given in map files, except that the font source will be downloaded multiple times for various sizes, which causes a much larger \PDF\ output. On the other hand if a font in the map files is defined 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 a some example lines. First we use two fonts from the 14 standard fonts with font||specific encoding, i.\,e.~no external encoding is given. In the first line, the fontfile is missing, so viewers will use their own font. The ZapfDingbats font is taken from the given font file. \starttyping psyr Symbol pzdr ZapfDingbats -o \stoptyping A TrueType file can be recognized by its suffix \filename {ttf}. The optional {\em encoding} specifies the encoding, which is the same as the encoding vector used in map files for \PDFTEX\ and \type{dvips}. If the encoding is not given, all the glyphs of the \AFM\ output will be mapped to \type {/.notdef}. \type{ttf2afm} writes the output \AFM\ to standard output. If we need to know which glyphs are available in the font, we can run \type {ttf2afm} without encoding to get all glyph names. The resulting \AFM\ file can be used to generate a \TFM\ one by applying \filename {afm2tfm}. To use a new TrueType font the minimal steps may look like below. We suppose that \filename {test.map} is used. \starttyping ttf2afm -e 8r.enc -o times.afm times.ttf afm2tfm times.afm -T 8r.enc echo "times TimesNewRomanPSMT <8r.enc >test.map \stoptyping There are a few limitations with TrueType fonts in comparison with Type~1 fonts: \startitemize[a,packed] \item The special effects SlantFont|/|ExtendFont cannot be used. \item To subset a TrueType font, the font must be specified as re||encoded, therefore an encoding vector must be given. \item TrueType fonts coming with embedded \PDF\ files are kept untouched; they are not replaced by local ones. \stopitemize %*********************************************************************** \section{Formal syntax specification} This section formally specifies the \PDFTEX\ specific extensions to the \TEX\ macro programming language. All primitives are prefixed by \type {pdf} except for \type{\efcode}, \type{\lpcode}, and \type{\rpcode}. The general definitions and syntax rules follow after the list of primitives. \startpacked %%S This is the list of new or extended primitives provided by pdftex. %%S Don't edit this file, as it is now auto-generated from the %%S pdfTeX documentation file pdftex-t.tex by script syntaxform.awk. %%S Used convention for syntax rules is borrowed from `TeXbook naruby' %%S by Petr Olsak. %%S $Id: pdftex-t.tex,v 1.582 2005/01/06 13:35:51 hahe Exp hahe $ %%S NL %%S integer registers: \Syntax { \Tex {\pdfoutput} \Whatever{integer} } \Syntax { \Tex {\pdfadjustspacing} \Whatever{integer} } \Syntax { \Tex {\pdfcompresslevel} \Whatever{integer} } \Syntax { \Tex {\pdfdecimaldigits} \Whatever{integer} } \Syntax { \Tex {\pdfmovechars} \Whatever{integer} } \Syntax { \Tex {\pdfimageresolution} \Whatever{integer} } \Syntax { \Tex {\pdfpkresolution} \Whatever{integer} } \Syntax { \Tex {\pdfuniqueresname} \Whatever{integer} } \Syntax { \Tex {\pdfprotrudechars} \Whatever{integer} } \Syntax { \Tex {\pdfoptionpdfminorversion} \Whatever{integer} } \Syntax { \Tex {\pdfoptionalwaysusepdfpagebox} \Whatever{integer} } \Syntax { \Tex {\pdfoptionpdfinclusionerrorlevel} \Whatever{integer} } %%S NL %%S dimen registers: \Syntax { \Tex {\pdfhorigin} \Whatever{dimen} } \Syntax { \Tex {\pdfvorigin} \Whatever{dimen} } \Syntax { \Tex {\pdfpagewidth} \Whatever{dimen} } \Syntax { \Tex {\pdfpageheight} \Whatever{dimen} } \Syntax { \Tex {\pdflinkmargin} \Whatever{dimen} } \Syntax { \Tex {\pdfdestmargin} \Whatever{dimen} } \Syntax { \Tex {\pdfthreadmargin} \Whatever{dimen} } %%S NL %%S token registers: \Syntax { \Tex {\pdfpagesattr} \Whatever{tokens} } \Syntax { \Tex {\pdfpageattr} \Whatever{tokens} } \Syntax { \Tex {\pdfpageresources} \Whatever{tokens} } %%S NL %%S expandable commands: \Syntax { \Tex {\pdftexrevision} \Whatever{expandable} } \Syntax { \Tex {\pdftexbanner} \Whatever{expandable} } \Syntax { \Tex {\pdffontname} \Something{font} \Whatever{expandable} } \Syntax { \Tex {\pdffontobjnum} \Something{font} \Whatever{expandable} } \Syntax { \Tex {\pdfincludechars} \Something{font} \Something{general text} \Whatever{expandable} } %%S NL %%S read-only integers: \Syntax { \Tex {\pdftexversion} \Whatever{read||only integer} } \Syntax { \Tex {\pdflastobj} \Whatever{read||only integer} } \Syntax { \Tex {\pdflastxform} \Whatever{read||only integer} } \Syntax { \Tex {\pdflastximage} \Whatever{read||only integer} } \Syntax { \Tex {\pdflastximagepages} \Whatever{read||only integer} } \Syntax { \Tex {\pdflastannot} \Whatever{read||only integer} } \Syntax { \Tex {\pdflastxpos} \Whatever{read||only integer} } \Syntax { \Tex {\pdflastypos} \Whatever{read||only integer} } \Syntax { \Tex {\pdflastdemerits} \Whatever{read||only integer} } \Syntax { \Tex {\pdflastvbreakpenalty} \Whatever{read||only integer} } %%S NL %%S general commands: \Syntax { \Tex {\pdfliteral} \Optional{\Literal {direct}} \Something{general text} \Whatever{h, v, m} } \Syntax { \Tex {\pdfobj} \Something{object type spec} \Whatever{h, v, m} } \Syntax { \Tex {\pdfrefobj} \Something{object number} \Whatever{h, v, m} } \Syntax { \Tex {\pdfxform} \Optional{\Something{xform attr spec}} \Something{box number} \Whatever{h, v, m} } \Syntax { \Tex {\pdfrefxform} \Something{object number} \Whatever{h, v, m} } \Syntax { \Tex {\pdfximage} \Optional{\Something{image attr spec}} % \Something{general text} \Whatever{h, v, m} } \Syntax { \Tex {\pdfrefximage} \Something{object number} \Whatever{h, v, m} } \Syntax { \Tex {\pdfannot} \Optional{\Something{rule spec}} \Something{general text} \Whatever{h, v, m} } \Syntax { \Tex {\pdfstartlink} % \Optional{\Something{rule spec}} % \Optional{\Something{attr spec}} \Something{action spec} \Whatever{h, m} } \Syntax { \Tex {\pdfendlink} \Whatever{h, m} } \Syntax { \Tex {\pdfoutline} \Something{outline spec} \Whatever{h, v, m} } \Syntax { \Tex {\pdfdest} \Something{dest spec} \Whatever{h, v, m} } \Syntax { \Tex {\pdfthread} \Something{thread spec} \Whatever{h, v, m} } \Syntax { \Tex {\pdfstartthread} \Something{thread spec} \Whatever{v, m} } \Syntax { \Tex {\pdfendthread} \Whatever{v, m} } \Syntax { \Tex {\pdfsavepos} \Whatever{h, v, m} } \Syntax { \Tex {\pdfinfo} \Something{general text} } \Syntax { \Tex {\pdfcatalog} \Something{general text} % \Optional{\Something{open-action spec}} } \Syntax { \Tex {\pdfnames} \Something{general text} } \Syntax { \Tex {\pdfmapfile} \Something{map spec} } \Syntax { \Tex {\pdfmapline} \Something{map spec} } \Syntax { \Tex {\pdffontattr} \Something{font} \Something{general text} } \Syntax { \Tex {\pdftrailer} \Something{general text} } \Syntax { \Tex {\pdffontexpand} \Something{font} \Something{expand spec} } \Syntax { \Tex {\efcode} \Something{font} \Something{8-bit number} \Whatever{integer} } \Syntax { \Tex {\lpcode} \Something{font} \Something{8-bit number} \Whatever{integer} } \Syntax { \Tex {\rpcode} \Something{font} \Something{8-bit number} \Whatever{integer} } \Syntax { \Tex {\vadjust} \Something{pre spec} \Something{filler} \Lbrace \Something{vertical material} \Rbrace \Whatever{h, m} } \Syntax { \Tex {\special} \Something{pdfspecial spec} } \stoppacked The general definitions and syntax rules are given below. \Something {general text} is expanded immediately, like \type{\special} in traditional \TEX, unless explicitly mentioned otherwise. \startpacked %%S NL %%S syntax rules: \Syntax { \Something{general text} \Means % \Lbrace \Something{balanced text} \Rbrace } \Syntax { \Something{attr spec} \Means % \Literal {attr} \Something{general text} } \Syntax { \Something{rule spec} \Means % (\Literal {width} \Or \Literal {height} \Or \Literal {depth}) % \Something{dimension} \Optional{\Something{rule spec}} } %\Syntax {\Something{object type spec} \Means % \Optional{\Literal {stream} % \Optional{\Something{attr spec}}} \Something{object contents}} \Syntax { \Something{object type spec} \Means % \Literal{reserveobjnum} \Or \Next % \Optional{\Literal{useobjnum} \Something{number}} \Next % \Optional{\Something{attr spec}} % \Optional{\Literal{stream} \Optional{\Something{attr spec}}} % \Something{object contents} } \Syntax { \Something{object contents} \Means % \Something{file spec} \Or \Something{general text} } \Syntax { \Something{xform attr spec} \Means % \Optional{\Something{attr spec}} \Optional{\Something{resources spec}} } \Syntax { \Something{resources spec} \Means % \Literal {resources} \Something{general text} } \Syntax { \Something{image attr spec} \Means % \Optional{\Something{rule spec}} % \Optional{\Something{attr spec}} % \Optional{\Something{page spec}} % \Optional{\Something{pdf box spec}} } \Syntax { \Something{outline spec} \Means % \Something{attr spec} % \Something{action spec} % \Optional{\Literal{count} \Something{number}} % \Something{general text} } \Syntax { \Something{action spec} \Means % \Literal {user} \Something{user-action spec} \Or \Literal {goto} \Something{goto-action spec} \Or \Next \Literal {thread} \Something{thread-action spec} } \Syntax { \Something{user-action spec} \Means % \Something{general text} } %HE Check: \Syntax { \Something{goto-action spec} \Means % \Something{numid} \Or \Next \Optional{\Something{file spec}} \Something{nameid} \Or \Next \Optional{\Something{file spec}} \Optional{\Something{page spec}} \Something{general text} \Or \Next \Something{file spec} \Something{nameid} \Something{newwindow spec} \Or \Next \Something{file spec} \Optional{\Something{page spec}} \Something{general text} \Something{newwindow spec} } \Syntax { \Something{thread-action spec} \Means % \Optional{\Something{file spec}} \Something{numid} \Or \Optional{\Something{file spec}} \Something{nameid} } \Syntax { \Something{open-action spec} \Means % \Literal {openaction} \Something{action spec} } \Syntax{ \Something{pdf box spec} \Means % \Literal{mediabox} % \Or \Literal{cropbox} % \Or \Literal{bleedbox} % \Or \Literal{trimbox} % \Or \Literal{artbox} } \Syntax{ \Something{map spec} \Means % \Lbrace \Optional{\Something{map modifier}} % \Something{balanced text} \Rbrace } \Syntax{ \Something{map modifier} \Means % \Literal{+} \Or \Literal{=} \Or \Literal{-} } \Syntax { \Something{numid} \Means % \Literal {num} \Something{number} } \Syntax { \Something{nameid} \Means % \Literal {name} \Something{general text} } \Syntax { \Something{newwindow spec} \Means % \Literal {newwindow} \Or \Literal {nonewwindow} } \Syntax { \Something{dest spec} \Means % \Something{numid} \Something{dest type} \Or \Something{nameid} \Something{dest type} } \Syntax { \Something{dest type} \Means % \Literal {xyz} \Optional{\Literal {zoom} \Something{number}} \Or \Literal {fitr} \Something{rule spec} \Or \Next \Literal {fitbh} \Or \Literal {fitbv} \Or \Literal {fitb} \Or \Literal {fith} \Or \Literal {fitv} \Or \Literal {fit} } \Syntax { \Something{thread spec} \Means % \Optional{\Something{rule spec}} % \Optional{\Something{attr spec}} % \Something{id spec} } \Syntax { \Something{id spec} \Means % \Something{numid} \Or \Something{nameid} } \Syntax { \Something{file spec} \Means % \Literal {file} \Something{general text} } \Syntax { \Something{page spec} \Means % \Literal {page} \Something{number} } \Syntax { \Something{expand spec} \Means % \Something{stretch} % \Something{shrink} % \Something{step} % \Optional{\Literal{autoexpand}} } \Syntax { \Something{stretch} \Means % \Something{number} } \Syntax { \Something{shrink} \Means % \Something{number} } \Syntax { \Something{step} \Means % \Something{number} } \Syntax { \Something{pdfspecial spec} \Means % \Lbrace \Optional{\Something{pdfspecial id} \Optional{\Something{pdfspecial modifier}}} % \Something{balanced text} \Rbrace } \Syntax { \Something{pdfspecial id} \Means % \Literal{pdf:} \Or \Literal{PDF:} } \Syntax { \Something{pdfspecial modifier} \Means % \Literal{direct:} } \stoppacked Some of the object and image related primitives can be prefixed by \type {\immediate}. More about that in the next sections. %*********************************************************************** \section[primitives]{New 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 file \filename {example.tex} in the \PDFTEX\ distribution. Note that if the output is \DVI\ then the \PDFTEX\ specific dimension parameters are not used at all. However some \PDFTEX\ integer parameters can affect the \DVI\ as well as \PDF\ output (currently \type{\pdfoutput} and \type{\pdfadjustspacing}). General warning: many of these new primitives, for example \type{\pdfdest} and \type{\pdfoutline}, write their arguments directly to the \PDF\ output file (when producing \PDF), as \PDF\ string constants. This means that {\em you} (or, more likely, the macros you write) must escape characters as necessary (namely \type{\}, \type{(}, and \type{)}. Otherwise, an invalid \PDF\ file may result. The \type{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. %*********************************************************************** \subsection{Document setup} \pdftexprimitive {\Syntax {\Tex {\pdfoutput} \Whatever{integer}}} \bookmark{\type{\pdfoutput}} This parameter specifies whether the output format should be \DVI\ or \PDF. A positive value means \PDF\ output, otherwise (default 0) one gets \DVI\ output. This primitive is the only one that must be set to produce \PDF\ output (unless the commandline option \type{-output-format=pdf} is used); all other primitives are optional. This parameter cannot be specified {\em after} shipping out the first page. In other words, if we want \PDF\ output, we have to set \type{\pdfoutput} before \PDFTEX\ ships out the first page. When \PDFTEX\ starts complaining about specials, one can be rather sure that a macro package is not aware of the \PDF\ mode. A simple way of making macros aware of \PDFTEX\ in \PDF\ or \DVI\ mode is: \starttyping \ifx\pdfoutput\undefined \csname newcount\endcsname\pdfoutput \fi \ifcase\pdfoutput DVI CODE \else PDF CODE \fi \stoptyping Using the \type{ifpdf.sty} file, which works with both \LATEX\ and plain \TeX, is a cleaner way of doing this. Historically, the simple test \type{\ifx\pdfoutput\undefined} was defined; but nowadays, the \PDFTEX\ engine is used in distributions even for non-\PDF\ formats (e.\,g.\ \LATEX), so \type{\pdfoutput} may be defined even when the output format is \DVI. \pdftexprimitive {\Syntax {\Tex {\pdfcompresslevel} \Whatever{integer}}} \bookmark{\type{\pdfcompresslevel}} This integer parameter specifies the level of stream compression (text, in||line graphics, and embedded \PNG\ images; all done by the \type{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 \type{\pdfcompresslevel=0} is great for \PDF\ stream debugging. \pdftexprimitive {\Syntax {\Tex {\pdfdecimaldigits} \Whatever{integer}}} \bookmark{\type{\pdfdecimaldigits}} This integer parameter specifies the numeric accuracy of real coordinates as written to the \PDF\ file. 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 file size and more time to display or print. In most cases the optimal value is~2. This parameter does not influence the precision of numbers used in raw \PDF\ code, like that used in \type{\pdfliteral} and annotation action specifications; 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 \filename {supp-pdf.tex}, one can limit the accuracy to two digits by typing: \type{\twodigitMPoutput}. \pdftexprimitive {\Syntax {\Tex {\pdfmovechars} \Whatever{integer}}} \bookmark{\type{\pdfmovechars}} This parameter specifies whether \PDFTEX\ should try to move characters in range 0..31 to higher slots. When set to~1, this feature affects only those fonts that have all character codes below~128; for instance, Computer Modern. When set to~2 or higher \PDFTEX\ will try to move those characters to free slots in encoding array, even if the font contains characters with code greater than or equal to 128. This parameter is read when \PDFTEX\ writes a character of a font to the \PDF\ output, at which moment it has to decide whether to move the character or not. \pdftexprimitive {\Syntax {\Tex {\pdfpkresolution} \Whatever{integer}}} \bookmark{\type{\pdfpkresolution}} This integer parameter specifies the default resolution of embedded \PK\ fonts and is read when \PDFTEX\ downloads a \PK\ font during finishing the \PDF\ output. As bitmap fonts are still rendered poorly by some \PDF\ viewers, it is best to use Type~1 fonts when available. \pdftexprimitive {\Syntax {\Tex {\pdfhorigin} \Whatever{dimension}}} \bookmark{\type{\pdfhorigin}} 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 \TEX's own \type{\horigin} primitive. To avoid surprises, after global magnification has been changed by the \type{\mag} primitive, the \type{\pdfhorigin} parameter should still be 1~true inch, e.\,g.\ by typing \type{\pdfhorigin=1 true in} after issuing the \type{\mag} command. Or, you can preadjust the \type{\pdfhorigin} value before typing \type{\mag}, so that its value after the \type{\mag} command ends up at 1~true inch again. \pdftexprimitive {\Syntax {\Tex {\pdfvorigin} \Whatever{dimension}}} \bookmark{\type{\pdfvorigin}} This parameter is the vertical companion of \type{\pdfhorigin}, and the notes above regarding \type{\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). \pdftexprimitive {\Syntax {\Tex {\pdfpagewidth} \Whatever{dimension}}} \bookmark{\type{\pdfpagewidth}} This dimension parameter specifies the page width of the \PDF\ output (the screen, the paper, etc.). \PDFTEX\ reads this parameter when it starts shipping out a page. After magnification has been changed by the \type{\mag} primitive, check that this parameter reflects the wished true page width. If the value is not given, the page width is calculated as $w_{\hbox{\txx box being shipped out}} + 2 \times (\hbox{horigin} + \hbox{\type{\hoffset}})$. When part of the page falls off the paper or screen, you can be rather sure that this parameter is set wrong. \pdftexprimitive {\Syntax {\Tex {\pdfpageheight} \Whatever{dimension}}} \bookmark{\type{\pdfpageheight}} Similar to the previous item, this dimension parameter specifies the page height of the \PDF\ output. If not given, the page height will be calculated analogously to the above. After magnification has been changed by the \type{\mag} primitive, check that this parameter reflects the wished true page height. \pdftexprimitive {\Syntax {\Tex {\pdfpagesattr} \Whatever{tokens}}} \bookmark{\type{\pdfpagesattr}} \PDFTEX\ expands this token list when it finishes the \PDF\ output and adds the resulting character stream to the root \type{Pages} object. When defined, these are applied to all pages in the document. Some examples of attributes are \type{/MediaBox}, the rectangle specifying the natural size of the page, \type{/CropBox}, the rectangle specifying the region of the page being displayed and printed, and \type{/Rotate}, the number of degrees (in multiples of 90) the page should be rotated clockwise when it is displayed or printed. \starttyping \pdfpagesattr { /Rotate 90 % rotate all pages by 90 degrees /MediaBox [0 0 612 792] } % the media size of all pages (in bp) \stoptyping \pdftexprimitive {\Syntax {\Tex {\pdfpageattr} \Whatever{tokens}}} \bookmark{\type{\pdfpageattr}} This is similar to \type{\pdfpagesattr}, but has priority over it. It can be used to override any attribute given by \type{\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. \subsection{The document info and catalog} \pdftexprimitive {\Syntax {\Tex {\pdfinfo} \Whatever{general text}}} \bookmark{\type{\pdfinfo}} This primitive allows the user to add information to the document info section; if this information is provided, it can be extracted by Acrobat Reader (version 3.1: menu option {\em Document Information, General}). The \Something{general text} is a collection of key||value||pairs. The key names are preceded by a \type{/}, and the values, being strings, are given between parentheses. All keys are optional. Possible keys are \type{/Author}, \type{/CreationDate} (defaults to current date including time zone info), \type{/ModDate}, \type{/Creator} (defaults to \type {TeX}), \type{/Producer} (defaults to \type{pdfTeX-1.20b}), \type{/Title}, \type{/Subject}, and \type{/Keywords}. \type{/CreationDate} and \type{/ModDate} are expressed in the form \type{D:YYYYMMDDhhmmssTZ..}, where \type{YYYY} is the year, \type{MM} is the month, \type{DD} is the day, hh is the hour, \type{mm} is the minutes, \type{ss} is the seconds, and \type{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 \type{\pdfinfo} will be concatenated. If a key is given more than once, then the first appearance will be used. An example of the use of \type{\pdfinfo} is: \starttyping \pdfinfo { /Title (example.pdf) /Creator (TeX) /Producer (pdfeTeX 1.20b) /Author (Tom and Jerry) /CreationDate (D:20050106154343+01'00') /ModDate (D:20050106155343+01'00') /Subject (Example) /Keywords (mouse, cat) } \stoptyping \pdftexprimitive {\Syntax {\Tex {\pdfcatalog} \Something{general text} \Optional{\Something{open-action spec}}}} \bookmark{\type{\pdfcatalog}} Similar to the document info section is the document catalog, where keys are \type{/URI}, which provides the base \URL\ of the document, and \type {/PageMode}, which determines how Acrobat displays the document on startup. The possibilities for the latter are explained in \in {Table} [pagemode]: \startbuffer \starttabulate[|l|l|] \HL \NC \bf value \NC \bf meaning \NC\NR \HL \NC \tt /UseNone \NC neither outline nor thumbnails visible \NC\NR \NC \tt /UseOutlines \NC outline visible \NC\NR \NC \tt /UseThumbs \NC thumbnails visible \NC\NR \NC \tt /FullScreen \NC full||screen mode \NC\NR \HL \stoptabulate \stopbuffer \placetable [here][pagemode] {Supported \type{/PageMode} values.} {\getbuffer} In full||screen mode, there is no menu bar, window controls, nor any other window present. The default setting is \type{/UseNone}. The \Something{openaction} is the action provided when opening the document and is specified in the same way as internal links, see \in {section} [linking]. Instead of using this method, one can also write the open action directly into the catalog. \pdftexprimitive {\Syntax {\Tex {\pdfnames} \Something{general text}}} \bookmark{\type{\pdfnames}} This primitive inserts the \Something{general text} to the \type {/Names} array. The text must conform to the specifications as laid down in the \PDF\ Reference Manual, otherwise the document can be invalid. \pdftexprimitive {\Syntax {\Tex {\pdftrailer} \Something{general text}}} \bookmark{\type{\pdftrailer}} This command puts its argument text verbatim into the file trailer dictionary. \pdftexprimitive {\Syntax {\Tex {\pdfoptionpdfminorversion} \Whatever{integer}}} \bookmark{\type{\pdfoptionpdfminorversion}} This primitive sets the \PDF\ version of the generated file and the latest allowed \PDF\ version of included pdfs. E.\,g., \type{\pdfoptionpdfminorversion=3} tells pdfTeX to set the \PDF\ version to 1.3 and allows only included \PDF\ files with versions numbers up to 1.3. The default for \type{\pdfoptionpdfminorversion} is 4 for \PDF\ version 1.4. If specified, this primitive must appear before any data is to be written to the generated \PDF\ file, so you should put it at the very start of your files. %*********************************************************************** \subsection{Fonts} \pdftexprimitive {\Syntax {\Tex {\pdffontexpand} \Something{font} \Something{stretch} \Something{shrink} \Something{step} \Optional{\Literal{autoexpand}}}} \bookmark{\type{\pdffontexpand}} This extension to \TEX's font definitions controls a \PDFTEX\ automatism called {\em font expansion}. We describe this by an example: \starttyping \font\somefont=somefile at 10pt \pdffontexpand\somefont 30 20 10 autoexpand \pdfadjustspacing=2 \stoptyping The \type{30 20 10} means this: \quotation {hey \TEX, when line breaking is going badly, you may stretch the glyphs in this font as much as 3\,\% or shrink them by 2\,\%}. Because \PDFTEX\ uses internal data structures with fixed widths, each additional width also means an additional font. For practical reasons \PDFTEX\ uses discrete steps, in this example, 1\,\%. This means that for font \type{somefile} up to~6 differently scaled alternatives may be used. When no step is specified, 0.5\,\% steps are used. 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 fixed steps, until the line fits. 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 {\em font expansion}. The additional expanded fonts get artificial names by adding the font expansion value to the base font name, e.\,g.\ \type{somefile+10} for 1\,\% stretch or \type {somefile-15} for 1.5\,\% shrink. If the \type{autoexpand} option is not given, \TFM\ files with these names and appropriate dimensions must be available. So, each expanded variant of a font must have its own \TFM\ file! Expanded \TFM\ names like \type{somefile+10} must not be mentioned in the map file (but the \TFM\ name of the base font without expansion must be there). When no \TFM\ file can be found, \PDFTEX\ will try to generate it by executing the script \type{mktextfm}, where available and supported. The font expansion is greatly simplified, if the \type{autoexpand} option is there. Then no expanded \TFM\ file versions are needed; instead, \PDFTEX\ generates expanded copies of the unexpanded \TFM\ data structures and keeps them in its memory. \PDFTEX\ requires only unexpanded Type~1 font files for font expansion, from which all expanded font versions are internally generated and included (subsetted) into the \PDF\ output file. To enable font expansion, don't forget to set \type{\pdfadjustspacing} to a value greater than zero. The font expansion mechanism is inspired by an optimization first 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. So, there are many, slightly different~a's, e's, 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, it's 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. \pdftexprimitive {\Syntax {\Tex {\pdfadjustspacing} \Whatever{integer}}} \bookmark{\type{\pdfadjustspacing}} The output that \PDFTEX\ produces is generally compatible with the normal \TEX\ output: \TEX's typesetting engine is normally unchanged, because the optimization described here is turned off by default. At this moment there are two methods provided. When \type{\pdfadjustspacing} is set to~1, stretching is applied {\em after} \TEX's 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 {\em 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 use the extended collection of \TFM\ files that are related to the \type{stretch} and \type{shrink} settings as described in the previous section, unless \type{\pdffontexpand} is given with the option \type{autoexpand}. \pdftexprimitive {\Syntax {\Tex {\efcode} \Something{font} \Whatever{integer}}} \bookmark{\type{\efcode}} We didn't yet tell the whole story. One can imagine that some glyphs are more sensitive to scaling than others. The \type{\efcode} primitive can be used to influence the stretchability of a glyph within a given font. The syntax is similar to \type{\sfcode} (but with the \Syntax{\Something{font}}\ required), and defaults to~1000, meaning 100\,\%. \starttyping \efcode\somefont`A=800 \efcode\somefont`O=0 \stoptyping In this example an~A may stretch 0.8~times as much as normal and the~O is not to be stretched at all. The minimum and maximum stretch is still bound by the font specification, otherwise one would end up with more possible font inclusions than would be comfortable. \pdftexprimitive {\Syntax {\Tex {\pdfprotrudechars} \Whatever{integer}}} \bookmark{\type{\pdfprotrudechars}} Yet another way of optimizing paragraph breaking is to let certain characters move into the margin. When this primitive is set to 1 (or another positive integer value), the glyphs qualified as such will make this move when applicable. This qualification and the amount of shift are set by the primitives \type{\rpcode} and \type{\lpcode}. If you want to protrude some item other than a character (e.\,g.\ a \type{\hbox}), you can do so by padding the item with an invisible zero||width character, for which protrusion is activated. \pdftexprimitive {\Syntax {\Tex {\rpcode} \Something{font} \Whatever{integer}}} \bookmark{\type{\rpcode}} The amount that a character from a given font may shift into the right margin (``character protrusion'') is set by the primitive \type {\rpcode}. The protrusion distance is the integer value given to \type {\rpcode}, multiplied with 0.001\,em from the current font. Example: \starttyping \rpcode\somefont`,=200 \rpcode\somefont`-=150 \stoptyping Here the comma may shift 0.2\,em into the margin and the hyphen 0.15\,em. All these small bits and pieces will help \PDFTEX\ to give you better paragraphs (use \type{\rpcode} judiciously; don't overdo it). Remark: old versions of \PDFTEX\ use the character width as measure. This was changed to a proportion of the em-width after \THANH\ finished his master's thesis. \pdftexprimitive {\Syntax {\Tex {\lpcode} \Something{font} \Whatever{integer}}} \bookmark{\type{\lpcode}} This is similar to \type{\rpcode}, but affects the amount by which characters may protrude into the left margin. \pdftexprimitive {\Syntax {\Tex {\pdffontname} \Something{font} \Whatever {expandable}}} \bookmark{\type{\pdffontname}} In \PDF\ files produced by \PDFTEX\ one can recognize a font resource by the prefix~\type{/F} followed by a number, for instance \type{/F12} or \type{/F54}. This command returns, for a given \TEX\ font, the number from the corresponding font resource name. E.\,g., if \type{/F12} corresponds to some \TEX\ font \type{\foo}, the \type{\pdffontname\foo} gives the number~12. In the current implementation, when \type{\pdfuniqueresname} (see below) is set to a positive value, the \type{\pdffontname} still returns only the number from the font resource name, but not the appended random string. \pdftexprimitive {\Syntax {\Tex {\pdffontobjnum} \Something{font} \Whatever {expandable}}} \bookmark{\type{\pdffontobjnum}} This command is similar to \type{\pdffontname}, but it returns the \PDF\ object number of the font dictionary instead of the number from the font resource name. E.\,g., if the font dictionary (`\type{/Type /Font}') in \PDF\ object~3 corresponds to some \TEX\ font \type{\foo}, the \type{\pdffontobjnum\foo} gives the number~3. Use of \type{\pdffontname} and \type {\pdffontobjnum} allows users full access to all the font resources used in the document. \pdftexprimitive {\Syntax {\Tex {\pdfincludechars} \Something{font} \Something{general text}}} \bookmark{\type{\pdfincludechars}} This command causes \PDFTEX\ to treat the characters in \Something{general text} as if they were used with \Something{font}\unkern, 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. \pdftexprimitive {\Syntax {\Tex {\pdfuniqueresname} \Whatever{integer}}} \bookmark{\type{\pdfuniqueresname}} 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. \pdftexprimitive {\Syntax {\Tex {\pdfmapfile} \Something{map spec}}} \bookmark{\type{\pdfmapfile}} This primitive is used for managing font map files, to make them known to \PDFTEX\ so that they can be read in. If no \type{\pdfmapfile} primitive is given, the default map file \filename{pdftex.map} will be read in by \PDFTEX. Normally there is no need for the \PDFTEX\ user to bother about the \type{\pdfmapfile} primitive, as the main \TEX\ distributions provide nice helper tools that automatically assemble the default font map file. One prominent tool example is the script \type{updmap} coming with \TETEX. The operation mode of the \type{\pdfmapfile} primitive is selected by a flag letter (\type{+}, \type{=}, \type{-}, or omitted). This flag defines how a map file is going to be handled, and how a collision between an existing 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. The companion primitive \type{\pdfmapline} allows something similar, only that a single map line for one font (instead of a map file name) is given as argument. Here are two examples: \starttyping \pdfmapfile{+myfont.map} \pdfmapline{+ptmri8r Times-Italic <8r.enc > endobj}. When \Something{object type spec} is not given, a dictionary object with contents \Something{general text} is created. When however \Something{object type spec} is given as \Something{attr spec} \Literal{stream}, the object will be created as a stream with contents \Something{general text} and additional attributes in \Something{attr spec}\unkern. When \Something{object type spec} is given as \Something{attr spec} \Literal{file}, then the \Something{general text} will be treated as a file name and its contents will be copied into the stream contents. When \Something{object type spec} is given as \type{reserveobjnum}, just a new object number is reserved. The number of the reserved object is accessible via \type{\pdflastobj}. The object can later be filled with contents by \Syntax{\Tex{\pdfobj} \Literal{useobjnum} \Something{number} \Lbrace\Something{balanced text}\Rbrace}. But the reserved object number can already before be used 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 \type{\pdfrefobj} or when \type{\pdfobj} is preceded by \type{\immediate}. Nothing is appended to the list being built. The number of the most recently created object is accessible via \type{\pdflastobj}. \pdftexprimitive {\Syntax {\Tex {\pdflastobj} \Whatever{read||only integer}}} \bookmark{\type{\pdflastobj}} This command returns the object number of the last object created by \type {\pdfobj}. \pdftexprimitive {\Syntax {\Tex {\pdfrefobj} \Something{object number}}} \bookmark{\type{\pdfrefobj}} This command appends a whatsit node to the list being built. When the whatsit node is searched at shipout time, \PDFTEX\ will write the object \Something{object number} to the \PDF\ output if it has not been written yet. %*********************************************************************** \subsection{XObject forms} The next three primitives support a \PDF\ feature called \quote {object reuse} in \PDFTEX. The idea is first to create a XObject form in \PDF. The content of this object corresponds to the content of a \TEX\ box; it can contain pictures and references to other XObject form objects as well. After creation, the XObject form can be used by simply referring to its object number. This feature can be useful for large documents with many similar elements, as it can reduce the duplication of identical objects. These command behave similarly to \type{\pdfobj}, \type{\pdflastobj} and \type{\pdfrefobj} but instead of taking raw \PDF\ code, they handle text typeset by \TEX. \pdftexprimitive {\Syntax {\Tex {\pdfxform} \Optional{\Something{attr spec}} \Optional{\Something{resources spec}} \Something{box number}}} \bookmark{\type{\pdfxform}} This command creates a XObject form corresponding to the contents of the box \Something{box number}. The box can contain other raw objects, XObject forms or images as well. It can however {\em not} contain annotations because they are laid out on a separate layer, are positioned absolutely, and have dedicated housekeeping. \type{\pdfxform} makes the box void, as \type{\box} does. When \Something{attr spec} is given, the text will be written as additional attributes of the form. The \Something{resources spec} is similar, but the text will be added to the resources dictionary of the form. The text given by \Something{attr spec} or \Something{resources spec} is written before other keys of the form dictionary and|/|or the resources dictionary and takes priority over later ones. \pdftexprimitive {\Syntax {\Tex {\pdfrefxform} \Something{object number}}} \bookmark{\type{\pdfrefxform}} The form is kept in memory and will be written to the \PDF\ output only when its number is referred to by \type{\pdfrefxform} or \type{\pdfxform} is preceded by \type{\immediate}. Nothing is appended to the list being built. The number of the most recently created XObject form is accessible via \type {\pdflastxform}. When issued, \type{\pdfrefxform} appends a whatsit node to the list being built. When the whatsit node is searched at shipout time, \PDFTEX\ will write the form \Something{object number} to the \PDF\ output if it is not written yet. \pdftexprimitive {\Syntax {\Tex {\pdflastxform}} \Whatever{read||only integer}} \bookmark{\type{\pdflastxform} \Whatever{read||only integer}} The number of the most recently created XObject form is accessible via \type {\pdflastxform}. As said, this feature can be used for reusing information. This mechanism also plays a role in typesetting fill||in forms. Such widgets sometimes depends on visuals that show up on user request, but are hidden otherwise. %*********************************************************************** \subsection{Graphics inclusion} \PDF\ provides a mechanism for embedding graphic and textual objects: XObject forms. In \PDFTEX\ this mechanism is accessed by means of \type{\pdfxform}, \type{\pdflastxform} and \type{\pdfrefxform}. A special kind of XObjects are bitmap graphics and for manipulating them similar commands are provided. \pdftexprimitive {\Syntax { \Tex {\pdfximage} \Optional{\Something{rule spec}} \Optional{\Something{attr spec}} \Optional{\Something{page spec}} \Something{file spec} }} \bookmark{\type{\pdfximage}} This command creates an image object. The dimensions of the image can be controlled via \Something{rule spec}\unkern. The default values are zero for depth and \quote {running} for height and width. If all of them are given, the image will be scaled to fit the specified 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 \type {\pdfimageresolution} (see below) given in dots per inch in the output file, 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 \type{\pdfrefximage} command to a box and checking the dimensions of the box: \starttyping \setbox0=\hbox{\pdfximage{somefile.png}\pdfrefximage\pdflastximage} \stoptyping Now we can use \type{\wd0} and \type{\ht0} to question the natural size of the image as determined by \PDFTEX. When dimensions are specified before the \type{{somefile.png}}, the graphic is scaled to fit these. Note that, unlike the e.\,g.\ \type{\input} primitive, the filename is supplied between braces. The image type is specified by the extension of the given file name: \type {.png} stands for \PNG\ image, \type{.jpg} for \JPEG, and \type{.pdf} for \PDF\ file. But once \PDFTEX\ has opened the file, it checks the file type first by looking to the magic number at the file start, which gets precedence over the file name extension. This gives a certain degree of fault tolerance, if the file name extension is stated wrongly. Similarly to \type{\pdfxform}, the optional text given by \Something{attr spec} will be written as additional attributes of the image before other keys of the image dictionary. \pdftexprimitive {\Syntax {\Tex {\pdfrefximage} \Something{integer}}} \bookmark{\type{\pdfrefximage}} The image is kept in memory and will be written to the \PDF\ output only when its number is referred to by \type{\pdfrefximage} or \type{\pdfximage} is preceded by \type{\immediate}. Nothing is appended to the list being built. \type{\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 \Something{integer} to the \PDF\ output if it has not been written yet. \pdftexprimitive {\Syntax {\Tex {\pdflastximage} \Whatever{read||only integer}}} \bookmark{\type{\pdflastximage}} The number of the most recently created XObject image is accessible via \type {\pdflastximage}. \pdftexprimitive {\Syntax {\Tex {\pdflastximagepages} \Whatever{read||only integer}}} \bookmark{\type{\pdflastximagepages}} This read||only register returns the highest page number from a file previously accessed via the \type{\pdfximage} command. This is useful only for \PDF\ files; it always returns `1' for \PNG\ or \JPEG\ files. \pdftexprimitive {\Syntax {\Tex {\pdfimageresolution} \Whatever{integer}}} \bookmark{\type{\pdfimageresolution}} The integer \type{\pdfimageresolution} parameter (unit: dots per inch, dpi) is a last resort value, used only for bitmap (\JPEG, \PNG) images, but not for \PDF{}s. The priorities are as follows: Often one image dimension (\type{width} or \type{height}) is stated explicitely in the \TEX\ file. 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\ file, 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 file. If one of these resolution values is missing or weird (either $<$~0 or $>$~65535), the \type{\pdfimageresolution} value will be used for both $x$ and $y$ resolution, when calculating the image size. And if the \type{\pdfimageresolution} is zero, finally a default resolution of 72\,dpi would be taken. The \type{\pdfimageresolution} is read when \PDFTEX\ creates an image via \type{\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\ files are currently ignored. \pdftexprimitive {\Syntax {\Tex {\pdfoptionalwaysusepdfpagebox} \Whatever{integer}}} \bookmark{\type{\pdfoptionalwaysusepdfpagebox}} %- It is now possible to specify the pdf page box to use when including pdfs. % The syntax has been extended: % \pdfximage [] (h, v, m) % --> [] [] [] [] % --> mediabox|cropbox|bleedbox|trimbox|artbox % The default is cropbox (which defaults to mediabox), to be compatible with % previous versions of pdfTeX. % The page box specified at \pdfximage can be globally overridden with the % config parameter always_use_pdfpagebox and the command % \pdfoptionalwaysusepdfpagebox , where 0 is the default (use whatever % is specified with \pdfximage), 1 is media, 2 is crop, 3 is bleed, 4 is trim % and 5 is artbox. This can only be set once per object, i.\,e.\ the value used at % \pdfximage is remembered. % See the pdf reference for an explanation of the boxes. When \PDF\ files are included, the command \type{\pdfximage} allows selection of which \PDF\ page box to use in the optional field \Something{image attr spec}\unkern. The integer primitive \type{\pdfoptionalwaysusepdfpagebox} 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. \pdftexprimitive {\Syntax {\Tex {\pdfoptionpdfinclusionerrorlevel} \Whatever{integer}}} \bookmark{\type{\pdfoptionpdfinclusionerrorlevel}} This controls the behaviour of \PDFTEX\ when a \PDF\ file is included that has a newer version than the one specified by this primitive: If it is set to 0, \pdfTeX\ gives only a warning; if it's 1, \pdfTeX\ raises an error. %*********************************************************************** \subsection{Annotations} \PDF\ level 1.4 provides four basic kinds of annotations: \startitemize[packed] \item hyperlinks, general navigation \item text clips (notes) \item movies \item sound fragments \stopitemize The first 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. \pdftexprimitive {\Syntax {\Tex {\pdfannot} \Optional{\Something{rule spec}} \Something{general text}}} \bookmark{\type{\pdfannot}} This command appends a whatsit node corresponding to an annotation to the list being built. The dimensions of the annotation can be controlled via the \Something{rule spec}. The default values are running for all width, height and depth. When an annotation is written out, running dimensions will take the corresponding values from the box containing the whatsit node representing the annotation. The \Something{general text} is inserted as raw \PDF\ code to the contents of annotation. The annotation is written out only if the corresponding whatsit node is searched at shipout time. \pdftexprimitive {\Syntax {\Tex {\pdflastannot} \Whatever{read||only integer}}} \bookmark{\type{\pdflastannot}} This primitive returns the object number of the last annotation created by \type{\pdfannot}. These two primitives allow users to create any annotation that cannot be created by \type{\pdfstartlink} (see below). \subsection[linking]{Destinations and links} The first type of annotation, mentioned above, is implemented by three primitives. The first one is used to define a specific location as being referred to. This location is tied to the page, not the exact location on the page. The main reason for this is that \PDF\ maintains a dedicated list of these annotations |<|and some more when optimized|>| for the sole purpose of speed. \pdftexprimitive {\Syntax {\Tex {\pdfdest} \Something{dest spec}}} \bookmark{\type{\pdfdest}} This primitive appends a whatsit node which establishes a destination for links and bookmark outlines; the link is identified by either a number or a symbolic name, and the way the viewer is to display the page must be specified in \Something{dest type}\unkern, which must be one of those mentioned in \in{table}[appearance]. \startbuffer \starttabulate[|l|l|] \HL \NC \bf keyword \NC \bf meaning \NC\NR \HL \NC \tt fit \NC fit the page in the window \NC\NR \NC \tt fith \NC fit the width of the page \NC\NR \NC \tt fitv \NC fit the height of the page \NC\NR \NC \tt fitb \NC fit the \quote{Bounding Box} of the page \NC\NR \NC \tt fitbh \NC fit the width of \quote{Bounding Box} of the page \NC\NR \NC \tt fitbv \NC fit the height of \quote{Bounding Box} of the page \NC\NR \NC \tt xyz \NC goto the current position (see below) \NC\NR \HL \stoptabulate \stopbuffer \placetable [here][appearance] {Options for display of outline and destinations.} {\getbuffer} The specification \Literal {xyz} can optionally be followed by \Literal {zoom} \Something{integer} to provide a fixed zoom||in. The \Something {integer} is processed like \TEX\ magnification, i.\,e.\ 1000 is the normal page view. When \Literal {zoom} \Something{integer} is given, the zoom factor changes to number, otherwise the current zoom factor is kept unchanged. The destination is written out only if the corresponding whatsit node is searched at shipout time. \pdftexprimitive {\Syntax {\Tex {\pdfstartlink} \Optional{\Something{rule spec}} \Optional{\Something{attr spec}} \Something{action spec}}} \bookmark{\type{\pdfstartlink}} This primitive is used along with \type{\pdfendlink} and appends a whatsit node corresponding to the start of a hyperlink. The whatsit node representing the end of the hyperlink is created by \type{\pdfendlink}. The dimensions of the link are handled in the similar way as in \type{\pdfannot}. Both \type {\pdfstartlink} and \type{\pdfendlink} must be in the same level of box nesting. A hyperlink with running width can be multi||line or even multi||page, in which case all horizontal boxes with the same nesting level as the boxes containing \type{\pdfstartlink} and \type{\pdfendlink} will be treated as part of the hyperlink. The hyperlink is written out only if the corresponding whatsit node is searched at shipout time. Additional attributes, which are explained in great detail in the \PDF\ Reference Manual, can be given via \Something{attr spec}\unkern. Typically, the attributes specify the color and thickness of any border around the link. Thus \typ {/C [0.9 0 0] /Border [0 0 2]} specifies 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 {\em not} obey transformations issued by \type {\pdfliteral}'s. The \Something{action spec} specifies the action that should be performed when the hyperlink is activated while the \Something{user-action spec} performs a user||defined action. A typical use of the latter is to specify a \URL, like \typ {/S /URI /URI (http://www.tug.org/)}, or a named action like \typ {/S /Named /N /NextPage}. A \Something{goto-action spec} performs a GoTo action. Here \Something {numid} and \Something{nameid} specify the destination identifier (see below). The \Something{page spec} specifies the page number of the destination, in this case the zoom factor is given by \Something{general text}\unkern. A destination can be performed in another \PDF\ file by specifying \Something{file spec}\unkern, in which case \Something{newwindow spec} specifies whether the file should be opened in a new window. A \Something{file spec} can be either a \type{(string)} or a \type{<>}. The default behaviour of the \Something{newwindow spec} depends on the browser setting. A \Something{thread-action spec} performs an article thread reading. The thread identifier is similar to the destination identifier. A thread can be performed in another \PDF\ file by specifying a \Something{file spec}\unkern. \pdftexprimitive {\Syntax {\Tex {\pdfendlink}}} \bookmark{\type{\pdfendlink}} This primitive ends a link started with \type{\pdfstartlink}. All text between \type{\pdfstartlink} and \type{\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. \pdftexprimitive {\Syntax {\Tex {\pdflinkmargin} \Whatever{dimension}}} \bookmark{\type{\pdflinkmargin}} This dimension parameter specifies the margin of the box representing a hyperlink and is read when a page containing hyperlinks is shipped out. \pdftexprimitive {\Syntax {\Tex {\pdfdestmargin} \Whatever{dimension}}} \bookmark{\type{\pdfdestmargin}} Margin added to the dimensions of the rectangle around the destinations. %*********************************************************************** \subsection{Bookmarks} \pdftexprimitive {\Syntax {\Tex {\pdfoutline} \Something{action spec} \Optional{\Literal {count} \Something{integer}} \Something{general text}}} \bookmark{\type{\pdfoutline}} This primitive creates an outline (or bookmark) entry. The first parameter specifies the action to be taken, and is the same as that allowed for \type {\pdfstartlink}. The \Something{count} specifies 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 specifies the number of subentries. The \Something{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. %*********************************************************************** \subsection{Article threads} \pdftexprimitive {\Syntax {\Tex {\pdfthread} \Something{rule spec} \Optional {\Something{attr spec}} \Something{id spec}}} \bookmark{\type{\pdfthread}} Defines a bead within an article thread. Thread beads with same identifiers (spread across the document) will be joined together. \pdftexprimitive {\Syntax {\Tex {\pdftstarthread} \Something{rule spec} \Optional {\Something{attr spec}} \Something{id spec}}} \bookmark{\type{\pdfstartthread}} This uses the same syntax as \type{\pdfthread}, apart that it must be followed by a \type{\pdfendthread}. \type{\pdfstartthread} and the corresponding \type{\pdfendthread} must end up in vboxes with the same nesting level; all vboxes between them will be added into the thread. Note that during output runtime if there are other newly created boxes which have the same nesting level as the vbox/vboxes containing \type{\pdfstartthread} and \type{\pdfendthread}, they will be also added into the thread, which is probably not what you want. To avoid such unconsidered behaviour, it's often enough to wrap boxes that shouldn't belong to the thread by a box to change their box nesting level. \pdftexprimitive {\Syntax {\Tex {\pdfendthread}}} \bookmark{\t