1 CHANGES.txt - 2009-05-08
2 ------------------------
6 - Documentation fixes (STR #3044, STR #3057)
7 - Added complete localizations for German, Japanese, Polish, and
8 Russian and partial localizations for Chinese, Danish, Finnish,
9 French, Italian, Korean, Norwegian, Portuguese, and Swedish
10 (STR #3096, STR #3098, STR #3109, STR #3111, STR #3141)
11 - Fixed a number of ppdi issues and added a unit test to validate that
12 ppdc + ppdi can generate and import the same data (STR #3152)
13 - Moving jobs in the web interface now shows an error if you only have
14 one printer or class added (STR #3094)
15 - Since classes have never truly supported the printer-error-policy
16 stuff added in CUPS 1.2, update the code to reflect the current
17 reality and support only the retry-current-job policy for now
19 - Revised the password callback support (STR #2953)
20 - ppdEmit*() did not choose between PageSize and PageRegion properly.
21 - Make some fairly substantial changes to the Kerberos support code so
22 that CUPS can work in multi-realm environments and does not require
23 delegatable credentials. Shared printing still requires delegation,
24 however "delegation by policy" can be enabled in the KDC to make this
26 - "AccessLogLevel actions" did not hide client-error-not-found errors.
27 - AP_FIRST_InputSlot did not work with number-up.
28 - cupsBackChannelRead() and cupsBackChannelWrite() could fail due to a
29 lack of kernel buffers.
30 - The IPP and LPD backends did not respond to side-channel requests
31 while copying print data to a temporary file.
32 - cupsWriteRequestData() flushed the output buffer unnecessarily,
33 causing reduced performance in some situations.
34 - If a CGI process died before sending its MIME headers, the request
35 would hang on the client.
36 - The printer/class/job search feature on the web interface did not
38 - The scheduler did not write the printers out for classes.
39 - CUPS-Get-PPDs did not work properly when filtering by language,
40 product, or psversion (STR #3136)
41 - The scheduler now kills job filters when it takes more than 30 seconds
42 (configurable) to cancel or hold the job.
43 - The cupstestppd program did not validate the capitalization of
44 filenames in the PPD file.
45 - The cupstestppd program did not validate the PageSize and PageRegion
47 - The cups-deviced helper program could miss reporting some backend
49 - The cupsSideChannelSNMP* functions did not work.
50 - The scheduler could consume 100% CPU when jobs were canceled.
51 - Clicking on "Select Another Make/Manufacturer" in the web interface
52 incorrectly added the printer (STR #3095)
53 - The scheduler no longer uses programs with insecure file
55 - httpAssembleURI*() did not escape backslashes in hostnames.
56 - The dnssd backend did not unquote "full names" before creating the
58 - The scheduler now supports JobRetryInterval values less than 10
60 - Updated the Spanish localization (STR #3090)
61 - The scheduler did not redo Bonjour/DNS-SD registrations when updating
63 - The "authenticated" policy incorrectly required authentication for
65 - ppdOpen*() incorrectly loaded PPDs with multiple JobPatchFile
67 - The network backends no longer report the SNMP "offline" or
68 maintenance status bits since they are inconsistently implemented and
70 - The scheduler no longer logs child processes killed via SIGKILL as
72 - The printer link shown on the "job moved" template was bad (STR #3085)
73 - Updated the HTML templates to use the final HTML 4 DOCTYPE (STR #3086)
74 - The scheduler did not track the "paused" reason properly if a
75 printer had other reasons associated with it.
76 - cupsSendRequest() did not clear old local certificate auth data.
77 - The PPD compiler did not search for localization files properly
79 - cupsGetNamedDest() did not use the fallback default like
80 cupsGetDests*() (STR #3082)
81 - The scheduler now provides a LogTimeFormat directive to enable
82 microseconds in the date and time that are logged.
83 - The scheduler now provides a MultipleOperationTimeout directive to
84 control the timeout for multi-file print jobs.
85 - The configure script incorrectly allowed Avahi to be used for DNS-SD
86 printer discovery (STR #3065)
87 - The web interface and scheduler did not support URIs up to 1024 bytes
89 - Fixed pdftops issues with page sizes (STR #3063)
90 - Fixed pdftops issues with Ghostscript (STR #3062)
91 - The scheduler incorrectly registered default profiles for PostScript
92 printers with no specified colorspace.
93 - The scheduler incorrectly created an empty org.cups.printers.plist
95 - cupsGetPPD3() did not look for local PPDs in the right directory.
96 - SNMP lookups via side-channel did not work for NULL-VALUE and
97 and OCTET-STRING OIDs containing nul characters.
98 - The libusb-based USB backend did not work.
99 - The scheduler did not set the printer-commands attribute correctly
101 - The ppdi utility did not work.
102 - The web interface no longer uses multi-part output with old or broken
103 web browsers (STR #3049)
104 - CUPS now conforms to the draft IPP/2.0 and IPP/2.1 specification.
105 - Added a new cupsGetConflicts() API to get a list of conflicting
107 - The PPD compiler didn't localize options or choices that did not
108 have associated translation text (STR #3045)
109 - Updated the Spanish localization (STR #3043)
110 - Fixed build problems (STR #3040, STR #3047)
111 - cupsResolveConflicts() did not resolve using the default option
112 choice in some cases due to the mirror UIConstraints that are
113 present in most PPD files.
114 - The scheduler did not honor MIME type priorities.
115 - The commandtops filter incorrectly used the JCLBegin code to end
117 - The default BrowseLocalProtocols value was not set properly.
118 - Since the commandtops filter does not actually support ReportLevels
119 all on its own, don't list that printer command by default for PS
121 - The scheduler did not give filters a chance to log errors or update
122 printer attributes when a job was canceled.
123 - The scheduler did not clear the "connecting-to-device" reason keyword
127 CHANGES IN CUPS V1.4b2
129 - Documentation updates (STR #2983, STR #2998, STR #3021)
130 - The cupstestppd utility now validates the FileVersion and
131 FormatVersion values in PPD files.
132 - The default cupsd.conf file did not reflect the
133 --with-local-protocols value set at compile-time (STR #3037)
134 - The cupsGetPPD* APIs now create symlinks to local PPD files
135 rather than copying them whenever possible.
136 - Various performance optimizations in the string pool, dests, and
137 options implementations.
138 - The cupsGetDests* APIs now return the marker and printer-commands
140 - Side-channel SNMP lookups would not work when cupsSNMPSupplies
141 was set to False in the PPD file.
142 - Localized the device descriptions for the SCSI, serial,
143 and network backends (STR #3014)
144 - Added a Spanish localization (STR #3015)
145 - Added support for marker-low-levels and marker-high-levels
147 - The scheduler could hang writing a long log line.
148 - The cupsGetDevices() function now has an "include_schemes"
150 - The lpinfo command now supports --include-schemes and
151 --exclude-schemes options.
152 - The CUPS-Get-PPDs operation now supports the include-schemes
153 and exclude-schemes attributes.
154 - The CUPS-Get-Devices operation now supports the include-schemes
156 - The print filters now support a replacement for the fitplot
157 option called "fit-to-page".
158 - The LPD backend no longer tries to collect page accounting
159 information since the LPD protocol does not allow us to
160 prevent race conditions.
161 - The scheduler did not save the last marker-change-time value.
162 - Fixed a problem with printing to some IPP printers, including
164 - Fixed a redirection problem with the printer web page (STR #3012)
165 - Fixed a PPD compiler problem with the loading of message
167 - Fixed a PPD compiler problem with the loading of .strings files
169 - The cupsfilter utility did not set the CONTENT_TYPE environment
170 variable when running filters.
171 - The scheduler now waits to allow system sleep until the jobs
173 - The IPP, LPD, and socket backends used different "connecting"
177 CHANGES IN CUPS V1.4b1
179 - Documentation updates (STR #2567)
180 - The PPD compiler now allows local message catalogs to
181 override the standard CUPS translations (STR #2642)
182 - The ppdmerge command did not merge custom option strings
184 - The scheduler now supports the Hold-New-Jobs and
185 Release-Held-New-Jobs operations; these are exposed via the
186 cupsdisable and cupsenable commands (STR #2332)
187 - The lpstat command is now much faster when displaying the
188 status of a single printer (STR #2843)
189 - The scheduler now caches information from PPD files to provide
190 significantly faster startup time with large numbers of PPDs
192 - CUPS-Get-Driver now provides much better driver matching based
193 on the IEEE-1284 device ID and make/model strings (STR #2707)
194 - Now support the cupsSNMPSupplies keyword to control whether
195 the network backends query the SNMP Printer MIB for supply
197 - Now support and use a new banner file format for better text
198 support and easier customization (STR #2490)
199 - The scheduler now sets the PRINTER_INFO and PRINTER_LOCATION
200 environment variables from the corresponding IPP attributes.
201 - The ippRead*() and ippWrite*() functions no longer use a
202 stack-based buffer (STR #2388)
203 - The CUPS-Add-Modify-Printer operation now allows you to set
204 the printer-state-reasons attribute.
205 - The "set printer options" page now supports auto-configuration
206 of printer options (STR #1440)
207 - The web interface now provides an advanced server settings
209 - The web interface's "modify printer" pages now make it
210 easier to change just one setting (STR #1919)
211 - The scheduler now supports a plist PrintcapFormat.
212 - The scheduler now supports multiple addresses in Allow and
213 Deny lines, just like Apache (STR #2947)
214 - Added CUPS_JOBTYPE environment variable for job filters so
215 they know whether they are printing a banner or document
217 - Added support for printer filtering by the cupsfilter
219 - Added a SSLOptions directive to allow Windows clients to
220 talk to CUPS in FIPS mode (STR #2827)
221 - Renamed the accept and reject commands to cupsaccept and
222 cupsreject; the old names are still available (STR #2936)
223 - The locale/translate utility needed an update to work with
225 - The lpstat command now supports a -H option to display the
226 default server (STR #2833)
227 - The scheduler now supports a FatalErrors directive to control
228 which errors should cause the scheduler to exit (STR #2536)
229 - The scheduler now uses the php-cgi program if it is available
231 - The scheduler now supports a DefaultPaperSize directive
233 - The scheduler now passes the job-originating-host-name
234 value to filters in the options argument (STR #2558)
235 - CUPS now supports job tickets in PDF files (STR #2903)
236 - Added a DBUS notifier (STR #2529)
237 - The LPD mini-daemon now passes the document name when queuing
238 print jobs (STR #2482)
239 - The IPP backend did not relay com.apple.print.recoverable-message
241 - The scheduler now supports a job-media-progress attribute to
242 track the progress of individual pages.
243 - The sample HP driver now supports A5 (STR #2798)
244 - The CUPS web interface menu item now uses the xdg-open
245 command, when available (STR #2724)
246 - The cups-lpd program now supports the -h option (STR #2794)
247 - The scheduler now sets the PAM_TTY parameter and the
248 PAM_ESTABLISH_CRED credential flag (STR #2745)
249 - The scheduler now logs unsuccessful requests to the error_log
250 file as errors (STR #2616)
251 - Added support for a "retry-current-job" error policy that
252 retries the current job immediately when the backend encounters
254 - The scheduler now returns a "forbidden" error when a user
255 correctly authenticates but does not have permission to
256 continue further (STR #2101)
257 - The scheduler now loads both the server and CA certificates
258 (if present) from the ServerCertificate file (STR #2146)
259 - New RSS subscriptions now create their feed files immediately
261 - Added support for a device-location attribute which provides
262 the physical location of a printer device.
263 - Added a cupsBackendReport() API which handles quoting of the
264 device data by a backend.
265 - Added support for custom options in the web interface
267 - Added support for Mozilla LDAP, reconnection to LDAP servers,
268 and improved LDAP performance (STR #1962)
269 - Added Solaris SMF support (STR #1477)
270 - Added optional support for using TCP wrappers to limit access
272 - Added ppdPageSizeLimits API.
273 - Added support for new cupsMediaQualifier2, cupsMediaQualifier3,
274 cupsMinSize, and cupsMaxSize attributes.
275 - Added cupsResolveConflicts and ppdInstallableConflict APIs.
276 - Added support for new cupsUIConstraints and cupsUIResolver
277 attributes for better option conflict detection and
279 - Increased the maximum size of 1284 device ID strings to
280 256 bytes (STR #2877)
281 - Added an AccessLogLevel directive to cupsd.conf to control
282 what is logged to the access_log file.
283 - The default LogLevel is now "warn" instead of "info" to reduce
284 the amount of logging that is done to disk by default.
285 - The PPD compiler did not include OID query keywords in PPD
287 - The cups-driverd helper program now directly supports driver
289 - The USB backend now uses libusb when available (STR #1575)
290 - Added ppdLocalizeAttr function to get the localized version
292 - MIME types now support a priority() attribute (STR #2719)
293 - The standard MIME types are now installed in
294 DataDir/mime (STR #2719)
295 - The lpoptions command now describes custom options and
296 the necessary parameters (STR #2660)
297 - The ppdmerge program did not support Simplified Chinese
298 or Traditional Chinese language version strings (STR #2851)
299 - The PPD compiler now supports localizable attributes
301 - The ppdpo utility now includes cupsIPPReasons values in
302 the message catalogs it generates (STR #2754)
303 - The PPD compiler now supports conditional directives
305 - The ppdc utility now supports a "-t" option to test PPD
307 - The ppdc utility now supports a "-m" option to use the
308 ModelName value as the output filename.
309 - The ppdc utility now supports a FileName directive to
310 set an alternate output filename (STR #2740)
311 - The side-channel API now supports SNMP queries for the
312 standard network backends.
313 - Added a PageLogFormat directive to the cupsd.conf file to
314 control the format of lines in the page_log file.
315 - Filters can now send PPD: messages to stderr to set PPD
316 keywords like DefaultPageSize while a job is printing.
317 - Added a mdns backend for discovery and printing to printers
318 that advertise themselves via DNS-SD (Bonjour)
319 - The ipp, lpd, and socket backends now support DNS-SD service
321 - The scheduler now uses a single shared file descriptor for
322 all DNS-SD registrations (STR #2674)
323 - The ipp, lpd, and socket backends now support SNMP-based
324 page accounting and supply level monitoring (STR #1655)
325 - Added support for cupsPJLDisplay attribute to control what
326 PJL commands are used to display the job information.
327 - Driver information files can now be installed in
328 /Library/Printers/PPDs.drv on Mac OS X.
329 - The CUPS image library now supports reading images larger
331 - The scheduler now delays writing config and state files to
332 reduce disk activity (STR #2684)
333 - The CUPS-Get-Devices operation now supports the
334 exclude-schemes and timeout attributes to control which
335 backends are polled and for how long.
336 - The cups-deviced helper application now runs backends in
337 parallel to get the list of devices faster.
338 - Added --enable-pap configure option.
339 - The default cupsd.conf file now includes an "authenticated"
340 policy which requires authentication for remote print jobs.
341 - Added support for Czech and Hungarian in PPD files
342 (STR #2735, STR #2736)
343 - The PPD compiler tools now support Mac OS X .strings files
344 for localization (STR #2737)
345 - ppdOpen*() now default the colorspace member to PPD_CS_N
346 when no DefaultColorSpace attribute is present in the PPD
348 - The build system has been updated to support separate
349 installation of data, program, header, and library files.
350 - All support libraries are now built as shared libraries
352 - The scheduler now manages ICC color profiles on Mac OS X.
353 - The network backends (ipp, lpd, socket) now support
354 SNMP-based supply and page count monitoring (STR #1655)
355 - The lppasswd program is no longer installed setuid to
356 root to make the default installation more secure.
357 - Added a new ppdLocalizeMarkerName() function to get
358 the localized version of a marker-names value.
359 - The scheduler now provides the printer-dns-sd-name
360 attribute for printers shared via DNS-SD/Bonjour.
361 - The pdftops filter now executes the Xpdf or poppler
362 pdftops utility to convert PDF files (STR #1471)
363 - Bonjour printer registrations now advertise as local or
364 global based on the current access policies for the
366 - cupsGetDests*() and cupsSetDests*() now track the last
367 used printer preference on Mac OS X.
368 - Added a new streaming request API (STR #2261)
369 - Added a new cupsGetNamedDest() function to the CUPS
370 library for faster printing with lp and lpr (STR #2638)
371 - The scheduler now sets the PAM RHOST value on systems
372 that support it (STR #2637)
373 - The scheduler now sandboxes child processes when
375 - The Cancel-Job operation now supports a purge-job
376 attriibute to purge a specified job.
377 - ppdEmit* and ppdCollect* now use the NonUIOrderDependency
378 attributes for custom option selections.
379 - The web interface now enables/disables the printer
380 sharing (formerly publishing) controls based on the
381 server-is-sharing-printers state (STR #2233)
382 - The scheduler now tracks printer sharing via the
383 server-is-sharing-printers attribute, and manages LPD
384 and SMB sharing as well (STR #2233)
385 - The web interface now allows you to go back to the make/
386 manufacturer page if there is no matching printer driver
387 on the model page (STR #2436)
388 - The printer list now shows the default media, banner, and
389 duplex options as well as the color and duplex capabilities
390 of printers (STR #1175)
391 - The web interface look-n-feel has been updated (STR #2492)
392 - The scheduler now supports a CUPS-Get-Document operation
393 that returns the specified print job document (STR #118)
394 - The cupsfilter utility now supports a "-J jobid" option
395 to filter the document from the specified job.
396 - The scheduler (cupsd) now supports a new option (-t) to
397 do a syntax check of the cupsd.conf file (STR #2003)
398 - Added new cupsGetPPD3() API to allow applications to
399 cache PPDs safely (STR #1473)
400 - Added generic PostScript and PCL printer driver PPDs.