X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fnet%2Finet.cpp;h=dbbd12d7e5e7e65cb5292a1c5b04592b29cf4c4f;hb=ede42d5bb352841e2e425972e12b8ef31ddf2123;hp=29e24aa7836d6843652da740fb47de576e8db387;hpb=50e9f9ea7f7385a2c5931fca2b8fb1103078e67c;p=libs%2Fnet.git diff --git a/source/net/inet.cpp b/source/net/inet.cpp index 29e24aa..dbbd12d 100644 --- a/source/net/inet.cpp +++ b/source/net/inet.cpp @@ -1,8 +1,4 @@ -#ifdef WIN32 -#include -#else -#include -#endif +#include "platform_api.h" #include #include "inet.h" #include "sockaddr_private.h" @@ -12,19 +8,11 @@ using namespace std; namespace Msp { namespace Net { -InetAddr::InetAddr(): - port(0) -{ - fill(addr, addr+4, 0); -} - InetAddr::InetAddr(const SysAddr &sa) { const sockaddr_in &sai = reinterpret_cast(sa.addr); - addr[0] = sai.sin_addr.s_addr>>24; - addr[1] = sai.sin_addr.s_addr>>16; - addr[2] = sai.sin_addr.s_addr>>8; - addr[3] = sai.sin_addr.s_addr; + const char *ptr = reinterpret_cast(&sai.sin_addr.s_addr); + std::copy(ptr, ptr+4, addr); port = ntohs(sai.sin_port); } @@ -34,7 +22,8 @@ SockAddr::SysAddr InetAddr::to_sys() const sa.size = sizeof(sockaddr_in); sockaddr_in &sai = reinterpret_cast(sa.addr); sai.sin_family = AF_INET; - sai.sin_addr.s_addr = (addr[0]<<24) | (addr[1]<<16) | (addr[2]<<8) | (addr[3]); + char *ptr = reinterpret_cast(&sai.sin_addr.s_addr); + std::copy(addr, addr+4, ptr); sai.sin_port = htons(port); return sa;