Mercurial > emacs
annotate etc/ps-prin1.ps @ 29189:59e5b57b10db
(cp-decoding-vector-for-codepage):
Fill up unsupported characters with their own codes.
author | Eli Zaretskii <eliz@gnu.org> |
---|---|
date | Thu, 25 May 2000 15:44:00 +0000 |
parents | 66e571cf74c6 |
children | a6ce0d37c2cf |
rev | line source |
---|---|
27165 | 1 % === BEGIN ps-print prologue 1 |
2 | |
3 % ISOLatin1Encoding stolen from ps_init.ps in GhostScript 2.6.1.4: | |
4 /ISOLatin1Encoding where {pop}{ | |
5 % -- The ISO Latin-1 encoding vector isn't known, so define it. | |
6 % -- The first half is the same as the standard encoding, | |
7 % -- except for minus instead of hyphen at code 055. | |
8 /ISOLatin1Encoding | |
9 StandardEncoding 0 45 getinterval aload pop | |
10 /minus | |
11 StandardEncoding 46 82 getinterval aload pop | |
12 %*** NOTE: the following are missing in the Adobe documentation, | |
13 %*** but appear in the displayed table: | |
14 %*** macron at 0225, dieresis at 0230, cedilla at 0233, space at 0240. | |
15 % 0200 (128) | |
16 /.notdef /.notdef /.notdef /.notdef /.notdef /.notdef /.notdef /.notdef | |
17 /.notdef /.notdef /.notdef /.notdef /.notdef /.notdef /.notdef /.notdef | |
18 /dotlessi /grave /acute /circumflex /tilde /macron /breve /dotaccent | |
19 /dieresis /.notdef /ring /cedilla /.notdef /hungarumlaut /ogonek /caron | |
20 % 0240 (160) | |
21 /space /exclamdown /cent /sterling | |
22 /currency /yen /brokenbar /section | |
23 /dieresis /copyright /ordfeminine /guillemotleft | |
24 /logicalnot /hyphen /registered /macron | |
25 /degree /plusminus /twosuperior /threesuperior | |
26 /acute /mu /paragraph /periodcentered | |
27 /cedilla /onesuperior /ordmasculine /guillemotright | |
28 /onequarter /onehalf /threequarters /questiondown | |
29 % 0300 (192) | |
30 /Agrave /Aacute /Acircumflex /Atilde | |
31 /Adieresis /Aring /AE /Ccedilla | |
32 /Egrave /Eacute /Ecircumflex /Edieresis | |
33 /Igrave /Iacute /Icircumflex /Idieresis | |
34 /Eth /Ntilde /Ograve /Oacute | |
35 /Ocircumflex /Otilde /Odieresis /multiply | |
36 /Oslash /Ugrave /Uacute /Ucircumflex | |
37 /Udieresis /Yacute /Thorn /germandbls | |
38 % 0340 (224) | |
39 /agrave /aacute /acircumflex /atilde | |
40 /adieresis /aring /ae /ccedilla | |
41 /egrave /eacute /ecircumflex /edieresis | |
42 /igrave /iacute /icircumflex /idieresis | |
43 /eth /ntilde /ograve /oacute | |
44 /ocircumflex /otilde /odieresis /divide | |
45 /oslash /ugrave /uacute /ucircumflex | |
46 /udieresis /yacute /thorn /ydieresis | |
47 256 packedarray def | |
48 }ifelse | |
49 | |
50 /reencodeFontISO{ %def | |
51 dup | |
52 length 12 add dict % Make a new font (a new dict the same size | |
53 % as the old one) with room for our new symbols. | |
54 | |
55 begin % Make the new font the current dictionary. | |
56 | |
57 | |
58 {1 index /FID ne | |
59 {def}{pop pop}ifelse | |
60 }forall % Copy each of the symbols from the old dictionary | |
61 % to the new one except for the font ID. | |
62 | |
63 currentdict /FontType get 0 ne{ | |
64 /Encoding ISOLatin1Encoding def % Override the encoding with | |
65 % the ISOLatin1 encoding. | |
66 }if | |
67 | |
68 % Use the font's bounding box to determine the ascent, descent, | |
69 % and overall height; don't forget that these values have to be | |
70 % transformed using the font's matrix. | |
71 | |
72 % ^ (x2 y2) | |
73 % | | | |
74 % | v | |
75 % | +----+ - - | |
76 % | | | ^ | |
77 % | | | | Ascent (usually > 0) | |
78 % | | | | | |
79 % (0 0) -> +--+----+--------> | |
80 % | | | | |
81 % | | v Descent (usually < 0) | |
82 % (x1 y1) --> +----+ - - | |
83 | |
84 currentdict /FontType get 0 ne{ | |
85 /FontBBox load aload pop % -- x1 y1 x2 y2 | |
86 FontMatrix transform /Ascent exch def pop | |
87 FontMatrix transform /Descent exch def pop | |
88 }{ | |
89 /PrimaryFont FDepVector 0 get def | |
90 PrimaryFont /FontBBox get aload pop | |
91 PrimaryFont /FontMatrix get transform /Ascent exch def pop | |
92 PrimaryFont /FontMatrix get transform /Descent exch def pop | |
93 }ifelse | |
94 | |
95 /FontHeight Ascent Descent sub def % use `sub' because descent < 0 | |
96 | |
97 % Define these in case they're not in the FontInfo | |
98 % (also, here they're easier to get to). | |
99 /UnderlinePosition Descent 0.70 mul def | |
100 /OverlinePosition Descent UnderlinePosition sub Ascent add def | |
101 /StrikeoutPosition Ascent 0.30 mul def | |
102 /LineThickness FontHeight 0.05 mul def | |
103 /Xshadow FontHeight 0.08 mul def | |
104 /Yshadow FontHeight -0.09 mul def | |
105 /SpaceBackground Descent neg UnderlinePosition add def | |
106 /XBox Descent neg def | |
107 /YBox LineThickness 0.7 mul def | |
108 | |
109 currentdict % Leave the new font on the stack | |
110 end % Stop using the font as the current dictionary. | |
111 definefont % Put the font into the font dictionary | |
112 pop % Discard the returned font. | |
113 }bind def | |
114 | |
115 /DefFont{ % Font definition | |
116 findfont exch scalefont reencodeFontISO | |
117 }def | |
118 | |
119 /F{ % Font selection | |
120 findfont | |
121 dup /Ascent get /Ascent exch def | |
122 dup /Descent get /Descent exch def | |
123 dup /FontHeight get /FontHeight exch def | |
124 dup /UnderlinePosition get /UnderlinePosition exch def | |
125 dup /OverlinePosition get /OverlinePosition exch def | |
126 dup /StrikeoutPosition get /StrikeoutPosition exch def | |
127 dup /LineThickness get /LineThickness exch def | |
128 dup /Xshadow get /Xshadow exch def | |
129 dup /Yshadow get /Yshadow exch def | |
130 dup /SpaceBackground get /SpaceBackground exch def | |
131 dup /XBox get /XBox exch def | |
132 dup /YBox get /YBox exch def | |
133 setfont | |
134 }def | |
135 | |
136 /FG /setrgbcolor load def | |
137 | |
138 /bg false def | |
139 /BG{ | |
140 dup /bg exch def | |
141 {mark 4 1 roll ]} | |
142 {[ 1.0 1.0 1.0 ]} | |
143 ifelse | |
144 /bgcolor exch def | |
145 }def | |
146 | |
147 % B width C | |
148 % +-----------+ | |
149 % | Ascent (usually > 0) | |
150 % A + + | |
151 % | Descent (usually < 0) | |
152 % +-----------+ | |
153 % E width D | |
154 | |
155 /dobackground{ % width -- | |
156 currentpoint % -- width x y | |
157 gsave | |
158 newpath | |
159 moveto % A (x y) | |
160 0 Ascent rmoveto % B | |
161 dup 0 rlineto % C | |
162 0 Descent Ascent sub rlineto % D | |
163 neg 0 rlineto % E | |
164 closepath | |
28428
b2d43a699564
Replace gs_languagelevel by languagelevel.
Gerd Moellmann <gerd@gnu.org>
parents:
28284
diff
changeset
|
165 FillBgColor |
27165 | 166 grestore |
167 }def | |
168 | |
169 /eolbg{ % dobackground until right margin | |
170 PrintWidth % -- x-eol | |
171 currentpoint pop % -- cur-x | |
172 sub % -- width until eol | |
173 dobackground | |
174 }def | |
175 | |
28762
8e8534ef4b0a
PostScript level 1 compatibility, Upside-down
Gerd Moellmann <gerd@gnu.org>
parents:
28428
diff
changeset
|
176 /PSL{bg{eolbg}if 0 currentpoint exch pop LineHeight sub moveto}def |
27165 | 177 /PLN{PrintLineNumber{doLineNumber}if}def |
178 | |
28762
8e8534ef4b0a
PostScript level 1 compatibility, Upside-down
Gerd Moellmann <gerd@gnu.org>
parents:
28428
diff
changeset
|
179 /SL{PSL isLineStep pop}def % Soft Linefeed |
27165 | 180 |
28762
8e8534ef4b0a
PostScript level 1 compatibility, Upside-down
Gerd Moellmann <gerd@gnu.org>
parents:
28428
diff
changeset
|
181 /HL{PSL PLN}def % Hard Linefeed |
27165 | 182 |
183 % Some debug | |
184 /dcp{currentpoint exch 40 string cvs print (, ) print =}def | |
185 /dp{print 2 copy exch 40 string cvs print (, ) print =}def | |
186 | |
187 /W{ | |
188 ( ) stringwidth % Get the width of a space in the current font. | |
189 pop % Discard the Y component. | |
190 mul % Multiply the width of a space | |
191 % by the number of spaces to plot | |
192 bg{dup dobackground}if | |
193 0 rmoveto | |
194 }def | |
195 | |
196 /Effect 0 def | |
197 /EF{/Effect exch def}def | |
198 | |
199 % stack: string |- -- | |
200 % effect: 1 - underline 2 - strikeout 4 - overline | |
201 % 8 - shadow 16 - box 32 - outline | |
202 /S{ | |
203 /xx currentpoint dup Descent add /yy exch def | |
204 Ascent add /YY exch def def | |
205 dup stringwidth pop xx add /XX exch def | |
206 Effect 8 and 0 ne{ | |
207 /yy yy Yshadow add def | |
208 /XX XX Xshadow add def | |
209 }if | |
210 bg{ | |
211 true | |
212 Effect 16 and 0 ne | |
213 {SpaceBackground doBox} | |
214 {xx yy XX YY doRect} | |
215 ifelse | |
216 }if % background | |
217 Effect 16 and 0 ne{false 0 doBox}if % box | |
218 Effect 8 and 0 ne{dup doShadow}if % shadow | |
219 Effect 32 and 0 ne | |
220 {true doOutline} % outline | |
221 {show} % normal text | |
222 ifelse | |
223 Effect 1 and 0 ne{UnderlinePosition Hline}if % underline | |
224 Effect 2 and 0 ne{StrikeoutPosition Hline}if % strikeout | |
225 Effect 4 and 0 ne{OverlinePosition Hline}if % overline | |
226 }bind def | |
227 | |
228 % stack: position |- -- | |
229 /Hline{ | |
230 currentpoint exch pop add dup | |
231 gsave | |
232 newpath | |
233 xx exch moveto | |
234 XX exch lineto | |
235 closepath | |
236 LineThickness setlinewidth stroke | |
237 grestore | |
238 }bind def | |
239 | |
240 % stack: fill-or-not delta |- -- | |
241 /doBox{ | |
242 /dd exch def | |
243 xx XBox sub dd sub yy YBox sub dd sub | |
244 XX XBox add dd add YY YBox add dd add | |
245 doRect | |
246 }bind def | |
247 | |
248 % stack: fill-or-not lower-x lower-y upper-x upper-y |- -- | |
249 /doRect{ | |
250 /rYY exch def | |
251 /rXX exch def | |
252 /ryy exch def | |
253 /rxx exch def | |
254 gsave | |
255 newpath | |
256 rXX rYY moveto | |
257 rxx rYY lineto | |
258 rxx ryy lineto | |
259 rXX ryy lineto | |
260 closepath | |
261 % top of stack: fill-or-not | |
262 {FillBgColor} | |
263 {LineThickness setlinewidth stroke} | |
264 ifelse | |
265 grestore | |
266 }bind def | |
267 | |
268 % stack: string |- -- | |
269 /doShadow{ | |
270 gsave | |
271 Xshadow Yshadow rmoveto | |
272 false doOutline | |
273 grestore | |
274 }bind def | |
275 | |
276 /st 1 string def | |
277 | |
278 % stack: string fill-or-not |- -- | |
279 /doOutline{ | |
280 /-fillp- exch def | |
281 /-ox- currentpoint /-oy- exch def def | |
282 gsave | |
283 LineThickness setlinewidth | |
284 {st 0 3 -1 roll put | |
285 st dup true charpath | |
286 -fillp- {gsave FillBgColor grestore}if | |
287 stroke stringwidth | |
288 -oy- add /-oy- exch def | |
289 -ox- add /-ox- exch def | |
290 -ox- -oy- moveto | |
291 }forall | |
292 grestore | |
293 -ox- -oy- moveto | |
294 }bind def | |
295 | |
296 % stack: -- | |
297 /FillBgColor{bgcolor aload pop setrgbcolor fill}bind def | |
298 | |
299 /L0 6 /Times-Italic DefFont | |
300 | |
28762
8e8534ef4b0a
PostScript level 1 compatibility, Upside-down
Gerd Moellmann <gerd@gnu.org>
parents:
28428
diff
changeset
|
301 % stack: -- |- boolean |
8e8534ef4b0a
PostScript level 1 compatibility, Upside-down
Gerd Moellmann <gerd@gnu.org>
parents:
28428
diff
changeset
|
302 /isLineStep{ |
8e8534ef4b0a
PostScript level 1 compatibility, Upside-down
Gerd Moellmann <gerd@gnu.org>
parents:
28428
diff
changeset
|
303 SyncLineZebra |
28980
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
304 {PLScounter 0 gt % or zebra |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
305 {/PLScounter PLScounter 1 sub def PLScounter 0 eq} |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
306 {false}ifelse |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
307 PrintLineStep 1 gt |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
308 {/PrintLineStep PrintLineStep 1 sub def} |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
309 {/PrintLineStep ZebraHeight def |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
310 /PLScounter PrintLineStart def}ifelse} |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
311 {LineNumber PrintLineStart sub PrintLineStep mod 0 eq}ifelse % or line step |
28762
8e8534ef4b0a
PostScript level 1 compatibility, Upside-down
Gerd Moellmann <gerd@gnu.org>
parents:
28428
diff
changeset
|
312 }def |
8e8534ef4b0a
PostScript level 1 compatibility, Upside-down
Gerd Moellmann <gerd@gnu.org>
parents:
28428
diff
changeset
|
313 |
27165 | 314 % stack: -- |
315 /doLineNumber{ | |
316 /LineNumber where | |
28762
8e8534ef4b0a
PostScript level 1 compatibility, Upside-down
Gerd Moellmann <gerd@gnu.org>
parents:
28428
diff
changeset
|
317 {pop |
8e8534ef4b0a
PostScript level 1 compatibility, Upside-down
Gerd Moellmann <gerd@gnu.org>
parents:
28428
diff
changeset
|
318 isLineStep % or line step |
8e8534ef4b0a
PostScript level 1 compatibility, Upside-down
Gerd Moellmann <gerd@gnu.org>
parents:
28428
diff
changeset
|
319 LineNumber Lines ge or % or last line |
8e8534ef4b0a
PostScript level 1 compatibility, Upside-down
Gerd Moellmann <gerd@gnu.org>
parents:
28428
diff
changeset
|
320 {currentfont |
27165 | 321 gsave |
322 0.0 0.0 0.0 setrgbcolor | |
323 /L0 findfont setfont | |
324 LineNumber Lines ge | |
28762
8e8534ef4b0a
PostScript level 1 compatibility, Upside-down
Gerd Moellmann <gerd@gnu.org>
parents:
28428
diff
changeset
|
325 {(end )} |
8e8534ef4b0a
PostScript level 1 compatibility, Upside-down
Gerd Moellmann <gerd@gnu.org>
parents:
28428
diff
changeset
|
326 {LineNumber 6 string cvs ( ) strcat}ifelse |
27165 | 327 dup stringwidth pop neg 0 rmoveto |
328 show | |
329 grestore | |
28762
8e8534ef4b0a
PostScript level 1 compatibility, Upside-down
Gerd Moellmann <gerd@gnu.org>
parents:
28428
diff
changeset
|
330 setfont}if |
27165 | 331 /LineNumber LineNumber 1 add def |
332 }if | |
333 }def | |
334 | |
28428
b2d43a699564
Replace gs_languagelevel by languagelevel.
Gerd Moellmann <gerd@gnu.org>
parents:
28284
diff
changeset
|
335 % stack: color-specifier |- -- |
b2d43a699564
Replace gs_languagelevel by languagelevel.
Gerd Moellmann <gerd@gnu.org>
parents:
28284
diff
changeset
|
336 /SetColor{dup type /realtype eq{setgray}{aload pop setrgbcolor}ifelse}def |
b2d43a699564
Replace gs_languagelevel by languagelevel.
Gerd Moellmann <gerd@gnu.org>
parents:
28284
diff
changeset
|
337 |
27165 | 338 % stack: -- |
339 /printZebra{ | |
340 gsave | |
28428
b2d43a699564
Replace gs_languagelevel by languagelevel.
Gerd Moellmann <gerd@gnu.org>
parents:
28284
diff
changeset
|
341 ZebraColor SetColor |
27165 | 342 /double-zebra ZebraHeight ZebraHeight add def |
343 /yiter double-zebra LineHeight mul neg def | |
344 /xiter PrintWidth InterColumn add def | |
345 NumberOfColumns{LinesPerColumn doColumnZebra xiter 0 rmoveto}repeat | |
346 grestore | |
347 }def | |
348 | |
349 % stack: lines-per-column |- -- | |
350 /doColumnZebra{ | |
351 gsave | |
352 dup double-zebra idiv{ZebraHeight doZebra 0 yiter rmoveto}repeat | |
353 double-zebra mod | |
354 dup 0 le{pop}{dup ZebraHeight gt {pop ZebraHeight}if doZebra}ifelse | |
355 grestore | |
356 }def | |
357 | |
358 % stack: zebra-height (in lines) |- -- | |
359 /doZebra{ | |
360 /zh exch 0.05 sub LineHeight mul def | |
361 gsave | |
362 0 LineHeight 0.65 mul rmoveto | |
363 PrintWidth 0 rlineto | |
364 0 zh neg rlineto | |
365 PrintWidth neg 0 rlineto | |
366 0 zh rlineto | |
367 fill | |
368 grestore | |
369 }def | |
370 | |
28428
b2d43a699564
Replace gs_languagelevel by languagelevel.
Gerd Moellmann <gerd@gnu.org>
parents:
28284
diff
changeset
|
371 % stack: -- |
b2d43a699564
Replace gs_languagelevel by languagelevel.
Gerd Moellmann <gerd@gnu.org>
parents:
28284
diff
changeset
|
372 /printBackground{ |
b2d43a699564
Replace gs_languagelevel by languagelevel.
Gerd Moellmann <gerd@gnu.org>
parents:
28284
diff
changeset
|
373 /BackgroundColor where{ |
b2d43a699564
Replace gs_languagelevel by languagelevel.
Gerd Moellmann <gerd@gnu.org>
parents:
28284
diff
changeset
|
374 pop gsave BackgroundColor SetColor |
b2d43a699564
Replace gs_languagelevel by languagelevel.
Gerd Moellmann <gerd@gnu.org>
parents:
28284
diff
changeset
|
375 NumberOfColumns{ |
b2d43a699564
Replace gs_languagelevel by languagelevel.
Gerd Moellmann <gerd@gnu.org>
parents:
28284
diff
changeset
|
376 gsave |
b2d43a699564
Replace gs_languagelevel by languagelevel.
Gerd Moellmann <gerd@gnu.org>
parents:
28284
diff
changeset
|
377 0 LineHeight 0.65 mul rmoveto |
b2d43a699564
Replace gs_languagelevel by languagelevel.
Gerd Moellmann <gerd@gnu.org>
parents:
28284
diff
changeset
|
378 PrintWidth 0 rlineto |
b2d43a699564
Replace gs_languagelevel by languagelevel.
Gerd Moellmann <gerd@gnu.org>
parents:
28284
diff
changeset
|
379 0 PrintHeight neg rlineto |
b2d43a699564
Replace gs_languagelevel by languagelevel.
Gerd Moellmann <gerd@gnu.org>
parents:
28284
diff
changeset
|
380 PrintWidth neg 0 rlineto |
b2d43a699564
Replace gs_languagelevel by languagelevel.
Gerd Moellmann <gerd@gnu.org>
parents:
28284
diff
changeset
|
381 0 PrintHeight rlineto |
b2d43a699564
Replace gs_languagelevel by languagelevel.
Gerd Moellmann <gerd@gnu.org>
parents:
28284
diff
changeset
|
382 fill |
b2d43a699564
Replace gs_languagelevel by languagelevel.
Gerd Moellmann <gerd@gnu.org>
parents:
28284
diff
changeset
|
383 grestore |
b2d43a699564
Replace gs_languagelevel by languagelevel.
Gerd Moellmann <gerd@gnu.org>
parents:
28284
diff
changeset
|
384 PrintWidth InterColumn add 0 rmoveto |
b2d43a699564
Replace gs_languagelevel by languagelevel.
Gerd Moellmann <gerd@gnu.org>
parents:
28284
diff
changeset
|
385 }repeat |
b2d43a699564
Replace gs_languagelevel by languagelevel.
Gerd Moellmann <gerd@gnu.org>
parents:
28284
diff
changeset
|
386 grestore |
b2d43a699564
Replace gs_languagelevel by languagelevel.
Gerd Moellmann <gerd@gnu.org>
parents:
28284
diff
changeset
|
387 }if |
b2d43a699564
Replace gs_languagelevel by languagelevel.
Gerd Moellmann <gerd@gnu.org>
parents:
28284
diff
changeset
|
388 }def |
b2d43a699564
Replace gs_languagelevel by languagelevel.
Gerd Moellmann <gerd@gnu.org>
parents:
28284
diff
changeset
|
389 |
27165 | 390 % tx ty rotation xscale yscale xpos ypos BeginBackImage |
391 /BeginBackImage{ | |
392 /-save-image- save def | |
393 /showpage{}def | |
394 translate | |
395 scale | |
396 rotate | |
397 translate | |
398 }def | |
399 | |
400 /EndBackImage{-save-image- restore}def | |
401 | |
402 % string fontsize fontname rotation gray xpos ypos ShowBackText | |
403 /ShowBackText{ | |
404 gsave | |
405 translate | |
406 setgray | |
407 rotate | |
408 findfont exch dup /-offset- exch -0.25 mul def scalefont setfont | |
409 0 -offset- moveto | |
410 /-saveLineThickness- LineThickness def | |
411 /LineThickness 1 def | |
412 false doOutline | |
413 /LineThickness -saveLineThickness- def | |
414 grestore | |
415 }def | |
416 | |
417 /BeginDoc{ | |
418 % ---- Remember space width of the normal text font `f0'. | |
419 /SpaceWidth /f0 findfont setfont ( ) stringwidth pop def | |
420 % ---- save the state of the document (useful for ghostscript!) | |
421 /docState save def | |
422 % ---- [andrewi] set PageSize based on chosen dimensions | |
423 UseSetpagedevice{ | |
28980
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
424 BMark/PageSize[PageWidth LandscapePageHeight LandscapeMode{exch}if]EMark setpagedevice |
27165 | 425 }if |
426 /ColumnWidth PrintWidth InterColumn add def | |
427 % ---- define where printing will start | |
428 /f0 F % this installs Ascent | |
429 /PrintStartY PrintHeight Ascent sub def | |
430 /ColumnIndex 1 def | |
431 /N-Up-Counter N-Up-End 1 sub def | |
28980
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
432 /PLScounter PrintLineStart def |
27165 | 433 }def |
434 | |
435 /EndDoc{ | |
436 % ---- restore the state of the document (useful for ghostscript!) | |
437 docState restore | |
438 }def | |
439 | |
440 /BeginDSCPage{ | |
441 % ---- when 1st column, save the state of the page | |
442 ColumnIndex 1 eq{ | |
443 /pageState save def | |
444 }if | |
445 % ---- save the state of the column | |
446 /columnState save def | |
447 }def | |
448 | |
449 /PrintHeaderWidth PrintOnlyOneHeader{PrintPageWidth}{PrintWidth}ifelse def | |
450 | |
451 /BeginPage{ | |
452 % ---- when 1st column, print all background effects | |
453 ColumnIndex 1 eq{ | |
454 0 PrintStartY moveto % move to where printing will start | |
28428
b2d43a699564
Replace gs_languagelevel by languagelevel.
Gerd Moellmann <gerd@gnu.org>
parents:
28284
diff
changeset
|
455 printBackground |
27165 | 456 Zebra {printZebra}if |
457 printGlobalBackground | |
458 printLocalBackground | |
459 }if | |
460 PrintHeader{ | |
461 PrintOnlyOneHeader{ColumnIndex 1 eq}{true}ifelse{ | |
462 PrintHeaderFrame{HeaderFrame}if | |
463 HeaderText | |
464 }if | |
465 }if | |
466 0 PrintStartY moveto % move to where printing will start | |
467 PLN | |
468 }def | |
469 | |
470 /EndPage{bg{eolbg}if}def | |
471 | |
472 /EndDSCPage{ | |
473 ColumnIndex NumberOfColumns eq{ | |
474 % ---- restore the state of the page | |
475 pageState restore | |
476 /ColumnIndex 1 def | |
477 % ---- N-up printing | |
478 N-Up 1 gt{ | |
479 N-Up-Counter 0 gt{ | |
480 % ---- Next page on same row | |
481 /N-Up-Counter N-Up-Counter 1 sub def | |
482 N-Up-XColumn N-Up-YColumn | |
483 }{ | |
484 % ---- Next page on next line | |
485 /N-Up-Counter N-Up-End 1 sub def | |
486 N-Up-XLine N-Up-YLine | |
487 }ifelse | |
488 translate | |
489 }if | |
490 }{ % else | |
491 % ---- restore the state of the current column | |
492 columnState restore | |
493 % ---- and translate to the next column | |
494 ColumnWidth 0 translate | |
495 /ColumnIndex ColumnIndex 1 add def | |
496 }ifelse | |
497 }def | |
498 | |
499 % stack: number-of-pages-per-sheet |- -- | |
500 /BeginSheet{ | |
501 /sheetState save def | |
502 /pages-per-sheet exch def | |
28980
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
503 |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
504 % ---- translate to bottom-right corner of Portrait page |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
505 LandscapeMode{ |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
506 LandscapePageHeight 0 translate |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
507 90 rotate |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
508 }if |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
509 % ---- [jack] Kludge: my ghostscript window is 21x27.7 instead of 21x29.7 |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
510 /JackGhostscript where{pop 1 27.7 29.7 div scale}if |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
511 UpsideDown{PageWidth LandscapePageHeight translate 180 rotate}if |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
512 % ---- N-Up printing |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
513 N-Up 1 gt{ |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
514 % ---- landscape |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
515 N-Up-Landscape{ |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
516 PageWidth 0 translate |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
517 90 rotate |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
518 }if |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
519 N-Up-Margin dup translate |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
520 % ---- scale |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
521 LandscapeMode{ |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
522 /HH PageWidth def |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
523 /WW LandscapePageHeight def |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
524 }{ |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
525 /HH LandscapePageHeight def |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
526 /WW PageWidth def |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
527 }ifelse |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
528 WW N-Up-Margin sub N-Up-Margin sub |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
529 N-Up-Landscape |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
530 {N-Up-Lines div HH}{N-Up-Columns N-Up-Missing add div WW}ifelse |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
531 div dup scale |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
532 0 N-Up-Repeat 1 sub LandscapePageHeight mul translate |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
533 % ---- go to start position in page matrix |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
534 N-Up-XStart N-Up-Missing 0.5 mul |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
535 LandscapeMode |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
536 {LandscapePageHeight mul N-Up-YStart add} |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
537 {PageWidth mul add N-Up-YStart}ifelse |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
538 translate |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
539 }if |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
540 % ---- translate to lower left corner of TEXT |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
541 LeftMargin BottomMargin translate |
66e571cf74c6
PostScript code compatibility with other utilities
Gerd Moellmann <gerd@gnu.org>
parents:
28762
diff
changeset
|
542 |
27165 | 543 % ---- N-up printing |
544 N-Up 1 gt N-Up-Border and pages-per-sheet 0 gt and{ | |
545 % ---- page border | |
546 gsave | |
547 0 setgray | |
548 LeftMargin neg BottomMargin neg moveto | |
549 N-Up-Repeat | |
550 {N-Up-End | |
551 {gsave | |
552 PageWidth 0 rlineto | |
553 0 LandscapePageHeight rlineto | |
554 PageWidth neg 0 rlineto | |
555 closepath stroke | |
556 grestore | |
557 /pages-per-sheet pages-per-sheet 1 sub def | |
558 pages-per-sheet 0 le{exit}if | |
559 N-Up-XColumn N-Up-YColumn rmoveto | |
560 }repeat | |
561 pages-per-sheet 0 le{exit}if | |
562 N-Up-XLine N-Up-XColumn sub N-Up-YLine rmoveto | |
563 }repeat | |
564 grestore | |
565 }if | |
566 }def | |
567 | |
568 /EndSheet{ | |
569 showpage | |
570 sheetState restore | |
571 }def | |
572 | |
573 /SetHeaderLines{ % nb-lines -- | |
574 /HeaderLines exch def | |
575 % ---- bottom up | |
576 HeaderPad | |
577 HeaderLines 1 sub HeaderLineHeight mul add | |
578 HeaderTitleLineHeight add | |
579 HeaderPad add | |
580 /HeaderHeight exch def | |
581 }def | |
582 | |
583 % |---------| | |
584 % | tm | | |
585 % |---------| | |
586 % | header | | |
587 % |-+-------| <-- (x y) | |
588 % | ho | | |
589 % |---------| | |
590 % | text | | |
591 % |-+-------| <-- (0 0) | |
592 % | bm | | |
593 % |---------| | |
594 | |
595 /HeaderFrameStart{ % -- x y | |
596 0 PrintHeight HeaderOffset add | |
597 }def | |
598 | |
599 /HeaderFramePath{ | |
600 PrintHeaderWidth 0 rlineto | |
601 0 HeaderHeight rlineto | |
602 PrintHeaderWidth neg 0 rlineto | |
603 0 HeaderHeight neg rlineto | |
604 }def | |
605 | |
606 /HeaderFrame{ | |
607 gsave | |
608 0.4 setlinewidth | |
609 % ---- fill a black rectangle (the shadow of the next one) | |
610 HeaderFrameStart moveto | |
611 1 -1 rmoveto | |
612 HeaderFramePath | |
613 0 setgray fill | |
614 % ---- do the next rectangle ... | |
615 HeaderFrameStart moveto | |
616 HeaderFramePath | |
617 gsave 0.9 setgray fill grestore % filled with grey | |
618 gsave 0 setgray stroke grestore % drawn with black | |
619 grestore | |
620 }def | |
621 | |
622 /HeaderStart{ | |
623 HeaderFrameStart | |
624 exch HeaderPad add exch % horizontal pad | |
625 % ---- bottom up | |
626 HeaderPad add % vertical pad | |
627 HeaderDescent sub | |
628 HeaderLineHeight HeaderLines 1 sub mul add | |
629 }def | |
630 | |
631 /strcat{ | |
632 dup length 3 -1 roll dup length dup 4 -1 roll add string dup | |
633 0 5 -1 roll putinterval | |
634 dup 4 2 roll exch putinterval | |
635 }def | |
636 | |
637 /pagenumberstring{ | |
638 PageNumber 32 string cvs | |
639 ShowNofN{ | |
640 (/) strcat | |
641 PageCount 32 string cvs strcat | |
642 }if | |
643 }def | |
644 | |
645 /HeaderText{ | |
646 HeaderStart moveto | |
647 | |
648 HeaderLinesRight HeaderLinesLeft % -- rightLines leftLines | |
649 | |
650 % ---- hack: `PN 1 and' == `PN 2 modulo' | |
651 | |
652 % ---- if even page number and duplex, then exchange left and right | |
653 PageNumber 1 and 0 eq DuplexValue and{exch}if | |
654 | |
655 { % ---- process the left lines | |
656 aload pop | |
657 exch F | |
658 gsave | |
659 dup xcheck{exec}if | |
660 show | |
661 grestore | |
662 0 HeaderLineHeight neg rmoveto | |
663 }forall | |
664 | |
665 HeaderStart moveto | |
666 | |
667 { % ---- process the right lines | |
668 aload pop | |
669 exch F | |
670 gsave | |
671 dup xcheck{exec}if | |
672 dup stringwidth pop | |
673 PrintHeaderWidth exch sub HeaderPad 2 mul sub 0 rmoveto | |
674 show | |
675 grestore | |
676 0 HeaderLineHeight neg rmoveto | |
677 }forall | |
678 }def | |
679 | |
680 /ReportFontInfo{ | |
681 2 copy | |
682 /t0 3 1 roll DefFont | |
683 /t0 F | |
684 /lh FontHeight def | |
685 /sw ( ) stringwidth pop def | |
686 /aw (01234567890abcdefghijklmnopqrstuvwxyz) dup length exch | |
687 stringwidth pop exch div def | |
688 /t1 12 /Helvetica-Oblique DefFont | |
689 /t1 F | |
690 gsave | |
691 (languagelevel = ) show | |
28428
b2d43a699564
Replace gs_languagelevel by languagelevel.
Gerd Moellmann <gerd@gnu.org>
parents:
28284
diff
changeset
|
692 languagelevel 32 string cvs show |
27165 | 693 grestore |
694 0 FontHeight neg rmoveto | |
695 gsave | |
696 (For ) show | |
697 128 string cvs show | |
698 ( ) show | |
699 32 string cvs show | |
700 ( point, the line height is ) show | |
701 lh 32 string cvs show | |
702 (, the space width is ) show | |
703 sw 32 string cvs show | |
704 (,) show | |
705 grestore | |
706 0 FontHeight neg rmoveto | |
707 gsave | |
708 (and a crude estimate of average character width is ) show | |
709 aw 32 string cvs show | |
710 (.) show | |
711 grestore | |
712 0 FontHeight neg rmoveto | |
713 }def | |
714 | |
715 /cm{ % cm to point | |
716 72 mul 2.54 div | |
717 }def | |
718 | |
719 /ReportAllFontInfo{ | |
720 FontDirectory | |
721 { % key = font name value = font dictionary | |
722 pop 10 exch ReportFontInfo | |
723 }forall | |
724 }def | |
725 | |
726 % 3 cm 20 cm moveto 10 /Courier ReportFontInfo showpage | |
727 % 3 cm 20 cm moveto ReportAllFontInfo showpage | |
728 | |
729 % === END ps-print prologue 1 |