From: Julian Smart <julian@anthemion.co.uk>
Date: Sun, 11 Jan 2004 16:54:39 +0000 (+0000)
Subject: Applied patch [ 849212 ] Sets SO_REUSEADDR flag on server sockets
X-Git-Url: https://git.saurik.com/wxWidgets.git/commitdiff_plain/e8b7a986a6e8257dbcf2c04183ec2924e7906fd4

Applied patch [ 849212 ] Sets SO_REUSEADDR flag on server sockets


git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@25128 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
---

diff --git a/src/msw/gsocket.c b/src/msw/gsocket.c
index b4156f5afe..9eb8d69513 100644
--- a/src/msw/gsocket.c
+++ b/src/msw/gsocket.c
@@ -376,6 +376,11 @@ GSocketError GSocket_SetServer(GSocket *sck)
   ioctlsocket(sck->m_fd, FIONBIO, (u_long FAR *) &arg);
   _GSocket_Enable_Events(sck);
 
+  /* allow a socket to re-bind if the socket is in the TIME_WAIT
+     state after being previously closed.
+   */
+  setsockopt(sck->m_fd, SOL_SOCKET, SO_REUSEADDR, (const char*)&arg, sizeof(u_long));
+
   /* Bind to the local address,
    * retrieve the actual address bound,
    * and listen up to 5 connections.
diff --git a/src/unix/gsocket.c b/src/unix/gsocket.c
index c7b0d7cf49..396a93641d 100644
--- a/src/unix/gsocket.c
+++ b/src/unix/gsocket.c
@@ -488,6 +488,11 @@ GSocketError GSocket_SetServer(GSocket *sck)
 #endif
   _GSocket_Enable_Events(sck);
 
+  /* allow a socket to re-bind if the socket is in the TIME_WAIT
+     state after being previously closed.
+   */
+  setsockopt(sck->m_fd, SOL_SOCKET, SO_REUSEADDR, (const char*)&arg, sizeof(u_long));
+
   /* Bind to the local address,
    * retrieve the actual address bound,
    * and listen up to 5 connections.