Annotation of coherent/g/usr/lib/misc/match.c, revision 1.1.1.1

1.1       root        1: /* 
                      2:  * match(string, pattern, fin)
                      3:  * returns start of pattern in string or NULL if no match.
                      4:  * pattern:
                      5:  *     [c1c2...cn-cm]  class of characters.
                      6:  *     ?               any character.
                      7:  *     *               any # of any character.
                      8:  *     ^               beginning of string
                      9:  *     $               end of string
                     10:  * if patttern is found fin is aimed past the end of the pattern.
                     11:  */
                     12: #include "local_misc.h"
                     13: 
                     14: /*
                     15:  * amatch is used internally by match.
                     16:  */
                     17: static char *
                     18: amatch(s, p, pfc, start, fin)
                     19: register char *s, *p;
                     20: int pfc;       /* past first char */
                     21: char **start, **fin;
                     22: {
                     23:        char *save;
                     24:        register c1;
                     25:        int c2;
                     26: 
                     27:        if (NULL == *start)
                     28:                *start = s;
                     29:        for (;c2 = *p++; pfc = 1) {
                     30:                c1 = *s++;
                     31:                *fin = s;
                     32: 
                     33:                switch (c2) {
                     34:                case '^':
                     35:                        if (pfc)
                     36:                                return (*start = NULL);
                     37:                        s--;
                     38:                        continue;
                     39: 
                     40:                case '$':
                     41:                        if (c1)
                     42:                                *start = NULL;
                     43:                        return (*start);
                     44: 
                     45:                case '[':
                     46:                        for (;;) {
                     47:                                c2 = *p++;
                     48:                                if (c2=='\0' || c2==']')
                     49:                                        return (*start = NULL);
                     50:                                if (c2 == '\\' && *p == '-')
                     51:                                        c2 = *p++;
                     52:                                if (c2 == c1)
                     53:                                        break;
                     54:                                if (*p == '-')
                     55:                                        if (c1<=*++p && c1>=c2)
                     56:                                                break;
                     57:                        }
                     58:                        while (*p && *p++!=']')
                     59:                                ;
                     60: 
                     61:                case '?':
                     62:                        if (c1)
                     63:                                continue;
                     64:                        return (*start = NULL);
                     65: 
                     66:                case '*':
                     67:                        if (!*p)
                     68:                                return (*start);
                     69:                        s--;
                     70:                        save = *start;
                     71:                        do {
                     72:                                if (NULL != amatch(s, p, 1, start, fin))
                     73:                                        return (*start);
                     74:                                *start = save;
                     75:                        } while (*s++ != '\0');
                     76:                        return (*start = NULL);
                     77: 
                     78:                case '\\':
                     79:                        if ((c2 = *p++) == '\0')
                     80:                                return (*start = NULL);
                     81:                }
                     82:                if (c1 != c2)
                     83:                        return (*start = NULL);
                     84:        }
                     85:        return (*start);
                     86: }
                     87: 
                     88: char *
                     89: match(s, p, fin)
                     90: register char *s, *p;
                     91: char **fin;
                     92: {
                     93:        char *start;
                     94:        int pfc;
                     95: 
                     96:        start = *fin = NULL;
                     97:        for (pfc = 0; *s; pfc = 1)
                     98:                if (NULL != amatch(s++, p, pfc, &start, fin))
                     99:                        return (start);
                    100:        return (*fin = start);
                    101: }
                    102: 
                    103: /*
                    104:  * This pnmatch takes advantage of amatch.
                    105:  */
                    106: pnmatch(s1, pat, flag)
                    107: char *s1, *pat;
                    108: {
                    109:        char *start, *fin;
                    110: 
                    111:        if (flag)
                    112:                return (NULL != match(s1, pat, &fin));
                    113:        return ((NULL != amatch(s1, pat, 0, &start, &fin)) && !*fin);
                    114: }
                    115: 
                    116: #ifdef TEST
                    117: main()
                    118: {
                    119:        char s1[80], pat[80], *start, *fin;
                    120: 
                    121:        for (;;) {
                    122:                ask(s1, "String  ");
                    123:                if (!strcmp(s1, "quit"))
                    124:                        exit(0);
                    125:                ask(pat, "Pattern");
                    126:                if (NULL == (start = match(s1, pat, &fin)))
                    127:                        printf("Not Found\n");
                    128:                else {
                    129:                        *fin = '\0';
                    130:                        printf("%s\n", start);
                    131:                }
                    132:        }
                    133: }
                    134: #endif

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.