Changeset 388 for python/vendor/current/Modules/addrinfo.h
- Timestamp:
- Mar 19, 2014, 11:11:30 AM (11 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
python/vendor/current/Modules/addrinfo.h
r2 r388 2 2 * Copyright (C) 1995, 1996, 1997, 1998, and 1999 WIDE Project. 3 3 * All rights reserved. 4 * 4 * 5 5 * Redistribution and use in source and binary forms, with or without 6 6 * modification, are permitted provided that the following conditions … … 14 14 * may be used to endorse or promote products derived from this software 15 15 * without specific prior written permission. 16 * 16 * 17 17 * THIS SOFTWARE IS PROVIDED BY THE PROJECT AND CONTRIBUTORS ``AS IS'' AND 18 18 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE … … 56 56 #endif /* EAI_ADDRFAMILY */ 57 57 58 #define EAI_ADDRFAMILY 1/* address family for hostname not supported */59 #define EAI_AGAIN 2/* temporary failure in name resolution */60 #define EAI_BADFLAGS 3/* invalid value for ai_flags */61 #define EAI_FAIL 4/* non-recoverable failure in name resolution */62 #define EAI_FAMILY 5/* ai_family not supported */63 #define EAI_MEMORY 6/* memory allocation failure */64 #define EAI_NODATA 7/* no address associated with hostname */65 #define EAI_NONAME 8/* hostname nor servname provided, or not known */66 #define EAI_SERVICE 9/* servname not supported for ai_socktype */67 #define EAI_SOCKTYPE 10/* ai_socktype not supported */68 #define EAI_SYSTEM 11/* system error returned in errno */69 #define EAI_BADHINTS 70 #define EAI_PROTOCOL 71 #define EAI_MAX 58 #define EAI_ADDRFAMILY 1 /* address family for hostname not supported */ 59 #define EAI_AGAIN 2 /* temporary failure in name resolution */ 60 #define EAI_BADFLAGS 3 /* invalid value for ai_flags */ 61 #define EAI_FAIL 4 /* non-recoverable failure in name resolution */ 62 #define EAI_FAMILY 5 /* ai_family not supported */ 63 #define EAI_MEMORY 6 /* memory allocation failure */ 64 #define EAI_NODATA 7 /* no address associated with hostname */ 65 #define EAI_NONAME 8 /* hostname nor servname provided, or not known */ 66 #define EAI_SERVICE 9 /* servname not supported for ai_socktype */ 67 #define EAI_SOCKTYPE 10 /* ai_socktype not supported */ 68 #define EAI_SYSTEM 11 /* system error returned in errno */ 69 #define EAI_BADHINTS 12 70 #define EAI_PROTOCOL 13 71 #define EAI_MAX 14 72 72 73 73 /* … … 86 86 #endif /* AI_PASSIVE */ 87 87 88 #define AI_PASSIVE0x00000001 /* get address to use bind() */89 #define AI_CANONNAME0x00000002 /* fill ai_canonname */90 #define AI_NUMERICHOST0x00000004 /* prevent name resolution */88 #define AI_PASSIVE 0x00000001 /* get address to use bind() */ 89 #define AI_CANONNAME 0x00000002 /* fill ai_canonname */ 90 #define AI_NUMERICHOST 0x00000004 /* prevent name resolution */ 91 91 /* valid flags for addrinfo */ 92 #define AI_MASK(AI_PASSIVE | AI_CANONNAME | AI_NUMERICHOST)92 #define AI_MASK (AI_PASSIVE | AI_CANONNAME | AI_NUMERICHOST) 93 93 94 #define AI_ALL0x00000100 /* IPv6 and IPv4-mapped (with AI_V4MAPPED) */95 #define AI_V4MAPPED_CFG0x00000200 /* accept IPv4-mapped if kernel supports */96 #define AI_ADDRCONFIG0x00000400 /* only if any address is assigned */97 #define AI_V4MAPPED0x00000800 /* accept IPv4-mapped IPv6 address */94 #define AI_ALL 0x00000100 /* IPv6 and IPv4-mapped (with AI_V4MAPPED) */ 95 #define AI_V4MAPPED_CFG 0x00000200 /* accept IPv4-mapped if kernel supports */ 96 #define AI_ADDRCONFIG 0x00000400 /* only if any address is assigned */ 97 #define AI_V4MAPPED 0x00000800 /* accept IPv4-mapped IPv6 address */ 98 98 /* special recommended flags for getipnodebyname */ 99 #define AI_DEFAULT(AI_V4MAPPED_CFG | AI_ADDRCONFIG)99 #define AI_DEFAULT (AI_V4MAPPED_CFG | AI_ADDRCONFIG) 100 100 101 101 #endif /* !HAVE_GETADDRINFO */ … … 107 107 */ 108 108 #ifndef NI_MAXHOST 109 #define NI_MAXHOST1025110 #define NI_MAXSERV32109 #define NI_MAXHOST 1025 110 #define NI_MAXSERV 32 111 111 #endif /* !NI_MAXHOST */ 112 112 … … 115 115 */ 116 116 #ifndef NI_NOFQDN 117 #define NI_NOFQDN0x00000001118 #define NI_NUMERICHOST0x00000002119 #define NI_NAMEREQD0x00000004120 #define NI_NUMERICSERV0x00000008121 #define NI_DGRAM0x00000010117 #define NI_NOFQDN 0x00000001 118 #define NI_NUMERICHOST 0x00000002 119 #define NI_NAMEREQD 0x00000004 120 #define NI_NUMERICSERV 0x00000008 121 #define NI_DGRAM 0x00000010 122 122 #endif /* !NI_NOFQDN */ 123 123 … … 126 126 #ifndef HAVE_ADDRINFO 127 127 struct addrinfo { 128 int ai_flags;/* AI_PASSIVE, AI_CANONNAME */129 int ai_family;/* PF_xxx */130 int ai_socktype;/* SOCK_xxx */131 int ai_protocol;/* 0 or IPPROTO_xxx for IPv4 and IPv6 */132 size_t ai_addrlen;/* length of ai_addr */133 char *ai_canonname;/* canonical name for hostname */134 struct sockaddr *ai_addr;/* binary address */135 struct addrinfo *ai_next;/* next structure in linked list */128 int ai_flags; /* AI_PASSIVE, AI_CANONNAME */ 129 int ai_family; /* PF_xxx */ 130 int ai_socktype; /* SOCK_xxx */ 131 int ai_protocol; /* 0 or IPPROTO_xxx for IPv4 and IPv6 */ 132 size_t ai_addrlen; /* length of ai_addr */ 133 char *ai_canonname; /* canonical name for hostname */ 134 struct sockaddr *ai_addr; /* binary address */ 135 struct addrinfo *ai_next; /* next structure in linked list */ 136 136 }; 137 137 #endif /* !HAVE_ADDRINFO */ … … 141 141 * RFC 2553: protocol-independent placeholder for socket addresses 142 142 */ 143 #define _SS_MAXSIZE 143 #define _SS_MAXSIZE 128 144 144 #ifdef HAVE_LONG_LONG 145 #define _SS_ALIGNSIZE 145 #define _SS_ALIGNSIZE (sizeof(PY_LONG_LONG)) 146 146 #else 147 #define _SS_ALIGNSIZE 147 #define _SS_ALIGNSIZE (sizeof(double)) 148 148 #endif /* HAVE_LONG_LONG */ 149 #define _SS_PAD1SIZE 150 #define _SS_PAD2SIZE 151 149 #define _SS_PAD1SIZE (_SS_ALIGNSIZE - sizeof(u_char) * 2) 150 #define _SS_PAD2SIZE (_SS_MAXSIZE - sizeof(u_char) * 2 - \ 151 _SS_PAD1SIZE - _SS_ALIGNSIZE) 152 152 153 153 struct sockaddr_storage { 154 154 #ifdef HAVE_SOCKADDR_SA_LEN 155 unsigned char ss_len;/* address length */156 unsigned char ss_family;/* address family */155 unsigned char ss_len; /* address length */ 156 unsigned char ss_family; /* address family */ 157 157 #else 158 unsigned short ss_family;/* address family */158 unsigned short ss_family; /* address family */ 159 159 #endif /* HAVE_SOCKADDR_SA_LEN */ 160 char__ss_pad1[_SS_PAD1SIZE];160 char __ss_pad1[_SS_PAD1SIZE]; 161 161 #ifdef HAVE_LONG_LONG 162 PY_LONG_LONG __ss_align;/* force desired structure storage alignment */162 PY_LONG_LONG __ss_align; /* force desired structure storage alignment */ 163 163 #else 164 double __ss_align;/* force desired structure storage alignment */164 double __ss_align; /* force desired structure storage alignment */ 165 165 #endif /* HAVE_LONG_LONG */ 166 char__ss_pad2[_SS_PAD2SIZE];166 char __ss_pad2[_SS_PAD2SIZE]; 167 167 }; 168 168 #endif /* !HAVE_SOCKADDR_STORAGE */
Note:
See TracChangeset
for help on using the changeset viewer.