{2:}{4:}{$C-,A+,D-}{$C+,D+}{:4} PROGRAM TANGLE(WEBFILE,CHANGEFILE,PASCALFILE,POOL);LABEL 9999;CONST{8:} BUFSIZE=100;MAXBYTES=45000;MAXTOKS=50000;MAXNAMES=4000;MAXTEXTS=2000; HASHSIZE=353;LONGESTNAME=400;LINELENGTH=72;OUTBUFSIZE=144;STACKSIZE=50; MAXIDLENGTH=12;UNAMBIGLENGT=7;{:8}TYPE{11:}ASCIICODE=0..127;{:11}{12:} TEXTFILE=PACKED FILE OF CHAR;{:12}{37:}EIGHTBITS=0..255; SIXTEENBITS=0..65535;{:37}{39:}NAMEPOINTER=0..MAXNAMES;{:39}{43:} TEXTPOINTER=0..MAXTEXTS;{:43}{78:} OUTPUTSTATE=RECORD ENDFIELD:SIXTEENBITS;BYTEFIELD:SIXTEENBITS; NAMEFIELD:NAMEPOINTER;REPLFIELD:TEXTPOINTER;MODFIELD:0..12287;END;{:78} VAR{9:}HISTORY:0..3;{:9}{13:}XORD:ARRAY[CHAR]OF ASCIICODE; XCHR:ARRAY[ASCIICODE]OF CHAR;{:13}{20:}TERMOUT:TEXTFILE;{:20}{23:} WEBFILE:TEXTFILE;CHANGEFILE:TEXTFILE;{:23}{25:}PASCALFILE:TEXTFILE; POOL:TEXTFILE;{:25}{27:}BUFFER:ARRAY[0..BUFSIZE]OF ASCIICODE;{:27}{29:} PHASEONE:BOOLEAN;{:29}{38:} BYTEMEM:PACKED ARRAY[0..1,0..MAXBYTES]OF ASCIICODE; TOKMEM:PACKED ARRAY[0..2,0..MAXTOKS]OF EIGHTBITS; BYTESTART:ARRAY[0..MAXNAMES]OF SIXTEENBITS; TOKSTART:ARRAY[0..MAXTEXTS]OF SIXTEENBITS; LINK:ARRAY[0..MAXNAMES]OF SIXTEENBITS; ILK:ARRAY[0..MAXNAMES]OF SIXTEENBITS; EQUIV:ARRAY[0..MAXNAMES]OF SIXTEENBITS; TEXTLINK:ARRAY[0..MAXTEXTS]OF SIXTEENBITS;{:38}{40:}NAMEPTR:NAMEPOINTER; STRINGPTR:NAMEPOINTER;BYTEPTR:ARRAY[0..1]OF 0..MAXBYTES; POOLCHECKSUM:INTEGER;{:40}{44:}TEXTPTR:TEXTPOINTER; TOKPTR:ARRAY[0..2]OF 0..MAXTOKS;Z:0..2; MAXTOKPTR:ARRAY[0..2]OF 0..MAXTOKS;{:44}{50:}IDFIRST:0..BUFSIZE; IDLOC:0..BUFSIZE;DOUBLECHARS:0..BUFSIZE; HASH,CHOPHASH:ARRAY[0..HASHSIZE]OF SIXTEENBITS; CHOPPEDID:ARRAY[0..UNAMBIGLENGT]OF ASCIICODE;{:50}{65:} MODTEXT:ARRAY[0..LONGESTNAME]OF ASCIICODE;{:65}{70:} LASTUNNAMED:TEXTPOINTER;{:70}{79:}CURSTATE:OUTPUTSTATE; STACK:ARRAY[1..STACKSIZE]OF OUTPUTSTATE;STACKPTR:0..STACKSIZE;{:79}{80:} ZO:0..2;{:80}{82:}BRACELEVEL:EIGHTBITS;{:82}{86:}CURVAL:INTEGER;{:86} {94:}OUTBUF:ARRAY[0..OUTBUFSIZE]OF ASCIICODE;OUTPTR:0..OUTBUFSIZE; BREAKPTR:0..OUTBUFSIZE;SEMIPTR:0..OUTBUFSIZE;{:94}{95:} OUTSTATE:EIGHTBITS;OUTVAL,OUTAPP:INTEGER;OUTSIGN:ASCIICODE; LASTSIGN:-1..+1;{:95}{100:}OUTCONTRIB:ARRAY[1..LINELENGTH]OF ASCIICODE; {:100}{124:}LINE:INTEGER;OTHERLINE:INTEGER;TEMPLINE:INTEGER; LIMIT:0..BUFSIZE;LOC:0..BUFSIZE;INPUTHASENDE:BOOLEAN;CHANGING:BOOLEAN; {:124}{126:}CHANGEBUFFER:ARRAY[0..BUFSIZE]OF ASCIICODE; CHANGELIMIT:0..BUFSIZE;{:126}{143:}CURMODULE:NAMEPOINTER; SCANNINGHEX:BOOLEAN;{:143}{156:}NEXTCONTROL:EIGHTBITS;{:156}{164:} CURREPLTEXT:TEXTPOINTER;{:164}{171:}MODULECOUNT:0..12287;{:171}{179:} TROUBLESHOOT:BOOLEAN;DDT:INTEGER;DD:INTEGER;DEBUGCYCLE:INTEGER; DEBUGSKIPPED:INTEGER;TERMIN:TEXTFILE;{:179}{185:}WO:0..1;{:185}{30:} PROCEDURE DEBUGHELP;FORWARD;{:30}{31:}PROCEDURE ERROR; VAR J:0..OUTBUFSIZE;K,L:0..BUFSIZE;BEGIN IF PHASEONE THEN{32:} BEGIN IF CHANGING THEN WRITE(TERMOUT,'. (change file ')ELSE WRITE( TERMOUT,'. (');WRITELN(TERMOUT,'l.',LINE:1,')'); IF LOC>=LIMIT THEN L:=LIMIT ELSE L:=LOC; FOR K:=1 TO L DO IF BUFFER[K-1]=9 THEN WRITE(TERMOUT,' ')ELSE WRITE( TERMOUT,XCHR[BUFFER[K-1]]);WRITELN(TERMOUT); FOR K:=1 TO L DO WRITE(TERMOUT,' '); FOR K:=L+1 TO LIMIT DO WRITE(TERMOUT,XCHR[BUFFER[K-1]]); WRITE(TERMOUT,' ');END{:32}ELSE{33:} BEGIN WRITELN(TERMOUT,'. (l.',LINE:1,')'); FOR J:=1 TO OUTPTR DO WRITE(TERMOUT,XCHR[OUTBUF[J-1]]); WRITE(TERMOUT,'... ');END{:33};BREAK(TERMOUT);HISTORY:=2;DEBUGHELP;END; {:31}{34:}PROCEDURE JUMPOUT;BEGIN GOTO 9999;END;{:34} PROCEDURE INITIALIZE;VAR{16:}I:0..127;{:16}{41:}WI:0..1;{:41}{45:} ZI:0..2;{:45}{51:}H:0..HASHSIZE;{:51}BEGIN{10:}HISTORY:=0;{:10}{14:} XCHR[32]:=' ';XCHR[33]:='!';XCHR[34]:='"';XCHR[35]:='#';XCHR[36]:='$'; XCHR[37]:='%';XCHR[38]:='&';XCHR[39]:='''';XCHR[40]:='(';XCHR[41]:=')'; XCHR[42]:='*';XCHR[43]:='+';XCHR[44]:=',';XCHR[45]:='-';XCHR[46]:='.'; XCHR[47]:='/';XCHR[48]:='0';XCHR[49]:='1';XCHR[50]:='2';XCHR[51]:='3'; XCHR[52]:='4';XCHR[53]:='5';XCHR[54]:='6';XCHR[55]:='7';XCHR[56]:='8'; XCHR[57]:='9';XCHR[58]:=':';XCHR[59]:=';';XCHR[60]:='<';XCHR[61]:='='; XCHR[62]:='>';XCHR[63]:='?';XCHR[64]:='@';XCHR[65]:='A';XCHR[66]:='B'; XCHR[67]:='C';XCHR[68]:='D';XCHR[69]:='E';XCHR[70]:='F';XCHR[71]:='G'; XCHR[72]:='H';XCHR[73]:='I';XCHR[74]:='J';XCHR[75]:='K';XCHR[76]:='L'; XCHR[77]:='M';XCHR[78]:='N';XCHR[79]:='O';XCHR[80]:='P';XCHR[81]:='Q'; XCHR[82]:='R';XCHR[83]:='S';XCHR[84]:='T';XCHR[85]:='U';XCHR[86]:='V'; XCHR[87]:='W';XCHR[88]:='X';XCHR[89]:='Y';XCHR[90]:='Z';XCHR[91]:='['; XCHR[92]:='\';XCHR[93]:=']';XCHR[94]:='^';XCHR[95]:='_';XCHR[96]:='`'; XCHR[97]:='a';XCHR[98]:='b';XCHR[99]:='c';XCHR[100]:='d';XCHR[101]:='e'; XCHR[102]:='f';XCHR[103]:='g';XCHR[104]:='h';XCHR[105]:='i'; XCHR[106]:='j';XCHR[107]:='k';XCHR[108]:='l';XCHR[109]:='m'; XCHR[110]:='n';XCHR[111]:='o';XCHR[112]:='p';XCHR[113]:='q'; XCHR[114]:='r';XCHR[115]:='s';XCHR[116]:='t';XCHR[117]:='u'; XCHR[118]:='v';XCHR[119]:='w';XCHR[120]:='x';XCHR[121]:='y'; XCHR[122]:='z';XCHR[123]:='{';XCHR[124]:='|';XCHR[125]:='}'; XCHR[126]:='~';XCHR[0]:=' ';XCHR[127]:=' ';{:14}{17:} FOR I:=1 TO 31 DO XCHR[I]:=' ';{:17}{18:} FOR I:=0 TO 127 DO XORD[CHR(I)]:=32;FOR I:=1 TO 126 DO XORD[XCHR[I]]:=I; {:18}{21:}REWRITE(TERMOUT,'TTY:');{:21}{26:}REWRITE(PASCALFILE); REWRITE(POOL);{:26}{42:}FOR WI:=0 TO 1 DO BEGIN BYTESTART[WI]:=0; BYTEPTR[WI]:=0;END;BYTESTART[2]:=0;NAMEPTR:=1;STRINGPTR:=128; POOLCHECKSUM:=271828;{:42}{46:}FOR ZI:=0 TO 2 DO BEGIN TOKSTART[ZI]:=0; TOKPTR[ZI]:=0;END;TOKSTART[3]:=0;TEXTPTR:=1;Z:=1 MOD 3;{:46}{48:} ILK[0]:=0;EQUIV[0]:=0;{:48}{52:} FOR H:=0 TO HASHSIZE-1 DO BEGIN HASH[H]:=0;CHOPHASH[H]:=0;END;{:52}{71:} LASTUNNAMED:=0;TEXTLINK[0]:=0;{:71}{144:}SCANNINGHEX:=FALSE;{:144}{152:} MODTEXT[0]:=32;{:152}{180:}TROUBLESHOOT:=TRUE;DEBUGCYCLE:=1; DEBUGSKIPPED:=0;TROUBLESHOOT:=FALSE;DEBUGCYCLE:=99999; RESET(TERMIN,'TTY:','/I');{:180}END;{:2}{24:}PROCEDURE OPENINPUT; BEGIN RESET(WEBFILE);RESET(CHANGEFILE);END;{:24}{28:} FUNCTION INPUTLN(VAR F:TEXTFILE):BOOLEAN;VAR FINALLIMIT:0..BUFSIZE; BEGIN LIMIT:=0;FINALLIMIT:=0; IF EOF(F)THEN INPUTLN:=FALSE ELSE BEGIN WHILE NOT EOLN(F)DO BEGIN BUFFER [LIMIT]:=XORD[F^];GET(F);LIMIT:=LIMIT+1; IF BUFFER[LIMIT-1]<>32 THEN FINALLIMIT:=LIMIT; IF LIMIT=BUFSIZE THEN BEGIN WHILE NOT EOLN(F)DO GET(F);LIMIT:=LIMIT-1; BEGIN WRITELN(TERMOUT);WRITE(TERMOUT,'! Input line too long');END; LOC:=0;ERROR;END;END;READLN(F);LIMIT:=FINALLIMIT;INPUTLN:=TRUE;END;END; {:28}{49:}PROCEDURE PRINTID(P:NAMEPOINTER);VAR K:0..MAXBYTES;W:0..1; BEGIN IF P>=NAMEPTR THEN WRITE(TERMOUT,'IMPOSSIBLE')ELSE BEGIN W:=P MOD 2; FOR K:=BYTESTART[P]TO BYTESTART[P+2]-1 DO WRITE(TERMOUT,XCHR[BYTEMEM[W,K ]]);END;END;{:49}{53:}FUNCTION IDLOOKUP(T:EIGHTBITS):NAMEPOINTER; LABEL 31,32;VAR C:EIGHTBITS;I:0..BUFSIZE;H:0..HASHSIZE;K:0..MAXBYTES; W:0..1;L:0..BUFSIZE;P,Q:NAMEPOINTER;S:0..UNAMBIGLENGT; BEGIN L:=IDLOC-IDFIRST;{54:}H:=BUFFER[IDFIRST];I:=IDFIRST+1; WHILE I0 DO BEGIN IF BYTESTART[P+2]-BYTESTART[P]=L THEN{56:} BEGIN I:=IDFIRST;K:=BYTESTART[P];W:=P MOD 2; WHILE(I0)THEN{57:} BEGIN IF((P<>NAMEPTR)AND(T<>0)AND(ILK[P]=0))OR((P=NAMEPTR)AND(T=0)AND( BUFFER[IDFIRST]<>34))THEN{58:}BEGIN I:=IDFIRST;S:=0;H:=0; WHILE(I95 THEN BEGIN IF BUFFER[I]>=97 THEN CHOPPEDID[S]:=BUFFER[I]-32 ELSE CHOPPEDID[S]:=BUFFER[ I];H:=(H+H+CHOPPEDID[S])MOD HASHSIZE;S:=S+1;END;I:=I+1;END; CHOPPEDID[S]:=0;END{:58};IF P<>NAMEPTR THEN{59:} BEGIN IF ILK[P]=0 THEN BEGIN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! This identifier has already appeared');ERROR;END;{60:} Q:=CHOPHASH[H]; IF Q=P THEN CHOPHASH[H]:=EQUIV[P]ELSE BEGIN WHILE EQUIV[Q]<>P DO Q:= EQUIV[Q];EQUIV[Q]:=EQUIV[P];END{:60};END ELSE BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! This identifier was defined before');ERROR;END; ILK[P]:=T;END{:59}ELSE{61:} BEGIN IF(T=0)AND(BUFFER[IDFIRST]<>34)THEN{62:}BEGIN Q:=CHOPHASH[H]; WHILE Q<>0 DO BEGIN{63:}BEGIN K:=BYTESTART[Q];S:=0;W:=Q MOD 2; WHILE(K95 THEN BEGIN IF C>=97 THEN C:=C-32; IF CHOPPEDID[S]<>C THEN GOTO 32;S:=S+1;END;K:=K+1;END; IF(K=BYTESTART[Q+2])AND(CHOPPEDID[S]<>0)THEN GOTO 32; BEGIN WRITELN(TERMOUT);WRITE(TERMOUT,'! Identifier conflict with ');END; FOR K:=BYTESTART[Q]TO BYTESTART[Q+2]-1 DO WRITE(TERMOUT,XCHR[BYTEMEM[W,K ]]);ERROR;Q:=0;32:END{:63};Q:=EQUIV[Q];END;EQUIV[P]:=CHOPHASH[H]; CHOPHASH[H]:=P;END{:62};W:=NAMEPTR MOD 2;K:=BYTEPTR[W]; IF K+L>MAXBYTES THEN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Sorry, ','byte memory',' capacity exceeded');ERROR; HISTORY:=3;JUMPOUT;END; IF NAMEPTR>MAXNAMES-2 THEN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Sorry, ','name',' capacity exceeded');ERROR;HISTORY:=3; JUMPOUT;END;I:=IDFIRST;WHILE I34 THEN ILK[P]:=T ELSE{64:} BEGIN ILK[P]:=1; IF L-DOUBLECHARS=2 THEN EQUIV[P]:=BUFFER[IDFIRST+1]+32768 ELSE BEGIN EQUIV[P]:=STRINGPTR+32768;L:=L-DOUBLECHARS-1; IF L>99 THEN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Preprocessed string is too long');ERROR;END; STRINGPTR:=STRINGPTR+1;WRITE(POOL,XCHR[48+L DIV 10],XCHR[48+L MOD 10]); POOLCHECKSUM:=POOLCHECKSUM+POOLCHECKSUM+L; WHILE POOLCHECKSUM>536870839 DO POOLCHECKSUM:=POOLCHECKSUM-536870839; I:=IDFIRST+1;WHILE I536870839 DO POOLCHECKSUM:=POOLCHECKSUM-536870839; IF(BUFFER[I]=34)OR(BUFFER[I]=64)THEN I:=I+2 ELSE I:=I+1;END; WRITELN(POOL);END;END{:64};END{:61};END{:57};IDLOOKUP:=P;END;{:53}{66:} FUNCTION MODLOOKUP(L:SIXTEENBITS):NAMEPOINTER;LABEL 31;VAR C:0..4; J:0..LONGESTNAME;K:0..MAXBYTES;W:0..1;P:NAMEPOINTER;Q:NAMEPOINTER; BEGIN C:=2;Q:=0;P:=ILK[0];WHILE P<>0 DO BEGIN{68:}BEGIN K:=BYTESTART[P]; W:=P MOD 2;C:=1;J:=1; WHILE(KL THEN C:=1 ELSE C:=4 ELSE IF J>L THEN C:=3 ELSE IF MODTEXT[J]MAXBYTES THEN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Sorry, ','byte memory',' capacity exceeded');ERROR; HISTORY:=3;JUMPOUT;END; IF NAMEPTR>MAXNAMES-2 THEN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Sorry, ','name',' capacity exceeded');ERROR;HISTORY:=3; JUMPOUT;END;P:=NAMEPTR;IF C=0 THEN LINK[Q]:=P ELSE ILK[Q]:=P;LINK[P]:=0; ILK[P]:=0;C:=1;EQUIV[P]:=0; FOR J:=1 TO L DO BYTEMEM[W,K+J-1]:=MODTEXT[J];BYTEPTR[W]:=K+L; BYTESTART[NAMEPTR+2]:=K+L;NAMEPTR:=NAMEPTR+1;{:67}; 31:IF C<>1 THEN BEGIN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Incompatible section names');ERROR;END;P:=0;END; MODLOOKUP:=P;END;{:66}{69:} FUNCTION PREFIXLOOKUP(L:SIXTEENBITS):NAMEPOINTER;VAR C:0..4; COUNT:0..MAXNAMES;J:0..LONGESTNAME;K:0..MAXBYTES;W:0..1;P:NAMEPOINTER; Q:NAMEPOINTER;R:NAMEPOINTER;BEGIN Q:=0;P:=ILK[0];COUNT:=0;R:=0; WHILE P<>0 DO BEGIN{68:}BEGIN K:=BYTESTART[P];W:=P MOD 2;C:=1;J:=1; WHILE(KL THEN C:=1 ELSE C:=4 ELSE IF J>L THEN C:=3 ELSE IF MODTEXT[J]1 THEN IF COUNT=0 THEN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Name does not match');ERROR; END ELSE BEGIN WRITELN(TERMOUT);WRITE(TERMOUT,'! Ambiguous prefix'); ERROR;END;PREFIXLOOKUP:=R;END;{:69}{73:} PROCEDURE STORETWOBYTE(X:SIXTEENBITS); BEGIN IF TOKPTR[Z]+2>MAXTOKS THEN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Sorry, ','token',' capacity exceeded');ERROR; HISTORY:=3;JUMPOUT;END;TOKMEM[Z,TOKPTR[Z]]:=X DIV 256; TOKMEM[Z,TOKPTR[Z]+1]:=X MOD 256;TOKPTR[Z]:=TOKPTR[Z]+2;END;{:73}{74:} PROCEDURE PRINTREPL(P:TEXTPOINTER);VAR K:0..MAXTOKS;A:SIXTEENBITS; ZP:0..2; BEGIN IF P>=TEXTPTR THEN WRITE(TERMOUT,'BAD')ELSE BEGIN K:=TOKSTART[P]; ZP:=P MOD 3;WHILE K=128 THEN{75:}BEGIN K:=K+1; IF A<168 THEN BEGIN A:=(A-128)*256+TOKMEM[ZP,K];PRINTID(A); IF BYTEMEM[A MOD 2,BYTESTART[A]]=34 THEN WRITE(TERMOUT,'"')ELSE WRITE( TERMOUT,' ');END ELSE IF A<208 THEN BEGIN WRITE(TERMOUT,'@<'); PRINTID((A-168)*256+TOKMEM[ZP,K]);WRITE(TERMOUT,'@>'); END ELSE BEGIN A:=(A-208)*256+TOKMEM[ZP,K]; WRITE(TERMOUT,'@',XCHR[123],A:1,'@',XCHR[125]);END;END{:75}ELSE{76:} CASE A OF 9:WRITE(TERMOUT,'@',XCHR[123]); 10:WRITE(TERMOUT,'@',XCHR[125]);12:WRITE(TERMOUT,'@'''); 13:WRITE(TERMOUT,'@"');125:WRITE(TERMOUT,'@$');0:WRITE(TERMOUT,'#'); 64:WRITE(TERMOUT,'@@');2:WRITE(TERMOUT,'@=');3:WRITE(TERMOUT,'@\'); OTHERS:WRITE(TERMOUT,XCHR[A])END{:76};K:=K+1;END;END;END;{:74}{84:} PROCEDURE PUSHLEVEL(P:NAMEPOINTER); BEGIN IF STACKPTR=STACKSIZE THEN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Sorry, ','stack',' capacity exceeded');ERROR; HISTORY:=3;JUMPOUT;END ELSE BEGIN STACK[STACKPTR]:=CURSTATE; STACKPTR:=STACKPTR+1;CURSTATE.NAMEFIELD:=P;CURSTATE.REPLFIELD:=EQUIV[P]; ZO:=CURSTATE.REPLFIELD MOD 3; CURSTATE.BYTEFIELD:=TOKSTART[CURSTATE.REPLFIELD]; CURSTATE.ENDFIELD:=TOKSTART[CURSTATE.REPLFIELD+3];CURSTATE.MODFIELD:=0; END;END;{:84}{85:}PROCEDURE POPLEVEL;LABEL 10; BEGIN IF TEXTLINK[CURSTATE.REPLFIELD]=0 THEN BEGIN IF ILK[CURSTATE. NAMEFIELD]=3 THEN{91:}BEGIN NAMEPTR:=NAMEPTR-1;TEXTPTR:=TEXTPTR-1; Z:=TEXTPTR MOD 3;IF TOKPTR[Z]>MAXTOKPTR[Z]THEN MAXTOKPTR[Z]:=TOKPTR[Z]; TOKPTR[Z]:=TOKSTART[TEXTPTR]; BYTEPTR[NAMEPTR MOD 2]:=BYTEPTR[NAMEPTR MOD 2]-1;END{:91}; END ELSE IF TEXTLINK[CURSTATE.REPLFIELD]0 THEN BEGIN CURSTATE:=STACK[STACKPTR]; ZO:=CURSTATE.REPLFIELD MOD 3;END;10:END;{:85}{87:} FUNCTION GETOUTPUT:SIXTEENBITS;LABEL 20,30,31;VAR A:SIXTEENBITS; B:EIGHTBITS;BAL:SIXTEENBITS;K:0..MAXBYTES;W:0..1; BEGIN 20:IF STACKPTR=0 THEN BEGIN A:=0;GOTO 31;END; IF CURSTATE.BYTEFIELD=CURSTATE.ENDFIELD THEN BEGIN CURVAL:=-CURSTATE. MODFIELD;POPLEVEL;IF CURVAL=0 THEN GOTO 20;A:=129;GOTO 31;END; A:=TOKMEM[ZO,CURSTATE.BYTEFIELD]; CURSTATE.BYTEFIELD:=CURSTATE.BYTEFIELD+1;IF A<128 THEN IF A=0 THEN{92:} BEGIN PUSHLEVEL(NAMEPTR-1);GOTO 20;END{:92}ELSE GOTO 31; A:=(A-128)*256+TOKMEM[ZO,CURSTATE.BYTEFIELD]; CURSTATE.BYTEFIELD:=CURSTATE.BYTEFIELD+1;IF A<10240 THEN{89:} BEGIN CASE ILK[A]OF 0:BEGIN CURVAL:=A;A:=130;END; 1:BEGIN CURVAL:=EQUIV[A]-32768;A:=128;END;2:BEGIN PUSHLEVEL(A);GOTO 20; END;3:BEGIN{90:} WHILE(CURSTATE.BYTEFIELD=CURSTATE.ENDFIELD)AND(STACKPTR>0)DO POPLEVEL; IF(STACKPTR=0)OR(TOKMEM[ZO,CURSTATE.BYTEFIELD]<>40)THEN BEGIN BEGIN WRITELN(TERMOUT);WRITE(TERMOUT,'! No parameter given for ');END; PRINTID(A);ERROR;GOTO 20;END;{93:}BAL:=1; CURSTATE.BYTEFIELD:=CURSTATE.BYTEFIELD+1; WHILE TRUE DO BEGIN B:=TOKMEM[ZO,CURSTATE.BYTEFIELD]; CURSTATE.BYTEFIELD:=CURSTATE.BYTEFIELD+1; IF B=0 THEN STORETWOBYTE(NAMEPTR+32767)ELSE BEGIN IF B>=128 THEN BEGIN BEGIN IF TOKPTR[Z]=MAXTOKS THEN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Sorry, ','token',' capacity exceeded');ERROR; HISTORY:=3;JUMPOUT;END;TOKMEM[Z,TOKPTR[Z]]:=B;TOKPTR[Z]:=TOKPTR[Z]+1; END;B:=TOKMEM[ZO,CURSTATE.BYTEFIELD]; CURSTATE.BYTEFIELD:=CURSTATE.BYTEFIELD+1; END ELSE CASE B OF 40:BAL:=BAL+1;41:BEGIN BAL:=BAL-1; IF BAL=0 THEN GOTO 30;END; 39:REPEAT BEGIN IF TOKPTR[Z]=MAXTOKS THEN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Sorry, ','token',' capacity exceeded');ERROR; HISTORY:=3;JUMPOUT;END;TOKMEM[Z,TOKPTR[Z]]:=B;TOKPTR[Z]:=TOKPTR[Z]+1; END;B:=TOKMEM[ZO,CURSTATE.BYTEFIELD]; CURSTATE.BYTEFIELD:=CURSTATE.BYTEFIELD+1;UNTIL B=39;OTHERS:END; BEGIN IF TOKPTR[Z]=MAXTOKS THEN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Sorry, ','token',' capacity exceeded');ERROR; HISTORY:=3;JUMPOUT;END;TOKMEM[Z,TOKPTR[Z]]:=B;TOKPTR[Z]:=TOKPTR[Z]+1; END;END;END;30:{:93};EQUIV[NAMEPTR]:=TEXTPTR;ILK[NAMEPTR]:=2; W:=NAMEPTR MOD 2;K:=BYTEPTR[W]; IF K=MAXBYTES THEN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Sorry, ','byte memory',' capacity exceeded');ERROR; HISTORY:=3;JUMPOUT;END;BYTEMEM[W,K]:=35;K:=K+1;BYTEPTR[W]:=K; IF NAMEPTR>MAXNAMES-2 THEN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Sorry, ','name',' capacity exceeded');ERROR;HISTORY:=3; JUMPOUT;END;BYTESTART[NAMEPTR+2]:=K;NAMEPTR:=NAMEPTR+1; IF TEXTPTR>MAXTEXTS-3 THEN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Sorry, ','text',' capacity exceeded');ERROR;HISTORY:=3; JUMPOUT;END;TEXTLINK[TEXTPTR]:=0;TOKSTART[TEXTPTR+3]:=TOKPTR[Z]; TEXTPTR:=TEXTPTR+1;Z:=TEXTPTR MOD 3{:90};PUSHLEVEL(A);GOTO 20;END; OTHERS:BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! This can''t happen (','output',')');ERROR;HISTORY:=3; JUMPOUT;END END;GOTO 31;END{:89};IF A<20480 THEN{88:}BEGIN A:=A-10240; IF EQUIV[A]<>0 THEN PUSHLEVEL(A)ELSE IF A<>0 THEN BEGIN BEGIN WRITELN( TERMOUT);WRITE(TERMOUT,'! Not present: <');END;PRINTID(A); WRITE(TERMOUT,'>');ERROR;END;GOTO 20;END{:88};CURVAL:=A-20480;A:=129; CURSTATE.MODFIELD:=CURVAL;31:IF TROUBLESHOOT THEN DEBUGHELP; GETOUTPUT:=A;END;{:87}{97:}PROCEDURE FLUSHBUFFER;VAR K:0..OUTBUFSIZE; B:0..OUTBUFSIZE;BEGIN B:=BREAKPTR; IF(SEMIPTR<>0)AND(OUTPTR-SEMIPTR<=LINELENGTH)THEN BREAKPTR:=SEMIPTR; FOR K:=1 TO BREAKPTR DO WRITE(PASCALFILE,XCHR[OUTBUF[K-1]]); WRITELN(PASCALFILE);LINE:=LINE+1; IF LINE MOD 100=0 THEN BEGIN WRITE(TERMOUT,'.'); IF LINE MOD 500=0 THEN WRITE(TERMOUT,LINE:1);BREAK(TERMOUT);END; IF BREAKPTRB THEN B:=BREAKPTR;END; FOR K:=BREAKPTR TO OUTPTR-1 DO OUTBUF[K-BREAKPTR]:=OUTBUF[K];END; OUTPTR:=OUTPTR-BREAKPTR;BREAKPTR:=B-BREAKPTR;SEMIPTR:=0; IF OUTPTR>LINELENGTH THEN BEGIN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Long line must be truncated');ERROR;END; OUTPTR:=LINELENGTH;END;END;{:97}{99:}PROCEDURE APPVAL(V:INTEGER); VAR K:0..OUTBUFSIZE;BEGIN K:=OUTBUFSIZE;REPEAT OUTBUF[K]:=V MOD 10; V:=V DIV 10;K:=K-1;UNTIL V=0;REPEAT K:=K+1; BEGIN OUTBUF[OUTPTR]:=OUTBUF[K]+48;OUTPTR:=OUTPTR+1;END; UNTIL K=OUTBUFSIZE;END;{:99}{101:}PROCEDURE SENDOUT(T:EIGHTBITS; V:SIXTEENBITS);LABEL 20;VAR K:0..LINELENGTH;BEGIN{102:} 20:CASE OUTSTATE OF 1:IF T<>3 THEN BEGIN BREAKPTR:=OUTPTR; IF T=2 THEN BEGIN OUTBUF[OUTPTR]:=32;OUTPTR:=OUTPTR+1;END;END; 2:BEGIN BEGIN OUTBUF[OUTPTR]:=44-OUTAPP;OUTPTR:=OUTPTR+1;END; IF OUTPTR>LINELENGTH THEN FLUSHBUFFER;BREAKPTR:=OUTPTR;END; 3,4:BEGIN{103:} IF(OUTVAL<0)OR((OUTVAL=0)AND(LASTSIGN<0))THEN BEGIN OUTBUF[OUTPTR]:=45; OUTPTR:=OUTPTR+1; END ELSE IF OUTSIGN>0 THEN BEGIN OUTBUF[OUTPTR]:=OUTSIGN; OUTPTR:=OUTPTR+1;END;APPVAL(ABS(OUTVAL)); IF OUTPTR>LINELENGTH THEN FLUSHBUFFER;{:103};OUTSTATE:=OUTSTATE-2; GOTO 20;END;5:{104:}BEGIN IF(T=3)OR({105:} ((T=2)AND(V=3)AND(((OUTCONTRIB[1]=68)AND(OUTCONTRIB[2]=73)AND(OUTCONTRIB [3]=86))OR((OUTCONTRIB[1]=77)AND(OUTCONTRIB[2]=79)AND(OUTCONTRIB[3]=68)) ))OR((T=0)AND((V=42)OR(V=47))){:105})THEN BEGIN{103:} IF(OUTVAL<0)OR((OUTVAL=0)AND(LASTSIGN<0))THEN BEGIN OUTBUF[OUTPTR]:=45; OUTPTR:=OUTPTR+1; END ELSE IF OUTSIGN>0 THEN BEGIN OUTBUF[OUTPTR]:=OUTSIGN; OUTPTR:=OUTPTR+1;END;APPVAL(ABS(OUTVAL)); IF OUTPTR>LINELENGTH THEN FLUSHBUFFER;{:103};OUTSIGN:=43;OUTVAL:=OUTAPP; END ELSE OUTVAL:=OUTVAL+OUTAPP;OUTSTATE:=3;GOTO 20;END{:104}; 0:IF T<>3 THEN BREAKPTR:=OUTPTR;OTHERS:END{:102}; IF T<>0 THEN FOR K:=1 TO V DO BEGIN OUTBUF[OUTPTR]:=OUTCONTRIB[K]; OUTPTR:=OUTPTR+1;END ELSE BEGIN OUTBUF[OUTPTR]:=V;OUTPTR:=OUTPTR+1;END; IF OUTPTR>LINELENGTH THEN FLUSHBUFFER; IF(T=0)AND((V=59)OR(V=125))THEN BEGIN SEMIPTR:=OUTPTR;BREAKPTR:=OUTPTR; END;IF T>=2 THEN OUTSTATE:=1 ELSE OUTSTATE:=0 END;{:101}{106:} PROCEDURE SENDSIGN(V:INTEGER); BEGIN CASE OUTSTATE OF 2,4:OUTAPP:=OUTAPP*V;3:BEGIN OUTAPP:=V; OUTSTATE:=4;END;5:BEGIN OUTVAL:=OUTVAL+OUTAPP;OUTAPP:=V;OUTSTATE:=4;END; OTHERS:BEGIN BREAKPTR:=OUTPTR;OUTAPP:=V;OUTSTATE:=2;END END; LASTSIGN:=OUTAPP;END;{:106}{107:}PROCEDURE SENDVAL(V:INTEGER); LABEL 666,10;BEGIN CASE OUTSTATE OF 1:BEGIN{110:} IF(OUTPTR=BREAKPTR+3)OR((OUTPTR=BREAKPTR+4)AND(OUTBUF[BREAKPTR]=32))THEN IF((OUTBUF[OUTPTR-3]=68)AND(OUTBUF[OUTPTR-2]=73)AND(OUTBUF[OUTPTR-1]=86) )OR((OUTBUF[OUTPTR-3]=77)AND(OUTBUF[OUTPTR-2]=79)AND(OUTBUF[OUTPTR-1]=68 ))THEN GOTO 666{:110};OUTSIGN:=32;OUTSTATE:=3;OUTVAL:=V; BREAKPTR:=OUTPTR;LASTSIGN:=+1;END;0:BEGIN{109:} IF(OUTPTR=BREAKPTR+1)AND((OUTBUF[BREAKPTR]=42)OR(OUTBUF[BREAKPTR]=47)) THEN GOTO 666{:109};OUTSIGN:=0;OUTSTATE:=3;OUTVAL:=V;BREAKPTR:=OUTPTR; LASTSIGN:=+1;END;{108:}2:BEGIN OUTSIGN:=43;OUTSTATE:=3;OUTVAL:=OUTAPP*V; END;3:BEGIN OUTSTATE:=5;OUTAPP:=V;BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Two numbers occurred without a sign between them'); ERROR;END;END;4:BEGIN OUTSTATE:=5;OUTAPP:=OUTAPP*V;END; 5:BEGIN OUTVAL:=OUTVAL+OUTAPP;OUTAPP:=V;BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Two numbers occurred without a sign between them'); ERROR;END;END;{:108}OTHERS:GOTO 666 END;GOTO 10;666:{111:} IF V>=0 THEN BEGIN IF OUTSTATE=1 THEN BEGIN BREAKPTR:=OUTPTR; BEGIN OUTBUF[OUTPTR]:=32;OUTPTR:=OUTPTR+1;END;END;APPVAL(V); IF OUTPTR>LINELENGTH THEN FLUSHBUFFER;OUTSTATE:=1; END ELSE BEGIN BEGIN OUTBUF[OUTPTR]:=40;OUTPTR:=OUTPTR+1;END; BEGIN OUTBUF[OUTPTR]:=45;OUTPTR:=OUTPTR+1;END;APPVAL(-V); BEGIN OUTBUF[OUTPTR]:=41;OUTPTR:=OUTPTR+1;END; IF OUTPTR>LINELENGTH THEN FLUSHBUFFER;OUTSTATE:=0;END{:111};10:END; {:107}{113:}PROCEDURE SENDTHEOUTPU;LABEL 2,21,22;VAR CURCHAR:EIGHTBITS; K:0..LINELENGTH;J:0..MAXBYTES;W:0..1;N:INTEGER; BEGIN WHILE STACKPTR>0 DO BEGIN CURCHAR:=GETOUTPUT; 21:CASE CURCHAR OF 0:;{116:} 65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88, 89,90:BEGIN OUTCONTRIB[1]:=CURCHAR;SENDOUT(2,1);END; 97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115 ,116,117,118,119,120,121,122:BEGIN OUTCONTRIB[1]:=CURCHAR-32; SENDOUT(2,1);END;130:BEGIN K:=0;J:=BYTESTART[CURVAL];W:=CURVAL MOD 2; WHILE(K=97 THEN OUTCONTRIB[K]:=OUTCONTRIB[K]-32 ELSE IF OUTCONTRIB[K]=95 THEN K:=K-1;END;SENDOUT(2,K);END;{:116}{119:} 48,49,50,51,52,53,54,55,56,57:BEGIN N:=0;REPEAT CURCHAR:=CURCHAR-48; IF N>=214748364 THEN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Constant too big');ERROR;END ELSE N:=10*N+CURCHAR; CURCHAR:=GETOUTPUT;UNTIL(CURCHAR>57)OR(CURCHAR<48);SENDVAL(N);K:=0; IF CURCHAR=101 THEN CURCHAR:=69;IF CURCHAR=69 THEN GOTO 2 ELSE GOTO 21; END;125:SENDVAL(POOLCHECKSUM);12:BEGIN N:=0;CURCHAR:=48; REPEAT CURCHAR:=CURCHAR-48;IF N>=268435456 THEN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Constant too big');ERROR;END ELSE N:=8*N+CURCHAR; CURCHAR:=GETOUTPUT;UNTIL(CURCHAR>55)OR(CURCHAR<48);SENDVAL(N);GOTO 21; END;13:BEGIN N:=0;CURCHAR:=48; REPEAT IF CURCHAR>=65 THEN CURCHAR:=CURCHAR-55 ELSE CURCHAR:=CURCHAR-48; IF N>=134217728 THEN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Constant too big');ERROR;END ELSE N:=16*N+CURCHAR; CURCHAR:=GETOUTPUT; UNTIL(CURCHAR>70)OR(CURCHAR<48)OR((CURCHAR>57)AND(CURCHAR<65)); SENDVAL(N);GOTO 21;END;128:SENDVAL(CURVAL);46:BEGIN K:=1; OUTCONTRIB[1]:=46;CURCHAR:=GETOUTPUT; IF CURCHAR=46 THEN BEGIN OUTCONTRIB[2]:=46;SENDOUT(1,2); END ELSE IF(CURCHAR>=48)AND(CURCHAR<=57)THEN GOTO 2 ELSE BEGIN SENDOUT(0 ,46);GOTO 21;END;END;{:119}43,45:SENDSIGN(44-CURCHAR);{114:} 4:BEGIN OUTCONTRIB[1]:=65;OUTCONTRIB[2]:=78;OUTCONTRIB[3]:=68; SENDOUT(2,3);END;5:BEGIN OUTCONTRIB[1]:=78;OUTCONTRIB[2]:=79; OUTCONTRIB[3]:=84;SENDOUT(2,3);END;6:BEGIN OUTCONTRIB[1]:=73; OUTCONTRIB[2]:=78;SENDOUT(2,2);END;31:BEGIN OUTCONTRIB[1]:=79; OUTCONTRIB[2]:=82;SENDOUT(2,2);END;24:BEGIN OUTCONTRIB[1]:=58; OUTCONTRIB[2]:=61;SENDOUT(1,2);END;26:BEGIN OUTCONTRIB[1]:=60; OUTCONTRIB[2]:=62;SENDOUT(1,2);END;28:BEGIN OUTCONTRIB[1]:=60; OUTCONTRIB[2]:=61;SENDOUT(1,2);END;29:BEGIN OUTCONTRIB[1]:=62; OUTCONTRIB[2]:=61;SENDOUT(1,2);END;30:BEGIN OUTCONTRIB[1]:=61; OUTCONTRIB[2]:=61;SENDOUT(1,2);END;32:BEGIN OUTCONTRIB[1]:=46; OUTCONTRIB[2]:=46;SENDOUT(1,2);END;{:114}39:{117:}BEGIN K:=1; OUTCONTRIB[1]:=39;REPEAT IF K0 THEN BEGIN BRACELEVEL:=BRACELEVEL-1; IF BRACELEVEL=0 THEN SENDOUT(0,125)ELSE SENDOUT(0,93); END ELSE BEGIN WRITELN(TERMOUT);WRITE(TERMOUT,'! Extra @}');ERROR;END; 129:BEGIN IF BRACELEVEL=0 THEN SENDOUT(0,123)ELSE SENDOUT(0,91); IF CURVAL<0 THEN BEGIN SENDOUT(0,58);SENDVAL(-CURVAL); END ELSE BEGIN SENDVAL(CURVAL);SENDOUT(0,58);END; IF BRACELEVEL=0 THEN SENDOUT(0,125)ELSE SENDOUT(0,93);END;{:121} 127:BEGIN SENDOUT(3,0);OUTSTATE:=6;END;2:{118:}BEGIN K:=0; REPEAT IF K0 DO BEGIN IF OUTPTR<=LINELENGTH THEN BREAKPTR:=OUTPTR; FLUSHBUFFER;END;OUTSTATE:=0;END{:122};OTHERS:BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Can''t output ASCII code ',CURCHAR:1);ERROR;END END; GOTO 22;2:{120:}REPEAT IF K69)AND((CURCHAR<48)OR(CURCHAR>57)); IF K=LINELENGTH THEN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Fraction too long');ERROR;END;SENDOUT(3,K); GOTO 21{:120};22:END;END;{:113}{127:}FUNCTION LINESDONTMAT:BOOLEAN; LABEL 10;VAR K:0..BUFSIZE;BEGIN LINESDONTMAT:=TRUE; IF CHANGELIMIT<>LIMIT THEN GOTO 10; IF LIMIT>0 THEN FOR K:=0 TO LIMIT-1 DO IF CHANGEBUFFER[K]<>BUFFER[K]THEN GOTO 10;LINESDONTMAT:=FALSE;10:END;{:127}{128:}PROCEDURE PRIMETHECHAN; LABEL 22,30,10;VAR K:0..BUFSIZE;BEGIN CHANGELIMIT:=0;{129:} WHILE TRUE DO BEGIN LINE:=LINE+1;IF NOT INPUTLN(CHANGEFILE)THEN GOTO 10; IF LIMIT<2 THEN GOTO 22;IF BUFFER[0]<>64 THEN GOTO 22; IF(BUFFER[1]>=88)AND(BUFFER[1]<=90)THEN BUFFER[1]:=BUFFER[1]+32; IF BUFFER[1]=120 THEN GOTO 30; IF(BUFFER[1]=121)OR(BUFFER[1]=122)THEN BEGIN LOC:=2; BEGIN WRITELN(TERMOUT);WRITE(TERMOUT,'! Where is the matching @x?'); ERROR;END;END;22:END;30:{:129};{130:}REPEAT LINE:=LINE+1; IF NOT INPUTLN(CHANGEFILE)THEN BEGIN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Change file ended after @x');ERROR;END;GOTO 10;END; UNTIL LIMIT>0;{:130};{131:}BEGIN CHANGELIMIT:=LIMIT; IF LIMIT>0 THEN FOR K:=0 TO LIMIT-1 DO CHANGEBUFFER[K]:=BUFFER[K]; END{:131};10:END;{:128}{132:}PROCEDURE CHECKCHANGE;LABEL 10; VAR N:INTEGER;K:0..BUFSIZE;BEGIN IF LINESDONTMAT THEN GOTO 10;N:=0; WHILE TRUE DO BEGIN CHANGING:=NOT CHANGING;TEMPLINE:=OTHERLINE; OTHERLINE:=LINE;LINE:=TEMPLINE;LINE:=LINE+1; IF NOT INPUTLN(CHANGEFILE)THEN BEGIN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Change file ended before @y');ERROR;END;CHANGELIMIT:=0; CHANGING:=NOT CHANGING;TEMPLINE:=OTHERLINE;OTHERLINE:=LINE; LINE:=TEMPLINE;GOTO 10;END;{133:} IF LIMIT>1 THEN IF BUFFER[0]=64 THEN BEGIN IF(BUFFER[1]>=88)AND(BUFFER[1 ]<=90)THEN BUFFER[1]:=BUFFER[1]+32; IF(BUFFER[1]=120)OR(BUFFER[1]=122)THEN BEGIN LOC:=2; BEGIN WRITELN(TERMOUT);WRITE(TERMOUT,'! Where is the matching @y?'); ERROR;END;END ELSE IF BUFFER[1]=121 THEN BEGIN IF N>0 THEN BEGIN LOC:=2; BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Hmm... ',N:1,' of the preceding lines failed to match') ;ERROR;END;END;GOTO 10;END;END{:133};{131:}BEGIN CHANGELIMIT:=LIMIT; IF LIMIT>0 THEN FOR K:=0 TO LIMIT-1 DO CHANGEBUFFER[K]:=BUFFER[K]; END{:131};CHANGING:=NOT CHANGING;TEMPLINE:=OTHERLINE;OTHERLINE:=LINE; LINE:=TEMPLINE;LINE:=LINE+1; IF NOT INPUTLN(WEBFILE)THEN BEGIN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! WEB file ended during a change');ERROR;END; INPUTHASENDE:=TRUE;GOTO 10;END;IF LINESDONTMAT THEN N:=N+1;END;10:END; {:132}{135:}PROCEDURE GETLINE;LABEL 20;BEGIN 20:IF CHANGING THEN{137:} BEGIN LINE:=LINE+1; IF NOT INPUTLN(CHANGEFILE)THEN BEGIN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Change file ended without @z');ERROR;END;BUFFER[0]:=64; BUFFER[1]:=122;LIMIT:=2;END; IF LIMIT>1 THEN IF BUFFER[0]=64 THEN BEGIN IF(BUFFER[1]>=88)AND(BUFFER[1 ]<=90)THEN BUFFER[1]:=BUFFER[1]+32; IF(BUFFER[1]=120)OR(BUFFER[1]=121)THEN BEGIN LOC:=2; BEGIN WRITELN(TERMOUT);WRITE(TERMOUT,'! Where is the matching @z?'); ERROR;END;END ELSE IF BUFFER[1]=122 THEN BEGIN PRIMETHECHAN; CHANGING:=NOT CHANGING;TEMPLINE:=OTHERLINE;OTHERLINE:=LINE; LINE:=TEMPLINE;END;END;END{:137};IF NOT CHANGING THEN BEGIN{136:} BEGIN LINE:=LINE+1; IF NOT INPUTLN(WEBFILE)THEN INPUTHASENDE:=TRUE ELSE IF LIMIT=CHANGELIMIT THEN IF BUFFER[0]=CHANGEBUFFER[0]THEN IF CHANGELIMIT>0 THEN CHECKCHANGE; END{:136};IF CHANGING THEN GOTO 20;END;LOC:=0;BUFFER[LIMIT]:=32;END; {:135}{139:}FUNCTION CONTROLCODE(C:ASCIICODE):EIGHTBITS; BEGIN CASE C OF 64:CONTROLCODE:=64;39:CONTROLCODE:=12; 34:CONTROLCODE:=13;36:CONTROLCODE:=125;32,9:CONTROLCODE:=136; 42:BEGIN WRITE(TERMOUT,'*',MODULECOUNT+1:1);BREAK(TERMOUT); CONTROLCODE:=136;END;68,100:CONTROLCODE:=133;70,102:CONTROLCODE:=132; 123:CONTROLCODE:=9;125:CONTROLCODE:=10;80,112:CONTROLCODE:=134; 84,116,94,46,58:CONTROLCODE:=131;38:CONTROLCODE:=127; 60:CONTROLCODE:=135;61:CONTROLCODE:=2;92:CONTROLCODE:=3; OTHERS:CONTROLCODE:=0 END;END;{:139}{140:}FUNCTION SKIPAHEAD:EIGHTBITS; LABEL 30;VAR C:EIGHTBITS; BEGIN WHILE TRUE DO BEGIN IF LOC>LIMIT THEN BEGIN GETLINE; IF INPUTHASENDE THEN BEGIN C:=136;GOTO 30;END;END;BUFFER[LIMIT+1]:=64; WHILE BUFFER[LOC]<>64 DO LOC:=LOC+1;IF LOC<=LIMIT THEN BEGIN LOC:=LOC+2; C:=CONTROLCODE(BUFFER[LOC-1]);IF(C<>0)OR(BUFFER[LOC-1]=62)THEN GOTO 30; END;END;30:SKIPAHEAD:=C;END;{:140}{141:}PROCEDURE SKIPCOMMENT;LABEL 10; VAR BAL:EIGHTBITS;C:ASCIICODE;BEGIN BAL:=0; WHILE TRUE DO BEGIN IF LOC>LIMIT THEN BEGIN GETLINE; IF INPUTHASENDE THEN BEGIN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Input ended in mid-comment');ERROR;END;GOTO 10;END;END; C:=BUFFER[LOC];LOC:=LOC+1;{142:}IF C=64 THEN BEGIN C:=BUFFER[LOC]; IF(C<>32)AND(C<>9)AND(C<>42)AND(C<>122)AND(C<>90)THEN LOC:=LOC+1 ELSE BEGIN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Section ended in mid-comment');ERROR;END;LOC:=LOC-1; GOTO 10; END END ELSE IF(C=92)AND(BUFFER[LOC]<>64)THEN LOC:=LOC+1 ELSE IF C=123 THEN BAL:=BAL+1 ELSE IF C=125 THEN BEGIN IF BAL=0 THEN GOTO 10; BAL:=BAL-1;END{:142};END;10:END;{:141}{145:}FUNCTION GETNEXT:EIGHTBITS; LABEL 20,30,31;VAR C:EIGHTBITS;D:EIGHTBITS;J,K:0..LONGESTNAME; BEGIN 20:IF LOC>LIMIT THEN BEGIN GETLINE; IF INPUTHASENDE THEN BEGIN C:=136;GOTO 31;END;END;C:=BUFFER[LOC]; LOC:=LOC+1;IF SCANNINGHEX THEN{146:} IF((C>=48)AND(C<=57))OR((C>=65)AND(C<=70))THEN GOTO 31 ELSE SCANNINGHEX :=FALSE{:146}; CASE C OF 65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85 ,86,87,88,89,90,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111 ,112,113,114,115,116,117,118,119,120,121,122:{148:} BEGIN IF((C=101)OR(C=69))AND(LOC>1)THEN IF(BUFFER[LOC-2]<=57)AND(BUFFER[ LOC-2]>=48)THEN C:=0;IF C<>0 THEN BEGIN LOC:=LOC-1;IDFIRST:=LOC; REPEAT LOC:=LOC+1;D:=BUFFER[LOC]; UNTIL((D<48)OR((D>57)AND(D<65))OR((D>90)AND(D<97))OR(D>122))AND(D<>95); IF LOC>IDFIRST+1 THEN BEGIN C:=130;IDLOC:=LOC;END;END ELSE C:=69; END{:148};34:{149:}BEGIN DOUBLECHARS:=0;IDFIRST:=LOC-1; REPEAT D:=BUFFER[LOC];LOC:=LOC+1; IF(D=34)OR(D=64)THEN IF BUFFER[LOC]=D THEN BEGIN LOC:=LOC+1;D:=0; DOUBLECHARS:=DOUBLECHARS+1; END ELSE BEGIN IF D=64 THEN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Double @ sign missing');ERROR; END END ELSE IF LOC>LIMIT THEN BEGIN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! String constant didn''t end');ERROR;END;D:=34;END; UNTIL D=34;IDLOC:=LOC-1;C:=130;END{:149};64:{150:} BEGIN C:=CONTROLCODE(BUFFER[LOC]);LOC:=LOC+1; IF C=0 THEN GOTO 20 ELSE IF C=13 THEN SCANNINGHEX:=TRUE ELSE IF C=135 THEN{151:}BEGIN{153:}K:=0; WHILE TRUE DO BEGIN IF LOC>LIMIT THEN BEGIN GETLINE; IF INPUTHASENDE THEN BEGIN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Input ended in section name');ERROR;END;GOTO 30;END; END;D:=BUFFER[LOC];{154:}IF D=64 THEN BEGIN D:=BUFFER[LOC+1]; IF D=62 THEN BEGIN LOC:=LOC+2;GOTO 30;END; IF(D=32)OR(D=9)OR(D=42)THEN BEGIN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Section name didn''t end');ERROR;END;GOTO 30;END; K:=K+1;MODTEXT[K]:=64;LOC:=LOC+1;END{:154};LOC:=LOC+1; IF K=LONGESTNAME-2 THEN BEGIN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Section name too long: ');END; FOR J:=1 TO 25 DO WRITE(TERMOUT,XCHR[MODTEXT[J]]);WRITE(TERMOUT,'...'); IF HISTORY=0 THEN HISTORY:=1;END{:155}; IF(MODTEXT[K]=32)AND(K>0)THEN K:=K-1;{:153}; IF K>3 THEN BEGIN IF(MODTEXT[K]=46)AND(MODTEXT[K-1]=46)AND(MODTEXT[K-2]= 46)THEN CURMODULE:=PREFIXLOOKUP(K-3)ELSE CURMODULE:=MODLOOKUP(K); END ELSE CURMODULE:=MODLOOKUP(K);END{:151} ELSE IF C=131 THEN BEGIN REPEAT C:=SKIPAHEAD;UNTIL C<>64; IF BUFFER[LOC-1]<>62 THEN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Improper @ within control text');ERROR;END;GOTO 20;END; END{:150};{147:} 46:IF BUFFER[LOC]=46 THEN BEGIN IF LOC<=LIMIT THEN BEGIN C:=32; LOC:=LOC+1;END; END ELSE IF BUFFER[LOC]=41 THEN BEGIN IF LOC<=LIMIT THEN BEGIN C:=93; LOC:=LOC+1;END;END; 58:IF BUFFER[LOC]=61 THEN BEGIN IF LOC<=LIMIT THEN BEGIN C:=24; LOC:=LOC+1;END;END; 61:IF BUFFER[LOC]=61 THEN BEGIN IF LOC<=LIMIT THEN BEGIN C:=30; LOC:=LOC+1;END;END; 62:IF BUFFER[LOC]=61 THEN BEGIN IF LOC<=LIMIT THEN BEGIN C:=29; LOC:=LOC+1;END;END; 60:IF BUFFER[LOC]=61 THEN BEGIN IF LOC<=LIMIT THEN BEGIN C:=28; LOC:=LOC+1;END; END ELSE IF BUFFER[LOC]=62 THEN BEGIN IF LOC<=LIMIT THEN BEGIN C:=26; LOC:=LOC+1;END;END; 40:IF BUFFER[LOC]=42 THEN BEGIN IF LOC<=LIMIT THEN BEGIN C:=9; LOC:=LOC+1;END; END ELSE IF BUFFER[LOC]=46 THEN BEGIN IF LOC<=LIMIT THEN BEGIN C:=91; LOC:=LOC+1;END;END; 42:IF BUFFER[LOC]=41 THEN BEGIN IF LOC<=LIMIT THEN BEGIN C:=10; LOC:=LOC+1;END;END;{:147}32,9:GOTO 20;123:BEGIN SKIPCOMMENT;GOTO 20;END; OTHERS:END;31:IF TROUBLESHOOT THEN DEBUGHELP;GETNEXT:=C;END;{:145}{157:} PROCEDURE SCANNUMERIC(P:NAMEPOINTER);LABEL 21,30; VAR ACCUMULATOR:INTEGER;NEXTSIGN:-1..+1;Q:NAMEPOINTER;VAL:INTEGER; BEGIN{158:}ACCUMULATOR:=0;NEXTSIGN:=+1; WHILE TRUE DO BEGIN NEXTCONTROL:=GETNEXT; 21:CASE NEXTCONTROL OF 48,49,50,51,52,53,54,55,56,57:BEGIN{160:}VAL:=0; REPEAT VAL:=10*VAL+NEXTCONTROL-48;NEXTCONTROL:=GETNEXT; UNTIL(NEXTCONTROL>57)OR(NEXTCONTROL<48){:160}; BEGIN ACCUMULATOR:=ACCUMULATOR+NEXTSIGN*(VAL);NEXTSIGN:=+1;END;GOTO 21; END;12:BEGIN{161:}VAL:=0;NEXTCONTROL:=48; REPEAT VAL:=8*VAL+NEXTCONTROL-48;NEXTCONTROL:=GETNEXT; UNTIL(NEXTCONTROL>55)OR(NEXTCONTROL<48){:161}; BEGIN ACCUMULATOR:=ACCUMULATOR+NEXTSIGN*(VAL);NEXTSIGN:=+1;END;GOTO 21; END;13:BEGIN{162:}VAL:=0;NEXTCONTROL:=48; REPEAT IF NEXTCONTROL>=65 THEN NEXTCONTROL:=NEXTCONTROL-7; VAL:=16*VAL+NEXTCONTROL-48;NEXTCONTROL:=GETNEXT; UNTIL(NEXTCONTROL>70)OR(NEXTCONTROL<48)OR((NEXTCONTROL>57)AND( NEXTCONTROL<65)){:162};BEGIN ACCUMULATOR:=ACCUMULATOR+NEXTSIGN*(VAL); NEXTSIGN:=+1;END;GOTO 21;END;130:BEGIN Q:=IDLOOKUP(0); IF ILK[Q]<>1 THEN BEGIN NEXTCONTROL:=42;GOTO 21;END; BEGIN ACCUMULATOR:=ACCUMULATOR+NEXTSIGN*(EQUIV[Q]-32768);NEXTSIGN:=+1; END;END;43:;45:NEXTSIGN:=-NEXTSIGN;132,133,135,134,136:GOTO 30; 59:BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Omit semicolon in numeric definition');ERROR;END; OTHERS:{159:}BEGIN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Improper numeric definition will be flushed');ERROR; END;REPEAT NEXTCONTROL:=SKIPAHEAD UNTIL(NEXTCONTROL>=132); IF NEXTCONTROL=135 THEN BEGIN LOC:=LOC-2;NEXTCONTROL:=GETNEXT;END; ACCUMULATOR:=0;GOTO 30;END{:159}END;END;30:{:158}; IF ABS(ACCUMULATOR)>=32768 THEN BEGIN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Value too big: ',ACCUMULATOR:1);ERROR;END; ACCUMULATOR:=0;END;EQUIV[P]:=ACCUMULATOR+32768;END;{:157}{165:} PROCEDURE SCANREPL(T:EIGHTBITS);LABEL 22,30,31;VAR A:SIXTEENBITS; B:ASCIICODE;BAL:EIGHTBITS;BEGIN BAL:=0; WHILE TRUE DO BEGIN 22:A:=GETNEXT;CASE A OF 40:BAL:=BAL+1; 41:IF BAL=0 THEN BEGIN WRITELN(TERMOUT);WRITE(TERMOUT,'! Extra )'); ERROR;END ELSE BAL:=BAL-1;39:{168:}BEGIN B:=39; WHILE TRUE DO BEGIN BEGIN IF TOKPTR[Z]=MAXTOKS THEN BEGIN WRITELN( TERMOUT);WRITE(TERMOUT,'! Sorry, ','token',' capacity exceeded');ERROR; HISTORY:=3;JUMPOUT;END;TOKMEM[Z,TOKPTR[Z]]:=B;TOKPTR[Z]:=TOKPTR[Z]+1; END;IF B=64 THEN IF BUFFER[LOC]=64 THEN LOC:=LOC+1 ELSE BEGIN WRITELN( TERMOUT);WRITE(TERMOUT,'! You should double @ signs in strings');ERROR; END;IF LOC=LIMIT THEN BEGIN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! String didn''t end');ERROR;END;BUFFER[LOC]:=39; BUFFER[LOC+1]:=0;END;B:=BUFFER[LOC];LOC:=LOC+1; IF B=39 THEN BEGIN IF BUFFER[LOC]<>39 THEN GOTO 31 ELSE BEGIN LOC:=LOC+1 ;BEGIN IF TOKPTR[Z]=MAXTOKS THEN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Sorry, ','token',' capacity exceeded');ERROR; HISTORY:=3;JUMPOUT;END;TOKMEM[Z,TOKPTR[Z]]:=39;TOKPTR[Z]:=TOKPTR[Z]+1; END;END;END;END;31:END{:168};35:IF T=3 THEN A:=0;{167:} 130:BEGIN A:=IDLOOKUP(0); BEGIN IF TOKPTR[Z]=MAXTOKS THEN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Sorry, ','token',' capacity exceeded');ERROR; HISTORY:=3;JUMPOUT;END;TOKMEM[Z,TOKPTR[Z]]:=(A DIV 256)+128; TOKPTR[Z]:=TOKPTR[Z]+1;END;A:=A MOD 256;END; 135:IF T<>135 THEN GOTO 30 ELSE BEGIN BEGIN IF TOKPTR[Z]=MAXTOKS THEN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Sorry, ','token',' capacity exceeded');ERROR; HISTORY:=3;JUMPOUT;END;TOKMEM[Z,TOKPTR[Z]]:=(CURMODULE DIV 256)+168; TOKPTR[Z]:=TOKPTR[Z]+1;END;A:=CURMODULE MOD 256;END;2:{169:} BEGIN BEGIN IF TOKPTR[Z]=MAXTOKS THEN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Sorry, ','token',' capacity exceeded');ERROR; HISTORY:=3;JUMPOUT;END;TOKMEM[Z,TOKPTR[Z]]:=2;TOKPTR[Z]:=TOKPTR[Z]+1; END;BUFFER[LIMIT+1]:=64; WHILE BUFFER[LOC]<>64 DO BEGIN BEGIN IF TOKPTR[Z]=MAXTOKS THEN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Sorry, ','token',' capacity exceeded');ERROR; HISTORY:=3;JUMPOUT;END;TOKMEM[Z,TOKPTR[Z]]:=BUFFER[LOC]; TOKPTR[Z]:=TOKPTR[Z]+1;END;LOC:=LOC+1; IF LOC=LIMIT THEN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Verbatim string didn''t end');ERROR; END ELSE IF BUFFER[LOC+1]<>62 THEN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! You should double @ signs in verbatim strings');ERROR; END;LOC:=LOC+2;END{:169}; 133,132,134:IF T<>135 THEN GOTO 30 ELSE BEGIN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! @',XCHR[BUFFER[LOC-1]],' is ignored in Pascal text'); ERROR;END;GOTO 22;END;136:GOTO 30;{:167}OTHERS:END; BEGIN IF TOKPTR[Z]=MAXTOKS THEN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Sorry, ','token',' capacity exceeded');ERROR; HISTORY:=3;JUMPOUT;END;TOKMEM[Z,TOKPTR[Z]]:=A;TOKPTR[Z]:=TOKPTR[Z]+1; END;END;30:NEXTCONTROL:=A;{166:} IF BAL>0 THEN BEGIN IF BAL=1 THEN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Missing )');ERROR;END ELSE BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Missing ',BAL:1,' )''s');ERROR;END; WHILE BAL>0 DO BEGIN BEGIN IF TOKPTR[Z]=MAXTOKS THEN BEGIN WRITELN( TERMOUT);WRITE(TERMOUT,'! Sorry, ','token',' capacity exceeded');ERROR; HISTORY:=3;JUMPOUT;END;TOKMEM[Z,TOKPTR[Z]]:=41;TOKPTR[Z]:=TOKPTR[Z]+1; END;BAL:=BAL-1;END;END{:166}; IF TEXTPTR>MAXTEXTS-3 THEN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Sorry, ','text',' capacity exceeded');ERROR;HISTORY:=3; JUMPOUT;END;CURREPLTEXT:=TEXTPTR;TOKSTART[TEXTPTR+3]:=TOKPTR[Z]; TEXTPTR:=TEXTPTR+1;IF Z=2 THEN Z:=0 ELSE Z:=Z+1;END;{:165}{170:} PROCEDURE DEFINEMACRO(T:EIGHTBITS);VAR P:NAMEPOINTER; BEGIN P:=IDLOOKUP(T);SCANREPL(T);EQUIV[P]:=CURREPLTEXT; TEXTLINK[CURREPLTEXT]:=0;END;{:170}{172:}PROCEDURE SCANMODULE; LABEL 22,30,10;VAR P:NAMEPOINTER;BEGIN MODULECOUNT:=MODULECOUNT+1;{173:} NEXTCONTROL:=0; WHILE TRUE DO BEGIN 22:WHILE NEXTCONTROL<=132 DO BEGIN NEXTCONTROL:= SKIPAHEAD;IF NEXTCONTROL=135 THEN BEGIN LOC:=LOC-2;NEXTCONTROL:=GETNEXT; END;END;IF NEXTCONTROL<>133 THEN GOTO 30;NEXTCONTROL:=GETNEXT; IF NEXTCONTROL<>130 THEN BEGIN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Definition flushed, must start with ', 'identifier of length > 1');ERROR;END;GOTO 22;END;NEXTCONTROL:=GETNEXT; IF NEXTCONTROL=61 THEN BEGIN SCANNUMERIC(IDLOOKUP(1));GOTO 22; END ELSE IF NEXTCONTROL=30 THEN BEGIN DEFINEMACRO(2);GOTO 22; END ELSE{174:}IF NEXTCONTROL=40 THEN BEGIN NEXTCONTROL:=GETNEXT; IF NEXTCONTROL=35 THEN BEGIN NEXTCONTROL:=GETNEXT; IF NEXTCONTROL=41 THEN BEGIN NEXTCONTROL:=GETNEXT; IF NEXTCONTROL=61 THEN BEGIN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Use == for macros');ERROR;END;NEXTCONTROL:=30;END; IF NEXTCONTROL=30 THEN BEGIN DEFINEMACRO(3);GOTO 22;END;END;END;END; {:174};BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Definition flushed since it starts badly');ERROR;END; END;30:{:173};{175:}CASE NEXTCONTROL OF 134:P:=0;135:BEGIN P:=CURMODULE; {176:}REPEAT NEXTCONTROL:=GETNEXT;UNTIL NEXTCONTROL<>43; IF(NEXTCONTROL<>61)AND(NEXTCONTROL<>30)THEN BEGIN BEGIN WRITELN(TERMOUT) ;WRITE(TERMOUT,'! Pascal text flushed, = sign is missing');ERROR;END; REPEAT NEXTCONTROL:=SKIPAHEAD;UNTIL NEXTCONTROL=136;GOTO 10;END{:176}; END;OTHERS:GOTO 10 END;{177:}STORETWOBYTE(53248+MODULECOUNT);{:177}; SCANREPL(135);{178:} IF P=0 THEN BEGIN TEXTLINK[LASTUNNAMED]:=CURREPLTEXT; LASTUNNAMED:=CURREPLTEXT; END ELSE IF EQUIV[P]=0 THEN EQUIV[P]:=CURREPLTEXT ELSE BEGIN P:=EQUIV[P] ;WHILE TEXTLINK[P]0 THEN BEGIN FOR LOC:=0 TO CHANGELIMIT DO BUFFER[LOC]:= CHANGEBUFFER[LOC];LIMIT:=CHANGELIMIT;CHANGING:=TRUE;LINE:=OTHERLINE; LOC:=CHANGELIMIT;BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Change file entry did not match');ERROR;END;END{:138}; PHASEONE:=FALSE;{:183};FOR ZO:=0 TO 2 DO MAXTOKPTR[ZO]:=TOKPTR[ZO]; {112:}IF TEXTLINK[0]=0 THEN BEGIN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! No output was specified.');END; IF HISTORY=0 THEN HISTORY:=1;END ELSE BEGIN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'Writing the output file');END;BREAK(TERMOUT);{83:} STACKPTR:=1;BRACELEVEL:=0;CURSTATE.NAMEFIELD:=0; CURSTATE.REPLFIELD:=TEXTLINK[0];ZO:=CURSTATE.REPLFIELD MOD 3; CURSTATE.BYTEFIELD:=TOKSTART[CURSTATE.REPLFIELD]; CURSTATE.ENDFIELD:=TOKSTART[CURSTATE.REPLFIELD+3];CURSTATE.MODFIELD:=0; {:83};{96:}OUTSTATE:=0;OUTPTR:=0;BREAKPTR:=0;SEMIPTR:=0;OUTBUF[0]:=0; LINE:=1;{:96};SENDTHEOUTPU;{98:}BREAKPTR:=OUTPTR;SEMIPTR:=0;FLUSHBUFFER; IF BRACELEVEL<>0 THEN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'! Program ended at brace level ',BRACELEVEL:1);ERROR;END; {:98};BEGIN WRITELN(TERMOUT);WRITE(TERMOUT,'Done.');END;END{:112}; 9999:IF STRINGPTR>128 THEN{184:}BEGIN BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,STRINGPTR-128:1,' strings written to string pool file.'); END;WRITE(POOL,'*'); FOR STRINGPTR:=1 TO 9 DO BEGIN OUTBUF[STRINGPTR]:=POOLCHECKSUM MOD 10; POOLCHECKSUM:=POOLCHECKSUM DIV 10;END; FOR STRINGPTR:=9 DOWNTO 1 DO WRITE(POOL,XCHR[48+OUTBUF[STRINGPTR]]); WRITELN(POOL);END{:184};{186:}BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'Memory usage statistics:');END;BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,NAMEPTR:1,' names, ',TEXTPTR:1,' replacement texts;');END; BEGIN WRITELN(TERMOUT);WRITE(TERMOUT,BYTEPTR[0]:1);END; FOR WO:=1 TO 1 DO WRITE(TERMOUT,'+',BYTEPTR[WO]:1); WRITE(TERMOUT,' bytes, ',MAXTOKPTR[0]:1); FOR ZO:=1 TO 2 DO WRITE(TERMOUT,'+',MAXTOKPTR[ZO]:1); WRITE(TERMOUT,' tokens.');{:186};{187:} CASE HISTORY OF 0:BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'(No errors were found.)');END;1:BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'(Did you see the warning message above?)');END; 2:BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'(Pardon me, but I think I spotted something wrong.)'); END;3:BEGIN WRITELN(TERMOUT); WRITE(TERMOUT,'(That was a fatal error, my friend.)');END;END{:187}; END.{:182}