diff options
author | Nick Mathewson <nickm@torproject.org> | 2008-05-16 19:19:49 +0000 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2008-05-16 19:19:49 +0000 |
commit | 09cd8fa371092e1c1f75ba86c8899a2af04857ad (patch) | |
tree | 62542f4994c13ff8824352e6b9dbea9260543523 /src/common/compat.c | |
parent | 54d7c388fccc17a16ba6addb7ba7e99ba35d409d (diff) | |
download | tor-09cd8fa371092e1c1f75ba86c8899a2af04857ad.tar.gz tor-09cd8fa371092e1c1f75ba86c8899a2af04857ad.zip |
r19795@catbus: nickm | 2008-05-16 14:54:24 -0400
Rename tor_addr_t manipulation functions for a consistent style.
svn:r14639
Diffstat (limited to 'src/common/compat.c')
-rw-r--r-- | src/common/compat.c | 29 |
1 files changed, 27 insertions, 2 deletions
diff --git a/src/common/compat.c b/src/common/compat.c index d9266da576..7a6859af34 100644 --- a/src/common/compat.c +++ b/src/common/compat.c @@ -935,6 +935,31 @@ get_user_homedir(const char *username) } #endif +/** DOCDOC */ +socklen_t +tor_addr_to_sockaddr(const tor_addr_t *a, + uint16_t port, + struct sockaddr *sa_out) +{ + if (a->family == AF_INET) { + struct sockaddr_in *sin = (struct sockaddr_in *)sa_out; + sin->sin_family = AF_INET; + sin->sin_port = port; + sin->sin_addr.s_addr = a->addr.in_addr.s_addr; + return sizeof(struct sockaddr_in); + } else if (a->family == AF_INET6) { + struct sockaddr_in6 *sin6 = (struct sockaddr_in6 *)sa_out; + tor_assert(a->family == AF_INET6); + memset(sin6, 0, sizeof(struct sockaddr_in6)); + sin6->sin6_family = AF_INET6; + sin6->sin6_port = port; + memcpy(&sin6->sin6_addr, &a->addr.in6_addr, sizeof(struct in6_addr)); + return sizeof(struct sockaddr_in6); + } else { + return -1; + } +} + /** Set *addr to the IP address (in dotted-quad notation) stored in c. * Return 1 on success, 0 if c is badly formatted. (Like inet_aton(c,addr), * but works on Windows and Solaris.) @@ -1166,8 +1191,8 @@ tor_lookup_hostname(const char *name, uint32_t *addr) if ((ret = tor_addr_lookup(name, AF_INET, &myaddr))) return ret; - if (IN_FAMILY(&myaddr) == AF_INET) { - *addr = IPV4IPh(&myaddr); + if (tor_addr_family(&myaddr) == AF_INET) { + *addr = tor_addr_to_ipv4h(&myaddr); return ret; } |