diff --git a/cups-1.3.x.patch b/cups-1.3.x.patch new file mode 100644 index 0000000..1d5f34a --- /dev/null +++ b/cups-1.3.x.patch @@ -0,0 +1,7990 @@ +diff -up cups-1.3.5/cgi-bin/template.c.1.3.x cups-1.3.5/cgi-bin/template.c +--- cups-1.3.5/cgi-bin/template.c.1.3.x 2007-08-15 20:33:36.000000000 +0100 ++++ cups-1.3.5/cgi-bin/template.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * CGI template function. + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2006 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -54,6 +54,13 @@ cgiCopyTemplateFile(FILE *out, /* + tmpl ? tmpl : "(null)"); + + /* ++ * Range check input... ++ */ ++ ++ if (!tmpl || !out) ++ return; ++ ++ /* + * Open the template file... + */ + +diff -up cups-1.3.5/cgi-bin/admin.c.1.3.x cups-1.3.5/cgi-bin/admin.c +--- cups-1.3.5/cgi-bin/admin.c.1.3.x 2007-11-30 07:00:59.000000000 +0000 ++++ cups-1.3.5/cgi-bin/admin.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * Administration CGI for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2007 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -1647,14 +1647,15 @@ do_config_server(http_t *http) /* I - H + * Allocate memory and load the file into a string buffer... + */ + +- buffer = calloc(1, info.st_size + 1); ++ if ((buffer = calloc(1, info.st_size + 1)) != NULL) ++ { ++ cupsFileRead(cupsd, buffer, info.st_size); ++ cgiSetVariable("CUPSDCONF", buffer); ++ free(buffer); ++ } + +- cupsFileRead(cupsd, buffer, info.st_size); + cupsFileClose(cupsd); + +- cgiSetVariable("CUPSDCONF", buffer); +- free(buffer); +- + /* + * Then get the default cupsd.conf file and put that into a string as + * well... +@@ -1665,37 +1666,39 @@ do_config_server(http_t *http) /* I - H + if (!stat(filename, &info) && info.st_size < (1024 * 1024) && + (cupsd = cupsFileOpen(filename, "r")) != NULL) + { +- buffer = calloc(1, 2 * info.st_size + 1); +- bufend = buffer + 2 * info.st_size - 1; +- +- for (bufptr = buffer; +- bufptr < bufend && (ch = cupsFileGetChar(cupsd)) != EOF;) ++ if ((buffer = calloc(1, 2 * info.st_size + 1)) != NULL) + { +- if (ch == '\\' || ch == '\"') +- { +- *bufptr++ = '\\'; +- *bufptr++ = ch; +- } +- else if (ch == '\n') +- { +- *bufptr++ = '\\'; +- *bufptr++ = 'n'; +- } +- else if (ch == '\t') ++ bufend = buffer + 2 * info.st_size - 1; ++ ++ for (bufptr = buffer; ++ bufptr < bufend && (ch = cupsFileGetChar(cupsd)) != EOF;) + { +- *bufptr++ = '\\'; +- *bufptr++ = 't'; ++ if (ch == '\\' || ch == '\"') ++ { ++ *bufptr++ = '\\'; ++ *bufptr++ = ch; ++ } ++ else if (ch == '\n') ++ { ++ *bufptr++ = '\\'; ++ *bufptr++ = 'n'; ++ } ++ else if (ch == '\t') ++ { ++ *bufptr++ = '\\'; ++ *bufptr++ = 't'; ++ } ++ else if (ch >= ' ') ++ *bufptr++ = ch; + } +- else if (ch >= ' ') +- *bufptr++ = ch; +- } + +- *bufptr = '\0'; ++ *bufptr = '\0'; + +- cupsFileClose(cupsd); ++ cgiSetVariable("CUPSDCONF_DEFAULT", buffer); ++ free(buffer); ++ } + +- cgiSetVariable("CUPSDCONF_DEFAULT", buffer); +- free(buffer); ++ cupsFileClose(cupsd); + } + + /* +@@ -3084,7 +3087,7 @@ do_set_options(http_t *http, /* I - HTT + * Binary protocol support... + */ + +- if (ppd->protocols && strstr(ppd->protocols, "BCP")) ++ if (ppd && ppd->protocols && strstr(ppd->protocols, "BCP")) + { + protocol = ppdFindAttr(ppd, "cupsProtocol", NULL); + +diff -up cups-1.3.5/cgi-bin/search.c.1.3.x cups-1.3.5/cgi-bin/search.c +--- cups-1.3.5/cgi-bin/search.c.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/cgi-bin/search.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * Search routines for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2006 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -53,7 +53,8 @@ cgiCompileSearch(const char *query) /* I + * Allocate a regular expression storage structure... + */ + +- re = (regex_t *)calloc(1, sizeof(regex_t)); ++ if ((re = (regex_t *)calloc(1, sizeof(regex_t))) == NULL) ++ return (NULL); + + /* + * Allocate a buffer to hold the regular expression string, starting +@@ -65,7 +66,11 @@ cgiCompileSearch(const char *query) /* I + if (slen < 1024) + slen = 1024; + +- s = (char *)malloc(slen); ++ if ((s = (char *)malloc(slen)) == NULL) ++ { ++ free(re); ++ return (NULL); ++ } + + /* + * Copy the query string to the regular expression, handling basic +@@ -227,7 +232,13 @@ cgiCompileSearch(const char *query) /* I + char *lword2; /* New "last word" */ + + +- lword2 = strdup(sword); ++ if ((lword2 = strdup(sword)) == NULL) ++ { ++ free(lword); ++ free(s); ++ free(re); ++ return (NULL); ++ } + + strcpy(sptr, ".*|.*"); + sptr += 5; +diff -up cups-1.3.5/cgi-bin/ipp-var.c.1.3.x cups-1.3.5/cgi-bin/ipp-var.c +--- cups-1.3.5/cgi-bin/ipp-var.c.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/cgi-bin/ipp-var.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * CGI <-> IPP variable routines for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2007 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -158,6 +158,8 @@ cgiGetAttributes(ipp_t *request, /* + for (i = 0; i < num_attrs; i ++) + free(attrs[i]); + } ++ ++ fclose(in); + } + + +@@ -523,8 +525,7 @@ cgiPrintTestPage(http_t *http, /* I + * See who is logged in... + */ + +- if ((user = getenv("REMOTE_USER")) == NULL) +- user = "guest"; ++ user = getenv("REMOTE_USER"); + + /* + * Locate the test page file... +@@ -562,8 +563,9 @@ cgiPrintTestPage(http_t *http, /* I + ippAddString(request, IPP_TAG_OPERATION, IPP_TAG_URI, "printer-uri", + NULL, uri); + +- ippAddString(request, IPP_TAG_OPERATION, IPP_TAG_NAME, +- "requesting-user-name", NULL, user); ++ if (user) ++ ippAddString(request, IPP_TAG_OPERATION, IPP_TAG_NAME, ++ "requesting-user-name", NULL, user); + + ippAddString(request, IPP_TAG_OPERATION, IPP_TAG_NAME, "job-name", + NULL, "Test Page"); +@@ -593,6 +595,11 @@ cgiPrintTestPage(http_t *http, /* I + snprintf(refresh, sizeof(refresh), "2;URL=%s", uri); + cgiSetVariable("refresh_page", refresh); + } ++ else if (cupsLastError() == IPP_NOT_AUTHORIZED) ++ { ++ puts("Status: 401\n"); ++ exit(0); ++ } + + cgiStartHTML(cgiText(_("Print Test Page"))); + +diff -up cups-1.3.5/cgi-bin/jobs.c.1.3.x cups-1.3.5/cgi-bin/jobs.c +--- cups-1.3.5/cgi-bin/jobs.c.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/cgi-bin/jobs.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * Job status CGI for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2006 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -185,6 +185,11 @@ do_job_op(http_t *http, /* I - HTT + cgiFormEncode(url + 6, getenv("HTTP_REFERER"), sizeof(url) - 6); + cgiSetVariable("refresh_page", url); + } ++ else if (cupsLastError() == IPP_NOT_AUTHORIZED) ++ { ++ puts("Status: 401\n"); ++ exit(0); ++ } + + cgiStartHTML(cgiText(_("Jobs"))); + +diff -up cups-1.3.5/cgi-bin/var.c.1.3.x cups-1.3.5/cgi-bin/var.c +--- cups-1.3.5/cgi-bin/var.c.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/cgi-bin/var.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * CGI form variable and array functions. + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2005 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -322,9 +322,15 @@ cgiSetArray(const char *name, /* I - Na + { + if (element >= var->avalues) + { ++ const char **temp; /* Temporary pointer */ ++ ++ temp = (const char **)realloc((void *)(var->values), ++ sizeof(char *) * (element + 16)); ++ if (!temp) ++ return; ++ + var->avalues = element + 16; +- var->values = (const char **)realloc((void *)(var->values), +- sizeof(char *) * var->avalues); ++ var->values = temp; + } + + if (element >= var->nvalues) +@@ -362,9 +368,15 @@ cgiSetSize(const char *name, /* I - Nam + + if (size >= var->avalues) + { ++ const char **temp; /* Temporary pointer */ ++ ++ temp = (const char **)realloc((void *)(var->values), ++ sizeof(char *) * (size + 16)); ++ if (!temp) ++ return; ++ + var->avalues = size + 16; +- var->values = (const char **)realloc((void *)(var->values), +- sizeof(char *) * var->avalues); ++ var->values = temp; + } + + if (size > var->nvalues) +@@ -426,7 +438,7 @@ cgi_add_variable(const char *name, /* I + int element, /* I - Array element number */ + const char *value) /* I - Variable value */ + { +- _cgi_var_t *var; /* New variable */ ++ _cgi_var_t *var; /* New variable */ + + + if (name == NULL || value == NULL || element < 0 || element > 100000) +@@ -438,19 +450,29 @@ cgi_add_variable(const char *name, /* I + + if (form_count >= form_alloc) + { ++ _cgi_var_t *temp_vars; /* Temporary form pointer */ ++ ++ + if (form_alloc == 0) +- form_vars = malloc(sizeof(_cgi_var_t) * 16); ++ temp_vars = malloc(sizeof(_cgi_var_t) * 16); + else +- form_vars = realloc(form_vars, (form_alloc + 16) * sizeof(_cgi_var_t)); ++ temp_vars = realloc(form_vars, (form_alloc + 16) * sizeof(_cgi_var_t)); ++ ++ if (!temp_vars) ++ return; + ++ form_vars = temp_vars; + form_alloc += 16; + } + +- var = form_vars + form_count; ++ var = form_vars + form_count; ++ ++ if ((var->values = calloc(element + 1, sizeof(char *))) == NULL) ++ return; ++ + var->name = strdup(name); + var->nvalues = element + 1; + var->avalues = element + 1; +- var->values = calloc(element + 1, sizeof(char *)); + var->values[element] = strdup(value); + + form_count ++; +@@ -784,11 +806,15 @@ cgi_initialize_post(void) + + for (tbytes = 0; tbytes < length; tbytes += nbytes) + if ((nbytes = read(0, data + tbytes, length - tbytes)) < 0) ++ { + if (errno != EAGAIN) + { + free(data); + return (0); + } ++ else ++ nbytes = 0; ++ } + + data[length] = '\0'; + +diff -up cups-1.3.5/cgi-bin/printers.c.1.3.x cups-1.3.5/cgi-bin/printers.c +--- cups-1.3.5/cgi-bin/printers.c.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/cgi-bin/printers.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * Printer status CGI for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2006 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -280,6 +280,11 @@ print_command(http_t *http, /* I - + snprintf(refresh, sizeof(refresh), "2;URL=%s", uri); + cgiSetVariable("refresh_page", refresh); + } ++ else if (cupsLastError() == IPP_NOT_AUTHORIZED) ++ { ++ puts("Status: 401\n"); ++ exit(0); ++ } + + cgiStartHTML(cgiText(_("Printer Maintenance"))); + +diff -up cups-1.3.5/locale/checkpo.c.1.3.x cups-1.3.5/locale/checkpo.c +--- cups-1.3.5/locale/checkpo.c.1.3.x 2007-09-06 15:34:31.000000000 +0100 ++++ cups-1.3.5/locale/checkpo.c 2008-02-05 15:08:55.000000000 +0000 +@@ -50,8 +50,7 @@ main(int argc, /* I - Number of comm + *strfmts; /* Format strings in msgstr */ + char *idfmt, /* Current msgid format string */ + *strfmt; /* Current msgstr format string */ +- int fmtidx, /* Format index */ +- fmtcount; /* Format count */ ++ int fmtidx; /* Format index */ + int status, /* Exit status */ + pass, /* Pass/fail status */ + untranslated; /* Untranslated messages */ +@@ -135,8 +134,6 @@ main(int argc, /* I - Number of comm + + if (!idfmt || strcmp(strfmt, idfmt)) + break; +- +- fmtcount ++; + } + + if (cupsArrayCount(strfmts) != cupsArrayCount(idfmts) || strfmt) +diff -up cups-1.3.5/backend/usb-unix.c.1.3.x cups-1.3.5/backend/usb-unix.c +--- cups-1.3.5/backend/usb-unix.c.1.3.x 2007-11-30 07:00:59.000000000 +0000 ++++ cups-1.3.5/backend/usb-unix.c 2008-02-05 15:08:55.000000000 +0000 +@@ -516,7 +516,7 @@ open_device(const char *uri, /* I - Dev + } + #else + { +- if (use_bc) ++ if (*use_bc) + fd = open(uri + 4, O_RDWR | O_EXCL); + else + fd = -1; +diff -up cups-1.3.5/backend/snmp.c.1.3.x cups-1.3.5/backend/snmp.c +--- cups-1.3.5/backend/snmp.c.1.3.x 2007-12-17 22:12:45.000000000 +0000 ++++ cups-1.3.5/backend/snmp.c 2008-02-05 15:08:55.000000000 +0000 +@@ -1090,7 +1090,7 @@ asn1_get_string( + * String is larger than the buffer... + */ + +- memcpy(string, buffer, strsize - 1); ++ memcpy(string, *buffer, strsize - 1); + string[strsize - 1] = '\0'; + } + +diff -up cups-1.3.5/backend/pap.c.1.3.x cups-1.3.5/backend/pap.c +--- cups-1.3.5/backend/pap.c.1.3.x 2007-10-10 22:25:29.000000000 +0100 ++++ cups-1.3.5/backend/pap.c 2008-02-05 15:08:55.000000000 +0000 +@@ -1,7 +1,7 @@ + /* + * "$Id: pap.c 7013 2007-10-10 21:25:29Z mike $" + * +-* © Copyright 2004 Apple Computer, Inc. All rights reserved. ++* © Copyright 2004-2008 Apple Computer, Inc. All rights reserved. + * + * IMPORTANT: This Apple software is supplied to you by Apple Computer, + * Inc. ("Apple") in consideration of your agreement to the following +@@ -70,6 +70,16 @@ + * signalHandler() - handle SIGINT to close the session before quiting. + */ + ++/* ++ * This backend uses deprecated APIs for AppleTalk; we know this, so ++ * silence any warnings about it... ++ */ ++ ++#ifdef MAC_OS_X_VERSION_MIN_REQUIRED ++# undef MAC_OS_X_VERSION_MIN_REQUIRED ++#endif /* MAX_OS_X_VERSION_MIN_REQUIRED */ ++#define MAC_OS_X_VERSION_MIN_REQUIRED MAC_OS_X_VERSION_10_0 ++ + #include + + #include +@@ -85,17 +95,17 @@ + #include + #include + ++#include ++#include ++#include ++#include ++ + #include + #include + #include + #include + #include + +-#include +-#include +-#include +-#include +- + #include + + #ifdef HAVE_APPLETALK_AT_PROTO_H +diff -up cups-1.3.5/backend/runloop.c.1.3.x cups-1.3.5/backend/runloop.c +--- cups-1.3.5/backend/runloop.c.1.3.x 2007-08-22 19:34:34.000000000 +0100 ++++ cups-1.3.5/backend/runloop.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * Common run loop APIs for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 2006-2007 by Easy Software Products, all rights reserved. + * + * These coded instructions, statements, and computer programs are the +@@ -216,7 +216,7 @@ backendRunLoop( + FD_SET(CUPS_SC_FD, &input); + + FD_ZERO(&output); +- if (print_bytes || !use_bc) ++ if (print_bytes || (!use_bc && !side_cb)) + FD_SET(device_fd, &output); + + if (use_bc || side_cb) +diff -up cups-1.3.5/backend/ipp.c.1.3.x cups-1.3.5/backend/ipp.c +--- cups-1.3.5/backend/ipp.c.1.3.x 2007-11-09 19:54:09.000000000 +0000 ++++ cups-1.3.5/backend/ipp.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * IPP backend for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2007 by Easy Software Products, all rights reserved. + * + * These coded instructions, statements, and computer programs are the +@@ -521,8 +521,8 @@ main(int argc, /* I - Number of comm + _("INFO: Unable to contact printer, queuing on next " + "printer in class...\n")); + +- if (argc == 6 || strcmp(filename, argv[6])) +- unlink(filename); ++ if (tmpfilename[0]) ++ unlink(tmpfilename); + + /* + * Sleep 5 seconds to keep the job from requeuing too rapidly... +@@ -579,8 +579,8 @@ main(int argc, /* I - Number of comm + + if (job_cancelled) + { +- if (argc == 6 || strcmp(filename, argv[6])) +- unlink(filename); ++ if (tmpfilename[0]) ++ unlink(tmpfilename); + + return (CUPS_BACKEND_FAILED); + } +@@ -765,8 +765,8 @@ main(int argc, /* I - Number of comm + ippDelete(supported); + httpClose(http); + +- if (argc == 6 || strcmp(filename, argv[6])) +- unlink(filename); ++ if (tmpfilename[0]) ++ unlink(tmpfilename); + + /* + * Sleep 5 seconds to keep the job from requeuing too rapidly... +@@ -865,12 +865,13 @@ main(int argc, /* I - Number of comm + num_options = cupsParseOptions(argv[5], 0, &options); + + #ifdef __APPLE__ +- if (!strcasecmp(content_type, "application/pictwps") && num_files == 1) ++ if (!strcasecmp(final_content_type, "application/pictwps") && ++ num_files == 1) + { + if (format_sup != NULL) + { + for (i = 0; i < format_sup->num_values; i ++) +- if (!strcasecmp(content_type, format_sup->values[i].string.text)) ++ if (!strcasecmp(final_content_type, format_sup->values[i].string.text)) + break; + } + +@@ -881,10 +882,18 @@ main(int argc, /* I - Number of comm + * so convert the document to PostScript... + */ + +- if (run_pictwps_filter(argv, filename)) ++ if (run_pictwps_filter(argv, files[0])) ++ { ++ if (pstmpname[0]) ++ unlink(pstmpname); ++ ++ if (tmpfilename[0]) ++ unlink(tmpfilename); ++ + return (CUPS_BACKEND_FAILED); ++ } + +- filename = pstmpname; ++ files[0] = pstmpname; + + /* + * Change the MIME type to application/postscript and change the +@@ -1680,7 +1689,6 @@ run_pictwps_filter(char **argv, /* + + _cupsLangPrintf(stderr, _("ERROR: Unable to fork pictwpstops: %s\n"), + strerror(errno)); +- unlink(filename); + if (ppdfile) + unlink(ppdfile); + return (-1); +@@ -1695,7 +1703,6 @@ run_pictwps_filter(char **argv, /* + _cupsLangPrintf(stderr, _("ERROR: Unable to wait for pictwpstops: %s\n"), + strerror(errno)); + close(fd); +- unlink(filename); + if (ppdfile) + unlink(ppdfile); + return (-1); +@@ -1715,7 +1722,6 @@ run_pictwps_filter(char **argv, /* + _cupsLangPrintf(stderr, _("ERROR: pictwpstops exited on signal %d!\n"), + status); + +- unlink(filename); + return (status); + } + +diff -up cups-1.3.5/cups/adminutil.c.1.3.x cups-1.3.5/cups/adminutil.c +--- cups-1.3.5/cups/adminutil.c.1.3.x 2007-11-30 07:00:59.000000000 +0000 ++++ cups-1.3.5/cups/adminutil.c 2008-02-05 15:08:55.000000000 +0000 +@@ -4,7 +4,7 @@ + * Administration utility API definitions for the Common UNIX Printing + * System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 2001-2007 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -1057,7 +1057,7 @@ _cupsAdminGetServerSettings( + in_admin_location = 0; + in_location = 0; + } +- else if (!strcasecmp(line, "Allow") && in_admin_location && ++ else if (!strcasecmp(line, "Allow") && + strcasecmp(value, "localhost") && strcasecmp(value, "127.0.0.1") + #ifdef AF_LOCAL + && *value != '/' +@@ -1067,9 +1067,9 @@ _cupsAdminGetServerSettings( + #endif /* AF_INET6 */ + ) + { +- remote_admin = 1; +- +- if (!strcasecmp(value, "all")) ++ if (in_admin_location) ++ remote_admin = 1; ++ else if (!strcasecmp(value, "all")) + remote_any = 1; + } + else if (line[0] != '<' && !in_location && !in_policy) +@@ -1578,8 +1578,6 @@ _cupsAdminSetServerSettings( + if (remote_admin) + cupsFilePrintf(temp, " Allow %s\n", + remote_any > 0 ? "all" : "@LOCAL"); +- else +- cupsFilePuts(temp, " Allow localhost\n"); + } + else if (in_conf_location && remote_admin >= 0) + { +@@ -1597,8 +1595,6 @@ _cupsAdminSetServerSettings( + if (remote_admin) + cupsFilePrintf(temp, " Allow %s\n", + remote_any > 0 ? "all" : "@LOCAL"); +- else +- cupsFilePuts(temp, " Allow localhost\n"); + } + else if (in_root_location && (remote_admin >= 0 || share_printers >= 0)) + { +@@ -1619,8 +1615,6 @@ _cupsAdminSetServerSettings( + if (remote_admin > 0 || share_printers > 0) + cupsFilePrintf(temp, " Allow %s\n", + remote_any > 0 ? "all" : "@LOCAL"); +- else +- cupsFilePuts(temp, " Allow localhost\n"); + } + + in_admin_location = 0; +@@ -1841,8 +1835,6 @@ _cupsAdminSetServerSettings( + + if (remote_admin > 0 || share_printers > 0) + cupsFilePrintf(temp, " Allow %s\n", remote_any > 0 ? "all" : "@LOCAL"); +- else +- cupsFilePuts(temp, " Allow localhost\n"); + + cupsFilePuts(temp, "\n"); + } +@@ -1859,8 +1851,6 @@ _cupsAdminSetServerSettings( + + if (remote_admin) + cupsFilePrintf(temp, " Allow %s\n", remote_any > 0 ? "all" : "@LOCAL"); +- else +- cupsFilePuts(temp, " Allow localhost\n"); + + cupsFilePuts(temp, "\n"); + } +@@ -1880,8 +1870,6 @@ _cupsAdminSetServerSettings( + + if (remote_admin) + cupsFilePrintf(temp, " Allow %s\n", remote_any > 0 ? "all" : "@LOCAL"); +- else +- cupsFilePuts(temp, " Allow localhost\n"); + + cupsFilePuts(temp, "\n"); + } +diff -up cups-1.3.5/cups/transcode.c.1.3.x cups-1.3.5/cups/transcode.c +--- cups-1.3.5/cups/transcode.c.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/cups/transcode.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * Transcoding support for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2007 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -132,8 +132,6 @@ _cupsCharmapFlush(void) + vnext = vmap->next; + + free_vbcs_charmap(vmap); +- +- free(vmap); + } + + vmap_cache = NULL; +@@ -330,13 +328,8 @@ cupsCharsetToUTF8( + + if (encoding < CUPS_ENCODING_SBCS_END) + bytes = conv_sbcs_to_utf8(dest, (cups_sbcs_t *)src, maxout, encoding); +- else if (encoding < CUPS_ENCODING_VBCS_END) +- bytes = conv_vbcs_to_utf8(dest, (cups_sbcs_t *)src, maxout, encoding); + else +- { +- DEBUG_puts(" Bad encoding, returning -1"); +- bytes = -1; +- } ++ bytes = conv_vbcs_to_utf8(dest, (cups_sbcs_t *)src, maxout, encoding); + + #ifdef HAVE_PTHREAD_H + pthread_mutex_unlock(&map_mutex); +@@ -437,10 +430,8 @@ cupsUTF8ToCharset( + + if (encoding < CUPS_ENCODING_SBCS_END) + bytes = conv_utf8_to_sbcs((cups_sbcs_t *)dest, src, maxout, encoding); +- else if (encoding < CUPS_ENCODING_VBCS_END) +- bytes = conv_utf8_to_vbcs((cups_sbcs_t *)dest, src, maxout, encoding); + else +- bytes = -1; ++ bytes = conv_utf8_to_vbcs((cups_sbcs_t *)dest, src, maxout, encoding); + + #ifdef HAVE_PTHREAD_H + pthread_mutex_unlock(&map_mutex); +@@ -1468,6 +1459,8 @@ get_vbcs_charmap( + { + DEBUG_puts(" Unable to get charmap count!"); + ++ cupsFileClose(fp); ++ + return (NULL); + } + +@@ -1479,9 +1472,10 @@ get_vbcs_charmap( + + if ((vmap = (_cups_vmap_t *)calloc(1, sizeof(_cups_vmap_t))) == NULL) + { +- cupsFileClose(fp); + DEBUG_puts(" Unable to allocate memory!"); + ++ cupsFileClose(fp); ++ + return (NULL); + } + +diff -up cups-1.3.5/cups/testcups.c.1.3.x cups-1.3.5/cups/testcups.c +--- cups-1.3.5/cups/testcups.c.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/cups/testcups.c 2008-02-05 15:08:55.000000000 +0000 +@@ -106,6 +106,7 @@ main(int argc, /* I - Number of comm + { + status = 1; + puts("FAIL"); ++ return (1); + } + else + puts("PASS"); +diff -up cups-1.3.5/cups/http.c.1.3.x cups-1.3.5/cups/http.c +--- cups-1.3.5/cups/http.c.1.3.x 2007-07-25 21:39:33.000000000 +0100 ++++ cups-1.3.5/cups/http.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * HTTP routines for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2007 by Easy Software Products, all rights reserved. + * + * This file contains Kerberos support code, copyright 2006 by +@@ -402,9 +402,11 @@ httpConnectEncrypt( + * Allocate memory for the structure... + */ + +- http = calloc(sizeof(http_t), 1); +- if (http == NULL) ++ if ((http = calloc(sizeof(http_t), 1)) == NULL) ++ { ++ httpAddrFreeList(addrlist); + return (NULL); ++ } + + http->version = HTTP_1_1; + http->blocking = 1; +@@ -1735,9 +1737,15 @@ httpSetAuthString(http_t *http, /* I + */ + + int len = (int)strlen(scheme) + (data ? (int)strlen(data) + 1 : 0) + 1; ++ char *temp; + + if (len > (int)sizeof(http->_authstring)) +- http->authstring = malloc(len); ++ { ++ if ((temp = malloc(len)) == NULL) ++ len = sizeof(http->_authstring); ++ else ++ http->authstring = temp; ++ } + + if (data) + snprintf(http->authstring, len, "%s %s", scheme, data); +diff -up cups-1.3.5/cups/libcups.exp.1.3.x cups-1.3.5/cups/libcups.exp +--- cups-1.3.5/cups/libcups.exp.1.3.x 2007-07-25 18:19:09.000000000 +0100 ++++ cups-1.3.5/cups/libcups.exp 2008-02-05 15:08:55.000000000 +0000 +@@ -1,6 +1,7 @@ + __cups_strcpy + __cupsAdminGetServerSettings + __cupsAdminSetServerSettings ++__cupsAppleLanguage + __cupsCharmapFlush + __cupsCharmapFree + __cupsCharmapGet +diff -up cups-1.3.5/cups/auth.c.1.3.x cups-1.3.5/cups/auth.c +--- cups-1.3.5/cups/auth.c.1.3.x 2007-10-31 18:35:56.000000000 +0000 ++++ cups-1.3.5/cups/auth.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * Authentication functions for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2007 by Easy Software Products. + * + * This file contains Kerberos support code, copyright 2006 by +@@ -91,8 +91,7 @@ cupsDoAuthentication(http_t *http, / + const char *password; /* Password string */ + char prompt[1024], /* Prompt for user */ + realm[HTTP_MAX_VALUE], /* realm="xyz" string */ +- nonce[HTTP_MAX_VALUE], /* nonce="xyz" string */ +- encode[4096]; /* Encoded username:password */ ++ nonce[HTTP_MAX_VALUE]; /* nonce="xyz" string */ + int localauth; /* Local authentication result */ + _cups_globals_t *cg; /* Global data */ + +@@ -301,14 +300,40 @@ cupsDoAuthentication(http_t *http, / + if (major_status == GSS_S_CONTINUE_NEEDED) + DEBUG_gss_printf(major_status, minor_status, "Continuation needed!"); + +- if (output_token.length) ++ if (output_token.length > 0 && output_token.length <= 65536) + { +- httpEncode64_2(encode, sizeof(encode), output_token.value, ++ /* ++ * Allocate the authorization string since Windows KDCs can have ++ * arbitrarily large credentials... ++ */ ++ ++ int authsize = 10 + /* "Negotiate " */ ++ output_token.length * 4 / 3 + 1 + /* Base64 */ ++ 1; /* nul */ ++ ++ httpSetAuthString(http, NULL, NULL); ++ ++ if ((http->authstring = malloc(authsize)) == NULL) ++ { ++ http->authstring = http->_authstring; ++ authsize = sizeof(http->_authstring); ++ } ++ ++ strcpy(http->authstring, "Negotiate "); ++ httpEncode64_2(http->authstring + 10, authsize - 10, output_token.value, + output_token.length); +- httpSetAuthString(http, "Negotiate", encode); + + major_status = gss_release_buffer(&minor_status, &output_token); + } ++ else ++ { ++ DEBUG_printf(("cupsDoAuthentication: Kerberos credentials too large - " ++ "%d bytes!\n", output_token.length)); ++ ++ major_status = gss_release_buffer(&minor_status, &output_token); ++ ++ return (-1); ++ } + #endif /* HAVE_GSSAPI */ + } + else if (strncmp(http->fields[HTTP_FIELD_WWW_AUTHENTICATE], "Digest", 6)) +@@ -317,6 +342,9 @@ cupsDoAuthentication(http_t *http, / + * Basic authentication... + */ + ++ char encode[256]; /* Base64 buffer */ ++ ++ + httpEncode64_2(encode, sizeof(encode), http->userpass, + (int)strlen(http->userpass)); + httpSetAuthString(http, "Basic", encode); +@@ -327,7 +355,8 @@ cupsDoAuthentication(http_t *http, / + * Digest authentication... + */ + +- char digest[1024]; /* Digest auth data */ ++ char encode[33], /* MD5 buffer */ ++ digest[1024]; /* Digest auth data */ + + + httpGetSubField(http, HTTP_FIELD_WWW_AUTHENTICATE, "realm", realm); +diff -up cups-1.3.5/cups/options.c.1.3.x cups-1.3.5/cups/options.c +--- cups-1.3.5/cups/options.c.1.3.x 2007-07-20 22:28:10.000000000 +0100 ++++ cups-1.3.5/cups/options.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * Option routines for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2007 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -470,18 +470,28 @@ cupsParseOptions( + char *copyarg, /* Copy of input string */ + *ptr, /* Pointer into string */ + *name, /* Pointer to name */ +- *value; /* Pointer to value */ ++ *value, /* Pointer to value */ ++ quote; /* Quote character */ + + +- if (arg == NULL || options == NULL || num_options < 0) ++ /* ++ * Range check input... ++ */ ++ ++ if (!arg) ++ return (num_options); ++ ++ if (!options || num_options < 0) + return (0); + + /* + * Make a copy of the argument string and then divide it up... + */ + +- copyarg = strdup(arg); +- ptr = copyarg; ++ if ((copyarg = strdup(arg)) == NULL) ++ return (num_options); ++ ++ ptr = copyarg; + + /* + * Skip leading spaces... +@@ -501,7 +511,7 @@ cupsParseOptions( + */ + + name = ptr; +- while (!isspace(*ptr & 255) && *ptr != '=' && *ptr != '\0') ++ while (!isspace(*ptr & 255) && *ptr != '=' && *ptr) + ptr ++; + + /* +@@ -521,10 +531,10 @@ cupsParseOptions( + if (*ptr != '=') + { + /* +- * Start of another option... ++ * Boolean option... + */ + +- if (strncasecmp(name, "no", 2) == 0) ++ if (!strncasecmp(name, "no", 2)) + num_options = cupsAddOption(name + 2, "false", num_options, + options); + else +@@ -539,38 +549,18 @@ cupsParseOptions( + + *ptr++ = '\0'; + +- if (*ptr == '\'') ++ if (*ptr == '\'' || *ptr == '\"') + { + /* + * Quoted string constant... + */ + +- ptr ++; +- value = ptr; +- +- while (*ptr != '\'' && *ptr != '\0') +- { +- if (*ptr == '\\') +- _cups_strcpy(ptr, ptr + 1); +- +- ptr ++; +- } +- +- if (*ptr != '\0') +- *ptr++ = '\0'; +- } +- else if (*ptr == '\"') +- { +- /* +- * Double-quoted string constant... +- */ +- +- ptr ++; ++ quote = *ptr++; + value = ptr; + +- while (*ptr != '\"' && *ptr != '\0') ++ while (*ptr != quote && *ptr) + { +- if (*ptr == '\\') ++ if (*ptr == '\\' && ptr[1]) + _cups_strcpy(ptr, ptr + 1); + + ptr ++; +@@ -603,7 +593,7 @@ cupsParseOptions( + break; + } + } +- else if (*ptr == '\\') ++ else if (*ptr == '\\' && ptr[1]) + _cups_strcpy(ptr, ptr + 1); + + if (*ptr != '\0') +@@ -617,9 +607,9 @@ cupsParseOptions( + + value = ptr; + +- while (!isspace(*ptr & 255) && *ptr != '\0') ++ while (!isspace(*ptr & 255) && *ptr) + { +- if (*ptr == '\\') ++ if (*ptr == '\\' && ptr[1]) + _cups_strcpy(ptr, ptr + 1); + + ptr ++; +diff -up cups-1.3.5/cups/i18n.h.1.3.x cups-1.3.5/cups/i18n.h +--- cups-1.3.5/cups/i18n.h.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/cups/i18n.h 2008-02-05 15:08:55.000000000 +0000 +@@ -82,6 +82,10 @@ typedef struct _cups_vmap_s /**** VBCS + * Prototypes... + */ + ++#ifdef __APPLE__ ++extern const char *_cupsAppleLanguage(const char *locale, char *language, ++ size_t langsize); ++#endif /* __APPLE__ */ + extern void _cupsCharmapFlush(void); + extern void _cupsCharmapFree(const cups_encoding_t encoding); + extern void *_cupsCharmapGet(const cups_encoding_t encoding); +diff -up cups-1.3.5/cups/util.c.1.3.x cups-1.3.5/cups/util.c +--- cups-1.3.5/cups/util.c.1.3.x 2007-10-10 23:00:43.000000000 +0100 ++++ cups-1.3.5/cups/util.c 2008-02-05 15:08:55.000000000 +0000 +@@ -846,9 +846,6 @@ cupsGetPPD2(http_t *http, /* I - HT + + close(fd); + +- if (http2 != http) +- httpClose(http2); +- + /* + * See if we actually got the file or an error... + */ +@@ -877,6 +874,9 @@ cupsGetPPD2(http_t *http, /* I - HT + return (NULL); + } + ++ if (http2 != http) ++ httpClose(http2); ++ + /* + * Return the PPD file... + */ +diff -up cups-1.3.5/cups/language.c.1.3.x cups-1.3.5/cups/language.c +--- cups-1.3.5/cups/language.c.1.3.x 2007-10-31 18:51:08.000000000 +0000 ++++ cups-1.3.5/cups/language.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * I18N/language support for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2007 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -16,6 +16,8 @@ + * + * Contents: + * ++ * _cupsAppleLanguage() - Get the Apple language identifier associated ++ * with a locale ID. + * _cupsEncodingName() - Return the character encoding name string + * for the given encoding enumeration. + * cupsLangDefault() - Return the default language. +@@ -65,26 +67,6 @@ static pthread_mutex_t lang_mutex = PTHR + #endif /* HAVE_PTHREAD_H */ + static cups_lang_t *lang_cache = NULL; + /* Language string cache */ +- +- +-/* +- * Local functions... +- */ +- +-#ifdef __APPLE__ +-static const char *appleLangDefault(void); +-#endif /* __APPLE__ */ +-static cups_lang_t *cups_cache_lookup(const char *name, +- cups_encoding_t encoding); +-static int cups_message_compare(_cups_message_t *m1, +- _cups_message_t *m2); +-static void cups_unquote(char *d, const char *s); +- +- +-/* +- * Local globals... +- */ +- + static const char * const lang_encodings[] = + { /* Encoding strings */ + "us-ascii", "iso-8859-1", +@@ -155,6 +137,123 @@ static const char * const lang_encodings + "euc-kr", "euc-tw" + }; + ++#ifdef __APPLE__ ++typedef struct ++{ ++ const char * const language; /* Language ID */ ++ const char * const locale; /* Locale ID */ ++} _apple_language_locale_t; ++ ++static const _apple_language_locale_t apple_language_locale[] = ++{ /* Locale to language ID LUT */ ++ { "en" , "en_US" }, ++ { "nb" , "no" }, ++ { "zh-Hans" , "zh_CN" }, ++ { "zh-Hant" , "zh_TW" } ++}; ++#endif /* __APPLE__ */ ++ ++ ++/* ++ * Local functions... ++ */ ++ ++#ifdef __APPLE__ ++static const char *appleLangDefault(void); ++#endif /* __APPLE__ */ ++static cups_lang_t *cups_cache_lookup(const char *name, ++ cups_encoding_t encoding); ++static int cups_message_compare(_cups_message_t *m1, ++ _cups_message_t *m2); ++static void cups_unquote(char *d, const char *s); ++ ++ ++#ifdef __APPLE__ ++/* ++ * _cupsAppleLanguage() - Get the Apple language identifier associated ++ * with a locale ID. ++ */ ++ ++const char * /* O - Language ID */ ++_cupsAppleLanguage(const char *locale, /* I - Locale ID */ ++ char *language,/* I - Language ID buffer */ ++ size_t langsize) /* I - Size of language ID buffer */ ++{ ++ int i; /* Looping var */ ++ CFStringRef localeid, /* CF locale identifier */ ++ langid; /* CF language identifier */ ++ ++ ++ /* ++ * Copy the locale name and convert, as needed, to the Apple-specific ++ * locale identifier... ++ */ ++ ++ switch (strlen(locale)) ++ { ++ default : ++ /* ++ * Invalid locale... ++ */ ++ ++ strlcpy(language, "en", langsize); ++ break; ++ ++ case 2 : ++ strlcpy(language, locale, langsize); ++ break; ++ ++ case 5 : ++ strlcpy(language, locale, langsize); ++ ++ if (language[2] == '-') ++ { ++ /* ++ * Convert ll-cc to ll_CC... ++ */ ++ ++ language[2] = '_'; ++ language[3] = toupper(language[3] & 255); ++ language[4] = toupper(language[4] & 255); ++ } ++ break; ++ } ++ ++ for (i = 0; ++ i < (int)(sizeof(apple_language_locale) / ++ sizeof(apple_language_locale[0])); ++ i ++) ++ if (!strcmp(locale, apple_language_locale[i].locale)) ++ { ++ strlcpy(language, apple_language_locale[i].language, sizeof(language)); ++ break; ++ } ++ ++ /* ++ * Attempt to map the locale ID to a language ID... ++ */ ++ ++ if ((localeid = CFStringCreateWithCString(kCFAllocatorDefault, language, ++ kCFStringEncodingASCII)) != NULL) ++ { ++ if ((langid = CFLocaleCreateCanonicalLanguageIdentifierFromString( ++ kCFAllocatorDefault, localeid)) != NULL) ++ { ++ CFStringGetCString(langid, language, langsize, kCFStringEncodingASCII); ++ CFRelease(langid); ++ } ++ ++ CFRelease(localeid); ++ } ++ ++ /* ++ * Return what we got... ++ */ ++ ++ return (language); ++} ++#endif /* __APPLE__ */ ++ + + /* + * '_cupsEncodingName()' - Return the character encoding name string +@@ -876,7 +975,12 @@ _cupsMessageLoad(const char *filename) / + return (a); + } + +- m->id = strdup(ptr); ++ if ((m->id = strdup(ptr)) == NULL) ++ { ++ free(m); ++ cupsFileClose(fp); ++ return (a); ++ } + } + else if (s[0] == '\"' && m) + { +@@ -924,7 +1028,11 @@ _cupsMessageLoad(const char *filename) / + * Set the string... + */ + +- m->str = strdup(ptr); ++ if ((m->str = strdup(ptr)) == NULL) ++ { ++ cupsFileClose(fp); ++ return (a); ++ } + } + } + +@@ -974,30 +1082,6 @@ _cupsMessageLookup(cups_array_t *a, /* I + + #ifdef __APPLE__ + /* +- * Code & data to translate OSX's language names to their ISO 639-1 locale. +- * +- * The first version uses the new CoreFoundation API added in 10.3 (Panther), +- * the second is for 10.2 (Jaguar). +- */ +- +-# ifdef HAVE_CF_LOCALE_ID +- +-typedef struct +-{ +- const char * const name; /* Language name */ +- const char * const locale; /* Locale name */ +-} _apple_name_locale_t; +- +-static const _apple_name_locale_t apple_name_locale[] = +-{ +- { "en" , "en_US" }, +- { "nb" , "no" }, +- { "zh-Hans" , "zh_CN" }, +- { "zh-Hant" , "zh_TW" } +-}; +- +- +-/* + * 'appleLangDefault()' - Get the default locale string. + */ + +@@ -1067,14 +1151,15 @@ appleLangDefault(void) + */ + + for (i = 0; +- i < sizeof(apple_name_locale) / sizeof(apple_name_locale[0]); +- i++) ++ i < (int)(sizeof(apple_language_locale) / ++ sizeof(apple_language_locale[0])); ++ i ++) + { +- if (!strcmp(cg->language, apple_name_locale[i].name)) ++ if (!strcmp(cg->language, apple_language_locale[i].language)) + { + DEBUG_printf(("appleLangDefault: mapping \"%s\" to \"%s\"...\n", +- cg->language, apple_name_locale[i].locale)); +- strlcpy(cg->language, apple_name_locale[i].locale, ++ cg->language, apple_language_locale[i].locale)); ++ strlcpy(cg->language, apple_language_locale[i].locale, + sizeof(cg->language)); + break; + } +@@ -1110,166 +1195,6 @@ appleLangDefault(void) + + return (cg->language); + } +-# else +-/* +- * Code & data to translate OSX 10.2's language names to their ISO 639-1 +- * locale. +- */ +- +-typedef struct +-{ +- const char * const name; /* Language name */ +- const char * const locale; /* Locale name */ +-} _apple_name_locale_t; +- +-static const _apple_name_locale_t apple_name_locale[] = +-{ +- { "English" , "en_US.UTF-8" }, { "French" , "fr.UTF-8" }, +- { "German" , "de.UTF-8" }, { "Italian" , "it.UTF-8" }, +- { "Dutch" , "nl.UTF-8" }, { "Swedish" , "sv.UTF-8" }, +- { "Spanish" , "es.UTF-8" }, { "Danish" , "da.UTF-8" }, +- { "Portuguese" , "pt.UTF-8" }, { "Norwegian" , "no.UTF-8" }, +- { "Hebrew" , "he.UTF-8" }, { "Japanese" , "ja.UTF-8" }, +- { "Arabic" , "ar.UTF-8" }, { "Finnish" , "fi.UTF-8" }, +- { "Greek" , "el.UTF-8" }, { "Icelandic" , "is.UTF-8" }, +- { "Maltese" , "mt.UTF-8" }, { "Turkish" , "tr.UTF-8" }, +- { "Croatian" , "hr.UTF-8" }, { "Chinese" , "zh.UTF-8" }, +- { "Urdu" , "ur.UTF-8" }, { "Hindi" , "hi.UTF-8" }, +- { "Thai" , "th.UTF-8" }, { "Korean" , "ko.UTF-8" }, +- { "Lithuanian" , "lt.UTF-8" }, { "Polish" , "pl.UTF-8" }, +- { "Hungarian" , "hu.UTF-8" }, { "Estonian" , "et.UTF-8" }, +- { "Latvian" , "lv.UTF-8" }, { "Sami" , "se.UTF-8" }, +- { "Faroese" , "fo.UTF-8" }, { "Farsi" , "fa.UTF-8" }, +- { "Russian" , "ru.UTF-8" }, { "Chinese" , "zh.UTF-8" }, +- { "Dutch" , "nl.UTF-8" }, { "Irish" , "ga.UTF-8" }, +- { "Albanian" , "sq.UTF-8" }, { "Romanian" , "ro.UTF-8" }, +- { "Czech" , "cs.UTF-8" }, { "Slovak" , "sk.UTF-8" }, +- { "Slovenian" , "sl.UTF-8" }, { "Yiddish" , "yi.UTF-8" }, +- { "Serbian" , "sr.UTF-8" }, { "Macedonian" , "mk.UTF-8" }, +- { "Bulgarian" , "bg.UTF-8" }, { "Ukrainian" , "uk.UTF-8" }, +- { "Byelorussian", "be.UTF-8" }, { "Uzbek" , "uz.UTF-8" }, +- { "Kazakh" , "kk.UTF-8" }, { "Azerbaijani", "az.UTF-8" }, +- { "Azerbaijani" , "az.UTF-8" }, { "Armenian" , "hy.UTF-8" }, +- { "Georgian" , "ka.UTF-8" }, { "Moldavian" , "mo.UTF-8" }, +- { "Kirghiz" , "ky.UTF-8" }, { "Tajiki" , "tg.UTF-8" }, +- { "Turkmen" , "tk.UTF-8" }, { "Mongolian" , "mn.UTF-8" }, +- { "Mongolian" , "mn.UTF-8" }, { "Pashto" , "ps.UTF-8" }, +- { "Kurdish" , "ku.UTF-8" }, { "Kashmiri" , "ks.UTF-8" }, +- { "Sindhi" , "sd.UTF-8" }, { "Tibetan" , "bo.UTF-8" }, +- { "Nepali" , "ne.UTF-8" }, { "Sanskrit" , "sa.UTF-8" }, +- { "Marathi" , "mr.UTF-8" }, { "Bengali" , "bn.UTF-8" }, +- { "Assamese" , "as.UTF-8" }, { "Gujarati" , "gu.UTF-8" }, +- { "Punjabi" , "pa.UTF-8" }, { "Oriya" , "or.UTF-8" }, +- { "Malayalam" , "ml.UTF-8" }, { "Kannada" , "kn.UTF-8" }, +- { "Tamil" , "ta.UTF-8" }, { "Telugu" , "te.UTF-8" }, +- { "Sinhalese" , "si.UTF-8" }, { "Burmese" , "my.UTF-8" }, +- { "Khmer" , "km.UTF-8" }, { "Lao" , "lo.UTF-8" }, +- { "Vietnamese" , "vi.UTF-8" }, { "Indonesian" , "id.UTF-8" }, +- { "Tagalog" , "tl.UTF-8" }, { "Malay" , "ms.UTF-8" }, +- { "Malay" , "ms.UTF-8" }, { "Amharic" , "am.UTF-8" }, +- { "Tigrinya" , "ti.UTF-8" }, { "Oromo" , "om.UTF-8" }, +- { "Somali" , "so.UTF-8" }, { "Swahili" , "sw.UTF-8" }, +- { "Kinyarwanda" , "rw.UTF-8" }, { "Rundi" , "rn.UTF-8" }, +- { "Nyanja" , "" }, { "Malagasy" , "mg.UTF-8" }, +- { "Esperanto" , "eo.UTF-8" }, { "Welsh" , "cy.UTF-8" }, +- { "Basque" , "eu.UTF-8" }, { "Catalan" , "ca.UTF-8" }, +- { "Latin" , "la.UTF-8" }, { "Quechua" , "qu.UTF-8" }, +- { "Guarani" , "gn.UTF-8" }, { "Aymara" , "ay.UTF-8" }, +- { "Tatar" , "tt.UTF-8" }, { "Uighur" , "ug.UTF-8" }, +- { "Dzongkha" , "dz.UTF-8" }, { "Javanese" , "jv.UTF-8" }, +- { "Sundanese" , "su.UTF-8" }, { "Galician" , "gl.UTF-8" }, +- { "Afrikaans" , "af.UTF-8" }, { "Breton" , "br.UTF-8" }, +- { "Inuktitut" , "iu.UTF-8" }, { "Scottish" , "gd.UTF-8" }, +- { "Manx" , "gv.UTF-8" }, { "Irish" , "ga.UTF-8" }, +- { "Tongan" , "to.UTF-8" }, { "Greek" , "el.UTF-8" }, +- { "Greenlandic" , "kl.UTF-8" }, { "Azerbaijani", "az.UTF-8" } +-}; +- +- +-/* +- * 'appleLangDefault()' - Get the default locale string. +- */ +- +-static const char * /* O - Locale string */ +-appleLangDefault(void) +-{ +- int i; /* Looping var */ +- CFPropertyListRef localizationList; +- /* List of localization data */ +- CFStringRef localizationName; +- /* Current name */ +- char buff[256]; /* Temporary buffer */ +- _cups_globals_t *cg = _cupsGlobals(); +- /* Pointer to library globals */ +- char *lang; /* LANG environment variable */ +- +- +- /* +- * Only do the lookup and translation the first time. +- */ +- +- if (!cg->language[0]) +- { +- if ((lang = getenv("LANG"))) +- strlcpy(cg->language, lang, sizeof(cg->language)); +- else +- { +- localizationList = +- CFPreferencesCopyAppValue(CFSTR("AppleLanguages"), +- kCFPreferencesCurrentApplication); +- +- if (localizationList != NULL) +- { +- if (CFGetTypeID(localizationList) == CFArrayGetTypeID() && +- CFArrayGetCount(localizationList) > 0) +- { +- localizationName = CFArrayGetValueAtIndex(localizationList, 0); +- +- if (localizationName != NULL && +- CFGetTypeID(localizationName) == CFStringGetTypeID()) +- { +- CFIndex length = CFStringGetLength(localizationName); +- +- if (length <= sizeof(buff) && +- CFStringGetCString(localizationName, buff, sizeof(buff), +- kCFStringEncodingASCII)) +- { +- buff[sizeof(buff) - 1] = '\0'; +- +- for (i = 0; +- i < sizeof(apple_name_locale) / sizeof(apple_name_locale[0]); +- i++) +- { +- if (!strcasecmp(buff, apple_name_locale[i].name)) +- { +- strlcpy(cg->language, apple_name_locale[i].locale, +- sizeof(cg->language)); +- break; +- } +- } +- } +- } +- } +- +- CFRelease(localizationList); +- } +- } +- +- /* +- * If we didn't find the language, default to en_US... +- */ +- +- if (!cg->language[0]) +- strlcpy(cg->language, apple_name_locale[0].locale, sizeof(cg->language)); +- } +- +- /* +- * Return the cached locale... +- */ +- +- return (cg->language); +-} +-# endif /* HAVE_CF_LOCALE_ID */ + #endif /* __APPLE__ */ + + +diff -up cups-1.3.5/cups/emit.c.1.3.x cups-1.3.5/cups/emit.c +--- cups-1.3.5/cups/emit.c.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/cups/emit.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * PPD code emission routines for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2007 by Easy Software Products, all rights reserved. + * + * These coded instructions, statements, and computer programs are the +@@ -106,15 +106,24 @@ ppdCollect2(ppd_file_t *ppd, /* I - + DEBUG_printf(("ppdCollect2(ppd=%p, section=%d, min_order=%f, choices=%p)\n", + ppd, section, min_order, choices)); + +- if (ppd == NULL) ++ if (!ppd || !choices) ++ { ++ if (choices) ++ *choices = NULL; ++ + return (0); ++ } + + /* + * Allocate memory for up to 1000 selected choices... + */ + +- count = 0; +- collect = calloc(sizeof(ppd_choice_t *), 1000); ++ count = 0; ++ if ((collect = calloc(sizeof(ppd_choice_t *), 1000)) == NULL) ++ { ++ *choices = NULL; ++ return (0); ++ } + + /* + * Loop through all options and add choices as needed... +diff -up cups-1.3.5/cups/ipp-private.h.1.3.x cups-1.3.5/cups/ipp-private.h +--- cups-1.3.5/cups/ipp-private.h.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/cups/ipp-private.h 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * Private IPP definitions for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2006 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -40,6 +40,7 @@ extern "C" { + + typedef struct /**** Attribute mapping data ****/ + { ++ int multivalue; /* Option has multiple values? */ + const char *name; /* Option/attribute name */ + ipp_tag_t value_tag; /* Value tag for this attribute */ + ipp_tag_t group_tag; /* Group tag for this attribute */ +diff -up cups-1.3.5/cups/http-addrlist.c.1.3.x cups-1.3.5/cups/http-addrlist.c +--- cups-1.3.5/cups/http-addrlist.c.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/cups/http-addrlist.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * HTTP address list routines for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2007 by Easy Software Products, all rights reserved. + * + * These coded instructions, statements, and computer programs are the +@@ -202,9 +202,11 @@ httpAddrGetList(const char *hostname, /* + * Domain socket address... + */ + +- first = (http_addrlist_t *)calloc(1, sizeof(http_addrlist_t)); +- first->addr.un.sun_family = AF_LOCAL; +- strlcpy(first->addr.un.sun_path, hostname, sizeof(first->addr.un.sun_path)); ++ if ((first = (http_addrlist_t *)calloc(1, sizeof(http_addrlist_t))) != NULL) ++ { ++ first->addr.un.sun_family = AF_LOCAL; ++ strlcpy(first->addr.un.sun_path, hostname, sizeof(first->addr.un.sun_path)); ++ } + } + else + #endif /* AF_LOCAL */ +diff -up cups-1.3.5/cups/http-private.h.1.3.x cups-1.3.5/cups/http-private.h +--- cups-1.3.5/cups/http-private.h.1.3.x 2007-09-10 17:46:20.000000000 +0100 ++++ cups-1.3.5/cups/http-private.h 2008-02-05 15:08:55.000000000 +0000 +@@ -26,12 +26,6 @@ + # include + + # ifdef __sun +-/* +- * Define FD_SETSIZE to CUPS_MAX_FDS on Solaris to get the correct version of +- * select() for large numbers of file descriptors. +- */ +- +-# define FD_SETSIZE CUPS_MAX_FDS + # include + # endif /* __sun */ + +diff -up cups-1.3.5/cups/ppd.c.1.3.x cups-1.3.5/cups/ppd.c +--- cups-1.3.5/cups/ppd.c.1.3.x 2007-11-30 19:29:50.000000000 +0000 ++++ cups-1.3.5/cups/ppd.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * PPD file routines for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2007 by Easy Software Products, all rights reserved. + * + * These coded instructions, statements, and computer programs are the +@@ -814,6 +814,13 @@ ppdOpen2(cups_file_t *fp) /* I - File t + profile = realloc(ppd->profiles, sizeof(ppd_profile_t) * + (ppd->num_profiles + 1)); + ++ if (!profile) ++ { ++ cg->ppd_status = PPD_ALLOC_ERROR; ++ ++ goto error; ++ } ++ + ppd->profiles = profile; + profile += ppd->num_profiles; + ppd->num_profiles ++; +@@ -1102,7 +1109,12 @@ ppdOpen2(cups_file_t *fp) /* I - File t + } + + ppd->num_emulations = count; +- ppd->emulations = calloc(count, sizeof(ppd_emul_t)); ++ if ((ppd->emulations = calloc(count, sizeof(ppd_emul_t))) == NULL) ++ { ++ cg->ppd_status = PPD_ALLOC_ERROR; ++ ++ goto error; ++ } + + for (i = 0, sptr = string; i < count; i ++) + { +@@ -1866,7 +1878,12 @@ ppdOpen2(cups_file_t *fp) /* I - File t + * Add the option choice... + */ + +- choice = ppd_add_choice(option, name); ++ if ((choice = ppd_add_choice(option, name)) == NULL) ++ { ++ cg->ppd_status = PPD_ALLOC_ERROR; ++ ++ goto error; ++ } + + if (text[0]) + cupsCharsetToUTF8((cups_utf8_t *)choice->text, text, +diff -up cups-1.3.5/cups/cups.h.1.3.x cups-1.3.5/cups/cups.h +--- cups-1.3.5/cups/cups.h.1.3.x 2007-11-01 23:29:14.000000000 +0000 ++++ cups-1.3.5/cups/cups.h 2008-02-05 15:08:55.000000000 +0000 +@@ -59,10 +59,10 @@ extern "C" { + * Constants... + */ + +-# define CUPS_VERSION 1.0305 ++# define CUPS_VERSION 1.0306 + # define CUPS_VERSION_MAJOR 1 + # define CUPS_VERSION_MINOR 3 +-# define CUPS_VERSION_PATCH 5 ++# define CUPS_VERSION_PATCH 6 + # define CUPS_DATE_ANY -1 + + +diff -up cups-1.3.5/cups/ipp.c.1.3.x cups-1.3.5/cups/ipp.c +--- cups-1.3.5/cups/ipp.c.1.3.x 2007-10-31 18:35:56.000000000 +0000 ++++ cups-1.3.5/cups/ipp.c 2008-02-05 15:08:55.000000000 +0000 +@@ -4,7 +4,7 @@ + * Internet Printing Protocol support functions for the Common UNIX + * Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2007 by Easy Software Products, all rights reserved. + * + * These coded instructions, statements, and computer programs are the +@@ -361,7 +361,12 @@ ippAddOctetString(ipp_t *ipp, /* I + + if (data) + { +- attr->values[0].unknown.data = malloc(datalen); ++ if ((attr->values[0].unknown.data = malloc(datalen)) == NULL) ++ { ++ ippDeleteAttribute(ipp, attr); ++ return (NULL); ++ } ++ + memcpy(attr->values[0].unknown.data, data, datalen); + } + +@@ -1182,17 +1187,15 @@ ippReadIO(void *src, /* I - Data + + attr->value_tag = tag; + } +- else if (value_tag == IPP_TAG_STRING || +- (value_tag >= IPP_TAG_TEXTLANG && +- value_tag <= IPP_TAG_MIMETYPE)) ++ else if (value_tag >= IPP_TAG_TEXTLANG && ++ value_tag <= IPP_TAG_MIMETYPE) + { + /* + * String values can sometimes come across in different + * forms; accept sets of differing values... + */ + +- if (tag != IPP_TAG_STRING && +- (tag < IPP_TAG_TEXTLANG || tag > IPP_TAG_MIMETYPE)) ++ if (tag < IPP_TAG_TEXTLANG || tag > IPP_TAG_MIMETYPE) + return (IPP_ERROR); + } + else if (value_tag != tag) +@@ -1277,7 +1280,11 @@ ippReadIO(void *src, /* I - Data + if (ipp->current) + ipp->prev = ipp->current; + +- attr = ipp->current = _ippAddAttr(ipp, 1); ++ if ((attr = ipp->current = _ippAddAttr(ipp, 1)) == NULL) ++ { ++ DEBUG_puts("ippReadIO: unable to allocate attribute!"); ++ return (IPP_ERROR); ++ } + + DEBUG_printf(("ippReadIO: name=\'%s\', ipp->current=%p, ipp->prev=%p\n", + buffer, ipp->current, ipp->prev)); +@@ -1325,6 +1332,7 @@ ippReadIO(void *src, /* I - Data + + value->integer = n; + break; ++ + case IPP_TAG_BOOLEAN : + if (n != 1) + { +@@ -1340,10 +1348,10 @@ ippReadIO(void *src, /* I - Data + + value->boolean = buffer[0]; + break; ++ + case IPP_TAG_TEXT : + case IPP_TAG_NAME : + case IPP_TAG_KEYWORD : +- case IPP_TAG_STRING : + case IPP_TAG_URI : + case IPP_TAG_URISCHEME : + case IPP_TAG_CHARSET : +@@ -1366,6 +1374,7 @@ ippReadIO(void *src, /* I - Data + DEBUG_printf(("ippReadIO: value = \'%s\'\n", + value->string.text)); + break; ++ + case IPP_TAG_DATE : + if (n != 11) + { +@@ -1379,6 +1388,7 @@ ippReadIO(void *src, /* I - Data + return (IPP_ERROR); + } + break; ++ + case IPP_TAG_RESOLUTION : + if (n != 9) + { +@@ -1401,6 +1411,7 @@ ippReadIO(void *src, /* I - Data + value->resolution.units = + (ipp_res_t)buffer[8]; + break; ++ + case IPP_TAG_RANGE : + if (n != 8) + { +@@ -1421,6 +1432,7 @@ ippReadIO(void *src, /* I - Data + (((((buffer[4] << 8) | buffer[5]) << 8) | buffer[6]) << 8) | + buffer[7]; + break; ++ + case IPP_TAG_TEXTLANG : + case IPP_TAG_NAMELANG : + if (n >= sizeof(buffer) || n < 4) +@@ -1538,7 +1550,7 @@ ippReadIO(void *src, /* I - Data + break; + + default : /* Other unsupported values */ +- if (n > sizeof(buffer)) ++ if (n > IPP_MAX_LENGTH) + { + DEBUG_printf(("ippReadIO: bad value length %d!\n", n)); + return (IPP_ERROR); +@@ -1547,7 +1559,12 @@ ippReadIO(void *src, /* I - Data + value->unknown.length = n; + if (n > 0) + { +- value->unknown.data = malloc(n); ++ if ((value->unknown.data = malloc(n)) == NULL) ++ { ++ DEBUG_puts("ippReadIO: Unable to allocate value"); ++ return (IPP_ERROR); ++ } ++ + if ((*cb)(src, value->unknown.data, n) < n) + { + DEBUG_puts("ippReadIO: Unable to read unsupported value!"); +@@ -1941,7 +1958,6 @@ ippWriteIO(void *dst, /* I - Dest + case IPP_TAG_TEXT : + case IPP_TAG_NAME : + case IPP_TAG_KEYWORD : +- case IPP_TAG_STRING : + case IPP_TAG_URI : + case IPP_TAG_URISCHEME : + case IPP_TAG_CHARSET : +@@ -2507,7 +2523,6 @@ _ippFreeAttr(ipp_attribute_t *attr) /* I + case IPP_TAG_TEXT : + case IPP_TAG_NAME : + case IPP_TAG_KEYWORD : +- case IPP_TAG_STRING : + case IPP_TAG_URI : + case IPP_TAG_URISCHEME : + case IPP_TAG_CHARSET : +@@ -2546,6 +2561,13 @@ _ippFreeAttr(ipp_attribute_t *attr) /* I + ippDelete(value->collection); + break; + ++ case IPP_TAG_STRING : ++ for (i = 0, value = attr->values; ++ i < attr->num_values; ++ i ++, value ++) ++ free(value->unknown.data); ++ break; ++ + default : + if (!((int)attr->value_tag & IPP_TAG_COPY)) + { +@@ -2634,7 +2656,6 @@ ipp_length(ipp_t *ipp, /* I - IPP mess + case IPP_TAG_TEXT : + case IPP_TAG_NAME : + case IPP_TAG_KEYWORD : +- case IPP_TAG_STRING : + case IPP_TAG_URI : + case IPP_TAG_URISCHEME : + case IPP_TAG_CHARSET : +diff -up cups-1.3.5/cups/encode.c.1.3.x cups-1.3.5/cups/encode.c +--- cups-1.3.5/cups/encode.c.1.3.x 2007-11-02 19:15:27.000000000 +0000 ++++ cups-1.3.5/cups/encode.c 2008-02-05 15:08:55.000000000 +0000 +@@ -43,98 +43,98 @@ + + static const _ipp_option_t ipp_options[] = + { +- { "auth-info", IPP_TAG_TEXT, IPP_TAG_JOB }, +- { "auth-info-required", IPP_TAG_KEYWORD, IPP_TAG_PRINTER }, +- { "blackplot", IPP_TAG_BOOLEAN, IPP_TAG_JOB }, +- { "blackplot-default", IPP_TAG_BOOLEAN, IPP_TAG_PRINTER }, +- { "brightness", IPP_TAG_INTEGER, IPP_TAG_JOB }, +- { "brightness-default", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, +- { "columns", IPP_TAG_INTEGER, IPP_TAG_JOB }, +- { "columns-default", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, +- { "copies", IPP_TAG_INTEGER, IPP_TAG_JOB }, +- { "copies-default", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, +- { "document-format", IPP_TAG_MIMETYPE, IPP_TAG_OPERATION }, +- { "document-format-default", IPP_TAG_MIMETYPE, IPP_TAG_PRINTER }, +- { "finishings", IPP_TAG_ENUM, IPP_TAG_JOB }, +- { "finishings-default", IPP_TAG_ENUM, IPP_TAG_PRINTER }, +- { "fitplot", IPP_TAG_BOOLEAN, IPP_TAG_JOB }, +- { "fitplot-default", IPP_TAG_BOOLEAN, IPP_TAG_PRINTER }, +- { "gamma", IPP_TAG_INTEGER, IPP_TAG_JOB }, +- { "gamma-default", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, +- { "hue", IPP_TAG_INTEGER, IPP_TAG_JOB }, +- { "hue-default", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, +- { "job-k-limit", IPP_TAG_INTEGER, IPP_TAG_JOB }, +- { "job-page-limit", IPP_TAG_INTEGER, IPP_TAG_JOB }, +- { "job-priority", IPP_TAG_INTEGER, IPP_TAG_JOB }, +- { "job-quota-period", IPP_TAG_INTEGER, IPP_TAG_JOB }, +- { "job-uuid", IPP_TAG_URI, IPP_TAG_JOB }, +- { "landscape", IPP_TAG_BOOLEAN, IPP_TAG_JOB }, +- { "media", IPP_TAG_KEYWORD, IPP_TAG_JOB }, +- { "mirror", IPP_TAG_BOOLEAN, IPP_TAG_JOB }, +- { "mirror-default", IPP_TAG_BOOLEAN, IPP_TAG_PRINTER }, +- { "natural-scaling", IPP_TAG_INTEGER, IPP_TAG_JOB }, +- { "natural-scaling-default", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, +- { "notify-charset", IPP_TAG_CHARSET, IPP_TAG_SUBSCRIPTION }, +- { "notify-events", IPP_TAG_KEYWORD, IPP_TAG_SUBSCRIPTION }, +- { "notify-events-default", IPP_TAG_KEYWORD, IPP_TAG_PRINTER }, +- { "notify-lease-duration", IPP_TAG_INTEGER, IPP_TAG_SUBSCRIPTION }, +- { "notify-lease-duration-default", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, +- { "notify-natural-language", IPP_TAG_LANGUAGE, IPP_TAG_SUBSCRIPTION }, +- { "notify-pull-method", IPP_TAG_KEYWORD, IPP_TAG_SUBSCRIPTION }, +- { "notify-recipient-uri", IPP_TAG_URI, IPP_TAG_SUBSCRIPTION }, +- { "notify-time-interval", IPP_TAG_INTEGER, IPP_TAG_SUBSCRIPTION }, +- { "notify-user-data", IPP_TAG_STRING, IPP_TAG_SUBSCRIPTION }, +- { "number-up", IPP_TAG_INTEGER, IPP_TAG_JOB }, +- { "number-up-default", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, +- { "orientation-requested", IPP_TAG_ENUM, IPP_TAG_JOB }, +- { "orientation-requested-default", IPP_TAG_ENUM, IPP_TAG_PRINTER }, +- { "page-bottom", IPP_TAG_INTEGER, IPP_TAG_JOB }, +- { "page-bottom-default", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, +- { "page-left", IPP_TAG_INTEGER, IPP_TAG_JOB }, +- { "page-left-default", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, +- { "page-ranges", IPP_TAG_RANGE, IPP_TAG_JOB }, +- { "page-ranges-default", IPP_TAG_RANGE, IPP_TAG_PRINTER }, +- { "page-right", IPP_TAG_INTEGER, IPP_TAG_JOB }, +- { "page-right-default", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, +- { "page-top", IPP_TAG_INTEGER, IPP_TAG_JOB }, +- { "page-top-default", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, +- { "penwidth", IPP_TAG_INTEGER, IPP_TAG_JOB }, +- { "penwidth-default", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, +- { "port-monitor", IPP_TAG_NAME, IPP_TAG_PRINTER }, +- { "ppi", IPP_TAG_INTEGER, IPP_TAG_JOB }, +- { "ppi-default", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, +- { "prettyprint", IPP_TAG_BOOLEAN, IPP_TAG_JOB }, +- { "prettyprint-default", IPP_TAG_BOOLEAN, IPP_TAG_PRINTER }, +- { "print-quality", IPP_TAG_ENUM, IPP_TAG_JOB }, +- { "print-quality-default", IPP_TAG_ENUM, IPP_TAG_PRINTER }, +- { "printer-error-policy", IPP_TAG_NAME, IPP_TAG_PRINTER }, +- { "printer-info", IPP_TAG_TEXT, IPP_TAG_PRINTER }, +- { "printer-is-accepting-jobs",IPP_TAG_BOOLEAN, IPP_TAG_PRINTER }, +- { "printer-is-shared", IPP_TAG_BOOLEAN, IPP_TAG_PRINTER }, +- { "printer-location", IPP_TAG_TEXT, IPP_TAG_PRINTER }, +- { "printer-make-and-model", IPP_TAG_TEXT, IPP_TAG_PRINTER }, +- { "printer-more-info", IPP_TAG_URI, IPP_TAG_PRINTER }, +- { "printer-op-policy", IPP_TAG_NAME, IPP_TAG_PRINTER }, +- { "printer-resolution", IPP_TAG_RESOLUTION, IPP_TAG_JOB }, +- { "printer-state", IPP_TAG_ENUM, IPP_TAG_PRINTER }, +- { "printer-state-change-time",IPP_TAG_INTEGER, IPP_TAG_PRINTER }, +- { "printer-state-reasons", IPP_TAG_KEYWORD, IPP_TAG_PRINTER }, +- { "printer-type", IPP_TAG_ENUM, IPP_TAG_PRINTER }, +- { "printer-uri", IPP_TAG_URI, IPP_TAG_OPERATION }, +- { "queued-job-count", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, +- { "raw", IPP_TAG_MIMETYPE, IPP_TAG_OPERATION }, +- { "requesting-user-name-allowed", IPP_TAG_NAME, IPP_TAG_PRINTER }, +- { "requesting-user-name-denied", IPP_TAG_NAME, IPP_TAG_PRINTER }, +- { "resolution", IPP_TAG_RESOLUTION, IPP_TAG_JOB }, +- { "resolution-default", IPP_TAG_RESOLUTION, IPP_TAG_PRINTER }, +- { "saturation", IPP_TAG_INTEGER, IPP_TAG_JOB }, +- { "saturation-default", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, +- { "scaling", IPP_TAG_INTEGER, IPP_TAG_JOB }, +- { "scaling-default", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, +- { "sides", IPP_TAG_KEYWORD, IPP_TAG_JOB }, +- { "sides-default", IPP_TAG_KEYWORD, IPP_TAG_PRINTER }, +- { "wrap", IPP_TAG_BOOLEAN, IPP_TAG_JOB }, +- { "wrap-default", IPP_TAG_BOOLEAN, IPP_TAG_PRINTER } ++ { 1, "auth-info", IPP_TAG_TEXT, IPP_TAG_JOB }, ++ { 1, "auth-info-required", IPP_TAG_KEYWORD, IPP_TAG_PRINTER }, ++ { 0, "blackplot", IPP_TAG_BOOLEAN, IPP_TAG_JOB }, ++ { 0, "blackplot-default", IPP_TAG_BOOLEAN, IPP_TAG_PRINTER }, ++ { 0, "brightness", IPP_TAG_INTEGER, IPP_TAG_JOB }, ++ { 0, "brightness-default", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, ++ { 0, "columns", IPP_TAG_INTEGER, IPP_TAG_JOB }, ++ { 0, "columns-default", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, ++ { 0, "copies", IPP_TAG_INTEGER, IPP_TAG_JOB }, ++ { 0, "copies-default", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, ++ { 0, "document-format", IPP_TAG_MIMETYPE, IPP_TAG_OPERATION }, ++ { 0, "document-format-default", IPP_TAG_MIMETYPE, IPP_TAG_PRINTER }, ++ { 1, "finishings", IPP_TAG_ENUM, IPP_TAG_JOB }, ++ { 1, "finishings-default", IPP_TAG_ENUM, IPP_TAG_PRINTER }, ++ { 0, "fitplot", IPP_TAG_BOOLEAN, IPP_TAG_JOB }, ++ { 0, "fitplot-default", IPP_TAG_BOOLEAN, IPP_TAG_PRINTER }, ++ { 0, "gamma", IPP_TAG_INTEGER, IPP_TAG_JOB }, ++ { 0, "gamma-default", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, ++ { 0, "hue", IPP_TAG_INTEGER, IPP_TAG_JOB }, ++ { 0, "hue-default", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, ++ { 0, "job-k-limit", IPP_TAG_INTEGER, IPP_TAG_JOB }, ++ { 0, "job-page-limit", IPP_TAG_INTEGER, IPP_TAG_JOB }, ++ { 0, "job-priority", IPP_TAG_INTEGER, IPP_TAG_JOB }, ++ { 0, "job-quota-period", IPP_TAG_INTEGER, IPP_TAG_JOB }, ++ { 0, "job-uuid", IPP_TAG_URI, IPP_TAG_JOB }, ++ { 0, "landscape", IPP_TAG_BOOLEAN, IPP_TAG_JOB }, ++ { 1, "media", IPP_TAG_KEYWORD, IPP_TAG_JOB }, ++ { 0, "mirror", IPP_TAG_BOOLEAN, IPP_TAG_JOB }, ++ { 0, "mirror-default", IPP_TAG_BOOLEAN, IPP_TAG_PRINTER }, ++ { 0, "natural-scaling", IPP_TAG_INTEGER, IPP_TAG_JOB }, ++ { 0, "natural-scaling-default", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, ++ { 0, "notify-charset", IPP_TAG_CHARSET, IPP_TAG_SUBSCRIPTION }, ++ { 1, "notify-events", IPP_TAG_KEYWORD, IPP_TAG_SUBSCRIPTION }, ++ { 1, "notify-events-default", IPP_TAG_KEYWORD, IPP_TAG_PRINTER }, ++ { 0, "notify-lease-duration", IPP_TAG_INTEGER, IPP_TAG_SUBSCRIPTION }, ++ { 0, "notify-lease-duration-default", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, ++ { 0, "notify-natural-language", IPP_TAG_LANGUAGE, IPP_TAG_SUBSCRIPTION }, ++ { 0, "notify-pull-method", IPP_TAG_KEYWORD, IPP_TAG_SUBSCRIPTION }, ++ { 0, "notify-recipient-uri", IPP_TAG_URI, IPP_TAG_SUBSCRIPTION }, ++ { 0, "notify-time-interval", IPP_TAG_INTEGER, IPP_TAG_SUBSCRIPTION }, ++ { 0, "notify-user-data", IPP_TAG_STRING, IPP_TAG_SUBSCRIPTION }, ++ { 0, "number-up", IPP_TAG_INTEGER, IPP_TAG_JOB }, ++ { 0, "number-up-default", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, ++ { 0, "orientation-requested", IPP_TAG_ENUM, IPP_TAG_JOB }, ++ { 0, "orientation-requested-default", IPP_TAG_ENUM, IPP_TAG_PRINTER }, ++ { 0, "page-bottom", IPP_TAG_INTEGER, IPP_TAG_JOB }, ++ { 0, "page-bottom-default", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, ++ { 0, "page-left", IPP_TAG_INTEGER, IPP_TAG_JOB }, ++ { 0, "page-left-default", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, ++ { 1, "page-ranges", IPP_TAG_RANGE, IPP_TAG_JOB }, ++ { 1, "page-ranges-default", IPP_TAG_RANGE, IPP_TAG_PRINTER }, ++ { 0, "page-right", IPP_TAG_INTEGER, IPP_TAG_JOB }, ++ { 0, "page-right-default", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, ++ { 0, "page-top", IPP_TAG_INTEGER, IPP_TAG_JOB }, ++ { 0, "page-top-default", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, ++ { 0, "penwidth", IPP_TAG_INTEGER, IPP_TAG_JOB }, ++ { 0, "penwidth-default", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, ++ { 0, "port-monitor", IPP_TAG_NAME, IPP_TAG_PRINTER }, ++ { 0, "ppi", IPP_TAG_INTEGER, IPP_TAG_JOB }, ++ { 0, "ppi-default", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, ++ { 0, "prettyprint", IPP_TAG_BOOLEAN, IPP_TAG_JOB }, ++ { 0, "prettyprint-default", IPP_TAG_BOOLEAN, IPP_TAG_PRINTER }, ++ { 0, "print-quality", IPP_TAG_ENUM, IPP_TAG_JOB }, ++ { 0, "print-quality-default", IPP_TAG_ENUM, IPP_TAG_PRINTER }, ++ { 0, "printer-error-policy", IPP_TAG_NAME, IPP_TAG_PRINTER }, ++ { 0, "printer-info", IPP_TAG_TEXT, IPP_TAG_PRINTER }, ++ { 0, "printer-is-accepting-jobs", IPP_TAG_BOOLEAN, IPP_TAG_PRINTER }, ++ { 0, "printer-is-shared", IPP_TAG_BOOLEAN, IPP_TAG_PRINTER }, ++ { 0, "printer-location", IPP_TAG_TEXT, IPP_TAG_PRINTER }, ++ { 0, "printer-make-and-model", IPP_TAG_TEXT, IPP_TAG_PRINTER }, ++ { 0, "printer-more-info", IPP_TAG_URI, IPP_TAG_PRINTER }, ++ { 0, "printer-op-policy", IPP_TAG_NAME, IPP_TAG_PRINTER }, ++ { 0, "printer-resolution", IPP_TAG_RESOLUTION, IPP_TAG_JOB }, ++ { 0, "printer-state", IPP_TAG_ENUM, IPP_TAG_PRINTER }, ++ { 0, "printer-state-change-time", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, ++ { 1, "printer-state-reasons", IPP_TAG_KEYWORD, IPP_TAG_PRINTER }, ++ { 0, "printer-type", IPP_TAG_ENUM, IPP_TAG_PRINTER }, ++ { 0, "printer-uri", IPP_TAG_URI, IPP_TAG_OPERATION }, ++ { 0, "queued-job-count", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, ++ { 0, "raw", IPP_TAG_MIMETYPE, IPP_TAG_OPERATION }, ++ { 1, "requesting-user-name-allowed", IPP_TAG_NAME, IPP_TAG_PRINTER }, ++ { 1, "requesting-user-name-denied", IPP_TAG_NAME, IPP_TAG_PRINTER }, ++ { 0, "resolution", IPP_TAG_RESOLUTION, IPP_TAG_JOB }, ++ { 0, "resolution-default", IPP_TAG_RESOLUTION, IPP_TAG_PRINTER }, ++ { 0, "saturation", IPP_TAG_INTEGER, IPP_TAG_JOB }, ++ { 0, "saturation-default", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, ++ { 0, "scaling", IPP_TAG_INTEGER, IPP_TAG_JOB }, ++ { 0, "scaling-default", IPP_TAG_INTEGER, IPP_TAG_PRINTER }, ++ { 0, "sides", IPP_TAG_KEYWORD, IPP_TAG_JOB }, ++ { 0, "sides-default", IPP_TAG_KEYWORD, IPP_TAG_PRINTER }, ++ { 0, "wrap", IPP_TAG_BOOLEAN, IPP_TAG_JOB }, ++ { 0, "wrap-default", IPP_TAG_BOOLEAN, IPP_TAG_PRINTER } + }; + + +@@ -192,7 +192,8 @@ cupsEncodeOptions2( + char *s, /* Pointer into option value */ + *val, /* Pointer to option value */ + *copy, /* Copy of option value */ +- *sep; /* Option separator */ ++ *sep, /* Option separator */ ++ quote; /* Quote character */ + ipp_attribute_t *attr; /* IPP attribute */ + ipp_tag_t value_tag; /* IPP value tag */ + cups_option_t *option; /* Current option */ +@@ -284,41 +285,28 @@ cupsEncodeOptions2( + * Count the number of values... + */ + +- for (count = 1, sep = option->value; *sep; sep ++) ++ if (match && match->multivalue) + { +- if (*sep == '\'') ++ for (count = 1, sep = option->value, quote = 0; *sep; sep ++) + { +- /* +- * Skip quoted option value... +- */ +- +- sep ++; +- +- while (*sep && *sep != '\'') +- sep ++; +- +- if (!*sep) +- sep --; +- } +- else if (*sep == '\"') +- { +- /* +- * Skip quoted option value... +- */ +- +- sep ++; +- +- while (*sep && *sep != '\"') ++ if (*sep == quote) ++ quote = 0; ++ else if (!quote && (*sep == '\'' || *sep == '\"')) ++ { ++ /* ++ * Skip quoted option value... ++ */ ++ ++ quote = *sep++; ++ } ++ else if (*sep == ',' && !quote) ++ count ++; ++ else if (*sep == '\\' && sep[1]) + sep ++; +- +- if (!*sep) +- sep --; + } +- else if (*sep == ',') +- count ++; +- else if (*sep == '\\' && sep[1]) +- sep ++; + } ++ else ++ count = 1; + + DEBUG_printf(("cupsEncodeOptions2: option = \'%s\', count = %d\n", + option->name, count)); +@@ -390,16 +378,47 @@ cupsEncodeOptions2( + * Scan the value string for values... + */ + +- for (j = 0; j < count; val = sep, j ++) ++ for (j = 0, sep = val; j < count; val = sep, j ++) + { + /* + * Find the end of this value and mark it if needed... + */ + +- if ((sep = strchr(val, ',')) != NULL) +- *sep++ = '\0'; +- else +- sep = val + strlen(val); ++ if (count > 1) ++ { ++ for (quote = 0; *sep; sep ++) ++ { ++ if (*sep == quote) ++ { ++ /* ++ * Finish quoted value... ++ */ ++ ++ quote = 0; ++ } ++ else if (!quote && (*sep == '\'' || *sep == '\"')) ++ { ++ /* ++ * Handle quoted option value... ++ */ ++ ++ quote = *sep; ++ } ++ else if (*sep == ',' && count > 1) ++ break; ++ else if (*sep == '\\' && sep[1]) ++ { ++ /* ++ * Skip quoted character... ++ */ ++ ++ sep ++; ++ } ++ } ++ ++ if (*sep == ',') ++ *sep++ = '\0'; ++ } + + /* + * Copy the option value(s) over as needed by the type... +@@ -413,7 +432,7 @@ cupsEncodeOptions2( + * Integer/enumeration value... + */ + +- attr->values[j].integer = strtol(val, &s, 0); ++ attr->values[j].integer = strtol(val, &s, 10); + + DEBUG_printf(("cupsEncodeOptions2: Added integer option value %d...\n", + attr->values[j].integer)); +@@ -455,12 +474,12 @@ cupsEncodeOptions2( + s = val; + } + else +- attr->values[j].range.lower = strtol(val, &s, 0); ++ attr->values[j].range.lower = strtol(val, &s, 10); + + if (*s == '-') + { + if (s[1]) +- attr->values[j].range.upper = strtol(s + 1, NULL, 0); ++ attr->values[j].range.upper = strtol(s + 1, NULL, 10); + else + attr->values[j].range.upper = 2147483647; + } +@@ -477,10 +496,10 @@ cupsEncodeOptions2( + * Resolution... + */ + +- attr->values[j].resolution.xres = strtol(val, &s, 0); ++ attr->values[j].resolution.xres = strtol(val, &s, 10); + + if (*s == 'x') +- attr->values[j].resolution.yres = strtol(s + 1, &s, 0); ++ attr->values[j].resolution.yres = strtol(s + 1, &s, 10); + else + attr->values[j].resolution.yres = attr->values[j].resolution.xres; + +@@ -499,7 +518,7 @@ cupsEncodeOptions2( + */ + + attr->values[j].unknown.length = (int)strlen(val); +- attr->values[j].unknown.data = _cupsStrAlloc(val); ++ attr->values[j].unknown.data = strdup(val); + + DEBUG_printf(("cupsEncodeOptions2: Added octet-string value \"%s\"...\n", + attr->values[j].unknown.data)); +diff -up cups-1.3.5/notifier/Makefile.1.3.x cups-1.3.5/notifier/Makefile +--- cups-1.3.5/notifier/Makefile.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/notifier/Makefile 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + # + # Notifier makefile for the Common UNIX Printing System (CUPS). + # +-# Copyright 2007 by Apple Inc. ++# Copyright 2007-2008 by Apple Inc. + # Copyright 1997-2007 by Easy Software Products, all rights reserved. + # + # These coded instructions, statements, and computer programs are the +@@ -44,7 +44,7 @@ install: all + for file in $(TARGETS); do \ + $(INSTALL_BIN) $$file $(SERVERBIN)/notifier; \ + done +- $(INSTALL_DIR) -m 755 $(CACHEDIR)/rss ++ $(INSTALL_DIR) -m 775 $(CACHEDIR)/rss + -chgrp $(CUPS_GROUP) $(CACHEDIR)/rss + if test "x$(SYMROOT)" != "x"; then \ + $(INSTALL_DIR) $(SYMROOT); \ +diff -up cups-1.3.5/pdftops/pdftops.cxx.1.3.x cups-1.3.5/pdftops/pdftops.cxx +--- cups-1.3.5/pdftops/pdftops.cxx.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/pdftops/pdftops.cxx 2008-02-05 15:08:55.000000000 +0000 +@@ -308,8 +308,7 @@ main(int argc, // I - Number of comm + // write PostScript file + psOut = new PSOutputDev(psFileName->getCString(), doc->getXRef(), + doc->getCatalog(), 1, doc->getNumPages(), +- psModePS, 0, 0, 0, 0, gFalse, +- cupsGetOption("page-ranges", num_options, options)); ++ psModePS, 0, 0, 0, 0, gFalse, NULL); + if (psOut->isOk()) + doc->displayPages(psOut, 1, doc->getNumPages(), 72.0, 72.0, 0, + gTrue, gFalse, gFalse); +diff -up cups-1.3.5/scheduler/testspeed.c.1.3.x cups-1.3.5/scheduler/testspeed.c +--- cups-1.3.5/scheduler/testspeed.c.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/scheduler/testspeed.c 2008-02-05 15:08:55.000000000 +0000 +@@ -166,7 +166,7 @@ main(int argc, /* I - Number of comm + * Exit with no errors... + */ + +- return (status); ++ return (0); + } + + +diff -up cups-1.3.5/scheduler/banners.c.1.3.x cups-1.3.5/scheduler/banners.c +--- cups-1.3.5/scheduler/banners.c.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/scheduler/banners.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * Banner routines for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2006 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -147,8 +147,8 @@ add_banner(const char *name, /* I - Nam + if ((filetype = mimeFileType(MimeDatabase, filename, NULL, NULL)) == NULL) + { + cupsdLogMessage(CUPSD_LOG_WARN, +- "add_banner: Banner \"%s\" (\"%s\") is of an unknown file type - skipping!", +- name, filename); ++ "add_banner: Banner \"%s\" (\"%s\") is of an unknown file " ++ "type - skipping!", name, filename); + return; + } + +@@ -156,13 +156,27 @@ add_banner(const char *name, /* I - Nam + * Allocate memory... + */ + +- temp = calloc(1, sizeof(cupsd_banner_t)); ++ if ((temp = calloc(1, sizeof(cupsd_banner_t))) == NULL) ++ { ++ cupsdLogMessage(CUPSD_LOG_WARN, ++ "add_banner: Unable to allocate memory for banner \"%s\" - " ++ "skipping!", name); ++ return; ++ } + + /* + * Copy the new banner data over... + */ + +- temp->name = strdup(name); ++ if ((temp->name = strdup(name)) == NULL) ++ { ++ cupsdLogMessage(CUPSD_LOG_WARN, ++ "add_banner: Unable to allocate memory for banner \"%s\" - " ++ "skipping!", name); ++ free(temp); ++ return; ++ } ++ + temp->filetype = filetype; + + cupsArrayAdd(Banners, temp); +diff -up cups-1.3.5/scheduler/printers.h.1.3.x cups-1.3.5/scheduler/printers.h +--- cups-1.3.5/scheduler/printers.h.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/scheduler/printers.h 2008-02-05 15:08:55.000000000 +0000 +@@ -86,6 +86,7 @@ typedef struct cupsd_printer_s + const char *auth_info_required[4]; /* Required authentication fields */ + char *alert, /* PSX printer-alert value */ + *alert_description; /* PSX printer-alert-description value */ ++ time_t marker_time; /* Last time marker attributes were updated */ + + #ifdef __APPLE__ + char *recoverable; /* com.apple.print.recoverable-message */ +@@ -150,6 +151,8 @@ extern void cupsdSaveAllPrinters(void); + extern int cupsdSetAuthInfoRequired(cupsd_printer_t *p, + const char *values, + ipp_attribute_t *attr); ++extern void cupsdSetPrinterAttr(cupsd_printer_t *p, ++ const char *name, char *value); + extern void cupsdSetPrinterAttrs(cupsd_printer_t *p); + extern void cupsdSetPrinterReasons(cupsd_printer_t *p, + const char *s); +diff -up cups-1.3.5/scheduler/cupsfilter.c.1.3.x cups-1.3.5/scheduler/cupsfilter.c +--- cups-1.3.5/scheduler/cupsfilter.c.1.3.x 2007-08-20 21:16:00.000000000 +0100 ++++ cups-1.3.5/scheduler/cupsfilter.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * CUPS filtering program for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2006 by Easy Software Products, all rights reserved. + * + * These coded instructions, statements, and computer programs are the +@@ -131,6 +131,7 @@ main(int argc, /* I - Number of comm + + mime = NULL; + srctype = NULL; ++ compression = 0; + dsttype = "application/pdf"; + infile = NULL; + outfile = NULL; +@@ -456,7 +457,8 @@ escape_options( + for (i = num_options, option = options, bytes = 1; i > 0; i --, option ++) + bytes += 2 * (strlen(option->name) + strlen(option->value)) + 2; + +- s = malloc(bytes); ++ if ((s = malloc(bytes)) == NULL) ++ return (NULL); + + /* + * Copy the options to the string... +@@ -806,6 +808,8 @@ exec_filters(cups_array_t *filters, /* + } + } + ++ cupsArrayDelete(pids); ++ + return (retval); + } + +diff -up cups-1.3.5/scheduler/main.c.1.3.x cups-1.3.5/scheduler/main.c +--- cups-1.3.5/scheduler/main.c.1.3.x 2007-11-09 19:54:09.000000000 +0000 ++++ cups-1.3.5/scheduler/main.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * Scheduler main loop for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2007 by Easy Software Products, all rights reserved. + * + * These coded instructions, statements, and computer programs are the +@@ -133,10 +133,7 @@ main(int argc, /* I - Number of comm + browse_time, /* Next browse send time */ + senddoc_time, /* Send-Document time */ + expire_time, /* Subscription expire time */ +- mallinfo_time; /* Malloc information time */ +- size_t string_count, /* String count */ +- alloc_bytes, /* Allocated string bytes */ +- total_bytes; /* Total string bytes */ ++ report_time; /* Malloc/client/job report time */ + long timeout; /* Timeout for cupsdDoSelect() */ + struct rlimit limit; /* Runtime limit */ + #if defined(HAVE_SIGACTION) && !defined(HAVE_SIGSET) +@@ -149,6 +146,8 @@ main(int argc, /* I - Number of comm + #ifdef __APPLE__ + int run_as_child = 0; + /* Needed for Mac OS X fork/exec */ ++#else ++ time_t netif_time = 0; /* Time since last network update */ + #endif /* __APPLE__ */ + #if HAVE_LAUNCHD + int launchd_idle_exit; +@@ -226,11 +225,22 @@ main(int argc, /* I - Number of comm + * are passed a NULL pointer. + */ + +- current = malloc(1024); +- getcwd(current, 1024); ++ if ((current = malloc(1024)) == NULL) ++ { ++ _cupsLangPuts(stderr, ++ _("cupsd: Unable to get current directory!\n")); ++ return (1); ++ } ++ ++ if (!getcwd(current, 1024)) ++ { ++ _cupsLangPuts(stderr, ++ _("cupsd: Unable to get current directory!\n")); ++ free(current); ++ return (1); ++ } + + cupsdSetStringf(&ConfigurationFile, "%s/%s", current, argv[i]); +- + free(current); + } + break; +@@ -632,11 +642,11 @@ main(int argc, /* I - Number of comm + * Loop forever... + */ + +- mallinfo_time = 0; + browse_time = time(NULL); +- senddoc_time = time(NULL); + expire_time = time(NULL); + fds = 1; ++ report_time = 0; ++ senddoc_time = time(NULL); + + while (!stop_scheduler) + { +@@ -827,6 +837,18 @@ main(int argc, /* I - Number of comm + + current_time = time(NULL); + ++#ifndef __APPLE__ ++ /* ++ * Update the network interfaces once a minute... ++ */ ++ ++ if ((current_time - netif_time) >= 60) ++ { ++ netif_time = current_time; ++ NetIFUpdate = 1; ++ } ++#endif /* !__APPLE__ */ ++ + #if HAVE_LAUNCHD + /* + * If no other work was scheduled and we're being controlled by launchd +@@ -903,7 +925,7 @@ main(int argc, /* I - Number of comm + */ + + cupsdDeleteCert(0); +- cupsdAddCert(0, "root"); ++ cupsdAddCert(0, "root", NULL); + } + + /* +@@ -951,30 +973,49 @@ main(int argc, /* I - Number of comm + } + + /* +- * Log memory usage every minute... ++ * Log statistics at most once a minute when in debug mode... + */ + +- if ((current_time - mallinfo_time) >= 60 && LogLevel >= CUPSD_LOG_DEBUG2) ++ if ((current_time - report_time) >= 60 && LogLevel >= CUPSD_LOG_DEBUG) + { ++ size_t string_count, /* String count */ ++ alloc_bytes, /* Allocated string bytes */ ++ total_bytes; /* Total string bytes */ + #ifdef HAVE_MALLINFO +- struct mallinfo mem; /* Malloc information */ ++ struct mallinfo mem; /* Malloc information */ + + + mem = mallinfo(); +- cupsdLogMessage(CUPSD_LOG_DEBUG2, +- "mallinfo: arena = %d, used = %d, free = %d\n", +- mem.arena, mem.usmblks + mem.uordblks, ++ cupsdLogMessage(CUPSD_LOG_DEBUG, "Report: malloc-arena=%lu", mem.arena); ++ cupsdLogMessage(CUPSD_LOG_DEBUG, "Report: malloc-used=%lu", ++ mem.usmblks + mem.uordblks); ++ cupsdLogMessage(CUPSD_LOG_DEBUG, "Report: malloc-free=%lu", + mem.fsmblks + mem.fordblks); + #endif /* HAVE_MALLINFO */ + ++ cupsdLogMessage(CUPSD_LOG_DEBUG, "Report: clients=%d", ++ cupsArrayCount(Clients)); ++ cupsdLogMessage(CUPSD_LOG_DEBUG, "Report: jobs=%d", ++ cupsArrayCount(Jobs)); ++ cupsdLogMessage(CUPSD_LOG_DEBUG, "Report: jobs-active=%d", ++ cupsArrayCount(ActiveJobs)); ++ cupsdLogMessage(CUPSD_LOG_DEBUG, "Report: printers=%d", ++ cupsArrayCount(Printers)); ++ cupsdLogMessage(CUPSD_LOG_DEBUG, "Report: printers-implicit=%d", ++ cupsArrayCount(ImplicitPrinters)); ++ + string_count = _cupsStrStatistics(&alloc_bytes, &total_bytes); +- cupsdLogMessage(CUPSD_LOG_DEBUG2, +- "stringpool: " CUPS_LLFMT " strings, " +- CUPS_LLFMT " allocated, " CUPS_LLFMT " total bytes", +- CUPS_LLCAST string_count, CUPS_LLCAST alloc_bytes, ++ cupsdLogMessage(CUPSD_LOG_DEBUG, ++ "Report: stringpool-string-count=" CUPS_LLFMT, ++ CUPS_LLCAST string_count); ++ cupsdLogMessage(CUPSD_LOG_DEBUG, ++ "Report: stringpool-alloc-bytes=" CUPS_LLFMT, ++ CUPS_LLCAST alloc_bytes); ++ cupsdLogMessage(CUPSD_LOG_DEBUG, ++ "Report: stringpool-total-bytes=" CUPS_LLFMT, + CUPS_LLCAST total_bytes); + +- mallinfo_time = current_time; ++ report_time = current_time; + } + + /* +@@ -1015,7 +1056,7 @@ main(int argc, /* I - Number of comm + * Reset the accumulated events... + */ + +- LastEvent = CUPSD_EVENT_NONE; ++ LastEvent = CUPSD_EVENT_NONE; + } + } + +diff -up cups-1.3.5/scheduler/conf.c.1.3.x cups-1.3.5/scheduler/conf.c +--- cups-1.3.5/scheduler/conf.c.1.3.x 2007-11-09 19:54:09.000000000 +0000 ++++ cups-1.3.5/scheduler/conf.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * Configuration routines for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2007 by Easy Software Products, all rights reserved. + * + * These coded instructions, statements, and computer programs are the +@@ -384,7 +384,7 @@ cupsdReadConfiguration(void) + if (NumRelays > 0) + { + for (i = 0; i < NumRelays; i ++) +- if (Relays[i].from.type == AUTH_NAME) ++ if (Relays[i].from.type == CUPSD_AUTH_NAME) + free(Relays[i].from.mask.name.name); + + free(Relays); +@@ -508,7 +508,7 @@ cupsdReadConfiguration(void) + */ + + ConfigFilePerm = CUPS_DEFAULT_CONFIG_FILE_PERM; +- DefaultAuthType = AUTH_BASIC; ++ DefaultAuthType = CUPSD_AUTH_BASIC; + #ifdef HAVE_SSL + DefaultEncryption = HTTP_ENCRYPT_REQUIRED; + #endif /* HAVE_SSL */ +@@ -962,8 +962,8 @@ cupsdReadConfiguration(void) + cupsdLogMessage(CUPSD_LOG_INFO, "Order Deny,Allow"); + + po = cupsdAddPolicyOp(p, NULL, IPP_SEND_DOCUMENT); +- po->order_type = AUTH_ALLOW; +- po->level = AUTH_USER; ++ po->order_type = CUPSD_AUTH_ALLOW; ++ po->level = CUPSD_AUTH_USER; + + cupsdAddName(po, "@OWNER"); + cupsdAddName(po, "@SYSTEM"); +@@ -1003,9 +1003,9 @@ cupsdReadConfiguration(void) + cupsdLogMessage(CUPSD_LOG_INFO, "AuthType Default"); + + po = cupsdAddPolicyOp(p, NULL, IPP_PAUSE_PRINTER); +- po->order_type = AUTH_ALLOW; +- po->type = AUTH_DEFAULT; +- po->level = AUTH_USER; ++ po->order_type = CUPSD_AUTH_ALLOW; ++ po->type = CUPSD_AUTH_DEFAULT; ++ po->level = CUPSD_AUTH_USER; + + cupsdAddName(po, "@SYSTEM"); + cupsdLogMessage(CUPSD_LOG_INFO, "Require user @SYSTEM"); +@@ -1038,7 +1038,7 @@ cupsdReadConfiguration(void) + cupsdLogMessage(CUPSD_LOG_INFO, "Order Deny,Allow"); + + po = cupsdAddPolicyOp(p, NULL, IPP_ANY_OPERATION); +- po->order_type = AUTH_ALLOW; ++ po->order_type = CUPSD_AUTH_ALLOW; + + cupsdLogMessage(CUPSD_LOG_INFO, ""); + cupsdLogMessage(CUPSD_LOG_INFO, ""); +@@ -1119,19 +1119,27 @@ cupsdReadConfiguration(void) + if (!mimeType(MimeDatabase, "application", "octet-stream")) + NumMimeTypes ++; + +- MimeTypes = calloc(NumMimeTypes, sizeof(const char *)); +- +- for (i = 0, type = mimeFirstType(MimeDatabase); +- type; +- i ++, type = mimeNextType(MimeDatabase)) ++ if ((MimeTypes = calloc(NumMimeTypes, sizeof(const char *))) == NULL) + { +- snprintf(mimetype, sizeof(mimetype), "%s/%s", type->super, type->type); +- +- MimeTypes[i] = _cupsStrAlloc(mimetype); ++ cupsdLogMessage(CUPSD_LOG_ERROR, ++ "Unable to allocate memory for %d MIME types!", ++ NumMimeTypes); ++ NumMimeTypes = 0; + } ++ else ++ { ++ for (i = 0, type = mimeFirstType(MimeDatabase); ++ type; ++ i ++, type = mimeNextType(MimeDatabase)) ++ { ++ snprintf(mimetype, sizeof(mimetype), "%s/%s", type->super, type->type); ++ ++ MimeTypes[i] = _cupsStrAlloc(mimetype); ++ } + +- if (i < NumMimeTypes) +- MimeTypes[i] = _cupsStrAlloc("application/octet-stream"); ++ if (i < NumMimeTypes) ++ MimeTypes[i] = _cupsStrAlloc("application/octet-stream"); ++ } + + if (LogLevel == CUPSD_LOG_DEBUG2) + { +@@ -1568,9 +1576,9 @@ parse_aaa(cupsd_location_t *loc, /* I - + */ + + if (!strncasecmp(value, "deny", 4)) +- loc->order_type = AUTH_ALLOW; ++ loc->order_type = CUPSD_AUTH_ALLOW; + else if (!strncasecmp(value, "allow", 5)) +- loc->order_type = AUTH_DENY; ++ loc->order_type = CUPSD_AUTH_DENY; + else + { + cupsdLogMessage(CUPSD_LOG_ERROR, "Unknown Order value %s on line %d.", +@@ -1681,44 +1689,44 @@ parse_aaa(cupsd_location_t *loc, /* I - + + if (!strcasecmp(value, "none")) + { +- loc->type = AUTH_NONE; +- loc->level = AUTH_ANON; ++ loc->type = CUPSD_AUTH_NONE; ++ loc->level = CUPSD_AUTH_ANON; + } + else if (!strcasecmp(value, "basic")) + { +- loc->type = AUTH_BASIC; ++ loc->type = CUPSD_AUTH_BASIC; + +- if (loc->level == AUTH_ANON) +- loc->level = AUTH_USER; ++ if (loc->level == CUPSD_AUTH_ANON) ++ loc->level = CUPSD_AUTH_USER; + } + else if (!strcasecmp(value, "digest")) + { +- loc->type = AUTH_DIGEST; ++ loc->type = CUPSD_AUTH_DIGEST; + +- if (loc->level == AUTH_ANON) +- loc->level = AUTH_USER; ++ if (loc->level == CUPSD_AUTH_ANON) ++ loc->level = CUPSD_AUTH_USER; + } + else if (!strcasecmp(value, "basicdigest")) + { +- loc->type = AUTH_BASICDIGEST; ++ loc->type = CUPSD_AUTH_BASICDIGEST; + +- if (loc->level == AUTH_ANON) +- loc->level = AUTH_USER; ++ if (loc->level == CUPSD_AUTH_ANON) ++ loc->level = CUPSD_AUTH_USER; + } + else if (!strcasecmp(value, "default")) + { +- loc->type = AUTH_DEFAULT; ++ loc->type = CUPSD_AUTH_DEFAULT; + +- if (loc->level == AUTH_ANON) +- loc->level = AUTH_USER; ++ if (loc->level == CUPSD_AUTH_ANON) ++ loc->level = CUPSD_AUTH_USER; + } + #ifdef HAVE_GSSAPI + else if (!strcasecmp(value, "negotiate")) + { +- loc->type = AUTH_NEGOTIATE; ++ loc->type = CUPSD_AUTH_NEGOTIATE; + +- if (loc->level == AUTH_ANON) +- loc->level = AUTH_USER; ++ if (loc->level == CUPSD_AUTH_ANON) ++ loc->level = CUPSD_AUTH_USER; + } + #endif /* HAVE_GSSAPI */ + else +@@ -1737,8 +1745,8 @@ parse_aaa(cupsd_location_t *loc, /* I - + + if (!strcasecmp(value, "anonymous")) + { +- loc->type = AUTH_NONE; +- loc->level = AUTH_ANON; ++ loc->type = CUPSD_AUTH_NONE; ++ loc->level = CUPSD_AUTH_ANON; + + cupsdLogMessage(CUPSD_LOG_WARN, + "\"AuthClass %s\" is deprecated; consider removing " +@@ -1747,7 +1755,7 @@ parse_aaa(cupsd_location_t *loc, /* I - + } + else if (!strcasecmp(value, "user")) + { +- loc->level = AUTH_USER; ++ loc->level = CUPSD_AUTH_USER; + + cupsdLogMessage(CUPSD_LOG_WARN, + "\"AuthClass %s\" is deprecated; consider using " +@@ -1756,7 +1764,7 @@ parse_aaa(cupsd_location_t *loc, /* I - + } + else if (!strcasecmp(value, "group")) + { +- loc->level = AUTH_GROUP; ++ loc->level = CUPSD_AUTH_GROUP; + + cupsdLogMessage(CUPSD_LOG_WARN, + "\"AuthClass %s\" is deprecated; consider using " +@@ -1765,7 +1773,7 @@ parse_aaa(cupsd_location_t *loc, /* I - + } + else if (!strcasecmp(value, "system")) + { +- loc->level = AUTH_GROUP; ++ loc->level = CUPSD_AUTH_GROUP; + + cupsdAddName(loc, "@SYSTEM"); + +@@ -1810,9 +1818,9 @@ parse_aaa(cupsd_location_t *loc, /* I - + + if (!strcasecmp(value, "valid-user") || + !strcasecmp(value, "user")) +- loc->level = AUTH_USER; ++ loc->level = CUPSD_AUTH_USER; + else if (!strcasecmp(value, "group")) +- loc->level = AUTH_GROUP; ++ loc->level = CUPSD_AUTH_GROUP; + else + { + cupsdLogMessage(CUPSD_LOG_WARN, "Unknown Require type %s on line %d.", +@@ -1873,9 +1881,9 @@ parse_aaa(cupsd_location_t *loc, /* I - + else if (!strcasecmp(line, "Satisfy")) + { + if (!strcasecmp(value, "all")) +- loc->satisfy = AUTH_SATISFY_ALL; ++ loc->satisfy = CUPSD_AUTH_SATISFY_ALL; + else if (!strcasecmp(value, "any")) +- loc->satisfy = AUTH_SATISFY_ANY; ++ loc->satisfy = CUPSD_AUTH_SATISFY_ANY; + else + { + cupsdLogMessage(CUPSD_LOG_WARN, "Unknown Satisfy value %s on line %d.", +@@ -2353,9 +2361,9 @@ read_configuration(cups_file_t *fp) /* I + cupsdLogMessage(CUPSD_LOG_ERROR, + "Unable to initialize browse access control list!"); + else if (!strncasecmp(value, "deny", 4)) +- location->order_type = AUTH_ALLOW; ++ location->order_type = CUPSD_AUTH_ALLOW; + else if (!strncasecmp(value, "allow", 5)) +- location->order_type = AUTH_DENY; ++ location->order_type = CUPSD_AUTH_DENY; + else + cupsdLogMessage(CUPSD_LOG_ERROR, + "Unknown BrowseOrder value %s on line %d.", +@@ -2559,8 +2567,16 @@ read_configuration(cups_file_t *fp) /* I + if ((ptr = strchr(temp, ' ')) != NULL) + *ptr = '\0'; + +- relay->from.type = AUTH_NAME; +- relay->from.mask.name.name = strdup(temp); ++ relay->from.type = CUPSD_AUTH_NAME; ++ ++ if ((relay->from.mask.name.name = strdup(temp)) == NULL) ++ { ++ cupsdLogMessage(CUPSD_LOG_ERROR, ++ "Unable to allocate BrowseRelay name at line %d - %s.", ++ linenum, strerror(errno)); ++ continue; ++ } ++ + relay->from.mask.name.length = strlen(temp); + } + else +@@ -2576,7 +2592,7 @@ read_configuration(cups_file_t *fp) /* I + break; + } + +- relay->from.type = AUTH_IP; ++ relay->from.type = CUPSD_AUTH_IP; + memcpy(relay->from.mask.ip.address, ip, + sizeof(relay->from.mask.ip.address)); + memcpy(relay->from.mask.ip.netmask, mask, +@@ -2626,7 +2642,7 @@ read_configuration(cups_file_t *fp) /* I + + httpAddrString(&(relay->to), temp, sizeof(temp)); + +- if (relay->from.type == AUTH_IP) ++ if (relay->from.type == CUPSD_AUTH_IP) + snprintf(temp2, sizeof(temp2), "%u.%u.%u.%u/%u.%u.%u.%u", + relay->from.mask.ip.address[0] >> 24, + (relay->from.mask.ip.address[0] >> 16) & 255, +@@ -2652,7 +2668,7 @@ read_configuration(cups_file_t *fp) /* I + } + else + { +- if (relay->from.type == AUTH_NAME) ++ if (relay->from.type == CUPSD_AUTH_NAME) + free(relay->from.mask.name.name); + + cupsdLogMessage(CUPSD_LOG_ERROR, "Bad relay address %s at line %d.", +@@ -2728,16 +2744,16 @@ read_configuration(cups_file_t *fp) /* I + */ + + if (!strcasecmp(value, "none")) +- DefaultAuthType = AUTH_NONE; ++ DefaultAuthType = CUPSD_AUTH_NONE; + else if (!strcasecmp(value, "basic")) +- DefaultAuthType = AUTH_BASIC; ++ DefaultAuthType = CUPSD_AUTH_BASIC; + else if (!strcasecmp(value, "digest")) +- DefaultAuthType = AUTH_DIGEST; ++ DefaultAuthType = CUPSD_AUTH_DIGEST; + else if (!strcasecmp(value, "basicdigest")) +- DefaultAuthType = AUTH_BASICDIGEST; ++ DefaultAuthType = CUPSD_AUTH_BASICDIGEST; + #ifdef HAVE_GSSAPI + else if (!strcasecmp(value, "negotiate")) +- DefaultAuthType = AUTH_NEGOTIATE; ++ DefaultAuthType = CUPSD_AUTH_NEGOTIATE; + #endif /* HAVE_GSSAPI */ + else + { +@@ -3125,7 +3141,7 @@ read_location(cups_file_t *fp, /* I - C + if ((parent = cupsdAddLocation(location)) == NULL) + return (0); + +- parent->limit = AUTH_LIMIT_ALL; ++ parent->limit = CUPSD_AUTH_LIMIT_ALL; + loc = parent; + + while (cupsFileGetConf(fp, line, sizeof(line), &value, &linenum)) +@@ -3157,19 +3173,19 @@ read_location(cups_file_t *fp, /* I - C + *valptr++ = '\0'; + + if (!strcmp(value, "ALL")) +- loc->limit = AUTH_LIMIT_ALL; ++ loc->limit = CUPSD_AUTH_LIMIT_ALL; + else if (!strcmp(value, "GET")) +- loc->limit |= AUTH_LIMIT_GET; ++ loc->limit |= CUPSD_AUTH_LIMIT_GET; + else if (!strcmp(value, "HEAD")) +- loc->limit |= AUTH_LIMIT_HEAD; ++ loc->limit |= CUPSD_AUTH_LIMIT_HEAD; + else if (!strcmp(value, "OPTIONS")) +- loc->limit |= AUTH_LIMIT_OPTIONS; ++ loc->limit |= CUPSD_AUTH_LIMIT_OPTIONS; + else if (!strcmp(value, "POST")) +- loc->limit |= AUTH_LIMIT_POST; ++ loc->limit |= CUPSD_AUTH_LIMIT_POST; + else if (!strcmp(value, "PUT")) +- loc->limit |= AUTH_LIMIT_PUT; ++ loc->limit |= CUPSD_AUTH_LIMIT_PUT; + else if (!strcmp(value, "TRACE")) +- loc->limit |= AUTH_LIMIT_TRACE; ++ loc->limit |= CUPSD_AUTH_LIMIT_TRACE; + else + cupsdLogMessage(CUPSD_LOG_WARN, "Unknown request type %s on line %d!", + value, linenum); +@@ -3178,7 +3194,7 @@ read_location(cups_file_t *fp, /* I - C + } + + if (!strcasecmp(line, "limit = AUTH_LIMIT_ALL ^ loc->limit; ++ loc->limit = CUPSD_AUTH_LIMIT_ALL ^ loc->limit; + + parent->limit &= ~loc->limit; + } +diff -up cups-1.3.5/scheduler/auth.c.1.3.x cups-1.3.5/scheduler/auth.c +--- cups-1.3.5/scheduler/auth.c.1.3.x 2007-10-22 21:27:22.000000000 +0100 ++++ cups-1.3.5/scheduler/auth.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * Authorization routines for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2007 by Easy Software Products, all rights reserved. + * + * This file contains Kerberos support code, copyright 2006 by +@@ -176,8 +176,13 @@ cupsdAddLocation(const char *location) / + * Initialize the record and copy the name over... + */ + +- temp->location = strdup(location); +- temp->length = strlen(temp->location); ++ if ((temp->location = strdup(location)) == NULL) ++ { ++ free(temp); ++ return (NULL); ++ } ++ ++ temp->length = strlen(temp->location); + + cupsArrayAdd(Locations, temp); + +@@ -257,7 +262,7 @@ cupsdAllowHost(cupsd_location_t *loc, /* + * Allow *interface*... + */ + +- temp->type = AUTH_INTERFACE; ++ temp->type = CUPSD_AUTH_INTERFACE; + temp->mask.name.name = strdup("*"); + temp->mask.name.length = 1; + } +@@ -277,7 +282,7 @@ cupsdAllowHost(cupsd_location_t *loc, /* + *ifptr = '\0'; + } + +- temp->type = AUTH_INTERFACE; ++ temp->type = CUPSD_AUTH_INTERFACE; + temp->mask.name.name = strdup(ifname); + temp->mask.name.length = ifptr - ifname; + } +@@ -287,7 +292,7 @@ cupsdAllowHost(cupsd_location_t *loc, /* + * Allow name... + */ + +- temp->type = AUTH_NAME; ++ temp->type = CUPSD_AUTH_NAME; + temp->mask.name.name = strdup(name); + temp->mask.name.length = strlen(name); + } +@@ -316,7 +321,7 @@ cupsdAllowIP(cupsd_location_t *loc, /* I + if ((temp = add_allow(loc)) == NULL) + return; + +- temp->type = AUTH_IP; ++ temp->type = CUPSD_AUTH_IP; + memcpy(temp->mask.ip.address, address, sizeof(temp->mask.ip.address)); + memcpy(temp->mask.ip.netmask, netmask, sizeof(temp->mask.ip.netmask)); + } +@@ -363,15 +368,15 @@ cupsdAuthorize(cupsd_client_t *con) /* I + */ + + con->best = cupsdFindBest(con->uri, con->http.state); +- con->type = AUTH_NONE; ++ con->type = CUPSD_AUTH_NONE; + + cupsdLogMessage(CUPSD_LOG_DEBUG2, + "cupsdAuthorize: con->uri=\"%s\", con->best=%p(%s)", + con->uri, con->best, con->best ? con->best->location : ""); + +- if (con->best && con->best->type != AUTH_NONE) ++ if (con->best && con->best->type != CUPSD_AUTH_NONE) + { +- if (con->best->type == AUTH_DEFAULT) ++ if (con->best->type == CUPSD_AUTH_DEFAULT) + type = DefaultAuthType; + else + type = con->best->type; +@@ -463,7 +468,7 @@ cupsdAuthorize(cupsd_client_t *con) /* I + + AuthorizationFreeItemSet(authinfo); + +- con->type = AUTH_BASIC; ++ con->type = CUPSD_AUTH_BASIC; + } + #endif /* HAVE_AUTHORIZATION_H */ + #if defined(SO_PEERCRED) && defined(AF_LOCAL) +@@ -520,7 +525,7 @@ cupsdAuthorize(cupsd_client_t *con) /* I + "cupsdAuthorize: Authorized as %s using PeerCred", + username); + +- con->type = AUTH_BASIC; ++ con->type = CUPSD_AUTH_BASIC; + } + #endif /* SO_PEERCRED && AF_LOCAL */ + else if (!strncmp(authorization, "Local", 5) && +@@ -550,7 +555,7 @@ cupsdAuthorize(cupsd_client_t *con) /* I + return; + } + +- con->type = AUTH_BASIC; ++ con->type = CUPSD_AUTH_BASIC; + } + else if (!strncmp(authorization, "Basic", 5)) + { +@@ -612,7 +617,7 @@ cupsdAuthorize(cupsd_client_t *con) /* I + switch (type) + { + default : +- case AUTH_BASIC : ++ case CUPSD_AUTH_BASIC : + { + #if HAVE_LIBPAM + /* +@@ -811,7 +816,7 @@ cupsdAuthorize(cupsd_client_t *con) /* I + username); + break; + +- case AUTH_BASICDIGEST : ++ case CUPSD_AUTH_BASICDIGEST : + /* + * Do Basic authentication with the Digest password file... + */ +@@ -915,7 +920,7 @@ cupsdAuthorize(cupsd_client_t *con) /* I + "cupsdAuthorize: Authorized as %s using Digest", + username); + +- con->type = AUTH_DIGEST; ++ con->type = CUPSD_AUTH_DIGEST; + } + #ifdef HAVE_GSSAPI + else if (!strncmp(authorization, "Negotiate", 9)) +@@ -1056,7 +1061,7 @@ cupsdAuthorize(cupsd_client_t *con) /* I + + con->gss_have_creds = 1; + +- con->type = AUTH_NEGOTIATE; ++ con->type = CUPSD_AUTH_NEGOTIATE; + } + else + gss_release_name(&minor_status, &client_name); +@@ -1109,7 +1114,7 @@ cupsdCheckAuth( + { + switch (masks->type) + { +- case AUTH_INTERFACE : ++ case CUPSD_AUTH_INTERFACE : + /* + * Check for a match with a network interface... + */ +@@ -1217,7 +1222,7 @@ cupsdCheckAuth( + } + break; + +- case AUTH_NAME : ++ case CUPSD_AUTH_NAME : + /* + * Check for exact name match... + */ +@@ -1236,7 +1241,7 @@ cupsdCheckAuth( + return (1); + break; + +- case AUTH_IP : ++ case CUPSD_AUTH_IP : + /* + * Check for IP/network address match... + */ +@@ -1427,7 +1432,7 @@ cupsdCopyLocation( + for (i = 0; i < temp->num_allow; i ++) + switch (temp->allow[i].type = (*loc)->allow[i].type) + { +- case AUTH_NAME : ++ case CUPSD_AUTH_NAME : + temp->allow[i].mask.name.length = (*loc)->allow[i].mask.name.length; + temp->allow[i].mask.name.name = strdup((*loc)->allow[i].mask.name.name); + +@@ -1440,7 +1445,7 @@ cupsdCopyLocation( + return (NULL); + } + break; +- case AUTH_IP : ++ case CUPSD_AUTH_IP : + memcpy(&(temp->allow[i].mask.ip), &((*loc)->allow[i].mask.ip), + sizeof(cupsd_ipmask_t)); + break; +@@ -1465,7 +1470,7 @@ cupsdCopyLocation( + for (i = 0; i < temp->num_deny; i ++) + switch (temp->deny[i].type = (*loc)->deny[i].type) + { +- case AUTH_NAME : ++ case CUPSD_AUTH_NAME : + temp->deny[i].mask.name.length = (*loc)->deny[i].mask.name.length; + temp->deny[i].mask.name.name = strdup((*loc)->deny[i].mask.name.name); + +@@ -1478,7 +1483,7 @@ cupsdCopyLocation( + return (NULL); + } + break; +- case AUTH_IP : ++ case CUPSD_AUTH_IP : + memcpy(&(temp->deny[i].mask.ip), &((*loc)->deny[i].mask.ip), + sizeof(cupsd_ipmask_t)); + break; +@@ -1538,14 +1543,14 @@ cupsdDeleteLocation( + free(loc->names); + + for (i = loc->num_allow, mask = loc->allow; i > 0; i --, mask ++) +- if (mask->type == AUTH_NAME || mask->type == AUTH_INTERFACE) ++ if (mask->type == CUPSD_AUTH_NAME || mask->type == CUPSD_AUTH_INTERFACE) + free(mask->mask.name.name); + + if (loc->num_allow > 0) + free(loc->allow); + + for (i = loc->num_deny, mask = loc->deny; i > 0; i --, mask ++) +- if (mask->type == AUTH_NAME || mask->type == AUTH_INTERFACE) ++ if (mask->type == CUPSD_AUTH_NAME || mask->type == CUPSD_AUTH_INTERFACE) + free(mask->mask.name.name); + + if (loc->num_deny > 0) +@@ -1582,7 +1587,7 @@ cupsdDenyHost(cupsd_location_t *loc, /* + * Deny *interface*... + */ + +- temp->type = AUTH_INTERFACE; ++ temp->type = CUPSD_AUTH_INTERFACE; + temp->mask.name.name = strdup("*"); + temp->mask.name.length = 1; + } +@@ -1602,7 +1607,7 @@ cupsdDenyHost(cupsd_location_t *loc, /* + *ifptr = '\0'; + } + +- temp->type = AUTH_INTERFACE; ++ temp->type = CUPSD_AUTH_INTERFACE; + temp->mask.name.name = strdup(ifname); + temp->mask.name.length = ifptr - ifname; + } +@@ -1612,7 +1617,7 @@ cupsdDenyHost(cupsd_location_t *loc, /* + * Deny name... + */ + +- temp->type = AUTH_NAME; ++ temp->type = CUPSD_AUTH_NAME; + temp->mask.name.name = strdup(name); + temp->mask.name.length = strlen(name); + } +@@ -1641,7 +1646,7 @@ cupsdDenyIP(cupsd_location_t *loc, /* I + if ((temp = add_deny(loc)) == NULL) + return; + +- temp->type = AUTH_IP; ++ temp->type = CUPSD_AUTH_IP; + memcpy(temp->mask.ip.address, address, sizeof(temp->mask.ip.address)); + memcpy(temp->mask.ip.netmask, netmask, sizeof(temp->mask.ip.netmask)); + } +@@ -1662,22 +1667,22 @@ cupsdFindBest(const char *path, /* I - + *best; /* Best match for location so far */ + int bestlen; /* Length of best match */ + int limit; /* Limit field */ +- static const int limits[] = /* Map http_status_t to AUTH_LIMIT_xyz */ ++ static const int limits[] = /* Map http_status_t to CUPSD_AUTH_LIMIT_xyz */ + { +- AUTH_LIMIT_ALL, +- AUTH_LIMIT_OPTIONS, +- AUTH_LIMIT_GET, +- AUTH_LIMIT_GET, +- AUTH_LIMIT_HEAD, +- AUTH_LIMIT_POST, +- AUTH_LIMIT_POST, +- AUTH_LIMIT_POST, +- AUTH_LIMIT_PUT, +- AUTH_LIMIT_PUT, +- AUTH_LIMIT_DELETE, +- AUTH_LIMIT_TRACE, +- AUTH_LIMIT_ALL, +- AUTH_LIMIT_ALL ++ CUPSD_AUTH_LIMIT_ALL, ++ CUPSD_AUTH_LIMIT_OPTIONS, ++ CUPSD_AUTH_LIMIT_GET, ++ CUPSD_AUTH_LIMIT_GET, ++ CUPSD_AUTH_LIMIT_HEAD, ++ CUPSD_AUTH_LIMIT_POST, ++ CUPSD_AUTH_LIMIT_POST, ++ CUPSD_AUTH_LIMIT_POST, ++ CUPSD_AUTH_LIMIT_PUT, ++ CUPSD_AUTH_LIMIT_PUT, ++ CUPSD_AUTH_LIMIT_DELETE, ++ CUPSD_AUTH_LIMIT_TRACE, ++ CUPSD_AUTH_LIMIT_ALL, ++ CUPSD_AUTH_LIMIT_ALL + }; + + +@@ -1837,16 +1842,16 @@ cupsdIsAuthorized(cupsd_client_t *con, / + + best = con->best; + +- if ((type = best->type) == AUTH_DEFAULT) ++ if ((type = best->type) == CUPSD_AUTH_DEFAULT) + type = DefaultAuthType; + + cupsdLogMessage(CUPSD_LOG_DEBUG2, +- "cupsdIsAuthorized: level=AUTH_%s, type=%s, " +- "satisfy=AUTH_SATISFY_%s, num_names=%d", ++ "cupsdIsAuthorized: level=CUPSD_AUTH_%s, type=%s, " ++ "satisfy=CUPSD_AUTH_SATISFY_%s, num_names=%d", + levels[best->level], types[type], + best->satisfy ? "ANY" : "ALL", best->num_names); + +- if (best->limit == AUTH_LIMIT_IPP) ++ if (best->limit == CUPSD_AUTH_LIMIT_IPP) + cupsdLogMessage(CUPSD_LOG_DEBUG2, "cupsdIsAuthorized: op=%x(%s)", + best->op, ippOpString(best->op)); + +@@ -1890,7 +1895,7 @@ cupsdIsAuthorized(cupsd_client_t *con, / + * Access from localhost (127.0.0.1 or ::1) is always allowed... + */ + +- auth = AUTH_ALLOW; ++ auth = CUPSD_AUTH_ALLOW; + } + else + { +@@ -1901,39 +1906,39 @@ cupsdIsAuthorized(cupsd_client_t *con, / + switch (best->order_type) + { + default : +- auth = AUTH_DENY; /* anti-compiler-warning-code */ ++ auth = CUPSD_AUTH_DENY; /* anti-compiler-warning-code */ + break; + +- case AUTH_ALLOW : /* Order Deny,Allow */ +- auth = AUTH_ALLOW; ++ case CUPSD_AUTH_ALLOW : /* Order Deny,Allow */ ++ auth = CUPSD_AUTH_ALLOW; + + if (cupsdCheckAuth(address, con->http.hostname, hostlen, + best->num_deny, best->deny)) +- auth = AUTH_DENY; ++ auth = CUPSD_AUTH_DENY; + + if (cupsdCheckAuth(address, con->http.hostname, hostlen, + best->num_allow, best->allow)) +- auth = AUTH_ALLOW; ++ auth = CUPSD_AUTH_ALLOW; + break; + +- case AUTH_DENY : /* Order Allow,Deny */ +- auth = AUTH_DENY; ++ case CUPSD_AUTH_DENY : /* Order Allow,Deny */ ++ auth = CUPSD_AUTH_DENY; + + if (cupsdCheckAuth(address, con->http.hostname, hostlen, + best->num_allow, best->allow)) +- auth = AUTH_ALLOW; ++ auth = CUPSD_AUTH_ALLOW; + + if (cupsdCheckAuth(address, con->http.hostname, hostlen, + best->num_deny, best->deny)) +- auth = AUTH_DENY; ++ auth = CUPSD_AUTH_DENY; + break; + } + } + +- cupsdLogMessage(CUPSD_LOG_DEBUG2, "cupsdIsAuthorized: auth=AUTH_%s...", ++ cupsdLogMessage(CUPSD_LOG_DEBUG2, "cupsdIsAuthorized: auth=CUPSD_AUTH_%s...", + auth ? "DENY" : "ALLOW"); + +- if (auth == AUTH_DENY && best->satisfy == AUTH_SATISFY_ALL) ++ if (auth == CUPSD_AUTH_DENY && best->satisfy == CUPSD_AUTH_SATISFY_ALL) + return (HTTP_FORBIDDEN); + + #ifdef HAVE_SSL +@@ -1943,9 +1948,9 @@ cupsdIsAuthorized(cupsd_client_t *con, / + + if ((best->encryption >= HTTP_ENCRYPT_REQUIRED && !con->http.tls && + strcasecmp(con->http.hostname, "localhost") && +- best->satisfy == AUTH_SATISFY_ALL) && +- !(type == AUTH_NEGOTIATE || +- (type == AUTH_NONE && DefaultAuthType == AUTH_NEGOTIATE))) ++ best->satisfy == CUPSD_AUTH_SATISFY_ALL) && ++ !(type == CUPSD_AUTH_NEGOTIATE || ++ (type == CUPSD_AUTH_NONE && DefaultAuthType == CUPSD_AUTH_NEGOTIATE))) + { + cupsdLogMessage(CUPSD_LOG_DEBUG, + "cupsdIsAuthorized: Need upgrade to TLS..."); +@@ -1957,12 +1962,12 @@ cupsdIsAuthorized(cupsd_client_t *con, / + * Now see what access level is required... + */ + +- if (best->level == AUTH_ANON || /* Anonymous access - allow it */ +- (type == AUTH_NONE && best->num_names == 0)) ++ if (best->level == CUPSD_AUTH_ANON || /* Anonymous access - allow it */ ++ (type == CUPSD_AUTH_NONE && best->num_names == 0)) + return (HTTP_OK); + +- if (!con->username[0] && type == AUTH_NONE && +- best->limit == AUTH_LIMIT_IPP) ++ if (!con->username[0] && type == CUPSD_AUTH_NONE && ++ best->limit == CUPSD_AUTH_LIMIT_IPP) + { + /* + * Check for unauthenticated username... +@@ -1979,7 +1984,7 @@ cupsdIsAuthorized(cupsd_client_t *con, / + attr->values[0].string.text); + strlcpy(username, attr->values[0].string.text, sizeof(username)); + } +- else if (best->satisfy == AUTH_SATISFY_ALL || auth == AUTH_DENY) ++ else if (best->satisfy == CUPSD_AUTH_SATISFY_ALL || auth == CUPSD_AUTH_DENY) + return (HTTP_UNAUTHORIZED); /* Non-anonymous needs user/pass */ + else + return (HTTP_OK); /* unless overridden with Satisfy */ +@@ -1995,14 +2000,14 @@ cupsdIsAuthorized(cupsd_client_t *con, / + if (!con->username[0]) + #endif /* HAVE_AUTHORIZATION_H */ + { +- if (best->satisfy == AUTH_SATISFY_ALL || auth == AUTH_DENY) ++ if (best->satisfy == CUPSD_AUTH_SATISFY_ALL || auth == CUPSD_AUTH_DENY) + return (HTTP_UNAUTHORIZED); /* Non-anonymous needs user/pass */ + else + return (HTTP_OK); /* unless overridden with Satisfy */ + } + +- if (con->type != type && type != AUTH_NONE && +- (con->type != AUTH_BASIC || type != AUTH_BASICDIGEST)) ++ if (con->type != type && type != CUPSD_AUTH_NONE && ++ (con->type != CUPSD_AUTH_BASIC || type != CUPSD_AUTH_BASICDIGEST)) + { + cupsdLogMessage(CUPSD_LOG_ERROR, "Authorized using %s, expected %s!", + types[con->type], types[type]); +@@ -2050,7 +2055,7 @@ cupsdIsAuthorized(cupsd_client_t *con, / + else + pw = NULL; + +- if (best->level == AUTH_USER) ++ if (best->level == CUPSD_AUTH_USER) + { + /* + * If there are no names associated with this location, then +diff -up cups-1.3.5/scheduler/cert.c.1.3.x cups-1.3.5/scheduler/cert.c +--- cups-1.3.5/scheduler/cert.c.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/scheduler/cert.c 2008-02-05 15:08:55.000000000 +0000 +@@ -4,7 +4,7 @@ + * Authentication certificate routines for the Common UNIX + * Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2006 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -42,7 +42,8 @@ + + void + cupsdAddCert(int pid, /* I - Process ID */ +- const char *username) /* I - Username */ ++ const char *username, /* I - Username */ ++ void *ccache) /* I - Kerberos credentials or NULL */ + { + int i; /* Looping var */ + cupsd_cert_t *cert; /* Current certificate */ +@@ -244,6 +245,16 @@ cupsdAddCert(int pid, /* I - Pro + close(fd); + + /* ++ * Add Kerberos credentials as needed... ++ */ ++ ++#ifdef HAVE_GSSAPI ++ cert->ccache = (krb5_ccache)ccache; ++#else ++ (void)ccache; ++#endif /* HAVE_GSSAPI */ ++ ++ /* + * Insert the certificate at the front of the list... + */ + +@@ -282,6 +293,15 @@ cupsdDeleteCert(int pid) /* I - Process + else + prev->next = cert->next; + ++#ifdef HAVE_GSSAPI ++ /* ++ * Release Kerberos credentials as needed... ++ */ ++ ++ if (cert->ccache) ++ krb5_cc_destroy(KerberosContext, cert->ccache); ++#endif /* HAVE_GSSAPI */ ++ + free(cert); + + /* +@@ -412,7 +432,7 @@ cupsdInitCerts(void) + */ + + if (!RunUser) +- cupsdAddCert(0, "root"); ++ cupsdAddCert(0, "root", NULL); + } + + +diff -up cups-1.3.5/scheduler/log.c.1.3.x cups-1.3.5/scheduler/log.c +--- cups-1.3.5/scheduler/log.c.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/scheduler/log.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * Log file routines for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2007 by Easy Software Products, all rights reserved. + * + * These coded instructions, statements, and computer programs are the +@@ -261,6 +261,9 @@ cupsdLogMessage(int level, /* I - + + if (len >= linesize) + { ++ char *temp; /* Temporary string pointer */ ++ ++ + len ++; + + if (len < 8192) +@@ -268,18 +271,12 @@ cupsdLogMessage(int level, /* I - + else if (len > 65536) + len = 65536; + +- line = realloc(line, len); ++ temp = realloc(line, len); + +- if (line) +- linesize = len; +- else ++ if (temp) + { +- cupsFilePrintf(ErrorFile, +- "ERROR: Unable to allocate memory for line - %s\n", +- strerror(errno)); +- cupsFileFlush(ErrorFile); +- +- return (0); ++ line = temp; ++ linesize = len; + } + + va_start(ap, message); +diff -up cups-1.3.5/scheduler/cups-deviced.c.1.3.x cups-1.3.5/scheduler/cups-deviced.c +--- cups-1.3.5/scheduler/cups-deviced.c.1.3.x 2007-10-10 22:25:29.000000000 +0100 ++++ cups-1.3.5/scheduler/cups-deviced.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * Device scanning mini-daemon for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2006 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -291,6 +291,8 @@ main(int argc, /* I - Number of comm + if (!dev) + { + cupsDirClose(dir); ++ fclose(fp); ++ kill(pid, SIGTERM); + return (1); + } + +diff -up cups-1.3.5/scheduler/cups-driverd.c.1.3.x cups-1.3.5/scheduler/cups-driverd.c +--- cups-1.3.5/scheduler/cups-driverd.c.1.3.x 2007-08-02 19:05:03.000000000 +0100 ++++ cups-1.3.5/scheduler/cups-driverd.c 2008-02-05 15:08:55.000000000 +0000 +@@ -7,7 +7,7 @@ + * in CUPS_DATADIR/model and dynamically generated PPD files using + * the driver helper programs in CUPS_SERVERBIN/driver. + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2007 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -1664,6 +1664,7 @@ load_drivers(void) + if (!ppd) + { + cupsDirClose(dir); ++ pclose(fp); + return (0); + } + +diff -up cups-1.3.5/scheduler/mime.c.1.3.x cups-1.3.5/scheduler/mime.c +--- cups-1.3.5/scheduler/mime.c.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/scheduler/mime.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * MIME database file routines for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2006 by Easy Software Products, all rights reserved. + * + * These coded instructions, statements, and computer programs are the +@@ -235,7 +235,10 @@ mimeMerge(mime_t *mime, /* I - MIME + if (!mime) + mime = mimeNew(); + if (!mime) ++ { ++ cupsDirClose(dir); + return (NULL); ++ } + + /* + * Read all the .types files... +diff -up cups-1.3.5/scheduler/job.h.1.3.x cups-1.3.5/scheduler/job.h +--- cups-1.3.5/scheduler/job.h.1.3.x 2007-08-01 20:02:47.000000000 +0100 ++++ cups-1.3.5/scheduler/job.h 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * Print job definitions for the Common UNIX Printing System (CUPS) scheduler. + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2007 by Easy Software Products, all rights reserved. + * + * These coded instructions, statements, and computer programs are the +@@ -122,7 +122,7 @@ extern void cupsdSetJobHoldUntil(cupsd_ + extern void cupsdSetJobPriority(cupsd_job_t *job, int priority); + extern void cupsdStopAllJobs(int force); + extern void cupsdStopJob(cupsd_job_t *job, int force); +-extern void cupsdTimeoutJob(cupsd_job_t *job); ++extern int cupsdTimeoutJob(cupsd_job_t *job); + extern void cupsdUnloadCompletedJobs(void); + + +diff -up cups-1.3.5/scheduler/cups-lpd.c.1.3.x cups-1.3.5/scheduler/cups-lpd.c +--- cups-1.3.5/scheduler/cups-lpd.c.1.3.x 2007-08-08 22:09:31.000000000 +0100 ++++ cups-1.3.5/scheduler/cups-lpd.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * Line Printer Daemon interface for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2006 by Easy Software Products, all rights reserved. + * + * These coded instructions, statements, and computer programs are the +@@ -1274,9 +1274,9 @@ recv_print_job( + if (status) + break; + } +- +- fclose(fp); + } ++ ++ fclose(fp); + } + } + +diff -up cups-1.3.5/scheduler/client.c.1.3.x cups-1.3.5/scheduler/client.c +--- cups-1.3.5/scheduler/client.c.1.3.x 2007-09-28 20:47:00.000000000 +0100 ++++ cups-1.3.5/scheduler/client.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * Client routines for the Common UNIX Printing System (CUPS) scheduler. + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2007 by Easy Software Products, all rights reserved. + * + * This file contains Kerberos support code, copyright 2006 by +@@ -144,9 +144,19 @@ cupsdAcceptClient(cupsd_listener_t *lis) + Clients = cupsArrayNew(NULL, NULL); + + if (!Clients) ++ { ++ cupsdLogMessage(CUPSD_LOG_ERROR, ++ "Unable to allocate memory for client array!"); ++ cupsdPauseListening(); + return; ++ } + +- con = calloc(1, sizeof(cupsd_client_t)); ++ if ((con = calloc(1, sizeof(cupsd_client_t))) == NULL) ++ { ++ cupsdLogMessage(CUPSD_LOG_ERROR, "Unable to allocate memory for client!"); ++ cupsdPauseListening(); ++ return; ++ } + + con->http.activity = time(NULL); + con->file = -1; +@@ -843,7 +853,7 @@ cupsdReadClient(cupsd_client_t *con) /* + cupsdLogMessage(CUPSD_LOG_ERROR, + "Bad request line \"%s\" from %s!", line, + con->http.hostname); +- cupsdSendError(con, HTTP_BAD_REQUEST, AUTH_NONE); ++ cupsdSendError(con, HTTP_BAD_REQUEST, CUPSD_AUTH_NONE); + cupsdCloseClient(con); + return; + case 2 : +@@ -855,7 +865,7 @@ cupsdReadClient(cupsd_client_t *con) /* + cupsdLogMessage(CUPSD_LOG_ERROR, + "Bad request line \"%s\" from %s!", line, + con->http.hostname); +- cupsdSendError(con, HTTP_BAD_REQUEST, AUTH_NONE); ++ cupsdSendError(con, HTTP_BAD_REQUEST, CUPSD_AUTH_NONE); + cupsdCloseClient(con); + return; + } +@@ -870,7 +880,7 @@ cupsdReadClient(cupsd_client_t *con) /* + } + else + { +- cupsdSendError(con, HTTP_NOT_SUPPORTED, AUTH_NONE); ++ cupsdSendError(con, HTTP_NOT_SUPPORTED, CUPSD_AUTH_NONE); + cupsdCloseClient(con); + return; + } +@@ -916,7 +926,7 @@ cupsdReadClient(cupsd_client_t *con) /* + + cupsdLogMessage(CUPSD_LOG_ERROR, "Bad URI \"%s\" in request!", + con->uri); +- cupsdSendError(con, HTTP_METHOD_NOT_ALLOWED, AUTH_NONE); ++ cupsdSendError(con, HTTP_METHOD_NOT_ALLOWED, CUPSD_AUTH_NONE); + cupsdCloseClient(con); + return; + } +@@ -950,7 +960,7 @@ cupsdReadClient(cupsd_client_t *con) /* + else + { + cupsdLogMessage(CUPSD_LOG_ERROR, "Bad operation \"%s\"!", operation); +- cupsdSendError(con, HTTP_BAD_REQUEST, AUTH_NONE); ++ cupsdSendError(con, HTTP_BAD_REQUEST, CUPSD_AUTH_NONE); + cupsdCloseClient(con); + return; + } +@@ -982,7 +992,7 @@ cupsdReadClient(cupsd_client_t *con) /* + + if (status != HTTP_OK && status != HTTP_CONTINUE) + { +- cupsdSendError(con, HTTP_BAD_REQUEST, AUTH_NONE); ++ cupsdSendError(con, HTTP_BAD_REQUEST, CUPSD_AUTH_NONE); + cupsdCloseClient(con); + return; + } +@@ -1050,7 +1060,7 @@ cupsdReadClient(cupsd_client_t *con) /* + * HTTP/1.1 and higher require the "Host:" field... + */ + +- if (!cupsdSendError(con, HTTP_BAD_REQUEST, AUTH_NONE)) ++ if (!cupsdSendError(con, HTTP_BAD_REQUEST, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -1062,9 +1072,9 @@ cupsdReadClient(cupsd_client_t *con) /* + * Do OPTIONS command... + */ + +- if (con->best && con->best->type != AUTH_NONE) ++ if (con->best && con->best->type != CUPSD_AUTH_NONE) + { +- if (!cupsdSendHeader(con, HTTP_UNAUTHORIZED, NULL, AUTH_NONE)) ++ if (!cupsdSendHeader(con, HTTP_UNAUTHORIZED, NULL, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -1079,7 +1089,7 @@ cupsdReadClient(cupsd_client_t *con) /* + * Do encryption stuff... + */ + +- if (!cupsdSendHeader(con, HTTP_SWITCHING_PROTOCOLS, NULL, AUTH_NONE)) ++ if (!cupsdSendHeader(con, HTTP_SWITCHING_PROTOCOLS, NULL, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -1102,7 +1112,7 @@ cupsdReadClient(cupsd_client_t *con) /* + return; + } + #else +- if (!cupsdSendError(con, HTTP_NOT_IMPLEMENTED, AUTH_NONE)) ++ if (!cupsdSendError(con, HTTP_NOT_IMPLEMENTED, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -1110,7 +1120,7 @@ cupsdReadClient(cupsd_client_t *con) /* + #endif /* HAVE_SSL */ + } + +- if (!cupsdSendHeader(con, HTTP_OK, NULL, AUTH_NONE)) ++ if (!cupsdSendHeader(con, HTTP_OK, NULL, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -1132,7 +1142,7 @@ cupsdReadClient(cupsd_client_t *con) /* + * Protect against malicious users! + */ + +- if (!cupsdSendError(con, HTTP_FORBIDDEN, AUTH_NONE)) ++ if (!cupsdSendError(con, HTTP_FORBIDDEN, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -1148,7 +1158,7 @@ cupsdReadClient(cupsd_client_t *con) /* + * Do encryption stuff... + */ + +- if (!cupsdSendHeader(con, HTTP_SWITCHING_PROTOCOLS, NULL, AUTH_NONE)) ++ if (!cupsdSendHeader(con, HTTP_SWITCHING_PROTOCOLS, NULL, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -1171,7 +1181,7 @@ cupsdReadClient(cupsd_client_t *con) /* + return; + } + #else +- if (!cupsdSendError(con, HTTP_NOT_IMPLEMENTED, AUTH_NONE)) ++ if (!cupsdSendError(con, HTTP_NOT_IMPLEMENTED, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -1184,7 +1194,7 @@ cupsdReadClient(cupsd_client_t *con) /* + cupsdLogMessage(CUPSD_LOG_DEBUG2, + "cupsdReadClient: Unauthorized request for %s...\n", + con->uri); +- cupsdSendError(con, status, AUTH_NONE); ++ cupsdSendError(con, status, CUPSD_AUTH_NONE); + cupsdCloseClient(con); + return; + } +@@ -1198,7 +1208,7 @@ cupsdReadClient(cupsd_client_t *con) /* + * Send 100-continue header... + */ + +- if (!cupsdSendHeader(con, HTTP_CONTINUE, NULL, AUTH_NONE)) ++ if (!cupsdSendHeader(con, HTTP_CONTINUE, NULL, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -1210,7 +1220,7 @@ cupsdReadClient(cupsd_client_t *con) /* + * Send 417-expectation-failed header... + */ + +- if (!cupsdSendHeader(con, HTTP_EXPECTATION_FAILED, NULL, AUTH_NONE)) ++ if (!cupsdSendHeader(con, HTTP_EXPECTATION_FAILED, NULL, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -1244,7 +1254,7 @@ cupsdReadClient(cupsd_client_t *con) /* + snprintf(con->uri, sizeof(con->uri), "/ppd/%s.ppd", p->name); + else + { +- if (!cupsdSendError(con, HTTP_NOT_FOUND, AUTH_NONE)) ++ if (!cupsdSendError(con, HTTP_NOT_FOUND, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -1316,7 +1326,7 @@ cupsdReadClient(cupsd_client_t *con) /* + + if (!cupsdSendCommand(con, con->command, con->options, 0)) + { +- if (!cupsdSendError(con, HTTP_NOT_FOUND, AUTH_NONE)) ++ if (!cupsdSendError(con, HTTP_NOT_FOUND, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -1340,7 +1350,7 @@ cupsdReadClient(cupsd_client_t *con) /* + * /admin/conf... + */ + +- if (!cupsdSendError(con, HTTP_FORBIDDEN, AUTH_NONE)) ++ if (!cupsdSendError(con, HTTP_FORBIDDEN, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -1357,7 +1367,7 @@ cupsdReadClient(cupsd_client_t *con) /* + if ((filename = get_file(con, &filestats, buf, + sizeof(buf))) == NULL) + { +- if (!cupsdSendError(con, HTTP_NOT_FOUND, AUTH_NONE)) ++ if (!cupsdSendError(con, HTTP_NOT_FOUND, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -1377,7 +1387,7 @@ cupsdReadClient(cupsd_client_t *con) /* + + if (!cupsdSendCommand(con, con->command, con->options, 0)) + { +- if (!cupsdSendError(con, HTTP_NOT_FOUND, AUTH_NONE)) ++ if (!cupsdSendError(con, HTTP_NOT_FOUND, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -1393,7 +1403,7 @@ cupsdReadClient(cupsd_client_t *con) /* + + if (!check_if_modified(con, &filestats)) + { +- if (!cupsdSendError(con, HTTP_NOT_MODIFIED, AUTH_NONE)) ++ if (!cupsdSendError(con, HTTP_NOT_MODIFIED, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -1433,7 +1443,7 @@ cupsdReadClient(cupsd_client_t *con) /* + * Request too large... + */ + +- if (!cupsdSendError(con, HTTP_REQUEST_TOO_LARGE, AUTH_NONE)) ++ if (!cupsdSendError(con, HTTP_REQUEST_TOO_LARGE, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -1447,7 +1457,7 @@ cupsdReadClient(cupsd_client_t *con) /* + * Negative content lengths are invalid! + */ + +- if (!cupsdSendError(con, HTTP_BAD_REQUEST, AUTH_NONE)) ++ if (!cupsdSendError(con, HTTP_BAD_REQUEST, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -1542,7 +1552,7 @@ cupsdReadClient(cupsd_client_t *con) /* + if ((filename = get_file(con, &filestats, buf, + sizeof(buf))) == NULL) + { +- if (!cupsdSendError(con, HTTP_NOT_FOUND, AUTH_NONE)) ++ if (!cupsdSendError(con, HTTP_NOT_FOUND, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -1559,7 +1569,7 @@ cupsdReadClient(cupsd_client_t *con) /* + * Only POST to CGI's... + */ + +- if (!cupsdSendError(con, HTTP_UNAUTHORIZED, AUTH_NONE)) ++ if (!cupsdSendError(con, HTTP_UNAUTHORIZED, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -1582,7 +1592,7 @@ cupsdReadClient(cupsd_client_t *con) /* + * /admin/conf... + */ + +- if (!cupsdSendError(con, HTTP_FORBIDDEN, AUTH_NONE)) ++ if (!cupsdSendError(con, HTTP_FORBIDDEN, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -1608,7 +1618,7 @@ cupsdReadClient(cupsd_client_t *con) /* + * Request too large... + */ + +- if (!cupsdSendError(con, HTTP_REQUEST_TOO_LARGE, AUTH_NONE)) ++ if (!cupsdSendError(con, HTTP_REQUEST_TOO_LARGE, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -1622,7 +1632,7 @@ cupsdReadClient(cupsd_client_t *con) /* + * Negative content lengths are invalid! + */ + +- if (!cupsdSendError(con, HTTP_BAD_REQUEST, AUTH_NONE)) ++ if (!cupsdSendError(con, HTTP_BAD_REQUEST, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -1639,19 +1649,23 @@ cupsdReadClient(cupsd_client_t *con) /* + request_id ++); + con->file = open(con->filename, O_WRONLY | O_CREAT | O_TRUNC, 0640); + +- cupsdLogMessage(CUPSD_LOG_DEBUG2, +- "cupsdReadClient: %d REQUEST %s=%d", con->http.fd, +- con->filename, con->file); +- + if (con->file < 0) + { +- if (!cupsdSendError(con, HTTP_REQUEST_TOO_LARGE, AUTH_NONE)) ++ cupsdLogMessage(CUPSD_LOG_ERROR, ++ "Unable to create request file %s: %s", ++ con->filename, strerror(errno)); ++ ++ if (!cupsdSendError(con, HTTP_REQUEST_TOO_LARGE, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; + } + } + ++ cupsdLogMessage(CUPSD_LOG_DEBUG2, ++ "cupsdReadClient: %d REQUEST %s=%d", con->http.fd, ++ con->filename, con->file); ++ + fchmod(con->file, 0640); + fchown(con->file, RunUser, Group); + fcntl(con->file, F_SETFD, fcntl(con->file, F_GETFD) | FD_CLOEXEC); +@@ -1659,7 +1673,7 @@ cupsdReadClient(cupsd_client_t *con) /* + + case HTTP_DELETE : + case HTTP_TRACE : +- cupsdSendError(con, HTTP_NOT_IMPLEMENTED, AUTH_NONE); ++ cupsdSendError(con, HTTP_NOT_IMPLEMENTED, CUPSD_AUTH_NONE); + cupsdCloseClient(con); + return; + +@@ -1678,7 +1692,7 @@ cupsdReadClient(cupsd_client_t *con) /* + snprintf(con->uri, sizeof(con->uri), "/ppd/%s.ppd", p->name); + else + { +- if (!cupsdSendError(con, HTTP_NOT_FOUND, AUTH_NONE)) ++ if (!cupsdSendError(con, HTTP_NOT_FOUND, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -1700,7 +1714,7 @@ cupsdReadClient(cupsd_client_t *con) /* + * CGI output... + */ + +- if (!cupsdSendHeader(con, HTTP_OK, "text/html", AUTH_NONE)) ++ if (!cupsdSendHeader(con, HTTP_OK, "text/html", CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -1732,7 +1746,7 @@ cupsdReadClient(cupsd_client_t *con) /* + * /admin/conf... + */ + +- if (!cupsdSendError(con, HTTP_FORBIDDEN, AUTH_NONE)) ++ if (!cupsdSendError(con, HTTP_FORBIDDEN, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -1743,7 +1757,7 @@ cupsdReadClient(cupsd_client_t *con) /* + else if ((filename = get_file(con, &filestats, buf, + sizeof(buf))) == NULL) + { +- if (!cupsdSendHeader(con, HTTP_NOT_FOUND, "text/html", AUTH_NONE)) ++ if (!cupsdSendHeader(con, HTTP_NOT_FOUND, "text/html", CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -1753,7 +1767,7 @@ cupsdReadClient(cupsd_client_t *con) /* + } + else if (!check_if_modified(con, &filestats)) + { +- if (!cupsdSendError(con, HTTP_NOT_MODIFIED, AUTH_NONE)) ++ if (!cupsdSendError(con, HTTP_NOT_MODIFIED, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -1773,7 +1787,7 @@ cupsdReadClient(cupsd_client_t *con) /* + else + snprintf(line, sizeof(line), "%s/%s", type->super, type->type); + +- if (!cupsdSendHeader(con, HTTP_OK, line, AUTH_NONE)) ++ if (!cupsdSendHeader(con, HTTP_OK, line, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -1862,7 +1876,7 @@ cupsdReadClient(cupsd_client_t *con) /* + unlink(con->filename); + cupsdClearString(&con->filename); + +- if (!cupsdSendError(con, HTTP_REQUEST_TOO_LARGE, AUTH_NONE)) ++ if (!cupsdSendError(con, HTTP_REQUEST_TOO_LARGE, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -1902,7 +1916,7 @@ cupsdReadClient(cupsd_client_t *con) /* + unlink(con->filename); + cupsdClearString(&con->filename); + +- if (!cupsdSendError(con, HTTP_REQUEST_TOO_LARGE, AUTH_NONE)) ++ if (!cupsdSendError(con, HTTP_REQUEST_TOO_LARGE, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -1919,7 +1933,7 @@ cupsdReadClient(cupsd_client_t *con) /* + * Return the status to the client... + */ + +- if (!cupsdSendError(con, status, AUTH_NONE)) ++ if (!cupsdSendError(con, status, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -1950,7 +1964,7 @@ cupsdReadClient(cupsd_client_t *con) /* + "cupsdReadClient: %d IPP Read Error!", + con->http.fd); + +- cupsdSendError(con, HTTP_BAD_REQUEST, AUTH_NONE); ++ cupsdSendError(con, HTTP_BAD_REQUEST, CUPSD_AUTH_NONE); + cupsdCloseClient(con); + return; + } +@@ -1958,7 +1972,7 @@ cupsdReadClient(cupsd_client_t *con) /* + { + if (con->http.state == HTTP_POST_SEND) + { +- cupsdSendError(con, HTTP_BAD_REQUEST, AUTH_NONE); ++ cupsdSendError(con, HTTP_BAD_REQUEST, CUPSD_AUTH_NONE); + cupsdCloseClient(con); + return; + } +@@ -1978,18 +1992,22 @@ cupsdReadClient(cupsd_client_t *con) /* + cupsdSetStringf(&con->filename, "%s/%08x", RequestRoot, request_id ++); + con->file = open(con->filename, O_WRONLY | O_CREAT | O_TRUNC, 0640); + +- cupsdLogMessage(CUPSD_LOG_DEBUG2, "cupsdReadClient: %d REQUEST %s=%d", con->http.fd, +- con->filename, con->file); +- + if (con->file < 0) + { +- if (!cupsdSendError(con, HTTP_REQUEST_TOO_LARGE, AUTH_NONE)) ++ cupsdLogMessage(CUPSD_LOG_ERROR, ++ "Unable to create request file %s: %s", ++ con->filename, strerror(errno)); ++ ++ if (!cupsdSendError(con, HTTP_REQUEST_TOO_LARGE, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; + } + } + ++ cupsdLogMessage(CUPSD_LOG_DEBUG2, "cupsdReadClient: %d REQUEST %s=%d", con->http.fd, ++ con->filename, con->file); ++ + fchmod(con->file, 0640); + fchown(con->file, RunUser, Group); + fcntl(con->file, F_SETFD, fcntl(con->file, F_GETFD) | FD_CLOEXEC); +@@ -2025,7 +2043,7 @@ cupsdReadClient(cupsd_client_t *con) /* + unlink(con->filename); + cupsdClearString(&con->filename); + +- if (!cupsdSendError(con, HTTP_REQUEST_TOO_LARGE, AUTH_NONE)) ++ if (!cupsdSendError(con, HTTP_REQUEST_TOO_LARGE, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -2081,7 +2099,7 @@ cupsdReadClient(cupsd_client_t *con) /* + con->request = NULL; + } + +- if (!cupsdSendError(con, HTTP_REQUEST_TOO_LARGE, AUTH_NONE)) ++ if (!cupsdSendError(con, HTTP_REQUEST_TOO_LARGE, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -2092,7 +2110,7 @@ cupsdReadClient(cupsd_client_t *con) /* + { + if (!cupsdSendCommand(con, con->command, con->options, 0)) + { +- if (!cupsdSendError(con, HTTP_NOT_FOUND, AUTH_NONE)) ++ if (!cupsdSendError(con, HTTP_NOT_FOUND, CUPSD_AUTH_NONE)) + { + cupsdCloseClient(con); + return; +@@ -2232,7 +2250,7 @@ cupsdSendError(cupsd_client_t *con, /* I + * never disable it in that case. + */ + +- if (code >= HTTP_BAD_REQUEST && con->http.auth_type != AUTH_NEGOTIATE) ++ if (code >= HTTP_BAD_REQUEST && con->http.auth_type != CUPSD_AUTH_NEGOTIATE) + con->http.keep_alive = HTTP_KEEPALIVE_OFF; + + /* +@@ -2351,7 +2369,11 @@ cupsdSendHeader( + char *type, /* I - MIME type of document */ + int auth_type) /* I - Type of authentication */ + { +- char auth_str[1024]; /* Authorization string */ ++ char auth_str[1024]; /* Authorization string */ ++#ifdef HAVE_GSSAPI ++ static char *gss_buf = NULL; /* Kerberos auth data buffer */ ++ static int gss_bufsize = 0; /* Size of Kerberos auth data buffer */ ++#endif /* HAVE_GSSAPI */ + + + /* +@@ -2394,9 +2416,9 @@ cupsdSendHeader( + + if (code == HTTP_UNAUTHORIZED) + { +- if (auth_type == AUTH_NONE) ++ if (auth_type == CUPSD_AUTH_NONE) + { +- if (!con->best || con->best->type <= AUTH_NONE) ++ if (!con->best || con->best->type <= CUPSD_AUTH_NONE) + auth_type = DefaultAuthType; + else + auth_type = con->best->type; +@@ -2404,18 +2426,18 @@ cupsdSendHeader( + + auth_str[0] = '\0'; + +- if (auth_type == AUTH_BASIC || auth_type == AUTH_BASICDIGEST) ++ if (auth_type == CUPSD_AUTH_BASIC || auth_type == CUPSD_AUTH_BASICDIGEST) + strlcpy(auth_str, "Basic realm=\"CUPS\"", sizeof(auth_str)); +- else if (auth_type == AUTH_DIGEST) ++ else if (auth_type == CUPSD_AUTH_DIGEST) + snprintf(auth_str, sizeof(auth_str), "Digest realm=\"CUPS\", nonce=\"%s\"", + con->http.hostname); + #ifdef HAVE_GSSAPI +- else if (auth_type == AUTH_NEGOTIATE && con->gss_output_token.length == 0) ++ else if (auth_type == CUPSD_AUTH_NEGOTIATE && con->gss_output_token.length == 0) + strlcpy(auth_str, "Negotiate", sizeof(auth_str)); + #endif /* HAVE_GSSAPI */ + + #ifdef HAVE_AUTHORIZATION_H +- if (con->best && auth_type != AUTH_NEGOTIATE) ++ if (con->best && auth_type != CUPSD_AUTH_NEGOTIATE) + { + int i; /* Looping var */ + char *auth_key; /* Auth key buffer */ +@@ -2460,23 +2482,57 @@ cupsdSendHeader( + * non-401 replies... + */ + +- if (con->gss_output_token.length > 0) ++ if (con->gss_output_token.length > 0 && con->gss_output_token.length <= 65536) + { +- char buf[2048]; /* Output token buffer */ + OM_uint32 minor_status; /* Minor status code */ ++ int bufsize; /* Size of output token buffer */ ++ ++ ++ bufsize = con->gss_output_token.length * 4 / 3 + 2; ++ ++ if (bufsize > gss_bufsize) ++ { ++ char *buf; /* New buffer */ ++ ++ ++ bufsize = (bufsize + 1023) & 1023;/* Round up */ ++ ++ if (gss_buf) ++ buf = realloc(gss_buf, bufsize); ++ else ++ buf = malloc(bufsize); + ++ if (!buf) ++ { ++ cupsdLogMessage(CUPSD_LOG_ERROR, ++ "Unable to allocate %d bytes for Kerberos credentials!", ++ bufsize); ++ return (0); ++ } + +- httpEncode64_2(buf, sizeof(buf), +- con->gss_output_token.value, ++ gss_buf = buf; ++ gss_bufsize = bufsize; ++ } ++ ++ httpEncode64_2(gss_buf, gss_bufsize, ++ con->gss_output_token.value, + con->gss_output_token.length); + gss_release_buffer(&minor_status, &con->gss_output_token); + + cupsdLogMessage(CUPSD_LOG_DEBUG, +- "cupsdSendHeader: WWW-Authenticate: Negotiate %s", buf); ++ "cupsdSendHeader: WWW-Authenticate: Negotiate %s", gss_buf); + +- if (httpPrintf(HTTP(con), "WWW-Authenticate: Negotiate %s\r\n", buf) < 0) ++ if (httpPrintf(HTTP(con), "WWW-Authenticate: Negotiate %s\r\n", ++ gss_buf) < 0) + return (0); + } ++ else if (con->gss_output_token.length > 65536) ++ { ++ cupsdLogMessage(CUPSD_LOG_ERROR, ++ "Kerberos credentials larger than 64k (%d)!", ++ con->gss_output_token.length); ++ return (0); ++ } + #endif /* HAVE_GSSAPI */ + + if (con->language && strcmp(con->language->language, "C")) +@@ -2619,7 +2675,7 @@ cupsdWriteClient(cupsd_client_t *con) /* + + if (!strncasecmp(buf, "Location:", 9)) + { +- cupsdSendHeader(con, HTTP_SEE_OTHER, NULL, AUTH_NONE); ++ cupsdSendHeader(con, HTTP_SEE_OTHER, NULL, CUPSD_AUTH_NONE); + con->sent_header = 2; + + if (httpPrintf(HTTP(con), "Content-Length: 0\r\n") < 0) +@@ -2627,12 +2683,12 @@ cupsdWriteClient(cupsd_client_t *con) /* + } + else if (!strncasecmp(buf, "Status:", 7)) + { +- cupsdSendError(con, (http_status_t)atoi(buf + 7), AUTH_NONE); ++ cupsdSendError(con, (http_status_t)atoi(buf + 7), CUPSD_AUTH_NONE); + con->sent_header = 2; + } + else + { +- cupsdSendHeader(con, HTTP_OK, NULL, AUTH_NONE); ++ cupsdSendHeader(con, HTTP_OK, NULL, CUPSD_AUTH_NONE); + con->sent_header = 1; + + if (con->http.version == HTTP_1_1) +@@ -4220,7 +4276,7 @@ pipe_command(cupsd_client_t *con, /* I - + char argbuf[10240], /* Argument buffer */ + *argv[100], /* Argument strings */ + *envp[MAX_ENV + 20]; /* Environment variables */ +- char auth_type[256], /* AUTH_TYPE environment variable */ ++ char auth_type[256], /* CUPSD_AUTH_TYPE environment variable */ + content_length[1024], /* CONTENT_LENGTH environment variable */ + content_type[1024], /* CONTENT_TYPE environment variable */ + http_cookie[32768], /* HTTP_COOKIE environment variable */ +@@ -4236,6 +4292,10 @@ pipe_command(cupsd_client_t *con, /* I - + server_name[1024], /* SERVER_NAME environment variable */ + server_port[1024]; /* SERVER_PORT environment variable */ + ipp_attribute_t *attr; /* attributes-natural-language attribute */ ++#ifdef HAVE_GSSAPI ++ krb5_ccache ccache = NULL; /* Kerberos credentials */ ++ char krb5ccname[1024]; /* KRB5CCNAME environment variable */ ++#endif /* HAVE_GSSAPI */ + + + /* +@@ -4362,7 +4422,7 @@ pipe_command(cupsd_client_t *con, /* I - + + if (con->username[0]) + { +- snprintf(auth_type, sizeof(auth_type), "AUTH_TYPE=%s", ++ snprintf(auth_type, sizeof(auth_type), "CUPSD_AUTH_TYPE=%s", + httpGetField(HTTP(con), HTTP_FIELD_AUTHORIZATION)); + + if ((uriptr = strchr(auth_type + 10, ' ')) != NULL) +@@ -4455,6 +4515,120 @@ pipe_command(cupsd_client_t *con, /* I - + snprintf(remote_user, sizeof(remote_user), "REMOTE_USER=%s", con->username); + + envp[envc ++] = remote_user; ++ ++ /* ++ * Save Kerberos credentials, if any... ++ */ ++ ++#ifdef HAVE_GSSAPI ++ if (con->gss_have_creds) ++ { ++# if !defined(HAVE_KRB5_CC_NEW_UNIQUE) && !defined(HAVE_HEIMDAL) ++ cupsdLogMessage(CUPSD_LOG_INFO, ++ "Sorry, your version of Kerberos does not support " ++ "delegated credentials!"); ++ ++# else ++ krb5_error_code error; /* Kerberos error code */ ++ OM_uint32 major_status, /* Major status code */ ++ minor_status; /* Minor status code */ ++ krb5_principal principal; /* Kerberos principal */ ++ ++ ++# ifdef __APPLE__ ++ /* ++ * If the weak-linked GSSAPI/Kerberos library is not present, don't try ++ * to use it... ++ */ ++ ++ if (krb5_init_context != NULL) ++ { ++# endif /* __APPLE__ */ ++ ++ /* ++ * We MUST create a file-based cache because memory-based caches are ++ * only valid for the current process/address space. ++ * ++ * Due to various bugs/features in different versions of Kerberos, we ++ * need either the krb5_cc_new_unique() function or Heimdal's version ++ * of krb5_cc_gen_new() to create a new FILE: credential cache that ++ * can be passed to the backend. These functions create a temporary ++ * file (typically in /tmp) containing the cached credentials, which ++ * are removed when we have successfully printed a job. ++ */ ++ ++# ifdef HAVE_KRB5_CC_NEW_UNIQUE ++ if ((error = krb5_cc_new_unique(KerberosContext, "FILE", NULL, ++ &ccache)) != 0) ++# else /* HAVE_HEIMDAL */ ++ if ((error = krb5_cc_gen_new(KerberosContext, &krb5_fcc_ops, ++ &ccache)) != 0) ++# endif /* HAVE_KRB5_CC_NEW_UNIQUE */ ++ { ++ cupsdLogMessage(CUPSD_LOG_ERROR, ++ "Unable to create new credentials cache (%d/%s)", ++ error, strerror(errno)); ++ ccache = NULL; ++ } ++ else if ((error = krb5_parse_name(KerberosContext, con->username, ++ &principal)) != 0) ++ { ++ cupsdLogMessage(CUPSD_LOG_ERROR, ++ "Unable to parse kerberos username (%d/%s)", error, ++ strerror(errno)); ++ krb5_cc_destroy(KerberosContext, ccache); ++ ccache = NULL; ++ } ++ else if ((error = krb5_cc_initialize(KerberosContext, ccache, ++ principal))) ++ { ++ cupsdLogMessage(CUPSD_LOG_ERROR, ++ "Unable to initialize credentials cache (%d/%s)", error, ++ strerror(errno)); ++ krb5_cc_destroy(KerberosContext, ccache); ++ krb5_free_principal(KerberosContext, principal); ++ ccache = NULL; ++ } ++ else ++ { ++ krb5_free_principal(KerberosContext, principal); ++ ++ /* ++ * Copy the user's credentials to the new cache file... ++ */ ++ ++ major_status = gss_krb5_copy_ccache(&minor_status, ++ con->gss_delegated_cred, ccache); ++ ++ if (GSS_ERROR(major_status)) ++ { ++ cupsdLogGSSMessage(CUPSD_LOG_ERROR, major_status, minor_status, ++ "Unable to import client credentials cache"); ++ krb5_cc_destroy(KerberosContext, ccache); ++ ccache = NULL; ++ } ++ else ++ { ++ /* ++ * Add the KRB5CCNAME environment variable to the job so that the ++ * backend can use the credentials when printing. ++ */ ++ ++ snprintf(krb5ccname, sizeof(krb5ccname), "KRB5CCNAME=FILE:%s", ++ krb5_cc_get_name(KerberosContext, ccache)); ++ envp[envc++] = krb5ccname; ++ ++ if (!RunUser) ++ chown(krb5_cc_get_name(KerberosContext, ccache), User, Group); ++ } ++ } ++# ifdef __APPLE__ ++ } ++# endif /* __APPLE__ */ ++# endif /* HAVE_KRB5_CC_NEW_UNIQUE || HAVE_HEIMDAL */ ++ } ++#endif /* HAVE_GSSAPI */ ++ + } + + if (con->http.version == HTTP_1_1) +@@ -4568,7 +4742,11 @@ pipe_command(cupsd_client_t *con, /* I - + */ + + if (con->username[0]) +- cupsdAddCert(pid, con->username); ++#ifdef HAVE_GSSAPI ++ cupsdAddCert(pid, con->username, ccache); ++#else ++ cupsdAddCert(pid, con->username, NULL); ++#endif /* HAVE_GSSAPI */ + + cupsdLogMessage(CUPSD_LOG_DEBUG, "[CGI] %s started - PID = %d", + command, pid); +@@ -4604,7 +4782,7 @@ write_file(cupsd_client_t *con, /* I - + + con->pipe_pid = 0; + +- if (!cupsdSendHeader(con, code, type, AUTH_NONE)) ++ if (!cupsdSendHeader(con, code, type, CUPSD_AUTH_NONE)) + return (0); + + if (httpPrintf(HTTP(con), "Last-Modified: %s\r\n", +diff -up cups-1.3.5/scheduler/cups-polld.c.1.3.x cups-1.3.5/scheduler/cups-polld.c +--- cups-1.3.5/scheduler/cups-polld.c.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/scheduler/cups-polld.c 2008-02-05 15:08:55.000000000 +0000 +@@ -144,7 +144,7 @@ main(int argc, /* I - Number of comm + * Loop forever, asking for available printers and classes... + */ + +- for (http = NULL;;) ++ for (http = NULL; !ferror(stderr);) + { + /* + * Open a connection to the server... +@@ -180,6 +180,8 @@ main(int argc, /* I - Number of comm + if (remain > 0 && !restart_polling) + sleep(remain); + } ++ ++ return (1); + } + + +diff -up cups-1.3.5/scheduler/classes.c.1.3.x cups-1.3.5/scheduler/classes.c +--- cups-1.3.5/scheduler/classes.c.1.3.x 2007-11-30 03:37:11.000000000 +0000 ++++ cups-1.3.5/scheduler/classes.c 2008-02-05 15:08:55.000000000 +0000 +@@ -393,7 +393,7 @@ cupsdLoadAllClasses(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of classes.conf.", linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "")) +@@ -407,14 +407,14 @@ cupsdLoadAllClasses(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of classes.conf.", linenum); +- return; ++ break; + } + } + else if (!p) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of classes.conf.", linenum); +- return; ++ break; + } + else if (!strcasecmp(line, "AuthInfoRequired")) + { +@@ -458,7 +458,7 @@ cupsdLoadAllClasses(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of classes.conf.", linenum); +- return; ++ break; + } + else if ((temp = cupsdFindPrinter(value)) == NULL) + { +@@ -504,7 +504,7 @@ cupsdLoadAllClasses(void) + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of classes.conf.", + linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "StateMessage")) +@@ -546,7 +546,7 @@ cupsdLoadAllClasses(void) + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of classes.conf.", + linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "Shared")) +@@ -568,9 +568,9 @@ cupsdLoadAllClasses(void) + else + { + cupsdLogMessage(CUPSD_LOG_ERROR, +- "Syntax error on line %d of printers.conf.", ++ "Syntax error on line %d of classes.conf.", + linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "JobSheets")) +@@ -609,7 +609,7 @@ cupsdLoadAllClasses(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of classes.conf.", linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "AllowUser")) +@@ -623,7 +623,7 @@ cupsdLoadAllClasses(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of classes.conf.", linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "DenyUser")) +@@ -637,7 +637,7 @@ cupsdLoadAllClasses(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of classes.conf.", linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "QuotaPeriod")) +@@ -648,7 +648,7 @@ cupsdLoadAllClasses(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of classes.conf.", linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "PageLimit")) +@@ -659,7 +659,7 @@ cupsdLoadAllClasses(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of classes.conf.", linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "KLimit")) +@@ -670,7 +670,7 @@ cupsdLoadAllClasses(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of classes.conf.", linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "OpPolicy")) +@@ -694,7 +694,7 @@ cupsdLoadAllClasses(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of classes.conf.", linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "ErrorPolicy")) +@@ -705,7 +705,7 @@ cupsdLoadAllClasses(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of classes.conf.", linenum); +- return; ++ break; + } + } + else +diff -up cups-1.3.5/scheduler/cert.h.1.3.x cups-1.3.5/scheduler/cert.h +--- cups-1.3.5/scheduler/cert.h.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/scheduler/cert.h 2008-02-05 15:08:55.000000000 +0000 +@@ -4,7 +4,7 @@ + * Authentication certificate definitions for the Common UNIX + * Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2005 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -24,6 +24,9 @@ typedef struct cupsd_cert_s + int pid; /* Process ID (0 for root certificate) */ + char certificate[33]; /* 32 hex characters, or 128 bits */ + char username[33]; /* Authenticated username */ ++#ifdef HAVE_GSSAPI ++ krb5_ccache ccache; /* Kerberos credential cache */ ++#endif /* HAVE_GSSAPI */ + } cupsd_cert_t; + + +@@ -39,7 +42,8 @@ VAR time_t RootCertTime; /* Root certif + * Prototypes... + */ + +-extern void cupsdAddCert(int pid, const char *username); ++extern void cupsdAddCert(int pid, const char *username, ++ void *ccache); + extern void cupsdDeleteCert(int pid); + extern void cupsdDeleteAllCerts(void); + extern const char *cupsdFindCert(const char *certificate); +diff -up cups-1.3.5/scheduler/policy.c.1.3.x cups-1.3.5/scheduler/policy.c +--- cups-1.3.5/scheduler/policy.c.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/scheduler/policy.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * Policy routines for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2006 by Easy Software Products, all rights reserved. + * + * These coded instructions, statements, and computer programs are the +@@ -105,7 +105,7 @@ cupsdAddPolicyOp(cupsd_policy_t *p, /* + p->num_ops ++; + + temp->op = op; +- temp->limit = AUTH_LIMIT_IPP; ++ temp->limit = CUPSD_AUTH_LIMIT_IPP; + + if (po) + { +@@ -125,12 +125,12 @@ cupsdAddPolicyOp(cupsd_policy_t *p, /* + for (i = 0; i < po->num_allow; i ++) + switch (po->allow[i].type) + { +- case AUTH_IP : ++ case CUPSD_AUTH_IP : + cupsdAllowIP(temp, po->allow[i].mask.ip.address, + po->allow[i].mask.ip.netmask); + break; + +- case AUTH_INTERFACE : ++ case CUPSD_AUTH_INTERFACE : + snprintf(name, sizeof(name), "@IF(%s)", + po->allow[i].mask.name.name); + cupsdAllowHost(temp, name); +@@ -144,12 +144,12 @@ cupsdAddPolicyOp(cupsd_policy_t *p, /* + for (i = 0; i < po->num_deny; i ++) + switch (po->deny[i].type) + { +- case AUTH_IP : ++ case CUPSD_AUTH_IP : + cupsdDenyIP(temp, po->deny[i].mask.ip.address, + po->deny[i].mask.ip.netmask); + break; + +- case AUTH_INTERFACE : ++ case CUPSD_AUTH_INTERFACE : + snprintf(name, sizeof(name), "@IF(%s)", + po->deny[i].mask.name.name); + cupsdDenyHost(temp, name); +diff -up cups-1.3.5/scheduler/auth.h.1.3.x cups-1.3.5/scheduler/auth.h +--- cups-1.3.5/scheduler/auth.h.1.3.x 2007-08-08 21:50:42.000000000 +0100 ++++ cups-1.3.5/scheduler/auth.h 2008-02-05 15:08:55.000000000 +0000 +@@ -4,7 +4,7 @@ + * Authorization definitions for the Common UNIX Printing System (CUPS) + * scheduler. + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2006 by Easy Software Products, all rights reserved. + * + * These coded instructions, statements, and computer programs are the +@@ -25,36 +25,36 @@ + * HTTP authorization types and levels... + */ + +-#define AUTH_DEFAULT -1 /* Use DefaultAuthType */ +-#define AUTH_NONE 0 /* No authentication */ +-#define AUTH_BASIC 1 /* Basic authentication */ +-#define AUTH_DIGEST 2 /* Digest authentication */ +-#define AUTH_BASICDIGEST 3 /* Basic authentication w/passwd.md5 */ +-#define AUTH_NEGOTIATE 4 /* Kerberos authentication */ +- +-#define AUTH_ANON 0 /* Anonymous access */ +-#define AUTH_USER 1 /* Must have a valid username/password */ +-#define AUTH_GROUP 2 /* Must also be in a named group */ +- +-#define AUTH_ALLOW 0 /* Allow access */ +-#define AUTH_DENY 1 /* Deny access */ +- +-#define AUTH_NAME 0 /* Authorize host by name */ +-#define AUTH_IP 1 /* Authorize host by IP */ +-#define AUTH_INTERFACE 2 /* Authorize host by interface */ +- +-#define AUTH_SATISFY_ALL 0 /* Satisfy both address and auth */ +-#define AUTH_SATISFY_ANY 1 /* Satisfy either address or auth */ +- +-#define AUTH_LIMIT_DELETE 1 /* Limit DELETE requests */ +-#define AUTH_LIMIT_GET 2 /* Limit GET requests */ +-#define AUTH_LIMIT_HEAD 4 /* Limit HEAD requests */ +-#define AUTH_LIMIT_OPTIONS 8 /* Limit OPTIONS requests */ +-#define AUTH_LIMIT_POST 16 /* Limit POST requests */ +-#define AUTH_LIMIT_PUT 32 /* Limit PUT requests */ +-#define AUTH_LIMIT_TRACE 64 /* Limit TRACE requests */ +-#define AUTH_LIMIT_ALL 127 /* Limit all requests */ +-#define AUTH_LIMIT_IPP 128 /* Limit IPP requests */ ++#define CUPSD_AUTH_DEFAULT -1 /* Use DefaultAuthType */ ++#define CUPSD_AUTH_NONE 0 /* No authentication */ ++#define CUPSD_AUTH_BASIC 1 /* Basic authentication */ ++#define CUPSD_AUTH_DIGEST 2 /* Digest authentication */ ++#define CUPSD_AUTH_BASICDIGEST 3 /* Basic authentication w/passwd.md5 */ ++#define CUPSD_AUTH_NEGOTIATE 4 /* Kerberos authentication */ ++ ++#define CUPSD_AUTH_ANON 0 /* Anonymous access */ ++#define CUPSD_AUTH_USER 1 /* Must have a valid username/password */ ++#define CUPSD_AUTH_GROUP 2 /* Must also be in a named group */ ++ ++#define CUPSD_AUTH_ALLOW 0 /* Allow access */ ++#define CUPSD_AUTH_DENY 1 /* Deny access */ ++ ++#define CUPSD_AUTH_NAME 0 /* Authorize host by name */ ++#define CUPSD_AUTH_IP 1 /* Authorize host by IP */ ++#define CUPSD_AUTH_INTERFACE 2 /* Authorize host by interface */ ++ ++#define CUPSD_AUTH_SATISFY_ALL 0 /* Satisfy both address and auth */ ++#define CUPSD_AUTH_SATISFY_ANY 1 /* Satisfy either address or auth */ ++ ++#define CUPSD_AUTH_LIMIT_DELETE 1 /* Limit DELETE requests */ ++#define CUPSD_AUTH_LIMIT_GET 2 /* Limit GET requests */ ++#define CUPSD_AUTH_LIMIT_HEAD 4 /* Limit HEAD requests */ ++#define CUPSD_AUTH_LIMIT_OPTIONS 8 /* Limit OPTIONS requests */ ++#define CUPSD_AUTH_LIMIT_POST 16 /* Limit POST requests */ ++#define CUPSD_AUTH_LIMIT_PUT 32 /* Limit PUT requests */ ++#define CUPSD_AUTH_LIMIT_TRACE 64 /* Limit TRACE requests */ ++#define CUPSD_AUTH_LIMIT_ALL 127 /* Limit all requests */ ++#define CUPSD_AUTH_LIMIT_IPP 128 /* Limit IPP requests */ + + #define IPP_ANY_OPERATION (ipp_op_t)0 + /* Any IPP operation */ +@@ -116,7 +116,7 @@ typedef struct cupsd_client_s cupsd_clie + + VAR cups_array_t *Locations VALUE(NULL); + /* Authorization locations */ +-VAR int DefaultAuthType VALUE(AUTH_BASIC); ++VAR int DefaultAuthType VALUE(CUPSD_AUTH_BASIC); + /* Default AuthType, if not specified */ + #ifdef HAVE_SSL + VAR http_encryption_t DefaultEncryption VALUE(HTTP_ENCRYPT_REQUIRED); +diff -up cups-1.3.5/scheduler/subscriptions.h.1.3.x cups-1.3.5/scheduler/subscriptions.h +--- cups-1.3.5/scheduler/subscriptions.h.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/scheduler/subscriptions.h 2008-02-05 15:08:55.000000000 +0000 +@@ -20,47 +20,52 @@ + typedef enum + { + /* Individual printer events... */ +- CUPSD_EVENT_PRINTER_RESTARTED = 0x0001, ++ CUPSD_EVENT_PRINTER_STATE = 0x0001, /* Sent after generic printer state change */ ++ CUPSD_EVENT_PRINTER_RESTARTED = 0x0002, + /* Sent after printer restarted */ +- CUPSD_EVENT_PRINTER_SHUTDOWN = 0x0002,/* Sent after printer shutdown */ +- CUPSD_EVENT_PRINTER_STOPPED = 0x0004, /* Sent after printer stopped */ +- CUPSD_EVENT_PRINTER_FINISHINGS_CHANGED = 0x0008, ++ CUPSD_EVENT_PRINTER_SHUTDOWN = 0x0004,/* Sent after printer shutdown */ ++ CUPSD_EVENT_PRINTER_STOPPED = 0x0008, /* Sent after printer stopped */ ++ ++ CUPSD_EVENT_PRINTER_CONFIG = 0x0010, /* Send after add/modify changes attrs */ ++ CUPSD_EVENT_PRINTER_FINISHINGS_CHANGED = 0x0020, + /* Sent after finishings-supported changed */ +- CUPSD_EVENT_PRINTER_MEDIA_CHANGED = 0x0010, ++ CUPSD_EVENT_PRINTER_MEDIA_CHANGED = 0x0040, + /* Sent after media-supported changed */ +- CUPSD_EVENT_PRINTER_ADDED = 0x0020, /* Sent after printer added */ +- CUPSD_EVENT_PRINTER_DELETED = 0x0040, /* Sent after printer deleted */ +- CUPSD_EVENT_PRINTER_MODIFIED = 0x0080,/* Sent after printer modified */ ++ CUPSD_EVENT_PRINTER_ADDED = 0x0080, /* Sent after printer added */ ++ CUPSD_EVENT_PRINTER_DELETED = 0x0100, /* Sent after printer deleted */ ++ CUPSD_EVENT_PRINTER_MODIFIED = 0x0200,/* Sent after printer modified */ ++ CUPSD_EVENT_PRINTER_QUEUE_ORDER_CHANGED = 0x0400, ++ /* Sent when the order of jobs is changed */ + + /* Convenience printer event groupings... */ +- CUPSD_EVENT_PRINTER_STATE_CHANGED = 0x0007, +- /* RESTARTED + SHUTDOWN + STOPPED */ +- CUPSD_EVENT_PRINTER_CONFIG_CHANGED = 0x0018, +- /* FINISHINGS_CHANGED + MEDIA_CHANGED */ +- CUPSD_EVENT_PRINTER_CHANGED = 0x00ff, /* All of the above */ ++ CUPSD_EVENT_PRINTER_STATE_CHANGED = 0x000f, ++ /* STATE + RESTARTED + SHUTDOWN + STOPPED */ ++ CUPSD_EVENT_PRINTER_CONFIG_CHANGED = 0x0070, ++ /* CONFIG + FINISHINGS_CHANGED + MEDIA_CHANGED */ ++ CUPSD_EVENT_PRINTER_CHANGED = 0x07ff, /* All of the above */ + + /* Individual job events... */ +- CUPSD_EVENT_JOB_STATE = 0x0100, /* Any state change */ +- CUPSD_EVENT_JOB_CREATED = 0x0200, /* Send after job is created */ +- CUPSD_EVENT_JOB_COMPLETED = 0x0400, /* Sent after job is completed */ +- CUPSD_EVENT_JOB_STOPPED = 0x0800, /* Sent after job is stopped */ +- CUPSD_EVENT_JOB_CONFIG_CHANGED = 0x1000, ++ CUPSD_EVENT_JOB_STATE = 0x0800, /* Any state change */ ++ CUPSD_EVENT_JOB_CREATED = 0x1000, /* Send after job is created */ ++ CUPSD_EVENT_JOB_COMPLETED = 0x2000, /* Sent after job is completed */ ++ CUPSD_EVENT_JOB_STOPPED = 0x4000, /* Sent after job is stopped */ ++ CUPSD_EVENT_JOB_CONFIG_CHANGED = 0x8000, + /* Sent after set-job-attributes */ +- CUPSD_EVENT_JOB_PROGRESS = 0x2000, /* Sent for each page */ ++ CUPSD_EVENT_JOB_PROGRESS = 0x10000, /* Sent for each page */ + + /* Convenience job event grouping... */ +- CUPSD_EVENT_JOB_STATE_CHANGED = 0x0f00, +- /* Any state change + CREATED + COMPLETED + STOPPED */ ++ CUPSD_EVENT_JOB_STATE_CHANGED = 0x7800, ++ /* STATE + CREATED + COMPLETED + STOPPED */ + + /* Server events... */ +- CUPSD_EVENT_SERVER_RESTARTED = 0x4000,/* Sent after server restarts */ +- CUPSD_EVENT_SERVER_STARTED = 0x8000, /* Sent when server first starts */ +- CUPSD_EVENT_SERVER_STOPPED = 0x10000, /* Sent when server is stopped */ +- CUPSD_EVENT_SERVER_AUDIT = 0x20000, /* Security-related stuff */ ++ CUPSD_EVENT_SERVER_RESTARTED = 0x20000,/* Sent after server restarts */ ++ CUPSD_EVENT_SERVER_STARTED = 0x40000, /* Sent when server first starts */ ++ CUPSD_EVENT_SERVER_STOPPED = 0x80000, /* Sent when server is stopped */ ++ CUPSD_EVENT_SERVER_AUDIT = 0x100000, /* Security-related stuff */ + + /* Everything and nothing... */ + CUPSD_EVENT_NONE = 0, /* Nothing */ +- CUPSD_EVENT_ALL = 0x1ffff /* Everything */ ++ CUPSD_EVENT_ALL = 0x1fffff /* Everything */ + } cupsd_eventmask_t; + + +diff -up cups-1.3.5/scheduler/job.c.1.3.x cups-1.3.5/scheduler/job.c +--- cups-1.3.5/scheduler/job.c.1.3.x 2007-11-27 00:09:24.000000000 +0000 ++++ cups-1.3.5/scheduler/job.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * Job management routines for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2007 by Easy Software Products, all rights reserved. + * + * These coded instructions, statements, and computer programs are the +@@ -113,7 +113,8 @@ cupsdAddJob(int priority, /* I - + cupsd_job_t *job; /* New job record */ + + +- job = calloc(sizeof(cupsd_job_t), 1); ++ if ((job = calloc(sizeof(cupsd_job_t), 1)) == NULL) ++ return (NULL); + + job->id = NextJobId ++; + job->priority = priority; +@@ -376,7 +377,11 @@ cupsdCheckJobs(void) + job->hold_until < time(NULL)) + { + if (job->pending_timeout) +- cupsdTimeoutJob(job); /* Add trailing banner as needed */ ++ { ++ /* Add trailing banner as needed */ ++ if (cupsdTimeoutJob(job)) ++ continue; ++ } + + job->state->values[0].integer = IPP_JOB_PENDING; + job->state_value = IPP_JOB_PENDING; +@@ -1812,6 +1817,7 @@ free_job(cupsd_job_t *job) /* I - Job * + cupsdClearString(&job->auth_username); + cupsdClearString(&job->auth_domain); + cupsdClearString(&job->auth_password); ++ + #ifdef HAVE_GSSAPI + /* + * Destroy the credential cache and clear the KRB5CCNAME env var string. +@@ -2445,7 +2451,7 @@ start_job(cupsd_job_t *job, /* I - + title[IPP_MAX_NAME], + /* Job title string */ + copies[255], /* # copies string */ +- *envp[MAX_ENV + 15], ++ *envp[MAX_ENV + 16], + /* Environment variables */ + charset[255], /* CHARSET env variable */ + class_name[255],/* CLASS env variable */ +@@ -2458,6 +2464,10 @@ start_job(cupsd_job_t *job, /* I - + final_content_type[1024], + /* FINAL_CONTENT_TYPE env variable */ + lang[255], /* LANG env variable */ ++#ifdef __APPLE__ ++ apple_language[255], ++ /* APPLE_LANGUAGE env variable */ ++#endif /* __APPLE__ */ + ppd[1024], /* PPD env variable */ + printer_name[255], + /* PRINTER env variable */ +@@ -2514,7 +2524,7 @@ start_job(cupsd_job_t *job, /* I - + "[Job %d] Unable to convert file %d to printable format!", + job->current_file, job->id); + cupsdLogMessage(CUPSD_LOG_INFO, +- "Hint: Do you have ESP Ghostscript installed?"); ++ "Hint: Do you have Ghostscript installed?"); + + if (LogLevel < CUPSD_LOG_DEBUG) + cupsdLogMessage(CUPSD_LOG_INFO, +@@ -2964,6 +2974,17 @@ start_job(cupsd_job_t *job, /* I - + else + argv = calloc(8, sizeof(char *)); + ++ if (!argv) ++ { ++ cupsdLogMessage(CUPSD_LOG_ERROR, "Unable to allocate argument array!"); ++ cupsArrayDelete(filters); ++ ++ FilterLevel -= job->cost; ++ ++ cupsdStopPrinter(printer, 0); ++ return; ++ } ++ + sprintf(jobid, "%d", job->id); + + argv[0] = printer->name; +@@ -3000,6 +3021,12 @@ start_job(cupsd_job_t *job, /* I - + attr = ippFindAttribute(job->attrs, "attributes-natural-language", + IPP_TAG_LANGUAGE); + ++#ifdef __APPLE__ ++ strcpy(apple_language, "APPLE_LANGUAGE"); ++ _cupsAppleLanguage(attr->values[0].string.text, ++ apple_language + 15, sizeof(apple_language) - 15); ++#endif /* __APPLE__ */ ++ + switch (strlen(attr->values[0].string.text)) + { + default : +@@ -3060,6 +3087,9 @@ start_job(cupsd_job_t *job, /* I - + + envp[envc ++] = charset; + envp[envc ++] = lang; ++#ifdef __APPLE__ ++ envp[envc ++] = apple_language; ++#endif /* __APPLE__ */ + envp[envc ++] = ppd; + envp[envc ++] = rip_max_cache; + envp[envc ++] = content_type; +@@ -3114,8 +3144,8 @@ start_job(cupsd_job_t *job, /* I - + envp[envc] = NULL; + + for (i = 0; i < envc; i ++) +- if (!strncmp(envp[i], "AUTH_", 5)) +- cupsdLogMessage(CUPSD_LOG_DEBUG, "[Job %d] envp[%d]=\"AUTH_%c****\"", ++ if (!strncmp(envp[i], "CUPSD_AUTH_", 5)) ++ cupsdLogMessage(CUPSD_LOG_DEBUG, "[Job %d] envp[%d]=\"CUPSD_AUTH_%c****\"", + job->id, i, envp[i][5]); + else if (strncmp(envp[i], "DEVICE_URI=", 11)) + cupsdLogMessage(CUPSD_LOG_DEBUG, "[Job %d] envp[%d]=\"%s\"", +@@ -3321,7 +3351,7 @@ start_job(cupsd_job_t *job, /* I - + + if (strncmp(printer->device_uri, "file:", 5) != 0) + { +- if (job->current_file == 1) ++ if (job->current_file == 1 || printer->remote) + { + sscanf(printer->device_uri, "%254[^:]", method); + snprintf(command, sizeof(command), "%s/backend/%s", ServerBin, method); +@@ -3538,7 +3568,7 @@ update_job(cupsd_job_t *job) /* I - Job + * job sheet count... + */ + +- if (job->sheets != NULL) ++ if (job->sheets) + { + if (!strncasecmp(message, "total ", 6)) + { +@@ -3583,8 +3613,9 @@ update_job(cupsd_job_t *job) /* I - Job + + cupsdLogPage(job, message); + +- cupsdAddEvent(CUPSD_EVENT_JOB_PROGRESS, job->printer, job, +- "Printed %d page(s).", job->sheets->values[0].integer); ++ if (job->sheets) ++ cupsdAddEvent(CUPSD_EVENT_JOB_PROGRESS, job->printer, job, ++ "Printed %d page(s).", job->sheets->values[0].integer); + } + else if (loglevel == CUPSD_LOG_STATE) + { +@@ -3597,7 +3628,7 @@ update_job(cupsd_job_t *job) /* I - Job + { + cupsdSetPrinterReasons(job->printer, message); + cupsdAddPrinterHistory(job->printer); +- event |= CUPSD_EVENT_PRINTER_STATE_CHANGED; ++ event |= CUPSD_EVENT_PRINTER_STATE; + } + + update_job_attrs(job); +@@ -3626,14 +3657,42 @@ update_job(cupsd_job_t *job) /* I - Job + if ((attr = cupsGetOption("printer-alert", num_attrs, attrs)) != NULL) + { + cupsdSetString(&job->printer->alert, attr); +- event |= CUPSD_EVENT_PRINTER_STATE_CHANGED; ++ event |= CUPSD_EVENT_PRINTER_STATE; + } + + if ((attr = cupsGetOption("printer-alert-description", num_attrs, + attrs)) != NULL) + { + cupsdSetString(&job->printer->alert_description, attr); +- event |= CUPSD_EVENT_PRINTER_STATE_CHANGED; ++ event |= CUPSD_EVENT_PRINTER_STATE; ++ } ++ ++ if ((attr = cupsGetOption("marker-colors", num_attrs, attrs)) != NULL) ++ { ++ cupsdSetPrinterAttr(job->printer, "marker-colors", (char *)attr); ++ job->printer->marker_time = time(NULL); ++ event |= CUPSD_EVENT_PRINTER_STATE; ++ } ++ ++ if ((attr = cupsGetOption("marker-levels", num_attrs, attrs)) != NULL) ++ { ++ cupsdSetPrinterAttr(job->printer, "marker-levels", (char *)attr); ++ job->printer->marker_time = time(NULL); ++ event |= CUPSD_EVENT_PRINTER_STATE; ++ } ++ ++ if ((attr = cupsGetOption("marker-names", num_attrs, attrs)) != NULL) ++ { ++ cupsdSetPrinterAttr(job->printer, "marker-names", (char *)attr); ++ job->printer->marker_time = time(NULL); ++ event |= CUPSD_EVENT_PRINTER_STATE; ++ } ++ ++ if ((attr = cupsGetOption("marker-types", num_attrs, attrs)) != NULL) ++ { ++ cupsdSetPrinterAttr(job->printer, "marker-types", (char *)attr); ++ job->printer->marker_time = time(NULL); ++ event |= CUPSD_EVENT_PRINTER_STATE; + } + + cupsFreeOptions(num_attrs, attrs); +@@ -3650,7 +3709,7 @@ update_job(cupsd_job_t *job) /* I - Job + + cupsdSetString(&job->printer->recoverable, ptr); + cupsdAddPrinterHistory(job->printer); +- event |= CUPSD_EVENT_PRINTER_STATE_CHANGED; ++ event |= CUPSD_EVENT_PRINTER_STATE; + } + else if (!strncmp(message, "recovered:", 10)) + { +@@ -3663,7 +3722,7 @@ update_job(cupsd_job_t *job) /* I - Job + + cupsdSetString(&job->printer->recoverable, ptr); + cupsdAddPrinterHistory(job->printer); +- event |= CUPSD_EVENT_PRINTER_STATE_CHANGED; ++ event |= CUPSD_EVENT_PRINTER_STATE; + } + #endif /* __APPLE__ */ + else if (loglevel <= job->status_level) +@@ -3678,7 +3737,7 @@ update_job(cupsd_job_t *job) /* I - Job + strlcpy(job->printer->state_message, message, + sizeof(job->printer->state_message)); + cupsdAddPrinterHistory(job->printer); +- event |= CUPSD_EVENT_PRINTER_STATE_CHANGED; ++ event |= CUPSD_EVENT_PRINTER_STATE; + + update_job_attrs(job); + } +@@ -3687,8 +3746,8 @@ update_job(cupsd_job_t *job) /* I - Job + break; + } + +- if ((event & CUPSD_EVENT_PRINTER_STATE_CHANGED)) +- cupsdAddEvent(CUPSD_EVENT_PRINTER_STATE_CHANGED, job->printer, NULL, ++ if (event & CUPSD_EVENT_PRINTER_STATE) ++ cupsdAddEvent(CUPSD_EVENT_PRINTER_STATE, job->printer, NULL, + (job->printer->type & CUPS_PRINTER_CLASS) ? + "Class \"%s\" state changed." : + "Printer \"%s\" state changed.", +diff -up cups-1.3.5/scheduler/type.c.1.3.x cups-1.3.5/scheduler/type.c +--- cups-1.3.5/scheduler/type.c.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/scheduler/type.c 2008-02-05 15:08:55.000000000 +0000 +@@ -567,12 +567,12 @@ mimeFileType(mime_t *mime, /* I - M + if ((base = strrchr(filename, '/')) != NULL) + base ++; + else +- filename = filename; ++ base = filename; + } + else if ((base = strrchr(pathname, '/')) != NULL) + base ++; + else +- filename = pathname; ++ base = pathname; + + /* + * Then check it against all known types... +@@ -638,8 +638,8 @@ compare_types(mime_type_t *t0, /* I - F + int i; /* Result of comparison */ + + +- if ((i = strcmp(t0->super, t1->super)) == 0) +- i = strcmp(t0->type, t1->type); ++ if ((i = strcasecmp(t0->super, t1->super)) == 0) ++ i = strcasecmp(t0->type, t1->type); + + return (i); + } +diff -up cups-1.3.5/scheduler/subscriptions.c.1.3.x cups-1.3.5/scheduler/subscriptions.c +--- cups-1.3.5/scheduler/subscriptions.c.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/scheduler/subscriptions.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * Subscription routines for the Common UNIX Printing System (CUPS) scheduler. + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2007 by Easy Software Products, all rights reserved. + * + * These coded instructions, statements, and computer programs are the +@@ -323,7 +323,7 @@ cupsdAddSubscription( + "cupsdAddSubscription(mask=%x, dest=%p(%s), job=%p(%d), " + "uri=\"%s\")", + mask, dest, dest ? dest->name : "", job, job ? job->id : 0, +- uri); ++ uri ? uri : "(null)"); + + if (!Subscriptions) + Subscriptions = cupsArrayNew((cups_array_func_t)cupsd_compare_subscriptions, +@@ -504,9 +504,14 @@ cupsdEventName( + case CUPSD_EVENT_PRINTER_MODIFIED : + return ("printer-modified"); + ++ case CUPSD_EVENT_PRINTER_QUEUE_ORDER_CHANGED : ++ return ("printer-queue-order-changed"); ++ ++ case CUPSD_EVENT_PRINTER_STATE : + case CUPSD_EVENT_PRINTER_STATE_CHANGED : + return ("printer-state-changed"); + ++ case CUPSD_EVENT_PRINTER_CONFIG : + case CUPSD_EVENT_PRINTER_CONFIG_CHANGED : + return ("printer-config-changed"); + +@@ -529,8 +534,6 @@ cupsdEventName( + return ("job-progress"); + + case CUPSD_EVENT_JOB_STATE : +- return ("job-state"); +- + case CUPSD_EVENT_JOB_STATE_CHANGED : + return ("job-state-changed"); + +@@ -577,14 +580,14 @@ cupsdEventValue(const char *name) /* I - + return (CUPSD_EVENT_PRINTER_DELETED); + else if (!strcmp(name, "printer-modified")) + return (CUPSD_EVENT_PRINTER_MODIFIED); ++ else if (!strcmp(name, "printer-queue-order-changed")) ++ return (CUPSD_EVENT_PRINTER_QUEUE_ORDER_CHANGED); + else if (!strcmp(name, "printer-state-changed")) + return (CUPSD_EVENT_PRINTER_STATE_CHANGED); + else if (!strcmp(name, "printer-config-changed")) + return (CUPSD_EVENT_PRINTER_CONFIG_CHANGED); + else if (!strcmp(name, "printer-changed")) + return (CUPSD_EVENT_PRINTER_CHANGED); +- else if (!strcmp(name, "job-state")) +- return (CUPSD_EVENT_JOB_STATE); + else if (!strcmp(name, "job-created")) + return (CUPSD_EVENT_JOB_CREATED); + else if (!strcmp(name, "job-completed")) +@@ -731,7 +734,7 @@ cupsdLoadAllSubscriptions(void) + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of subscriptions.conf.", + linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "")) +@@ -741,7 +744,7 @@ cupsdLoadAllSubscriptions(void) + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of subscriptions.conf.", + linenum); +- return; ++ break; + } + + if (delete_sub) +@@ -755,7 +758,7 @@ cupsdLoadAllSubscriptions(void) + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of subscriptions.conf.", + linenum); +- return; ++ break; + } + else if (!strcasecmp(line, "Events")) + { +@@ -769,7 +772,7 @@ cupsdLoadAllSubscriptions(void) + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of subscriptions.conf.", + linenum); +- return; ++ break; + } + + while (*value) +@@ -792,7 +795,7 @@ cupsdLoadAllSubscriptions(void) + cupsdLogMessage(CUPSD_LOG_ERROR, + "Unknown event name \'%s\' on line %d of subscriptions.conf.", + value, linenum); +- return; ++ break; + } + + value = valueptr; +@@ -811,7 +814,7 @@ cupsdLoadAllSubscriptions(void) + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of subscriptions.conf.", + linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "Recipient")) +@@ -827,7 +830,7 @@ cupsdLoadAllSubscriptions(void) + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of subscriptions.conf.", + linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "JobId")) +@@ -851,7 +854,7 @@ cupsdLoadAllSubscriptions(void) + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of subscriptions.conf.", + linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "PrinterName")) +@@ -875,7 +878,7 @@ cupsdLoadAllSubscriptions(void) + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of subscriptions.conf.", + linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "UserData")) +@@ -937,7 +940,7 @@ cupsdLoadAllSubscriptions(void) + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of subscriptions.conf.", + linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "LeaseDuration")) +@@ -956,7 +959,7 @@ cupsdLoadAllSubscriptions(void) + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of subscriptions.conf.", + linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "Interval")) +@@ -972,7 +975,7 @@ cupsdLoadAllSubscriptions(void) + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of subscriptions.conf.", + linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "ExpirationTime")) +@@ -988,7 +991,7 @@ cupsdLoadAllSubscriptions(void) + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of subscriptions.conf.", + linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "NextEventId")) +@@ -1004,7 +1007,7 @@ cupsdLoadAllSubscriptions(void) + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of subscriptions.conf.", + linenum); +- return; ++ break; + } + } + else +diff -up cups-1.3.5/scheduler/ipp.c.1.3.x cups-1.3.5/scheduler/ipp.c +--- cups-1.3.5/scheduler/ipp.c.1.3.x 2007-12-15 00:23:16.000000000 +0000 ++++ cups-1.3.5/scheduler/ipp.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * IPP routines for the Common UNIX Printing System (CUPS) scheduler. + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2007 by Easy Software Products, all rights reserved. + * + * This file contains Kerberos support code, copyright 2006 by +@@ -658,7 +658,7 @@ cupsdProcessIPPRequest( + con->http.fd, con->response->request.status.status_code, + ippErrorString(con->response->request.status.status_code)); + +- if (cupsdSendHeader(con, HTTP_OK, "application/ipp", AUTH_NONE)) ++ if (cupsdSendHeader(con, HTTP_OK, "application/ipp", CUPSD_AUTH_NONE)) + { + #ifdef CUPSD_USE_CHUNKING + /* +@@ -746,7 +746,7 @@ cupsdProcessIPPRequest( + * 'cupsdTimeoutJob()' - Timeout a job waiting on job files. + */ + +-void ++int /* O - 0 on success, -1 on error */ + cupsdTimeoutJob(cupsd_job_t *job) /* I - Job to timeout */ + { + cupsd_printer_t *printer; /* Destination printer or class */ +@@ -774,10 +774,13 @@ cupsdTimeoutJob(cupsd_job_t *job) /* I - + cupsdLogMessage(CUPSD_LOG_INFO, "[Job %d] Adding end banner page \"%s\".", + job->id, attr->values[1].string.text); + +- kbytes = copy_banner(NULL, job, attr->values[1].string.text); ++ if ((kbytes = copy_banner(NULL, job, attr->values[1].string.text)) < 0) ++ return (-1); + + cupsdUpdateQuota(printer, job->username, 0, kbytes); + } ++ ++ return (0); + } + + +@@ -1786,7 +1789,8 @@ add_job(cupsd_client_t *con, /* I - Cl + "[Job %d] Adding start banner page \"%s\".", + job->id, attr->values[0].string.text); + +- kbytes = copy_banner(con, job, attr->values[0].string.text); ++ if ((kbytes = copy_banner(con, job, attr->values[0].string.text)) < 0) ++ return (NULL); + + cupsdUpdateQuota(printer, job->username, 0, kbytes); + } +@@ -2403,12 +2407,15 @@ add_printer(cupsd_client_t *con, /* I - + + supported = ippFindAttribute(printer->attrs, "port-monitor-supported", + IPP_TAG_NAME); +- for (i = 0; i < supported->num_values; i ++) +- if (!strcmp(supported->values[i].string.text, +- attr->values[0].string.text)) +- break; ++ if (supported) ++ { ++ for (i = 0; i < supported->num_values; i ++) ++ if (!strcmp(supported->values[i].string.text, ++ attr->values[0].string.text)) ++ break; ++ } + +- if (i >= supported->num_values) ++ if (!supported || i >= supported->num_values) + { + send_ipp_status(con, IPP_NOT_POSSIBLE, _("Bad port-monitor \"%s\"!"), + attr->values[0].string.text); +@@ -3410,13 +3417,6 @@ check_quotas(cupsd_client_t *con, /* I + con, con->http.fd, p, p->name); + + /* +- * Check input... +- */ +- +- if (!con || !p) +- return (0); +- +- /* + * Figure out who is printing... + */ + +@@ -3922,7 +3922,7 @@ copy_banner(cupsd_client_t *con, /* I - + */ + + if (add_file(con, job, banner->filetype, 0)) +- return (0); ++ return (-1); + + snprintf(filename, sizeof(filename), "%s/d%05d-%03d", RequestRoot, job->id, + job->num_files); +@@ -4644,6 +4644,10 @@ copy_printer_attrs( + printer->recoverable); + #endif /* __APPLE__ */ + ++ if (!ra || cupsArrayFind(ra, "marker-change-time")) ++ ippAddInteger(con->response, IPP_TAG_PRINTER, IPP_TAG_INTEGER, ++ "marker-change-time", printer->marker_time); ++ + if (printer->alert && (!ra || cupsArrayFind(ra, "printer-alert"))) + ippAddString(con->response, IPP_TAG_PRINTER, IPP_TAG_STRING, + "printer-alert", NULL, printer->alert); +@@ -7541,7 +7545,8 @@ print_job(cupsd_client_t *con, /* I - + * See if we need to add the ending sheet... + */ + +- cupsdTimeoutJob(job); ++ if (cupsdTimeoutJob(job)) ++ return; + + /* + * Log and save the job... +@@ -8265,13 +8270,13 @@ save_auth_info( + cupsFilePrintf(fp, "%s\n", line); + + if (!strcmp(dest->auth_info_required[i], "username")) +- cupsdSetStringf(&job->auth_username, "AUTH_USERNAME=%s", ++ cupsdSetStringf(&job->auth_username, "CUPSD_AUTH_USERNAME=%s", + auth_info->values[i].string.text); + else if (!strcmp(dest->auth_info_required[i], "domain")) +- cupsdSetStringf(&job->auth_domain, "AUTH_DOMAIN=%s", ++ cupsdSetStringf(&job->auth_domain, "CUPSD_AUTH_DOMAIN=%s", + auth_info->values[i].string.text); + else if (!strcmp(dest->auth_info_required[i], "password")) +- cupsdSetStringf(&job->auth_password, "AUTH_PASSWORD=%s", ++ cupsdSetStringf(&job->auth_password, "CUPSD_AUTH_PASSWORD=%s", + auth_info->values[i].string.text); + } + } +@@ -8284,7 +8289,7 @@ save_auth_info( + httpEncode64_2(line, sizeof(line), con->username, strlen(con->username)); + cupsFilePrintf(fp, "%s\n", line); + +- cupsdSetStringf(&job->auth_username, "AUTH_USERNAME=%s", con->username); ++ cupsdSetStringf(&job->auth_username, "CUPSD_AUTH_USERNAME=%s", con->username); + cupsdClearString(&job->auth_domain); + + /* +@@ -8294,7 +8299,7 @@ save_auth_info( + httpEncode64_2(line, sizeof(line), con->password, strlen(con->password)); + cupsFilePrintf(fp, "%s\n", line); + +- cupsdSetStringf(&job->auth_password, "AUTH_PASSWORD=%s", con->password); ++ cupsdSetStringf(&job->auth_password, "CUPSD_AUTH_PASSWORD=%s", con->password); + } + + /* +@@ -8745,7 +8750,8 @@ send_document(cupsd_client_t *con, /* I + * See if we need to add the ending sheet... + */ + +- cupsdTimeoutJob(job); ++ if (cupsdTimeoutJob(job)) ++ return; + + if (job->state_value == IPP_JOB_STOPPED) + { +@@ -8830,7 +8836,7 @@ send_http_error( + if (status == HTTP_UNAUTHORIZED && + printer && printer->num_auth_info_required > 0 && + !strcmp(printer->auth_info_required[0], "negotiate")) +- cupsdSendError(con, status, AUTH_NEGOTIATE); ++ cupsdSendError(con, status, CUPSD_AUTH_NEGOTIATE); + else if (printer) + { + char resource[HTTP_MAX_URI]; /* Resource portion of URI */ +@@ -8843,13 +8849,13 @@ send_http_error( + snprintf(resource, sizeof(resource), "/printers/%s", printer->name); + + if ((auth = cupsdFindBest(resource, HTTP_POST)) == NULL || +- auth->type == AUTH_NONE) ++ auth->type == CUPSD_AUTH_NONE) + auth = cupsdFindPolicyOp(printer->op_policy_ptr, IPP_PRINT_JOB); + +- cupsdSendError(con, status, auth ? auth->type : AUTH_NONE); ++ cupsdSendError(con, status, auth ? auth->type : CUPSD_AUTH_NONE); + } + else +- cupsdSendError(con, status, AUTH_NONE); ++ cupsdSendError(con, status, CUPSD_AUTH_NONE); + + ippDelete(con->response); + con->response = NULL; +@@ -9152,7 +9158,8 @@ set_job_attrs(cupsd_client_t *con, /* I + else if (con->response->request.status.status_code == IPP_OK) + { + cupsdSetJobPriority(job, attr->values[0].integer); +- event |= CUPSD_EVENT_JOB_CONFIG_CHANGED; ++ event |= CUPSD_EVENT_JOB_CONFIG_CHANGED | ++ CUPSD_EVENT_PRINTER_QUEUE_ORDER_CHANGED; + } + } + else if (!strcmp(attr->name, "job-state")) +@@ -9299,6 +9306,10 @@ set_job_attrs(cupsd_client_t *con, /* I + * Send events as needed... + */ + ++ if (event & CUPSD_EVENT_PRINTER_QUEUE_ORDER_CHANGED) ++ cupsdAddEvent(CUPSD_EVENT_PRINTER_QUEUE_ORDER_CHANGED, job->printer, job, ++ "Job priority changed by user."); ++ + if (event & CUPSD_EVENT_JOB_STATE) + cupsdAddEvent(CUPSD_EVENT_JOB_STATE, job->printer, job, + job->state_value == IPP_JOB_HELD ? +@@ -9805,6 +9816,8 @@ user_allowed(cupsd_printer_t *p, /* I - + { + int i; /* Looping var */ + struct passwd *pw; /* User password data */ ++ char baseuser[256], /* Base username */ ++ *baseptr; /* Pointer to "@" in base username */ + + + if (p->num_users == 0) +@@ -9813,6 +9826,20 @@ user_allowed(cupsd_printer_t *p, /* I - + if (!strcmp(username, "root")) + return (1); + ++ if (strchr(username, '@')) ++ { ++ /* ++ * Strip @REALM for username check... ++ */ ++ ++ strlcpy(baseuser, username, sizeof(baseuser)); ++ ++ if ((baseptr = strchr(baseuser, '@')) != NULL) ++ *baseptr = '\0'; ++ ++ username = baseuser; ++ } ++ + pw = getpwnam(username); + endpwent(); + +@@ -9979,8 +10006,8 @@ validate_user(cupsd_job_t *job, /* I + cupsdLogMessage(CUPSD_LOG_DEBUG2, + "validate_user(job=%d, con=%d, owner=\"%s\", username=%p, " + "userlen=%d)", +- job ? job->id : 0, con->http.fd, owner ? owner : "(null)", +- username, userlen); ++ job->id, con ? con->http.fd : 0, ++ owner ? owner : "(null)", username, userlen); + + /* + * Validate input... +diff -up cups-1.3.5/scheduler/dirsvc.c.1.3.x cups-1.3.5/scheduler/dirsvc.c +--- cups-1.3.5/scheduler/dirsvc.c.1.3.x 2007-12-06 20:44:04.000000000 +0000 ++++ cups-1.3.5/scheduler/dirsvc.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * Directory services routines for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2007 by Easy Software Products, all rights reserved. + * + * These coded instructions, statements, and computer programs are the +@@ -325,7 +325,7 @@ cupsdLoadRemoteCache(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of remote.cache.", linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "") || +@@ -386,14 +386,14 @@ cupsdLoadRemoteCache(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of remote.cache.", linenum); +- return; ++ break; + } + } + else if (!p) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of remote.cache.", linenum); +- return; ++ break; + } + else if (!strcasecmp(line, "Info")) + { +@@ -426,7 +426,7 @@ cupsdLoadRemoteCache(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of remote.cache.", linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "Option") && value) +@@ -462,7 +462,7 @@ cupsdLoadRemoteCache(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of remote.cache.", linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "StateMessage")) +@@ -494,7 +494,7 @@ cupsdLoadRemoteCache(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of remote.cache.", linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "Type")) +@@ -505,7 +505,7 @@ cupsdLoadRemoteCache(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of remote.cache.", linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "BrowseTime")) +@@ -521,7 +521,7 @@ cupsdLoadRemoteCache(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of remote.cache.", linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "JobSheets")) +@@ -556,7 +556,7 @@ cupsdLoadRemoteCache(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of remote.cache.", linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "AllowUser")) +@@ -570,7 +570,7 @@ cupsdLoadRemoteCache(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of remote.cache.", linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "DenyUser")) +@@ -584,7 +584,7 @@ cupsdLoadRemoteCache(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of remote.cache.", linenum); +- return; ++ break; + } + } + else +@@ -1793,9 +1793,9 @@ process_browse_data( + if (hptr && !*hptr) + *hptr = '.'; /* Resource FQDN */ + +- if ((p = cupsdFindClass(name)) == NULL && BrowseShortNames) ++ if ((p = cupsdFindDest(name)) == NULL && BrowseShortNames) + { +- if ((p = cupsdFindClass(resource + 9)) != NULL) ++ if ((p = cupsdFindDest(resource + 9)) != NULL) + { + if (p->hostname && strcasecmp(p->hostname, host)) + { +@@ -1900,9 +1900,9 @@ process_browse_data( + if (hptr && !*hptr) + *hptr = '.'; /* Resource FQDN */ + +- if ((p = cupsdFindPrinter(name)) == NULL && BrowseShortNames) ++ if ((p = cupsdFindDest(name)) == NULL && BrowseShortNames) + { +- if ((p = cupsdFindPrinter(resource + 10)) != NULL) ++ if ((p = cupsdFindDest(resource + 10)) != NULL) + { + if (p->hostname && strcasecmp(p->hostname, host)) + { +@@ -3629,7 +3629,7 @@ update_cups_browse(void) + * Access from localhost (127.0.0.1) is always allowed... + */ + +- auth = AUTH_ALLOW; ++ auth = CUPSD_AUTH_ALLOW; + } + else + { +@@ -3640,39 +3640,39 @@ update_cups_browse(void) + switch (BrowseACL->order_type) + { + default : +- auth = AUTH_DENY; /* anti-compiler-warning-code */ ++ auth = CUPSD_AUTH_DENY; /* anti-compiler-warning-code */ + break; + +- case AUTH_ALLOW : /* Order Deny,Allow */ +- auth = AUTH_ALLOW; ++ case CUPSD_AUTH_ALLOW : /* Order Deny,Allow */ ++ auth = CUPSD_AUTH_ALLOW; + + if (cupsdCheckAuth(address, srcname, len, + BrowseACL->num_deny, BrowseACL->deny)) +- auth = AUTH_DENY; ++ auth = CUPSD_AUTH_DENY; + + if (cupsdCheckAuth(address, srcname, len, + BrowseACL->num_allow, BrowseACL->allow)) +- auth = AUTH_ALLOW; ++ auth = CUPSD_AUTH_ALLOW; + break; + +- case AUTH_DENY : /* Order Allow,Deny */ +- auth = AUTH_DENY; ++ case CUPSD_AUTH_DENY : /* Order Allow,Deny */ ++ auth = CUPSD_AUTH_DENY; + + if (cupsdCheckAuth(address, srcname, len, + BrowseACL->num_allow, BrowseACL->allow)) +- auth = AUTH_ALLOW; ++ auth = CUPSD_AUTH_ALLOW; + + if (cupsdCheckAuth(address, srcname, len, + BrowseACL->num_deny, BrowseACL->deny)) +- auth = AUTH_DENY; ++ auth = CUPSD_AUTH_DENY; + break; + } + } + } + else +- auth = AUTH_ALLOW; ++ auth = CUPSD_AUTH_ALLOW; + +- if (auth == AUTH_DENY) ++ if (auth == CUPSD_AUTH_DENY) + { + cupsdLogMessage(CUPSD_LOG_DEBUG, + "update_cups_browse: Refused %d bytes from %s", bytes, +diff -up cups-1.3.5/scheduler/printers.c.1.3.x cups-1.3.5/scheduler/printers.c +--- cups-1.3.5/scheduler/printers.c.1.3.x 2007-12-11 00:37:08.000000000 +0000 ++++ cups-1.3.5/scheduler/printers.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * Printer routines for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2007 by Easy Software Products, all rights reserved. + * + * These coded instructions, statements, and computer programs are the +@@ -27,6 +27,7 @@ + * cupsdSaveAllPrinters() - Save all printer definitions to the + * printers.conf file. + * cupsdSetAuthInfoRequired() - Set the required authentication info. ++ * cupsdSetPrinterAttr() - Set a printer attribute. + * cupsdSetPrinterAttrs() - Set printer attributes based upon the PPD + * file. + * cupsdSetPrinterReasons() - Set/update the reasons strings. +@@ -900,7 +901,7 @@ cupsdLoadAllPrinters(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of printers.conf.", linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "")) +@@ -945,14 +946,14 @@ cupsdLoadAllPrinters(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of printers.conf.", linenum); +- return; ++ break; + } + } + else if (!p) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of printers.conf.", linenum); +- return; ++ break; + } + else if (!strcasecmp(line, "AuthInfoRequired")) + { +@@ -979,7 +980,7 @@ cupsdLoadAllPrinters(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of printers.conf.", linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "Option") && value) +@@ -1011,7 +1012,7 @@ cupsdLoadAllPrinters(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of printers.conf.", linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "State")) +@@ -1028,7 +1029,7 @@ cupsdLoadAllPrinters(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of printers.conf.", linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "StateMessage")) +@@ -1069,7 +1070,7 @@ cupsdLoadAllPrinters(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of printers.conf.", linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "Shared")) +@@ -1092,7 +1093,7 @@ cupsdLoadAllPrinters(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of printers.conf.", linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "JobSheets")) +@@ -1127,7 +1128,7 @@ cupsdLoadAllPrinters(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of printers.conf.", linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "AllowUser")) +@@ -1141,7 +1142,7 @@ cupsdLoadAllPrinters(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of printers.conf.", linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "DenyUser")) +@@ -1155,7 +1156,7 @@ cupsdLoadAllPrinters(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of printers.conf.", linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "QuotaPeriod")) +@@ -1166,7 +1167,7 @@ cupsdLoadAllPrinters(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of printers.conf.", linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "PageLimit")) +@@ -1177,7 +1178,7 @@ cupsdLoadAllPrinters(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of printers.conf.", linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "KLimit")) +@@ -1188,7 +1189,7 @@ cupsdLoadAllPrinters(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of printers.conf.", linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "OpPolicy")) +@@ -1212,7 +1213,7 @@ cupsdLoadAllPrinters(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of printers.conf.", linenum); +- return; ++ break; + } + } + else if (!strcasecmp(line, "ErrorPolicy")) +@@ -1223,7 +1224,7 @@ cupsdLoadAllPrinters(void) + { + cupsdLogMessage(CUPSD_LOG_ERROR, + "Syntax error on line %d of printers.conf.", linenum); +- return; ++ break; + } + } + else +@@ -1642,6 +1643,120 @@ cupsdSetAuthInfoRequired( + + + /* ++ * 'cupsdSetPrinterAttr()' - Set a printer attribute. ++ */ ++ ++void ++cupsdSetPrinterAttr( ++ cupsd_printer_t *p, /* I - Printer */ ++ const char *name, /* I - Attribute name */ ++ char *value) /* I - Attribute value string */ ++{ ++ ipp_attribute_t *attr; /* Attribute */ ++ int i, /* Looping var */ ++ count; /* Number of values */ ++ char *ptr; /* Pointer into value */ ++ ipp_tag_t value_tag; /* Value tag for this attribute */ ++ ++ ++ /* ++ * Count the number of values... ++ */ ++ ++ for (count = 1, ptr = value; ++ (ptr = strchr(ptr, ',')) != NULL; ++ ptr ++, count ++); ++ ++ /* ++ * Then add or update the attribute as needed... ++ */ ++ ++ if (!strcmp(name, "marker-levels")) ++ { ++ /* ++ * Integer values... ++ */ ++ ++ if ((attr = ippFindAttribute(p->attrs, name, IPP_TAG_INTEGER)) != NULL && ++ attr->num_values < count) ++ { ++ ippDeleteAttribute(p->attrs, attr); ++ attr = NULL; ++ } ++ ++ if (attr) ++ attr->num_values = count; ++ else ++ attr = ippAddIntegers(p->attrs, IPP_TAG_PRINTER, IPP_TAG_INTEGER, name, ++ count, NULL); ++ ++ if (!attr) ++ { ++ cupsdLogMessage(CUPSD_LOG_ERROR, ++ "Unable to allocate memory for printer attribute " ++ "(%d values)", count); ++ return; ++ } ++ ++ for (i = 0; i < count; i ++) ++ { ++ if ((ptr = strchr(value, ',')) != NULL) ++ *ptr++ = '\0'; ++ ++ attr->values[i].integer = strtol(value, NULL, 10); ++ ++ if (ptr) ++ value = ptr; ++ } ++ } ++ else ++ { ++ /* ++ * Name or keyword values... ++ */ ++ ++ if (!strcmp(name, "marker-types")) ++ value_tag = IPP_TAG_KEYWORD; ++ else ++ value_tag = IPP_TAG_NAME; ++ ++ if ((attr = ippFindAttribute(p->attrs, name, value_tag)) != NULL && ++ attr->num_values < count) ++ { ++ ippDeleteAttribute(p->attrs, attr); ++ attr = NULL; ++ } ++ ++ if (attr) ++ attr->num_values = count; ++ else ++ attr = ippAddStrings(p->attrs, IPP_TAG_PRINTER, value_tag, name, ++ count, NULL, NULL); ++ ++ if (!attr) ++ { ++ cupsdLogMessage(CUPSD_LOG_ERROR, ++ "Unable to allocate memory for printer attribute " ++ "(%d values)", count); ++ return; ++ } ++ ++ for (i = 0; i < count; i ++) ++ { ++ if ((ptr = strchr(value, ',')) != NULL) ++ *ptr++ = '\0'; ++ ++ _cupsStrFree(attr->values[i].string.text); ++ attr->values[i].string.text = _cupsStrAlloc(value); ++ ++ if (ptr) ++ value = ptr; ++ } ++ } ++} ++ ++ ++/* + * 'cupsdSetPrinterAttrs()' - Set printer attributes based upon the PPD file. + */ + +@@ -1736,25 +1851,25 @@ cupsdSetPrinterAttrs(cupsd_printer_t *p) + snprintf(resource, sizeof(resource), "/printers/%s", p->name); + + if ((auth = cupsdFindBest(resource, HTTP_POST)) == NULL || +- auth->type == AUTH_NONE) ++ auth->type == CUPSD_AUTH_NONE) + auth = cupsdFindPolicyOp(p->op_policy_ptr, IPP_PRINT_JOB); + + if (auth) + { +- if (auth->type == AUTH_BASIC || auth->type == AUTH_BASICDIGEST) ++ if (auth->type == CUPSD_AUTH_BASIC || auth->type == CUPSD_AUTH_BASICDIGEST) + { + auth_supported = "basic"; + num_air = 2; + air = air_userpass; + } +- else if (auth->type == AUTH_DIGEST) ++ else if (auth->type == CUPSD_AUTH_DIGEST) + { + auth_supported = "digest"; + num_air = 2; + air = air_userpass; + } + #ifdef HAVE_GSSAPI +- else if (auth->type == AUTH_NEGOTIATE) ++ else if (auth->type == CUPSD_AUTH_NEGOTIATE) + { + auth_supported = "negotiate"; + num_air = 1; +@@ -1762,7 +1877,7 @@ cupsdSetPrinterAttrs(cupsd_printer_t *p) + } + #endif /* HAVE_GSSAPI */ + +- if (auth->type != AUTH_NONE) ++ if (auth->type != CUPSD_AUTH_NONE) + p->type |= CUPS_PRINTER_AUTHENTICATED; + else + p->type &= ~CUPS_PRINTER_AUTHENTICATED; +@@ -2634,7 +2749,7 @@ cupsdSetPrinterState( + if (old_state != s) + { + cupsdAddEvent(s == IPP_PRINTER_STOPPED ? CUPSD_EVENT_PRINTER_STOPPED : +- CUPSD_EVENT_PRINTER_STATE_CHANGED, p, NULL, ++ CUPSD_EVENT_PRINTER_STATE, p, NULL, + "%s \"%s\" state changed.", + (p->type & CUPS_PRINTER_CLASS) ? "Class" : "Printer", + p->name); +diff -up cups-1.3.5/test/ipptest.c.1.3.x cups-1.3.5/test/ipptest.c +--- cups-1.3.5/test/ipptest.c.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/test/ipptest.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * IPP test command for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2007 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -268,6 +268,7 @@ do_tests(const char *uri, /* I - URI to + { + printf("Unable to connect to %s on port %d - %s\n", server, port, + strerror(errno)); ++ fclose(fp); + return (0); + } + +diff -up cups-1.3.5/scripting/java/src/com/easysw/cups/IPPAttribute.java.1.3.x cups-1.3.5/scripting/java/src/com/easysw/cups/IPPAttribute.java +--- cups-1.3.5/scripting/java/src/com/easysw/cups/IPPAttribute.java.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/scripting/java/src/com/easysw/cups/IPPAttribute.java 2008-02-05 15:08:55.000000000 +0000 +@@ -7,7 +7,7 @@ package com.easysw.cups; + * Internet Printing Protocol definitions for the Common UNIX Printing + * System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2002 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -263,7 +263,9 @@ public class IPPAttribute + { + IPPValue val; + int bytes = 0; // Start with one for the group tag. +- ++ Charset utf8 = Charset::forName("UTF-8"); ++ ByteBuffer temp; ++ + // + // Add 1 if first time, or group tag changes. + // +@@ -308,8 +310,12 @@ public class IPPAttribute + case IPPDefs.TAG_CHARSET: + case IPPDefs.TAG_LANGUAGE: + case IPPDefs.TAG_MIMETYPE: ++ temp = utf8.encode(val.text); + bytes += 2; +- bytes += val.text.length(); ++ if (temp.capacity() > 32767) ++ bytes += 32767; ++ else ++ bytes += temp.capacity(); + break; + + case IPPDefs.TAG_DATE : +@@ -329,9 +335,13 @@ public class IPPAttribute + + case IPPDefs.TAG_TEXTLANG : + case IPPDefs.TAG_NAMELANG : ++ temp = utf8.encode(val.text); + bytes += 6; // 2 overall len, 2 charset len, 2 text len +- bytes += val.charset.length() + +- val.text.length(); ++ bytes += val.charset.length(); ++ if (temp.capacity() > 32767) ++ bytes += 32767; ++ else ++ bytes += temp.capacity(); + break; + + default : +@@ -359,6 +369,8 @@ public class IPPAttribute + int i,j, n; + int bi = 0; // Start with one for the group tag. + byte[] bytes = new byte[sz]; ++ Charset utf8 = Charset::forName("UTF-8"); ++ ByteBuffer temp; + + if (group_tag != last_group) + { +@@ -412,12 +424,16 @@ public class IPPAttribute + case IPPDefs.TAG_CHARSET : + case IPPDefs.TAG_LANGUAGE : + case IPPDefs.TAG_MIMETYPE : +- bytes[bi++] = (byte)((val.text.length() & 0xff00) >> 8); +- bytes[bi++] = (byte)(val.text.length() & 0xff); +- for (j=0; j < val.text.length(); j++) +- { +- bytes[bi++] = (byte)val.text.charAt(j); +- } ++ temp = utf8.encode(val.text); ++ n = temp.capacity(); ++ ++ if (n > 32767) ++ n = 32767; ++ ++ bytes[bi++] = (byte)((n & 0x7f00) >> 8); ++ bytes[bi++] = (byte)(n & 0xff); ++ temp.get(bytes, bi, n); ++ bi += n; + break; + + case IPPDefs.TAG_DATE: +@@ -456,23 +472,30 @@ public class IPPAttribute + + case IPPDefs.TAG_TEXTLANG : + case IPPDefs.TAG_NAMELANG : +- n = val.charset.length() + +- val.text.length() + 4; +- bytes[bi++] = (byte)((n & 0xff00) >> 8); ++ temp = utf8.encode(val.text); ++ n = temp.capacity() + val.charset.length() + 4; ++ ++ if (n > 32767) ++ n = 32767; ++ ++ bytes[bi++] = (byte)((n & 0x7f00) >> 8); + bytes[bi++] = (byte)(n & 0xff); + + n = val.charset.length(); +- bytes[bi++] = (byte)((n & 0xff00) >> 8); ++ bytes[bi++] = (byte)((n & 0x7f00) >> 8); + bytes[bi++] = (byte)(n & 0xff); + for (j=0; j < val.charset.length(); j++) + bytes[bi++] = (byte)val.charset.charAt(j); +- +- n = val.text.length(); +- bytes[bi++] = (byte)((n & 0xff00) >> 8); ++ ++ n = temp.capacity(); ++ ++ if (n > 32767) ++ n = 32767; ++ ++ bytes[bi++] = (byte)((n & 0x7f00) >> 8); + bytes[bi++] = (byte)(n & 0xff); +- for (j=0; j < (byte)val.text.length(); j++) +- bytes[bi++] = (byte)val.text.charAt(j); +- ++ temp.get(bytes, bi, n); ++ bi += n; + break; + + default : +diff -up cups-1.3.5/scripting/java/src/com/easysw/cups/Cups.java.1.3.x cups-1.3.5/scripting/java/src/com/easysw/cups/Cups.java +--- cups-1.3.5/scripting/java/src/com/easysw/cups/Cups.java.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/scripting/java/src/com/easysw/cups/Cups.java 2008-02-05 15:08:55.000000000 +0000 +@@ -7,7 +7,7 @@ package com.easysw.cups; + * Internet Printing Protocol definitions for the Common UNIX Printing + * System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2006 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -831,7 +831,7 @@ public class Cups + + a = new IPPAttribute( IPPDefs.TAG_OPERATION, IPPDefs.TAG_CHARSET, + "attributes-charset" ); +- a.addString( "", "iso-8859-1" ); ++ a.addString( "", "utf-8" ); + ipp.addAttribute(a); + + +@@ -1014,7 +1014,7 @@ public class Cups + + a = new IPPAttribute( IPPDefs.TAG_OPERATION, IPPDefs.TAG_CHARSET, + "attributes-charset" ); +- a.addString( "", "iso-8859-1" ); ++ a.addString( "", "utf-8" ); + ipp.addAttribute(a); + + +@@ -1091,7 +1091,7 @@ public class Cups + + a = new IPPAttribute( IPPDefs.TAG_OPERATION, IPPDefs.TAG_CHARSET, + "attributes-charset" ); +- a.addString( "", "iso-8859-1" ); ++ a.addString( "", "utf-8" ); + ipp.addAttribute(a); + + +@@ -1155,7 +1155,7 @@ public class Cups + + a = new IPPAttribute( IPPDefs.TAG_OPERATION, IPPDefs.TAG_CHARSET, + "attributes-charset" ); +- a.addString( "", "iso-8859-1" ); ++ a.addString( "", "utf-8" ); + ipp.addAttribute(a); + + +@@ -1229,7 +1229,7 @@ public class Cups + + a = new IPPAttribute( IPPDefs.TAG_OPERATION, IPPDefs.TAG_CHARSET, + "attributes-charset" ); +- a.addString( "", "iso-8859-1" ); ++ a.addString( "", "utf-8" ); + ipp.addAttribute(a); + + // ------------ +@@ -1315,7 +1315,7 @@ public class Cups + + a = new IPPAttribute( IPPDefs.TAG_OPERATION, IPPDefs.TAG_CHARSET, + "attributes-charset" ); +- a.addString( "", "iso-8859-1" ); ++ a.addString( "", "utf-8" ); + ipp.addAttribute(a); + + // ------------ +@@ -1375,7 +1375,7 @@ public class Cups + + a = new IPPAttribute( IPPDefs.TAG_OPERATION, IPPDefs.TAG_CHARSET, + "attributes-charset" ); +- a.addString( "", "iso-8859-1" ); ++ a.addString( "", "utf-8" ); + ipp.addAttribute(a); + + +diff -up cups-1.3.5/CHANGES.txt.1.3.x cups-1.3.5/CHANGES.txt +--- cups-1.3.5/CHANGES.txt.1.3.x 2007-12-17 22:12:45.000000000 +0000 ++++ cups-1.3.5/CHANGES.txt 2008-02-05 15:08:55.000000000 +0000 +@@ -1,6 +1,85 @@ +-CHANGES.txt - 2007-12-17 ++CHANGES.txt - 2008-01-30 + ------------------------ + ++CHANGES IN CUPS V1.3.6 ++ ++ - Documentation updates (STR #2646, STR #2647, STR #2649) ++ - The scheduler did not support printer supply attributes ++ (STR #1307) ++ - The Kerberos credentials provided by some Windows KDCs ++ were still too large - now use a dynamic buffer to ++ support credentials up to 64k in size (STR #2695) ++ - Printing a test page from the web interface incorrectly ++ defaulted to the "guest" user (STR #2688) ++ - The cupsEncodeOptions2() function did not parse multiple- ++ value attribute values properly (STR #2690) ++ - The scheduler incorrectly sent printer-stopped events for ++ status updates from the print filters (STR #2680) ++ - The IPP backend could crash when handling printer errors ++ (STR #2667) ++ - Multi-file jobs did not print to remote CUPS servers ++ (STR #2673) ++ - The scheduler did not provide the Apple language ID to ++ job filters. ++ - Kerberos authentication did not work with the web ++ interface (STR #2606, STR #2669) ++ - The requesing-user-name-allowed and -denied functionality ++ did not work for Kerberos-authenticated usernames (STR ++ #2670) ++ - CUPS didn't compile on HP-UX 11i (STR #2679) ++ - cupsEncodeOptions2() did not handle option values like ++ "What's up, doc?" properly. ++ - Added lots of memory allocation checks (Fortify) ++ - The scheduler would crash if it was unable to add a job ++ file (Fortify) ++ - ppdOpen*() did not check all memory allocations (Coverity) ++ - ippReadIO() did not check all memory allocations (Coverity) ++ - The PostScript filter did not detect read errors (Coverity) ++ - The scheduler did not check for a missing job-sheets-completed ++ attribute when sending an event notification (Coverity) ++ - "Set Printer Options" might not work with raw queues (Coverity) ++ - cupsRasterInterpretPPD() could crash on certain PostScript ++ errors (Coverity) ++ - The USB backend did not check for back-channel support ++ properly on all systems (Coverity) ++ - Fixed memory leaks in the GIF and PNM image loading code ++ (Coverity) ++ - Removed some dead code in the CUPS API and scheduler (Coverity) ++ - Fixed two overflow bugs in the HP-GL/2 filter (Coverity) ++ - Fixed another ASN1 string parsing bug (STR #2665) ++ - The RSS notifier directory was not installed with the ++ correct permissions. ++ - The standard CUPS backends could use 100% CPU while waiting ++ for print data (STR #2664) ++ - Filename-based MIME rules did not work (STR #2659) ++ - The cups-polld program did not exit if the scheduler crashed ++ (STR #2640) ++ - The scheduler would crash if you tried to set the port-monitor ++ on a raw queue (STR #2639) ++ - The scheduler could crash if a polled remote printer was ++ converted to a class (STR #2656) ++ - The web interface and cupsctl did not correctly reflect ++ the "allow printing from the Internet" state (STR #2650) ++ - The scheduler incorrectly treated MIME types as case- ++ sensitive (STR #2657) ++ - The Java support classes did not send UTF-8 strings to ++ the scheduler (STR #2651) ++ - The CGI code did not handle interrupted POST requests ++ properly (STR #2652) ++ - The PostScript filter incorrectly handled number-up when ++ the number of pages was evenly divisible by the number-up ++ value. ++ - The PDF filter incorrectly filtered pages when page-ranges ++ and number-up were both specified (STR #2643) ++ - The IPP backend did not handle printing of pictwps files ++ to a non-Mac CUPS server properly. ++ - The scheduler did not detect network interface changes ++ on operating systems other than Mac OS X (STR #2631) ++ - The scheduler now logs the UNIX error message when it ++ is unable to create a request file such as a print job. ++ - Added support for --enable-pie on Mac OS X. ++ ++ + CHANGES IN CUPS V1.3.5 + + - The SNMP backend did not check for negative string +diff -up cups-1.3.5/conf/cupsd.conf.in.1.3.x cups-1.3.5/conf/cupsd.conf.in +--- cups-1.3.5/conf/cupsd.conf.in.1.3.x 2007-07-25 01:40:03.000000000 +0100 ++++ cups-1.3.5/conf/cupsd.conf.in 2008-02-05 15:08:55.000000000 +0000 +@@ -29,14 +29,12 @@ DefaultAuthType Basic + # Restrict access to the server... + + Order allow,deny +- Allow localhost + + + # Restrict access to the admin pages... + + @ENCRYPTION_REQUIRED@ + Order allow,deny +- Allow localhost + + + # Restrict access to configuration files... +@@ -44,7 +42,6 @@ DefaultAuthType Basic + AuthType Default + Require user @SYSTEM + Order allow,deny +- Allow localhost + + + # Set the default printer/job policies... +diff -up cups-1.3.5/templates/trailer.tmpl.1.3.x cups-1.3.5/templates/trailer.tmpl +--- cups-1.3.5/templates/trailer.tmpl.1.3.x 2007-12-07 18:37:40.000000000 +0000 ++++ cups-1.3.5/templates/trailer.tmpl 2008-02-05 15:08:55.000000000 +0000 +@@ -6,9 +6,9 @@ + WIDTH="15" HEIGHT="15" ALT=""> + + +-

The Common UNIX Printing System, CUPS, and the CUPS logo are the +-trademark property of Apple Inc. CUPS +-is copyright 2007 by Apple Inc., all rights reserved.

++

The Common UNIX Printing System, CUPS, and the CUPS logo are ++trademarks of Apple Inc. CUPS is ++copyright 2007-2008 Apple Inc. All rights reserved.

+ + + +diff -up cups-1.3.5/config-scripts/cups-compiler.m4.1.3.x cups-1.3.5/config-scripts/cups-compiler.m4 +--- cups-1.3.5/config-scripts/cups-compiler.m4.1.3.x 2007-09-18 21:39:31.000000000 +0100 ++++ cups-1.3.5/config-scripts/cups-compiler.m4 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ dnl "$Id: cups-compiler.m4 6976 2007-09- + dnl + dnl Compiler stuff for the Common UNIX Printing System (CUPS). + dnl +-dnl Copyright 2007 by Apple Inc. ++dnl Copyright 2007-2008 by Apple Inc. + dnl Copyright 1997-2007 by Easy Software Products, all rights reserved. + dnl + dnl These coded instructions, statements, and computer programs are the +@@ -98,36 +98,56 @@ if test -n "$GCC"; then + fi + fi + ++ # Generate position-independent code as needed... + if test $PICFLAG = 1 -a $uname != AIX; then + OPTIM="-fPIC $OPTIM" + fi + +- case $uname in +- Linux*) +- if test x$enable_pie = xyes; then +- PIEFLAGS="-pie -fPIE" +- fi +- +- if test x$enable_relro = xyes; then +- RELROFLAGS="-Wl,-z,relro" +- fi +- ;; +- +- *) +- if test x$enable_pie = xyes; then +- echo "Sorry, --enable-pie is not supported on this OS!" +- fi +- ;; +- esac ++ # The -fstack-protector option is available with some versions of ++ # GCC and adds "stack canaries" which detect when the return address ++ # has been overwritten, preventing many types of exploit attacks. ++ AC_MSG_CHECKING(if GCC supports -fstack-protector) ++ OLDCFLAGS="$CFLAGS" ++ CFLAGS="$CFLAGS -fstack-protector" ++ AC_TRY_COMPILE(,, ++ OPTIM="$OPTIM -fstack-protector" ++ AC_MSG_RESULT(yes), ++ AC_MSG_RESULT(no)) ++ CFLAGS="$OLDCFLAGS" ++ ++ # The -pie option is available with some versions of GCC and adds ++ # randomization of addresses, which avoids another class of exploits ++ # that depend on a fixed address for common functions. ++ if test x$enable_pie = xyes; then ++ AC_MSG_CHECKING(if GCC supports -pie) ++ OLDCFLAGS="$CFLAGS" ++ CFLAGS="$CFLAGS -pie -fPIE" ++ AC_TRY_COMPILE(,, ++ PIEFLAGS="-pie -fPIE" ++ AC_MSG_RESULT(yes), ++ AC_MSG_RESULT(no, ignoring --enable-pie)) ++ CFLAGS="$OLDCFLAGS" ++ fi + + if test "x$with_optim" = x; then + # Add useful warning options for tracking down problems... + OPTIM="-Wall -Wno-format-y2k $OPTIM" +- # Additional warning options for alpha testing... +- OPTIM="-Wshadow -Wunused $OPTIM" ++ # Additional warning options for development testing... ++ if test -d .svn; then ++ OPTIM="-Wshadow -Wunused $OPTIM" ++ fi + fi + + case "$uname" in ++ Darwin*) ++ # -D_FORTIFY_SOURCE=2 adds additional object size ++ # checking, basically wrapping all string functions ++ # with buffer-limited ones. Not strictly needed for ++ # CUPS since we already use buffer-limited calls, but ++ # this will catch any additions that are broken. ++ CFLAGS="$CFLAGS -D_FORTIFY_SOURCE=2" ++ ;; ++ + HP-UX*) + if test "x$enable_32bit" = xyes; then + # Build 32-bit libraries, 64-bit base... +@@ -201,6 +221,12 @@ if test -n "$GCC"; then + ;; + + Linux*) ++ # The -z relro option is provided by the Linux linker command to ++ # make relocatable data read-only. ++ if test x$enable_relro = xyes; then ++ RELROFLAGS="-Wl,-z,relro" ++ fi ++ + if test "x$enable_32bit" = xyes; then + # Build 32-bit libraries, 64-bit base... + if test -z "$with_arch32flags"; then +@@ -468,8 +494,8 @@ else + # cups-support@cups.org... + echo "Building CUPS with default compiler optimizations; contact" + echo "cups-bugs@cups.org with uname and compiler options needed" +- echo "for your platform, or set the CFLAGS and CXXFLAGS" +- echo "environment variable before running configure." ++ echo "for your platform, or set the CFLAGS, CXXFLAGS, and LDFLAGS" ++ echo "environment variables before running configure." + ;; + esac + fi +diff -up cups-1.3.5/config-scripts/cups-network.m4.1.3.x cups-1.3.5/config-scripts/cups-network.m4 +--- cups-1.3.5/config-scripts/cups-network.m4.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/config-scripts/cups-network.m4 2008-02-05 15:08:55.000000000 +0000 +@@ -29,24 +29,6 @@ fi + AC_CHECK_MEMBER(struct sockaddr.sa_len,,, [#include ]) + AC_CHECK_HEADER(sys/sockio.h, AC_DEFINE(HAVE_SYS_SOCKIO_H)) + +-if test "$uname" = "SunOS"; then +- case "$uversion" in +- 55* | 56*) +- maxfiles=1024 +- ;; +- *) +- maxfiles=4096 +- ;; +- esac +-else +- maxfiles=4096 +-fi +- +-AC_ARG_WITH(maxfiles, [ --with-maxfiles=N set maximum number of file descriptors for scheduler ], +- maxfiles=$withval) +- +-AC_DEFINE_UNQUOTED(CUPS_MAX_FDS, $maxfiles) +- + CUPS_DEFAULT_DOMAINSOCKET="" + + dnl Domain socket support... +diff -up cups-1.3.5/config-scripts/cups-common.m4.1.3.x cups-1.3.5/config-scripts/cups-common.m4 +--- cups-1.3.5/config-scripts/cups-common.m4.1.3.x 2007-12-17 22:14:15.000000000 +0000 ++++ cups-1.3.5/config-scripts/cups-common.m4 2008-02-05 15:08:55.000000000 +0000 +@@ -205,15 +205,6 @@ case $uname in + CUPSDLIBS="-sectorder __TEXT __text cupsd.order -e start -framework IOKit -framework SystemConfiguration" + LIBS="-framework CoreFoundation $LIBS" + +- dnl Check for CFLocaleCreateCanonicalLocaleIdentifierFromString... +- AC_MSG_CHECKING(for CFLocaleCreateCanonicalLocaleIdentifierFromString) +- if test "$uname" = "Darwin" -a $uversion -ge 70; then +- AC_DEFINE(HAVE_CF_LOCALE_ID) +- AC_MSG_RESULT(yes) +- else +- AC_MSG_RESULT(no) +- fi +- + dnl Check for framework headers... + AC_CHECK_HEADER(CoreFoundation/CoreFoundation.h,AC_DEFINE(HAVE_COREFOUNDATION_H)) + AC_CHECK_HEADER(CoreFoundation/CFPriv.h,AC_DEFINE(HAVE_CFPRIV_H)) +diff -up cups-1.3.5/man/lpq.man.1.3.x cups-1.3.5/man/lpq.man +--- cups-1.3.5/man/lpq.man.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/man/lpq.man 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + .\" + .\" lpq man page for the Common UNIX Printing System (CUPS). + .\" +-.\" Copyright 2007 by Apple Inc. ++.\" Copyright 2007-2008 by Apple Inc. + .\" Copyright 1997-2006 by Easy Software Products. + .\" + .\" These coded instructions, statements, and computer programs are the +@@ -12,7 +12,7 @@ + .\" which should have been included with this file. If this file is + .\" file is missing or damaged, see the license at "http://www.cups.org/". + .\" +-.TH lpq 1 "Common UNIX Printing System" "12 February 2006" "Apple Inc." ++.TH lpq 1 "Common UNIX Printing System" "2 January 2008" "Apple Inc." + .SH NAME + lpq \- show printer queue status + .SH SYNOPSIS +@@ -33,7 +33,7 @@ no printer or class is specified on the + .LP + The \fI+interval\fR option allows you to continuously report the + jobs in the queue until the queue is empty; the list of jobs is +-show one every \fIinterval\fR seconds. ++show once every \fIinterval\fR seconds. + .SH OPTIONS + \fIlpq\fR supports the following options: + .TP 5 +@@ -66,7 +66,7 @@ Requests a more verbose (long) reporting + .br + http://localhost:631/help + .SH COPYRIGHT +-Copyright 2007 by Apple Inc. ++Copyright 2007-2008 by Apple Inc. + .\" + .\" End of "$Id: lpq.man 6649 2007-07-11 21:46:42Z mike $". + .\" +diff -up cups-1.3.5/man/lpadmin.man.1.3.x cups-1.3.5/man/lpadmin.man +--- cups-1.3.5/man/lpadmin.man.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/man/lpadmin.man 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + .\" + .\" lpadmin man page for the Common UNIX Printing System (CUPS). + .\" +-.\" Copyright 2007 by Apple Inc. ++.\" Copyright 2007-2008 by Apple Inc. + .\" Copyright 1997-2006 by Easy Software Products. + .\" + .\" These coded instructions, statements, and computer programs are the +@@ -12,7 +12,7 @@ + .\" which should have been included with this file. If this file is + .\" file is missing or damaged, see the license at "http://www.cups.org/". + .\" +-.TH lpadmin 8 "Common UNIX Printing System" "13 July 2006" "Apple Inc." ++.TH lpadmin 8 "Common UNIX Printing System" "2 January 2008" "Apple Inc." + .SH NAME + lpadmin \- configure cups printers and classes + .SH SYNOPSIS +@@ -81,12 +81,6 @@ and is intended for providing support fo + Sets a standard System V interface script or PPD file from the + \fImodel\fR directory. + .TP 5 +--o name=value +-.br +-Sets a PPD or server option for the printer. PPD options can be +-listed using the \fI-l\fR option with the \fIlpoptions(1)\fR +-command. +-.TP 5 + -o job-k-limit=value + .br + Sets the kilobyte limit for per-user quotas. The value is an +@@ -109,10 +103,23 @@ integer number of seconds; 86,400 second + .br + Sets the default banner page(s) to use for print jobs. + .TP 5 ++-o name=value ++.br ++Sets a PPD option for the printer. PPD options can be ++listed using the \fI-l\fR option with the \fIlpoptions(1)\fR ++command. ++.TP 5 ++-o name-default=value ++.br ++Sets a default server-side option for the printer. Any print-time ++option can be defaulted, e.g. "-o cpi-default=17" to set the default ++"cpi" option value to 17. ++.TP 5 + -o port-monitor=name + .br + Sets the binary communications program to use when printing, +-"none", "bcp", or "tbcp". The default program is "none". ++"none", "bcp", or "tbcp". The default program is "none". The ++specified port monitor must be listed in the printer's PPD file. + .TP 5 + -o printer-error-policy=name + .br +@@ -194,7 +201,7 @@ System V or Solaris printing system conf + .br + http://localhost:631/help + .SH COPYRIGHT +-Copyright 2007 by Apple Inc. ++Copyright 2007-2008 by Apple Inc. + .\" + .\" End of "$Id: lpadmin.man 6649 2007-07-11 21:46:42Z mike $". + .\" +diff -up cups-1.3.5/man/cupsd.conf.man.in.1.3.x cups-1.3.5/man/cupsd.conf.man.in +--- cups-1.3.5/man/cupsd.conf.man.in.1.3.x 2007-10-02 00:11:47.000000000 +0100 ++++ cups-1.3.5/man/cupsd.conf.man.in 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + .\" + .\" cupsd.conf man page for the Common UNIX Printing System (CUPS). + .\" +-.\" Copyright 2007 by Apple Inc. ++.\" Copyright 2007-2008 by Apple Inc. + .\" Copyright 1997-2006 by Easy Software Products. + .\" + .\" These coded instructions, statements, and computer programs are the +@@ -12,7 +12,7 @@ + .\" which should have been included with this file. If this file is + .\" file is missing or damaged, see the license at "http://www.cups.org/". + .\" +-.TH cupsd.conf 5 "Common UNIX Printing System" "6 June 2006" "Apple Inc." ++.TH cupsd.conf 5 "Common UNIX Printing System" "2 January 2008" "Apple Inc." + .SH NAME + cupsd.conf \- server configuration file for cups + .SH DESCRIPTION +@@ -230,6 +230,12 @@ DefaultPolicy policy-name + .br + Specifies the default access policy to use. + .TP 5 ++DefaultShared Yes ++.TP 5 ++DefaultShared No ++.br ++Specifies whether local printers are shared by default. ++.TP 5 + Deny all + .TP 5 + Deny none +@@ -606,7 +612,7 @@ Specifies the user name or ID that is us + .br + http://localhost:631/help + .SH COPYRIGHT +-Copyright 2007 by Apple Inc. ++Copyright 2007-2008 by Apple Inc. + .\" + .\" End of "$Id: cupsd.conf.man.in 7004 2007-10-01 23:11:47Z mike $". + .\" +diff -up cups-1.3.5/INSTALL.txt.1.3.x cups-1.3.5/INSTALL.txt +--- cups-1.3.5/INSTALL.txt.1.3.x 2007-09-18 21:39:31.000000000 +0100 ++++ cups-1.3.5/INSTALL.txt 2008-02-05 15:08:55.000000000 +0000 +@@ -1,4 +1,4 @@ +-INSTALL - CUPS v1.3.2 - 2007-09-18 ++INSTALL - CUPS v1.3.6 - 2008-01-22 + ---------------------------------- + + This file describes how to compile and install CUPS from source +@@ -31,9 +31,8 @@ BEFORE YOU BEGIN + compile and run without these, however you'll miss out on + many of the features provided by CUPS. + +- Kerberos support requires a very recent version of the MIT +- implementation with the krb5_cc_new_unique() function or the +- Heimdal implementation, along with the corresponding GSSAPI ++ Kerberos support requires MIT Kerberos 1.6.3 or later or ++ or Heimdal Kerberos, along with the corresponding GSSAPI + pieces. + + Also, please note that CUPS no longer includes the +@@ -47,7 +46,7 @@ COMPILING FROM SUBVERSION + + The CUPS Subversion repository doesn't hold a copy of the + pre-built configure script. You'll need to run the GNU +- autoconf software (2.52 or higher) before compiling the ++ autoconf software (2.60 or higher) before compiling the + software from Subversion: + + autoconf -f +diff -up cups-1.3.5/filter/pstops.c.1.3.x cups-1.3.5/filter/pstops.c +--- cups-1.3.5/filter/pstops.c.1.3.x 2007-11-09 19:54:09.000000000 +0000 ++++ cups-1.3.5/filter/pstops.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * PostScript filter for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1993-2007 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -164,27 +164,27 @@ static void cancel_job(int sig); + static int check_range(pstops_doc_t *doc, int page); + static void copy_bytes(cups_file_t *fp, off_t offset, + size_t length); +-static size_t copy_comments(cups_file_t *fp, pstops_doc_t *doc, ++static ssize_t copy_comments(cups_file_t *fp, pstops_doc_t *doc, + ppd_file_t *ppd, char *line, +- size_t linelen, size_t linesize); ++ ssize_t linelen, size_t linesize); + static void copy_dsc(cups_file_t *fp, pstops_doc_t *doc, +- ppd_file_t *ppd, char *line, size_t linelen, ++ ppd_file_t *ppd, char *line, ssize_t linelen, + size_t linesize); + static void copy_non_dsc(cups_file_t *fp, pstops_doc_t *doc, + ppd_file_t *ppd, char *line, +- size_t linelen, size_t linesize); +-static size_t copy_page(cups_file_t *fp, pstops_doc_t *doc, ++ ssize_t linelen, size_t linesize); ++static ssize_t copy_page(cups_file_t *fp, pstops_doc_t *doc, + ppd_file_t *ppd, int number, char *line, +- size_t linelen, size_t linesize); +-static size_t copy_prolog(cups_file_t *fp, pstops_doc_t *doc, ++ ssize_t linelen, size_t linesize); ++static ssize_t copy_prolog(cups_file_t *fp, pstops_doc_t *doc, + ppd_file_t *ppd, char *line, +- size_t linelen, size_t linesize); +-static size_t copy_setup(cups_file_t *fp, pstops_doc_t *doc, ++ ssize_t linelen, size_t linesize); ++static ssize_t copy_setup(cups_file_t *fp, pstops_doc_t *doc, + ppd_file_t *ppd, char *line, +- size_t linelen, size_t linesize); +-static size_t copy_trailer(cups_file_t *fp, pstops_doc_t *doc, ++ ssize_t linelen, size_t linesize); ++static ssize_t copy_trailer(cups_file_t *fp, pstops_doc_t *doc, + ppd_file_t *ppd, int number, char *line, +- size_t linelen, size_t linesize); ++ ssize_t linelen, size_t linesize); + static void do_prolog(pstops_doc_t *doc, ppd_file_t *ppd); + static void do_setup(pstops_doc_t *doc, ppd_file_t *ppd); + static void doc_printf(pstops_doc_t *doc, const char *format, ...) +@@ -203,7 +203,7 @@ static char *parse_text(const char *sta + static void set_pstops_options(pstops_doc_t *doc, ppd_file_t *ppd, + char *argv[], int num_options, + cups_option_t *options); +-static size_t skip_page(cups_file_t *fp, char *line, size_t linelen, ++static ssize_t skip_page(cups_file_t *fp, char *line, ssize_t linelen, + size_t linesize); + static void start_nup(pstops_doc_t *doc, int number, + int show_border, const int *bounding_box); +@@ -581,12 +581,12 @@ copy_bytes(cups_file_t *fp, /* I - File + * On return, "line" will contain the next line in the file, if any. + */ + +-static size_t /* O - Length of next line */ ++static ssize_t /* O - Length of next line */ + copy_comments(cups_file_t *fp, /* I - File to read from */ + pstops_doc_t *doc, /* I - Document info */ + ppd_file_t *ppd, /* I - PPD file */ + char *line, /* I - Line buffer */ +- size_t linelen, /* I - Length of initial line */ ++ ssize_t linelen, /* I - Length of initial line */ + size_t linesize) /* I - Size of line buffer */ + { + int saw_bounding_box, /* Saw %%BoundingBox: comment? */ +@@ -809,7 +809,7 @@ copy_dsc(cups_file_t *fp, /* I - File + pstops_doc_t *doc, /* I - Document info */ + ppd_file_t *ppd, /* I - PPD file */ + char *line, /* I - Line buffer */ +- size_t linelen, /* I - Length of initial line */ ++ ssize_t linelen, /* I - Length of initial line */ + size_t linesize) /* I - Size of line buffer */ + { + int number; /* Page number */ +@@ -889,7 +889,8 @@ copy_dsc(cups_file_t *fp, /* I - File + * Finish up the last page(s)... + */ + +- if (number && !is_first_page(number) && cupsArrayLast(doc->pages)) ++ if (number && is_not_last_page(number) && cupsArrayLast(doc->pages) && ++ check_range(doc, (number - 1) / doc->number_up + 1)) + { + pageinfo = (pstops_page_t *)cupsArrayLast(doc->pages); + +@@ -930,7 +931,7 @@ copy_dsc(cups_file_t *fp, /* I - File + + number = doc->slow_order ? 0 : doc->page; + +- if (doc->temp && !JobCanceled) ++ if (doc->temp && !JobCanceled && cupsArrayCount(doc->pages) > 0) + { + int copy; /* Current copy */ + +@@ -1068,7 +1069,7 @@ copy_non_dsc(cups_file_t *fp, /* I - F + pstops_doc_t *doc, /* I - Document info */ + ppd_file_t *ppd, /* I - PPD file */ + char *line, /* I - Line buffer */ +- size_t linelen, /* I - Length of initial line */ ++ ssize_t linelen, /* I - Length of initial line */ + size_t linesize) /* I - Size of line buffer */ + { + int copy; /* Current copy */ +@@ -1244,13 +1245,13 @@ copy_non_dsc(cups_file_t *fp, /* I - F + * On return, "line" will contain the next line in the file, if any. + */ + +-static size_t /* O - Length of next line */ ++static ssize_t /* O - Length of next line */ + copy_page(cups_file_t *fp, /* I - File to read from */ + pstops_doc_t *doc, /* I - Document info */ + ppd_file_t *ppd, /* I - PPD file */ + int number, /* I - Current page number */ + char *line, /* I - Line buffer */ +- size_t linelen, /* I - Length of initial line */ ++ ssize_t linelen, /* I - Length of initial line */ + size_t linesize) /* I - Size of line buffer */ + { + char label[256], /* Page label string */ +@@ -1713,12 +1714,12 @@ copy_page(cups_file_t *fp, /* I - File + * On return, "line" will contain the next line in the file, if any. + */ + +-static size_t /* O - Length of next line */ ++static ssize_t /* O - Length of next line */ + copy_prolog(cups_file_t *fp, /* I - File to read from */ + pstops_doc_t *doc, /* I - Document info */ + ppd_file_t *ppd, /* I - PPD file */ + char *line, /* I - Line buffer */ +- size_t linelen, /* I - Length of initial line */ ++ ssize_t linelen, /* I - Length of initial line */ + size_t linesize) /* I - Size of line buffer */ + { + while (strncmp(line, "%%BeginProlog", 13)) +@@ -1767,12 +1768,12 @@ copy_prolog(cups_file_t *fp, /* I - Fi + * On return, "line" will contain the next line in the file, if any. + */ + +-static size_t /* O - Length of next line */ ++static ssize_t /* O - Length of next line */ + copy_setup(cups_file_t *fp, /* I - File to read from */ + pstops_doc_t *doc, /* I - Document info */ + ppd_file_t *ppd, /* I - PPD file */ + char *line, /* I - Line buffer */ +- size_t linelen, /* I - Length of initial line */ ++ ssize_t linelen, /* I - Length of initial line */ + size_t linesize) /* I - Size of line buffer */ + { + while (strncmp(line, "%%BeginSetup", 12)) +@@ -1832,13 +1833,13 @@ copy_setup(cups_file_t *fp, /* I - Fil + * On return, "line" will contain the next line in the file, if any. + */ + +-static size_t /* O - Length of next line */ ++static ssize_t /* O - Length of next line */ + copy_trailer(cups_file_t *fp, /* I - File to read from */ + pstops_doc_t *doc, /* I - Document info */ + ppd_file_t *ppd, /* I - PPD file */ + int number, /* I - Number of pages */ + char *line, /* I - Line buffer */ +- size_t linelen, /* I - Length of initial line */ ++ ssize_t linelen, /* I - Length of initial line */ + size_t linesize) /* I - Size of line buffer */ + { + /* +@@ -2711,10 +2712,10 @@ set_pstops_options( + * 'skip_page()' - Skip past a page that won't be printed... + */ + +-static size_t /* O - Length of next line */ ++static ssize_t /* O - Length of next line */ + skip_page(cups_file_t *fp, /* I - File to read from */ + char *line, /* I - Line buffer */ +- size_t linelen, /* I - Length of initial line */ ++ ssize_t linelen, /* I - Length of initial line */ + size_t linesize) /* I - Size of line buffer */ + { + int level; /* Embedded document level */ +diff -up cups-1.3.5/filter/image-photocd.c.1.3.x cups-1.3.5/filter/image-photocd.c +--- cups-1.3.5/filter/image-photocd.c.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/filter/image-photocd.c 2008-02-05 15:08:55.000000000 +0000 +@@ -7,7 +7,7 @@ + * is only YCC encoded. Support for the higher resolution images will + * require a lot of extra code... + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1993-2006 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -99,11 +99,33 @@ _cupsImageReadPhotoCD( + cupsImageSetMaxTiles(img, 0); + + bpp = cupsImageGetDepth(img); +- in = malloc(768 * 3); +- out = malloc(768 * bpp); ++ ++ if ((in = malloc(768 * 3)) == NULL) ++ { ++ fputs("DEBUG: Unable to allocate memory!\n", stderr); ++ fclose(fp); ++ return (1); ++ } ++ ++ if ((out = malloc(768 * bpp)) == NULL) ++ { ++ fputs("DEBUG: Unable to allocate memory!\n", stderr); ++ fclose(fp); ++ free(in); ++ return (1); ++ } + + if (bpp > 1) +- rgb = malloc(768 * 3); ++ { ++ if ((rgb = malloc(768 * 3)) == NULL) ++ { ++ fputs("DEBUG: Unable to allocate memory!\n", stderr); ++ fclose(fp); ++ free(in); ++ free(out); ++ return (1); ++ } ++ } + else + rgb = NULL; + +@@ -141,6 +163,9 @@ _cupsImageReadPhotoCD( + free(in); + free(out); + ++ if (bpp > 1) ++ free(rgb); ++ + return (-1); + } + +diff -up cups-1.3.5/filter/image-sgilib.c.1.3.x cups-1.3.5/filter/image-sgilib.c +--- cups-1.3.5/filter/image-sgilib.c.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/filter/image-sgilib.c 2008-02-05 15:08:55.000000000 +0000 +@@ -4,7 +4,7 @@ + * SGI image file format library routines for the Common UNIX Printing + * System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1993-2005 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -250,8 +250,20 @@ sgiOpenFile(FILE *file, /* I - File to + + fseek(sgip->file, 512, SEEK_SET); + +- sgip->table = calloc(sgip->zsize, sizeof(long *)); +- sgip->table[0] = calloc(sgip->ysize * sgip->zsize, sizeof(long)); ++ if ((sgip->table = calloc(sgip->zsize, sizeof(long *))) == NULL) ++ { ++ free(sgip); ++ return (NULL); ++ } ++ ++ if ((sgip->table[0] = calloc(sgip->ysize * sgip->zsize, ++ sizeof(long))) == NULL) ++ { ++ free(sgip->table); ++ free(sgip); ++ return (NULL); ++ } ++ + for (i = 1; i < sgip->zsize; i ++) + sgip->table[i] = sgip->table[0] + i * sgip->ysize; + +@@ -333,12 +345,39 @@ sgiOpenFile(FILE *file, /* I - File to + + sgip->firstrow = ftell(sgip->file); + sgip->nextrow = ftell(sgip->file); +- sgip->table = calloc(sgip->zsize, sizeof(long *)); +- sgip->table[0] = calloc(sgip->ysize * sgip->zsize, sizeof(long)); ++ if ((sgip->table = calloc(sgip->zsize, sizeof(long *))) == NULL) ++ { ++ free(sgip); ++ return (NULL); ++ } ++ ++ if ((sgip->table[0] = calloc(sgip->ysize * sgip->zsize, ++ sizeof(long))) == NULL) ++ { ++ free(sgip->table); ++ free(sgip); ++ return (NULL); ++ } ++ + for (i = 1; i < sgip->zsize; i ++) + sgip->table[i] = sgip->table[0] + i * sgip->ysize; +- sgip->length = calloc(sgip->zsize, sizeof(long *)); +- sgip->length[0] = calloc(sgip->ysize * sgip->zsize, sizeof(long)); ++ ++ if ((sgip->length = calloc(sgip->zsize, sizeof(long *))) == NULL) ++ { ++ free(sgip->table); ++ free(sgip); ++ return (NULL); ++ } ++ ++ if ((sgip->length[0] = calloc(sgip->ysize * sgip->zsize, ++ sizeof(long))) == NULL) ++ { ++ free(sgip->length); ++ free(sgip->table); ++ free(sgip); ++ return (NULL); ++ } ++ + for (i = 1; i < sgip->zsize; i ++) + sgip->length[i] = sgip->length[0] + i * sgip->ysize; + break; +diff -up cups-1.3.5/filter/interpret.c.1.3.x cups-1.3.5/filter/interpret.c +--- cups-1.3.5/filter/interpret.c.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/filter/interpret.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * PPD command interpreter for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1993-2007 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -571,7 +571,7 @@ _cupsRasterExecPS( + break; + } + +- if (obj->type == CUPS_PS_OTHER) ++ if (obj && obj->type == CUPS_PS_OTHER) + break; + } + +diff -up cups-1.3.5/filter/image-sun.c.1.3.x cups-1.3.5/filter/image-sun.c +--- cups-1.3.5/filter/image-sun.c.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/filter/image-sun.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * Sun Raster image file routines for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1993-2007 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -152,9 +152,32 @@ _cupsImageReadSunRaster( + in = malloc(img->xsize * 3 + 1); + } + +- bpp = cupsImageGetDepth(img); +- out = malloc(img->xsize * bpp); +- scanline = malloc(scanwidth); ++ if (!in) ++ { ++ fputs("DEBUG: Unable to allocate memory!\n", stderr); ++ fclose(fp); ++ return (1); ++ } ++ ++ bpp = cupsImageGetDepth(img); ++ ++ if ((out = malloc(img->xsize * bpp)) == NULL) ++ { ++ fputs("DEBUG: Unable to allocate memory!\n", stderr); ++ fclose(fp); ++ free(in); ++ return (1); ++ } ++ ++ if ((scanline = malloc(scanwidth)) == NULL) ++ { ++ fputs("DEBUG: Unable to allocate memory!\n", stderr); ++ fclose(fp); ++ free(in); ++ free(out); ++ return (1); ++ } ++ + run_count = 0; + run_value = 0; + +diff -up cups-1.3.5/filter/rastertoepson.c.1.3.x cups-1.3.5/filter/rastertoepson.c +--- cups-1.3.5/filter/rastertoepson.c.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/filter/rastertoepson.c 2008-02-05 15:08:55.000000000 +0000 +@@ -4,7 +4,7 @@ + * EPSON ESC/P and ESC/P2 filter for the Common UNIX Printing System + * (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1993-2007 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -153,7 +153,7 @@ StartPage(const ppd_file_t *ppd, + * Send a reset sequence. + */ + +- if (ppd->nickname && strstr(ppd->nickname, "OKIDATA") != NULL) ++ if (ppd && ppd->nickname && strstr(ppd->nickname, "OKIDATA") != NULL) + printf("\033{A"); /* Set EPSON emulation mode */ + + printf("\033@"); +@@ -164,7 +164,7 @@ StartPage(const ppd_file_t *ppd, + + EjectPage = header->Margins[0] || header->Margins[1]; + +- switch (ppd->model_number) ++ switch (Model) + { + case EPSON_9PIN : + case EPSON_24PIN : +@@ -196,7 +196,7 @@ StartPage(const ppd_file_t *ppd, + DotColumns = header->HWResolution[0] / 60; + Shingling = 0; + +- if (ppd->model_number == EPSON_9PIN) ++ if (Model == EPSON_9PIN) + printf("\033\063\030"); /* Set line feed */ + else + switch (header->HWResolution[0]) +@@ -251,8 +251,11 @@ StartPage(const ppd_file_t *ppd, + putchar(n); + putchar(n >> 8); + +- t = (ppd->sizes[1].length - ppd->sizes[1].top) * +- header->HWResolution[1] / 72.0; ++ if (ppd) ++ t = (ppd->sizes[1].length - ppd->sizes[1].top) * ++ header->HWResolution[1] / 72.0; ++ else ++ t = 0; + + pwrite("\033(c\004\000", 5); /* Top & bottom margins */ + putchar(t); +@@ -293,18 +296,35 @@ StartPage(const ppd_file_t *ppd, + * Allocate memory for a line/row of graphics... + */ + +- Planes[0] = malloc(header->cupsBytesPerLine); ++ if ((Planes[0] = malloc(header->cupsBytesPerLine)) == NULL) ++ { ++ fputs("ERROR: Unable to allocate memory!\n", stderr); ++ exit(1); ++ } ++ + for (plane = 1; plane < NumPlanes; plane ++) + Planes[plane] = Planes[0] + plane * header->cupsBytesPerLine / NumPlanes; + + if (header->cupsCompression || DotBytes) +- CompBuffer = calloc(2, header->cupsWidth); ++ { ++ if ((CompBuffer = calloc(2, header->cupsWidth)) == NULL) ++ { ++ fputs("ERROR: Unable to allocate memory!\n", stderr); ++ exit(1); ++ } ++ } + else + CompBuffer = NULL; + + if (DotBytes) + { +- LineBuffers[0] = calloc(DotBytes, header->cupsWidth * (Shingling + 1)); ++ if ((LineBuffers[0] = calloc(DotBytes, ++ header->cupsWidth * (Shingling + 1))) == NULL) ++ { ++ fputs("ERROR: Unable to allocate memory!\n", stderr); ++ exit(1); ++ } ++ + LineBuffers[1] = LineBuffers[0] + DotBytes * header->cupsWidth; + DotBit = 128; + LineCount = 0; +diff -up cups-1.3.5/filter/image-sgi.c.1.3.x cups-1.3.5/filter/image-sgi.c +--- cups-1.3.5/filter/image-sgi.c.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/filter/image-sgi.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * SGI image file routines for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1993-2007 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -77,7 +77,6 @@ _cupsImageReadSGI( + fprintf(stderr, "DEBUG: Bad SGI image dimensions %ux%ux%u!\n", + sgip->xsize, sgip->ysize, sgip->zsize); + sgiClose(sgip); +- fclose(fp); + return (1); + } + +@@ -92,10 +91,32 @@ _cupsImageReadSGI( + cupsImageSetMaxTiles(img, 0); + + bpp = cupsImageGetDepth(img); +- in = malloc(img->xsize * sgip->zsize); +- out = malloc(img->xsize * bpp); + +- rows[0] = calloc(img->xsize * sgip->zsize, sizeof(unsigned short)); ++ if ((in = malloc(img->xsize * sgip->zsize)) == NULL) ++ { ++ fputs("DEBUG: Unable to allocate memory!\n", stderr); ++ sgiClose(sgip); ++ return (1); ++ } ++ ++ if ((out = malloc(img->xsize * bpp)) == NULL) ++ { ++ fputs("DEBUG: Unable to allocate memory!\n", stderr); ++ sgiClose(sgip); ++ free(in); ++ return (1); ++ } ++ ++ if ((rows[0] = calloc(img->xsize * sgip->zsize, ++ sizeof(unsigned short))) == NULL) ++ { ++ fputs("DEBUG: Unable to allocate memory!\n", stderr); ++ sgiClose(sgip); ++ free(in); ++ free(out); ++ return (1); ++ } ++ + for (i = 1; i < sgip->zsize; i ++) + rows[i] = rows[0] + i * img->xsize; + +diff -up cups-1.3.5/filter/image-pnm.c.1.3.x cups-1.3.5/filter/image-pnm.c +--- cups-1.3.5/filter/image-pnm.c.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/filter/image-pnm.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * Portable Any Map file routines for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1993-2007 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -67,7 +67,13 @@ _cupsImageReadPNM( + * max sample + */ + +- lineptr = fgets(line, sizeof(line), fp); ++ if ((lineptr = fgets(line, sizeof(line), fp)) == NULL) ++ { ++ fputs("DEBUG: Bad PNM header!\n", stderr); ++ fclose(fp); ++ return (1); ++ } ++ + lineptr ++; + + format = atoi(lineptr); +@@ -147,8 +153,21 @@ _cupsImageReadPNM( + cupsImageSetMaxTiles(img, 0); + + bpp = cupsImageGetDepth(img); +- in = malloc(img->xsize * 3); +- out = malloc(img->xsize * bpp); ++ ++ if ((in = malloc(img->xsize * 3)) == NULL) ++ { ++ fputs("DEBUG: Unable to allocate memory!\n", stderr); ++ fclose(fp); ++ return (1); ++ } ++ ++ if ((out = malloc(img->xsize * bpp)) == NULL) ++ { ++ fputs("DEBUG: Unable to allocate memory!\n", stderr); ++ fclose(fp); ++ free(in); ++ return (1); ++ } + + /* + * Read the image file... +diff -up cups-1.3.5/filter/hpgl-input.c.1.3.x cups-1.3.5/filter/hpgl-input.c +--- cups-1.3.5/filter/hpgl-input.c.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/filter/hpgl-input.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * HP-GL/2 input processing for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1993-2006 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -48,6 +48,7 @@ ParseCommand(FILE *fp, /* I - File to + i; /* Looping var */ + char buf[262144], /* String buffer */ + *bufptr; /* Pointer into buffer */ ++ float temp; /* Temporary parameter value */ + static param_t p[MAX_PARAMS]; /* Parameter buffer */ + + +@@ -212,10 +213,10 @@ ParseCommand(FILE *fp, /* I - File to + case '-' : + case '+' : + ungetc(ch, fp); +- fscanf(fp, "%f", &(p[num_params].value.number)); +- if (num_params < MAX_PARAMS) ++ if (fscanf(fp, "%f", &temp) == 1 && num_params < MAX_PARAMS) + { +- p[num_params].type = PARAM_RELATIVE; ++ p[num_params].type = PARAM_RELATIVE; ++ p[num_params].value.number = temp; + num_params ++; + } + break; +@@ -231,10 +232,10 @@ ParseCommand(FILE *fp, /* I - File to + case '9' : + case '.' : + ungetc(ch, fp); +- fscanf(fp, "%f", &(p[num_params].value.number)); +- if (num_params < MAX_PARAMS) ++ if (fscanf(fp, "%f", &temp) == 1 && num_params < MAX_PARAMS) + { +- p[num_params].type = PARAM_ABSOLUTE; ++ p[num_params].type = PARAM_ABSOLUTE; ++ p[num_params].value.number = temp; + num_params ++; + } + break; +diff -up cups-1.3.5/filter/image-bmp.c.1.3.x cups-1.3.5/filter/image-bmp.c +--- cups-1.3.5/filter/image-bmp.c.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/filter/image-bmp.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * BMP image routines for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1993-2007 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -179,9 +179,22 @@ _cupsImageReadBMP( + + cupsImageSetMaxTiles(img, 0); + +- in = malloc(img->xsize * 3); + bpp = cupsImageGetDepth(img); +- out = malloc(img->xsize * bpp); ++ ++ if ((in = malloc(img->xsize * 3)) == NULL) ++ { ++ fputs("DEBUG: Unable to allocate memory!\n", stderr); ++ fclose(fp); ++ return (1); ++ } ++ ++ if ((out = malloc(img->xsize * bpp)) == NULL) ++ { ++ fputs("DEBUG: Unable to allocate memory!\n", stderr); ++ free(in); ++ fclose(fp); ++ return (1); ++ } + + /* + * Read the image data... +diff -up cups-1.3.5/filter/image-gif.c.1.3.x cups-1.3.5/filter/image-gif.c +--- cups-1.3.5/filter/image-gif.c.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/filter/image-gif.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * GIF image routines for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1993-2007 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -462,8 +462,14 @@ gif_read_image(FILE *fp, /* I - + pass = 0; + code_size = getc(fp); + ++ if (!pixels) ++ return (-1); ++ + if (gif_read_lzw(fp, 1, code_size) < 0) ++ { ++ free(pixels); + return (-1); ++ } + + temp = pixels; + while ((pixel = gif_read_lzw(fp, 0, code_size)) >= 0) +diff -up cups-1.3.5/filter/image-pix.c.1.3.x cups-1.3.5/filter/image-pix.c +--- cups-1.3.5/filter/image-pix.c.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/filter/image-pix.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * Alias PIX image routines for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1993-2007 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -95,9 +95,22 @@ _cupsImageReadPIX( + + cupsImageSetMaxTiles(img, 0); + +- in = malloc(img->xsize * (depth / 8)); + bpp = cupsImageGetDepth(img); +- out = malloc(img->xsize * bpp); ++ ++ if ((in = malloc(img->xsize * (depth / 8))) == NULL) ++ { ++ fputs("DEBUG: Unable to allocate memory!\n", stderr); ++ fclose(fp); ++ return (1); ++ } ++ ++ if ((out = malloc(img->xsize * bpp)) == NULL) ++ { ++ fputs("DEBUG: Unable to allocate memory!\n", stderr); ++ fclose(fp); ++ free(in); ++ return (1); ++ } + + /* + * Read the image data... +diff -up cups-1.3.5/filter/image.c.1.3.x cups-1.3.5/filter/image.c +--- cups-1.3.5/filter/image.c.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/filter/image.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * Base image support for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1993-2005 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -320,15 +320,10 @@ cupsImageOpen( + */ + + if ((fp = fopen(filename, "r")) == NULL) +- { +-/* perror("ERROR: Unable to open image file"); +-*/ return (NULL); +- } ++ return (NULL); + + if (fread(header, 1, sizeof(header), fp) == 0) + { +-/* perror("ERROR: Unable to read image file header"); +-*/ + fclose(fp); + return (NULL); + } +@@ -346,8 +341,7 @@ cupsImageOpen( + + if (img == NULL) + { +-/* perror("ERROR: Unable to allocate memory for image file"); +-*/ fclose(fp); ++ fclose(fp); + return (NULL); + } + +@@ -401,8 +395,7 @@ cupsImageOpen( + #endif /* HAVE_LIBTIFF */ + else + { +-/* fputs("ERROR: Unknown image file format!"); +-*/ fclose(fp); ++ fclose(fp); + status = -1; + } + +@@ -729,8 +722,11 @@ get_tile(cups_image_t *img, /* I - Imag + + DEBUG_printf(("Creating tile array (%dx%d)\n", xtiles, ytiles)); + +- img->tiles = calloc(sizeof(cups_itile_t *), ytiles); +- tile = calloc(sizeof(cups_itile_t), xtiles * ytiles); ++ if ((img->tiles = calloc(sizeof(cups_itile_t *), ytiles)) == NULL) ++ return (NULL); ++ ++ if ((tile = calloc(sizeof(cups_itile_t), xtiles * ytiles)) == NULL) ++ return (NULL); + + for (tiley = 0; tiley < ytiles; tiley ++) + { +@@ -751,13 +747,23 @@ get_tile(cups_image_t *img, /* I - Imag + { + if (img->num_ics < img->max_ics) + { +- ic = calloc(sizeof(cups_ic_t) + bpp * CUPS_TILE_SIZE * +- CUPS_TILE_SIZE, 1); +- ic->pixels = ((cups_ib_t *)ic) + sizeof(cups_ic_t); ++ if ((ic = calloc(sizeof(cups_ic_t) + ++ bpp * CUPS_TILE_SIZE * CUPS_TILE_SIZE, 1)) == NULL) ++ { ++ if (img->num_ics == 0) ++ return (NULL); ++ ++ flush_tile(img); ++ ic = img->first; ++ } ++ else ++ { ++ ic->pixels = ((cups_ib_t *)ic) + sizeof(cups_ic_t); + +- img->num_ics ++; ++ img->num_ics ++; + +- DEBUG_printf(("Allocated cache tile %d (%p)...\n", img->num_ics, ic)); ++ DEBUG_printf(("Allocated cache tile %d (%p)...\n", img->num_ics, ic)); ++ } + } + else + { +diff -up cups-1.3.5/filter/rastertohp.c.1.3.x cups-1.3.5/filter/rastertohp.c +--- cups-1.3.5/filter/rastertohp.c.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/filter/rastertohp.c 2008-02-05 15:08:55.000000000 +0000 +@@ -4,7 +4,7 @@ + * Hewlett-Packard Page Control Language filter for the Common UNIX + * Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1993-2007 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -277,7 +277,7 @@ StartPage(ppd_file_t *ppd, /* I + * Set graphics mode... + */ + +- if (ppd->model_number == 2) ++ if (ppd && ppd->model_number == 2) + { + /* + * Figure out the number of color planes... +@@ -382,7 +382,12 @@ StartPage(ppd_file_t *ppd, /* I + * Allocate memory for a line of graphics... + */ + +- Planes[0] = malloc(header->cupsBytesPerLine); ++ if ((Planes[0] = malloc(header->cupsBytesPerLine)) == NULL) ++ { ++ fputs("ERROR: Unable to allocate memory!\n", stderr); ++ exit(1); ++ } ++ + for (plane = 1; plane < NumPlanes; plane ++) + Planes[plane] = Planes[0] + plane * header->cupsBytesPerLine / NumPlanes; + +diff -up cups-1.3.5/config.h.in.1.3.x cups-1.3.5/config.h.in +--- cups-1.3.5/config.h.in.1.3.x 2007-08-29 18:22:26.000000000 +0100 ++++ cups-1.3.5/config.h.in 2008-02-05 15:08:55.000000000 +0000 +@@ -77,13 +77,6 @@ + + + /* +- * Maximum number of file descriptors to support. +- */ +- +-#define CUPS_MAX_FDS 4096 +- +- +-/* + * Do we have domain socket support? + */ + +@@ -446,13 +439,6 @@ + + + /* +- * Do we have CFLocaleCreateCanonicalLocaleIdentifierFromString()? +- */ +- +-#undef HAVE_CF_LOCALE_ID +- +- +-/* + * Do we have MacOSX 10.4's mbr_XXX functions()? + */ + +diff -up cups-1.3.5/Makedefs.in.1.3.x cups-1.3.5/Makedefs.in +--- cups-1.3.5/Makedefs.in.1.3.x 2007-10-10 23:50:07.000000000 +0100 ++++ cups-1.3.5/Makedefs.in 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + # + # Common makefile definitions for the Common UNIX Printing System (CUPS). + # +-# Copyright 2007 by Apple Inc. ++# Copyright 2007-2008 by Apple Inc. + # Copyright 1997-2007 by Easy Software Products, all rights reserved. + # + # These coded instructions, statements, and computer programs are the +@@ -108,17 +108,17 @@ INSTALLSTATIC = @INSTALLSTATIC@ + # for extra debug info) + # + +-ALL_CFLAGS = $(CFLAGS) $(SSLFLAGS) @LARGEFILE@ @PTHREAD_FLAGS@ \ +- $(OPTIONS) ++ALL_CFLAGS = -I.. -D_CUPS_SOURCE $(CFLAGS) $(SSLFLAGS) \ ++ @LARGEFILE@ @PTHREAD_FLAGS@ $(OPTIONS) ++ALL_CXXFLAGS = -I.. -D_CUPS_SOURCE $(CXXFLAGS) $(SSLFLAGS) \ ++ @LARGEFILE@ @PTHREAD_FLAGS@ $(OPTIONS) + ARCHFLAGS = @ARCHFLAGS@ + ARFLAGS = @ARFLAGS@ + BACKLIBS = @BACKLIBS@ +-CFLAGS = -I.. @CPPFLAGS@ @CFLAGS@ \ +- @LARGEFILE@ @PTHREAD_FLAGS@ $(OPTIONS) ++CFLAGS = @CPPFLAGS@ @CFLAGS@ + COMMONLIBS = @LIBS@ + CUPSDLIBS = @CUPSDLIBS@ +-CXXFLAGS = -I.. $(SSLFLAGS) @CPPFLAGS@ @CXXFLAGS@ \ +- @LARGEFILE@ @PTHREAD_FLAGS@ $(OPTIONS) ++CXXFLAGS = @CPPFLAGS@ @CXXFLAGS@ + CXXLIBS = @CXXLIBS@ + DSOFLAGS = @DSOFLAGS@ + DSOLIBS = @DSOLIBS@ $(COMMONLIBS) +@@ -258,7 +258,7 @@ DBUSDIR = @DBUSDIR@ + + .cxx.o: + echo Compiling $<... +- $(CXX) $(ARCHFLAGS) $(OPTIM) $(CXXFLAGS) -c $< ++ $(CXX) $(ARCHFLAGS) $(OPTIM) $(ALL_CXXFLAGS) -c $< + + .man.1 .man.1m .man.5 .man.7 .man.8: + echo Linking $<... +diff -up cups-1.3.5/doc/index.html.in.1.3.x cups-1.3.5/doc/index.html.in +--- cups-1.3.5/doc/index.html.in.1.3.x 2007-12-07 18:37:40.000000000 +0000 ++++ cups-1.3.5/doc/index.html.in 2008-02-05 15:08:55.000000000 +0000 +@@ -112,9 +112,9 @@ assistance:

+ WIDTH="15" HEIGHT="15" ALT=""> + + +-

The Common UNIX Printing System, CUPS, and the CUPS logo are the +-trademark property of Apple Inc. +-CUPS is copyright 2007 by Apple Inc., All Rights Reserved.

++

The Common UNIX Printing System, CUPS, and the CUPS logo are ++trademarks of Apple Inc. CUPS is ++copyright 2007-2008 Apple Inc. All rights reserved.

+ + + +diff -up cups-1.3.5/doc/help/spec-ppd.html.1.3.x cups-1.3.5/doc/help/spec-ppd.html +--- cups-1.3.5/doc/help/spec-ppd.html.1.3.x 2007-10-31 18:35:56.000000000 +0000 ++++ cups-1.3.5/doc/help/spec-ppd.html 2008-02-05 15:08:55.000000000 +0000 +@@ -1204,7 +1204,7 @@ list of locale names ("en", "en_US", "fr + +
+ *% Specify Canadian, UK, and US English, and Candian and French French 
+-*cupsLanguages: "en_CA en_UK en_US fr_CA fr_CA"
++*cupsLanguages: "en_CA en_UK en_US fr_CA fr_FR"
+ 
+ +

cupsManualCopies

+diff -up cups-1.3.5/doc/help/spec-ipp.html.1.3.x cups-1.3.5/doc/help/spec-ipp.html +--- cups-1.3.5/doc/help/spec-ipp.html.1.3.x 2007-07-12 23:58:17.000000000 +0100 ++++ cups-1.3.5/doc/help/spec-ipp.html 2008-02-05 15:08:55.000000000 +0000 +@@ -11,7 +11,7 @@ + + CUPS IPP specification for the Common UNIX Printing System (CUPS). + +- Copyright 2007 by Apple Inc. ++ Copyright 2007-2008 by Apple Inc. + Copyright 1997-2007 by Easy Software Products. + + These coded instructions, statements, and computer programs are the +@@ -2251,6 +2251,101 @@ the system. +

The job-sheets-supported attribute specifies the available banner files. + There will always be at least one banner file available called "none". + ++

marker-change-time (integer)

++ ++

The marker-change-time attribute specifies the printer-up-time value when ++the last change to the marker-colors, marker-levels, marker-names, or ++marker-types attributes was made.

++ ++

marker-colors (1setof name(MAX))

++ ++

The marker-colors attribute specifies the color(s) for each supply in the ++printer. It is only available when the driver provides supply levels. The ++color is either "none" or one or more hex-encoded sRGB colors of the form ++"#RRGGBB".

++ ++

marker-levels (1setof integer(-1:100))

++ ++

The marker-levels attribute specifies the current supply levels for the ++printer. It is only available when the driver provides supply levels. A ++value of -1 indicates the level is unknown, while values from 0 to 100 ++indicate the corresponding percentage.

++ ++

marker-names (1setof name(MAX))

++ ++

The marker-names attribute specifies the name(s) for each supply in the ++printer. It is only available when the driver provides supply levels.

++ ++

marker-types (1setof type3 keyword)

++ ++

The marker-types attribute specifies the type(s) of each supply in the ++printer. It is only available when the driver provides supply levels. The ++following (RFC 3805) types are currently supported:

++ ++
    ++ ++
  • toner
  • ++ ++
  • wasteToner
  • ++ ++
  • ink
  • ++ ++
  • inkCartridge
  • ++ ++
  • inkRibbon
  • ++ ++
  • wasteInk
  • ++ ++
  • opc
  • ++ ++
  • developer
  • ++ ++
  • fuserOil
  • ++ ++
  • solidWax
  • ++ ++
  • ribbonWax
  • ++ ++
  • wasteWax
  • ++ ++
  • fuser
  • ++ ++
  • coronaWire
  • ++ ++
  • fuserOilWick
  • ++ ++
  • cleanerUnit
  • ++ ++
  • fuserCleaningPad
  • ++ ++
  • transferUnit
  • ++ ++
  • tonerCartridge
  • ++ ++
  • fuserOiler
  • ++ ++
  • water
  • ++ ++
  • wasteWater
  • ++ ++
  • bindingSupply
  • ++ ++
  • bandingSupply
  • ++ ++
  • stichingWire
  • ++ ++
  • shrinkWrap
  • ++ ++
  • paperWrap
  • ++ ++
  • staples
  • ++ ++
  • inserts
  • ++ ++
  • covers
  • ++ ++
++ +

port-monitor" (name(127))

+ +

The port-monitor attribute specifies the port monitor to use when printing +diff -up cups-1.3.5/systemv/cupstestppd.c.1.3.x cups-1.3.5/systemv/cupstestppd.c +--- cups-1.3.5/systemv/cupstestppd.c.1.3.x 2007-11-27 00:09:24.000000000 +0000 ++++ cups-1.3.5/systemv/cupstestppd.c 2008-02-05 15:08:55.000000000 +0000 +@@ -3,7 +3,7 @@ + * + * PPD test program for the Common UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2007 by Easy Software Products, all rights reserved. + * + * These coded instructions, statements, and computer programs are the +@@ -2010,8 +2010,10 @@ check_translations(ppd_file_t *ppd, /* I + * This file contains localizations, check them... + */ + +- languages = strdup(attr->value); +- langlist = cupsArrayNew((cups_array_func_t)strcmp, NULL); ++ if ((languages = strdup(attr->value)) == NULL) ++ return (1); ++ ++ langlist = cupsArrayNew((cups_array_func_t)strcmp, NULL); + + for (langptr = languages; *langptr;) + { +diff -up cups-1.3.5/systemv/lpmove.c.1.3.x cups-1.3.5/systemv/lpmove.c +--- cups-1.3.5/systemv/lpmove.c.1.3.x 2007-11-27 00:09:24.000000000 +0000 ++++ cups-1.3.5/systemv/lpmove.c 2008-02-05 15:08:55.000000000 +0000 +@@ -61,7 +61,6 @@ main(int argc, /* I - Number of comm + + dest = NULL; + dests = NULL; +- http = NULL; + job = NULL; + jobid = 0; + num_dests = 0; +@@ -75,8 +74,6 @@ main(int argc, /* I - Number of comm + #ifdef HAVE_SSL + cupsSetEncryption(HTTP_ENCRYPT_REQUIRED); + +- if (http) +- httpEncryption(http, HTTP_ENCRYPT_REQUIRED); + #else + _cupsLangPrintf(stderr, + _("%s: Sorry, no encryption support compiled in!\n"), +@@ -85,12 +82,6 @@ main(int argc, /* I - Number of comm + break; + + case 'h' : /* Connect to host */ +- if (http) +- { +- httpClose(http); +- http = NULL; +- } +- + if (argv[i][2] != '\0') + cupsSetServer(argv[i] + 2); + else +@@ -142,17 +133,14 @@ main(int argc, /* I - Number of comm + return (1); + } + +- if (!http) +- { +- http = httpConnectEncrypt(cupsServer(), ippPort(), cupsEncryption()); ++ http = httpConnectEncrypt(cupsServer(), ippPort(), cupsEncryption()); + +- if (http == NULL) +- { +- _cupsLangPrintf(stderr, +- _("lpmove: Unable to connect to server: %s\n"), +- strerror(errno)); +- return (1); +- } ++ if (http == NULL) ++ { ++ _cupsLangPrintf(stderr, ++ _("lpmove: Unable to connect to server: %s\n"), ++ strerror(errno)); ++ return (1); + } + + return (move_job(http, src, jobid, dest)); +diff -up cups-1.3.5/systemv/accept.c.1.3.x cups-1.3.5/systemv/accept.c +--- cups-1.3.5/systemv/accept.c.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/systemv/accept.c 2008-02-05 15:08:55.000000000 +0000 +@@ -4,7 +4,7 @@ + * "accept", "disable", "enable", and "reject" commands for the Common + * UNIX Printing System (CUPS). + * +- * Copyright 2007 by Apple Inc. ++ * Copyright 2007-2008 by Apple Inc. + * Copyright 1997-2006 by Easy Software Products. + * + * These coded instructions, statements, and computer programs are the +@@ -125,8 +125,11 @@ main(int argc, /* I - Number of comm + break; + + case 'h' : /* Connect to host */ +- if (http != NULL) ++ if (http) ++ { + httpClose(http); ++ http = NULL; ++ } + + if (argv[i][2] != '\0') + cupsSetServer(argv[i] + 2); +diff -up cups-1.3.5/README.txt.1.3.x cups-1.3.5/README.txt +--- cups-1.3.5/README.txt.1.3.x 2007-09-18 21:39:31.000000000 +0100 ++++ cups-1.3.5/README.txt 2008-02-05 15:08:55.000000000 +0000 +@@ -1,4 +1,4 @@ +-README - CUPS v1.3.2 - 2007-09-18 ++README - CUPS v1.3.6 - 2008-01-22 + --------------------------------- + + Looking for compile instructions? Read the file "INSTALL.txt" +@@ -153,9 +153,9 @@ PRINTING FILES + + LEGAL STUFF + +- CUPS is Copyright 2007 by Apple Inc. CUPS, the CUPS logo, and +- the Common UNIX Printing System are the trademark property of +- Apple Inc. ++ CUPS is Copyright 2007-2008 by Apple Inc. CUPS, the CUPS logo, ++ and the Common UNIX Printing System are the trademark property ++ of Apple Inc. + + The MD5 Digest code is Copyright 1999 Aladdin Enterprises. + +diff -up cups-1.3.5/data/testprint.ps.1.3.x cups-1.3.5/data/testprint.ps +--- cups-1.3.5/data/testprint.ps.1.3.x 2007-07-11 22:46:42.000000000 +0100 ++++ cups-1.3.5/data/testprint.ps 2008-02-05 15:08:55.000000000 +0000 +@@ -14,7 +14,7 @@ + % + % PostScript test page for the Common UNIX Printing System ("CUPS"). + % +-% Copyright 2007 Apple Inc. ++% Copyright 2007-2008 Apple Inc. + % Copyright 1993-2007 Easy Software Products + % + % These coded instructions, statements, and computer programs are the +@@ -573,10 +573,10 @@ gsave + pageHeight 8 mul % Move down... + 2 copy moveto % Position text + smallFont setfont % Font +- (Copyright 2007 Apple Inc., All Rights Reserved. CUPS and the CUPS logo are the trademark) show ++ (Copyright 2007-2008 Apple Inc., All Rights Reserved. CUPS and the CUPS logo are the) show + pageHeight 2 add sub % Move down... + 2 copy moveto % Position text +- (property of Apple Inc., 1 Infinite Loop, Cupertino, CA 95014, USA.) show ++ (trademark property of Apple Inc., 1 Infinite Loop, Cupertino, CA 95014, USA.) show + pageHeight 2 mul 4 add sub % Move down... + moveto % Position text + (Need help? Contact your operating system vendor or visit "http://www.cups.org/".) show diff --git a/cups-lspp.patch b/cups-lspp.patch index 2d7edba..e699817 100644 --- a/cups-lspp.patch +++ b/cups-lspp.patch @@ -1297,7 +1297,7 @@ + { + if (getfilecon(con->filename, &spoolcon) == -1) + { -+ cupsdSendError(con, HTTP_SERVER_ERROR, AUTH_NONE); ++ cupsdSendError(con, HTTP_SERVER_ERROR, CUPSD_AUTH_NONE); + return (cupsdCloseClient(con)); + } + clicon = context_new(con->scon); @@ -1305,7 +1305,7 @@ + freecon(spoolcon); + if (!clicon || !tmpcon) + { -+ cupsdSendError(con, HTTP_SERVER_ERROR, AUTH_NONE); ++ cupsdSendError(con, HTTP_SERVER_ERROR, CUPSD_AUTH_NONE); + if (clicon) + context_free(clicon); + if (tmpcon) @@ -1320,7 +1320,7 @@ + { + if (context_range_set(tmpcon, cliclearance) == -1) + { -+ cupsdSendError(con, HTTP_SERVER_ERROR, AUTH_NONE); ++ cupsdSendError(con, HTTP_SERVER_ERROR, CUPSD_AUTH_NONE); + free(clirange); + context_free(tmpcon); + context_free(clicon); @@ -1331,7 +1331,7 @@ + { + if (context_range_set(tmpcon, (context_range_get(clicon))) == -1) + { -+ cupsdSendError(con, HTTP_SERVER_ERROR, AUTH_NONE); ++ cupsdSendError(con, HTTP_SERVER_ERROR, CUPSD_AUTH_NONE); + free(clirange); + context_free(tmpcon); + context_free(clicon); @@ -1342,7 +1342,7 @@ + } + if (setfilecon(con->filename, context_str(tmpcon)) == -1) + { -+ cupsdSendError(con, HTTP_SERVER_ERROR, AUTH_NONE); ++ cupsdSendError(con, HTTP_SERVER_ERROR, CUPSD_AUTH_NONE); + context_free(tmpcon); + context_free(clicon); + return (cupsdCloseClient(con)); diff --git a/cups-str2650.patch b/cups-str2650.patch deleted file mode 100644 index 695806c..0000000 --- a/cups-str2650.patch +++ /dev/null @@ -1,25 +0,0 @@ -diff -up cups-1.3.5/cups/adminutil.c.str2650 cups-1.3.5/cups/adminutil.c ---- cups-1.3.5/cups/adminutil.c.str2650 2007-11-30 07:00:59.000000000 +0000 -+++ cups-1.3.5/cups/adminutil.c 2008-01-09 12:14:45.000000000 +0000 -@@ -1057,7 +1057,7 @@ _cupsAdminGetServerSettings( - in_admin_location = 0; - in_location = 0; - } -- else if (!strcasecmp(line, "Allow") && in_admin_location && -+ else if (!strcasecmp(line, "Allow") && - strcasecmp(value, "localhost") && strcasecmp(value, "127.0.0.1") - #ifdef AF_LOCAL - && *value != '/' -@@ -1067,9 +1067,9 @@ _cupsAdminGetServerSettings( - #endif /* AF_INET6 */ - ) - { -- remote_admin = 1; -- -- if (!strcasecmp(value, "all")) -+ if (in_admin_location) -+ remote_admin = 1; -+ else if (!strcasecmp(value, "all")) - remote_any = 1; - } - else if (line[0] != '<' && !in_location && !in_policy) diff --git a/cups-str2664.patch b/cups-str2664.patch deleted file mode 100644 index 8ca7ee9..0000000 --- a/cups-str2664.patch +++ /dev/null @@ -1,12 +0,0 @@ -diff -up cups-1.3.5/backend/runloop.c~ cups-1.3.5/backend/runloop.c ---- cups-1.3.5/backend/runloop.c~ 2007-08-22 19:34:34.000000000 +0100 -+++ cups-1.3.5/backend/runloop.c 2008-01-09 15:37:44.000000000 +0000 -@@ -216,7 +216,7 @@ backendRunLoop( - FD_SET(CUPS_SC_FD, &input); - - FD_ZERO(&output); -- if (print_bytes || !use_bc) -+ if (print_bytes || (!use_bc && !side_cb)) - FD_SET(device_fd, &output); - - if (use_bc || side_cb) diff --git a/cups.spec b/cups.spec index 11b9c19..92adbf1 100644 --- a/cups.spec +++ b/cups.spec @@ -6,7 +6,7 @@ Summary: Common Unix Printing System Name: cups Version: 1.3.5 -Release: 3%{?dist} +Release: 4%{?dist} License: GPLv2 Group: System Environment/Daemons Source: ftp://ftp.easysw.com/pub/cups/test//cups-%{version}-source.tar.bz2 @@ -24,6 +24,7 @@ Source12: cups.cron Source13: pdftops.conf Source14: textonly.filter Source15: textonly.ppd +Patch0: cups-1.3.x.patch Patch1: cups-1.1.15-initscript.patch Patch2: cups-no-gzip-man.patch Patch3: cups-1.1.16-system-auth.patch @@ -40,12 +41,10 @@ Patch13: cups-direct-usb.patch Patch14: cups-lpr-help.patch Patch16: cups-pid.patch Patch17: cups-foomatic-recommended.patch -Patch18: cups-str2650.patch Patch19: cups-eggcups.patch Patch20: cups-getpass.patch Patch21: cups-driverd-timeout.patch Patch22: cups-strict-ppd-line-length.patch -Patch23: cups-str2664.patch Patch25: cups-usb-paperout.patch Patch100: cups-lspp.patch Epoch: 1 @@ -138,6 +137,7 @@ lpd emulation. %prep %setup -q -n %{name}-%{version} +%patch0 -p1 -b .1.3.x %patch1 -p1 -b .noinit %patch2 -p1 -b .no-gzip-man %patch3 -p1 -b .system-auth @@ -154,12 +154,10 @@ lpd emulation. %patch14 -p1 -b .lpr-help %patch16 -p1 -b .pid %patch17 -p1 -b .foomatic-recommended -%patch18 -p1 -b .str2650 %patch19 -p1 -b .eggcups %patch20 -p1 -b .getpass %patch21 -p1 -b .driverd-timeout %patch22 -p1 -b .strict-ppd-line-length -%patch23 -p1 -b .str2664 %patch25 -p1 -b .usb-paperout %if %lspp @@ -452,6 +450,10 @@ rm -rf $RPM_BUILD_ROOT %{cups_serverbin}/daemon/cups-lpd %changelog +* Tue Feb 5 2008 Tim Waugh 1:1.3.5-4 +- Include fixes from svn up to revision 7287. No longer need str2650 or + str2664 patches. + * Fri Feb 1 2008 Tim Waugh - Updated initscript for LSB exit codes and actions (bug #246897).