repo: ngircd
action: commit
revision: 
path_from: 
revision_from: cf4ad8d6f7f9adffda596d67551811ac26f6a35a:
path_to: 
revision_to: 
git.thebackupbox.net
ngircd
git clone git://git.thebackupbox.net/ngircd
commit cf4ad8d6f7f9adffda596d67551811ac26f6a35a
Author: Alexander Barton 
Date:   Fri Feb 21 19:19:27 2003 +0000

    - Conn_Close() ignores recursive calls for the same link now.

diff --git a/src/ngircd/conn.c b/src/ngircd/conn.c
index 1819e36f62eb70105ed76a002471dd492769f5db..
index ..37c5c3819a49390a298bfcb80a33b7919595d1f8 100644
--- a/src/ngircd/conn.c
+++ b/src/ngircd/conn.c
@@ -16,7 +16,7 @@

 #include "portab.h"

-static char UNUSED id[] = "$Id: conn.c,v 1.115 2003/01/15 14:28:59 alex Exp $";
+static char UNUSED id[] = "$Id: conn.c,v 1.116 2003/02/21 19:19:27 alex Exp $";

 #include "imp.h"
 #include 
@@ -529,6 +529,17 @@ Conn_Close( CONN_ID Idx, CHAR *LogMsg, CHAR *FwdMsg, BOOLEAN InformClient )
 	assert( Idx > NONE );
 	assert( My_Connections[Idx].sock > NONE );

+	/* Is this link already shutting down? */
+	if( My_Connections[Idx].options & CONN_ISCLOSING )
+	{
+		/* Conn_Close() has been called recursively for this link;
+		 * probabe reason: Try_Write() failed  -- see below. */
+		return;
+	}
+
+	/* Mark link as "closing" */
+	My_Connections[Idx].options |= CONN_ISCLOSING;
+
 	/* Search client, if any */
 	c = Client_GetFromConn( Idx );

@@ -550,7 +561,7 @@ Conn_Close( CONN_ID Idx, CHAR *LogMsg, CHAR *FwdMsg, BOOLEAN InformClient )
 	}

 	/* Try to write out the write buffer */
-	Try_Write( Idx );
+	(VOID)Try_Write( Idx );

 	/* Shut down socket */
 	if( close( My_Connections[Idx].sock ) != 0 )

-----END OF PAGE-----