os161-1.99
 All Data Structures
strtok_r.c
00001 /*
00002  * Copyright (c) 2000, 2001, 2002, 2003, 2004, 2005, 2008, 2009
00003  *      The President and Fellows of Harvard College.
00004  *
00005  * Redistribution and use in source and binary forms, with or without
00006  * modification, are permitted provided that the following conditions
00007  * are met:
00008  * 1. Redistributions of source code must retain the above copyright
00009  *    notice, this list of conditions and the following disclaimer.
00010  * 2. Redistributions in binary form must reproduce the above copyright
00011  *    notice, this list of conditions and the following disclaimer in the
00012  *    documentation and/or other materials provided with the distribution.
00013  * 3. Neither the name of the University nor the names of its contributors
00014  *    may be used to endorse or promote products derived from this software
00015  *    without specific prior written permission.
00016  *
00017  * THIS SOFTWARE IS PROVIDED BY THE UNIVERSITY AND CONTRIBUTORS ``AS IS'' AND
00018  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
00019  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
00020  * ARE DISCLAIMED.  IN NO EVENT SHALL THE UNIVERSITY OR CONTRIBUTORS BE LIABLE
00021  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
00022  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
00023  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
00024  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
00025  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
00026  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
00027  * SUCH DAMAGE.
00028  */
00029 
00030 /*
00031  * This file is shared between libc and the kernel, so don't put anything
00032  * in here that won't work in both contexts.
00033  */
00034 
00035 #ifdef _KERNEL
00036 #include <types.h>
00037 #include <lib.h>
00038 #else
00039 #include <string.h>
00040 #endif
00041 
00042 /*
00043  * Standard C string function: tokenize a string splitting based on a
00044  * list of separator characters. Reentrant version.
00045  *
00046  * The "context" argument should point to a "char *" that is preserved
00047  * between calls to strtok_r that wish to operate on same string.
00048  */
00049 char *
00050 strtok_r(char *string, const char *seps, char **context)
00051 {
00052         char *head;  /* start of word */
00053         char *tail;  /* end of word */
00054 
00055         /* If we're starting up, initialize context */
00056         if (string) {
00057                 *context = string;
00058         }
00059 
00060         /* Get potential start of this next word */
00061         head = *context;
00062         if (head == NULL) {
00063                 return NULL;
00064         }
00065 
00066         /* Skip any leading separators */
00067         while (*head && strchr(seps, *head)) {
00068                 head++;
00069         }
00070 
00071         /* Did we hit the end? */
00072         if (*head == 0) {
00073                 /* Nothing left */
00074                 *context = NULL;
00075                 return NULL;
00076         }
00077 
00078         /* skip over word */
00079         tail = head;
00080         while (*tail && !strchr(seps, *tail)) {
00081                 tail++;
00082         }
00083 
00084         /* Save head for next time in context */
00085         if (*tail == 0) {
00086                 *context = NULL;
00087         }
00088         else {
00089                 *tail = 0;
00090                 tail++;
00091                 *context = tail;
00092         }
00093 
00094         /* Return current word */
00095         return head;
00096 }
 All Data Structures