]> git.tdb.fi Git - libs/net.git/commitdiff
Fix storage order of InetAddr::addr
authorMikko Rasa <tdb@tdb.fi>
Wed, 10 Aug 2011 19:30:29 +0000 (22:30 +0300)
committerMikko Rasa <tdb@tdb.fi>
Wed, 10 Aug 2011 19:30:29 +0000 (22:30 +0300)
source/net/inet.cpp

index 29e24aa7836d6843652da740fb47de576e8db387..c78ea6165cd9d4e77d535172b1d2e4b6cb0a10de 100644 (file)
@@ -21,10 +21,8 @@ InetAddr::InetAddr():
 InetAddr::InetAddr(const SysAddr &sa)
 {
        const sockaddr_in &sai = reinterpret_cast<const sockaddr_in &>(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<const char *>(&sai.sin_addr.s_addr);
+       std::copy(ptr, ptr+4, addr);
        port = ntohs(sai.sin_port);
 }
 
@@ -34,7 +32,8 @@ SockAddr::SysAddr InetAddr::to_sys() const
        sa.size = sizeof(sockaddr_in);
        sockaddr_in &sai = reinterpret_cast<sockaddr_in &>(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<char *>(&sai.sin_addr.s_addr);
+       std::copy(addr, addr+4, ptr);
        sai.sin_port = htons(port);
 
        return sa;