mirror of
https://github.com/mirror/wget.git
synced 2025-01-23 18:50:11 +08:00
[svn] Fix some IPv6-related problems.
Submitted in <sxsg04w6zl6.fsf@florida.arsdigita.de>.
This commit is contained in:
parent
cb40034035
commit
853a1c9e35
@ -1,3 +1,11 @@
|
|||||||
|
2002-01-24 Hrvoje Niksic <hniksic@arsdigita.com>
|
||||||
|
|
||||||
|
* host.c (lookup_host): Use sizeof(ip4_address) to calculate the
|
||||||
|
offset.
|
||||||
|
(address_list_new): Use map_ipv4_to_ip.
|
||||||
|
(wget_sockaddr_set_address): Convert ADDR to IPv4 before using it
|
||||||
|
in IPv4 context.
|
||||||
|
|
||||||
2002-01-24 Hrvoje Niksic <hniksic@arsdigita.com>
|
2002-01-24 Hrvoje Niksic <hniksic@arsdigita.com>
|
||||||
|
|
||||||
* source: Integrated IPv6 support by Thomas Lussnig.
|
* source: Integrated IPv6 support by Thomas Lussnig.
|
||||||
|
21
src/host.c
21
src/host.c
@ -205,7 +205,7 @@ address_list_new (char **h_addr_list)
|
|||||||
al->refcount = 1;
|
al->refcount = 1;
|
||||||
|
|
||||||
for (i = 0; i < count; i++)
|
for (i = 0; i < count; i++)
|
||||||
memcpy (al->addresses + i, h_addr_list[i], sizeof (ip_address));
|
map_ipv4_to_ip ((ip4_address *)h_addr_list[i], al->addresses + i);
|
||||||
|
|
||||||
return al;
|
return al;
|
||||||
}
|
}
|
||||||
@ -267,12 +267,16 @@ wget_sockaddr_set_address (wget_sockaddr *sa,
|
|||||||
{
|
{
|
||||||
if (ip_family == AF_INET)
|
if (ip_family == AF_INET)
|
||||||
{
|
{
|
||||||
|
ip4_address addr4;
|
||||||
|
if (!map_ip_to_ipv4 (addr, &addr4))
|
||||||
|
/* should the callers have prevented this? */
|
||||||
|
abort ();
|
||||||
sa->sin.sin_family = ip_family;
|
sa->sin.sin_family = ip_family;
|
||||||
sa->sin.sin_port = htons (port);
|
sa->sin.sin_port = htons (port);
|
||||||
if (addr == NULL)
|
if (addr == NULL)
|
||||||
memset ((unsigned char*)&sa->sin.sin_addr, 0, sizeof(ip_address));
|
memset (&sa->sin.sin_addr, 0, sizeof(ip4_address));
|
||||||
else
|
else
|
||||||
memcpy ((unsigned char*)&sa->sin.sin_addr, addr, sizeof(ip_address));
|
memcpy (&sa->sin.sin_addr, &addr4, sizeof(ip4_address));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
#ifdef INET6
|
#ifdef INET6
|
||||||
@ -281,9 +285,9 @@ wget_sockaddr_set_address (wget_sockaddr *sa,
|
|||||||
sa->sin6.sin6_family = ip_family;
|
sa->sin6.sin6_family = ip_family;
|
||||||
sa->sin6.sin6_port = htons (port);
|
sa->sin6.sin6_port = htons (port);
|
||||||
if (addr == NULL)
|
if (addr == NULL)
|
||||||
memset (&sa->sin6.sin6_addr, 0 , sizeof(ip_address));
|
memset (&sa->sin6.sin6_addr, 0 , 16);
|
||||||
else
|
else
|
||||||
memcpy (&sa->sin6.sin6_addr, addr, sizeof(ip_address));
|
memcpy (&sa->sin6.sin6_addr, addr, 16);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -521,7 +525,7 @@ lookup_host (const char *host, int silent)
|
|||||||
we copy the correct four bytes. */
|
we copy the correct four bytes. */
|
||||||
int offset = 0;
|
int offset = 0;
|
||||||
#ifdef WORDS_BIGENDIAN
|
#ifdef WORDS_BIGENDIAN
|
||||||
offset = sizeof (unsigned long) - sizeof (ip_address);
|
offset = sizeof (unsigned long) - sizeof (ip4_address);
|
||||||
#endif
|
#endif
|
||||||
map_ipv4_to_ip ((ip4_address *)((char *)&addr_ipv4 + offset), &addr);
|
map_ipv4_to_ip ((ip4_address *)((char *)&addr_ipv4 + offset), &addr);
|
||||||
return address_list_new_one (&addr);
|
return address_list_new_one (&addr);
|
||||||
@ -548,7 +552,10 @@ lookup_host (const char *host, int silent)
|
|||||||
int err;
|
int err;
|
||||||
|
|
||||||
memset (&hints, 0, sizeof (hints));
|
memset (&hints, 0, sizeof (hints));
|
||||||
hints.ai_family = PF_UNSPEC;
|
if (ip_default_family == AF_INET)
|
||||||
|
hints.ai_family = AF_INET;
|
||||||
|
else
|
||||||
|
hints.ai_family = PF_UNSPEC;
|
||||||
hints.ai_socktype = SOCK_STREAM;
|
hints.ai_socktype = SOCK_STREAM;
|
||||||
err = getaddrinfo (host, NULL, &hints, &ai);
|
err = getaddrinfo (host, NULL, &hints, &ai);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user