2 .\" GNU enscript manual page.
3 .\" Copyright (c) 1995-1999 Markku Rossi.
4 .\" Author: Markku Rossi <mtr@iki.fi>
7 .\" This file is part of GNU Enscript.
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.
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.
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/>.
22 .TH ENSCRIPT 1 "Mar 12, 1999" "ENSCRIPT" "ENSCRIPT"
25 enscript \- convert text files to PostScript, HTML, RTF, ANSI, and
30 [\f3\-123456789BcgGhjkKlmOqrRvVzZ\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]]
41 [\f3\-F \f2header_font\f1]
42 [\f3\-H\f1[\f2num\f1]]
46 [\f3\-L \f2lines_per_page\f1]
49 [\f3\-N \f2newline\f1]
50 [\f3\-o \f2outputfile\f1]
52 [\f3\-p \f2outputfile\f1]
54 [\f3\-P \f2printer\f1]
55 [\f3\-s \f2baselineskip\f1]
56 [\f3\-S \f2key\f1[\f3:\f2value\f1]]
58 [\f3\-T \f2tabsize\f1]
59 [\f3\-u\f1[\f2text\f1]]
61 [\f3\-w \f2language\f1]
62 [\f3\-X \f2encoding\f1]
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.
77 Print \f2num\f1 copies of each page.
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.
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:
88 \f2begin\f1\-\f2end\f1
89 print pages from \f2begin\f1 to \f2end\f1
92 print pages from 0 to \f2end\f1
95 print pages from \f2begin\f1 to end
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).
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
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:
121 \f3enscript \-\-header='$n %W Page $% of $=' *.c\f1
123 The header string can also contain left, center and right justified
124 fields. The fields are separated by the \f3'|'\f1 character:
126 \f3enscript \-\-header='$n|%W|Page $% of $=' *.c\f1
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.
131 .B \-B, \-\-no\-header
132 Do not print page headers.
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
139 You can also use the \f3\-\-slice\f1 option which slices long lines to
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.
148 Spool output to the printer \f2name\f1.
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.
154 For example, the command
156 .B enscript \-DDuplex:true foo.txt
158 prints file foo.txt in duplex (two side) mode.
160 Page device operators are implementation dependant but they are
161 standardized. See section \f3PAGE DEVICE OPTIONS\f1 for the details.
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.
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
174 You can print a short description of the supported highlighting
175 languages and file formats with the command:
177 .B enscript \-\-help\-highlight
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.
183 \f3Note!\f1 You can not use your own input filters with this option.
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.
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
195 The font specification \f2name\f1 can also be given in format
196 `\f2name\f1@\f2ptsize\f1', where the name of the font and its point
197 size are separated by a `@' character. This allows \f3enscript\f1 to use
198 fonts which contain digit characters in their names.
200 The font point size can also be given in the format
201 \f2width\f1/\f2height\f1 where the \f2width\f1 and the \f2height\f1
202 specify the size of the font in x- and y-directions. For example,
203 "\f3Times\-Roman@10/12\f1" selects a 10 points wide and 12 points high
206 You can also give the font sizes as decimal numbers. For example,
207 "\f3Times\-Roman10.2\f1" selects a 10.2pt "Times\-Roman" font.
209 .B \-F \f2name\f3, \-\-header\-font=\f2name\f3
210 Select a font for the header texts.
212 .B \-g, \-\-print\-anyway
213 Print a file even if it contains binary data. The option is
214 implemented only for compatibility purposes. \f3Enscript\f1 prints
215 binary files anyway regardless of the option.
217 .B \-G, \-\-fancy\-header\f1[\f3=\f2name\f1]\f3
218 Print a fancy page header \f2name\f1 to the top of each page. The
219 option \f3\-G\f1 specifies the default fancy header. See section
220 \f3CONFIGURATION FILES\f1 to see how the default fancy header can be
223 .B \-h, \-\-no\-job\-header
224 Suppress printing of the job header page.
226 .B \-H\f1[\f2num\f1]\f3, \-\-highlight\-bars\f1[\f3=\f2num\f1]\f3
227 Specify how high the highlight bars are in lines. If the \f2num\f1 is
228 not given, the default value 2 is used. As a default, no highlight bars
231 .B \-i \f2num\f3, \-\-indent=\f2num\f3
232 Indent every line \f2num\f1 characters. The indentation can also be
233 specified in other units by appending an unit specifier after the
234 number. The possible unit specifiers and the corresponding units are:
250 .B \-I \f2filter\f3, \-\-filter=\f2filter\f1
251 Read all input files through an input filter \f2filter\f1. The input
252 filter can be a single command or a command pipeline. The filter can
253 refer to the name of the input file with the escape `\f3%s\f1'. The
254 name of the standard input can be changed with the option
255 `\f3\-\-filter\-stdin\f1'.
257 For example, the following command prints the file `foo.c' by using
258 only upper-case characters:
260 .B enscript \-\-filter="cat %s | tr 'a-z' 'A-Z'" foo.c
262 The following command highlights changes which are made to files since
265 .B enscript \-\-filter="rcsdiff %s | diffpp %s" \-e *.c
267 To include the string "%s" to the filter command, you must write it as
271 Print borders around columns.
274 An alias for the option \f3\-t\f1, \f3\-\-title\f1.
276 .B \-k, \-\-page\-prefeed
279 .B \-K, \-\-no\-page\-prefeed
280 Disable page prefeed (default).
282 .B \-l, \-\-lineprinter
283 Emulate lineprinter. This option is a shortcut for the options
284 \f3\-\-lines\-per\-page=66\f1, and \f3\-\-no\-header\f1.
286 .B \-L \f2num\f3, \-\-lines\-per\-page=\f2num\f3
287 Print only \f2num\f1 lines for each page. As a default, the number of
288 lines per page is computed from the height of the page and from the
292 Send a mail notification to user after the print job has been
295 .B \-M \f2name\f3, \-\-media=\f2name\f3
296 Select an output media \f2name\f1. \f3Enscript\f1's default output
297 media is \f3@media@\f1.
299 .B \-n \f2num\f3, \-\-copies=\f2num\f3
300 Print \f2num\f1 copies of each page.
302 .B \-N \f2nl\f3, \-\-newline=\f2nl\f3
303 Select the \f2newline\f1 character. The possible values for \f2nl\f1
304 are: \f3n\f1 (unix newline, 0xa hex) and \f3r\f1 (mac newline, 0xd hex).
307 An alias for the option \f3\-p\f1, \f3\-\-output\f1.
309 .B \-O, \-\-missing\-characters
310 Print a listing of character codes which couldn't be printed.
312 .B \-p \f2file\f3, \-\-output=\f2file\f3
313 Leave the output to file \f2file\f1. If the \f2file\f1 is `\-',
314 enscript sends the output to the standard output \f3stdout\f1.
316 .B \-P \f2name\f3, \-\-printer=\f2name\f3
317 Spool the output to the printer \f2name\f1.
319 .B \-q, \-\-quiet, \-\-silent
320 Make \f3enscript\f1 really quiet. Only fatal error messages are
321 printed to \f2stderr\f1.
323 .B \-r, \-\-landscape
324 Print in the landscape mode; rotate page 90 degrees.
327 Print in the portrait mode (default).
329 .B \-s \f2num\f3, \-\-baselineskip=\f2num\f3
330 Specify the baseline skip in PostScript points. The number \f2num\f1
331 can be given as a decimal number. When \f3enscript\f1 moves from line
332 to line, the current point \f2y\f1 coordinate is moved (\f2font point
333 size + baselineskip\f1) points down. The default baseline skip is 1.
335 .B \-S \f2key\f1[\f3:\f2value\f1]\f3, \-\-statusdict=\f2key\f1[\f3:\f2value\f1]\f3
336 Pass a statusdict definition to the generated PostScript output. If
337 no value is given, the key \f2key\f1 is removed from the definitions.
339 The statusdict operators are implementation dependant; see the
340 printer's documentation for the details.
342 For example, the command
344 .B enscript \-Ssetpapertray:1 foo.txt
346 prints the file \f2foo.txt\f1 by using paper from the paper tray 1
347 (assuming that the printer supports paper tray selection).
349 .B \-t \f2title\f3, \-\-title=\f2title\f3
350 Set banner page's job title to \f2title\f1. The option sets also the
351 name of the input file \f3stdin\f1.
353 .B \-T \f2num\f3, \-\-tabsize=\f2num\f3
354 Set the tabulator size to \f2num\f1 characters. The default is 8.
356 .B \-u\f1[\f2text\f1]\f3, \-\-underlay\f1[\f3=\f2text\f1]\f3
357 Print the string \f2text\f1 under every page. The properties of the
358 text can be changed with the options \f3\-\-ul\-angle\f1,
359 \f3\-\-ul\-font\f1, \f3\-\-ul\-gray\f1, \f3\-\-ul\-position\f1, and
362 If no \f2text\f1 is given, the underlay is not printed. This can be used
363 to remove an underlay text that was specified with the
364 `\f3Underlay\f1' configuration file option.
366 .B \-U \f2num\f3, \-\-nup=\f2num\f3
367 Print \f2num\f1 logical pages on each output page (N\-up printing).
368 The values \f2num\f1 must be a power of 2.
370 .B \-v, \-\-verbose\f1[\f3=\f2level\f1]\f3
371 Tell what \f3enscript\f1 is doing.
374 Print \f3enscript\f1 version information and exit.
376 .B \-w \f1[\f2lang\f1]\f3, \-\-language\f1[\f3=\f2lang\f1]\f3
377 Generate output for the language \f2lang\f1. The possible values for
382 generate PostScript (default)
388 generate overstrikes (line printers, less)
391 generate RTF (Rich Text Format)
394 generate ANSI terminal control codes
397 .B \-X \f2name\f3, \-\-encoding=\f2name\f3
398 Use the input encoding \f2name\f1. Currently \f3enscript\f1 supports
399 the following encodings:
403 ISO\-8859\-1 (ISO Latin1) (\f3enscript\f1's default encoding).
406 ISO\-8859\-2 (ISO Latin2)
409 ISO\-8859\-3 (ISO Latin3)
412 ISO\-8859\-4 (ISO Latin4)
415 ISO\-8859\-5 (ISO Cyrillic)
418 ISO\-8859\-7 (ISO Greek)
421 ISO\-8859\-9 (ISO Latin5)
424 ISO\-8859\-10 (ISO Latin6)
429 .B asciifise, asciifi, asciise
430 7\-bit ascii with some scandinavian (Finland, Sweden) extensions
432 .B asciidkno, asciidk, asciino
433 7\-bit ascii with some scandinavian (Denmark, Norway) extensions
442 VMS multinational charset
448 Adobe Standard Cyrillic Font KOI8 charset
451 PostScript font's default encoding
453 .B pslatin1, ISOLatin1Encoding
454 PostScript interpreter's `ISOLatin1Encoding'
457 .B \-z, \-\-no\-formfeed
458 Turn off the form feed character interpretation.
460 .B \-Z, \-\-pass\-through
461 Pass through all PostScript and PCL files without any modifications.
462 This allows that \f3enscript\f1 can be used as a lp filter.
464 The PostScript files are recognized by looking up the `%!' magic
465 cookie from the beginning of the file. \f3Note!\f1 \f3Enscript\f1
466 recognized also the Windoze damaged `^D%!' cookie.
468 The PCL files are recognized by looking up the `^[E' or `^[%' magic
469 cookies from the beginning of the file.
471 .B \-\-color\f1[\f3=\f2bool\f1]\f3
472 Use colors in the highlighting outputs.
474 .B \-\-download\-font=\f2fontname\f3
475 Include the font description file (\f2.pfa\f1 or \f2.pfb\f1 file) of
476 the font \f2fontname\f1 to the generated output.
478 .B \-\-extended\-return\-values
479 Enable extended return values. As a default, \f3enscript\f1 returns 1
480 on error and 0 otherwise. The extended return values give more
481 details about the printing operation. See the section \f3RETURN
482 VALUE\f1 for the details.
484 .B \-\-filter\-stdin=\f2name\f1
485 Specify how the \f3stdin\f1 is shown to the input filter. The default
486 value is an empty string ("") but some programs require that the
487 \f3stdin\f1 is called something else, usually "-".
489 .B \-\-footer=\f2footer\f3
490 Use the text \f2footer\f1 as a page footer. Otherwise the option
491 works like the \f3\-\-header\f1 option
493 .B \-\-h\-column\-height=\f2height\f3
494 Set the horizontal column height to be \f2height\f1 PostScript
495 points. The option sets the formfeed type to
496 \f3horizontal\-columns\f1.
499 Print a short help message and exit.
501 .B \-\-help\-highlight
502 Describe all supported \f3\-\-highlight\f1 languages and file
505 .B \-\-highlight\-bar\-gray=\f2gray\f3
506 Specify the gray level which is used in printing the highlight bars.
509 List the names of all known output media and exit successfully.
511 .B \-\-margins=\f2left\f3:\f2right\f3:\f2top\f3:\f2bottom\f3
512 Adjust the page marginals to be exactly \f2left\f1, \f2right\f1, \f2top\f1
513 and \f2bottom\f1 PostScript points. Any of the arguments can be left
514 empty in which case the default value is used.
516 .B \-\-mark\-wrapped\-lines\f1[\f3=\f2style\f1]\f3
517 Mark wrapped lines in the output with the style \f2style\f1. The
518 possible values for the \f2style\f1 are:
522 do not mark them (default)
525 print a plus (+) character to the end of each wrapped line
528 print a black box to the end of each wrapped line
531 print a small arrow to the end of each wrapped line
534 .B \-\-non\-printable\-format=\f2format\f3
535 Specify how the non-printable characters are printed. The possible
536 values for the \f2format\f1 are:
540 caret notation: `^@', `^A', `^B', ...
543 octal notation: `\\000', `\\001', `\\002', ... (default)
546 replace non-printable characters with a question mark `?'
549 replace non-printable characters with a space ` '
552 .B \-\-nup\-columnwise
553 Change the layout of the sub-pages in the N\-up printing from row-wise
556 .B \-\-nup\-xpad=\f2num\f3
557 Set the page x-padding of the \f2n\f1-up printing to \f2num\f1
558 PostScript points. The default is 10 points.
560 .B \-\-nup\-ypad=\f2num\f3
561 Set the page y-padding of the \f2n\f1-up printing to \f2num\f1
562 PostScript points. The default is 10 points.
564 .B \-\-page\-label\-format=\f2format\f3
565 Set the page label format to \f2format\f1. The page label format
566 specifies how the labels for the `%%Page:' PostScript comments are
567 formatted. The possible values are:
571 Print the current pagenumber: `%%Page: (1) 1' (default)
574 Print the current filename and pagenumber: `%%Page: (main.c: 1) 1'
577 .B \-\-ps\-level=\f2level\f3
578 Set the PostScript language level that \f3enscript\f1 uses for its
579 output to \f2level\f1. The possible values are \f31\f1, and
582 .B \-\-printer\-options=\f2options\f3
583 Pass extra options to the printer command.
585 .B \-\-rotate\-even\-pages
586 Rotate each even\-numbered page 180 degrees.
588 .B \-\-slice=\f2num\f3
589 Print the vertical slice \f2num\f1. The slices are vertical regions
590 of input files. A new slice starts from the point where the line
591 would otherwise be wrapped to the next line. The slice numbers start
594 .B \-\-style=\f2style\f3
595 Set the highlighting style to \f2style\f1. The possible values are:
596 \f3a2ps\f1, \f3emacs\f1, \f3emacs_verbose\f1, \f3ifh\f1, and
599 .B \-\-swap\-even\-page\-margins
600 Swap left and right page margins for even\-numbered pages.
603 Print a table of contents to the end of the output.
606 Wrap long lines from word boundaries.
608 .B \-\-ul\-angle=\f2angle\f3
609 Set the angle of the underlay text to \f2angle\f1. As a default,
610 the angle is \f3atan(\-d_page_h, d_page_w)\f1.
612 .B \-\-ul\-font=\f2name\f3
613 Select a font for the underlay text. The default underlay font is
614 \f3Times-Roman200\f1.
616 .B \-\-ul\-gray=\f2num\f3
617 Print the underlay text with the gray value \f2num\f1 (0 ... 1), the
618 default gray value is .8.
620 .B \-\-ul\-position=\f2position_spec\f3
621 Set the underlay text's starting position according to the
622 \f2position_spec\f1. The position specification must be given in
623 format: `\f2sign\f1 \f2xpos\f1 \f2sign\f1 \f2ypos\f1', where the
624 \f2sign\f1 must be `+' or `-'. The positive dimensions are measured
625 from the lower left corner and the negative dimensions from the upper
626 right corner. For example, the specification `+0-0' specifies the
627 upper left corner and `-0+0' specifies the lower right corner.
629 .B \-\-ul\-style=\f2style\f3
630 Set the underlay text's style to \f2style\f1. The possible values for
635 print outline underlay texts (default)
638 print filled underlay texts
641 .SH CONFIGURATION FILES
644 reads configuration information from the following sources (in this
645 order): command line options, environment variable \f3ENSCRIPT\f1,
646 user's personal configuration file (\f3$HOME/.enscriptrc\f1), site
647 configuration file (\f3@SYSCONFDIR@/enscriptsite.cfg\f1) and system's
648 global configuration file (\f3@SYSCONFDIR@/enscript.cfg\f1).
650 The configuration files have the following format:
652 Empty lines and lines starting with `#' are comments.
654 All other lines are option lines and have format:
656 \f2option\f1 [\f2arguments ...\f1].
658 The following options can be specified:
660 .B AcceptCompositeCharacters: \f2bool\f1
661 Specify whether PostScript font's composite characters are accepted
662 as printable or if they should be considered as non-existent. The
663 default value is false (0).
665 .B AFMPath: \f2path\f3
666 Specifies the search path for the \f2AFM\f1 files.
668 .B AppendCtrlD: \f2bool\f3
669 Specify if the Control-D (^D) character should be appended to the end
670 of the output. The default value is false (0).
672 .B Clean7Bit: \f2bool\f3
673 Specify how characters greater than 127 are printed. The valuee true
674 (1) generates 7-bit clean code by escaping all characters greater than
675 127 to the backslash-octal notation (default). The value false (0)
676 generates 8-bit PostScript code leaving all characters untouched.
678 .B DefaultEncoding: \f2name\f3
679 Select the default input encoding. The encoding name \f2name\f1 can
680 be one of the values of the option \f3\-X\f1, \f3\-\-encoding\f1.
682 .B DefaultFancyHeader: \f2name\f3
683 Select the default fancy header. The default header is used when the
684 option \f3\-G\f1 is specified or the option \f3\-\-fancy\-header\f1 is
685 given without an argument. The system\-wide default is `\f3enscript\f1'.
687 .B DefaultMedia: \f2name\f3
688 Select the default output media.
690 .B DefaultOutputMethod: \f2method\f3
691 Select the default target to which the generated output is sent.
692 The possible values for the \f2method\f1 are:
696 send output to printer (default)
699 send output to \f3stdout\f1
702 .B DownloadFont: \f2fontname\f3
703 Include the font description file of the font \f2fontname\f1 to the
706 .B EscapeChar: \f2num\f3
707 Specify the escape character for the special escapes. The default
710 .B FormFeedType: \f2type\f3
711 Specify what to do when a formfeed character is encountered from the
712 input. The possible values for \f2type\f1 are:
716 move to the beginning of the next column (default)
719 move to the beginning of the next page
722 .B GeneratePageSize: \f2bool\f3
723 Specify whether the \f3PageSize\f1 page device setting is generated to
724 the PostScript output. The default value is true (1).
726 .B HighlightBarGray: \f2gray\f3
727 Specify the gray level which is used to print the highlight bars.
729 .B HighlightBars: \f2num\f3
730 Specify how high the highlight bars are in lines. The default value
731 is 0 which means that no highlight bars are printed.
733 .B LibraryPath: \f2path\f3
734 Specifies the \f3enscript\f1's library path that is used to lookup
735 various resources. The default path is:
736 `@DATADIR@/enscript:\f2home\f1/.enscript'. Where the \f2home\f1 is
737 the user's home directory.
739 .B MarkWrappedLines: \f2style\f3
740 Mark wraped lines in the output with the style \f2style\f1. The
741 possible values for the \f2format\f1 are the same which can be given
742 for the \f3\-\-mark\-wrapped\-lines\f1 option.
744 \f3Media: \f2name\f3 \f2width\f3 \f2height\f3 \f2llx\f3 \f2lly\f3 \f2urx\f3 \f2ury\f3
745 Add a new output media with the name \f2name\f1. The physical
746 dimensions of the media are \f2width\f1 and \f2height\f1. The
747 bounding box of the Media is specified by the points (\f2llx\f1,
748 \f2lly\f1) and (\f2urx\f1, \f2ury\f1). \f3Enscript\f1 prints all
749 graphics inside the bounding box of the media.
751 User can select this media with option \f3\-M \f2name\f1.
753 .B NoJobHeaderSwitch: \f2switch\f1
754 Specify the spooler option to suppress the print job header page.
755 This option is passed to the printer spooler when the \f3enscript\f1's
756 option \f3\-h\f1, \f3\-\-no\-job\-header\f1 is selected.
758 .B NonPrintableFormat: \f2format\f1
759 Specify how the non-printable characters are printed. The possible
760 values for \f2format\f1 are the same which can be given for the
761 \f3\-\-non\-printable\-format\f1 option.
763 .B OutputFirstLine: \f2line\f1
764 Set the PostScript output's first line to \f2line\f1. The default
765 value is \f3PS-Adobe-3.0\f1. Since some printers do not like DSC
766 levels greater than 2.0, this option can be used to change the output
767 first line to something more suitable like \f3%!PS-Adobe-2.0\f1 or
770 .B PageLabelFormat: \f2format\f1
771 Set the page label format to \f2format\f1. The possible values for
772 \f2format\f1 are the same which can be given for the
773 \f3\-\-page\-label\-format\f1 option.
775 .B PagePrefeed: \f2bool\f3
776 Enable / disable page prefeed. The default value is false (0).
778 .B PostScriptLevel: \f2level\f3
779 Set the PostScript language level, that \f3enscript\f1 uses for its
780 output, to \f2level\f1. The possible values for \f2level\f1 are the
781 same which can be given for the \f3\-\-ps\-level\f1 option.
783 .B Printer: \f2name\f3
784 Names the printer to which the output is spooled.
786 .B QueueParam: \f2name\f3
787 The spooler command switch to select the printer queue, e.g. \f3\-P\f1
788 in \f3lpr \-Pps\f1. This option can also be used to pass other flags
789 to the spooler command. These options must be given before the queue
792 .B SetPageDevice: \f2key\f1[\f3:\f2value\f1]\f3
793 Pass a page device definition to the generated PostScript output.
795 .B Spooler: \f2name\f3
796 Names the printer spooler command. \f3Enscript\f1 pipes generated
797 PostScript to the command \f2name\f1.
799 .B StatesBinary: \f2path\f3
800 Define an absolute path to the \f3states\f1 program.
802 .B StatesColor: \f2bool\f3
803 Should the \f3states\f1 program generate color outputs.
805 .B StatesConfigFile: \f2file\f3
806 Read highlighting states configuration from the file \f2file\f1. The
807 default config file is `@DATADIR@/enscript/hl/enscript.st'.
809 .B StatesHighlightStyle: \f2style\f3
810 Set the highlight style to \f2style\f1.
812 .B StatesPath: \f2path\f3
813 Define the path for the \f3states\f1 program. The \f3states\f1
814 program will lookup its state definition files from this path. The
815 default value is `$HOME/.enscript:@DATADIR@/enscript/hl'.
817 .B StatusDict: \f2key\f1[\f3:\f2value\f1]\f3
818 Pass a statusdict definition to the generated PostScript output.
820 .B TOCFormat: \f2format\f3
821 Format table of contents entries with the format string \f2format\f1.
822 The format string \f2format\f1 can contain the same escapes which are
823 used to format header strings with the `%Format' special comment.
825 .B Underlay: \f2text\f3
826 Print string \f2text\f1 under every page.
828 .B UnderlayAngle: \f2num\f3
829 Set the angle of the underlay text to \f2num\f1.
831 .B UnderlayFont: \f2fontspec\f3
832 Select a font for the underlay text.
834 .B UnderlayGray: \f2num\f3
835 Print the underlay text with the gray value \f2num\f1.
837 .B UnderlayPosition: \f2position_spec\f3
838 Set the underlay text's starting position according to the
841 .B UnderlayStyle: \f2style\f3
842 Set the underlay text's style to \f2style\f1.
846 Users can create their own fancy headers by creating a header
847 description file and placing it in a directory which is in
848 \f3enscript\f1's library path. The name of the header file must be in
849 format: `\f2headername\f1.hdr'. Header can be selected by giving
850 option: \f3\-\-fancy\-header=\f2headername\f1.
852 Header description file contains PostScript code that paints the
853 header. Description file must provide procedure \f3do_header\f1 which
854 is called by \f3enscript\f1 at the beginning of every page.
856 Header description file contains two parts: comments and code. Parts
857 are separated by a line containing text:
859 % \-\- code follows this line \-\-
862 copies only the code part of description file to the generated
863 PostScript output. The comments part can contain any data, it is not
864 copied. If separator line is missing, no data is copied to output.
867 defines following constants which can be used in header description
877 header lower left \f2x\f1 coordinate
880 header lower left \f2y\f1 coordinate
889 footer lower left \f2x\f1 coordinate
892 footer lower left \f2y\f1 coordinate
901 width of the text output area
904 height of the text output area
907 predicate which tells if user has defined his/her own header string:
908 \f3true\f1/\f3false\f1
910 .B user_header_left_str
911 if \f3user_header_p\f1 is \f3true\f1, this is the left field of the
912 user supplied header string.
914 .B user_header_center_str
915 if \f3user_header_p\f1 is \f3true\f1, this is the center field of the
916 user supplied header string
918 .B user_header_right_str
919 if \f3user_header_p\f1 is \f3true\f1, this is the right field of the
920 user supplied header string
923 predicate which tells if user has defined his/her own footer string:
924 \f3true\f1/\f3false\f1
926 .B user_footer_left_str
927 if \f3user_footer_p\f1 is \f3true\f1, this is the left field of the
928 user supplied footer string.
930 .B user_footer_center_str
931 if \f3user_footer_p\f1 is \f3true\f1, this is the center field of the
932 user supplied footer string
934 .B user_footer_right_str
935 if \f3user_footer_p\f1 is \f3true\f1, this is the right field of the
936 user supplied footer string
939 standard header font (from \f3\-F\f1, \f3\-\-header\-font\f1 option).
940 This can be selected simply by invoking command: `\f3HF setfont\f1'.
943 the number of the current page
946 the full name of the printed file (/foo/bar.c)
949 the directory part of the file name (/foo)
952 file name without the directory part (bar.c)
955 PostScript interpreter's language level (currently 1 or 2)
958 You can also use the following special comments to customize your
959 headers and to specify some extra options. Special comments are like
960 DSC comments but they start with a single `%' character; special
961 comments start from the beginning of the line and they have the
964 %\f2commentname\f1: \f2options\f1
966 Currently \f3enscript\f1 support the following special comments:
968 .B %Format: \f2name\f3 \f2format\f3
969 Define a new string constant \f2name\f1 according to the format string
970 \f2format\f1. Format string start from the first non-space character
971 and it ends to the end of the line. Format string can contain general
972 `%' escapes and input file related `$' escapes. Currently following
973 escapes are supported:
986 number of pages in the current file
989 number of pages processed so far
992 value of the environment variable \f2VAR\f1.
995 trailing component of the current working directory
997 .B %C \f1(\f3$C\f1)\f3
998 current time (file modification time) in `hh:mm:ss' format
1001 current working directory
1003 .B %D \f1(\f3$D\f1)\f3
1004 current date (file modification date) in `yy-mm-dd' format
1006 .B %D{\f2string\f3} \f1(\f3$D{\f2string\f3}\f1)\f3
1007 format string \f2string\f1 with the strftime(3) function.
1008 `\f3%D{}\f1' refers to the current date and `\f3$D{}\f1' to the input
1009 file's last modification date.
1011 .B %E \f1(\f3$E\f1)\f3
1012 current date (file modification date) in `yy/mm/dd' format
1014 .B %F \f1(\f3$F\f1)\f3
1015 current date (file modification date) in `dd.mm.yyyy' format
1021 number of lines in the current input file. This is valid only for the
1022 toc entries, it can't be used in header strings.
1025 the hostname up to the first `.' character
1034 input file name without the directory part
1037 the user's pw_gecos field up to the first `,' character
1040 the full input file name
1042 .B %t \f1(\f3$t\f1)\f3
1043 current time (file modification time) in 12-hour am/pm format
1045 .B %T \f1(\f3$T\f1)\f3
1046 current time (file modification time) in 24-hour format `hh:mm'
1048 .B %* \f1(\f3$*\f1)\f3
1049 current time (file modification time) in 24-hour format with seconds
1053 the sequence number of the current input file
1056 the sequence number of the current input file in the `Table of
1057 Contents' format: if the \f3\-\-toc\f1 option is given, escape expands
1058 to `\f2num\f1\-'; if the \f3\-\-toc\f1 is not given, escape expands to
1061 .B %W \f1(\f3$W\f1)\f3
1062 current date (file modification date) in `mm/dd/yy' format
1066 All format directives except `$=' can also be given in format
1068 \f2escape\f1 \f2width\f1 \f2directive\f1
1070 where \f2width\f1 specifies the width of the column to which the
1071 escape is printed. For example, escape "$5%" will expand to something
1072 like " 12". If the width is negative, the value will be printed
1075 For example, the `emacs.hdr' defines its date string with the
1076 following format comment:
1078 .B %Format: eurdatestr %E
1082 .B /eurdatestr (96/01/08) def
1086 .B %HeaderHeight: \f2height\f1
1087 Allocate \f2height\f1 points space for the page header. The default
1088 header height is 36 points.
1090 .B %FooterHeight: \f2height\f1
1091 Allocate \f2height\f1 points space for the page footer. The default
1092 footer height is 0 points.
1095 According to Adobe's Document Structuring Conventions (DSC), all
1096 resources needed by a document must be listed in document's prolog.
1097 Since user's can create their own headers, \f3enscript\f1 don't know
1098 what resources those headers use. That's why all headers must contain
1099 a standard DSC comment that lists all needed resources. For example,
1100 used fonts can be listed with following comment:
1102 %%DocumentNeededResources: font \f2fontname1\f1 \f2fontname2\f1
1104 Comment can be continued to the next line with the standard
1105 continuation comment:
1107 %%+ font \f2fontname3\f1
1111 \f3Enscript\f1 supports special escape sequences which can be used to
1112 add some page formatting commands to ASCII documents. As a default,
1113 special escapes interpretation is off, so all ASCII files print out as
1114 everyone expects. Special escapes interpretation is activated by
1115 giving option \f3\-e\f1, \f3\-\-escapes\f1 to \f3enscript\f1.
1117 All special escapes start with the escape character. The default
1118 escape character is ^@ (octal 000); escape character can be changed
1119 with option \f3\-e\f1, \f3\-\-escapes\f1. Escape character is
1120 followed by escape's name and optional options and arguments.
1122 Currently \f3enscript\f1 supports following escapes:
1125 change the text background color. The syntax of the escape is:
1127 ^@bgcolor{\f2red\f1 \f2green\f1 \f2blue\f1}
1129 where the color components \f2red\f1, \f2green\f1, and \f1blue\f1 are
1130 given as decimal numbers between values 0 and 1.
1134 change the text background color. The syntax of the escape is:
1136 ^@bggray{\f2gray\f1}
1138 where \f2gray\f1 is the new text background gray value. The default
1139 value is 1.0 (white).
1142 change the text color. The syntax of the escape is:
1144 ^@color{\f2red\f1 \f2green\f1 \f2blue\f1}
1146 where color components \f2red\f1, \f2green\f1 and \f2blue\f1 are given
1147 as decimal numbers between values 0 and 1.
1150 comment the rest of the line including the newline character.
1153 ^@comment \f2text\f1 \f2newline_character\f1
1156 change the escape character. The syntax of the escape is:
1158 ^@escape{\f2code\f1}
1160 where \f2code\f1 is the decimal code of the new escape character.
1163 inline EPS file to the document. The syntax of the escape is:
1165 ^@epsf[\f2options\f1]{\f2filename\f1}
1167 where \f2options\f1 is an optional sequence of option characters and
1168 values enclosed with brackets and \f2filename\f1 is the name of the
1171 If \f2filename\f1 ends to the `|' character, then \f2filename\f1 is
1172 assumed to name a command that prints EPS data to its standard output.
1173 In this case, \f3enscript\f1 opens a pipe to the specified command
1174 and reads EPS data from pipe.
1176 Following options can be given for the \f3epsf\f1 escape:
1180 print image centered
1183 print image right justified
1186 do not update current point. Following output is printed to that
1187 position where the current point was just before the \f3epsf\f1 escape
1190 do not update current point \f2x\f1 coordinate
1193 do not update current point \f2y\f1 coordinate
1196 move image's top left \f2x\f1 coordinate \f2num\f1 characters from
1197 current point \f2x\f1 coordinate (relative position)
1200 set image's top left \f2x\f1 coordinate to column \f2num\f1 (absolute
1204 move image's top left \f2y\f1 coordinate \f2num\f1 lines from current
1205 line (relative position)
1208 set image's top left \f2y\f1 coordinate to line \f2num\f1 (absolute
1212 set image's height to \f2num\f1 lines
1215 scale image with factor \f2num\f1
1218 scale image in \f2x\f1 direction with factor \f2num\f1
1221 scale image in \f2y\f1 direction with factor \f2num\f1
1223 As a default, all dimensions are given in lines (vertical) and
1224 characters (horizontal). You can also specify other units by
1225 appending an unit specifier after number. Possible unit specifiers
1226 and the corresponding units are:
1235 lines or characters (default)
1240 For example to print an image one inch high, you can specify height by
1241 following options: \f3h1i\f1 (1 inch), \f3h2.54c\f1 (2.54 cm),
1242 \f3h72p\f1 (72 points).
1246 select current font. The syntax of the escape is:
1248 ^@font{\f2fontname\f1[:\f2encoding\f1]}
1250 where \f2fontname\f1 is a standard font specification. Special font
1251 specification \f3default\f1 can be used to select the default body
1252 font (\f3enscript\f1's default or the one specified by the command
1253 line option \f3\-f\f1, \f3\-\-font\f1).
1255 The optional argument \f2encoding\f1 specifies the encoding that
1256 should be used for the new font. Currently the encoding can only be
1257 the \f3enscript\f1's global input encoding or \f3ps\f1.
1260 include raw PostScript code to the output. The syntax of the escape
1266 highlight regions of text by changing the text background color.
1271 where \f2gray\f1 is the new text background gray value. The default
1272 value is 1.0 (white) which disables highlighting.
1274 .SH PAGE DEVICE OPTIONS
1276 Page device is a PostScript level 2 feature that offers an uniform
1277 interface to control printer's output device. \f3Enscript\f1
1278 protects all page device options inside an if block so they have no
1279 effect in level 1 interpreters. Although all level 2 interpreters
1280 support page device, they do not have to support all page device
1281 options. For example some printers can print in duplex mode and some
1282 can not. Refer to the documentation of your printer for supported
1285 Here are some usable page device options which can be selected with
1286 the \f3\-D\f1, \f3\-\-setpagedevice\f1 option. For a complete listing,
1287 see \f2PostScript Language Reference Manual\f1: section 4.11 Device
1290 .B Collate \f2boolean\f1
1291 how output is organized when printing multiple copies
1293 .B Duplex \f2boolean\f1
1294 duplex (two side) printing
1296 .B ManualFeed \f2boolean\f1
1297 manual feed paper tray
1299 .B OutputFaceUp \f2boolean\f1
1300 print output `face up' or `face down'
1302 .B Tumble \f2boolean\f1
1303 how opposite sides are positioned in duplex printing
1305 .SH PRINTING EXAMPLES
1307 Following printing examples assume that \f3enscript\f1 uses the
1308 default configuration. If default actions have been changed from the
1309 configuration files, some examples will behave differently.
1312 Print file \f3foo.txt\f1 to the default printer.
1314 .B enscript \-Possu foo.txt
1315 Print file \f3foo.txt\f1 to printer \f3ossu\f1.
1317 .B enscript \-pfoo.ps foo.txt
1318 Print file \f3foo.txt\f1, but leave PostScript output to file
1321 .B enscript \-2 foo.txt
1322 Print file \f3foo.txt\f1 to two columns.
1324 .B enscript \-2r foo.txt
1325 Print file to two columns and rotate output 90 degrees (landscape).
1327 .B enscript \-DDuplex:true foo.txt
1328 Print file in duplex (two side) mode (printer dependant).
1330 .B enscript \-G2rE \-U2 foo.c
1331 My default code printing command: gaudy header, two columns,
1332 landscape, code highlighting, 2-up printing.
1334 \f3enscript \-E \-\-color \-whtml \-\-toc -pfoo.html *.h *.c\f1
1335 A nice HTML report of your project's C source files.
1337 .SH ENVIRONMENT VARIABLES
1339 The environment variable \f3ENSCRIPT\f1 can be used to pass default
1340 options for \f3enscript\f1. For example, to select the default body
1341 font to be Times\-Roman 7pt, set the following value to the
1342 \f3ENSCRIPT\f1 environment variable:
1347 The value of the \f3ENSCRIPT\f1 variable is processed before the
1348 command line options, so command line options can be used to overwrite
1351 Variable \f3ENSCRIPT_LIBRARY\f1 specifies the \f3enscript\f1's
1352 library directory. It can be used to overwrite the build-in default
1353 `@DATADIR@/enscript'.
1357 \f3Enscript\f1 returns value 1 to the shell if any errors were
1358 encountered or 0 otherwise. If the option
1359 \f3\-\-extended\-return\-values\f1 was specified, the return value is
1360 constructed from the following flags:
1363 no errors or warnings
1366 some lines were truncated or wrapped
1369 some characters were missing from the used fonts
1372 some characters were unprintable
1378 @DATADIR@/enscript/*.hdr header files
1379 @DATADIR@/enscript/*.enc input encoding vectors
1380 @DATADIR@/enscript/enscript.pro PostScript prolog
1381 @DATADIR@/enscript/afm/*.afm AFM files for PostScript fonts
1382 @DATADIR@/enscript/font.map index for the AFM files
1383 @DATADIR@/enscript/hl/*.st states definition files
1384 @SYSCONFDIR@/enscript.cfg system\-wide configuration file
1385 @SYSCONFDIR@/enscriptsite.cfg site configuration file
1386 ~/.enscriptrc personal configuration file
1387 ~/.enscript/ personal resource directory
1391 diffpp(1), ghostview(1), gs(1), lpq(1), lpr(1), lprm(1), states(1)
1394 Markku Rossi <mtr@iki.fi> <http://www.iki.fi/~mtr/>
1396 GNU Enscript WWW home page: <http://www.iki.fi/~mtr/genscript/>