/*
- * "$Id: http-addr.c 5138 2006-02-21 10:49:06Z mike $"
+ * "$Id: http-addr.c 5161 2006-02-24 03:11:46Z mike $"
*
* HTTP address routines for the Common UNIX Printing System (CUPS).
*
#endif /* AF_LOCAL */
#ifdef HAVE_GETNAMEINFO
{
- char servname[1024]; /* Service name (not used) */
-
-
if (getnameinfo(&addr->addr, httpAddrLength(addr), name, namelen,
- servname, sizeof(servname), 0))
+ NULL, 0, 0))
{
/*
* If we get an error back, then the address type is not supported
strlcpy(s, addr->un.sun_path, slen);
else
#endif /* AF_LOCAL */
-#ifdef HAVE_GETNAMEINFO
+ if (addr->addr.sa_family == AF_INET)
{
- char servname[1024]; /* Service name (not used) */
+ unsigned temp; /* Temporary address */
+ temp = ntohl(addr->ipv4.sin_addr.s_addr);
+
+ snprintf(s, slen, "%d.%d.%d.%d", (temp >> 24) & 255,
+ (temp >> 16) & 255, (temp >> 8) & 255, temp & 255);
+ }
+#ifdef AF_INET6
+ else if (addr->addr.sa_family == AF_INET6)
+ {
+# ifdef HAVE_GETNAMEINFO
if (getnameinfo(&addr->addr, httpAddrLength(addr), s, slen,
- servname, sizeof(servname), NI_NUMERICHOST))
+ NULL, 0, NI_NUMERICHOST))
{
/*
* If we get an error back, then the address type is not supported
return (NULL);
}
- }
-#else
- {
-#ifdef AF_INET6
- if (addr->addr.sa_family == AF_INET6)
+# else
+ char *sptr; /* Pointer into string */
+ int i; /* Looping var */
+ unsigned temp; /* Current value */
+ const char *prefix; /* Prefix for address */
+
+
+ prefix = "";
+ for (sptr = s, i = 0; i < 4 && addr->ipv6.sin6_addr.s6_addr32[i]; i ++)
{
- char *sptr; /* Pointer into string */
- int i; /* Looping var */
- unsigned temp; /* Current value */
- const char *prefix; /* Prefix for address */
+ temp = ntohl(addr->ipv6.sin6_addr.s6_addr32[i]);
+ snprintf(sptr, slen, "%s%x", prefix, (temp >> 16) & 0xffff);
+ prefix = ":";
+ slen -= strlen(sptr);
+ sptr += strlen(sptr);
- prefix = "";
- for (sptr = s, i = 0; i < 4 && addr->ipv6.sin6_addr.s6_addr32[i]; i ++)
- {
- temp = ntohl(addr->ipv6.sin6_addr.s6_addr32[i]);
+ temp &= 0xffff;
- snprintf(sptr, slen, "%s%x", prefix, (temp >> 16) & 0xffff);
- prefix = ":";
+ if (temp || i == 3 || addr->ipv6.sin6_addr.s6_addr32[i + 1])
+ {
+ snprintf(sptr, slen, "%s%x", prefix, temp);
slen -= strlen(sptr);
sptr += strlen(sptr);
-
- temp &= 0xffff;
-
- if (temp || i == 3 || addr->ipv6.sin6_addr.s6_addr32[i + 1])
- {
- snprintf(sptr, slen, "%s%x", prefix, temp);
- slen -= strlen(sptr);
- sptr += strlen(sptr);
- }
}
+ }
+
+ if (i < 4)
+ {
+ while (i < 4 && !addr->ipv6.sin6_addr.s6_addr32[i])
+ i ++;
if (i < 4)
{
- while (i < 4 && !addr->ipv6.sin6_addr.s6_addr32[i])
- i ++;
+ snprintf(sptr, slen, "%s:", prefix);
+ prefix = ":";
+ slen -= strlen(sptr);
+ sptr += strlen(sptr);
- if (i < 4)
+ for (; i < 4; i ++)
{
- snprintf(sptr, slen, "%s:", prefix);
- prefix = ":";
- slen -= strlen(sptr);
- sptr += strlen(sptr);
+ temp = ntohl(addr->ipv6.sin6_addr.s6_addr32[i]);
- for (; i < 4; i ++)
+ if ((temp & 0xffff0000) || addr->ipv6.sin6_addr.s6_addr32[i - 1])
{
- temp = ntohl(addr->ipv6.sin6_addr.s6_addr32[i]);
-
- if ((temp & 0xffff0000) || addr->ipv6.sin6_addr.s6_addr32[i - 1])
- {
- snprintf(sptr, slen, "%s%x", prefix, (temp >> 16) & 0xffff);
- slen -= strlen(sptr);
- sptr += strlen(sptr);
- }
-
- snprintf(sptr, slen, "%s%x", prefix, temp & 0xffff);
+ snprintf(sptr, slen, "%s%x", prefix, (temp >> 16) & 0xffff);
slen -= strlen(sptr);
sptr += strlen(sptr);
- }
- }
- else if (sptr == s)
- {
- /*
- * Empty address...
- */
+ }
- strlcpy(s, "::", slen);
- sptr = s + 2;
- slen -= 2;
- }
- else
- {
- /*
- * Empty at end...
- */
-
- strlcpy(sptr, "::", slen);
- sptr += 2;
- slen -= 2;
+ snprintf(sptr, slen, "%s%x", prefix, temp & 0xffff);
+ slen -= strlen(sptr);
+ sptr += strlen(sptr);
}
}
- }
- else
-#endif /* AF_INET6 */
- if (addr->addr.sa_family == AF_INET)
- {
- unsigned temp; /* Temporary address */
-
+ else if (sptr == s)
+ {
+ /*
+ * Empty address...
+ */
- temp = ntohl(addr->ipv4.sin_addr.s_addr);
+ strlcpy(s, "::", slen);
+ sptr = s + 2;
+ slen -= 2;
+ }
+ else
+ {
+ /*
+ * Empty at end...
+ */
- snprintf(s, slen, "%d.%d.%d.%d", (temp >> 24) & 255,
- (temp >> 16) & 255, (temp >> 8) & 255, temp & 255);
+ strlcpy(sptr, "::", slen);
+ sptr += 2;
+ slen -= 2;
+ }
}
- else
- strlcpy(s, "UNKNOWN", slen);
+# endif /* HAVE_GETNAMEINFO */
}
-#endif /* HAVE_GETNAMEINFO */
+#endif /* AF_INET6 */
+ else
+ strlcpy(s, "UNKNOWN", slen);
DEBUG_printf(("httpAddrString: returning \"%s\"...\n", s));
/*
- * End of "$Id: http-addr.c 5138 2006-02-21 10:49:06Z mike $".
+ * End of "$Id: http-addr.c 5161 2006-02-24 03:11:46Z mike $".
*/