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