X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fsockaddr.cpp;h=9b41f81b948492dc077920dbe83ea06a80ea8a67;hb=21c596567e3b6fd794ed6af73d304ce2bc70e58f;hp=08babb12c5f881c84a59471c06b178e4e2c173a1;hpb=28e7bf7a13656620452e19d017ea5eedf14a8bc5;p=libs%2Fnet.git diff --git a/source/sockaddr.cpp b/source/sockaddr.cpp index 08babb1..9b41f81 100644 --- a/source/sockaddr.cpp +++ b/source/sockaddr.cpp @@ -1,26 +1,30 @@ -#include +#include #include "inet.h" #include "inet6.h" +#include "sockaddr_private.h" + +using namespace std; namespace Msp { namespace Net { -SockAddr *SockAddr::create(const sockaddr_storage &sa) +SockAddr *SockAddr::new_from_sys(const SysAddr &sa) { - switch(sa.ss_family) + switch(sa.addr.ss_family) { case AF_INET: - return new InetAddr(reinterpret_cast(sa)); + return new InetAddr(sa); case AF_INET6: - return new Inet6Addr(reinterpret_cast(sa)); + return new Inet6Addr(sa); default: - throw InvalidParameterValue("Unknown address family"); + throw invalid_argument("SockAddr::create"); } } -unsigned SockAddr::fill_sockaddr(sockaddr_storage &sa) const +SockAddr::SysAddr::SysAddr(): + size(sizeof(sockaddr_storage)) { - return fill_sockaddr(reinterpret_cast(sa)); + addr.ss_family = AF_UNSPEC; } } // namespace Net