]> git.ipfire.org Git - thirdparty/cups.git/commitdiff
Merge changes from CUPS 1.5svn-r8829.
authormsweet <msweet@a1ca3aef-8c08-0410-bb20-df032aa958be>
Thu, 24 Sep 2009 23:50:39 +0000 (23:50 +0000)
committermsweet <msweet@a1ca3aef-8c08-0410-bb20-df032aa958be>
Thu, 24 Sep 2009 23:50:39 +0000 (23:50 +0000)
git-svn-id: svn+ssh://src.apple.com/svn/cups/easysw/current@1695 a1ca3aef-8c08-0410-bb20-df032aa958be

35 files changed:
CHANGES-1.4.txt [new file with mode: 0644]
CHANGES.txt
backend/backend-private.h
backend/ipp.c
backend/network.c
backend/pap.c
backend/parallel.c
backend/runloop.c
backend/serial.c
backend/snmp-supplies.c
backend/usb-darwin.c
backend/usb-libusb.c
backend/usb-unix.c
conf/Makefile
conf/cupsd.conf.in
conf/pam.irix [deleted file]
conf/pam.std.in
config-scripts/cups-common.m4
config-scripts/cups-pam.m4
cups/cups.h
cups/sidechannel.c
cups/sidechannel.h
cups/snmp.c
doc/help/spec-ipp.html
filter/hpgl-input.c
ppdc/ppdc.cxx
ppdc/sample.drv
scheduler/cups-driverd.cxx
scheduler/ipp.c
scheduler/printers.c
standards/cs-ipp20-20090731-5100.10.pdf [new file with mode: 0644]
standards/cs-ippstate10-20090731-5100.9.pdf [new file with mode: 0644]
standards/lcrc-ipp20-20090602.pdf [deleted file]
standards/lcrc-ippstate10-20090603.pdf [deleted file]
tools/makesrcdist

diff --git a/CHANGES-1.4.txt b/CHANGES-1.4.txt
new file mode 100644 (file)
index 0000000..7bf0924
--- /dev/null
@@ -0,0 +1,533 @@
+CHANGES-1.4.txt
+---------------
+
+CHANGES IN CUPS V1.4.2
+
+       - cupsSideChannelRead() did not return an error for short reads.
+       - The installed PAM configuration file did not use the correct options
+         with the pam_unix2 module (STR #3313)
+       - The scheduler did not preserve default options that contained special
+         characters (STR #3340)
+       - The scheduler did not remove old pre-filters when updating a printer
+         driver (STR #3342)
+       - The HP/GL-2 filter did not check for early end-of-file (STR #3319)
+       - The USB backend did not compile on some platforms (STR #3332)
+       - cupsSideChannelSNMPWalk() could go into an infinite loop with broken
+         SNMP implementations.
+
+
+CHANGES IN CUPS V1.4.1
+
+       - Documention fixes (STR #3296)
+       - SNMP supply levels and states were wrong for some printers.
+       - The IPP backend did not update the auth-info-required value.
+       - The libusb-based USB backend would hang at the end of the job
+         (STR #3315, STR #3318)
+       - DNS-SD registrations for raw queues had an empty "ty" key (STR #3299)
+       - The JPEG and BMP MIME type rules were broken (STR #3284)
+       - cupsGetNamedDest returned the default printer when the named
+         destination did not exist (STR #3285)
+       - The JobKillDelay was not triggered for canceled jobs (STR #3292)
+       - The PPD compiler could get in an infinite loop (STR #3293)
+       - The configure check for dns-sd.h was broken (STR #3297)
+       - The "Query Printer for Default Options" page did not go away if the
+         query job was held (STR #3302)
+       - Boolean options did not show up as selected in the web interface
+         (STR #3303)
+       - The scheduler did not cache or report driver information files
+         correctly, leading to a variety of issues (STR #3283, STR #3297,
+         STR #3305)
+       - cupsDoIORequest() did not abort on permanent errors (STR #3311)
+       - Modifying a class in the web interface did not work (STR #3312)
+       - BrowseLocalProtocols could be cleared when changing the sharing
+         setting (STR #3287)
+       - The scheduler could return an empty supported document format
+         (STR #3308)
+       - The PPD compiler generated invalid PPD files when the locale used
+         something other than "." for the decimal point (STR #3300)
+       - The IPP backend did not handle some non-comforming IPP printer
+         implementations (STR #3262)
+       - The scheduler leaked three file descriptors to each job filter
+         (STR #3263)
+       - The scheduler now uses a default CUPS-Get-Devices timeout of 15
+         seconds (STR #3307)
+
+
+CHANGES IN CUPS V1.4.0
+
+       - Localization updates (STR #3223, STR #3246, STR #3248, STR #3250)
+       - Documentation updates (STR #3225, STR #3230, STR #3242, STR #3260)
+       - The --with-pdftops configure option did not accept a full path to the
+         filter (STR #3278)
+       - The banner filter did not position the back side image correctly
+         (STR #3277)
+       - The dnssd backend could crash (STR #3272)
+       - The 1284 device ID sometimes contained trailing garbage (STR #3266)
+       - The USB backend returned different URIs for some printers than in
+         CUPS 1.3 (STR #3259)
+       - The scheduler did not do local job-hold-until processing for remote
+         queues (STR #3258)
+       - The scheduler did not try all possible SSL certificates on Mac OS X.
+       - The scheduler did not always remove a file descriptor when using the
+         kqueue interface (STR #3256)
+       - The scheduler did not protect against bad job control files in all
+         cases (STR #3253)
+       - The scheduler did not encode "+" in model names (STR #3254)
+       - The web interface didn't show the default options (STR #3244)
+       - The IPP and LPD backends needed print data before they would do an
+         SNMP query.
+       - Fixed a GNU TLS compatibility issue (STR #3231)
+       - Fixed a HTML error in the add and modify printer web interface
+         templates (STR #3229)
+       - The scheduler did not minimize the number of printer state events that
+         were generated by filter STATE: messages, which could lead to poor
+         performance.
+       - The USB backend on Mac OS X did not cleanly cancel a job.
+       - The network backends now set the connecting-to-device printer-state-
+         reasons value when looking up the address and copying the print data
+         for consistency.
+       - The scheduler now supports the com.apple.print.recoverable-warning
+         reason on all platforms.
+
+
+CHANGES IN CUPS V1.4rc1
+
+       - The PPD compiler documentation was missing information on localization
+         (STR #3212)
+       - The IPP backend now reconnects after every request when talking to
+         printers that claim IPP support but only use HTTP/1.0.
+       - The PPD compiler crashed when both "Resolution" and "Group foo Option
+         Resolution" were specified in the .drv file.
+       - The PPD compiler's #if/#elif/#else/#endif did not work for undefined
+         variables (STR #3210)
+       - Static libraries could not be installed by a non-root user on systems
+         needing a ranlib program (STR #3209)
+       - The scheduler incorrectly always tried to copy Kerberos credentials
+         for print jobs.
+       - Updated the Spanish localization (STR #3204)
+       - The scheduler crashed when getting the default paper size from
+         libpaper (STR #3205, STR #3206)
+       - The PPD compiler now defines six variables: CUPS_VERSION,
+         CUPS_VERSION_MAJOR, CUPS_VERSION_MINOR, CUPS_VERSION_PATCH,
+         PLATFORM_NAME, and PLATFORM_ARCH (STR #3203)
+       - Fixed a whitespace skipping bug in cupsRasterInterpretPPD.
+       - The scheduler did not return HTTP 403 (Forbidden) for authenticated
+         users that were not authorized to do IPP operations (STR #3193)
+       - The scheduler did not report more than 8 Product strings from a PPD
+         file.  Some PPD files have as many as 24.
+       - ppdOpen*() could crash if a keyword had no value string (something
+         that cupstestppd looks for...)
+       - cupsLangDefault() did not return the correct language on Mac OS X.
+       - The Mac OS X USB backend did not handle aborted or stalled pipe
+         conditions properly, which prevented drivers from ejecting partial
+         pages when a job was canceled or held.
+
+
+CHANGES IN CUPS V1.4b3
+
+       - Documentation fixes (STR #3044, STR #3057, STR #3153, STR #3158,
+         STR #3173)
+       - Added complete localizations for German, Japanese, Polish, and
+         Russian and partial localizations for Chinese, Danish, Finnish,
+         French, Italian, Korean, Norwegian, Portuguese, and Swedish
+         (STR #3096, STR #3098, STR #3109, STR #3111, STR #3141)
+       - Updated the configure check for -fstack-protector (STR #3198)
+       - The network backends now correctly convert SNMP supply descriptions to
+         UTF-8 encoding as needed.
+       - The scheduler could crash when deleting an attribute (STR #3197)
+       - The cups-driverd program did not detect symlink loops (STR #3185)
+       - The EPSON 24-pin series driver should now feed the correct amount
+         (STR #2624)
+       - The scheduler now automatically logs the last N debug messages for
+         failed print jobs.
+       - You can now modify a raw print queue (STR #3133)
+        - Fixed a number of ppdi issues and added a unit test to validate that
+         ppdc + ppdi can generate and import the same data (STR #3152)
+       - Moving jobs in the web interface now shows an error if you only have
+         one printer or class added (STR #3094)
+       - Since classes have never truly supported the printer-error-policy
+         stuff added in CUPS 1.2, update the code to reflect the current
+         reality and support only the retry-current-job policy for now
+         (STR #3171)
+       - Revised the password callback support (STR #2953)
+       - ppdEmit*() did not choose between PageSize and PageRegion properly.
+       - Make some fairly substantial changes to the Kerberos support code so
+         that CUPS can work in multi-realm environments and does not require
+         delegatable credentials.  Shared printing still requires delegation,
+         however "delegation by policy" can be enabled in the KDC to make this
+         all work.
+       - "AccessLogLevel actions" did not hide client-error-not-found errors.
+       - AP_FIRST_InputSlot did not work with number-up.
+       - cupsBackChannelRead() and cupsBackChannelWrite() could fail due to a
+         lack of kernel buffers.
+       - The IPP and LPD backends did not respond to side-channel requests
+         while copying print data to a temporary file.
+       - cupsWriteRequestData() flushed the output buffer unnecessarily,
+         causing reduced performance in some situations.
+       - If a CGI process died before sending its MIME headers, the request
+         would hang on the client.
+       - The printer/class/job search feature on the web interface did not
+         work (STR #3132)
+       - The scheduler did not write the printers out for classes.
+       - CUPS-Get-PPDs did not work properly when filtering by language,
+         product, or psversion (STR #3136)
+       - The scheduler now kills job filters when it takes more than 30 seconds
+         (configurable) to cancel or hold the job.
+       - The cupstestppd program did not validate the capitalization of
+         filenames in the PPD file.
+       - The cupstestppd program did not validate the PageSize and PageRegion
+         values.
+       - The cups-deviced helper program could miss reporting some backend
+         devices (STR #3108)
+       - The cupsSideChannelSNMP* functions did not work.
+       - The scheduler could consume 100% CPU when jobs were canceled.
+       - Clicking on "Select Another Make/Manufacturer" in the web interface
+         incorrectly added the printer (STR #3095)
+       - The scheduler no longer uses programs with insecure file
+         permissions.
+       - httpAssembleURI*() did not escape backslashes in hostnames.
+       - The dnssd backend did not unquote "full names" before creating the
+         device URI.
+       - The scheduler now supports JobRetryInterval values less than 10
+         seconds.
+       - Updated the Spanish localization (STR #3090)
+       - The scheduler did not redo Bonjour/DNS-SD registrations when updating
+         them failed.
+       - The "authenticated" policy incorrectly required authentication for
+         status operations.
+       - ppdOpen*() incorrectly loaded PPDs with multiple JobPatchFile
+         keywords.
+       - The network backends no longer report the SNMP "offline" or
+         maintenance status bits since they are inconsistently implemented and
+         often unreliable.
+       - The scheduler no longer logs child processes killed via SIGKILL as
+         "crashed".
+       - The printer link shown on the "job moved" template was bad (STR #3085)
+       - Updated the HTML templates to use the final HTML 4 DOCTYPE (STR #3086)
+       - The scheduler did not track the "paused" reason properly if a
+         printer had other reasons associated with it.
+       - cupsSendRequest() did not clear old local certificate auth data.
+       - The PPD compiler did not search for localization files properly
+         (STR #3084)
+       - cupsGetNamedDest() did not use the fallback default like
+         cupsGetDests*() (STR #3082)
+       - The scheduler now provides a LogTimeFormat directive to enable
+         microseconds in the date and time that are logged.
+       - The scheduler now provides a MultipleOperationTimeout directive to
+         control the timeout for multi-file print jobs.
+       - The configure script incorrectly allowed Avahi to be used for DNS-SD
+         printer discovery (STR #3065)
+       - The web interface and scheduler did not support URIs up to 1024 bytes
+         in length (STR #3072)
+       - Fixed pdftops issues with page sizes (STR #3063)
+       - Fixed pdftops issues with Ghostscript (STR #3062)
+       - The scheduler incorrectly registered default profiles for PostScript
+         printers with no specified colorspace.
+       - The scheduler incorrectly created an empty org.cups.printers.plist
+         file on Mac OS X.
+       - cupsGetPPD3() did not look for local PPDs in the right directory.
+       - SNMP lookups via side-channel did not work for NULL-VALUE and
+         and OCTET-STRING OIDs containing nul characters.
+       - The libusb-based USB backend did not work.
+       - The scheduler did not set the printer-commands attribute correctly
+         for some PPDs.
+       - The ppdi utility did not work.
+       - The web interface no longer uses multi-part output with old or broken
+         web browsers (STR #3049)
+       - CUPS now conforms to the draft IPP/2.0 and IPP/2.1 specification.
+       - Added a new cupsGetConflicts() API to get a list of conflicting
+         options.
+       - The PPD compiler didn't localize options or choices that did not
+         have associated translation text (STR #3045)
+       - Updated the Spanish localization (STR #3043)
+       - Fixed build problems (STR #3040, STR #3047)
+       - cupsResolveConflicts() did not resolve using the default option
+         choice in some cases due to the mirror UIConstraints that are
+         present in most PPD files.
+       - The scheduler did not honor MIME type priorities.
+       - The commandtops filter incorrectly used the JCLBegin code to end
+         its jobs.
+       - The default BrowseLocalProtocols value was not set properly.
+       - Since the commandtops filter does not actually support ReportLevels
+         all on its own, don't list that printer command by default for PS
+         printers.
+       - The scheduler did not give filters a chance to log errors or update
+         printer attributes when a job was canceled.
+       - The scheduler did not clear the "connecting-to-device" reason keyword
+         when a job finished.
+
+
+CHANGES IN CUPS V1.4b2
+
+       - Documentation updates (STR #2983, STR #2998, STR #3021)
+       - The cupstestppd utility now validates the FileVersion and
+         FormatVersion values in PPD files.
+       - The default cupsd.conf file did not reflect the
+         --with-local-protocols value set at compile-time (STR #3037)
+       - The cupsGetPPD* APIs now create symlinks to local PPD files
+         rather than copying them whenever possible.
+       - Various performance optimizations in the string pool, dests, and
+         options implementations.
+       - The cupsGetDests* APIs now return the marker and printer-commands
+         attributes.
+       - Side-channel SNMP lookups would not work when cupsSNMPSupplies
+         was set to False in the PPD file.
+       - Localized the device descriptions for the SCSI, serial,
+         and network backends (STR #3014)
+       - Added a Spanish localization (STR #3015)
+       - Added support for marker-low-levels and marker-high-levels
+         attributes.
+       - The scheduler could hang writing a long log line.
+       - The cupsGetDevices() function now has an "include_schemes"
+         parameter.
+       - The lpinfo command now supports --include-schemes and
+         --exclude-schemes options.
+       - The CUPS-Get-PPDs operation now supports the include-schemes
+         and exclude-schemes attributes.
+        - The CUPS-Get-Devices operation now supports the include-schemes
+         attribute.
+       - The print filters now support a replacement for the fitplot
+         option called "fit-to-page".
+       - The LPD backend no longer tries to collect page accounting
+         information since the LPD protocol does not allow us to
+         prevent race conditions.
+       - The scheduler did not save the last marker-change-time value.
+       - Fixed a problem with printing to some IPP printers, including
+         CUPS 1.1.x.
+       - Fixed a redirection problem with the printer web page (STR #3012)
+       - Fixed a PPD compiler problem with the loading of message
+         catalogs (STR #2990)
+       - Fixed a PPD compiler problem with the loading of .strings files
+         (STR #2989)
+       - The cupsfilter utility did not set the CONTENT_TYPE environment
+         variable when running filters.
+       - The scheduler now waits to allow system sleep until the jobs
+         have all stopped.
+       - The IPP, LPD, and socket backends used different "connecting"
+         progress messages.
+
+
+CHANGES IN CUPS V1.4b1
+
+       - Documentation updates (STR #2567)
+       - The PPD compiler now allows local message catalogs to
+         override the standard CUPS translations (STR #2642)
+       - The ppdmerge command did not merge custom option strings
+         (STR #2863)
+       - The scheduler now supports the Hold-New-Jobs and
+         Release-Held-New-Jobs operations; these are exposed via the
+         cupsdisable and cupsenable commands (STR #2332)
+       - The lpstat command is now much faster when displaying the
+         status of a single printer (STR #2843)
+       - The scheduler now caches information from PPD files to provide
+         significantly faster startup time with large numbers of PPDs
+         (STR #1293)
+       - CUPS-Get-Driver now provides much better driver matching based
+         on the IEEE-1284 device ID and make/model strings (STR #2707)
+       - Now support the cupsSNMPSupplies keyword to control whether
+         the network backends query the SNMP Printer MIB for supply
+         levels.
+       - Now support and use a new banner file format for better text
+         support and easier customization (STR #2490)
+       - The scheduler now sets the PRINTER_INFO and PRINTER_LOCATION
+         environment variables from the corresponding IPP attributes.
+       - The ippRead*() and ippWrite*() functions no longer use a
+         stack-based buffer (STR #2388)
+       - The CUPS-Add-Modify-Printer operation now allows you to set
+         the printer-state-reasons attribute.
+       - The "set printer options" page now supports auto-configuration
+         of printer options (STR #1440)
+       - The web interface now provides an advanced server settings
+         form.
+       - The web interface's "modify printer" pages now make it
+         easier to change just one setting (STR #1919)
+       - The scheduler now supports a plist PrintcapFormat.
+       - The scheduler now supports multiple addresses in Allow and
+         Deny lines, just like Apache (STR #2947)
+       - Added CUPS_JOBTYPE environment variable for job filters so
+         they know whether they are printing a banner or document
+         file (STR #2799)
+       - Added support for printer filtering by the cupsfilter
+         command (STR #2562)
+       - Added a SSLOptions directive to allow Windows clients to
+         talk to CUPS in FIPS mode (STR #2827)
+       - Renamed the accept and reject commands to cupsaccept and
+         cupsreject; the old names are still available (STR #2936)
+       - The locale/translate utility needed an update to work with
+         Google (STR #2882)
+       - The lpstat command now supports a -H option to display the
+         default server (STR #2833)
+       - The scheduler now supports a FatalErrors directive to control
+         which errors should cause the scheduler to exit (STR #2536)
+       - The scheduler now uses the php-cgi program if it is available
+         (STR #2923)
+       - The scheduler now supports a DefaultPaperSize directive
+         (STR #2848)
+       - The scheduler now passes the job-originating-host-name
+         value to filters in the options argument (STR #2558)
+       - CUPS now supports job tickets in PDF files (STR #2903)
+       - Added a DBUS notifier (STR #2529)
+       - The LPD mini-daemon now passes the document name when queuing
+         print jobs (STR #2482)
+       - The IPP backend did not relay com.apple.print.recoverable-message
+         values.
+       - The scheduler now supports a job-media-progress attribute to
+         track the progress of individual pages.
+       - The sample HP driver now supports A5 (STR #2798)
+       - The CUPS web interface menu item now uses the xdg-open
+         command, when available (STR #2724)
+       - The cups-lpd program now supports the -h option (STR #2794)
+       - The scheduler now sets the PAM_TTY parameter and the
+         PAM_ESTABLISH_CRED credential flag (STR #2745)
+       - The scheduler now logs unsuccessful requests to the error_log
+         file as errors (STR #2616)
+       - Added support for a "retry-current-job" error policy that
+         retries the current job immediately when the backend encounters
+         an error (STR #2555)
+       - The scheduler now returns a "forbidden" error when a user
+         correctly authenticates but does not have permission to
+         continue further (STR #2101)
+       - The scheduler now loads both the server and CA certificates
+         (if present) from the ServerCertificate file (STR #2146)
+       - New RSS subscriptions now create their feed files immediately
+         (STR #2853)
+       - Added support for a device-location attribute which provides
+         the physical location of a printer device.
+       - Added a cupsBackendReport() API which handles quoting of the
+         device data by a backend.
+       - Added support for custom options in the web interface
+         (STR #1729)
+       - Added support for Mozilla LDAP, reconnection to LDAP servers,
+         and improved LDAP performance (STR #1962)
+       - Added Solaris SMF support (STR #1477)
+       - Added optional support for using TCP wrappers to limit access
+         to CUPS (STR #263)
+       - Added ppdPageSizeLimits API.
+       - Added support for new cupsMediaQualifier2, cupsMediaQualifier3,
+         cupsMinSize, and cupsMaxSize attributes.
+       - Added cupsResolveConflicts and ppdInstallableConflict APIs.
+       - Added support for new cupsUIConstraints and cupsUIResolver
+         attributes for better option conflict detection and
+         resolution.
+       - Increased the maximum size of 1284 device ID strings to
+         256 bytes (STR #2877)
+       - Added an AccessLogLevel directive to cupsd.conf to control
+         what is logged to the access_log file.
+       - The default LogLevel is now "warn" instead of "info" to reduce
+         the amount of logging that is done to disk by default.
+       - The PPD compiler did not include OID query keywords in PPD
+         files (STR #2871)
+       - The cups-driverd helper program now directly supports driver
+         information files.
+       - The USB backend now uses libusb when available (STR #1575)
+       - Added ppdLocalizeAttr function to get the localized version
+         of an attribute.
+       - MIME types now support a priority() attribute (STR #2719)
+       - The standard MIME types are now installed in
+         DataDir/mime (STR #2719)
+       - The lpoptions command now describes custom options and
+         the necessary parameters (STR #2660)
+       - The ppdmerge program did not support Simplified Chinese
+         or Traditional Chinese language version strings (STR #2851)
+       - The PPD compiler now supports localizable attributes
+         (STR #2738)
+       - The ppdpo utility now includes cupsIPPReasons values in
+         the message catalogs it generates (STR #2754)
+       - The PPD compiler now supports conditional directives
+         (STR #2636)
+       - The ppdc utility now supports a "-t" option to test PPD
+         files (STR #2739)
+       - The ppdc utility now supports a "-m" option to use the
+         ModelName value as the output filename.
+       - The ppdc utility now supports a FileName directive to
+         set an alternate output filename (STR #2740)
+       - The side-channel API now supports SNMP queries for the
+         standard network backends.
+       - Added a PageLogFormat directive to the cupsd.conf file to
+         control the format of lines in the page_log file.
+       - Filters can now send PPD: messages to stderr to set PPD
+         keywords like DefaultPageSize while a job is printing.
+       - Added a mdns backend for discovery and printing to printers
+         that advertise themselves via DNS-SD (Bonjour)
+       - The ipp, lpd, and socket backends now support DNS-SD service
+         name resolution.
+       - The scheduler now uses a single shared file descriptor for
+         all DNS-SD registrations (STR #2674)
+       - The ipp, lpd, and socket backends now support SNMP-based
+         page accounting and supply level monitoring (STR #1655)
+       - Added support for cupsPJLDisplay attribute to control what
+         PJL commands are used to display the job information.
+       - Driver information files can now be installed in
+         /Library/Printers/PPDs.drv on Mac OS X.
+       - The CUPS image library now supports reading images larger
+         than 2GB.
+       - The scheduler now delays writing config and state files to
+         reduce disk activity (STR #2684)
+       - The CUPS-Get-Devices operation now supports the
+         exclude-schemes and timeout attributes to control which
+         backends are polled and for how long.
+       - The cups-deviced helper application now runs backends in
+         parallel to get the list of devices faster.
+       - Added --enable-pap configure option.
+       - The default cupsd.conf file now includes an "authenticated"
+         policy which requires authentication for remote print jobs.
+       - Added support for Czech and Hungarian in PPD files
+         (STR #2735, STR #2736)
+       - The PPD compiler tools now support Mac OS X .strings files
+         for localization (STR #2737)
+       - ppdOpen*() now default the colorspace member to PPD_CS_N
+         when no DefaultColorSpace attribute is present in the PPD
+         file.
+       - The build system has been updated to support separate
+         installation of data, program, header, and library files.
+       - All support libraries are now built as shared libraries
+         by default.
+       - The scheduler now manages ICC color profiles on Mac OS X.
+       - The network backends (ipp, lpd, socket) now support
+         SNMP-based supply and page count monitoring (STR #1655)
+       - The lppasswd program is no longer installed setuid to
+         root to make the default installation more secure.
+       - Added a new ppdLocalizeMarkerName() function to get
+         the localized version of a marker-names value.
+       - The scheduler now provides the printer-dns-sd-name
+         attribute for printers shared via DNS-SD/Bonjour.
+       - The pdftops filter now executes the Xpdf or poppler
+         pdftops utility to convert PDF files (STR #1471)
+       - Bonjour printer registrations now advertise as local or
+         global based on the current access policies for the
+         printer.
+       - cupsGetDests*() and cupsSetDests*() now track the last
+         used printer preference on Mac OS X.
+       - Added a new streaming request API (STR #2261)
+       - Added a new cupsGetNamedDest() function to the CUPS
+         library for faster printing with lp and lpr (STR #2638)
+       - The scheduler now sets the PAM RHOST value on systems
+         that support it (STR #2637)
+       - The scheduler now sandboxes child processes when
+         possible.
+       - The Cancel-Job operation now supports a purge-job
+         attriibute to purge a specified job.
+       - ppdEmit* and ppdCollect* now use the NonUIOrderDependency
+         attributes for custom option selections.
+       - The web interface now enables/disables the printer
+         sharing (formerly publishing) controls based on the
+         server-is-sharing-printers state (STR #2233)
+       - The scheduler now tracks printer sharing via the
+         server-is-sharing-printers attribute, and manages LPD
+         and SMB sharing as well (STR #2233)
+       - The web interface now allows you to go back to the make/
+         manufacturer page if there is no matching printer driver
+         on the model page (STR #2436)
+       - The printer list now shows the default media, banner, and
+         duplex options as well as the color and duplex capabilities
+         of printers (STR #1175)
+       - The web interface look-n-feel has been updated (STR #2492)
+       - The scheduler now supports a CUPS-Get-Document operation
+         that returns the specified print job document (STR #118)
+       - The cupsfilter utility now supports a "-J jobid" option
+         to filter the document from the specified job.
+       - The scheduler (cupsd) now supports a new option (-t) to
+         do a syntax check of the cupsd.conf file (STR #2003)
+       - Added new cupsGetPPD3() API to allow applications to
+         cache PPDs safely (STR #1473)
+       - Added generic PostScript and PCL printer driver PPDs.
index e101a5c247a15f32ead6e107ae3f1304fe1191d0..c5f663c418bd02e066cf6ae9501a7e7923099cb9 100644 (file)
@@ -1,514 +1,7 @@
-CHANGES.txt - 2009-08-28
+CHANGES.txt - 2009-09-11
 ------------------------
 
-CHANGES IN CUPS V1.4.1
+CHANGES IN CUPS V1.5b1
 
-       - Documention fixes (STR #3296)
-       - DNS-SD registrations for raw queues had an empty "ty" key (STR #3299)
-       - The JPEG and BMP MIME type rules were broken (STR #3284)
-       - cupsGetNamedDest returned the default printer when the named
-         destination did not exist (STR #3285)
-       - The JobKillDelay was not triggered for canceled jobs (STR #3292)
-       - The PPD compiler could get in an infinite loop (STR #3293)
-       - The configure check for dns-sd.h was broken (STR #3297)
-       - The "Query Printer for Default Options" page did not go away if the
-         query job was held (STR #3302)
-       - Boolean options did not show up as selected in the web interface
-         (STR #3303)
-       - The scheduler did not cache or report driver information files
-         correctly, leading to a variety of issues (STR #3283, STR #3297,
-         STR #3305)
-       - cupsDoIORequest() did not abort on permanent errors (STR #3311)
-       - Modifying a class in the web interface did not work (STR #3312)
-       - BrowseLocalProtocols could be cleared when changing the sharing
-         setting (STR #3287)
-       - The scheduler could return an empty supported document format
-         (STR #3308)
-       - The PPD compiler generated invalid PPD files when the locale used
-         something other than "." for the decimal point (STR #3300)
-       - The IPP backend did not handle some non-comforming IPP printer
-         implementations (STR #3262)
-       - The scheduler leaked three file descriptors to each job filter
-         (STR #3263)
-       - The scheduler now uses a default CUPS-Get-Devices timeout of 15
-         seconds (STR #3307)
-
-
-CHANGES IN CUPS V1.4.0
-
-       - Localization updates (STR #3223, STR #3246, STR #3248, STR #3250)
-       - Documentation updates (STR #3225, STR #3230, STR #3242, STR #3260)
-       - The --with-pdftops configure option did not accept a full path to the
-         filter (STR #3278)
-       - The banner filter did not position the back side image correctly
-         (STR #3277)
-       - The dnssd backend could crash (STR #3272)
-       - The 1284 device ID sometimes contained trailing garbage (STR #3266)
-       - The USB backend returned different URIs for some printers than in
-         CUPS 1.3 (STR #3259)
-       - The scheduler did not do local job-hold-until processing for remote
-         queues (STR #3258)
-       - The scheduler did not try all possible SSL certificates on Mac OS X.
-       - The scheduler did not always remove a file descriptor when using the
-         kqueue interface (STR #3256)
-       - The scheduler did not protect against bad job control files in all
-         cases (STR #3253)
-       - The scheduler did not encode "+" in model names (STR #3254)
-       - The web interface didn't show the default options (STR #3244)
-       - The IPP and LPD backends needed print data before they would do an
-         SNMP query.
-       - Fixed a GNU TLS compatibility issue (STR #3231)
-       - Fixed a HTML error in the add and modify printer web interface
-         templates (STR #3229)
-       - The scheduler did not minimize the number of printer state events that
-         were generated by filter STATE: messages, which could lead to poor
-         performance.
-       - The USB backend on Mac OS X did not cleanly cancel a job.
-       - The network backends now set the connecting-to-device printer-state-
-         reasons value when looking up the address and copying the print data
-         for consistency.
-       - The scheduler now supports the com.apple.print.recoverable-warning
-         reason on all platforms.
-
-
-CHANGES IN CUPS V1.4rc1
-
-       - The PPD compiler documentation was missing information on localization
-         (STR #3212)
-       - The IPP backend now reconnects after every request when talking to
-         printers that claim IPP support but only use HTTP/1.0.
-       - The PPD compiler crashed when both "Resolution" and "Group foo Option
-         Resolution" were specified in the .drv file.
-       - The PPD compiler's #if/#elif/#else/#endif did not work for undefined
-         variables (STR #3210)
-       - Static libraries could not be installed by a non-root user on systems
-         needing a ranlib program (STR #3209)
-       - The scheduler incorrectly always tried to copy Kerberos credentials
-         for print jobs.
-       - Updated the Spanish localization (STR #3204)
-       - The scheduler crashed when getting the default paper size from
-         libpaper (STR #3205, STR #3206)
-       - The PPD compiler now defines six variables: CUPS_VERSION,
-         CUPS_VERSION_MAJOR, CUPS_VERSION_MINOR, CUPS_VERSION_PATCH,
-         PLATFORM_NAME, and PLATFORM_ARCH (STR #3203)
-       - Fixed a whitespace skipping bug in cupsRasterInterpretPPD.
-       - The scheduler did not return HTTP 403 (Forbidden) for authenticated
-         users that were not authorized to do IPP operations (STR #3193)
-       - The scheduler did not report more than 8 Product strings from a PPD
-         file.  Some PPD files have as many as 24.
-       - ppdOpen*() could crash if a keyword had no value string (something
-         that cupstestppd looks for...)
-       - cupsLangDefault() did not return the correct language on Mac OS X.
-       - The Mac OS X USB backend did not handle aborted or stalled pipe
-         conditions properly, which prevented drivers from ejecting partial
-         pages when a job was canceled or held.
-
-
-CHANGES IN CUPS V1.4b3
-
-       - Documentation fixes (STR #3044, STR #3057, STR #3153, STR #3158,
-         STR #3173)
-       - Added complete localizations for German, Japanese, Polish, and
-         Russian and partial localizations for Chinese, Danish, Finnish,
-         French, Italian, Korean, Norwegian, Portuguese, and Swedish
-         (STR #3096, STR #3098, STR #3109, STR #3111, STR #3141)
-       - Updated the configure check for -fstack-protector (STR #3198)
-       - The network backends now correctly convert SNMP supply descriptions to
-         UTF-8 encoding as needed.
-       - The scheduler could crash when deleting an attribute (STR #3197)
-       - The cups-driverd program did not detect symlink loops (STR #3185)
-       - The EPSON 24-pin series driver should now feed the correct amount
-         (STR #2624)
-       - The scheduler now automatically logs the last N debug messages for
-         failed print jobs.
-       - You can now modify a raw print queue (STR #3133)
-        - Fixed a number of ppdi issues and added a unit test to validate that
-         ppdc + ppdi can generate and import the same data (STR #3152)
-       - Moving jobs in the web interface now shows an error if you only have
-         one printer or class added (STR #3094)
-       - Since classes have never truly supported the printer-error-policy
-         stuff added in CUPS 1.2, update the code to reflect the current
-         reality and support only the retry-current-job policy for now
-         (STR #3171)
-       - Revised the password callback support (STR #2953)
-       - ppdEmit*() did not choose between PageSize and PageRegion properly.
-       - Make some fairly substantial changes to the Kerberos support code so
-         that CUPS can work in multi-realm environments and does not require
-         delegatable credentials.  Shared printing still requires delegation,
-         however "delegation by policy" can be enabled in the KDC to make this
-         all work.
-       - "AccessLogLevel actions" did not hide client-error-not-found errors.
-       - AP_FIRST_InputSlot did not work with number-up.
-       - cupsBackChannelRead() and cupsBackChannelWrite() could fail due to a
-         lack of kernel buffers.
-       - The IPP and LPD backends did not respond to side-channel requests
-         while copying print data to a temporary file.
-       - cupsWriteRequestData() flushed the output buffer unnecessarily,
-         causing reduced performance in some situations.
-       - If a CGI process died before sending its MIME headers, the request
-         would hang on the client.
-       - The printer/class/job search feature on the web interface did not
-         work (STR #3132)
-       - The scheduler did not write the printers out for classes.
-       - CUPS-Get-PPDs did not work properly when filtering by language,
-         product, or psversion (STR #3136)
-       - The scheduler now kills job filters when it takes more than 30 seconds
-         (configurable) to cancel or hold the job.
-       - The cupstestppd program did not validate the capitalization of
-         filenames in the PPD file.
-       - The cupstestppd program did not validate the PageSize and PageRegion
-         values.
-       - The cups-deviced helper program could miss reporting some backend
-         devices (STR #3108)
-       - The cupsSideChannelSNMP* functions did not work.
-       - The scheduler could consume 100% CPU when jobs were canceled.
-       - Clicking on "Select Another Make/Manufacturer" in the web interface
-         incorrectly added the printer (STR #3095)
-       - The scheduler no longer uses programs with insecure file
-         permissions.
-       - httpAssembleURI*() did not escape backslashes in hostnames.
-       - The dnssd backend did not unquote "full names" before creating the
-         device URI.
-       - The scheduler now supports JobRetryInterval values less than 10
-         seconds.
-       - Updated the Spanish localization (STR #3090)
-       - The scheduler did not redo Bonjour/DNS-SD registrations when updating
-         them failed.
-       - The "authenticated" policy incorrectly required authentication for
-         status operations.
-       - ppdOpen*() incorrectly loaded PPDs with multiple JobPatchFile
-         keywords.
-       - The network backends no longer report the SNMP "offline" or
-         maintenance status bits since they are inconsistently implemented and
-         often unreliable.
-       - The scheduler no longer logs child processes killed via SIGKILL as
-         "crashed".
-       - The printer link shown on the "job moved" template was bad (STR #3085)
-       - Updated the HTML templates to use the final HTML 4 DOCTYPE (STR #3086)
-       - The scheduler did not track the "paused" reason properly if a
-         printer had other reasons associated with it.
-       - cupsSendRequest() did not clear old local certificate auth data.
-       - The PPD compiler did not search for localization files properly
-         (STR #3084)
-       - cupsGetNamedDest() did not use the fallback default like
-         cupsGetDests*() (STR #3082)
-       - The scheduler now provides a LogTimeFormat directive to enable
-         microseconds in the date and time that are logged.
-       - The scheduler now provides a MultipleOperationTimeout directive to
-         control the timeout for multi-file print jobs.
-       - The configure script incorrectly allowed Avahi to be used for DNS-SD
-         printer discovery (STR #3065)
-       - The web interface and scheduler did not support URIs up to 1024 bytes
-         in length (STR #3072)
-       - Fixed pdftops issues with page sizes (STR #3063)
-       - Fixed pdftops issues with Ghostscript (STR #3062)
-       - The scheduler incorrectly registered default profiles for PostScript
-         printers with no specified colorspace.
-       - The scheduler incorrectly created an empty org.cups.printers.plist
-         file on Mac OS X.
-       - cupsGetPPD3() did not look for local PPDs in the right directory.
-       - SNMP lookups via side-channel did not work for NULL-VALUE and
-         and OCTET-STRING OIDs containing nul characters.
-       - The libusb-based USB backend did not work.
-       - The scheduler did not set the printer-commands attribute correctly
-         for some PPDs.
-       - The ppdi utility did not work.
-       - The web interface no longer uses multi-part output with old or broken
-         web browsers (STR #3049)
-       - CUPS now conforms to the draft IPP/2.0 and IPP/2.1 specification.
-       - Added a new cupsGetConflicts() API to get a list of conflicting
-         options.
-       - The PPD compiler didn't localize options or choices that did not
-         have associated translation text (STR #3045)
-       - Updated the Spanish localization (STR #3043)
-       - Fixed build problems (STR #3040, STR #3047)
-       - cupsResolveConflicts() did not resolve using the default option
-         choice in some cases due to the mirror UIConstraints that are
-         present in most PPD files.
-       - The scheduler did not honor MIME type priorities.
-       - The commandtops filter incorrectly used the JCLBegin code to end
-         its jobs.
-       - The default BrowseLocalProtocols value was not set properly.
-       - Since the commandtops filter does not actually support ReportLevels
-         all on its own, don't list that printer command by default for PS
-         printers.
-       - The scheduler did not give filters a chance to log errors or update
-         printer attributes when a job was canceled.
-       - The scheduler did not clear the "connecting-to-device" reason keyword
-         when a job finished.
-
-
-CHANGES IN CUPS V1.4b2
-
-       - Documentation updates (STR #2983, STR #2998, STR #3021)
-       - The cupstestppd utility now validates the FileVersion and
-         FormatVersion values in PPD files.
-       - The default cupsd.conf file did not reflect the
-         --with-local-protocols value set at compile-time (STR #3037)
-       - The cupsGetPPD* APIs now create symlinks to local PPD files
-         rather than copying them whenever possible.
-       - Various performance optimizations in the string pool, dests, and
-         options implementations.
-       - The cupsGetDests* APIs now return the marker and printer-commands
-         attributes.
-       - Side-channel SNMP lookups would not work when cupsSNMPSupplies
-         was set to False in the PPD file.
-       - Localized the device descriptions for the SCSI, serial,
-         and network backends (STR #3014)
-       - Added a Spanish localization (STR #3015)
-       - Added support for marker-low-levels and marker-high-levels
-         attributes.
-       - The scheduler could hang writing a long log line.
-       - The cupsGetDevices() function now has an "include_schemes"
-         parameter.
-       - The lpinfo command now supports --include-schemes and
-         --exclude-schemes options.
-       - The CUPS-Get-PPDs operation now supports the include-schemes
-         and exclude-schemes attributes.
-        - The CUPS-Get-Devices operation now supports the include-schemes
-         attribute.
-       - The print filters now support a replacement for the fitplot
-         option called "fit-to-page".
-       - The LPD backend no longer tries to collect page accounting
-         information since the LPD protocol does not allow us to
-         prevent race conditions.
-       - The scheduler did not save the last marker-change-time value.
-       - Fixed a problem with printing to some IPP printers, including
-         CUPS 1.1.x.
-       - Fixed a redirection problem with the printer web page (STR #3012)
-       - Fixed a PPD compiler problem with the loading of message
-         catalogs (STR #2990)
-       - Fixed a PPD compiler problem with the loading of .strings files
-         (STR #2989)
-       - The cupsfilter utility did not set the CONTENT_TYPE environment
-         variable when running filters.
-       - The scheduler now waits to allow system sleep until the jobs
-         have all stopped.
-       - The IPP, LPD, and socket backends used different "connecting"
-         progress messages.
-
-
-CHANGES IN CUPS V1.4b1
-
-       - Documentation updates (STR #2567)
-       - The PPD compiler now allows local message catalogs to
-         override the standard CUPS translations (STR #2642)
-       - The ppdmerge command did not merge custom option strings
-         (STR #2863)
-       - The scheduler now supports the Hold-New-Jobs and
-         Release-Held-New-Jobs operations; these are exposed via the
-         cupsdisable and cupsenable commands (STR #2332)
-       - The lpstat command is now much faster when displaying the
-         status of a single printer (STR #2843)
-       - The scheduler now caches information from PPD files to provide
-         significantly faster startup time with large numbers of PPDs
-         (STR #1293)
-       - CUPS-Get-Driver now provides much better driver matching based
-         on the IEEE-1284 device ID and make/model strings (STR #2707)
-       - Now support the cupsSNMPSupplies keyword to control whether
-         the network backends query the SNMP Printer MIB for supply
-         levels.
-       - Now support and use a new banner file format for better text
-         support and easier customization (STR #2490)
-       - The scheduler now sets the PRINTER_INFO and PRINTER_LOCATION
-         environment variables from the corresponding IPP attributes.
-       - The ippRead*() and ippWrite*() functions no longer use a
-         stack-based buffer (STR #2388)
-       - The CUPS-Add-Modify-Printer operation now allows you to set
-         the printer-state-reasons attribute.
-       - The "set printer options" page now supports auto-configuration
-         of printer options (STR #1440)
-       - The web interface now provides an advanced server settings
-         form.
-       - The web interface's "modify printer" pages now make it
-         easier to change just one setting (STR #1919)
-       - The scheduler now supports a plist PrintcapFormat.
-       - The scheduler now supports multiple addresses in Allow and
-         Deny lines, just like Apache (STR #2947)
-       - Added CUPS_JOBTYPE environment variable for job filters so
-         they know whether they are printing a banner or document
-         file (STR #2799)
-       - Added support for printer filtering by the cupsfilter
-         command (STR #2562)
-       - Added a SSLOptions directive to allow Windows clients to
-         talk to CUPS in FIPS mode (STR #2827)
-       - Renamed the accept and reject commands to cupsaccept and
-         cupsreject; the old names are still available (STR #2936)
-       - The locale/translate utility needed an update to work with
-         Google (STR #2882)
-       - The lpstat command now supports a -H option to display the
-         default server (STR #2833)
-       - The scheduler now supports a FatalErrors directive to control
-         which errors should cause the scheduler to exit (STR #2536)
-       - The scheduler now uses the php-cgi program if it is available
-         (STR #2923)
-       - The scheduler now supports a DefaultPaperSize directive
-         (STR #2848)
-       - The scheduler now passes the job-originating-host-name
-         value to filters in the options argument (STR #2558)
-       - CUPS now supports job tickets in PDF files (STR #2903)
-       - Added a DBUS notifier (STR #2529)
-       - The LPD mini-daemon now passes the document name when queuing
-         print jobs (STR #2482)
-       - The IPP backend did not relay com.apple.print.recoverable-message
-         values.
-       - The scheduler now supports a job-media-progress attribute to
-         track the progress of individual pages.
-       - The sample HP driver now supports A5 (STR #2798)
-       - The CUPS web interface menu item now uses the xdg-open
-         command, when available (STR #2724)
-       - The cups-lpd program now supports the -h option (STR #2794)
-       - The scheduler now sets the PAM_TTY parameter and the
-         PAM_ESTABLISH_CRED credential flag (STR #2745)
-       - The scheduler now logs unsuccessful requests to the error_log
-         file as errors (STR #2616)
-       - Added support for a "retry-current-job" error policy that
-         retries the current job immediately when the backend encounters
-         an error (STR #2555)
-       - The scheduler now returns a "forbidden" error when a user
-         correctly authenticates but does not have permission to
-         continue further (STR #2101)
-       - The scheduler now loads both the server and CA certificates
-         (if present) from the ServerCertificate file (STR #2146)
-       - New RSS subscriptions now create their feed files immediately
-         (STR #2853)
-       - Added support for a device-location attribute which provides
-         the physical location of a printer device.
-       - Added a cupsBackendReport() API which handles quoting of the
-         device data by a backend.
-       - Added support for custom options in the web interface
-         (STR #1729)
-       - Added support for Mozilla LDAP, reconnection to LDAP servers,
-         and improved LDAP performance (STR #1962)
-       - Added Solaris SMF support (STR #1477)
-       - Added optional support for using TCP wrappers to limit access
-         to CUPS (STR #263)
-       - Added ppdPageSizeLimits API.
-       - Added support for new cupsMediaQualifier2, cupsMediaQualifier3,
-         cupsMinSize, and cupsMaxSize attributes.
-       - Added cupsResolveConflicts and ppdInstallableConflict APIs.
-       - Added support for new cupsUIConstraints and cupsUIResolver
-         attributes for better option conflict detection and
-         resolution.
-       - Increased the maximum size of 1284 device ID strings to
-         256 bytes (STR #2877)
-       - Added an AccessLogLevel directive to cupsd.conf to control
-         what is logged to the access_log file.
-       - The default LogLevel is now "warn" instead of "info" to reduce
-         the amount of logging that is done to disk by default.
-       - The PPD compiler did not include OID query keywords in PPD
-         files (STR #2871)
-       - The cups-driverd helper program now directly supports driver
-         information files.
-       - The USB backend now uses libusb when available (STR #1575)
-       - Added ppdLocalizeAttr function to get the localized version
-         of an attribute.
-       - MIME types now support a priority() attribute (STR #2719)
-       - The standard MIME types are now installed in
-         DataDir/mime (STR #2719)
-       - The lpoptions command now describes custom options and
-         the necessary parameters (STR #2660)
-       - The ppdmerge program did not support Simplified Chinese
-         or Traditional Chinese language version strings (STR #2851)
-       - The PPD compiler now supports localizable attributes
-         (STR #2738)
-       - The ppdpo utility now includes cupsIPPReasons values in
-         the message catalogs it generates (STR #2754)
-       - The PPD compiler now supports conditional directives
-         (STR #2636)
-       - The ppdc utility now supports a "-t" option to test PPD
-         files (STR #2739)
-       - The ppdc utility now supports a "-m" option to use the
-         ModelName value as the output filename.
-       - The ppdc utility now supports a FileName directive to
-         set an alternate output filename (STR #2740)
-       - The side-channel API now supports SNMP queries for the
-         standard network backends.
-       - Added a PageLogFormat directive to the cupsd.conf file to
-         control the format of lines in the page_log file.
-       - Filters can now send PPD: messages to stderr to set PPD
-         keywords like DefaultPageSize while a job is printing.
-       - Added a mdns backend for discovery and printing to printers
-         that advertise themselves via DNS-SD (Bonjour)
-       - The ipp, lpd, and socket backends now support DNS-SD service
-         name resolution.
-       - The scheduler now uses a single shared file descriptor for
-         all DNS-SD registrations (STR #2674)
-       - The ipp, lpd, and socket backends now support SNMP-based
-         page accounting and supply level monitoring (STR #1655)
-       - Added support for cupsPJLDisplay attribute to control what
-         PJL commands are used to display the job information.
-       - Driver information files can now be installed in
-         /Library/Printers/PPDs.drv on Mac OS X.
-       - The CUPS image library now supports reading images larger
-         than 2GB.
-       - The scheduler now delays writing config and state files to
-         reduce disk activity (STR #2684)
-       - The CUPS-Get-Devices operation now supports the
-         exclude-schemes and timeout attributes to control which
-         backends are polled and for how long.
-       - The cups-deviced helper application now runs backends in
-         parallel to get the list of devices faster.
-       - Added --enable-pap configure option.
-       - The default cupsd.conf file now includes an "authenticated"
-         policy which requires authentication for remote print jobs.
-       - Added support for Czech and Hungarian in PPD files
-         (STR #2735, STR #2736)
-       - The PPD compiler tools now support Mac OS X .strings files
-         for localization (STR #2737)
-       - ppdOpen*() now default the colorspace member to PPD_CS_N
-         when no DefaultColorSpace attribute is present in the PPD
-         file.
-       - The build system has been updated to support separate
-         installation of data, program, header, and library files.
-       - All support libraries are now built as shared libraries
-         by default.
-       - The scheduler now manages ICC color profiles on Mac OS X.
-       - The network backends (ipp, lpd, socket) now support
-         SNMP-based supply and page count monitoring (STR #1655)
-       - The lppasswd program is no longer installed setuid to
-         root to make the default installation more secure.
-       - Added a new ppdLocalizeMarkerName() function to get
-         the localized version of a marker-names value.
-       - The scheduler now provides the printer-dns-sd-name
-         attribute for printers shared via DNS-SD/Bonjour.
-       - The pdftops filter now executes the Xpdf or poppler
-         pdftops utility to convert PDF files (STR #1471)
-       - Bonjour printer registrations now advertise as local or
-         global based on the current access policies for the
-         printer.
-       - cupsGetDests*() and cupsSetDests*() now track the last
-         used printer preference on Mac OS X.
-       - Added a new streaming request API (STR #2261)
-       - Added a new cupsGetNamedDest() function to the CUPS
-         library for faster printing with lp and lpr (STR #2638)
-       - The scheduler now sets the PAM RHOST value on systems
-         that support it (STR #2637)
-       - The scheduler now sandboxes child processes when
-         possible.
-       - The Cancel-Job operation now supports a purge-job
-         attriibute to purge a specified job.
-       - ppdEmit* and ppdCollect* now use the NonUIOrderDependency
-         attributes for custom option selections.
-       - The web interface now enables/disables the printer
-         sharing (formerly publishing) controls based on the
-         server-is-sharing-printers state (STR #2233)
-       - The scheduler now tracks printer sharing via the
-         server-is-sharing-printers attribute, and manages LPD
-         and SMB sharing as well (STR #2233)
-       - The web interface now allows you to go back to the make/
-         manufacturer page if there is no matching printer driver
-         on the model page (STR #2436)
-       - The printer list now shows the default media, banner, and
-         duplex options as well as the color and duplex capabilities
-         of printers (STR #1175)
-       - The web interface look-n-feel has been updated (STR #2492)
-       - The scheduler now supports a CUPS-Get-Document operation
-         that returns the specified print job document (STR #118)
-       - The cupsfilter utility now supports a "-J jobid" option
-         to filter the document from the specified job.
-       - The scheduler (cupsd) now supports a new option (-t) to
-         do a syntax check of the cupsd.conf file (STR #2003)
-       - Added new cupsGetPPD3() API to allow applications to
-         cache PPDs safely (STR #1473)
-       - Added generic PostScript and PCL printer driver PPDs.
+       - The PPD compiler now checks for overlapping filenames when writing
+         PPD files.
index 612a9b6802359d8467d80c5671b6be81e94cadb8..7d8fd2e2c514cf6e914a2d4b8f9d3ee07e5225f3 100644 (file)
@@ -276,16 +276,16 @@ extern int                backendGetDeviceID(int fd, char *device_id,
 extern int             backendGetMakeModel(const char *device_id,
                                            char *make_model,
                                            int make_model_size);
-extern void            backendNetworkSideCB(int print_fd, int device_fd,
+extern int             backendNetworkSideCB(int print_fd, int device_fd,
                                             int snmp_fd, http_addr_t *addr,
                                             int use_bc);
 extern ssize_t         backendRunLoop(int print_fd, int device_fd, int snmp_fd,
                                       http_addr_t *addr, int use_bc,
-                                      void (*side_cb)(int print_fd,
-                                                      int device_fd,
-                                                      int snmp_fd,
-                                                      http_addr_t *addr,
-                                                      int use_bc));
+                                      int (*side_cb)(int print_fd,
+                                                     int device_fd,
+                                                     int snmp_fd,
+                                                     http_addr_t *addr,
+                                                     int use_bc));
 extern int             backendSNMPSupplies(int snmp_fd, http_addr_t *addr,
                                            int *page_count,
                                            int *printer_state);
index 65c254c860f9fd6ca3bbf7fae80817435008ce14..c2fd7dbc8903bb8fbbc8e2db404f85510748a249 100644 (file)
@@ -45,6 +45,8 @@
 
 static char    *password = NULL;       /* Password for device URI */
 static int     password_tries = 0;     /* Password tries */
+static const char *auth_info_required = "none";
+                                       /* New auth-info-required value */
 #ifdef __APPLE__
 static char    pstmpname[1024] = "";   /* Temporary PostScript file name */
 #endif /* __APPLE__ */
@@ -1049,16 +1051,21 @@ main(int  argc,                         /* I - Number of command-line args */
         _cupsLangPrintf(stderr, _("ERROR: Print file was not accepted (%s)!\n"),
                        cupsLastErrorString());
 
-       if (ipp_status == IPP_NOT_AUTHORIZED)
+       if (ipp_status == IPP_NOT_AUTHORIZED || ipp_status == IPP_FORBIDDEN)
        {
          fprintf(stderr, "DEBUG: WWW-Authenticate=\"%s\"\n",
                  httpGetField(http, HTTP_FIELD_WWW_AUTHENTICATE));
 
+         /*
+         * Normal authentication goes through the password callback, which sets
+         * auth_info_required to "username,password".  Kerberos goes directly
+         * through GSSAPI, so look for Negotiate in the WWW-Authenticate header
+         * here and set auth_info_required as needed...
+         */
+
          if (!strncmp(httpGetField(http, HTTP_FIELD_WWW_AUTHENTICATE),
                       "Negotiate", 9))
-           fputs("ATTR: auth-info-required=negotiate\n", stderr);
-         else
-           fputs("ATTR: auth-info-required=username,password\n", stderr);
+           auth_info_required = "negotiate";
        }
       }
     }
@@ -1296,6 +1303,15 @@ main(int  argc,                          /* I - Number of command-line args */
       page_count > start_count)
     fprintf(stderr, "PAGE: total %d\n", page_count - start_count);
 
+#ifdef HAVE_GSSAPI
+ /*
+  * See if we used Kerberos at all...
+  */
+
+  if (http->gssctx)
+    auth_info_required = "negotiate";
+#endif /* HAVE_GSSAPI */
+
  /*
   * Free memory...
   */
@@ -1328,7 +1344,9 @@ main(int  argc,                           /* I - Number of command-line args */
   * Return the queue status...
   */
 
-  if (ipp_status == IPP_NOT_AUTHORIZED)
+  fprintf(stderr, "ATTR: auth-info-required=%s\n", auth_info_required);
+
+  if (ipp_status == IPP_NOT_AUTHORIZED || ipp_status == IPP_FORBIDDEN)
     return (CUPS_BACKEND_AUTH_REQUIRED);
   else if (ipp_status == IPP_INTERNAL_ERROR)
     return (CUPS_BACKEND_STOP);
@@ -1532,6 +1550,12 @@ password_cb(const char *prompt)          /* I - Prompt (not used) */
 {
   (void)prompt;
 
+ /*
+  * Remember that we need to authenticate...
+  */
+
+  auth_info_required = "username,password";
+
   if (password && *password && password_tries < 3)
   {
     password_tries ++;
@@ -1541,23 +1565,10 @@ password_cb(const char *prompt)         /* I - Prompt (not used) */
   else
   {
    /*
-    * If there is no password set in the device URI, return the
-    * "authentication required" exit code...
+    * Give up after 3 tries or if we don't have a password to begin with...
     */
 
-    if (tmpfilename[0])
-      unlink(tmpfilename);
-
-#ifdef __APPLE__
-    if (pstmpname[0])
-      unlink(pstmpname);
-#endif /* __APPLE__ */
-
-    fputs("ATTR: auth-info-required=username,password\n", stderr);
-
-    exit(CUPS_BACKEND_AUTH_REQUIRED);
-
-    return (NULL);                     /* Eliminate compiler warning */
+    return (NULL);
   }
 }
 
index 06ffc04675ae23ac528950a2ae8245888f373117..e5cb16d1a68f62dd47800b328b5da063be816640 100644 (file)
@@ -61,7 +61,7 @@ backendCheckSideChannel(
  * 'backendNetworkSideCB()' - Handle common network side-channel commands.
  */
 
-void
+int                                    /* O - -1 on error, 0 on success */
 backendNetworkSideCB(
     int         print_fd,              /* I - Print file or -1 */
     int         device_fd,             /* I - Device file or -1 */
@@ -79,10 +79,7 @@ backendNetworkSideCB(
   datalen = sizeof(data);
 
   if (cupsSideChannelRead(&command, &status, data, &datalen, 1.0))
-  {
-    _cupsLangPuts(stderr, _("WARNING: Failed to read side-channel request!\n"));
-    return;
-  }
+    return (-1);
 
   switch (command)
   {
@@ -284,7 +281,7 @@ backendNetworkSideCB(
        break;
   }
 
-  cupsSideChannelWrite(command, status, data, datalen, 1.0);
+  return (cupsSideChannelWrite(command, status, data, datalen, 1.0));
 }
 
 
index 12dbb9e89c4c382bcf777867c21fe7cfc01dc087..8acda032e01c7c6ec27d72692433f91f7b704ded 100644 (file)
@@ -1278,7 +1278,7 @@ int papCancelRequest(int sockfd, u_short tid)
  * 'sidechannel_request()' - Handle side-channel requests.
  */
 
-static void
+static int
 sidechannel_request()
 {
   cups_sc_command_t    command;        /* Request command */
@@ -1289,32 +1289,29 @@ sidechannel_request()
   datalen = sizeof(data);
 
   if (cupsSideChannelRead(&command, &status, data, &datalen, 1.0))
-  {
-    fputs(_("WARNING: Failed to read side-channel request!\n"), stderr);
-    return;
-  }
+    return (-1);
 
   switch (command)
   {
     case CUPS_SC_CMD_GET_BIDI:         /* Is the connection bidirectional? */
        data[0] = 1;
-       cupsSideChannelWrite(command, CUPS_SC_STATUS_OK, data, 1, 1.0);
+       return (cupsSideChannelWrite(command, CUPS_SC_STATUS_OK, data, 1, 1.0));
        break;
 
     case CUPS_SC_CMD_GET_STATE:                /* Return device state */
        data[0] = CUPS_SC_STATE_ONLINE;
-       cupsSideChannelWrite(command, CUPS_SC_STATUS_OK, data, 1, 1.0);
+       return (cupsSideChannelWrite(command, CUPS_SC_STATUS_OK, data, 1, 1.0));
        break;
 
     case CUPS_SC_CMD_DRAIN_OUTPUT:     /* Drain all pending output */
     case CUPS_SC_CMD_SOFT_RESET:       /* Do a soft reset */
     case CUPS_SC_CMD_GET_DEVICE_ID:    /* Return IEEE-1284 device ID */
     default:
-       cupsSideChannelWrite(command, CUPS_SC_STATUS_NOT_IMPLEMENTED, 
-                            NULL, 0, 1.0);
+       return (cupsSideChannelWrite(command, CUPS_SC_STATUS_NOT_IMPLEMENTED, 
+                                    NULL, 0, 1.0));
        break;
   }
-  return;
+  return (0);
 }
 
 
index 41238a8e97acce9da3a9c9fcb6152a26b7a93913..03d59d443dd062c735c6a51118e506f7a4dcb82e 100644 (file)
@@ -59,7 +59,7 @@
  */
 
 static void    list_devices(void);
-static void    side_cb(int print_fd, int device_fd, int snmp_fd,
+static int     side_cb(int print_fd, int device_fd, int snmp_fd,
                        http_addr_t *addr, int use_bc);
 
 
@@ -615,7 +615,7 @@ list_devices(void)
  * 'side_cb()' - Handle side-channel requests...
  */
 
-static void
+static int                             /* O - 0 on success, -1 on error */
 side_cb(int         print_fd,          /* I - Print file */
         int         device_fd,         /* I - Device file */
         int         snmp_fd,           /* I - SNMP socket (unused) */
@@ -634,10 +634,7 @@ side_cb(int         print_fd,              /* I - Print file */
   datalen = sizeof(data);
 
   if (cupsSideChannelRead(&command, &status, data, &datalen, 1.0))
-  {
-    _cupsLangPuts(stderr, _("WARNING: Failed to read side-channel request!\n"));
-    return;
-  }
+    return (-1);
 
   switch (command)
   {
@@ -680,7 +677,7 @@ side_cb(int         print_fd,               /* I - Print file */
        break;
   }
 
-  cupsSideChannelWrite(command, status, data, datalen, 1.0);
+  return (cupsSideChannelWrite(command, status, data, datalen, 1.0));
 }
 
 
index fa8825ce29aafa122679438a39d936e392cf065d..d5de2e4c325e77b8f01004325368d70ef731d7df 100644 (file)
@@ -147,7 +147,7 @@ backendRunLoop(
     int         snmp_fd,               /* I - SNMP socket or -1 if none */
     http_addr_t *addr,                 /* I - Address of device */
     int         use_bc,                        /* I - Use back-channel? */
-    void        (*side_cb)(int, int, int, http_addr_t *, int))
+    int         (*side_cb)(int, int, int, http_addr_t *, int))
                                        /* I - Side-channel callback */
 {
   int          nfds;                   /* Maximum file descriptor value + 1 */
@@ -274,7 +274,8 @@ backendRunLoop(
       * loop since it may have read from print_fd...
       */
 
-      (*side_cb)(print_fd, device_fd, snmp_fd, addr, use_bc);
+      if ((*side_cb)(print_fd, device_fd, snmp_fd, addr, use_bc))
+        side_cb = NULL;
       continue;
     }
 
index 803df0cb6c83d1456ba877656ee0207823de8949..c83f13705a8c44e353e95e254ebd7e28cb27b63a 100644 (file)
@@ -84,7 +84,7 @@
  */
 
 static void    list_devices(void);
-static void    side_cb(int print_fd, int device_fd, int use_bc);
+static int     side_cb(int print_fd, int device_fd, int use_bc);
 
 
 /*
@@ -109,7 +109,8 @@ main(int  argc,                             /* I - Number of command-line arguments (6 or 7) */
                sep;                    /* Option separator */
   int          port;                   /* Port number (not used) */
   int          copies;                 /* Number of copies to print */
-  int          print_fd,               /* Print file */
+  int          side_eof = 0,           /* Saw EOF on side-channel? */
+               print_fd,               /* Print file */
                device_fd;              /* Serial device */
   int          nfds;                   /* Maximum file descriptor value + 1 */
   fd_set       input,                  /* Input set for reading */
@@ -558,7 +559,7 @@ main(int  argc,                             /* I - Number of command-line arguments (6 or 7) */
       if (!print_bytes)
        FD_SET(print_fd, &input);
       FD_SET(device_fd, &input);
-      if (!print_bytes)
+      if (!print_bytes && !side_eof)
         FD_SET(CUPS_SC_FD, &input);
 
       FD_ZERO(&output);
@@ -579,7 +580,8 @@ main(int  argc,                             /* I - Number of command-line arguments (6 or 7) */
        * loop since it may have read from print_fd...
        */
 
-        side_cb(print_fd, device_fd, 1);
+        if (side_cb(print_fd, device_fd, 1))
+         side_eof = 1;
        continue;
       }
 
@@ -1278,7 +1280,7 @@ list_devices(void)
  * 'side_cb()' - Handle side-channel requests...
  */
 
-static void
+static int                             /* O - 0 on success, -1 on error */
 side_cb(int print_fd,                  /* I - Print file */
         int device_fd,                 /* I - Device file */
        int use_bc)                     /* I - Using back-channel? */
@@ -1292,11 +1294,7 @@ side_cb(int print_fd,                    /* I - Print file */
   datalen = sizeof(data);
 
   if (cupsSideChannelRead(&command, &status, data, &datalen, 1.0))
-  {
-    _cupsLangPuts(stderr,
-                  _("WARNING: Failed to read side-channel request!\n"));
-    return;
-  }
+    return (-1);
 
   switch (command)
   {
@@ -1323,7 +1321,7 @@ side_cb(int print_fd,                     /* I - Print file */
        break;
   }
 
-  cupsSideChannelWrite(command, status, data, datalen, 1.0);
+  return (cupsSideChannelWrite(command, status, data, datalen, 1.0));
 }
 
 
index 684ff54b58f809d6574bb25849e42f4a07e632c7..6be80ee14e6f251f1488b3c869238ff9160d8923 100644 (file)
@@ -229,8 +229,11 @@ backendSNMPSupplies(
         packet.object_type != CUPS_ASN1_OCTET_STRING)
       return (-1);
 
-    new_state = (packet.object_value.string.bytes[0] << 8) |
-               packet.object_value.string.bytes[1];
+    if (packet.object_value.string.num_bytes == 2)
+      new_state = (packet.object_value.string.bytes[0] << 8) |
+                 packet.object_value.string.bytes[1];
+    else
+      new_state = 0;
 
     if (current_state < 0)
       change_state = 0xffff;
index 2c7932cb256e0f923dedbbe2b9884345bddf5132..0fb993d83aa9bd29d6bef23e0c9bd0aa047ca45f 100644 (file)
@@ -292,9 +292,8 @@ static void status_timer_cb(CFRunLoopTimerRef timer, void *info);
 #if defined(__i386__) || defined(__x86_64__)
 static pid_t   child_pid;              /* Child PID */
 static void run_legacy_backend(int argc, char *argv[], int fd);        /* Starts child backend process running as a ppc executable */
-#endif /* __i386__ || __x86_64__ */
-static int     job_canceled = 0;       /* Was the job canceled? */
 static void sigterm_handler(int sig);  /* SIGTERM handler */
+#endif /* __i386__ || __x86_64__ */
 
 #ifdef PARSE_PS_ERRORS
 static const char *next_line (const char *buffer);
@@ -461,9 +460,9 @@ print_device(const char *uri,               /* I - Device URI */
   fputs("STATE: -connecting-to-device\n", stderr);
 
   /*
-   * Now that we are "connected" to the port, catch SIGTERM so that we
+   * Now that we are "connected" to the port, ignore SIGTERM so that we
    * can finish out any page data the driver sends (e.g. to eject the
-   * current page...  Only catch SIGTERM if we are printing data from
+   * current page...  Only ignore SIGTERM if we are printing data from
    * stdin (otherwise you can't cancel raw jobs...)
    */
 
@@ -475,7 +474,7 @@ print_device(const char *uri,               /* I - Device URI */
     memset(&action, 0, sizeof(action));
 
     sigemptyset(&action.sa_mask);
-    action.sa_handler = sigterm_handler;
+    action.sa_handler = SIG_IGN;
     sigaction(SIGTERM, &action, NULL);
   }
 
@@ -725,7 +724,7 @@ print_device(const char *uri,               /* I - Device URI */
          fprintf(stderr, "DEBUG: USB class driver Abort returned %x\n",
                  err);
 
-         status = job_canceled ? CUPS_BACKEND_FAILED : CUPS_BACKEND_STOP;
+         status = CUPS_BACKEND_FAILED;
          break;
        }
        else if (bytes > 0)
@@ -944,7 +943,7 @@ sidechannel_thread(void *reference)
     datalen = sizeof(data);
 
     if (cupsSideChannelRead(&command, &status, data, &datalen, 1.0))
-      continue;
+      break;
 
     switch (command)
     {
@@ -2020,8 +2019,6 @@ static void run_legacy_backend(int argc,
 
   exit(exitstatus);
 }
-#endif /* __i386__ || __x86_64__ */
-
 
 /*
  * 'sigterm_handler()' - SIGTERM handler.
@@ -2030,7 +2027,8 @@ static void run_legacy_backend(int argc,
 static void
 sigterm_handler(int sig)               /* I - Signal */
 {
-#if defined(__i386__) || defined(__x86_64__)
+  /* If we started a child process pass the signal on to it...
+   */
   if (child_pid)
   {
    /*
@@ -2052,15 +2050,10 @@ sigterm_handler(int sig)                /* I - Signal */
       exit(CUPS_BACKEND_STOP);
     }
   }
-#endif /* __i386__ || __x86_64__ */
-
- /*
-  * Otherwise just flag that the job has been canceled...
-  */
-
-  job_canceled = 1;
 }
 
+#endif /* __i386__ || __x86_64__ */
+
 
 #ifdef PARSE_PS_ERRORS
 /*
index d5c6ae5b64b9d8843ce4fcf75825fa3a70099967..d265d120302a1353db42f93799908b78c6f072e9 100644 (file)
@@ -158,7 +158,16 @@ print_device(const char *uri,              /* I - Device URI */
 
     while (poll(pfds, 2, -1) > 0)
     {
-      if (pfds[0].revents & POLLIN)
+     /*
+      * CUPS STR #3318: USB process hangs on end-of-file, making further
+      *                 printing impossible
+      *
+      * From a strict interpretation of POSIX poll(), POLLHUP should never be
+      * set without POLLIN, since POLLIN is the event you request.  That said,
+      * it appears that some versions of Linux break this.
+      */
+
+      if (pfds[0].revents & (POLLIN | POLLHUP))
       {
        if ((bytes = read(print_fd, buffer, sizeof(buffer))) > 0)
        {
@@ -178,8 +187,13 @@ print_device(const char *uri,              /* I - Device URI */
          break;
       }
 
-      if (pfds[1].revents & POLLIN)
-        tbytes += side_cb(printer, print_fd);
+      if (pfds[1].revents & (POLLIN | POLLHUP))
+      {
+        if ((bytes = side_cb(printer, print_fd)) < 0)
+         pfds[1].events = 0;           /* Filter has gone away... */
+       else
+          tbytes += bytes;
+      }
     }
   }
 
@@ -745,10 +759,7 @@ side_cb(usb_printer_t *printer,            /* I - Printer */
   datalen = sizeof(data);
 
   if (cupsSideChannelRead(&command, &status, data, &datalen, 1.0))
-  {
-    _cupsLangPuts(stderr, _("WARNING: Failed to read side-channel request!\n"));
-    return (0);
-  }
+    return (-1);
 
   switch (command)
   {
index 9808f8c0a29786a0e28c4449a7e2f8a955ee833e..44faa630c03d8aa77540761f69e35c9ab1ff3369 100644 (file)
@@ -36,7 +36,7 @@
  */
 
 static int     open_device(const char *uri, int *use_bc);
-static void    side_cb(int print_fd, int device_fd, int snmp_fd,
+static int     side_cb(int print_fd, int device_fd, int snmp_fd,
                        http_addr_t *addr, int use_bc);
 
 
@@ -560,7 +560,7 @@ open_device(const char *uri,                /* I - Device URI */
  * 'side_cb()' - Handle side-channel requests...
  */
 
-static void
+static int                             /* O - 0 on success, -1 on error */
 side_cb(int         print_fd,          /* I - Print file */
         int         device_fd,         /* I - Device file */
         int         snmp_fd,           /* I - SNMP socket (unused) */
@@ -579,10 +579,7 @@ side_cb(int         print_fd,              /* I - Print file */
   datalen = sizeof(data);
 
   if (cupsSideChannelRead(&command, &status, data, &datalen, 1.0))
-  {
-    _cupsLangPuts(stderr, _("WARNING: Failed to read side-channel request!\n"));
-    return;
-  }
+    return (-1);
 
   switch (command)
   {
@@ -625,7 +622,7 @@ side_cb(int         print_fd,               /* I - Print file */
        break;
   }
 
-  cupsSideChannelWrite(command, status, data, datalen, 1.0);
+  return (cupsSideChannelWrite(command, status, data, datalen, 1.0));
 }
 
 
index e8cdbfc1099afb50a7b28caa766a891e93a171d8..4e3963e21a8f4cb7643f68021a10773d76f804a7 100644 (file)
@@ -90,7 +90,7 @@ install-data:
        done
        -if test x$(PAMDIR) != x; then \
                $(INSTALL_DIR) -m 755 $(BUILDROOT)$(PAMDIR); \
-               if test -r $(BUILDROOT)$(PAMDIR)/cups/$(PAMFILE) ; then \
+               if test -r $(BUILDROOT)$(PAMDIR)/cups ; then \
                        $(INSTALL_DATA) $(PAMFILE) $(BUILDROOT)$(PAMDIR)/cups.N ; \
                else \
                        $(INSTALL_DATA) $(PAMFILE) $(BUILDROOT)$(PAMDIR)/cups ; \
index adc0752cf97ad4a33505b1bdeba31f2fc4ac9332..f02a741338e5e40d14db45989f0caba0d5a9da1c 100644 (file)
@@ -1,9 +1,8 @@
 #
 # "$Id: cupsd.conf.in 7888 2008-08-29 21:16:56Z mike $"
 #
-#   Sample configuration file for the Common UNIX Printing System (CUPS)
-#   scheduler.  See "man cupsd.conf" for a complete description of this
-#   file.
+# Sample configuration file for the CUPS scheduler.  See "man cupsd.conf" for a
+# complete description of this file.
 #
 
 # Log general information in error_log - change "@CUPS_LOG_LEVEL@" to "debug"
diff --git a/conf/pam.irix b/conf/pam.irix
deleted file mode 100644 (file)
index 476383a..0000000
+++ /dev/null
@@ -1,3 +0,0 @@
-#%PAM-1.0
-auth   required        pam_unix.so shadow nodelay nullok
-account        required        pam_unix.so
index 3ddcdd0d3553ea3c19f24933977906f3e1d13202..68fb50af3dc7093dcbb1087ee5ea3d50c69cc2f9 100644 (file)
@@ -1,2 +1,2 @@
-auth   required        @PAMMOD@ nullok shadow
+auth   required        @PAMMODAUTH@
 account        required        @PAMMOD@
index d0535dd3b7de22b1ea59426e506d1692cb2e8f8a..8a744a745a132c12f9db46bcad4d7c6558a5093b 100644 (file)
@@ -1,5 +1,5 @@
 dnl
-dnl "$Id: cups-common.m4 7900 2008-09-03 13:47:57Z mike $"
+dnl "$Id: cups-common.m4 8781 2009-08-28 17:34:54Z mike $"
 dnl
 dnl   Common configuration stuff for the Common UNIX Printing System (CUPS).
 dnl
@@ -20,7 +20,7 @@ dnl Set the name of the config header file...
 AC_CONFIG_HEADER(config.h)
 
 dnl Version number information...
-CUPS_VERSION="1.4.1"
+CUPS_VERSION="1.5svn"
 CUPS_REVISION=""
 #if test -z "$CUPS_REVISION" -a -d .svn; then
 #      CUPS_REVISION="-r`svnversion . | awk -F: '{print $NF}' | sed -e '1,$s/[[a-zA-Z]]*//g'`"
@@ -355,5 +355,5 @@ AC_SUBST(FONTS)
 AC_SUBST(LEGACY_BACKENDS)
 
 dnl
-dnl End of "$Id: cups-common.m4 7900 2008-09-03 13:47:57Z mike $".
+dnl End of "$Id: cups-common.m4 8781 2009-08-28 17:34:54Z mike $".
 dnl
index 1b554a411f9c46c5bfa99cd616207bac68ec7289..1cb1efc9dd202c61fd8f87db30a36200310d7eca 100644 (file)
@@ -22,9 +22,10 @@ if test $uname = AIX; then
 fi
 
 PAMDIR=""
-PAMFILE=""
+PAMFILE="pam.std"
 PAMLIBS=""
 PAMMOD="pam_unknown.so"
+PAMMODAUTH="pam_unknown.so"
 
 if test x$enable_pam != xno; then
        SAVELIBS="$LIBS"
@@ -60,7 +61,7 @@ if test x$enable_pam != xno; then
 
        case "$uname" in
                Darwin*)
-                       # Darwin, MacOS X
+                       # Darwin/Mac OS X
                        if test "x$with_pam_module" != x; then
                                PAMFILE="pam.$with_pam_module"
                        elif test -f /usr/lib/pam/pam_opendirectory.so.2; then
@@ -70,26 +71,22 @@ if test x$enable_pam != xno; then
                        fi
                        ;;
 
-               IRIX)
-                       # SGI IRIX
-                       PAMFILE="pam.irix"
-                       ;;
-
                *)
                        # All others; this test might need to be updated
                        # as Linux distributors move things around...
                        if test "x$with_pam_module" != x; then
                                PAMMOD="pam_${with_pam_module}.so"
-                       else
-                               for mod in pam_unix2.so pam_unix.so pam_pwdb.so; do
-                                       if test -f /lib/security/$mod; then
-                                               PAMMOD="$mod"
-                                               break;
-                                       fi
-                               done
+                       elif test -f /lib/security/pam_unix2.so; then
+                               PAMMOD="pam_unix2.so"
+                       elif test -f /lib/security/pam_unix.so; then
+                               PAMMOD="pam_unix.so"
                        fi
 
-                       PAMFILE="pam.std"
+                       if test "x$PAMMOD" = xpam_unix.so; then
+                               PAMMODAUTH="$PAMMOD shadow nodelay"
+                       else
+                               PAMMODAUTH="$PAMMOD nodelay"
+                       fi
                        ;;
        esac
 fi
@@ -98,6 +95,7 @@ AC_SUBST(PAMDIR)
 AC_SUBST(PAMFILE)
 AC_SUBST(PAMLIBS)
 AC_SUBST(PAMMOD)
+AC_SUBST(PAMMODAUTH)
 
 dnl
 dnl End of "$Id: cups-pam.m4 7960 2008-09-17 19:42:02Z mike $".
index 09aa2d1c432f3b8ee1ac0c6e260b677348806f65..c460e8f894967d616a2598c4f0cd62b61940bc70 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * "$Id: cups.h 7847 2008-08-19 04:22:14Z mike $"
+ * "$Id: cups.h 8781 2009-08-28 17:34:54Z mike $"
  *
  *   API definitions for the Common UNIX Printing System (CUPS).
  *
@@ -59,10 +59,10 @@ extern "C" {
  * Constants...
  */
 
-#  define CUPS_VERSION         1.0401
+#  define CUPS_VERSION         1.0499
 #  define CUPS_VERSION_MAJOR   1
-#  define CUPS_VERSION_MINOR   4
-#  define CUPS_VERSION_PATCH   1
+#  define CUPS_VERSION_MINOR   5
+#  define CUPS_VERSION_PATCH   -1
 
 #  define CUPS_BC_FD           3       /* Back-channel file descriptor for select/poll */
 #  define CUPS_DATE_ANY                (time_t)-1
@@ -334,5 +334,5 @@ extern http_status_t        cupsWriteRequestData(http_t *http, const char *buffer,
 #endif /* !_CUPS_CUPS_H_ */
 
 /*
- * End of "$Id: cups.h 7847 2008-08-19 04:22:14Z mike $".
+ * End of "$Id: cups.h 8781 2009-08-28 17:34:54Z mike $".
  */
index 0f51fd1bd24ee1efac096495224fb2c844a5f6b4..da3d2b84778a69536ab7797cc44584036d1a37a7 100644 (file)
@@ -191,9 +191,23 @@ cupsSideChannelRead(
     if (errno != EINTR && errno != EAGAIN)
     {
       DEBUG_printf(("1cupsSideChannelRead: Read error: %s", strerror(errno)));
+      *command = CUPS_SC_CMD_NONE;
+      *status  = CUPS_SC_STATUS_IO_ERROR;
       return (-1);
     }
 
+ /*
+  * Watch for EOF or too few bytes...
+  */
+
+  if (bytes < 4)
+  {
+    DEBUG_printf(("1cupsSideChannelRead: Short read of %d bytes", bytes));
+    *command = CUPS_SC_CMD_NONE;
+    *status  = CUPS_SC_STATUS_BAD_MESSAGE;
+    return (-1);
+  }
+
  /*
   * Validate the command code in the message...
   */
@@ -202,6 +216,8 @@ cupsSideChannelRead(
       buffer[0] > CUPS_SC_CMD_SNMP_GET_NEXT)
   {
     DEBUG_printf(("1cupsSideChannelRead: Bad command %d!", buffer[0]));
+    *command = CUPS_SC_CMD_NONE;
+    *status  = CUPS_SC_STATUS_BAD_MESSAGE;
     return (-1);
   }
 
@@ -379,6 +395,7 @@ cupsSideChannelSNMPWalk(
                        real_oidlen,    /* Length of returned OID string */
                        oidlen;         /* Length of first OID */
   const char           *current_oid;   /* Current OID */
+  char                 last_oid[2048]; /* Last OID */
 
 
   DEBUG_printf(("cupsSideChannelSNMPWalk(oid=\"%s\", timeout=%.3f, cb=%p, "
@@ -397,6 +414,7 @@ cupsSideChannelSNMPWalk(
 
   current_oid = oid;
   oidlen      = (int)strlen(oid);
+  last_oid[0] = '\0';
 
   do
   {
@@ -422,7 +440,8 @@ cupsSideChannelSNMPWalk(
       * Parse the response of the form "oid\0value"...
       */
 
-      if (strncmp(real_data, oid, oidlen) || real_data[oidlen] != '.')
+      if (strncmp(real_data, oid, oidlen) || real_data[oidlen] != '.' ||
+          !strcmp(real_data, last_oid))
       {
        /*
         * Done with this set of OIDs...
@@ -448,6 +467,7 @@ cupsSideChannelSNMPWalk(
       */
 
       current_oid = real_data;
+      strlcpy(last_oid, current_oid, sizeof(last_oid));
     }
   }
   while (status == CUPS_SC_STATUS_OK);
index 8242247cbb252a30da9a6fc5a44eca689a3de223..c52cd51cb65c93747f5401d9d562753e560ce1b0 100644 (file)
@@ -55,6 +55,7 @@ typedef enum cups_sc_bidi_e cups_sc_bidi_t;
 
 enum cups_sc_command_e                 /**** Request command codes ****/
 {
+  CUPS_SC_CMD_NONE = 0,                        /* No command @private@ */
   CUPS_SC_CMD_SOFT_RESET = 1,          /* Do a soft reset */
   CUPS_SC_CMD_DRAIN_OUTPUT = 2,                /* Drain all pending output */
   CUPS_SC_CMD_GET_BIDI = 3,            /* Return bidirectional capabilities */
index d37582b96bcd116ee9e5da9ad75f253e01356c48..c9951702e69578bbb3296225e3024ee4b7d080a7 100644 (file)
@@ -608,6 +608,8 @@ _cupsSNMPWalk(int            fd,    /* I - SNMP socket */
   int          count = 0;              /* Number of OIDs found */
   int          request_id = 0;         /* Current request ID */
   cups_snmp_t  packet;                 /* Current response packet */
+  int          lastoid[CUPS_SNMP_MAX_OID];
+                                       /* Last OID we got */
 
 
  /*
@@ -631,14 +633,15 @@ _cupsSNMPWalk(int            fd,  /* I - SNMP socket */
   */
 
   _cupsSNMPCopyOID(packet.object_name, prefix, CUPS_SNMP_MAX_OID);
+  lastoid[0] = -1;
 
   for (;;)
   {
     request_id ++;
 
     if (!_cupsSNMPWrite(fd, address, version, community,
-                       CUPS_ASN1_GET_NEXT_REQUEST, request_id,
-                      packet.object_name))
+                        CUPS_ASN1_GET_NEXT_REQUEST, request_id,
+                       packet.object_name))
     {
       DEBUG_puts("5_cupsSNMPWalk: Returning -1");
 
@@ -652,7 +655,8 @@ _cupsSNMPWalk(int            fd,    /* I - SNMP socket */
       return (-1);
     }
 
-    if (!_cupsSNMPIsOIDPrefixed(&packet, prefix))
+    if (!_cupsSNMPIsOIDPrefixed(&packet, prefix) ||
+        _cupsSNMPIsOID(&packet, lastoid))
     {
       DEBUG_printf(("5_cupsSNMPWalk: Returning %d", count));
 
@@ -666,6 +670,8 @@ _cupsSNMPWalk(int            fd,    /* I - SNMP socket */
       return (count > 0 ? count : -1);
     }
 
+    _cupsSNMPCopyOID(lastoid, packet.object_name, CUPS_SNMP_MAX_OID);
+
     count ++;
 
     (*cb)(&packet, data);
@@ -1280,7 +1286,7 @@ asn1_get_integer(
   int  value;                          /* Integer value */
 
 
-  for (value = 0;
+  for (value = (**buffer & 0x80) ? -1 : 0;
        length > 0 && *buffer < bufend;
        length --, (*buffer) ++)
     value = (value << 8) | **buffer;
index ae043e744d4daa23690ac27377f8ba94e9c3cd04..efdc7b041a92042ef71ca0fe549887582823861a 100644 (file)
@@ -558,7 +558,7 @@ job as well.
 <h4>Cancel-Job Request</h4>
 
 <p>The following groups of attributes are supplied as part of the
-Set-Job-Attributes request:
+Cancel-Job request:
 
 <p>Group 1: Operation Attributes
 
@@ -632,6 +632,17 @@ Purge-Jobs request:
        <dd>The client MUST supply a URI for the specified printer or
        "ipp://.../printers" for all printers and classes.
 
+       <dt><span class="info">CUPS 1.2/Mac OS X 10.5</span>"requesting-user-name" (name(MAX)):
+
+       <dd>The client OPTIONALLY supplies this attribute to specify whose jobs
+       jobs are purged or canceled.
+
+       <dt><span class="info">CUPS 1.2/Mac OS X 10.5</span>"my-jobs" (boolean):
+
+       <dd>The client OPTIONALLY supplies this attribute to specify that only
+       the jobs owned by the requesting user are purged or canceled. The
+       default is false.
+
        <dt><span class="info">CUPS 1.2/Mac OS X 10.5</span>"purge-jobs" (boolean):
 
        <dd>The client OPTIONALLY supplies this attribute to specify
index fdc45555ee4ebcec739ccf4d6bb59e67dc393c41..75102dd7db88819b8c4e93a90934b68f9211bce7 100644 (file)
@@ -144,7 +144,7 @@ ParseCommand(FILE    *fp,   /* I - File to read from */
   if (!strcasecmp(name, "LB"))
   {
     bufptr = buf;
-    while ((ch = getc(fp)) != StringTerminator)
+    while ((ch = getc(fp)) != StringTerminator && ch != EOF)
       if (bufptr < (buf + sizeof(buf) - 1))
         *bufptr++ = ch;
     *bufptr = '\0';
index 42d09fc0ebbad8b75b3c4aa8621cc9c3f8806254..fbc54378f132485cc5c9e91aabbd5954d35e3e70 100644 (file)
@@ -61,6 +61,7 @@ main(int  argc,                               // I - Number of command-line arguments
                        verbose;        // Verbosity
   ppdcLineEnding       le;             // Line ending to use
   ppdcArray            *locales;       // List of locales
+  cups_array_t         *filenames;     // List of generated filenames
 
 
   _cupsSetLocale(argv);
@@ -75,6 +76,7 @@ main(int  argc,                               // I - Number of command-line arguments
   src            = new ppdcSource();
   use_model_name = 0;
   verbose        = 0;
+  filenames      = cupsArrayNew((cups_array_func_t)strcasecmp, NULL);
 
   for (i = 1; i < argc; i ++)
     if (argv[i][0] == '-')
@@ -339,6 +341,13 @@ main(int  argc,                            // I - Number of command-line arguments
        else
          snprintf(filename, sizeof(filename), "%s/%s", outdir, pcfilename);
 
+        if (cupsArrayFind(filenames, filename))
+         _cupsLangPrintf(stderr,
+                         _("ppdc: Warning - overlapping filename \"%s\".\n"),
+                         filename);
+       else
+         cupsArrayAdd(filenames, strdup(filename));
+
        fp = cupsFileOpen(filename, comp ? "w9" : "w");
        if (!fp)
        {
index 94966f45f08ee67a304f5e08e8a79c40fefd8280..a6c45c89f5ce9fdb89a4146b14e590a76005e839 100644 (file)
 #media "w576h468/8.00x6.50\"" 576 468
 
 // Common stuff for all drivers...
-Attribute "cupsVersion" "" "1.4"
+Attribute "cupsVersion" "" "1.5"
 Attribute "FileSystem" "" "False"
 Attribute "LandscapeOrientation" "" "Plus90"
 Attribute "TTRasterizer" "" "Type42"
index 1439dd79583b07042666ed274f4605cd8a3982a2..0d776a637874877f64b1c9b8cafe14ba888d82dd 100644 (file)
@@ -328,7 +328,8 @@ cat_drv(const char *name,           /* I - PPD name */
   *pc_file_name++ = '\0';
 
 #ifdef __APPLE__
-  if (!strncmp(resource, "/Library/Printers/PPDs.drv/", 27))
+  if (!strncmp(resource, "/Library/Printers/PPDs/Contents/Resources/", 42) ||
+      !strncmp(resource, "/System/Library/Printers/PPDs/Contents/Resources/", 49))
     strlcpy(filename, resource, sizeof(filename));
   else
 #endif // __APPLE__
index d212b20551b7121cffab7b68cf26f2ca1b7d8e6c..60aa932ecf902ac942e1d54c782bc666a7f79af3 100644 (file)
@@ -8470,7 +8470,9 @@ ppd_parse_line(const char *line,  /* I - Line */
   * Read the option name...
   */
 
-  for (line += 8, olen --; isalnum(*line & 255); line ++)
+  for (line += 8, olen --;
+       *line > ' ' && *line < 0x7f && *line != ':' && *line != '/';
+       line ++)
     if (olen > 0)
     {
       *option++ = *line;
@@ -8498,7 +8500,9 @@ ppd_parse_line(const char *line,  /* I - Line */
   while (isspace(*line & 255))
     line ++;
 
-  for (clen --; isalnum(*line & 255); line ++)
+  for (clen --;
+       *line > ' ' && *line < 0x7f && *line != ':' && *line != '/';
+       line ++)
     if (clen > 0)
     {
       *choice++ = *line;
index 29f55231be6334deb02a738b1b5b22ba921f5a4f..84400085450f491ec97344489172b5f5020ec196 100644 (file)
@@ -3834,7 +3834,7 @@ delete_printer_filters(
   for (filter = mimeFirstFilter(MimeDatabase);
        filter;
        filter = mimeNextFilter(MimeDatabase))
-    if (filter->dst == p->filetype)
+    if (filter->dst == p->filetype || filter->dst == p->prefiltertype)
     {
      /*
       * Delete the current filter...
diff --git a/standards/cs-ipp20-20090731-5100.10.pdf b/standards/cs-ipp20-20090731-5100.10.pdf
new file mode 100644 (file)
index 0000000..1623ccb
Binary files /dev/null and b/standards/cs-ipp20-20090731-5100.10.pdf differ
diff --git a/standards/cs-ippstate10-20090731-5100.9.pdf b/standards/cs-ippstate10-20090731-5100.9.pdf
new file mode 100644 (file)
index 0000000..3c3c525
Binary files /dev/null and b/standards/cs-ippstate10-20090731-5100.9.pdf differ
diff --git a/standards/lcrc-ipp20-20090602.pdf b/standards/lcrc-ipp20-20090602.pdf
deleted file mode 100644 (file)
index 004b1ee..0000000
Binary files a/standards/lcrc-ipp20-20090602.pdf and /dev/null differ
diff --git a/standards/lcrc-ippstate10-20090603.pdf b/standards/lcrc-ippstate10-20090603.pdf
deleted file mode 100644 (file)
index cb9be4c..0000000
Binary files a/standards/lcrc-ippstate10-20090603.pdf and /dev/null differ
index bda71393f8b6a07f8a8daa357bfa411a73b145a2..9642409a5a03ab3bbac6983a612bab1373ea33e1 100755 (executable)
@@ -32,7 +32,7 @@ else
        fileurl="ftp://ftp.easysw.com/pub/cups/$version/cups-$fileversion-source.tar."
        url="https://svn.easysw.com/public/cups/tags/release-$version"
 
-       svn copy https://svn.easysw.com/public/cups/branches/branch-1.4 "$url" \
+       svn copy https://svn.easysw.com/public/cups/trunk "$url" \
                -m "Tag $version" || exit 1
 fi