diff options
| author | Scott Perry <scperry@ucsd.edu> | 2008-05-26 12:38:15 +0200 |
|---|---|---|
| committer | Florian Westphal <fw@strlen.de> | 2008-05-26 21:20:03 +0200 |
| commit | b90f71ca2ab1b2eea7ca992b1e51a4b39afe0728 (patch) | |
| tree | 836a85f7f9160e69e618aa9cc54f0b2b2cdff245 /src/portab/strtok_r.c | |
| parent | d060e90de06e0fb3fc3e557fe97f9d0b0e132a29 (diff) | |
| download | ngircd-b90f71ca2ab1b2eea7ca992b1e51a4b39afe0728.tar.gz ngircd-b90f71ca2ab1b2eea7ca992b1e51a4b39afe0728.zip | |
Use strtok_r instead of strchr in IRC_JOIN.
This patch does significant cleanup on the join code by using strtok_r instead of mangling strchr to parse channel names and keys in parallel when a JOIN command contains a list of channels and keys. Also adds an strtok_r implementation to libportab.
Diffstat (limited to 'src/portab/strtok_r.c')
| -rw-r--r-- | src/portab/strtok_r.c | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/src/portab/strtok_r.c b/src/portab/strtok_r.c new file mode 100644 index 00000000..852c8f70 --- /dev/null +++ b/src/portab/strtok_r.c @@ -0,0 +1,27 @@ +#include "portab.h" +#include <string.h> + +#ifndef HAVE_STRTOK_R + +char * +strtok_r(char *str, const char *delim, char **saveptr) +{ + char *tmp; + + if (!str) + str = *saveptr; + str += strspn(str, delim); + if (*str == 0) + return NULL; + + tmp = str + strcspn(str, delim); /* get end of token */ + if (*tmp) { /* another delimiter */ + *tmp = 0; + tmp++; + } + *saveptr = tmp; + return str; +} + +#endif + |