1999-12-01 23:42:23 -08:00
|
|
|
/* Declarations for host.c
|
2009-09-04 00:13:47 -07:00
|
|
|
Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004,
|
2010-05-08 21:56:15 +02:00
|
|
|
2005, 2006, 2007, 2008, 2009, 2010 Free Software Foundation, Inc.
|
1999-12-01 23:42:23 -08:00
|
|
|
|
2001-05-27 12:35:15 -07:00
|
|
|
This file is part of GNU Wget.
|
1999-12-01 23:42:23 -08:00
|
|
|
|
2001-05-27 12:35:15 -07:00
|
|
|
GNU Wget is free software; you can redistribute it and/or modify
|
1999-12-01 23:42:23 -08:00
|
|
|
it under the terms of the GNU General Public License as published by
|
2007-07-09 22:53:22 -07:00
|
|
|
the Free Software Foundation; either version 3 of the License, or
|
2003-10-29 10:23:56 -08:00
|
|
|
(at your option) any later version.
|
1999-12-01 23:42:23 -08:00
|
|
|
|
2001-05-27 12:35:15 -07:00
|
|
|
GNU Wget is distributed in the hope that it will be useful,
|
1999-12-01 23:42:23 -08: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
|
2007-07-09 22:53:22 -07:00
|
|
|
along with Wget. If not, see <http://www.gnu.org/licenses/>.
|
2002-05-17 19:16:36 -07:00
|
|
|
|
2007-11-28 00:05:33 -08:00
|
|
|
Additional permission under GNU GPL version 3 section 7
|
|
|
|
|
|
|
|
If you modify this program, or any covered work, by linking or
|
|
|
|
combining it with the OpenSSL project's OpenSSL library (or a
|
|
|
|
modified version of that library), containing parts covered by the
|
|
|
|
terms of the OpenSSL or SSLeay licenses, the Free Software Foundation
|
|
|
|
grants you additional permission to convey the resulting work.
|
|
|
|
Corresponding Source for a non-source form of such a combination
|
|
|
|
shall include the source code for the parts of OpenSSL used as well
|
|
|
|
as that of the covered work. */
|
1999-12-01 23:42:23 -08:00
|
|
|
|
|
|
|
#ifndef HOST_H
|
|
|
|
#define HOST_H
|
|
|
|
|
2002-02-18 21:25:42 -08:00
|
|
|
#ifdef WINDOWS
|
2010-05-07 12:28:26 +02:00
|
|
|
# include <winsock2.h>
|
2002-02-18 21:25:42 -08:00
|
|
|
#else
|
2008-04-22 14:48:36 -07:00
|
|
|
# ifdef __VMS
|
|
|
|
# include "vms_ip.h"
|
|
|
|
# else /* def __VMS */
|
|
|
|
# include <netdb.h>
|
|
|
|
# endif /* def __VMS [else] */
|
2002-02-18 21:25:42 -08:00
|
|
|
# include <sys/socket.h>
|
|
|
|
# include <netinet/in.h>
|
|
|
|
#ifndef __BEOS__
|
|
|
|
# include <arpa/inet.h>
|
|
|
|
#endif
|
|
|
|
#endif
|
2002-01-23 21:45:54 -08:00
|
|
|
|
2001-11-21 16:24:28 -08:00
|
|
|
struct url;
|
2001-11-25 21:36:33 -08:00
|
|
|
struct address_list;
|
1999-12-01 23:42:23 -08:00
|
|
|
|
2003-10-29 15:13:25 -08:00
|
|
|
/* This struct defines an IP address, tagged with family type. */
|
|
|
|
|
2002-01-23 21:45:54 -08:00
|
|
|
typedef struct {
|
2005-08-10 06:50:08 -07:00
|
|
|
/* Address family, one of AF_INET or AF_INET6. */
|
|
|
|
int family;
|
2003-10-29 15:13:25 -08:00
|
|
|
|
2005-08-10 06:50:08 -07:00
|
|
|
/* The actual data, in the form of struct in_addr or in6_addr: */
|
2003-10-29 10:23:56 -08:00
|
|
|
union {
|
2005-08-10 06:50:08 -07:00
|
|
|
struct in_addr d4; /* IPv4 address */
|
2003-10-29 10:23:56 -08:00
|
|
|
#ifdef ENABLE_IPV6
|
2005-08-10 06:50:08 -07:00
|
|
|
struct in6_addr d6; /* IPv6 address */
|
|
|
|
#endif
|
|
|
|
} data;
|
2003-11-02 15:48:45 -08:00
|
|
|
|
2005-08-10 06:50:08 -07:00
|
|
|
/* Under IPv6 getaddrinfo also returns scope_id. Since it's
|
|
|
|
IPv6-specific it strictly belongs in the above union, but we put
|
|
|
|
it here for simplicity. */
|
|
|
|
#if defined ENABLE_IPV6 && defined HAVE_SOCKADDR_IN6_SCOPE_ID
|
|
|
|
int ipv6_scope;
|
|
|
|
#endif
|
|
|
|
} ip_address;
|
2002-01-23 21:45:54 -08:00
|
|
|
|
2005-08-10 06:50:08 -07:00
|
|
|
/* IP_INADDR_DATA macro returns a void pointer that can be interpreted
|
|
|
|
as a pointer to struct in_addr in IPv4 context or a pointer to
|
|
|
|
struct in6_addr in IPv4 context. This pointer can be passed to
|
|
|
|
functions that work on either, such as inet_ntop. */
|
|
|
|
#define IP_INADDR_DATA(x) ((void *) &(x)->data)
|
2002-01-23 21:45:54 -08:00
|
|
|
|
2003-11-14 17:49:52 -08:00
|
|
|
enum {
|
|
|
|
LH_SILENT = 1,
|
|
|
|
LH_BIND = 2,
|
|
|
|
LH_REFRESH = 4
|
|
|
|
};
|
2005-06-19 15:34:58 -07:00
|
|
|
struct address_list *lookup_host (const char *, int);
|
|
|
|
|
|
|
|
void address_list_get_bounds (const struct address_list *, int *, int *);
|
|
|
|
const ip_address *address_list_address_at (const struct address_list *, int);
|
2005-06-22 12:38:10 -07:00
|
|
|
bool address_list_contains (const struct address_list *, const ip_address *);
|
2005-06-19 15:34:58 -07:00
|
|
|
void address_list_set_faulty (struct address_list *, int);
|
|
|
|
void address_list_set_connected (struct address_list *);
|
2005-06-22 12:38:10 -07:00
|
|
|
bool address_list_connected_p (const struct address_list *);
|
2005-06-19 15:34:58 -07:00
|
|
|
void address_list_release (struct address_list *);
|
|
|
|
|
2005-06-30 13:03:18 -07:00
|
|
|
const char *print_address (const ip_address *);
|
2005-03-04 11:21:02 -08:00
|
|
|
#ifdef ENABLE_IPV6
|
2005-06-22 12:38:10 -07:00
|
|
|
bool is_valid_ipv6_address (const char *, const char *);
|
2005-03-04 11:21:02 -08:00
|
|
|
#endif
|
2001-11-25 21:36:33 -08:00
|
|
|
|
2005-06-22 12:38:10 -07:00
|
|
|
bool accept_domain (struct url *);
|
|
|
|
bool sufmatch (const char **, const char *);
|
1999-12-01 23:42:23 -08:00
|
|
|
|
2005-06-19 15:34:58 -07:00
|
|
|
void host_cleanup (void);
|
2002-01-23 21:45:54 -08:00
|
|
|
|
1999-12-01 23:42:23 -08:00
|
|
|
#endif /* HOST_H */
|