]> git.tdb.fi Git - libs/net.git/blobdiff - source/datagramsocket.cpp
Fix a comparison operator on win32
[libs/net.git] / source / datagramsocket.cpp
index 1394ffa59db669965f94564a777385ac85e91ce6..7944532aa673a4e09ae0ae619bc98e719e381e62 100644 (file)
@@ -14,7 +14,12 @@ namespace Net {
 
 DatagramSocket::DatagramSocket(Family f, int p):
        Socket(f, SOCK_DGRAM, p)
-{ }
+{
+#ifdef WIN32
+       WSAEventSelect(handle, event, FD_READ|FD_CLOSE);
+#endif
+       set_events(IO::P_INPUT);
+}
 
 int DatagramSocket::connect(const SockAddr &addr)
 {
@@ -25,7 +30,7 @@ int DatagramSocket::connect(const SockAddr &addr)
 
        int err=::connect(handle, &sa, size);
        if(err==-1)
-               throw Exception(format("Unable to connect: %s", strerror(errno)));
+               throw SystemError("Unable to connect", errno);
 
        delete peer_addr;
        peer_addr=addr.copy();
@@ -56,7 +61,7 @@ unsigned DatagramSocket::sendto(const char *buf, unsigned size, const SockAddr &
                if(errno==EAGAIN)
                        return 0;
                else
-                       throw Exception(format("Sendto failed: %s", strerror(errno)));
+                       throw SystemError("Sendto failed", errno);
        }
 
        return ret;
@@ -78,7 +83,7 @@ unsigned DatagramSocket::recvfrom(char *buf, unsigned size, SockAddr *&addr_)
                if(errno==EAGAIN)
                        return 0;
                else
-                       throw Exception(format("Recvfrom failed: %s", strerror(errno)));
+                       throw SystemError("Recvfrom failed", errno);
        }
 
        addr_=SockAddr::create(addr);
@@ -86,10 +91,5 @@ unsigned DatagramSocket::recvfrom(char *buf, unsigned size, SockAddr *&addr_)
        return ret;
 }
 
-IO::PollEvent DatagramSocket::get_initial_events() const
-{
-       return IO::P_INPUT;
-}
-
 } // namespace Net
 } // namespace Msp