diff options
author | Bert Belder <bertbelder@gmail.com> | 2012-08-07 01:35:10 +0200 |
---|---|---|
committer | Bert Belder <bertbelder@gmail.com> | 2012-08-07 01:57:58 +0200 |
commit | acea4c4123b346495de79498f5b4200d6fd1bf1d (patch) | |
tree | 88ecc368e7faa381d8aaf87dd9deddb6bcd8319a | |
parent | e0a603a4993e995080a8926fcddbbde752a2136e (diff) | |
download | node-new-acea4c4123b346495de79498f5b4200d6fd1bf1d.tar.gz |
dns: use uv_inet_ntop/uv_inet_pton instead of c-ares equivalents
-rw-r--r-- | src/cares_wrap.cc | 39 | ||||
-rw-r--r-- | src/tcp_wrap.cc | 14 | ||||
-rw-r--r-- | src/udp_wrap.cc | 15 |
3 files changed, 16 insertions, 52 deletions
diff --git a/src/cares_wrap.cc b/src/cares_wrap.cc index 3d1cb23fc2..2e509abade 100644 --- a/src/cares_wrap.cc +++ b/src/cares_wrap.cc @@ -37,21 +37,6 @@ # include <arpa/nameser.h> #endif -// Temporary hack: libuv should provide uv_inet_pton and uv_inet_ntop. -#if defined(__MINGW32__) || defined(_MSC_VER) - extern "C" { -# include <inet_net_pton.h> -# include <inet_ntop.h> - } -# define uv_inet_pton ares_inet_pton -# define uv_inet_ntop ares_inet_ntop - -#else // __POSIX__ -# include <arpa/inet.h> -# define uv_inet_pton inet_pton -# define uv_inet_ntop inet_ntop -#endif - namespace node { @@ -627,10 +612,10 @@ class GetHostByAddrWrap: public QueryWrap { int length, family; char address_buffer[sizeof(struct in6_addr)]; - if (uv_inet_pton(AF_INET, name, &address_buffer) == 1) { + if (uv_inet_pton(AF_INET, name, &address_buffer).code == UV_OK) { length = sizeof(struct in_addr); family = AF_INET; - } else if (uv_inet_pton(AF_INET6, name, &address_buffer) == 1) { + } else if (uv_inet_pton(AF_INET6, name, &address_buffer).code == UV_OK) { length = sizeof(struct in6_addr); family = AF_INET6; } else { @@ -772,11 +757,15 @@ void AfterGetAddrInfo(uv_getaddrinfo_t* req, int status, struct addrinfo* res) { if (address->ai_family == AF_INET) { // Juggle pointers addr = (char*) &((struct sockaddr_in*) address->ai_addr)->sin_addr; - const char* c = uv_inet_ntop(address->ai_family, addr, ip, - INET6_ADDRSTRLEN); + uv_err_t err = uv_inet_ntop(address->ai_family, + addr, + ip, + INET6_ADDRSTRLEN); + if (err.code != UV_OK) + continue; // Create JavaScript string - Local<String> s = String::New(c); + Local<String> s = String::New(ip); results->Set(n, s); n++; } @@ -794,11 +783,15 @@ void AfterGetAddrInfo(uv_getaddrinfo_t* req, int status, struct addrinfo* res) { if (address->ai_family == AF_INET6) { // Juggle pointers addr = (char*) &((struct sockaddr_in6*) address->ai_addr)->sin6_addr; - const char* c = uv_inet_ntop(address->ai_family, addr, ip, - INET6_ADDRSTRLEN); + uv_err_t err = uv_inet_ntop(address->ai_family, + addr, + ip, + INET6_ADDRSTRLEN); + if (err.code != UV_OK) + continue; // Create JavaScript string - Local<String> s = String::New(c); + Local<String> s = String::New(ip); results->Set(n, s); n++; } diff --git a/src/tcp_wrap.cc b/src/tcp_wrap.cc index 481838a5a1..778fc71f07 100644 --- a/src/tcp_wrap.cc +++ b/src/tcp_wrap.cc @@ -28,20 +28,6 @@ #include <stdlib.h> -// Temporary hack: libuv should provide uv_inet_pton and uv_inet_ntop. -#if defined(__MINGW32__) || defined(_MSC_VER) - extern "C" { -# include <inet_net_pton.h> -# include <inet_ntop.h> - } -# define uv_inet_pton ares_inet_pton -# define uv_inet_ntop ares_inet_ntop - -#else // __POSIX__ -# include <arpa/inet.h> -# define uv_inet_pton inet_pton -# define uv_inet_ntop inet_ntop -#endif namespace node { diff --git a/src/udp_wrap.cc b/src/udp_wrap.cc index 2e9776b2e6..34fe33562c 100644 --- a/src/udp_wrap.cc +++ b/src/udp_wrap.cc @@ -30,21 +30,6 @@ #define SLAB_SIZE (1024 * 1024) -// Temporary hack: libuv should provide uv_inet_pton and uv_inet_ntop. -// Clean this up in tcp_wrap.cc too. -#if defined(__MINGW32__) || defined(_MSC_VER) - extern "C" { -# include <inet_net_pton.h> -# include <inet_ntop.h> - } -# define uv_inet_pton ares_inet_pton -# define uv_inet_ntop ares_inet_ntop - -#else // __POSIX__ -# include <arpa/inet.h> -# define uv_inet_pton inet_pton -# define uv_inet_ntop inet_ntop -#endif using namespace v8; |