summary refs log tree commit diff
path: root/src/portab/strtok_r.c
diff options
context:
space:
mode:
authorScott Perry <scperry@ucsd.edu>2008-05-26 12:38:15 +0200
committerFlorian Westphal <fw@strlen.de>2008-05-26 21:20:03 +0200
commitb90f71ca2ab1b2eea7ca992b1e51a4b39afe0728 (patch)
tree836a85f7f9160e69e618aa9cc54f0b2b2cdff245 /src/portab/strtok_r.c
parentd060e90de06e0fb3fc3e557fe97f9d0b0e132a29 (diff)
downloadngircd-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.c27
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
+