TEX(1)                                                     TEX(1)

     NAME
          tex, latex, slitex, bibtex, dvips, dviselect, mf, mktexlsr -
          text formatting and typesetting

     SYNOPSIS
          tex [ first-line ]

          latex file[.tex]

          slitex [ first-line ]

          dvips [ option ... ] dvifile

          dviselect [ -s ] [ -i infile ] [ -o outfile ] list of pages
          [ infile [ outfile ] ]

          bibtex auxname

          mf [ first-line ]

          mktexlsr

     DESCRIPTION
          Tex formats interspersed text and commands and outputs a
          .dvi (`device independent') file.

          An argument given on the command line behaves as the first
          input line.  That line should begin with a (possibly trun-
          cated) file name or a \controlsequence. Thus tex paper pro-
          cesses the file paper.tex.  The base name of paper becomes
          the jobname, and is used in forming output file names.  If
          no file is named, the jobname is texput.  The default .tex
          extension can be overridden by specifying an extension
          explicitly.

          The output is written on jobname.dvi, which can be printed
          using lp(1). A log of error messages goes into jobname.log.

          As well as the standard TeX fonts, many PostScript fonts can
          be used (see the contents of /sys/lib/tex/fonts/psvf).  The
          file testfont.tex (in the standard macro directory) will
          print a table of any font.

          The following environment variables adjust the behavior of
          tex. Search paths are lists of directories separated by
          colons.  The wildcard // may expand to any path, so
          /sys/lib/texmf// means the entire tree rooted at
          /sys/lib/texmf, and /usr//lib includes any directories named
          lib that sit anywhere under /usr.  Finally, braces may be
          used to specify alternatives, so that /a/{b:c}/d means

     Page 1                       Plan 9            (printed 11/22/24)

     TEX(1)                                                     TEX(1)

          /a/b/d or /a/c/d.

          If a directory contains a file called ls-R, that file is
          used as an index of the hierarchy rooted there.  These files
          may be created with mktexlsr (see below) If a sought file is
          not found in an ls-R listing, it is searched for by walking
          the directory or directory hierarchy as specified.  If the
          path begins with !!, the search is constrained to only look
          in the ls-R and not walk the hierarchy.  Thus
          !!/sys/lib/texmf// means the entire tree rooted at
          /sys/lib/texmf, but only consulting /sys/lib/texmf/ls-R to
          search for files.

          TEXINPUTS
            Search path for \input and \openin files.  It should be
            colon-separated, and start with dot.  Default:
            .:$home/lib/tex:!!/sys/lib/texmf/tex//
          TFMFONTS
            Search path for font metric files.  Default:
            .:!!/sys/lib/texmf/tex/fonts//tfm//
          PKFONTS
            Search path for font bitmaps.  Default:
            .:!!/sys/lib/texmf/fonts//pk//
          TEXFORMATS
            Search path for program format files.  Default:
            .:!!/sys/lib/texmf/web2c
          TEXPOOL
            Search path for strings.  Default:
            .:!!/sys/lib/texmf/web2c
          TEXEDIT
            Template for the switch-to-editor-on-error option, with %s
            for the file name and %d for the line number.  Default:
            /bin/ed %s
          MFINPUTS
            Search path for Metafont input files.  Default:
            .:!!/sys/lib/texmf/metafont//:!!/sys/lib/texmf/fonts//source//
          MPINPUTS
            Search path for MetaPost input files.  Default:
            .:!!/sys/lib/texmf/metapost//

          Slitex is a version of tex that is preloaded with a set of
          macros useful for creating viewgraphs.

          Latex is a version of tex with a standard set of macros
          loaded.  Latex produces file.dvi and a cross-referencing
          file, file.aux.  It might be necessary to run latex twice,
          to get all of the cross-referencing done properly.

          Bibtex is a bibliography processing program, often used in
          conjunction with latex. Bibtex reads the top-level auxiliary
          (.aux) file output by latex and creates a bibliography
          (.bbl) file to be included in the LaTeX source file.  The

     Page 2                       Plan 9            (printed 11/22/24)

     TEX(1)                                                     TEX(1)

          auxname on the command line should be given without an
          extension.  Each \cite in the source file is looked up in
          bibliography files to gather together those used in the doc-
          ument.  Then a bibliography style file is executed to write
          a \thebibliography environment.

          The source file should have defined the bibliography (.bib)
          files to search with the \bibliography command, and the bib-
          liography style (.bst) file to execute with the
          \bibliographystyle command.  Bibtex searches the TEXINPUTS
          path for .bst files, and the BIBINPUTS path (default
          .:!!/sys/lib/texmf/bibtex//) for .bst files.  The LaTeX man-
          ual describes how to make bibliography files.

          Dvips converts .dvi files to PostScript, writing the result
          on standard output.  It is normally invoked by lp(1), but if
          invoked separately, the following options are useful:

          -r      reverse pages.  -r0 means don't reverse pages (if
                  reversing is default).

          -q0     Enable verbose chatter on standard error.

          -Pdev   output device: dev is one of ps (default for dvips),
                  psfonts, or bitmapfonts.  The ps device uses
                  PostScript fonts wherever possible, quickly creating
                  small documents that are not very portable (since
                  most sites and printers don't have the necessary
                  PostScript fonts installed).  The psfonts device
                  includes all necessary fonts in the files, and thus
                  quickly creates large portable documents.  These are
                  especially good for distilling (see distill(1)) into
                  PDF.  The bitmapfonts device behaves in the manner
                  most common in other tex installations: it creates
                  bitmap versions of each font and includes them in
                  the document, resulting in portable yet medium sized
                  documents that don't convert well to PDF.  If the
                  bitmap fonts needed do not exist, they will be cre-
                  ated on the fly, which takes a fair bit of time.

          -L      print paper in landscape mode.

          -Z      compress the fonts before sending them.

          -Z0     don't compress the fonts before sending them.

          The following environment variables affect dvips:

          PKFONTS    Search path for font bitmaps (PK files).
          VFFONTS    Search path for virtual font descriptions.

          Dviselect selects pages from a .dvi file, creating a new

     Page 3                       Plan 9            (printed 11/22/24)

     TEX(1)                                                     TEX(1)

          .dvi file.  A range is a string of the form first:last where
          both first and last are optional numeric strings, with nega-
          tive numbers indicated by a leading underscore character
          (_).  If both first and last are omitted, the colon may also
          be omitted, or may be replaced with an asterisk (*).  A TeX
          page selector is a list of pages separated by periods.  A
          list of pages is described by a set of page TeX page selec-
          tors, separated by commas and/or white space.  Dviselect
          actually looks at the ten count variables that TeX writes;
          the first of these (\count0) is the page number, with
          \count1 through \count9 having varied uses depending on
          which macro packages are in use.  (Typically \count1 is a
          chapter or section number.)  A page is included in
          dviselect's output if all its \count values are within any
          one of the ranges listed on the command line.  For example,
          the command `dviselect *.1,35:' might select everything in
          chapter 1, as well as pages 35 and up.

          Instead of \count values, dviselect can also select by abso-
          lute page number, indicated by a leading equal sign (=).
          Ranges of absolute pages are also allowed: `dviselect =3:7'
          will extract the third through seventh pages.

          Dvips understands some extended graphics commands that can
          be output using tpic specials in the TeX source.  Many of
          them work by building up a path of x,y pairs, and then doing
          something with the path.  The tpic coordinate system has its
          origin at the current dvi position when a drawing special is
          emitted; all length arguments are in units of milli-inches,
          and the y-axis goes positive downward.

          \special{pa x y}
               Add x,y to the current path.

          \special{fp}
               Flush the current path: draw it as a polygonal line and
               reset the path to be empty.

          \special{da dlen}
               Like fp but draw dashed line, with dashes dlen milli-
               inches long.

          \special{dt slen}
               Like fp but draw a dotted line, with dots slen apart.

          \special{sp}
               Like fp but draw a quadratic spline.  The spline goes
               through the midpoints of the segments of the path, and
               straight pieces extend it to the endpoints.

          \special{ar x y xr yr s e}
               Draw a circular or elliptical arc with center at x,y

     Page 4                       Plan 9            (printed 11/22/24)

     TEX(1)                                                     TEX(1)

               and radii xr and yr.  The arc goes clockwise from angle
               s to angle e (angles measured clockwise from the posi-
               tive x-axis).

          \special{pn n}
               Set line width (pen diameter) to nmilli-inches.

          \special{bk}
               Set shading to black (will fill the next object drawn
               with black).

          \special{sh}
               Set shading to grey.

          \special{wh}
               Set shading to white.

          \special{psfile=file options}
               Include file, which should be a PostScript illustra-
               tion, making its origin be the current dvi position.
               The default PostScript transformation matrix will be in
               effect, but it can be modified by the options, a list
               of space-separated key=value assignments.  Allowed keys
               are: hoffset, voffset, hscale, vscale, angle, If sup-
               plied, these values are supplied to PostScript
               translate,scale, and rotate commands, in that order.
               Also, keys hsize and vsize may be supplied, to cause
               clipping to those sizes.  Sizes and offsets should be
               specified in points, angles should be specified in
               degrees.

          All of the specials leave TeX at the same position on the
          page that it started in.

          Mf runs metafont, a program that produces fonts for TeX.  It
          is used by dvips when bitmaps for a given font at a given
          size do not exist.

          Mktexlsr is used to generate ls-R files for quick path
          searching.  It simulates the Unix command ``ls -LAR .''.

     FILES
          Directory containing files directly supporting
               the runtime environment of tex et al., such as .mem and
               .pool files.

          /sys/lib/texmf/web2c/texmf.cnf
               Configuration file listing the default search paths
               mentioned above.

          /sys/lib/texmf/tex
               Tex macros.

     Page 5                       Plan 9            (printed 11/22/24)

     TEX(1)                                                     TEX(1)

          /sys/lib/texmf/tex/latex
               Latex macros.

          /sys/lib/texmf/tex/latex/local
               Locally installed latex macros.

          /sys/lib/texmf/fonts
               Fonts, fonts, and more fonts.

          /sys/lib/texmf/dvips
               Miscellaneous configuration files and PostScript head-
               ers

          /sys/lib/texmf/doc
               Various documentation organized in the same manner as
               /sys/lib/texmf.

          /sys/lib/texmf/bin/$objtype, /sys/lib/texmf/bin/rc
               Auxiliary programs, such as mktexlsr, used by tex and
               friends.

     SOURCE
          /sys/src/cmd/tex

     SEE ALSO
          lp(1), mp(1), page(1), pic(1), proof(1), troff(1), delatex
          in deroff(1)
          D. E. Knuth, TheTEXbook, Addison-Wesley, 1984
          L. Lamport, LaTeX, A Document Preparation System, Addison-
          Wesley, 1985
          H. Trickey, ``Latex User Guide'', Unix Research System
          Programmer's Manual, Tenth Edition, Volume 2.
          Various documents in /sys/lib/texmf/doc.

     BUGS
          Should be spelled τεχ.
          The path notation is bizarre.

     Page 6                       Plan 9            (printed 11/22/24)