X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fsockaddr.cpp;h=9b41f81b948492dc077920dbe83ea06a80ea8a67;hb=21c596567e3b6fd794ed6af73d304ce2bc70e58f;hp=26c77b643df8b4ae9b8180ddd1c38145f71dcc65;hpb=1b2aabf076169e6d2049227188e464e95ac40514;p=libs%2Fnet.git diff --git a/source/sockaddr.cpp b/source/sockaddr.cpp index 26c77b6..9b41f81 100644 --- a/source/sockaddr.cpp +++ b/source/sockaddr.cpp @@ -1,34 +1,31 @@ -/* $Id$ - -This file is part of libmspnet -Copyright © 2008, 2011 Mikkosoft Productions, Mikko Rasa -Distributed under the LGPL -*/ - -#include +#include #include "inet.h" #include "inet6.h" +#include "sockaddr_private.h" + +using namespace std; namespace Msp { namespace Net { -unsigned SockAddr::fill_sockaddr(sockaddr_storage &sa) const +SockAddr *SockAddr::new_from_sys(const SysAddr &sa) { - return fill_sockaddr(reinterpret_cast(sa)); -} - -SockAddr *SockAddr::create(const sockaddr_storage &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"); } } +SockAddr::SysAddr::SysAddr(): + size(sizeof(sockaddr_storage)) +{ + addr.ss_family = AF_UNSPEC; +} + } // namespace Net } // namespace Msp