Annotation of 43BSD/contrib/icon/functions/find.c, revision 1.1

1.1     ! root        1: #include "../h/rt.h"
        !             2: 
        !             3: /*
        !             4:  * find(s1,s2,i,j) - find string s1 in s2[i:j] and return position in
        !             5:  *  s2 of beginning of s1.
        !             6:  * Generates successive positions.
        !             7:  */
        !             8: 
        !             9: Xfind(nargs, arg4, arg3, arg2, arg1, arg0)
        !            10: int nargs;
        !            11: struct descrip arg4, arg3, arg2, arg1, arg0;
        !            12:    {
        !            13:    register int l;
        !            14:    register char *s1, *s2;
        !            15:    int i, j, t;
        !            16:    long l1, l2;
        !            17:    char sbuf1[MAXSTRING], sbuf2[MAXSTRING];
        !            18: 
        !            19:    /*
        !            20:     * s1 must be a string.  s2 defaults to &subject; i defaults to &pos
        !            21:     *  if s defaulted, 1 otherwise;  j defaults to 0.
        !            22:     */
        !            23:    if (cvstr(&arg1, sbuf1) == NULL)
        !            24:       runerr(103, &arg1);
        !            25:    if (defstr(&arg2, sbuf2, &k_subject))
        !            26:       defint(&arg3, &l1, k_pos);
        !            27:    else
        !            28:       defint(&arg3, &l1, 1);
        !            29:    defint(&arg4, &l2, 0);
        !            30: 
        !            31:    /*
        !            32:     * Convert i and j to absolute positions in s2 and order them so i <= j.
        !            33:     */
        !            34:    i = cvpos(l1, STRLEN(arg2));
        !            35:    j = cvpos(l2, STRLEN(arg2));
        !            36:    if (i > j) {
        !            37:       t = i;
        !            38:       i = j;
        !            39:       j = t;
        !            40:       }
        !            41: 
        !            42:    /*
        !            43:     * Loop through s2[i:j] trying to find s1 at each point, stopping
        !            44:     *  when the remaining portion s2[i:j] is too short to contain s1.
        !            45:     */
        !            46:    while (i <= j - STRLEN(arg1)) {
        !            47:       s1 = STRLOC(arg1);
        !            48:       s2 = STRLOC(arg2) + i - 1;
        !            49:       l = STRLEN(arg1);
        !            50:       /*
        !            51:        * Compare strings on bytewise basis; if end is reached before
        !            52:        *  inequality is found, suspend the position of the string.
        !            53:        */
        !            54:       do {
        !            55:          if (l-- <= 0) {
        !            56:             arg0.type = D_INTEGER;
        !            57:             INTVAL(arg0) = i;
        !            58:             suspend();
        !            59:             break;
        !            60:             }
        !            61:          } while (*s1++ == *s2++);
        !            62:       i++;
        !            63:       }
        !            64: 
        !            65:    fail();
        !            66:    }
        !            67: 
        !            68: Procblock(find,4)

unix.superglobalmegacorp.com

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