* net.cc (gai_errmap): Add EAI_OVERFLOW entry. Fix formatting.
(cygwin_gai_strerror): Drop using EAI_MAX. (w32_to_gai_err): Ditto. * include/netdb.h: Define EAI_OVERFLOW. Remove EAI_MAX.
This commit is contained in:
parent
f7fee067b6
commit
f28f68cc4f
@ -1,3 +1,10 @@
|
|||||||
|
2007-01-23 Corinna Vinschen <corinna@vinschen.de>
|
||||||
|
|
||||||
|
* net.cc (gai_errmap): Add EAI_OVERFLOW entry. Fix formatting.
|
||||||
|
(cygwin_gai_strerror): Drop using EAI_MAX.
|
||||||
|
(w32_to_gai_err): Ditto.
|
||||||
|
* include/netdb.h: Define EAI_OVERFLOW. Remove EAI_MAX.
|
||||||
|
|
||||||
2007-01-23 Corinna Vinschen <corinna@vinschen.de>
|
2007-01-23 Corinna Vinschen <corinna@vinschen.de>
|
||||||
|
|
||||||
* include/netdb.h: Add AI_xxx flags available since Vista.
|
* include/netdb.h: Add AI_xxx flags available since Vista.
|
||||||
|
@ -174,8 +174,7 @@ extern __declspec(dllimport) int h_errno;
|
|||||||
#define EAI_SYSTEM 11
|
#define EAI_SYSTEM 11
|
||||||
#define EAI_BADHINTS 12
|
#define EAI_BADHINTS 12
|
||||||
#define EAI_PROTOCOL 13
|
#define EAI_PROTOCOL 13
|
||||||
|
#define EAI_OVERFLOW 14
|
||||||
#define EAI_MAX 14
|
|
||||||
|
|
||||||
#ifndef __INSIDE_CYGWIN_NET__
|
#ifndef __INSIDE_CYGWIN_NET__
|
||||||
void endhostent (void);
|
void endhostent (void);
|
||||||
|
@ -3751,26 +3751,27 @@ struct gai_errmap_t
|
|||||||
|
|
||||||
static gai_errmap_t gai_errmap[] =
|
static gai_errmap_t gai_errmap[] =
|
||||||
{
|
{
|
||||||
{0, "Success"},
|
{0, "Success"},
|
||||||
{0, "Address family for hostname not supported"},
|
{0, "Address family for hostname not supported"},
|
||||||
{WSATRY_AGAIN, "Temporary failure in name resolution"},
|
{WSATRY_AGAIN, "Temporary failure in name resolution"},
|
||||||
{WSAEINVAL, "Invalid value for ai_flags"},
|
{WSAEINVAL, "Invalid value for ai_flags"},
|
||||||
{WSANO_RECOVERY, "Non-recoverable failure in name resolution"},
|
{WSANO_RECOVERY, "Non-recoverable failure in name resolution"},
|
||||||
{WSAEAFNOSUPPORT, "ai_family not supported"},
|
{WSAEAFNOSUPPORT, "ai_family not supported"},
|
||||||
{WSA_NOT_ENOUGH_MEMORY, "Memory allocation failure"},
|
{WSA_NOT_ENOUGH_MEMORY, "Memory allocation failure"},
|
||||||
{WSANO_DATA, "No address associated with hostname"},
|
{WSANO_DATA, "No address associated with hostname"},
|
||||||
{WSAHOST_NOT_FOUND, "hostname nor servname provided, or not known"},
|
{WSAHOST_NOT_FOUND, "hostname nor servname provided, or not known"},
|
||||||
{WSATYPE_NOT_FOUND, "servname not supported for ai_socktype"},
|
{WSATYPE_NOT_FOUND, "servname not supported for ai_socktype"},
|
||||||
{WSAESOCKTNOSUPPORT, "ai_socktype not supported"},
|
{WSAESOCKTNOSUPPORT, "ai_socktype not supported"},
|
||||||
{0, "System error returned in errno"},
|
{0, "System error returned in errno"},
|
||||||
{0, "Invalid value for hints"},
|
{0, "Invalid value for hints"},
|
||||||
{0, "Resolved protocol is unknown"}
|
{0, "Resolved protocol is unknown"},
|
||||||
|
{WSAEFAULT, "An argument buffer overflowed"}
|
||||||
};
|
};
|
||||||
|
|
||||||
extern "C" const char *
|
extern "C" const char *
|
||||||
cygwin_gai_strerror (int err)
|
cygwin_gai_strerror (int err)
|
||||||
{
|
{
|
||||||
if (err >= 0 && err < EAI_MAX)
|
if (err >= 0 && err < (int) (sizeof gai_errmap / sizeof *gai_errmap))
|
||||||
return gai_errmap[err].errtxt;
|
return gai_errmap[err].errtxt;
|
||||||
return "Unknown error";
|
return "Unknown error";
|
||||||
}
|
}
|
||||||
@ -3779,7 +3780,7 @@ static int
|
|||||||
w32_to_gai_err (int w32_err)
|
w32_to_gai_err (int w32_err)
|
||||||
{
|
{
|
||||||
if (w32_err >= WSABASEERR)
|
if (w32_err >= WSABASEERR)
|
||||||
for (int i = 0; i < EAI_MAX; ++i)
|
for (unsigned i = 0; i < sizeof gai_errmap / sizeof *gai_errmap; ++i)
|
||||||
if (gai_errmap[i].w32_errval == w32_err)
|
if (gai_errmap[i].w32_errval == w32_err)
|
||||||
return i;
|
return i;
|
||||||
return w32_err;
|
return w32_err;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user