X-Git-Url: http://git.tdb.fi/?p=libs%2Fnet.git;a=blobdiff_plain;f=source%2Fstreamsocket.cpp;h=c6cd214e18dc08dc1620cd190f27287dd8c6ce11;hp=59590846f16d0661917b4134b4b6aaa9ef919abb;hb=4b408e693bcb004ccaa6958610e946cfbeff9465;hpb=5cf15ce8f6b17a47f662eb8f60de619fd6bf7b53 diff --git a/source/streamsocket.cpp b/source/streamsocket.cpp index 5959084..c6cd214 100644 --- a/source/streamsocket.cpp +++ b/source/streamsocket.cpp @@ -3,19 +3,21 @@ #endif #include #include +#include #include #include +#include "socket_private.h" #include "streamsocket.h" namespace Msp { namespace Net { -StreamSocket::StreamSocket(SocketHandle h, const SockAddr &paddr): - Socket(h, paddr), +StreamSocket::StreamSocket(const Private &p, const SockAddr &paddr): + Socket(p, paddr), connecting(false) { #ifdef WIN32 - WSAEventSelect(handle, event, FD_READ|FD_CLOSE); + WSAEventSelect(priv->handle, *priv->event, FD_READ|FD_CLOSE); #endif set_events(IO::P_INPUT); } @@ -56,7 +58,7 @@ int StreamSocket::poll_connect(const Time::TimeDelta &timeout) } #ifdef WIN32 - WSAEventSelect(handle, event, FD_READ|FD_CLOSE); + WSAEventSelect(priv->handle, *priv->event, FD_READ|FD_CLOSE); #endif set_events(IO::P_INPUT); @@ -77,21 +79,21 @@ int StreamSocket::connect(const SockAddr &addr) socklen_t size = addr.fill_sockaddr(sa); #ifdef WIN32 - int err = WSAConnect(handle, reinterpret_cast(&sa), size, 0, 0, 0, 0); + int err = WSAConnect(priv->handle, reinterpret_cast(&sa), size, 0, 0, 0, 0); if(err==SOCKET_ERROR) { int err_code = WSAGetLastError(); if(err_code==WSAEWOULDBLOCK) { connecting = true; - WSAEventSelect(handle, event, FD_CONNECT); + WSAEventSelect(priv->handle, *priv->event, FD_CONNECT); set_events(IO::P_OUTPUT); } else throw system_error("connect", err_code); } #else - int err = ::connect(handle, reinterpret_cast(&sa), size); + int err = ::connect(priv->handle, reinterpret_cast(&sa), size); if(err==-1) { if(errno==EINPROGRESS) @@ -109,7 +111,7 @@ int StreamSocket::connect(const SockAddr &addr) delete local_addr; size = sizeof(sockaddr_storage); - getsockname(handle, reinterpret_cast(&sa), &size); + getsockname(priv->handle, reinterpret_cast(&sa), &size); local_addr = SockAddr::create(sa); if(err==0) @@ -141,7 +143,7 @@ void StreamSocket::on_event(IO::PollEvent ev) } #ifdef WIN32 - WSAEventSelect(handle, event, FD_READ|FD_CLOSE); + WSAEventSelect(priv->handle, *priv->event, FD_READ|FD_CLOSE); #endif set_events((err==0) ? IO::P_INPUT : IO::P_NONE); }