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