repo: ngircd
action: commit
revision: 
path_from: 
revision_from: d0ac1e9ca9ff0e9f2838e72e94905073e8b7cb9e:
path_to: 
revision_to: 
git.thebackupbox.net
ngircd
git clone git://git.thebackupbox.net/ngircd
commit d0ac1e9ca9ff0e9f2838e72e94905073e8b7cb9e
Author: Alexander Barton 
Date:   Sun Dec 23 22:04:37 2001 +0000

    - einige neue Funktionen,
    - CLIENT-Struktur erweitert.

diff --git a/src/ngircd/client.c b/src/ngircd/client.c
index 531709192dbfe0a1ed1ee1ca5d15afad8e96efef..
index ..950e977c57e2085e6af7d60fee1ac7743cde2ca5 100644
--- a/src/ngircd/client.c
+++ b/src/ngircd/client.c
@@ -9,7 +9,7 @@
  * Naehere Informationen entnehmen Sie bitter der Datei COPYING. Eine Liste
  * der an comBase beteiligten Autoren finden Sie in der Datei AUTHORS.
  *
- * $Id: client.c,v 1.1 2001/12/14 08:13:43 alex Exp $
+ * $Id: client.c,v 1.2 2001/12/23 22:04:37 alex Exp $
  *
  * client.c: Management aller Clients
  *
@@ -21,6 +21,10 @@
  * Server gewesen, so existiert eine entsprechende CONNECTION-Struktur.
  *
  * $Log: client.c,v $
+ * Revision 1.2  2001/12/23 22:04:37  alex
+ * - einige neue Funktionen,
+ * - CLIENT-Struktur erweitert.
+ *
  * Revision 1.1  2001/12/14 08:13:43  alex
  * - neues Modul begonnen :-)
  *
@@ -32,6 +36,8 @@

 #include 
 #include 
+#include 
+#include 

 #include "channel.h"
 #include "conn.h"
@@ -41,7 +47,7 @@
 #include "client.h"


-LOCAL CLIENT *This_Server, *My_Clients;
+LOCAL CLIENT *My_Clients;


 LOCAL CLIENT *New_Client_Struct( VOID );
@@ -61,19 +67,100 @@ GLOBAL VOID Client_Init( VOID )
 	This_Server->type = CLIENT_SERVER;
 	This_Server->conn_id = NONE;
 	This_Server->introducer = This_Server;
-	strcpy( This_Server->nick, "ngircd" );	/* FIXME! */
-	
+	gethostname( This_Server->host, CLIENT_HOST_LEN );
+	strcpy( This_Server->nick, This_Server->host );
+
 	My_Clients = This_Server;
 } /* Client_Init */


 GLOBAL VOID Client_Exit( VOID )
 {
+	CLIENT *c, *next;
+	INT cnt;
+
+	Client_Destroy( This_Server );
+	
+	cnt = 0;
+	c = My_Clients;
+	while( c )
+	{
+		cnt++;
+		next = c->next;
+		free( c );
+		c = next;
+	}
+	if( cnt ) Log( LOG_DEBUG, "Freed %d client structure%s.", cnt, cnt == 1 ? "" : "s" );
 } /* Client Exit */


+GLOBAL CLIENT *Client_New_Local( CONN_ID Idx, CHAR *Hostname )
+{
+	/* Neuen lokalen Client erzeugen. */
+	
+	CLIENT *client;
+
+	client = New_Client_Struct( );
+	if( ! client ) return NULL;
+
+	/* Initgialisieren */
+	client->conn_id = Idx;
+	client->introducer = This_Server;
+	strncpy( client->host, Hostname, CLIENT_HOST_LEN );
+	client->host[CLIENT_HOST_LEN] = '\0';
+
+	/* Verketten */
+	client->next = My_Clients;
+	My_Clients = client;
+	
+	return client;
+} /* Client_New_Local */
+
+
+GLOBAL VOID Client_Destroy( CLIENT *Client )
+{
+	/* Client entfernen. */
+	
+	CLIENT *last, *c;
+
+	last = NULL;
+	c = My_Clients;
+	while( c )
+	{
+		if( c == Client )
+		{
+			if( last ) last->next = c->next;
+			else My_Clients = c->next;
+			free( c );
+			break;
+		}
+		last = c;
+		c = c->next;
+	}
+} /* Client_Destroy */
+
+
+GLOBAL CLIENT *Client_GetFromConn( CONN_ID Idx )
+{
+	/* Client-Struktur, die zur lokalen Verbindung Idx gehoert
+	 * liefern. Wird keine gefunden, so wird NULL geliefert. */
+
+	CLIENT *c;
+
+	c = My_Clients;
+	while( c )
+	{
+		if( c->conn_id == Idx ) return c;
+		c = c->next;
+	}
+	return NULL;
+} /* Client_GetFromConn */
+
+
 LOCAL CLIENT *New_Client_Struct( VOID )
 {
+	/* Neue CLIENT-Struktur pre-initialisieren */
+	
 	CLIENT *c;
 	INT i;

@@ -90,8 +177,11 @@ LOCAL CLIENT *New_Client_Struct( VOID )
 	c->introducer = NULL;
 	strcpy( c->nick, "" );
 	strcpy( c->pass, "" );
+	strcpy( c->host, "" );
+	strcpy( c->user, "" );
+	strcpy( c->name, "" );
 	for( i = 0; i < MAX_CHANNELS; c->channels[i++] = NULL );
-	
+
 	return c;
 } /* New_Client */

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