diff options
author | teor <teor@torproject.org> | 2019-06-02 18:20:25 +1000 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2019-06-26 09:55:37 -0400 |
commit | 29cf64c8389fd4de1e4419cb8ac30b2ca582ba5e (patch) | |
tree | d17f466021767be34d68e6d4c041d51434cda9b8 /src/lib/net/resolve.c | |
parent | cd1de99468aa4d7b48c9f3bcb7c7d4fb5b3bfe9a (diff) | |
download | tor-29cf64c8389fd4de1e4419cb8ac30b2ca582ba5e.tar.gz tor-29cf64c8389fd4de1e4419cb8ac30b2ca582ba5e.zip |
resolve: refactor address family logic in tor_addr_lookup()
Cleanup after 30721.
Diffstat (limited to 'src/lib/net/resolve.c')
-rw-r--r-- | src/lib/net/resolve.c | 20 |
1 files changed, 7 insertions, 13 deletions
diff --git a/src/lib/net/resolve.c b/src/lib/net/resolve.c index 71c033fe7a..1b68a0b33a 100644 --- a/src/lib/net/resolve.c +++ b/src/lib/net/resolve.c @@ -81,30 +81,24 @@ tor_addr_lookup,(const char *name, uint16_t family, tor_addr_t *addr)) tor_assert(addr); tor_assert(family == AF_INET || family == AF_INET6 || family == AF_UNSPEC); - /* Clear address before starting, to avoid returning uninitialised data */ - memset(addr, 0, sizeof(tor_addr_t)); - if (!*name) { /* Empty address is an error. */ + memset(addr, 0, sizeof(tor_addr_t)); return -1; } /* Is it an IP address? */ parsed_family = tor_addr_parse(addr, name); - if (parsed_family == AF_INET) { - /* It's an IPv4 IP. */ - if (family == AF_INET6) { - memset(addr, 0, sizeof(tor_addr_t)); - return -1; - } - return 0; - } else if (parsed_family == AF_INET6) { - if (family == AF_INET) { + if (parsed_family >= 0) { + /* If the IP address family matches, or was unspecified */ + if (parsed_family == family || family == AF_UNSPEC) { + return 0; + } else { + /* Clear the address before returning an error. */ memset(addr, 0, sizeof(tor_addr_t)); return -1; } - return 0; } else { /* Clear the address after a failed tor_addr_parse(). */ memset(addr, 0, sizeof(tor_addr_t)); |