Automake 1.12 and up no longer supports pre-ANSI
[enscript.git] / docs / enscript.man
1 .\"
2 .\" GNU enscript manual page.
3 .\" Copyright (c) 1995-1999 Markku Rossi.
4 .\" Author: Markku Rossi <mtr@iki.fi>
5 .\"
6 .\"
7 .\" This file is part of GNU Enscript.
8 .\"
9 .\" Enscript is free software: you can redistribute it and/or modify
10 .\" it under the terms of the GNU General Public License as published by
11 .\" the Free Software Foundation, either version 3 of the License, or
12 .\" (at your option) any later version.
13 .\"
14 .\" Enscript is distributed in the hope that it will be useful,
15 .\" but WITHOUT ANY WARRANTY; without even the implied warranty of
16 .\" MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17 .\" GNU General Public License for more details.
18 .\"
19 .\" You should have received a copy of the GNU General Public License
20 .\" along with Enscript.  If not, see <http://www.gnu.org/licenses/>.
21 .\"
22 .TH ENSCRIPT 1 "Mar 12, 1999" "ENSCRIPT" "ENSCRIPT"
23
24 .SH NAME
25 enscript \- convert text files to PostScript, HTML, RTF, ANSI, and
26 overstrikes
27
28 .SH SYNOPSIS
29 .B enscript
30 [\f3\-123456789BcgGhjkKlmOqrRvVzZ\f1]
31 [\f3\-# \f2copies\f1]
32 [\f3\-a \f2pages\f1]
33 [\f3\-A \f2align\f1]
34 [\f3\-b \f2header\f1]
35 [\f3\-C\f1[\f2start_line\f1]]
36 [\f3\-d \f2printer\f1]
37 [\f3\-D \f2key\f1[\f3:\f2value\f1]]
38 [\f3\-e\f1[\f2char\f1]]
39 [\f3\-E\f1[\f2lang\f1]]
40 [\f3\-f \f2font\f1]
41 [\f3\-F \f2header_font\f1]
42 [\f3\-H\f1[\f2num\f1]]
43 [\f3\-i \f2indent\f1]
44 [\f3\-I \f2filter\f1]
45 [\f3\-J \f2title\f1]
46 [\f3\-L \f2lines_per_page\f1]
47 [\f3\-M \f2media\f1]
48 [\f3\-n \f2copies\f1]
49 [\f3\-N \f2newline\f1]
50 [\f3\-o \f2outputfile\f1]
51 [\f3\-o \-\f1]
52 [\f3\-p \f2outputfile\f1]
53 [\f3\-p \-\f1]
54 [\f3\-P \f2printer\f1]
55 [\f3\-s \f2baselineskip\f1]
56 [\f3\-S \f2key\f1[\f3:\f2value\f1]]
57 [\f3\-t \f2title\f1]
58 [\f3\-T \f2tabsize\f1]
59 [\f3\-u\f1[\f2text\f1]]
60 [\f3\-U \f2num\f1]
61 [\f3\-w \f2language\f1]
62 [\f3\-X \f2encoding\f1]
63 [\f2filename\f1 ...]
64
65 .SH DESCRIPTION
66
67 \f3Enscript\f1 converts text files to PostScript or to other output
68 languages.  \f3Enscript\f1 can spool the generated output directly to
69 a specified printer or leave it to a file.  If no input files are
70 given, \f3enscript\f1 processes the standard input \f3stdin\f1.
71 \f3Enscript\f1 can be extended to handle different output media and it
72 has many options which can be used to customize the printouts.
73
74 .SH OPTIONS
75 .TP 8
76 .B \-# \f2num\f3
77 Print \f2num\f1 copies of each page.
78 .TP 8
79 .B \-1, \-2, \-3, \-4, \-5, \-6, \-7, \-8, \-9, \-\-columns=\f2num\f3
80 Specify how many columns each page have.  With the long option
81 \f3\-\-columns=\f2num\f1 you can specify more than 9 columns per page.
82 .TP 8
83 .B \-a \f2pages\f3, \-\-pages=\f2pages\f3
84 Specify which pages are printed.  The page specification \f2pages\f1
85 can be given in the following formats:
86 .RS 8
87 .TP 8
88 \f2begin\f1\-\f2end\f1
89 print pages from \f2begin\f1 to \f2end\f1
90 .TP 8
91 \-\f2end\f1
92 print pages from 0 to \f2end\f1
93 .TP 8
94 \f2begin\f1\-
95 print pages from \f2begin\f1 to end
96 .TP 8
97 \f2page\f1
98 print page \f2page\f1
99 .TP 8
100 odd
101 print odd pages
102 .TP 8
103 even
104 print even pages
105 .RE
106 .TP 8
107 .B \-A \f2align\f3, \-\-file\-align=\f2align\f3
108 Align separate input files to even \f2align\f1 page count.  This
109 option is useful in two-side and 2-up printings (\-\-file\-align=2).
110 .TP 8
111 .B \-b \f2header\f3, \-\-header=\f2header\f3
112 Use the text \f2header\f1 as a page header.  The default page header
113 is constructed from the name of the file and from its last
114 modification time.
115
116 The header string \f2header\f1 can contain the same formatting escapes
117 which can be specified for the \f3%Format\f1 directives in the user
118 defined fancy headers.  For example, the following option prints the
119 file name, current date and page numbers:
120
121 \f3enscript \-\-header='$n %W Page $% of $=' *.c\f1
122
123 The header string can also contain left, center and right justified
124 fields.  The fields are separated by the \f3'|'\f1 character:
125
126 \f3enscript \-\-header='$n|%W|Page $% of $=' *.c\f1
127
128 now the file name is printed left justified, the date is centered to
129 the header and the page numbers are printed right justified.
130 .TP 8
131 .B \-B, \-\-no\-header
132 Do not print page headers.
133 .TP 8
134 .B \-c, \-\-truncate\-lines
135 Cut lines that are too long for the page.  As a default,
136 \f3enscript\f1 wraps long lines to the next line so no information is
137 lost.
138
139 You can also use the \f3\-\-slice\f1 option which slices long lines to
140 separate pages.
141 .TP 8
142 .B \-C\f1[\f2start_line\f1]\f3, \-\-line\-numbers\f1[\f3=\f2start_line\f1]\f3
143 Precede each line with its line number.  The optional argument
144 \f2start_line\f1 specifies the number of the first line in the input.
145 The number of the first line defaults to 1.
146 .TP 8
147 .B \-d \f2name\f3
148 Spool output to the printer \f2name\f1.
149 .TP 8
150 .B \-D \f2key\f1[\f3:\f2value\f1]\f3, \-\-setpagedevice=\f2key\f1[\f3:\f2value\f1]\f3
151 Pass a page device definition to the generated PostScript output.  If
152 no value is given, the key \f2key\f1 is removed from the definitions.
153
154 For example, the command
155
156 .B enscript \-DDuplex:true foo.txt
157
158 prints file foo.txt in duplex (two side) mode.
159
160 Page device operators are implementation dependent but they are
161 standardized.  See section \f3PAGE DEVICE OPTIONS\f1 for the details.
162 .TP 8
163 .B \-e\f1[\f2char\f1]\f3, \-\-escapes\f1[\f3=\f2char\f1]\f3
164 Enable special escapes interpretation (see section \f3SPECIAL
165 ESCAPES\f1).  If the argument \f2char\f1 is given, it changes the
166 escape character to \f2char\f1.  The default escape character is 0.
167 .TP 8
168 .B \-E\f1[\f2lang\f1]\f3, \-\-highlight\f1[\f3=\f2lang\f1]\f3
169 Highlight source code by creating a special input filter with the
170 \f3states\f1 program.  The optional argument \f2lang\f1 specifies the
171 language to highlight.  As a default the \f3states\f1 makes an
172 educated guess.
173
174 You can print a short description of the supported highlighting
175 languages and file formats with the command:
176
177 .B enscript \-\-help\-highlight
178
179 The highlighting rules are defined in the
180 `@DATADIR@/enscript/hl/*.st' files which can be edited to create
181 highlighting definitions for new languages.
182
183 \f3Note!\f1 You can not use your own input filters with this option.
184 .TP 8
185 .B \-f \f2name\f3, \-\-font=\f2name\f3
186 Select a font that is used for the body text.  The default body font is
187 \f3Courier10\f1, unless multicolumn landscape printing mode is
188 selected, in which case the default font is \f3Courier7\f1.
189
190 The font specification \f2name\f1 contains two parts: the name of the
191 font and its size in PostScript points.  For example,
192 "\f3Times\-Roman12\f1" selects the "Times\-Roman" font with size
193 12pt.
194
195 The name of the font must appear in @DATADIR@/enscript/font.map and
196 have a corresponding AFM file. See section \f3USING NEW FONTS\f1 for
197 information on adding a font beyond the defaults.
198
199 The font specification \f2name\f1 can also be given in format
200 `\f2name\f1@\f2ptsize\f1', where the name of the font and its point
201 size are separated by a `@' character.  This allows \f3enscript\f1 to use
202 fonts which contain digit characters in their names.
203
204 The font point size can also be given in the format
205 \f2width\f1/\f2height\f1 where the \f2width\f1 and the \f2height\f1
206 specify the size of the font in x- and y-directions.  For example,
207 "\f3Times\-Roman@10/12\f1" selects a 10 points wide and 12 points high
208 "Times\-Roman" font.
209
210 You can also give the font sizes as decimal numbers.  For example,
211 "\f3Times\-Roman10.2\f1" selects a 10.2pt "Times\-Roman" font.
212 .TP 8
213 .B \-F \f2name\f3, \-\-header\-font=\f2name\f3
214 Select a font for the header texts.
215 .TP 8
216 .B \-g, \-\-print\-anyway
217 Print a file even if it contains binary data.  The option is
218 implemented only for compatibility purposes.  \f3Enscript\f1 prints
219 binary files anyway regardless of the option.
220 .TP 8
221 .B \-G, \-\-fancy\-header\f1[\f3=\f2name\f1]\f3
222 Print a fancy page header \f2name\f1 to the top of each page.  The
223 option \f3\-G\f1 specifies the default fancy header.  See section
224 \f3CONFIGURATION FILES\f1 to see how the default fancy header can be
225 changed.
226 .TP 8
227 .B \-h, \-\-no\-job\-header
228 Suppress printing of the job header page.
229 .TP 8
230 .B \-H\f1[\f2num\f1]\f3, \-\-highlight\-bars\f1[\f3=\f2num\f1]\f3
231 Specify how high the highlight bars are in lines.  If the \f2num\f1 is
232 not given, the default value 2 is used.  As a default, no highlight bars
233 are printed.
234 .TP 8
235 .B \-i \f2num\f3, \-\-indent=\f2num\f3
236 Indent every line \f2num\f1 characters.  The indentation can also be
237 specified in other units by appending an unit specifier after the
238 number.  The possible unit specifiers and the corresponding units are:
239 .RS 8
240 .TP 8
241 .B c
242 centimeters
243 .TP 8
244 .B i
245 inches
246 .TP 8
247 .B l
248 characters (default)
249 .TP 8
250 .B p
251 PostScript points
252 .RE
253 .TP 8
254 .B \-I \f2filter\f3, \-\-filter=\f2filter\f1
255 Read all input files through an input filter \f2filter\f1.  The input
256 filter can be a single command or a command pipeline.  The filter can
257 refer to the name of the input file with the escape `\f3%s\f1'.  The
258 name of the standard input can be changed with the option
259 `\f3\-\-filter\-stdin\f1'.
260
261 For example, the following command prints the file `foo.c' by using
262 only upper-case characters:
263
264 .B enscript \-\-filter="cat %s | tr 'a-z' 'A-Z'" foo.c
265
266 The following command highlights changes which are made to files since
267 the last checkout:
268
269 .B enscript \-\-filter="rcsdiff %s | diffpp %s" \-e *.c
270
271 To include the string "%s" to the filter command, you must write it as
272 "%%s".
273 .TP 8
274 .B \-j, \-\-borders
275 Print borders around columns.
276 .TP 8
277 .B \-J \f2title\f3
278 An alias for the option \f3\-t\f1, \f3\-\-title\f1.
279 .TP 8
280 .B \-k, \-\-page\-prefeed
281 Enable page prefeed.
282 .TP 8
283 .B \-K, \-\-no\-page\-prefeed
284 Disable page prefeed (default).
285 .TP 8
286 .B \-l, \-\-lineprinter
287 Emulate lineprinter.  This option is a shortcut for the options
288 \f3\-\-lines\-per\-page=66\f1, and \f3\-\-no\-header\f1.
289 .TP 8
290 .B \-L \f2num\f3, \-\-lines\-per\-page=\f2num\f3
291 Print only \f2num\f1 lines for each page.  As a default, the number of
292 lines per page is computed from the height of the page and from the
293 size of the font.
294 .TP 8
295 .B \-m, \-\-mail
296 Send a mail notification to user after the print job has been
297 completed.
298 .TP 8
299 .B \-M \f2name\f3, \-\-media=\f2name\f3
300 Select an output media \f2name\f1.  \f3Enscript\f1's default output
301 media is \f3@media@\f1.
302 .TP 8
303 .B \-n \f2num\f3, \-\-copies=\f2num\f3
304 Print \f2num\f1 copies of each page.
305 .TP 8
306 .B \-N \f2nl\f3, \-\-newline=\f2nl\f3
307 Select the \f2newline\f1 character.  The possible values for \f2nl\f1
308 are: \f3n\f1 (unix newline, 0xa hex) and \f3r\f1 (mac newline, 0xd hex).
309 .TP 8
310 .B \-o \f2file\f3
311 An alias for the option \f3\-p\f1, \f3\-\-output\f1.
312 .TP 8
313 .B \-O, \-\-missing\-characters
314 Print a listing of character codes which couldn't be printed.
315 .TP 8
316 .B \-p \f2file\f3, \-\-output=\f2file\f3
317 Leave the output to file \f2file\f1.  If the \f2file\f1 is `\-',
318 enscript sends the output to the standard output \f3stdout\f1.
319 .TP 8
320 .B \-P \f2name\f3, \-\-printer=\f2name\f3
321 Spool the output to the printer \f2name\f1.
322 .TP 8
323 .B \-q, \-\-quiet, \-\-silent
324 Make \f3enscript\f1 really quiet.  Only fatal error messages are
325 printed to \f2stderr\f1.
326 .TP 8
327 .B \-r, \-\-landscape
328 Print in the landscape mode; rotate page 90 degrees.
329 .TP 8
330 .B \-R, \-\-portrait
331 Print in the portrait mode (default).
332 .TP 8
333 .B \-s \f2num\f3, \-\-baselineskip=\f2num\f3
334 Specify the baseline skip in PostScript points.  The number \f2num\f1
335 can be given as a decimal number.  When \f3enscript\f1 moves from line
336 to line, the current point \f2y\f1 coordinate is moved (\f2font point
337 size + baselineskip\f1) points down.  The default baseline skip is 1.
338 .TP 8
339 .B \-S \f2key\f1[\f3:\f2value\f1]\f3, \-\-statusdict=\f2key\f1[\f3:\f2value\f1]\f3
340 Pass a statusdict definition to the generated PostScript output.  If
341 no value is given, the key \f2key\f1 is removed from the definitions.
342
343 The statusdict operators are implementation dependent; see the
344 printer's documentation for the details.
345
346 For example, the command
347
348 .B enscript \-Ssetpapertray:1 foo.txt
349
350 prints the file \f2foo.txt\f1 by using paper from the paper tray 1
351 (assuming that the printer supports paper tray selection).
352 .TP 8
353 .B \-t \f2title\f3, \-\-title=\f2title\f3
354 Set banner page's job title to \f2title\f1.  The option sets also the
355 name of the input file \f3stdin\f1.
356 .TP 8
357 .B \-T \f2num\f3, \-\-tabsize=\f2num\f3
358 Set the tabulator size to \f2num\f1 characters.  The default is 8.
359 .TP 8
360 .B \-u\f1[\f2text\f1]\f3, \-\-underlay\f1[\f3=\f2text\f1]\f3
361 Print the string \f2text\f1 under every page.  The properties of the
362 text can be changed with the options \f3\-\-ul\-angle\f1,
363 \f3\-\-ul\-font\f1, \f3\-\-ul\-gray\f1, \f3\-\-ul\-position\f1, and
364 \f3\-\-ul\-style\f1.
365
366 If no \f2text\f1 is given, the underlay is not printed.  This can be used
367 to remove an underlay text that was specified with the
368 `\f3Underlay\f1' configuration file option.
369 .TP 8
370 .B \-U \f2num\f3, \-\-nup=\f2num\f3
371 Print \f2num\f1 logical pages on each output page (N\-up printing).
372 The values \f2num\f1 must be a power of 2.
373 .TP 8
374 .B \-v, \-\-verbose\f1[\f3=\f2level\f1]\f3
375 Tell what \f3enscript\f1 is doing.
376 .TP 8
377 .B \-V, \-\-version
378 Print \f3enscript\f1 version information and exit.
379 .TP 8
380 .B \-w \f1[\f2lang\f1]\f3, \-\-language\f1[\f3=\f2lang\f1]\f3
381 Generate output for the language \f2lang\f1.  The possible values for
382 \f2lang\f1 are:
383 .RS 8
384 .TP 8
385 .B PostScript
386 generate PostScript (default)
387 .TP 8
388 .B html
389 generate HTML
390 .TP 8
391 .B overstrike
392 generate overstrikes (line printers, less)
393 .TP 8
394 .B rtf
395 generate RTF (Rich Text Format)
396 .TP 8
397 .B ansi
398 generate ANSI terminal control codes
399 .RE
400 .TP 8
401 .B \-X \f2name\f3, \-\-encoding=\f2name\f3
402 Use the input encoding \f2name\f1.  Currently \f3enscript\f1 supports
403 the following encodings:
404 .RS 8
405 .TP 8
406 .B 88591, latin1
407 ISO\-8859\-1 (ISO Latin1) (\f3enscript\f1's default encoding).
408 .TP 8
409 .B 88592, latin2
410 ISO\-8859\-2 (ISO Latin2)
411 .TP 8
412 .B 88593, latin3
413 ISO\-8859\-3 (ISO Latin3)
414 .TP 8
415 .B 88594, latin4
416 ISO\-8859\-4 (ISO Latin4)
417 .TP 8
418 .B 88595, cyrillic
419 ISO\-8859\-5 (ISO Cyrillic)
420 .TP 8
421 .B 88597, greek
422 ISO\-8859\-7 (ISO Greek)
423 .TP 8
424 .B 88599, latin5
425 ISO\-8859\-9 (ISO Latin5)
426 .TP 8
427 .B 885910, latin6
428 ISO\-8859\-10 (ISO Latin6)
429 .TP 8
430 .B ascii
431 7\-bit ascii
432 .TP 8
433 .B asciifise, asciifi, asciise
434 7\-bit ascii with some scandinavian (Finland, Sweden) extensions
435 .TP 8
436 .B asciidkno, asciidk, asciino
437 7\-bit ascii with some scandinavian (Denmark, Norway) extensions
438 .TP 8
439 .B ibmpc, pc, dos
440 IBM PC charset
441 .TP 8
442 .B mac
443 Mac charset
444 .TP 8
445 .B vms
446 VMS multinational charset
447 .TP 8
448 .B hp8
449 HP Roman-8 charset
450 .TP 8
451 .B koi8
452 Adobe Standard Cyrillic Font KOI8 charset
453 .TP 8
454 .B ps, PS
455 PostScript font's default encoding
456 .TP 8
457 .B pslatin1, ISOLatin1Encoding
458 PostScript interpreter's `ISOLatin1Encoding'
459 .RE
460 .TP 8
461 .B \-z, \-\-no\-formfeed
462 Turn off the form feed character interpretation.
463 .TP 8
464 .B \-Z, \-\-pass\-through
465 Pass through all PostScript and PCL files without any modifications.
466 This allows that \f3enscript\f1 can be used as a lp filter.
467
468 The PostScript files are recognized by looking up the `%!' magic
469 cookie from the beginning of the file. \f3Note!\f1 \f3Enscript\f1
470 recognized also the Windoze damaged `^D%!' cookie.
471
472 The PCL files are recognized by looking up the `^[E' or `^[%' magic
473 cookies from the beginning of the file.
474 .TP 8
475 .B \-\-color\f1[\f3=\f2bool\f1]\f3
476 Use colors in the highlighting outputs.
477 .TP 8
478 .B \-\-download\-font=\f2fontname\f3
479 Include the font description file (\f2.pfa\f1 or \f2.pfb\f1 file) of
480 the font \f2fontname\f1 to the generated output.
481 .TP 8
482 .B \-\-extended\-return\-values
483 Enable extended return values.  As a default, \f3enscript\f1 returns 1
484 on error and 0 otherwise.  The extended return values give more
485 details about the printing operation.  See the section \f3RETURN
486 VALUE\f1 for the details.
487 .TP 8
488 .B \-\-filter\-stdin=\f2name\f1
489 Specify how the \f3stdin\f1 is shown to the input filter.  The default
490 value is an empty string ("") but some programs require that the
491 \f3stdin\f1 is called something else, usually "-".
492 .TP 8
493 .B \-\-footer=\f2footer\f3
494 Use the text \f2footer\f1 as a page footer.  Otherwise the option
495 works like the \f3\-\-header\f1 option
496 .TP 8
497 .B \-\-h\-column\-height=\f2height\f3
498 Set the horizontal column height to be \f2height\f1 PostScript
499 points.  The option sets the formfeed type to
500 \f3horizontal\-columns\f1.
501 .TP 8
502 .B \-\-help
503 Print a short help message and exit.
504 .TP 8
505 .B \-\-help\-highlight
506 Describe all supported \f3\-\-highlight\f1 languages and file
507 formats.
508 .TP 8
509 .B \-\-highlight\-bar\-gray=\f2gray\f3
510 Specify the gray level which is used in printing the highlight bars.
511 .TP 8
512 .B \-\-list\-media
513 List the names of all known output media and exit successfully.
514 .TP 8
515 .B \-\-margins=\f2left\f3:\f2right\f3:\f2top\f3:\f2bottom\f3
516 Adjust the page marginals to be exactly \f2left\f1, \f2right\f1, \f2top\f1
517 and \f2bottom\f1 PostScript points.  Any of the arguments can be left
518 empty in which case the default value is used.
519 .TP 8
520 .B \-\-mark\-wrapped\-lines\f1[\f3=\f2style\f1]\f3
521 Mark wrapped lines in the output with the style \f2style\f1.  The
522 possible values for the \f2style\f1 are:
523 .RS 8
524 .TP 8
525 .B none
526 do not mark them (default)
527 .TP 8
528 .B plus
529 print a plus (+) character to the end of each wrapped line
530 .TP 8
531 .B box
532 print a black box to the end of each wrapped line
533 .TP 8
534 .B arrow
535 print a small arrow to the end of each wrapped line
536 .RE
537 .TP 8
538 .B \-\-non\-printable\-format=\f2format\f3
539 Specify how the non-printable characters are printed.  The possible
540 values for the \f2format\f1 are:
541 .RS 8
542 .TP 8
543 .B caret
544 caret notation: `^@', `^A', `^B', ...
545 .TP 8
546 .B octal
547 octal notation: `\\000', `\\001', `\\002', ... (default)
548 .TP 8
549 .B questionmark
550 replace non-printable characters with a question mark `?'
551 .TP 8
552 .B space
553 replace non-printable characters with a space ` '
554 .RE
555 .TP 8
556 .B \-\-nup\-columnwise
557 Change the layout of the sub-pages in the N\-up printing from row-wise
558 to columnwise.
559 .TP 8
560 .B \-\-nup\-xpad=\f2num\f3
561 Set the page x-padding of the \f2n\f1-up printing to \f2num\f1
562 PostScript points.  The default is 10 points.
563 .TP 8
564 .B \-\-nup\-ypad=\f2num\f3
565 Set the page y-padding of the \f2n\f1-up printing to \f2num\f1
566 PostScript points.  The default is 10 points.
567 .TP 8
568 .B \-\-page\-label\-format=\f2format\f3
569 Set the page label format to \f2format\f1.  The page label format
570 specifies how the labels for the `%%Page:' PostScript comments are
571 formatted.  The possible values are:
572 .RS 8
573 .TP 8
574 .B short
575 Print the current pagenumber: `%%Page: (1) 1' (default)
576 .TP 8
577 .B long
578 Print the current filename and pagenumber: `%%Page: (main.c:  1) 1'
579 .RE
580 .TP 8
581 .B \-\-ps\-level=\f2level\f3
582 Set the PostScript language level that \f3enscript\f1 uses for its
583 output to \f2level\f1.  The possible values are \f31\f1, and
584 \f32\f1.
585 .TP 8
586 .B \-\-printer\-options=\f2options\f3
587 Pass extra options to the printer command.
588 .TP 8
589 .B \-\-rotate\-even\-pages
590 Rotate each even\-numbered page 180 degrees.
591 .TP 8
592 .B \-\-slice=\f2num\f3
593 Print the vertical slice \f2num\f1.  The slices are vertical regions
594 of input files.  A new slice starts from the point where the line
595 would otherwise be wrapped to the next line.  The slice numbers start
596 from 1.
597 .TP 8
598 .B \-\-style=\f2style\f3
599 Set the highlighting style to \f2style\f1.  The possible values are:
600 \f3a2ps\f1, \f3emacs\f1, \f3emacs_verbose\f1, \f3ifh\f1, and
601 \f3msvc\f1.
602 .TP 8
603 .B \-\-swap\-even\-page\-margins
604 Swap left and right page margins for even\-numbered pages.
605 .TP 8
606 .B \-\-toc
607 Print a table of contents to the end of the output.
608 .TP 8
609 .B \-\-word\-wrap
610 Wrap long lines from word boundaries.
611 .TP 8
612 .B \-\-ul\-angle=\f2angle\f3
613 Set the angle of the underlay text to \f2angle\f1.  As a default,
614 the angle is \f3atan(\-d_page_h, d_page_w)\f1.
615 .TP 8
616 .B \-\-ul\-font=\f2name\f3
617 Select a font for the underlay text.  The default underlay font is
618 \f3Times-Roman200\f1.
619 .TP 8
620 .B \-\-ul\-gray=\f2num\f3
621 Print the underlay text with the gray value \f2num\f1 (0 ... 1), the
622 default gray value is .8.
623 .TP 8
624 .B \-\-ul\-position=\f2position_spec\f3
625 Set the underlay text's starting position according to the
626 \f2position_spec\f1.  The position specification must be given in
627 format: `\f2sign\f1 \f2xpos\f1 \f2sign\f1 \f2ypos\f1', where the
628 \f2sign\f1 must be `+' or `\-'.  The positive dimensions are measured
629 from the lower left corner and the negative dimensions from the upper
630 right corner.  For example, the specification `+0\-0' specifies the
631 upper left corner and `\-0+0' specifies the lower right corner.
632 .TP 8
633 .B \-\-ul\-style=\f2style\f3
634 Set the underlay text's style to \f2style\f1.  The possible values for
635 \f2style\f1 are:
636 .RS 8
637 .TP 8
638 .B outline
639 print outline underlay texts (default)
640 .TP 8
641 .B filled
642 print filled underlay texts
643 .RE
644
645 .SH CONFIGURATION FILES
646
647 .B Enscript
648 reads configuration information from the following sources (in this
649 order): command line options, environment variable \f3ENSCRIPT\f1,
650 user's personal configuration file (\f3$HOME/.enscriptrc\f1), site
651 configuration file (\f3@SYSCONFDIR@/enscriptsite.cfg\f1) and system's
652 global configuration file (\f3@SYSCONFDIR@/enscript.cfg\f1).
653
654 The configuration files have the following format:
655
656 Empty lines and lines starting with `#' are comments.
657
658 All other lines are option lines and have format:
659
660 \f2option\f1 [\f2arguments ...\f1].
661
662 The following options can be specified:
663 .TP 8
664 .B AcceptCompositeCharacters: \f2bool\f1
665 Specify whether PostScript font's composite characters are accepted
666 as printable or if they should be considered as non-existent.  The
667 default value is false (0).
668 .TP 8
669 .B AFMPath: \f2path\f3
670 Specifies the search path for the \f2AFM\f1 files.
671 .TP 8
672 .B AppendCtrlD: \f2bool\f3
673 Specify if the Control-D (^D) character should be appended to the end
674 of the output.  The default value is false (0).
675 .TP 8
676 .B Clean7Bit: \f2bool\f3
677 Specify how characters greater than 127 are printed.  The valuee true
678 (1) generates 7-bit clean code by escaping all characters greater than
679 127 to the backslash-octal notation (default).  The value false (0)
680 generates 8-bit PostScript code leaving all characters untouched.
681 .TP 8
682 .B DefaultEncoding: \f2name\f3
683 Select the default input encoding.  The encoding name \f2name\f1 can
684 be one of the values of the option \f3\-X\f1, \f3\-\-encoding\f1.
685 .TP 8
686 .B DefaultFancyHeader: \f2name\f3
687 Select the default fancy header.  The default header is used when the
688 option \f3\-G\f1 is specified or the option \f3\-\-fancy\-header\f1 is
689 given without an argument.  The system\-wide default is `\f3enscript\f1'.
690 .TP 8
691 .B DefaultMedia: \f2name\f3
692 Select the default output media.
693 .TP 8
694 .B DefaultOutputMethod: \f2method\f3
695 Select the default target to which the generated output is sent.
696 The possible values for the \f2method\f1 are:
697 .RS 8
698 .TP 8
699 .B printer
700 send output to printer (default)
701 .TP 8
702 .B stdout
703 send output to \f3stdout\f1
704 .RE
705 .TP 8
706 .B DownloadFont: \f2fontname\f3
707 Include the font description file of the font \f2fontname\f1 to the
708 generated output.
709 .TP 8
710 .B EscapeChar: \f2num\f3
711 Specify the escape character for the special escapes.  The default
712 value is 0.
713 .TP 8
714 .B FormFeedType: \f2type\f3
715 Specify what to do when a formfeed character is encountered from the
716 input.  The possible values for \f2type\f1 are:
717 .RS 8
718 .TP 8
719 .B column
720 move to the beginning of the next column (default)
721 .TP 8
722 .B page
723 move to the beginning of the next page
724 .RE
725 .TP 8
726 .B GeneratePageSize: \f2bool\f3
727 Specify whether the \f3PageSize\f1 page device setting is generated to
728 the PostScript output.  The default value is true (1).
729 .TP 8
730 .B HighlightBarGray: \f2gray\f3
731 Specify the gray level which is used to print the highlight bars.
732 .TP 8
733 .B HighlightBars: \f2num\f3
734 Specify how high the highlight bars are in lines.  The default value
735 is 0 which means that no highlight bars are printed.
736 .TP 8
737 .B LibraryPath: \f2path\f3
738 Specifies the \f3enscript\f1's library path that is used to lookup
739 various resources.  The default path is:
740 `@DATADIR@/enscript:\f2home\f1/.enscript'.  Where the \f2home\f1 is
741 the user's home directory.
742 .TP 8
743 .B MarkWrappedLines: \f2style\f3
744 Mark wrapped lines in the output with the style \f2style\f1.  The
745 possible values for the \f2format\f1 are the same which can be given
746 for the \f3\-\-mark\-wrapped\-lines\f1 option.
747 .TP 8
748 \f3Media: \f2name\f3 \f2width\f3 \f2height\f3 \f2llx\f3 \f2lly\f3 \f2urx\f3 \f2ury\f3
749 Add a new output media with the name \f2name\f1.  The physical
750 dimensions of the media are \f2width\f1 and \f2height\f1.  The
751 bounding box of the Media is specified by the points (\f2llx\f1,
752 \f2lly\f1) and (\f2urx\f1, \f2ury\f1).  \f3Enscript\f1 prints all
753 graphics inside the bounding box of the media.
754
755 User can select this media with option \f3\-M \f2name\f1.
756 .TP 8
757 .B NoJobHeaderSwitch: \f2switch\f1
758 Specify the spooler option to suppress the print job header page.
759 This option is passed to the printer spooler when the \f3enscript\f1's
760 option \f3\-h\f1, \f3\-\-no\-job\-header\f1 is selected.
761 .TP 8
762 .B NonPrintableFormat: \f2format\f1
763 Specify how the non-printable characters are printed.  The possible
764 values for \f2format\f1 are the same which can be given for the
765 \f3\-\-non\-printable\-format\f1 option.
766 .TP 8
767 .B OutputFirstLine: \f2line\f1
768 Set the PostScript output's first line to \f2line\f1.  The default
769 value is \f3PS-Adobe-3.0\f1.  Since some printers do not like DSC
770 levels greater than 2.0, this option can be used to change the output
771 first line to something more suitable like \f3%!PS-Adobe-2.0\f1 or
772 \f3%!\f1.
773 .TP 8
774 .B PageLabelFormat: \f2format\f1
775 Set the page label format to \f2format\f1.  The possible values for
776 \f2format\f1 are the same which can be given for the
777 \f3\-\-page\-label\-format\f1 option.
778 .TP 8
779 .B PagePrefeed: \f2bool\f3
780 Enable / disable page prefeed.  The default value is false (0).
781 .TP 8
782 .B PostScriptLevel: \f2level\f3
783 Set the PostScript language level, that \f3enscript\f1 uses for its
784 output, to \f2level\f1.  The possible values for \f2level\f1 are the
785 same which can be given for the \f3\-\-ps\-level\f1 option.
786 .TP 8
787 .B Printer: \f2name\f3
788 Names the printer to which the output is spooled.
789 .TP 8
790 .B QueueParam: \f2name\f3
791 The spooler command switch to select the printer queue, e.g. \f3\-P\f1
792 in \f3lpr \-Pps\f1.  This option can also be used to pass other flags
793 to the spooler command.  These options must be given before the queue
794 switch.
795 .TP 8
796 .B SetPageDevice: \f2key\f1[\f3:\f2value\f1]\f3
797 Pass a page device definition to the generated PostScript output.
798 .TP 8
799 .B Spooler: \f2name\f3
800 Names the printer spooler command.  \f3Enscript\f1 pipes generated
801 PostScript to the command \f2name\f1.
802 .TP 8
803 .B StatesBinary: \f2path\f3
804 Define an absolute path to the \f3states\f1 program.
805 .TP 8
806 .B StatesColor: \f2bool\f3
807 Should the \f3states\f1 program generate color outputs.
808 .TP 8
809 .B StatesConfigFile: \f2file\f3
810 Read highlighting states configuration from the file \f2file\f1.  The
811 default config file is `@DATADIR@/enscript/hl/enscript.st'.
812 .TP 8
813 .B StatesHighlightStyle: \f2style\f3
814 Set the highlight style to \f2style\f1.
815 .TP 8
816 .B StatesPath: \f2path\f3
817 Define the path for the \f3states\f1 program.  The \f3states\f1
818 program will lookup its state definition files from this path.  The
819 default value is `$HOME/.enscript:@DATADIR@/enscript/hl'.
820 .TP 8
821 .B StatusDict: \f2key\f1[\f3:\f2value\f1]\f3
822 Pass a statusdict definition to the generated PostScript output.
823 .TP 8
824 .B TOCFormat: \f2format\f3
825 Format table of contents entries with the format string \f2format\f1.
826 The format string \f2format\f1 can contain the same escapes which are
827 used to format header strings with the `%Format' special comment.
828 .TP 8
829 .B Underlay: \f2text\f3
830 Print string \f2text\f1 under every page.
831 .TP 8
832 .B UnderlayAngle: \f2num\f3
833 Set the angle of the underlay text to \f2num\f1.
834 .TP 8
835 .B UnderlayFont: \f2fontspec\f3
836 Select a font for the underlay text.
837 .TP 8
838 .B UnderlayGray: \f2num\f3
839 Print the underlay text with the gray value \f2num\f1.
840 .TP 8
841 .B UnderlayPosition: \f2position_spec\f3
842 Set the underlay text's starting position according to the
843 \f2position_spec\f1.
844 .TP 8
845 .B UnderlayStyle: \f2style\f3
846 Set the underlay text's style to \f2style\f1.
847
848 .SH FANCY HEADERS
849
850 Users can create their own fancy headers by creating a header
851 description file and placing it in a directory which is in
852 \f3enscript\f1's library path.  The name of the header file must be in
853 format: `\f2headername\f1.hdr'.  Header can be selected by giving
854 option: \f3\-\-fancy\-header=\f2headername\f1.
855
856 Header description file contains PostScript code that paints the
857 header.  Description file must provide procedure \f3do_header\f1 which
858 is called by \f3enscript\f1 at the beginning of every page.
859
860 Header description file contains two parts: comments and code.  Parts
861 are separated by a line containing text:
862
863 % \-\- code follows this line \-\-
864
865 .B Enscript
866 copies only the code part of description file to the generated
867 PostScript output.  The comments part can contain any data, it is not
868 copied.  If separator line is missing, no data is copied to output.
869
870 .B Enscript
871 defines following constants which can be used in header description
872 files:
873 .TP 16
874 .B  d_page_w
875 page width
876 .TP 16
877 .B  d_page_h
878 page height
879 .TP 16
880 .B  d_header_x
881 header lower left \f2x\f1 coordinate
882 .TP 16
883 .B  d_header_y
884 header lower left \f2y\f1 coordinate
885 .TP 16
886 .B  d_header_w
887 header width
888 .TP 16
889 .B  d_header_h
890 header height
891 .TP 16
892 .B d_footer_x
893 footer lower left \f2x\f1 coordinate
894 .TP 16
895 .B d_footer_y
896 footer lower left \f2y\f1 coordinate
897 .TP 16
898 .B d_footer_w
899 footer width
900 .TP 16
901 .B d_footer_h
902 footer height
903 .TP 16
904 .B  d_output_w
905 width of the text output area
906 .TP 16
907 .B  d_output_h
908 height of the text output area
909 .TP 16
910 .B  user_header_p
911 predicate which tells if user has defined his/her own header string:
912 \f3true\f1/\f3false\f1
913 .TP 16
914 .B  user_header_left_str
915 if \f3user_header_p\f1 is \f3true\f1, this is the left field of the
916 user supplied header string.
917 .TP 16
918 .B user_header_center_str
919 if \f3user_header_p\f1 is \f3true\f1, this is the center field of the
920 user supplied header string
921 .TP 16
922 .B user_header_right_str
923 if \f3user_header_p\f1 is \f3true\f1, this is the right field of the
924 user supplied header string
925 .TP 16
926 .B  user_footer_p
927 predicate which tells if user has defined his/her own footer string:
928 \f3true\f1/\f3false\f1
929 .TP 16
930 .B  user_footer_left_str
931 if \f3user_footer_p\f1 is \f3true\f1, this is the left field of the
932 user supplied footer string.
933 .TP 16
934 .B user_footer_center_str
935 if \f3user_footer_p\f1 is \f3true\f1, this is the center field of the
936 user supplied footer string
937 .TP 16
938 .B user_footer_right_str
939 if \f3user_footer_p\f1 is \f3true\f1, this is the right field of the
940 user supplied footer string
941 .TP 16
942 .B  HF
943 standard header font (from \f3\-F\f1, \f3\-\-header\-font\f1 option).
944 This can be selected simply by invoking command: `\f3HF setfont\f1'.
945 .TP 16
946 .B pagenum
947 the number of the current page
948 .TP 16
949 .B fname
950 the full name of the printed file (/foo/bar.c)
951 .TP 16
952 .B fdir
953 the directory part of the file name (/foo)
954 .TP 16
955 .B ftail
956 file name without the directory part (bar.c)
957 .TP 16
958 .B gs_languagelevel
959 PostScript interpreter's language level (currently 1 or 2)
960 .P
961
962 You can also use the following special comments to customize your
963 headers and to specify some extra options.  Special comments are like
964 DSC comments but they start with a single `%' character; special
965 comments start from the beginning of the line and they have the
966 following syntax:
967
968 %\f2commentname\f1: \f2options\f1
969
970 Currently \f3enscript\f1 support the following special comments:
971 .TP 8
972 .B %Format: \f2name\f3 \f2format\f3
973 Define a new string constant \f2name\f1 according to the format string
974 \f2format\f1.  Format string start from the first non-space character
975 and it ends to the end of the line.  Format string can contain general
976 `%' escapes and input file related `$' escapes.  Currently following
977 escapes are supported:
978 .RS 8
979 .TP 8
980 .B %%
981 character `%'
982 .TP 8
983 .B $$
984 character `$'
985 .TP 8
986 .B $%
987 current page number
988 .TP 8
989 .B $=
990 number of pages in the current file
991 .TP 8
992 .B $p
993 number of pages processed so far
994 .TP 8
995 .B $(\f2VAR\f3)
996 value of the environment variable \f2VAR\f1.
997 .TP 8
998 .B %c
999 trailing component of the current working directory
1000 .TP 8
1001 .B %C \f1(\f3$C\f1)\f3
1002 current time (file modification time) in `hh:mm:ss' format
1003 .TP 8
1004 .B %d
1005 current working directory
1006 .TP 8
1007 .B %D \f1(\f3$D\f1)\f3
1008 current date (file modification date) in `yy-mm-dd' format
1009 .TP 8
1010 .B %D{\f2string\f3} \f1(\f3$D{\f2string\f3}\f1)\f3
1011 format string \f2string\f1 with the strftime(3) function.
1012 `\f3%D{}\f1' refers to the current date and `\f3$D{}\f1' to the input
1013 file's last modification date.
1014 .TP 8
1015 .B %E \f1(\f3$E\f1)\f3
1016 current date (file modification date) in `yy/mm/dd' format
1017 .TP 8
1018 .B %F \f1(\f3$F\f1)\f3
1019 current date (file modification date) in `dd.mm.yyyy' format
1020 .TP 8
1021 .B %H
1022 document title
1023 .TP 8
1024 .B $L
1025 number of lines in the current input file.  This is valid only for the
1026 toc entries, it can't be used in header strings.
1027 .TP 8
1028 .B %m
1029 the hostname up to the first `.' character
1030 .TP 8
1031 .B %M
1032 the full hostname
1033 .TP 8
1034 .B %n
1035 the user login name
1036 .TP 8
1037 .B $n
1038 input file name without the directory part
1039 .TP 8
1040 .B %N
1041 the user's pw_gecos field up to the first `,' character
1042 .TP 8
1043 .B $N
1044 the full input file name
1045 .TP 8
1046 .B %t \f1(\f3$t\f1)\f3
1047 current time (file modification time) in 12-hour am/pm format
1048 .TP 8
1049 .B %T \f1(\f3$T\f1)\f3
1050 current time (file modification time) in 24-hour format `hh:mm'
1051 .TP 8
1052 .B %* \f1(\f3$*\f1)\f3
1053 current time (file modification time) in 24-hour format with seconds
1054 `hh:mm:ss'
1055 .TP 8
1056 .B $v
1057 the sequence number of the current input file
1058 .TP 8
1059 .B $V
1060 the sequence number of the current input file in the `Table of
1061 Contents' format: if the \f3\-\-toc\f1 option is given, escape expands
1062 to `\f2num\f1\-'; if the \f3\-\-toc\f1 is not given, escape expands to
1063 an empty string.
1064 .TP 8
1065 .B %W \f1(\f3$W\f1)\f3
1066 current date (file modification date) in `mm/dd/yy' format
1067 .RE
1068
1069 .RS 8
1070 All format directives except `$=' can also be given in format
1071
1072 \f2escape\f1 \f2width\f1 \f2directive\f1
1073
1074 where \f2width\f1 specifies the width of the column to which the
1075 escape is printed.  For example, escape "$5%" will expand to something
1076 like " 12".  If the width is negative, the value will be printed
1077 left-justified.
1078
1079 For example, the `emacs.hdr' defines its date string with the
1080 following format comment:
1081
1082 .B %Format: eurdatestr %E
1083
1084 which expands to:
1085
1086 .B /eurdatestr (96/01/08) def
1087 .RE
1088 .P
1089 .TP 8
1090 .B %HeaderHeight: \f2height\f1
1091 Allocate \f2height\f1 points space for the page header.  The default
1092 header height is 36 points.
1093 .TP 8
1094 .B %FooterHeight: \f2height\f1
1095 Allocate \f2height\f1 points space for the page footer.  The default
1096 footer height is 0 points.
1097 .P
1098
1099 According to Adobe's Document Structuring Conventions (DSC), all
1100 resources needed by a document must be listed in document's prolog.
1101 Since user's can create their own headers, \f3enscript\f1 don't know
1102 what resources those headers use.  That's why all headers must contain
1103 a standard DSC comment that lists all needed resources.  For example,
1104 used fonts can be listed with following comment:
1105
1106 %%DocumentNeededResources: font \f2fontname1\f1 \f2fontname2\f1
1107
1108 Comment can be continued to the next line with the standard
1109 continuation comment:
1110
1111 %%+ font \f2fontname3\f1
1112
1113 .SH SPECIAL ESCAPES
1114
1115 \f3Enscript\f1 supports special escape sequences which can be used to
1116 add some page formatting commands to ASCII documents.  As a default,
1117 special escapes interpretation is off, so all ASCII files print out as
1118 everyone expects.  Special escapes interpretation is activated by
1119 giving option \f3\-e\f1, \f3\-\-escapes\f1 to \f3enscript\f1.
1120
1121 All special escapes start with the escape character.  The default
1122 escape character is ^@ (octal 000); escape character can be changed
1123 with option \f3\-e\f1, \f3\-\-escapes\f1.  Escape character is
1124 followed by escape's name and optional options and arguments.
1125
1126 Currently \f3enscript\f1 supports following escapes:
1127 .TP 8
1128 .B bgcolor
1129 change the text background color.  The syntax of the escape is:
1130
1131 ^@bgcolor{\f2red\f1 \f2green\f1 \f2blue\f1}
1132
1133 where the color components \f2red\f1, \f2green\f1, and \f1blue\f1 are
1134 given as decimal numbers between values 0 and 1.
1135
1136 .TP 8
1137 .B bggray
1138 change the text background color.  The syntax of the escape is:
1139
1140 ^@bggray{\f2gray\f1}
1141
1142 where \f2gray\f1 is the new text background gray value.  The default
1143 value is 1.0 (white).
1144 .TP 8
1145 .B color
1146 change the text color.  The syntax of the escape is:
1147
1148 ^@color{\f2red\f1 \f2green\f1 \f2blue\f1}
1149
1150 where color components \f2red\f1, \f2green\f1 and \f2blue\f1 are given
1151 as decimal numbers between values 0 and 1.
1152 .TP 8
1153 .B comment
1154 comment the rest of the line including the newline character.
1155 Escape's syntax is:
1156
1157 ^@comment \f2text\f1 \f2newline_character\f1
1158 .TP 8
1159 .B escape
1160 change the escape character.  The syntax of the escape is:
1161
1162 ^@escape{\f2code\f1}
1163
1164 where \f2code\f1 is the decimal code of the new escape character.
1165 .TP 8
1166 .B epsf
1167 inline EPS file to the document.  The syntax of the escape is:
1168
1169 ^@epsf[\f2options\f1]{\f2filename\f1}
1170
1171 where \f2options\f1 is an optional sequence of option characters and
1172 values enclosed with brackets and \f2filename\f1 is the name of the
1173 EPS file.
1174
1175 If \f2filename\f1 ends to the `|' character, then \f2filename\f1 is
1176 assumed to name a command that prints EPS data to its standard output.
1177 In this case, \f3enscript\f1 opens a pipe to the specified command
1178 and reads EPS data from pipe.
1179
1180 Following options can be given for the \f3epsf\f1 escape:
1181 .RS 8
1182 .TP 8
1183 .B c
1184 print image centered
1185 .TP 8
1186 .B r
1187 print image right justified
1188 .TP 8
1189 .B n
1190 do not update current point.  Following output is printed to that
1191 position where the current point was just before the \f3epsf\f1 escape
1192 .TP 8
1193 .B nx
1194 do not update current point \f2x\f1 coordinate
1195 .TP 8
1196 .B ny
1197 do not update current point \f2y\f1 coordinate
1198 .TP 8
1199 .B x\f2num\f3
1200 move image's top left \f2x\f1 coordinate \f2num\f1 characters from
1201 current point \f2x\f1 coordinate (relative position)
1202 .TP 8
1203 .B x\f2num\f3a
1204 set image's top left \f2x\f1 coordinate to column \f2num\f1 (absolute
1205 position)
1206 .TP 8
1207 .B y\f2num\f3
1208 move image's top left \f2y\f1 coordinate \f2num\f1 lines from current
1209 line (relative position)
1210 .TP 8
1211 .B y\f2num\f3a
1212 set image's top left \f2y\f1 coordinate to line \f2num\f1 (absolute
1213 position)
1214 .TP 8
1215 .B h\f2num\f3
1216 set image's height to \f2num\f1 lines
1217 .TP 8
1218 .B s\f2num\f3
1219 scale image with factor \f2num\f1
1220 .TP 8
1221 .B sx\f2num\f3
1222 scale image in \f2x\f1 direction with factor \f2num\f1
1223 .TP 8
1224 .B sy\f2num\f3
1225 scale image in \f2y\f1 direction with factor \f2num\f1
1226 .P
1227 As a default, all dimensions are given in lines (vertical) and
1228 characters (horizontal).  You can also specify other units by
1229 appending an unit specifier after number.  Possible unit specifiers
1230 and the corresponding units are:
1231 .TP 8
1232 .B c
1233 centimeters
1234 .TP 8
1235 .B i
1236 inches
1237 .TP 8
1238 .B l
1239 lines or characters (default)
1240 .TP 8
1241 .B p
1242 PostScript points
1243 .P
1244 For example to print an image one inch high, you can specify height by
1245 following options: \f3h1i\f1 (1 inch), \f3h2.54c\f1 (2.54 cm),
1246 \f3h72p\f1 (72 points).
1247 .RE
1248 .TP 8
1249 .B font
1250 select current font.  The syntax of the escape is:
1251
1252 ^@font{\f2fontname\f1[:\f2encoding\f1]}
1253
1254 where \f2fontname\f1 is a standard font specification.  Special font
1255 specification \f3default\f1 can be used to select the default body
1256 font (\f3enscript\f1's default or the one specified by the command
1257 line option \f3\-f\f1, \f3\-\-font\f1).
1258
1259 The optional argument \f2encoding\f1 specifies the encoding that
1260 should be used for the new font.  Currently the encoding can only be
1261 the \f3enscript\f1's global input encoding or \f3ps\f1.
1262 .TP 8
1263 .B ps
1264 include raw PostScript code to the output.  The syntax of the escape
1265 is:
1266
1267 ^@ps{\f2code\f1}
1268 .TP 8
1269 .B shade
1270 highlight regions of text by changing the text background color.
1271 Escape's syntax is:
1272
1273 ^@shade{\f2gray\f1}
1274
1275 where \f2gray\f1 is the new text background gray value.  The default
1276 value is 1.0 (white) which disables highlighting.
1277
1278 .SH PAGE DEVICE OPTIONS
1279
1280 Page device is a PostScript level 2 feature that offers an uniform
1281 interface to control printer's output device.  \f3Enscript\f1
1282 protects all page device options inside an if block so they have no
1283 effect in level 1 interpreters.  Although all level 2 interpreters
1284 support page device, they do not have to support all page device
1285 options.  For example some printers can print in duplex mode and some
1286 can not.  Refer to the documentation of your printer for supported
1287 options.
1288
1289 Here are some usable page device options which can be selected with
1290 the \f3\-D\f1, \f3\-\-setpagedevice\f1 option.  For a complete listing,
1291 see \f2PostScript Language Reference Manual\f1: section 4.11 Device
1292 Setup.
1293 .TP 8
1294 .B Collate \f2boolean\f1
1295 how output is organized when printing multiple copies
1296 .TP 8
1297 .B Duplex \f2boolean\f1
1298 duplex (two side) printing
1299 .TP 8
1300 .B ManualFeed \f2boolean\f1
1301 manual feed paper tray
1302 .TP 8
1303 .B OutputFaceUp \f2boolean\f1
1304 print output `face up' or `face down'
1305 .TP 8
1306 .B Tumble \f2boolean\f1
1307 how opposite sides are positioned in duplex printing
1308
1309 .SH PRINTING EXAMPLES
1310
1311 Following printing examples assume that \f3enscript\f1 uses the
1312 default configuration.  If default actions have been changed from the
1313 configuration files, some examples will behave differently.
1314 .TP 8
1315 .B enscript foo.txt
1316 Print file \f3foo.txt\f1 to the default printer.
1317 .TP 8
1318 .B enscript \-Possu foo.txt
1319 Print file \f3foo.txt\f1 to printer \f3ossu\f1.
1320 .TP 8
1321 .B enscript \-pfoo.ps foo.txt
1322 Print file \f3foo.txt\f1, but leave PostScript output to file
1323 \f3foo.ps\f1.
1324 .TP 8
1325 .B enscript \-2 foo.txt
1326 Print file \f3foo.txt\f1 to two columns.
1327 .TP 8
1328 .B enscript \-2r foo.txt
1329 Print file to two columns and rotate output 90 degrees (landscape).
1330 .TP 8
1331 .B enscript \-DDuplex:true foo.txt
1332 Print file in duplex (two side) mode (printer dependent).
1333 .TP 8
1334 .B enscript \-G2rE \-U2 foo.c
1335 My default code printing command: gaudy header, two columns,
1336 landscape, code highlighting, 2-up printing.
1337 .TP 8
1338 \f3enscript \-E \-\-color \-whtml \-\-toc \-pfoo.html *.h *.c\f1
1339 A nice HTML report of your project's C source files.
1340
1341 .SH ENVIRONMENT VARIABLES
1342
1343 The environment variable \f3ENSCRIPT\f1 can be used to pass default
1344 options for \f3enscript\f1.  For example, to select the default body
1345 font to be Times\-Roman 7pt, set the following value to the
1346 \f3ENSCRIPT\f1 environment variable:
1347 .TP 8
1348 .B \-fTimes\-Roman7
1349 .P
1350
1351 The value of the \f3ENSCRIPT\f1 variable is processed before the
1352 command line options, so command line options can be used to overwrite
1353 these defaults.
1354
1355 Variable \f3ENSCRIPT_LIBRARY\f1 specifies the \f3enscript\f1's
1356 library directory.  It can be used to overwrite the build-in default
1357 `@DATADIR@/enscript'.
1358
1359 .SH RETURN VALUE
1360
1361 \f3Enscript\f1 returns value 1 to the shell if any errors were
1362 encountered or 0 otherwise.  If the option
1363 \f3\-\-extended\-return\-values\f1 was specified, the return value is
1364 constructed from the following flags:
1365 .TP 8
1366 .B 0
1367 no errors or warnings
1368 .TP 8
1369 .B 2
1370 some lines were truncated or wrapped
1371 .TP 8
1372 .B 4
1373 some characters were missing from the used fonts
1374 .TP 8
1375 .B 8
1376 some characters were unprintable
1377
1378 .SH FILES
1379
1380 .nf
1381 .ta 4i
1382 @DATADIR@/enscript/*.hdr                header files
1383 @DATADIR@/enscript/*.enc                input encoding vectors
1384 @DATADIR@/enscript/enscript.pro PostScript prolog
1385 @DATADIR@/enscript/afm/*.afm            AFM files for PostScript fonts
1386 @DATADIR@/enscript/font.map     index for the AFM files
1387 @DATADIR@/enscript/hl/*.st      states definition files
1388 @SYSCONFDIR@/enscript.cfg               system\-wide configuration file
1389 @SYSCONFDIR@/enscriptsite.cfg           site configuration file
1390 ~/.enscriptrc                           personal configuration file
1391 ~/.enscript/                            personal resource directory
1392 .fi
1393
1394 .SH USING NEW FONTS
1395
1396 If you instruct enscript to use a font whose name does not appear in the
1397 font map, it will give the warning "couldn't open AFM file for font".
1398
1399 To create an AFM file for a TrueType font, you can use \f3ttf2pt1\f1.
1400
1401 Once you create the AFM file, you must add it to the font map.
1402
1403 To generate a new font map automatically, use \f3mkafmmap\f1.
1404
1405 .SH SEE ALSO
1406 diffpp(1), ghostview(1), gs(1), lpq(1), lpr(1), lprm(1), states(1)
1407
1408 .SH AUTHOR
1409 Markku Rossi <mtr@iki.fi> <http://www.iki.fi/~mtr/>
1410
1411 GNU Enscript WWW home page: <http://www.iki.fi/~mtr/genscript/>