]> git.tdb.fi Git - libs/net.git/blobdiff - source/datagramsocket.cpp
Add an overload for resolve that takes host and service separately
[libs/net.git] / source / datagramsocket.cpp
index 43b86615b2ee2e631cef68be878c69299f73701e..d24ca4e1ec8ec1c10fcd11c3188da874426b053b 100644 (file)
@@ -1,85 +1,97 @@
-#include <errno.h>
-#include <msp/strings/formatter.h>
+#include <cerrno>
+#include <msp/core/systemerror.h>
+#include <msp/io/handle_private.h>
+#include <msp/strings/format.h>
 #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(handle, event, FD_READ|FD_CLOSE);
+       WSAEventSelect(priv->handle, *priv->event, FD_READ|FD_CLOSE);
 #endif
        set_events(IO::P_INPUT);
 }
 
-int DatagramSocket::connect(const SockAddr &addr)
+bool DatagramSocket::connect(const SockAddr &addr)
 {
-       check_state(false);
+       SockAddr::SysAddr sa = addr.to_sys();
 
-       sockaddr_storage sa;
-       socklen_t size=addr.fill_sockaddr(sa);
-
-       int err=::connect(handle, reinterpret_cast<sockaddr *>(&sa), size);
+       int err = ::connect(priv->handle, reinterpret_cast<sockaddr *>(&sa.addr), sa.size);
        if(err==-1)
-               throw SystemError("Unable to connect", errno);
+       {
+#ifdef WIN32
+               throw system_error("connect", WSAGetLastError());
+#else
+               throw system_error("connect");
+#endif
+       }
 
        delete peer_addr;
-       peer_addr=addr.copy();
+       peer_addr = addr.copy();
 
        delete local_addr;
-       size=sizeof(sockaddr_storage);
-       getsockname(handle, reinterpret_cast<sockaddr *>(&sa), &size);
-       local_addr=SockAddr::create(sa);
+       SockAddr::SysAddr lsa;
+       getsockname(priv->handle, reinterpret_cast<sockaddr *>(&lsa.addr), &lsa.size);
+       local_addr = SockAddr::new_from_sys(lsa);
 
-       connected=true;
+       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)
 {
-       check_state(false);
-
        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(handle, buf, size, 0, reinterpret_cast<sockaddr *>(&addr), addr_len);
+       int ret = ::sendto(priv->handle, buf, size, 0, reinterpret_cast<sockaddr *>(&sa.addr), sa.size);
        if(ret<0)
        {
                if(errno==EAGAIN)
                        return 0;
                else
-                       throw SystemError("Sendto failed", errno);
+               {
+#ifdef WIN32
+                       throw system_error("sendto", WSAGetLastError());
+#else
+                       throw system_error("sendto");
+#endif
+               }
        }
 
        return ret;
 }
 
-unsigned DatagramSocket::recvfrom(char *buf, unsigned size, SockAddr *&addr_)
+unsigned DatagramSocket::recvfrom(char *buf, unsigned size, SockAddr *&from_addr)
 {
-       check_state(false);
-
        if(size==0)
                return 0;
 
-       sockaddr_storage addr;
-       socklen_t addr_len=sizeof(sockaddr_storage);
-
-       int ret=::recvfrom(handle, buf, size, 0, reinterpret_cast<sockaddr *>(&addr), &addr_len);
+       SockAddr::SysAddr sa;
+       int ret = ::recvfrom(priv->handle, buf, size, 0, reinterpret_cast<sockaddr *>(&sa.addr), &sa.size);
        if(ret<0)
        {
                if(errno==EAGAIN)
                        return 0;
                else
-                       throw SystemError("Recvfrom failed", errno);
+               {
+#ifdef WIN32
+                       throw system_error("recvfrom", WSAGetLastError());
+#else
+                       throw system_error("recvfrom");
+#endif
+               }
        }
 
-       addr_=SockAddr::create(addr);
+       from_addr = SockAddr::new_from_sys(sa);
 
        return ret;
 }