Mention options for helper apps in manual page
[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 \-W \f2app\f1,\f2option\f3, \-\-language\f3=\f2app\f1,\f2option\f3
402 pass the option \f2option\f3 to helper application \f2app\f3.
403 .TP 8
404 .B \-X \f2name\f3, \-\-encoding=\f2name\f3
405 Use the input encoding \f2name\f1.  Currently \f3enscript\f1 supports
406 the following encodings:
407 .RS 8
408 .TP 8
409 .B 88591, latin1
410 ISO\-8859\-1 (ISO Latin1) (\f3enscript\f1's default encoding).
411 .TP 8
412 .B 88592, latin2
413 ISO\-8859\-2 (ISO Latin2)
414 .TP 8
415 .B 88593, latin3
416 ISO\-8859\-3 (ISO Latin3)
417 .TP 8
418 .B 88594, latin4
419 ISO\-8859\-4 (ISO Latin4)
420 .TP 8
421 .B 88595, cyrillic
422 ISO\-8859\-5 (ISO Cyrillic)
423 .TP 8
424 .B 88597, greek
425 ISO\-8859\-7 (ISO Greek)
426 .TP 8
427 .B 88599, latin5
428 ISO\-8859\-9 (ISO Latin5)
429 .TP 8
430 .B 885910, latin6
431 ISO\-8859\-10 (ISO Latin6)
432 .TP 8
433 .B ascii
434 7\-bit ascii
435 .TP 8
436 .B asciifise, asciifi, asciise
437 7\-bit ascii with some scandinavian (Finland, Sweden) extensions
438 .TP 8
439 .B asciidkno, asciidk, asciino
440 7\-bit ascii with some scandinavian (Denmark, Norway) extensions
441 .TP 8
442 .B ibmpc, pc, dos
443 IBM PC charset
444 .TP 8
445 .B mac
446 Mac charset
447 .TP 8
448 .B vms
449 VMS multinational charset
450 .TP 8
451 .B hp8
452 HP Roman-8 charset
453 .TP 8
454 .B koi8
455 Adobe Standard Cyrillic Font KOI8 charset
456 .TP 8
457 .B ps, PS
458 PostScript font's default encoding
459 .TP 8
460 .B pslatin1, ISOLatin1Encoding
461 PostScript interpreter's `ISOLatin1Encoding'
462 .RE
463 .TP 8
464 .B \-z, \-\-no\-formfeed
465 Turn off the form feed character interpretation.
466 .TP 8
467 .B \-Z, \-\-pass\-through
468 Pass through all PostScript and PCL files without any modifications.
469 This allows that \f3enscript\f1 can be used as a lp filter.
470
471 The PostScript files are recognized by looking up the `%!' magic
472 cookie from the beginning of the file. \f3Note!\f1 \f3Enscript\f1
473 recognized also the Windoze damaged `^D%!' cookie.
474
475 The PCL files are recognized by looking up the `^[E' or `^[%' magic
476 cookies from the beginning of the file.
477 .TP 8
478 .B \-\-color\f1[\f3=\f2bool\f1]\f3
479 Use colors in the highlighting outputs.
480 .TP 8
481 .B \-\-download\-font=\f2fontname\f3
482 Include the font description file (\f2.pfa\f1 or \f2.pfb\f1 file) of
483 the font \f2fontname\f1 to the generated output.
484 .TP 8
485 .B \-\-extended\-return\-values
486 Enable extended return values.  As a default, \f3enscript\f1 returns 1
487 on error and 0 otherwise.  The extended return values give more
488 details about the printing operation.  See the section \f3RETURN
489 VALUE\f1 for the details.
490 .TP 8
491 .B \-\-filter\-stdin=\f2name\f1
492 Specify how the \f3stdin\f1 is shown to the input filter.  The default
493 value is an empty string ("") but some programs require that the
494 \f3stdin\f1 is called something else, usually "-".
495 .TP 8
496 .B \-\-footer=\f2footer\f3
497 Use the text \f2footer\f1 as a page footer.  Otherwise the option
498 works like the \f3\-\-header\f1 option
499 .TP 8
500 .B \-\-h\-column\-height=\f2height\f3
501 Set the horizontal column height to be \f2height\f1 PostScript
502 points.  The option sets the formfeed type to
503 \f3horizontal\-columns\f1.
504 .TP 8
505 .B \-\-help
506 Print a short help message and exit.
507 .TP 8
508 .B \-\-help\-highlight
509 Describe all supported \f3\-\-highlight\f1 languages and file
510 formats.
511 .TP 8
512 .B \-\-highlight\-bar\-gray=\f2gray\f3
513 Specify the gray level which is used in printing the highlight bars.
514 .TP 8
515 .B \-\-list\-media
516 List the names of all known output media and exit successfully.
517 .TP 8
518 .B \-\-margins=\f2left\f3:\f2right\f3:\f2top\f3:\f2bottom\f3
519 Adjust the page marginals to be exactly \f2left\f1, \f2right\f1, \f2top\f1
520 and \f2bottom\f1 PostScript points.  Any of the arguments can be left
521 empty in which case the default value is used.
522 .TP 8
523 .B \-\-mark\-wrapped\-lines\f1[\f3=\f2style\f1]\f3
524 Mark wrapped lines in the output with the style \f2style\f1.  The
525 possible values for the \f2style\f1 are:
526 .RS 8
527 .TP 8
528 .B none
529 do not mark them (default)
530 .TP 8
531 .B plus
532 print a plus (+) character to the end of each wrapped line
533 .TP 8
534 .B box
535 print a black box to the end of each wrapped line
536 .TP 8
537 .B arrow
538 print a small arrow to the end of each wrapped line
539 .RE
540 .TP 8
541 .B \-\-non\-printable\-format=\f2format\f3
542 Specify how the non-printable characters are printed.  The possible
543 values for the \f2format\f1 are:
544 .RS 8
545 .TP 8
546 .B caret
547 caret notation: `^@', `^A', `^B', ...
548 .TP 8
549 .B octal
550 octal notation: `\\000', `\\001', `\\002', ... (default)
551 .TP 8
552 .B questionmark
553 replace non-printable characters with a question mark `?'
554 .TP 8
555 .B space
556 replace non-printable characters with a space ` '
557 .RE
558 .TP 8
559 .B \-\-nup\-columnwise
560 Change the layout of the sub-pages in the N\-up printing from row-wise
561 to columnwise.
562 .TP 8
563 .B \-\-nup\-xpad=\f2num\f3
564 Set the page x-padding of the \f2n\f1-up printing to \f2num\f1
565 PostScript points.  The default is 10 points.
566 .TP 8
567 .B \-\-nup\-ypad=\f2num\f3
568 Set the page y-padding of the \f2n\f1-up printing to \f2num\f1
569 PostScript points.  The default is 10 points.
570 .TP 8
571 .B \-\-page\-label\-format=\f2format\f3
572 Set the page label format to \f2format\f1.  The page label format
573 specifies how the labels for the `%%Page:' PostScript comments are
574 formatted.  The possible values are:
575 .RS 8
576 .TP 8
577 .B short
578 Print the current pagenumber: `%%Page: (1) 1' (default)
579 .TP 8
580 .B long
581 Print the current filename and pagenumber: `%%Page: (main.c:  1) 1'
582 .RE
583 .TP 8
584 .B \-\-ps\-level=\f2level\f3
585 Set the PostScript language level that \f3enscript\f1 uses for its
586 output to \f2level\f1.  The possible values are \f31\f1, and
587 \f32\f1.
588 .TP 8
589 .B \-\-printer\-options=\f2options\f3
590 Pass extra options to the printer command.
591 .TP 8
592 .B \-\-rotate\-even\-pages
593 Rotate each even\-numbered page 180 degrees.
594 .TP 8
595 .B \-\-slice=\f2num\f3
596 Print the vertical slice \f2num\f1.  The slices are vertical regions
597 of input files.  A new slice starts from the point where the line
598 would otherwise be wrapped to the next line.  The slice numbers start
599 from 1.
600 .TP 8
601 .B \-\-style=\f2style\f3
602 Set the highlighting style to \f2style\f1.  The possible values are:
603 \f3a2ps\f1, \f3emacs\f1, \f3emacs_verbose\f1, \f3ifh\f1, and
604 \f3msvc\f1.
605 .TP 8
606 .B \-\-swap\-even\-page\-margins
607 Swap left and right page margins for even\-numbered pages.
608 .TP 8
609 .B \-\-toc
610 Print a table of contents to the end of the output.
611 .TP 8
612 .B \-\-word\-wrap
613 Wrap long lines from word boundaries.
614 .TP 8
615 .B \-\-ul\-angle=\f2angle\f3
616 Set the angle of the underlay text to \f2angle\f1.  As a default,
617 the angle is \f3atan(\-d_page_h, d_page_w)\f1.
618 .TP 8
619 .B \-\-ul\-font=\f2name\f3
620 Select a font for the underlay text.  The default underlay font is
621 \f3Times-Roman200\f1.
622 .TP 8
623 .B \-\-ul\-gray=\f2num\f3
624 Print the underlay text with the gray value \f2num\f1 (0 ... 1), the
625 default gray value is .8.
626 .TP 8
627 .B \-\-ul\-position=\f2position_spec\f3
628 Set the underlay text's starting position according to the
629 \f2position_spec\f1.  The position specification must be given in
630 format: `\f2sign\f1 \f2xpos\f1 \f2sign\f1 \f2ypos\f1', where the
631 \f2sign\f1 must be `+' or `\-'.  The positive dimensions are measured
632 from the lower left corner and the negative dimensions from the upper
633 right corner.  For example, the specification `+0\-0' specifies the
634 upper left corner and `\-0+0' specifies the lower right corner.
635 .TP 8
636 .B \-\-ul\-style=\f2style\f3
637 Set the underlay text's style to \f2style\f1.  The possible values for
638 \f2style\f1 are:
639 .RS 8
640 .TP 8
641 .B outline
642 print outline underlay texts (default)
643 .TP 8
644 .B filled
645 print filled underlay texts
646 .RE
647
648 .SH CONFIGURATION FILES
649
650 .B Enscript
651 reads configuration information from the following sources (in this
652 order): command line options, environment variable \f3ENSCRIPT\f1,
653 user's personal configuration file (\f3$HOME/.enscriptrc\f1), site
654 configuration file (\f3@SYSCONFDIR@/enscriptsite.cfg\f1) and system's
655 global configuration file (\f3@SYSCONFDIR@/enscript.cfg\f1).
656
657 The configuration files have the following format:
658
659 Empty lines and lines starting with `#' are comments.
660
661 All other lines are option lines and have format:
662
663 \f2option\f1 [\f2arguments ...\f1].
664
665 The following options can be specified:
666 .TP 8
667 .B AcceptCompositeCharacters: \f2bool\f1
668 Specify whether PostScript font's composite characters are accepted
669 as printable or if they should be considered as non-existent.  The
670 default value is false (0).
671 .TP 8
672 .B AFMPath: \f2path\f3
673 Specifies the search path for the \f2AFM\f1 files.
674 .TP 8
675 .B AppendCtrlD: \f2bool\f3
676 Specify if the Control-D (^D) character should be appended to the end
677 of the output.  The default value is false (0).
678 .TP 8
679 .B Clean7Bit: \f2bool\f3
680 Specify how characters greater than 127 are printed.  The valuee true
681 (1) generates 7-bit clean code by escaping all characters greater than
682 127 to the backslash-octal notation (default).  The value false (0)
683 generates 8-bit PostScript code leaving all characters untouched.
684 .TP 8
685 .B DefaultEncoding: \f2name\f3
686 Select the default input encoding.  The encoding name \f2name\f1 can
687 be one of the values of the option \f3\-X\f1, \f3\-\-encoding\f1.
688 .TP 8
689 .B DefaultFancyHeader: \f2name\f3
690 Select the default fancy header.  The default header is used when the
691 option \f3\-G\f1 is specified or the option \f3\-\-fancy\-header\f1 is
692 given without an argument.  The system\-wide default is `\f3enscript\f1'.
693 .TP 8
694 .B DefaultMedia: \f2name\f3
695 Select the default output media.
696 .TP 8
697 .B DefaultOutputMethod: \f2method\f3
698 Select the default target to which the generated output is sent.
699 The possible values for the \f2method\f1 are:
700 .RS 8
701 .TP 8
702 .B printer
703 send output to printer (default)
704 .TP 8
705 .B stdout
706 send output to \f3stdout\f1
707 .RE
708 .TP 8
709 .B DownloadFont: \f2fontname\f3
710 Include the font description file of the font \f2fontname\f1 to the
711 generated output.
712 .TP 8
713 .B EscapeChar: \f2num\f3
714 Specify the escape character for the special escapes.  The default
715 value is 0.
716 .TP 8
717 .B FormFeedType: \f2type\f3
718 Specify what to do when a formfeed character is encountered from the
719 input.  The possible values for \f2type\f1 are:
720 .RS 8
721 .TP 8
722 .B column
723 move to the beginning of the next column (default)
724 .TP 8
725 .B page
726 move to the beginning of the next page
727 .RE
728 .TP 8
729 .B GeneratePageSize: \f2bool\f3
730 Specify whether the \f3PageSize\f1 page device setting is generated to
731 the PostScript output.  The default value is true (1).
732 .TP 8
733 .B HighlightBarGray: \f2gray\f3
734 Specify the gray level which is used to print the highlight bars.
735 .TP 8
736 .B HighlightBars: \f2num\f3
737 Specify how high the highlight bars are in lines.  The default value
738 is 0 which means that no highlight bars are printed.
739 .TP 8
740 .B LibraryPath: \f2path\f3
741 Specifies the \f3enscript\f1's library path that is used to lookup
742 various resources.  The default path is:
743 `@DATADIR@/enscript:\f2home\f1/.enscript'.  Where the \f2home\f1 is
744 the user's home directory.
745 .TP 8
746 .B MarkWrappedLines: \f2style\f3
747 Mark wrapped lines in the output with the style \f2style\f1.  The
748 possible values for the \f2format\f1 are the same which can be given
749 for the \f3\-\-mark\-wrapped\-lines\f1 option.
750 .TP 8
751 \f3Media: \f2name\f3 \f2width\f3 \f2height\f3 \f2llx\f3 \f2lly\f3 \f2urx\f3 \f2ury\f3
752 Add a new output media with the name \f2name\f1.  The physical
753 dimensions of the media are \f2width\f1 and \f2height\f1.  The
754 bounding box of the Media is specified by the points (\f2llx\f1,
755 \f2lly\f1) and (\f2urx\f1, \f2ury\f1).  \f3Enscript\f1 prints all
756 graphics inside the bounding box of the media.
757
758 User can select this media with option \f3\-M \f2name\f1.
759 .TP 8
760 .B NoJobHeaderSwitch: \f2switch\f1
761 Specify the spooler option to suppress the print job header page.
762 This option is passed to the printer spooler when the \f3enscript\f1's
763 option \f3\-h\f1, \f3\-\-no\-job\-header\f1 is selected.
764 .TP 8
765 .B NonPrintableFormat: \f2format\f1
766 Specify how the non-printable characters are printed.  The possible
767 values for \f2format\f1 are the same which can be given for the
768 \f3\-\-non\-printable\-format\f1 option.
769 .TP 8
770 .B OutputFirstLine: \f2line\f1
771 Set the PostScript output's first line to \f2line\f1.  The default
772 value is \f3PS-Adobe-3.0\f1.  Since some printers do not like DSC
773 levels greater than 2.0, this option can be used to change the output
774 first line to something more suitable like \f3%!PS-Adobe-2.0\f1 or
775 \f3%!\f1.
776 .TP 8
777 .B PageLabelFormat: \f2format\f1
778 Set the page label format to \f2format\f1.  The possible values for
779 \f2format\f1 are the same which can be given for the
780 \f3\-\-page\-label\-format\f1 option.
781 .TP 8
782 .B PagePrefeed: \f2bool\f3
783 Enable / disable page prefeed.  The default value is false (0).
784 .TP 8
785 .B PostScriptLevel: \f2level\f3
786 Set the PostScript language level, that \f3enscript\f1 uses for its
787 output, to \f2level\f1.  The possible values for \f2level\f1 are the
788 same which can be given for the \f3\-\-ps\-level\f1 option.
789 .TP 8
790 .B Printer: \f2name\f3
791 Names the printer to which the output is spooled.
792 .TP 8
793 .B QueueParam: \f2name\f3
794 The spooler command switch to select the printer queue, e.g. \f3\-P\f1
795 in \f3lpr \-Pps\f1.  This option can also be used to pass other flags
796 to the spooler command.  These options must be given before the queue
797 switch.
798 .TP 8
799 .B SetPageDevice: \f2key\f1[\f3:\f2value\f1]\f3
800 Pass a page device definition to the generated PostScript output.
801 .TP 8
802 .B Spooler: \f2name\f3
803 Names the printer spooler command.  \f3Enscript\f1 pipes generated
804 PostScript to the command \f2name\f1.
805 .TP 8
806 .B StatesBinary: \f2path\f3
807 Define an absolute path to the \f3states\f1 program.
808 .TP 8
809 .B StatesColor: \f2bool\f3
810 Should the \f3states\f1 program generate color outputs.
811 .TP 8
812 .B StatesConfigFile: \f2file\f3
813 Read highlighting states configuration from the file \f2file\f1.  The
814 default config file is `@DATADIR@/enscript/hl/enscript.st'.
815 .TP 8
816 .B StatesHighlightStyle: \f2style\f3
817 Set the highlight style to \f2style\f1.
818 .TP 8
819 .B StatesPath: \f2path\f3
820 Define the path for the \f3states\f1 program.  The \f3states\f1
821 program will lookup its state definition files from this path.  The
822 default value is `$HOME/.enscript:@DATADIR@/enscript/hl'.
823 .TP 8
824 .B StatusDict: \f2key\f1[\f3:\f2value\f1]\f3
825 Pass a statusdict definition to the generated PostScript output.
826 .TP 8
827 .B TOCFormat: \f2format\f3
828 Format table of contents entries with the format string \f2format\f1.
829 The format string \f2format\f1 can contain the same escapes which are
830 used to format header strings with the `%Format' special comment.
831 .TP 8
832 .B Underlay: \f2text\f3
833 Print string \f2text\f1 under every page.
834 .TP 8
835 .B UnderlayAngle: \f2num\f3
836 Set the angle of the underlay text to \f2num\f1.
837 .TP 8
838 .B UnderlayFont: \f2fontspec\f3
839 Select a font for the underlay text.
840 .TP 8
841 .B UnderlayGray: \f2num\f3
842 Print the underlay text with the gray value \f2num\f1.
843 .TP 8
844 .B UnderlayPosition: \f2position_spec\f3
845 Set the underlay text's starting position according to the
846 \f2position_spec\f1.
847 .TP 8
848 .B UnderlayStyle: \f2style\f3
849 Set the underlay text's style to \f2style\f1.
850
851 .SH FANCY HEADERS
852
853 Users can create their own fancy headers by creating a header
854 description file and placing it in a directory which is in
855 \f3enscript\f1's library path.  The name of the header file must be in
856 format: `\f2headername\f1.hdr'.  Header can be selected by giving
857 option: \f3\-\-fancy\-header=\f2headername\f1.
858
859 Header description file contains PostScript code that paints the
860 header.  Description file must provide procedure \f3do_header\f1 which
861 is called by \f3enscript\f1 at the beginning of every page.
862
863 Header description file contains two parts: comments and code.  Parts
864 are separated by a line containing text:
865
866 % \-\- code follows this line \-\-
867
868 .B Enscript
869 copies only the code part of description file to the generated
870 PostScript output.  The comments part can contain any data, it is not
871 copied.  If separator line is missing, no data is copied to output.
872
873 .B Enscript
874 defines following constants which can be used in header description
875 files:
876 .TP 16
877 .B  d_page_w
878 page width
879 .TP 16
880 .B  d_page_h
881 page height
882 .TP 16
883 .B  d_header_x
884 header lower left \f2x\f1 coordinate
885 .TP 16
886 .B  d_header_y
887 header lower left \f2y\f1 coordinate
888 .TP 16
889 .B  d_header_w
890 header width
891 .TP 16
892 .B  d_header_h
893 header height
894 .TP 16
895 .B d_footer_x
896 footer lower left \f2x\f1 coordinate
897 .TP 16
898 .B d_footer_y
899 footer lower left \f2y\f1 coordinate
900 .TP 16
901 .B d_footer_w
902 footer width
903 .TP 16
904 .B d_footer_h
905 footer height
906 .TP 16
907 .B  d_output_w
908 width of the text output area
909 .TP 16
910 .B  d_output_h
911 height of the text output area
912 .TP 16
913 .B  user_header_p
914 predicate which tells if user has defined his/her own header string:
915 \f3true\f1/\f3false\f1
916 .TP 16
917 .B  user_header_left_str
918 if \f3user_header_p\f1 is \f3true\f1, this is the left field of the
919 user supplied header string.
920 .TP 16
921 .B user_header_center_str
922 if \f3user_header_p\f1 is \f3true\f1, this is the center field of the
923 user supplied header string
924 .TP 16
925 .B user_header_right_str
926 if \f3user_header_p\f1 is \f3true\f1, this is the right field of the
927 user supplied header string
928 .TP 16
929 .B  user_footer_p
930 predicate which tells if user has defined his/her own footer string:
931 \f3true\f1/\f3false\f1
932 .TP 16
933 .B  user_footer_left_str
934 if \f3user_footer_p\f1 is \f3true\f1, this is the left field of the
935 user supplied footer string.
936 .TP 16
937 .B user_footer_center_str
938 if \f3user_footer_p\f1 is \f3true\f1, this is the center field of the
939 user supplied footer string
940 .TP 16
941 .B user_footer_right_str
942 if \f3user_footer_p\f1 is \f3true\f1, this is the right field of the
943 user supplied footer string
944 .TP 16
945 .B  HF
946 standard header font (from \f3\-F\f1, \f3\-\-header\-font\f1 option).
947 This can be selected simply by invoking command: `\f3HF setfont\f1'.
948 .TP 16
949 .B pagenum
950 the number of the current page
951 .TP 16
952 .B fname
953 the full name of the printed file (/foo/bar.c)
954 .TP 16
955 .B fdir
956 the directory part of the file name (/foo)
957 .TP 16
958 .B ftail
959 file name without the directory part (bar.c)
960 .TP 16
961 .B gs_languagelevel
962 PostScript interpreter's language level (currently 1 or 2)
963 .P
964
965 You can also use the following special comments to customize your
966 headers and to specify some extra options.  Special comments are like
967 DSC comments but they start with a single `%' character; special
968 comments start from the beginning of the line and they have the
969 following syntax:
970
971 %\f2commentname\f1: \f2options\f1
972
973 Currently \f3enscript\f1 support the following special comments:
974 .TP 8
975 .B %Format: \f2name\f3 \f2format\f3
976 Define a new string constant \f2name\f1 according to the format string
977 \f2format\f1.  Format string start from the first non-space character
978 and it ends to the end of the line.  Format string can contain general
979 `%' escapes and input file related `$' escapes.  Currently following
980 escapes are supported:
981 .RS 8
982 .TP 8
983 .B %%
984 character `%'
985 .TP 8
986 .B $$
987 character `$'
988 .TP 8
989 .B $%
990 current page number
991 .TP 8
992 .B $=
993 number of pages in the current file
994 .TP 8
995 .B $p
996 number of pages processed so far
997 .TP 8
998 .B $(\f2VAR\f3)
999 value of the environment variable \f2VAR\f1.
1000 .TP 8
1001 .B %c
1002 trailing component of the current working directory
1003 .TP 8
1004 .B %C \f1(\f3$C\f1)\f3
1005 current time (file modification time) in `hh:mm:ss' format
1006 .TP 8
1007 .B %d
1008 current working directory
1009 .TP 8
1010 .B %D \f1(\f3$D\f1)\f3
1011 current date (file modification date) in `yy-mm-dd' format
1012 .TP 8
1013 .B %D{\f2string\f3} \f1(\f3$D{\f2string\f3}\f1)\f3
1014 format string \f2string\f1 with the strftime(3) function.
1015 `\f3%D{}\f1' refers to the current date and `\f3$D{}\f1' to the input
1016 file's last modification date.
1017 .TP 8
1018 .B %E \f1(\f3$E\f1)\f3
1019 current date (file modification date) in `yy/mm/dd' format
1020 .TP 8
1021 .B %F \f1(\f3$F\f1)\f3
1022 current date (file modification date) in `dd.mm.yyyy' format
1023 .TP 8
1024 .B %H
1025 document title
1026 .TP 8
1027 .B $L
1028 number of lines in the current input file.  This is valid only for the
1029 toc entries, it can't be used in header strings.
1030 .TP 8
1031 .B %m
1032 the hostname up to the first `.' character
1033 .TP 8
1034 .B %M
1035 the full hostname
1036 .TP 8
1037 .B %n
1038 the user login name
1039 .TP 8
1040 .B $n
1041 input file name without the directory part
1042 .TP 8
1043 .B %N
1044 the user's pw_gecos field up to the first `,' character
1045 .TP 8
1046 .B $N
1047 the full input file name
1048 .TP 8
1049 .B %t \f1(\f3$t\f1)\f3
1050 current time (file modification time) in 12-hour am/pm format
1051 .TP 8
1052 .B %T \f1(\f3$T\f1)\f3
1053 current time (file modification time) in 24-hour format `hh:mm'
1054 .TP 8
1055 .B %* \f1(\f3$*\f1)\f3
1056 current time (file modification time) in 24-hour format with seconds
1057 `hh:mm:ss'
1058 .TP 8
1059 .B $v
1060 the sequence number of the current input file
1061 .TP 8
1062 .B $V
1063 the sequence number of the current input file in the `Table of
1064 Contents' format: if the \f3\-\-toc\f1 option is given, escape expands
1065 to `\f2num\f1\-'; if the \f3\-\-toc\f1 is not given, escape expands to
1066 an empty string.
1067 .TP 8
1068 .B %W \f1(\f3$W\f1)\f3
1069 current date (file modification date) in `mm/dd/yy' format
1070 .RE
1071
1072 .RS 8
1073 All format directives except `$=' can also be given in format
1074
1075 \f2escape\f1 \f2width\f1 \f2directive\f1
1076
1077 where \f2width\f1 specifies the width of the column to which the
1078 escape is printed.  For example, escape "$5%" will expand to something
1079 like " 12".  If the width is negative, the value will be printed
1080 left-justified.
1081
1082 For example, the `emacs.hdr' defines its date string with the
1083 following format comment:
1084
1085 .B %Format: eurdatestr %E
1086
1087 which expands to:
1088
1089 .B /eurdatestr (96/01/08) def
1090 .RE
1091 .P
1092 .TP 8
1093 .B %HeaderHeight: \f2height\f1
1094 Allocate \f2height\f1 points space for the page header.  The default
1095 header height is 36 points.
1096 .TP 8
1097 .B %FooterHeight: \f2height\f1
1098 Allocate \f2height\f1 points space for the page footer.  The default
1099 footer height is 0 points.
1100 .P
1101
1102 According to Adobe's Document Structuring Conventions (DSC), all
1103 resources needed by a document must be listed in document's prolog.
1104 Since user's can create their own headers, \f3enscript\f1 don't know
1105 what resources those headers use.  That's why all headers must contain
1106 a standard DSC comment that lists all needed resources.  For example,
1107 used fonts can be listed with following comment:
1108
1109 %%DocumentNeededResources: font \f2fontname1\f1 \f2fontname2\f1
1110
1111 Comment can be continued to the next line with the standard
1112 continuation comment:
1113
1114 %%+ font \f2fontname3\f1
1115
1116 .SH SPECIAL ESCAPES
1117
1118 \f3Enscript\f1 supports special escape sequences which can be used to
1119 add some page formatting commands to ASCII documents.  As a default,
1120 special escapes interpretation is off, so all ASCII files print out as
1121 everyone expects.  Special escapes interpretation is activated by
1122 giving option \f3\-e\f1, \f3\-\-escapes\f1 to \f3enscript\f1.
1123
1124 All special escapes start with the escape character.  The default
1125 escape character is ^@ (octal 000); escape character can be changed
1126 with option \f3\-e\f1, \f3\-\-escapes\f1.  Escape character is
1127 followed by escape's name and optional options and arguments.
1128
1129 Currently \f3enscript\f1 supports following escapes:
1130 .TP 8
1131 .B bgcolor
1132 change the text background color.  The syntax of the escape is:
1133
1134 ^@bgcolor{\f2red\f1 \f2green\f1 \f2blue\f1}
1135
1136 where the color components \f2red\f1, \f2green\f1, and \f1blue\f1 are
1137 given as decimal numbers between values 0 and 1.
1138
1139 .TP 8
1140 .B bggray
1141 change the text background color.  The syntax of the escape is:
1142
1143 ^@bggray{\f2gray\f1}
1144
1145 where \f2gray\f1 is the new text background gray value.  The default
1146 value is 1.0 (white).
1147 .TP 8
1148 .B color
1149 change the text color.  The syntax of the escape is:
1150
1151 ^@color{\f2red\f1 \f2green\f1 \f2blue\f1}
1152
1153 where color components \f2red\f1, \f2green\f1 and \f2blue\f1 are given
1154 as decimal numbers between values 0 and 1.
1155 .TP 8
1156 .B comment
1157 comment the rest of the line including the newline character.
1158 Escape's syntax is:
1159
1160 ^@comment \f2text\f1 \f2newline_character\f1
1161 .TP 8
1162 .B escape
1163 change the escape character.  The syntax of the escape is:
1164
1165 ^@escape{\f2code\f1}
1166
1167 where \f2code\f1 is the decimal code of the new escape character.
1168 .TP 8
1169 .B epsf
1170 inline EPS file to the document.  The syntax of the escape is:
1171
1172 ^@epsf[\f2options\f1]{\f2filename\f1}
1173
1174 where \f2options\f1 is an optional sequence of option characters and
1175 values enclosed with brackets and \f2filename\f1 is the name of the
1176 EPS file.
1177
1178 If \f2filename\f1 ends to the `|' character, then \f2filename\f1 is
1179 assumed to name a command that prints EPS data to its standard output.
1180 In this case, \f3enscript\f1 opens a pipe to the specified command
1181 and reads EPS data from pipe.
1182
1183 Following options can be given for the \f3epsf\f1 escape:
1184 .RS 8
1185 .TP 8
1186 .B c
1187 print image centered
1188 .TP 8
1189 .B r
1190 print image right justified
1191 .TP 8
1192 .B n
1193 do not update current point.  Following output is printed to that
1194 position where the current point was just before the \f3epsf\f1 escape
1195 .TP 8
1196 .B nx
1197 do not update current point \f2x\f1 coordinate
1198 .TP 8
1199 .B ny
1200 do not update current point \f2y\f1 coordinate
1201 .TP 8
1202 .B x\f2num\f3
1203 move image's top left \f2x\f1 coordinate \f2num\f1 characters from
1204 current point \f2x\f1 coordinate (relative position)
1205 .TP 8
1206 .B x\f2num\f3a
1207 set image's top left \f2x\f1 coordinate to column \f2num\f1 (absolute
1208 position)
1209 .TP 8
1210 .B y\f2num\f3
1211 move image's top left \f2y\f1 coordinate \f2num\f1 lines from current
1212 line (relative position)
1213 .TP 8
1214 .B y\f2num\f3a
1215 set image's top left \f2y\f1 coordinate to line \f2num\f1 (absolute
1216 position)
1217 .TP 8
1218 .B h\f2num\f3
1219 set image's height to \f2num\f1 lines
1220 .TP 8
1221 .B s\f2num\f3
1222 scale image with factor \f2num\f1
1223 .TP 8
1224 .B sx\f2num\f3
1225 scale image in \f2x\f1 direction with factor \f2num\f1
1226 .TP 8
1227 .B sy\f2num\f3
1228 scale image in \f2y\f1 direction with factor \f2num\f1
1229 .P
1230 As a default, all dimensions are given in lines (vertical) and
1231 characters (horizontal).  You can also specify other units by
1232 appending an unit specifier after number.  Possible unit specifiers
1233 and the corresponding units are:
1234 .TP 8
1235 .B c
1236 centimeters
1237 .TP 8
1238 .B i
1239 inches
1240 .TP 8
1241 .B l
1242 lines or characters (default)
1243 .TP 8
1244 .B p
1245 PostScript points
1246 .P
1247 For example to print an image one inch high, you can specify height by
1248 following options: \f3h1i\f1 (1 inch), \f3h2.54c\f1 (2.54 cm),
1249 \f3h72p\f1 (72 points).
1250 .RE
1251 .TP 8
1252 .B font
1253 select current font.  The syntax of the escape is:
1254
1255 ^@font{\f2fontname\f1[:\f2encoding\f1]}
1256
1257 where \f2fontname\f1 is a standard font specification.  Special font
1258 specification \f3default\f1 can be used to select the default body
1259 font (\f3enscript\f1's default or the one specified by the command
1260 line option \f3\-f\f1, \f3\-\-font\f1).
1261
1262 The optional argument \f2encoding\f1 specifies the encoding that
1263 should be used for the new font.  Currently the encoding can only be
1264 the \f3enscript\f1's global input encoding or \f3ps\f1.
1265 .TP 8
1266 .B ps
1267 include raw PostScript code to the output.  The syntax of the escape
1268 is:
1269
1270 ^@ps{\f2code\f1}
1271 .TP 8
1272 .B shade
1273 highlight regions of text by changing the text background color.
1274 Escape's syntax is:
1275
1276 ^@shade{\f2gray\f1}
1277
1278 where \f2gray\f1 is the new text background gray value.  The default
1279 value is 1.0 (white) which disables highlighting.
1280
1281 .SH PAGE DEVICE OPTIONS
1282
1283 Page device is a PostScript level 2 feature that offers an uniform
1284 interface to control printer's output device.  \f3Enscript\f1
1285 protects all page device options inside an if block so they have no
1286 effect in level 1 interpreters.  Although all level 2 interpreters
1287 support page device, they do not have to support all page device
1288 options.  For example some printers can print in duplex mode and some
1289 can not.  Refer to the documentation of your printer for supported
1290 options.
1291
1292 Here are some usable page device options which can be selected with
1293 the \f3\-D\f1, \f3\-\-setpagedevice\f1 option.  For a complete listing,
1294 see \f2PostScript Language Reference Manual\f1: section 4.11 Device
1295 Setup.
1296 .TP 8
1297 .B Collate \f2boolean\f1
1298 how output is organized when printing multiple copies
1299 .TP 8
1300 .B Duplex \f2boolean\f1
1301 duplex (two side) printing
1302 .TP 8
1303 .B ManualFeed \f2boolean\f1
1304 manual feed paper tray
1305 .TP 8
1306 .B OutputFaceUp \f2boolean\f1
1307 print output `face up' or `face down'
1308 .TP 8
1309 .B Tumble \f2boolean\f1
1310 how opposite sides are positioned in duplex printing
1311
1312 .SH PRINTING EXAMPLES
1313
1314 Following printing examples assume that \f3enscript\f1 uses the
1315 default configuration.  If default actions have been changed from the
1316 configuration files, some examples will behave differently.
1317 .TP 8
1318 .B enscript foo.txt
1319 Print file \f3foo.txt\f1 to the default printer.
1320 .TP 8
1321 .B enscript \-Possu foo.txt
1322 Print file \f3foo.txt\f1 to printer \f3ossu\f1.
1323 .TP 8
1324 .B enscript \-pfoo.ps foo.txt
1325 Print file \f3foo.txt\f1, but leave PostScript output to file
1326 \f3foo.ps\f1.
1327 .TP 8
1328 .B enscript \-2 foo.txt
1329 Print file \f3foo.txt\f1 to two columns.
1330 .TP 8
1331 .B enscript \-2r foo.txt
1332 Print file to two columns and rotate output 90 degrees (landscape).
1333 .TP 8
1334 .B enscript \-DDuplex:true foo.txt
1335 Print file in duplex (two side) mode (printer dependent).
1336 .TP 8
1337 .B enscript \-G2rE \-U2 foo.c
1338 My default code printing command: gaudy header, two columns,
1339 landscape, code highlighting, 2-up printing.
1340 .TP 8
1341 \f3enscript \-E \-\-color \-whtml \-\-toc \-pfoo.html *.h *.c\f1
1342 A nice HTML report of your project's C source files.
1343
1344 .SH ENVIRONMENT VARIABLES
1345
1346 The environment variable \f3ENSCRIPT\f1 can be used to pass default
1347 options for \f3enscript\f1.  For example, to select the default body
1348 font to be Times\-Roman 7pt, set the following value to the
1349 \f3ENSCRIPT\f1 environment variable:
1350 .TP 8
1351 .B \-fTimes\-Roman7
1352 .P
1353
1354 The value of the \f3ENSCRIPT\f1 variable is processed before the
1355 command line options, so command line options can be used to overwrite
1356 these defaults.
1357
1358 Variable \f3ENSCRIPT_LIBRARY\f1 specifies the \f3enscript\f1's
1359 library directory.  It can be used to overwrite the build-in default
1360 `@DATADIR@/enscript'.
1361
1362 .SH RETURN VALUE
1363
1364 \f3Enscript\f1 returns value 1 to the shell if any errors were
1365 encountered or 0 otherwise.  If the option
1366 \f3\-\-extended\-return\-values\f1 was specified, the return value is
1367 constructed from the following flags:
1368 .TP 8
1369 .B 0
1370 no errors or warnings
1371 .TP 8
1372 .B 2
1373 some lines were truncated or wrapped
1374 .TP 8
1375 .B 4
1376 some characters were missing from the used fonts
1377 .TP 8
1378 .B 8
1379 some characters were unprintable
1380
1381 .SH FILES
1382
1383 .nf
1384 .ta 4i
1385 @DATADIR@/enscript/*.hdr                header files
1386 @DATADIR@/enscript/*.enc                input encoding vectors
1387 @DATADIR@/enscript/enscript.pro PostScript prolog
1388 @DATADIR@/enscript/afm/*.afm            AFM files for PostScript fonts
1389 @DATADIR@/enscript/font.map     index for the AFM files
1390 @DATADIR@/enscript/hl/*.st      states definition files
1391 @SYSCONFDIR@/enscript.cfg               system\-wide configuration file
1392 @SYSCONFDIR@/enscriptsite.cfg           site configuration file
1393 ~/.enscriptrc                           personal configuration file
1394 ~/.enscript/                            personal resource directory
1395 .fi
1396
1397 .SH USING NEW FONTS
1398
1399 If you instruct enscript to use a font whose name does not appear in the
1400 font map, it will give the warning "couldn't open AFM file for font".
1401
1402 To create an AFM file for a TrueType font, you can use \f3ttf2pt1\f1.
1403
1404 Once you create the AFM file, you must add it to the font map.
1405
1406 To generate a new font map automatically, use \f3mkafmmap\f1.
1407
1408 .SH SEE ALSO
1409 diffpp(1), ghostview(1), gs(1), lpq(1), lpr(1), lprm(1), states(1)
1410
1411 .SH AUTHOR
1412 Markku Rossi <mtr@iki.fi> <http://www.iki.fi/~mtr/>
1413
1414 GNU Enscript WWW home page: <http://www.iki.fi/~mtr/genscript/>