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

1.1     ! root        1: #include "../h/rt.h"
        !             2: 
        !             3: /*
        !             4:  * many(c,s,i,j) - find longest prefix of s[i:j] of characters in c.
        !             5:  */
        !             6: 
        !             7: Xmany(nargs, arg4, arg3, arg2, arg1, arg0)
        !             8: int nargs;
        !             9: struct descrip arg4, arg3, arg2, arg1, arg0;
        !            10:    {
        !            11:    register int i, j;
        !            12:    int t, *cs, csbuf[CSETSIZE];
        !            13:    long l1, l2;
        !            14:    char sbuf[MAXSTRING];
        !            15: 
        !            16:    /*
        !            17:     * c must be a cset.  s defaults to &subject;  i defaults to &pos if s
        !            18:     *  defaulted, 1 otherwise;  j defaults to 0.
        !            19:     */
        !            20:    if (cvcset(&arg1, &cs, csbuf) == NULL)
        !            21:       runerr(104, &arg1);
        !            22:    if (defstr(&arg2, sbuf, &k_subject))
        !            23:       defint(&arg3, &l1, k_pos);
        !            24:    else
        !            25:       defint(&arg3, &l1, 1);
        !            26:    defint(&arg4, &l2, 0);
        !            27: 
        !            28:    /*
        !            29:     * Convert i and j to absolute positions and order them.  If i == j,
        !            30:     *  then the specified substring of s is the empty string and many
        !            31:     *  fails.
        !            32:     */
        !            33:    i = cvpos(l1, STRLEN(arg2));
        !            34:    j = cvpos(l2, STRLEN(arg2));
        !            35:    if (i == j)
        !            36:       fail();
        !            37:    if (i > j) {
        !            38:       t = i;
        !            39:       i = j;
        !            40:       j = t;
        !            41:       }
        !            42: 
        !            43:    /*
        !            44:     * Fail if first character of s[i:j] isn't in c.
        !            45:     */
        !            46:    if (!tstb(STRLOC(arg2)[i-1], cs))
        !            47:       fail();
        !            48: 
        !            49:    /*
        !            50:     * Move i along s[i:j] until a character that is not in c is found or
        !            51:     *  the end of the string is reached.
        !            52:     */
        !            53:    i++;
        !            54:    while (i < j && tstb(STRLOC(arg2)[i-1], cs))
        !            55:       i++;
        !            56: 
        !            57:    /*
        !            58:     * Return the position of the first character not in c.
        !            59:     */
        !            60:    arg0.type = D_INTEGER;
        !            61:    INTVAL(arg0) = i;
        !            62:    }
        !            63: 
        !            64: Procblock(many,4)

unix.superglobalmegacorp.com

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