diff options
| -rw-r--r-- | protocols/msn/msn.h | 1 | ||||
| -rw-r--r-- | protocols/msn/msn_util.c | 51 | 
2 files changed, 10 insertions, 42 deletions
| diff --git a/protocols/msn/msn.h b/protocols/msn/msn.h index 2669a736..4052f7ef 100644 --- a/protocols/msn/msn.h +++ b/protocols/msn/msn.h @@ -247,7 +247,6 @@ int msn_buddy_list_add(struct im_connection *ic, msn_buddy_flags_t list, const c                         const char *group);  int msn_buddy_list_remove(struct im_connection *ic, msn_buddy_flags_t list, const char *who, const char *group);  void msn_buddy_ask(bee_user_t *bu); -char **msn_linesplit(char *line);  int msn_handler(struct msn_data *h);  char *msn_p11_challenge(char *challenge);  gint msn_domaintree_cmp(gconstpointer a_, gconstpointer b_); diff --git a/protocols/msn/msn_util.c b/protocols/msn/msn_util.c index 8318a458..4d9c85f2 100644 --- a/protocols/msn/msn_util.c +++ b/protocols/msn/msn_util.c @@ -171,39 +171,6 @@ void msn_buddy_ask(bee_user_t *bu)  	imcb_ask_with_free(bu->ic, buf, bla, msn_buddy_ask_yes, msn_buddy_ask_no, msn_buddy_ask_free);  } -/* *NOT* thread-safe, but that's not a problem for now... */ -char **msn_linesplit(char *line) -{ -	static char **ret = NULL; -	static int size = 3; -	int i, n = 0; - -	if (ret == NULL) { -		ret = g_new0(char*, size); -	} - -	for (i = 0; line[i] && line[i] == ' '; i++) { -		; -	} -	if (line[i]) { -		ret[n++] = line + i; -		for (i++; line[i]; i++) { -			if (line[i] == ' ') { -				line[i] = 0; -			} else if (line[i] != ' ' && !line[i - 1]) { -				ret[n++] = line + i; -			} - -			if (n >= size) { -				ret = g_renew(char*, ret, size += 2); -			} -		} -	} -	ret[n] = NULL; - -	return(ret); -} -  /* This one handles input from a MSN Messenger server. Both the NS and SB servers usually give     commands, but sometimes they give additional data (payload). This function tries to handle     this all in a nice way and send all data to the right places. */ @@ -242,11 +209,12 @@ int msn_handler(struct msn_data *h)  					int count;  					cmd_text = g_strndup(h->rxq, i); -					cmd = msn_linesplit(cmd_text); -					for (count = 0; cmd[count]; count++) { -						; -					} +					cmd = g_strsplit_set(cmd_text, " ", -1); +					count = g_strv_length(cmd); +  					st = msn_ns_command(h, cmd, count); + +					g_strfreev(cmd);  					g_free(cmd_text);  					/* If the connection broke, don't continue. We don't even exist anymore. */ @@ -282,12 +250,13 @@ int msn_handler(struct msn_data *h)  			}  			msg = g_strndup(h->rxq, h->msglen); -			cmd = msn_linesplit(h->cmd_text); -			for (count = 0; cmd[count]; count++) { -				; -			} + +			cmd = g_strsplit_set(h->cmd_text, " ", -1); +			count = g_strv_length(cmd);  			st = msn_ns_message(h, msg, h->msglen, cmd, count); + +			g_strfreev(cmd);  			g_free(msg);  			g_free(h->cmd_text);  			h->cmd_text = NULL; | 
