40000     (*  COPYRIGHT 1983 C.H.LINDSEY, UNIVERSITY OF MANCHESTER  *)
40001 THINGS NEEDING ATTENTION
40002     CHECK THE START OF THE LOCAL POPS
40003     ATTEND TO PDUP1PILE AND P2DUP2PILE
40010 (**)
40020 (**)
40040 (*+05()
40050 (*+86()
40100     (*************************)
40110     (* MEANING OF PARAMTYPES *)
40120     (*************************)
40130 (**)
40140 (* OPX - OPERAND SUPPLIED BY CODE GENERATOR
40150    ONX - NEGATIVE OF OPERAND SUPPLIED BY CODE GENERATOR
40160    LCX - LOCAL INSTRUCTION LABEL
40170    GBX - GLOBAL INSTRUCTION LABEL
40180    WOP - OPERAND SUPPLIED BY CODETABLE
40190    WNP - NEGATIVE OF OPERAND SUPPLIED BY CODETABLE
40200    NON - NO OPERAND
40210    JMP - FORWARD JUMP WITHIN CODETABLE
40220    ANP - AS WNP, BUT PROVIDES LAST OPERAND FOR AN OCODE
40230    ACP - AS WOP, BUT DITTO
40240    ACX - AS OPX, BUT DITTO
40250    ANX - AS ONX, BUT DITTO
40252    MOR - LONG OPERAND TO BE FOUND IN THE NEXT OPCOD
40260 *)
40270 (**)
46726 (**)
46728 PROCEDURE INITCODES;
46730 (*INITIALISES CODETABLE+)
46732 CONST
46734 (**)
46736  PLOADRTA(*3*)=194; PDEPROC=197;
46737 PLOADE(*3*)=198; PLOADEIM(*2*)=201; PETOSTK(*3*)=203; PS4TOS2=206; PPUSHIM2(*2*)=207;
46738 PPUSHFSTK=209; PPUSHFSTK1=210; PLOADF=211; PLOADF1=212; QPUSHIM2(*2*)=213;
46739 PLOADFIM=215; PLOADFIM1=216; PLOADFSTK=217; PLOADFSTK1=218; PSTOS4=219; PPUSHF=220; PPUSHF1=221;
46740 PF0TOF1=222; PF1TOF0=223; PPUSH2(*3*)=224; PSTOS2=227; PPUSHER0=228; PLOADER0F0=229; PLOADER0F1=230;
46741 PLOADER0STK=231;  QPUSHER0(*2*)=232; QLPINIT(*8*)=234; QDIV(*2*)=242; QCALL(*8*)=244;
46742 QABSI(*7*)=252;
46743 QRNSTART=259; QHOIST(*3*)=260; QSCOPEVAR(*6*)=263; QENVCHAIN=269;
46744 QIPUSH=270; QODD=271; QLEBT(*2*)=272; QLINE=274; QDATALIST=275; QGETPROC(*4*)=276;
46745 QNOTB=280; QPUSH1=281; QCAS(*3*)=282;
46746 QLOOPINCR(*6*)=285; QDCLSP(*4*)=291; QDCLINIT(*2*)=295;
46747  QELMBT(*5*)=297; QDUP1ST=302; QDUP2ND=303;
46748 QASGVART(*3*)=304; QRANGENT(*2*)=307;
46749 QNAKEDPTR=309; QLOADI=310; QADJSP2=311; QSTKTOE(*3+)=312; QADJSP4=315;
46750 QLOADF=316; QLOADF1=317; QLOADVAR(*6*)=318; QPUSH2(*4*)=324;
46751 QLOADRTA(*2*)=328; QCFSTRNG(*2*)=330; QRANGEXT(*3*)=332; QCALLA(*4*)=335;
46752 QSETIB=339; QSELECT(*3*)=340; (*SPARE(3)=343;*) QCOLLTOTAL(*11*)=346;
46753 QETOSTK(*6*)=357; QGETTOTAL(*5*)=363; (*SPARE(7)=368;*) QHEAVE(*6*)=375; QLOADER0STK(*6*)=381;
46754 QGETTOTCMN(*4*)=387; (*SPARE=391..400*)
46755             ST=SBTSTK; STP=SBTSTK; STS=SBTSTK;
46756             ST4=SBTSTK4; S4P=SBTSTK4; S4S=SBTSTK4;
46758             STN=SBTSTKN; SNP=SBTSTKN; SNS=SBTSTKN;
46760             PR1=SBTPR1;  PR2=SBTPR2;
46761             FP0=SBTFPR0; FP1=SBTFPR1; FP2=SBTFPR2; FP3=SBTFPR3; F0P=SBTFPR0;
46764             XN=SBTXN;
46770             O=SBTVOID; SDL=SBTDL; E=SBTE; ER0=SBTER0;
46780 (*+)
46790   PROCEDURE ICODE(OPCOD:POP;PERQCODE:MNEMONICS;TYP:PARAMTYPES;PM:INTEGER;PNXT:POP;VP1,VP2,VPR:  SBTTYP);
46800       BEGIN
46810       WITH CODETABLE[OPCOD] DO
46820         BEGIN
46830         INLINE := TRUE;
46840         PERQCOD := PERQCODE;
46850         P1 := VP1;
46860         P2 := VP2;
46870         PR := VPR;
46880         NEXT := PNXT;
46890         PARTYP := TYP;
46900         PARM := PM;
46930         END;
46950       END;
46960 (*+)
46970   PROCEDURE QCODE(OPCOD:POP;PERQCODE:MNEMONICS;TYP:PARAMTYPES;PM:INTEGER;PNXT:POP);
46980       BEGIN
46990       ICODE(OPCOD,PERQCODE,TYP,PM,PNXT,O,O,O);
47000       END;
47010 (*+)
47020   PROCEDURE OCODE(OPCOD:POP;PROUTINE:ALFA;VP1,VP2,VPR:SBTTYP);
47030     VAR I:INTEGER;
47040       BEGIN
47050       WITH CODETABLE[OPCOD] DO
47060         BEGIN
47070         INLINE := FALSE;
47080         P1 := VP1;
47090         P2 := VP2;
47100         PR := VPR;
47110         IF (P1=O) AND (P2 <> O) THEN WRITELN(OUTPUT,'FAILED OCODE-A');
47120         FOR I := 1 TO 7 DO
47124           ROUTINE[I] := PROUTINE[I];
47130         END;
47140       END;
47150   PROCEDURE FIRSTPART;
47160     VAR I:INTEGER;
47170       BEGIN
47180         FOR I := PNONE TO PLAST DO OCODE(I,'DUMMY     ',O,O,O);
47182         OCODE(PPBEGIN+1  , 'ESTART_   '                         , O , O , O );
47185         OCODE(PPBEGIN    , 'START68   '                         , O , O , O );
47190         OCODE(PPEND      , 'STOP68    '                         , O , O , O );
47210         ICODE(PABSI      ,  'DUPL    ' , NON , 0 ,QABSI         , E , O , E );
47215         QCODE(QABSI      ,  'CI      ' , WOP , 0 ,QABSI+1                   );
47220         QCODE(QABSI+1    ,  'IJGE    ' , JMP , 2 ,QABSI+2                   );
47230         QCODE(QABSI+2    ,  'INEG    ' , NON , 0 ,0                         );
47240         ICODE(PABSI-2    ,  'CI      ' , WOP , 0 ,QABSI+3       ,FP0, O ,FP0);
47250         QCODE(QABSI+3    ,  'FLOAT   ' , WOP , 3 ,QABSI+4);
47260         QCODE(QABSI+4    ,  'RGE 0,3 ' , NON , 0 ,QABSI+5);
47270         QCODE(QABSI+5    ,  'JTRUE   ' , JMP , 2 ,QABSI+6);
47272         QCODE(QABSI+6    ,  'RNEG    ' , WOP , 0 ,0);
47274         OCODE(PABSI-4     , 'CABSI     '                        ,PR1,O  ,E  );
47280         ICODE(PABSB      ,  'NULL    ' , NON , 0 ,0             , E , O , E );
47290         ICODE(PABSB-1    ,  'NULL    ' , NON , 0 ,0             , E , O , E );
47300         ICODE(PABSCH     ,  'NULL    ' , NON , 0 ,0             ,ST , O ,ST );
47310         ICODE(PADD       ,  'IADD    ' , NON , 0 ,0             , E , E , E );
47320         ICODE(PADD-2     ,  'RADD 0,1' , NON , 0 ,0             ,FP0,FP1,FP0);
47325         OCODE(PADD-4      , 'CPLUS     '                        ,PR1,PR2, E );
47330 (*+61()
47340         ICODE(PADD-3     ,  '?ADD-3  ' , WOP , 8 ,0             ,ST4,ST4,ST4);
47350 ()+61+)
47360         ICODE(PANDB      ,  'ILAND   ' , NON , 0 ,0             , E , E , E );
47370         ICODE(PANDB-1    ,  'ILAND   ' , NON , 0 ,0             , E , E , E );
47375         OCODE(PARG       ,  'CARG      '                        ,PR1, O , E );
47380         ICODE(PBIN       ,  'NULL    ' , NON , 0 ,0             , E , O , E );
47390         OCODE(PCAT       , 'CATCC     '                         ,PR1,PR2, E );
47400         OCODE(PCAT-1     , 'CATSS     '                         ,PR1,PR2, E );
47405         OCODE(PCONJ      , 'CCONJ     '                         ,PR1, O , E );
47410         ICODE(PDIV       ,  'FLOAT   ' , WOP , 3 ,QDIV          , E , E ,FP0);
47412         QCODE(QDIV       ,  'FLOAT   ' , WOP , 0 ,QDIV+1);
47414         QCODE(QDIV+1     ,  'RDIV 0,3' , NON , 0 ,0);
47420         ICODE(PDIV-2     ,  'RDIV 0,1' , NON , 0 ,0             ,FP0,FP1,FP0);
47425         OCODE(PDIV-4      , 'CDIV      '                        ,PR1,PR2, E );
47430         ICODE(PDIVAB     ,  'RDIV 0,1' , NON , 0 ,0             ,FP0,FP1,FP0);
47435         OCODE(PDIVAB-2    , 'CDIVAB    '                        ,PR1,PR2, E );
47440         ICODE(PELMBT     ,  'EXCH    ' , NON , 0 ,QELMBT        , E , E , E );
47450         QCODE(QELMBT     ,  'CI      ' , WOP , 1 ,QELMBT+1);
47452         QCODE(QELMBT+1   ,  'ISUB    ' , NON , 0 ,QELMBT+2);
47460         QCODE(QELMBT+2   ,  'ISLLT   ' , NON , 0 ,QELMBT+3);
47470         QCODE(QELMBT+3   ,  'CI      ' , WOP , 0 ,QELMBT+4);
47472         QCODE(QELMBT+4   ,  'IGT     ' , NON , 0 ,0);
47480         OCODE(PELMBY     , 'ELMBY     '                         ,PR1,PR2, E );
47490         OCODE(PENTI      , 'ENTIER    '                         ,PR1, O , E );
47500         ICODE(PEQ        ,  'IEQ     ' , NON , 0 ,0             , E , E , E );
47520         ICODE(PEQ-2      ,  'REQ 0,1 ' , NON , 0 ,0             ,FP0,FP1, E );
47525         OCODE(PEQ-4       , 'CEQ       '                        ,PR1,PR2, E );
47530         ICODE(PEQB       ,  'IEQ     ' , NON , 0 ,0             , E , E , E );
47540         ICODE(PEQB-1     ,  'IEQ     ' , NON , 0 ,0             , E , E , E );
47550         ICODE(PEQB-2     ,  'IEQ     ' , NON , 0 ,0             , E , E , E );
47560         ICODE(PEQCS      ,  'IEQ     ' , NON , 0 ,0             , E , E , E );
47570         ICODE(PEQCS-1    ,  'CI      ' , ACP , 2 ,QCFSTRNG      ,PR1,PR2, E );
47590         OCODE(PEXP       ,  'POWI      '                        ,PR1,PR2, E );
47600         OCODE(PEXP-2     ,  'POWR      '                        ,PR1,PR2,FP0);
47605         OCODE(PEXP-4     ,  'CPOW      '                        ,PR1,PR2, E );
47610         ICODE(PPASC      ,  'CALL    ' , OPX , 0 ,0             ,SDL, O , E );
47620         ICODE(PPASC+1    ,  'CALL    ' , OPX , 0 ,0             ,PR1, O , E );
47670         ICODE(PGE        ,  'ILE     ' , NON , 0 ,0             , E , E , E );
47680         ICODE(PGE-2      ,  'RGE 0,1 ' , NON , 0 ,0             ,FP0,FP1, E );
47690         ICODE(PGEBT      ,  'EXCH    ' , NON , 0 ,PLEBT         , E , E , E );
47700         ICODE(PGEBT-1    ,  'ILE     ' , NON , 0 ,0             , E , E , E );
47710         ICODE(PGECS      ,  'ILE     ' , NON , 0 ,0             , E , E , E );
47720         ICODE(PGECS-1    ,  'CI      ' , ACP , 4 ,QCFSTRNG      ,PR1,PR2, E );
47740         ICODE(PGT        ,  'ILT     ' , NON , 0 ,0             , E , E , E );
47760         ICODE(PGT-2      ,  'RGT 0,1 ' , NON , 0 ,0             ,FP0,FP1, E );
47770         ICODE(PGTBY      ,  'ILT     ' , NON , 0 ,0             , E , E , E );
47780         ICODE(PGTCS      ,  'ILT     ' , NON , 0 ,0             , E , E , E );
47790         ICODE(PGTCS-1    ,  'CI      ' , ACP , 5 ,QCFSTRNG      ,PR1,PR2, E );
47795         OCODE(PIM         , 'CIM       '                        ,PR1, O , E );
47800         ICODE(PLE        ,  'IGE     ' , NON , 0 ,0             , E , E , E );
47820         ICODE(PLE-2      ,  'RLE 0,1 ' , NON , 0 ,0             ,FP0,FP1, E );
47830         ICODE(PLEBT      ,  'ILNOT   ' , NON , 0 ,QLEBT         , E , E , E );
47832         QCODE(QLEBT      ,  'ILAND   ' , NON , 0 ,QLEBT+1);
47834         QCODE(QLEBT+1    ,  'INOT    ' , NON , 0 ,0);
47840         ICODE(PLEBT-1    ,  'ILE     ' , NON , 0 ,0             , E , E , E );
47850         ICODE(PLECS      ,  'IGE     ' , NON , 0 ,0             , E , E , E );
47860         ICODE(PLECS-1    ,  'CI      ' , ACP , 1 ,QCFSTRNG      ,PR1,PR2, E );
47920         ICODE(PLT        ,  'IGT     ' , NON , 0 ,0             , E , E , E );
47940         ICODE(PLT-2      ,  'RLT 0,1 ' , NON , 0 ,0             ,FP0,FP1, E );
47950         ICODE(PLTBY      ,  'IGT     ' , NON , 0 ,0             , E , E , E );
47960         ICODE(PLTCS      ,  'IGT     ' , NON , 0 ,0             , E , E , E );
47970         ICODE(PLTCS-1    ,  'CI      ' , ACP , 0 ,QCFSTRNG      ,PR1,PR2, E );
47980         OCODE(PLWBMSTR   , 'LWBMSTR   '                         ,PR1, O , E );
47990         OCODE(PLWBM      , 'LWBM      '                         ,PR1, O , E );
48000         OCODE(PLWB       , 'LWB       '                         ,PR1,PR2, E );
48010         ICODE(PMINUSAB   ,  'ISUB    ' , NON , 0 ,0             , E , E , E );
48020         ICODE(PMINUSAB-2 ,  'RSUB 0,1' , NON , 0 ,0             ,FP0,FP1,FP0);
48025         OCODE(PMINUSAB-4  , 'CMINAB    '                        ,PR1,PR2, E );
48030         OCODE(PMOD       , 'MOD       '                         ,PR1,PR2, E );
48040         OCODE(PMODAB     , 'MOD       '                         ,PR1,PR2, E );
48050         ICODE(PMUL       ,  'IMULT   ' , NON , 0 ,0             , E , E , E );
48060         ICODE(PMUL-2     ,  'RMULT 0,' , WOP , 1 ,0             ,FP0,FP1,FP0);
48070 (*+61()
48080         ICODE(PMUL-3     ,  '?MUL-3  ' , WOP , 8 ,0             ,ST4,ST4,ST4);
48090 ()+61+)
48095         OCODE(PMUL-4     , 'CTIMS     '                         ,PR1,PR2, E );
48100         OCODE(PMULCI     , 'MULCI     '                         ,PR1,PR2, E );
48110         OCODE(PMULCI-1   , 'MULSI     '                         ,PR1,PR2, E );
48120         OCODE(PMULIC     , 'MULIC     '                         ,PR1,PR2, E );
48130         OCODE(PMULIC-1   , 'MULIS     '                         ,PR1,PR2, E );
48140         END;
48150  PROCEDURE SECONDPART;
48160         BEGIN
48170         ICODE(PNE        ,  'INE     ' , NON , 0 ,0             , E , E , E );
48190         ICODE(PNE-2      ,  'RNE 0,1 ' , NON , 0 ,0             ,FP0,FP1, E );
48195         OCODE(PNE-4       , 'CNE       '                        ,PR1,PR2, E );
48210         ICODE(PNEB       ,  'INE     ' , NON , 0 ,0             , E , E , E );
48220         ICODE(PNEB-1     ,  'INE     ' , NON , 0 ,0             , E , E , E );
48230         ICODE(PNEB-2     ,  'INE     ' , NON , 0 ,0             , E , E , E );
48240         ICODE(PNECS      ,  'INE     ' , NON , 0 ,0             , E , E , E );
48250         ICODE(PNECS-1    ,  'CI      ' , ACP , 3 ,QCFSTRNG      ,PR1,PR2, E );
48252         ICODE(PNEGI      ,  'INEG    ' , NON , 0 ,0             , E , O , E );
48260         ICODE(PNEGI-2    ,  'RNEG    ' , WOP , 0 ,0             ,FP0, O ,FP0);
48265         OCODE(PNEGI-4     , 'CNEGI     '                        ,PR1,PR2, E );
48270         ICODE(PNOTB      ,  'INOT    ' , NON , 0 ,0             , E , O , E );
48290         ICODE(PNOTB-1    ,  'ILNOT   ' , NON , 0 ,0             , E , O , E );
48300         ICODE(PNOOP      ,  'NULL    ' , NON , 0 ,0             , E , O ,ST );
48310         ICODE(PNOOP-2    ,  'NULL    ' , NON , 0 ,0             ,FP0, O ,ST );
48320         ICODE(PNOOP-4    ,  'NULL    ' , NON , 0 ,0             , E , O ,ST );
48330         ICODE(PODD       ,  'CI      ' , WOP , 1 ,QODD          , E , O , E );
48340         QCODE(QODD       ,  'ILAND   ' , NON , 0 ,0                         );
48350         ICODE(PORB       ,  'ILOR    ' , NON , 0 ,0             , E , E , E );
48360         ICODE(PORB-1     ,  'ILOR    ' , NON , 0 ,0             , E , E , E );
48370         ICODE(POVER      ,  'IDIV    ' , NON , 0 ,0             , E , E , E );
48380         ICODE(POVERAB    ,  'IDIV    ' , NON , 0 ,0             , E , E , E );
48385         OCODE(PPLITM      , 'CRCOMPLEX '                        ,PR1,PR2, E );
48390         ICODE(PPLSAB     ,  'IADD    ' , NON , 0 ,0             , E , E , E );
48400         ICODE(PPLSAB-2   ,  'RADD 0,1' , NON , 0 ,0             ,FP0,FP1,FP0);
48410 (*+61()
48420         ICODE(PPLSAB-3   ,  '?PLSAB-3' , WOP , 8 ,0             ,ST4,ST4,ST4);
48430 ()+61+)
48435         OCODE(PPLSAB-4    , 'CPLUSAB   '                        ,PR1,PR2, E );
48440         OCODE(PPLSABS    , 'PLABSS    '                         ,PR1,PR2, E );
48450         OCODE(PPLSABS-1  , 'PLABSS    '                         ,PR1,PR2, E );
48460         OCODE(PPLSTOCS   , 'PLTOSS    '                         ,PR1,PR2, E );
48470         OCODE(PPLSTOCS-1 , 'PLTOSS    '                         ,PR1,PR2, E );
48475         OCODE(PRE        , 'CRE       '                         ,PR1,O  , E );
48480         ICODE(PREPR      ,  'NULL    ' , NON , 0 ,0             , E , E , E );
48490         ICODE(PROUN      ,  'ROUND   ' , WOP , 0 ,0             ,FP0, O , E );
48500         OCODE(PSGNI      , 'SIGNI     '                         ,PR1, O , E );
48510         OCODE(PSGNI-2    , 'SIGNR     '                         ,PR1, O , E );
48520         OCODE(PSHL       , 'SHL       '                         ,PR1,PR2, E );
48530 (*+61()
48540         ICODE(PSHRTR     ,  '?SHRTR  ' , WOP , 8 ,QSHRTR        ,ST4, O ,ST2);
48550         QCODE(QSHRTR     ,  'RUBBISH ' , WOP , 4 ,QSHRTR+1                  );
48560         QCODE(QSHRTR+1   ,  'RUBBISH ' , NON , 0 ,0                         );
48570 ()+61+)
48580         OCODE(PSHR       , 'SHR       '                         ,PR1,PR2, E );
48590         ICODE(PSUB       ,  'ISUB    ' , NON , 0 ,0             , E , E , E );
48600         ICODE(PSUB-2     ,  'RSUB 0,1' , NON , 0 ,0             ,FP0,FP1, FP0);
48605         OCODE(PSUB-4     , 'CMINUS    '                         ,PR1,PR2, E );
48610         ICODE(PTIMSAB    ,  'IMULT   ' , NON , 0 ,0             , E , E , E );
48620         ICODE(PTIMSAB-2  ,  'RMULT 0,' , WOP , 1 ,0             ,FP0,FP1,FP0);
48630 (*+61()
48640         ICODE(PTIMSAB-3  ,  '?TIMSAB-' , WOP , 8 ,0             ,ST4,ST4,ST4);
48650 ()+61+)
48655         OCODE(PTIMSAB-4  , 'CTIMSAB   '                         ,PR1,PR2, E );
48660         OCODE(PTIMSABS   , 'MULABSI   '                         ,PR1,PR2, E );
48670         OCODE(PUPBMSTR   , 'UPBMSTR   '                         ,PR1, O , E );
48680         OCODE(PUPBM      , 'UPBM      '                         ,PR1, O , E );
48690         OCODE(PUPB       , 'UPB       '                         ,PR1,PR2, E );
48696         QCODE(QCFSTRNG   ,  'IPUSH   ' , NON , 0 ,QCFSTRNG+1);
48700         OCODE(QCFSTRNG+1 , 'CFSTR     '                         , O , O , O );
48730         ICODE(PSELECT    ,  ' SR0    ' , NON , 0 ,QSELECT       , E , O ,ER0);
48731         QCODE(QSELECT    ,  'LRO0    ' , WOP , 6 ,PSELECT+2);
48734         ICODE(PSELECT+1  ,  ' SR0    ' , NON , 0 ,QSELECT+1     , E , O ,ER0);
48736         QCODE(QSELECT+1  ,  'CI      ' , OPX , 6 ,0);
48740         ICODE(PSELECT+2  ,  'CI      ' , OPX , 0 ,QSELECT+2     ,ER0, O ,ER0);
48742         QCODE(QSELECT+2  ,  'IADD    ' , NON , 0 ,0);
48760         OCODE(PSELECTROW , 'SELECTR   '                         ,PR1, O , E );
48770         OCODE(PSTRNGSLICE, 'STRSUB    '                         ,PR1,PR2, E );
48780         OCODE(PSTRNGSLICE+1, 'STRTRIM   '                       ,PR1, O , E );
48790         OCODE(PSTARTSLICE, 'STARTSL   '                         , O , O , O );
48800         OCODE(PSLICE1    , 'SLICE1    '                         , E , E ,ER0);
48810         OCODE(PSLICE2    , 'SLICE2    '                         , E , E ,ER0);
48820         OCODE(PSLICEN    , 'SLICEN    '                         ,PR1, O ,FP0);
48822         ICODE(PCASE      ,  'JUMP    ' , LCX , 0 ,0             , E , O , O );
48830         ICODE(PCASCOUNT  ,  'CI      ' , WOP , 1 ,QCAS          , O , O , O );
48840         QCODE(QCAS       ,  'ISUB    ' , NON , 0 ,QCAS+1);
48842         QCODE(QCAS+1     ,  'INDXJUMP' , NON , 0 ,QCAS+2);
48844         QCODE(QCAS+2     ,  'ARG     ' , OPX , 0 ,0);
48846         ICODE(PCASJMP    ,  'LAB     ' , LCX , 0 ,0             , O , O , O );
48848         ICODE(PCASJMP+1  ,  'JUMP    ' , LCX , 0 ,0             , O , O , O );
48850         ICODE(PJMPF      ,  'JFALSE  ' , LCX , 0 ,0             , E , O , O );
48860         ICODE(PLPINIT    ,  'LAS     ' , ANX , 0 ,QLPINIT       ,PR1, O , E );
48862         QCODE(QLPINIT    ,  'IPUSH   ' , NON , 0 ,QLPINIT+1);
48864         OCODE(QLPINIT+1  , 'LINIT1    '                         , O , O , O );
48870         ICODE(PLPINIT+1  ,  'LAS     ' , ANX , 0 ,QLPINIT+2     ,PR1, O , E );
48872         QCODE(QLPINIT+2  ,  'IPUSH   ' , NON , 0 ,QLPINIT+3);
48874         OCODE(QLPINIT+3  , 'LINIT2    '                         , O , O , O );
48880         ICODE(PLPINIT+2  ,  'LAS     ' , ANX , 0 ,QLPINIT+4     ,PR1, O , O );
48882         QCODE(QLPINIT+4  ,  'IPUSH   ' , NON , 0 ,QLPINIT+5);
48884         OCODE(QLPINIT+5  , 'LINIT3    '                         , O , O , O );
48890         ICODE(PLPINIT+3  ,  'LAS     ' , ANX , 0 ,QLPINIT+6     ,PR1, O , O );
48892         QCODE(QLPINIT+6  ,  'IPUSH   ' , NON , 0 ,QLPINIT+7);
48894         OCODE(QLPINIT+7  , 'LINIT4    '                         , O , O , O );
48900         ICODE(PLPTEST    ,  'JFALSE  ' , LCX , 0 ,0             , E , O , O );
48902         ICODE(PLPINCR    ,  'LAS     ' , ANX , 0 ,QLOOPINCR+4   , O , O , E );
48904         QCODE(QLOOPINCR+4,  'IPUSH   ' , NON , 0 ,QLOOPINCR+5);
48910         OCODE(QLOOPINCR+5, 'LOOPINC   '                         , O , O , O );
48920         ICODE(PLPINCR+1  ,  'CI      ' , WOP , 1 ,QLOOPINCR     , O , O , E );
48930         QCODE(QLOOPINCR  ,  'LAS     ' , ONX , 0 ,QLOOPINCR+1);
48940         QCODE(QLOOPINCR+1,  'OAADD   ' , NON , 0 ,QLOOPINCR+2);
48950
48960         QCODE(QLOOPINCR+2,  'IL      ' , ONX , 2 ,QLOOPINCR+3);
48964         QCODE(QLOOPINCR+3,  'IGE     ' , NON , 0 ,0);
48966         ICODE(PRANGENT   ,  'LAS     ' , ANX , 0 ,QRANGENT      , O , O , O );
48968         QCODE(QRANGENT   ,  'IPUSH   ' , NON , 0 ,QRANGENT+1);
48970         OCODE(QRANGENT+1 , 'RANGENT   '                         , O , O , O );
48980         OCODE(PRANGEXT   , 'RANGEXT   '                         , O , O , O );
48990         ICODE(PRANGEXT+1 ,  'IL      ' , WNP ,(SIZIBBASE+SIZLEBBASE-8),QRANGEXT, O , O , O );
48992         QCODE(QRANGEXT   ,  ' SR2    ' , NON , 0 ,QRANGEXT+1);
48994         QCODE(QRANGEXT+1 ,  'LRO2    ' , WOP , 8 ,QRANGEXT+2);
49000         QCODE(QRANGEXT+2 ,  ' IS     ' , WNP ,(SIZIBBASE+SIZLEBBASE-8),0   );
49020         OCODE(PRANGEXT+2 , 'RANGXTP   '                         ,STP, O , E );
49022         OCODE(PRECGEN    , 'DORECGE   '                         , O , O , O );
49030         OCODE(PACTDRSTRUCT,'CRSTRUC   '                         , O , O , E );
49040         OCODE(PACTDRMULT , 'CRMULT    '                         ,PR1, O , E );
49050         OCODE(PCHECKDESC , 'CHKDESC   '                         ,PR1,PR2, E );
49080         OCODE(PVARLISTEND, 'GARBAGE   '                         ,PR1, O , O );
49090         ICODE(PVARLISTEND+1,'ASFW    ' , WOP , 2 ,0             ,ST , O , O );
49096         ICODE(PDCLINIT   ,  'LGI     ' , MOR , 0 ,QDCLINIT      , O , O , O );
49097         QCODE(QDCLINIT   ,  '_UNINT  ' , NON , 0 ,0);
49098         ICODE(PDCLINIT+1 ,  'LGI     ' , MOR , 0 ,QDCLINIT+1    , O , O , O );
49099         QCODE(QDCLINIT+1 ,  '_UNDEFIN' , NON , 0 ,0);
49100         ICODE(PDCLINIT+2 ,  'IS      ' , ONX , 2 ,0             , O , O , O );
49106         ICODE(PPARM      ,  'IL      ' , ONX , 0 ,QDCLSP        , O , O , O );
49108
49110
49120         OCODE(PCREATEREF , 'CRREFN    '                         ,PR1, O , E );
49130         OCODE(PCREATEREF+1,'CRRECN    '                         ,PR1, O , E );
49140         OCODE(PCREATEREF+2,'CRREFR    '                         ,PR1, O , E );
49150         OCODE(PCREATEREF+3,'CRRECR    '                         ,PR1, O , E );
49160
49170         ICODE(PDCLSP     ,  ' IS     ' , ONX , 2 ,0             , E , O , O );
49180         ICODE(PDCLSP+1   ,  ' IS     ' , ONX , 2 ,QDCLSP        , E , O , O );
49190         QCODE(QDCLSP     ,  'CI      ' , MOR , 0 ,QDCLSP+1                  );
49200         QCODE(QDCLSP+1   ,  '65536   ' , NON , 0 ,QDCLSP+2                  );
49230         QCODE(QDCLSP+2   ,  'EXCH    ' , NON , 0 ,QDCLSP+3                  );
49232         QCODE(QDCLSP+3   ,  ' OAADD  ' , NON , 0 ,0);
49240         OCODE(PDCLSP+2   , 'DCLSN     '                         ,SNS, O , O );
49250         OCODE(PDCLSP+3   , 'DCLPN     '                         ,SNS, O , O );
49252         ICODE(PFIXRG     ,  'LAS     ' , ONX , 0 ,0             , O , O , O );
49254         ICODE(PFIXRG+1   ,  'IS      ' , ONX , 0 ,0             , O , O , O );
49260         END;
49270     PROCEDURE THIRDPART;
49280         BEGIN
49290         OCODE(PBOUNDS    , 'BOUND     '                         ,STS, O , E );
49300         ICODE(PLOADVAR   ,  'LAS     ' , ACP , 0 ,QLOADVAR      , O , O , E );
49304         QCODE(QLOADVAR   ,  'LAS     ' , ACX , 0 ,QLOADVAR+3);
49310         ICODE(PLOADVAR+1 ,  'LROA3   ' , ACP ,250,QLOADVAR+1    , O , O , E );
49312         QCODE(QLOADVAR+1 ,  'LROA3   ' , ACX ,250,QLOADVAR+3);
49320         ICODE(PLOADVAR+2 ,  'LROA2   ' , ACP ,192,QLOADVAR+2    , O , O , E );
49322         QCODE(QLOADVAR+2 ,  'LROA2   ' , ACX ,192,QLOADVAR+3);
49324         QCODE(QLOADVAR+3 ,  'IPUSH   ' , NON , 0 ,QLOADVAR+4);
49326         QCODE(QLOADVAR+4 ,  'IPUSH   ' , NON , 0 ,QLOADVAR+5);
49328         OCODE(QLOADVAR+5 , 'GLDVAR    '                         , O , O , O );
49330         OCODE(PLOADRT    , 'ROUTN     '                         , O , O , E );
49331         ICODE(PLOADRTA   ,  'LAS     ' , ACX , 0 ,QLOADRTA      , O , O , E );
49332         ICODE(PLOADRTA+1 ,  'LROA3   ' , ACX ,250,QLOADRTA      , O , O , E );
49333         ICODE(PLOADRTA+2 ,  'LROA2   ' , ACX ,192,QLOADRTA      , O , O , E );
49334         QCODE(QLOADRTA   ,  'IPUSH   ' , NON , 0 ,QLOADRTA+1);
49335         OCODE(QLOADRTA+1 , 'ROUTNA    '                         , O , O , O );
49336         OCODE(PLOADRTP   , 'ROUTNP    '                         ,PR1, O , E );
49340         OCODE(PSCOPETT+2 , 'TASSTPT   '                         ,PR1,PR2, E );
49350         OCODE(PSCOPETT+3 , 'SCPTTP    '                         ,PR1,PR2, E );
49360         OCODE(PSCOPETT+4 , 'SCPTTM    '                         ,PR1,PR2, E );
49370         OCODE(PASSIGTT   , 'TASSTS    '                         , E , E , E );
49372         OCODE(PASSIGTT+1 , 'TASSTS2   '                         , E ,FP0, E );
49380         OCODE(PASSIGTT+2 , 'TASSTPT   '                         ,PR1,PR2, E );
49390         OCODE(PASSIGTT+3 , 'TASSTP    '                         ,PR1,PR2, E );
49400         OCODE(PASSIGTT+4 , 'TASSTM    '                         ,PR1,PR2, E );
49410         OCODE(PSCOPETN   , 'SCPTNP    '                         ,PR1,PR2, E );
49420         OCODE(PASSIGTN   , 'TASSNP    '                         ,PR1,PR2, E );
49430         OCODE(PSCOPENT+2 , 'SCPNTPT   '                         ,PR1,PR2,FP0);
49440         OCODE(PSCOPENT+3 , 'SCPNTP    '                         ,PR1,PR2,FP0);
49480         OCODE(PASSIGNT   , 'NASSTS    '                         ,ER0, E ,ER0);
49490         OCODE(PASSIGNT+1 , 'NASSTS2   '                         ,ER0,FP0,ER0);
49500         OCODE(PASSIGNT+2 , 'NASSTPP   '                         ,ER0, E ,ER0);
49520         OCODE(PASSIGNT+3 , 'NASSTP    '                         ,PR1,PR2,FP0);
49530
49540         OCODE(PSCOPENN   , 'SCPNNP    '                         ,PR1,PR2,FP0);
49560         OCODE(PASSIGNN   , 'NASSNP    '                         ,PR1,PR2,FP0);
49580         ICODE(PSCOPEVAR  ,  'LAS     ' , ACP , 0 ,QSCOPEVAR     ,PR1, O , O );
49584         QCODE(QSCOPEVAR  ,  'LAS     ' , ACX , 0 ,QSCOPEVAR+3);
49590         ICODE(PSCOPEVAR+1,  'LROA3   ' , ACP ,250,QSCOPEVAR+1   ,PR1, O , O );
49591         QCODE(QSCOPEVAR+1,  'LROA3   ' , ACX ,250,QSCOPEVAR+3);
49592         ICODE(PSCOPEVAR+2,  'LROA2   ' , ACP ,192,QSCOPEVAR+2   ,PR1, O , O );
49594         QCODE(QSCOPEVAR+2,  'LROA2   ' , ACX ,192,QSCOPEVAR+3);
49596         QCODE(QSCOPEVAR+3,  'IPUSH   ' , NON , 0 ,QSCOPEVAR+4);
49598         QCODE(QSCOPEVAR+4,  'IPUSH   ' , NON , 0 ,QSCOPEVAR+5);
49600         OCODE(QSCOPEVAR+5, 'GVSCOPE   '                         , O , O , O );
49610         OCODE(PSCOPEEXT  , 'SCOPEXT   '                         ,PR1, O , E );
49620         ICODE(PASGVART   ,  ' IS     ' , OPX , 0 ,0             ,E , O , O );
49630         ICODE(PASGVART+1 ,  ' SRO3   ' , OPX ,250,0             ,E , O , O );
49640         ICODE(PASGVART+2 ,  ' SRO2   ' , OPX ,192,0             ,E , O , O );
49660         ICODE(PASGVART+3 ,  'LAS     ' , OPX , 0 ,QASGVART      ,FP0, O , O );
49671         QCODE(QASGVART   ,  ' ASSD   ' , WOP , 0 ,0                         );
49680         ICODE(PASGVART+4 ,  'LROA3   ' , OPX ,250,QASGVART      ,FP0, O , O );
49690         ICODE(PASGVART+5 ,  'LROA2   ' , OPX ,192,QASGVART      ,FP0, O , O );
49710         ICODE(PASGVART+6 ,  'LAS     ' , ACX , 0 ,QASGVART+1    ,PR1, O , O );
49712         QCODE(QASGVART+1 ,  'IPUSH   ' , NON , 0 ,QASGVART+2);
49714         OCODE(QASGVART+2 , 'GVASSTX   '                         , O , O , O );
49720         ICODE(PASGVART+7 ,  'LROA3   ' , ACX ,250,QASGVART+1    ,PR1, O , O );
49730         ICODE(PASGVART+8 ,  'LROA2   ' , ACX ,192,QASGVART+1    ,PR1, O , O );
49740         OCODE(PIDTYREL   , 'IS        '                         ,PR1,PR2, E );
49750         OCODE(PIDTYREL+1 , 'ISNT      '                         ,PR1,PR2, E );
49752         ICODE(PGETTOTCMN ,  'LR0     ' , NON , 0 ,QGETTOTCMN    ,ER0, O ,ER0);
49753         QCODE(QGETTOTCMN ,  'IADD    ' , NON , 0 ,0);
49754         ICODE(PGETTOTCMN+1, 'LRO0    ' , WOP , 2 ,QGETTOTCMN    ,ER0, O ,ER0);
49755         ICODE(PGETTOTCMN+2, 'LRO0    ' , WOP , 4 ,QGETTOTCMN+1  ,ER0, O ,ER0);
49756         QCODE(QGETTOTCMN+1, 'SR1     ' , NON , 0 ,QGETTOTCMN+2);
49757         QCODE(QGETTOTCMN+2, 'JFALSE  ' , JMP , 1 ,QGETTOTCMN+3);
49758         QCODE(QGETTOTCMN+3, 'LRO1    ' , WOP , 2 ,QGETTOTCMN);
49760         ICODE(PGETTOTAL  ,  'LI      ' , NON , 0 ,QGETTOTAL     ,ER0, O , E );
49761
49762
49763
49764         ICODE(PGETTOTAL+1,  'LDI     ' , WOP , 0 ,QGETTOTAL     ,ER0, O ,FP0);
49765
49766
49767
49768         QCODE(QGETTOTAL  ,  'LRO0    ' , WOP , 0 ,QGETTOTAL+1);
49769
49770         QCODE(QGETTOTAL+1,  'CI      ' , MOR , 0 ,QGETTOTAL+2);
49771         QCODE(QGETTOTAL+2,  '65536   ' , NON , 0 ,QGETTOTAL+3);
49772         QCODE(QGETTOTAL+3,  'IJGE    ' , JMP , 2 ,QGETTOTAL+4);
49773         OCODE(QGETTOTAL+4, 'SAVGARB   '                         , O , O , O );
49774         OCODE(PGETTOTAL+2, 'GTOTP     '                         ,PR1, O , E );
49775         OCODE(PGETTOTAL+3, 'GTOTN     '                         ,PR1, O , E );
49776         OCODE(PGETTOTAL+4, 'GTOTREF   '                         ,PR1, O , E );
49778         OCODE(PGETMULT   , 'GETMULT   '                         ,PR1, O , E );
49780         OCODE(PGETMULT+1 , 'GETSLN    '                         ,PR1, O , E );
49782         OCODE(PDEREF     , 'DREFS     '                         ,PR1, O , E );
49784         OCODE(PDEREF+1   , 'DREFS2    '                         ,PR1, O , E );
49786         OCODE(PDEREF+2   , 'DREFPTR   '                         ,PR1, O , E );
49788         OCODE(PDEREF+3   , 'DREFN     '                         ,PR1, O , E );
49790         OCODE(PDEREF+4   , 'DREFM     '                         ,PR1, O , E );
49800         OCODE(PSKIP      , 'SKIPS     '                         , O , O , E );
49810         OCODE(PSKIP+1    , 'SKIPPIL   '                         , O , O , E );
49812         OCODE(PSKIP+2    , 'SKIPS2    '                         , O , O ,FP0);
49820         OCODE(PSKIPSTRUCT, 'SKIPSTR   '                         , O , O , E );
49830         OCODE(PNIL       , 'NILP      '                         , O , O , E );
49840         ICODE(PVOIDNORMAL,  'SR0     ' , NON , 0 ,PVOIDNAKED    , E , O , O );
49843         ICODE(PVOIDNAKED ,  'LRO0    ' , WOP , 0 ,QGETTOTAL+1   ,ER0, O , O );
49844
49845
49846
49847
49848
49900
49910         ICODE(PWIDEN     ,  'FLOAT   ' , WOP , 0 ,0             ,E  , O ,FP0);
49940         OCODE(PWIDEN+2   , 'WIDREAL   '                         ,PR1, O , E );
49950         OCODE(PWIDEN+4   , 'WIDCHAR   '                         ,PR1, O , E );
49960         OCODE(PWIDEN+5   , 'WIDBITS   '                         ,PR1, O , E );
49970         OCODE(PWIDEN+6   , 'WIDBYTS   '                         ,PR1, O , E );
49980         OCODE(PWIDEN+7   , 'WIDSTR    '                         ,PR1, O , E );
49990         OCODE(PROWNONMULT, 'ROWNM     '                         ,PR1, O , E );
50000         OCODE(PROWMULT   , 'ROWM      '                         ,PR1, O , E );
50001         ICODE(PGETPROC   ,  'SFA     ' , NON , 0 ,QGETPROC      , O , O , O );
50002         QCODE(QGETPROC   ,  'CI      ' , ANX , 0 ,QGETPROC+1);
50003         QCODE(QGETPROC+1 ,  'IADD    ' , NON , 0 ,QGETPROC+2);
50004         QCODE(QGETPROC+2 ,  'LI      ' , NON , 0 ,QGETPROC+3);
50005         QCODE(QGETPROC+3 ,  'IPUSH   ' , NON , 0 ,PGETPROC+1);
50006         OCODE(PGETPROC+1 , 'GETPROC   '                         ,PR1, O , O );
50010         ICODE(PCALL      ,  'CI      ' , ACX , 0 ,QCALL         ,SNS, O , O );
50011         QCODE(QCALL      ,  'IPUSH   ' , NON , 0 ,QCALL+1);
50012         QCODE(QCALL+1    ,  'RPUSH   ' , WOP , 0 ,QCALL+2);
50013         QCODE(QCALL+2    ,  'SFA     ' , NON , 0 ,QCALL+3);
50014         QCODE(QCALL+3    ,  'CI      ' , WOP , 2 ,QCALL+4);
50015         QCODE(QCALL+4    ,  'IADD    ' , NON , 0 ,QCALL+5);
50016         QCODE(QCALL+5    ,  'LI      ' , NON , 0 ,QCALL+6);
50017         QCODE(QCALL+6    ,  'LI      ' , NON , 0 ,QCALL+7);
50018         QCODE(QCALL+7    ,  'CALLT   ' , NON , 0 ,0);
50019         ICODE(PCALLA     ,  'SFA     ' , NON , 0 ,QCALLA        ,SNS, O , O );
50020         QCODE(QCALLA     ,  'LAS     ' , ACX , 0 ,QCALLA+3);
50021         ICODE(PCALLA+1   ,  'SFA     ' , NON , 0 ,QCALLA+1      ,SNS, O , O );
50022         QCODE(QCALLA+1   ,  'LROA3   ' , ACX ,250,QCALLA+3);
50023         ICODE(PCALLA+2   ,  'SFA     ' , NON , 0 ,QCALLA+2      ,SNS, O , O );
50024         QCODE(QCALLA+2   ,  'LROA2   ' , ACX ,192,QCALLA+3);
50025         QCODE(QCALLA+3   ,  'IPUSH   ' , NON , 0 ,QCALL+5);
50026         ICODE(PRNSTART   ,  'ASFW    ' , OPX , 0 ,QRNSTART      , O , O , O );
50028         OCODE(QRNSTART   , 'RNSTART   '                         , O , O , O );
50029         ICODE(PRETURN    ,  'RETURN  ' , NON , 0 ,0             ,XN , O , O );
50030         OCODE(PGBSTK     , 'GBSTK     '                         , O , O , O );
50034         OCODE(POUTJUMP   , 'OUTJUMP   '                         , O , O , O );
50040         OCODE(PGETOUT    , 'GETOUT    '                         , O , O , O );
50042         ICODE(PSETIB     ,  'RPUSH   ' , WOP , 0 ,QSETIB        , O , O , O );
50044         OCODE(QSETIB     , 'SETIB     '                         , O , O , O );
50050         OCODE(PLEAPGEN   , 'GENSTR    '                         , O , O , E );
50060         OCODE(PLEAPGEN+1 , 'HEAPSTR   '                         , O , O , E );
50070         OCODE(PLEAPGEN+2 , 'GENRSTR   '                         , O , O , E );
50080         OCODE(PLEAPGEN+3 , 'GENMUL    '                         ,PR1, O , E );
50090         OCODE(PLEAPGEN+4 , 'HEAPMUL   '                         ,PR1, O , E );
50100         OCODE(PLEAPGEN+5 , 'GENRMUL   '                         ,PR1, O , E );
50110         OCODE(PPREPSTRDISP , 'PCOLLST   '                       , O , O ,FP0);
50120         OCODE(PPREPROWDISP , 'PCOLLR    '                       ,STS, O ,FP0);
50130         OCODE(PPREPROWDISP+1, 'PCOLLRM   '                      ,STS, O ,FP0);
50140         OCODE(PCOLLCHECK , 'PCOLLCK   '                         ,S4P, O ,FP0);
50150         ICODE(PCOLLTOTAL ,  'EXCH    ' , NON , 0 ,QCOLLTOTAL    ,ER0, E ,ER0);
50151         QCODE(QCOLLTOTAL  , 'SR1     ' , NON , 0 ,QCOLLTOTAL+1);
50152         QCODE(QCOLLTOTAL+1, 'EXCH    ' , NON , 0 ,QCOLLTOTAL+2);
50153
50154         QCODE(QCOLLTOTAL+2, 'SRO1    ' , OPX , 0 ,QCOLLTOTAL+3);
50155         QCODE(QCOLLTOTAL+3, 'JFALSE  ' , JMP , 1 ,0);
50156
50170         ICODE(PCOLLTOTAL+1, 'SR1     ' , NON , 0 ,QCOLLTOTAL+4  ,ER0,FP0,ER0);
50171
50172
50173         QCODE(QCOLLTOTAL+4, 'LROA1   ' , OPX , 0 ,QCOLLTOTAL+5);
50174         QCODE(QCOLLTOTAL+5, 'ASSD    ' , WOP , 0 ,0);
50175
50200         ICODE(PCOLLTOTAL+2, 'DUPL    ' , NON , 0 ,QCOLLTOTAL+6  ,ER0, E ,ER0);
50210         QCODE(QCOLLTOTAL+6, 'CI      ' , MOR , 0 ,QCOLLTOTAL+7);
50220         QCODE(QCOLLTOTAL+7, '65536   ' , NON , 0 ,QCOLLTOTAL+8);
50222         QCODE(QCOLLTOTAL+8, 'EXCH    ' , NON , 0 ,QCOLLTOTAL+9);
50230         QCODE(QCOLLTOTAL+9, 'OAADD   ' , NON , 0 ,QCOLLTOTAL+10);
50240         QCODE(QCOLLTOTAL+10,'JFALSE  ' , JMP , 1 ,PCOLLTOTAL);
50250         OCODE(PCOLLTOTAL+3,'COLLTP    '                         ,PR1,PR2,FP0);
50260         OCODE(PCOLLTOTAL+4,'COLLTM    '                         ,PR1,PR2,FP0);
50270         OCODE(PCOLLNAKED , 'COLLNP    '                         ,PR1,PR2,FP0);
50280         ICODE(PNAKEDPTR  ,  'JFALSE  ' , JMP , 1 ,QNAKEDPTR     ,ER0, O , E );
50282         QCODE(QNAKEDPTR  ,  'LR0     ' , NON , 0 ,0);
50290         ICODE(PLINE      ,  'CI      ' , OPX , 0 ,QLINE         , O , O , O );
50300         QCODE(QLINE      ,  ' IS     ' , WNP ,12 ,0);
50320         OCODE(PENDSLICE  , 'ENDSL     '                         ,PR1, O , E );
50330         OCODE(PTRIM      , 'SLICEA    '                         , O , O , O );
50340         OCODE(PTRIM+1    , 'SLICEB    '                         , O , O , O );
50350         OCODE(PTRIM+2    , 'SLICEC    '                         , O , O , O );
50360         OCODE(PTRIM+3    , 'SLICED    '                         , O , O , O );
50370         OCODE(PTRIM+4    , 'SLICEE    '                         , O , O , O );
50380         OCODE(PTRIM+5    , 'SLICEF    '                         , O , O , O );
50390         OCODE(PTRIM+6    , 'SLICEG    '                         , O , O , O );
50400         OCODE(PTRIM+7    , 'SLICEH    '                         , O , O , O );
50410         OCODE(PTRIM+8    , 'SLICEI    '                         , O , O , O );
50420         OCODE(PTRIM+9    , 'SLICEJ    '                         , O , O , O );
50430         ICODE(PJMP       ,  'JUMP    ' , LCX , 0 ,0             , O , O , O );
50432         ICODE(PENVCHAIN  ,  'IL      ' , WOP , 4 ,QENVCHAIN     , O , O , O );
50434         QCODE(QENVCHAIN  ,  ' SR2    ' , NON , 0 ,0);
50436         ICODE(PENVCHAIN+1,  'LRO2    ' , WOP ,196,QENVCHAIN     , O , O , O );
50438         ICODE(PDISCARD   ,  'JFALSE  ' , JMP , 1 ,0             , O , O , O );
50440         ICODE(PDUP1ST    ,  'SFA     ' , NON , 0 ,QDUP1ST       ,STP, O , E );
50441         ICODE(PDUP1ST+1  ,  'SFA     ' , NON , 0 ,QDUP2ND       ,ST4, O ,FP1);
50442         QCODE(QDUP1ST    ,  'LI      ' , NON , 0 ,0);
50450         ICODE(PDUP2ND    ,  'SFA     ' , NON , 0 ,QDUP1ST       ,STP, E , E );
50460         ICODE(PDUP2ND+1  ,  'SFA     ' , NON , 0 ,QDUP2ND       ,ST4, E ,FP1);
50464         ICODE(PDUP2ND+2  ,  'SFA     ' , NON , 0 ,QDUP1ST       ,STP,F0P, E );
50466         ICODE(PDUP2ND+3  ,  'SFA     ' , NON , 0 ,QDUP2ND       ,ST4,F0P,FP1);
50468         QCODE(QDUP2ND    ,  'LDI     ' , WOP , 1 ,0);
50470         ICODE(PDATALIST  ,  'CI      ' , OPX , 0 ,QDATALIST     ,SNS, O ,SDL);
50471         QCODE(QDATALIST  ,  'IPUSH   ' , NON , 0 ,PALIGN);
50472         ICODE(PASP       ,  'ASFW    ' , OPX , 0 , 0            , O , O , O );
50474         ICODE(PALIGN     ,  'ALIGN   ' , NON , 0 , 0            , O , O , O );
50476         ICODE(PHEAVE     ,  'SFA     ' , NON , 0 ,QHEAVE        , O , O , O );
50478         QCODE(QHEAVE     ,  'SFA     ' , NON , 0 ,QHEAVE+1);
50480         QCODE(QHEAVE+1   ,  'CI      ' , WOP , 2 ,QHEAVE+2);
50482         QCODE(QHEAVE+2   ,  'ISUB    ' , NON , 0 ,QHEAVE+3);
50484         QCODE(QHEAVE+3   ,  'CI      ' , OPX , 0 ,QHEAVE+4);
50486         QCODE(QHEAVE+4   ,  ' MVW    ' , NON , 0 ,QHEAVE+5);
50487         QCODE(QHEAVE+5   ,  'ASFW    ' , WNP , 2 ,0);
50490         ICODE(PHOIST     ,  'ASFW    ' , ONX , 0 ,QHOIST        , O , O , O );
50492         QCODE(QHOIST     ,  'CI      ' , ACX , 0 ,QHOIST+1);
50493         QCODE(QHOIST+1   ,  'IPUSH   ' , NON , 0 ,QHOIST+2);
50494         OCODE(QHOIST+2   , 'HOIST     '                         , O , O , O );
50496         ICODE(PPUSH      ,  'IL      ' , OPX , 0 ,QIPUSH        , O , O , O );
50498         QCODE(QIPUSH     ,  'IPUSH   ' , NON , 0 , 0                        );
50510         ICODE(PPUSH+1    ,  'LRO3    ' , OPX ,250,QIPUSH        , O , O ,ST );
50512         ICODE(PPUSH+2    ,  'LRO2    ' , OPX ,192,QIPUSH        , O , O , O );
50520         ICODE(PPUSHIM    ,  'CI      ' , OPX , 0 ,QIPUSH        , O , O ,ST );
50530         ICODE(PPUSHIM+1  ,  'LGA     ' , GBX , 0 ,QIPUSH        , O , O , O );
50531         ICODE(PLOADEIM   ,  'CI      ' , OPX , 0 ,0             , O , O , E );
50532         ICODE(PLOADEIM+1 ,  'LGA     ' , GBX , 0 ,0             , O , O , O );
50533         ICODE(PLOADE     ,  'IL      ' , OPX , 0 ,0             , O , O , O );
50534         ICODE(PLOADE+1   ,  'LRO3    ' , OPX ,250,0             , O , O , O );
50535         ICODE(PLOADE+2   ,  'LRO2    ' , OPX ,192,0             , O , O , O );
50550         ICODE(PPUSHIM2   ,  'LGA     ' , OPX , 0 ,QPUSHIM2      , O , O , O ); (*SPECIAL FOR*)
50552         QCODE(QPUSHIM2   ,  'IPUSH   ' , NON , 0 ,QPUSHIM2+1);                 (*MDCHAN AND *)
50554         QCODE(QPUSHIM2+1 ,  'IL      ' , WNP , 2 ,QIPUSH);                     (*MDCODE     *)
50560         ICODE(PPUSHIM2+1 ,  'LGA     ' , GBX , 0 ,QPUSH2        , O , O , O );
50570         ICODE(PPUSHER0   ,  'IPUSH   ' , NON , 0 ,QPUSHER0      , O , O , O );
50572         QCODE(QPUSHER0   ,  'LR0     ' , NON , 0 ,QPUSHER0+1);
50574         QCODE(QPUSHER0+1 ,  'IPUSH   ' , NON , 0 ,0);
50580         ICODE(PLOADER0F0 ,  'RPUSH   ' , WOP , 0 ,PLOADER0STK   , O , O , O );
50582         ICODE(PLOADER0F1 ,  'RPUSH   ' , WOP , 1 ,PLOADER0STK   , O , O , O );
50590         ICODE(PLOADER0STK,  'SFA     ' , NON , 0 ,QLOADER0STK   , O , O , O );
50592         QCODE(QLOADER0STK,  ' SR1    ' , NON , 0 ,QLOADER0STK+1);
50594         QCODE(QLOADER0STK+1,'LRO1    ' , WOP , 0 ,QLOADER0STK+2);
50596         QCODE(QLOADER0STK+2,' SR0    ' , NON , 0 ,QLOADER0STK+3);
50598         QCODE(QLOADER0STK+3,'LRO1    ' , WOP , 2 ,QLOADER0STK+4);
50600         QCODE(QLOADER0STK+4,'ASFW    ' , WOP , 4 ,0);
50640         ICODE(PPUSH2     ,  'LAS     ' , OPX , 0 ,QPUSH2        , O , O , O );
50650         QCODE(QPUSH2     ,  'LDI     ' , WOP , 3 ,QPUSH2+1);
50652         QCODE(QPUSH2+1   ,  'RPUSH   ' , WOP , 3 ,0);
50660         ICODE(PPUSH2+1   ,  'LRO3    ' , OPX ,252,QPUSH2+2      , O , O , O );
50662         QCODE(QPUSH2+2   ,  'IPUSH   ' , NON , 0 ,PPUSH+1);
50670         ICODE(PPUSH2+2   ,  'LRO2    ' , OPX ,194,QPUSH2+3      , O , O , O );
50672         QCODE(QPUSH2+3   ,  'IPUSH   ' , NON , 0 ,PPUSH+2);
50690         ICODE(PDECM      ,  'CI      ' , OPX , 0 ,0             , O , O , O );
50694         QCODE(PDECM+1    ,  ' IS     ' , ONX , 0 ,0);
50696         ICODE(PETOSTK    ,  'IPUSH   ' , NON , 0 ,0             , O , O , O );
50700         ICODE(PETOSTK+1  ,  'ASFW    ' , WNP , 4 ,QETOSTK        , O , O , O );
50701         QCODE(QETOSTK    ,  'SFA     ' , NON , 0 ,QETOSTK+1);
50702         QCODE(QETOSTK+1  ,  'SR1     ' , NON , 0 ,QETOSTK+2);
50703         QCODE(QETOSTK+2  ,  'JFALSE  ' , JMP , 1 ,QETOSTK+3);
50704         QCODE(QETOSTK+3  ,  'SRO1    ' , WOP , 0 ,QETOSTK+4);
50705         QCODE(QETOSTK+4  ,  'JFALSE  ' , JMP , 1 ,QETOSTK+5);
50706         QCODE(QETOSTK+5  ,  'SRO1    ' , WOP , 2 ,0);
50714         OCODE(PETOSTK+2  ,  'ETOSTK    '                        , O , O , O );
50715         ICODE(PSTKTOE    ,  'SFA     ' , NON , 0 ,QLOADI        , O , O , O );
50716         QCODE(QLOADI     ,  'LI      ' , NON , 0 ,QADJSP2                   );
50717         QCODE(QADJSP2    ,  'ASFW    ' , WOP , 2 ,0                         );
50718         ICODE(PSTKTOE+1  ,  'SFA     ' , NON , 0 ,QSTKTOE       , O , O , O );
50719         QCODE(QSTKTOE    ,  ' SR1    ' , NON , 0 ,QSTKTOE+1                 );
50720         QCODE(QSTKTOE+1  ,  'LRO1    ' , WOP , 2 ,QSTKTOE+2                 );
50721         QCODE(QSTKTOE+2  ,  'LRO1    ' , WOP , 0 ,QADJSP4                   );
50722         QCODE(QADJSP4    ,  'ASFW    ' , WOP , 4 ,0                         );
50723         OCODE(PSTKTOE+2  ,  'STKTOE    '                        , O , O , O );
50724         ICODE(PSWAP      ,  'EXCH    ' , NON , 0 ,0             , O , O , O );
50725         ICODE(PPUSHFSTK  ,  'RPUSH   ' , WOP , 0 ,0             , O , O , O );
50726         ICODE(PPUSHFSTK1 ,  'RPUSH   ' , WOP , 1 ,0             , O , O , O );
50727         ICODE(PLOADF     ,  'LAS     ' , OPX , 0 ,QLOADF        , O , O , O );
50728         QCODE(QLOADF     ,  'LDI     ' , WOP , 0 ,0);
50732         ICODE(PLOADFIM   ,  'LGA     ' , GBX , 0 ,QLOADF        , O , O , O );
50734         ICODE(PLOADF1    ,  'LAS     ' , OPX , 0 ,QLOADF1       , O , O , E );
50735         QCODE(QLOADF1    ,  'LDI     ' , WOP , 1 ,0                         );
50739         ICODE(PLOADFIM1  ,  'LGA     ' , GBX , 0 ,QLOADF1       , O , O ,FP1);
50742         ICODE(PLOADFSTK  ,  'RPOP    ' , WOP , 0 ,0             , O , O , O );
50743         ICODE(PLOADFSTK1 ,  'RPOP    ' , WOP , 1 ,0             , O , O , O );
50744         ICODE(PF0TOF1    ,  'RPUSH   ' , WOP , 0 ,PLOADFSTK1    , O , O ,FP1);
50745         ICODE(PF1TOF0    ,  'RPUSH   ' , WOP , 1 ,PLOADFSTK     , O , O ,FP0);
50750          END;
50755   PROCEDURE INITPOPARRAY;
50757     VAR I,J:SBTTYP;
50760       BEGIN
50761       FOR I := SBTSTK TO SBTFPR3 DO
50770         FOR J := SBTVOID TO SBTFPR3 DO
50780           BEGIN
50790           POPARRAY [I,J] := PNONE;
50800           POPARRAY [I,I] := PNOOP;
50810           POPARRAY [I,SBTVOID] :=PNOOP;
50820           POPARRAY [I,SBTVAR ] := PLOADVAR;
50822           POPARRAY [I,SBTPROC] := PLOADRTA;
50824           POPARRAY [I,SBTRPROC]:= PLOADRTA;
50830           END;
50910       POPARRAY[ SBTSTK  , SBTSTK4 ] := PVARLISTEND+1;
50920       POPARRAY[ SBTSTK  , SBTID   ] := PPUSH;
50930       POPARRAY[ SBTSTK  , SBTIDV  ] := PPUSH;
50940       POPARRAY[ SBTSTK  , SBTLIT  ] := PPUSHIM;
50950       POPARRAY[ SBTSTK  , SBTDEN  ] := PPUSHIM;
50951       POPARRAY[ SBTE    , SBTID   ] := PLOADE;
50952       POPARRAY[ SBTE    , SBTIDV  ] := PLOADE;
50954       POPARRAY[ SBTE    , SBTVAR  ] := PLOADVAR;
50956       POPARRAY[ SBTE    , SBTLIT  ] := PLOADEIM;
50958       POPARRAY[ SBTE    , SBTDEN  ] := PLOADEIM;
50960       POPARRAY[ SBTSTK  , SBTDL   ] := PNOOP;
50970       POPARRAY[ SBTSTK4 , SBTID   ] := PPUSH2;
50980       POPARRAY[ SBTSTK4 , SBTIDV  ] := PPUSH2;
51000       POPARRAY[ SBTSTK4 , SBTDEN  ] := PPUSHIM2;
51030       POPARRAY[ SBTSTK  , SBTPR1  ] := PNOOP;
51040       POPARRAY[ SBTSTK  , SBTPR2  ] := PNOOP;
51050       POPARRAY[ SBTSTK4 , SBTPR1  ] := PNOOP;
51060       POPARRAY[ SBTSTK4 , SBTPR2  ] := PNOOP;
51070       POPARRAY[ SBTSTK4 , SBTSTK  ] := PSTOS4;
51071       POPARRAY[ SBTSTK  , SBTE    ] := PETOSTK;
51072       POPARRAY[ SBTE    , SBTSTK  ] := PSTKTOE;
51073       POPARRAY[ SBTSTK4 , SBTFPR0 ] := PPUSHFSTK;
51074       POPARRAY[ SBTSTK4 , SBTFPR1 ] := PPUSHFSTK1;
51075       POPARRAY[ SBTFPR0 , SBTID   ] := PLOADF;
51076       POPARRAY[ SBTFPR0 , SBTIDV  ] := PLOADF;
51077       POPARRAY[ SBTFPR0 , SBTLIT  ] := PLOADFIM;
51078       POPARRAY[ SBTFPR0 , SBTDEN  ] := PLOADFIM-1;
51079       POPARRAY[ SBTFPR1 , SBTID   ] := PLOADF1;
51080       POPARRAY[ SBTFPR1 , SBTIDV  ] := PLOADF1;
51082       POPARRAY[ SBTFPR1 , SBTLIT  ] := PLOADFIM1;
51083       POPARRAY[ SBTFPR1 , SBTDEN  ] := PLOADFIM1-1;
51084       POPARRAY[ SBTFPR0 , SBTSTK4 ] := PLOADFSTK;
51085       POPARRAY[ SBTFPR1 , SBTSTK4 ] := PLOADFSTK1;
51086       POPARRAY[ SBTFPR1 , SBTFPR0 ] := PF0TOF1;
51087       POPARRAY[ SBTFPR0 , SBTFPR1 ] := PF1TOF0;
51090       POPARRAY[ SBTSTK4 , SBTER0  ] := PPUSHER0;
51092       POPARRAY[ SBTSTK4 , SBTSTKR0] := PPUSHER0; (*ACTUALLY, LOAD PUTS IT INTO SBTER0 FIRST*)
51094       POPARRAY[ SBTER0  , SBTSTKR0] := PNOOP; (*ACTUALLY, LOAD PUTS IT INTO SBTER0 FIRST*)
51100       POPARRAY[ SBTER0  , SBTSTK4 ] := PLOADER0STK;
51110       POPARRAY[ SBTER0  , SBTFPR0 ] := PLOADER0F0;
51120       POPARRAY[ SBTER0  , SBTFPR1 ] := PLOADER0F1;
51130       END;
51140   PROCEDURE INITLENARRAY;
51150     VAR I:SBTTYP;
51160       BEGIN
51170       FOR I := SBTSTK TO SBTXN DO LENARRAY[I] := 0;
51180       LENARRAY[SBTSTK ] := SZWORD;
51184       LENARRAY[SBTSTK4] := 2*SZWORD;
51186       LENARRAY[SBTSTKR0]:= SZWORD; (*FOR NAKES VALUES*)
51190       LENARRAY[SBTE   ] := SZWORD;
51191       LENARRAY[SBTER0 ] := 2*SZWORD; (*FOR NAKED VALUES*)
51192       LENARRAY[SBTFPR0] := 2*SZWORD;
51193       LENARRAY[SBTFPR1] := 2*SZWORD;
51194       LENARRAY[SBTFPR2] := 2*SZWORD;
51195       LENARRAY[SBTFPR3] := 2*SZWORD;
51210       END;
51220     BEGIN  (* INITCODES +)
51230     FIRSTPART; SECONDPART; THIRDPART;  INITPOPARRAY; INITLENARRAY;
51240     END;
51250 (*+)
51260 ()+86+)
51270 ()+05*)
59771
59772
59773
60280 (**)
60290 (**)
60300 (**)
60310 (**)
60320 (**)
60340 BEGIN
60360 (*+25() LINELIMIT(OUTPUT,10000); LINELIMIT(LSTFILE,10000); ()+25*)
60375         DUMP(FIRSTSTACK,LASTSTACK);
60380 END  (*+25()     (*$G-+)    ()+25*).
####S