Skip to content

Commit

Permalink
SockAddr: factorize setters
Browse files Browse the repository at this point in the history
  • Loading branch information
aberaud committed Oct 5, 2017
1 parent 131073e commit 0733bb6
Showing 1 changed file with 15 additions and 15 deletions.
30 changes: 15 additions & 15 deletions include/opendht/sockaddr.h
Original file line number Diff line number Diff line change
Expand Up @@ -49,22 +49,15 @@ class OPENDHT_PUBLIC SockAddr {
public:
SockAddr() {}
SockAddr(const SockAddr& o) {
len = o.len;
if (len) {
addr.reset((sockaddr*)std::malloc(len));
std::memcpy((uint8_t*)addr.get(), (const uint8_t*)o.get(), len);
} else
addr.reset();
set(o.get(), o.getLength());
}
SockAddr(SockAddr&& o) : len(o.len), addr(std::move(o.addr)) {
o.len = 0;
}
SockAddr(const sockaddr* sa, socklen_t length) {
if (length > sizeof(sockaddr_storage))
throw std::runtime_error("Socket address length is too large");
len = length;
addr.reset((sockaddr*)std::malloc(len));
std::memcpy((uint8_t*)get(), (const uint8_t*)sa, len);
set(sa, length);
}
SockAddr(const sockaddr_storage& ss, socklen_t len) : SockAddr((const sockaddr*)&ss, len) {}

Expand All @@ -76,14 +69,10 @@ class OPENDHT_PUBLIC SockAddr {

bool equals(const SockAddr& o) const {
return len == o.len
&& std::memcmp((uint8_t*)get(), (uint8_t*)o.get(), len) == 0;
&& std::memcmp((const uint8_t*)get(), (const uint8_t*)o.get(), len) == 0;
}
SockAddr& operator=(const SockAddr& o) {
if (len != o.len) {
len = o.len;
addr.reset((sockaddr*)std::realloc(addr.release(), len));
}
std::memcpy((uint8_t*)get(), (const uint8_t*)o.get(), len);
set(o.get(), o.getLength());
return *this;
}
SockAddr& operator=(SockAddr&& o) {
Expand Down Expand Up @@ -204,6 +193,17 @@ class OPENDHT_PUBLIC SockAddr {
socklen_t len {0};
struct free_delete { void operator()(void* p) { std::free(p); } };
std::unique_ptr<sockaddr, free_delete> addr {};

void set(const sockaddr* sa, socklen_t length) {
if (len != length) {
len = length;
if (len) addr.reset((sockaddr*)std::malloc(len));
else addr.reset();
}
if (len)
std::memcpy((uint8_t*)get(), (const uint8_t*)sa, len);
}

};

OPENDHT_PUBLIC bool operator==(const SockAddr& a, const SockAddr& b);
Expand Down

0 comments on commit 0733bb6

Please sign in to comment.