1999-12-02 02:42:23 -05:00
|
|
|
/* Declarations for host.c
|
2001-11-26 00:36:33 -05:00
|
|
|
Copyright (C) 1995, 1996, 1997, 2001 Free Software Foundation, Inc.
|
1999-12-02 02:42:23 -05:00
|
|
|
|
2001-05-27 15:35:15 -04:00
|
|
|
This file is part of GNU Wget.
|
1999-12-02 02:42:23 -05:00
|
|
|
|
2001-05-27 15:35:15 -04:00
|
|
|
GNU Wget is free software; you can redistribute it and/or modify
|
1999-12-02 02:42:23 -05:00
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation; either version 2 of the License, or
|
2003-10-29 13:23:56 -05:00
|
|
|
(at your option) any later version.
|
1999-12-02 02:42:23 -05:00
|
|
|
|
2001-05-27 15:35:15 -04:00
|
|
|
GNU Wget is distributed in the hope that it will be useful,
|
1999-12-02 02:42:23 -05:00
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
2001-05-27 15:35:15 -04:00
|
|
|
along with Wget; if not, write to the Free Software
|
2002-05-17 22:16:36 -04:00
|
|
|
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
|
|
|
|
|
|
|
In addition, as a special exception, the Free Software Foundation
|
|
|
|
gives permission to link the code of its release of Wget with the
|
|
|
|
OpenSSL project's "OpenSSL" library (or with modified versions of it
|
|
|
|
that use the same license as the "OpenSSL" library), and distribute
|
|
|
|
the linked executables. You must obey the GNU General Public License
|
|
|
|
in all respects for all of the code used other than "OpenSSL". If you
|
|
|
|
modify this file, you may extend this exception to your version of the
|
|
|
|
file, but you are not obligated to do so. If you do not wish to do
|
|
|
|
so, delete this exception statement from your version. */
|
1999-12-02 02:42:23 -05:00
|
|
|
|
|
|
|
#ifndef HOST_H
|
|
|
|
#define HOST_H
|
|
|
|
|
2002-02-19 00:25:42 -05:00
|
|
|
#ifdef WINDOWS
|
|
|
|
# include <winsock.h>
|
|
|
|
#else
|
2002-03-18 15:21:58 -05:00
|
|
|
# include <netdb.h>
|
2002-02-19 00:25:42 -05:00
|
|
|
# include <sys/socket.h>
|
|
|
|
# include <netinet/in.h>
|
|
|
|
#ifndef __BEOS__
|
|
|
|
# include <arpa/inet.h>
|
|
|
|
#endif
|
|
|
|
#endif
|
2002-01-24 00:45:54 -05:00
|
|
|
|
2001-11-21 19:24:28 -05:00
|
|
|
struct url;
|
2001-11-26 00:36:33 -05:00
|
|
|
struct address_list;
|
1999-12-02 02:42:23 -05:00
|
|
|
|
2003-10-29 18:13:25 -05:00
|
|
|
/* This struct defines an IP address, tagged with family type. */
|
|
|
|
|
2002-01-24 00:45:54 -05:00
|
|
|
typedef struct {
|
2003-10-29 18:13:25 -05:00
|
|
|
/* Address type. */
|
2003-10-29 13:23:56 -05:00
|
|
|
enum {
|
2003-10-29 18:13:25 -05:00
|
|
|
IPV4_ADDRESS,
|
2003-10-29 13:23:56 -05:00
|
|
|
#ifdef ENABLE_IPV6
|
2003-10-29 18:13:25 -05:00
|
|
|
IPV6_ADDRESS
|
2003-10-29 13:23:56 -05:00
|
|
|
#endif /* ENABLE_IPV6 */
|
|
|
|
} type;
|
2003-10-29 18:13:25 -05:00
|
|
|
|
|
|
|
/* Address data union: ipv6 contains IPv6-related data (address and
|
2003-11-02 18:48:45 -05:00
|
|
|
scope), and ipv4 contains the IPv4 address. */
|
2003-10-29 13:23:56 -05:00
|
|
|
union {
|
|
|
|
#ifdef ENABLE_IPV6
|
|
|
|
struct {
|
|
|
|
struct in6_addr addr;
|
2003-11-14 08:55:02 -05:00
|
|
|
# ifdef HAVE_SOCKADDR_IN6_SCOPE_ID
|
2003-10-29 13:23:56 -05:00
|
|
|
unsigned int scope_id;
|
2003-11-14 08:55:02 -05:00
|
|
|
# endif
|
2003-10-29 13:23:56 -05:00
|
|
|
} ipv6;
|
|
|
|
#endif /* ENABLE_IPV6 */
|
|
|
|
struct {
|
|
|
|
struct in_addr addr;
|
|
|
|
} ipv4;
|
2003-10-29 18:13:25 -05:00
|
|
|
} u;
|
2003-10-29 13:23:56 -05:00
|
|
|
} ip_address;
|
2002-01-24 00:45:54 -05:00
|
|
|
|
2003-10-29 18:13:25 -05:00
|
|
|
/* Because C doesn't support anonymous unions, access to ip_address
|
2003-11-02 18:48:45 -05:00
|
|
|
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)
|
2002-01-24 00:45:54 -05:00
|
|
|
|
2003-10-29 18:13:25 -05:00
|
|
|
#define ADDRESS_IPV6_IN6_ADDR(x) ((x)->u.ipv6.addr)
|
2003-11-02 18:48:45 -05:00
|
|
|
#define ADDRESS_IPV6_DATA(x) ((void *)&(x)->u.ipv6.addr)
|
2003-10-29 18:13:25 -05:00
|
|
|
#define ADDRESS_IPV6_SCOPE(x) ((x)->u.ipv6.scope_id)
|
2002-01-24 00:45:54 -05:00
|
|
|
|
2003-11-14 20:49:52 -05:00
|
|
|
enum {
|
|
|
|
LH_SILENT = 1,
|
|
|
|
LH_BIND = 2,
|
|
|
|
LH_REFRESH = 4
|
|
|
|
};
|
2001-11-26 00:36:33 -05:00
|
|
|
struct address_list *lookup_host PARAMS ((const char *, int));
|
2003-10-30 19:18:08 -05:00
|
|
|
|
2003-10-29 13:23:56 -05:00
|
|
|
void address_list_get_bounds PARAMS ((const struct address_list *,
|
|
|
|
int *, int *));
|
2003-10-30 19:18:08 -05:00
|
|
|
const ip_address *address_list_address_at PARAMS ((const struct address_list *,
|
|
|
|
int));
|
2003-11-18 17:18:44 -05:00
|
|
|
int address_list_contains PARAMS ((const struct address_list *, const ip_address *));
|
2001-11-27 09:55:40 -05:00
|
|
|
void address_list_set_faulty PARAMS ((struct address_list *, int));
|
2003-11-10 08:20:46 -05:00
|
|
|
void address_list_set_connected PARAMS ((struct address_list *));
|
|
|
|
int address_list_connected_p PARAMS ((const struct address_list *));
|
2001-11-27 09:55:40 -05:00
|
|
|
void address_list_release PARAMS ((struct address_list *));
|
2001-11-26 00:36:33 -05:00
|
|
|
|
2003-10-29 13:23:56 -05:00
|
|
|
const char *pretty_print_address PARAMS ((const ip_address *));
|
2005-03-04 14:21:02 -05:00
|
|
|
#ifdef ENABLE_IPV6
|
|
|
|
int is_valid_ipv6_address PARAMS ((const char *, const char *));
|
|
|
|
#endif
|
2001-11-26 00:36:33 -05:00
|
|
|
|
2001-11-21 19:24:28 -05:00
|
|
|
int accept_domain PARAMS ((struct url *));
|
1999-12-02 02:42:23 -05:00
|
|
|
int sufmatch PARAMS ((const char **, const char *));
|
|
|
|
|
2003-10-29 13:23:56 -05:00
|
|
|
void host_cleanup PARAMS ((void));
|
2002-01-24 00:45:54 -05:00
|
|
|
|
1999-12-02 02:42:23 -05:00
|
|
|
#endif /* HOST_H */
|