summaryrefslogtreecommitdiff
path: root/src/map/irc.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/map/irc.c')
-rw-r--r--src/map/irc.c16
1 files changed, 11 insertions, 5 deletions
diff --git a/src/map/irc.c b/src/map/irc.c
index 33e90669f..b3cd74468 100644
--- a/src/map/irc.c
+++ b/src/map/irc.c
@@ -208,9 +208,10 @@ void irc_parse_sub(int fd, char *incoming_string)
sscanf(incoming_string, ":%255s %255s %255s :%4095[^\n]", source, command, target, message);
if (source != NULL) {
if (strstr(source,"!") != NULL) {
- source_nick = strtok_r(source,"!",&state_mgr);
- source_ident = strtok_r(NULL,"@",&state_mgr);
- source_host = strtok_r(NULL,"%%",&state_mgr);
+ sscanf(source,"%s!%s@$s",source_nick, source_ident, source_host);
+ //source_nick = strtok_r(source,"!",&state_mgr);
+ //source_ident = strtok_r(NULL,"@",&state_mgr);
+ //source_host = strtok_r(NULL,"%%",&state_mgr);
}
}
if (irc_si->state == 0){
@@ -249,15 +250,20 @@ void irc_parse_sub(int fd, char *incoming_string)
int send_to_parser(int fd, char *input,char key[2])
{
+ char format[4];
char *temp_string=NULL;
+ char *next_string=NULL;
char *state_mgr=NULL;
int total_loops=0;
- temp_string = strtok_r(input,key,&state_mgr);
+ //temp_string = strtok_r(input,key,&state_mgr);
+ sprintf(format,"%s%s%s","%s",key,"%s");
+ sscanf(input, format, temp_string, next_string);
while (temp_string != NULL){
total_loops = total_loops+1;
irc_parse_sub(fd,temp_string);
- temp_string = strtok_r(NULL,key,&state_mgr);
+ //temp_string = strtok_r(NULL,key,&state_mgr);
+ sscanf(next_string, format, temp_string, next_string);
}
return total_loops;
}