Skip to content

Commit

Permalink
Changed code so that the proper error code is always returned even in…
Browse files Browse the repository at this point in the history
… the event

that closesocket() fails.
  • Loading branch information
davisking committed May 21, 2014
1 parent 7e09a08 commit c6eaca5
Showing 1 changed file with 15 additions and 9 deletions.
24 changes: 15 additions & 9 deletions dlib/sockets/sockets_kernel_1.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -205,7 +205,7 @@ namespace dlib
hostent* address;
unsigned long ipnum = inet_addr(ip.c_str());

// if inet_addr coudln't convert ip then return an error
// if inet_addr couldn't convert ip then return an error
if (ipnum == INADDR_NONE)
{
return OTHER_ERROR;
Expand Down Expand Up @@ -693,7 +693,7 @@ namespace dlib
{
// if there is a specific ip to listen on
sa.sin_addr.S_un.S_addr = inet_addr(ip.c_str());
// if inet_addr cound't convert the ip then return an error
// if inet_addr couldn't convert the ip then return an error
if ( sa.sin_addr.S_un.S_addr == INADDR_NONE )
{
closesocket(sock);
Expand All @@ -707,11 +707,13 @@ namespace dlib

// bind the new socket to the requested port and ip
if (bind(sock,reinterpret_cast<sockaddr*>(&sa),sizeof(sockaddr_in))==SOCKET_ERROR)
{ // if there was an error
{
const int err = WSAGetLastError();
// if there was an error
closesocket(sock);

// if the port is already bound then return PORTINUSE
if (WSAGetLastError() == WSAEADDRINUSE)
if (err == WSAEADDRINUSE)
return PORTINUSE;
else
return OTHER_ERROR;
Expand All @@ -721,11 +723,12 @@ namespace dlib
// tell the new socket to listen
if ( listen(sock,SOMAXCONN) == SOCKET_ERROR)
{
const int err = WSAGetLastError();
// if there was an error return OTHER_ERROR
closesocket(sock);

// if the port is already bound then return PORTINUSE
if (WSAGetLastError() == WSAEADDRINUSE)
if (err == WSAEADDRINUSE)
return PORTINUSE;
else
return OTHER_ERROR;
Expand Down Expand Up @@ -810,7 +813,7 @@ namespace dlib
foreign_sa.sin_port = htons(foreign_port);
foreign_sa.sin_addr.S_un.S_addr = inet_addr(foreign_ip.c_str());

// if inet_addr cound't convert the ip then return an error
// if inet_addr couldn't convert the ip then return an error
if ( foreign_sa.sin_addr.S_un.S_addr == INADDR_NONE )
{
closesocket(sock);
Expand Down Expand Up @@ -852,11 +855,13 @@ namespace dlib
sizeof(sockaddr_in)
) == SOCKET_ERROR
)
{ // if there was an error
{
const int err = WSAGetLastError();
// if there was an error
closesocket(sock);

// if the port is already bound then return PORTINUSE
if (WSAGetLastError() == WSAEADDRINUSE)
if (err == WSAEADDRINUSE)
return PORTINUSE;
else
return OTHER_ERROR;
Expand All @@ -870,9 +875,10 @@ namespace dlib
) == SOCKET_ERROR
)
{
const int err = WSAGetLastError();
closesocket(sock);
// if the port is already bound then return PORTINUSE
if (WSAGetLastError() == WSAEADDRINUSE)
if (err == WSAEADDRINUSE)
return PORTINUSE;
else
return OTHER_ERROR;
Expand Down

0 comments on commit c6eaca5

Please sign in to comment.