
This translation guide provides instructions for creating translations of the CUPS message catalogs and web pages for the Common UNIX Printing System ("CUPS") Version 1.1 software.
CUPS provides a portable printing layer for UNIX®-based operating systems. It has been developed by Easy Software Products to promote a standard printing solution for all UNIX vendors and users. CUPS provides the System V and Berkeley command-line interfaces.
CUPS uses the Internet Printing Protocol ("IPP") as the basis for managing print jobs and queues. The Line Printer Daemon ("LPD") Server Message Block ("SMB"), and AppSocket (a.k.a. JetDirect) protocols are also supported with reduced functionality. CUPS adds network printer browsing and PostScript Printer Description ("PPD") based printing options to support real-world printing under UNIX.
CUPS also includes a customized version of GNU Ghostscript (currently based off GNU Ghostscript 5.50) and an image file RIP that are used to support non-PostScript printers. Sample drivers for HP and EPSON printers are included that use these filters.
This translation guide is organized into the following sections:
The following CUPS documentation is referenced by this document:
The following non-CUPS documents are referenced by this document:
CUPS uses character set files to define the mapping of local character sets to Unicode code points, as well as the fonts that should be used for different ranges of characters.
CUPS includes files for common 8-bit encodings as well as UTF-8 for Unicode text. The format of these files is described in the CUPS Interface Design Description (IDD) document. Current character sets are enumerated in the CUPS API, so in order to add a new character set you must patch the CUPS source as well as provide a new charset file.
CUPS 1.1 supports the following character sets:
CUPS message catalogs are text files that identify the default character set for the locale and a list of localized message strings for the CUPS software. The format of the message catalog files is described in the CUPS IDD.
Message catalogs are named cups_ll, cups_ll_CC, or cups_ll_CC.charset, where "ll" is the standard 2-letter abbreviation for the language, "CC" is the standard 2-letter abbreviation for the country, and "charset" is the charset name which may differ from the list above.
Each message catalog file is stored in a subdirectory named ll , ll_CC, or ll_CC.charset to match the trailing portion of the message catalog filename.
When translating a new message catalog, copy the cups_C message catalog file to a new subdirectory; to translate the message catalog to Canadian French, you would type the following commands:
cd locale ENTER mkdir fr_CA ENTER cp C/cups_C fr_CA/cups_fr_CA ENTER
Alternatively, you could copy the existing cups_fr message catalog and then make any changes necessary.
Once you have make your copy of the file, edit it using your favorite text editor to translate the text to the desired language. Be sure to preserve any numbers starting in the first column, as they indicate a new message number - you'll see this for the HTTP status messages.
Finally, add your locale to the list of locales in the makefile and run the following command to install it:
make install ENTER
The CUPS scheduler provides a web interface that can be used to do many common printing and administration tasks. The built-in web server supports localization of web pages through the use of subdirectories for each locale, e.g. "fr" for French, "de" for German, "fr_ca" for French in Canada, and so forth.
Template files are HTML files with special formatting characters in
 them that allow substition of variables and arrays. The CUPS CGI
 programs (admin.cgi, classes.cgi, 
jobs.cgi, and printers.cgi) use these template file
 to provide dynamic content for the web interface. Template files are
 installed in the /usr/share/cups/templates directory by
 default.
Translated versions of the template files should be installed in the appropriate subdirectories under /usr/share/cups/templates. For example, Canadian French template files should be stored in the /usr/share/cups/templates/fr_CA directory.
Template files consist of HTML with variable substitutions for named inside curley braces "{name}". Variable names are generally the IPP attribute names with the hyphen ("-") replaced by the underscore ("_") character. For example, the job-printer-uri attribute is renamed to job_printer_uri.
Curley braces ("{" and "}") to indicate substitutions, and the
 backslash ("\") character for quoting. To insert any of these special
 characters as-is you need to use the HTML &name; mechanism
 or prefix each special character with the backslash ("\".)
You substitute the value of a variable using {NAME} in
 your template file. If the variable is undefined then the {NAME}
 string is output as-is.
To substitute an empty string if the variable is undefined, use 
{?NAME} instead.
The number of array elements can be inserted using {#NAME}
. If the array is undefined then 0 is output. The current array element
 (starting at 1) is inserted with {#}.
Arrays are handled using {[NAME] at the beginning of a
 section and } at the end. The information between the
 closing bracket ("]") and closing brace ("}") is repeated for as many
 elements as are in the named array. For example, the following template
 will display a list of each job in the job_id array:
<TABLE>
<TR>
	<TH>Job ID</TH>
	<TH>Destination</TH>
	<TH>Title</TH>
</TR>
{[job_id]
<TR>
	<TD>{?job_id}</TD>
	<TD>{?job_printer_name}</TD>
	<TD>{?job_name}</TD>
</TR>
}
</TABLE>
Arrays can be nested, however all elements within the curley braces ("{" and "}") are indexed using the innermost array.
Templates can also test variables against specific values and conditionally include text in the template. The format is:
{variable?true:false}
{variable=value?true:false}
{variable!value?true:false}
{variable<value?true:false}
{variable>value?true:false}
where true is the text that is included if the condition
 is true and false is the text that is included if the
 condition is false. A value of # is replaced with the
 current element number (starting at 1.)
The character after the variable name specifies the condition to test:
| Char | Condition | 
|---|---|
| ? | True if variable exists. | 
| = | True if variable is equal to value . | 
| ! | True if variable is not equal to value . | 
| < | True if variable is less than value . | 
| > | True if variable is greater than value . | 
The following template files are used by the web interface:
CUPS uses four CGI programs to manage the dynamic web interfaces:
admin.cgiclasses.cgijobs.cgiprinters.cgiThe admin.cgi program handles all of the printer and
 class administration functions and is run for all direct accesses to
 the /admin resource. For most operations it uses the 
PRINTER_NAME and OP form variables to specify the
 action requested.
The following OP values are supported:
MEMBER_URIS
 values can be provided.CONFIRM may
 be set to any value to bypass the confirmation page.CONFIRM may be set
 to any value to bypass the confirmation page.The classes.cgi program is responsible for listing class
 information, including jobs destined for that class. It is for all
 direct accesses to the /classes resource and supports the
 optional form variables OP and WHICH_JOBS. If
 no form variables are supplied then the CGI lists all or a specific
 class and the active jobs on each class.
The following WHICH_JOBS values are supported:
The following OP values are supported:
The jobs.cgi program handles all of the job functions
 and is run for all direct accesses to the /jobs resource.
 For most operations it uses the JOB_ID, OP,
 and WHICH_JOBS form variables to specify the action
 requested.
The following WHICH_JOBS values are supported:
The following OP values are supported:
The printers.cgi program is responsible for listing
 printer information, including jobs destined for that printer. It is
 for all direct accesses to the /printers resource and
 supports the optional form variables OP and 
WHICH_JOBS. If no form variables are supplied then the CGI lists
 all or a specific printer and the active jobs on each printer.
The following WHICH_JOBS values are supported:
The following OP values are supported: