home *** CD-ROM | disk | FTP | other *** search
/ PC World 1999 August / PCWorld_1999-08_cd.bin / doc / HOWTO / Printing-HOWTO < prev    next >
Text File  |  1999-03-21  |  64KB  |  1,915 lines

  1.   The Linux Printing HOWTO
  2.   Grant Taylor <gtaylor+pht@picante.com>
  3.   v3.29, 9 March 1999
  4.  
  5.   This is the Linux Printing HOWTO, a collection of information on how
  6.   to generate, preview, print and fax anything under Linux (and other
  7.   Unices in general).
  8.   ______________________________________________________________________
  9.  
  10.   Table of Contents
  11.  
  12.  
  13.  
  14.  
  15.  
  16.  
  17.  
  18.  
  19.  
  20.  
  21.  
  22.  
  23.  
  24.  
  25.  
  26.  
  27.  
  28.  
  29.  
  30.  
  31.  
  32.  
  33.  
  34.  
  35.  
  36.  
  37.  
  38.  
  39.  
  40.  
  41.  
  42.  
  43.  
  44.  
  45.  
  46.  
  47.  
  48.  
  49.  
  50.  
  51.  
  52.  
  53.  
  54.  
  55.  
  56.  
  57.  
  58.  
  59.  
  60.  
  61.  
  62.  
  63.  
  64.  
  65.  
  66.  
  67.   1. Introduction
  68.  
  69.      1.1 History
  70.      1.2 Copyright
  71.  
  72.   2. How to print
  73.  
  74.   3. Kernel printer devices
  75.  
  76.      3.1 The lp device (kernels <=2.1.32)
  77.      3.2 The parport device (kernels >= 2.1.33)
  78.      3.3 Serial devices
  79.  
  80.   4. Supported Printers
  81.  
  82.      4.1 Postscript
  83.      4.2 Non-Postscript
  84.      4.3 What printers work?
  85.         4.3.1 Printer compatibility list
  86.  
  87.   5. Which spooling software?
  88.  
  89.   6. How it works, basic
  90.  
  91.   7. How to set things up, basic
  92.  
  93.      7.1 Traditional lpd configuration
  94.      7.2 File Permissions
  95.  
  96.   8. Getting Printing Software
  97.  
  98.   9. Vendor Solutions
  99.  
  100.      9.1 Red Hat
  101.      9.2 Debian
  102.      9.3 Other Distributions
  103.  
  104.   10. Ghostscript.
  105.  
  106.      10.1 Invoking Ghostscript
  107.      10.2 Ghostscript output tuning
  108.         10.2.1 Output location and size
  109.         10.2.2 Gamma, dotsizes, etc.
  110.  
  111.   11. How to print to a printer over the network
  112.  
  113.      11.1 To a Unix/lpd host
  114.         11.1.1 With
  115.         11.1.2 With
  116.      11.2 To a Win95, WinNT, LanManager, or Samba printer
  117.      11.3 To a NetWare Printer
  118.      11.4 To an EtherTalk (Apple) printer
  119.      11.5 To an HP or other ethernet printer
  120.         11.5.1 To older HPs
  121.      11.6 Running an
  122.      11.7 From Windows.
  123.      11.8 From an Apple.
  124.      11.9 From Netware.
  125.  
  126.   12. Windows-only printers
  127.  
  128.      12.1 The Ghostscript Windows redirector
  129.      12.2 The pbm2ppa program
  130.      12.3 The pbm2l7k program
  131.  
  132.   13. How to print to a fax machine.
  133.      13.1 Using a faxmodem
  134.      13.2 Using the Remote Printing Service
  135.  
  136.   14. How to generate something worth printing.
  137.  
  138.      14.1 Markup languages
  139.      14.2 WYSIWYG Word Processors
  140.  
  141.   15. On-screen previewing of printable things.
  142.  
  143.      15.1 PostScript
  144.      15.2 TeX dvi
  145.      15.3 Adobe PDF
  146.  
  147.   16. Serial printers under lpd
  148.  
  149.      16.1 Setting up in printcap
  150.      16.2 Older serial printers that drop characters
  151.  
  152.   17. Credits
  153.  
  154.  
  155.  
  156.   ______________________________________________________________________
  157.  
  158.   1.  Introduction
  159.  
  160.   The Printing HOWTO should contain everything you need to know to help
  161.   you set up printing services on your Linux box(en).  As life would
  162.   have it, it's a bit more complicated than in the point-and-click world
  163.   of Microsoft and Apple, but it's also a bit more flexible and
  164.   certainly easier to administer for large LANs.
  165.  
  166.   This document is structured so that most people will only need to read
  167.   the first half or so.  Most of the more obscure and situation-
  168.   dependant information in here is in the last half, and can be easily
  169.   located in the Table of Contents, whereas most of the information
  170.   through section 9 or 10 is probably needed by most people.
  171.  
  172.   Since version 3.x is a complete rewrite, much information from
  173.   previous editions has been lost.  This is by design, as the previous
  174.   HOWTOs were so large as to be 60 typeset pages, and had the narrative
  175.   flow of a dead turtle.  If you do not find the answer here, you are
  176.   encouraged to a) scan the previous version at the Printing HOWTO Home
  177.   Page <http://www.picante.com/~gtaylor/pht/> and b) drop me a note
  178.   saying what ought to be here but isn't.
  179.  
  180.   The Printing HOWTO Home Page <http://www.picante.com/~gtaylor/pht/> is
  181.   a good place to find the latest version; it is also, of course,
  182.   distributed from Metalab (metalab.unc.edu) and your friendly local LDP
  183.   mirror.
  184.  
  185.  
  186.   1.1.  History
  187.  
  188.   This is the third generation, which is to say the third complete
  189.   rewrite, of the Printing HOWTO.  The history of the PHT may be
  190.   chronicled thusly:
  191.  
  192.   1. I wrote the printing-howto in 1992 in response to too many printing
  193.      questions in comp.os.linux, and posted it.  This predated the HOWTO
  194.      project by a few months and was the first FAQlet called a `howto'.
  195.      This edition was in plain ascii.
  196.  
  197.   2. After joining the HOWTO project, the Printing-HOWTO was merged with
  198.      an Lpd FAQ by Brian McCauley <B.A.McCauley@bham.ac.uk>; we
  199.      continued to co-author the PHT for two years or so.  At some point
  200.      we incorporated the work of Karl Auer <Karl.Auer@anu.edu.au>.  This
  201.      generation of the PHT was in TeXinfo, and available in PS, HTML,
  202.      Ascii, and Info.
  203.  
  204.   3. After letting the PHT rot and decay for over a year, and an
  205.      unsuccessful attempt at getting someone else to maintain it, this
  206.      rewrite happened.  This generation of the PHT is written in SGML
  207.      using the LinuxDoc DTD and the SGML-Tools-1 package.  Beginning
  208.      with version 3.27, it incorporates a summary of a companion printer
  209.      support database; before 3.27 there was never a printer
  210.      compatability list in this HOWTO (!).
  211.  
  212.   1.2.  Copyright
  213.  
  214.   This document is Copyright (c) 1992-1999 by Grant Taylor.  Feel free
  215.   to copy and redistribute this document according to the terms of the
  216.   GNU General Public License, revision 2 or later.
  217.  
  218.  
  219.   2.  How to print
  220.  
  221.   If you've already got lpd setup to print to your printer, or your
  222.   system administrator already did so, or your vendor did so for you,
  223.   then all you need to do is learn how to use the lpr command.  The
  224.   Printing Usage HOWTO <http://metalab.unc.edu/LDP/HOWTO/Printing-Usage-
  225.   HOWTO.html> covers this, and a few other queue manipulation commands
  226.   you should probably know.
  227.  
  228.   If, however, you have a new system or new printer, then you'll have to
  229.   set up printing services one way or another before you can print.
  230.   Read on!
  231.  
  232.  
  233.   3.  Kernel printer devices
  234.  
  235.   There are two completely different device drivers for the parallel
  236.   port; which one you are using depends on your kernel version.  The
  237.   driver changed in Linux 2.1.33.
  238.  
  239.   A few details are the same for both styles of driver.  Most notably,
  240.   many people have found that Linux will not detect their parallel port
  241.   unless they disable "Plug and Play" in their PC BIOS.  (This is no
  242.   surprise; the track record for PnP of non-PCI devices with Windows and
  243.   elsewhere has been something of a disaster).
  244.  
  245.  
  246.   3.1.  The lp device (kernels <=2.1.32)
  247.  
  248.   The Linux kernel (<=2.1.32), assuming you have compiled in or loaded
  249.   the lp device (the output of cat /proc/devices should include the
  250.   device lp if it is loaded), provides one or more of /dev/lp0,
  251.   /dev/lp1, and /dev/lp2.  These are NOT assigned dynamically, rather,
  252.   each corresponds to a specific hardware I/O address.  This means that
  253.   your first printer may be lp0 or lp1 depending on your hardware.  Just
  254.   try both.
  255.  
  256.   A few users have reported that their bidirectional lp ports aren't
  257.   detected if they use an older unidirectional printer cable.  Check
  258.   that you've got a decent cable.
  259.  
  260.   One cannot run the plip and lp drivers at the same time on any given
  261.   port (under 2.0, anyway).  You can, however, have one or the other
  262.   driver loaded at any given time either manually, or by kerneld with
  263.   version 2.x (and later 1.3.x) kernels.  By carefully setting the
  264.   interrupts and such, you can supposedly run plip on one port and lp on
  265.   the other.  One person did so by editing the drivers; I eagerly await
  266.   a success report of someone doing so with only a clever command line.
  267.  
  268.   There is a little utility called tunelp floating about with which you,
  269.   as root, can tune the Linux 2.0 lp device's interrupt usage, polling
  270.   rate, and other options.
  271.  
  272.   When the lp driver is built into the kernel, the kernel will accept an
  273.   lp= option to set interrupts and io addresses:
  274.  
  275.  
  276.        When the lp driver is built in to the kernel, you may use the
  277.        LILO/LOADLIN command line to set the port addresses and interrupts
  278.        that the driver will use.
  279.  
  280.        Syntax:      lp=port0[,irq0[,port1[,irq1[,port2[,irq2]]]]]
  281.  
  282.        For example:   lp=0x378,0   or   lp=0x278,5,0x378,7 **
  283.  
  284.        Note that if this feature is used, you must specify *all* the ports
  285.        you want considered, there are no defaults.  You can disable a
  286.        built-in driver with lp=0.
  287.  
  288.  
  289.  
  290.  
  291.   When loaded as a module, it is possible to specify io addresses and
  292.   interrupt lines on the insmod command line (or in /etc/conf.modules so
  293.   as to affect kerneld) using the usual module argument syntax.  The
  294.   parameters are io=port0,port1,port2 and irq=irq0,irq1,irq2.  Read ye
  295.   the man page for insmod for more information on this.
  296.  
  297.  
  298.   **For those of you who (like me) can never find the standard port
  299.   numbers when you need them, they are as in the second example above.
  300.   The other port (lp0) is at 0x3bc.  I've no idea what interrupt it
  301.   usually uses.
  302.  
  303.  
  304.   The source code for the Linux 2.0 parallel port driver is in
  305.   /usr/src/linux/drivers/char/lp.c.
  306.  
  307.  
  308.   3.2.  The parport device (kernels >= 2.1.33)
  309.  
  310.   Beginning with kernel 2.1.33 (and available as a patch for kernel
  311.   2.0.30), the lp device is merely a client of the new parport device.
  312.   The addition of the parport device corrects a number of the problems
  313.   that plague the old lp device driver - it can share the port with
  314.   other drivers, it dynamically assigns available parallel ports to
  315.   device numbers rather than enforcing a fixed correspondence between
  316.   I/O addresses and port numbers, and so forth.
  317.  
  318.   The advent of the parport device has enabled a whole flock of new
  319.   parallel-port drivers for things like Zip drives, Backpack CD-ROMs and
  320.   disks, and so forth.  Some of these are also available in versions for
  321.   2.0 kernels; look around on the web.
  322.  
  323.   The main difference that you will notice, so far as printing goes, is
  324.   that parport-based kernels dynamically assign lp devices to parallel
  325.   ports.  So what was lp1 under Linux 2.0 may well be lp0 under Linux
  326.   2.2.  Be sure to check this if you upgrade from an lp-driver kernel to
  327.   a parport-driver kernel.
  328.  
  329.   I'll cover the parport driver more completely when I find myself using
  330.   one, but in the meantime you can read the file
  331.   Documentation/parport.txt in your kernel sources, or look at the
  332.   parport web site <http://www.cyberelk.demon.co.uk/parport.html>.
  333.  
  334.  
  335.  
  336.   3.3.  Serial devices
  337.  
  338.   Serial devices are usually called something like /dev/ttyS1 under
  339.   Linux.  The utility stty will allow you to interactively view or set
  340.   the settings for a serial port; setserial will allow you to control a
  341.   few extended attributes and configure IRQs and I/O addresses for non-
  342.   standard ports.  Further discussion of serial ports under Linux may be
  343.   found in the Serial-HOWTO <http://metalab.unc.edu/mdw/HOWTO/Serial-
  344.   HOWTO.html>.
  345.  
  346.  
  347.   When using a slow serial printer with flow control, you may find that
  348.   some of your print jobs get truncated.  This may be due to the serial
  349.   port, whose default behavior is to purge any untransmitted characters
  350.   from its buffer 30 seconds after the port device is closed.  The
  351.   buffer can hold up to 4096 characters, and if your printer uses flow
  352.   control and is slow enough that it can't accept all the data from the
  353.   buffer within 30 seconds after printing software has closed the serial
  354.   port, the tail end of the buffer's contents will be lost.  If the
  355.   command cat file > /dev/ttyS2 produces complete printouts for short
  356.   files but truncated ones for longer files, you may have this
  357.   condition.
  358.  
  359.  
  360.   The 30 second interval can be adjusted through the "closing_wait"
  361.   commandline option of setserial (version 2.12 and later).  A machine's
  362.   serial ports are usually initialized by a call to setserial in the
  363.   rc.serial boot file.  The call for the printing serial port can be
  364.   modified to set the closing_wait at the same time as it sets that
  365.   port's other parameters.
  366.  
  367.  
  368.  
  369.   4.  Supported Printers
  370.  
  371.   The Linux kernel mostly supports any printer that you can plug into a
  372.   serial or parallel port, but there are things to look out for, and
  373.   printers that you won't be able to use, even though they can
  374.   (electrically speaking) communicate with Linux.  Primary among these
  375.   incompatible printers are those referred to as "Windows" or "GDI"
  376.   printers.  They are called this because part or all of the printer
  377.   control language and the design details of the printing mechanism are
  378.   not documented.  Typically the vendor will provide a Windows driver
  379.   and happily sell only to Windows users; this is why they are called
  380.   Winprinters.  In some cases the vendor also provides drivers for NT,
  381.   OS/2, or other operating systems.
  382.  
  383.   Many of these printers do not work with Linux.  A few of them do, and
  384.   some of them only work a little bit (usually because someone has
  385.   reverse engineered the details needed to write a driver).  See the
  386.   printer support list below for details on specific printers.
  387.  
  388.   A few printers are in-between.  Some of NEC's models, for example,
  389.   implement a simple form of the standard printer language PCL that
  390.   allows PCL-speaking software to print at up to 300dpi, but only NEC
  391.   knows how to get the full 600dpi out of these printers.
  392.  
  393.   Note that if you already have one of these Winprinters, there are
  394.   roundabout ways to get Linux to print to one, but they're rather
  395.   awkward and I've never tried it myself.  See Section 12 of this
  396.   document for more discussion of Windows-only printers.
  397.   4.1.  Postscript
  398.  
  399.   As for what printers do work with Linux, the best choice is to buy a
  400.   printer with native PostScript support.  Nearly all Unix software that
  401.   produces printable output produces it in PostScript, so obviously it'd
  402.   be nice to get a printer that supports PostScript directly.
  403.   Unfortunately, PostScript support is scarce outside the laser printer
  404.   domain, and is sometimes a costly add-on.
  405.  
  406.  
  407.   Unix software, and the publishing industry in general, have
  408.   standardized upon Postscript as the printer control language of
  409.   choice.  This happened for several reasons:
  410.  
  411.      Timing
  412.         Postscript arrived as part of the Apple Laserwriter, a perfect
  413.         companion to the Macintosh, the system largely responsible for
  414.         the desktop publishing revolution of the 80s.
  415.  
  416.      It's device-independant
  417.         Postscript programs can be run to generate output on a pixel
  418.         screen, a vector screen, a fax machine, or almost any sort of
  419.         printer mechanism, without the original program needing to be
  420.         changed.  Postscript output will look the same on any Postscript
  421.         device, at least within the limits of the device's capabilities.
  422.         Before the creation of PDF, people exchanged complex documents
  423.         online as Postscript files.  The only reason this standard
  424.         didn't "stick" was because Windows machines didn't usually
  425.         include a Postscript previewer, so Adobe specified hyperlinks
  426.         and compression for Postscript, called the result PDF,
  427.         distributed previewers for it, and invented a market for their
  428.         "distiller" tools (the functionality of which is also provided
  429.         by ghostscript's ps2pdf and pdf2ps programs).
  430.  
  431.      It's a real programming language
  432.         Postscript is a complete programming language; you can write
  433.         software to do most anything in it.  This is mostly useful for
  434.         defining subroutines at the start of your program to reproduce
  435.         complex things over and over throughout your document, like a
  436.         logo or a big "DRAFT" in the background.
  437.  
  438.      It's open
  439.         Postscript is fully specified in a publically available series
  440.         of books (which you can find at any good bookstore).  Although
  441.         Adobe invented it and provides the dominant commercial
  442.         implementation, other vendors like Aladdin produce independantly
  443.         coded implementations as well.
  444.  
  445.  
  446.  
  447.   4.2.  Non-Postscript
  448.  
  449.   Failing the (larger) budget necessary to buy a Postscript printer, you
  450.   can use any printer supported by Ghostscript, the free Postscript
  451.   interpreter used in lieu of actual printer Postscript support.  The
  452.   Ghostscript Home Page <http://www.cs.wisc.edu/~ghost/> has a list of
  453.   supported printers and information on the status of new and
  454.   experimental drivers.  Note that this page lists supported printers in
  455.   the latest version of Ghostscript, while most Linux distributions can
  456.   only ship a somewhat outdated version of Ghostscript due to the
  457.   license.  Fortunately, there is usually a prepackaged up to date
  458.   Ghostscript made available in each distribution's contrib area.
  459.   Please help improve the Ghostscript printer support page by reporting
  460.   your successes and failures as it asks.
  461.  
  462.  
  463.   Adobe now has a new printer language called "PrintGear".  I think it's
  464.   a greatly simplified binary format language with some Postscript
  465.   heritage but no Postscript compatibility.  And I haven't heard of
  466.   Ghostscript supporting it.  But some PrintGear printers seem to
  467.   support another language like PCL, and these printers will work with
  468.   Linux (iff the PCL is implemented in the printer and not in a Windows
  469.   driver).
  470.  
  471.  
  472.   4.3.  What printers work?
  473.  
  474.   If you want to buy a printer, you can look in several places to see if
  475.   it will work.  The cooperatively maintained Printing HOWTO printer
  476.   database <http://www.picante.com/~gtaylor/pht/printer_list.cgi> aims
  477.   to be a comprehensive listing of the state of Linux printer support.
  478.   A summary of it is below; be sure to check online for more details and
  479.   information on what driver to use.
  480.  
  481.  
  482.   Ghostscript's printer compatibility page
  483.   <http://www.cs.wisc.edu/~ghost/printer.html> has a list of some
  484.   working printers, as well as links to other pages.  And Dejanews
  485.   contains hundreds of "it works" and "it doesn't work" testimonials.
  486.   Try all three, and when you're done, check that your printer is
  487.   present and correct in the database
  488.   <http://www.picante.com/~gtaylor/pht/printer_list.cgi>, so that it
  489.   will be listed properly in this document in the future.
  490.  
  491.  
  492.   4.3.1.  Printer compatibility list
  493.  
  494.   This section is a summary of the online version.  The online version
  495.   includes basic specifications, notes, links to driver information,
  496.   user-maintained documentation, manufacturer web pages, and so forth.
  497.   The online version of this list is also interactive; people can and do
  498.   add printers all the time, so be sure to check it as well.  Finally,
  499.   if your printer isn't listed, add it!
  500.  
  501.  
  502.   Printers here are categorized into three types:
  503.  
  504.      Perfectly
  505.         Perfect printers work perfectly - you can print to the full
  506.         ability of the printer, including color, full resolution, etc.
  507.         In a few cases printers with undocumented "resolution
  508.         enhancement" modes that don't work are listed as perfect;
  509.         generally the difference in print quality is small enough that
  510.         it isn't worth worrying about.
  511.  
  512.      Mostly
  513.         You can print fine, but there may be minor limitations or one
  514.         sort or another in either printing or other features.
  515.  
  516.      Partially
  517.         You can print, but maybe not in color, or only at a poor
  518.         resolution.  See the online listing's notes column for
  519.         information on the limitation.
  520.  
  521.      Paperweight
  522.         You can't print a darned thing; typically this will be due to
  523.         lack of a driver and/or documentation on how to write one.
  524.  
  525.   In all cases, since this information is provided by dozens of people,
  526.   none of it is guaranteed to be correct.  It should, however, be easy
  527.   to corroborate from the driver web pages and manufacturer web sites.
  528.  
  529.   And without further ado, here is the printer compatability list:
  530.  
  531.      Brother
  532.  
  533.         Perfectly
  534.            HL-10V, HL-660, HL-720, HL-760.
  535.  
  536.         Mostly
  537.            HL-1050.
  538.  
  539.      Canon
  540.  
  541.         Perfectly
  542.            BJ-10e, BJ-20, BJ-200, BJC-210, BJC-240, BJC-250, BJC-610,
  543.            BJC-620, BJC-70, BJC-800, LBP-8II, LIPS-III.
  544.  
  545.         Mostly
  546.            BJ-300, BJC-4000, BJC-4100, BJC-4200, BJC-4300, BJC-4400,
  547.            BJC-7000, BJC-7004.
  548.  
  549.         Partially
  550.            BJC-4550, MultiPASS C2500, MultiPASS C3500.
  551.  
  552.         Paperweight
  553.            BJC-5000, LBP-460, LBP-660.
  554.  
  555.      Epson
  556.  
  557.         Perfectly
  558.            ActionLaser 1100, LP 8000, LQ 850, Stylus Color, Stylus Color
  559.            400, Stylus Color 500, Stylus Color 600, Stylus Color 640,
  560.            Stylus Color 850, Stylus Color II, Stylus Color IIs, Stylus
  561.            Pro XL.
  562.  
  563.         Mostly
  564.            Stylus Color 800, Stylus Photo 750.
  565.  
  566.         Partially
  567.            Stylus Color 740.
  568.  
  569.      HP
  570.  
  571.         Perfectly
  572.            2000Cse, 2500C, DesignJet 650C, DeskJet 1200C, DeskJet 1600C,
  573.            DeskJet 1600Cm, DeskJet 400, DeskJet 420C, DeskJet 500,
  574.            DeskJet 550C, DeskJet 600, DeskJet 660Cse, DeskJet 690C,
  575.            DeskJet 850C, DeskJet 855C, DeskJet 870, DeskJet 870Cxi,
  576.            DeskJet 890, LaserJet 1100, LaserJet 2100, LaserJet 2100M,
  577.            LaserJet 4000N, LaserJet 4L, LaserJet 5, LaserJet 5L,
  578.            LaserJet 5MP, LaserJet 6L, LaserJet 6MP, LaserJet 8000,
  579.            LaserJet 8100, Laserjet 5000, Mopier 320, PaintJet XL300.
  580.  
  581.         Mostly
  582.            HP 660C.
  583.  
  584.         Partially
  585.            DeskJet 1000C, DeskJet 670C, DeskJet 710, DeskJet 720C,
  586.            DeskJet 722C, DeskJet 820C.
  587.  
  588.         Paperweight
  589.            LaserJet 3100.
  590.  
  591.      IBM
  592.  
  593.         Perfectly
  594.            Jetprinter 3852.
  595.      Lexmark
  596.  
  597.         Perfectly
  598.            Optra Color 1200, Optra Color 1275, Optra Color 40, Optra
  599.            Color 45, Optra E, Optra E+, Optra Ep, Optra S 1250.
  600.  
  601.         Partially
  602.            1020 Business, 3000, 5700, 7000.
  603.  
  604.         Paperweight
  605.            1000, 1020, 1100, 2030, 2050, 2070, 5000, 7200, Winwriter
  606.            100, Winwriter 150c, Winwriter 200.
  607.  
  608.      Minolta
  609.  
  610.         Perfectly
  611.            PagePro 6, PagePro 8.
  612.  
  613.      NEC
  614.  
  615.         Perfectly
  616.            P2X.
  617.  
  618.         Partially
  619.            SuperScript 100C, SuperScript 1260, SuperScript 150C,
  620.            SuperScript 650C, SuperScript 750C, SuperScript 860,
  621.            SuperScript 870.
  622.  
  623.         Paperweight
  624.            SuperScript 660i, SuperScript 660plus.
  625.  
  626.      Okidata
  627.  
  628.         Perfectly
  629.            OL 410e, OL 610e/PS, OL 810e/PS, Okipage 6e, Okipage 6ex,
  630.            Okipage 8c.
  631.  
  632.         Mostly
  633.            Okipage 4w.
  634.  
  635.         Paperweight
  636.            Okipage 8w, okijet 2010.
  637.  
  638.      Olivetti
  639.  
  640.         Perfectly
  641.            JP350S.
  642.  
  643.      Panasonic
  644.  
  645.         Perfectly
  646.            KX-P1123, KX-P4440, KX-P5400, KX-P8420, KX-P8475.
  647.  
  648.         Partially
  649.            KX-P6500.
  650.  
  651.         Paperweight
  652.            KX-P6100, KX-P8410.
  653.  
  654.      QMS
  655.  
  656.         Perfectly
  657.            2425 Turbo EX.
  658.  
  659.      Ricoh
  660.  
  661.         Perfectly
  662.            4801, 6000.
  663.  
  664.      Xerox
  665.  
  666.         Perfectly
  667.            DocuPrint C55, DocuPrint N17, DocuPrint N32.
  668.  
  669.  
  670.  
  671.   5.  Which spooling software?
  672.  
  673.   Until recently, the choice for Linux users was simple - everyone ran
  674.   the same old lpd lifted mostly verbatim out of BSD's Net-2 code.  Even
  675.   today, most vendors ship this software.  But this is beginning to
  676.   change.  SVR4-like systems including Sun's Solaris come with a
  677.   completely different print spooling package, centered around lpsched.
  678.   And there are signs that some Linux vendors will shift to providing
  679.   LPRng, a far less ancient print spooling implementation that is freely
  680.   available.  LPRng is far easier to administer for large installations
  681.   (read: more than one printer, any serial printers, or any peculiar
  682.   non-lpd network printers) and has a less frightfully haphazard
  683.   codebase than does stock lpd.  It can even honestly claim to be secure
  684.   - there are no SUID binaries, and it supports authentication via PGP
  685.   or Kerberos.
  686.  
  687.  
  688.   For the moment, even in light of the new options, lpd is probably fine
  689.   for most Linux users.  While it isn't the snazziest system, it works
  690.   fine once set up, and it is well understood and extensively documented
  691.   in third-party Unix books.
  692.  
  693.  
  694.   If you'd like more information on LPRng, check out the LPRng Web Page
  695.   <http://www.astart.com/lprng/LPRng.html>.  Future versions of this
  696.   HOWTO will include information on using both LPRng and regular lpd.
  697.  
  698.  
  699.   6.  How it works, basic
  700.  
  701.  
  702.   In order to get printing working well, you need to understand how the
  703.   lpd system works.
  704.  
  705.   Lpd stands for Line Printer Daemon, and refers in different contexts
  706.   to both the daemon and the whole collection of programs which run
  707.   print spooling.  These are:
  708.  
  709.  
  710.      lpd
  711.         The spooling daemon.  One of these runs to control everything on
  712.         a machine, AND one is run per printer while the printer is
  713.         printing.
  714.  
  715.      lpr
  716.         The user spooling command.  Lpr contacts lpd and injects a new
  717.         print job into the spool.
  718.  
  719.      lpq
  720.         Lists the jobs in a print queue.
  721.  
  722.      lpc
  723.         The Lpd system control command.  With lpc you can stop, start,
  724.         reorder, etc, the print queues.
  725.  
  726.  
  727.      lprm
  728.         lprm will remove a job from the print spool.
  729.  
  730.   So how does it fit together?  Well, when the system boots, lpd is run.
  731.   It scans the file /etc/printcap to learn which printers it will be
  732.   managing spools for.  Each time someone runs lpr, lpr contacts lpd
  733.   through the named socket /dev/printer, and feeds lpd both the file to
  734.   print and some information about who is printing and how to print it.
  735.   Lpd then prints the file on the appropriate printer in turn.
  736.  
  737.   The lp system was originally designed when most printers were line
  738.   printers - that is, people mostly printed plain ascii.  As it turns
  739.   out, only a little extra scripting is needed to make lpd work quite
  740.   well for today's print jobs, which are often in PostScript, or text,
  741.   or dvi, or...
  742.  
  743.  
  744.   7.  How to set things up, basic
  745.  
  746.   7.1.  Traditional lpd configuration
  747.  
  748.   The minimal setup for lpd rsults in a system that can queue files and
  749.   print them.  It will not pay any attention to wether or not your
  750.   printer will understand them, and will probably not let you produce
  751.   attractive output.  Nevertheless, it is the first step to
  752.   understanding, so read on!
  753.  
  754.   Basically, to add a print queue to lpd, you must add an entry in
  755.   /etc/printcap, and make the new spool directory under /var/spool/lpd.
  756.  
  757.   An entry in /etc/printcap looks like:
  758.  
  759.  
  760.        # LOCAL djet500
  761.        lp|dj|deskjet:\
  762.                :sd=/var/spool/lpd/dj:\
  763.                :mx#0:\
  764.                :lp=/dev/lp0:\
  765.                :sh:
  766.  
  767.  
  768.  
  769.  
  770.   This defines a spool called lp, dj, or deskjet, spooled in the direc¡
  771.   tory /var/spool/lpd/dj, with no per-job maximum size limit, which
  772.   prints to the device /dev/lp0, and which does not have a banner page
  773.   (with the name of the person who printed, etc) added to the front of
  774.   the print job.
  775.  
  776.   Go now and read the man page for printcap.
  777.  
  778.   The above looks very simple, but there a catch - unless I send in
  779.   files a DeskJet 500 can understand, this DeskJet will print strange
  780.   things.  For example, sending an ordinary Unix text file to a deskjet
  781.   results in literally interpreted newlines, and gets me:
  782.  
  783.  
  784.        This is line one.
  785.                         This is line two.
  786.                                          This is line three.
  787.  
  788.  
  789.  
  790.  
  791.   ad nauseam.  Printing a PostScript file to this spool would get a
  792.   beautiful listing of the PostScript commands, printed out with this
  793.   "staircase effect", but no useful output.
  794.  
  795.   Clearly more is needed, and this is the purpose of filtering.  The
  796.   more observant of you who read the printcap man page might have
  797.   noticed the spool attributes if and of.  Well, if, or the input
  798.   filter, is just what we need here.
  799.  
  800.   If we write a small shell script called filter that adds carriage
  801.   returns before newlines, the staircasing can be eliminated.  So we
  802.   have to add in an if line to our printcap entry above:
  803.  
  804.  
  805.        lp|dj|deskjet:\
  806.                :sd=/var/spool/lpd/dj:\
  807.                :mx#0:\
  808.                :lp=/dev/lp0:\
  809.                :if=/var/spool/lpd/dj/filter:\
  810.                :sh:
  811.  
  812.  
  813.  
  814.  
  815.   A simple filter script might be:
  816.  
  817.  
  818.        #!perl
  819.        # The above line should really have the whole path to perl
  820.        # This script must be executable: chmod 755 filter
  821.        while(<STDIN>){chop $_; print "$_\r\n";};
  822.        # You might also want to end with a form feed: print "\f";
  823.  
  824.  
  825.  
  826.  
  827.   If we were to do the above, we'd have a spool to which we could print
  828.   regular Unix text files and get meaningful results.  (Yes, there are
  829.   four million better ways to write this filter, but few so illustra¡
  830.   tive.  You are encouraged to do this more efficiently.)
  831.  
  832.   The only remaining problem is that printing plain text is really not
  833.   too hot - surely it would be better to be able to print PostScript and
  834.   other formatted or graphic types of output.  Well, yes, it would, and
  835.   it's easy to do.  The method is simply an extention of the above
  836.   linefeed-fixing filter.  If you write a filter than can accept
  837.   arbitrary file types as input and produce DeskJet-kosher output for
  838.   each case, then you've got a clever print spooler indeed!
  839.  
  840.   Such a filter is called a magic filter.  Don't bother writing one
  841.   yourself unless you print strange things - there are a good many
  842.   written for you already on the net.  APS Filter is among the best, or
  843.   your Linux distribution may have a printer setup tool that makes this
  844.   all really easy.
  845.  
  846.  
  847.   7.2.  File Permissions
  848.  
  849.   By popular demand, I include below a listing of the permissions on
  850.   interesting files on my system.  There are a number of better ways to
  851.   do this, ideally using only SGID binaries and not making everything
  852.   SUID root, but this is how my system came out of the box, and it works
  853.   for me.  (Quite frankly, if your vendor can't even ship a working lpd
  854.   you're in for a rough ride).
  855.  
  856.  
  857.  
  858.  
  859.   -r-sr-sr-x   1 root     lp    /usr/bin/lpr*
  860.   -r-sr-sr-x   1 root     lp    /usr/bin/lprm*
  861.   -rwxr--r--   1 root     root  /usr/sbin/lpd*
  862.   -r-xr-sr-x   1 root     lp    /usr/sbin/lpc*
  863.   drwxrwxr-x   4 root     lp    /var/spool/lpd/
  864.   drwxr-xr-x   2 root     lp    /var/spool/lpd/lp/
  865.  
  866.  
  867.  
  868.  
  869.   Lpd must currently be run as root so that it can bind to the low-
  870.   numbered lp service port.  It should probably become UID lp.lp or
  871.   something after binding, but I don't think it does.  Bummer.
  872.  
  873.  
  874.   8.  Getting Printing Software
  875.  
  876.   Many prewritten filter packages (and other printer-related software)
  877.   are available from Metalab
  878.   <ftp://metalab.unc.edu/pub/Linux/system/printing/>.  Such utilities as
  879.   psutils, a2ps, mpage, dvitodvi, flpr, etc can all be found there.
  880.  
  881.  
  882.   For a while, there were several packages out there all trying to make
  883.   printer configuration easier.  They probably all still exist, but one
  884.   of the best and most up-to-date is Andreas Klemm's APS Filter package,
  885.   which has a menu-driven printcap configurator and handles practically
  886.   any type of input imaginable.  If your vendor doesn't ship a nice
  887.   printer setup tool, APS Filter is the way to go.
  888.  
  889.  
  890.   9.  Vendor Solutions
  891.  
  892.   This section is, by definition, incomplete.  Feel free to send in
  893.   details of your favourite distribution.
  894.  
  895.  
  896.   9.1.  Red Hat
  897.  
  898.   Red Hat has a GUI printer administration tool (in the control panel)
  899.   which can add remote printers and printers on local devices.  It lets
  900.   you choose a ghostscript-supported printer type and Unix device file
  901.   to print to, then installs a print queue in /etc/printcap and writes a
  902.   short PostScript-and-ascii magic filter based around gs and nenscript.
  903.   This solution works fairly well, and is trivial to setup for common
  904.   cases.
  905.  
  906.   Where Red Hat fails is when you have a printer which isn't supported
  907.   by their standard Ghostscript (which is GNU rather than Aladdin
  908.   Ghostscript, and which supports fewer printers).  Check in the printer
  909.   compatibility list above (or online
  910.   <http://www.picante.com/~gtaylor/pht/printer_list.cgi>) if you find
  911.   that you can't print properly with the stock Red Hat software.  If
  912.   your printer isn't supported by Red Hat's tools, you may need to
  913.   install a contributed verison of Aladdin Ghostscript, and will
  914.   probably also be better off if you use the apsfilter package, which
  915.   knows all about the printers supported by late-model Ghostscripts.
  916.  
  917.  
  918.   9.2.  Debian
  919.  
  920.   Debian offers a choice between plain lpd and LPRng; LPRng is probably
  921.   a better choice.  I believe Debian also offers a choice of printer
  922.   configuration tools; apsfilter version 5 or later is probably your
  923.   best bet, since that verison adds support for LPRng and Ghostscript's
  924.   uniprint driver scheme.
  925.   9.3.  Other Distributions
  926.  
  927.   Please send me info on what other distributions do!
  928.  
  929.  
  930.   10.  Ghostscript.
  931.  
  932.   Ghostscript is an incredibly significant program for Linux printing.
  933.   Most printing software under Unix generates PostScript, which is
  934.   typically a $100 option on a printer.  Ghostscript, however, is free,
  935.   and will generate the language of your printer from PostScript.  When
  936.   tied in with your lpd input filter, it gives you a virtual PostScript
  937.   printer and simplifies life immensely.
  938.  
  939.   Ghostscript is available in two forms.  The commercial version of
  940.   Ghostscript, called Aladdin Ghostscript, may be used freely for
  941.   personal use but may not be distributed by commercial Linux
  942.   distributions.  It is generally a year or so ahead of the free
  943.   Ghostscript; at the moment, for example, it supports many color
  944.   inkjets that the older Ghostscripts do not.
  945.  
  946.   The free version of Ghostscript is GNU Ghostscript, and is simply an
  947.   aged version of Aladdin ghostscript kindly given to GNU.  (Kudos to
  948.   Aladdin for this arrangement; more software vendors should support
  949.   free software in this way, if they can't handle full-blown GPL
  950.   distribution of their code).
  951.  
  952.   Whatever you do with gs, be very sure to run it with the option for
  953.   disabling file access (-dSAFER).  PostScript is a fully functional
  954.   language, and a bad PostScript program could give you quite a
  955.   headache.
  956.  
  957.   Speaking of PDF, Adobe's Portable Document Format is actually little
  958.   more than organized PostScript in a compressed file.  Ghostscript can
  959.   handle PDF input just as it does PostScript.  So you can be the first
  960.   on your block with a PDF-capable printer.
  961.  
  962.   10.1.  Invoking Ghostscript
  963.  
  964.   Typically, Ghostscript will be run by whatever magic filter you settle
  965.   upon (I recommend apsfilter if your vendor didn't supply anything that
  966.   suits you), but for debugging purposes it's often handy to run it
  967.   directly.
  968.  
  969.   gs -help will give a brief informative listing of options and
  970.   available drivers (note that this list is the list of drivers compiled
  971.   in, not the master list of all available drivers).
  972.  
  973.   You might run gs for testing purposes like: gs options -q -dSAFER
  974.   -sOutputFile=/dev/lp1 test.ps.
  975.  
  976.  
  977.   10.2.  Ghostscript output tuning
  978.  
  979.   There are a number of things one can do if gs's output is not
  980.   satisfactory (actually, you can do anything you darn well please,
  981.   since you have the source).
  982.  
  983.  
  984.   10.2.1.  Output location and size
  985.  
  986.   The location, size, and aspect ratio of the image on a page is
  987.   controlled by the printer-specific driver in ghostscript.  If you find
  988.   that your pages are coming out scrunched too short, or too long, or
  989.   too big by a factor of two, you might want to look in your driver's
  990.   source module and adjust whatever parameters jump out at you.
  991.   Unfortunately, each driver is different, so I can't really tell you
  992.   what to adjust, but most of them are reasonably well commented.
  993.  
  994.  
  995.   10.2.2.  Gamma, dotsizes, etc.
  996.  
  997.   Most non-laser printers suffer from the fact that their dots are
  998.   rather large. This results in pictures coming out too dark. If you
  999.   experience this problem you should use your own transfer function.
  1000.   Simply create the following file in the ghostscript lib-dir and add
  1001.   its name to the gs call just before the actual file. You may need to
  1002.   tweak the actual values to fit your printer. Lower values result in a
  1003.   brighter print.  Especially if your driver uses a Floyd-Steinberg
  1004.   algorithm to rasterize colors, lower values ( 0.2 - 0.15 ) are
  1005.   probably a good choice.
  1006.  
  1007.  
  1008.  
  1009.        ---8<---- gamma.ps ----8<---
  1010.        %!
  1011.        %transfer functions for cyan magenta yellow black
  1012.        {0.3 exp} {0.3 exp} {0.3 exp} {0.3 exp} setcolortransfer
  1013.        ---8<------------------8<---
  1014.  
  1015.  
  1016.  
  1017.  
  1018.  
  1019.   It is also possible to mend printers that have some kind of colour
  1020.   fault by tweaking these values. If you do that kind of thing, I
  1021.   recommend using the file colorcir.ps, that comes with ghostscript (in
  1022.   the examples/ subdir), as a test page.
  1023.  
  1024.  
  1025.   For many of the newer color inkjet drivers, there are command-line
  1026.   options, or different upp driver files, which implement gamma and
  1027.   other changes to adapt the printer to different paper types.  You
  1028.   sould look into this before playing with Postscript to fix things.
  1029.  
  1030.  
  1031.   11.  How to print to a printer over the network
  1032.  
  1033.   One of the features of lpd is that it supports printing over the
  1034.   network to printers physically connected to a different machine.  With
  1035.   the careful combination of filter scripts and assorted utilities, you
  1036.   can make lpr print transparently to printers on all sorts of networks.
  1037.  
  1038.  
  1039.   11.1.  To a Unix/lpd host
  1040.  
  1041.   To allow remote machines to print to your printer, you must list the
  1042.   machines in /etc/hosts.equiv or /etc/hosts.lpd.  (Note that
  1043.   hosts.equiv has a host of other effects; be sure you know what you are
  1044.   doing if you list any machine there).  You can allow only certain
  1045.   users on the other machines to print to your printer by usign the rs
  1046.   attribute; read the lpd man page for information on this.
  1047.  
  1048.  
  1049.   11.1.1.  With lpd
  1050.  
  1051.   To print to another machine, you make an /etc/printcap entry like
  1052.   this:
  1053.  
  1054.  
  1055.  
  1056.  
  1057.   # REMOTE djet500
  1058.   lp|dj|deskjet:\
  1059.           :sd=/var/spool/lpd/dj:\
  1060.           :rm=machine.out.there.com:\
  1061.           :rp=printername:\
  1062.           :lp=/dev/null:\
  1063.           :sh:
  1064.  
  1065.  
  1066.  
  1067.  
  1068.   Note that there is still a spool directory on the local machine man¡
  1069.   aged by lpd.  If the remote machine is busy or offline, print jobs
  1070.   from the local machine wait in the spool area until they can be sent.
  1071.  
  1072.  
  1073.   11.1.2.  With rlpr
  1074.  
  1075.   You can also use rlpr to send a print job directly to a queue on a
  1076.   remote machine without going through the hassle of configuring lpd to
  1077.   handle it.  This is mostly useful in situations where you print to a
  1078.   variety of printers only occasionally.  From the announcement for
  1079.   rlpr:
  1080.  
  1081.  
  1082.   Rlpr uses TCP/IP to send print jobs to lpd servers anywhere on a
  1083.   network.
  1084.  
  1085.  
  1086.   Unlike lpr, it *does not* require that the remote printers be
  1087.   explicitly known to the machine you wish to print from, (e.g. through
  1088.   /etc/printcap) and thus is considerably more flexible and requires
  1089.   less administration.
  1090.  
  1091.  
  1092.   rlpr can be used anywhere a traditional lpr might be used, and is
  1093.   backwards compatible with traditional BSD lpr.
  1094.  
  1095.  
  1096.   The main power gained by rlpr is the power to print remotely *from
  1097.   anywhere to anywhere* without regard for how the system you wish to
  1098.   print from was configured.  Rlpr can work as a filter just like
  1099.   traditional lpr so that clients executing on a remote machine like
  1100.   netscape, xemacs, etc, etc can print to your local machine with little
  1101.   effort.
  1102.  
  1103.  
  1104.   Rlpr is available from Metalab
  1105.   <ftp://metalab.unc.edu/pub/Linux/system/printing/>.
  1106.  
  1107.  
  1108.   11.2.  To a Win95, WinNT, LanManager, or Samba printer
  1109.  
  1110.   There is a Printing to Windows mini-HOWTO out there which has more
  1111.   info than there is here.
  1112.  
  1113.   It is possible to direct an lpd queue through the smbclient program
  1114.   (part of the samba suite) to a TCP/IP based SMB print service.  Samba
  1115.   includes a script to do this called smbprint.  In short, you put a
  1116.   configuration file for the specific printer in question in the spool
  1117.   directory, and install the smbprint script as the if.
  1118.  
  1119.   The /etc/printcap entry goes like this:
  1120.  
  1121.  
  1122.  
  1123.   lp|remote-smbprinter:\
  1124.       :lp=/dev/null:sh:\
  1125.       :sd=/var/spool/lpd/lp:\
  1126.       :if=/usr/local/sbin/smbprint:
  1127.  
  1128.  
  1129.  
  1130.  
  1131.   You should read the documentation inside the smbprint script for more
  1132.   information on how to set this up.
  1133.  
  1134.   You can also use smbclient to submit a file directly to an SMB
  1135.   printing service without involving lpd.  See the man page.
  1136.  
  1137.  
  1138.   11.3.  To a NetWare Printer
  1139.  
  1140.   The ncpfs suite includes a utility called nprint which provides the
  1141.   same functionality as smbprint but for NetWare.  You can get ncpfs
  1142.   from Metalab.  From the LSM entry for version 0.16:
  1143.  
  1144.  
  1145.        With ncpfs you can mount volumes of your netware server
  1146.        under Linux. You can also print to netware print queues and
  1147.        spool netware print queues to the Linux printing system. You
  1148.        need kernel 1.2.x or 1.3.54 and above. ncpfs does NOT work
  1149.        with any 1.3.x kernel below 1.3.54.
  1150.  
  1151.  
  1152.  
  1153.   To make nprint work via lpd, you write a little shell script to print
  1154.   stdin on the NetWare printer, and install that as the if for an lpd
  1155.   print queue.  You'll get something like:
  1156.  
  1157.  
  1158.        sub2|remote-NWprinter:\
  1159.                :lp=/dev/null:sh:\
  1160.                :sd=/var/spool/lpd/sub2:\
  1161.                :if=/var/spool/lpd/nprint-script:
  1162.  
  1163.  
  1164.  
  1165.  
  1166.   The nprint-script might look approximately like:
  1167.  
  1168.  
  1169.        #! /bin/sh
  1170.        # You should try the guest account with no password first!
  1171.        /usr/local/bin/nprint -S net -U name -P passwd -q printq-name -
  1172.  
  1173.  
  1174.  
  1175.  
  1176.  
  1177.   11.4.  To an EtherTalk (Apple) printer
  1178.  
  1179.   The netatalk package includes something like nprint and smbclient.
  1180.   Others have documented the procedure for printing to and from an Apple
  1181.   network far better than I ever will; see the Linux Netatalk-HOWTO
  1182.   <http://thehamptons.com/anders/netatalk/>.
  1183.  
  1184.  
  1185.   11.5.  To an HP or other ethernet printer
  1186.  
  1187.   HPs and some other printers come with an ethernet interface which you
  1188.   can print to directly using lpd.  You should follow the instructions
  1189.   that came with your printer or its network adaptor, but in general,
  1190.   such printers are "running" lpd, and provide one or more queues which
  1191.   you can print to.  An HP, for example, might work with a printcap
  1192.   like:
  1193.  
  1194.  
  1195.        lj-5|remote-hplj:\
  1196.                :lp=/dev/null:sh:\
  1197.                :sd=/var/spool/lpd/lj-5:\
  1198.                :rm=printer.name.com:rp=raw:
  1199.  
  1200.  
  1201.  
  1202.  
  1203.   HP Laserjet printers with Jet Direct interfaces generally support two
  1204.   built in lpd queues - "raw" which accepts PCL (and possibly
  1205.   Postscript) and "text" which accepts straight ascii (and copes
  1206.   automatically with the staircase effect).  If you've got a JetDirect
  1207.   Plus3 three-port box, the queues are named "raw1", "text2", and so
  1208.   forth.
  1209.  
  1210.   Note that the ISS company has identified an assortment of denial of
  1211.   service attacks which hang HP Jetdirect interfaces.  Most of these
  1212.   have been addressed beginning in Fall 98.
  1213.  
  1214.   In a large scale environment, especially a large environment where
  1215.   some printers do not support PostScript, it may be useful to establish
  1216.   a dedicated print server to which all machines print and on which all
  1217.   ghostscript jobs are run.
  1218.  
  1219.   This also allows your Linux box to act as a spool server for the
  1220.   printer so that your network users can complete their print jobs
  1221.   quickly and get on with things without waiting for the printer to
  1222.   print any other job that someone else has sent.  This is suggested too
  1223.   if you have unfixable older HP Jetdirects; it reduces the likelihood
  1224.   of the printers wedging.
  1225.  
  1226.   To do this, set up a queue on your linux box that points at the
  1227.   ethernet equipped HP LJ (as above). Now set up all the clients on your
  1228.   LAN to point at the Linux queue (eg lj-5 in the example above).
  1229.  
  1230.   Some HP network printers apparently don't heed the banner page setting
  1231.   sent by clients; you can turn off their internally generated banner
  1232.   page by telnetting to the printer, hitting return twice, typing
  1233.   "banner: 0" followed by "quit".  There are other settings you can
  1234.   change this way, as well; type "?" to see a list.
  1235.  
  1236.   The full range of settings can be controlled with HP's WebJet
  1237.   <http://www.hp.com/go/webjetadmin> software.  This package runs as a
  1238.   daemon, and accepts http requests on a designated port.  It serves up
  1239.   forms and Java applets which can control HP printers on the network.
  1240.   In theory, it can also control Unix print queues, but it does so using
  1241.   the rexec service, which is completely unsecure.  I don't advise using
  1242.   that feature.
  1243.  
  1244.  
  1245.   11.5.1.  To older HPs
  1246.  
  1247.   Some printers (and printer networking "black boxes") support only a
  1248.   cheesy little non-protocol involving plain TCP connections.  Notable
  1249.   in this category are early-model JetDirect (including some
  1250.   JetDirectEx) cards.  Basically, to print to the printer, you must open
  1251.   a TCP connection to the printer on a specified port (typically 9100,
  1252.   or 9100, 9101 and 9102 for three-port boxes) and stuff your print job
  1253.   into it.  LPRng (which you really should be using instead, if you're
  1254.   reading this section) has built-in support for stuffing print jobs
  1255.   into random TCP ports, but with BSD lpd it's not so easy.  This can be
  1256.   implemented, among other ways, in Perl:
  1257.  
  1258.  
  1259.  
  1260.  
  1261.  
  1262.  
  1263.  
  1264.  
  1265.  
  1266.  
  1267.  
  1268.  
  1269.  
  1270.  
  1271.  
  1272.  
  1273.  
  1274.  
  1275.  
  1276.  
  1277.  
  1278.  
  1279.  
  1280.  
  1281.  
  1282.  
  1283.  
  1284.  
  1285.  
  1286.  
  1287.  
  1288.  
  1289.  
  1290.  
  1291.  
  1292.  
  1293.  
  1294.  
  1295.  
  1296.  
  1297.  
  1298.  
  1299.  
  1300.  
  1301.  
  1302.  
  1303.  
  1304.  
  1305.  
  1306.  
  1307.  
  1308.  
  1309.  
  1310.  
  1311.  
  1312.  
  1313.  
  1314.  
  1315.  
  1316.  
  1317.  
  1318.  
  1319.  
  1320.  
  1321.   #!/usr/bin/perl
  1322.   # Thanks to Dan McLaughlin for writing the original version of this
  1323.   # script (And to Jim W. Jones for sitting next to Dan when writing me
  1324.   # for help ;)
  1325.  
  1326.   $fileName = @ARGV[0];
  1327.  
  1328.   open(IN,"$fileName") || die "Can't open file $fileName";
  1329.  
  1330.   $dpi300     = "\x1B*t300R";
  1331.   $dosCr      = "\x1B&k3G";
  1332.   $ends = "\x0A";
  1333.  
  1334.   $port =  9100 unless $port;
  1335.   $them = "bach.sr.hp.com" unless $them;
  1336.  
  1337.   $AF_INET = 2;
  1338.   $SOCK_STREAM = 1;
  1339.   $SIG{'INT'} = 'dokill';
  1340.   $sockaddr = 'S n a4 x8';
  1341.  
  1342.   chop($hostname = `hostname`);
  1343.   ($name,$aliases,$proto) = getprotobyname('tcp');
  1344.   ($name,$aliases,$port) = getservbyname($port,'tcp')
  1345.       unless $port =~ /^\d+$/;;
  1346.   ($name,$aliases,$type,$len,$thisaddr) =
  1347.           gethostbyname($hostname);
  1348.   ($name,$aliases,$type,$len,$thataddr) = gethostbyname($them);
  1349.   $this = pack($sockaddr, $AF_INET, 0, $thisaddr);
  1350.   $that = pack($sockaddr, $AF_INET, $port, $thataddr);
  1351.  
  1352.   if (socket(S, $AF_INET, $SOCK_STREAM, $proto)) {
  1353.   #    print "socket ok\n";
  1354.   }
  1355.   else {
  1356.       die $!;
  1357.   }
  1358.   # Give the socket an address.
  1359.   if (bind(S, $this)) {
  1360.   #    print "bind ok\n";
  1361.   }
  1362.   else {
  1363.       die $!;
  1364.   }
  1365.  
  1366.   # Call up the server.
  1367.  
  1368.   if (connect(S,$that)) {
  1369.   #    print "connect ok\n";
  1370.   }
  1371.   else {
  1372.       die $!;
  1373.   }
  1374.  
  1375.   # Set socket to be command buffered.
  1376.  
  1377.   select(S); $| = 1; select(STDOUT);
  1378.  
  1379.   #    print S "@PJL ECHO Hi $hostname! $ends";
  1380.   #    print S "@PJL OPMSG DISPLAY=\"Job $whoami\" $ends";
  1381.   #    print S $dpi300;
  1382.  
  1383.   # Avoid deadlock by forking.
  1384.  
  1385.   if($child = fork) {
  1386.       print S $dosCr;
  1387.       print S $TimesNewR;
  1388.  
  1389.       while (<IN>) {
  1390.           print S;
  1391.       }
  1392.       sleep 3;
  1393.       do dokill();
  1394.   } else {
  1395.       while(<S>) {
  1396.           print;
  1397.       }
  1398.   }
  1399.  
  1400.   sub dokill {
  1401.       kill 9,$child if $child;
  1402.   }
  1403.  
  1404.  
  1405.  
  1406.  
  1407.  
  1408.   11.6.  Running an if  for remote printers
  1409.  
  1410.   One oddity of lpd is that the if is not run for remote printers.  If
  1411.   you find that you need to run an if, you can do so by setting up a
  1412.   double queue and requeueing the job.  As an example, consider this
  1413.   printcap:
  1414.  
  1415.  
  1416.        lj-5:\
  1417.                :lp=/dev/null:sh:\
  1418.                :sd=/var/spool/lpd/lj-5:\
  1419.                :if=/usr/lib/lpd/filter-lj-5:
  1420.        lj-5-remote:lp=/dev/null:sh:rm=printer.name.com:\
  1421.                :rp=raw:sd=/var/spool/lpd/lj-5-raw:
  1422.  
  1423.  
  1424.  
  1425.  
  1426.   in light of this filter-lj-5 script:
  1427.  
  1428.  
  1429.        #!/bin/sh
  1430.        gs <options> -q -dSAFER -sOutputFile=- - | \
  1431.                lpr -Plj-5-remote -U$5
  1432.  
  1433.  
  1434.  
  1435.  
  1436.   The -U option to lpr only works if lpr is run as daemon, and it sets
  1437.   the submitter's name for the job in the resubmitted queue correctly.
  1438.   You should probably use a more robust method of getting the username,
  1439.   since in some cases it is not argument 5.  See the man page for
  1440.   printcap.
  1441.  
  1442.  
  1443.   11.7.  From Windows.
  1444.  
  1445.   Printing from a Windows (or presumably, OS/2) client to a Linux server
  1446.   is directly supported over SMB through the use of the SAMBA package,
  1447.   which also supports file sharing of your Linux filesystem to Windows
  1448.   clients.
  1449.  
  1450.   Samba includes fairly complete documentation, and there is a good
  1451.   Samba FAQ which covers it, too.  You can either configure a magic
  1452.   filter on the Linux box and print PostScript to it, or run around
  1453.   installing printer-specific drivers on all the Windows machines and
  1454.   having a queue for them with no filters at all.  Relying on the
  1455.   Windows drivers may in some cases produce better output, but is a bit
  1456.   more of an administrative hassle if there are many Windows boxen.  So
  1457.   try Postscript first.
  1458.  
  1459.  
  1460.   11.8.  From an Apple.
  1461.  
  1462.   Netatalk supports printing from Apple clients over EtherTalk.  See the
  1463.   Netatalk HOWTO Page <http://thehamptons.com/anders/netatalk/> for more
  1464.   information.
  1465.  
  1466.  
  1467.   11.9.  From Netware.
  1468.  
  1469.   The ncpfs package includes a daemon named pserver which can be used to
  1470.   privide service to a NetWare print queue.  From what I understand,
  1471.   this system requires a Bindery-based NetWare, ie 2.x, 3.x, or 4.x with
  1472.   bindery access enabled.
  1473.  
  1474.   For more information on ncpfs and it's pserver program, see the ncpfs
  1475.   FTP site <ftp://ftp.gwdg.de/pub/linux/misc/ncpfs/>.
  1476.  
  1477.  
  1478.   12.  Windows-only printers
  1479.  
  1480.   As I discussed earlier, some printers are inherently unsupported
  1481.   because they don't speak a normal printer language, instead using the
  1482.   computer's CPU to render a bitmap which is then piped to the printer
  1483.   at a fixed speed.  In a few cases, these printers also speak something
  1484.   normal like PCL, but often they do not.  In some (really low-end)
  1485.   cases, the printer doesn't even use a normal parallel connection but
  1486.   relies on the vendor's driver to emulate what should be hardware
  1487.   behaviour (most importantly flow control).
  1488.  
  1489.  
  1490.   In any case, there are a few possible workarounds if you find yourself
  1491.   stuck with such a lemon.
  1492.  
  1493.  
  1494.   12.1.  The Ghostscript Windows redirector
  1495.  
  1496.   There is now a Windows printer driver available (called mswinpr2) that
  1497.   will run a print job through Ghostscript before finally printing it.
  1498.   (Rather like an if filter in Unix's LPD).  There is also a new
  1499.   Ghostscript driver which will print using Windows GDI calls.  Taken
  1500.   all together, this should(tm) allow a Windows machine to print
  1501.   PostScript to a Windows-only printer through the vendor's driver.
  1502.  
  1503.   If you get that working, you can then follow the instructions above
  1504.   for printing to a Windows printer over the network from Linux to let
  1505.   Unix (and other Windows, Mac, etc) hosts print to your lemon printer.
  1506.  
  1507.   That said, I've never tried this since I don't have a winprinter, so
  1508.   your mileage may vary.  All the software involved should be available
  1509.   from the Ghostscript home page (see the links in the Ghostscript
  1510.   section of this document).
  1511.  
  1512.  
  1513.   12.2.  The pbm2ppa program
  1514.  
  1515.   Some HP printers use "Printing Performance Architecture"
  1516.   (marketingspeak for "we were too cheap to implement PCL").  This is
  1517.   supported in a roundabout way via the pbm2ppa translator written by
  1518.   Tim Norman.  Basically, you use ghostscript to render PostScript into
  1519.   a bitmapped image in pbm format and then use pbm2ppa to translate this
  1520.   into a printer-specific ppa format bitmap ready to be dumped to the
  1521.   printer.  This program may also come in ghostscript driver format by
  1522.   now.
  1523.  
  1524.  
  1525.   The ppa software can be had from the ppa home page
  1526.   <http://www.rpi.edu/~normat/technical/ppa/>; pbm2ppa supports some
  1527.   models of the HP 720, 820, and 1000; read the documentation that comes
  1528.   with the package for more details on ppa printer support.
  1529.  
  1530.  
  1531.   12.3.  The pbm2l7k program
  1532.  
  1533.   Most of the cheap Lexmark inkjets use a proprietary language and are
  1534.   therefore Winprinters.  However, Henryk Paluch has written a program
  1535.   which can print in black and white on a Lexmark 7000.  Hopefully he'll
  1536.   be able to figure out color and expand support to other Lexmark
  1537.   inkjets.  See here <http://bimbo.fjfi.cvut.cz/~paluch/l7kdriver/> for
  1538.   more info.
  1539.  
  1540.  
  1541.  
  1542.   13.  How to print to a fax machine.
  1543.  
  1544.   13.1.  Using a faxmodem
  1545.  
  1546.   There are a number of fax programs out there that will let you fax and
  1547.   receive documents.  One of the most complex is Sam Leffler's HylaFax,
  1548.   available from ftp.sgi.com.  It supports all sorts of things from
  1549.   multiple modems to broadcasting.
  1550.  
  1551.   SuSE ships a Java HylaFax client which allegedly works on any Java
  1552.   platform (including Windows and Linux).  There are also non-Java fax
  1553.   clients for most platforms; Linux can almost certainly handle your
  1554.   network faxing needs.
  1555.  
  1556.   Also available, and a better choice for most Linux boxen, is efax, a
  1557.   simple program which sends faxes.  The getty program mgetty can
  1558.   receive faxes (and even do voicemail on some modems!).
  1559.  
  1560.  
  1561.   13.2.  Using the Remote Printing Service
  1562.  
  1563.   There is an experimental service offered that lets you send an email
  1564.   message containing something you'd like printed such that it will
  1565.   appear on a fax machine elsewhere.  Nice formats like postscript are
  1566.   supported, so even though global coverage is spotty, this can still be
  1567.   a very useful service.  For more information on printing via the
  1568.   remote printing service, see the Remote Printing WWW Site
  1569.   <http://www.tpc.int/>.
  1570.  
  1571.  
  1572.  
  1573.   14.  How to generate something worth printing.
  1574.  
  1575.   Here we get into a real rat's-nest of software.  Basically, Linux can
  1576.   run many types of binaries with varying degrees of success: Linux/x86,
  1577.   Linux/Alpha, Linux/Sparc, Linux/foo, iBCS, Win16/Win32s (with dosemu
  1578.   and, someday, with Wine), Mac/68k (with Executor), and Java.  I'll
  1579.   just discuss native Linux and common Unix software.
  1580.  
  1581.   For Linux itself, choices are mostly limited to those available for
  1582.   Unix in general:
  1583.  
  1584.  
  1585.   14.1.  Markup languages
  1586.  
  1587.   Most markup languages are more suitable for large or repetitive
  1588.   projects, where you want the computer to control the layout of the
  1589.   text to make things uniform.
  1590.  
  1591.  
  1592.      nroff
  1593.         This was one of the first Unix markup languages.  Man pages are
  1594.         the most common examples of things formatted in *roff macros;
  1595.         many people swear by them, but nroff has, to me at least, a more
  1596.         arcane syntax than needed, and probably makes a poor choice for
  1597.         new works.  It is worth knowing, though, that you can typeset a
  1598.         man page directly into postscript with groff.  Most man commands
  1599.         will do this for you with man -t foo | lpr.
  1600.  
  1601.  
  1602.      TeX
  1603.         TeX, and the macro package LaTeX, are one of the most widely
  1604.         used markup languages on Unix.  Technical works are frequently
  1605.         written in LaTeX because it greatly simplifies the layout issues
  1606.         and is still one of the few text processing systems to support
  1607.         mathematics both completely and well.  TeX's output format is
  1608.         dvi, and is converted to PostScript or Hewlett Packard's PCL
  1609.         with dvips or dvilj.  If you wish to install TeX or LaTeX,
  1610.         install the whole teTeX group of packages; it contains
  1611.         everything.
  1612.  
  1613.  
  1614.      SGML
  1615.         There is at least one free sgml parser available for Unix and
  1616.         Linux; it forms the basis of Linuxdoc-SGML's homegrown document
  1617.         system.  It can support other DTD's, as well.
  1618.  
  1619.  
  1620.      HTML
  1621.         Someone suggested that for simple projects, it may suffice to
  1622.         write it in HTML and print it out using Netscape.  I disagree,
  1623.         but YMMV.
  1624.  
  1625.  
  1626.   14.2.  WYSIWYG Word Processors
  1627.  
  1628.   There is no longer any shortage of WYSIWYG word processing software.
  1629.   Several complete office suites are available, including one that's
  1630.   free for personal use (StarOffice).
  1631.  
  1632.      StarOffice
  1633.         A German company is distributing StarOffice on the net free for
  1634.         Linux.  This full-blown office suite has all the features you'd
  1635.         expect, and you can't beat the price.  There's a mini-HOWTO out
  1636.         there which describes how to obtain and install it.  It
  1637.         generates PostScript or PCL, so should work with most any
  1638.         printer that works otherwise on Linux.  Apparently it's an
  1639.         Office clone and is rather bloated.
  1640.  
  1641.  
  1642.      WordPerfect
  1643.         Corel distributes a basic version of Word Perfect 8 free for
  1644.         Linux, and has suggested that they will distribute Corel Draw
  1645.         and Quattro Pro as well, once they are ported.  This is probably
  1646.         the best option if you have an ARM machine; Corel makes the ARM-
  1647.         based Netwinder Linux computers and is almost certian to offer
  1648.         ARM Linux versions of everything.  You can also buy the full-
  1649.         blown version and support, together or separately.  The Linux
  1650.         WordPerfect Fonts and Printers
  1651.         <http://www.channel1.com/users/rodsmith/wpfonts.html> page has
  1652.         information about configuring WordPerfect for use with either
  1653.         Ghostscript or its built-in printer drivers (which are
  1654.         apparently identical the DOS WordPerfect drivers, if your
  1655.         printer's driver isn't included in the WP8 distribution).
  1656.  
  1657.  
  1658.      Applix
  1659.         Applix is a cross-platform (ie, various Unices, Windows, and
  1660.         others) office suite sold by the Applix company.  Red Hat and
  1661.         SuSE sold it themselves when it was the only game in town; now
  1662.         sales have reverted to Applix.
  1663.  
  1664.  
  1665.      LyX
  1666.         LyX is a front-end to LaTeX which looks very promising.  See the
  1667.         LyX Homepage <http://www.lyx.org/> for more information.  There
  1668.         is a KDE-styled version of LyX, called Klyx; the author of LyX
  1669.         and the instigator of KDE are the same person.
  1670.  
  1671.  
  1672.      Maxwell
  1673.         Maxwell is a simple MS RTF-format based word processor which
  1674.         started as a commercial product but is now distributed under the
  1675.         GPL.
  1676.  
  1677.  
  1678.      The Andrew User Interface System
  1679.         AUIS includes ez, a WYSIWYG-style editor with most basic word
  1680.         processor features, HTML capabilities, and full MIME email and
  1681.         newsgroup support.  Unfortunately, AUIS is no longer maintained.
  1682.  
  1683.  
  1684.      Koffice
  1685.         The KDE project is working toward a whole office suite.  I don't
  1686.         think it's ready for prime time yet.  The word processor will
  1687.         apparently be a descendant of LyX.
  1688.  
  1689.  
  1690.      GNOME
  1691.         The GNOME project also is working toward various GNU-licensed
  1692.         officey tools.  None are available yet, though.
  1693.  
  1694.  
  1695.  
  1696.         Jeff Phillips <jeff@I_RATUS.org> uses Caldera's WordPerfect 7
  1697.         for Linux (on Slackware, of all things) and says that it works
  1698.         well.  It apparently includes built-in printer support, as one
  1699.         would expect.  Caldera should have info on
  1700.         <http://www.caldera.com/>.  You can also buy a newer version of
  1701.         Wordperfect directly from Corel's chosen Unix port company.
  1702.  
  1703.  
  1704.         Other vendors should feel free to drop me a line with your
  1705.         offerings.
  1706.  
  1707.  
  1708.  
  1709.   15.  On-screen previewing of printable things.
  1710.  
  1711.   Nearly anything you can print can be viewed on the screen, too.
  1712.  
  1713.   15.1.  PostScript
  1714.  
  1715.   Ghostscript has an X11 driver best used under the management of the
  1716.   PostScript previewer gv.  The latest versions of these programs should
  1717.   be able to view PDF files, as well.  Note that gv has replaced the
  1718.   older previewer "Ghostview"; the new user interface is mch prettier
  1719.   and featureful that ghostview's plain old Athena gui.
  1720.  
  1721.  
  1722.   15.2.  TeX dvi
  1723.  
  1724.   TeX DeVice Independant files may be previewed under X11 with xdvi.
  1725.   Modern versions of xdvi call ghostscript to render PostScript
  1726.   specials.
  1727.  
  1728.   A VT100 driver exists as well.  It's called dgvt.  Tmview works with
  1729.   Linux and svgalib, if that's all you can do.
  1730.  
  1731.  
  1732.   15.3.  Adobe PDF
  1733.  
  1734.   Adobe's Acrobat Reader is available for Linux; just download it from
  1735.   their web site  <http://www.adobe.com/>.
  1736.  
  1737.   You can also use xpdf, which is freeware and comes with source, and I
  1738.   should think Ghostview supports viewing PDF files with gs under X11 by
  1739.   now.
  1740.  
  1741.  
  1742.   16.  Serial printers under lpd
  1743.  
  1744.   16.1.  Setting up in printcap
  1745.  
  1746.   Lpd provides five attributes which you can set in /etc/printcap to
  1747.   control all the settings of the serial port a printer is on.  Read the
  1748.   printcap man page and note the meanings of br#, fc#, xc#, fs# and xs#.
  1749.   The last four of these attributes are bitmaps indicating the settings
  1750.   for use the port.  The br# atrribute is simply the baud rate, ie
  1751.   `br#9600'.
  1752.  
  1753.  
  1754.   It is very easy to translate from stty settings to printcap flag
  1755.   settings. If you need to, see the man page for stty now.
  1756.  
  1757.  
  1758.   Use stty to set up the printer port so that you can cat a file to it
  1759.   and have it print correctly. Here's what `stty -a' looks like for my
  1760.   printer port:
  1761.  
  1762.  
  1763.        dina:/usr/users/andy/work/lpd/lpd# stty -a < /dev/ttyS2
  1764.        speed 9600 baud; rows 0; columns 0; line = 0;
  1765.        intr = ^C; quit = ^\; erase = ^?; kill = ^U; eof = ^D; eol = <undef>;
  1766.        eol2 = <undef>; start = ^Q; stop = ^S; susp = ^Z; rprnt = ^R; werase = ^W;
  1767.        lnext = ^V; min = 1; time = 0;
  1768.        -parenb -parodd cs8 hupcl -cstopb cread -clocal -crtscts
  1769.        -ignbrk -brkint -ignpar -parmrk -inpck -istrip -inlcr
  1770.        -igncr -icrnl ixon -ixoff -iuclc -ixany -imaxbel
  1771.        -opost -olcuc -ocrnl -onlcr -onocr -onlret -ofill -ofdel nl0 cr0 tab0
  1772.        bs0 vt0 ff0
  1773.        -isig -icanon -iexten -echo -echoe -echok -echonl -noflsh -xcase
  1774.        -tostop -echoprt -echoctl -echoke
  1775.  
  1776.  
  1777.  
  1778.  
  1779.   The only changes between this and the way the port is initialized at
  1780.   bootup are -clocal, -crtscts, and ixon. Your port may well be differ¡
  1781.   ent depending on how your printer does flow control.
  1782.  
  1783.   You actually use stty in a somewhat odd way.  Since stty operates on
  1784.   the terminal connected to it's standard input, you use it to
  1785.   manipulate a given serial port by using the `<' character as above.
  1786.  
  1787.  
  1788.   Once you have your stty settings right, so that `cat file >
  1789.   /dev/ttyS2' (in my case) sends the file to the printer, look at the
  1790.   file /usr/src/linux/include/asm-i386/termbits.h. This contains a lot
  1791.   of #defines and a few structs (You may wish to cat this file to the
  1792.   printer (you do have that working, right?) and use it as scratch
  1793.   paper).  Go to the section that starts out
  1794.  
  1795.  
  1796.  
  1797.        /* c_cflag bit meaning */
  1798.        #define CBAUD   0000017
  1799.  
  1800.  
  1801.  
  1802.  
  1803.   This section lists the meaning of the fc# and fs# bits. You will
  1804.   notice that the names there (after the baud rates) match up with one
  1805.   of the lines of stty output. Didn't I say this was going to be easy?
  1806.  
  1807.  
  1808.   Note which of those settings are preceded with a - in your stty
  1809.   output. Sum up all those numbers (they are octal). This represents the
  1810.   bits you want to clear, so the result is your fc# capability.  Of
  1811.   course, remember that you will be setting bits directly after you
  1812.   clear, so you can just use `fc#0177777' (I do).
  1813.  
  1814.  
  1815.   Now do the same for those settings (listed in this section) which do
  1816.   not have a - before them in your stty output. In my example the
  1817.   important ones are CS8 (0000060), HUPCL (0002000), and CREAD
  1818.   (0000200). Also note the flags for your baud rate (mine is 0000015).
  1819.   Add those all up, and in my example you get 0002275. This goes in your
  1820.   fs# capability (`fs#02275' works fine in my example).
  1821.  
  1822.  
  1823.   Do the same with set and clear for the next section of the include
  1824.   file, "c_lflag bits". In my case I didn't have to set anything, so I
  1825.   just use `xc#0157777' and `xs#0'.
  1826.  
  1827.  
  1828.   16.2.  Older serial printers that drop characters
  1829.  
  1830.   Jon Luckey points out that some older serial printers with ten-cent
  1831.   serial interfaces and small buffers really mean stop when they say so
  1832.   with flow control.  He found that disabling the FIFO in his Linux
  1833.   box's 16550 serial port with setserial corrected the problem of
  1834.   dropped characters (you apparently just specify the uart type as an
  1835.   8250 to do this).
  1836.  
  1837.  
  1838.   17.  Credits
  1839.  
  1840.   The smbprint information is from an article by Marcel Roelofs
  1841.   <marcel@paragon.nl>.
  1842.  
  1843.  
  1844.   The nprint information for using Netware printers was provided by
  1845.   Michael Smith <mikes@bioch.ox.ac.uk>.
  1846.  
  1847.  
  1848.  
  1849.   The serial printers under lpd section is from Andrew Tefft
  1850.   <teffta@engr.dnet.ge.com>.
  1851.  
  1852.  
  1853.   The blurb about gammas and such for gs was sent in by Andreas
  1854.   <quasi@hub-fue.franken.de>.
  1855.  
  1856.  
  1857.   The two paragraphs about the 30 second closing_wait of the serial
  1858.   driver was contributed by Chris Johnson <cdj@netcom.com>.
  1859.  
  1860.  
  1861.   Robert Hart sent a few excellent paragraphs about setting up a print
  1862.   server to networked HPs which I used verbatim.
  1863.  
  1864.  
  1865.   And special thanks to the dozens upon dozens of you who've pointed out
  1866.   typos, bad urls, and errors in the document over the years.
  1867.  
  1868.  
  1869.  
  1870.  
  1871.  
  1872.  
  1873.  
  1874.  
  1875.  
  1876.  
  1877.  
  1878.  
  1879.  
  1880.  
  1881.  
  1882.  
  1883.  
  1884.  
  1885.  
  1886.  
  1887.  
  1888.  
  1889.  
  1890.  
  1891.  
  1892.  
  1893.  
  1894.  
  1895.  
  1896.  
  1897.  
  1898.  
  1899.  
  1900.  
  1901.  
  1902.  
  1903.  
  1904.  
  1905.  
  1906.  
  1907.  
  1908.  
  1909.  
  1910.  
  1911.  
  1912.  
  1913.  
  1914.  
  1915.