0
0
mirror of https://github.com/zeromq/libzmq.git synced 2025-01-15 10:18:01 +08:00

Merge pull request #1869 from jimklimov/fix-tcp_address

zeromq-4.1.4/src/tcp_address.cpp : fix relaxed use of sizeof() without parenthesis
This commit is contained in:
Luca Boccassi 2016-03-29 18:01:10 +01:00
commit 05c8de7928

View File

@ -133,10 +133,10 @@ int zmq::tcp_address_t::resolve_nic_name (const char *nic_, bool ipv6_, bool is_
struct ifreq ifr; struct ifreq ifr;
// Copy interface name for ioctl get. // Copy interface name for ioctl get.
strncpy (ifr.ifr_name, nic_, sizeof ifr.ifr_name); strncpy (ifr.ifr_name, nic_, sizeof (ifr.ifr_name) );
// Fetch interface address. // Fetch interface address.
const int rc = ioctl (sd, SIOCGIFADDR, (caddr_t) &ifr, sizeof ifr); const int rc = ioctl (sd, SIOCGIFADDR, (caddr_t) &ifr, sizeof (ifr) );
// Clean up. // Clean up.
close (sd); close (sd);
@ -244,23 +244,23 @@ int zmq::tcp_address_t::resolve_interface (const char *interface_, bool ipv6_, b
// with the address. // with the address.
if (ipv6_) { if (ipv6_) {
sockaddr_in6 ip6_addr; sockaddr_in6 ip6_addr;
memset (&ip6_addr, 0, sizeof ip6_addr); memset (&ip6_addr, 0, sizeof (ip6_addr) );
ip6_addr.sin6_family = AF_INET6; ip6_addr.sin6_family = AF_INET6;
memcpy (&ip6_addr.sin6_addr, &in6addr_any, sizeof in6addr_any); memcpy (&ip6_addr.sin6_addr, &in6addr_any, sizeof (in6addr_any) );
out_addrlen = sizeof ip6_addr; out_addrlen = sizeof (ip6_addr);
memcpy (out_addr, &ip6_addr, out_addrlen); memcpy (out_addr, &ip6_addr, out_addrlen);
} }
else { else {
sockaddr_in ip4_addr; sockaddr_in ip4_addr;
memset (&ip4_addr, 0, sizeof ip4_addr); memset (&ip4_addr, 0, sizeof (ip4_addr) );
ip4_addr.sin_family = AF_INET; ip4_addr.sin_family = AF_INET;
ip4_addr.sin_addr.s_addr = htonl (INADDR_ANY); ip4_addr.sin_addr.s_addr = htonl (INADDR_ANY);
out_addrlen = sizeof ip4_addr; out_addrlen = sizeof (ip4_addr);
memcpy (out_addr, &ip4_addr, out_addrlen); memcpy (out_addr, &ip4_addr, out_addrlen);
} }
// "*" resolves to INADDR_ANY or in6addr_any. // "*" resolves to INADDR_ANY or in6addr_any.
if (strcmp (interface_, "*") == 0) { if (strcmp (interface_, "*") == 0) {
zmq_assert (out_addrlen <= sizeof address); zmq_assert (out_addrlen <= sizeof (address) );
if (is_src_) if (is_src_)
memcpy (&source_address, out_addr, out_addrlen); memcpy (&source_address, out_addr, out_addrlen);
else else
@ -281,7 +281,7 @@ int zmq::tcp_address_t::resolve_interface (const char *interface_, bool ipv6_, b
addrinfo *res = NULL; addrinfo *res = NULL;
addrinfo req; addrinfo req;
#endif #endif
memset (&req, 0, sizeof req); memset (&req, 0, sizeof (req) );
// Choose IPv4 or IPv6 protocol family. Note that IPv6 allows for // Choose IPv4 or IPv6 protocol family. Note that IPv6 allows for
// IPv4-in-IPv6 addresses. // IPv4-in-IPv6 addresses.
@ -314,7 +314,7 @@ int zmq::tcp_address_t::resolve_interface (const char *interface_, bool ipv6_, b
// Use the first result. // Use the first result.
zmq_assert (res != NULL); zmq_assert (res != NULL);
zmq_assert ((size_t) res->ai_addrlen <= sizeof address); zmq_assert ((size_t) res->ai_addrlen <= sizeof (address) );
if (is_src_) if (is_src_)
memcpy (&source_address, res->ai_addr, res->ai_addrlen); memcpy (&source_address, res->ai_addr, res->ai_addrlen);
else else
@ -334,7 +334,7 @@ int zmq::tcp_address_t::resolve_hostname (const char *hostname_, bool ipv6_, boo
#else #else
addrinfo req; addrinfo req;
#endif #endif
memset (&req, 0, sizeof req); memset (&req, 0, sizeof (req) );
// Choose IPv4 or IPv6 protocol family. Note that IPv6 allows for // Choose IPv4 or IPv6 protocol family. Note that IPv6 allows for
// IPv4-in-IPv6 addresses. // IPv4-in-IPv6 addresses.
@ -375,7 +375,7 @@ int zmq::tcp_address_t::resolve_hostname (const char *hostname_, bool ipv6_, boo
} }
// Copy first result to output addr with hostname and service. // Copy first result to output addr with hostname and service.
zmq_assert ((size_t) res->ai_addrlen <= sizeof address); zmq_assert ((size_t) res->ai_addrlen <= sizeof (address) );
if (is_src_) if (is_src_)
memcpy (&source_address, res->ai_addr, res->ai_addrlen); memcpy (&source_address, res->ai_addr, res->ai_addrlen);
else else
@ -389,8 +389,8 @@ int zmq::tcp_address_t::resolve_hostname (const char *hostname_, bool ipv6_, boo
zmq::tcp_address_t::tcp_address_t () : zmq::tcp_address_t::tcp_address_t () :
_has_src_addr (false) _has_src_addr (false)
{ {
memset (&address, 0, sizeof address); memset (&address, 0, sizeof (address) );
memset (&source_address, 0, sizeof source_address); memset (&source_address, 0, sizeof (source_address) );
} }
zmq::tcp_address_t::tcp_address_t (const sockaddr *sa, socklen_t sa_len) : zmq::tcp_address_t::tcp_address_t (const sockaddr *sa, socklen_t sa_len) :
@ -398,13 +398,13 @@ zmq::tcp_address_t::tcp_address_t (const sockaddr *sa, socklen_t sa_len) :
{ {
zmq_assert (sa && sa_len > 0); zmq_assert (sa && sa_len > 0);
memset (&address, 0, sizeof address); memset (&address, 0, sizeof (address) );
memset (&source_address, 0, sizeof source_address); memset (&source_address, 0, sizeof (source_address) );
if (sa->sa_family == AF_INET && sa_len >= (socklen_t) sizeof address.ipv4) if (sa->sa_family == AF_INET && sa_len >= (socklen_t) sizeof (address.ipv4) )
memcpy (&address.ipv4, sa, sizeof address.ipv4); memcpy (&address.ipv4, sa, sizeof (address.ipv4) );
else else
if (sa->sa_family == AF_INET6 && sa_len >= (socklen_t) sizeof address.ipv6) if (sa->sa_family == AF_INET6 && sa_len >= (socklen_t) sizeof (address.ipv6) )
memcpy (&address.ipv6, sa, sizeof address.ipv6); memcpy (&address.ipv6, sa, sizeof (address.ipv6) );
} }
zmq::tcp_address_t::~tcp_address_t () zmq::tcp_address_t::~tcp_address_t ()
@ -514,7 +514,7 @@ int zmq::tcp_address_t::to_string (std::string &addr_)
// Not using service resolving because of // Not using service resolving because of
// https://github.com/zeromq/libzmq/commit/1824574f9b5a8ce786853320e3ea09fe1f822bc4 // https://github.com/zeromq/libzmq/commit/1824574f9b5a8ce786853320e3ea09fe1f822bc4
char hbuf [NI_MAXHOST]; char hbuf [NI_MAXHOST];
int rc = getnameinfo (addr (), addrlen (), hbuf, sizeof hbuf, NULL, 0, NI_NUMERICHOST); int rc = getnameinfo (addr (), addrlen (), hbuf, sizeof (hbuf), NULL, 0, NI_NUMERICHOST);
if (rc != 0) { if (rc != 0) {
addr_.clear (); addr_.clear ();
return rc; return rc;
@ -541,9 +541,9 @@ const sockaddr *zmq::tcp_address_t::addr () const
socklen_t zmq::tcp_address_t::addrlen () const socklen_t zmq::tcp_address_t::addrlen () const
{ {
if (address.generic.sa_family == AF_INET6) if (address.generic.sa_family == AF_INET6)
return (socklen_t) sizeof address.ipv6; return (socklen_t) sizeof (address.ipv6);
else else
return (socklen_t) sizeof address.ipv4; return (socklen_t) sizeof (address.ipv4);
} }
const sockaddr *zmq::tcp_address_t::src_addr () const const sockaddr *zmq::tcp_address_t::src_addr () const
@ -554,9 +554,9 @@ const sockaddr *zmq::tcp_address_t::src_addr () const
socklen_t zmq::tcp_address_t::src_addrlen () const socklen_t zmq::tcp_address_t::src_addrlen () const
{ {
if (address.generic.sa_family == AF_INET6) if (address.generic.sa_family == AF_INET6)
return (socklen_t) sizeof source_address.ipv6; return (socklen_t) sizeof (source_address.ipv6);
else else
return (socklen_t) sizeof source_address.ipv4; return (socklen_t) sizeof (source_address.ipv4);
} }
bool zmq::tcp_address_t::has_src_addr () const bool zmq::tcp_address_t::has_src_addr () const
@ -646,7 +646,7 @@ int zmq::tcp_address_mask_t::to_string (std::string &addr_)
} }
char hbuf [NI_MAXHOST]; char hbuf [NI_MAXHOST];
int rc = getnameinfo (addr (), addrlen (), hbuf, sizeof hbuf, NULL, 0, NI_NUMERICHOST); int rc = getnameinfo (addr (), addrlen (), hbuf, sizeof (hbuf), NULL, 0, NI_NUMERICHOST);
if (rc != 0) { if (rc != 0) {
addr_.clear (); addr_.clear ();
return rc; return rc;