X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fstreamsocket.cpp;h=0322f12f1c286b63977435e7bb64b151daf0af68;hb=a4f75be32827b00d9de9d8a68855fec2f5157a10;hp=30c7efd77a35d2b257785e7af1ddb6b80f0156cd;hpb=3103b110c863c19a56cc176a173cc30ddf13afec;p=libs%2Fnet.git diff --git a/source/streamsocket.cpp b/source/streamsocket.cpp index 30c7efd..0322f12 100644 --- a/source/streamsocket.cpp +++ b/source/streamsocket.cpp @@ -1,7 +1,7 @@ /* $Id$ This file is part of libmspnet -Copyright © 2008 Mikkosoft Productions, Mikko Rasa +Copyright © 2008-2009, 2011 Mikkosoft Productions, Mikko Rasa Distributed under the LGPL */ @@ -102,12 +102,12 @@ int StreamSocket::connect(const SockAddr &addr) if(connected) throw InvalidState("Socket is already connected"); - sockaddr sa; + sockaddr_storage sa; socklen_t size=addr.fill_sockaddr(sa); #ifdef WIN32 - int err=WSAConnect(handle, &sa, size, 0, 0, 0, 0); - if(err=SOCKET_ERROR) + int err=WSAConnect(handle, reinterpret_cast(&sa), size, 0, 0, 0, 0); + if(err==SOCKET_ERROR) { int err_code=WSAGetLastError(); if(err_code==WSAEWOULDBLOCK) @@ -120,7 +120,7 @@ int StreamSocket::connect(const SockAddr &addr) throw Exception(format("Unable to connect: %d", err_code)); } #else - int err=::connect(handle, &sa, size); + int err=::connect(handle, reinterpret_cast(&sa), size); if(err==-1) { if(errno==EINPROGRESS) @@ -137,13 +137,14 @@ int StreamSocket::connect(const SockAddr &addr) peer_addr=addr.copy(); delete local_addr; - size=sizeof(sockaddr); - getsockname(handle, &sa, &size); + size=sizeof(sockaddr_storage); + getsockname(handle, reinterpret_cast(&sa), &size); local_addr=SockAddr::create(sa); if(err==0) { connected=true; + set_events(IO::P_INPUT); signal_connect_finished.emit(0); }