]> git.eshelyaron.com Git - emacs.git/commitdiff
(Fmake_network_process): Remove kludge for interrupted
authorKim F. Storm <storm@cua.dk>
Tue, 9 Nov 2004 09:40:37 +0000 (09:40 +0000)
committerKim F. Storm <storm@cua.dk>
Tue, 9 Nov 2004 09:40:37 +0000 (09:40 +0000)
connects on BSD.  If connect is interrupted, just close socket and
start over rather than sleeping and retry with same socket.

src/process.c

index bebcd577e9e165c9ee227bd5a42f14f213c90e03..00bac03dc2bcf4e07bf0b7e655c49ee019bf79ed 100644 (file)
@@ -3023,6 +3023,8 @@ usage: (make-network-process &rest ARGS)  */)
     {
       int optn, optbits;
 
+    retry_connect:
+
       s = socket (lres->ai_family, lres->ai_socktype, lres->ai_protocol);
       if (s < 0)
        {
@@ -3101,8 +3103,6 @@ usage: (make-network-process &rest ARGS)  */)
          break;
        }
 
-    retry_connect:
-
       immediate_quit = 1;
       QUIT;
 
@@ -3144,22 +3144,13 @@ usage: (make-network-process &rest ARGS)  */)
 
       immediate_quit = 0;
 
-      if (xerrno == EINTR)
-       goto retry_connect;
-      if (xerrno == EADDRINUSE && retry < 20)
-       {
-         /* A delay here is needed on some FreeBSD systems,
-            and it is harmless, since this retrying takes time anyway
-            and should be infrequent.  */
-         Fsleep_for (make_number (1), Qnil);
-         retry++;
-         goto retry_connect;
-       }
-
       /* Discard the unwind protect closing S.  */
       specpdl_ptr = specpdl + count1;
       emacs_close (s);
       s = -1;
+
+      if (xerrno == EINTR)
+       goto retry_connect;
     }
 
   if (s >= 0)