Annotation of 42BSD/bin/sh/word.c, revision 1.1

1.1     ! root        1: #ifndef lint
        !             2: static char sccsid[] = "@(#)word.c     4.3 8/11/83";
        !             3: #endif
        !             4: 
        !             5: #
        !             6: /*
        !             7:  * UNIX shell
        !             8:  *
        !             9:  * S. R. Bourne
        !            10:  * Bell Telephone Laboratories
        !            11:  *
        !            12:  */
        !            13: 
        !            14: #include       "defs.h"
        !            15: #include       "sym.h"
        !            16: 
        !            17: 
        !            18: /* ========    character handling for command lines    ========*/
        !            19: 
        !            20: 
        !            21: word()
        !            22: {
        !            23:        REG CHAR        c, d;
        !            24:        REG CHAR        *argp=locstak()+BYTESPERWORD;
        !            25:        INT             alpha=1;
        !            26: 
        !            27:        wdnum=0; wdset=0;
        !            28: 
        !            29:        WHILE (c=nextc(0), space(c)) DONE
        !            30: 
        !            31:        IF c=='#'
        !            32:        THEN    WHILE (c=readc()) ANDF c!=NL DONE
        !            33:        FI
        !            34: 
        !            35:        IF !eofmeta(c)
        !            36:        THEN    REP     IF c==LITERAL
        !            37:                        THEN    *argp++=(DQUOTE);
        !            38:                                WHILE (c=readc()) ANDF c!=LITERAL
        !            39:                                DO *argp++=(c|QUOTE); chkpr(c) OD
        !            40:                                *argp++=(DQUOTE);
        !            41: 
        !            42:                        ELSE    *argp++=(c);
        !            43:                                IF c=='=' THEN wdset |= alpha FI
        !            44:                                IF !alphanum(c) THEN alpha=0 FI
        !            45:                                IF qotchar(c)
        !            46:                                THEN    d=c;
        !            47:                                        WHILE (*argp++=(c=nextc(d))) ANDF c!=d
        !            48:                                        DO chkpr(c) OD
        !            49:                                FI
        !            50:                        FI
        !            51:                PER (c=nextc(0), !eofmeta(c)) DONE
        !            52:                argp=endstak(argp);
        !            53:                IF !letter(argp->argval[0]) THEN wdset=0 FI
        !            54: 
        !            55:                peekc=c|MARK;
        !            56:                IF argp->argval[1]==0 ANDF (d=argp->argval[0], digit(d)) ANDF (c=='>' ORF c=='<')
        !            57:                THEN    word(); wdnum=d-'0';
        !            58:                ELSE    /*check for reserved words*/
        !            59:                        IF reserv==FALSE ORF (wdval=syslook(argp->argval,reserved))==0
        !            60:                        THEN    wdarg=argp; wdval=0;
        !            61:                        FI
        !            62:                FI
        !            63: 
        !            64:        ELIF dipchar(c)
        !            65:        THEN    IF (d=nextc(0))==c
        !            66:                THEN    wdval = c|SYMREP;
        !            67:                ELSE    peekc = d|MARK; wdval = c;
        !            68:                FI
        !            69:        ELSE    IF (wdval=c)==EOF
        !            70:                THEN    wdval=EOFSYM;
        !            71:                FI
        !            72:                IF iopend ANDF eolchar(c)
        !            73:                THEN    copy(iopend); iopend=0;
        !            74:                FI
        !            75:        FI
        !            76:        reserv=FALSE;
        !            77:        return(wdval);
        !            78: }
        !            79: 
        !            80: nextc(quote)
        !            81:        CHAR            quote;
        !            82: {
        !            83:        REG CHAR        c, d;
        !            84:        IF (d=readc())==ESCAPE
        !            85:        THEN    IF (c=readc())==NL
        !            86:                THEN    chkpr(NL); d=nextc(quote);
        !            87:                ELIF quote ANDF c!=quote ANDF !escchar(c)
        !            88:                THEN    peekc=c|MARK;
        !            89:                ELSE    d = c|QUOTE;
        !            90:                FI
        !            91:        FI
        !            92:        return(d);
        !            93: }
        !            94: 
        !            95: readc()
        !            96: {
        !            97:        REG CHAR        c;
        !            98:        REG INT         len;
        !            99:        REG FILE        f;
        !           100: 
        !           101: retry:
        !           102:        IF peekc
        !           103:        THEN    c=peekc; peekc=0;
        !           104:        ELIF (f=standin, f->fnxt!=f->fend)
        !           105:        THEN    IF (c = *f->fnxt++)==0
        !           106:                THEN    IF f->feval
        !           107:                        THEN    IF estabf(*f->feval++)
        !           108:                                THEN    c=EOF;
        !           109:                                ELSE    c=SP;
        !           110:                                FI
        !           111:                        ELSE    goto retry; /* = c=readc(); */
        !           112:                        FI
        !           113:                FI
        !           114:                IF flags&readpr ANDF standin->fstak==0 THEN prc(c) FI
        !           115:                IF c==NL THEN f->flin++ FI
        !           116:        ELIF f->feof ORF f->fdes<0
        !           117:        THEN    c=EOF; f->feof++;
        !           118:        ELIF (len=readb())<=0
        !           119:        THEN    close(f->fdes); f->fdes = -1; c=EOF; f->feof++;
        !           120:        ELSE    f->fend = (f->fnxt = f->fbuf)+len;
        !           121:                goto retry;
        !           122:        FI
        !           123:        return(c);
        !           124: }
        !           125: 
        !           126: LOCAL  readb()
        !           127: {
        !           128:        REG FILE        f=standin;
        !           129:        REG INT         len;
        !           130: 
        !           131:        IF setjmp(INTbuf) == 0 THEN trapjmp[INTR] = 1; FI
        !           132:        REP     IF trapnote&SIGSET THEN newline(); sigchk() FI
        !           133:        PER (len=read(f->fdes,f->fbuf,f->fsiz))<0 ANDF trapnote DONE
        !           134:        trapjmp[INTR] = 0;
        !           135:        return(len);
        !           136: }

unix.superglobalmegacorp.com

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