X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fstreamsocket.cpp;h=7919ec4d01d348c6fa1d6955588d4d84bdd26ac8;hb=446707e0be6f2dfc3c983296b74030b7121a58b8;hp=ed506d6320881c4a4169b54d836da483538510ec;hpb=18fd377f86b47234d1598524092167a5930b3e3b;p=libs%2Fnet.git diff --git a/source/streamsocket.cpp b/source/streamsocket.cpp index ed506d6..7919ec4 100644 --- a/source/streamsocket.cpp +++ b/source/streamsocket.cpp @@ -33,8 +33,8 @@ bool StreamSocket::connect(const SockAddr &addr) SockAddr::SysAddr sa = addr.to_sys(); + int err = ::connect(priv->handle, reinterpret_cast(&sa.addr), sa.size); #ifdef WIN32 - int err = WSAConnect(priv->handle, reinterpret_cast(&sa.addr), sa.size, 0, 0, 0, 0); if(err==SOCKET_ERROR) { int err_code = WSAGetLastError(); @@ -48,7 +48,6 @@ bool StreamSocket::connect(const SockAddr &addr) throw system_error("connect", err_code); } #else - int err = ::connect(priv->handle, reinterpret_cast(&sa.addr), sa.size); if(err==-1) { if(errno==EINPROGRESS) @@ -124,7 +123,13 @@ void StreamSocket::on_event(IO::PollEvent ev) connecting = false; connected = (err==0); - signal_connect_finished.emit(err); + if(err) + { + system_error exc("connect", err); + signal_connect_finished.emit(&exc); + } + else + signal_connect_finished.emit(0); if(err!=0) {