diff --git a/defs.h b/defs.h index e9050cf9..afeb5062 100644 --- a/defs.h +++ b/defs.h @@ -16,12 +16,13 @@ #include #if defined _MSC_VER && _MSC_VER < 1800 -/* Work around lack of inttypes.h in older MSVC */ +/* Work around lack of inttypes.h and strtoumax in older MSVC */ #define PRIx32 "x" #define PRIu64 "I64u" #define PRIdMAX "I64d" #define PRIXMAX "I64X" #define SCNu64 "I64u" +uintmax_t strtoumax(const char *nptr, char **endptr, int base); #else #include #endif diff --git a/windows/winnet.c b/windows/winnet.c index b8177ce2..ae5b11f6 100644 --- a/windows/winnet.c +++ b/windows/winnet.c @@ -247,7 +247,7 @@ void sk_init(void) if (GetProcAddress(winsock_module, "getaddrinfo") != NULL) { GET_WINDOWS_FUNCTION(winsock_module, getaddrinfo); GET_WINDOWS_FUNCTION(winsock_module, freeaddrinfo); - GET_WINDOWS_FUNCTION(winsock_module, getnameinfo); + GET_WINDOWS_FUNCTION_NO_TYPECHECK(winsock_module, getnameinfo); /* This function would fail its type-check if we did one, * because the VS header file provides an inline definition * which is __cdecl instead of WINAPI. */ @@ -258,8 +258,8 @@ void sk_init(void) if (wship6_module) { GET_WINDOWS_FUNCTION(wship6_module, getaddrinfo); GET_WINDOWS_FUNCTION(wship6_module, freeaddrinfo); - GET_WINDOWS_FUNCTION(wship6_module, getnameinfo); /* See comment above about type check */ + GET_WINDOWS_FUNCTION_NO_TYPECHECK(wship6_module, getnameinfo); GET_WINDOWS_FUNCTION_NO_TYPECHECK(winsock_module, gai_strerror); } else { }