Annotation of 43BSD/contrib/B/src/bsmall/b2cmd.c, revision 1.1

1.1     ! root        1: /* Copyright (c) Stichting Mathematisch Centrum, Amsterdam, 1984. */
        !             2: /* $Header: b2cmd.c,v 1.1 84/06/28 00:49:04 timo Exp $ */
        !             3: 
        !             4: /* B commands */
        !             5: #include "b.h"
        !             6: #include "b0con.h"
        !             7: #include "b1obj.h"
        !             8: #include "b2env.h"
        !             9: #include "b2scr.h"
        !            10: #include "b2err.h"
        !            11: #include "b2key.h"
        !            12: #include "b2syn.h"
        !            13: #include "b2sem.h"
        !            14: #include "b2typ.h"
        !            15: 
        !            16: #define Nex if (!xeq) {tx= ceol; return Yes;}
        !            17: 
        !            18: char rdbuf[RDBUFSIZE];
        !            19: txptr rdbufend= &rdbuf[RDBUFSIZE];
        !            20: 
        !            21: #define USE_QUIT "\r*** use QUIT or interrupt to abort READ command\n"
        !            22: 
        !            23: Hidden Procedure read_line(l, t, eg) loc l; btype t; bool eg; {
        !            24:        context c; txptr tx0= tx, rp; intlet k; value r; btype rt;
        !            25:        envtab svprmnvtab= Vnil; bool must_sv= eg, got;
        !            26:        sv_context(&c);
        !            27:        if (active_reads >= MAX_NMB_ACT_READS)
        !            28:                error("too many READs simultaneously active");
        !            29:        if (setjmp(reading[active_reads++]) != 0) /* long jump occurred */
        !            30:                set_context(&c);
        !            31:        if (cntxt != In_read) sv_context(&read_context);
        !            32:        if (must_sv) svprmnvtab= prmnvtab == Vnil ? Vnil : prmnv->tab;
        !            33:        /* save scratch-pad copy because of following setprmnv() */
        !            34:        if (eg) setprmnv(); must_sv= No;
        !            35:        cntxt= In_read;
        !            36:        got= No;
        !            37:        while (!got) {
        !            38:                tx= rp= rdbuf;
        !            39:                if (read_interactive) {
        !            40:                        fprintf(stderr, eg ? eg_prompt : raw_prompt);
        !            41:                }
        !            42:                got= Yes;
        !            43:                while ((k= getchar()) != EOF && k != '\n') {
        !            44:                        *rp++= k;
        !            45:                        if (rp > rdbufend-1) syserr("read buffer overflow");
        !            46:                }
        !            47:                if (k == EOF) {
        !            48:                        if (read_interactive) {
        !            49:                                fprintf(stderr, USE_QUIT);
        !            50:                                CLEAR_EOF;
        !            51:                                if (outeractive) at_nwl= Yes;
        !            52:                                got= No;
        !            53:                        } else error("End of file encountered during READ command");
        !            54:                }
        !            55:        }
        !            56:        if (read_interactive && outeractive && k == '\n') at_nwl= Yes;
        !            57:        *rp= '\n';
        !            58:        Skipsp(tx);
        !            59:        if (atkw(QUIT)) int_signal(Yes);
        !            60:        if (eg) {
        !            61:                r= expr(rp); rt= valtype(r);
        !            62:                if (svprmnvtab != Vnil) {
        !            63:                        prmnvtab= prmnv->tab;
        !            64:                        prmnv->tab= svprmnvtab;
        !            65:                }
        !            66:                must_sv= Yes;
        !            67:                set_context(&c);
        !            68:                must_agree(t, rt,
        !            69:                    "type of expression does not agree with that of EG sample");
        !            70:                release(rt);
        !            71:        } else {
        !            72:                *rp= '\0';
        !            73:                r= mk_text(rdbuf);
        !            74:                set_context(&c);
        !            75:        }
        !            76:        put(r, l);
        !            77:        active_reads--;
        !            78:        release(r);
        !            79:        tx= tx0;
        !            80: }
        !            81: 
        !            82: Hidden Procedure check(o) outcome o; {
        !            83:        if (o == Fail) checkerr();
        !            84: }
        !            85: 
        !            86: Hidden bool sim_com() {
        !            87:        txptr ftx, ttx;
        !            88:        switch (Char(tx)) {
        !            89: case 'C': if (atkw(CHECK)) {
        !            90:                env e0= curnv; outcome o;
        !            91:                Nex;
        !            92:                o= test(ceol);
        !            93:                if (xeq) {
        !            94:                        check(o);
        !            95:                        restore_env(e0);
        !            96:                }
        !            97:                return Yes;
        !            98:        } else if (atkw(CHOOSE)) {
        !            99:                loc l; value v;
        !           100:                reqkw(FROM_choose, &ftx, &ttx);
        !           101:                Nex;
        !           102:                l= targ(ftx);
        !           103:                tx= ttx; v= expr(ceol);
        !           104:                if (xeq) choose(l, v);
        !           105:                release(v); release(l);
        !           106:                return Yes;
        !           107:          }
        !           108:          return No;
        !           109: case 'D': if (atkw(DELETE)) {
        !           110:                loc l;
        !           111:                Nex;
        !           112:                l= targ(ceol);
        !           113:                if (xeq) l_delete(l);
        !           114:                release(l);
        !           115:                return Yes;
        !           116:        } else if (atkw(DRAW)) {
        !           117:                loc l;
        !           118:                Nex;
        !           119:                l= targ(ceol);
        !           120:                if (xeq) draw(l);
        !           121:                release(l);
        !           122:                return Yes;
        !           123:          }
        !           124:          return No;
        !           125: case 'E': if (atkw(ELSE)) {
        !           126:               pprerr("ELSE only allowed as alternative test after SELECT", "");
        !           127:          }
        !           128:          return No;
        !           129: case 'I': if (atkw(INSERT)) {
        !           130:                value v; loc l;
        !           131:                reqkw(IN_insert, &ftx, &ttx);
        !           132:                Nex;
        !           133:                v= expr(ftx);
        !           134:                tx= ttx; l= targ(ceol);
        !           135:                if (xeq) l_insert(v, l);
        !           136:                release(v); release(l);
        !           137:                return Yes;
        !           138:          }
        !           139:          return No;
        !           140: case 'P': if (atkw(PUT)) {
        !           141:                value v; loc l;
        !           142:                reqkw(IN_put, &ftx, &ttx);
        !           143:                Nex;
        !           144:                v= expr(ftx);
        !           145:                tx= ttx; l= targ(ceol);
        !           146:                if (xeq) put(v, l);
        !           147:                release(v); release(l);
        !           148:                return Yes;
        !           149:          }
        !           150:          return No;
        !           151: case 'R': if (atkw(READ)) {
        !           152:                value v; loc l; btype vt, lt; bool eg= Yes;
        !           153:                if (find(RAW, ceol, &ftx, &ttx)) {
        !           154:                        eg= No;
        !           155:                        vt= mk_text("");
        !           156:                } else reqkw(EG, &ftx, &ttx);
        !           157:                Nex;
        !           158:                l= targ(ftx); lt= loctype(l);
        !           159:                tx= ttx;
        !           160:                if (eg) {
        !           161:                        v= expr(ceol);
        !           162:                        vt= valtype(v); release(v);
        !           163:                }
        !           164:                must_agree(vt, lt,
        !           165:                    eg ? "this sample could not lawfully be put in the target"
        !           166:                       : "in READ x RAW, x must be a simple textual target");
        !           167:                release(lt);
        !           168:                if (xeq) read_line(l, vt, eg);
        !           169:                release(l); release(vt);
        !           170:                return Yes;
        !           171:        } else if (atkw(REMOVE)) {
        !           172:                value v; loc l;
        !           173:                reqkw(FROM_remove, &ftx, &ttx);
        !           174:                Nex;
        !           175:                v= expr(ftx);
        !           176:                tx= ttx; l= targ(ceol);
        !           177:                if (xeq) l_remove(v, l);
        !           178:                release(v); release(l);
        !           179:                return Yes;
        !           180:          }
        !           181:          return No;
        !           182: case 'S': if (atkw(SET_RANDOM)) {
        !           183:                value v;
        !           184:                Nex;
        !           185:                v= expr(ceol);
        !           186:                if (xeq) set_random(v);
        !           187:                release(v);
        !           188:                return Yes;
        !           189:          } else if (atkw(SHARE)) pprerr(
        !           190:          "SHARE only allowed following HOW'TO-, YIELD- or TEST-heading", "");
        !           191:          return No;
        !           192: case 'W': if (atkw(WRITE)) {
        !           193:                txptr tx0; value v; intlet nwlc;
        !           194:                Nex;
        !           195:                Skipsp(tx);
        !           196:                while (Char(tx) == '/' && (Char(tx+1) == '/')) {
        !           197:                        if (xeq) newline();
        !           198:                        tx++;
        !           199:                }
        !           200:                tx0= tx;
        !           201:        loop:   if (Char(tx++) != '/') {tx= tx0; goto postnl;}
        !           202:                if (Char(tx++) == '*') goto loop;
        !           203:                if (xeq) newline();
        !           204:                tx= tx0+1;
        !           205:        postnl: ftx= ceol;
        !           206:                while (Space(Char(ftx-1))) ftx--;
        !           207:                nwlc= 0;
        !           208:                while (ftx > tx && Char(ftx-1) == '/') {
        !           209:                        nwlc++;
        !           210:                        ftx--;
        !           211:                }
        !           212:                if (ftx > tx) {
        !           213:                        v= expr(ftx);
        !           214:                        if (xeq) writ(v);
        !           215:                        release(v);
        !           216:                }
        !           217:                while (nwlc-- > 0) {
        !           218:                        if (xeq) newline();
        !           219:                }
        !           220:                return Yes;
        !           221:          }
        !           222:          return No;
        !           223: default:  return No;
        !           224:        }
        !           225: }
        !           226: 
        !           227: #define Reqcol {req(":", ceol, &utx, &vtx); \
        !           228:                if (!xeq) {tx= vtx; comm_suite(); return Yes;}}
        !           229: #define Resetx(tx0) {tx= (tx0); lino= lino0; cur_ilev= cil;}
        !           230: 
        !           231: Hidden bool con_com() {
        !           232:        intlet lino0= lino, cil= cur_ilev;
        !           233:        txptr ftx, ttx, utx, vtx;
        !           234:        switch (Char(tx)) {
        !           235: case 'I': if (atkw(IF)) {
        !           236:                env e0= curnv; bool xeq0= xeq;
        !           237:                outcome o;
        !           238:                Reqcol;
        !           239:                o= test(utx);
        !           240:                xeq= o == Succ;
        !           241:                tx= vtx; comm_suite();
        !           242:                xeq= xeq0; restore_env(e0); 
        !           243:                return Yes;
        !           244:          }
        !           245:          return No;
        !           246: case 'S': if (atkw(SELECT)) {
        !           247:                need(":");
        !           248:                upto(ceol, "SELECT:");
        !           249:                alt_suite();
        !           250:                return Yes;
        !           251:          }
        !           252:          return No;
        !           253: case 'W': if (atkw(WHILE)) {
        !           254:                env e0= curnv; bool xeq0= xeq; txptr tx0= tx;
        !           255:                outcome o;
        !           256:                Reqcol;
        !           257:        loop:   o= test(utx);
        !           258:                if (xeq0) xeq= o == Succ;
        !           259:                tx= vtx; comm_suite();
        !           260:                xeq= xeq0; restore_env(e0);
        !           261:                if (xeq && o == Succ && !terminated) {
        !           262:                        Resetx(tx0); goto loop;
        !           263:                }
        !           264:                return Yes;
        !           265:          }
        !           266:          return No;
        !           267: case 'F': if (atkw(FOR)) {
        !           268:                env e0= curnv; bool xeq0= xeq; loc l; value v, w;
        !           269:                Reqcol;
        !           270:                if (find(PARSING, utx, &ftx, &ttx)) {
        !           271:                        tx= ttx; pprerr("PARSING not allowed in FOR ...", "");
        !           272:                }
        !           273:                reqkw(IN_for, &ftx, &ttx);
        !           274:                if (ttx > ceol) {
        !           275:                        tx= ceol;
        !           276:                        parerr("IN after colon", "");
        !           277:                }
        !           278:                l= targ(ftx);
        !           279:                if (!Is_simploc(l) && !Is_compound(l)) /*to bloc.c?*/
        !           280:                        pprerr("inappropriate identifier after FOR", "");
        !           281:                bind(l);
        !           282:                tx= ttx; v= expr(utx);
        !           283:                {value k, k1, len= xeq ? size(v) : copy(one);
        !           284:                        if (compare(len, zero) == 0) {
        !           285:                                xeq= No; release(len); len= copy(one);
        !           286:                        }
        !           287:                        k= copy(one);
        !           288:                        while (!terminated && compare(k, len) <= 0) {
        !           289:                                Resetx(utx);
        !           290:                                if (xeq) {
        !           291:                                        w= th_of(k, v);
        !           292:                                        put(w, l);
        !           293:                                        release(w);
        !           294:                                }
        !           295:                                k= sum(k1= k, one); release(k1);
        !           296:                                tx= vtx; comm_suite();
        !           297:                        }
        !           298:                        release(k); release(len);
        !           299:                }
        !           300:                xeq= xeq0; restore_env(e0);
        !           301:                release(v); release(l);
        !           302:                return Yes;
        !           303:          }
        !           304:          return No;
        !           305: default:  return No;
        !           306:        }
        !           307: }
        !           308: 
        !           309: Hidden bool term_com() {
        !           310:        switch (Char(tx)) {
        !           311: case 'F': if (atkw(FAIL)) {
        !           312:                upto(ceol, "FAIL");
        !           313:                if (xeq) {
        !           314:                        chckvtc(Rep);
        !           315:                        resout= Fail;
        !           316:                        terminated= Yes;
        !           317:                } else tx= ceol;
        !           318:                return Yes;
        !           319:          }
        !           320:          return No;
        !           321: case 'Q': if (atkw(QUIT)) {
        !           322:                upto(ceol, "QUIT");
        !           323:                if (xeq) {
        !           324:                        if (cur_ilev == 0) bye(0);
        !           325:                        chckvtc(Voi);
        !           326:                        terminated= Yes;
        !           327:                }
        !           328:                return Yes;
        !           329:          }
        !           330:          return No;
        !           331: case 'R': if (atkw(RETURN)) {
        !           332:                if (xeq) {
        !           333:                        chckvtc(Ret);
        !           334:                        resval= expr(ceol);
        !           335:                        terminated= Yes;
        !           336:                } else tx= ceol;
        !           337:                return Yes;
        !           338:          } else if (atkw(REPORT)) {
        !           339:                if (xeq) {
        !           340:                        chckvtc(Rep);
        !           341:                        resout= test(ceol);
        !           342:                        terminated= Yes;
        !           343:                } else tx= ceol;
        !           344:                return Yes;
        !           345:          }
        !           346:          return No;
        !           347: case 'S': if (atkw(SUCCEED)) {
        !           348:                upto(ceol, "SUCCEED");
        !           349:                if (xeq) {
        !           350:                        chckvtc(Rep);
        !           351:                        resout= Succ;
        !           352:                        terminated= Yes;
        !           353:                } else tx= ceol;
        !           354:                return Yes;
        !           355:          }
        !           356:          return No;
        !           357: default:  return No;
        !           358:        }
        !           359: }
        !           360: 
        !           361: Hidden bool secret_com() {
        !           362:        switch (Char(tx)) {
        !           363: case 'D': if (atkw("DEBUG")) {
        !           364:                Nex;
        !           365:                bugs= Yes;
        !           366:                return Yes;
        !           367:          }
        !           368:          return No;
        !           369: case 'G': if (atkw("GR")) {
        !           370:                Nex;
        !           371:                prgr();
        !           372:                return Yes;
        !           373:          }
        !           374:          return No;
        !           375: case 'N': if (atkw("NO'DEBUG")) {
        !           376:                Nex;
        !           377:                bugs= No;
        !           378:                return Yes;
        !           379:          } else if (atkw("NO'TRACE")) {
        !           380:                Nex;
        !           381:                tracing= No;
        !           382:                return Yes;
        !           383:          }
        !           384:          return No;
        !           385: case 'T': if (atkw("TRACE")) {
        !           386:                Nex;
        !           387:                tracing= Yes;
        !           388:                return Yes;
        !           389:          }
        !           390:          return No;
        !           391: default:  return No;
        !           392:        }
        !           393: }
        !           394: 
        !           395: Hidden Procedure chckvtc(re) literal re; {
        !           396:        if (cntxt != In_unit || resexp == Voi) {
        !           397:                if (re == Ret)
        !           398:                        pprerr("RETURN e only allowed inside YIELD-unit or\n",
        !           399:                               "    expression-refinement");
        !           400:                else if (re == Rep)
        !           401:                        pprerr("REPORT t only allowed inside TEST-unit",
        !           402:                               " or test-refinement");
        !           403:        }
        !           404:        if (re != resexp) {
        !           405:                if (resexp == Ret)
        !           406:                        pprerr(
        !           407:        "RETURN e must terminate YIELD-unit or expression-refinement", "");
        !           408:                if (resexp == Rep)
        !           409:                        pprerr(
        !           410:        "REPORT t must terminate TEST-unit or test-refinement", "");
        !           411:        }
        !           412: }
        !           413: 
        !           414: Hidden bool expr_s() {
        !           415:        char c;
        !           416:        Skipsp(tx);
        !           417:        if (tx >= ceol) return No;
        !           418:        c= Char(tx);
        !           419:        return Letter(c) || Montormark(c) || Dig(c) || c == '.' || c == 'E' ||
        !           420:                c == '(' || c == '{' || c == '\'' || c == '"';
        !           421: }
        !           422: 
        !           423: intlet comcnt= 0;
        !           424: 
        !           425: Visible Procedure command() {
        !           426:        if (++comcnt > 10000) {
        !           427:                putprmnv();
        !           428:                comcnt= 1;
        !           429:        }
        !           430:        if (Char(tx) == Eotc) getline();
        !           431: debug("analyzing command");
        !           432:        if (tracing) trace();
        !           433:        if (Ceol(tx));
        !           434:        else if (sim_com() || con_com() ||
        !           435:                unit() || term_com() || ref_com() || udc() ||
        !           436:                secret_com()) skipping= No;
        !           437:        else if (Char(tx) == ':' || Char(tx) == '=' || Char(tx) == '!') {
        !           438:                if (!interactive) parerr("special commands only interactively", "");
        !           439:                if (!(cntxt == In_command && cur_ilev == 0)) parerr(
        !           440:                        "special commands only on outermost level (no indentation)", "");
        !           441:                special();
        !           442:        } else if (cntxt == In_command && cur_ilev == 0 && expr_s()) {
        !           443:                value w= expr(ceol);
        !           444:                wri(w, Yes, No, No);
        !           445:                release(w);
        !           446:        } else {txptr tx0= tx; value uc= keyword(ceol);
        !           447:                tx= tx0; parerr("you have not told me HOW'TO ", strval(uc));
        !           448:        }
        !           449:        To_eol(tx);
        !           450: debug("command treated");
        !           451: }
        !           452: 
        !           453: Visible Procedure comm_suite() {
        !           454:        intlet cil= cur_ilev;
        !           455:        if (ateol()) {
        !           456:                txptr tx0= tx; bool xeq0= xeq;
        !           457:                if (Char(tx+1) == Eotc) xeq= No;
        !           458:                while (ilev(No) > cil) {
        !           459:                        findceol();
        !           460:                        command();
        !           461:                        if (terminated) return;
        !           462:                        if (cur_ilev <= cil) goto brk1;
        !           463:                }
        !           464:                veli();
        !           465:        brk1:   if (xeq0 && !xeq) {
        !           466:                        tx= tx0; xeq= Yes;
        !           467:                        cur_ilev= cil;
        !           468:                        while (ilev(No) > cil) {
        !           469:                                findceol();
        !           470:                                command();
        !           471:                                if (terminated) return;
        !           472:                                if (cur_ilev <= cil) goto brk2;
        !           473:                        }
        !           474:                        veli();
        !           475:                brk2:   ;
        !           476:                }
        !           477:        } else command();
        !           478: }
        !           479: 
        !           480: Hidden Procedure alt_suite() {
        !           481:        intlet cil= cur_ilev; env e0= curnv; txptr utx, vtx;
        !           482:        bool xeq0= xeq, succ= !xeq, Else= No;
        !           483:        if (!ateol()) syserr("alt_suite not at end of line");
        !           484:        while (ilev(No) > cil) {
        !           485:                findceol();
        !           486:                if (Else)
        !           487:                parerr("after ELSE: ... no more alternatives are allowed", "");
        !           488:                req(":", ceol, &utx, &vtx);
        !           489:                if (atkw(ELSE)) {
        !           490:                        succ= Else= Yes;
        !           491:                        upto(utx, "ELSE");
        !           492:                        tx= vtx; comm_suite();
        !           493:                        if (terminated) return;
        !           494:                } else {
        !           495:                        if (xeq) succ= test(utx) == Succ;
        !           496:                        xeq= xeq && succ;
        !           497:                        tx= vtx; comm_suite();
        !           498:                        if (terminated) return;
        !           499:                        xeq= !succ;
        !           500:                }
        !           501:                if (cur_ilev <= cil) goto brk;
        !           502:        }
        !           503:        veli();
        !           504: brk:   if (!succ) error("none of the alternative tests of SELECT succeeds");
        !           505:        xeq= xeq0; if (xeq) restore_env(e0);
        !           506: }

unix.superglobalmegacorp.com

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