From 4bc5f48001a8ef59fa847ba2aafef73f7669fb46 Mon Sep 17 00:00:00 2001 From: Rose <83477269+AtariDreams@users.noreply.github.com> Date: Thu, 27 Apr 2023 12:14:29 -0400 Subject: [PATCH] Simplify bounds checks We can save a lot of work this way. --- backend/dnssd.c | 23 +++++++++++++++-------- cgi-bin/ipp-var.c | 12 ++++++------ cgi-bin/template.c | 6 +++--- cgi-bin/var.c | 12 ++++++------ cups/debug.c | 12 ++++++------ cups/dest.c | 3 +++ cups/encode.c | 5 ++--- cups/http-addrlist.c | 42 ++++++++++++++++++++++-------------------- cups/options.c | 5 +++-- scheduler/auth.c | 9 +++++---- scheduler/log.c | 13 ++++++------- scheduler/printers.c | 15 +++++---------- tools/ippeveprinter.c | 26 +++++++++++++------------- tools/ippfind.c | 11 +++++++---- tools/ipptool.c | 8 ++++++-- 15 files changed, 108 insertions(+), 94 deletions(-) diff --git a/backend/dnssd.c b/backend/dnssd.c index ba98826757..26b29e9f0d 100644 --- a/backend/dnssd.c +++ b/backend/dnssd.c @@ -1085,12 +1085,13 @@ query_callback( if (!_cups_strncasecmp(key, "usb_", 4)) { + size_t device_id_len = strlen(device_id); /* * Add USB device ID information... */ - ptr = device_id + strlen(device_id); - snprintf(ptr, sizeof(device_id) - (size_t)(ptr - device_id), "%s:%s;", key + 4, value); + ptr = device_id + device_id_len; + snprintf(ptr, sizeof(device_id) - device_id_len, "%s:%s;", key + 4, value); } if (!_cups_strcasecmp(key, "usb_MFG") || !_cups_strcasecmp(key, "usb_MANU") || @@ -1102,9 +1103,12 @@ query_callback( { if (value[0] == '(') { - /* - * Strip parenthesis... - */ + size_t val_len = strlen(value); + /* + * Strip parenthesis... + */ + if (val_len > 1 && value[val_len - 1] == ')') + value[val_len - 1] = '\0'; if ((ptr = value + strlen(value) - 1) > value && *ptr == ')') *ptr = '\0'; @@ -1189,7 +1193,7 @@ query_callback( char *valptr = value + strlen(value); /* Pointer into value */ - if (valptr < (value + sizeof(value) - 1)) + if (valptr < (value + (sizeof(value) - 1))) *valptr++ = ','; ptr += 6; @@ -1204,8 +1208,11 @@ query_callback( *valptr = '\0'; } - ptr = device_id + strlen(device_id); - snprintf(ptr, sizeof(device_id) - (size_t)(ptr - device_id), "CMD:%s;", value + 1); + { + size_t device_len = strlen(device_id); + ptr = device_id + device_len; + snprintf(ptr, sizeof(device_id) - device_len, "CMD:%s;", value + 1); + } } if (device_id[0]) diff --git a/cgi-bin/ipp-var.c b/cgi-bin/ipp-var.c index ade70deac2..75fc1331d9 100644 --- a/cgi-bin/ipp-var.c +++ b/cgi-bin/ipp-var.c @@ -97,13 +97,13 @@ cgiGetAttributes(ipp_t *request, /* I - IPP request */ break; else if (nameptr > name && ch == '?') break; - else if (nameptr < (name + sizeof(name) - 1)) - { - if (ch == '_') + else if (nameptr < (name + (sizeof(name) - 1))) + { + if (ch == '_') *nameptr++ = '-'; else *nameptr++ = (char)ch; - } + } *nameptr = '\0'; @@ -875,7 +875,7 @@ cgiRewriteURL(const char *uri, /* I - Current URI */ *resptr++ = hexchars[*rawptr & 15]; } } - else if (resptr < (resource + sizeof(resource) - 1)) + else if (resptr < (resource + (sizeof(resource) - 1))) *resptr++ = *rawptr; *resptr = '\0'; @@ -967,7 +967,7 @@ cgiSetIPPObjectVars( else nameptr = name; - for (i = 0; attr->name[i] && nameptr < (name + sizeof(name) - 1); i ++) + for (i = 0; attr->name[i] && nameptr < (name + (sizeof(name) - 1)); i++) if (attr->name[i] == '-') *nameptr++ = '_'; else diff --git a/cgi-bin/template.c b/cgi-bin/template.c index acd3f43140..f51de486a3 100644 --- a/cgi-bin/template.c +++ b/cgi-bin/template.c @@ -249,7 +249,7 @@ cgi_copy(FILE *out, /* I - Output file */ uriencode = 1; else if (s > name && ch == '?') break; - else if (s < (name + sizeof(name) - 1)) + else if (s < (name + (sizeof(name) - 1))) *s++ = (char)ch; *s = '\0'; @@ -454,8 +454,8 @@ cgi_copy(FILE *out, /* I - Output file */ for (s = compare; (ch = getc(in)) != EOF;) if (ch == '?') break; - else if (s >= (compare + sizeof(compare) - 1)) - continue; + else if (s >= (compare + (sizeof(compare) - 1))) + continue; else if (ch == '#') { snprintf(s, sizeof(compare) - (size_t)(s - compare), "%d", element + 1); diff --git a/cgi-bin/var.c b/cgi-bin/var.c index b2bcb00720..09c3c520c8 100644 --- a/cgi-bin/var.c +++ b/cgi-bin/var.c @@ -651,7 +651,7 @@ cgi_initialize_cookies(void) */ for (ptr = name; *cookie && *cookie != '=';) - if (ptr < (name + sizeof(name) - 1)) + if (ptr < (name + (sizeof(name) - 1))) { *ptr++ = *cookie++; } @@ -674,7 +674,7 @@ cgi_initialize_cookies(void) if (*cookie == '\"') { for (cookie ++, ptr = value; *cookie && *cookie != '\"';) - if (ptr < (value + sizeof(value) - 1)) + if (ptr < (value + (sizeof(value) - 1))) { *ptr++ = *cookie++; } @@ -692,7 +692,7 @@ cgi_initialize_cookies(void) else { for (ptr = value; *cookie && *cookie != ';';) - if (ptr < (value + sizeof(value) - 1)) + if (ptr < (value + (sizeof(value) - 1))) { *ptr++ = *cookie++; } @@ -1103,7 +1103,7 @@ cgi_initialize_string(const char *data) /* I - Form data string */ break; case '+' : /* Escaped space character */ - if (s < (value + sizeof(value) - 1)) + if (s < (value + (sizeof(value) - 1))) *s++ = ' '; break; @@ -1115,7 +1115,7 @@ cgi_initialize_string(const char *data) /* I - Form data string */ if (!isxdigit(data[1] & 255) || !isxdigit(data[2] & 255)) return (0); - if (s < (value + sizeof(value) - 1)) + if (s < (value + (sizeof(value) - 1))) { data ++; ch = *data - '0'; @@ -1134,7 +1134,7 @@ cgi_initialize_string(const char *data) /* I - Form data string */ break; default : /* Other characters come straight through */ - if (*data >= ' ' && s < (value + sizeof(value) - 1)) + if (*data >= ' ' && s < (value + (sizeof(value) - 1))) *s++ = *data; break; } diff --git a/cups/debug.c b/cups/debug.c index 714e7f912c..5341ca5c53 100644 --- a/cups/debug.c +++ b/cups/debug.c @@ -405,7 +405,7 @@ _cups_safe_vsnprintf( while (isdigit(*format & 255)) { - if (tptr < (tformat + sizeof(tformat) - 1)) + if (tptr < (tformat + (sizeof(tformat) - 1))) *tptr++ = *format; width = width * 10 + *format++ - '0'; @@ -414,7 +414,7 @@ _cups_safe_vsnprintf( if (*format == '.') { - if (tptr < (tformat + sizeof(tformat) - 1)) + if (tptr < (tformat + (sizeof(tformat) - 1))) *tptr++ = *format; format ++; @@ -437,7 +437,7 @@ _cups_safe_vsnprintf( while (isdigit(*format & 255)) { - if (tptr < (tformat + sizeof(tformat) - 1)) + if (tptr < (tformat + (sizeof(tformat) - 1))) *tptr++ = *format; prec = prec * 10 + *format++ - '0'; @@ -459,8 +459,8 @@ _cups_safe_vsnprintf( } else if (*format == 'h' || *format == 'l' || *format == 'L') { - if (tptr < (tformat + sizeof(tformat) - 1)) - *tptr++ = *format; + if (tptr < (tformat + (sizeof(tformat) - 1))) + *tptr++ = *format; size = *format++; } @@ -470,7 +470,7 @@ _cups_safe_vsnprintf( if (!*format) break; - if (tptr < (tformat + sizeof(tformat) - 1)) + if (tptr < (tformat + (sizeof(tformat) - 1))) *tptr++ = *format; type = *format++; diff --git a/cups/dest.c b/cups/dest.c index 906d2bd5c8..93ef9ed976 100644 --- a/cups/dest.c +++ b/cups/dest.c @@ -3859,6 +3859,9 @@ cups_queue_name( const char *ptr; // Pointer into serviceName char *nameptr; // Pointer into name + if (namesize == 0) { + return; + } for (nameptr = name, ptr = serviceName; *ptr && nameptr < (name + namesize - 1); ptr ++) { diff --git a/cups/encode.c b/cups/encode.c index 735c2d3c19..ff5ebd2ad0 100644 --- a/cups/encode.c +++ b/cups/encode.c @@ -862,10 +862,9 @@ cupsEncodeOptions2( const char * /* O - First out-of-order option or NULL */ _ippCheckOptions(void) { - int i; /* Looping var */ + size_t i; /* Looping var */ - - for (i = 0; i < (int)(sizeof(ipp_options) / sizeof(ipp_options[0]) - 1); i ++) + for (i = 0; i < sizeof(ipp_options) / sizeof(ipp_options[0]) - 1; i++) if (strcmp(ipp_options[i].name, ipp_options[i + 1].name) >= 0) return (ipp_options[i + 1].name); diff --git a/cups/http-addrlist.c b/cups/http-addrlist.c index 28f16a3198..d1cff0b3c7 100644 --- a/cups/http-addrlist.c +++ b/cups/http-addrlist.c @@ -57,13 +57,20 @@ httpAddrConnect2( { int val; /* Socket option value */ #ifndef _WIN32 - int i, j, /* Looping vars */ - flags, /* Socket flags */ - result; /* Result from select() or poll() */ + unsigned i, j; /* Looping vars */ + int flags, /* Socket flags */ + result; /* Result from select() or poll() */ #endif /* !_WIN32 */ int remaining; /* Remaining timeout */ + +# ifdef _WIN32 int nfds, /* Number of file descriptors */ fds[100]; /* Socket file descriptors */ +#else + nfds_t nfds; /* Number of file descriptors */ + int fds[100]; /* Socket file descriptors */ +#endif + http_addrlist_t *addrs[100]; /* Addresses */ int max_fd = -1; /* Highest file descriptor */ #ifdef O_NONBLOCK @@ -108,14 +115,13 @@ httpAddrConnect2( { while (nfds > 0) { - nfds --; - httpAddrClose(NULL, fds[nfds]); + httpAddrClose(NULL, fds[--nfds]); } return (NULL); } - if (addrlist && nfds < (int)(sizeof(fds) / sizeof(fds[0]))) + if (addrlist && nfds < (sizeof(fds) / sizeof(fds[0]))) { /* * Create the socket... @@ -196,8 +202,7 @@ httpAddrConnect2( while (nfds > 0) { - nfds --; - httpAddrClose(NULL, fds[nfds]); + httpAddrClose(NULL, fds[--nfds]); } return (addrlist); @@ -222,8 +227,7 @@ httpAddrConnect2( if (fds[nfds] > max_fd) max_fd = fds[nfds]; - addrs[nfds] = addrlist; - nfds ++; + addrs[nfds++] = addrlist; addrlist = addrlist->next; } @@ -256,8 +260,7 @@ httpAddrConnect2( while (nfds > 0) { - nfds --; - httpAddrClose(NULL, fds[nfds]); + httpAddrClose(NULL, fds[--nfds]); } *sock = -1; @@ -271,7 +274,7 @@ httpAddrConnect2( pfds[i].events = POLLIN | POLLOUT; } - result = poll(pfds, (nfds_t)nfds, addrlist ? 100 : remaining > 250 ? 250 : remaining); + result = poll(pfds, nfds, addrlist ? 100 : remaining > 250 ? 250 : remaining); DEBUG_printf("1httpAddrConnect2: poll() returned %d (%d)", result, errno); } @@ -364,8 +367,7 @@ httpAddrConnect2( while (nfds > 0) { - nfds --; - httpAddrClose(NULL, fds[nfds]); + httpAddrClose(NULL, fds[--nfds]); } #ifdef _WIN32 @@ -471,7 +473,7 @@ httpAddrGetList(const char *hostname, /* I - Hostname, IP address, or NULL for p *temp; /* New address */ char ipv6[64], /* IPv6 address */ *ipv6zone; /* Pointer to zone separator */ - int ipv6len; /* Length of IPv6 address */ + size_t ipv6len; /* Length of IPv6 address */ _cups_globals_t *cg = _cupsGlobals(); /* Global data */ @@ -565,9 +567,9 @@ httpAddrGetList(const char *hostname, /* I - Hostname, IP address, or NULL for p */ cupsCopyString(ipv6, hostname + 4, sizeof(ipv6)); - if ((ipv6len = (int)strlen(ipv6) - 1) >= 0 && ipv6[ipv6len] == ']') + if ((ipv6len = strlen(ipv6) - 1) >= 0 && ipv6[ipv6len] == ']') { - ipv6[ipv6len] = '\0'; + ipv6[ipv6len - 1] = '\0'; hostname = ipv6; /* @@ -585,9 +587,9 @@ httpAddrGetList(const char *hostname, /* I - Hostname, IP address, or NULL for p */ cupsCopyString(ipv6, hostname + 1, sizeof(ipv6)); - if ((ipv6len = (int)strlen(ipv6) - 1) >= 0 && ipv6[ipv6len] == ']') + if ((ipv6len = strlen(ipv6) - 1) >= 0 && ipv6[ipv6len] == ']') { - ipv6[ipv6len] = '\0'; + ipv6[ipv6len - 1] = '\0'; hostname = ipv6; } } diff --git a/cups/options.c b/cups/options.c index cbc51ce77b..c1bfaf2aaf 100644 --- a/cups/options.c +++ b/cups/options.c @@ -297,13 +297,14 @@ cupsParseOptions( if (*copyarg == '{') { + size_t copyarg_len = strlen(copyarg); /* * Remove surrounding {} so we can parse "{name=value ... name=value}"... */ - if ((ptr = copyarg + strlen(copyarg) - 1) > copyarg && *ptr == '}') + if (copyarg_len > 1 && copyarg[copyarg_len - 1] == '}') { - *ptr = '\0'; + copyarg[copyarg_len - 1] = '\0'; ptr = copyarg + 1; } else diff --git a/scheduler/auth.c b/scheduler/auth.c index 80cf59fc99..e08a081d27 100644 --- a/scheduler/auth.c +++ b/scheduler/auth.c @@ -1331,8 +1331,9 @@ cupsdFindBest(const char *path, /* I - Resource path */ if ((uriptr = strchr(uri, '?')) != NULL) *uriptr = '\0'; /* Drop trailing query string */ - if ((uriptr = uri + strlen(uri) - 1) > uri && *uriptr == '/') - *uriptr = '\0'; /* Remove trailing '/' */ + bestlen = strlen(uri); + if (bestlen > 1 && uri[bestlen - 1] == '/') + uri[bestlen - 1] = '\0'; /* Remove trailing '/' */ if (!strncmp(uri, "/printers/", 10) || !strncmp(uri, "/classes/", 9)) @@ -1341,7 +1342,7 @@ cupsdFindBest(const char *path, /* I - Resource path */ * Check if the URI has .ppd on the end... */ - uriptr = uri + strlen(uri) - 4; /* len > 4 if we get here... */ + uriptr = uri + bestlen - 4; /* len > 4 if we get here... */ if (!strcmp(uriptr, ".ppd")) *uriptr = '\0'; @@ -1362,7 +1363,7 @@ cupsdFindBest(const char *path, /* I - Resource path */ loc; loc = (cupsd_location_t *)cupsArrayNext(Locations)) { - cupsdLogMessage(CUPSD_LOG_DEBUG2, "cupsdFindBest: Location %s(%d) Limit %x", loc->location ? loc->location : "(null)", (int)loc->length, loc->limit); + cupsdLogMessage(CUPSD_LOG_DEBUG2, "cupsdFindBest: Location %s(%u) Limit %x", loc->location ? loc->location : "(null)", (unsigned)loc->length, loc->limit); if (!strncmp(uri, "/printers/", 10) || !strncmp(uri, "/classes/", 9)) { diff --git a/scheduler/log.c b/scheduler/log.c index 267ce77a04..58cf88a7f6 100644 --- a/scheduler/log.c +++ b/scheduler/log.c @@ -156,8 +156,7 @@ cupsdCheckLogFile(cups_file_t **lf, /* IO - Log file */ filename[0] = '\0'; for (logptr = logname, ptr = filename + strlen(filename); - *logptr && ptr < (filename + sizeof(filename) - 1); - logptr ++) + *logptr && ptr < (filename + (sizeof(filename) - 1)); logptr++) if (*logptr == '%') { /* @@ -801,7 +800,7 @@ cupsdLogPage(cupsd_job_t *job, /* I - Job being printed */ switch (*format) { case '%' : /* Literal % */ - if (bufptr < (buffer + sizeof(buffer) - 1)) + if (bufptr < (buffer + (sizeof(buffer) - 1))) *bufptr++ = '%'; break; @@ -875,7 +874,7 @@ cupsdLogPage(cupsd_job_t *job, /* I - Job being printed */ for (i = 0; i < attr->num_values && - bufptr < (buffer + sizeof(buffer) - 1); + bufptr < (buffer + (sizeof(buffer) - 1)); i ++) { if (i) @@ -934,13 +933,13 @@ cupsdLogPage(cupsd_job_t *job, /* I - Job being printed */ } } } - else if (bufptr < (buffer + sizeof(buffer) - 1)) + else if (bufptr < (buffer + (sizeof(buffer) - 1))) *bufptr++ = '-'; break; } default : - if (bufptr < (buffer + sizeof(buffer) - 2)) + if (bufptr < (buffer + (sizeof(buffer) - 2))) { *bufptr++ = '%'; *bufptr++ = *format; @@ -948,7 +947,7 @@ cupsdLogPage(cupsd_job_t *job, /* I - Job being printed */ break; } } - else if (bufptr < (buffer + sizeof(buffer) - 1)) + else if (bufptr < (buffer + (sizeof(buffer) - 1))) *bufptr++ = *format; } diff --git a/scheduler/printers.c b/scheduler/printers.c index 7bca3bdc9b..89b52c7445 100644 --- a/scheduler/printers.c +++ b/scheduler/printers.c @@ -1577,9 +1577,7 @@ cupsdSaveAllPrinters(void) snprintf(value, sizeof(value), "%s ", marker->name); for (i = 0, ptr = value + strlen(value); - i < marker->num_values && ptr < (value + sizeof(value) - 1); - i ++) - { + i < marker->num_values && ptr < (value + (sizeof(value) - 1)); i++) { if (i) *ptr++ = ','; @@ -1636,9 +1634,7 @@ cupsdSaveAllPrinters(void) snprintf(value, sizeof(value), "%s ", marker->name); for (i = 0, ptr = value + strlen(value); - i < marker->num_values && ptr < (value + sizeof(value) - 1); - i ++) - { + i < marker->num_values && ptr < (value + (sizeof(value) - 1)); i++) { if (i) *ptr++ = ','; @@ -1656,8 +1652,7 @@ cupsdSaveAllPrinters(void) snprintf(value, sizeof(value), "%s ", marker->name); for (i = 0, ptr = value + strlen(value); - i < marker->num_values && ptr < (value + sizeof(value) - 1); - i ++) + i < marker->num_values && ptr < (value + (sizeof(value) - 1)); i++) { if (i) *ptr++ = ','; @@ -2144,7 +2139,7 @@ cupsdSetPrinterAttr( level = ippGetInteger(levels, i); type = ippGetString(types, i, NULL); - for (psptr = pstype; *type && psptr < (pstype + sizeof(pstype) - 1); type ++) + for (psptr = pstype; *type && psptr < (pstype + (sizeof(pstype) - 1)); type++) if (*type == '-') { type ++; @@ -2590,7 +2585,7 @@ cupsdSetPrinterReasons( sptr ++; for (rptr = reason; *sptr && !isspace(*sptr & 255) && *sptr != ','; sptr ++) - if (rptr < (reason + sizeof(reason) - 1)) + if (rptr < (reason + (sizeof(reason) - 1))) *rptr++ = *sptr; if (rptr == reason) diff --git a/tools/ippeveprinter.c b/tools/ippeveprinter.c index d9bc582001..6241ea482e 100644 --- a/tools/ippeveprinter.c +++ b/tools/ippeveprinter.c @@ -1107,7 +1107,7 @@ create_job_file( if ((job_name = ippGetString(ippFindAttribute(job->attrs, "job-name", IPP_TAG_NAME), 0, NULL)) == NULL) job_name = "untitled"; - for (nameptr = name; *job_name && nameptr < (name + sizeof(name) - 1); job_name ++) + for (nameptr = name; *job_name && nameptr < (name + (sizeof(name) - 1)); job_name++) { if (isalnum(*job_name & 255) || *job_name == '-') { @@ -2641,7 +2641,7 @@ html_printf(ippeve_client_t *client, // I - Client while (isdigit(*format & 255)) { - if (tptr < (tformat + sizeof(tformat) - 1)) + if (tptr < (tformat + (sizeof(tformat) - 1))) *tptr++ = *format; width = width * 10 + *format++ - '0'; @@ -2650,8 +2650,8 @@ html_printf(ippeve_client_t *client, // I - Client if (*format == '.') { - if (tptr < (tformat + sizeof(tformat) - 1)) - *tptr++ = *format; + if (tptr < (tformat + (sizeof(tformat) - 1))) + *tptr++ = *format; format ++; @@ -2670,7 +2670,7 @@ html_printf(ippeve_client_t *client, // I - Client while (isdigit(*format & 255)) { - if (tptr < (tformat + sizeof(tformat) - 1)) + if (tptr < (tformat + (sizeof(tformat) - 1))) *tptr++ = *format; prec = prec * 10 + *format++ - '0'; @@ -2692,8 +2692,8 @@ html_printf(ippeve_client_t *client, // I - Client } else if (*format == 'h' || *format == 'l' || *format == 'L') { - if (tptr < (tformat + sizeof(tformat) - 1)) - *tptr++ = *format; + if (tptr < (tformat + (sizeof(tformat) - 1))) + *tptr++ = *format; size = *format++; } @@ -2706,7 +2706,7 @@ html_printf(ippeve_client_t *client, // I - Client break; } - if (tptr < (tformat + sizeof(tformat) - 1)) + if (tptr < (tformat + (sizeof(tformat) - 1))) *tptr++ = *format; type = *format++; @@ -4419,7 +4419,7 @@ load_legacy_attributes( ptr += strlen(ptr); prefix = ","; } - if (ptr < (device_id + sizeof(device_id) - 1)) + if (ptr < (device_id + (sizeof(device_id) - 1))) { *ptr++ = ';'; *ptr = '\0'; @@ -5855,13 +5855,13 @@ register_printer( if (!strcasecmp(value, "application/octet-stream")) continue; - if (ptr > formats && ptr < (formats + sizeof(formats) - 1)) + if (ptr > formats && ptr < (formats + (sizeof(formats) - 1))) *ptr++ = ','; cupsCopyString(ptr, value, sizeof(formats) - (size_t)(ptr - formats)); ptr += strlen(ptr); - if (ptr >= (formats + sizeof(formats) - 1)) + if (ptr >= (formats + (sizeof(formats) - 1))) break; } @@ -5870,13 +5870,13 @@ register_printer( { value = ippGetString(urf_supported, i, NULL); - if (ptr > urf && ptr < (urf + sizeof(urf) - 1)) + if (ptr > urf && ptr < (urf + (sizeof(urf) - 1))) *ptr++ = ','; cupsCopyString(ptr, value, sizeof(urf) - (size_t)(ptr - urf)); ptr += strlen(ptr); - if (ptr >= (urf + sizeof(urf) - 1)) + if (ptr >= (urf + (sizeof(urf) - 1))) break; } diff --git a/tools/ippfind.c b/tools/ippfind.c index 4b2392411c..bae73af078 100644 --- a/tools/ippfind.c +++ b/tools/ippfind.c @@ -1431,7 +1431,7 @@ exec_program(ippfind_srv_t *service, // I - Service tptr += strlen(tptr); } - else if (tptr < (temp + sizeof(temp) - 1)) + else if (tptr < (temp + (sizeof(temp) - 1))) *tptr++ = *ptr; } @@ -1912,9 +1912,12 @@ resolve_callback( service->host = strdup(hostTarget); service->port = port; - value = service->host + strlen(service->host) - 1; - if (value >= service->host && *value == '.') - *value = '\0'; + host_len = strlen(service->host); + + if (host_len > 1 && service->host[host_len - 1] == '.') + { + service->host[host_len - 1] = '\0'; + } // Loop through the TXT key/value pairs and add them to an array... for (i = 0; i < num_txt; i ++) diff --git a/tools/ipptool.c b/tools/ipptool.c index 79446aa5af..f2c51aae8e 100644 --- a/tools/ipptool.c +++ b/tools/ipptool.c @@ -892,6 +892,7 @@ compare_uris(const char *a, // I - First URI auserpass[256], ahost[256], aresource[256]; + size_t aport_len; /* Size of aport */ int aport; char bscheme[32], // Components of second URI buserpass[256], @@ -913,8 +914,9 @@ compare_uris(const char *a, // I - First URI if ((ptr = ahost + strlen(ahost) - 1) > ahost && *ptr == '.') *ptr = '\0'; - if ((ptr = bhost + strlen(bhost) - 1) > bhost && *ptr == '.') - *ptr = '\0'; + bport_len = strlen(bhost); + if (bport_len > 1 && ahost[bport_len - 1] == '.') + bhost[bport_len - 1] = '\0'; // Compare each component... if ((result = _cups_strcasecmp(ascheme, bscheme)) != 0) @@ -2803,6 +2805,8 @@ get_string(ipp_attribute_t *attr, // I - IPP attribute { if (httpSeparateURI(HTTP_URI_CODING_ALL, value, scheme, sizeof(scheme), userpass, sizeof(userpass), buffer, bufsize, &port, resource, sizeof(resource)) < HTTP_URI_STATUS_OK) buffer[0] = '\0'; + return buffer; + } ptr = buffer + strlen(buffer) - 1; if (ptr >= buffer && *ptr == '.')