diff options
author | Manuel Novoa III <mjn3@codepoet.org> | 2001-03-01 19:49:41 +0000 |
---|---|---|
committer | Manuel Novoa III <mjn3@codepoet.org> | 2001-03-01 19:49:41 +0000 |
commit | 9aed53cc26d900ab64f49c38df535cf10518aa51 (patch) | |
tree | 7adebf35513bee04d390a3eb258a64059b22b085 | |
parent | 57e9510d983d40d7ad26cfaa27f7f285d090bf3f (diff) |
Added __strtok_r function. Change strtok to a wrapper around __strtok_r and
add a weak alias of __strtok_r for strtok_r since optional. Also reduced
code size.
-rw-r--r-- | include/string.h | 10 | ||||
-rw-r--r-- | libc/string/strtok.c | 61 | ||||
-rw-r--r-- | libc/string/strtok_r.c | 55 |
3 files changed, 68 insertions, 58 deletions
diff --git a/include/string.h b/include/string.h index 7d284e5d6..58614b291 100644 --- a/include/string.h +++ b/include/string.h @@ -92,6 +92,16 @@ extern char *strstr __P ((__const char *__haystack, __const char *__needle)); /* Divide S into tokens separated by characters in DELIM. */ extern char *strtok __P ((char *__restrict __s, __const char *__restrict __delim)); +/* Divide S into tokens separated by characters in DELIM. Information + passed between calls are stored in SAVE_PTR. */ +extern char *__strtok_r __P ((char *__restrict __s, + __const char *__restrict __delim, + char **__restrict __save_ptr)); +#if defined __USE_POSIX || defined __USE_MISC +extern char *strtok_r __P ((char *__restrict __s, + __const char *__restrict __delim, + char **__restrict __save_ptr)); +#endif /* Return the length of the initial segment of S which consists entirely of characters not in REJECT. */ extern size_t strcspn __P ((__const char *__s, __const char *__reject)); diff --git a/libc/string/strtok.c b/libc/string/strtok.c index 51bc6038a..9dc19a90b 100644 --- a/libc/string/strtok.c +++ b/libc/string/strtok.c @@ -1,63 +1,8 @@ -/* Copyright (C) 1991 Free Software Foundation, Inc. -This file is part of the GNU C Library. - -The GNU C Library is free software; you can redistribute it and/or -modify it under the terms of the GNU Library General Public License as -published by the Free Software Foundation; either version 2 of the -License, or (at your option) any later version. - -The GNU C Library is distributed in the hope that it will be useful, -but WITHOUT ANY WARRANTY; without even the implied warranty of -MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -Library General Public License for more details. - -You should have received a copy of the GNU Library General Public -License along with the GNU C Library; see the file COPYING.LIB. If -not, write to the Free Software Foundation, Inc., 675 Mass Ave, -Cambridge, MA 02139, USA. */ - #include <string.h> +static char *save = 0; -static char *olds = 0; - -/* Parse S into tokens separated by characters in DELIM. - If S is NULL, the last string strtok() was called with is - used. For example: - char s[] = "-abc=-def"; - x = strtok(s, "-"); // x = "abc" - x = strtok(NULL, "=-"); // x = "def" - x = strtok(NULL, "="); // x = NULL - // s = "abc\0-def\0" -*/ -char *strtok( register char *s, register const char *delim) +char *strtok(char *s, const char *delim) { - char *token; - - if (s == 0) { - if (olds == 0) { - return 0; - } else - s = olds; - } - - /* Scan leading delimiters. */ - s += strspn(s, delim); - if (*s == '\0') { - olds = 0; - return 0; - } - - /* Find the end of the token. */ - token = s; - s = strpbrk(token, delim); - if (s == 0) - /* This token finishes the string. */ - olds = 0; - else { - /* Terminate the token and make OLDS point past it. */ - *s = '\0'; - olds = s + 1; - } - return token; + return __strtok_r(s, delim, &save); } diff --git a/libc/string/strtok_r.c b/libc/string/strtok_r.c new file mode 100644 index 000000000..37b313455 --- /dev/null +++ b/libc/string/strtok_r.c @@ -0,0 +1,55 @@ +/* Copyright (C) 1991 Free Software Foundation, Inc. +This file is part of the GNU C Library. + +The GNU C Library is free software; you can redistribute it and/or +modify it under the terms of the GNU Library General Public License as +published by the Free Software Foundation; either version 2 of the +License, or (at your option) any later version. + +The GNU C Library is distributed in the hope that it will be useful, +but WITHOUT ANY WARRANTY; without even the implied warranty of +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +Library General Public License for more details. + +You should have received a copy of the GNU Library General Public +License along with the GNU C Library; see the file COPYING.LIB. If +not, write to the Free Software Foundation, Inc., 675 Mass Ave, +Cambridge, MA 02139, USA. */ + +/* + * Modified by Manuel Novoa III Mar 1, 2001 + * + * Converted original strtok.c code of strtok to __strtok_r. + * Cleaned up logic and reduced code size. + */ + +#include <string.h> + +char *__strtok_r(char *s, const char *delim, char **save_ptr) +{ + char *token; + + token = 0; /* Initialize to no token. */ + + if (s == 0) { /* If not first time called... */ + s = *save_ptr; /* restart from where we left off. */ + } + + if (s != 0) { /* If not finished... */ + *save_ptr = 0; + + s += strspn(s, delim); /* Skip past any leading delimiters. */ + if (*s != '\0') { /* We have a token. */ + token = s; + *save_ptr = strpbrk(token, delim); /* Find token's end. */ + if (*save_ptr != 0) { + /* Terminate the token and make SAVE_PTR point past it. */ + *(*save_ptr)++ = '\0'; + } + } + } + + return token; +} + +__asm__(".weak strtok_r; strtok_r = __strtok_r"); |