33000 (*+01()   (*$P+,T-+)   ()+01*)
33010  (*+25()   (*$P+,T-+)   ()+25*)
33020      (*  COPYRIGHT 1983 C.H.LINDSEY, UNIVERSITY OF MANCHESTER  *)
33030  (**)
33040  (**)
33050  (**)
33060  (*+83()
33070  (**)
33080  (**)
33090  PROCEDURE INITIALIZE;
33100  (*FUNCTION: COMPILER INITIALIZATION TO SET UP LEXEMES, PARSER,
33110      STANDARD-PRELUDE, ETC.  ULTIMATELY, THE COMPILER WILL BE FROZEN
33120      AFTER THE CALL OF INITIALIZE, AND HOPEFULLY THIS PROCEDURE CAN
33130      THEN BE MADE TO VANISH AWAY.
33140  *)
33150    VAR I: INTEGER;
33160      OTCOUNT: INTEGER;
33170  (*+84()
33180    (*MDMS*)
33190      MDVINT, MDVLINT, MDVREAL, MDVLREAL, MDVCHAR, MDVBITS, MDVBYTES, MDVSTRNG, MDVBOOL,
33200      MDVCHAN, MDVCOVER, MDVVOID, MDVSKIP, MDVJUMP, MDVNIL,
33210      MDVOUT, MDVIN, MDVOUTB, MDVINB, MDVNUMBER,
33220      MDVROWS, MDVBNDS, MDVABSENT, MDVERROR (*, MDVPROC, MDVREF, MDVSTRUCT, MDVROW*): MDM;
33230  ()+84*)
33240  (*+81()
33250    (*LXMS - NONTERMINALS*)
33260      LXVACTPL, LXVACTRL,
33270      LXVBOUNDS, LXVBRINPT, LXVBRTHPT,
33280      LXVCSTICK,
33290      LXVDCLL,
33300      LXVFLDSPL, LXVFORDCL, LXVFORRLB,
33310      LXVIDEFL,
33320      LXVLABSQ,
33330      LXVMOIDDR,
33340      LXVNONRDR,
33350      LXVODEFL, LXVOPRAND,
33360      LXVPRIM, LXVPRMDRL,
33370      LXVRIDEFL, LXVRODEFL, LXVRSPEC, LXVRVDEFL,
33380      LXVTERT, LXVTRMSCL,
33390      LXVUNLC, LXVUNLP, LXVUNSR,
33400      LXVVDEFL,
33410    (*LXMS - TERMINALS*)
33420      LXVAGAIN, LXVAT,
33430      LXVBECOM, LXVBEGIN, LXVBOOLDEN, LXVBUS, LXVBY,
33440      LXVCASE, LXVCLOSE, LXVCOLON, LXVCOMMA, LXVCMMENT,
33450      LXVDO,
33460      LXVELIF, LXVELSE, LXVEND, LXVEQUAL, LXVERROR, LXVESAC, LXVEXIT,
33470      LXVFI, LXVFOR, LXVFROM,
33480      LXVGO, LXVGOTO,
33490      LXVHEAP,
33500      LXVIDTY, LXVIF, LXVIN,
33510      LXVLOC, LXVLONG,
33520      (*LXVMDIND,*) LXVMODE,
33530      LXVNIL,
33540      LXVOD, LXVOF, LXVOP, LXVOPEN, (*LXVOPR,*) LXVOTHDR, LXVOUSE, LXVOUT,
33550      LXVPRAGMAT, (*LXVPRDEN,*) LXVPRDR, LXVPRIO, LXVPROC,
33560      LXVREF,
33570      LXVSEMIC, LXVSHORT, LXVSKIP, LXVSTART, LXVSTICK, LXVSTOP, (*LXVSTRGDEN*) LXVSTRUCT, LXVSUB,
33580      (*LXVTAB,*) (*LXVTAG,*) LXVTHEN, LXVTO,
33590      LXVVOID,
33600      LXVWHILE: LXM;
33610    (*PLEXES - NONTERMINALS*)
33620      LEXACTPL, LEXACTRL,
33630      LEXBOUNDS, LEXBRINPT, (*LEXBRTHPT,*)
33640      LEXCSTICK,
33650      LEXDCLL,
33660      LEXFLDSPL, LEXFORDCL, LEXFORRLB,
33670      LEXIDEFL,
33680      LEXLABSQ,
33690      LEXMOIDDR,
33700      LEXNONRDR,
33710      LEXODEFL, LEXOPRAND,
33720      LEXPRIM, LEXPRMDRL,
33730      LEXRIDEFL, LEXRODEFL, LEXRSPEC, LEXRVDEFL,
33740      LEXTERT, LEXTRMSCL,
33750      LEXUNLC, LEXUNLP, LEXUNSR,
33760      LEXVDEFL,
33770    (*PLEXES - TERMINALS*)
33780      LEXAGAIN, LEXAT, LEXATB,
33790      LEXBECOM, (*LEXBEGIN,*) LEXBUSB, LEXBY,
33800      (*LEXCASE,*) LEXCLOSE, LEXCOLON, LEXCOMMA, LEXCO, LEXCO2, LEXCMMENT,
33810      LEXDIV, LEXDO, LEXDVAB,
33820      LEXELIF, LEXELSE, LEXEMPTY, LEXEND, LEXEQUAL, (*LEXERROR,*) LEXESAC, LEXEXIT,
33830      (*LEXFALSE,*) LEXFI, LEXFLEX, LEXFOR, LEXFROM,
33840      LEXGE, LEXGO, LEXGOTO, LEXGT,
33850      LEXHEAP,
33860      (*LEXIF,*) LEXIN, LEXIS, LEXISB, LEXISNT, LEXISNTB,
33870      LEXLE, LEXLOC, LEXLONG, LEXLT,
33880      LEXMDAB, LEXMINUS, LEXMNAB, LEXMOD, LEXMODE,
33890      LEXNE, LEXNIL,
33900      LEXOD, LEXOF, LEXOP, (*LEXOPEN,*) LEXOUSE, LEXOUT, LEXOVAB, LEXOVER,
33910      LEXPAR, LEXPLAB, LEXPLTO, LEXPLUS, LEXPLITM, LEXPR, LEXPRAGMAT, LEXPRIO, LEXPROC,
33920      LEXREF,
33930      LEXSEMA, LEXSEMIC, LEXSHORT, LEXSKIP, (*LEXSTART,*) LEXSTICK, (*LEXLSTOP, LEXSTOP,*) LEXSTRUCT, LEXSUBB,
33940      LEXTHEN, LEXTIMES, LEXTMAB, LEXTO, (*LEXTRUE,*)
33950      LEXUP1, LEXUP2, LEXUNION,
33960      LEXVOID (*, LEXWHILE*)
33970         : PLEX;
33980  ()+81*)
33990    PROCEDURE LXVVAL(VAR LXVVAR: LXM; IO: LXIOTYPE; CL0: CL0TYPE; CL1: CL1TYPE; CL2: CL2TYPE);
34000      VAR WORD: RECORD CASE SEVERAL OF
34010    (*-02() (*-05()     1:(LXV: LXM); 2:(INT: INTEGER) END; ()-05*) ()-02*)
34020    (*+02()      1:(LXV:LXM); 2:(INT,INT2,INT3: INTEGER); 3,4,5,6,7,8,9,10:() END; ()+02*)
34030    (*+05()      1:(LXV:LXM); 2:(INT,INT2: INTEGER); 3,4,5,6,7,8,9,10:() END; ()+05*)
34040      BEGIN WORD.INT := 0; (*TO ENSURE THAT PARTS OF WORD NOT OCCUPIED BY THE LXM ARE CLEAR*)
34050  (*+02()   WORD.INT2 := 0; WORD.INT3 := 0;  ()+02*)
34060  (*+05()   WORD.INT2 := 0; ()+05*)
34070      WITH WORD.LXV DO
34080            BEGIN LXIO := IO; LXCLASS0 := CL0; LXCLASS1 := CL1; LXCLASS2 := CL2; LXPSTB := NIL END;
34090      LXVVAR := WORD.LXV
34100        END;
34110  (*+81()
34120    PROCEDURE LOCNDEX(VAR LEX: PLEX; LXV: LXM);
34130        BEGIN
34140        ENEW(LEX, LEX1SIZE);
34150        LEX^.LXV := LXV;
34160        LEX^.LXCOUNT := 0;
34170        END;
34180  ()+81*)
34190  (*+84()
34200    FUNCTION DEFPRC0(YIELD: MODE; CP: CODEPROC): MODE;
34210        BEGIN SRSEMP := -1; SRSUBP := 0; SUBSAVE;
34220        FINDPRC(YIELD,0,CP); DEFPRC0 := SRSTK[SRSEMP].MD
34230        END;
34240    FUNCTION DEFPRC1(P1, YIELD: MODE; CP: CODEPROC): MODE;
34250        BEGIN SRSEMP := -1; SRSUBP := 0; SUBSAVE;
34260        SRSEMP := SRSEMP+1; SRSTK[SRSEMP].MD := P1;
34270        FINDPRC(YIELD,1,CP); DEFPRC1 := SRSTK[SRSEMP].MD
34280        END;
34290    FUNCTION DEFPRC2(P1, P2, YIELD: MODE; CP: CODEPROC): MODE;
34300        BEGIN SRSEMP := -1; SRSUBP := 0; SUBSAVE;
34310        SRSEMP := SRSEMP+1; SRSTK[SRSEMP].MD := P1;
34320        SRSEMP := SRSEMP+1; SRSTK[SRSEMP].MD := P2;
34330        FINDPRC(YIELD,2,CP); DEFPRC2 := SRSTK[SRSEMP].MD
34340        END;
34350  ()+84*)
34360  (*+81()
34370    PROCEDURE DEFSYMB(VAR LEX: PLEX; TLXV: LXM; SYMB: ALFA);
34380      VAR I: INTEGER;
34390        BEGIN WITH CURRENTLEX DO
34400          BEGIN
34410          LXV := TLXV; LXTOKEN := TKSYMBOL;
34420  (*+11() S10 := SYMB; LXCOUNT := 1; ()+11*)
34430  (*-11() STASHLEX(SYMB); ()-11*)
34440          ENEW(LEX, LEX1SIZE+LXCOUNT*SZWORD);
34450          FOR I := 1 TO LEX1SIZE DIV SZWORD + LXCOUNT DO
34460            LEX^.LEXWORDS[I] := LEXWORDS[I];
34470          END
34480        END;
34490  (**)
34500  ()+81*)
34510  (**)
34520    PROCEDURE INTAB(VAR LEX: PLEX; TAG: ALFA; LXVV: LXM);
34530     VAR I:  INTEGER;
34540        BEGIN WITH CURRENTLEX DO
34550            BEGIN
34560            LXV := LXVV;  LXTOKEN := TKBOLD;
34570  (*+11()  S10:=TAG; LXCOUNT:=1;   ()+11*)
34580  (*-11()  STASHLEX(TAG); ()-11*)
34590            END;
34600        LEX := HASHIN
34610        END;
34620  (*+84()
34630    FUNCTION DEFTAG(TAG: ALFA): PLEX;
34640        BEGIN WITH CURRENTLEX DO
34650          BEGIN
34660          LXV := LXVTAG;  LXTOKEN := TKTAG;
34670  (*+11()  S10:=TAG; LXCOUNT:=1;   ()+11*)
34680  (*-11() STASHLEX(TAG); ()-11*)
34690          END;
34700        DEFTAG := HASHIN
34710        END;
34720  ()+84*)
34730  (*+81()
34740    FUNCTION DEFLTAG(TAG1, TAG2: ALFA): PLEX;
34750        BEGIN WITH CURRENTLEX DO
34760          BEGIN
34770          LXV := LXVTAG; LXTOKEN := TKTAG;
34780  (*+11() S20 := TAG2; S10 := TAG1; LXCOUNT := 2;   ()+11*)
34790  (*-11() STASHLLEX(TAG1, TAG2); ()-11*)
34800          DEFLTAG := HASHIN;
34810          END
34820        END;
34830    PROCEDURE OTPAIR(OTCOUNT: OPCHTABBOUND; TCHAR: CHAR; TNEXT, TALT: OPCHTABBOUND; TLEX: PLEX);
34840        BEGIN WITH OPCHTABLE[OTCOUNT] DO
34850            BEGIN OTCHAR := TCHAR; OTNEXT := TNEXT; OTALT := TALT; OTLEX := TLEX;
34860             END
34870        END;
34880    PROCEDURE INITLEXES;
34890        BEGIN
34900    (*SET UP LXV VALUES - NONTERMINALS*)
34910      LXVVAL(LXVACTPL  , LXIOACTPL  , 0, 0, 00); (*ACTUAL PARAMETER LIST*)
34920      LXVVAL(LXVACTRL  , LXIOACTRL  , 0, 0, 00); (*ACTUAL ROWER LIST*)
34930      LXVVAL(LXVBOUNDS , LXIOBOUNDS , 0, 0, 00); (*BOUNDS*)
34940      LXVVAL(LXVBRINPT , LXIOBRINPT , 0, 0, 02); (*BRIEF IN PART*)
34950      LXVVAL(LXVBRTHPT , LXIOBRTHPT , 0, 0, 02); (*BRIEF THEN PART*)
34960      LXVVAL(LXVCSTICK , LXIOCSTICK , 0, 3, 09); (*STICK IN CASE-CLAUSE*)
34970      LXVVAL(LXVDCLL   , LXIODCLL   , 0, 0, 00); (*DECLARATION LIST*)
34980      LXVVAL(LXVFLDSPL , LXIOFLDSPL , 0, 0, 07); (*FIELD SPECIFICATION LIST*)
34990      LXVVAL(LXVFORDCL , LXIOFORDCL , 0, 0, 00); (*FORMAL DECLARATIVE LIST*)
35000      LXVVAL(LXVFORRLB , LXIOFORRLB , 0, 0, 00); (*FORMAL ROWER LIST BRACKET*)
35010      LXVVAL(LXVIDEFL  , LXIOIDEFL  , 0, 0, 00); (*IDENTITY DEFINITION LIST*)
35020      LXVVAL(LXVLABSQ  , LXIOLABSQ  , 0, 0, 00); (*LABEL SEQUENCE*)
35030      LXVVAL(LXVMOIDDR , LXIOMOIDDR , 0, 0, 00); (*MOID DECLARER*)
35040      LXVVAL(LXVNONRDR , LXIONONRDR , 0, 0, 00); (*NONROWED DECLARER*)
35050      LXVVAL(LXVODEFL  , LXIOODEFL  , 0, 0, 00); (*OPERATION DEFINITION LIST*)
35060      LXVVAL(LXVOPRAND , LXIOOPRAND , 0, 0, 00); (*OPERAND*)
35070      LXVVAL(LXVPRIM   , LXIOPRIM   , 0, 0, 00); (*PRIMARY*)
35080      LXVVAL(LXVPRMDRL , LXIOPRMDRL , 0, 0, 00); (*PARAMETER DECLARER LIST*)
35090      LXVVAL(LXVRIDEFL , LXIORIDEFL , 0, 0, 00); (*ROUTINE IDENTITY DEFINITION LIST*)
35100      LXVVAL(LXVRODEFL , LXIORODEFL , 0, 0, 00); (*ROUTINE OPERATION DEFINITION LIST*)
35110      LXVVAL(LXVRSPEC  , LXIORSPEC  , 0, 0, 00); (*ROUTINE SPECIFICATION*)
35120      LXVVAL(LXVRVDEFL , LXIORVDEFL , 0, 0, 00); (*ROUTINE VARIABLE DEFINITION LIST*)
35130      LXVVAL(LXVTERT   , LXIOTERT   , 0, 0, 00); (*TERTIARY*)
35140      LXVVAL(LXVTRMSCL , LXIOTRMSCL , 0, 0, 00); (*TRIMSCRIPT LIST*)
35150      LXVVAL(LXVUNLC   , LXIOUNLC   , 0, 0, 00); (*UNIT LIST PROPER IN COLLATERAL*)
35160      LXVVAL(LXVUNLP   , LXIOUNLP   , 0, 0, 00); (*UNIT LIST PROPER*)
35170      LXVVAL(LXVUNSR   , LXIOUNSR   , 0, 3, 00); (*UNIT SERIES*)
35180      LXVVAL(LXVVDEFL  , LXIOVDEFL  , 0, 0, 00); (*VARIABLE DEFINITION LIST*)
35190    (*SET UP LXV VALUES - TERMINALS*)
35200      LXVVAL(LXVAGAIN  , LXIOAGAIN  , 1, 3, 09);
35210      LXVVAL(LXVAT     , LXIOAT     , 1, 1, 05);
35220      LXVVAL(LXVBECOM  , LXIOBECOM  , 1, 0, 00);
35230      LXVVAL(LXVBEGIN  , LXIOBEGIN  , 0, 3, 02);
35240      LXVVAL(LXVBOOLDEN, LXIOBOOLDEN, 0, 0, 10);
35250      LXVBOOLDEN.LXPYPTR := 0;
35260      LXVVAL(LXVBUS    , LXIOBUS    , 1, 1, 00);
35270      LXVVAL(LXVBY     , LXIOBY     , 0, 0, 01);
35280      LXVVAL(LXVCASE   , LXIOCASE   , 0, 3, 02);
35290      LXVVAL(LXVCLOSE  , LXIOCLOSE  , 1, 1, 15);
35300      LXVVAL(LXVCOLON  , LXIOCOLON  , 1, 0, 05);
35310      LXVVAL(LXVCOMMA  , LXIOCOMMA  , 1, 1, 13);
35320      LXVVAL(LXVCMMENT , LXIOCMMENT , 0, 0, 00);
35330      LXVVAL(LXVDO     , LXIODO     , 0, 3, 01);
35340      LXVVAL(LXVELIF   , LXIOELIF   , 1, 3, 04);
35350      LXVVAL(LXVELSE   , LXIOELSE   , 1, 3, 04);
35360      LXVVAL(LXVEND    , LXIOEND    , 1, 0, 15);
35370      LXVVAL(LXVEQUAL  , LXIOEQUAL  , 0, 4, 00);
35380      LXVVAL(LXVERROR  , LXIOERROR  , 0, 0, 00);
35390      LXVVAL(LXVESAC   , LXIOESAC   , 1, 0, 15);
35400      LXVVAL(LXVEXIT   , LXIOEXIT   , 1, 0, 00);
35410      LXVVAL(LXVFI     , LXIOFI     , 1, 0, 15);
35420      LXVVAL(LXVFOR    , LXIOFOR    , 0, 0, 01);
35430      LXVVAL(LXVFROM   , LXIOFROM   , 0, 0, 01);
35440      LXVVAL(LXVGO     , LXIOGO     , 0, 0, 00);
35450      LXVVAL(LXVGOTO   , LXIOGOTO   , 0, 0, 00);
35460      LXVVAL(LXVHEAP   , LXIOHEAP   , 0, 0, 14);
35470      LXVVAL(LXVIDTY   , LXIOIDTY   , 1, 0, 00);
35480      LXVVAL(LXVIF     , LXIOIF     , 0, 3, 02);
35490      LXVVAL(LXVIN     , LXIOIN     , 1, 3, 00);
35500      LXVVAL(LXVLOC    , LXIOLOC    , 0, 0, 14);
35510      LXVVAL(LXVLONG   , LXIOLONG   , 0, 2, 00);
35520      LXVVAL(LXVMDIND  , LXIOMDIND  , 0, 2, 11);
35530      LXVVAL(LXVMODE   , LXIOMODE   , 0, 0, 00);
35540      LXVVAL(LXVNIL    , LXIONIL    , 0, 0, 00);
35550      LXVVAL(LXVOD     , LXIOOD     , 1, 0, 15);
35560      LXVVAL(LXVOF     , LXIOOF     , 1, 0, 00);
35570      LXVVAL(LXVOP     , LXIOOP     , 0, 0, 12);
35580      LXVVAL(LXVOPEN   , LXIOOPEN   , 0, 3, 06);
35590      LXVVAL(LXVOPR    , LXIOOPR    , 0, 4, 00);
35600      LXVVAL(LXVOTHDR  , LXIOOTHDR  , 0, 2, 08); (*DOESN'T SEEM TO BE USED ANYWHERE*)
35610      LXVVAL(LXVOUSE   , LXIOOUSE   , 1, 3, 03);
35620      LXVVAL(LXVOUT    , LXIOOUT    , 1, 3, 03);
35630      LXVVAL(LXVPRAGMAT, LXIOPRAGMAT, 0, 0, 00);
35640      LXVVAL(LXVPRDEN  , LXIOPRDEN  , 0, 0, 10);
35650      LXVPRDEN.LXPYPTR := 0;
35660      LXVVAL(LXVPRDR   , LXIOPRDR   , 0, 2, 08);
35670      LXVVAL(LXVPRIO   , LXIOPRIO   , 0, 0, 00);
35680      LXVVAL(LXVPROC   , LXIOPROC   , 0, 2, 12);
35690      LXVVAL(LXVREF    , LXIOREF    , 0, 2, 00);
35700      LXVVAL(LXVSEMIC  , LXIOSEMIC  , 1, 0, 13);
35710      LXVVAL(LXVSHORT  , LXIOSHORT  , 0, 2, 00);
35720      LXVVAL(LXVSKIP   , LXIOSKIP   , 0, 0, 00);
35730      LXVVAL(LXVSTART  , LXIOSTART  , 0, 0, 00);
35740      LXVVAL(LXVSTICK  , LXIOSTICK  , 1, 3, 09);
35750      LXVVAL(LXVSTOP   , LXIOSTOP   , 1, 0, 00);
35760      LXVVAL(LXVSTRGDEN, LXIOSTRGDEN, 0, 0, 10);
35770      LXVSTRGDEN.LXPYPTR := 0;
35780      LXVVAL(LXVSTRUCT , LXIOSTRUCT , 0, 2, 07);
35790      LXVVAL(LXVSUB    , LXIOSUB    , 0, 2, 06);
35800      LXVVAL(LXVTAB    , LXIOTAB    , 0, 4, 11);
35810      LXVVAL(LXVTAG    , LXIOTAG    , 0, 0, 00);
35820      LXVVAL(LXVTHEN   , LXIOTHEN   , 1, 3, 00);
35830      LXVVAL(LXVTO     , LXIOTO     , 0, 0, 01);
35840      LXVVAL(LXVVOID   , LXIOVOID   , 0, 0, 00);
35850      LXVVAL(LXVWHILE  , LXIOWHILE  , 0, 3, 01);
35860    (*SET UP LEX VALUES - NONTERMINALS*)
35870      LOCNDEX(LEXACTPL,  LXVACTPL);
35880      LOCNDEX(LEXACTRL,  LXVACTRL);
35890      LOCNDEX(LEXBOUNDS, LXVBOUNDS);
35900      LOCNDEX(LEXBRINPT, LXVBRINPT);
35910      LOCNDEX(LEXBRTHPT, LXVBRTHPT);
35920      LOCNDEX(LEXCSTICK, LXVCSTICK);
35930      LOCNDEX(LEXDCLL,   LXVDCLL);
35940      LOCNDEX(LEXFLDSPL, LXVFLDSPL);
35950      LOCNDEX(LEXFORDCL, LXVFORDCL);
35960      LOCNDEX(LEXFORRLB, LXVFORRLB);
35970      LOCNDEX(LEXIDEFL,  LXVIDEFL);
35980      LOCNDEX(LEXLABSQ,  LXVLABSQ);
35990      LOCNDEX(LEXMOIDDR, LXVMOIDDR);
36000      LOCNDEX(LEXNONRDR, LXVNONRDR);
36010      LOCNDEX(LEXODEFL,  LXVODEFL);
36020      LOCNDEX(LEXOPRAND, LXVOPRAND);
36030      LOCNDEX(LEXPRIM,   LXVPRIM);
36040      LOCNDEX(LEXPRMDRL, LXVPRMDRL);
36050      LOCNDEX(LEXRIDEFL, LXVRIDEFL);
36060      LOCNDEX(LEXRODEFL, LXVRODEFL);
36070      LOCNDEX(LEXRSPEC,  LXVRSPEC);
36080      LOCNDEX(LEXRVDEFL, LXVRVDEFL);
36090      LOCNDEX(LEXTERT,   LXVTERT);
36100      LOCNDEX(LEXTRMSCL, LXVTRMSCL);
36110      LOCNDEX(LEXUNLC, LXVUNLC);
36120      LOCNDEX(LEXUNLP, LXVUNLP);
36130      LOCNDEX(LEXUNSR, LXVUNSR);
36140      LOCNDEX(LEXVDEFL,  LXVVDEFL);
36150    (*SET UP LEX VALUES - BRIEF TERMINALS*)
36160      LOCNDEX(LEXAGAIN, LXVAGAIN);
36170      LOCNDEX(LEXAT,    LXVAT);
36180      LOCNDEX(LEXBECOM, LXVBECOM);
36190      LOCNDEX(LEXBUSB,  LXVBUS);
36200      LOCNDEX(LEXCLOSE, LXVCLOSE);
36210      LOCNDEX(LEXCOLON, LXVCOLON);
36220      LOCNDEX(LEXCOMMA, LXVCOMMA);
36230      DEFSYMB(LEXCO2,   LXVCMMENT, '#         ');
36240      DEFSYMB(LEXDIV,   LXVOPR,    '/         ');
36250      DEFSYMB(LEXDVAB,  LXVOPR,    '/:=       ');
36260      DEFSYMB(LEXEQUAL, LXVEQUAL,  '=         ');
36270      LOCNDEX(LEXERROR, LXVERROR);
36280      DEFSYMB(LEXGE,    LXVOPR,    '>=        ');
36290      DEFSYMB(LEXGT,    LXVOPR,    '>         ');
36300      LOCNDEX(LEXIS,    LXVIDTY);
36310      LEXIS^.LXV.LXP := 0;
36320      LOCNDEX(LEXISNT,  LXVIDTY);
36330      LEXISNT^.LXV.LXP := 1;
36340      DEFSYMB(LEXLE,    LXVOPR,    '<=        ');
36350      DEFSYMB(LEXLT,    LXVOPR,    '<         ');
36360      DEFSYMB(LEXMDAB,  LXVOPR,    '%*:=      ');
36370      DEFSYMB(LEXMINUS, LXVOPR,    '-         ');
36380      DEFSYMB(LEXMNAB,  LXVOPR,    '-:=       ');
36390      DEFSYMB(LEXMOD,   LXVOPR,    '%*        ');
36400      DEFSYMB(LEXNE,    LXVOPR,    '/=        ');
36410      LOCNDEX(LEXOPEN,  LXVOPEN);
36420      DEFSYMB(LEXOVAB,  LXVOPR,    '%:=       ');
36430      DEFSYMB(LEXOVER,  LXVOPR,    '%         ');
36440      DEFSYMB(LEXPLAB,  LXVOPR,    '+:=       ');
36450      DEFSYMB(LEXPLTO,  LXVOPR,    '+=:       ');
36460      DEFSYMB(LEXPLUS,  LXVOPR,    '+         ');
36470      DEFSYMB(LEXPLITM, LXVOPR,    '+*        ');
36480        (*LEXPR2 OMITTED*)
36490      LOCNDEX(LEXSEMIC, LXVSEMIC);
36500      LOCNDEX(LEXSTART, LXVSTART);
36510      LOCNDEX(LEXSTICK, LXVSTICK);
36520      LOCNDEX(LEXSTOP,  LXVSTOP);
36530      LOCNDEX(LEXSUBB,  LXVSUB);
36540      DEFSYMB(LEXTIMES, LXVOPR,    '*         ');
36550      DEFSYMB(LEXTMAB,  LXVOPR,    '*:=       ');
36560      DEFSYMB(LEXUP1,   LXVOPR,    '^         ');
36570      DEFSYMB(LEXUP2,   LXVOPR,    '**        ');
36580        END;
36590  (**)
36600    PROCEDURE MAKEPUSHTBL;
36610    (*SET UP PUSHTBL*)
36620      BEGIN
36630      PUSHTBL[LXIOACTPL]  := LEXACTPL;
36640      PUSHTBL[LXIOACTRL]  := LEXACTRL;
36650      PUSHTBL[LXIOBOUNDS] := LEXBOUNDS;
36660      PUSHTBL[LXIOBRINPT] := LEXBRINPT;
36670      PUSHTBL[LXIOBRTHPT] := LEXBRTHPT;
36680      PUSHTBL[LXIOCSTICK] := LEXCSTICK;
36690      PUSHTBL[LXIODCLL]   := LEXDCLL;
36700      PUSHTBL[LXIOFLDSPL] := LEXFLDSPL;
36710      PUSHTBL[LXIOFORDCL] := LEXFORDCL;
36720      PUSHTBL[LXIOFORRLB] := LEXFORRLB;
36730      PUSHTBL[LXIOIDEFL]  := LEXIDEFL;
36740      PUSHTBL[LXIOLABSQ]  := LEXLABSQ;
36750      PUSHTBL[LXIOMOIDDR] := LEXMOIDDR;
36760      PUSHTBL[LXIONONRDR] := LEXNONRDR;
36770      PUSHTBL[LXIOODEFL]  := LEXODEFL;
36780      PUSHTBL[LXIOOPRAND] := LEXOPRAND;
36790      PUSHTBL[LXIOPRIM]   := LEXPRIM;
36800      PUSHTBL[LXIOPRMDRL] := LEXPRMDRL;
36810      PUSHTBL[LXIORIDEFL] := LEXRIDEFL;
36820      PUSHTBL[LXIORODEFL] := LEXRODEFL;
36830      PUSHTBL[LXIORSPEC]  := LEXRSPEC;
36840      PUSHTBL[LXIORVDEFL] := LEXRVDEFL;
36850      PUSHTBL[LXIOTERT]   := LEXTERT;
36860      PUSHTBL[LXIOTRMSCL] := LEXTRMSCL;
36870      PUSHTBL[LXIOUNLC] := LEXUNLC;
36880      PUSHTBL[LXIOUNLP] := LEXUNLP;
36890      PUSHTBL[LXIOUNSR] := LEXUNSR;
36900      PUSHTBL[LXIOVDEFL]  := LEXVDEFL;
36910      END;
36920   PROCEDURE OTPAIRS;
36930    (*SET UP OPCHTABLE*)
36940      BEGIN
36950    (*THE INITIAL ENTRIES TO THIS TABLE (THE ONES LESS INDENTED) DEPEND UPON
36960      THE POSITION OF THE CHARACTER CONCERNED IN THE CHARACTER CODE*)
36970  (*+01() (*BUT ':' OCCUPIES THE POSITION OF '$'*) ()+01*)
36980  (*-01() (*BUT '[', ']' AND '^' OCCUPY THE POSITIONS OF '$', '&' AND ''''*) ()-01*)
36990  (*+01() (*CDC CODE*)
37000      OTPAIR( 0, '+', 37,  0, LEXPLUS);
37010      OTPAIR( 1, '-', 15,  0, LEXMINUS);
37020      OTPAIR( 2, '*', 45,  0, LEXTIMES);
37030      OTPAIR( 3, '/', 42,  0, LEXDIV);
37040      OTPAIR( 4, '(',  0,  0, LEXOPEN);
37050      OTPAIR( 5, ')',  0,  0, LEXCLOSE);
37060      OTPAIR( 6, ':', 27,  0, LEXCOLON);
37070      OTPAIR( 7, '=',  0,  0, LEXEQUAL);
37080        OTPAIR( 8, ':',  0,  0, LEXAGAIN);
37090      OTPAIR( 9, ',',  0,  0, LEXCOMMA);
37100        OTPAIR(10, '=',  0,  0, LEXLE);
37110      OTPAIR(11, '#',  0,  0, LEXCO2);
37120      OTPAIR(12, '[',  0,  0, LEXSUBB);
37130      OTPAIR(13, ']',  0,  0, LEXBUSB);
37140      OTPAIR(14, '%', 32,  0, LEXOVER);
37150        OTPAIR(15, ':', 16,  0, LEXERROR);
37160        OTPAIR(16, '=',  0,  0, LEXMNAB);
37170  (*-51()
37180      OTPAIR(17, '!',  8,  0, LEXSTICK);
37190  ()-51*)
37200  (*+51()
37210      OTPAIR(18, '&',  8,  0, LEXSTICK);
37220      OTPAIR(19, '''', 0,  0, LEXUP1);
37230  ()+51*)
37240      OTPAIR(20, '=',  0,  0, LEXTMAB);
37250      OTPAIR(21, '<', 10, 0, LEXLT);
37260      OTPAIR(22, '>', 24,  0, LEXGT);
37270      OTPAIR(23, '@',  0,  0, LEXAT);
37280        OTPAIR(24, '=',  0,  0, LEXGE);
37290  (*-51()
37300      OTPAIR(25, '^',  0,  0, LEXUP1);
37310  ()-51*)
37320      OTPAIR(26, ';',  0,  0, LEXSEMIC);
37330        OTPAIR(27, '=', 28, 29, LEXBECOM);
37340        OTPAIR(28, ':',  0,  0, LEXIS);
37350        OTPAIR(29, '/', 30,  0, LEXERROR);
37360        OTPAIR(30, '=', 31,  0, LEXERROR);
37370        OTPAIR(31, ':',  0,  0, LEXISNT);
37380   ()+01*)
37390  (*+25() (*CDC CODE*)
37400     OTPAIR( 0, '+', 37,  0, LEXPLUS);
37410      OTPAIR( 1, '-', 15,  0, LEXMINUS);
37420      OTPAIR( 2, '*', 45,  0, LEXTIMES);
37430      OTPAIR( 3, '/', 42,  0, LEXDIV);
37440      OTPAIR( 4, '(',  0,  0, LEXOPEN);
37450      OTPAIR( 5, ')',  0,  0, LEXCLOSE);
37460      OTPAIR( 6, ':', 27,  0, LEXCOLON);
37470      OTPAIR( 7, '=',  0,  0, LEXEQUAL);
37480        OTPAIR( 8, ':',  0,  0, LEXAGAIN);
37490      OTPAIR( 9, ',',  0,  0, LEXCOMMA);
37500        OTPAIR(10, '=',  0,  0, LEXLE);
37510      OTPAIR(11, '#',  0,  0, LEXCO2);
37520      OTPAIR(12, '[',  0,  0, LEXSUBB);
37530      OTPAIR(13, ']',  0,  0, LEXBUSB);
37540      OTPAIR(14, '%', 32,  0, LEXOVER);
37550        OTPAIR(15, ':', 16,  0, LEXERROR);
37560        OTPAIR(16, '=',  0,  0, LEXMNAB);
37570  (*-51()
37580      OTPAIR(17, '!',  8,  0, LEXSTICK);
37590  ()-51*)
37600  (*+51()
37610      OTPAIR(18, '&',  8,  0, LEXSTICK);
37620      OTPAIR(19, '''', 0,  0, LEXUP1);
37630  ()+51*)
37640      OTPAIR(20, '=',  0,  0, LEXTMAB);
37650      OTPAIR(21, '<', 10, 0, LEXLT);
37660      OTPAIR(22, '>', 24,  0, LEXGT);
37670      OTPAIR(23, '@',  0,  0, LEXAT);
37680        OTPAIR(24, '=',  0,  0, LEXGE);
37690  (*-51()
37700      OTPAIR(25, '^',  0,  0, LEXUP1);
37710  ()-51*)
37720      OTPAIR(26, ';',  0,  0, LEXSEMIC);
37730        OTPAIR(27, '=', 28, 29, LEXBECOM);
37740        OTPAIR(28, ':',  0,  0, LEXIS);
37750        OTPAIR(29, '/', 30,  0, LEXERROR);
37760        OTPAIR(30, '=', 31,  0, LEXERROR);
37770        OTPAIR(31, ':',  0,  0, LEXISNT);
37780   ()+25*)
37790  (*-01()  (*ASCII*)
37800  (*-25()
37810      OTPAIR( 0, '!',  1,  0, LEXSTICK); (*!*)
37820        OTPAIR( 1, ':',  0,  0, LEXAGAIN); (*!:*)
37830      OTPAIR( 2, '#',  0,  0, LEXCO2  ); (*#*)
37840      OTPAIR( 3, '[',  0,  0, LEXSUBB ); (*[*)
37850      OTPAIR( 4, '\',  0,  0, LEXSTICK); (*STICK*)
37860      OTPAIR( 5, ']',  0,  0, LEXBUSB ); (*]*)
37870      OTPAIR( 6, '^',  0,  0, LEXUP1  ); (*^*)
37880      OTPAIR( 7, '(',  0,  0, LEXOPEN ); (*(*)
37890      OTPAIR( 8, ')',  0,  0, LEXCLOSE); (*)*)
37900      OTPAIR( 9, '*', 45,  0, LEXTIMES); (***)
37910      OTPAIR(10, '+', 37,  0, LEXPLUS ); (*+*)
37920      OTPAIR(11, ',',  0,  0, LEXCOMMA); (*,*)
37930      OTPAIR(12, '-', 21,  0, LEXMINUS); (*-*)
37940        OTPAIR(13, '=',  0,  0, LEXLE   ); (*<=*)
37950      OTPAIR(14, '/', 42,  0, LEXDIV  ); (* / *)
37960        OTPAIR(15, '=', 16, 17, LEXBECOM);(*:=*)
37970        OTPAIR(16, ':',  0,  0, LEXIS   ); (*:=:*)
37980        OTPAIR(17, '/', 18,  0, LEXERROR);
37990        OTPAIR(18, '=', 19,  0, LEXERROR);
38000        OTPAIR(19, ':',  0,  0, LEXISNT ); (*:/=:*)
38010        OTPAIR(20, '=',  0,  0, LEXTMAB ); (**:=*)
38020        OTPAIR(21, ':', 22,  0, LEXERROR);
38030        OTPAIR(22, '=',  0,  0, LEXMNAB ); (*-:=*)
38040      OTPAIR(23, '%', 32,  0, LEXOVER ); (*%*)
38050        (*SPARE 24*)
38060      OTPAIR(25, ':', 15,  0, LEXCOLON); (*:*)
38070      OTPAIR(26, ';',  0,  0, LEXSEMIC); (*;*)
38080      OTPAIR(27, '<', 13,  0, LEXLT   ); (*<*)
38090      OTPAIR(28, '=',  0,  0, LEXEQUAL); (*=*)
38100      OTPAIR(29, '>', 30,  0, LEXGT   ); (*>*)
38110        OTPAIR(30, '=',  0,  0, LEXGE   ); (*>=*)
38120      OTPAIR(31, '@',  0,  0, LEXAT   ); (*@*)
38130   ()-25*)
38140   ()-01*)
38150        OTPAIR(32, '*', 33, 35, LEXMOD)  ; (*%**)
38160        OTPAIR(33, ':', 34,  0, LEXERROR);
38170        OTPAIR(34, '=',  0,  0, LEXMDAB ); (*%*:=*)
38180        OTPAIR(35, ':', 36,  0, LEXERROR);
38190        OTPAIR(36, '=',  0,  0, LEXOVAB ); (*%:=*)
38200        OTPAIR(37, '=', 38, 39, LEXERROR);
38210        OTPAIR(38, ':',  0,  0, LEXPLTO ); (*+=:*)
38220        OTPAIR(39, ':', 40, 41, LEXERROR);
38230        OTPAIR(40, '=',  0,  0, LEXPLAB ); (*+:=*)
38240        OTPAIR(41, '*',  0,  0, LEXPLITM); (*+**)
38250        OTPAIR(42, '=',  0, 43, LEXNE   ); (*/=*)
38260        OTPAIR(43, ':', 44,  0, LEXERROR);
38270        OTPAIR(44, '=',  0,  0, LEXDVAB ); (*/:=*)
38280        OTPAIR(45, '*',  0, 46, LEXUP2  ); (****)
38290        OTPAIR(46, ':', 20,  0, LEXERROR);
38300      END;
38310    PROCEDURE BOLDWORDS;
38320      BEGIN
38330      INTAB(LEXATB    , 'AT        ', LXVAT);
38340      INTAB(LEXBEGIN  , 'BEGIN     ', LXVBEGIN);
38350      INTAB(LEXBY     , 'BY        ', LXVBY);
38360      INTAB(LEXCASE   , 'CASE      ', LXVCASE);
38370      INTAB(LEXCO     , 'CO        ', LXVCMMENT);
38380      INTAB(LEXCMMENT, 'COMMENT   ', LXVCMMENT);
38390      INTAB(LEXDO     , 'DO        ', LXVDO);
38400      INTAB(LEXELIF   , 'ELIF      ', LXVELIF);
38410      INTAB(LEXELSE   , 'ELSE      ', LXVELSE);
38420      INTAB(LEXEMPTY  , 'EMPTY     ', LXVERROR);
38430      INTAB(LEXEND    , 'END       ', LXVEND);
38440      INTAB(LEXESAC   , 'ESAC      ', LXVESAC);
38450      INTAB(LEXEXIT   , 'EXIT      ', LXVEXIT);
38460      INTAB(LEXFALSE  , 'FALSE     ', LXVBOOLDEN);
38470      INTAB(LEXFI     , 'FI        ', LXVFI);
38480      INTAB(LEXFLEX   , 'FLEX      ', LXVERROR);
38490      INTAB(LEXFOR    , 'FOR       ', LXVFOR);
38500      INTAB(LEXFROM   , 'FROM      ', LXVFROM);
38510      INTAB(LEXGO     , 'GO        ', LXVGO);
38520      INTAB(LEXGOTO   , 'GOTO      ', LXVGOTO);
38530      INTAB(LEXHEAP   , 'HEAP      ', LXVHEAP);
38540      INTAB(LEXIF     , 'IF        ', LXVIF);
38550      INTAB(LEXIN     , 'IN        ', LXVIN);
38560      INTAB(LEXISB    , 'IS        ', LXVIDTY);
38570      INTAB(LEXISNTB  , 'ISNT      ', LXVIDTY);
38580      INTAB(LEXLOC    , 'LOC       ', LXVLOC);
38590      INTAB(LEXLONG   , 'LONG      ', LXVLONG);
38600      INTAB(LEXMODE   , 'MODE      ', LXVMODE);
38610      INTAB(LEXNIL    , 'NIL       ', LXVNIL);
38620      INTAB(LEXOD     , 'OD        ', LXVOD);
38630      INTAB(LEXOF     , 'OF        ', LXVOF);
38640      INTAB(LEXOP     , 'OP        ', LXVOP);
38650      INTAB(LEXOUSE   , 'OUSE      ', LXVOUSE);
38660      INTAB(LEXOUT    , 'OUT       ', LXVOUT);
38670      INTAB(LEXPAR    , 'PAR       ', LXVERROR);
38680      INTAB(LEXPR     , 'PR        ', LXVPRAGMAT);
38690      INTAB(LEXPRAGMAT, 'PRAGMAT   ', LXVPRAGMAT);
38700      INTAB(LEXPRIO   , 'PRIO      ', LXVPRIO);
38710      INTAB(LEXPROC   , 'PROC      ', LXVPROC);
38720      INTAB(LEXREF    , 'REF       ', LXVREF);
38730      INTAB(LEXSEMA   , 'SEMA      ', LXVERROR);
38740      INTAB(LEXSHORT  , 'SHORT     ', LXVSHORT);
38750      INTAB(LEXSKIP   , 'SKIP      ', LXVSKIP);
38760      INTAB(LEXSTRUCT , 'STRUCT    ', LXVSTRUCT);
38770      INTAB(LEXTHEN   , 'THEN      ', LXVTHEN);
38780      INTAB(LEXTO     , 'TO        ', LXVTO);
38790      INTAB(LEXTRUE   , 'TRUE      ', LXVBOOLDEN);
38800      INTAB(LEXUNION  , 'UNION     ', LXVERROR);
38810      INTAB(LEXVOID   , 'VOID      ', LXVVOID);
38820      INTAB(LEXWHILE  , 'WHILE     ', LXVWHILE);
38830      END;
38840  ()+81*)
38850  (*+84()
38860    PROCEDURE INITMODES;
38870      CONST SIMPLE=FALSE; PILE=TRUE; UNDRESSED=FALSE; DRESSED=TRUE; IO=TRUE;
38880          NOIO=FALSE; O=FALSE; SCOPE=TRUE;
38890      VAR I: INTEGER;
38900          PRFB: MODE;
38910          PLX: PLEX; LXEM: LXM; LX: LXM;
38920      PROCEDURE MDVVAL(VAR V: MDM; ID: MDIDTYPE; PILE, DRESSED, IO, SCOPE: BOOLEAN; LENGTH: INTEGER);
38930  (*+02() (*-25() VAR CLEAR: RECORD CASE BOOLEAN OF
38940                             TRUE: (V:MDM); FALSE: (A: ARRAY[1..MODE1SIZE] OF INTEGER) END
38950                      I: INTEGER; ()-25*) ()+02*)
38960        BEGIN
38970  (*+02() (*-25() WITH CLEAR DO FOR I:= 1 TO MODE1SIZE DIV SZWORD DO A[I] := 0;
38980                  V := CLEAR.V;
38990  ()-25*) ()+02*)
39000        WITH V DO
39010          BEGIN MDID := ID; MDLEN := LENGTH;
39020          MDDEPROC := FALSE; MDRECUR := FALSE;
39030          MDDRESSED := DRESSED; MDIO := IO; MDPILE := PILE; MDSCOPE := SCOPE; MDCNT := 0
39040          END
39050        END;
39060      PROCEDURE MDVAR(VAR V: MODE; MDV: MDM);
39070          BEGIN ENEW(V, MODE1SIZE); V^.MDV := MDV END;
39080      PROCEDURE MDIND(TAG: ALFA; M: MODE);
39090        VAR LEX: PLEX; STB: PSTB;
39100          BEGIN
39110          INTAB(LEX,TAG,LX);
39120          LEX^.LXV.LXPMD := M
39130          END;
39140      PROCEDURE PUTFIELD(M: MODE; L: PLEX);
39150          BEGIN
39152          SRSEMP := SRSEMP+2;
39154          SRSTK[SRSEMP-1].MD := M;
39156          SRSTK[SRSEMP].LEX := L ;
39158          END;
39160  (**)
39170        BEGIN
39180        REFL := NIL; ROWL := NIL; PROCL := NIL; PASCL := NIL; STRUCTL := NIL;
39190        MDVVAL(MDVINT   , MDIDINT   , SIMPLE, O        , IO  , O    , SZINT);
39200        MDVVAL(MDVLINT  , MDIDLINT  , SIMPLE, UNDRESSED, IO  , O    , SZLONG);
39210        MDVVAL(MDVREAL  , MDIDREAL  , SIMPLE, O        , IO  , O    , SZREAL);
39220        MDVVAL(MDVLREAL , MDIDLREAL , SIMPLE, UNDRESSED, IO  , O    , 2*SZREAL);
39230        MDVVAL(MDVCHAR  , MDIDCHAR  , SIMPLE, O        , IO  , O    , SZWORD);
39240        MDVVAL(MDVBITS  , MDIDBITS  , SIMPLE, O        , IO  , O    , SZINT);
39250        MDVVAL(MDVBYTES , MDIDBYTES , SIMPLE, O        , IO   ,O    , SZINT);
39260        MDVVAL(MDVSTRNG , MDIDSTRNG , PILE  , DRESSED  , IO  , O    , SZADDR);
39270        MDVVAL(MDVBOOL  , MDIDBOOL  , SIMPLE, O        , IO  , O    , SZWORD);
39280        MDVVAL(MDVCHAN  , MDIDCHAN  , SIMPLE, O        , NOIO, O    , SZPROC);
39290        MDVVAL(MDVCOVER , MDIDCOVER , PILE  , DRESSED  , NOIO, O    , SZADDR);
39300        MDVVAL(MDVVOID  , MDIDVOID  , O     , O        , NOIO, O    , 0);
39310        MDVVAL(MDVSKIP  , MDIDSKIP  , O     , O        , NOIO, O    , 0);
39320        MDVVAL(MDVJUMP  , MDIDJUMP  , O     , O        , NOIO, O    , 0);
39330        MDVVAL(MDVNIL   , MDIDNIL   , O     , O        , NOIO, O    , 0);
39340        MDVVAL(MDVOUT   , MDIDOUT   , O     , O        , O   , O    , SZWORD+SZINT);
39350        MDVVAL(MDVIN    , MDIDIN    , O     , O        , O   , SCOPE, 2*SZWORD+SZADDR);
39360        MDVVAL(MDVOUTB  , MDIDOUTB  , O     , O        , O   , O    , SZWORD+SZINT);
39370        MDVVAL(MDVINB   , MDIDINB   , O     , O        , O   , SCOPE, SZWORD+SZADDR);
39380        MDVVAL(MDVNUMBER, MDIDNUMBER, O     , O        , O   , O    , SZWORD+SZINT);
39390        MDVVAL(MDVROWS  , MDIDROWS  , PILE  , DRESSED  , O   , O    , SZADDR);
39400        MDVVAL(MDVBNDS  , MDIDBNDS  , PILE  , O        , NOIO, O    , SZADDR);
39410        MDVVAL(MDVABSENT, MDIDABSENT, SIMPLE, O        , O   , O    , SZWORD);
39420                     (*CAN BE USED TO MANUFACTURE UN-USER-FORGEABLE STRUCTURES*)
39430        MDVVAL(MDVERROR , MDIDERROR , SIMPLE, O        , O   , O    , SZWORD);
39440        MDVVAL(MDVPROC  , MDIDPROC  , PILE  , DRESSED  , NOIO, SCOPE, SZADDR);
39450        MDVVAL(MDVREF   , MDIDREF   , PILE  , DRESSED  , NOIO, SCOPE, SZADDR);
39460        MDVVAL(MDVSTRUCT, MDIDSTRUCT, PILE  , UNDRESSED, NOIO, SCOPE, 0);
39470        MDVVAL(MDVROW   , MDIDROW   , PILE  , O        , NOIO, SCOPE, 0);
39480        MDVVAL(MDVPASC  , MDIDPASC  , SIMPLE, O        , NOIO, O    , SZPROC);
39500      (*SET UP MD VALUES*)
39510        MDVAR(MDINT   , MDVINT);
39520        MDVAR(MDLINT  , MDVLINT);
39530        MDVAR(MDBITS  , MDVBITS);
39540        MDVAR(MDBYTES , MDVBYTES);
39550        MDVAR(MDREAL  , MDVREAL);
39560        MDVAR(MDLREAL , MDVLREAL);
39570        MDVAR(MDBOOL  , MDVBOOL);
39580        MDVAR(MDCHAN  , MDVCHAN);
39590        MDVAR(MDCHAR  , MDVCHAR);
39600        MDVAR(MDSTRNG, MDVSTRNG);
39610        MDVAR(MDCOVER , MDVCOVER);
39620        MDVAR(MDVOID  , MDVVOID);
39630        MDVAR(MDSKIP  , MDVSKIP);
39640        MDVAR(MDJUMP  , MDVJUMP);
39650        MDVAR(MDNIL   , MDVNIL);
39660        MDVAR(MDOUT   , MDVOUT);
39670        MDVAR(MDIN    , MDVIN);
39680        MDVAR(MDOUTB  , MDVOUTB);
39690        MDVAR(MDINB   , MDVINB);
39700        MDVAR(MDNUMBER, MDVNUMBER);
39710        MDVAR(MDROWS  , MDVROWS);
39720        MDVAR(MDBNDS  , MDVBNDS);
39730        MDVAR(MDABSENT, MDVABSENT);
39740        MDVAR(MDROUT  , MDVPROC);
39750        MDVAR(MDERROR , MDVERROR);
39760        INTAB(PLX,'GO        ',LXEM);
39770        PLX^.LXV.LXPMD := MDJUMP;
39780        INTAB(PLX,'GOTO      ',LXEM);
39790        PLX^.LXV.LXPMD := MDJUMP;
39800        INTAB(PLX,'IS        ',LXEM);
39810        PLX^.LXV.LXP := 0;
39820        INTAB(PLX,'ISNT      ',LXEM);
39830        PLX^.LXV.LXP := 1;
39840        INTAB(PLX,'NIL       ',LXEM);
39850        PLX^.LXV.LXPMD := MDNIL;
39860        INTAB(PLX,'SKIP      ',LXEM);
39870        PLX^.LXV.LXPMD := MDSKIP;
39880        INTAB(PLX,'VOID      ',LXEM);
39890        PLX^.LXV.LXPMD := MDVOID;
39900        MDREFERROR := FINDREF(MDERROR);
39910        PRCBNDS := DEFPRC0(MDBNDS, PROC);
39920        PRCERROR := DEFPRC0(MDERROR, PROC);
39930        SRSEMP := -1; SRSUBP := 0; SUBSAVE;
39940        PUTFIELD(MDREAL, DEFTAG('RE        '));
39950        PUTFIELD(MDREAL, DEFTAG('IM        '));
39960        FINSTRUCT(2); MDCOMPL := SRSTK[SRSEMP].MD;
39970        (*MDLCOMPL OUGHT TO BE DONE ONE OF THESE DAYS, TOO*)
39980        MDFILE := NIL; (*BECAUSE IT IS TO BE A RECURSIVE MODE*)
39990        PRFB := DEFPRC1(FINDREF(MDFILE), MDBOOL, PROC);
40000        SRSEMP := -1; SRSUBP := 0; SUBSAVE;
40010        FOR I := 1 TO 4 DO
40020          PUTFIELD(PRFB, LEXALEPH);
40030        PUTFIELD(MDCOVER, LEXALEPH);
40040        FOR I := 1 TO SZTERM DIV SZINT DO
40050          PUTFIELD(MDINT, LEXALEPH);
40060        FINSTRUCT(5+SZTERM DIV SZINT); MDFILE := SRSTK[SRSEMP].MD;
40070        PRCVF := DEFPRC1(FINDREF(MDFILE), MDVOID, PROC);
40080        PASCVF := DEFPRC1(FINDREF(MDFILE), MDVOID, PASC);
40090        ROWBOOL := FINDROW(MDBOOL,1);
40100        ROWCHAR := FINDROW(MDCHAR,1);
40110        ROWIN := FINDROW(MDIN,1);
40120        ROWINB := FINDROW(MDINB,1);
40130        REFSTRNG := FINDREF(MDSTRNG);
40140  (*+54()
40150        SRSEMP := -1; SRSUBP := 0; SUBSAVE;
40160        PUTFIELD(MDINT, DEFTAG('ALEPH     '));
40170        PUTFIELD(MDABSENT, LEXALEPH);
40180        FINSTRUCT(2); MDEXC := SRSTK[SRSEMP].MD;
40190  ()+54*)
40200      (*SET UP STANDARD-PRELUDE MODE-INDICATIONS*)
40210          LXVVAL(LX,LXIOPRDR,0,2,08);
40220        MDIND('INT       ', MDINT);
40230        MDIND('BITS      ', MDBITS);
40240        MDIND('BYTES     ', MDBYTES);
40250        MDIND('REAL      ', MDREAL);
40260        MDIND('BOOL      ', MDBOOL);
40270        MDIND('CHANNEL   ', MDCHAN);
40280        MDIND('CHAR      ', MDCHAR);
40290        MDIND('STRING    ', MDSTRNG);
40300        MDIND('FILE      ', MDFILE);
40310        MDIND('COMPL     ', MDCOMPL);
40320  (*+54() MDIND('EXCEPTION ', MDEXC); ()+54*)
40330        MODEID[MDIDINT]:=0;
40340        MODEID[MDIDLINT]:=1;
40350        MODEID[MDIDREAL]:=2;
40360        MODEID[MDIDLREAL]:=3;
40370        MODEID[MDIDCHAR]:=6;
40380        MODEID[MDIDBITS]:=9;
40390        MODEID[MDIDBYTES]:=10;
40400        MODEID[MDIDSTRNG]:=7;
40410        MODEID[MDIDBOOL]:=8;
40420        MODEID[MDIDCHAN]:=-1;
40430        MODEID[MDIDCOVER]:=-1;
40440        MODEID[MDIDVOID]:=-1;
40450        MODEID[MDIDSKIP]:=-1;
40460        MODEID[MDIDJUMP]:=-1;
40470        MODEID[MDIDNIL]:=-1;
40480        MODEID[MDIDOUT]:=-1;
40490        MODEID[MDIDIN]:=-1;
40500        MODEID[MDIDOUTB]:=-1;
40510        MODEID[MDIDINB]:=-1;
40520        MODEID[MDIDNUMBER]:=-1;
40530        MODEID[MDIDROWS]:=-1;
40540        MODEID[MDIDBNDS]:=-1;
40550        MODEID[MDIDABSENT]:=-1;
40560        MODEID[MDIDPROC]:=11;
40570        MODEID[MDIDREF]:=-1;
40580        MODEID[MDIDSTRUCT]:=12;  (*BUT NOT COMPL*)
40590        MODEID[MDIDROW]:=13;
40600        MODEID[MDIDPASC]:=14;
40620        XMODES[XINT] := MDINT;
40630        XMODES[XLINT] := MDLINT;
40640        XMODES[XREAL] := MDREAL;
40650        XMODES[XLREAL] := MDLREAL;
40660        XMODES[XCOMPL] := MDCOMPL;
40670  (*+61()
40680        XMODES[XLCOMPL] := MDLCOMPL;
40690  ()+61*)
40700        XMODES[XCHAR] := MDCHAR;
40710        XMODES[XSTRNG] := MDSTRNG;
40720        XMODES[XBOOL] := MDBOOL;
40730        XMODES[XBITS] := MDBITS;
40740        XMODES[XBYTES] := MDBYTES;
40750        END;
40760  (**)
40770  ()+84*)
40780  (**)
40790      BEGIN (*INITIALIZE*)
40800  (*+81()
40810      INITLEXES;
40820      MAKEPUSHTBL;
40830  (**)
40840      OTPAIRS;
40850      FOR I := 0 TO HTSIZE DO
40860        HT[I] := NIL;
40870      INPRAGMENT := FALSE;
40880      ENEW(LEXALEPH, LEX1SIZE); WITH LEXALEPH^ DO
40890        BEGIN LXV:=LXVTAG; LXCOUNT:=0; LXTOKEN:=TKTAG END;
40900        BOLDWORDS;
40910  ()+81*)
40920  (*+84() INITMODES; ()+84*)
40930  (*+84()
40940      ENEW(LEXONE, SZADDR+SZINT+LEX1SIZE); WITH LEXONE^ DO
40950        BEGIN LXV:=LXVPRDEN; LXCOUNT:= (SZADDR+SZINT) DIV SZWORD; LXTOKEN:=TKDENOT; LXDENRP:=1; LXDENMD:=MDINT END;
40960  ()+84*)
40970      END;
40980  (**)
40990  ()+83*)