]> sjero.net Git - wget/commitdiff
[svn] Don't take the address of in.s_addr because that doesn't work on some
authorhniksic <devnull@localhost>
Sun, 2 Nov 2003 23:48:45 +0000 (15:48 -0800)
committerhniksic <devnull@localhost>
Sun, 2 Nov 2003 23:48:45 +0000 (15:48 -0800)
machines.

src/ChangeLog
src/host.c
src/host.h

index d4959915ecaf6669b4d04d22ce96abae53cd352a..60debe4f7648ff68a2ba490c144ada3854bad75c 100644 (file)
@@ -1,3 +1,8 @@
+2003-11-03  Hrvoje Niksic  <hniksic@xemacs.org>
+
+       * host.h (ADDRESS_IPV4_DATA): Don't take the address of in.s_addr,
+       because that doesn't work on some machines.
+
 2003-11-03  Hrvoje Niksic  <hniksic@xemacs.org>
 
        * connect.c (select_fd): Generalize the third argument into WAIT,
index 3a08deeba196703a79a7817069243ba8cc1af724..655568047906214ba84e6b0e1915df7e6ef3368b 100644 (file)
@@ -163,7 +163,8 @@ address_list_match_all (const struct address_list *al1,
        {
        case IPV4_ADDRESS:
          if (ADDRESS_IPV4_IN_ADDR (ip1).s_addr
-             != ADDRESS_IPV4_IN_ADDR (ip2).s_addr)
+             !=
+             ADDRESS_IPV4_IN_ADDR (ip2).s_addr)
            return 0;
          break;
        case IPV6_ADDRESS:
index c5e1fd7ec43d9b5912989fede5678dee6dd77794..24e980147f8d1a6fcf2dcfa48691be5c9b8b5157 100644 (file)
@@ -56,7 +56,7 @@ typedef struct {
   } type;
 
   /* Address data union: ipv6 contains IPv6-related data (address and
-     scope), and ipv4 contains IPv4 address.  */
+     scope), and ipv4 contains the IPv4 address.  */
   union {
 #ifdef ENABLE_IPV6
     struct {
@@ -73,14 +73,23 @@ typedef struct {
 } ip_address;
 
 /* Because C doesn't support anonymous unions, access to ip_address
-   elements is clunky.  Hence the accessors.  */
+   elements is unwieldy.  Hence the accessors.
+
+   The _ADDR accessors return the address as the struct in_addr or
+   in6_addr.  The _DATA accessor returns a pointer to the address data
+   -- pretty much the same as the above, but cast to void*.  The
+   _SCOPE accessor returns the address's scope_id, and makes sense
+   only when IPv6 and HAVE_SOCKADDR_IN6_SCOPE_ID are both defined.  */
+
+#define ADDRESS_IPV4_IN_ADDR(x) ((x)->u.ipv4.addr)
+/* Don't use &x->u.ipv4.addr.s_addr because it can be #defined to a
+   bitfield, which you can't take an address of.  */
+#define ADDRESS_IPV4_DATA(x) ((void *)&(x)->u.ipv4.addr)
 
 #define ADDRESS_IPV6_IN6_ADDR(x) ((x)->u.ipv6.addr)
-#define ADDRESS_IPV6_DATA(x) ((void *)&(x)->u.ipv6.addr.s6_addr)
+#define ADDRESS_IPV6_DATA(x) ((void *)&(x)->u.ipv6.addr)
 #define ADDRESS_IPV6_SCOPE(x) ((x)->u.ipv6.scope_id)
 
-#define ADDRESS_IPV4_IN_ADDR(x) ((x)->u.ipv4.addr)
-#define ADDRESS_IPV4_DATA(x) ((void *)&(x)->u.ipv4.addr.s_addr)
 
 /* Flags for lookup_host */
 #define LH_SILENT    0x0001