netdb.h

来自「俄罗斯高人Mamaich的Pocket gcc编译器(运行在PocketPC上)」· C头文件 代码 · 共 494 行 · 第 1/2 页

H
494
字号
/* Copyright (C) 1996,97,98,99,2000,01,02 Free Software Foundation, Inc.   This file is part of the GNU C Library.   The GNU C Library is free software; you can redistribute it and/or   modify it under the terms of the GNU Lesser General Public   License as published by the Free Software Foundation; either   version 2.1 of the License, or (at your option) any later version.   The GNU C Library is distributed in the hope that it will be useful,   but WITHOUT ANY WARRANTY; without even the implied warranty of   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU   Lesser General Public License for more details.   You should have received a copy of the GNU Lesser General Public   License along with the GNU C Library; if not, write to the Free   Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA   02111-1307 USA.  *//* All data returned by the network data base library are supplied in   host order and returned in network order (suitable for use in   system calls).  */#ifndef	_NETDB_H#define	_NETDB_H	1#include <features.h>#include <netinet/in.h>#include <stdint.h>#include <time.h>#include <bits/netdb.h>/*!! CAV where is this supposed to go?? */#define __restrict_arr/* Absolute file name for network data base files.  */#define	_PATH_HEQUIV		"/etc/hosts.equiv"#define	_PATH_HOSTS		"/etc/hosts"#define	_PATH_NETWORKS		"/etc/networks"#define	_PATH_NSSWITCH_CONF	"/etc/nsswitch.conf"#define	_PATH_PROTOCOLS		"/etc/protocols"#define	_PATH_SERVICES		"/etc/services"__BEGIN_DECLS/* Error status for non-reentrant lookup functions.   We use a macro to access always the thread-specific `h_errno' variable.  */#define h_errno (*__h_errno_location ())/* Function to get address of global `h_errno' variable.  */extern int *__h_errno_location (void) __THROW __attribute__ ((__const__));/* Possible values left in `h_errno'.  */#define	NETDB_INTERNAL	-1	/* See errno.  */#define	NETDB_SUCCESS	0	/* No problem.  */#define	HOST_NOT_FOUND	1	/* Authoritative Answer Host not found.  */#define	TRY_AGAIN	2	/* Non-Authoritative Host not found,				   or SERVERFAIL.  */#define	NO_RECOVERY	3	/* Non recoverable errors, FORMERR, REFUSED,				   NOTIMP.  */#define	NO_DATA		4	/* Valid name, no data record of requested				   type.  */#define	NO_ADDRESS	NO_DATA	/* No address, look for MX record.  */#ifdef __USE_XOPEN2K/* Highest reserved Internet port number.  */# define IPPORT_RESERVED	1024#endif#ifdef __USE_GNU/* Scope delimiter for getaddrinfo(), getnameinfo().  */# define SCOPE_DELIMITER	'%'#endif/* Print error indicated by `h_errno' variable on standard error.  STR   if non-null is printed before the error string.  */extern void herror (__const char *__str) __THROW;/* Return string associated with error ERR_NUM.  */extern __const char *hstrerror (int __err_num) __THROW;/* Description of data base entry for a single host.  *//* CAV modified for compatibility w/winsock (fields 3&4 to short */struct hostent{  char *h_name;			/* Official name of host.  */  char **h_aliases;		/* Alias list.  */  short h_addrtype;		/* Host address type.  */  short h_length;			/* Length of address.  */  char **h_addr_list;		/* List of addresses from name server.  */#define	h_addr	h_addr_list[0]	/* Address, for backward compatibility.  */};/* Open host data base files and mark them as staying open even after   a later search if STAY_OPEN is non-zero.  */extern void sethostent (int __stay_open) __THROW;/* Close host data base files and clear `stay open' flag.  */extern void endhostent (void) __THROW;/* Get next entry from host data base file.  Open data base if   necessary.  */extern struct hostent *gethostent (void) __THROW;/* Return entry from host data base which address match ADDR with   length LEN and type TYPE.  */extern struct hostent *gethostbyaddr (__const void *__addr, __socklen_t __len,				      int __type) __THROW;/* Return entry from host data base for host with NAME.  */extern struct hostent *gethostbyname (__const char *__name) __THROW;#ifdef __USE_MISC/* Return entry from host data base for host with NAME.  AF must be   set to the address type which is `AF_INET' for IPv4 or `AF_INET6'   for IPv6.  */extern struct hostent *gethostbyname2 (__const char *__name, int __af) __THROW;/* Reentrant versions of the functions above.  The additional   arguments specify a buffer of BUFLEN starting at BUF.  The last   argument is a pointer to a variable which gets the value which   would be stored in the global variable `herrno' by the   non-reentrant functions.  */extern int gethostent_r (struct hostent *__restrict __result_buf,			 char *__restrict __buf, size_t __buflen,			 struct hostent **__restrict __result,			 int *__restrict __h_errnop) __THROW;extern int gethostbyaddr_r (__const void *__restrict __addr, __socklen_t __len,			    int __type,			    struct hostent *__restrict __result_buf,			    char *__restrict __buf, size_t __buflen,			    struct hostent **__restrict __result,			    int *__restrict __h_errnop) __THROW;extern int gethostbyname_r (__const char *__restrict __name,			    struct hostent *__restrict __result_buf,			    char *__restrict __buf, size_t __buflen,			    struct hostent **__restrict __result,			    int *__restrict __h_errnop) __THROW;extern int gethostbyname2_r (__const char *__restrict __name, int __af,			     struct hostent *__restrict __result_buf,			     char *__restrict __buf, size_t __buflen,			     struct hostent **__restrict __result,			     int *__restrict __h_errnop) __THROW;#endif	/* misc *//* Open network data base files and mark them as staying open even   after a later search if STAY_OPEN is non-zero.  */extern void setnetent (int __stay_open) __THROW;/* Close network data base files and clear `stay open' flag.  */extern void endnetent (void) __THROW;/* Get next entry from network data base file.  Open data base if   necessary.  */extern struct netent *getnetent (void) __THROW;/* Return entry from network data base which address match NET and   type TYPE.  */extern struct netent *getnetbyaddr (uint32_t __net, int __type)     __THROW;/* Return entry from network data base for network with NAME.  */extern struct netent *getnetbyname (__const char *__name) __THROW;#ifdef	__USE_MISC/* Reentrant versions of the functions above.  The additional   arguments specify a buffer of BUFLEN starting at BUF.  The last   argument is a pointer to a variable which gets the value which   would be stored in the global variable `herrno' by the   non-reentrant functions.  */extern int getnetent_r (struct netent *__restrict __result_buf,			char *__restrict __buf, size_t __buflen,			struct netent **__restrict __result,			int *__restrict __h_errnop) __THROW;extern int getnetbyaddr_r (uint32_t __net, int __type,			   struct netent *__restrict __result_buf,			   char *__restrict __buf, size_t __buflen,			   struct netent **__restrict __result,			   int *__restrict __h_errnop) __THROW;extern int getnetbyname_r (__const char *__restrict __name,			   struct netent *__restrict __result_buf,			   char *__restrict __buf, size_t __buflen,			   struct netent **__restrict __result,			   int *__restrict __h_errnop) __THROW;#endif	/* misc *//* Description of data base entry for a single service.  */struct servent{  char *s_name;			/* Official service name.  */  char **s_aliases;		/* Alias list.  */  int s_port;			/* Port number.  */  char *s_proto;		/* Protocol to use.  */};/* Open service data base files and mark them as staying open even   after a later search if STAY_OPEN is non-zero.  */extern void setservent (int __stay_open) __THROW;/* Close service data base files and clear `stay open' flag.  */extern void endservent (void) __THROW;/* Get next entry from service data base file.  Open data base if   necessary.  */extern struct servent *getservent (void) __THROW;/* Return entry from network data base for network with NAME and   protocol PROTO.  */extern struct servent *getservbyname (__const char *__name,				      __const char *__proto) __THROW;/* Return entry from service data base which matches port PORT and   protocol PROTO.  */extern struct servent *getservbyport (int __port, __const char *__proto)     __THROW;#ifdef	__USE_MISC/* Reentrant versions of the functions above.  The additional   arguments specify a buffer of BUFLEN starting at BUF.  */extern int getservent_r (struct servent *__restrict __result_buf,			 char *__restrict __buf, size_t __buflen,			 struct servent **__restrict __result) __THROW;extern int getservbyname_r (__const char *__restrict __name,			    __const char *__restrict __proto,			    struct servent *__restrict __result_buf,			    char *__restrict __buf, size_t __buflen,			    struct servent **__restrict __result) __THROW;extern int getservbyport_r (int __port, __const char *__restrict __proto,			    struct servent *__restrict __result_buf,			    char *__restrict __buf, size_t __buflen,			    struct servent **__restrict __result) __THROW;#endif	/* misc */

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?