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