| 1 |  | #ifndef lint | 
| 2 | < | static const char       RCSid[] = "$Id$"; | 
| 2 | > | static const char RCSid[] = "$Id$"; | 
| 3 |  | #endif | 
| 4 |  | /* | 
| 5 |  | * Routines for recognizing and moving about words in strings. | 
| 10 |  | #include "copyright.h" | 
| 11 |  |  | 
| 12 |  | #include  <ctype.h> | 
| 13 | – | #include  <string.h> | 
| 13 |  |  | 
| 14 | < | #ifdef  BSD | 
| 16 | < | #define  strchr         index | 
| 17 | < | #endif | 
| 14 | > | #include  "rtio.h" | 
| 15 |  |  | 
| 19 | – |  | 
| 16 |  | char * | 
| 17 | < | atos(rs, nb, s)                 /* get word from string, returning rs */ | 
| 22 | < | char  *rs; | 
| 23 | < | register int  nb; | 
| 24 | < | register char  *s; | 
| 17 | > | atos(char *rs, int nb, char *s)         /* get word from string, returning rs */ | 
| 18 |  | { | 
| 19 | < | register char  *cp = rs; | 
| 19 | > | char  *cp = rs; | 
| 20 |  |  | 
| 21 |  | while (isspace(*s)) | 
| 22 |  | s++; | 
| 28 |  |  | 
| 29 |  |  | 
| 30 |  | char * | 
| 31 | < | nextword(cp, nb, s)             /* get (quoted) word, returning new s */ | 
| 39 | < | register char  *cp; | 
| 40 | < | register int  nb; | 
| 41 | < | register char  *s; | 
| 31 | > | nextword(char *cp, int nb, char *s)     /* get (quoted) word, returning new s */ | 
| 32 |  | { | 
| 33 |  | int     quote = 0; | 
| 34 |  |  | 
| 52 |  |  | 
| 53 |  |  | 
| 54 |  | char * | 
| 55 | < | sskip(s)                        /* skip word in string, leaving on space */ | 
| 66 | < | register char  *s; | 
| 55 | > | sskip(char *s)                  /* skip word in string, leaving on space */ | 
| 56 |  | { | 
| 57 |  | while (isspace(*s)) | 
| 58 |  | s++; | 
| 63 |  |  | 
| 64 |  |  | 
| 65 |  | char * | 
| 66 | < | sskip2(s, n)                    /* skip word(s) in string, leaving on word */ | 
| 78 | < | register char  *s; | 
| 79 | < | register int    n; | 
| 66 | > | sskip2(char *s, int n)          /* skip word(s) in string, leaving on word */ | 
| 67 |  | { | 
| 68 |  | while (isspace(*s)) | 
| 69 |  | s++; | 
| 78 |  |  | 
| 79 |  |  | 
| 80 |  | char * | 
| 81 | < | iskip(s)                        /* skip integer in string */ | 
| 95 | < | register char  *s; | 
| 81 | > | iskip(char *s)                  /* skip integer in string */ | 
| 82 |  | { | 
| 83 |  | while (isspace(*s)) | 
| 84 |  | s++; | 
| 85 | < | if (*s == '-' || *s == '+') | 
| 85 | > | if ((*s == '-') | (*s == '+')) | 
| 86 |  | s++; | 
| 87 |  | if (!isdigit(*s)) | 
| 88 |  | return(NULL); | 
| 94 |  |  | 
| 95 |  |  | 
| 96 |  | char * | 
| 97 | < | fskip(s)                        /* skip float in string */ | 
| 112 | < | register char  *s; | 
| 97 | > | fskip(char *s)                  /* skip float in string */ | 
| 98 |  | { | 
| 99 | < | register char  *cp; | 
| 99 | > | char  *cp; | 
| 100 |  |  | 
| 101 |  | while (isspace(*s)) | 
| 102 |  | s++; | 
| 103 | < | if (*s == '-' || *s == '+') | 
| 103 | > | if ((*s == '-') | (*s == '+')) | 
| 104 |  | s++; | 
| 105 |  | cp = s; | 
| 106 |  | while (isdigit(*cp)) | 
| 112 |  | } | 
| 113 |  | if (cp == s) | 
| 114 |  | return(NULL); | 
| 115 | < | if (*cp == 'e' || *cp == 'E') | 
| 116 | < | return(iskip(cp+1)); | 
| 115 | > | if ((*cp == 'e') | (*cp == 'E')) | 
| 116 | > | return(isspace(*++cp) ? NULL : iskip(cp)); | 
| 117 |  | return(cp); | 
| 118 |  | } | 
| 119 |  |  | 
| 120 |  |  | 
| 121 |  | int | 
| 122 | < | isint(s)                        /* check integer format */ | 
| 138 | < | char  *s; | 
| 122 | > | isint(char *s)                  /* check integer format */ | 
| 123 |  | { | 
| 124 | < | register char  *cp; | 
| 124 | > | char  *cp; | 
| 125 |  |  | 
| 126 |  | cp = iskip(s); | 
| 127 |  | return(cp != NULL && *cp == '\0'); | 
| 129 |  |  | 
| 130 |  |  | 
| 131 |  | int | 
| 132 | < | isintd(s, ds)                   /* check integer format with delimiter set */ | 
| 149 | < | char  *s, *ds; | 
| 132 | > | isintd(char *s, char *ds)       /* check integer format with delimiter set */ | 
| 133 |  | { | 
| 134 | < | register char  *cp; | 
| 134 | > | char  *cp; | 
| 135 |  |  | 
| 136 |  | cp = iskip(s); | 
| 137 |  | return(cp != NULL && strchr(ds, *cp) != NULL); | 
| 139 |  |  | 
| 140 |  |  | 
| 141 |  | int | 
| 142 | < | isflt(s)                        /* check float format */ | 
| 160 | < | char  *s; | 
| 142 | > | isflt(char *s)                  /* check float format */ | 
| 143 |  | { | 
| 144 | < | register char  *cp; | 
| 144 | > | char  *cp; | 
| 145 |  |  | 
| 146 |  | cp = fskip(s); | 
| 147 |  | return(cp != NULL && *cp == '\0'); | 
| 149 |  |  | 
| 150 |  |  | 
| 151 |  | int | 
| 152 | < | isfltd(s, ds)                   /* check integer format with delimiter set */ | 
| 171 | < | char  *s, *ds; | 
| 152 | > | isfltd(char *s, char *ds)       /* check integer format with delimiter set */ | 
| 153 |  | { | 
| 154 | < | register char  *cp; | 
| 154 | > | char  *cp; | 
| 155 |  |  | 
| 156 |  | cp = fskip(s); | 
| 157 |  | return(cp != NULL && strchr(ds, *cp) != NULL); | 
| 158 | + | } | 
| 159 | + |  | 
| 160 | + |  | 
| 161 | + | int | 
| 162 | + | isname(char *s)                 /* check for legal identifier name */ | 
| 163 | + | { | 
| 164 | + | while (*s == '_')                       /* skip leading underscores */ | 
| 165 | + | s++; | 
| 166 | + | if (!isascii(*s) || !isalpha(*s))       /* start with a letter */ | 
| 167 | + | return(0); | 
| 168 | + | while (isascii(*++s) && isgraph(*s))    /* all visible characters */ | 
| 169 | + | ; | 
| 170 | + | return(*s == '\0');                     /* ending in nul */ | 
| 171 |  | } |