123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873 |
- % === BEGIN ps-print prologue 1
- % version: 6.1
- % Copyright (C) 2000-2012 Free Software Foundation, Inc.
- % This file is part of GNU Emacs.
- % GNU Emacs is free software: you can redistribute it and/or modify
- % it under the terms of the GNU General Public License as published by
- % the Free Software Foundation, either version 3 of the License, or
- % (at your option) any later version.
- % GNU Emacs is distributed in the hope that it will be useful,
- % but WITHOUT ANY WARRANTY; without even the implied warranty of
- % MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- % GNU General Public License for more details.
- % You should have received a copy of the GNU General Public License
- % along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>.
- % As a special exception, the copyright holders of this module give
- % you permission to include the module in a Postscript file generated
- % by Emacs or other free software together with the result of
- % converting text to be printed, regardless of the license terms of
- % that text, and to use under terms of your choice the page images
- % resulting from formatting said combination. If you modify this
- % module, you may extend this exception to your version of the module
- % but you are not obligated to do so. If you do not wish to do so,
- % delete this exception statement from your version.
- % ISOLatin1Encoding stolen from ps_init.ps in GhostScript 2.6.1.4:
- /ISOLatin1Encoding where{pop}{
- % -- The ISO Latin-1 encoding vector isn't known, so define it.
- % -- The first half is the same as the standard encoding,
- % -- except for minus instead of hyphen at code 055.
- /ISOLatin1Encoding
- StandardEncoding 0 45 getinterval aload pop
- /minus
- StandardEncoding 46 82 getinterval aload pop
- %*** NOTE: the following are missing in the Adobe documentation,
- %*** but appear in the displayed table:
- %*** macron at 0225, dieresis at 0230, cedilla at 0233, space at 0240.
- % 0200 (128)
- /.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef
- /.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef
- /dotlessi/grave/acute/circumflex/tilde/macron/breve/dotaccent
- /dieresis/.notdef/ring/cedilla/.notdef/hungarumlaut/ogonek/caron
- % 0240 (160)
- /space/exclamdown/cent/sterling
- /currency/yen/brokenbar/section
- /dieresis/copyright/ordfeminine/guillemotleft
- /logicalnot/hyphen/registered/macron
- /degree/plusminus/twosuperior/threesuperior
- /acute/mu/paragraph/periodcentered
- /cedilla/onesuperior/ordmasculine/guillemotright
- /onequarter/onehalf/threequarters/questiondown
- % 0300 (192)
- /Agrave/Aacute/Acircumflex/Atilde
- /Adieresis/Aring/AE/Ccedilla
- /Egrave/Eacute/Ecircumflex/Edieresis
- /Igrave/Iacute/Icircumflex/Idieresis
- /Eth/Ntilde/Ograve/Oacute
- /Ocircumflex/Otilde/Odieresis/multiply
- /Oslash/Ugrave/Uacute/Ucircumflex
- /Udieresis/Yacute/Thorn/germandbls
- % 0340 (224)
- /agrave/aacute/acircumflex/atilde
- /adieresis/aring/ae/ccedilla
- /egrave/eacute/ecircumflex/edieresis
- /igrave/iacute/icircumflex/idieresis
- /eth/ntilde/ograve/oacute
- /ocircumflex/otilde/odieresis/divide
- /oslash/ugrave/uacute/ucircumflex
- /udieresis/yacute/thorn/ydieresis
- 256 packedarray def
- }ifelse
- /reencodeFontISO{ %def
- dup
- length 12 add dict % Make a new font (a new dict the same size
- % as the old one) with room for our new symbols.
- begin % Make the new font the current dictionary.
- % Copy each of the symbols from the old dictionary
- % to the new one except for the font ID.
- {1 index/FID ne{def}{pop pop}ifelse}forall
- % Override the encoding with the ISOLatin1 encoding.
- currentdict/FontType get 0 ne{/Encoding ISOLatin1Encoding def}if
- % Use the font's bounding box to determine the ascent, descent,
- % and overall height; don't forget that these values have to be
- % transformed using the font's matrix.
- % ^ (x2 y2)
- % | |
- % | v
- % | +----+ - -
- % | | | ^
- % | | | | Ascent (usually > 0)
- % | | | |
- % (0 0) -> +--+----+-------->
- % | | |
- % | | v Descent (usually < 0)
- % (x1 y1) --> +----+ - -
- currentdict/FontType get 0 ne
- {/FontBBox load aload pop % -- x1 y1 x2 y2
- FontMatrix transform/Ascent exch def pop
- FontMatrix transform/Descent exch def pop}
- {/PrimaryFont FDepVector 0 get def
- PrimaryFont/FontBBox get aload pop
- PrimaryFont/FontMatrix get transform/Ascent exch def pop
- PrimaryFont/FontMatrix get transform/Descent exch def pop}ifelse
- /FontHeight Ascent Descent sub def % use `sub' because descent < 0
- % Define these in case they're not in the FontInfo
- % (also, here they're easier to get to).
- /UnderlinePosition Descent 0.70 mul def
- /OverlinePosition Descent UnderlinePosition sub Ascent add def
- /StrikeoutPosition Ascent 0.30 mul def
- /LineThickness FontHeight 0.05 mul def
- /Xshadow FontHeight 0.08 mul def
- /Yshadow FontHeight -0.09 mul def
- /SpaceBackground Descent neg UnderlinePosition add def
- /XBox Descent neg def
- /YBox LineThickness 0.7 mul def
- currentdict % Leave the new font on the stack
- end % Stop using the font as the current dictionary.
- definefont % Put the font into the font dictionary
- pop % Discard the returned font.
- }bind def
- % Font definition
- /DefFont{findfont exch scalefont reencodeFontISO}def
- % Font selection
- /F{
- findfont
- dup/Ascent get/Ascent exch def
- dup/Descent get/Descent exch def
- dup/FontHeight get/FontHeight exch def
- dup/UnderlinePosition get/UnderlinePosition exch def
- dup/OverlinePosition get/OverlinePosition exch def
- dup/StrikeoutPosition get/StrikeoutPosition exch def
- dup/LineThickness get/LineThickness exch def
- dup/Xshadow get/Xshadow exch def
- dup/Yshadow get/Yshadow exch def
- dup/SpaceBackground get/SpaceBackground exch def
- dup/XBox get/XBox exch def
- dup/YBox get/YBox exch def
- setfont
- }def
- /FG/setrgbcolor load def
- /bg false def
- /BG{
- dup/bg exch def
- {[4 1 roll]}
- {[1.0 1.0 1.0]}
- ifelse
- /bgcolor exch def
- }def
- % B width C
- % +-----------+
- % | Ascent (usually > 0)
- % A + +
- % | Descent (usually < 0)
- % +-----------+
- % E width D
- /dobackground{ % width --
- currentpoint % -- width x y
- gsave
- newpath
- moveto % A (x y)
- 0 Ascent rmoveto % B
- dup 0 rlineto % C
- 0 Descent Ascent sub rlineto % D
- neg 0 rlineto % E
- closepath
- FillBgColor
- grestore
- }def
- /eolbg{ % dobackground until right margin
- PrintWidth % -- x-eol
- currentpoint pop % -- cur-x
- sub % -- width until eol
- dobackground
- }def
- /LineHS LineHeight LineSpacing add def
- /ParagraphHS LineHeight ParagraphSpacing add def
- /PSL{/h exch def bg{eolbg}if 0 currentpoint exch pop h sub moveto}def
- /PLN{PrintLineNumber{doLineNumber}if}def
- /SL{LineHS PSL isLineStep pop}def % Soft Linefeed
- /PHL{ParagraphHS PSL PLN}def % Paragraph Hard Linefeed
- /LHL{LineHS PSL PLN}def % Hard Linefeed
- % Some debug
- /dcp{currentpoint exch 40 string cvs print(, )print =}def
- /dp{print 2 copy exch 40 string cvs print(, )print =}def
- /W{
- ( )stringwidth % Get the width of a space in the current font.
- pop % Discard the Y component.
- mul % Multiply the width of a space
- % by the number of spaces to plot
- bg{dup dobackground}if
- 0 rmoveto
- }def
- /Effect 0 def
- /EffectUnderline false def
- /EffectStrikeout false def
- /EffectOverline false def
- /EffectShadow false def
- /EffectBox false def
- /EffectOutline false def
- % effect: 1 - underline 2 - strikeout 4 - overline
- % 8 - shadow 16 - box 32 - outline
- /EF{
- /Effect exch def
- /EffectUnderline Effect 1 and 0 ne def
- /EffectStrikeout Effect 2 and 0 ne def
- /EffectOverline Effect 4 and 0 ne def
- /EffectShadow Effect 8 and 0 ne def
- /EffectBox Effect 16 and 0 ne def
- /EffectOutline Effect 32 and 0 ne def
- }def
- % stack: string |- --
- /S{
- /xx currentpoint dup Descent add/yy exch def
- Ascent add/YY exch def def
- dup stringwidth pop xx add/XX exch def
- EffectShadow{
- /yy yy Yshadow add def
- /XX XX Xshadow add def
- }if
- bg{
- true
- EffectBox
- {SpaceBackground doBox}
- {xx yy XX YY doRect}
- ifelse
- }if % background
- EffectBox {false 0 doBox}if % box
- EffectShadow {dup doShadow}if % shadow
- EffectOutline
- {true doOutline} % outline
- {show} % normal text
- ifelse
- EffectUnderline{UnderlinePosition Hline}if % underline
- EffectStrikeout{StrikeoutPosition Hline}if % strikeout
- EffectOverline {OverlinePosition Hline}if % overline
- }bind def
- % stack: position |- --
- /Hline{
- currentpoint exch pop add dup
- gsave
- newpath
- xx exch moveto
- XX exch lineto
- closepath
- LineThickness setlinewidth stroke
- grestore
- }bind def
- % stack: fill-or-not delta |- --
- /doBox{
- /dd exch def
- xx XBox sub dd sub yy YBox sub dd sub
- XX XBox add dd add YY YBox add dd add
- doRect
- }bind def
- % stack: fill-or-not lower-x lower-y upper-x upper-y |- --
- /doRect{
- /rYY exch def
- /rXX exch def
- /ryy exch def
- /rxx exch def
- gsave
- newpath
- rXX rYY moveto
- rxx rYY lineto
- rxx ryy lineto
- rXX ryy lineto
- closepath
- % top of stack: fill-or-not
- {FillBgColor}
- {LineThickness setlinewidth stroke}ifelse
- grestore
- }bind def
- % stack: string |- --
- /doShadow{
- gsave
- Xshadow Yshadow rmoveto
- false doOutline
- grestore
- }bind def
- /st 1 string def
- % stack: string fill-or-not |- --
- /doOutline{
- /-fillp- exch def
- /-ox- currentpoint/-oy- exch def def
- gsave
- LineThickness setlinewidth
- {st 0 3 -1 roll put
- st dup true charpath
- -fillp- {gsave FillBgColor grestore}if
- stroke stringwidth
- -oy- add/-oy- exch def
- -ox- add/-ox- exch def
- -ox- -oy- moveto
- }forall
- grestore
- -ox- -oy- moveto
- }bind def
- % stack: --
- /FillBgColor{bgcolor aload pop setrgbcolor fill}bind def
- % stack: -- |- boolean
- /isLineStep{
- SyncLineZebra
- {PLScounter 0 gt % or zebra
- {/PLScounter PLScounter 1 sub def PLScounter 0 eq}
- {false}ifelse
- PrintLineStep 1 gt
- {/PrintLineStep PrintLineStep 1 sub def}
- {/PrintLineStep ZebraHeight def
- /PLScounter PrintLineStart def}ifelse}
- {LineNumber PrintLineStart sub PrintLineStep mod 0 eq}ifelse % or line step
- }def
- % stack: --
- /doLineNumber{
- /LineNumber where
- {pop
- isLineStep % or line step
- LineNumber Lines ge or % or last line
- {currentfont
- gsave
- LineNumberColor SetColor
- /L0 findfont setfont
- LineNumber Lines ge
- {(end )}
- {LineNumber 6 string cvs( )strcat}ifelse
- dup stringwidth pop neg 0 rmoveto
- show
- grestore
- setfont}if
- /LineNumber LineNumber 1 add def
- }if
- }def
- % stack: color-specifier |- --
- /SetColor{dup type/realtype eq{setgray}{aload pop setrgbcolor}ifelse}def
- % stack: --
- /printZebra{
- gsave
- ZebraColor SetColor
- /double-zebra ZebraHeight ZebraHeight add def
- /yiter double-zebra LineHS mul neg def
- /xiter PrintWidth InterColumn add def
- /zebra-line LinesPrinted def
- NumberOfColumns{LinesPerColumn doColumnZebra xiter 0 rmoveto}repeat
- grestore
- }def
- % stack: lines-per-column |- --
- /doColumnZebra{
- /lpc exch def
- gsave
- ZebraFollow 1 and 0 ne{
- /H ZebraHeight zebra-line ZebraHeight mod sub def
- /lpc lpc H sub def
- zebra-line double-zebra mod ZebraHeight lt
- {H doZebra % "black" stripe followed by a "white" stripe
- /lpc lpc ZebraHeight sub def
- H ZebraHeight add}
- {H}ifelse % "white" stripe
- LineHS mul neg 0 exch rmoveto
- /zebra-line zebra-line LinesPerColumn add def
- }if
- /zspacing 0 def
- lpc dup double-zebra idiv{ZebraHeight doZebra 0 yiter rmoveto}repeat
- double-zebra mod dup 0 le{pop}
- {dup ZebraHeight gt
- {pop ZebraHeight}
- {/zspacing LineSpacing def
- ZebraFollow 2 and 0 ne{pop ZebraHeight}if}ifelse
- doZebra}ifelse
- grestore
- }def
- % stack: zebra-height (in lines) |- --
- /doZebra{
- /zh exch 0.05 sub LineHS mul zspacing sub def
- gsave
- 0 LineHeight 0.65 mul rmoveto
- PrintWidth 0 rlineto
- 0 zh neg rlineto
- PrintWidth neg 0 rlineto
- 0 zh rlineto
- fill
- grestore
- }def
- % stack: --
- /printBackground{
- /BackgroundColor where{
- /LHg LineHeight 0.65 mul def
- /PHg PrintHeight LHg add def
- pop gsave BackgroundColor SetColor
- NumberOfColumns{
- gsave
- 0 LHg rmoveto
- PrintWidth 0 rlineto
- 0 PHg neg rlineto
- PrintWidth neg 0 rlineto
- 0 PHg rlineto
- fill
- grestore
- PrintWidth InterColumn add 0 rmoveto
- }repeat
- grestore
- }if
- }def
- % tx ty rotation xscale yscale xpos ypos BeginBackImage
- /BeginBackImage{
- /-save-image- save def
- /showpage{}def
- translate
- scale
- rotate
- translate
- }def
- /EndBackImage{-save-image- restore}def
- % string fontsize fontname rotation gray xpos ypos ShowBackText
- /ShowBackText{
- gsave
- translate
- setgray
- rotate
- findfont exch dup/-offset- exch -0.25 mul def scalefont setfont
- 0 -offset- moveto
- /-saveLineThickness- LineThickness def
- /LineThickness 1 def
- false doOutline
- /LineThickness -saveLineThickness- def
- grestore
- }def
- /SetPageSize{
- BMark/PageSize[PageWidth LandscapePageHeight LandscapeMode{exch}if]EMark setpagedevice
- }def
- /BeginDoc{
- % ---- Remember space width of the normal text font `f0'.
- /SpaceWidth/f0 findfont setfont( )stringwidth pop def
- % ---- save the state of the document (useful for ghostscript!)
- /docState save def
- % ---- [andrewi] set PageSize based on chosen dimensions
- UseSetpagedevice{
- WarnPaperSize{SetPageSize}{mark{SetPageSize}stopped cleartomark}ifelse
- }if
- /ColumnWidth PrintWidth InterColumn add def
- % ---- define where printing will start
- /f0 F % this installs Ascent
- /PrintStartY PrintHeight Ascent sub def
- /ColumnIndex 1 def
- /N-Up-Counter N-Up-End 1 sub def
- /PLScounter PrintLineStart def
- }def
- /EndDoc{
- % ---- restore the state of the document (useful for ghostscript!)
- docState restore
- }def
- /BeginDSCPage{
- % ---- when 1st column, save the state of the page
- ColumnIndex 1 eq{/pageState save def}if
- % ---- save the state of the column
- /columnState save def
- }def
- /PrintHeaderWidth PrintOnlyOneHeader{PrintPageWidth}{PrintWidth}ifelse def
- /BeginPage{
- /LinesPrinted exch def
- % ---- when 1st column, print all background effects
- ColumnIndex 1 eq{
- 0 PrintStartY moveto % move to where printing will start
- printBackground
- Zebra{printZebra}if
- printGlobalBackground
- printLocalBackground
- }if
- PrintOnlyOneHeader{ColumnIndex 1 eq}{true}ifelse
- dup PrintHeader and{
- PrintHeaderFrame{HeaderFrame}if
- HeaderText
- }if
- PrintFooter and{
- PrintFooterFrame{FooterFrame}if
- FooterText
- }if
- 0 PrintStartY moveto % move to where printing will start
- /LineNumber where
- {pop
- SyncLineZebra
- {/H PageNumber 1 sub NumberOfColumns mul ColumnIndex 1 sub add
- LinesPerColumn mul ZebraHeight mod def
- /PLScounter H PrintLineStart ge{0}{PrintLineStart H sub}ifelse def
- /PrintLineStep ZebraHeight H sub def}if}if
- PLN
- }def
- /EndPage{bg{eolbg}if}def
- /EndDSCPage{
- ColumnIndex NumberOfColumns eq{
- % ---- restore the state of the page
- pageState restore
- /ColumnIndex 1 def
- % ---- N-up printing
- N-Up 1 gt{
- N-Up-Counter 0 gt
- {% ---- Next page on same row
- /N-Up-Counter N-Up-Counter 1 sub def
- N-Up-XColumn N-Up-YColumn}
- {% ---- Next page on next line
- /N-Up-Counter N-Up-End 1 sub def
- N-Up-XLine N-Up-YLine}ifelse
- translate
- }if
- }{ % else
- % ---- restore the state of the current column
- columnState restore
- % ---- and translate to the next column
- ColumnWidth 0 translate
- /ColumnIndex ColumnIndex 1 add def
- }ifelse
- }def
- /TextStart{
- LeftMargin BottomMargin
- PrintFooter{
- FooterPad add
- FooterLines FooterLineHeight mul add
- FooterPad add
- FooterOffset add}if
- }def
- % stack: number-of-pages-per-sheet |- --
- /BeginSheet{
- /sheetState save def
- /pages-per-sheet exch def
- % ---- translate to bottom-right corner of Portrait page
- LandscapeMode{
- LandscapePageHeight 0 translate
- 90 rotate
- }if
- % ---- [jack] Kludge: my ghostscript window is 21x27.7 instead of 21x29.7
- /JackGhostscript where{pop 1 27.7 29.7 div scale}if
- UpsideDown{PageWidth LandscapePageHeight translate 180 rotate}if
- % ---- N-Up printing
- N-Up 1 gt{
- % ---- landscape
- N-Up-Landscape{
- PageWidth 0 translate
- 90 rotate
- }if
- N-Up-Margin dup translate
- % ---- scale
- LandscapeMode{
- /HH PageWidth def
- /WW LandscapePageHeight def
- }{
- /HH LandscapePageHeight def
- /WW PageWidth def
- }ifelse
- /xx 0 def
- N-Up-Landscape{
- /ww WW WW mul N-Up-Lines HH mul div def
- /cc HH N-Up-Columns N-Up-Missing add div def
- ww cc gt{/xx WW def/WW cc ww div WW mul def/xx xx WW sub def}if
- }{
- /hh HH N-Up-Columns N-Up-Missing add div def
- /cc HH N-Up-Lines div def
- hh cc gt{/xx WW def/WW cc hh div WW mul def/xx xx WW sub def}if
- }ifelse
- WW N-Up-Margin sub N-Up-Margin sub
- N-Up-Landscape
- {N-Up-Lines div HH}
- {N-Up-Columns N-Up-Missing add div WW}ifelse
- div dup scale
- LandscapeMode{/yy 0 def}{/yy xx def/xx 0 def}ifelse
- xx N-Up-Repeat 1 sub LandscapePageHeight mul yy add translate
- % ---- go to start position in page matrix
- N-Up-XStart N-Up-Missing 0.5 mul
- LandscapeMode
- {LandscapePageHeight mul N-Up-YStart add}
- {PageWidth mul add N-Up-YStart}ifelse
- translate
- }if
- % ---- translate to lower left corner of TEXT
- TextStart translate
- % ---- N-up printing
- N-Up 1 gt N-Up-Border and pages-per-sheet 0 gt and{
- % ---- page border
- gsave
- 0 setgray
- TextStart exch neg exch neg moveto
- N-Up-Repeat
- {N-Up-End
- {gsave
- PageWidth 0 rlineto
- 0 LandscapePageHeight rlineto
- PageWidth neg 0 rlineto
- closepath stroke
- grestore
- /pages-per-sheet pages-per-sheet 1 sub def
- pages-per-sheet 0 le{exit}if
- N-Up-XColumn N-Up-YColumn rmoveto
- }repeat
- pages-per-sheet 0 le{exit}if
- N-Up-XLine N-Up-XColumn sub N-Up-YLine rmoveto
- }repeat
- grestore
- }if
- }def
- /EndSheet{
- showpage
- sheetState restore
- }def
- /SetHeaderLines{ % nb-lines --
- /HeaderLines exch def
- % ---- bottom up
- HeaderPad
- HeaderLines 1 sub HeaderLineHeight mul add
- HeaderTitleLineHeight add
- HeaderPad add
- /HeaderHeight exch def
- }def
- /SetFooterLines{ % nb-lines --
- /FooterLines exch def
- % ---- bottom up
- FooterPad
- FooterLines FooterLineHeight mul add
- FooterPad add
- /FooterHeight exch def
- }def
- % |---------|
- % | tm |
- % |---------|
- % | header |
- % |-+-------| <-- (x y)
- % | ho |
- % |---------|
- % | text |
- % |---------|
- % | fo |
- % |---------|
- % | footer |
- % |-+-------| <-- (0 0)
- % | bm |
- % |---------|
- % -- |- x y
- /HeaderFrameStart{0 PrintHeight HeaderOffset add}def
- /FooterFrameStart{0 FooterHeight FooterOffset add neg}def
- /doFramePath{
- /h exch def
- PrintHeaderWidth 0 rlineto
- 0 h rlineto
- PrintHeaderWidth neg 0 rlineto
- 0 h neg rlineto
- }def
- /HeaderFramePath{HeaderHeight doFramePath}def
- /FooterFramePath{FooterHeight doFramePath}def
- % /path-fun /start-fun vector-property doFrame
- /doFrame{
- /vecFrame exch def
- /startFrame exch load def
- /pathFrame exch load def
- gsave
- vecFrame 2 get setlinewidth % frame border width
- % ---- do the shadow of the next rectangle
- startFrame moveto
- 1 -1 rmoveto
- pathFrame
- vecFrame 4 get SetColor fill % frame shadow color
- % ---- do the next rectangle ...
- startFrame moveto
- pathFrame
- gsave vecFrame 1 get SetColor fill grestore % frame background
- gsave vecFrame 3 get SetColor stroke grestore % frame border color
- grestore
- }def
- /HeaderFrame{/HeaderFramePath /HeaderFrameStart HeaderFrameProperties doFrame}def
- /FooterFrame{/FooterFramePath /FooterFrameStart FooterFrameProperties doFrame}def
- /HeaderStart{
- HeaderFrameStart
- exch HeaderPad add exch % horizontal pad
- % ---- bottom up
- HeaderPad add % vertical pad
- HeaderDescent sub
- HeaderLineHeight HeaderLines 1 sub mul add
- }def
- /FooterStart{
- FooterFrameStart
- exch FooterPad add exch % horizontal pad
- % ---- bottom up
- FooterPad add % vertical pad
- FooterDescent sub
- FooterLineHeight FooterLines 1 sub mul add
- }def
- /HeaderClip{HeaderFrameStart moveto HeaderFramePath clip}def
- /FooterClip{FooterFrameStart moveto FooterFramePath clip}def
- /strcat{
- dup length 3 -1 roll dup length dup 4 -1 roll add string dup
- 0 5 -1 roll putinterval
- dup 4 2 roll exch putinterval
- }def
- /pagenumberstring{
- PageNumber 32 string cvs
- ShowNofN{(/)strcat PageCount 32 string cvs strcat}if
- }def
- % lines is-right HeaderOrFooterTextLines
- /HeaderOrFooterTextLines{
- /is_right exch def
- HFStart moveto
- { % ---- process the lines
- aload pop
- exch F
- gsave
- dup xcheck{exec}if
- is_right{
- dup stringwidth pop
- PrintHeaderWidth exch sub HFPad HFPad add sub 0 rmoveto
- }if
- HFColor SetColor
- show
- grestore
- 0 HFLineHeight neg rmoveto
- }forall
- }def
- % right-lines left-lines /start lineheight pad fore-color HeaderOrFooterText
- /HeaderOrFooterText{
- /HFColor exch def
- /HFPad exch def
- /HFLineHeight exch def
- /HFStart exch load def
- % -- rightLines leftLines -- at stack
- % ---- hack: `PN 1 and' == `PN 2 modulo'
- % ---- if even page number and duplex, then exchange left and right
- PageNumber 1 and 0 eq SwitchHeader and{exch}if
- % ---- process the left lines
- false HeaderOrFooterTextLines
- % ---- process the right lines
- true HeaderOrFooterTextLines
- }def
- /HeaderText{
- gsave HeaderClip
- HeaderLinesRight HeaderLinesLeft
- /HeaderStart HeaderLineHeight HeaderPad
- HeaderFrameProperties 0 get
- HeaderOrFooterText
- grestore
- }def
- /FooterText{
- gsave FooterClip
- FooterLinesRight FooterLinesLeft
- /FooterStart FooterLineHeight FooterPad
- FooterFrameProperties 0 get
- HeaderOrFooterText
- grestore
- }def
- /ReportFontInfo{
- 2 copy
- /t0 3 1 roll DefFont
- /t0 F
- /lh FontHeight def
- /sw( )stringwidth pop def
- /aw(01234567890abcdefghijklmnopqrstuvwxyz)dup length exch
- stringwidth pop exch div def
- /t1 12/Helvetica-Oblique DefFont
- /t1 F
- gsave
- (languagelevel = )show
- languagelevel 32 string cvs show
- grestore
- 0 FontHeight neg rmoveto
- gsave
- (For )show
- 128 string cvs show
- ( )show
- 32 string cvs show
- ( point, the line height is )show
- lh 32 string cvs show
- (, the space width is )show
- sw 32 string cvs show
- (,)show
- grestore
- 0 FontHeight neg rmoveto
- gsave
- (and a crude estimate of average character width is )show
- aw 32 string cvs show
- (.)show
- grestore
- 0 FontHeight neg rmoveto
- }def
- % cm to point
- /cm{72 mul 2.54 div}def
- /ReportAllFontInfo{
- % key = font name value = font dictionary
- FontDirectory{pop 10 exch ReportFontInfo}forall
- }def
- % 3 cm 20 cm moveto 10/Courier ReportFontInfo showpage
- % 3 cm 20 cm moveto ReportAllFontInfo showpage
- % === END ps-print prologue 1
|