--- ray/src/common/words.c 1991/07/22 14:34:27 1.1 +++ ray/src/common/words.c 1999/01/29 11:18:23 2.4 @@ -1,4 +1,4 @@ -/* Copyright (c) 1991 Regents of the University of California */ +/* Copyright (c) 1996 Regents of the University of California */ #ifndef lint static char SCCSid[] = "$SunId$ LBL"; @@ -20,11 +20,55 @@ extern char *strchr(); char * -sskip(s) /* skip word in string */ +atos(rs, nb, s) /* get word from string, returning rs */ +char *rs; +register int nb; register char *s; { + register char *cp = rs; + while (isspace(*s)) s++; + while (--nb > 0 && *s && !isspace(*s)) + *cp++ = *s++; + *cp = '\0'; + return(rs); +} + + +char * +nextword(cp, nb, s) /* get (quoted) word, returning new s */ +register char *cp; +register int nb; +register char *s; +{ + int quote = 0; + + if (s == NULL) return(NULL); + while (isspace(*s)) + s++; + switch (*s) { + case '\0': + return(NULL); + case '"': + case '\'': + quote = *s++; + } + while (--nb > 0 && *s && (quote ? *s!=quote : !isspace(*s))) + *cp++ = *s++; + *cp = '\0'; + if (quote && *s==quote) + s++; + return(s); +} + + +char * +sskip(s) /* skip word in string, leaving on space */ +register char *s; +{ + while (isspace(*s)) + s++; while (*s && !isspace(*s)) s++; return(s); @@ -32,38 +76,59 @@ register char *s; char * -iskip(s) /* skip integer in string */ -char *s; +sskip2(s, n) /* skip word(s) in string, leaving on word */ +register char *s; +register int n; { - register char *cp = s; + while (isspace(*s)) + s++; + while (n-- > 0) { + while (*s && !isspace(*s)) + s++; + while (isspace(*s)) + s++; + } + return(s); +} - while (isspace(*cp)) - cp++; - if (*cp == '-' || *cp == '+') - cp++; - while (isdigit(*cp)) - cp++; - return(cp); + +char * +iskip(s) /* skip integer in string */ +register char *s; +{ + while (isspace(*s)) + s++; + if (*s == '-' || *s == '+') + s++; + if (!isdigit(*s)) + return(NULL); + do + s++; + while (isdigit(*s)); + return(s); } char * fskip(s) /* skip float in string */ -char *s; +register char *s; { - register char *cp = s; + register char *cp; - while (isspace(*cp)) - cp++; - if (*cp == '-' || *cp == '+') - cp++; + while (isspace(*s)) + s++; + if (*s == '-' || *s == '+') + s++; + cp = s; while (isdigit(*cp)) cp++; if (*cp == '.') { - cp++; + cp++; s++; while (isdigit(*cp)) cp++; } + if (cp == s) + return(NULL); if (*cp == 'e' || *cp == 'E') return(iskip(cp+1)); return(cp); @@ -76,7 +141,7 @@ char *s; register char *cp; cp = iskip(s); - return(cp > s && *cp == '\0'); + return(cp != NULL && *cp == '\0'); } @@ -86,7 +151,7 @@ char *s, *ds; register char *cp; cp = iskip(s); - return(cp > s && strchr(*cp, ds) != NULL); + return(cp != NULL && strchr(ds, *cp) != NULL); } @@ -96,7 +161,7 @@ char *s; register char *cp; cp = fskip(s); - return(cp > s && *cp == '\0'); + return(cp != NULL && *cp == '\0'); } @@ -106,5 +171,5 @@ char *s, *ds; register char *cp; cp = fskip(s); - return(cp > s && strchr(*cp, ds) != NULL); + return(cp != NULL && strchr(ds, *cp) != NULL); }