US20050248791A1 - Printer description file format generator - Google Patents

Printer description file format generator Download PDF

Info

Publication number
US20050248791A1
US20050248791A1 US11/180,960 US18096005A US2005248791A1 US 20050248791 A1 US20050248791 A1 US 20050248791A1 US 18096005 A US18096005 A US 18096005A US 2005248791 A1 US2005248791 A1 US 2005248791A1
Authority
US
United States
Prior art keywords
ppd
file
base
printer
language
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Abandoned
Application number
US11/180,960
Inventor
Saeed Ganji
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Electronics for Imaging Inc
Original Assignee
Electronics for Imaging Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Electronics for Imaging Inc filed Critical Electronics for Imaging Inc
Priority to US11/180,960 priority Critical patent/US20050248791A1/en
Assigned to ELECTRONICS FOR IMAGING, INC. reassignment ELECTRONICS FOR IMAGING, INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: GANJI, SAEED
Publication of US20050248791A1 publication Critical patent/US20050248791A1/en
Abandoned legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/12Digital output to print unit, e.g. line printer, chain printer
    • G06F3/1201Dedicated interfaces to print systems
    • G06F3/1202Dedicated interfaces to print systems specifically adapted to achieve a particular effect
    • G06F3/1203Improving or facilitating administration, e.g. print management
    • G06F3/1204Improving or facilitating administration, e.g. print management resulting in reduced user or operator actions, e.g. presetting, automatic actions, using hardware token storing data
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/12Digital output to print unit, e.g. line printer, chain printer
    • G06F3/1201Dedicated interfaces to print systems
    • G06F3/1202Dedicated interfaces to print systems specifically adapted to achieve a particular effect
    • G06F3/1203Improving or facilitating administration, e.g. print management
    • G06F3/1206Improving or facilitating administration, e.g. print management resulting in increased flexibility in input data format or job format or job type
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/12Digital output to print unit, e.g. line printer, chain printer
    • G06F3/1201Dedicated interfaces to print systems
    • G06F3/1223Dedicated interfaces to print systems specifically adapted to use a particular technique
    • G06F3/1224Client or server resources management
    • G06F3/1227Printer definition files
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/12Digital output to print unit, e.g. line printer, chain printer
    • G06F3/1201Dedicated interfaces to print systems
    • G06F3/1278Dedicated interfaces to print systems specifically adapted to adopt a particular infrastructure
    • G06F3/1285Remote printer device, e.g. being remote from client or server
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/12Digital output to print unit, e.g. line printer, chain printer
    • G06F3/1201Dedicated interfaces to print systems
    • G06F3/1202Dedicated interfaces to print systems specifically adapted to achieve a particular effect
    • G06F3/121Facilitating exception or error detection and recovery, e.g. fault, media or consumables depleted
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/12Digital output to print unit, e.g. line printer, chain printer
    • G06F3/1201Dedicated interfaces to print systems
    • G06F3/1202Dedicated interfaces to print systems specifically adapted to achieve a particular effect
    • G06F3/1211Improving printing performance
    • G06F3/1212Improving printing performance achieving reduced delay between job submission and print start
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/12Digital output to print unit, e.g. line printer, chain printer
    • G06F3/1201Dedicated interfaces to print systems
    • G06F3/1223Dedicated interfaces to print systems specifically adapted to use a particular technique
    • G06F3/1237Print job management
    • G06F3/1244Job translation or job parsing, e.g. page banding

Definitions

  • the invention relates to PostScript® Printer Description (PPD) files and more particularly to computer processes and systems for generating PPD files for printers.
  • PPD file is a text file that describes the printer features unique to particular printers in particular environments to the PostScript printer driver(s) available for that environment.
  • Ubiquitous PostScript printer driver executable program files are used to provide communications between an application program and PostScript-enabled printers residing on the network.
  • Each PPD file contains certain phrases that describe what a particular printer is capable of doing.
  • PPD files are commonly created by manufacturers of PostScript printers.
  • the driver is created either by Adobe Systems, Inc., the creators of PostScript language, or by provider of the particular operating system the user is using (whether it be Microsoft Corporation in case of Windows or Apple Computer Corporation in case of Macintosh), or it is sometimes provided by manufacturers of different application programs that a user may be using.
  • a PPD file is not a printer driver. It is an information file in ASCII format that is used by a printer driver loaded by an operating system or application program. Because PPDs are all written in ASCII-text format, they are not limited to a specific software environment or platform. An ASCII-text PPD file can therefore be used equally well in Windows, MAC-OS, and UNIX environments, and by a variety of software applications. Adobe Systems, Inc. has defined how PPD files must be constructed by printer and software vendors in the “PPD Specification,” now at version 4.3.
  • a PPD file contains information that describe the capabilities of a particular printer to a printer driver.
  • the driver then communicates some of this information to the end-user and allows him to choose certain features suited to the file being printed. For example, if the printer in question is color capable, has duplexing (ability to print to both sides of the page), and supports paper sizes Letter, Legal, and Tabloid, then printer drivers having access to this PPD are capable of providing this information to user using common user interface features such as popup menus and radio buttons.
  • the user selects a combination of the features available on that particular printer to be used when the data is at some point being printed. For example, a user may choose to print a certain word processing document to a letter-size page in black and white mode while the same or another user may decide to print another file containing graphics to a tabloid-size page in color.
  • the invention provides a PPD generator that generates all the necessary PPD files for all supported platforms and languages for the print engines in a particular manufacturer's product line from one or more base PPDs.
  • the PPD generator uses an associated build file that contains information as to how the base PPDs are to be edited for all the supported languages, as well as exceptions to standard features attendant with a particular target platform/language.
  • the PPD generator includes the following components: First, there is an initial setup section where several flags, or variables, are set to initial values that are used during the PPD generation process. Second, there is a routine set of procedures that are performed on almost all PPDs with small variations based on the initial flag values. Thirdly, there is a component that uses information contained in the build file to change further and shape some of the generated PPDs based on unique criteria that are specific to that particular product line's PPDs.
  • the invention enables maximum flexibility because an engineer can provide specific information regarding the needed changes for each platform, and it is only necessary, in most situations, to work on the single base PPD for each new revision after the build file is first created.
  • the invention saves a significant amount of time that would otherwise be used to perform cut-and-paste operations, it minimizes the potential for human errors, it takes very little time to setup in most cases, and it provides an expansive method of customizing any number of PPDs based on the specific needs of a particular project.
  • Table I illustrates how the number of PPD files that need to be supplied for each printer or application program can proliferate. A different PPD file is needed in each user application environment.
  • TABLE I Typical PPD File Constellation Mac PC UNIX English English-Mac English-PC English- UNIX French French-Mac French-PC French- UNIX German German-Mac German-PC German- UNIX Japanese Japanese-Mac Japanese-PC Japanese- UNIX
  • the words or phrases, letter, legal, A4, or tabloid are supplied by the base PPD 201 .
  • the fact that such paper sizes can each be selected at all is also supplied by the base PPD.
  • the computer platform for the operating system matters because some platforms cannot support particular features of the printer that other platforms can. Because the base PPD is a text file, and not executable code, the platform differences appear only as PostScript® and text string differences.
  • Each base PPD comprises a text file of instructions and user strings that can be translated.
  • One object of the invention is to provide a PPD generator to translate such portions.
  • FIG. 1 is a block diagram that shows the interaction between the PPD, the PostScript printer driver, the printer, and the user;
  • FIG. 2 is a functional block diagram that shows how the base PPD and the build file interact with the PPD generator to create all the PPD files necessary to the project.
  • FIG. 1 is a block diagram that shows the interaction between a PPD, a PostScript printer driver, a printer, and an end user.
  • the end user 20 operates a computer that is running a particular application program 18 , such as Microsoft Word or Adobe PhotoShop.
  • a print file is sent to the PostScript printer driver 12 .
  • the PostScript printer driver accesses a PPD file 10 which describes the capabilities of a particular printer 14 to the printer driver.
  • the driver then communicates some of this information to the end-user and, as a result of a user dialog 14 , allows him to choose certain features suited to the file being printed.
  • the user selects a combination of the features available on that particular printer to be used when the data are at some point being printed.
  • FIG. 2 is a functional block diagram that shows how a base PPD and a build file interact with a PPD generator in the system 200 to create all the PPD files necessary for a project.
  • a project is a PPD file for a specific language/platform combination, e.g. French and Unix.
  • one or more base PPDs 201 are provided, where a base PPD is provided for each print engine in a particular manufacturer's product platform. For example, for the Xerox ZX Fiery product, a separate base PPD is provided for the 5750 and 5760 copier models.
  • a base PPD is best thought of as a quasi-PPD file that is used as a template during the PPD generation process.
  • the base PPD essentially mimics the PPD for one particular language and platform combination, for example, English-Macintosh.
  • the original design is expressed only once in the base PPDs using the English-Macintosh version.
  • This one parent or source is used by the PPD generator 202 in the automatic generation of all the other PPDs, e.g., for all other language/platform combinations 203 - 1 to 203 - n and 207 - 1 to 207 - n .
  • the conventional method of manually constructing each combinational PPD file is entirely avoided.
  • each base PPD is a text file that includes PostScript phrases and corresponding dialog window text strings that are related to particular features and user choices for a printer.
  • the exact construction of a PPD file is described by Adobe Systems, Inc. (Sunnyvale, Calif.) in their widely circulated publication titled, PPD Specification, now at version 4.3.
  • the base PPD provides the generic framework needed to generate all PPD file varieties for a particular printer.
  • PPD frameworks have components that must be tailored for the kind of platforms used and the natural language that users must see in page setup and printer setup dialog boxes.
  • the kinds of platforms can include WINDOWS, MacOS, UNIX, and OS/2.
  • the kinds of languages can include, for example, English, French, German, and Japanese.
  • Each such combination of platform and language is represented collectively by a project PPD file 203 - 1 to 203 - n and 207 - 1 to 207 - n .
  • the PPD generator 202 is a generation engine that contains a routine set of operations that are found in all PPDs for all language and platform combinations.
  • the invention also includes a build file 205 which (in the presently preferred embodiment of the invention) includes a single line for each base PPD that tells the PPD generator which languages must be created for converting that particular base PPD into all the varieties represented by the target PPD files 203 - 1 to 203 - n and 207 - 1 to 207 - n .
  • the build file is used primarily to take care of platform specific issues. For example, if for some reason it is desired that the Windows 95 translation be different than all of the rest, a section is added to the build file that expresses that difference.
  • the actual information that is necessary for a language translation e.g., where an English word in a print dialog should be replaced by a French, is part of the PPD generator.
  • the build file may specify that the Xerox 5750 PPDs are to include French, while the Xerox 5760 PPDs are to include Italian.
  • the actual translation files are not unique to a particular product line and are executed as part of the PPD generator.
  • one of the settings in the initial setup may be a variable named, e.g., OEMVersion. Based on that setting, a translation file in the PPD generator behaves differently for each printer manufacturer by using if statements.
  • the initial settings are: Set OEMVersion “Xerox.”
  • Design changes and bug fixes are accommodated by changing the base PPD files and then running the PPD generator so that it generates a new group of PPD files for all platform/language combinations.
  • the build file is used to identify a particular product's peculiarities to the PPD generator and to instruct the PPD generator with regard to these peculiarities.
  • the PPD generator applies a default set of translations to the base PPDs, while the build file identifies both normal operations, such as language translations, and specific exceptions to the default that must be taken into account for the project PPD.
  • the PPD generator produces the project PPD as a result of its interaction with both the base PPDs and the build file.
  • each base PPD has its own section in that project's build file.
  • each PPD may alternatively have an associated build file in other embodiments of the invention.
  • a base PPD file may be used for a virtually unlimited number of projects, where such projects can exist simultaneously for mass-marketed products, such as printers. Typically, only one set of base PPDs exists at the original equipment manufacturer's location. Key to the invention is the fact that a base PPD may be specified for any number of target projects and that a build file may be provided for project specific exceptions to a default conversion. Thus, the system assumes certain generic functions are to be provided for all PPDs that are generated, but these functions are easily reverted or changed, based upon specific project requirements. Further, system revisions are readily propagated throughout a product line to each language/platform combination by the simple expedient of changing the base PPDs and build file as appropriate. This avoids the need to rebuild each PPD manually for each project and language/platform combination.
  • Table II represents an English-language type PPD file.
  • Table III represents a corresponding French-language type PPD file for the same printer.
  • the build file for each project describes the build required for a particular printer to a main script in the PPD generator, e.g. a Canon versus a Xerox.
  • the PPD generator opens the build file and searches for particular strings in the build file. If it finds them, then it knows something has to be done. Otherwise, it assumes nothing special needs to take place for that particular project.
  • the input to the system is a base PPD file.
  • This is usually the Macintosh-English PPD, or a file that closely resembles the Mac/English PPD.
  • the purpose is to translate the base PPD to different languages and also different platforms as needed by the project.
  • the build file that contains information, parsable by the PPD generator, as to how the required project PPD(s) is different from a standard PPD generated solely based on default methods built into the generator. For example, assume we have a Xerox and then a Canon PPD.
  • the build file in each case instructs the scripting system how to go about doing each particular product's PPDs.
  • the Xerox PPD may ship only for English and French languages, but the Canon may include also Italian and Japanese, and may also have other differences.
  • Pseudo-code is used in Table V to state the operation in a way that resembles high level programming language.
  • TABLE V for each PPD in the “original PPD's” folder find the section in the build file corresponding to this PPD for each language from the build file for this PPD # start with Mac PPD duplicate the PPD to “Macintosh: ⁇ language ⁇ :” folder perform the English-> ⁇ language ⁇ translations # time to do windows PPD's, starting with Win31 duplicate the Mac PPD to “ ⁇ Language ⁇ :Win31:” folder perform Mac->win31 operations # now Windows 95/98 Duplicate the Win31 PPD to win95 folder perform Win31 ->win95 operations # repeat with win_nt_4.0 and win_nt_3.5 and if # needed (from the build file), also the OS/2 PPD's # here we look perform platform specific changes for each platform search build file for platform specific changes if found, perform these operations on needed PPDs end for each platform end of for each language end of for each P

Abstract

The conventional generation of original and design-change PPD files for printer drivers is tedious and prone to error as each version for a language-platform combination is constructed. The invention generates all the necessary PPD files for any needed platform/language combination from one or more base PPDs and one or more build files. A PPD generator draws on the information contained in the base PPD and build files to construct all the combinational varieties needed to support different languages and platforms, while providing an efficient and flexible environment for doing so.

Description

    REFERENCE TO RELATED APPLICATIONS
  • This application is a continuation of U.S. application Ser. No. 09/346,354, filed 2 Jul. 1999.
  • BACKGROUND
  • The invention relates to PostScript® Printer Description (PPD) files and more particularly to computer processes and systems for generating PPD files for printers. A PPD file is a text file that describes the printer features unique to particular printers in particular environments to the PostScript printer driver(s) available for that environment. Ubiquitous PostScript printer driver executable program files are used to provide communications between an application program and PostScript-enabled printers residing on the network. Each PPD file contains certain phrases that describe what a particular printer is capable of doing. PPD files are commonly created by manufacturers of PostScript printers. The driver is created either by Adobe Systems, Inc., the creators of PostScript language, or by provider of the particular operating system the user is using (whether it be Microsoft Corporation in case of Windows or Apple Computer Corporation in case of Macintosh), or it is sometimes provided by manufacturers of different application programs that a user may be using.
  • A PPD file is not a printer driver. It is an information file in ASCII format that is used by a printer driver loaded by an operating system or application program. Because PPDs are all written in ASCII-text format, they are not limited to a specific software environment or platform. An ASCII-text PPD file can therefore be used equally well in Windows, MAC-OS, and UNIX environments, and by a variety of software applications. Adobe Systems, Inc. has defined how PPD files must be constructed by printer and software vendors in the “PPD Specification,” now at version 4.3.
  • In general, a PPD file contains information that describe the capabilities of a particular printer to a printer driver. The driver then communicates some of this information to the end-user and allows him to choose certain features suited to the file being printed. For example, if the printer in question is color capable, has duplexing (ability to print to both sides of the page), and supports paper sizes Letter, Legal, and Tabloid, then printer drivers having access to this PPD are capable of providing this information to user using common user interface features such as popup menus and radio buttons. The user then selects a combination of the features available on that particular printer to be used when the data is at some point being printed. For example, a user may choose to print a certain word processing document to a letter-size page in black and white mode while the same or another user may decide to print another file containing graphics to a tabloid-size page in color.
  • It is an unfortunate fact for the manufacturer of PPDs that all PostScript printer drivers that claim to conform to the Adobe PPD Specifications often do not behave in exact manners when using a PPD. There are several gray area situations in which a PPD file that works correctly for one printer driver, may fail in part when used by another driver. As a result, a manufacturer of PPDs has to provide several PPD files that are each suited for a particular environment so that a majority of potential users can take advantage of their benefits. One such situation arises with PPD files for languages other than English. Since PPD files contain strings used in user-interface dialogs, these strings need to be translated for all supported languages. The way different drivers interpret non-English characters, such as “graves,” “acutes” and “umlates”, are different on different platforms. So a French PPD for the Macintosh platform is different than a PPD for Windows 3.1 at least when it comes to these strings. These PPDs may also be different due to technical reasons determined by the printer/PPD manufacturer. For example, the manufacturer may decide that a certain feature is to be supported only on Windows 95/98 platforms but not on Windows NT.
  • The conventional method of generating PPD files for different platforms and languages involves a significant amount of manual typing or “copy and paste” operations. This is an overwhelming task. Let us assume that at some point during the development of a printer, an engineer working for the printer manufacturing company is assigned the task of adding support for a new pagesize, A4, to all the PPDs pertaining to that product. The challenge is two-fold. First, he must come up with the ASCII text segments that must be added or changed in the existing PPD. Secondly, he must make these changes to every PPD the company is shipping for that printer. If the product line supports three languages and four platforms, he is faced with the daunting task of editing twelve (3 languages×4 platforms) files. The conventional method, therefore, can be described as time-consuming and prone to human errors as each revision for a language-platform combination is constructed.
  • It would be advantageous to provide a system that generates all the necessary PPD files for all platforms and languages from a single source.
  • SUMMARY
  • The invention provides a PPD generator that generates all the necessary PPD files for all supported platforms and languages for the print engines in a particular manufacturer's product line from one or more base PPDs. The PPD generator uses an associated build file that contains information as to how the base PPDs are to be edited for all the supported languages, as well as exceptions to standard features attendant with a particular target platform/language.
  • The PPD generator includes the following components: First, there is an initial setup section where several flags, or variables, are set to initial values that are used during the PPD generation process. Second, there is a routine set of procedures that are performed on almost all PPDs with small variations based on the initial flag values. Thirdly, there is a component that uses information contained in the build file to change further and shape some of the generated PPDs based on unique criteria that are specific to that particular product line's PPDs.
  • The invention enables maximum flexibility because an engineer can provide specific information regarding the needed changes for each platform, and it is only necessary, in most situations, to work on the single base PPD for each new revision after the build file is first created. Thus, the invention saves a significant amount of time that would otherwise be used to perform cut-and-paste operations, it minimizes the potential for human errors, it takes very little time to setup in most cases, and it provides an expansive method of customizing any number of PPDs based on the specific needs of a particular project.
  • Table I illustrates how the number of PPD files that need to be supplied for each printer or application program can proliferate. A different PPD file is needed in each user application environment.
    TABLE I
    Typical PPD File Constellation
    Mac PC UNIX
    English English-Mac English-PC English-
    UNIX
    French French-Mac French-PC French-
    UNIX
    German German-Mac German-PC German-
    UNIX
    Japanese Japanese-Mac Japanese-PC Japanese-
    UNIX
  • The reason that natural languages must be involved is that a printer driver must ask a user what printer features are to be selected. To do this, various spaces in conventional windows-type dialog boxes are presented on the computer screen. These spaces must be painted with an appropriate phrase scripted in the user's language. For example, it is very common for a printer driver literally to ask a user if letter, legal, A4, or tabloid paper sizes are to be used in a print job. The user's selection is made by pressing a radio button in the dialog box, and this choice is used to setup the preferences for the printer.
  • The words or phrases, letter, legal, A4, or tabloid are supplied by the base PPD 201. The fact that such paper sizes can each be selected at all is also supplied by the base PPD. The computer platform for the operating system matters because some platforms cannot support particular features of the printer that other platforms can. Because the base PPD is a text file, and not executable code, the platform differences appear only as PostScript® and text string differences.
  • Each base PPD comprises a text file of instructions and user strings that can be translated. One object of the invention is to provide a PPD generator to translate such portions.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • Features of the present invention can be more clearly understood from the following detailed description considered in conjunction with the following drawings, in which the same reference numerals denote the same elements throughout, and in which:
  • FIG. 1 is a block diagram that shows the interaction between the PPD, the PostScript printer driver, the printer, and the user; and
  • FIG. 2 is a functional block diagram that shows how the base PPD and the build file interact with the PPD generator to create all the PPD files necessary to the project.
  • DETAILED DESCRIPTION
  • FIG. 1 is a block diagram that shows the interaction between a PPD, a PostScript printer driver, a printer, and an end user. In such system 100, the end user 20 operates a computer that is running a particular application program 18, such as Microsoft Word or Adobe PhotoShop. When the user wants to print from the program, a print file is sent to the PostScript printer driver 12. The PostScript printer driver accesses a PPD file 10 which describes the capabilities of a particular printer 14 to the printer driver. The driver then communicates some of this information to the end-user and, as a result of a user dialog 14, allows him to choose certain features suited to the file being printed. The user then selects a combination of the features available on that particular printer to be used when the data are at some point being printed.
  • FIG. 2 is a functional block diagram that shows how a base PPD and a build file interact with a PPD generator in the system 200 to create all the PPD files necessary for a project. For purposes of the discussion herein, a project is a PPD file for a specific language/platform combination, e.g. French and Unix. In the preferred embodiment of the invention, one or more base PPDs 201 are provided, where a base PPD is provided for each print engine in a particular manufacturer's product platform. For example, for the Xerox ZX Fiery product, a separate base PPD is provided for the 5750 and 5760 copier models. For purposes of the discussion herein, a base PPD is best thought of as a quasi-PPD file that is used as a template during the PPD generation process.
  • The base PPD essentially mimics the PPD for one particular language and platform combination, for example, English-Macintosh. Thus, the original design is expressed only once in the base PPDs using the English-Macintosh version. This one parent or source is used by the PPD generator 202 in the automatic generation of all the other PPDs, e.g., for all other language/platform combinations 203-1 to 203-n and 207-1 to 207-n. Thus, the conventional method of manually constructing each combinational PPD file is entirely avoided.
  • In the preferred embodiment of the invention, each base PPD is a text file that includes PostScript phrases and corresponding dialog window text strings that are related to particular features and user choices for a printer. The exact construction of a PPD file is described by Adobe Systems, Inc. (Sunnyvale, Calif.) in their widely circulated publication titled, PPD Specification, now at version 4.3.
  • The base PPD provides the generic framework needed to generate all PPD file varieties for a particular printer. Such PPD frameworks have components that must be tailored for the kind of platforms used and the natural language that users must see in page setup and printer setup dialog boxes. For example, the kinds of platforms can include WINDOWS, MacOS, UNIX, and OS/2. The kinds of languages can include, for example, English, French, German, and Japanese. Each such combination of platform and language is represented collectively by a project PPD file 203-1 to 203-n and 207-1 to 207-n. The PPD generator 202 is a generation engine that contains a routine set of operations that are found in all PPDs for all language and platform combinations.
  • The invention also includes a build file 205 which (in the presently preferred embodiment of the invention) includes a single line for each base PPD that tells the PPD generator which languages must be created for converting that particular base PPD into all the varieties represented by the target PPD files 203-1 to 203-n and 207-1 to 207-n. The build file is used primarily to take care of platform specific issues. For example, if for some reason it is desired that the Windows 95 translation be different than all of the rest, a section is added to the build file that expresses that difference. The actual information that is necessary for a language translation, e.g., where an English word in a print dialog should be replaced by a French, is part of the PPD generator. For example, the build file may specify that the Xerox 5750 PPDs are to include French, while the Xerox 5760 PPDs are to include Italian. The actual translation files are not unique to a particular product line and are executed as part of the PPD generator.
  • Furthermore, if two different printer manufacturers want different translation strings to be used for the same English word, for example, where the English string “Plain paper” is translated for one OEM as “Papier normal,” and for another as “Papier ordinaire,” one of the settings in the initial setup may be a variable named, e.g., OEMVersion. Based on that setting, a translation file in the PPD generator behaves differently for each printer manufacturer by using if statements. Thus, in this embodiment of the invention the initial settings are: Set OEMVersion “Xerox.”
  • When the actual translation scripts are running, and it is time for the English_to_French script, the translation scripts have a line, such as:
    if { OEMVersion } == “Xerox”
    translate “Plain paper” this way
    elseif { OEMVersion } == “Canon”
    translate “Plain paper” this other way
    else
    translate “Plain paper” that way
    end
  • Design changes and bug fixes are accommodated by changing the base PPD files and then running the PPD generator so that it generates a new group of PPD files for all platform/language combinations. The build file is used to identify a particular product's peculiarities to the PPD generator and to instruct the PPD generator with regard to these peculiarities. Thus, the PPD generator applies a default set of translations to the base PPDs, while the build file identifies both normal operations, such as language translations, and specific exceptions to the default that must be taken into account for the project PPD. The PPD generator produces the project PPD as a result of its interaction with both the base PPDs and the build file.
  • Note: In the preferred embodiment of the invention, there is only one build file for each project (i.e., Xerox ZX). Each base PPD has its own section in that project's build file. However, each PPD may alternatively have an associated build file in other embodiments of the invention.
  • A base PPD file may be used for a virtually unlimited number of projects, where such projects can exist simultaneously for mass-marketed products, such as printers. Typically, only one set of base PPDs exists at the original equipment manufacturer's location. Key to the invention is the fact that a base PPD may be specified for any number of target projects and that a build file may be provided for project specific exceptions to a default conversion. Thus, the system assumes certain generic functions are to be provided for all PPDs that are generated, but these functions are easily reverted or changed, based upon specific project requirements. Further, system revisions are readily propagated throughout a product line to each language/platform combination by the simple expedient of changing the base PPDs and build file as appropriate. This avoids the need to rebuild each PPD manually for each project and language/platform combination.
  • Table II represents an English-language type PPD file. Table III represents a corresponding French-language type PPD file for the same printer.
    TABLE II
    English-Language PPD
    *OpenUI *EFCompression/Compression :PickOne
    *OrderDependency: 05.0 AnySetup *EFCompression
    *DefaultEFCompression: SCDefault
    *EFCompression SCDefault/Printer's Default: ““
    *EFCompression False/Off: “userdict/XJXsetRenderType known
    { (ADOBE) XJXsetRenderType }
    if“
    *End
    *EFCompression True/On: “userdict/XJXsetRenderType known
    { (AREND) XJXsetRenderType }
    if“
    *End
    *CloseUI: *EFCompression
  • TABLE III
    French-Language PPD
    *OpenUI *EFCompression/Compression :PickOne
    *OrderDependency: 05.0 AnySetup*EFCompression
    *DefaultEFCompression: SCDefault
    *EFCompression SCDefault/Imprimante par défaut: ““
    *EFCompression False/Non: “userdict/XJXsetRenderType known
    { (ADOBE) XJXsetRenderType }
    if“*
    End
    *EFCompression True/Oui: “ userdict/XJXsetRenderType known
    { (AREND) XJXsetRenderType }
    if“
    *End
    *CloseUI: *EFCompression
  • All the text strings in between a slash and colon pair are translated using automated scripts in the PPD generator. For example, in Table II, line 3, “Printer's Default” in English is replaced in Table III, line 3, by the French “Imprimante par defaut.” Also, in Table II, line 7, “On” in English is replaced in Table III, line 7, by the French “Oui.” These text strings are output to the user in a dialog by printer driver 12 (FIG. 1). The base PPD has only one of the necessary strings, all the others are translated by lookup files in the build file 205. Each time there is to be a design change, e.g., to add a new printer feature or modify an existing one, all the PPD files 203-1 to 203-n and 207-1 to 207-n for all the different languages and platforms are automatically generated by the PPD generator using the base PPDs and the build file. This is much faster in the manufacturing environment than trying to do a manual copy-and-paste operation one-at-a-time on each of PPD files.
  • The build file for each project describes the build required for a particular printer to a main script in the PPD generator, e.g. a Canon versus a Xerox. The PPD generator opens the build file and searches for particular strings in the build file. If it finds them, then it knows something has to be done. Otherwise, it assumes nothing special needs to take place for that particular project. For example, Table IV is a portion of a build file.
    TABLE IV
    == new Mac only modifications
    find ∘
    replace/”*OpenUI *InputSlotRest”/:/”*CloseUI: *InputSlotRest”/ ““
    find ∘
    replace/”*OpenUI *InputSlotFirst”/:/”*CloseUI: *InputSlotFirst”/ ““
    == end modifications
  • The PPD generator searches the build file for “==new Mac only modifications”. If found, it executes everything between that and “==end modifications”.
  • In the above example, there are two “find the top of file” commands and two replace commands. One command replaces everything between “*OpenUI *InputSlotRest” and “*CloseUI: *InputSlotRest” with a blank (deleting them), and the next replace command similarly provides a delete function.
  • The input to the system is a base PPD file. This is usually the Macintosh-English PPD, or a file that closely resembles the Mac/English PPD. The purpose is to translate the base PPD to different languages and also different platforms as needed by the project. Along with the needed base PPD(s), there is also the build file that contains information, parsable by the PPD generator, as to how the required project PPD(s) is different from a standard PPD generated solely based on default methods built into the generator. For example, assume we have a Xerox and then a Canon PPD. The build file in each case instructs the scripting system how to go about doing each particular product's PPDs. The Xerox PPD may ship only for English and French languages, but the Canon may include also Italian and Japanese, and may also have other differences.
  • Pseudo-code is used in Table V to state the operation in a way that resembles high level programming language.
    TABLE V
    for each PPD in the “original PPD's” folder
    find the section in the build file corresponding to this PPD
    for each language from the build file for this PPD
    # start with Mac PPD
    duplicate the PPD to “Macintosh: {language} :” folder
    perform the English-> {language} translations
    # time to do windows PPD's, starting with Win31
    duplicate the Mac PPD to “{Language} :Win31:” folder
    perform Mac->win31 operations
    # now Windows 95/98
    Duplicate the Win31 PPD to win95 folder
    perform Win31 ->win95 operations
    # repeat with win_nt_4.0 and win_nt_3.5 and if
    # needed (from the build file), also the OS/2 PPD's
    # here we look perform platform specific changes
    for each platform
    search build file for platform specific changes
    if found, perform these operations on needed PPDs
    end for each platform
    end of for each language
    end of for each PPD
  • Although the present invention is described herein with reference to the preferred embodiment, one skilled in the art will readily appreciate that other applications may be substituted for those set forth herein without departing from the spirit and scope of the present invention. Accordingly, the present invention should only be limited by the claims included below.

Claims (6)

1. A system for producing a PostScript® printer description (PPD) text file associated with a printer, the system comprising:
a base PPD text file that comprises information regarding the printer, the information including text in a first language, the base PPD text file adapted for a first software platform; and
a PPD generator adapted to import the base PPD text file and to generate therefrom a second PPD text file that includes text translated from the first language to a second language.
2. The system of claim 1, further comprising a build file that describes a product or platform specific set of features of the base PPD text file.
3. The system of claim 1, wherein the PPD generator parses the base PPD text file and the build file into text based instructions that may be parsed and assembled by PostScript® printer drivers.
4. The system of claim 1, wherein the PPD generator generates the second PPD file that is adapted for a second software platform.
5. A method for generating a PostScript® printer description (PPD) text file associated with a printer, the method comprising:
providing a base PPD text file that comprises information regarding the printer, the information including text in a first language, the base PPb text file adapted for a first software platform;
providing a build file that comprises information as to how the base PPD text file should be edited to provide a second PPD text file that includes text translated from the first language to a second language; and
implementing the build file to automatically generate the second PPD text file.
6. A method for revising a PostScript® printer description (PPD) text file associated with a printer, the method comprising:
providing a base PPD text file that comprises information regarding the printer, the information including text in a first language, the base PPD text file adapted for a first software platform, and a build file that comprises information as to how the base PPD text file should be edited to provide a second PPD text file that includes text translated from the first language to a second language;
modifying the base PPD text file to provide a revised PPD text file; and
implementing the build file to automatically generate a second PPD text file from the revised PPD text file.
US11/180,960 1999-07-02 2005-07-13 Printer description file format generator Abandoned US20050248791A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US11/180,960 US20050248791A1 (en) 1999-07-02 2005-07-13 Printer description file format generator

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US09/346,354 US7054015B1 (en) 1999-07-02 1999-07-02 Printer description file format generator
US11/180,960 US20050248791A1 (en) 1999-07-02 2005-07-13 Printer description file format generator

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US09/346,354 Continuation US7054015B1 (en) 1999-07-02 1999-07-02 Printer description file format generator

Publications (1)

Publication Number Publication Date
US20050248791A1 true US20050248791A1 (en) 2005-11-10

Family

ID=23359000

Family Applications (2)

Application Number Title Priority Date Filing Date
US09/346,354 Expired - Fee Related US7054015B1 (en) 1999-07-02 1999-07-02 Printer description file format generator
US11/180,960 Abandoned US20050248791A1 (en) 1999-07-02 2005-07-13 Printer description file format generator

Family Applications Before (1)

Application Number Title Priority Date Filing Date
US09/346,354 Expired - Fee Related US7054015B1 (en) 1999-07-02 1999-07-02 Printer description file format generator

Country Status (4)

Country Link
US (2) US7054015B1 (en)
EP (1) EP1194834A2 (en)
AU (1) AU768077B2 (en)
WO (1) WO2001002950A2 (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20110109933A1 (en) * 2009-05-15 2011-05-12 Canon U.S.A., Inc. Custom paper information converter

Families Citing this family (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2004192131A (en) * 2002-12-09 2004-07-08 Minolta Co Ltd Function setting program and function setting method for printer
US7872765B2 (en) * 2006-02-23 2011-01-18 Ricoh Company, Ltd. Non-postscript printer description file generating tool
US9224072B2 (en) 2011-11-29 2015-12-29 Google Inc. System and method for generating a user interface from a printer description

Citations (27)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4599691A (en) * 1982-05-20 1986-07-08 Kokusai Denshin Denwa Co., Ltd. Tree transformation system in machine translation system
US5392390A (en) * 1992-04-10 1995-02-21 Intellilink Corp. Method for mapping, translating, and dynamically reconciling data between disparate computer platforms
US5467435A (en) * 1992-07-10 1995-11-14 Microsoft Corporation System and method for mode switching
US5469533A (en) * 1992-07-10 1995-11-21 Microsoft Corporation Resource-oriented printer system and method of operation
US5471563A (en) * 1992-07-10 1995-11-28 Microsoft Corporation System and method for automatic resolution reduction
US5488458A (en) * 1995-05-08 1996-01-30 Xerox Corporation Duplex printing integrity system
US5559933A (en) * 1994-04-22 1996-09-24 Unisys Corporation Distributed enterprise print controller
US5566278A (en) * 1993-08-24 1996-10-15 Taligent, Inc. Object oriented printing system
US5625757A (en) * 1993-12-24 1997-04-29 Hitachi, Ltd. Printing system
US5699494A (en) * 1995-02-24 1997-12-16 Lexmark International, Inc. Remote replication of printer operator panel
US5713032A (en) * 1996-01-03 1998-01-27 Eastman Kodak Company Compound document processing system
US5715397A (en) * 1994-12-02 1998-02-03 Autoentry Online, Inc. System and method for data transfer and processing having intelligent selection of processing routing and advanced routing features
US5754748A (en) * 1996-09-13 1998-05-19 Lexmark International, Inc. Download of interpreter to a printer
US5754858A (en) * 1996-05-01 1998-05-19 Microsoft Corporation Customizable application project generation process and system
US5768564A (en) * 1994-10-07 1998-06-16 Tandem Computers Incorporated Method and apparatus for translating source code from one high-level computer language to another
US5857064A (en) * 1995-04-03 1999-01-05 Object Technology Licensing Corporation System for imaging complex graphical images
US5995724A (en) * 1996-11-01 1999-11-30 Mikkelsen; Carl Image process system and process using personalization techniques
US5993088A (en) * 1998-09-30 1999-11-30 International Business Machines Corporation Method for improving print performance and quality by accumulating, storing and using resource accounting information with a print job
US6049390A (en) * 1997-11-05 2000-04-11 Barco Graphics Nv Compressed merging of raster images for high speed digital printing
US6134018A (en) * 1997-09-26 2000-10-17 Electronics For Imaging, Inc. Method and apparatus for creating personalized documents that include variable data
US6281893B1 (en) * 1996-04-04 2001-08-28 Sun Microsystems, Inc. Method and apparatus for providing an object oriented approach to a device independent graphics control system
US6317873B1 (en) * 1998-10-14 2001-11-13 Alcatel Usa Sourcing, L.P. Assembly language translator
US6321372B1 (en) * 1998-12-23 2001-11-20 Xerox Corporation Executable for requesting a linguistic service
US6425118B1 (en) * 1997-07-18 2002-07-23 Compaq Computer Corporation System for automatically generating tests to ensure binary compatibility between software components produced by a source-to-source computer language translator
US6442663B1 (en) * 1998-06-19 2002-08-27 Board Of Supervisors Of Louisiana University And Agricultural And Mechanical College Data collection and restoration for homogeneous or heterogeneous process migration
US6467079B1 (en) * 1999-03-30 2002-10-15 International Business Machines Corporation Report program language source code translation to object-oriented language source code which emulates report program language behavior
US6711735B1 (en) * 1999-08-16 2004-03-23 Alcatel Method of automatic production of specifications

Family Cites Families (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5095512A (en) 1988-10-24 1992-03-10 Netexpress Systems, Inc. Method and apparatus for manipulating image data employing an intermediate format
US6119142A (en) 1995-04-25 2000-09-12 Canon Kabushiki Kaisha Data communication apparatus for managing information indicating that data has reached its destination
EP0741488A2 (en) 1995-05-03 1996-11-06 Agfa-Gevaert N.V. Automatic calibration for output devices based on device output mode
US6246485B1 (en) 1996-05-23 2001-06-12 Lexmark International, Inc. Printer communication system and method

Patent Citations (27)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4599691A (en) * 1982-05-20 1986-07-08 Kokusai Denshin Denwa Co., Ltd. Tree transformation system in machine translation system
US5392390A (en) * 1992-04-10 1995-02-21 Intellilink Corp. Method for mapping, translating, and dynamically reconciling data between disparate computer platforms
US5471563A (en) * 1992-07-10 1995-11-28 Microsoft Corporation System and method for automatic resolution reduction
US5467435A (en) * 1992-07-10 1995-11-14 Microsoft Corporation System and method for mode switching
US5469533A (en) * 1992-07-10 1995-11-21 Microsoft Corporation Resource-oriented printer system and method of operation
US5566278A (en) * 1993-08-24 1996-10-15 Taligent, Inc. Object oriented printing system
US5625757A (en) * 1993-12-24 1997-04-29 Hitachi, Ltd. Printing system
US5559933A (en) * 1994-04-22 1996-09-24 Unisys Corporation Distributed enterprise print controller
US5768564A (en) * 1994-10-07 1998-06-16 Tandem Computers Incorporated Method and apparatus for translating source code from one high-level computer language to another
US5715397A (en) * 1994-12-02 1998-02-03 Autoentry Online, Inc. System and method for data transfer and processing having intelligent selection of processing routing and advanced routing features
US5699494A (en) * 1995-02-24 1997-12-16 Lexmark International, Inc. Remote replication of printer operator panel
US5857064A (en) * 1995-04-03 1999-01-05 Object Technology Licensing Corporation System for imaging complex graphical images
US5488458A (en) * 1995-05-08 1996-01-30 Xerox Corporation Duplex printing integrity system
US5713032A (en) * 1996-01-03 1998-01-27 Eastman Kodak Company Compound document processing system
US6281893B1 (en) * 1996-04-04 2001-08-28 Sun Microsystems, Inc. Method and apparatus for providing an object oriented approach to a device independent graphics control system
US5754858A (en) * 1996-05-01 1998-05-19 Microsoft Corporation Customizable application project generation process and system
US5754748A (en) * 1996-09-13 1998-05-19 Lexmark International, Inc. Download of interpreter to a printer
US5995724A (en) * 1996-11-01 1999-11-30 Mikkelsen; Carl Image process system and process using personalization techniques
US6425118B1 (en) * 1997-07-18 2002-07-23 Compaq Computer Corporation System for automatically generating tests to ensure binary compatibility between software components produced by a source-to-source computer language translator
US6134018A (en) * 1997-09-26 2000-10-17 Electronics For Imaging, Inc. Method and apparatus for creating personalized documents that include variable data
US6049390A (en) * 1997-11-05 2000-04-11 Barco Graphics Nv Compressed merging of raster images for high speed digital printing
US6442663B1 (en) * 1998-06-19 2002-08-27 Board Of Supervisors Of Louisiana University And Agricultural And Mechanical College Data collection and restoration for homogeneous or heterogeneous process migration
US5993088A (en) * 1998-09-30 1999-11-30 International Business Machines Corporation Method for improving print performance and quality by accumulating, storing and using resource accounting information with a print job
US6317873B1 (en) * 1998-10-14 2001-11-13 Alcatel Usa Sourcing, L.P. Assembly language translator
US6321372B1 (en) * 1998-12-23 2001-11-20 Xerox Corporation Executable for requesting a linguistic service
US6467079B1 (en) * 1999-03-30 2002-10-15 International Business Machines Corporation Report program language source code translation to object-oriented language source code which emulates report program language behavior
US6711735B1 (en) * 1999-08-16 2004-03-23 Alcatel Method of automatic production of specifications

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20110109933A1 (en) * 2009-05-15 2011-05-12 Canon U.S.A., Inc. Custom paper information converter
US9405497B2 (en) * 2009-05-15 2016-08-02 Canon U.S.A. Inc. Custom paper information converter

Also Published As

Publication number Publication date
WO2001002950A3 (en) 2001-07-12
EP1194834A2 (en) 2002-04-10
US7054015B1 (en) 2006-05-30
AU6064700A (en) 2001-01-22
WO2001002950A2 (en) 2001-01-11
AU768077B2 (en) 2003-12-04

Similar Documents

Publication Publication Date Title
US6967728B1 (en) Reusable and transferable printer driver preference system
US7102768B2 (en) Printer drivers using filters that are operating system-independent and printer-independent
US6825941B1 (en) Modular and extensible printer device driver and text based method for characterizing printer devices for use therewith
US5353388A (en) System and method for document processing
US7466442B2 (en) Printing system and method for customization of a print job
US6765685B1 (en) Printing electronic documents with automatically interleaved separation sheets
US9013718B2 (en) Print control apparatus, control method thereof, and device driver for converting commands from one format to another
US20140204421A1 (en) Printer driver, storage medium, and information processing apparatus
US20110267628A1 (en) Information processing apparatus and computer program product
US6684260B1 (en) Maintaining consistency of device driver settings
US20020140958A1 (en) Page description language adapted for direct printing of multiple file formats
US20050248791A1 (en) Printer description file format generator
US20030074656A1 (en) Program execution apparatus and method, computer program for performing the program execution method, image forming system, and address solution method
JP4783225B2 (en) Print control program and information processing apparatus
US6684789B2 (en) Method and system for the transformation of digital print data streams and corresponding printer and printer server
JP3581463B2 (en) Information processing apparatus, printing apparatus, and data processing method
Rokicki DVIPS: A TEX Driver
JP2004038650A (en) Resource library, and method for generating help file
JPH11219269A (en) Printing system and printer server
JP3406706B2 (en) State variable management method
JP3406705B2 (en) Dictionary operation method
Winters International distributed systems—architectural and practical issues
LPS5003 PostScript Printer Description File Format Specification
JP2006186914A (en) Output control apparatus, output control method, program and recording medium
JPH06187108A (en) Document presentation controller

Legal Events

Date Code Title Description
AS Assignment

Owner name: ELECTRONICS FOR IMAGING, INC., CALIFORNIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:GANJI, SAEED;REEL/FRAME:016779/0347

Effective date: 19990616

STCB Information on status: application discontinuation

Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION