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