enscript.man




     ENSCRIPT(1)          ENSCRIPT (Jun 25, 1998)          ENSCRIPT(1)



     NAME
          enscript - convert text files to PostScript


     SYNOPSIS
          enscript [-12BcgGhjkKlmOqrRvVzZ] [-# copies] [-a pages] [-A
          align] [-b header] [-C[start_line]] [-d printer] [-D
          key[:value]] [-e[char]] [-E[lang]] [-f font] [-F
          header_font] [-H[num]] [-i indent] [-I filter] [-J title]
          [-L lines_per_page] [-M media] [-n copies] [-N newline] [-o
          outputfile] [-o -] [-p outputfile] [-p -] [-P printer] [-s
          baselineskip] [-S key[:value]] [-t title] [-T tabsize]
          [-u[text]] [-U num] [-W language] [-X encoding] [filename
          ...]


     DESCRIPTION
          Enscript converts text files to PostScript and spools
          generated PostScript output to the specified printer or
          leaves it to file.  If no input files are given, enscript
          processes standard input.  Enscript can be extended to
          handle different output media and it has many options which
          can be used to customize printouts.


     OPTIONS
          -# num  Print num copies of each page.

          -1, -2, --columns=num
                  Specify how many columns each page have.  With long
                  option --columns=num you can specify more than 2
                  columns per page.

          -a pages, --pages=pages
                  Specify which pages are printed.  Page specification
                  pages can be given in following formats:

                  begin-end
                          print pages from begin to end

                  -end    print pages from 0 to end

                  begin-  print pages from begin to end

                  page    print page page

                  odd     print odd pages

                  even    print even pages

          -A align, --file-align=align
                  Align separate input files to even align page count.
                  This is handy for two-side and 2-up printings
                  (--file-align=2).

          -b header, --header=header
                  Use text header as a page header.  The default page
                  header is constructed from file's name and last
                  modification time.

                  The header string header can contain the same
                  formatting escapes which can be specified for the
                  %Format directives in the user defined fancy
                  headers.  For example, the following option prints
                  the file name, current data and page numbers:

                  enscript --header='$n %W Page $% of $=' *.c

                  The header string can also contain left, center and
                  right justified fields which are separated with the
                  '|' character:

                  enscript --header='$n|%W|Page $% of $=' *.c

                  now the file name is printed left justified, the
                  date is centered to the header and the page numbers
                  are printed right justified.

          -B, --no-header
                  Do not print page headers.

          -c, --truncate-lines
                  Cut lines that are too long.  As a default, enscript
                  wraps long lines so no information is lost.

                  See also option --slice which can be used to slice
                  long lines to separate pages.

          -C[start_line], --line-numbers[=start_line]
                  Precede each line with its line number.  Optional
                  argument start_line specifies the number of the
                  first line in the input.  The number of the first
                  line defaults to 1.

          -d name Spool output to the printer name.

          -D key[:value], --setpagedevice=key[:value]
                  Pass a page device definition to the generated
                  PostScript output.  If no value is given, key key is
                  removed from definitions.

                  For example, command

                  enscript -DDuplex:true foo.txt
                  prints file foo.txt in duplex (two side) mode.

                  Page device operators are implementation dependant
                  but they are standardized.  See section PAGE DEVICE
                  OPTIONS for details.

          -e[char], --escapes[=char]
                  Enable special escapes interpretation (see section
                  SPECIAL ESCAPES).  If argument char is given, it
                  changes the escape character to char.  The default
                  escape character is 0.

          -E[lang], --pretty-print[=lang]
                  Pretty-print source code by creating a special input
                  filter with the states program.  Optional argument
                  lang specifies the language to highlight, as a
                  default states makes an educated guess.

                  A description of supported highlighting languages
                  and file formats can be printed with command:

                  enscript --help-pretty-print

                  The highlighting rules are defined in the
                  `/usr/local/share/enscript/enscript.st' file which
                  can be edited to create highlighting definitions for
                  new languages.

                  Note! You can't use your own input filters with this
                  option.

          -f name, --font=name
                  Select font that is used for body text.  The default
                  body font is Courier10, unless multicolumn landscape
                  printing mode is selected, in which case the default
                  is Courier7.

                  Font specification name contains two parts: font's
                  name and font's size in points.  For example
                  "Times-Roman12" selects "Times-Roman" font with size
                  12pt.

                  The font specification name can also be given in
                  format `name@ptsize', where font's name and point
                  size are separated by a `@' character.  This allows
                  enscript to use fonts which contain digit characters
                  in their names.

                  The font point size can also be given in format
                  width/height where width and height specify the
                  font's size in x- and y-directions.  For example
                  "Times-Roman@10/12" selects 10 points wide and 12
                  points high "Times-Roman" font.

                  Note! font sizes can be given as a decimal number.
                  For example "Times-Roman10.2" selects 10.2pt
                  "Times-Roman" font.

          -F name, --header-font=name
                  Select font for header texts.

          -g, --print-anyway
                  Print file even if it contains binary data.  Option
                  is here only for compatibility since enscript prints
                  binary files anyway.

          -G, --fancy-header[=name]
                  Print fancy page header name to top of each page.
                  Option -G specifies the default fancy header (see
                  section CONFIGURATION FILES to see how the default
                  fancy header can be changed).

          -h, --no-job-header
                  Suppress printing of the job header page.

          -H[num], --highlight-bars[=num]
                  Specify how high highlight bars are in lines.  If
                  num is not given, the default value 2 is used.  As a
                  default, no highlight bars are printed.

          -i num, --indent=num
                  Indent every line num characters.  The indentation
                  can also be specified in other units by appending an
                  unit specifier after the number.  Possible unit
                  specifiers and the corresponding units are:

                  c       centimeters

                  i       inches

                  l       characters (default)

                  p       PostScript points

          -I filter, --filter=filter
                  Read all input files through input filter filter.
                  Input filter can be a single command or a command
                  pipeline and it can refer to the name of the input
                  file with escape `%s'.  The name of the input file
                  stdin can be changed with option `--filter-stdin'.

                  For example, the following command can be used to
                  print file `foo.c' by using only upper-case
                  characters:
                  enscript --filter="cat %s | tr 'a-z' 'A-Z'" foo.c

                  And to highlight changes made to files since the
                  last checkout:

                  enscript --filter="rcsdiff %s | diffpp %s" -e *.c

                  Note! To include string "%s" to the filter command,
                  you must write it as "%%s".

          -j, --borders
                  Print borders around columns.

          -J title
                  An alias for option -t, --title.

          -k, --page-prefeed
                  Enable page prefeed.

          -K, --no-page-prefeed
                  Disable page prefeed (default).

          -l, --lineprinter
                  Emulate lineprinter.  This option is a shortcut for
                  options:  --lines-per-page=66, --no-header.

          -L num, --lines-per-page=num
                  Print only num lines per each page.

          -m, --mail
                  Send mail notification to user after print job has
                  been completed.

          -M name, --media=name
                  Select output media name.  Enscript's default output
                  media is A4.

          -n num, --copies=num
                  Print num copies of each page.

          -N nl, --newline=nl
                  Select the newline character.  Possible values for
                  nl are:  n (unix newline, 0xa hex) and r (mac
                  newline, 0xd hex).

          -o file An alias for option -p, --output.

          -O, --missing-characters
                  Print a listing of character codes which couldn't be
                  printed.

          -p file, --output=file
                  Leave output to file file.  If file is `-', leave
                  output to stdout.

          -P name, --printer=name
                  Spool output to the printer name.

          -q, --quiet, --silent
                  Make enscript really quiet.  Only fatal error
                  messages are printed to stderr.

          -r, --landscape
                  Print in landscape mode; rotate page 90 degrees.

          -R, --portrait
                  Print in portrait mode (default).

          -s num, --baselineskip=num
                  Specify the baseline skip in PostScript points.
                  Number num can be given as a decimal number.  When
                  enscript moves from line to line, current point y
                  coordinate is moved (font point size + baselineskip)
                  points down.  The default baseline skip is 1.

          -S key[:value], --statusdict=key[:value]
                  Pass a statusdict definition to the generated
                  PostScript output.  If no value is given, key key is
                  removed from definitions.

                  Statusdict operators are implementation dependant;
                  see printer's documentation for details.

                  For example, command

                  enscript -Ssetpapertray:1 foo.txt

                  prints file foo.txt by using paper from the paper
                  tray 1 (assuming that printer supports paper tray
                  selection).

          -t title, --title=title
                  Set banner page's job title to title.  Option sets
                  also the name of the input file stdin.

          -T num, --tabsize=num
                  Set tabulator size to num (default is 8).

          -u[text], --underlay[=text]
                  Print string text under every page.  Text's
                  properties can be changed with options --ul-angle,
                  --ul-font, --ul-gray, --ul-position and --ul-style.

                  If no text is given, no underlay is printed.  This
                  can be used to remove underlay that was specified
                  with the `Underlay' configuration file option.

          -U num, --nup=num
                  Print num logical pages on each output page (N-up
                  printing).

          -v, --verbose[=level]
                  Tell what enscript is doing.

          -V, --version
                  Print enscript version and exit.

          -W [lang], --language[=lang]
                  Generate output in language lang.  Possible values
                  for lang are:

                  PostScript
                          generate PostScript (default)

                  html    generate HTML

                  overstrike
                          generate overstrikes (line printers, less)

                  rtf     generate RTF (Rich Text Format)

          -X name, --encoding=name
                  Use input encoding name.  Currently enscript
                  supports following encodings:

                  88591, latin1
                          ISO-8859-1 (ISO Latin1) (enscript's default
                          encoding).

                  88592, latin2
                          ISO-8859-2 (ISO Latin2)

                  88593, latin3
                          ISO-8859-3 (ISO Latin3)

                  88594, latin4
                          ISO-8859-4 (ISO Latin4)

                  88595, cyrillic
                          ISO-8859-5 (ISO Cyrillic)

                  88597, greek
                          ISO-8859-7 (ISO Greek)

                  ascii   7-bit ascii

                  asciifise, asciifi, asciise
                          7-bit ascii with some scandinavian (fi, se)
                          extensions

                  asciidkno, asciidk, asciino
                          7-bit ascii with some scandinavian (dk, no)
                          extensions

                  ibmpc, pc, dos
                          IBM PC charset

                  mac     Mac charset

                  vms     VMS multinational charset

                  hp8     HP Roman-8 charset

                  koi8    Adobe Standard Cyrillic Font KOI8 charset

                  ps, PS  PostScript font's default encoding

                  pslatin1, ISOLatin1Encoding
                          PostScript interpreter's `ISOLatin1Encoding'

          -z, --no-formfeed
                  Turn off form feed character interpretation.

          -Z, --pass-through
                  Pass through all PostScript and PCL files without
                  any modifications.  This allows that enscript can be
                  used as a lp filter.

                  PostScript files are recognized by looking up the
                  `%!' magic cookie from the beginning of the file.
                  Note! Enscript recognized also the Windoze damaged
                  `^D%!' cookie.

                  PCL files are recognized by looking up the `^[E' or
                  `^[%' magic cookies from the beginning of the file.

          --color[=color]
                  Set the pretty-printing color model to color.  If no
                  color is specified, use color model emacs.

          --download-font=fontname
                  Include the font description file (.pfa or .pfb
                  file) of the font fontname to the generated output.

          --filter-stdin=name
                  Specify how stdin is shown to the input filter.  The
                  default value is an empty string ("") but some
                  programs require that stdin is called something
                  else, usually "-".

          --h-column-height=height
                  Set the horizontal column height to be height
                  PostScript points.  The option sets the formfeed
                  type to horizontal-columns.

          --help  Print short help message and exit.

          --help-pretty-print
                  Describe all supported --pretty-print languages and
                  file formats.

          --highlight-bar-gray=gray
                  Specify the gray level which is used to print
                  highlight bars.

          --list-media
                  List the names of all known output media and exit
                  successfully.

          --list-options
                  List all options and their current values.  Exit
                  successfully.

          --margins=left:right:top:bottom
                  Adjust page marginals to be exact left, right, top
                  and bottom PostScript points.  Any of arguments can
                  be left empty in which case the default value is
                  used.

          --mark-wrapped-lines[=style]
                  Mark wrapped lines in the output with style style.
                  Possible values for style are:

                  none    do not mark them (default)

                  plus    print a plus (+) character to the end of
                          each wrapped line

                  box     print a black box to the end of each wrapped
                          line

                  arrow   print a small arrow to the end of each
                          wrapped line

          --non-printable-format=format
                  Specify how non-printable characters are printed.
                  Possible values for format are:

                  caret   caret notation: `^@', `^A', `^B', ...

                  octal   octal notation: `\000', `\001', `\002', ...
                          (default)

                  questionmark
                          replace non-printable characters with a
                          question mark `?'

                  space   replace non-printable characters with a
                          space ` '

          --nup-xpad=num
                  Set the page x-padding of the n-up printing to num
                  PostScript points.  The default is 10 points.

          --nup-ypad=num
                  Set the page y-padding of the n-up printing to num
                  PostScript points.  The default is 10 points.

          --page-label-format=format
                  Set page label format to format.  Page label format
                  specifies how labels for the `%%Page:' PostScript
                  comments are formatted.  Possible values are:

                  short   Print current pagenumber: `%%Page: (1) 1'
                          (default)

                  long    Print current filename and pagenumber:
                          `%%Page: (main.c:  1) 1'

          --ps-level=level
                  Set the PostScript language level, that enscript
                  uses for its output, to level.  The possible values
                  are 1, and 2.

          --printer-options=options
                  Pass extra options to the printer command.

          --rotate-even-pages
                  Rotate each even-numbered page 180 degrees.

          --slice=num
                  Print vertical slice num.  Slices are vertical
                  regions of input files, new slice starts from the
                  point where the line would otherwise be wrapped to
                  the next line.  Slice numbers start from 1.

          --toc   Print table of contents to the end of the print job.

          --word-wrap
                  Wrap long lines from word boundaries.

          --ul-angle=angle
                  Set underlay text's angle.  As a default, angle is
                  atan(-page_height, page_width).

          --ul-font=name
                  Select font for the underlay text.  The default
                  underlay font is Times-Roman200.

          --ul-gray=num
                  Print underlay text with gray value num (0 ... 1),
                  the default gray is .8.

          --ul-position=position_spec
                  Set underlay text's starting position according to
                  position_spec.  Position specification must be given
                  in format:  `sign xpos sign ypos', where sign must
                  be `+' or `-'.  Positive dimensions are measured
                  from the lower left corner and negative dimensions
                  from the upper right corner.  For example, spec
                  `+0-0' specifies the upper left corner and `-0+0'
                  specifies the lower right corner.

          --ul-style=style
                  Set underlay text's style to style.  Possible values
                  for style are:

                  outline print outline underlay texts (default)

                  filled  print filled underlay texts


     CONFIGURATION FILES
          Enscript reads configuration information from following
          sources (in this order): command line options, environment
          variable ENSCRIPT, user's personal configuration file
          ($HOME/.enscriptrc), site configuration file
          (/usr/local/etc/enscriptsite.cfg) and system's global
          configuration file (/usr/local/etc/enscript.cfg).

          The configuration files have the following format:

          Empty lines and lines starting with `#' are comments.

          All other lines are option lines and have format:

          OPTION [arguments ...].

          Following options can be specified:

          AcceptCompositeCharacters: bool
                  Specify whatever PostScript font's composite
                  characters are accepted as printable or should they
                  be considered as non-existent.  The default value is
                  false (0).

          AFMPath: path
                  Specifies search path for the AFM files.

          AppendCtrlD: bool
                  Specify if the Control-D (^D) character should be
                  appended to the end of the output.  The default
                  value is false (0).

          Clean7Bit: bool
                  Specify how characters greater than 127 are printed.
                  Value true (1) generates 7-bit clean code by
                  escaping all characters greater than 127 to the
                  backslash-octal notation (default).  Value false (0)
                  generates 8-bit PostScript code leaving all
                  characters untouched.

          DefaultEncoding: name
                  Select the default input encoding.  Encoding name
                  name can be one of the values of the -X, --encoding
                  option.

          DefaultFancyHeader: name
                  Select the default fancy header.  Default header is
                  used when option -G is specified or option
                  --fancy-header is given without an argument.
                  System-wide default is `enscript'.

          DefaultMedia: name
                  Select the default output media.

          DefaultOutputMethod: method
                  Select the default target to which generated output
                  is send.  Possible values for method are:

                  printer send output to printer (default)

                  stdout  send output to stdout

          DownloadFont: fontname
                  Include the font description file of the font
                  fontname to the generated output.

          EscapeChar: num
                  Specify the escape character for special escapes.
                  The default value is 0.

          FormFeedType: type
                  Specify what to do when a formfeed character is
                  encountered from the input.  Possible values for
                  type are:
                  column  move to the beginning of the next column
                          (default)

                  page    move to the beginning of the next page

          GeneratePageSize: bool
                  Specify whether the PageSize page device setting is
                  generated to the PostScript output.  The default
                  value is true (1).

          HighlightBarGray: gray
                  Specify the gray level which is used to print
                  highlight bars.

          HighlightBars: num
                  Specify how high highlight bars are in lines.  The
                  default value is 0 so no highlight bars are printed.

          LibraryPath: path
                  Specifies enscript's library path that is used to
                  lookup various resources.  Default path is:
                  `/usr/local/share/enscript:home/.enscript'.  Where
                  home is the user's home directory.

          MarkWrappedLines: style
                  Mark wraped lines in the output with style style.
                  Possible values for format are the same which can be
                  given for the --mark-wrapped-lines option.

          Media: name width height llx lly urx ury
                  Add a new output media with name name.  Media's
                  physical dimensions are width and height.  Media's
                  bounding box is specified by points (llx, lly) and
                  (urx, ury).  Enscript prints all graphics inside
                  media's bounding box.

                  User can select this media by giving option -M name.

          NoJobHeaderSwitch: switch
                  Specify the spooler option to suppress the print job
                  header.  This option is passed to the printer
                  spooler when enscript's option -h, --no-job-header
                  is selected.

          NonPrintableFormat: format
                  Specify how non-printable characters are printed.
                  Possible values for format are the same which can be
                  given for the --non-printable-format option.

          OutputFirstLine: line
                  Set PostScript output's first line to line, the
                  default value is PS-Adobe-3.0.  Since some printers
                  do not like DSC levels greater than 2.0, this option
                  can be used to change the output first line to
                  something more suitable like %!PS-Adobe-2.0 or %!.

          PageLabelFormat: format
                  Set page label format to format.  Possible values
                  for format are the same which can be given for the
                  --page-label-format option.

          PagePrefeed: bool
                  Enable / disable page prefeed.  The default is false
                  (0).

          PostScriptLevel: level
                  Set the PostScript language level, that enscript
                  uses for its output, to level.  The possible values
                  for level are the same which can be given for the
                  --ps-level option.

          Printer: name
                  Names the printer to spool to.

          QueueParam: name
                  The spooler command switch for the printer queue,
                  e.g. -P in lpr -Pps.  This option can also be used
                  to pass other flags to the spooler command but they
                  must be given before the queue switch.

          SetPageDevice: key[:value]
                  Pass a page device definition to the generated
                  PostScript output.

          Spooler: name
                  Names printer spooler command.  Enscript pipes
                  generated PostScript to command name.

          StatesColorModel: model
                  Set the pretty-printing color model to model.
                  Possible values are blackwhite and emacs.

          StatesConfigFile: file
                  Read pretty-printer states configuration from file
                  file.  The default config file is
                  `/usr/local/share/enscript/enscript.st'.

          StatesHighlightLevel: level
                  Set the pretty-printing highlight level to level.
                  Possible values are none, light and heavy.

          StatesPath: path
                  Define path for the states program.

          StatusDict: key[:value]
                  Pass a statusdict definition to the generated
                  PostScript output.

          TOCFormat: format
                  Format table of contents entries with format string
                  format.  Format string format can contain the same
                  escapes which are used to format header strings with
                  the `%Format' special comment.

          Underlay: text
                  Print string text under every page.

          UnderlayAngle: num
                  Set underlay text's angle to num.

          UnderlayFont: fontspec
                  Select font for the underlay text.

          UnderlayGray: num
                  Print underlay text with gray value num.

          UnderlayPosition: position_spec
                  Set underlay text's starting position according to
                  position_spec.

          UnderlayStyle: style
                  Set underlay text's style to style.


     CUSTOMIZATION
          Users can create their own fancy headers by creating a
          header description file and placing it in a directory which
          is in enscript's library path.  The name of the header file
          must be in format: `headername.hdr'.  Header can be selected
          by giving option: --fancy-header=headername.

          Header description file contains PostScript code that paints
          the header.  Description file must provide procedure
          do__header which is called by enscript at the beginning of
          every page.

          Header description file contains two parts: comments and
          code.  Parts are separated by a line containing text:

          % -- code follows this line --

          Enscript copies only the code part of description file to
          the generated PostScript output.  The comments part can
          contain any data, it is not copied.  If separator line is
          missing, no data is copied to output.

          Enscript defines following constants which can be used in
          header description files:

          d__page__w        page width

          d__page__h        page height

          d__header__x      header lower left x coordinate

          d__header__y      header lower left y coordinate

          d__header__w      header width

          d__header__h      header height

          d__footer__x      footer lower left x coordinate

          d__footer__y      footer lower left y coordinate

          d__footer__w      footer width

          d__footer__h      footer height

          d__output__w      width of the text output area

          d__output__h      height of the text output area

          user__header__p   predicate which tells if user has defined
                          his/her own header string:  true/false

          user__header__left__str
                          if user__header__p is true, this is the left
                          field of the user supplied header string.

          user__header__center__str
                          if user__header__p is true, this is the center
                          field of the user supplied header string

          user__header__right__str
                          if user__header__p is true, this is the right
                          field of the user supplied header string

          HF              standard header font (from -F, --header-font
                          option).  This can be selected simply by
                          invoking command: `HF setfont'.

          pagenum         the number of the current page

          fname           the full name of the printed file
                          (/foo/bar.c)

          fdir            the directory part of the file name (/foo)
          ftail           file name without the directory part (bar.c)

          gs__languagelevel
                          PostScript interpreter's language level
                          (currently 1 or 2)

          You can also use the following special comments to customize
          your headers and to specify some extra options.  Special
          comments are like DSC comments but they start with a single
          `%' character; special comments start from the beginning of
          the line and they have the following syntax:

          %commentname: options

          Currently enscript support the following special comments:

          %Format: name format
                  Define a new string constant name according to the
                  format string format.  Format string start from the
                  first non-space character and it ends to the end of
                  the line.  Format string can contain general `%'
                  escapes and input file related `$' escapes.
                  Currently following escapes are supported:

                  %%      character `%'

                  $$      character `$'

                  $%      current page number

                  $=      number of pages in the current file

                  $(VAR)  value of the environment variable VAR.

                  %c      trailing component of the current working
                          directory

                  %C ($C) current time (file modification time) in
                          `hh:mm:ss' format

                  %d      current working directory

                  %D ($D) current date (file modification date) in
                          `yy-mm-dd' format

                  %D{string} ($D{string})
                          format string string with the strftime(3)
                          function.  `%D{}' refers to the current date
                          and `$D{}' to the input file's last
                          modification date.

                  %E ($E) current date (file modification date) in
                          `yy/mm/dd' format

                  %F ($F) current date (file modification date) in
                          `dd.mm.yyyy' format

                  %H      document title

                  $L      number of lines in the current input file.
                          This is valid only for the toc entries, it
                          can't be used in header strings.

                  %m      the hostname up to the first `.' character

                  %M      the full hostname

                  %n      the user login name

                  $n      input file name without the directory part

                  %N      the user's pw_gecos field up to the first
                          `,' character

                  $N      the full input file name

                  %t ($t) current time (file modification time) in
                          12-hour am/pm format

                  %T ($T) current time (file modification time) in
                          24-hour format `hh:mm'

                  %* ($*) current time (file modification time) in
                          24-hour format with seconds `hh:mm:ss'

                  $v      the sequence number of the current input
                          file

                  $V      the sequence number of the current input
                          file in the `Table of Contents' format: if
                          the --toc option is given, escape expands to
                          `num-'; if the --toc is not given, escape
                          expands to an empty string.

                  %W ($W) current date (file modification date) in
                          `mm/dd/yy' format

                  All format directives except `$=' can also be given
                  in format

                  escape width directive

                  where width specifies the width of the column to
                  which the escape is printed.  For example, escape
                  "$5%" will expand to something like " 12".  If the
                  width is negative, the value will be printed left-
                  justified.

                  For example, the `emacs.hdr' defines its date string
                  with the following format comment:

                  %Format: eurdatestr %E

                  which expands to:

                  /eurdatestr (96/01/08) def

          %HeaderHeight: height
                  Allocate height points space for the page header.
                  The default header height is 36 points.

          %FooterHeight: height
                  Allocate height points space for the page footer.
                  The default footer height is 0 points.

          According to Adobe's Document Structuring Conventions (DSC),
          all resources needed by a document must be listed in
          document's prolog.  Since user's can create their own
          headers, enscript don't know what resources those headers
          use.  That's why all headers must contain a standard DSC
          comment that lists all needed resources.  For example, used
          fonts can be listed with following comment:

          %%DocumentNeededResources: font fontname1 fontname2

          Comment can be continued to the next line with the standard
          continuation comment:

          %%+ font fontname3


     SPECIAL ESCAPES
          Enscript supports special escape sequences which can be used
          to add some page formatting commands to ASCII documents.  As
          a default, special escapes interpretation is off, so all
          ASCII files print out as everyone expects.  Special escapes
          interpretation is activated by giving option -e, --escapes
          to enscript.

          All special escapes start with the escape character.  The
          default escape character is ^@ (octal 000); escape character
          can be changed with option -e, --escapes.  Escape character
          is followed by escape's name and optional options and
          arguments.

          Currently enscript supports following escapes:
          bggray  change the text background color.  Escape's syntax
                  is:

                  ^@bggray{gray}

                  where gray is the new text background gray value.
                  The default value is 1.0 (white).

          color   change the text color.  Escape's syntax is:

                  ^@color{red green blue}

                  where color components red, green and blue are given
                  as a decimal numbers between 0 and 1.

          comment comment the rest of the line including the newline
                  character.  Escape's syntax is:

                  ^@comment text newline_character

          escape  change the escape character.  Escape's syntax is

                  ^@escape{code}

                  where code is the decimal code of the new escape
                  character.

          epsf    inline EPS file to the document.  Escape's syntax
                  is:

                  ^@epsf[options]{filename}

                  where options is an optional sequence of option
                  characters and values enclosed with brackets and
                  filename is the name of the EPS file.

                  If filename ends to the `|' character, then filename
                  is assumed to name a command that prints EPS data to
                  its standard output.  In this case, enscript opens a
                  pipe to the specified command and reads EPS data
                  from pipe.

                  Following options can be given for the epsf escape:

                  c       print image centered

                  r       print image right justified

                  n       do not update current point.  Following
                          output is printed to that position where the
                          current point was just before the epsf
                          escape
                  nx      do not update current point x coordinate

                  ny      do not update current point y coordinate

                  xnum    move image's top left x coordinate num
                          characters from current point x coordinate
                          (relative position)

                  xnuma   set image's top left x coordinate to column
                          num (absolute position)

                  ynum    move image's top left y coordinate num lines
                          from current line (relative position)

                  ynuma   set image's top left y coordinate to line
                          num (absolute position)

                  hnum    set image's height to num lines

                  snum    scale image with factor num

                  sxnum   scale image in x direction with factor num

                  synum   scale image in y direction with factor num

                  As a default, all dimensions are given in lines
                  (vertical) and characters (horizontal).  You can
                  also specify other units by appending an unit
                  specifier after number.  Possible unit specifiers
                  and the corresponding units are:

                  c       centimeters

                  i       inches

                  l       lines or characters (default)

                  p       PostScript points

                  For example to print an image one inch high, you can
                  specify height by following options: h1i (1 inch),
                  h2.54c (2.54 cm), h72p (72 points).

          font    select current font.  Escape's syntax is:

                  ^@font{fontname}

                  where fontname is a standard font specification.
                  Special font specification default can be used to
                  select the default body font (enscript's default or
                  the one specified by the command line option -f,
                  --font).
          ps      include raw PostScript code to the output.  Escape's
                  syntax is:

                  ^@ps{code}

          shade   highlight regions of text by changing the text
                  background color.  Escape's syntax is:

                  ^@shade{gray}

                  where gray is the new text background gray value.
                  The default value is 1.0 (white) which disables
                  highlighting.


     PAGE DEVICE OPTIONS
          Page device is a PostScript level 2 feature that offers an
          uniform interface to control printer's output device.
          Enscript protects all page device options inside an if block
          so they have no effect in level 1 interpreters.  Although
          all level 2 interpreters support page device, they do not
          have to support all page device options.  For example some
          printers can print in duplex mode and some can not.  Refer
          to the documentation of your printer for supported options.

          Here are some usable page device options which can be
          selected with the -D, --setpagedevice option.  For a
          complete listing, see PostScript Language Reference Manual:
          section 4.11 Device Setup.

          Collate boolean
                  how output is organized when printing multiple
                  copies

          Duplex boolean
                  duplex (two side) printing

          ManualFeed boolean
                  manual feed paper tray

          OutputFaceUp boolean
                  print output `face up' or `face down'

          Tumble boolean
                  how opposite sides are positioned in duplex printing


     PRINTING EXAMPLES
          Following printing examples assume that enscript uses the
          default configuration.  If default actions have been changed
          from the configuration files, some examples will behave
          differently.
          enscript foo.txt
                  Print file foo.txt to the default printer.

          enscript -Possu foo.txt
                  Print file foo.txt to printer ossu.

          enscript -pfoo.ps foo.txt
                  Print file foo.txt, but leave PostScript output to
                  file foo.ps.

          enscript -2 foo.txt
                  Print file foo.txt to two columns.

          enscript -2r foo.txt
                  Print file to two columns and rotate output 90
                  degrees (landscape).

          enscript -DDuplex:true foo.txt
                  Print file in duplex (two side) mode (printer
                  dependant).

          enscript -G2rE -U2 foo.c
                  My default code printing command: gaudy header, two
                  columns, landscape, code highlighting, 2-up
                  printing.

          enscript -E --color -Whtml --toc -pfoo.html *.h *.c
                  A nice HTML report of your project's C source files.


     ENVIRONMENT VARIABLES
          The environment variable ENSCRIPT can be used to pass
          default options for enscript.  For example, to select the
          default body font to be Times-Roman 7pt, set the following
          value to the ENSCRIPT environment variable:

          -fTimes-Roman7

          The value of the ENSCRIPT variable is processed before the
          command line options, so command line options can be used to
          overwrite these defaults.

          Variable ENSCRIPT__LIBRARY specifies the enscript's library
          directory.  It can be used to overwrite the build-in default
          `/usr/local/share/enscript'.


     RETURN VALUE
          Enscript returns value 1 to the shell if any errors were
          encountered.  On successfull termination, the return code is
          constucted from the following flags:

          0       no errors or warnings

          2       some lines were truncated or wrapped

          4       some characters were missing from the used fonts

          8       some characters were unprintable


     FILES
          /usr/local/share/enscript/*.hdr         header files
          /usr/local/share/enscript/*.enc         input encoding vectors
          /usr/local/share/enscript/enscript.pro  PostScript prolog
          /usr/local/share/enscript/*.afm         AFM files for PostScript fonts
          /usr/local/share/enscript/font.map      index for the AFM files
          /usr/local/share/enscript/enscript.st   states definition file
          /usr/local/etc/enscript.cfg             system-wide configuration file
          /usr/local/etc/enscriptsite.cfg         site configuration file
          ~/.enscriptrc                           personal configuration file
          ~/.enscript/                            personal resource directory


     SEE ALSO
          diffpp(1), ghostview(1), gs(1), lpq(1), lpr(1), lprm(1),
          states(1)


     AUTHOR
          Markku Rossi <mtr@iki.fi> <http://www.iki.fi/~mtr/>

          GNU Enscript WWW home page:
          <http://www.iki.fi/~mtr/genscript/>





















Generated by GNU enscript 1.6.1.