Tim Waugh 55c986
diff -up cups-1.6.2/cups/http-support.c.avahi-address cups-1.6.2/cups/http-support.c
Tim Waugh 55c986
--- cups-1.6.2/cups/http-support.c.avahi-address	2013-03-11 18:44:36.000000000 +0000
Tim Waugh d2f028
+++ cups-1.6.2/cups/http-support.c	2013-06-28 13:42:15.834715511 +0100
Tim Waugh 55c986
@@ -2121,7 +2121,7 @@ http_resolve_cb(
Tim Waugh 55c986
     const char             *type,	/* I - Registration type */
Tim Waugh 55c986
     const char             *domain,	/* I - Domain (unused) */
Tim Waugh 55c986
     const char             *hostTarget,	/* I - Hostname */
Tim Waugh 55c986
-    const AvahiAddress     *address,	/* I - Address (unused) */
Tim Waugh 55c986
+    const AvahiAddress     *address,	/* I - Address */
Tim Waugh 55c986
     uint16_t               port,	/* I - Port number */
Tim Waugh 55c986
     AvahiStringList        *txt,	/* I - TXT record */
Tim Waugh 55c986
     AvahiLookupResultFlags flags,	/* I - Lookup flags (unused) */
Tim Waugh d2f028
@@ -2248,41 +2248,59 @@ http_resolve_cb(
Tim Waugh d2f028
     * getting the IP address of the .local name and then do reverse-lookups...
Tim Waugh d2f028
     */
Tim Waugh d2f028
 
Tim Waugh d2f028
-    http_addrlist_t	*addrlist,	/* List of addresses */
Tim Waugh d2f028
-			*addr;		/* Current address */
Tim Waugh d2f028
+    http_addr_t addr;
Tim Waugh d2f028
+    size_t addrlen;
Tim Waugh d2f028
+    int error;
Tim Waugh 55c986
 
Tim Waugh 55c986
     DEBUG_printf(("8http_resolve_cb: Looking up \"%s\".", hostTarget));
Tim Waugh 55c986
 
Tim Waugh 55c986
-    snprintf(fqdn, sizeof(fqdn), "%d", ntohs(port));
Tim Waugh 55c986
-    if ((addrlist = httpAddrGetList(hostTarget, AF_UNSPEC, fqdn)) != NULL)
Tim Waugh d2f028
+    switch (address->proto)
Tim Waugh 55c986
     {
Tim Waugh 55c986
-      for (addr = addrlist; addr; addr = addr->next)
Tim Waugh d2f028
+    case AVAHI_PROTO_INET:
Tim Waugh d2f028
+      addr.ipv4.sin_family = AF_INET;
Tim Waugh d2f028
+      addrlen = sizeof (addr.ipv4.sin_addr);
Tim Waugh d2f028
+      memcpy (&addr.ipv4.sin_addr, &address->data, addrlen);
Tim Waugh d2f028
+      break;
Tim Waugh d2f028
+    case AVAHI_PROTO_INET6:
Tim Waugh d2f028
+      addr.ipv6.sin6_family = AF_INET6;
Tim Waugh d2f028
+      addrlen = sizeof (addr.ipv6.sin6_addr);
Tim Waugh d2f028
+      memcpy (&addr.ipv6.sin6_addr, &address->data, addrlen);
Tim Waugh d2f028
+      break;
Tim Waugh d2f028
+    default:
Tim Waugh d2f028
+      DEBUG_printf(("8http_resolve_cb: unknown address family %d",
Tim Waugh d2f028
+		    address->proto));
Tim Waugh d2f028
+      addrlen = 0;
Tim Waugh d2f028
+    }
Tim Waugh 55c986
+
Tim Waugh d2f028
+    if (addrlen > 0) {
Tim Waugh d2f028
+      error = getnameinfo(&addr.addr, httpAddrLength (&addr),
Tim Waugh d2f028
+			  fqdn, sizeof(fqdn), NULL, 0, NI_NAMEREQD);
Tim Waugh d2f028
+
Tim Waugh d2f028
+      if (!error)
Tim Waugh 55c986
       {
Tim Waugh 55c986
-        int error = getnameinfo(&(addr->addr.addr),
Tim Waugh 55c986
-	                        httpAddrLength(&(addr->addr)),
Tim Waugh 55c986
-			        fqdn, sizeof(fqdn), NULL, 0, NI_NAMEREQD);
Tim Waugh d2f028
+	DEBUG_printf(("8http_resolve_cb: Found \"%s\".", fqdn));
Tim Waugh d2f028
 
Tim Waugh 55c986
-        if (!error)
Tim Waugh d2f028
+	if ((hostptr = fqdn + strlen(fqdn) - 6) <= fqdn ||
Tim Waugh d2f028
+	    _cups_strcasecmp(hostptr, ".local"))
Tim Waugh d2f028
 	{
Tim Waugh 55c986
-	  DEBUG_printf(("8http_resolve_cb: Found \"%s\".", fqdn));
Tim Waugh 55c986
-
Tim Waugh 55c986
-	  if ((hostptr = fqdn + strlen(fqdn) - 6) <= fqdn ||
Tim Waugh 55c986
-	      _cups_strcasecmp(hostptr, ".local"))
Tim Waugh 55c986
-	  {
Tim Waugh 55c986
-	    hostTarget = fqdn;
Tim Waugh 55c986
-	    break;
Tim Waugh 55c986
-	  }
Tim Waugh d2f028
+	  hostTarget = fqdn;
Tim Waugh d2f028
 	}
Tim Waugh d2f028
+      } else {
Tim Waugh d2f028
+	avahi_address_snprint (fqdn, sizeof (fqdn), address);
Tim Waugh 55c986
+	hostTarget = fqdn;
Tim Waugh 55c986
 #ifdef DEBUG
Tim Waugh 55c986
-	else
Tim Waugh 55c986
-	  DEBUG_printf(("8http_resolve_cb: \"%s\" did not resolve: %d",
Tim Waugh 55c986
-	                httpAddrString(&(addr->addr), fqdn, sizeof(fqdn)),
Tim Waugh 55c986
-			error));
Tim Waugh d2f028
+	DEBUG_printf(("8http_resolve_cb: \"%s\" did not resolve: %d",
Tim Waugh d2f028
+		      fqdn, error));
Tim Waugh 55c986
 #endif /* DEBUG */
Tim Waugh d2f028
       }
Tim Waugh d2f028
-
Tim Waugh d2f028
-      httpAddrFreeList(addrlist);
Tim Waugh d2f028
     }
Tim Waugh 55c986
+  } else {
Tim Waugh 55c986
+   /*
Tim Waugh 55c986
+    * Use the IP address that responded...
Tim Waugh 55c986
+    */
Tim Waugh d2f028
+
Tim Waugh 55c986
+   avahi_address_snprint (fqdn, sizeof (fqdn), address);
Tim Waugh 55c986
+   hostTarget = fqdn;
Tim Waugh 55c986
   }
Tim Waugh 55c986
 
Tim Waugh 55c986
  /*