strtok.c revision 1.9
11.9Slukem/* $NetBSD: strtok.c,v 1.9 1999/09/16 11:45:43 lukem Exp $ */ 21.5Schristos 31.1Scgd/* 41.6Sperry * Copyright (c) 1988, 1993 51.6Sperry * The Regents of the University of California. All rights reserved. 61.1Scgd * 71.1Scgd * Redistribution and use in source and binary forms, with or without 81.1Scgd * modification, are permitted provided that the following conditions 91.1Scgd * are met: 101.1Scgd * 1. Redistributions of source code must retain the above copyright 111.1Scgd * notice, this list of conditions and the following disclaimer. 121.1Scgd * 2. Redistributions in binary form must reproduce the above copyright 131.1Scgd * notice, this list of conditions and the following disclaimer in the 141.1Scgd * documentation and/or other materials provided with the distribution. 151.1Scgd * 3. All advertising materials mentioning features or use of this software 161.1Scgd * must display the following acknowledgement: 171.1Scgd * This product includes software developed by the University of 181.1Scgd * California, Berkeley and its contributors. 191.1Scgd * 4. Neither the name of the University nor the names of its contributors 201.1Scgd * may be used to endorse or promote products derived from this software 211.1Scgd * without specific prior written permission. 221.1Scgd * 231.1Scgd * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 241.1Scgd * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 251.1Scgd * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 261.1Scgd * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 271.1Scgd * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 281.1Scgd * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 291.1Scgd * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 301.1Scgd * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 311.1Scgd * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 321.1Scgd * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 331.1Scgd * SUCH DAMAGE. 341.1Scgd */ 351.1Scgd 361.5Schristos#include <sys/cdefs.h> 371.1Scgd#if defined(LIBC_SCCS) && !defined(lint) 381.5Schristos#if 0 391.6Sperrystatic char sccsid[] = "@(#)strtok.c 8.1 (Berkeley) 6/4/93"; 401.5Schristos#else 411.9Slukem__RCSID("$NetBSD: strtok.c,v 1.9 1999/09/16 11:45:43 lukem Exp $"); 421.5Schristos#endif 431.1Scgd#endif /* LIBC_SCCS and not lint */ 441.1Scgd 451.9Slukem#include <assert.h> 461.1Scgd#include <string.h> 471.1Scgd 481.1Scgdchar * 491.1Scgdstrtok(s, delim) 501.7Sperry char *s; 511.7Sperry const char *delim; 521.1Scgd{ 531.8Schristos const char *spanp; 541.7Sperry int c, sc; 551.1Scgd char *tok; 561.1Scgd static char *last; 571.1Scgd 581.9Slukem /* s may be NULL */ 591.9Slukem _DIAGASSERT(delim != NULL); 601.9Slukem#ifdef _DIAGNOSTIC 611.9Slukem if (delim == NULL) 621.9Slukem return (NULL); 631.9Slukem#endif 641.1Scgd 651.1Scgd if (s == NULL && (s = last) == NULL) 661.1Scgd return (NULL); 671.1Scgd 681.1Scgd /* 691.1Scgd * Skip (span) leading delimiters (s += strspn(s, delim), sort of). 701.1Scgd */ 711.1Scgdcont: 721.1Scgd c = *s++; 731.8Schristos for (spanp = delim; (sc = *spanp++) != 0;) { 741.1Scgd if (c == sc) 751.1Scgd goto cont; 761.1Scgd } 771.1Scgd 781.1Scgd if (c == 0) { /* no non-delimiter characters */ 791.1Scgd last = NULL; 801.1Scgd return (NULL); 811.1Scgd } 821.1Scgd tok = s - 1; 831.1Scgd 841.1Scgd /* 851.1Scgd * Scan token (scan for delimiters: s += strcspn(s, delim), sort of). 861.1Scgd * Note that delim must have one NUL; we stop if we see that, too. 871.1Scgd */ 881.1Scgd for (;;) { 891.1Scgd c = *s++; 901.8Schristos spanp = delim; 911.1Scgd do { 921.1Scgd if ((sc = *spanp++) == c) { 931.1Scgd if (c == 0) 941.1Scgd s = NULL; 951.1Scgd else 961.1Scgd s[-1] = 0; 971.1Scgd last = s; 981.1Scgd return (tok); 991.1Scgd } 1001.1Scgd } while (sc != 0); 1011.1Scgd } 1021.1Scgd /* NOTREACHED */ 1031.1Scgd} 104