6 - Documentation changes (STR #3710, STR #3720, STR #3745, STR #3750,
7 STR #3757, STR #3758, STR #3782, STR #3826, STR #3829)
8 - Web interface fixes (STR #3412, STR #3345, STR #3455, STR #3707,
9 STR #3755, STR #3769, STR #3783)
10 - Configure script fixes (STR #3659, STR #3691)
11 - Compilation fixes (STR #3718, STR #3771, STR #3774)
12 - The scheduler might leave old job data files in the spool directory
14 - CUPS did not work with locales using the ASCII character set
16 - httpAddrString() did not return a URI-style IPv6 numeric address
18 - Fixed an issue when reading compressed CUPS raster streams (STR #3812)
19 - Fixed an issue with PostScript printer auto-configuration (STR #3443)
20 - Fixed some compatibility issues with the libusb-based USB backend
22 - The network backends no longer try to collect SNMP supply and status
23 information for raw queues (STR #3809)
24 - The DBUS notifier did not report job state changes (STR #3805)
25 - The scheduler did not always report that the "normal" print-quality
26 value was supported (STR #3803)
27 - The gziptoany filter did not report the correct error if it was unable
28 to write the uncompressed document to the next filter or backend in
30 - The Epson and Oki 9-pin drivers had a bad resolution option
32 - The scheduler did not always register the correct default ICC profile
34 - The scheduler did not use the job owner when authorizing access for
35 the CUPS-Get-Document operation, preventing non-admins from accessing
37 - CUPS did not work with some printers that incorrectly implemented the
38 HTTP/1.1 standard (STR #3778, STR #3791)
39 - The scheduler did not retry fax jobs properly.
40 - The scheduler now recognizes an empty cupsCommands PPD keyword as
41 meaning that CUPS commands are not supported for a printer (STR #3773)
42 - Fixed a crash bug in the scheduler when the application/octet-stream
43 MIME type was not defined (STR #3690)
44 - Polled printers were advertised more slowly than necessary (STR #3574)
45 - cupsResolveConflicts() did not handle resolving multiple UIConstraints
47 - The SetEnv and PassEnv directives had no effect (STR #3664)
48 - The libusb-based USB backend printed slowly to the LaserJet 1300 and
49 other printers (STR #3405)
50 - "lp" and "lpr" failed to print with Kerberos enabled (STR #3768)
51 - The cupsctl program now displays an error if you try to directly set
52 the Port or Listen directives (STR #3749)
53 - PPD files with "*JobPatchFile: bla" no longer fail to load in relaxed
54 conformance mode (STR #3747)
55 - The scheduler generated a bad notify-text string for printer state
56 change notifications (STR #3739)
57 - The scheduler incorrectly updated printers.conf when it really needed
58 to update classes.conf or remote.cache (STR #3726)
59 - Hardwired remote printers with options did not work (STR #3717)
60 - Accessing the CUPS web interface using a CNAME-based hostname would
61 sometimes fail due to redirection to the actual hostname (STR #3701)
62 - Subscription events had a misspelled attribute (STR #3693)
63 - "make check" failed if LC_MESSAGES was set (STR #3765)
64 - Fixed the configure script to always look for the pkg-config script
66 - The scheduler now only looks up interface hostnames if HostNameLookups
67 are enabled (STR #3737)
68 - Fixed a compilation problem on DragonFly BSD (STR #3738)
69 - The default PageLogFormat value had the username and job ID swapped
70 from CUPS 1.3.x (STR #3727)
71 - The scheduler could crash if a browsed printer times out while a job
72 is printing (STR #3754)
73 - The scheduler incorrectly mapped custom page sizes to standard sizes
75 - cupsfilter and pstops did not map IPP attributes to PPD options due to
76 a change in cupsMarkOptions (STR #3756)
77 - The scheduler did not always show the most recent status message from
78 the print filters (STR #3731)
79 - The PostScript filter did not apply the mirror and number-up options
80 properly, leading to offset and clipped output (STR #3732)
81 - The network backends always reported "low toner" or "out of toner"
82 states, even for inkjet printers (STR #3733)
85 CHANGES IN CUPS V1.4.6
87 - Fixed a "make check" issue on Solaris (STR #3729)
88 - Regression: The pstops filter did not support landscape printing of
89 PostScript files (STR #3722)
90 - The scheduler killed retried (fax) jobs after restarting them
92 - The cupsAdminSetServerSettings() function disabled sharing when
93 debug logging was enabled (STR #3712)
96 CHANGES IN CUPS V1.4.5
98 - Documentation fixes (STR #3542, STR #3650)
99 - Localization fixes (STR #3635, STR #3636, STR #3647, STR #3666)
100 - Security: Fixed a memory corruption bug reported in CVE-2010-2941
102 - The CUPS API incorrectly mapped the HTTP_UNAUTHORIZED status to the
103 IPP_NOT_AUTHORIZED status code, when IPP_NOT_AUTHENTICATED would be
104 the correct mapping (STR #3684)
105 - The scheduler would restart jobs while shutting down (STR #3679)
106 - Fixed a PPD loader bug that could cause a crash in cupsd (STR #3680)
107 - Improved the mapping of non-standard PPD and PWG names (STR #3671)
108 - The scheduler did not initialize Kerberos in all cases (STR #3662)
109 - cupsAdminSetServerSettings duplicated Listen and Order lines
111 - Added DeviceN colorspace support to the CUPS Raster format (STR #3419)
112 - ppdMarkDefaults() did not clear the marked field of the previous
114 - The serial backend would not allow a raw job to be canceled
116 - The socket backend could go into an infinite loop with certain
118 - Setting the PRINTER or LPDEST environment variables to "name/instance"
119 did not work (STR #3485)
120 - The scheduler did not handle the JobRetryLimit setting properly
122 - The lpstat command always showed a remote job ID of 0 for shared
124 - Increased the write timeout for the libusb-based USB backend to 5
126 - The libusb-base USB backend did not check whether the printer has a
127 serial number (STR #3590)
128 - The lpadmin command did not support setting of custom option values
130 - The lpadmin command did not support setting of the location or
131 description of a class (STR #3613)
132 - The cupsaddsmb command did not give up after too many failed attempts
134 - The CUPS library no longer uses certain problematic ctype macros that
135 change based on the locale's character set.
136 - PJL value substitution of more than 9 values was broken (STR #3621)
137 - Custom options with missing string values caused ppdEmit* to segfault
139 - Fixed an issue with the Italian version of the web interface
141 - Fixed the Solaris SMF configuration file for cups-lpd (STR #3611)
142 - The scheduler did not set the notify-subscribed-event attribute when
143 delivering printer-added or printer-modified events (STR #3608)
144 - The mailto notifier could get into an infinite loop (STR #3609)
145 - Date/time information was not shown in banner pages.
146 - Relational operators were broken in #if/#elif/#else/#endif expressions
147 for the PPD compiler.
148 - Moving a job via the web interface failed without asking for
149 authentication (STR #3559)
150 - The scheduler now clears the printer-state-reasons when the driver is
152 - The web interface did not allow a user to change the driver
153 (STR #3537, STR #3601)
154 - The scheduler was not setting the PATH_INFO environment variable when
156 - The scheduler incorrectly set the CUPSD_AUTH_TYPE environment
157 variable instead of AUTH_TYPE (STR #3599)
158 - Fixed a buffer overrun in the PPD compiler (STR #3594)
159 - Fixed some additional IPP job template attribute mapping issues in the
163 CHANGES IN CUPS V1.4.4
165 - Documentation updates (STR #3453, STR #3527, STR #3528, STR #3529)
166 - Security: The fix for CVE-2009-3553 was incomplete (STR #3490)
167 - Security: The texttops filter did not check the results of allocations
169 - Security: The web admin interface could disclose the contents of
171 - Security: CUPS could overwrite files as root in directories owned or
172 writable by non-root users (STR #3510)
173 - The cups-config utility did not return the correct linker options on
175 - Fixed some IPP conformance issues with the scheduler's
176 ippget-event-life, operations-supported, output-bin, and sides
177 attributes (STR #3554)
178 - The OpenSSL interfaces have been made thread-safe and the GNU TLS
179 interface is explicitly forbidden when threading is enabled
181 - Fixed an IPP conformance issue with the scheduler's Send-Document
182 implementation (STR #3514)
183 - Added additional validation checks for the 1284 device ID (STR #3534)
184 - Fixed a problem with the RPM spec file (STR #3544)
185 - The lpstat command did not limit the job list to the specified
187 - The cupsfilter command did not set the RIP_MAX_CACHE environment
189 - Fixed support for media-col and page size variants (STR #3394)
190 - The PostScript filter did not support all media selection options for
191 the first page (STR #3525)
192 - The scheduler did not always remove job control files (STR #3425)
193 - The scheduler could crash on restart if classes were defined
195 - The scheduler no longer looks up network interface hostnames by
196 default on Mac OS X (STR #3523)
197 - ippWriteIO did not write collection (member) attributes properly in
198 all cases (STR #3521)
199 - The "cupsctl --remote-any" and corresponding web interface check box
200 (allow printing from the Internet) did not work reliably (STR #3520)
201 - The lpq and lpr commands would sometimes choose different default
203 - cupsDo*Request did not flush error text, leading to multiple issues
204 (STR #3325, STR #3519)
205 - cupsDoAuthentication did not cancel password authentication after 3
207 - Fixed several LDAP browsing bugs (STR #3392)
208 - The Dymo driver did not support copies (STR #3457)
209 - The scheduler did not update the classes.conf file when deleting a
210 printer belonging to a class (STR #3505)
211 - The lppasswd command did not use localized password prompts
213 - The socket backend no longer waits for back-channel data on platforms
214 other than Mac OS X (STR #3495)
215 - The scheduler didn't send events when a printer started accepting or
216 rejecting jobs (STR #3480)
217 - The web interface now includes additional CSRF protection (STR #3498)
220 CHANGES IN CUPS V1.4.3
222 - SECURITY: The scheduler could try responding on a closed client
223 connection, leading to a crash (STR #3200)
224 - SECURITY: The lppasswd program allowed the localization files to be
225 overridden when running in setuid mode (STR #3482)
226 - Localization updates (STR #3352, STR #3409, STR #3422, STR #3452,
227 STR #3473, STR #3502)
228 - Documentation updates (STR #3451, STR #3504)
229 - The IPP backend now sets the printer-state-message to "Ready to
230 print." at the end of a successful job (STR #3460)
231 - The PPD compiler did not correctly add the manufacturer to the output
232 filename when using the "-m" option (STR #3469)
233 - The IPP backend did not handle authentication properly for the Get-
234 Printer-Attributes operation (STR 3458)
235 - Getting SNMP values larger than 127 bytes did not work.
236 - IPP conformance: Get-Jobs has a default value for requested-attributes
238 - cupsPrintFiles() did not report all errors (STR #3449)
239 - cupsAddDest() could read freed memory (STR #3448)
240 - The DBUS notifier did not build (STR #3447)
241 - The scheduler would crash when an active printer was deleted.
242 - The snmp backend did not work with some printers (STR #3413)
243 - The web interface did not show the conflicting values when setting
245 - Setting options in the web interface did not always work (STR #3439)
246 - The scheduler did not use the Get-Job-Attributes policy for a printer
248 - The scheduler added two job-name attributes to each job object
250 - CSS files would not print (STR #3442)
251 - The scheduler did not clean out completed jobs when PreserveJobHistory
252 was turned off (STR #3425)
253 - The web interface did not show completed jobs for a printer
255 - Authenticated printing did not always work when printing directly to
256 a remote server (STR #3435)
257 - The USB backend did not work on Solaris (STR #3423)
258 - cupstestppd didn't catch problems with JobPatchFile definitions
260 - The socket backend could crash if a SNMP string had a negative length.
261 - Fixed some termination issues with the USB backend on Mac OS X.
262 - The side-channel APIs did not handle interrupts properly.
263 - The network backends incorrectly cleared the media-empty-warning
265 - The web interface did not allow users to successfully add serial
267 - cupsTempFd() did not work in some situations (STR #3382)
268 - Some C API headers were missing C++ wrapper logic.
269 - The PPD compiler did not localize single-language PPD options properly
271 - Modifying a printer from the web interface sometimes caused the wrong
272 driver to be selected (STR #3418)
273 - The scheduler did not handle out-of-memory conditions properly when
274 loading a job (STR #3407)
275 - When adding printers from the web interface, the dynamic updates of
276 the device list made it hard to pick a device (STR #3406)
277 - Fixed a typo in the web interface admin page template (STR 3403)
278 - The web interface did not preserve the "printer is shared" state when
279 modifying a printer (STR #3390)
280 - The PPD compiler incorrectly inserted translations of empty strings
282 - The scheduler did not reset the SIGPIPE handler of child processes
284 - cupsGetNamedDest() incorrectly returned the default printer if the
285 named printer did not exist (STR #3397)
286 - Fixed a GNU TLS error handling bug (STR #3381)
289 CHANGES IN CUPS V1.4.2
291 - SECURITY: The CUPS web interface was vulnerable to several XSS and
292 HTTP header/body attacks via attribute injection (STR #3367,
294 - Fixed localization errors (STR #3359, STR #3372, STR #3380, STR #3387)
295 - The documentation for classes.conf and printers.conf did not provide
296 the correct instructions for manual changes (STR #3351)
297 - The scheduler did not always rebuild printer cache files when the
298 driver was changed (STR #3356)
299 - The documentation makefile failed to install localizations when using
300 newer versions of Bash (STR #3360)
301 - The configure script did not use the --with-xinetd value for the
302 default LPD configuration path (STR #3347)
303 - The configure script incorrectly required glib for DBUS support
305 - The cupstestppd program incorrectly reported filters with bad
306 permisssions as missing (STR #3363)
307 - The cups.desktop file used the wrong locale names (STR #3358)
308 - cupsSideChannelRead() did not return an error for short reads.
309 - The installed PAM configuration file did not use the correct options
310 with the pam_unix2 module (STR #3313)
311 - The scheduler did not preserve default options that contained special
312 characters (STR #3340)
313 - The scheduler did not remove old pre-filters when updating a printer
315 - The HP/GL-2 filter did not check for early end-of-file (STR #3319)
316 - The USB backend did not compile on some platforms (STR #3332)
317 - cupsSideChannelSNMPWalk() could go into an infinite loop with broken
318 SNMP implementations.
321 CHANGES IN CUPS V1.4.1
323 - Documention fixes (STR #3296)
324 - SNMP supply levels and states were wrong for some printers.
325 - The IPP backend did not update the auth-info-required value.
326 - The libusb-based USB backend would hang at the end of the job
327 (STR #3315, STR #3318)
328 - DNS-SD registrations for raw queues had an empty "ty" key (STR #3299)
329 - The JPEG and BMP MIME type rules were broken (STR #3284)
330 - cupsGetNamedDest returned the default printer when the named
331 destination did not exist (STR #3285)
332 - The JobKillDelay was not triggered for canceled jobs (STR #3292)
333 - The PPD compiler could get in an infinite loop (STR #3293)
334 - The configure check for dns-sd.h was broken (STR #3297)
335 - The "Query Printer for Default Options" page did not go away if the
336 query job was held (STR #3302)
337 - Boolean options did not show up as selected in the web interface
339 - The scheduler did not cache or report driver information files
340 correctly, leading to a variety of issues (STR #3283, STR #3297,
342 - cupsDoIORequest() did not abort on permanent errors (STR #3311)
343 - Modifying a class in the web interface did not work (STR #3312)
344 - BrowseLocalProtocols could be cleared when changing the sharing
346 - The scheduler could return an empty supported document format
348 - The PPD compiler generated invalid PPD files when the locale used
349 something other than "." for the decimal point (STR #3300)
350 - The IPP backend did not handle some non-comforming IPP printer
351 implementations (STR #3262)
352 - The scheduler leaked three file descriptors to each job filter
354 - The scheduler now uses a default CUPS-Get-Devices timeout of 15
358 CHANGES IN CUPS V1.4.0
360 - Localization updates (STR #3223, STR #3246, STR #3248, STR #3250)
361 - Documentation updates (STR #3225, STR #3230, STR #3242, STR #3260)
362 - The --with-pdftops configure option did not accept a full path to the
364 - The banner filter did not position the back side image correctly
366 - The dnssd backend could crash (STR #3272)
367 - The 1284 device ID sometimes contained trailing garbage (STR #3266)
368 - The USB backend returned different URIs for some printers than in
370 - The scheduler did not do local job-hold-until processing for remote
372 - The scheduler did not try all possible SSL certificates on Mac OS X.
373 - The scheduler did not always remove a file descriptor when using the
374 kqueue interface (STR #3256)
375 - The scheduler did not protect against bad job control files in all
377 - The scheduler did not encode "+" in model names (STR #3254)
378 - The web interface didn't show the default options (STR #3244)
379 - The IPP and LPD backends needed print data before they would do an
381 - Fixed a GNU TLS compatibility issue (STR #3231)
382 - Fixed a HTML error in the add and modify printer web interface
383 templates (STR #3229)
384 - The scheduler did not minimize the number of printer state events that
385 were generated by filter STATE: messages, which could lead to poor
387 - The USB backend on Mac OS X did not cleanly cancel a job.
388 - The network backends now set the connecting-to-device printer-state-
389 reasons value when looking up the address and copying the print data
391 - The scheduler now supports the com.apple.print.recoverable-warning
392 reason on all platforms.
395 CHANGES IN CUPS V1.4rc1
397 - The PPD compiler documentation was missing information on localization
399 - The IPP backend now reconnects after every request when talking to
400 printers that claim IPP support but only use HTTP/1.0.
401 - The PPD compiler crashed when both "Resolution" and "Group foo Option
402 Resolution" were specified in the .drv file.
403 - The PPD compiler's #if/#elif/#else/#endif did not work for undefined
404 variables (STR #3210)
405 - Static libraries could not be installed by a non-root user on systems
406 needing a ranlib program (STR #3209)
407 - The scheduler incorrectly always tried to copy Kerberos credentials
409 - Updated the Spanish localization (STR #3204)
410 - The scheduler crashed when getting the default paper size from
411 libpaper (STR #3205, STR #3206)
412 - The PPD compiler now defines six variables: CUPS_VERSION,
413 CUPS_VERSION_MAJOR, CUPS_VERSION_MINOR, CUPS_VERSION_PATCH,
414 PLATFORM_NAME, and PLATFORM_ARCH (STR #3203)
415 - Fixed a whitespace skipping bug in cupsRasterInterpretPPD.
416 - The scheduler did not return HTTP 403 (Forbidden) for authenticated
417 users that were not authorized to do IPP operations (STR #3193)
418 - The scheduler did not report more than 8 Product strings from a PPD
419 file. Some PPD files have as many as 24.
420 - ppdOpen*() could crash if a keyword had no value string (something
421 that cupstestppd looks for...)
422 - cupsLangDefault() did not return the correct language on Mac OS X.
423 - The Mac OS X USB backend did not handle aborted or stalled pipe
424 conditions properly, which prevented drivers from ejecting partial
425 pages when a job was canceled or held.
428 CHANGES IN CUPS V1.4b3
430 - Documentation fixes (STR #3044, STR #3057, STR #3153, STR #3158,
432 - Added complete localizations for German, Japanese, Polish, and
433 Russian and partial localizations for Chinese, Danish, Finnish,
434 French, Italian, Korean, Norwegian, Portuguese, and Swedish
435 (STR #3096, STR #3098, STR #3109, STR #3111, STR #3141)
436 - Updated the configure check for -fstack-protector (STR #3198)
437 - The network backends now correctly convert SNMP supply descriptions to
438 UTF-8 encoding as needed.
439 - The scheduler could crash when deleting an attribute (STR #3197)
440 - The cups-driverd program did not detect symlink loops (STR #3185)
441 - The EPSON 24-pin series driver should now feed the correct amount
443 - The scheduler now automatically logs the last N debug messages for
445 - You can now modify a raw print queue (STR #3133)
446 - Fixed a number of ppdi issues and added a unit test to validate that
447 ppdc + ppdi can generate and import the same data (STR #3152)
448 - Moving jobs in the web interface now shows an error if you only have
449 one printer or class added (STR #3094)
450 - Since classes have never truly supported the printer-error-policy
451 stuff added in CUPS 1.2, update the code to reflect the current
452 reality and support only the retry-current-job policy for now
454 - Revised the password callback support (STR #2953)
455 - ppdEmit*() did not choose between PageSize and PageRegion properly.
456 - Make some fairly substantial changes to the Kerberos support code so
457 that CUPS can work in multi-realm environments and does not require
458 delegatable credentials. Shared printing still requires delegation,
459 however "delegation by policy" can be enabled in the KDC to make this
461 - "AccessLogLevel actions" did not hide client-error-not-found errors.
462 - AP_FIRST_InputSlot did not work with number-up.
463 - cupsBackChannelRead() and cupsBackChannelWrite() could fail due to a
464 lack of kernel buffers.
465 - The IPP and LPD backends did not respond to side-channel requests
466 while copying print data to a temporary file.
467 - cupsWriteRequestData() flushed the output buffer unnecessarily,
468 causing reduced performance in some situations.
469 - If a CGI process died before sending its MIME headers, the request
470 would hang on the client.
471 - The printer/class/job search feature on the web interface did not
473 - The scheduler did not write the printers out for classes.
474 - CUPS-Get-PPDs did not work properly when filtering by language,
475 product, or psversion (STR #3136)
476 - The scheduler now kills job filters when it takes more than 30 seconds
477 (configurable) to cancel or hold the job.
478 - The cupstestppd program did not validate the capitalization of
479 filenames in the PPD file.
480 - The cupstestppd program did not validate the PageSize and PageRegion
482 - The cups-deviced helper program could miss reporting some backend
484 - The cupsSideChannelSNMP* functions did not work.
485 - The scheduler could consume 100% CPU when jobs were canceled.
486 - Clicking on "Select Another Make/Manufacturer" in the web interface
487 incorrectly added the printer (STR #3095)
488 - The scheduler no longer uses programs with insecure file
490 - httpAssembleURI*() did not escape backslashes in hostnames.
491 - The dnssd backend did not unquote "full names" before creating the
493 - The scheduler now supports JobRetryInterval values less than 10
495 - Updated the Spanish localization (STR #3090)
496 - The scheduler did not redo Bonjour/DNS-SD registrations when updating
498 - The "authenticated" policy incorrectly required authentication for
500 - ppdOpen*() incorrectly loaded PPDs with multiple JobPatchFile
502 - The network backends no longer report the SNMP "offline" or
503 maintenance status bits since they are inconsistently implemented and
505 - The scheduler no longer logs child processes killed via SIGKILL as
507 - The printer link shown on the "job moved" template was bad (STR #3085)
508 - Updated the HTML templates to use the final HTML 4 DOCTYPE (STR #3086)
509 - The scheduler did not track the "paused" reason properly if a
510 printer had other reasons associated with it.
511 - cupsSendRequest() did not clear old local certificate auth data.
512 - The PPD compiler did not search for localization files properly
514 - cupsGetNamedDest() did not use the fallback default like
515 cupsGetDests*() (STR #3082)
516 - The scheduler now provides a LogTimeFormat directive to enable
517 microseconds in the date and time that are logged.
518 - The scheduler now provides a MultipleOperationTimeout directive to
519 control the timeout for multi-file print jobs.
520 - The configure script incorrectly allowed Avahi to be used for DNS-SD
521 printer discovery (STR #3065)
522 - The web interface and scheduler did not support URIs up to 1024 bytes
523 in length (STR #3072)
524 - Fixed pdftops issues with page sizes (STR #3063)
525 - Fixed pdftops issues with Ghostscript (STR #3062)
526 - The scheduler incorrectly registered default profiles for PostScript
527 printers with no specified colorspace.
528 - The scheduler incorrectly created an empty org.cups.printers.plist
530 - cupsGetPPD3() did not look for local PPDs in the right directory.
531 - SNMP lookups via side-channel did not work for NULL-VALUE and
532 and OCTET-STRING OIDs containing nul characters.
533 - The libusb-based USB backend did not work.
534 - The scheduler did not set the printer-commands attribute correctly
536 - The ppdi utility did not work.
537 - The web interface no longer uses multi-part output with old or broken
538 web browsers (STR #3049)
539 - CUPS now conforms to the draft IPP/2.0 and IPP/2.1 specification.
540 - Added a new cupsGetConflicts() API to get a list of conflicting
542 - The PPD compiler didn't localize options or choices that did not
543 have associated translation text (STR #3045)
544 - Updated the Spanish localization (STR #3043)
545 - Fixed build problems (STR #3040, STR #3047)
546 - cupsResolveConflicts() did not resolve using the default option
547 choice in some cases due to the mirror UIConstraints that are
548 present in most PPD files.
549 - The scheduler did not honor MIME type priorities.
550 - The commandtops filter incorrectly used the JCLBegin code to end
552 - The default BrowseLocalProtocols value was not set properly.
553 - Since the commandtops filter does not actually support ReportLevels
554 all on its own, don't list that printer command by default for PS
556 - The scheduler did not give filters a chance to log errors or update
557 printer attributes when a job was canceled.
558 - The scheduler did not clear the "connecting-to-device" reason keyword
562 CHANGES IN CUPS V1.4b2
564 - Documentation updates (STR #2983, STR #2998, STR #3021)
565 - The cupstestppd utility now validates the FileVersion and
566 FormatVersion values in PPD files.
567 - The default cupsd.conf file did not reflect the
568 --with-local-protocols value set at compile-time (STR #3037)
569 - The cupsGetPPD* APIs now create symlinks to local PPD files
570 rather than copying them whenever possible.
571 - Various performance optimizations in the string pool, dests, and
572 options implementations.
573 - The cupsGetDests* APIs now return the marker and printer-commands
575 - Side-channel SNMP lookups would not work when cupsSNMPSupplies
576 was set to False in the PPD file.
577 - Localized the device descriptions for the SCSI, serial,
578 and network backends (STR #3014)
579 - Added a Spanish localization (STR #3015)
580 - Added support for marker-low-levels and marker-high-levels
582 - The scheduler could hang writing a long log line.
583 - The cupsGetDevices() function now has an "include_schemes"
585 - The lpinfo command now supports --include-schemes and
586 --exclude-schemes options.
587 - The CUPS-Get-PPDs operation now supports the include-schemes
588 and exclude-schemes attributes.
589 - The CUPS-Get-Devices operation now supports the include-schemes
591 - The print filters now support a replacement for the fitplot
592 option called "fit-to-page".
593 - The LPD backend no longer tries to collect page accounting
594 information since the LPD protocol does not allow us to
595 prevent race conditions.
596 - The scheduler did not save the last marker-change-time value.
597 - Fixed a problem with printing to some IPP printers, including
599 - Fixed a redirection problem with the printer web page (STR #3012)
600 - Fixed a PPD compiler problem with the loading of message
602 - Fixed a PPD compiler problem with the loading of .strings files
604 - The cupsfilter utility did not set the CONTENT_TYPE environment
605 variable when running filters.
606 - The scheduler now waits to allow system sleep until the jobs
608 - The IPP, LPD, and socket backends used different "connecting"
612 CHANGES IN CUPS V1.4b1
614 - Documentation updates (STR #2567)
615 - The PPD compiler now allows local message catalogs to
616 override the standard CUPS translations (STR #2642)
617 - The ppdmerge command did not merge custom option strings
619 - The scheduler now supports the Hold-New-Jobs and
620 Release-Held-New-Jobs operations; these are exposed via the
621 cupsdisable and cupsenable commands (STR #2332)
622 - The lpstat command is now much faster when displaying the
623 status of a single printer (STR #2843)
624 - The scheduler now caches information from PPD files to provide
625 significantly faster startup time with large numbers of PPDs
627 - CUPS-Get-Driver now provides much better driver matching based
628 on the IEEE-1284 device ID and make/model strings (STR #2707)
629 - Now support the cupsSNMPSupplies keyword to control whether
630 the network backends query the SNMP Printer MIB for supply
632 - Now support and use a new banner file format for better text
633 support and easier customization (STR #2490)
634 - The scheduler now sets the PRINTER_INFO and PRINTER_LOCATION
635 environment variables from the corresponding IPP attributes.
636 - The ippRead*() and ippWrite*() functions no longer use a
637 stack-based buffer (STR #2388)
638 - The CUPS-Add-Modify-Printer operation now allows you to set
639 the printer-state-reasons attribute.
640 - The "set printer options" page now supports auto-configuration
641 of printer options (STR #1440)
642 - The web interface now provides an advanced server settings
644 - The web interface's "modify printer" pages now make it
645 easier to change just one setting (STR #1919)
646 - The scheduler now supports a plist PrintcapFormat.
647 - The scheduler now supports multiple addresses in Allow and
648 Deny lines, just like Apache (STR #2947)
649 - Added CUPS_JOBTYPE environment variable for job filters so
650 they know whether they are printing a banner or document
652 - Added support for printer filtering by the cupsfilter
654 - Added a SSLOptions directive to allow Windows clients to
655 talk to CUPS in FIPS mode (STR #2827)
656 - Renamed the accept and reject commands to cupsaccept and
657 cupsreject; the old names are still available (STR #2936)
658 - The locale/translate utility needed an update to work with
660 - The lpstat command now supports a -H option to display the
661 default server (STR #2833)
662 - The scheduler now supports a FatalErrors directive to control
663 which errors should cause the scheduler to exit (STR #2536)
664 - The scheduler now uses the php-cgi program if it is available
666 - The scheduler now supports a DefaultPaperSize directive
668 - The scheduler now passes the job-originating-host-name
669 value to filters in the options argument (STR #2558)
670 - CUPS now supports job tickets in PDF files (STR #2903)
671 - Added a DBUS notifier (STR #2529)
672 - The LPD mini-daemon now passes the document name when queuing
673 print jobs (STR #2482)
674 - The IPP backend did not relay com.apple.print.recoverable-message
676 - The scheduler now supports a job-media-progress attribute to
677 track the progress of individual pages.
678 - The sample HP driver now supports A5 (STR #2798)
679 - The CUPS web interface menu item now uses the xdg-open
680 command, when available (STR #2724)
681 - The cups-lpd program now supports the -h option (STR #2794)
682 - The scheduler now sets the PAM_TTY parameter and the
683 PAM_ESTABLISH_CRED credential flag (STR #2745)
684 - The scheduler now logs unsuccessful requests to the error_log
685 file as errors (STR #2616)
686 - Added support for a "retry-current-job" error policy that
687 retries the current job immediately when the backend encounters
689 - The scheduler now returns a "forbidden" error when a user
690 correctly authenticates but does not have permission to
691 continue further (STR #2101)
692 - The scheduler now loads both the server and CA certificates
693 (if present) from the ServerCertificate file (STR #2146)
694 - New RSS subscriptions now create their feed files immediately
696 - Added support for a device-location attribute which provides
697 the physical location of a printer device.
698 - Added a cupsBackendReport() API which handles quoting of the
699 device data by a backend.
700 - Added support for custom options in the web interface
702 - Added support for Mozilla LDAP, reconnection to LDAP servers,
703 and improved LDAP performance (STR #1962)
704 - Added Solaris SMF support (STR #1477)
705 - Added optional support for using TCP wrappers to limit access
707 - Added ppdPageSizeLimits API.
708 - Added support for new cupsMediaQualifier2, cupsMediaQualifier3,
709 cupsMinSize, and cupsMaxSize attributes.
710 - Added cupsResolveConflicts and ppdInstallableConflict APIs.
711 - Added support for new cupsUIConstraints and cupsUIResolver
712 attributes for better option conflict detection and
714 - Increased the maximum size of 1284 device ID strings to
715 256 bytes (STR #2877)
716 - Added an AccessLogLevel directive to cupsd.conf to control
717 what is logged to the access_log file.
718 - The default LogLevel is now "warn" instead of "info" to reduce
719 the amount of logging that is done to disk by default.
720 - The PPD compiler did not include OID query keywords in PPD
722 - The cups-driverd helper program now directly supports driver
724 - The USB backend now uses libusb when available (STR #1575)
725 - Added ppdLocalizeAttr function to get the localized version
727 - MIME types now support a priority() attribute (STR #2719)
728 - The standard MIME types are now installed in
729 DataDir/mime (STR #2719)
730 - The lpoptions command now describes custom options and
731 the necessary parameters (STR #2660)
732 - The ppdmerge program did not support Simplified Chinese
733 or Traditional Chinese language version strings (STR #2851)
734 - The PPD compiler now supports localizable attributes
736 - The ppdpo utility now includes cupsIPPReasons values in
737 the message catalogs it generates (STR #2754)
738 - The PPD compiler now supports conditional directives
740 - The ppdc utility now supports a "-t" option to test PPD
742 - The ppdc utility now supports a "-m" option to use the
743 ModelName value as the output filename.
744 - The ppdc utility now supports a FileName directive to
745 set an alternate output filename (STR #2740)
746 - The side-channel API now supports SNMP queries for the
747 standard network backends.
748 - Added a PageLogFormat directive to the cupsd.conf file to
749 control the format of lines in the page_log file.
750 - Filters can now send PPD: messages to stderr to set PPD
751 keywords like DefaultPageSize while a job is printing.
752 - Added a mdns backend for discovery and printing to printers
753 that advertise themselves via DNS-SD (Bonjour)
754 - The ipp, lpd, and socket backends now support DNS-SD service
756 - The scheduler now uses a single shared file descriptor for
757 all DNS-SD registrations (STR #2674)
758 - The ipp, lpd, and socket backends now support SNMP-based
759 page accounting and supply level monitoring (STR #1655)
760 - Added support for cupsPJLDisplay attribute to control what
761 PJL commands are used to display the job information.
762 - Driver information files can now be installed in
763 /Library/Printers/PPDs.drv on Mac OS X.
764 - The CUPS image library now supports reading images larger
766 - The scheduler now delays writing config and state files to
767 reduce disk activity (STR #2684)
768 - The CUPS-Get-Devices operation now supports the
769 exclude-schemes and timeout attributes to control which
770 backends are polled and for how long.
771 - The cups-deviced helper application now runs backends in
772 parallel to get the list of devices faster.
773 - Added --enable-pap configure option.
774 - The default cupsd.conf file now includes an "authenticated"
775 policy which requires authentication for remote print jobs.
776 - Added support for Czech and Hungarian in PPD files
777 (STR #2735, STR #2736)
778 - The PPD compiler tools now support Mac OS X .strings files
779 for localization (STR #2737)
780 - ppdOpen*() now default the colorspace member to PPD_CS_N
781 when no DefaultColorSpace attribute is present in the PPD
783 - The build system has been updated to support separate
784 installation of data, program, header, and library files.
785 - All support libraries are now built as shared libraries
787 - The scheduler now manages ICC color profiles on Mac OS X.
788 - The network backends (ipp, lpd, socket) now support
789 SNMP-based supply and page count monitoring (STR #1655)
790 - The lppasswd program is no longer installed setuid to
791 root to make the default installation more secure.
792 - Added a new ppdLocalizeMarkerName() function to get
793 the localized version of a marker-names value.
794 - The scheduler now provides the printer-dns-sd-name
795 attribute for printers shared via DNS-SD/Bonjour.
796 - The pdftops filter now executes the Xpdf or poppler
797 pdftops utility to convert PDF files (STR #1471)
798 - Bonjour printer registrations now advertise as local or
799 global based on the current access policies for the
801 - cupsGetDests*() and cupsSetDests*() now track the last
802 used printer preference on Mac OS X.
803 - Added a new streaming request API (STR #2261)
804 - Added a new cupsGetNamedDest() function to the CUPS
805 library for faster printing with lp and lpr (STR #2638)
806 - The scheduler now sets the PAM RHOST value on systems
807 that support it (STR #2637)
808 - The scheduler now sandboxes child processes when
810 - The Cancel-Job operation now supports a purge-job
811 attriibute to purge a specified job.
812 - ppdEmit* and ppdCollect* now use the NonUIOrderDependency
813 attributes for custom option selections.
814 - The web interface now enables/disables the printer
815 sharing (formerly publishing) controls based on the
816 server-is-sharing-printers state (STR #2233)
817 - The scheduler now tracks printer sharing via the
818 server-is-sharing-printers attribute, and manages LPD
819 and SMB sharing as well (STR #2233)
820 - The web interface now allows you to go back to the make/
821 manufacturer page if there is no matching printer driver
822 on the model page (STR #2436)
823 - The printer list now shows the default media, banner, and
824 duplex options as well as the color and duplex capabilities
825 of printers (STR #1175)
826 - The web interface look-n-feel has been updated (STR #2492)
827 - The scheduler now supports a CUPS-Get-Document operation
828 that returns the specified print job document (STR #118)
829 - The cupsfilter utility now supports a "-J jobid" option
830 to filter the document from the specified job.
831 - The scheduler (cupsd) now supports a new option (-t) to
832 do a syntax check of the cupsd.conf file (STR #2003)
833 - Added new cupsGetPPD3() API to allow applications to
834 cache PPDs safely (STR #1473)
835 - Added generic PostScript and PCL printer driver PPDs.