]> arthur.barton.de Git - ngircd.git/commitdiff
revert to last good revision
authorFlorian Westphal <fw@strlen.de>
Sun, 17 Dec 2006 23:06:29 +0000 (23:06 +0000)
committerFlorian Westphal <fw@strlen.de>
Sun, 17 Dec 2006 23:06:29 +0000 (23:06 +0000)
src/ngircd/conn.c

index f36637b66eb8ddc2ba0d43472b5f611376f6688c..f5799e7f041523cbe6abaeea3b8d3a7db97e6160 100644 (file)
@@ -17,7 +17,7 @@
 #include "portab.h"
 #include "io.h"
 
-static char UNUSED id[] = "$Id: conn.c,v 1.198.2.1 2006/12/17 23:00:47 fw Exp $";
+static char UNUSED id[] = "$Id: conn.c,v 1.198.2.2 2006/12/17 23:06:29 fw Exp $";
 
 #include "imp.h"
 #include <assert.h>
@@ -998,18 +998,23 @@ New_Connection( int Sock )
        c = Client_NewLocal( new_sock, inet_ntoa( new_addr.sin_addr ), CLIENT_UNKNOWN, false );
        if( ! c ) {
                Log( LOG_ALERT, "Can't accept connection: can't create client structure!" );
-               goto out;
+               Simple_Message( new_sock, "ERROR :Internal error" );
+               close( new_sock );
+               return -1;
        }
 
-       /* register callback */
-       if (!io_event_create( new_sock, IO_WANTREAD, cb_clientserver))
-               goto out;
-
        Init_Conn_Struct( new_sock );
        My_Connections[new_sock].sock = new_sock;
        My_Connections[new_sock].addr = new_addr;
        My_Connections[new_sock].client = c;
 
+       /* register callback */
+       if (!io_event_create( new_sock, IO_WANTREAD, cb_clientserver)) {
+               Simple_Message( new_sock, "ERROR :Internal error" );
+               Conn_Close( new_sock, "io_event_create() failed", NULL, false );
+               return -1;
+       }
+
        Log( LOG_INFO, "Accepted connection %d from %s:%d on socket %d.", new_sock,
                        inet_ntoa( new_addr.sin_addr ), ntohs( new_addr.sin_port), Sock );
 
@@ -1025,11 +1030,7 @@ New_Connection( int Sock )
        /* Penalty-Zeit setzen */
        Conn_SetPenalty( new_sock, 4 );
        return new_sock;
- out:
-       Simple_Message( new_sock, "ERROR :Internal error" );
-       close( new_sock );
-       return -1;
-}/* New_Connection */
+} /* New_Connection */
 
 
 static CONN_ID