* Naehere Informationen entnehmen Sie bitter der Datei COPYING. Eine Liste
* der an comBase beteiligten Autoren finden Sie in der Datei AUTHORS.
*
- * $Id: parse.c,v 1.4 2001/12/25 22:04:26 alex Exp $
+ * $Id: parse.c,v 1.8 2001/12/29 03:08:19 alex Exp $
*
* parse.c: Parsen der Client-Anfragen
*
* $Log: parse.c,v $
+ * Revision 1.8 2001/12/29 03:08:19 alex
+ * - Fuehrende und folgende Leerzeichen etc. in Requests werden geloescht.
+ * - Logmeldungen (mal wieder) ein wenig angepasst.
+ *
+ * Revision 1.7 2001/12/27 19:13:21 alex
+ * - neue Befehle NOTICE und PRIVMSG.
+ * - Debug-Logging ein wenig reduziert.
+ *
+ * Revision 1.6 2001/12/26 14:45:37 alex
+ * - "Code Cleanups".
+ *
+ * Revision 1.5 2001/12/26 03:23:03 alex
+ * - PING/PONG-Befehle implementiert.
+ *
* Revision 1.4 2001/12/25 22:04:26 alex
* - Aenderungen an den Debug- und Logging-Funktionen.
*
#include "irc.h"
#include "log.h"
#include "messages.h"
+#include "tool.h"
#include <exp.h>
#include "parse.h"
Init_Request( &req );
+ /* Fuehrendes und folgendes "Geraffel" verwerfen */
+ ngt_TrimStr( Request );
+
/* gibt es ein Prefix? */
if( Request[0] == ':' )
{
assert( Req != NULL );
assert( Req->command != NULL );
-#ifdef SNIFFER
- Log( LOG_DEBUG, " connection %d: '%s', %d %s,%s prefix.", Idx, Req->command, Req->argc, Req->argc == 1 ? "parameter" : "parameters", Req->prefix ? "" : " no" );
-#endif
-
client = Client_GetFromConn( Idx );
assert( client != NULL );
else if( strcasecmp( Req->command, "NICK" ) == 0 ) return IRC_NICK( client, Req );
else if( strcasecmp( Req->command, "USER" ) == 0 ) return IRC_USER( client, Req );
else if( strcasecmp( Req->command, "QUIT" ) == 0 ) return IRC_QUIT( client, Req );
+ else if( strcasecmp( Req->command, "PING" ) == 0 ) return IRC_PING( client, Req );
+ else if( strcasecmp( Req->command, "PONG" ) == 0 ) return IRC_PONG( client, Req );
else if( strcasecmp( Req->command, "MOTD" ) == 0 ) return IRC_MOTD( client, Req );
-
+ else if( strcasecmp( Req->command, "PRIVMSG" ) == 0 ) return IRC_PRIVMSG( client, Req );
+ else if( strcasecmp( Req->command, "NOTICE" ) == 0 ) return IRC_NOTICE( client, Req );
+ else if( strcasecmp( Req->command, "MODE" ) == 0 ) return IRC_MODE( client, Req );
+
/* Unbekannter Befehl */
- Conn_WriteStr( Idx, ERR_UNKNOWNCOMMAND_MSG, Req->command );
+ IRC_WriteStrClient( client, This_Server, ERR_UNKNOWNCOMMAND_MSG, Client_Name( client ), Req->command );
+ Log( LOG_DEBUG, "User \"%s!%s@%s\": Unknown command \"%s\", %d %s,%s prefix.", client->nick, client->user, client->host, Req->command, Req->argc, Req->argc == 1 ? "parameter" : "parameters", Req->prefix ? "" : " no" );
- Log( LOG_DEBUG, "Connection %d: Unknown command '%s', %d %s,%s prefix.", Idx, Req->command, Req->argc, Req->argc == 1 ? "parameter" : "parameters", Req->prefix ? "" : " no" );
-
return TRUE;
} /* Handle_Request */