aboutsummaryrefslogtreecommitdiff
path: root/src/common/util.c
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2004-04-28 19:35:12 +0000
committerNick Mathewson <nickm@torproject.org>2004-04-28 19:35:12 +0000
commitac622d94dcf5c00ab9264ec234ea6e9e1a2a28f9 (patch)
tree1ab02f2335c4920d65fd518185dd5040903e18f9 /src/common/util.c
parent8cc9001391d010f06553a1576276925bc8fc0667 (diff)
downloadtor-ac622d94dcf5c00ab9264ec234ea6e9e1a2a28f9.tar
tor-ac622d94dcf5c00ab9264ec234ea6e9e1a2a28f9.tar.gz
Workarounds for a couple of pieces of windows strangeness.
svn:r1734
Diffstat (limited to 'src/common/util.c')
-rw-r--r--src/common/util.c51
1 files changed, 51 insertions, 0 deletions
diff --git a/src/common/util.c b/src/common/util.c
index fb92681e9..64e3a9b5a 100644
--- a/src/common/util.c
+++ b/src/common/util.c
@@ -39,6 +39,9 @@
#ifdef HAVE_SYS_SOCKET_H
#include <sys/socket.h>
#endif
+#ifdef HAVE_NETDB_H
+#include <netdb.h>
+#endif
#ifdef HAVE_UNISTD_H
#include <unistd.h>
#endif
@@ -55,6 +58,18 @@
#include <grp.h>
#endif
+#ifdef HAVE_WINSOCK_H
+#define WIN32_WINNT 0x400
+#define _WIN32_WINNT 0x400
+#define WIN32_LEAN_AND_MEAN
+#endif
+#if _MSC_VER > 1300
+#include <winsock2.h>
+#include <ws2tcpip.h>
+#elif defined(_MSC_VER)
+#include <winsock.h>
+#endif
+
/* used by inet_addr, not defined on solaris anywhere!? */
#ifndef INADDR_NONE
#define INADDR_NONE ((unsigned long) -1)
@@ -1368,6 +1383,42 @@ int tor_inet_aton(const char *c, struct in_addr* addr)
#endif
}
+/* Similar behavior to Unix gethostbyname: resolve 'name', and set
+ * *addr to the proper IP address, in network byte order. Returns 0
+ * on success, -1 on failure; 1 on transient failure.
+ *
+ * (This function exists because standard windows gethostbyname
+ * doesn't treat raw IP addresses properly.)
+ */
+/* Perhaps eventually this should be replaced by a tor_getaddrinfo or
+ * something.
+ */
+int tor_lookup_hostname(const char *name, uint32_t *addr)
+{
+ struct in_addr iaddr;
+ struct hostent *ent;
+ tor_assert(addr);
+ if (tor_inet_aton(name, &iaddr)) {
+ /* It's an IP. */
+ memcpy(addr, &iaddr.s_addr, 4);
+ return 0;
+ } else {
+ ent = gethostbyname(name);
+ if (ent) {
+ /* break to remind us if we move away from IPv4 */
+ tor_assert(ent->h_length == 4);
+ memcpy(addr, ent->h_addr, 4);
+ return 0;
+ }
+ memset(addr, 0, 4);
+#ifdef MS_WINDOWS
+ return (WSAGetLastError() == WSATRY_AGAIN) ? 1 : -1;
+#else
+ return (h_errno == TRY_AGAIN) ? 1 : -1;
+#endif
+ }
+}
+
/*
Local Variables:
mode:c