{2:}{4:}{: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=PACKED 0..127;{:11}{12:}TEXTFILE=TEXT;{:12}{37:} EIGHTBITS=PACKED 0..255;SIXTEENBITS=PACKED 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:}TTYOUT:TEXTFILE;{:20}{23:} WEBFILE:TEXTFILE;CHANGEFILE:TEXTFILE;{:23}{25:}PASCALFILE:TEXTFILE; POOL:TEXTFILE;{:25}{27:}BUFFER:PACKED 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:SIXTEENBITS;DD:SIXTEENBITS;DEBUGCYCLE:INTEGER; DEBUGSKIPPED:INTEGER;TTYIN: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(TTYOUT,'. (change file ')ELSE WRITE(TTYOUT, '. (');WRITELN(TTYOUT,'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(TTYOUT,' ')ELSE WRITE( TTYOUT,XCHR[BUFFER[K-1]]);WRITELN(TTYOUT); FOR K:=1 TO L DO WRITE(TTYOUT,' '); FOR K:=L+1 TO LIMIT DO WRITE(TTYOUT,XCHR[BUFFER[K-1]]); WRITE(TTYOUT,' ');END{:32}ELSE{33:} BEGIN WRITELN(TTYOUT,'. (l.',LINE:1,')'); FOR J:=1 TO OUTPTR DO WRITE(TTYOUT,XCHR[OUTBUF[J-1]]); WRITE(TTYOUT,'... ');END{:33};;HISTORY:=2;{DEBUGHELP;}END;{:31}{34:} PROCEDURE JUMPOUT;BEGIN GOTO 9999;END;{:34}PROCEDURE INITIALIZE;VAR{16:} I:0..255;{: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 255 DO XORD[CHR(I)]:=32; FOR I:=1 TO 126 DO XORD[XCHR[I]]:=I;{:18}{21:}REWRITE(TTYOUT);{: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; termin(TTYIN);}{:180}END;{:2}{24:}PROCEDURE OPENINPUT; BEGIN RESET(WEBFILE);RESET(CHANGEFILE);END;{:24}{28:} FUNCTION INPUTLN(VAR F:TEXTFILE):BOOLEAN;VAR I:0..BUFSIZE; TEMPBUF:STRING(BUFSIZE);BEGIN LIMIT:=0; IF EOF(F)THEN INPUTLN:=FALSE ELSE BEGIN READ(F,TEMPBUF); LIMIT:=length(TRIM(TEMPBUF)); IF NOT EOLN(F)THEN BEGIN BEGIN WRITELN(TTYOUT); WRITE(TTYOUT,'! Input line too long');END;LOC:=0;ERROR; END ELSE READLN(F); IF LIMIT>0 THEN FOR I:=0 TO LIMIT-1 DO BUFFER[I]:=XORD[TEMPBUF[I+1]]; INPUTLN:=TRUE;END;END;{:28}{49:}PROCEDURE PRINTID(P:NAMEPOINTER); VAR K:0..MAXBYTES;W:0..1; BEGIN IF P>=NAMEPTR THEN WRITE(TTYOUT,'IMPOSSIBLE')ELSE BEGIN W:=P MOD 2 ; FOR K:=BYTESTART[P]TO BYTESTART[P+2]-1 DO WRITE(TTYOUT,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(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT);WRITE(TTYOUT,'! Identifier conflict with ');END; FOR K:=BYTESTART[Q]TO BYTESTART[Q+2]-1 DO WRITE(TTYOUT,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(TTYOUT); WRITE(TTYOUT,'! Sorry, ','byte memory',' capacity exceeded');ERROR; HISTORY:=3;JUMPOUT;END;IF NAMEPTR>MAXNAMES-2 THEN BEGIN WRITELN(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT); WRITE(TTYOUT,'! 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>536870841 DO POOLCHECKSUM:=POOLCHECKSUM-536870841; I:=IDFIRST+1;WHILE I536870841 DO POOLCHECKSUM:=POOLCHECKSUM-536870841; 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(TTYOUT); WRITE(TTYOUT,'! Sorry, ','byte memory',' capacity exceeded');ERROR; HISTORY:=3;JUMPOUT;END;IF NAMEPTR>MAXNAMES-2 THEN BEGIN WRITELN(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT); WRITE(TTYOUT,'! Name does not match');ERROR; END ELSE BEGIN WRITELN(TTYOUT);WRITE(TTYOUT,'! Ambiguous prefix');ERROR; END;PREFIXLOOKUP:=R;END;{:69}{73:}PROCEDURE STORETWOBYTE(X:SIXTEENBITS); BEGIN IF TOKPTR[Z]+2>MAXTOKS THEN BEGIN WRITELN(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT,'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(TTYOUT,'"')ELSE WRITE( TTYOUT,' ');END ELSE IF A<208 THEN BEGIN WRITE(TTYOUT,'@<'); PRINTID((A-168)*256+TOKMEM[ZP,K]);WRITE(TTYOUT,'@>'); END ELSE BEGIN A:=(A-208)*256+TOKMEM[ZP,K]; WRITE(TTYOUT,'@',XCHR[123],A:1,'@',XCHR[125]);END; END[:75]ELSE[76:]CASE A OF 9:WRITE(TTYOUT,'@',XCHR[123]); 10:WRITE(TTYOUT,'@',XCHR[125]);12:WRITE(TTYOUT,'@'''); 13:WRITE(TTYOUT,'@"');125:WRITE(TTYOUT,'@$');0:WRITE(TTYOUT,'#'); 64:WRITE(TTYOUT,'@@');2:WRITE(TTYOUT,'@=');3:WRITE(TTYOUT,'@\'); OTHERWISE WRITE(TTYOUT,XCHR[A])END[:76];K:=K+1;END;END;END;}{:74}{84:} PROCEDURE PUSHLEVEL(P:NAMEPOINTER); BEGIN IF STACKPTR=STACKSIZE THEN BEGIN WRITELN(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT);WRITE(TTYOUT,'! 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(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT); WRITE(TTYOUT,'! 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;OTHERWISE END; BEGIN IF TOKPTR[Z]=MAXTOKS THEN BEGIN WRITELN(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT); WRITE(TTYOUT,'! Sorry, ','name',' capacity exceeded');ERROR;HISTORY:=3; JUMPOUT;END;BYTESTART[NAMEPTR+2]:=K;NAMEPTR:=NAMEPTR+1; IF TEXTPTR>MAXTEXTS-3 THEN BEGIN WRITELN(TTYOUT); WRITE(TTYOUT,'! 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; OTHERWISE BEGIN WRITELN(TTYOUT); WRITE(TTYOUT,'! 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( TTYOUT);WRITE(TTYOUT,'! Not present: <');END;PRINTID(A); WRITE(TTYOUT,'>');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(TTYOUT,'.'); IF LINE MOD 500=0 THEN WRITE(TTYOUT,LINE:1);;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(TTYOUT); WRITE(TTYOUT,'! 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;OTHERWISE 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; OTHERWISE 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(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT); WRITE(TTYOUT,'! Two numbers occurred without a sign between them'); ERROR;END;END;{:108}OTHERWISE 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(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT); WRITE(TTYOUT,'! 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;94:BEGIN OUTCONTRIB[1]:=64; SENDOUT(1,1);END;91:BEGIN OUTCONTRIB[1]:=40;OUTCONTRIB[2]:=46; SENDOUT(1,2);END;93:BEGIN OUTCONTRIB[1]:=46;OUTCONTRIB[2]:=41; 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(TTYOUT);WRITE(TTYOUT,'! 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};OTHERWISE BEGIN WRITELN(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT);WRITE(TTYOUT,'! 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(TTYOUT); WRITE(TTYOUT,'! Change file ended after @x');ERROR;END;GOTO 10;END; UNTIL LIMIT>0;{:130};{131:}BEGIN CHANGELIMIT:=LIMIT; FOR K:=0 TO LIMIT 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(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT);WRITE(TTYOUT,'! Where is the matching @y?');ERROR; END;END ELSE IF BUFFER[1]=121 THEN BEGIN IF N>0 THEN BEGIN LOC:=2; BEGIN WRITELN(TTYOUT); WRITE(TTYOUT,'! Hmm... ',N:1,' of the preceding lines failed to match'); ERROR;END;END;GOTO 10;END;END{:133};{131:}BEGIN CHANGELIMIT:=LIMIT; FOR K:=0 TO LIMIT 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(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT);WRITE(TTYOUT,'! 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(TTYOUT,'*',MODULECOUNT+1:1);;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; OTHERWISE 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(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT); WRITE(TTYOUT,'! Double @ sign missing');ERROR; END END ELSE IF LOC>LIMIT THEN BEGIN BEGIN WRITELN(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT); WRITE(TTYOUT,'! Section name too long: ');END; FOR J:=1 TO 25 DO WRITE(TTYOUT,XCHR[MODTEXT[J]]);WRITE(TTYOUT,'...'); 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(TTYOUT); WRITE(TTYOUT,'! 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; OTHERWISE 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(TTYOUT); WRITE(TTYOUT,'! Omit semicolon in numeric definition');ERROR;END; OTHERWISE{159:}BEGIN BEGIN WRITELN(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT);WRITE(TTYOUT,'! Extra )');ERROR; END ELSE BAL:=BAL-1;39:{168:}BEGIN B:=39; WHILE TRUE DO BEGIN BEGIN IF TOKPTR[Z]=MAXTOKS THEN BEGIN WRITELN(TTYOUT );WRITE(TTYOUT,'! 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(TTYOUT );WRITE(TTYOUT,'! You should double @ signs in strings');ERROR;END; IF LOC=LIMIT THEN BEGIN BEGIN WRITELN(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT);WRITE(TTYOUT,'! 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(TTYOUT); WRITE(TTYOUT,'! Verbatim string didn''t end');ERROR; END ELSE IF BUFFER[LOC+1]<>62 THEN BEGIN WRITELN(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT); WRITE(TTYOUT,'! @',XCHR[BUFFER[LOC-1]],' is ignored in Pascal text'); ERROR;END;GOTO 22;END;136:GOTO 30;{:167}OTHERWISE END; BEGIN IF TOKPTR[Z]=MAXTOKS THEN BEGIN WRITELN(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT); WRITE(TTYOUT,'! Missing )');ERROR;END ELSE BEGIN WRITELN(TTYOUT); WRITE(TTYOUT,'! Missing ',BAL:1,' )''s');ERROR;END; WHILE BAL>0 DO BEGIN BEGIN IF TOKPTR[Z]=MAXTOKS THEN BEGIN WRITELN( TTYOUT);WRITE(TTYOUT,'! 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(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT); WRITE(TTYOUT,'! Use == for macros');ERROR;END;NEXTCONTROL:=30;END; IF NEXTCONTROL=30 THEN BEGIN DEFINEMACRO(3);GOTO 22;END;END;END;END; {:174};BEGIN WRITELN(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT); WRITE(TTYOUT,'! Pascal text flushed, = sign is missing');ERROR;END; REPEAT NEXTCONTROL:=SKIPAHEAD;UNTIL NEXTCONTROL=136;GOTO 10;END{:176}; END;OTHERWISE 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(TTYOUT); WRITE(TTYOUT,'! 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(TTYOUT); WRITE(TTYOUT,'! No output was specified.');END; IF HISTORY=0 THEN HISTORY:=1;END ELSE BEGIN BEGIN WRITELN(TTYOUT); WRITE(TTYOUT,'Writing the output file');END;;{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(TTYOUT); WRITE(TTYOUT,'! Program ended at brace level ',BRACELEVEL:1);ERROR;END; {:98};BEGIN WRITELN(TTYOUT);WRITE(TTYOUT,'Done.');END;END{:112}; 9999:IF STRINGPTR>128 THEN{184:}BEGIN BEGIN WRITELN(TTYOUT); WRITE(TTYOUT,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(TTYOUT); WRITE(TTYOUT,'Memory usage statistics:');END;BEGIN WRITELN(TTYOUT); WRITE(TTYOUT,NAMEPTR:1,' names, ',TEXTPTR:1,' replacement texts;');END; BEGIN WRITELN(TTYOUT);WRITE(TTYOUT,BYTEPTR[0]:1);END; FOR WO:=1 TO 1 DO WRITE(TTYOUT,'+',BYTEPTR[WO]:1); WRITE(TTYOUT,' bytes, ',MAXTOKPTR[0]:1); FOR ZO:=1 TO 2 DO WRITE(TTYOUT,'+',MAXTOKPTR[ZO]:1); WRITE(TTYOUT,' tokens.');{:186};{187:}RETCODE(4*HISTORY); CASE HISTORY OF 0:BEGIN WRITELN(TTYOUT); WRITE(TTYOUT,'(No errors were found.)');END;1:BEGIN WRITELN(TTYOUT); WRITE(TTYOUT,'(Did you see the warning message above?)');END; 2:BEGIN WRITELN(TTYOUT); WRITE(TTYOUT,'(Pardon me, but I think I spotted something wrong.)');END; 3:BEGIN WRITELN(TTYOUT); WRITE(TTYOUT,'(That was a fatal error, my friend.)');END;END{:187}; END.{:182}