]> git.ipfire.org Git - thirdparty/cups.git/blame - CHANGES-1.4.txt
Add a debug message so that people know why we stopped the queue (STR #3262)
[thirdparty/cups.git] / CHANGES-1.4.txt
CommitLineData
6c472821 1CHANGES-1.4.txt
2---------------
3
4CHANGES IN CUPS V1.4.1
5
e0b93db4 6 - Documention fixes (STR #3296)
2aadca54 7 - DNS-SD registrations for raw queues had an empty "ty" key (STR #3299)
8 - The JPEG and BMP MIME type rules were broken (STR #3284)
7dbcf7ec 9 - cupsGetNamedDest returned the default printer when the named
10 destination did not exist (STR #3285)
a98a0f7b 11 - The JobKillDelay was not triggered for canceled jobs (STR #3292)
56a13d44 12 - The PPD compiler could get in an infinite loop (STR #3293)
81ed7e71 13 - The configure check for dns-sd.h was broken (STR #3297)
653972cc 14 - The "Query Printer for Default Options" page did not go away if the
15 query job was held (STR #3302)
f957247d 16 - Boolean options did not show up as selected in the web interface
17 (STR #3303)
b85b2ba5 18 - The scheduler did not cache or report driver information files
19 correctly, leading to a variety of issues (STR #3297, STR #3305)
74e726de 20 - cupsDoIORequest() did not abort on permanent errors (STR #3311)
75fde508 21 - Modifying a class in the web interface did not work (STR #3312)
2f150abd 22 - BrowseLocalProtocols could be cleared when changing the sharing
23 setting (STR #3287)
659ca617 24 - The scheduler could return an empty supported document format
25 (STR #3308)
10e8f916 26 - The PPD compiler generated invalid PPD files when the locale used
27 something other than "." for the decimal point (STR #3300)
f3fdb6b2 28 - The IPP backend did not handle some non-comforming IPP printer
29 implementations (STR #3262)
6c472821 30
31
32CHANGES IN CUPS V1.4.0
33
34 - Localization updates (STR #3223, STR #3246, STR #3248, STR #3250)
35 - Documentation updates (STR #3225, STR #3230, STR #3242, STR #3260)
36 - The --with-pdftops configure option did not accept a full path to the
37 filter (STR #3278)
38 - The banner filter did not position the back side image correctly
39 (STR #3277)
40 - The dnssd backend could crash (STR #3272)
41 - The 1284 device ID sometimes contained trailing garbage (STR #3266)
42 - The USB backend returned different URIs for some printers than in
43 CUPS 1.3 (STR #3259)
44 - The scheduler did not do local job-hold-until processing for remote
45 queues (STR #3258)
46 - The scheduler did not try all possible SSL certificates on Mac OS X.
47 - The scheduler did not always remove a file descriptor when using the
48 kqueue interface (STR #3256)
49 - The scheduler did not protect against bad job control files in all
50 cases (STR #3253)
51 - The scheduler did not encode "+" in model names (STR #3254)
52 - The web interface didn't show the default options (STR #3244)
53 - The IPP and LPD backends needed print data before they would do an
54 SNMP query.
55 - Fixed a GNU TLS compatibility issue (STR #3231)
56 - Fixed a HTML error in the add and modify printer web interface
57 templates (STR #3229)
58 - The scheduler did not minimize the number of printer state events that
59 were generated by filter STATE: messages, which could lead to poor
60 performance.
61 - The USB backend on Mac OS X did not cleanly cancel a job.
62 - The network backends now set the connecting-to-device printer-state-
63 reasons value when looking up the address and copying the print data
64 for consistency.
65 - The scheduler now supports the com.apple.print.recoverable-warning
66 reason on all platforms.
67
68
69CHANGES IN CUPS V1.4rc1
70
71 - The PPD compiler documentation was missing information on localization
72 (STR #3212)
73 - The IPP backend now reconnects after every request when talking to
74 printers that claim IPP support but only use HTTP/1.0.
75 - The PPD compiler crashed when both "Resolution" and "Group foo Option
76 Resolution" were specified in the .drv file.
77 - The PPD compiler's #if/#elif/#else/#endif did not work for undefined
78 variables (STR #3210)
79 - Static libraries could not be installed by a non-root user on systems
80 needing a ranlib program (STR #3209)
81 - The scheduler incorrectly always tried to copy Kerberos credentials
82 for print jobs.
83 - Updated the Spanish localization (STR #3204)
84 - The scheduler crashed when getting the default paper size from
85 libpaper (STR #3205, STR #3206)
86 - The PPD compiler now defines six variables: CUPS_VERSION,
87 CUPS_VERSION_MAJOR, CUPS_VERSION_MINOR, CUPS_VERSION_PATCH,
88 PLATFORM_NAME, and PLATFORM_ARCH (STR #3203)
89 - Fixed a whitespace skipping bug in cupsRasterInterpretPPD.
90 - The scheduler did not return HTTP 403 (Forbidden) for authenticated
91 users that were not authorized to do IPP operations (STR #3193)
92 - The scheduler did not report more than 8 Product strings from a PPD
93 file. Some PPD files have as many as 24.
94 - ppdOpen*() could crash if a keyword had no value string (something
95 that cupstestppd looks for...)
96 - cupsLangDefault() did not return the correct language on Mac OS X.
97 - The Mac OS X USB backend did not handle aborted or stalled pipe
98 conditions properly, which prevented drivers from ejecting partial
99 pages when a job was canceled or held.
100
101
102CHANGES IN CUPS V1.4b3
103
104 - Documentation fixes (STR #3044, STR #3057, STR #3153, STR #3158,
105 STR #3173)
106 - Added complete localizations for German, Japanese, Polish, and
107 Russian and partial localizations for Chinese, Danish, Finnish,
108 French, Italian, Korean, Norwegian, Portuguese, and Swedish
109 (STR #3096, STR #3098, STR #3109, STR #3111, STR #3141)
110 - Updated the configure check for -fstack-protector (STR #3198)
111 - The network backends now correctly convert SNMP supply descriptions to
112 UTF-8 encoding as needed.
113 - The scheduler could crash when deleting an attribute (STR #3197)
114 - The cups-driverd program did not detect symlink loops (STR #3185)
115 - The EPSON 24-pin series driver should now feed the correct amount
116 (STR #2624)
117 - The scheduler now automatically logs the last N debug messages for
118 failed print jobs.
119 - You can now modify a raw print queue (STR #3133)
120 - Fixed a number of ppdi issues and added a unit test to validate that
121 ppdc + ppdi can generate and import the same data (STR #3152)
122 - Moving jobs in the web interface now shows an error if you only have
123 one printer or class added (STR #3094)
124 - Since classes have never truly supported the printer-error-policy
125 stuff added in CUPS 1.2, update the code to reflect the current
126 reality and support only the retry-current-job policy for now
127 (STR #3171)
128 - Revised the password callback support (STR #2953)
129 - ppdEmit*() did not choose between PageSize and PageRegion properly.
130 - Make some fairly substantial changes to the Kerberos support code so
131 that CUPS can work in multi-realm environments and does not require
132 delegatable credentials. Shared printing still requires delegation,
133 however "delegation by policy" can be enabled in the KDC to make this
134 all work.
135 - "AccessLogLevel actions" did not hide client-error-not-found errors.
136 - AP_FIRST_InputSlot did not work with number-up.
137 - cupsBackChannelRead() and cupsBackChannelWrite() could fail due to a
138 lack of kernel buffers.
139 - The IPP and LPD backends did not respond to side-channel requests
140 while copying print data to a temporary file.
141 - cupsWriteRequestData() flushed the output buffer unnecessarily,
142 causing reduced performance in some situations.
143 - If a CGI process died before sending its MIME headers, the request
144 would hang on the client.
145 - The printer/class/job search feature on the web interface did not
146 work (STR #3132)
147 - The scheduler did not write the printers out for classes.
148 - CUPS-Get-PPDs did not work properly when filtering by language,
149 product, or psversion (STR #3136)
150 - The scheduler now kills job filters when it takes more than 30 seconds
151 (configurable) to cancel or hold the job.
152 - The cupstestppd program did not validate the capitalization of
153 filenames in the PPD file.
154 - The cupstestppd program did not validate the PageSize and PageRegion
155 values.
156 - The cups-deviced helper program could miss reporting some backend
157 devices (STR #3108)
158 - The cupsSideChannelSNMP* functions did not work.
159 - The scheduler could consume 100% CPU when jobs were canceled.
160 - Clicking on "Select Another Make/Manufacturer" in the web interface
161 incorrectly added the printer (STR #3095)
162 - The scheduler no longer uses programs with insecure file
163 permissions.
164 - httpAssembleURI*() did not escape backslashes in hostnames.
165 - The dnssd backend did not unquote "full names" before creating the
166 device URI.
167 - The scheduler now supports JobRetryInterval values less than 10
168 seconds.
169 - Updated the Spanish localization (STR #3090)
170 - The scheduler did not redo Bonjour/DNS-SD registrations when updating
171 them failed.
172 - The "authenticated" policy incorrectly required authentication for
173 status operations.
174 - ppdOpen*() incorrectly loaded PPDs with multiple JobPatchFile
175 keywords.
176 - The network backends no longer report the SNMP "offline" or
177 maintenance status bits since they are inconsistently implemented and
178 often unreliable.
179 - The scheduler no longer logs child processes killed via SIGKILL as
180 "crashed".
181 - The printer link shown on the "job moved" template was bad (STR #3085)
182 - Updated the HTML templates to use the final HTML 4 DOCTYPE (STR #3086)
183 - The scheduler did not track the "paused" reason properly if a
184 printer had other reasons associated with it.
185 - cupsSendRequest() did not clear old local certificate auth data.
186 - The PPD compiler did not search for localization files properly
187 (STR #3084)
188 - cupsGetNamedDest() did not use the fallback default like
189 cupsGetDests*() (STR #3082)
190 - The scheduler now provides a LogTimeFormat directive to enable
191 microseconds in the date and time that are logged.
192 - The scheduler now provides a MultipleOperationTimeout directive to
193 control the timeout for multi-file print jobs.
194 - The configure script incorrectly allowed Avahi to be used for DNS-SD
195 printer discovery (STR #3065)
196 - The web interface and scheduler did not support URIs up to 1024 bytes
197 in length (STR #3072)
198 - Fixed pdftops issues with page sizes (STR #3063)
199 - Fixed pdftops issues with Ghostscript (STR #3062)
200 - The scheduler incorrectly registered default profiles for PostScript
201 printers with no specified colorspace.
202 - The scheduler incorrectly created an empty org.cups.printers.plist
203 file on Mac OS X.
204 - cupsGetPPD3() did not look for local PPDs in the right directory.
205 - SNMP lookups via side-channel did not work for NULL-VALUE and
206 and OCTET-STRING OIDs containing nul characters.
207 - The libusb-based USB backend did not work.
208 - The scheduler did not set the printer-commands attribute correctly
209 for some PPDs.
210 - The ppdi utility did not work.
211 - The web interface no longer uses multi-part output with old or broken
212 web browsers (STR #3049)
213 - CUPS now conforms to the draft IPP/2.0 and IPP/2.1 specification.
214 - Added a new cupsGetConflicts() API to get a list of conflicting
215 options.
216 - The PPD compiler didn't localize options or choices that did not
217 have associated translation text (STR #3045)
218 - Updated the Spanish localization (STR #3043)
219 - Fixed build problems (STR #3040, STR #3047)
220 - cupsResolveConflicts() did not resolve using the default option
221 choice in some cases due to the mirror UIConstraints that are
222 present in most PPD files.
223 - The scheduler did not honor MIME type priorities.
224 - The commandtops filter incorrectly used the JCLBegin code to end
225 its jobs.
226 - The default BrowseLocalProtocols value was not set properly.
227 - Since the commandtops filter does not actually support ReportLevels
228 all on its own, don't list that printer command by default for PS
229 printers.
230 - The scheduler did not give filters a chance to log errors or update
231 printer attributes when a job was canceled.
232 - The scheduler did not clear the "connecting-to-device" reason keyword
233 when a job finished.
234
235
236CHANGES IN CUPS V1.4b2
237
238 - Documentation updates (STR #2983, STR #2998, STR #3021)
239 - The cupstestppd utility now validates the FileVersion and
240 FormatVersion values in PPD files.
241 - The default cupsd.conf file did not reflect the
242 --with-local-protocols value set at compile-time (STR #3037)
243 - The cupsGetPPD* APIs now create symlinks to local PPD files
244 rather than copying them whenever possible.
245 - Various performance optimizations in the string pool, dests, and
246 options implementations.
247 - The cupsGetDests* APIs now return the marker and printer-commands
248 attributes.
249 - Side-channel SNMP lookups would not work when cupsSNMPSupplies
250 was set to False in the PPD file.
251 - Localized the device descriptions for the SCSI, serial,
252 and network backends (STR #3014)
253 - Added a Spanish localization (STR #3015)
254 - Added support for marker-low-levels and marker-high-levels
255 attributes.
256 - The scheduler could hang writing a long log line.
257 - The cupsGetDevices() function now has an "include_schemes"
258 parameter.
259 - The lpinfo command now supports --include-schemes and
260 --exclude-schemes options.
261 - The CUPS-Get-PPDs operation now supports the include-schemes
262 and exclude-schemes attributes.
263 - The CUPS-Get-Devices operation now supports the include-schemes
264 attribute.
265 - The print filters now support a replacement for the fitplot
266 option called "fit-to-page".
267 - The LPD backend no longer tries to collect page accounting
268 information since the LPD protocol does not allow us to
269 prevent race conditions.
270 - The scheduler did not save the last marker-change-time value.
271 - Fixed a problem with printing to some IPP printers, including
272 CUPS 1.1.x.
273 - Fixed a redirection problem with the printer web page (STR #3012)
274 - Fixed a PPD compiler problem with the loading of message
275 catalogs (STR #2990)
276 - Fixed a PPD compiler problem with the loading of .strings files
277 (STR #2989)
278 - The cupsfilter utility did not set the CONTENT_TYPE environment
279 variable when running filters.
280 - The scheduler now waits to allow system sleep until the jobs
281 have all stopped.
282 - The IPP, LPD, and socket backends used different "connecting"
283 progress messages.
284
285
286CHANGES IN CUPS V1.4b1
287
288 - Documentation updates (STR #2567)
289 - The PPD compiler now allows local message catalogs to
290 override the standard CUPS translations (STR #2642)
291 - The ppdmerge command did not merge custom option strings
292 (STR #2863)
293 - The scheduler now supports the Hold-New-Jobs and
294 Release-Held-New-Jobs operations; these are exposed via the
295 cupsdisable and cupsenable commands (STR #2332)
296 - The lpstat command is now much faster when displaying the
297 status of a single printer (STR #2843)
298 - The scheduler now caches information from PPD files to provide
299 significantly faster startup time with large numbers of PPDs
300 (STR #1293)
301 - CUPS-Get-Driver now provides much better driver matching based
302 on the IEEE-1284 device ID and make/model strings (STR #2707)
303 - Now support the cupsSNMPSupplies keyword to control whether
304 the network backends query the SNMP Printer MIB for supply
305 levels.
306 - Now support and use a new banner file format for better text
307 support and easier customization (STR #2490)
308 - The scheduler now sets the PRINTER_INFO and PRINTER_LOCATION
309 environment variables from the corresponding IPP attributes.
310 - The ippRead*() and ippWrite*() functions no longer use a
311 stack-based buffer (STR #2388)
312 - The CUPS-Add-Modify-Printer operation now allows you to set
313 the printer-state-reasons attribute.
314 - The "set printer options" page now supports auto-configuration
315 of printer options (STR #1440)
316 - The web interface now provides an advanced server settings
317 form.
318 - The web interface's "modify printer" pages now make it
319 easier to change just one setting (STR #1919)
320 - The scheduler now supports a plist PrintcapFormat.
321 - The scheduler now supports multiple addresses in Allow and
322 Deny lines, just like Apache (STR #2947)
323 - Added CUPS_JOBTYPE environment variable for job filters so
324 they know whether they are printing a banner or document
325 file (STR #2799)
326 - Added support for printer filtering by the cupsfilter
327 command (STR #2562)
328 - Added a SSLOptions directive to allow Windows clients to
329 talk to CUPS in FIPS mode (STR #2827)
330 - Renamed the accept and reject commands to cupsaccept and
331 cupsreject; the old names are still available (STR #2936)
332 - The locale/translate utility needed an update to work with
333 Google (STR #2882)
334 - The lpstat command now supports a -H option to display the
335 default server (STR #2833)
336 - The scheduler now supports a FatalErrors directive to control
337 which errors should cause the scheduler to exit (STR #2536)
338 - The scheduler now uses the php-cgi program if it is available
339 (STR #2923)
340 - The scheduler now supports a DefaultPaperSize directive
341 (STR #2848)
342 - The scheduler now passes the job-originating-host-name
343 value to filters in the options argument (STR #2558)
344 - CUPS now supports job tickets in PDF files (STR #2903)
345 - Added a DBUS notifier (STR #2529)
346 - The LPD mini-daemon now passes the document name when queuing
347 print jobs (STR #2482)
348 - The IPP backend did not relay com.apple.print.recoverable-message
349 values.
350 - The scheduler now supports a job-media-progress attribute to
351 track the progress of individual pages.
352 - The sample HP driver now supports A5 (STR #2798)
353 - The CUPS web interface menu item now uses the xdg-open
354 command, when available (STR #2724)
355 - The cups-lpd program now supports the -h option (STR #2794)
356 - The scheduler now sets the PAM_TTY parameter and the
357 PAM_ESTABLISH_CRED credential flag (STR #2745)
358 - The scheduler now logs unsuccessful requests to the error_log
359 file as errors (STR #2616)
360 - Added support for a "retry-current-job" error policy that
361 retries the current job immediately when the backend encounters
362 an error (STR #2555)
363 - The scheduler now returns a "forbidden" error when a user
364 correctly authenticates but does not have permission to
365 continue further (STR #2101)
366 - The scheduler now loads both the server and CA certificates
367 (if present) from the ServerCertificate file (STR #2146)
368 - New RSS subscriptions now create their feed files immediately
369 (STR #2853)
370 - Added support for a device-location attribute which provides
371 the physical location of a printer device.
372 - Added a cupsBackendReport() API which handles quoting of the
373 device data by a backend.
374 - Added support for custom options in the web interface
375 (STR #1729)
376 - Added support for Mozilla LDAP, reconnection to LDAP servers,
377 and improved LDAP performance (STR #1962)
378 - Added Solaris SMF support (STR #1477)
379 - Added optional support for using TCP wrappers to limit access
380 to CUPS (STR #263)
381 - Added ppdPageSizeLimits API.
382 - Added support for new cupsMediaQualifier2, cupsMediaQualifier3,
383 cupsMinSize, and cupsMaxSize attributes.
384 - Added cupsResolveConflicts and ppdInstallableConflict APIs.
385 - Added support for new cupsUIConstraints and cupsUIResolver
386 attributes for better option conflict detection and
387 resolution.
388 - Increased the maximum size of 1284 device ID strings to
389 256 bytes (STR #2877)
390 - Added an AccessLogLevel directive to cupsd.conf to control
391 what is logged to the access_log file.
392 - The default LogLevel is now "warn" instead of "info" to reduce
393 the amount of logging that is done to disk by default.
394 - The PPD compiler did not include OID query keywords in PPD
395 files (STR #2871)
396 - The cups-driverd helper program now directly supports driver
397 information files.
398 - The USB backend now uses libusb when available (STR #1575)
399 - Added ppdLocalizeAttr function to get the localized version
400 of an attribute.
401 - MIME types now support a priority() attribute (STR #2719)
402 - The standard MIME types are now installed in
403 DataDir/mime (STR #2719)
404 - The lpoptions command now describes custom options and
405 the necessary parameters (STR #2660)
406 - The ppdmerge program did not support Simplified Chinese
407 or Traditional Chinese language version strings (STR #2851)
408 - The PPD compiler now supports localizable attributes
409 (STR #2738)
410 - The ppdpo utility now includes cupsIPPReasons values in
411 the message catalogs it generates (STR #2754)
412 - The PPD compiler now supports conditional directives
413 (STR #2636)
414 - The ppdc utility now supports a "-t" option to test PPD
415 files (STR #2739)
416 - The ppdc utility now supports a "-m" option to use the
417 ModelName value as the output filename.
418 - The ppdc utility now supports a FileName directive to
419 set an alternate output filename (STR #2740)
420 - The side-channel API now supports SNMP queries for the
421 standard network backends.
422 - Added a PageLogFormat directive to the cupsd.conf file to
423 control the format of lines in the page_log file.
424 - Filters can now send PPD: messages to stderr to set PPD
425 keywords like DefaultPageSize while a job is printing.
426 - Added a mdns backend for discovery and printing to printers
427 that advertise themselves via DNS-SD (Bonjour)
428 - The ipp, lpd, and socket backends now support DNS-SD service
429 name resolution.
430 - The scheduler now uses a single shared file descriptor for
431 all DNS-SD registrations (STR #2674)
432 - The ipp, lpd, and socket backends now support SNMP-based
433 page accounting and supply level monitoring (STR #1655)
434 - Added support for cupsPJLDisplay attribute to control what
435 PJL commands are used to display the job information.
436 - Driver information files can now be installed in
437 /Library/Printers/PPDs.drv on Mac OS X.
438 - The CUPS image library now supports reading images larger
439 than 2GB.
440 - The scheduler now delays writing config and state files to
441 reduce disk activity (STR #2684)
442 - The CUPS-Get-Devices operation now supports the
443 exclude-schemes and timeout attributes to control which
444 backends are polled and for how long.
445 - The cups-deviced helper application now runs backends in
446 parallel to get the list of devices faster.
447 - Added --enable-pap configure option.
448 - The default cupsd.conf file now includes an "authenticated"
449 policy which requires authentication for remote print jobs.
450 - Added support for Czech and Hungarian in PPD files
451 (STR #2735, STR #2736)
452 - The PPD compiler tools now support Mac OS X .strings files
453 for localization (STR #2737)
454 - ppdOpen*() now default the colorspace member to PPD_CS_N
455 when no DefaultColorSpace attribute is present in the PPD
456 file.
457 - The build system has been updated to support separate
458 installation of data, program, header, and library files.
459 - All support libraries are now built as shared libraries
460 by default.
461 - The scheduler now manages ICC color profiles on Mac OS X.
462 - The network backends (ipp, lpd, socket) now support
463 SNMP-based supply and page count monitoring (STR #1655)
464 - The lppasswd program is no longer installed setuid to
465 root to make the default installation more secure.
466 - Added a new ppdLocalizeMarkerName() function to get
467 the localized version of a marker-names value.
468 - The scheduler now provides the printer-dns-sd-name
469 attribute for printers shared via DNS-SD/Bonjour.
470 - The pdftops filter now executes the Xpdf or poppler
471 pdftops utility to convert PDF files (STR #1471)
472 - Bonjour printer registrations now advertise as local or
473 global based on the current access policies for the
474 printer.
475 - cupsGetDests*() and cupsSetDests*() now track the last
476 used printer preference on Mac OS X.
477 - Added a new streaming request API (STR #2261)
478 - Added a new cupsGetNamedDest() function to the CUPS
479 library for faster printing with lp and lpr (STR #2638)
480 - The scheduler now sets the PAM RHOST value on systems
481 that support it (STR #2637)
482 - The scheduler now sandboxes child processes when
483 possible.
484 - The Cancel-Job operation now supports a purge-job
485 attriibute to purge a specified job.
486 - ppdEmit* and ppdCollect* now use the NonUIOrderDependency
487 attributes for custom option selections.
488 - The web interface now enables/disables the printer
489 sharing (formerly publishing) controls based on the
490 server-is-sharing-printers state (STR #2233)
491 - The scheduler now tracks printer sharing via the
492 server-is-sharing-printers attribute, and manages LPD
493 and SMB sharing as well (STR #2233)
494 - The web interface now allows you to go back to the make/
495 manufacturer page if there is no matching printer driver
496 on the model page (STR #2436)
497 - The printer list now shows the default media, banner, and
498 duplex options as well as the color and duplex capabilities
499 of printers (STR #1175)
500 - The web interface look-n-feel has been updated (STR #2492)
501 - The scheduler now supports a CUPS-Get-Document operation
502 that returns the specified print job document (STR #118)
503 - The cupsfilter utility now supports a "-J jobid" option
504 to filter the document from the specified job.
505 - The scheduler (cupsd) now supports a new option (-t) to
506 do a syntax check of the cupsd.conf file (STR #2003)
507 - Added new cupsGetPPD3() API to allow applications to
508 cache PPDs safely (STR #1473)
509 - Added generic PostScript and PCL printer driver PPDs.