TweetFollow Us on Twitter

September 96 - Print Hints: The All-New LaserWriter Driver Version 8.4

Print Hints: The All-New LaserWriter Driver Version 8.4

Dave Polaschek

By the time you read this, version 8.4 of the LaserWriter 8 printer driver will have shipped. This driver -- LaserWriter version 8.4, for short -- is not the same old LaserWriter driver: it has new features that developers have been asking for, sports a new user interface, and beats earlier versions of the driver in the quarter mile.

Here I'll outline some of the changes -- a few minor, a few major -- that you need to be aware of for compatibility reasons. Even if you don't want to take advantage of any of the great new features, you'll at least need to address compatibility issues if any of the changes cause problems with your application.

To help you implement the new features, this column is backed up with detailed documentation on this issue's CD.


The 120-byte print record in the previous driver version doesn't have as many free bits available as some programmers would like. So to let you save all possible printing information about a document, Apple decided to allow for extensible print records.

If all you want to do is maintain compatibility with the new driver version, you shouldn't need to change your application at all. But if you want to take advantage of the extended print record -- and implement attractive features such as access to a larger number of paper sizes, tray handling that works with the PrJobMerge function, and the ability to reliably save more user settings from the Page Setup dialog -- you do need to make some minor changes, along the following lines:

  • Because the extended print record can be any size larger than 120 bytes, your application must not make any assumptions about the record's size.

  • Although the locations of fields that are currently defined within the TPrint structure won't change, you should use PrGeneral with the extended print record opcodes (described below) to access any additional fields.

  • When using an extended print record, you'll need to call the extendPrDefault and extendPrValidate functions where you previously would have called the functions PrintDefault and PrValidate. (The new extend functions really just call PrGeneral with specific opcodes, but are more convenient to use than PrGeneral itself.) See "Extending the Print Record" on this issue's CD for more information on the extend functions and how they use the new PrGeneral opcodes.
Those who break the rules might need to make more changes. See the Print Hints column in develop Issue 26 ("The Top 10 Printing Crimes Revisited") for more information.


LaserWriter version 8.4 adds three new PrGeneral opcodes for dealing with the extended print record: kExtendPrintRecOp (which extends the print record), kGetExtendedPrintRecOp, and kSetExtendedPrintRecOp.

Table 1 gives a complete list of all the PrGeneral opcodes as of June 1996 (but be aware that printing in Mac OS 8 might not implement all of these). These opcodes are all planned to be supported by LaserWriter version 8.4, except for the ones that aren't used by LaserWriter 8 (as noted in the table). Refer to the article "Meet PrGeneral" in develop Issue 3 for more information about PrGeneral.

Table 1. The PrGeneral opcodes

Opcode Operation
4 getRslDataOp
5 setRslOp
6 draftBitsOp
7 noDraftBitsOp
8 getRotnOp
9 NoGrayScl (not used by LaserWriter 8)
10 getPSInfoOp
11 PSIntentionsOp
12 enableColorMatchingOp
13 registerProfileOp (ColorSync 1 only; not used by LaserWriter 8)
14 PSAdobeOp
15 PSPrimaryPPDOp
16 kLoadCommProcsOp
17 kUnloadCommProcsOp
18 kExtendPrintRecOp (LaserWriter version 8.4 and later only)
19 kGetExtendedPrintRecOp (LaserWriter version 8.4 and later only)
20 kPrinterDirectOpCode (not used by any LaserWriter driver)
21 kSetExtendedPrintRecOp (LaserWriter version 8.4 and later only)


The print dialogs have been completely redesigned for LaserWriter version 8.4.

Applications that use the approved method of extending the print dialogs will continue to function. But if your application uses a nonstandard method of extending the print dialogs, it's in trouble. The definitive source about how to extend a print dialog is PDlog Expand, available as sample code on this issue's CD and included with the Macintosh Technical Note "Print Dialogs: Adding Items" (PR 09).

The new print dialogs have a pop-up menu that lets the user select between multiple panes of the dialog. In Figure 1, the General pane has been selected from the pop-up menu. When an application adds items to the print dialog, they're added to a pane that has the name of the application. Because of this new multipane dialog, applications that extend the print dialogs in a nonstandard manner will cause many problems, such as dialog items appearing in the wrong locations, standard items being overwritten within the dialog, and standard items being drawn incorrectly.

Figure 1. The new multipane print dialog

Applications also shouldn't assume that the print dialog's foreground color is black or that the background color is white. Furthermore, when applications exit their CDEFs or user items, they should be careful to leave the foreground and background colors as they found them. Other items in the dialog rely on these colors, so if you change them the standard controls in the print dialog could take on unusual colors.


With LaserWriter version 8.4, when background printing is disabled, printing is one-pass. This means that there are no longer any big spool files to fill up your hard drive, and the first printed page comes out of the printer more quickly (because it doesn't have to wait for the entire document to spool). The downside is that because the LaserWriter driver isn't making two passes over the data to be printed, it might not be able to perform the same optimizations on the PostScript(TM) code as when background printing is enabled.

As a result, jobs printed with background printing disabled might print more slowly, and in a few cases the final quality could suffer. With the advent of one-pass printing, if your application has its own PostScript LaserPrep dictionary, it should use the PREC 103 mechanism for this dictionary. With this mechanism, the driver downloads to the printer the PostScript dictionary contained in the PREC 103 resource before it's needed by application-generated PostScript code. If the application doesn't do this and defines its own PostScript procedures at the page level, these procedures will be undefined as part of the one-pass font-handling mechanism and you'll get PostScript errors (mostly undefined operators, because the operators you defined aren't there).


Some of the functionality of LaserWriter version 8.4 has been broken out into shared libraries, including the following:
  • Converter library -- generation of PostScript code

  • PPD library -- parsing of the PostScript printer description file

  • Preferences and Collection libraries -- storage and retrieval of preferences file data

  • Downloader library -- downloading of PostScript and EPS files to a printer

  • PostScript Utilities library -- PostScript utility functions

  • Communications library -- communications
In the future, Apple may provide APIs to these shared libraries for third parties.


If you're a printer developer, you should know that the way PPD files are parsed and handled has changed in LaserWriter version 8.4. Previous versions of the driver would supply a "Printer's Default" choice so that the user could choose not to decide about a certain feature and accept the default setting of the printer. With version 8.4, the driver will no longer provide this option. If PPD creators want to continue to have a Printer's Default option for a user interface feature (called UIFeature in the PPD specification), they'll have to add it to the PPD file in the list of options for that feature.

Also, common features available through the PPD file will be added to the correct pane of the print dialog. Features that aren't recognized or that are vendor-specific will be placed in their own pane. This can cause problems: if you use a nonstandard naming convention for a common feature, it will be placed with all other unknown features, and if you use a standard name for a nonstandard feature, it will probably end up in the wrong location.

One other change is that you can specify the graphic elements you'd like to use for UI features specified within the PPD file. See "LaserWriter 8.4 PPDs" on the CD for information about how to design your own pane for use with LaserWriter version 8.4. The latest Apple PPD files are the best examples of how to implement the new features.


LaserWriter 8 introduced a number of new error codes, but they haven't been documented -- until now, that is. See the unofficial documentation "LaserWriter 8 Errors" on the CD. Future versions of this document will be released as Technotes. These error codes are provided for debugging purposes. Be aware that they may change in the future, so you probably don't want your application to depend on them.


That's a quick rundown of the new features of the newest version of the LaserWriter driver. These features should make printing a better experience for the user, should give the developer more flexibility, and should require no changes to most applications. And to top it all off, they're cool!


    • "Print Hints: The Top Ten Printing Crimes Revisited" by Dave Polaschek, develop Issue 26.

    • "Meet PrGeneral, the Trap that Makes the Most of the Printing Manager" by Pete "Luke" Alexander, develop Issue 3.

    • Macintosh Technical Note "Print Dialogs: Adding Items" (PR 09).

    • "Extending the Print Record,""LaserWriter 8.4 PPDs," and "LaserWriter 8 Errors," all on this issue's CD.

DAVE POLASCHEK ( continues to be confused by California. There's nice weather when it isn't baseball season, the earth moves even when he's alone, and it's easier to find good wine than good beer. Dave works in Developer Technical Support (DTS) at Apple. If you'd like more details, look at*


Community Search:
MacTech Search:

Software Updates via MacUpdate

Gopogo guide - How to bounce like the be...
Nitrome just launched a new game and, as to be expected, it's a lot of addictive fun. It's called Gopogo, and it challenges you to hoparound a bunch of platforms, avoiding enemies and picking up shiny stuff. It's not easy though - just like the... | Read more »
Sago Mini Superhero (Education)
Sago Mini Superhero 1.0 Device: iOS Universal Category: Education Price: $2.99, Version: 1.0 (iTunes) Description: KAPOW! Jack the rabbit bursts into the sky as the Sago Mini Superhero! Fly with Jack as he lifts impossible weights,... | Read more »
Star Wars: Galaxy of Heroes guide - How...
Star Wars: Galaxy of Heroes is all about collecting heroes, powering them up, and using them together to defeat your foes. It's pretty straightforward stuff for the most part, but increasing your characters' stats can be a bit confusing because it... | Read more »
The best cooking apps (just in time for...
It’s that time of year again, where you’ll be gathering around the dinner table with your family and a huge feast in front of you. [Read more] | Read more »
Square Rave guide - How to grab those te...
Square Rave is an awesome little music-oriented puzzle game that smacks of games like Lumines, but with its own unique sense of gameplay. To help wrap your head around the game, keep the following tips and tricks in mind. [Read more] | Read more »
Snowboard Party 2 (Games)
Snowboard Party 2 1.0 Device: iOS Universal Category: Games Price: $1.99, Version: 1.0 (iTunes) Description: Crowned the best snowboarding game available on the market, Snowboard Party is back to fulfill all your adrenaline needs in... | Read more »
One Button Travel (Games)
One Button Travel 1.0 Device: iOS Universal Category: Games Price: $2.99, Version: 1.0 (iTunes) Description: “To cut a long story short, If you like interactive fiction, just go buy this one.” - “Oozes the polish that... | Read more »
Light Apprentice Volume 1 (Games)
Light Apprentice Volume 1 1.0 Device: iOS Universal Category: Games Price: $4.99, Version: 1.0 (iTunes) Description: Light Apprentice Volume 1 includes Chapters 1 to 4, all gathered in a new exclusive game. When life in the world of... | Read more »
The best games like Animal Crossing on m...
Animal Crossing amiibo Festival is out right now for the Wii U, reminding us of just how much fun that world can be. Or at least to go back and check in on our villages once in a while. [Read more] | Read more »
Between 2 Taps - Tap for Tap interview M...
Hello, and welcome back to Between 2 Taps, Tap for Tap’s Indie Dev interview series. [Read more] | Read more »

Price Scanner via

Black Friday deals on the Apple Watch and App...
Apple resellers are offering discounts and bundles with the purchase of an Apple Watch this Black Friday weekend. Below is a roundup of the deals being offered by authorized Watch resellers: Apple... Read more
Early Black Friday sale at B&H Photo, up...
B&H Photo has all new Macs on sale for up to $500 off MSRP as part of their early Black Friday sale including free shipping plus NY sales tax only: - 15″ 2.2GHz Retina MacBook Pro: $1699 $300 off... Read more
NewerTech/OWC/MacSales Black Friday Deals 201... • Free Shipping available on nearly EVERYTHING on orders $35.00 & up within USA + • International Delivery Specials from $2.99+ Special Purolator... Read more
Walmart Black Friday deals: $100 off select i...
Walmart has released their Black Friday deals for 2015, now available online. Choose free shipping or free local store pickup (if available): - 16GB iPad Air 2: $399, $100 off MSRP - 16GB iPad Air: $... Read more
Photo Cleaner 1.0 Reclaims iPhone Storage Spa...
Seoul, Korea based mix1009 has announced the release and immediate availability of Photo Cleaner 1.0, their handy iPhone app that deletes the video portion of Live Photos, in order to reclaim space... Read more
Black Friday and Holiday sales on our price t...
Scan our Mac Price Trackers for the latest Black Friday and Holiday season information on sales, bundles, and availability on systems from Apple’s authorized internet/catalog resellers. We update the... Read more
Best Buy Black Friday deals: Up to $200 off M...
Best Buy has posted their Black Friday sale prices for 2015. Save on MacBook Pros, MacBooks, MacBook Airs, iMacs, iPads, and Apple Watches. Choose free shipping or free local store pickup (if... Read more
Save $30-$40 on new Apple TVs after rebate
Adorama has new Apple TVs on sale for up to $40 off MSRP after mail-in rebate, good through December 15th. Shipping is free, and Adorama charges NY & NJ sales tax only: - 32GB Apple TV: $119.99... Read more
13-Inch Haswell MacBook Air At Two Years – Th...
The 13-inch mid-2013 “Haswell” MacBook Air I ordered in Apple’s November 2013 Black Friday sale was my first new Mac in four and a half years — the longest interval I’ve gone between system upgrades... Read more
Target Black Friday Early Access deals: $100...
Target is offering early access to their Black Friday deals on Apple products on their online store for today, the 25th, only. Choose free shipping or free local store pickup (if available): - Apple... Read more

Jobs Board

*Apple* Enterprise / Government Professional...
# Apple Enterprise / Gove ment Professional Services Engineer Job Number: 42292976 Reston, Virginia, United States Posted: Aug. 18, 2015 Weekly Hours: 40.00 **Job Read more
iOS Wallet & *Apple* Pay Engineer - App...
# iOS Wallet & Apple Pay Engineer Job Number: 40586801 Santa Clara Valley, Califo ia, United States Posted: Nov. 16, 2015 Weekly Hours: 40.00 **Job Summary** The iOS Read more
Software Engineer, *Apple* Watch - Clock Fa...
# Software Engineer, Apple Watch - Clock Face Team Job Number: 44368761 Santa Clara Valley, Califo ia, United States Posted: Nov. 14, 2015 Weekly Hours: 40.00 **Job Read more
Administrative Assistant, *Apple* Online St...
# Administrative Assistant, Apple Online Store Job Number: 43992352 Santa Clara Valley, Califo ia, United States Posted: Nov. 9, 2015 Weekly Hours: 40.00 **Job Summary** Read more
*Apple* Retail - Multiple Positions (US) - A...
Sales Specialist - Retail Customer Service and Sales Transform Apple Store visitors into loyal Apple customers. When customers enter the store, you're also the Read more
All contents are Copyright 1984-2011 by Xplain Corporation. All rights reserved. Theme designed by Icreon.