X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fdatagramsocket.cpp;h=d24ca4e1ec8ec1c10fcd11c3188da874426b053b;hb=21c596567e3b6fd794ed6af73d304ce2bc70e58f;hp=7aee3f868d455429c575f77f0d93cf817aaa860f;hpb=4b408e693bcb004ccaa6958610e946cfbeff9465;p=libs%2Fnet.git diff --git a/source/datagramsocket.cpp b/source/datagramsocket.cpp index 7aee3f8..d24ca4e 100644 --- a/source/datagramsocket.cpp +++ b/source/datagramsocket.cpp @@ -3,13 +3,14 @@ #include #include #include "datagramsocket.h" +#include "sockaddr_private.h" #include "socket_private.h" namespace Msp { namespace Net { DatagramSocket::DatagramSocket(Family f, int p): - Socket(f, SOCK_DGRAM, p) + ClientSocket(f, SOCK_DGRAM, p) { #ifdef WIN32 WSAEventSelect(priv->handle, *priv->event, FD_READ|FD_CLOSE); @@ -17,12 +18,11 @@ DatagramSocket::DatagramSocket(Family f, int p): set_events(IO::P_INPUT); } -int DatagramSocket::connect(const SockAddr &addr) +bool DatagramSocket::connect(const SockAddr &addr) { - sockaddr_storage sa; - socklen_t size = addr.fill_sockaddr(sa); + SockAddr::SysAddr sa = addr.to_sys(); - int err = ::connect(priv->handle, reinterpret_cast(&sa), size); + int err = ::connect(priv->handle, reinterpret_cast(&sa.addr), sa.size); if(err==-1) { #ifdef WIN32 @@ -36,24 +36,23 @@ int DatagramSocket::connect(const SockAddr &addr) peer_addr = addr.copy(); delete local_addr; - size = sizeof(sockaddr_storage); - getsockname(priv->handle, reinterpret_cast(&sa), &size); - local_addr = SockAddr::create(sa); + SockAddr::SysAddr lsa; + getsockname(priv->handle, reinterpret_cast(&lsa.addr), &lsa.size); + local_addr = SockAddr::new_from_sys(lsa); connected = true; - return (err==0)?0:1; + return true; } -unsigned DatagramSocket::sendto(const char *buf, unsigned size, const SockAddr &addr_) +unsigned DatagramSocket::sendto(const char *buf, unsigned size, const SockAddr &addr) { if(size==0) return 0; - sockaddr_storage addr; - socklen_t addr_len = addr_.fill_sockaddr(addr); + SockAddr::SysAddr sa = addr.to_sys(); - int ret = ::sendto(priv->handle, buf, size, 0, reinterpret_cast(&addr), addr_len); + int ret = ::sendto(priv->handle, buf, size, 0, reinterpret_cast(&sa.addr), sa.size); if(ret<0) { if(errno==EAGAIN) @@ -71,15 +70,13 @@ unsigned DatagramSocket::sendto(const char *buf, unsigned size, const SockAddr & return ret; } -unsigned DatagramSocket::recvfrom(char *buf, unsigned size, SockAddr *&addr_) +unsigned DatagramSocket::recvfrom(char *buf, unsigned size, SockAddr *&from_addr) { if(size==0) return 0; - sockaddr_storage addr; - socklen_t addr_len = sizeof(sockaddr_storage); - - int ret = ::recvfrom(priv->handle, buf, size, 0, reinterpret_cast(&addr), &addr_len); + SockAddr::SysAddr sa; + int ret = ::recvfrom(priv->handle, buf, size, 0, reinterpret_cast(&sa.addr), &sa.size); if(ret<0) { if(errno==EAGAIN) @@ -94,7 +91,7 @@ unsigned DatagramSocket::recvfrom(char *buf, unsigned size, SockAddr *&addr_) } } - addr_ = SockAddr::create(addr); + from_addr = SockAddr::new_from_sys(sa); return ret; }