Taming the Horrors of Printers and Printing, Part 3
Hello everyone, and welcome to another week of printing magic and demystification right here at the Sysadmin's Corner.
Before I go into this week's tips, tricks, and all around "this is how you do it" stuff, I want to tell you about something wonderful that happened to me yesterday. No, something else. It had to do with color. Some time ago, I bought a nice, shiny new HP DeskJet 710C color printer. Of course, I broke the first rule, "Thou shalt check the hardware compatibility list". As it turns out, this printer is one of the so-called "Winprinters", an evil invention for Windows-only systems. Sort of like a winmodem, only this is a printer.
Anyhow, my DeskJet 710C uses what HP calls PPA or Printing Performance Architecture. This is a closed protocol and HP had the right to decide to do this, but it made for some tough choices on my part. We did have one (and still do) Windows 95 PC in the office and it could use the printer. The color was beautiful and at least one of us could use it. Turning to the 'net, I found that there was a printer driver/filter in the early stages of development (it could print in black and white). So, armed with wild optimism and the belief in the stalwart band of Linux developers out there, I decided to keep the printer.
Time passes ... Tim Norman (the name on the httptech web page) and the Linux PPA development team (6 developers are listed on the sourceforge site) work their magic, and finally, we have a color driver for the HP 710, 720, 820, and 1000 series of color printers. They do warn that the code is in the test stages (read unstable), but after trying it, I think they've done a great job of finally letting my Linux systems take advantage of what is otherwise a great printer. The latest source and development information can be found at the sourceforge.net web site.
http://sourceforge.net/project/?group_id=1322
The original home page is at http://www.httptech.com/ppa/.
Before I repeat the big warning, I should also let you know you can download Red Hat and Mandrake RPMs and filters from the sourceforge site. You can also get the current source for pnm2ppa (which is what the driver is actually called) and pick up the latest documentation. Now, the warning once again ... while I am very happy with this release and it seems to work beautifully for me, the code is alpha and should be treated as such.
One last thing on the PPA filter: they are planning support for ghostscript, but that is sometime out there in the future. Speaking of ghostscript (can you say "segueway"?): last week, I talked about creating a ghostscript filter so that programs which generate postscript can be used with non-postscript printers. In Linux or UNIX land, that accounts for a lot of programs. Anyhow, here's a quick reminder of my ghostscript output filter to convert postscript to my LaserJet 5L printer. I've saved this file as /usr/local/bin/psfilter and made it executable with chmod 755 /usr/local/bin/psfilter.
#!/bin/bash # # This is a ghostscript filter so that our HP LJ5 will print postscript files # echo -ne \\033&k2G gs -q -dNOPAUSE -sDEVICE=ljet4 -r300 -sPAPERSIZE=letter -sOutputFile=- -
Now, I also have a definition for the printer which uses that output filter.
pshpljet:
:sd=/var/spool/lpd/pshpljet:
:mx#0:
:sh:
:lp=/dev/lp0:
:of=/usr/local/bin/psfilter:
Now that we can print postscript to our HP LaserJet (or Epson for that matter), we can do some pretty cool postscript things. Here is just one of them.
Say you've got a two-page document (a program listing, or a collection of bad but funny one-liners) and you really only want the thing to take up one page (the jokes are not that good). This is where the mpage command comes into play. We are now going to print this document so that two pages fit on one. The output will be rotated, so this will actually come out as portrait orientation.
mpage -2 funnyjokes.txt | lpr -Ppshpljet
My two pages appear on one page, with a nice thin line around both pages. Let's make this just a little fancier, shall we? Check out the next command, and see what kind of output it generates.
mpage -2 -B-5r-5l-3t-3b3 -M50l50r50t50b -H wright.txt | lpr -Plptest
What does this all mean? The -2, by the way, could be a -4 to fit 4 logical pages per physical page. Just so we are clear on my hastily chosen terminology, I am using the terms "logical" and "physical" to differentiate the printer output from the physical, "hold it in your hand" page. You can even do a -8 but that might be getting a tad silly. The -B-5r-5l-3t-3b3 means a bold line (3 pt) should be drawn around the box. That's actually the last 3 at the end of that line. The -5r- 5l-3t-3b means I want a three-line margin at the top and bottom and a five-character margin to the left and right. The -M line uses a similar format. Give me a 50-pt margin all around my virtual page. Remember, we have two logical pages on one physical page in this example. Finally, the -H means I want a header on each page. The header has the date on the right, the filename in the center, and a page number on the right.
So, where would you use this? One place that comes immediately to mind (after the one-liners, that is) is source code for your programs. This is a great way to generate compact program listings without having to import them into a word processor. I should point out that there is a non-postscript way of creating simple numbered pages. All you have to do is use the pr command. Try this with a text-only printer definition:
pr +2 -h "Secret Kernel Enhancements" -o 5 ftl_travel.c | lpr -Ptextonly
pr is a command designed to format text for printing. The line above says to take the file ftl_travel.c, start printing at page 2 (that's the +2), add a left-hand indent of 5 spaces (the -o 5), and print the header "Secret Kernel Enhancements" on each page (the -h followed by a string). If you do not specify a different header name, you'll get the file name itself, in this case ftl_travel.c. Oh, yes; it will actually start numbering the pages at 2.
Before we go, I'd like to talk about StarOffice. A number of people wrote and asked if I would add a little something to help them with StarOffice printing. Well, who am I to say no?
There are a couple of ways to get into the StarOffice printer dialog. If you have KDE installed, StarOffice popped up a nice little set of icons in the "Personal" section of your K menus. Those are Setup, SPAdmin and StarOffice. For printer configuration, click on the SPAdmin menu item. You can also choose printer configuration from your StarOffice menu when you start the package.
Notice that when the printer dialog appears, you've probably got something that says Generic Printer on queue default_queue (lpr). Below is a list of printers you can add--all of them postscript. My printer won't show up in that list, since I have a LaserJet 5L. I do, however, have a queue defined to print postscript to my LaserJet (pshpljet). So, I highlight the "Generic Printer" and click on the "Connect" button to the right. This brings up another window with a list of "Existing queues", one of which is my generic_queue (lpr) and the other says fax_queue=(FAX). We won't talk about faxing today, but I will tell you what you need to get that printer working. Click on the default_queue and change it to read something like this:
my_printer_queue=lpr -Pmy_ptrname
In my case, it actually looks like this:
Network_LaserJet=lpr-Ppshpljet
Now, click on the Test button (you'll be told that this will save your configuration). You should get a nice printout with a spiral pattern that seems to say, "You are getting sleepy...". At that point, you can specify this as your default printer and click Close. As I mentioned earlier, it is also possible to run this dialog from StarOffice itself, but for the really brave among you, there is yet another way. That is to edit the .Xpdefaults file in your home directory. The file is fairly interesting to look through, but in particular, look for the [ports] section of the file. In mine, there was a single entry for the default queue that looked like this:
default_queue=lpr
If you have only one printer that you intend to use StarOffice with, you could simply change this line in the same way I did.
default_queue=lpr -Ppshpljet
Of course, you would substitute your own queue name here. Now, all you need to do is restart StarOffice.
There you have it. When next we meet, I want to have one last look at filters: Red Hat filters, magic filters, apsfilters, et cetera, et cetera, et cetera. Filters, filters everywhere, and no paper left to print. Until then, "Print lightly and carry a big toner cartridge."
email: ljeditors@ssc.com
Realizing the promise of Apache® Hadoop® requires the effective deployment of compute, memory, storage and networking to achieve optimal results. With its flexibility and multitude of options, it is easy to over or under provision the server infrastructure, resulting in poor performance and high TCO. Join us for an in depth, technical discussion with industry experts from leading Hadoop and server companies who will provide insights into the key considerations for designing and deploying an optimal Hadoop cluster.
Sponsored by AMD
Built-in forensics, incident response, and security with Red Hat Enterprise Linux 6
Every security policy provides guidance and requirements for ensuring adequate protection of information and data, as well as high-level technical and administrative security requirements for a system in a given environment. Traditionally, providing security for a system focuses on the confidentiality of the information on it. However, protecting the data integrity and system and data availability is just as important. For example, when processing United States intelligence information, there are three attributes that require protection: confidentiality, integrity, and availability.
Learn more about catching the bad guy in this free white paper.
Sponsored by DLT Solutions
Free Webinar: Hadoop
How to Build an Optimal Hadoop Cluster to Store and Maintain Unlimited Amounts of Data Using Microservers
Realizing the promise of Apache® Hadoop® requires the effective deployment of compute, memory, storage and networking to achieve optimal results. With its flexibility and multitude of options, it is easy to over or under provision the server infrastructure, resulting in poor performance and high TCO. Join us for an in depth, technical discussion with industry experts from leading Hadoop and server companies who will provide insights into the key considerations for designing and deploying an optimal Hadoop cluster.
Some of key questions to be discussed are:
- What is the “typical” Hadoop cluster and what should be installed on the different machine types?
- Why should you consider the typical workload patterns when making your hardware decisions?
- Are all microservers created equal for Hadoop deployments?
- How do I plan for expansion if I require more compute, memory, storage or networking?
| Dynamic DNS—an Object Lesson in Problem Solving | May 21, 2013 |
| Using Salt Stack and Vagrant for Drupal Development | May 20, 2013 |
| Making Linux and Android Get Along (It's Not as Hard as It Sounds) | May 16, 2013 |
| Drupal Is a Framework: Why Everyone Needs to Understand This | May 15, 2013 |
| Home, My Backup Data Center | May 13, 2013 |
| Non-Linux FOSS: Seashore | May 10, 2013 |
- Dynamic DNS—an Object Lesson in Problem Solving
- Making Linux and Android Get Along (It's Not as Hard as It Sounds)
- Using Salt Stack and Vagrant for Drupal Development
- New Products
- A Topic for Discussion - Open Source Feature-Richness?
- Drupal Is a Framework: Why Everyone Needs to Understand This
- Validate an E-Mail Address with PHP, the Right Way
- RSS Feeds
- Readers' Choice Awards
- Tech Tip: Really Simple HTTP Server with Python



2 hours 2 min ago
5 hours 38 min ago
6 hours 10 min ago
8 hours 34 min ago
8 hours 37 min ago
8 hours 38 min ago
13 hours 3 min ago
14 hours 54 min ago
20 hours 8 min ago
23 hours 19 min ago