TweetFollow Us on Twitter

New PrGeneral

Volume Number: 13 (1997)
Issue Number: 6
Column Tag: develop

The New PrGeneral Version Opcode

by Ingrid Kelly

For the past 12 years, printer driver developers have used the print record's wDev field in the TPrStl data structure to store their device information. Specifically, they've consistently used the high-order byte of this field - commonly known as the wDev ID - to store the device code. Unfortunately, due to the design limitations of the print record and the wDev field, the Printing Manager allowed for a maximum of only 256 IDs. Surprisingly enough (ha ha), with the expansion of the printer market, we're running out of numbers! As a result, with LaserWriter driver version 8.4, we've added a PrGeneral opcode and new structures to the Printing Manager so that developers can work around this limitation.

Both printer driver and application developers need to add code to support this new information, but the changes are minimal. Accompanying this column on the MacTech Web site is a sample application, called PrGeneral Version, that shows you how to properly retrieve the new version information when your application is looking for the features of a particular printer driver.

The New PrGeneral Opcode:

kprversionop

LaserWriter driver version 8.4 introduced several new PrGeneral opcodes, including a new opcode for driver version information: kPrVersionOp. Using kPrVersionOp is now the recommended way for applications to find out the printer driver currently in use. Remember that for printer drivers that haven't updated to use this new PrGeneral opcode, your application needs to keep its wDev-checking code as well.

For more information on the extended print record opcodes introduced with LaserWriter version 8.4, read the Print Hints column "The All-New LaserWriter Driver Version 8.4" in develop Issue 27. There you'll find a table that lists all the other PrGeneral opcodes supported in Apple printer drivers. See the article "Meet PrGeneral, the Trap That Makes the Most of the Printing Manager" in develop Issue 3 for more information on PrGeneral.

What Printer Driver Developers Need to Know

From now on, Apple's Developer Support Center will assign all printer drivers a wDev ID of 255. If you have an old wDev ID number (which is less than 255), you should still use the number you were assigned so that you don't break any applications that vary their behavior based on your driver's wDev. In addition, you should implement the new kPrVersionOp opcode as described here so that new applications can take advantage of it with your driver.

Listing 1 shows the new opcode and structures that you'll need to implement in your PDEF 7 resource. You need to place your creator type in the driver.creator field of the TPrVersion structure. You should also place your version number in driver.release so that application developers know what version of the driver is available.

Listing 1. The new version opcode and structures

enum {
   ...
   kPrVersionOp = 22             // LaserWriter version 8.4 and later only
};

typedef struct {
   OSType     architecture;      // Architecture (for example, 'pwpc', 'm68k')
   OSType     creator;           // Driver's creator type (for example, 'AAPL')
   unsigned longrelease;         // Release number (for example, 0x8480)
   unsigned longinterfaces;      // Interfaces version (for example, 0x8480)
} TVersion;

typedef struct {
   short       iOpCode;          // Must be kPrVersionOp
   short       iError;           // For returning errors
   long        lReserved;        // Reserved, set to 0
   TVersion    driver;           // Driver information
   TVersion    reserved;         // Reserved, set to 0
} TPrVersion;

The release and interfaces fields have the same format as the first long in a 'vers' resource - that is, the following four 1-byte values: a major version number, a minor version number, a revision stage (development = 0x20, alpha = 0x40, beta = 0x60, and release = 0x80), and a prerelease version number.

That's all you'll need to do to support the new PrGeneral opcode in your driver - hard to believe, but true!

What Application Developers Need to Know

Although Apple doesn't recommend that application developers check the wDev field of the print record, many do. They assume that the wDev value means they can count on certain features being present in the printer. For instance, many developers assume that a wDev of 3 means the printer driver supports PostScript. In fact, it indicates only that the current printer uses the Apple LaserWriter driver. This leaves out the possibility that a user has a non-Apple PostScript printer driver with an ID of, say, 243.

Even though Apple doesn't recommend that application developers rely on the wDev field (or the new PrGeneral opcode, for that matter), if you're going to change application behavior based on the number or creator returned, at least do so properly so that your applications don't break with future releases of printer drivers. We recommend that you use the PrGeneral kPrVersionOp opcode, if available, to get the structure and then check the driver.creator and driver.release fields to determine the current printer driver and version (see Listing 1). You should also continue to support the old wDev method for printer drivers that have not yet updated to the new PrGeneral opcode. For your reference, the PrGeneral Version sample that accompanies this column shows how to properly retrieve the version and wDev information.

Go Forth and Print!

As you can see, the changes that printer driver and application developers need to make to support the new PrGeneral opcode are minimal. We've already adopted this new method with the LaserWriter version 8.4.x drivers. We hope you will, too!


WDEV Registration

Although from now on all printer drivers will be assigned a wDev ID of 255, we still request that you register your printer driver with Apple's Developer Support Center, to avoid creator type conflicts. To do so, register at http://www.devworld.apple.com/dev/wdev/. Here is the information you need to provide:

  • Company name and address
  • Contact name, phone number, and e-mail address
  • Make and model of device supported (for example, Apple LaserWriter 16/600)
  • Type of connection (for example, serial)
  • Creator type (for example, 'AAPL')

You'll receive confirmation of your registration within five to ten working days. If you have questions about wDev registration, write to devsupport@apple.com.


Related Reading

  • "Print Hints: The All-New LaserWriter Driver Version 8.4" by Dave Polaschek, develop Issue 27.
  • "Meet PrGeneral, the Trap that Makes the Most of the Printing Manager" by Pete "Luke" Alexander, develop Issue 3.

Ingrid Kelly (inge@apple.com) provides technical support for developers as a member of the Multimedia, Printing, Imaging, and Graphics group in Apple's Developer Technical Support. When she's not answering developer e-mails or trying to hold the record for most Technotes written in DTS, Ingrid can be found refilling her office candy bin, trying to come up with the ultimate chocolate chip cookie recipe, or attending Navy Blue Angels flight team demonstrations with her husband, Lance.

 
AAPL
$565.32
Apple Inc.
+0.00
MSFT
$29.07
Microsoft Corpora
+0.00
GOOG
$603.66
Google Inc.
+0.00
MacTech Search:
Community Search:

Empire of the Eclipse Review
Empire of the Eclipse Review By Carter Dotson on May 24th, 2012 Our Rating: :: OVERSHADOWINGiPhone App - Designed for the iPhone, compatible with the iPad Empire of the Eclipse is an ambitious strategy MMO that is very deep, and... | Read more »
Bejeweled HD Review
Bejeweled HD Review By Jennifer Allen on May 24th, 2012 Our Rating: :: ADDICTIVEiPad Only App - Designed for the iPad The iPad version of the ever addictive Match Three title.   Developer: PopCap Price: $3.99 Version Reviewed: 1... | Read more »
Facebook Releases New Camera App To Stre...
While not a replacement for Instagram, Facebook Camera is a good first step in this month+ old union of the two companies. Released today, Facebook camera looks to streamline the viewing of photos and the uploading of them. The app allows you to... | Read more »
Missile Monkey Review
Missile Monkey Review By Lisa Caplan on May 24th, 2012 Our Rating: :: FLYING LOWUniversal App - Designed for iPhone and iPad Missile Monkey is a must miss   Developer: Munsey Clan Games Price: $0.99 Version Reviewed: 1.0 Device... | Read more »
Boomlings Review
Boomlings Review By Lisa Caplan on May 24th, 2012 Our Rating: :: FUN FREEBIEUniversal App - Designed for iPhone and iPad Boomlings is a traditional matching puzzle game, with some explosive twists   | Read more »
Dave vs Cave Review
Dave vs Cave Review By Jason Wadsworth on May 24th, 2012 Our Rating: :: WATCH FOR FALLING ROCKSUniversal App - Designed for iPhone and iPad Kid falls down hole, kid gets trapped in cave, kid fights evil rock monsters to escape... | Read more »
Python Pocket Power: Python Bytes 3 – Mo...
Python fans are certain to welcome the best bits from the penultimate season of the BBC sketch comedy in a new iPhone app: Python Bytes 3 – Monty Python Series 3. If you have a flair for the obvious, you’ll correctly assume this is third in a series... | Read more »

Price Scanner via MacPrices.net

13″ 2.8GHz MacBook Pro on sale for $100 off MSRP
Adorama has lowered their price on the 13″ 2.8GHz MacBook Pro to $1399 including free shipping plus NY/NJ sales tax only. Their price is $100 off MSRP, and it’s the lowest price for this model from... Read more
Apple refurbished iPads available starting at $279
 The Apple Store Online has dropped prices on Apple Certified Refurbished iPad 2s and original iPads by as much as $50, with models now starting at $279. Apple’s one-year warranty is included with... Read more
Security Based Portable Operating System, Pocket D...
In conjunction with their consumer technology product, Pocket Desktop, a USB device that offers consumers enhanced security and portability in computing, has announced a new strategic alliance with... Read more
Apple’s Jonathan Ive Knighted By Britain’s Princes...
The BBC reports that Apple Senior Vice President Of Industrial Design Jonathan Ive is now Sir Jonathan Ive, having been knighted by Queen Elizabeth II’s daughter Anne, the Princess Royal (and an iPad... Read more
Microsoft Fixing to release Office for iOS and And...
BGR’s Jonathan S. Geller says BGR has learned from a “reliable source” that Microsoft is planning to release the company’s full Office suite for not only Apple’s iPad, but for Android tablets as well... Read more
Mac mini Server available for $949, $50 off MSRP
Adorama has Mac mini Servers on sale for $949 including free shipping. Their price is $50 off MSRP, and it’s the lowest price available for this model from any Apple Authorized Reseller. NY and NJ... Read more
21″ 2.7GHz iMac on sale for $1399, $100 off full r...
Adorama has the 21″ 2.7GHz iMac on sale for $1399 including free shipping. Their price is $100 off MSRP, and it’s the lowest price for this model from any Apple Authorized Reseller. NY and NJ sales... Read more
iMacs on sale bundled with free upgrade to 8GB RAM
MacConnection has 2011 iMacs in stock today with a free upgrade to 8GB of RAM. Shipping is also free. Their prices represent a $200+ savings over custom 8GB iMacs at The Apple Store: - 21″ 2.5GHz... Read more

Jobs Board

iPhone Mobile Developer at Mapmyfitness...
About MapMyFitness, Inc.: We're a well-funded and fast growing start-up. We're building the future of fitness applications on both the web and mobile. MapMyFitness is consistently ranked among the... Read more
Civil Engineering iPhone/iPad Applicatio...
I want to hire an application developer to design a universal iPhone/iPad application. The app is a calculator for civil engineers. Please see the attached Scope of Work. Desired Skills: iPhone, iPad... Read more
Helpdesk Support Technician - Mac Expert...
Mac hardwaresoftware preferably as a Mac Genius or Apple technician Demonstrated ability to troubleshoot ... in Mac OS X/Windows OS administration, exp supporting Mac, certified Apple and/or Windows... Read more
Mac Expert - Apple Online Store at Apple...
before calling a helpdesk for assistance). Description The Mac Expert is responsible for providing consultative ... to be effective, the Mac Expert will be knowledgeable about Mac product features... Read more
iOS Developer (iPhone and iPad) at Mahal...
Mahalo is looking for talented iOS developers to join its team of highly skilled engineers. Weve already released multiple successful apps in the Apple App Store with well over a million installs... Read more
All contents are Copyright 1984-2011 by Xplain Corporation. All rights reserved. Theme designed by Icreon.