Home » Archimedes archive » Zipped Apps » BCPL » BCPL/b/syn
BCPL/b/syn
This website contains an archive of files for the Acorn Electron, BBC Micro, Acorn Archimedes, Commodore 16 and Commodore 64 computers, which Dominic Ford has rescued from his private collection of floppy disks and cassettes.
Some of these files were originally commercial releases in the 1980s and 1990s, but they are now widely available online. I assume that copyright over them is no longer being asserted. If you own the copyright and would like files to be removed, please contact me.
Tape/disk: | Home » Archimedes archive » Zipped Apps » BCPL |
Filename: | BCPL/b/syn |
Read OK: | ✔ |
File size: | 83F0 bytes |
Load address: | 0000 |
Exec address: | 0000 |
File contents
SECTION "Lex" GET "b.Header" STATIC $( // Version of 28 Feb 86 13:04:59 dummy = VersionMark; version = 1*256+2 $) /* 1.2 28 Feb 86 13:05:10 ccstack initialised to zero (so unmatching tags don't cause compiler collapse */ LET initialise.lex() BE $( ccstack := 0; DeclSysWords() RCh() $) AND NextSymb() BE $( LET BasicSymb() BE $( nlPending := FALSE $( SWITCHON ch INTO $( CASE '*N': nlPending := TRUE CASE '*T': CASE '*S': RCh() REPEATWHILE ch='*S' LOOP CASE '0': CASE '1': CASE '2': CASE '3': CASE '4': CASE '5': CASE '6': CASE '7': CASE '8': CASE '9': symb := s.number ReadNumber(10); IF ch='.' | ch='E' | ch='e' THEN ReadFloat(); RETURN CASE 'a': CASE 'b': CASE 'c': CASE 'd': CASE 'e': CASE 'f': CASE 'g': CASE 'h': CASE 'i': CASE 'j': CASE 'k': CASE 'l': CASE 'm': CASE 'n': CASE 'o': CASE 'p': CASE 'q': CASE 'r': CASE 's': CASE 't': CASE 'u': CASE 'v': CASE 'w': CASE 'x': CASE 'y': CASE 'z': CASE 'A': CASE 'B': CASE 'C': CASE 'D': CASE 'E': CASE 'F': CASE 'G': CASE 'H': CASE 'I': CASE 'J': CASE 'K': CASE 'L': CASE 'M': CASE 'N': CASE 'O': CASE 'P': CASE 'Q': CASE 'R': CASE 'S': CASE 'T': CASE 'U': CASE 'V': CASE 'W': CASE 'X': CASE 'Y': CASE 'Z': $( LET c=ch RCh() RdTag(c) symb := LookUpWord() IF symb=s.get THEN $( PerformGet() LOOP $) RETURN $) CASE '{': CASE '}': symb := ch='{' -> s.lsect, s.rsect; RCh(); RdTag('$'); LookUpWord(); RETURN CASE '$': multichar("()<>$", s.lsect,s.rsect, 1,2, s.tagname, 0) IF symb=s.lsect | symb=s.rsect THEN $( RdTag('$') LookUpWord() RETURN $) IF extension.level>=3 & symb~=0 THEN $( LET cch = CapitalCh(ch) LET c = ch IF ~['A'<=cch<='Z' | '0'<=cch<='9'] THEN SynReport(2) RCh() RdTag(c) tagptr := LookUpTag(wordv) IF symb~=s.tagname THEN // // $<tag or $>tag // $( LET inverse = FALSE IF ch='*'' THEN $( RCh() inverse := TRUE $); conditional.compilation(symb=1, tagptr, inverse) LOOP $) RETURN $) SynReport(91) ENDCASE CASE '[': CASE '(': symb := s.lparen; BREAK CASE ']': CASE ')': symb := s.rparen; BREAK CASE '#': $( LET radix = 8 RCh() IF ~['0'<=ch<='7'] THEN $( SWITCHON CapitalCh(ch) INTO $( DEFAULT: BasicSymb(); SWITCHON symb INTO $( CASE s.plus:CASE s.minus:CASE s.mult:CASE s.div: CASE s.abs: CASE s.ls:CASE s.gr:CASE s.le:CASE s.ge: CASE s.eq:CASE s.ne: symb := symb+s.fadd; RETURN DEFAULT: SynReport(33) $) CASE 'B':radix := 2;ENDCASE CASE 'O':radix := 8;ENDCASE CASE 'X':radix := 16 $) RCh() $) ReadNumber(radix) symb := s.number RETURN $) CASE '?': symb := s.query; BREAK CASE '+': symb := s.plus; BREAK CASE ',': symb := s.comma; BREAK CASE ';': symb := s.semicolon; BREAK CASE '@': symb := s.lv; BREAK CASE '&': symb := s.logand; BREAK CASE '=': symb := s.eq; BREAK CASE '!': symb := s.vecap; BREAK CASE '**':symb := s.mult; BREAK CASE '%': IF extension.level<2 THEN $( ch := 0 LOOP $) symb := s.byteap BREAK CASE '|': IF extension.level<1 THEN $( symb := s.logor BREAK $) multichar("|", 0, s.logor) IF symb~=0 THEN RETURN cmnt: UNTIL ch='*N' | ch='*P' | ch=EndStreamCh DO RCh() LOOP CASE '/': multichar("\/**", s.logand, 0, -1, s.div) IF symb>0 THEN RETURN IF symb=0 THEN GOTO cmnt $( IF ch='**' THEN $( RCh() IF ch='/' THEN BREAK LOOP $) IF ch=EndStreamCh THEN SynReport(63); RCh() $) REPEAT RCh() LOOP CASE '~': multichar("=", s.ne, s.not) RETURN CASE '\': multichar("/=", s.logor, s.ne, s.not) RETURN CASE '<': multichar("=<", s.le, s.lshift, s.ls) RETURN CASE '>': multichar("=>", s.ge, s.rshift, s.gr) RETURN CASE '-': multichar(">", s.cond, s.minus) RETURN CASE ':': multichar("=", s.ass, s.colon) RETURN CASE '"': $( LET i = 0 LET sch = ? WHILE RdStrCh('"', @sch) DO $( IF i=255 THEN SynReport(34) i := i+1 wordv%i := sch $) wordv%0 := i symb := s.string BREAK $) CASE '*'': $( LET ok = RdStrCh('*'', @decval) symb := s.number; IF ok THEN $( RCh() ok := ch='*'' $) IF ~ok THEN SynReport(34) BREAK $) DEFAULT: IF ch~=EndStreamCh THEN $( ch := '*S' SynReport(94) $) CASE '.': IF getp=0 THEN $( symb := s.end BREAK $) close(sourceStream) getp := getp-3 sourceStream := getv!getp lineCount := getv!(getp+1) ch := getv!(getp+2) SelectInput(sourceStream) LOOP $) $) REPEAT RCh() $) BasicSymb() // Check for tag setting directive. This is of the // form: // $$tag or $$tag := expn // // A $$tag symbol is of type 's.tagname'. // // A loop is used to get cases like $$tag $$tag2 := .. right. WHILE symb=s.tagname DO $( LET tag = tagptr LET value = FALSE LET op = s.logor BasicSymb() // If the $$tag was not followed by :=, simply // invert the value of the tag and go round again. IF symb~=s.ass THEN $( tag.value!tag := ~tag.value!tag LOOP $) $( LET inverse = FALSE LET sval = ? BasicSymb() IF symb=s.not THEN $( inverse := TRUE BasicSymb() $) SWITCHON symb INTO $( CASE s.tagname: sval := tag.value!tagptr ENDCASE CASE s.true: sval := TRUE ENDCASE CASE s.false: sval := FALSE ENDCASE DEFAULT: SynReport(1) ENDCASE $) // Combine the value with the expression so far // and check for an operator. IF inverse THEN sval := ~sval TEST op=s.logor THEN value := value | sval ELSE value := value & sval BasicSymb() op := symb $) REPEATWHILE op=s.logor | op=s.logand tag.value!tag := value $) // Symbol is not $$tag: check for a compound assignment // (note that op:= is an extension). IF extension.level>=3 THEN SWITCHON symb INTO $( CASE s.mult: CASE s.div: CASE s.rem: CASE s.plus: CASE s.minus: CASE s.fmult: CASE s.fdiv: CASE s.fplus: CASE s.fminus: CASE s.logand: CASE s.logor: CASE s.eqv: CASE s.neqv: CASE s.lshift: CASE s.rshift: // // Check for := following operator. // IF ch=':' THEN $( LET ch = RdCh(); UnRdCh() IF ch='=' THEN $( RCh(); RCh() operator := symb symb := s.opab $) $) $) $) AND multichar(chars, a, b, c, d, e, f, g, h) BE $( LET t = @chars LET i, lim = 1, chars%0 RCh() WHILE i<=lim DO $( IF ch=chars%i THEN $( RCh() BREAK $) i := i+1 $) symb := t!i $) AND LookUpWord() = VALOF $( LET hashval = VALOF $( LET res = wordv%0 FOR i = 1 TO res DO res := (res*13 + CapitalCh(wordv%i)) & #X7FFF RESULTIS res REM nametablesize $) LET CString(s1, s2) = VALOF $( LET len = s1%0 IF len~=s2%0 THEN RESULTIS FALSE FOR j = 1 TO len DO TEST equateCases THEN IF CapitalCh(s1%j)~=CapitalCh(s2%j) THEN RESULTIS FALSE ELSE IF s1%j~=s2%j THEN RESULTIS FALSE RESULTIS TRUE $) LET i = 0 wordNode := nametable!hashval WHILE wordNode~=0 & ~CString(wordNode+2, wordv) DO wordNode := h2!wordNode IF wordNode=0 THEN $( LET size = wordv%0 / BytesPerWord wordNode := getblk(size+3) wordNode!0 := s.name wordNode!1 := nametable!hashval FOR i = 0 TO size DO wordNode!(i+2) := wordv!i nametable!hashval := wordNode $) RESULTIS h1!wordNode $) AND conditional.compilation(startcond, tagptr, inverse) BE // // Called after $<tag or $>tag has been recognised. // // startcond true for $<, false for $> // tagptr pointer to tag object // inverse true if tag was followed by '. // TEST startcond THEN TEST tag.value!tagptr~=inverse THEN $( // Do not skip: add new item to cc stack. LET s = get.ccstack.item() cc.link!s := ccstack ccstack := s cc.inverse!s := inverse cc.tagptr!s := tagptr $) ELSE $( // Skip until a matching $>tag is found. The quotes must match LET inv2 = FALSE $( IF ch=EndStreamCh THEN SynReport(3) IF ch='$' THEN $( RCh() IF ch='>' THEN $( LET c, d = ?, ? RCh() d := ch c := CapitalCh(ch) IF 'A'<=c<='Z' | '0'<=c<='9' THEN $( RCh() RdTag(d) IF CompString(wordv, tag.name+tagptr)=0 THEN BREAK $) LOOP $) LOOP $) RCh() $) REPEAT // Skip complete: check that quotes match IF ch='*'' THEN $( inv2 := TRUE RCh() $) IF inv2~=inverse THEN SynReport(4) $) ELSE $( // $>tag: check that it matches the last $<tag. IF ccstack~=0 THEN TEST tagptr=cc.tagptr!ccstack THEN $( // Proper match: unstack item and check quotes match. LET inv1 = cc.inverse!ccstack LET next = cc.link!ccstack cc.link!ccstack := free.ccstack.chain free.ccstack.chain := ccstack ccstack := next IF inv1~=inverse THEN SynReport(4) RETURN $) ELSE $( // Tags do not match: if the current tag occurs // below on the stack, remove those items above // it. LET m = ccstack WHILE m~=0 & cc.tagptr!m~=tagptr DO m := cc.link!m IF m~=0 THEN $( LET next = cc.link!m cc.link!m := free.ccstack.chain free.ccstack.chain := ccstack ccstack := next $) $) SynReport(5) $) AND get.ccstack.item() = VALOF $( LET c = free.ccstack.chain IF c=0 THEN RESULTIS GetBlk(cc.size) free.ccstack.chain := cc.link!c RESULTIS c $) AND DeclSysWords() BE $( LET bad = TABLE s.bad, s.bad symb := TABLE s.and,s.abs, s.be,s.break,s.by, s.case, s.do,s.default, s.eq,s.eqv,s.or,s.endcase, s.false,s.for,s.finish, s.goto,s.ge,s.gr,s.global,s.get, s.if,s.into, s.let,s.lv,s.le,s.ls,s.logor, s.logand,s.loop,s.lshift, s.manifest, s.ne,s.not,s.neqv,s.needs, s.or, s.resultis,s.return,s.rem,s.rshift,s.rv, s.repeat,s.repeatwhile,s.repeatuntil, s.switchon,s.static,s.section, s.to,s.test,s.true,s.do,s.table, s.until,s.unless, s.vec,s.valof, s.while, 0 D( "AND ABS * *BE BREAK BY * *CASE * *DO DEFAULT * *EQ EQV ELSE ENDCASE * *FALSE FOR FINISH * *GOTO GE GR GLOBAL GET * *IF INTO * *LET LV LE LS LOGOR LOGAND LOOP LSHIFT") D("MANIFEST * *NE NOT NEQV NEEDS * *OR * *RESULTIS RETURN REM RSHIFT RV * *REPEAT REPEATWHILE REPEATUNTIL * *SWITCHON STATIC SECTION * *TO TEST TRUE THEN TABLE * *UNTIL UNLESS * *VEC VALOF * *WHILE * *$") nulltag := wordNode IF lispExtensions THEN { symb := (TABLE s.nil, s.car, s.cdr, s.vcar, s.vcdr, s.lle,s.lge,s.lgr,s.lls); D("NIL CAR CDR VCAR VCDR LLE LGE LGR LLS") } // If the extension level is suitable, declare the // symbols SLCT and OF appropriately. Otherwise, // declare them as 'bad', so that they are still // reserved words. symb := extension.level>=3 -> (TABLE s.slct,s.of,s.fix,s.float),bad D("SLCT OF FIX FLOAT") // EXTERNAL is declared similarly symb := extension.level>=4 -> (TABLE s.external), bad D("EXTERNAL") $) AND D(words) BE $( LET i = 1 LET length = 0 $( LET ch = i>words%0 -> ' ', words%i TEST ch=' ' THEN $( IF length=0 THEN RETURN wordv%0 := length LookUpWord() h1!wordNode :=!symb symb := symb+1 length := 0 $) ELSE $( length := length+1 wordv%length := ch $) i := i+1 $) REPEAT $) AND RCh() BE $( ch := RdCh() IF ch='*N' | ch='*P' | ch='*C' THEN $( ch := '*N' lineCount := lineCount+1 $) chcount := chcount+1 chbuf!(chcount & 63) := ch $) AND RdTag(char) BE $( LET i = 1 wordv%i := char $( LET cc = CapitalCh(ch) UNLESS 'A' <= cc <= 'Z' | '0' <= ch <= '9' | ch='.' | (ch='_' & extension.level>0) THEN BREAK i := i+1 wordv%i := ch RCh() $) REPEAT wordv%0 := i $) AND PerformGet() BE $( LET s = 0 LET t = transchars transchars := FALSE NextSymb() transchars := t IF symb~=s.string | getp+2>getmax THEN SynReport(97) // Check for GET "" first - the meaning of this has // been changed so that it always refers to the source // file, even if a HDR parameter was given. // // Note that GET "" is an extension to standard BCPL. TEST wordv%0=0 THEN IF extension.level>=2 THEN s := Open(fromfile, TRUE, FALSE) ELSE TEST headers=0 THEN $( s := Open(wordv, TRUE, FALSE) IF s=0 THEN $( LET lenw = wordv%0 LET prefix = "$.alib." LET plen = prefix%0 LET v = VEC 30/BytesPerWord IF lenw>10 THEN lenw := 10 FOR i = 1 TO lenw DO v%(i+plen) := wordv%i FOR i = 1 TO plen DO v%i := prefix%i v%0 := lenw+plen s := Open(v, TRUE, FALSE) $) $) ELSE $( LET file = find.header(wordv) IF file~=0 THEN $( s := Open(file, TRUE, FALSE) FreeVector(file) $) $) IF s=0 THEN SynReport(96, wordv) getv!getp := sourceStream getv!(getp+1) := lineCount getv!(getp+2) := ch getp := getp+3 lineCount := 1 sourceStream := s SelectInput(s) RCh() $) AND find.header(string) = VALOF // // Finds the file associated with the given header name // in the HDR parameter. // // This has the format: // // H1=F1,H2=F2,....Hn=Fn // // Each Hi is a header name (eg. LIBHDR), and each Fi is a // file name. // // The result is a newly-allocated vector holding the file // name, or zero if the header name was not found. // // The conditional compilation tag RDARGSL is set if HDR // was read with the /L 'rdargs' options, in which case // the length is in the first WORD, not byte. // $( LET hupb = headers%0 LET hlwb = 1 LET slen = string%0 LET hpos = hlwb LET fpos = 0 LET v = 0 // Search through the HDR string to find the header // name. FOR j = hlwb TO hupb DO $( LET c = headers%j // A comma indicates the start of a header name, // an equals sign the end of one. TEST c=',' THEN hpos := j+1 ELSE IF c='=' THEN // // Does the current header name match the one // that is being sought? // IF j-hpos=slen THEN $( LET same = TRUE FOR j = 1 TO slen DO IF CompCh(headers%(j+hpos-1), string%j)~=0 THEN $( same := FALSE BREAK $) // If found, remember the position at // which the file name starts. IF same THEN $( fpos := j+1 BREAK $) $) $) IF fpos~=0 THEN $( LET flen = 0 FOR j = fpos TO hupb DO $( IF headers%j=',' THEN BREAK flen := flen+1 $) v := GetVector(flen / BytesPerWord+1) v%0 := flen FOR j = 1 TO flen DO v%j := headers%(fpos+j-1) $) RESULTIS v $) AND ReadNumber(radix) BE $( LET d = Value(ch); digits := 1; decval := d IF d>=radix THEN SynReport(33) $( RCh() d := Value(ch) IF d>=radix THEN RETURN; digits := digits+1; decval := radix * decval+d $) REPEAT $) AND ReadFloat() BE $( LET negativeExponent = FALSE; symb := s.fconst; mantissa, exponent := decval, 0; IF ch='.' THEN $( Rch(); UNLESS '0'<=ch<='9' THEN SynReport(33); ReadNumber(10); IF decval~=0 THEN $( exponent := exponent-digits; WHILE digits~=0 DO $( mantissa := mantissa*10; digits := digits-1 $); mantissa := mantissa+decval $) $); IF ch='E' | ch='e' THEN $( Rch(); IF ch='-' THEN $( negativeExponent := TRUE; Rch() $); UNLESS '0'<=ch<='9' THEN SynReport(33); ReadNumber(10); exponent := negativeExponent -> exponent-decval, exponent+decval $) $) AND Value(ch) = VALOF $( LET c = CapitalCh(ch) RESULTIS '0'<=c<='9' -> c-'0', 'A'<=c<='F' -> c-'A'+10, 100 $) AND RdStrCh(term, lv.ch) = VALOF $( LET trans = transchars RCh() IF ch=term THEN RESULTIS FALSE IF ch='*N' THEN SynReport(34) IF ch='**' THEN $( RCh() IF ch='*N' | ch='*S' | ch='*T' THEN TEST term='*'' THEN SynReport(34) ELSE $( WHILE ch='*N' | ch='*S' | ch='*T' DO RCh() IF ch~='**' THEN SynReport(34) LOOP $) ch := CapitalCh(ch) IF (ch='E' | ch='B' | ch='C') & extension.level=0 THEN ch := -1 SWITCHON ch INTO $( DEFAULT: SynReport(35); ENDCASE CASE 'T': ch := '*T'; ENDCASE CASE 'S': ch := '*S'; ENDCASE CASE 'N': ch := '*N'; ENDCASE CASE 'P': ch := '*P'; ENDCASE CASE 'B': ch := '*B'; ENDCASE CASE 'C': ch := '*C'; ENDCASE CASE 'E': ch := #X1B CASE '"': ENDCASE CASE '*'': ENDCASE CASE '**': ENDCASE CASE 'X': CASE 'O': CASE '0': CASE '1': CASE '2': CASE '3': CASE '4': CASE '5': CASE '6': CASE '7': $( LET r, n = 8, 3 IF ch='X' THEN r, n := 16, 2 IF ch='X' | ch='O' THEN RCh() ch := ReadOctalOrHex(r, n) IF ch>255 THEN SynReport(34) trans := FALSE ENDCASE $) $) $) !lv.ch := trans -> charcode!ch, ch RESULTIS TRUE $) REPEAT AND ReadOctalOrHex(radix, digits) = VALOF $( LET answer = 0 FOR j = 1 TO digits DO $( LET valch = value(ch) IF valch>=radix THEN SynReport(34) answer := answer*radix+valch IF j~=digits THEN RCh() $) RESULTIS answer $) . SECTION "Syn" GET "b.Header" STATIC $( dummy = VersionMark; version = 1*256+2 $) LET bcpl.syn() = VALOF $( LET a = 0; LET v = GetVector(nametablesize+64+wordmax+getmax+1); err.p := Level(); err.l := exit; getp := 0; chcount := 0; externals.list := 0; free.list.element.chain := 0; free.ccstack.chain := 0; zeroNode := List2(s.number, 0); FOR i = 0 TO NameTableSize+63 DO v!i := 0 nameTable := v chbuf := v+NameTableSize wordv := chbuf+64 getv := wordv+wordmax initialise.lex() IF ch=EndStreamCh THEN GOTO exit rec.p, rec.l := err.p, l l: NextSymb() $( LET RProg() = VALOF $( LET op, a = symb, 0 LET tag = ? NextSymb() IF symb~=s.string THEN SynReport(95) tag := LookUpTag(wordv) tag.value!tag := TRUE a := RbExp() IF op=s.section THEN WriteF("Section %S*N", a+1) RESULTIS List3(op, a, symb=s.needs -> RProg(), RdBlockBody()) $) a := extension.level>=1 & [symb=s.section | symb=s.needs] -> RProg(), RdBlockBody() IF symb~=s.end THEN SynReport(99) $) UnRdCh() exit: FreeVector(v) RESULTIS a $) AND List1(x) = VALOF $( LET p = GetBlk(1) p!0 := x RESULTIS p $) AND List2(x, y) = VALOF $( LET p = GetBlk(2) p!0, p!1 := x, y RESULTIS p $) AND List3(x, y, z) = VALOF $( LET p = GetBlk(3) p!0, p!1, p!2 := x, y, z RESULTIS p $) AND List4(x, y, z, t) = VALOF $( LET p = GetBlk(4) p!0, p!1, p!2, p!3 := x, y, z, t RESULTIS p $) AND List5(x, y, z, t, u) = VALOF $( LET p = GetBlk(5) p!0, p!1, p!2, p!3, p!4 := x, y, z, t, u RESULTIS p $) AND List6(x, y, z, t, u, v) = VALOF $( LET p = GetBlk(6) p!0, p!1, p!2, p!3, p!4, p!5 := x, y, z, t, u, v RESULTIS p $) AND GetListElement() = VALOF // Gets a new element for a 'makelist' chain, and // initialises the count and link fields to zero. // $( LET q = free.list.element.chain TEST q=0 THEN q := GetBlk(list.element.size) ELSE free.list.element.chain := list.link!q list.link !q := 0 list.count!q := 0 RESULTIS q $) AND InsertInListElement(lv.element, data) BE // Inserts the data in the list element addressed by // the pointer parameter. // $( LET element = !lv.element LET c = list.count!element IF c=list.element.data.size THEN $( LET n = GetListElement() list.link!element := n !lv.element := n element := n c := 0 $) (list.data+element)!c := data list.count!element := c+1 $) AND MakeList(list,listend,type1,type2,count,unitsize)=VALOF // Converts a list formed out of list elements into a // straight table. // // list first element in list // listend last element in list // type1 tree type for table // type2 type used for pair of units // count number of data words // unitsize size of a single 'object' in the list // // If the unitsize is one, and there is one value in the // list, a table is not constructed. // // If there are two objects and 'type2' is not zero, a // pair object is returned. // $( LET result = ? TEST count=1 & unitsize=1 THEN result := list.data!list ELSE $( LET l = list LET p = 1 TEST count=2*unitsize & type2~=0 THEN $( result := GetBlk(count+1) h1!result := type2 $) ELSE $( result := GetBlk(count+2) h1!result := type1 h2!result := count p := 2 $) WHILE l~=0 DO $( FOR j = 0 TO list.count!l-1 DO $( result!p := (list.data+l)!j p := p+1 $) l := list.link!l $) $) // Add list to chain of free elements list.link!listend := free.list.element.chain free.list.element.chain := list RESULTIS result $) AND SynReport(n, a) BE $( LET s = VALOF SWITCHON n INTO $( DEFAULT: a := n RESULTIS "Error %N" CASE 1: RESULTIS "Bad tag setting expression" CASE 2: RESULTIS "Bad tag name" CASE 3: RESULTIS "End of file while skipping text" CASE 4: RESULTIS "Tag conditions do not match" CASE 5: RESULTIS "Bad conditional compilation nesting" CASE 6: RESULTIS "'$(' expected" CASE 7: RESULTIS "'$)' expected" CASE 8: CASE 40: CASE 43: RESULTIS "Name expected" CASE 9: RESULTIS "Untagged '$)' mismatch" CASE 15: CASE 19: CASE 41: RESULTIS "')' missing" CASE 30: RESULTIS "Bad conditional expression" CASE 32: RESULTIS "Invalid expression" CASE 33: RESULTIS "Bad number" CASE 34: RESULTIS "Bad string or character constant" CASE 35: RESULTIS "Bad escape in string or character" CASE 42: RESULTIS "Bad procedure heading" CASE 44: CASE 45: RESULTIS "Bad declaration" CASE 50: RESULTIS "Unexpected ':'" CASE 51: RESULTIS "Invalid command" CASE 54: RESULTIS "'ELSE' expected" CASE 57: CASE 58: RESULTIS "Bad FOR loop" CASE 60: RESULTIS "'INTO' expected" CASE 61: CASE 62: RESULTIS "':' expected" CASE 63: RESULTIS "'**/' missing" CASE 91: RESULTIS "'$' out of context" CASE 94: RESULTIS "Illegal character" CASE 95: RESULTIS "Illegal section name" CASE 96: rc := 20 RESULTIS "Can't GET *"%S*" - " CASE 97: RESULTIS "Bad GET directive" CASE 99: RESULTIS "Incorrect termination" CASE 100:RESULTIS "Bad external name string" CASE 101:RESULTIS "Invalid use of symbol" $) IF rc<10 THEN rc := 10 WriteF("*NError near line %N: ", lineCount) WriteF(s, a) brk: IF rc>=20 THEN $( WriteS("compilation abandoned*N") WHILE getp~=0 DO $( Close(sourceStream) getp := getp-3 sourceStream := getv!getp SelectInput(sourceStream) $) LongJump(err.p,err.l) $) WrChBuf() nlPending := FALSE UNTIL symb=s.lsect | symb=s.rsect | symb=s.let | symb=s.and | symb=s.end | nlPending DO NextSymb() LongJump(rec.p, rec.l) $) AND WrChBuf() BE $( WriteS("*N...") FOR p = chcount-63 TO chcount DO $( LET k = chbuf!(p&63) IF k>0 THEN WrCh(k) $) NewLine() $) AND RdBlockBody() = VALOF $( LET p, l = rec.p, rec.l LET a = 0 LET ptr = @a $( LET op = 0 rec.p, rec.l := Level(), recover Ignore(s.semicolon) SWITCHON symb INTO $( CASE s.manifest: CASE s.static: CASE s.global: CASE s.external: op := symb NextSymb() !ptr := RdSect(RdCDefs, op) ENDCASE CASE s.let: NextSymb() !ptr := RDef() recover: $( LET qtr = ptr WHILE symb=s.and DO $( NextSymb() !qtr := List3(s.and, !qtr, RDef()) qtr := @h3!(!qtr) $) op := s.let ENDCASE $) DEFAULT: !ptr := RdSeq() IF symb~=s.rsect & symb~=s.end THEN SynReport(51) CASE s.rsect: CASE s.end: BREAK $) !ptr := List3(op,!ptr, 0) ptr := @h3!(!ptr) $) REPEAT rec.p, rec.l := p, l RESULTIS a $) AND RdSeq() = VALOF $( LET n = 0 LET list = GetListElement() LET liste = list $( LET lc = ? Ignore(s.semicolon) lc := lineCount InsertInListElement(@liste, rcom()) InsertInListElement(@liste, lc) n := n+2 $) REPEATUNTIL symb=s.rsect | symb=s.end RESULTIS MakeList(list, liste, s.semicolonlist, s.semicolon, n, 2) $) AND RdCDefs(op) = VALOF $( LET n = 0 LET list = GetListElement() LET liste = list LET p, l = rec.p, rec.l $( LET lc = ? LET e = 0 rec.p, rec.l := Level(), rec InsertInListElement(@liste, RName()) lc := lineCount IF symb~=s.eq & symb~=s.colon THEN SynReport(45) NextSymb() TEST op=s.external THEN $( IF symb~=s.string THEN SynReport(100) e := List4(externals.list, RbExp()+1, 0, 0) externals.list := e $) ELSE e := RExp(0) rec: n := n+3 InsertInListElement(@liste, e) Ignore(s.semicolon) InsertInListElement(@liste, lc) $) REPEATWHILE symb=s.name rec.p, rec.l := p, l RESULTIS MakeList(list, liste, s.semicolonlist, 0, n,3) $) AND RdSect(r, arg) = VALOF $( LET tag, a = wordNode, 0 CheckFor(s.lsect, 6) a := r(arg) IF symb~=s.rsect THEN SynReport(7) TEST tag=wordNode THEN NextSymb() ELSE IF wordNode=nulltag THEN $( symb := 0 SynReport(9) $) RESULTIS a $) AND RNamelist() = VALOF $( LET n = 0 LET list = GetListElement() LET liste = list $( InsertInListElement(@liste, RName()) n := n+1 IF symb~=s.comma THEN BREAK NextSymb() $) REPEAT RESULTIS MakeList(list,liste,s.commalist,s.comma,n,1) $) AND RName() = VALOF $( LET a = wordNode CheckFor(s.name, 8) RESULTIS a $) AND Ignore(item) BE IF symb=item THEN NextSymb() AND CheckFor(item, n) BE $( IF symb~=item THEN SynReport(n) NextSymb() $) AND RbExp() = VALOF $( LET a, op = 0, symb SWITCHON symb INTO $( DEFAULT: SynReport(32) CASE s.bad: SynReport(101) CASE s.query: NextSymb() RESULTIS List1(s.query) CASE s.true: CASE s.false: CASE s.name: CASE s.nil: a := wordNode NextSymb() RESULTIS a CASE s.string: $( LET wordSize = wordv%0 / BytesPerWord a := GetBlk(wordSize+2) a!0 := s.string FOR i = 0 TO wordSize DO a!(i+1) := wordv!i NextSymb() RESULTIS a $) CASE s.number: $( LET k = decval NextSymb() RESULTIS k=0 -> zeroNode, SmallNumber(k) -> k, List2(s.number, k) $) CASE s.fconst: $( LET i, j = mantissa, exponent; NextSymb(); RESULTIS List3(s.fconst, i, j) $) CASE s.lparen: NextSymb() a := RExp(0) CheckFor(s.rparen, 15) RESULTIS a CASE s.valof: NextSymb() RESULTIS List2(s.valof, RCom()) CASE s.vecap: op := s.rv CASE s.lv: CASE s.rv: CASE s.car: CASE s.vcar: CASE s.cdr: CASE s.vcdr: NextSymb() RESULTIS List2(op, RExp(37)) CASE s.plus: NextSymb() RESULTIS RExp(34) CASE s.minus: NextSymb() a := RExp(34) RESULTIS SmallNumber(a) -> List2(s.number, -a), List2(s.neg, a) CASE s.fminus: NextSymb(); RESULTIS List2(s.fneg, RExp(34)) CASE s.not: NextSymb() RESULTIS List2(s.not, RExp(24)) CASE s.abs: CASE s.fabs: CASE s.float: CASE s.fix: NextSymb() RESULTIS List2(op, RExp(35)) CASE s.table: $( LET ln = lineCount NextSymb() RESULTIS List4(s.table, -1, ln, RExpList()) $) CASE s.slct: $( LET k1 = zeroNode LET k2 = zeroNode LET k3 = ? NextSymb() k3 := RExp(0) IF symb=s.colon THEN $( NextSymb() k2 := k3 k3 := RExp(0) $) IF symb=s.colon THEN $( NextSymb() k1 := k2 k2 := k3 k3 := RExp(0) $) RESULTIS List4(s.slct, k1, k2, k3) $) $) $) AND RExp(n) = VALOF $( LET a = RbExp() LET b, c, p, q = 0, 0, 0, 0 $( LET op = symb IF nlPending THEN RESULTIS a SWITCHON op INTO $( DEFAULT: RESULTIS a CASE s.lparen: NextSymb() b := 0 IF symb~=s.rparen THEN b := RExpList() CheckFor(s.rparen, 19) a := List3(s.fnap, a, b) LOOP CASE s.vecap: CASE s.of: p := 40; GOTO lassoc CASE s.byteap: p := 36; GOTO lassoc CASE s.mult: CASE s.div: CASE s.rem: CASE s.fmult:CASE s.fdiv: p := 35; GOTO lassoc CASE s.plus: CASE s.minus: CASE s.fplus:CASE s.fminus: p := 34; GOTO lassoc CASE s.lshift: CASE s.rshift: p, q := 25, 30; GOTO dyadic CASE s.logand: p := 23; GOTO lassoc CASE s.logor: p := 22; GOTO lassoc CASE s.eqv: CASE s.neqv: p := 21; GOTO lassoc CASE s.eq: CASE s.ne: CASE s.le: CASE s.ge: CASE s.ls: CASE s.gr: CASE s.feq: CASE s.fne: CASE s.fle: CASE s.fge: CASE s.fls: CASE s.fgr: CASE s.lle: CASE s.lge: CASE s.lls: CASE s.lgr: IF n>=30 THEN RESULTIS a $( NextSymb() b := RExp(30) a := List3(op, a, b) c := c=0 -> a, List3(s.logand, c, a) a, op := b, symb $) REPEATWHILE (s.eq<=op<=s.ge) | (s.lls<=op<=s.lge) | (s.feq<=op<=s.fge) a := c LOOP CASE s.cond: IF n>=13 THEN RESULTIS a NextSymb() b := RExp(0) CheckFor(s.comma, 30) a := List4(s.cond, a, b, RExp(0)) LOOP $) lassoc: q := p dyadic: IF n>=p THEN RESULTIS a NextSymb() a := List3(op, a, RExp(q)) $) REPEAT $) AND RExpList() = VALOF $( LET a = 0 LET n = 0 LET list = GetListElement() LET liste = list $( InsertInListElement(@liste, RExp(0)) n := n+1 IF symb~=s.comma THEN BREAK NextSymb() $) REPEAT RESULTIS MakeList(list,liste,s.commalist,s.comma,n,1) $) AND RDef() = VALOF $( LET n = RNamelist() SWITCHON symb INTO $( CASE s.lparen: $( LET a = 0 LET ln = lineCount NextSymb() IF h1!n~=s.name THEN SynReport(40) IF symb=s.name THEN a := RNamelist() CheckFor(s.rparen, 41) IF symb=s.be THEN $( NextSymb() RESULTIS List6(s.rtdef, n, a, RCom(), 0, ln) $) IF symb=s.eq THEN $( NextSymb() RESULTIS List6(s.fndef, n, a, RExp(0), 0, ln) $) SynReport(42) $) DEFAULT: SynReport(44) CASE s.eq: $( LET ln = lineCount NextSymb() IF symb=s.vec THEN $( NextSymb() IF h1!n~=s.name THEN SynReport(43) RESULTIS List4(s.vecdef, n, RExp(0), ln) $) RESULTIS List4(s.valdef, n, RExpList(), ln) $) $) $) AND RbCom() = VALOF $( LET a, b, op = 0, 0, symb SWITCHON symb INTO $( DEFAULT: RESULTIS 0 CASE s.bad: SynReport(101) CASE s.name: CASE s.number: CASE s.string: CASE s.true: CASE s.false: CASE s.lv: CASE s.rv: CASE s.vecap: CASE s.lparen: CASE s.car: CASE s.cdr: CASE s.vcar: CASE s.vcdr: CASE s.nil: a := RExpList() IF symb=s.ass THEN $( op := symb NextSymb() RESULTIS List3(op, a, RExpList()) $) IF symb=s.opab THEN // // The node is of type 'OPAB', with the // actual operator in the second field. // $( LET dyadic = operator op := symb NextSymb() RESULTIS List4(op, dyadic, a, RExpList()) $) IF SmallNumber(a) THEN SynReport(51) IF symb=s.colon THEN $( IF h1!a~=s.name THEN SynReport(50) NextSymb() RESULTIS List4(s.colon, a, RbCom(), 0) $) IF h1!a=s.fnap THEN $( h1!a := s.rtap RESULTIS a $) SynReport(51) RESULTIS a CASE s.goto: CASE s.resultis: NextSymb() RESULTIS List2(op, RExp(0)) CASE s.if: CASE s.unless: CASE s.while: CASE s.until: NextSymb() a := RExp(0) Ignore(s.do) RESULTIS List3(op, a, RCom()) CASE s.test: NextSymb() a := RExp(0) Ignore(s.do) b := RCom() CheckFor(s.or, 54) RESULTIS List4(s.test, a, b, RCom()) CASE s.for: $( LET i, j, k = 0, 0, 0 NextSymb() a := RName() CheckFor(s.eq,57) i := RExp(0) CheckFor(s.to, 58) j := RExp(0) IF symb=s.by THEN $( NextSymb() k := RExp(0) $) Ignore(s.do) RESULTIS List6(s.for, a, i, j, k, RCom()) $) CASE s.loop: CASE s.break: CASE s.endcase: CASE s.return: CASE s.finish: a := wordNode NextSymb() RESULTIS a CASE s.switchon: $( LET cc = caseCount LET res = ? LET sect = ? NextSymb() a := RExp(0) CheckFor(s.into, 60) caseCount := 0 sect := RdSect(RdSeq) res := List4(s.switchon, a, sect, caseCount) caseCount := cc RESULTIS res $) CASE s.case: NextSymb() a := RExp(0) CheckFor(s.colon, 61) caseCount := caseCount+1 RESULTIS List3(s.case, a, RbCom()) CASE s.default: NextSymb() CheckFor(s.colon, 62) RESULTIS List2(s.default, RbCom()) CASE s.lsect: RESULTIS RdSect(RdBlockBody) $) $) AND RCom() = VALOF $( LET a = RbCom() IF a=0 THEN SynReport(51) WHILE symb=s.repeat | symb=s.repeatwhile | symb=s.repeatuntil DO $( LET op = symb NextSymb() a := op=s.repeat -> List2(op, a), List3(op, a, RExp(0)) $) RESULTIS a $)
00000000 53 45 43 54 49 4f 4e 20 22 4c 65 78 22 0a 0a 47 |SECTION "Lex"..G| 00000010 45 54 20 22 62 2e 48 65 61 64 65 72 22 0a 0a 53 |ET "b.Header"..S| 00000020 54 41 54 49 43 0a 24 28 20 2f 2f 20 56 65 72 73 |TATIC.$( // Vers| 00000030 69 6f 6e 20 6f 66 20 20 32 38 20 46 65 62 20 38 |ion of 28 Feb 8| 00000040 36 20 31 33 3a 30 34 3a 35 39 0a 20 20 20 64 75 |6 13:04:59. du| 00000050 6d 6d 79 20 3d 20 56 65 72 73 69 6f 6e 4d 61 72 |mmy = VersionMar| 00000060 6b 3b 0a 20 20 20 76 65 72 73 69 6f 6e 20 3d 20 |k;. version = | 00000070 31 2a 32 35 36 2b 32 0a 24 29 0a 0a 2f 2a 20 31 |1*256+2.$)../* 1| 00000080 2e 32 09 32 38 20 46 65 62 20 38 36 20 31 33 3a |.2.28 Feb 86 13:| 00000090 30 35 3a 31 30 0a 20 20 20 20 20 63 63 73 74 61 |05:10. ccsta| 000000a0 63 6b 20 69 6e 69 74 69 61 6c 69 73 65 64 20 74 |ck initialised t| 000000b0 6f 20 7a 65 72 6f 20 28 73 6f 20 75 6e 6d 61 74 |o zero (so unmat| 000000c0 63 68 69 6e 67 20 74 61 67 73 20 64 6f 6e 27 74 |ching tags don't| 000000d0 20 63 61 75 73 65 0a 20 20 20 20 20 63 6f 6d 70 | cause. comp| 000000e0 69 6c 65 72 20 63 6f 6c 6c 61 70 73 65 0a 2a 2f |iler collapse.*/| 000000f0 0a 0a 4c 45 54 20 69 6e 69 74 69 61 6c 69 73 65 |..LET initialise| 00000100 2e 6c 65 78 28 29 20 42 45 0a 24 28 20 63 63 73 |.lex() BE.$( ccs| 00000110 74 61 63 6b 20 3a 3d 20 30 3b 0a 20 20 20 44 65 |tack := 0;. De| 00000120 63 6c 53 79 73 57 6f 72 64 73 28 29 0a 20 20 20 |clSysWords(). | 00000130 52 43 68 28 29 0a 24 29 0a 0a 41 4e 44 20 4e 65 |RCh().$)..AND Ne| 00000140 78 74 53 79 6d 62 28 29 20 42 45 0a 24 28 20 4c |xtSymb() BE.$( L| 00000150 45 54 20 42 61 73 69 63 53 79 6d 62 28 29 20 42 |ET BasicSymb() B| 00000160 45 0a 20 20 20 24 28 20 6e 6c 50 65 6e 64 69 6e |E. $( nlPendin| 00000170 67 20 3a 3d 20 46 41 4c 53 45 0a 0a 20 20 20 20 |g := FALSE.. | 00000180 20 20 24 28 20 53 57 49 54 43 48 4f 4e 20 63 68 | $( SWITCHON ch| 00000190 20 49 4e 54 4f 0a 09 20 24 28 20 43 41 53 45 20 | INTO.. $( CASE | 000001a0 27 2a 4e 27 3a 20 6e 6c 50 65 6e 64 69 6e 67 20 |'*N': nlPending | 000001b0 3a 3d 20 54 52 55 45 0a 09 20 20 20 20 43 41 53 |:= TRUE.. CAS| 000001c0 45 20 27 2a 54 27 3a 0a 09 20 20 20 20 43 41 53 |E '*T':.. CAS| 000001d0 45 20 27 2a 53 27 3a 0a 09 20 20 20 20 20 20 52 |E '*S':.. R| 000001e0 43 68 28 29 20 52 45 50 45 41 54 57 48 49 4c 45 |Ch() REPEATWHILE| 000001f0 20 63 68 3d 27 2a 53 27 0a 09 20 20 20 20 20 20 | ch='*S'.. | 00000200 4c 4f 4f 50 0a 0a 09 20 20 20 20 43 41 53 45 20 |LOOP... CASE | 00000210 27 30 27 3a 20 43 41 53 45 20 27 31 27 3a 20 43 |'0': CASE '1': C| 00000220 41 53 45 20 27 32 27 3a 20 43 41 53 45 20 27 33 |ASE '2': CASE '3| 00000230 27 3a 0a 09 20 20 20 20 43 41 53 45 20 27 34 27 |':.. CASE '4'| 00000240 3a 20 43 41 53 45 20 27 35 27 3a 20 43 41 53 45 |: CASE '5': CASE| 00000250 20 27 36 27 3a 20 43 41 53 45 20 27 37 27 3a 0a | '6': CASE '7':.| 00000260 09 20 20 20 20 43 41 53 45 20 27 38 27 3a 20 43 |. CASE '8': C| 00000270 41 53 45 20 27 39 27 3a 0a 09 20 20 20 20 20 20 |ASE '9':.. | 00000280 73 79 6d 62 20 3a 3d 20 73 2e 6e 75 6d 62 65 72 |symb := s.number| 00000290 0a 09 20 20 20 20 20 20 52 65 61 64 4e 75 6d 62 |.. ReadNumb| 000002a0 65 72 28 31 30 29 3b 0a 09 20 20 20 20 20 20 49 |er(10);.. I| 000002b0 46 20 63 68 3d 27 2e 27 20 7c 20 63 68 3d 27 45 |F ch='.' | ch='E| 000002c0 27 20 7c 20 63 68 3d 27 65 27 20 54 48 45 4e 20 |' | ch='e' THEN | 000002d0 52 65 61 64 46 6c 6f 61 74 28 29 3b 0a 09 20 20 |ReadFloat();.. | 000002e0 20 20 20 20 52 45 54 55 52 4e 0a 0a 09 20 20 20 | RETURN... | 000002f0 20 43 41 53 45 20 27 61 27 3a 20 43 41 53 45 20 | CASE 'a': CASE | 00000300 27 62 27 3a 20 43 41 53 45 20 27 63 27 3a 20 43 |'b': CASE 'c': C| 00000310 41 53 45 20 27 64 27 3a 0a 09 20 20 20 20 43 41 |ASE 'd':.. CA| 00000320 53 45 20 27 65 27 3a 20 43 41 53 45 20 27 66 27 |SE 'e': CASE 'f'| 00000330 3a 20 43 41 53 45 20 27 67 27 3a 20 43 41 53 45 |: CASE 'g': CASE| 00000340 20 27 68 27 3a 0a 09 20 20 20 20 43 41 53 45 20 | 'h':.. CASE | 00000350 27 69 27 3a 20 43 41 53 45 20 27 6a 27 3a 20 43 |'i': CASE 'j': C| 00000360 41 53 45 20 27 6b 27 3a 20 43 41 53 45 20 27 6c |ASE 'k': CASE 'l| 00000370 27 3a 0a 09 20 20 20 20 43 41 53 45 20 27 6d 27 |':.. CASE 'm'| 00000380 3a 20 43 41 53 45 20 27 6e 27 3a 20 43 41 53 45 |: CASE 'n': CASE| 00000390 20 27 6f 27 3a 20 43 41 53 45 20 27 70 27 3a 0a | 'o': CASE 'p':.| 000003a0 09 20 20 20 20 43 41 53 45 20 27 71 27 3a 20 43 |. CASE 'q': C| 000003b0 41 53 45 20 27 72 27 3a 20 43 41 53 45 20 27 73 |ASE 'r': CASE 's| 000003c0 27 3a 20 43 41 53 45 20 27 74 27 3a 0a 09 20 20 |': CASE 't':.. | 000003d0 20 20 43 41 53 45 20 27 75 27 3a 20 43 41 53 45 | CASE 'u': CASE| 000003e0 20 27 76 27 3a 20 43 41 53 45 20 27 77 27 3a 20 | 'v': CASE 'w': | 000003f0 43 41 53 45 20 27 78 27 3a 0a 09 20 20 20 20 43 |CASE 'x':.. C| 00000400 41 53 45 20 27 79 27 3a 20 43 41 53 45 20 27 7a |ASE 'y': CASE 'z| 00000410 27 3a 0a 09 20 20 20 20 43 41 53 45 20 27 41 27 |':.. CASE 'A'| 00000420 3a 20 43 41 53 45 20 27 42 27 3a 20 43 41 53 45 |: CASE 'B': CASE| 00000430 20 27 43 27 3a 20 43 41 53 45 20 27 44 27 3a 0a | 'C': CASE 'D':.| 00000440 09 20 20 20 20 43 41 53 45 20 27 45 27 3a 20 43 |. CASE 'E': C| 00000450 41 53 45 20 27 46 27 3a 20 43 41 53 45 20 27 47 |ASE 'F': CASE 'G| 00000460 27 3a 20 43 41 53 45 20 27 48 27 3a 0a 09 20 20 |': CASE 'H':.. | 00000470 20 20 43 41 53 45 20 27 49 27 3a 20 43 41 53 45 | CASE 'I': CASE| 00000480 20 27 4a 27 3a 20 43 41 53 45 20 27 4b 27 3a 20 | 'J': CASE 'K': | 00000490 43 41 53 45 20 27 4c 27 3a 0a 09 20 20 20 20 43 |CASE 'L':.. C| 000004a0 41 53 45 20 27 4d 27 3a 20 43 41 53 45 20 27 4e |ASE 'M': CASE 'N| 000004b0 27 3a 20 43 41 53 45 20 27 4f 27 3a 20 43 41 53 |': CASE 'O': CAS| 000004c0 45 20 27 50 27 3a 0a 09 20 20 20 20 43 41 53 45 |E 'P':.. CASE| 000004d0 20 27 51 27 3a 20 43 41 53 45 20 27 52 27 3a 20 | 'Q': CASE 'R': | 000004e0 43 41 53 45 20 27 53 27 3a 20 43 41 53 45 20 27 |CASE 'S': CASE '| 000004f0 54 27 3a 0a 09 20 20 20 20 43 41 53 45 20 27 55 |T':.. CASE 'U| 00000500 27 3a 20 43 41 53 45 20 27 56 27 3a 20 43 41 53 |': CASE 'V': CAS| 00000510 45 20 27 57 27 3a 20 43 41 53 45 20 27 58 27 3a |E 'W': CASE 'X':| 00000520 0a 09 20 20 20 20 43 41 53 45 20 27 59 27 3a 20 |.. CASE 'Y': | 00000530 43 41 53 45 20 27 5a 27 3a 0a 09 20 20 20 20 20 |CASE 'Z':.. | 00000540 20 24 28 20 4c 45 54 20 63 3d 63 68 0a 0a 09 09 | $( LET c=ch....| 00000550 20 52 43 68 28 29 0a 09 09 20 52 64 54 61 67 28 | RCh()... RdTag(| 00000560 63 29 0a 09 09 20 73 79 6d 62 20 3a 3d 20 4c 6f |c)... symb := Lo| 00000570 6f 6b 55 70 57 6f 72 64 28 29 0a 0a 09 09 20 49 |okUpWord().... I| 00000580 46 20 73 79 6d 62 3d 73 2e 67 65 74 20 54 48 45 |F symb=s.get THE| 00000590 4e 0a 09 09 20 24 28 20 50 65 72 66 6f 72 6d 47 |N... $( PerformG| 000005a0 65 74 28 29 0a 09 09 20 20 20 20 4c 4f 4f 50 0a |et()... LOOP.| 000005b0 09 09 20 24 29 0a 09 09 20 52 45 54 55 52 4e 0a |.. $)... RETURN.| 000005c0 09 20 20 20 20 20 20 24 29 0a 0a 09 20 20 20 20 |. $)... | 000005d0 43 41 53 45 20 27 7b 27 3a 20 43 41 53 45 20 27 |CASE '{': CASE '| 000005e0 7d 27 3a 0a 09 20 20 20 20 20 20 73 79 6d 62 20 |}':.. symb | 000005f0 3a 3d 20 63 68 3d 27 7b 27 20 2d 3e 20 73 2e 6c |:= ch='{' -> s.l| 00000600 73 65 63 74 2c 20 73 2e 72 73 65 63 74 3b 0a 09 |sect, s.rsect;..| 00000610 20 20 20 20 20 20 52 43 68 28 29 3b 0a 09 20 20 | RCh();.. | 00000620 20 20 20 20 52 64 54 61 67 28 27 24 27 29 3b 0a | RdTag('$');.| 00000630 09 20 20 20 20 20 20 4c 6f 6f 6b 55 70 57 6f 72 |. LookUpWor| 00000640 64 28 29 3b 0a 09 20 20 20 20 20 20 52 45 54 55 |d();.. RETU| 00000650 52 4e 0a 0a 09 20 20 20 20 43 41 53 45 20 27 24 |RN... CASE '$| 00000660 27 3a 0a 09 20 20 20 20 20 20 6d 75 6c 74 69 63 |':.. multic| 00000670 68 61 72 28 22 28 29 3c 3e 24 22 2c 20 73 2e 6c |har("()<>$", s.l| 00000680 73 65 63 74 2c 73 2e 72 73 65 63 74 2c 20 31 2c |sect,s.rsect, 1,| 00000690 32 2c 0a 09 09 09 73 2e 74 61 67 6e 61 6d 65 2c |2,....s.tagname,| 000006a0 20 30 29 0a 0a 09 20 20 20 20 20 20 49 46 20 73 | 0)... IF s| 000006b0 79 6d 62 3d 73 2e 6c 73 65 63 74 20 7c 20 73 79 |ymb=s.lsect | sy| 000006c0 6d 62 3d 73 2e 72 73 65 63 74 20 54 48 45 4e 0a |mb=s.rsect THEN.| 000006d0 09 20 20 20 20 20 20 24 28 20 52 64 54 61 67 28 |. $( RdTag(| 000006e0 27 24 27 29 0a 09 09 20 4c 6f 6f 6b 55 70 57 6f |'$')... LookUpWo| 000006f0 72 64 28 29 0a 09 09 20 52 45 54 55 52 4e 20 24 |rd()... RETURN $| 00000700 29 0a 0a 09 20 20 20 20 20 20 49 46 20 65 78 74 |)... IF ext| 00000710 65 6e 73 69 6f 6e 2e 6c 65 76 65 6c 3e 3d 33 20 |ension.level>=3 | 00000720 26 20 73 79 6d 62 7e 3d 30 20 54 48 45 4e 0a 09 |& symb~=0 THEN..| 00000730 20 20 20 20 20 20 24 28 20 4c 45 54 20 63 63 68 | $( LET cch| 00000740 20 3d 20 43 61 70 69 74 61 6c 43 68 28 63 68 29 | = CapitalCh(ch)| 00000750 0a 09 09 20 4c 45 54 20 63 20 3d 20 63 68 0a 09 |... LET c = ch..| 00000760 09 20 49 46 20 7e 5b 27 41 27 3c 3d 63 63 68 3c |. IF ~['A'<=cch<| 00000770 3d 27 5a 27 20 7c 20 27 30 27 3c 3d 63 63 68 3c |='Z' | '0'<=cch<| 00000780 3d 27 39 27 5d 0a 09 09 20 20 20 20 54 48 45 4e |='9']... THEN| 00000790 20 53 79 6e 52 65 70 6f 72 74 28 32 29 0a 0a 09 | SynReport(2)...| 000007a0 09 20 52 43 68 28 29 0a 09 09 20 52 64 54 61 67 |. RCh()... RdTag| 000007b0 28 63 29 0a 09 09 20 74 61 67 70 74 72 20 3a 3d |(c)... tagptr :=| 000007c0 20 4c 6f 6f 6b 55 70 54 61 67 28 77 6f 72 64 76 | LookUpTag(wordv| 000007d0 29 0a 0a 09 09 20 49 46 20 73 79 6d 62 7e 3d 73 |).... IF symb~=s| 000007e0 2e 74 61 67 6e 61 6d 65 20 54 48 45 4e 0a 09 09 |.tagname THEN...| 000007f0 20 20 20 2f 2f 0a 09 09 20 20 20 2f 2f 20 24 3c | //... // $<| 00000800 74 61 67 20 6f 72 20 24 3e 74 61 67 0a 09 09 20 |tag or $>tag... | 00000810 20 20 2f 2f 0a 09 09 20 24 28 20 4c 45 54 20 69 | //... $( LET i| 00000820 6e 76 65 72 73 65 20 3d 20 46 41 4c 53 45 0a 09 |nverse = FALSE..| 00000830 09 20 20 20 20 49 46 20 63 68 3d 27 2a 27 27 20 |. IF ch='*'' | 00000840 54 48 45 4e 0a 09 09 20 20 20 20 24 28 20 52 43 |THEN... $( RC| 00000850 68 28 29 0a 09 09 20 20 20 20 20 20 20 69 6e 76 |h()... inv| 00000860 65 72 73 65 20 3a 3d 20 54 52 55 45 20 24 29 3b |erse := TRUE $);| 00000870 0a 09 09 20 20 20 20 63 6f 6e 64 69 74 69 6f 6e |... condition| 00000880 61 6c 2e 63 6f 6d 70 69 6c 61 74 69 6f 6e 28 73 |al.compilation(s| 00000890 79 6d 62 3d 31 2c 20 74 61 67 70 74 72 2c 20 69 |ymb=1, tagptr, i| 000008a0 6e 76 65 72 73 65 29 0a 09 09 20 20 20 20 4c 4f |nverse)... LO| 000008b0 4f 50 20 24 29 0a 09 09 20 52 45 54 55 52 4e 0a |OP $)... RETURN.| 000008c0 09 20 20 20 20 20 20 24 29 0a 09 20 20 20 20 20 |. $).. | 000008d0 20 53 79 6e 52 65 70 6f 72 74 28 39 31 29 0a 09 | SynReport(91)..| 000008e0 20 20 20 20 20 20 45 4e 44 43 41 53 45 0a 0a 09 | ENDCASE...| 000008f0 20 20 20 20 43 41 53 45 20 27 5b 27 3a 0a 09 20 | CASE '[':.. | 00000900 20 20 20 43 41 53 45 20 27 28 27 3a 20 73 79 6d | CASE '(': sym| 00000910 62 20 3a 3d 20 73 2e 6c 70 61 72 65 6e 3b 20 42 |b := s.lparen; B| 00000920 52 45 41 4b 0a 09 20 20 20 20 43 41 53 45 20 27 |REAK.. CASE '| 00000930 5d 27 3a 0a 09 20 20 20 20 43 41 53 45 20 27 29 |]':.. CASE ')| 00000940 27 3a 20 73 79 6d 62 20 3a 3d 20 73 2e 72 70 61 |': symb := s.rpa| 00000950 72 65 6e 3b 20 42 52 45 41 4b 0a 0a 09 20 20 20 |ren; BREAK... | 00000960 20 43 41 53 45 20 27 23 27 3a 0a 09 20 20 20 20 | CASE '#':.. | 00000970 20 20 24 28 20 4c 45 54 20 72 61 64 69 78 20 3d | $( LET radix =| 00000980 20 38 0a 09 09 20 52 43 68 28 29 0a 09 09 20 49 | 8... RCh()... I| 00000990 46 20 7e 5b 27 30 27 3c 3d 63 68 3c 3d 27 37 27 |F ~['0'<=ch<='7'| 000009a0 5d 20 54 48 45 4e 0a 09 09 20 24 28 20 53 57 49 |] THEN... $( SWI| 000009b0 54 43 48 4f 4e 20 43 61 70 69 74 61 6c 43 68 28 |TCHON CapitalCh(| 000009c0 63 68 29 20 49 4e 54 4f 0a 0a 09 09 20 20 20 20 |ch) INTO.... | 000009d0 24 28 20 44 45 46 41 55 4c 54 3a 0a 09 09 09 20 |$( DEFAULT:.... | 000009e0 20 42 61 73 69 63 53 79 6d 62 28 29 3b 0a 09 09 | BasicSymb();...| 000009f0 09 20 20 53 57 49 54 43 48 4f 4e 20 73 79 6d 62 |. SWITCHON symb| 00000a00 20 49 4e 54 4f 0a 09 09 09 20 20 24 28 20 43 41 | INTO.... $( CA| 00000a10 53 45 20 73 2e 70 6c 75 73 3a 43 41 53 45 20 73 |SE s.plus:CASE s| 00000a20 2e 6d 69 6e 75 73 3a 43 41 53 45 20 73 2e 6d 75 |.minus:CASE s.mu| 00000a30 6c 74 3a 43 41 53 45 20 73 2e 64 69 76 3a 0a 09 |lt:CASE s.div:..| 00000a40 09 09 20 20 20 20 20 43 41 53 45 20 73 2e 61 62 |.. CASE s.ab| 00000a50 73 3a 0a 09 09 09 20 20 20 20 20 43 41 53 45 20 |s:.... CASE | 00000a60 73 2e 6c 73 3a 43 41 53 45 20 73 2e 67 72 3a 43 |s.ls:CASE s.gr:C| 00000a70 41 53 45 20 73 2e 6c 65 3a 43 41 53 45 20 73 2e |ASE s.le:CASE s.| 00000a80 67 65 3a 0a 09 09 09 20 20 20 20 20 43 41 53 45 |ge:.... CASE| 00000a90 20 73 2e 65 71 3a 43 41 53 45 20 73 2e 6e 65 3a | s.eq:CASE s.ne:| 00000aa0 0a 09 09 09 09 73 79 6d 62 20 3a 3d 20 73 79 6d |.....symb := sym| 00000ab0 62 2b 73 2e 66 61 64 64 3b 0a 09 09 09 09 52 45 |b+s.fadd;.....RE| 00000ac0 54 55 52 4e 0a 0a 09 09 09 20 20 20 20 20 44 45 |TURN..... DE| 00000ad0 46 41 55 4c 54 3a 0a 09 09 09 09 53 79 6e 52 65 |FAULT:.....SynRe| 00000ae0 70 6f 72 74 28 33 33 29 0a 09 09 09 20 20 24 29 |port(33).... $)| 00000af0 0a 0a 09 09 20 20 20 20 20 20 20 43 41 53 45 20 |.... CASE | 00000b00 27 42 27 3a 72 61 64 69 78 20 3a 3d 20 32 3b 45 |'B':radix := 2;E| 00000b10 4e 44 43 41 53 45 0a 09 09 20 20 20 20 20 20 20 |NDCASE... | 00000b20 43 41 53 45 20 27 4f 27 3a 72 61 64 69 78 20 3a |CASE 'O':radix :| 00000b30 3d 20 38 3b 45 4e 44 43 41 53 45 0a 09 09 20 20 |= 8;ENDCASE... | 00000b40 20 20 20 20 20 43 41 53 45 20 27 58 27 3a 72 61 | CASE 'X':ra| 00000b50 64 69 78 20 3a 3d 20 31 36 0a 09 09 20 20 20 20 |dix := 16... | 00000b60 24 29 0a 09 09 20 20 20 20 52 43 68 28 29 20 24 |$)... RCh() $| 00000b70 29 0a 09 09 20 52 65 61 64 4e 75 6d 62 65 72 28 |)... ReadNumber(| 00000b80 72 61 64 69 78 29 0a 09 09 20 73 79 6d 62 20 3a |radix)... symb :| 00000b90 3d 20 73 2e 6e 75 6d 62 65 72 0a 09 09 20 52 45 |= s.number... RE| 00000ba0 54 55 52 4e 0a 09 20 20 20 20 20 20 24 29 0a 0a |TURN.. $)..| 00000bb0 09 20 20 20 20 43 41 53 45 20 27 3f 27 3a 20 73 |. CASE '?': s| 00000bc0 79 6d 62 20 3a 3d 20 73 2e 71 75 65 72 79 3b 09 |ymb := s.query;.| 00000bd0 20 20 20 42 52 45 41 4b 0a 09 20 20 20 20 43 41 | BREAK.. CA| 00000be0 53 45 20 27 2b 27 3a 20 73 79 6d 62 20 3a 3d 20 |SE '+': symb := | 00000bf0 73 2e 70 6c 75 73 3b 09 20 20 20 42 52 45 41 4b |s.plus;. BREAK| 00000c00 0a 09 20 20 20 20 43 41 53 45 20 27 2c 27 3a 20 |.. CASE ',': | 00000c10 73 79 6d 62 20 3a 3d 20 73 2e 63 6f 6d 6d 61 3b |symb := s.comma;| 00000c20 09 20 20 20 42 52 45 41 4b 0a 09 20 20 20 20 43 |. BREAK.. C| 00000c30 41 53 45 20 27 3b 27 3a 20 73 79 6d 62 20 3a 3d |ASE ';': symb :=| 00000c40 20 73 2e 73 65 6d 69 63 6f 6c 6f 6e 3b 20 42 52 | s.semicolon; BR| 00000c50 45 41 4b 0a 09 20 20 20 20 43 41 53 45 20 27 40 |EAK.. CASE '@| 00000c60 27 3a 20 73 79 6d 62 20 3a 3d 20 73 2e 6c 76 3b |': symb := s.lv;| 00000c70 09 20 20 20 42 52 45 41 4b 0a 09 20 20 20 20 43 |. BREAK.. C| 00000c80 41 53 45 20 27 26 27 3a 20 73 79 6d 62 20 3a 3d |ASE '&': symb :=| 00000c90 20 73 2e 6c 6f 67 61 6e 64 3b 20 20 20 20 42 52 | s.logand; BR| 00000ca0 45 41 4b 0a 09 20 20 20 20 43 41 53 45 20 27 3d |EAK.. CASE '=| 00000cb0 27 3a 20 73 79 6d 62 20 3a 3d 20 73 2e 65 71 3b |': symb := s.eq;| 00000cc0 09 20 20 20 42 52 45 41 4b 0a 09 20 20 20 20 43 |. BREAK.. C| 00000cd0 41 53 45 20 27 21 27 3a 20 73 79 6d 62 20 3a 3d |ASE '!': symb :=| 00000ce0 20 73 2e 76 65 63 61 70 3b 09 20 20 20 42 52 45 | s.vecap;. BRE| 00000cf0 41 4b 0a 09 20 20 20 20 43 41 53 45 20 27 2a 2a |AK.. CASE '**| 00000d00 27 3a 73 79 6d 62 20 3a 3d 20 73 2e 6d 75 6c 74 |':symb := s.mult| 00000d10 3b 09 20 20 20 42 52 45 41 4b 0a 0a 09 20 20 20 |;. BREAK... | 00000d20 20 43 41 53 45 20 27 25 27 3a 0a 09 20 20 20 20 | CASE '%':.. | 00000d30 20 20 20 49 46 20 65 78 74 65 6e 73 69 6f 6e 2e | IF extension.| 00000d40 6c 65 76 65 6c 3c 32 20 54 48 45 4e 0a 09 20 20 |level<2 THEN.. | 00000d50 20 20 20 20 20 24 28 20 63 68 20 3a 3d 20 30 0a | $( ch := 0.| 00000d60 09 09 20 20 4c 4f 4f 50 20 24 29 0a 09 20 20 20 |.. LOOP $).. | 00000d70 20 20 20 20 73 79 6d 62 20 3a 3d 20 73 2e 62 79 | symb := s.by| 00000d80 74 65 61 70 0a 09 20 20 20 20 20 20 20 42 52 45 |teap.. BRE| 00000d90 41 4b 0a 0a 09 20 20 20 20 43 41 53 45 20 27 7c |AK... CASE '|| 00000da0 27 3a 0a 09 20 20 20 20 20 20 49 46 20 65 78 74 |':.. IF ext| 00000db0 65 6e 73 69 6f 6e 2e 6c 65 76 65 6c 3c 31 20 54 |ension.level<1 T| 00000dc0 48 45 4e 0a 09 20 20 20 20 20 20 24 28 20 73 79 |HEN.. $( sy| 00000dd0 6d 62 20 3a 3d 20 73 2e 6c 6f 67 6f 72 0a 09 09 |mb := s.logor...| 00000de0 20 42 52 45 41 4b 20 24 29 0a 0a 09 20 20 20 20 | BREAK $)... | 00000df0 20 20 6d 75 6c 74 69 63 68 61 72 28 22 7c 22 2c | multichar("|",| 00000e00 20 30 2c 20 73 2e 6c 6f 67 6f 72 29 0a 09 20 20 | 0, s.logor).. | 00000e10 20 20 20 20 49 46 20 73 79 6d 62 7e 3d 30 20 54 | IF symb~=0 T| 00000e20 48 45 4e 20 52 45 54 55 52 4e 0a 0a 09 63 6d 6e |HEN RETURN...cmn| 00000e30 74 3a 20 55 4e 54 49 4c 20 63 68 3d 27 2a 4e 27 |t: UNTIL ch='*N'| 00000e40 20 7c 20 63 68 3d 27 2a 50 27 20 7c 20 63 68 3d | | ch='*P' | ch=| 00000e50 45 6e 64 53 74 72 65 61 6d 43 68 09 44 4f 0a 09 |EndStreamCh.DO..| 00000e60 09 52 43 68 28 29 0a 09 20 20 20 20 20 20 4c 4f |.RCh().. LO| 00000e70 4f 50 0a 0a 09 20 20 20 20 43 41 53 45 20 27 2f |OP... CASE '/| 00000e80 27 3a 0a 09 20 20 20 20 20 20 6d 75 6c 74 69 63 |':.. multic| 00000e90 68 61 72 28 22 5c 2f 2a 2a 22 2c 20 73 2e 6c 6f |har("\/**", s.lo| 00000ea0 67 61 6e 64 2c 20 30 2c 20 2d 31 2c 20 73 2e 64 |gand, 0, -1, s.d| 00000eb0 69 76 29 0a 09 20 20 20 20 20 20 49 46 20 73 79 |iv).. IF sy| 00000ec0 6d 62 3e 30 20 54 48 45 4e 20 52 45 54 55 52 4e |mb>0 THEN RETURN| 00000ed0 0a 09 20 20 20 20 20 20 49 46 20 73 79 6d 62 3d |.. IF symb=| 00000ee0 30 20 54 48 45 4e 20 47 4f 54 4f 20 63 6d 6e 74 |0 THEN GOTO cmnt| 00000ef0 0a 0a 09 20 20 20 20 20 20 24 28 20 49 46 20 63 |... $( IF c| 00000f00 68 3d 27 2a 2a 27 20 54 48 45 4e 0a 09 09 20 24 |h='**' THEN... $| 00000f10 28 20 52 43 68 28 29 0a 09 09 20 20 20 20 49 46 |( RCh()... IF| 00000f20 20 63 68 3d 27 2f 27 20 54 48 45 4e 20 42 52 45 | ch='/' THEN BRE| 00000f30 41 4b 0a 09 09 20 20 20 20 4c 4f 4f 50 20 24 29 |AK... LOOP $)| 00000f40 0a 09 09 20 49 46 20 63 68 3d 45 6e 64 53 74 72 |... IF ch=EndStr| 00000f50 65 61 6d 43 68 20 54 48 45 4e 20 53 79 6e 52 65 |eamCh THEN SynRe| 00000f60 70 6f 72 74 28 36 33 29 3b 0a 09 09 20 52 43 68 |port(63);... RCh| 00000f70 28 29 0a 09 20 20 20 20 20 20 24 29 20 52 45 50 |().. $) REP| 00000f80 45 41 54 0a 09 20 20 20 20 20 20 52 43 68 28 29 |EAT.. RCh()| 00000f90 0a 09 20 20 20 20 20 20 4c 4f 4f 50 0a 0a 09 20 |.. LOOP... | 00000fa0 20 20 20 43 41 53 45 20 27 7e 27 3a 0a 09 20 20 | CASE '~':.. | 00000fb0 20 20 20 20 6d 75 6c 74 69 63 68 61 72 28 22 3d | multichar("=| 00000fc0 22 2c 20 73 2e 6e 65 2c 20 73 2e 6e 6f 74 29 0a |", s.ne, s.not).| 00000fd0 09 20 20 20 20 20 20 52 45 54 55 52 4e 0a 0a 09 |. RETURN...| 00000fe0 20 20 20 20 43 41 53 45 20 27 5c 27 3a 0a 09 20 | CASE '\':.. | 00000ff0 20 20 20 20 20 6d 75 6c 74 69 63 68 61 72 28 22 | multichar("| 00001000 2f 3d 22 2c 20 73 2e 6c 6f 67 6f 72 2c 20 73 2e |/=", s.logor, s.| 00001010 6e 65 2c 20 73 2e 6e 6f 74 29 0a 09 20 20 20 20 |ne, s.not).. | 00001020 20 20 52 45 54 55 52 4e 0a 0a 09 20 20 20 20 43 | RETURN... C| 00001030 41 53 45 20 27 3c 27 3a 0a 09 20 20 20 20 20 20 |ASE '<':.. | 00001040 6d 75 6c 74 69 63 68 61 72 28 22 3d 3c 22 2c 20 |multichar("=<", | 00001050 73 2e 6c 65 2c 20 73 2e 6c 73 68 69 66 74 2c 20 |s.le, s.lshift, | 00001060 73 2e 6c 73 29 0a 09 20 20 20 20 20 20 52 45 54 |s.ls).. RET| 00001070 55 52 4e 0a 0a 09 20 20 20 20 43 41 53 45 20 27 |URN... CASE '| 00001080 3e 27 3a 0a 09 20 20 20 20 20 20 6d 75 6c 74 69 |>':.. multi| 00001090 63 68 61 72 28 22 3d 3e 22 2c 20 73 2e 67 65 2c |char("=>", s.ge,| 000010a0 20 73 2e 72 73 68 69 66 74 2c 20 73 2e 67 72 29 | s.rshift, s.gr)| 000010b0 0a 09 20 20 20 20 20 20 52 45 54 55 52 4e 0a 0a |.. RETURN..| 000010c0 09 20 20 20 20 43 41 53 45 20 27 2d 27 3a 0a 09 |. CASE '-':..| 000010d0 20 20 20 20 20 20 6d 75 6c 74 69 63 68 61 72 28 | multichar(| 000010e0 22 3e 22 2c 20 73 2e 63 6f 6e 64 2c 20 73 2e 6d |">", s.cond, s.m| 000010f0 69 6e 75 73 29 0a 09 20 20 20 20 20 20 52 45 54 |inus).. RET| 00001100 55 52 4e 0a 0a 09 20 20 20 20 43 41 53 45 20 27 |URN... CASE '| 00001110 3a 27 3a 0a 09 20 20 20 20 20 20 6d 75 6c 74 69 |:':.. multi| 00001120 63 68 61 72 28 22 3d 22 2c 20 73 2e 61 73 73 2c |char("=", s.ass,| 00001130 20 73 2e 63 6f 6c 6f 6e 29 0a 09 20 20 20 20 20 | s.colon).. | 00001140 20 52 45 54 55 52 4e 0a 0a 09 20 20 20 20 43 41 | RETURN... CA| 00001150 53 45 20 27 22 27 3a 0a 09 20 20 20 20 20 20 24 |SE '"':.. $| 00001160 28 20 4c 45 54 20 69 20 3d 20 30 0a 09 09 20 4c |( LET i = 0... L| 00001170 45 54 20 73 63 68 20 3d 20 3f 0a 0a 09 09 20 57 |ET sch = ?.... W| 00001180 48 49 4c 45 20 52 64 53 74 72 43 68 28 27 22 27 |HILE RdStrCh('"'| 00001190 2c 20 40 73 63 68 29 20 44 4f 0a 09 09 20 24 28 |, @sch) DO... $(| 000011a0 20 49 46 20 69 3d 32 35 35 20 54 48 45 4e 20 53 | IF i=255 THEN S| 000011b0 79 6e 52 65 70 6f 72 74 28 33 34 29 0a 09 09 20 |ynReport(34)... | 000011c0 20 20 20 69 20 3a 3d 20 69 2b 31 0a 09 09 20 20 | i := i+1... | 000011d0 20 20 77 6f 72 64 76 25 69 20 3a 3d 20 73 63 68 | wordv%i := sch| 000011e0 20 24 29 0a 09 09 20 77 6f 72 64 76 25 30 20 3a | $)... wordv%0 :| 000011f0 3d 20 69 0a 09 09 20 73 79 6d 62 20 3a 3d 20 73 |= i... symb := s| 00001200 2e 73 74 72 69 6e 67 0a 09 09 20 42 52 45 41 4b |.string... BREAK| 00001210 0a 09 20 20 20 20 20 20 24 29 0a 0a 09 20 20 20 |.. $)... | 00001220 20 43 41 53 45 20 27 2a 27 27 3a 0a 09 20 20 20 | CASE '*'':.. | 00001230 20 20 20 24 28 20 4c 45 54 20 6f 6b 20 3d 20 52 | $( LET ok = R| 00001240 64 53 74 72 43 68 28 27 2a 27 27 2c 20 40 64 65 |dStrCh('*'', @de| 00001250 63 76 61 6c 29 0a 09 09 20 73 79 6d 62 20 3a 3d |cval)... symb :=| 00001260 20 73 2e 6e 75 6d 62 65 72 3b 0a 09 09 20 49 46 | s.number;... IF| 00001270 20 6f 6b 20 54 48 45 4e 0a 09 09 20 24 28 20 52 | ok THEN... $( R| 00001280 43 68 28 29 0a 09 09 20 20 20 20 6f 6b 20 3a 3d |Ch()... ok :=| 00001290 20 63 68 3d 27 2a 27 27 20 24 29 0a 09 09 20 49 | ch='*'' $)... I| 000012a0 46 20 7e 6f 6b 20 54 48 45 4e 20 53 79 6e 52 65 |F ~ok THEN SynRe| 000012b0 70 6f 72 74 28 33 34 29 0a 09 09 20 42 52 45 41 |port(34)... BREA| 000012c0 4b 0a 09 20 20 20 20 20 20 24 29 0a 0a 09 20 20 |K.. $)... | 000012d0 20 20 44 45 46 41 55 4c 54 3a 0a 09 20 20 20 20 | DEFAULT:.. | 000012e0 20 20 49 46 20 63 68 7e 3d 45 6e 64 53 74 72 65 | IF ch~=EndStre| 000012f0 61 6d 43 68 20 54 48 45 4e 0a 09 20 20 20 20 20 |amCh THEN.. | 00001300 20 24 28 20 63 68 20 3a 3d 20 27 2a 53 27 0a 09 | $( ch := '*S'..| 00001310 09 20 53 79 6e 52 65 70 6f 72 74 28 39 34 29 20 |. SynReport(94) | 00001320 24 29 0a 0a 09 20 20 20 20 43 41 53 45 20 27 2e |$)... CASE '.| 00001330 27 3a 0a 09 20 20 20 20 20 20 49 46 20 67 65 74 |':.. IF get| 00001340 70 3d 30 20 54 48 45 4e 0a 09 20 20 20 20 20 20 |p=0 THEN.. | 00001350 24 28 20 73 79 6d 62 20 3a 3d 20 73 2e 65 6e 64 |$( symb := s.end| 00001360 0a 09 09 20 42 52 45 41 4b 20 24 29 0a 09 20 20 |... BREAK $).. | 00001370 20 20 20 20 63 6c 6f 73 65 28 73 6f 75 72 63 65 | close(source| 00001380 53 74 72 65 61 6d 29 0a 0a 09 20 20 20 20 20 20 |Stream)... | 00001390 67 65 74 70 20 3a 3d 20 67 65 74 70 2d 33 0a 09 |getp := getp-3..| 000013a0 20 20 20 20 20 20 73 6f 75 72 63 65 53 74 72 65 | sourceStre| 000013b0 61 6d 20 3a 3d 20 67 65 74 76 21 67 65 74 70 0a |am := getv!getp.| 000013c0 09 20 20 20 20 20 20 6c 69 6e 65 43 6f 75 6e 74 |. lineCount| 000013d0 20 3a 3d 20 67 65 74 76 21 28 67 65 74 70 2b 31 | := getv!(getp+1| 000013e0 29 0a 09 20 20 20 20 20 20 63 68 20 3a 3d 20 67 |).. ch := g| 000013f0 65 74 76 21 28 67 65 74 70 2b 32 29 0a 0a 09 20 |etv!(getp+2)... | 00001400 20 20 20 20 20 53 65 6c 65 63 74 49 6e 70 75 74 | SelectInput| 00001410 28 73 6f 75 72 63 65 53 74 72 65 61 6d 29 0a 09 |(sourceStream)..| 00001420 20 20 20 20 20 20 4c 4f 4f 50 0a 09 20 24 29 0a | LOOP.. $).| 00001430 20 20 20 20 20 20 24 29 20 52 45 50 45 41 54 0a | $) REPEAT.| 00001440 20 20 20 20 20 20 52 43 68 28 29 0a 20 20 20 24 | RCh(). $| 00001450 29 0a 0a 20 20 20 42 61 73 69 63 53 79 6d 62 28 |).. BasicSymb(| 00001460 29 0a 0a 20 20 20 2f 2f 20 43 68 65 63 6b 20 66 |).. // Check f| 00001470 6f 72 20 74 61 67 20 73 65 74 74 69 6e 67 20 64 |or tag setting d| 00001480 69 72 65 63 74 69 76 65 2e 09 54 68 69 73 20 69 |irective..This i| 00001490 73 20 6f 66 20 74 68 65 0a 20 20 20 2f 2f 20 66 |s of the. // f| 000014a0 6f 72 6d 3a 0a 20 20 20 2f 2f 09 20 20 20 20 24 |orm:. //. $| 000014b0 24 74 61 67 20 20 20 20 6f 72 20 20 20 24 24 74 |$tag or $$t| 000014c0 61 67 20 3a 3d 20 65 78 70 6e 0a 20 20 20 2f 2f |ag := expn. //| 000014d0 0a 20 20 20 2f 2f 20 41 20 24 24 74 61 67 20 73 |. // A $$tag s| 000014e0 79 6d 62 6f 6c 20 69 73 20 6f 66 20 74 79 70 65 |ymbol is of type| 000014f0 20 27 73 2e 74 61 67 6e 61 6d 65 27 2e 0a 20 20 | 's.tagname'.. | 00001500 20 2f 2f 0a 20 20 20 2f 2f 20 41 20 6c 6f 6f 70 | //. // A loop| 00001510 20 69 73 20 75 73 65 64 20 74 6f 20 67 65 74 20 | is used to get | 00001520 63 61 73 65 73 20 6c 69 6b 65 20 24 24 74 61 67 |cases like $$tag| 00001530 20 24 24 74 61 67 32 20 3a 3d 20 2e 2e 20 20 72 | $$tag2 := .. r| 00001540 69 67 68 74 2e 0a 0a 20 20 20 57 48 49 4c 45 20 |ight... WHILE | 00001550 73 79 6d 62 3d 73 2e 74 61 67 6e 61 6d 65 20 44 |symb=s.tagname D| 00001560 4f 0a 20 20 20 24 28 20 4c 45 54 20 74 61 67 20 |O. $( LET tag | 00001570 3d 20 74 61 67 70 74 72 0a 20 20 20 20 20 20 4c |= tagptr. L| 00001580 45 54 20 76 61 6c 75 65 20 3d 20 46 41 4c 53 45 |ET value = FALSE| 00001590 0a 20 20 20 20 20 20 4c 45 54 20 6f 70 20 3d 20 |. LET op = | 000015a0 73 2e 6c 6f 67 6f 72 0a 0a 20 20 20 20 20 20 42 |s.logor.. B| 000015b0 61 73 69 63 53 79 6d 62 28 29 0a 0a 20 20 20 20 |asicSymb().. | 000015c0 20 20 2f 2f 20 49 66 20 74 68 65 20 24 24 74 61 | // If the $$ta| 000015d0 67 20 77 61 73 20 6e 6f 74 20 66 6f 6c 6c 6f 77 |g was not follow| 000015e0 65 64 20 62 79 20 3a 3d 2c 20 73 69 6d 70 6c 79 |ed by :=, simply| 000015f0 0a 20 20 20 20 20 20 2f 2f 20 69 6e 76 65 72 74 |. // invert| 00001600 20 74 68 65 20 76 61 6c 75 65 20 6f 66 20 74 68 | the value of th| 00001610 65 20 74 61 67 20 61 6e 64 20 67 6f 20 72 6f 75 |e tag and go rou| 00001620 6e 64 20 61 67 61 69 6e 2e 0a 0a 20 20 20 20 20 |nd again... | 00001630 20 49 46 20 73 79 6d 62 7e 3d 73 2e 61 73 73 20 | IF symb~=s.ass | 00001640 54 48 45 4e 0a 20 20 20 20 20 20 24 28 20 74 61 |THEN. $( ta| 00001650 67 2e 76 61 6c 75 65 21 74 61 67 20 3a 3d 20 7e |g.value!tag := ~| 00001660 74 61 67 2e 76 61 6c 75 65 21 74 61 67 0a 09 20 |tag.value!tag.. | 00001670 4c 4f 4f 50 20 24 29 0a 0a 20 20 20 20 20 20 24 |LOOP $).. $| 00001680 28 20 4c 45 54 20 69 6e 76 65 72 73 65 20 3d 20 |( LET inverse = | 00001690 46 41 4c 53 45 0a 09 20 4c 45 54 20 73 76 61 6c |FALSE.. LET sval| 000016a0 20 3d 20 20 3f 0a 0a 09 20 42 61 73 69 63 53 79 | = ?... BasicSy| 000016b0 6d 62 28 29 0a 0a 09 20 49 46 20 73 79 6d 62 3d |mb()... IF symb=| 000016c0 73 2e 6e 6f 74 20 54 48 45 4e 0a 09 20 24 28 20 |s.not THEN.. $( | 000016d0 69 6e 76 65 72 73 65 20 3a 3d 20 54 52 55 45 0a |inverse := TRUE.| 000016e0 09 20 20 20 20 42 61 73 69 63 53 79 6d 62 28 29 |. BasicSymb()| 000016f0 20 24 29 0a 0a 09 20 53 57 49 54 43 48 4f 4e 20 | $)... SWITCHON | 00001700 73 79 6d 62 20 49 4e 54 4f 0a 09 20 24 28 20 43 |symb INTO.. $( C| 00001710 41 53 45 20 73 2e 74 61 67 6e 61 6d 65 3a 0a 09 |ASE s.tagname:..| 00001720 20 20 20 20 20 20 73 76 61 6c 20 3a 3d 20 74 61 | sval := ta| 00001730 67 2e 76 61 6c 75 65 21 74 61 67 70 74 72 0a 09 |g.value!tagptr..| 00001740 20 20 20 20 20 20 45 4e 44 43 41 53 45 0a 0a 09 | ENDCASE...| 00001750 20 20 20 20 43 41 53 45 20 73 2e 74 72 75 65 3a | CASE s.true:| 00001760 0a 09 20 20 20 20 20 20 73 76 61 6c 20 3a 3d 20 |.. sval := | 00001770 54 52 55 45 0a 09 20 20 20 20 20 20 45 4e 44 43 |TRUE.. ENDC| 00001780 41 53 45 0a 0a 09 20 20 20 20 43 41 53 45 20 73 |ASE... CASE s| 00001790 2e 66 61 6c 73 65 3a 0a 09 20 20 20 20 20 20 73 |.false:.. s| 000017a0 76 61 6c 20 3a 3d 20 46 41 4c 53 45 0a 09 20 20 |val := FALSE.. | 000017b0 20 20 20 20 45 4e 44 43 41 53 45 0a 0a 09 20 20 | ENDCASE... | 000017c0 20 20 44 45 46 41 55 4c 54 3a 0a 09 20 20 20 20 | DEFAULT:.. | 000017d0 20 20 53 79 6e 52 65 70 6f 72 74 28 31 29 0a 09 | SynReport(1)..| 000017e0 20 20 20 20 20 20 45 4e 44 43 41 53 45 0a 09 20 | ENDCASE.. | 000017f0 24 29 0a 0a 09 20 2f 2f 20 43 6f 6d 62 69 6e 65 |$)... // Combine| 00001800 20 74 68 65 20 76 61 6c 75 65 20 77 69 74 68 20 | the value with | 00001810 74 68 65 20 65 78 70 72 65 73 73 69 6f 6e 20 73 |the expression s| 00001820 6f 20 66 61 72 0a 09 20 2f 2f 20 61 6e 64 20 63 |o far.. // and c| 00001830 68 65 63 6b 20 66 6f 72 20 61 6e 20 6f 70 65 72 |heck for an oper| 00001840 61 74 6f 72 2e 0a 0a 09 20 49 46 20 69 6e 76 65 |ator.... IF inve| 00001850 72 73 65 20 54 48 45 4e 20 73 76 61 6c 20 3a 3d |rse THEN sval :=| 00001860 20 7e 73 76 61 6c 0a 0a 09 20 54 45 53 54 20 6f | ~sval... TEST o| 00001870 70 3d 73 2e 6c 6f 67 6f 72 0a 09 20 20 20 20 54 |p=s.logor.. T| 00001880 48 45 4e 20 76 61 6c 75 65 20 3a 3d 20 76 61 6c |HEN value := val| 00001890 75 65 20 7c 20 73 76 61 6c 0a 09 20 20 20 20 45 |ue | sval.. E| 000018a0 4c 53 45 20 76 61 6c 75 65 20 3a 3d 20 76 61 6c |LSE value := val| 000018b0 75 65 20 26 20 73 76 61 6c 0a 0a 09 20 42 61 73 |ue & sval... Bas| 000018c0 69 63 53 79 6d 62 28 29 0a 09 20 6f 70 20 3a 3d |icSymb().. op :=| 000018d0 20 73 79 6d 62 0a 20 20 20 20 20 20 24 29 20 52 | symb. $) R| 000018e0 45 50 45 41 54 57 48 49 4c 45 20 6f 70 3d 73 2e |EPEATWHILE op=s.| 000018f0 6c 6f 67 6f 72 20 7c 20 6f 70 3d 73 2e 6c 6f 67 |logor | op=s.log| 00001900 61 6e 64 0a 0a 20 20 20 20 20 20 74 61 67 2e 76 |and.. tag.v| 00001910 61 6c 75 65 21 74 61 67 20 3a 3d 20 76 61 6c 75 |alue!tag := valu| 00001920 65 0a 20 20 20 24 29 0a 0a 20 20 20 2f 2f 20 53 |e. $).. // S| 00001930 79 6d 62 6f 6c 20 69 73 20 6e 6f 74 20 24 24 74 |ymbol is not $$t| 00001940 61 67 3a 20 63 68 65 63 6b 20 66 6f 72 20 61 20 |ag: check for a | 00001950 63 6f 6d 70 6f 75 6e 64 20 61 73 73 69 67 6e 6d |compound assignm| 00001960 65 6e 74 0a 20 20 20 2f 2f 20 28 6e 6f 74 65 20 |ent. // (note | 00001970 74 68 61 74 20 6f 70 3a 3d 20 69 73 20 61 6e 20 |that op:= is an | 00001980 65 78 74 65 6e 73 69 6f 6e 29 2e 0a 0a 20 20 20 |extension)... | 00001990 49 46 20 65 78 74 65 6e 73 69 6f 6e 2e 6c 65 76 |IF extension.lev| 000019a0 65 6c 3e 3d 33 20 54 48 45 4e 20 53 57 49 54 43 |el>=3 THEN SWITC| 000019b0 48 4f 4e 20 73 79 6d 62 20 49 4e 54 4f 0a 20 20 |HON symb INTO. | 000019c0 20 24 28 20 43 41 53 45 20 73 2e 6d 75 6c 74 3a | $( CASE s.mult:| 000019d0 20 20 20 43 41 53 45 20 73 2e 64 69 76 3a 20 20 | CASE s.div: | 000019e0 43 41 53 45 20 73 2e 72 65 6d 3a 0a 20 20 20 20 |CASE s.rem:. | 000019f0 20 20 43 41 53 45 20 73 2e 70 6c 75 73 3a 20 20 | CASE s.plus: | 00001a00 20 43 41 53 45 20 73 2e 6d 69 6e 75 73 3a 0a 20 | CASE s.minus:. | 00001a10 20 20 20 20 20 43 41 53 45 20 73 2e 66 6d 75 6c | CASE s.fmul| 00001a20 74 3a 20 20 43 41 53 45 20 73 2e 66 64 69 76 3a |t: CASE s.fdiv:| 00001a30 0a 20 20 20 20 20 20 43 41 53 45 20 73 2e 66 70 |. CASE s.fp| 00001a40 6c 75 73 3a 20 20 43 41 53 45 20 73 2e 66 6d 69 |lus: CASE s.fmi| 00001a50 6e 75 73 3a 0a 20 20 20 20 20 20 43 41 53 45 20 |nus:. CASE | 00001a60 73 2e 6c 6f 67 61 6e 64 3a 20 43 41 53 45 20 73 |s.logand: CASE s| 00001a70 2e 6c 6f 67 6f 72 3a 0a 20 20 20 20 20 20 43 41 |.logor:. CA| 00001a80 53 45 20 73 2e 65 71 76 3a 20 20 20 20 43 41 53 |SE s.eqv: CAS| 00001a90 45 20 73 2e 6e 65 71 76 3a 0a 20 20 20 20 20 20 |E s.neqv:. | 00001aa0 43 41 53 45 20 73 2e 6c 73 68 69 66 74 3a 20 43 |CASE s.lshift: C| 00001ab0 41 53 45 20 73 2e 72 73 68 69 66 74 3a 0a 09 2f |ASE s.rshift:../| 00001ac0 2f 0a 09 2f 2f 20 43 68 65 63 6b 20 66 6f 72 20 |/..// Check for | 00001ad0 3a 3d 20 66 6f 6c 6c 6f 77 69 6e 67 20 6f 70 65 |:= following ope| 00001ae0 72 61 74 6f 72 2e 0a 09 2f 2f 0a 09 49 46 20 63 |rator...//..IF c| 00001af0 68 3d 27 3a 27 20 54 48 45 4e 0a 09 24 28 20 4c |h=':' THEN..$( L| 00001b00 45 54 20 63 68 20 3d 20 52 64 43 68 28 29 3b 20 |ET ch = RdCh(); | 00001b10 55 6e 52 64 43 68 28 29 0a 0a 09 20 20 20 49 46 |UnRdCh()... IF| 00001b20 20 63 68 3d 27 3d 27 20 54 48 45 4e 0a 09 20 20 | ch='=' THEN.. | 00001b30 20 24 28 20 52 43 68 28 29 3b 20 52 43 68 28 29 | $( RCh(); RCh()| 00001b40 0a 09 20 20 20 20 20 20 6f 70 65 72 61 74 6f 72 |.. operator| 00001b50 20 3a 3d 20 73 79 6d 62 0a 09 20 20 20 20 20 20 | := symb.. | 00001b60 73 79 6d 62 20 3a 3d 20 73 2e 6f 70 61 62 20 24 |symb := s.opab $| 00001b70 29 20 24 29 0a 20 20 20 24 29 0a 24 29 0a 0a 41 |) $). $).$)..A| 00001b80 4e 44 20 6d 75 6c 74 69 63 68 61 72 28 63 68 61 |ND multichar(cha| 00001b90 72 73 2c 20 61 2c 20 62 2c 20 63 2c 20 64 2c 20 |rs, a, b, c, d, | 00001ba0 65 2c 20 66 2c 20 67 2c 20 68 29 20 42 45 0a 24 |e, f, g, h) BE.$| 00001bb0 28 20 4c 45 54 20 74 20 3d 20 40 63 68 61 72 73 |( LET t = @chars| 00001bc0 0a 20 20 20 4c 45 54 20 69 2c 20 6c 69 6d 20 3d |. LET i, lim =| 00001bd0 20 31 2c 20 63 68 61 72 73 25 30 0a 20 20 20 52 | 1, chars%0. R| 00001be0 43 68 28 29 0a 0a 20 20 20 57 48 49 4c 45 20 69 |Ch().. WHILE i| 00001bf0 3c 3d 6c 69 6d 20 44 4f 0a 20 20 20 24 28 20 49 |<=lim DO. $( I| 00001c00 46 20 63 68 3d 63 68 61 72 73 25 69 20 54 48 45 |F ch=chars%i THE| 00001c10 4e 0a 20 20 20 20 20 20 24 28 20 52 43 68 28 29 |N. $( RCh()| 00001c20 0a 09 20 42 52 45 41 4b 20 24 29 0a 20 20 20 20 |.. BREAK $). | 00001c30 20 20 69 20 3a 3d 20 69 2b 31 20 24 29 0a 20 20 | i := i+1 $). | 00001c40 20 73 79 6d 62 20 3a 3d 20 74 21 69 0a 24 29 0a | symb := t!i.$).| 00001c50 0a 41 4e 44 20 4c 6f 6f 6b 55 70 57 6f 72 64 28 |.AND LookUpWord(| 00001c60 29 20 3d 20 56 41 4c 4f 46 0a 24 28 20 4c 45 54 |) = VALOF.$( LET| 00001c70 20 68 61 73 68 76 61 6c 20 3d 20 56 41 4c 4f 46 | hashval = VALOF| 00001c80 0a 20 20 20 24 28 20 4c 45 54 20 72 65 73 20 3d |. $( LET res =| 00001c90 20 77 6f 72 64 76 25 30 0a 20 20 20 20 20 20 46 | wordv%0. F| 00001ca0 4f 52 20 69 20 3d 20 31 20 54 4f 20 72 65 73 20 |OR i = 1 TO res | 00001cb0 44 4f 0a 09 72 65 73 20 3a 3d 20 28 72 65 73 2a |DO..res := (res*| 00001cc0 31 33 20 2b 20 43 61 70 69 74 61 6c 43 68 28 77 |13 + CapitalCh(w| 00001cd0 6f 72 64 76 25 69 29 29 20 26 20 23 58 37 46 46 |ordv%i)) & #X7FF| 00001ce0 46 0a 0a 20 20 20 20 20 20 52 45 53 55 4c 54 49 |F.. RESULTI| 00001cf0 53 20 72 65 73 20 52 45 4d 20 6e 61 6d 65 74 61 |S res REM nameta| 00001d00 62 6c 65 73 69 7a 65 0a 20 20 20 24 29 0a 0a 20 |blesize. $).. | 00001d10 20 20 4c 45 54 20 43 53 74 72 69 6e 67 28 73 31 | LET CString(s1| 00001d20 2c 20 73 32 29 20 3d 20 56 41 4c 4f 46 0a 20 20 |, s2) = VALOF. | 00001d30 20 24 28 20 4c 45 54 20 6c 65 6e 20 3d 20 73 31 | $( LET len = s1| 00001d40 25 30 0a 20 20 20 20 20 20 49 46 20 6c 65 6e 7e |%0. IF len~| 00001d50 3d 73 32 25 30 20 54 48 45 4e 20 52 45 53 55 4c |=s2%0 THEN RESUL| 00001d60 54 49 53 20 46 41 4c 53 45 0a 0a 20 20 20 20 20 |TIS FALSE.. | 00001d70 20 46 4f 52 20 6a 20 3d 20 31 20 54 4f 20 6c 65 | FOR j = 1 TO le| 00001d80 6e 20 44 4f 0a 09 54 45 53 54 20 65 71 75 61 74 |n DO..TEST equat| 00001d90 65 43 61 73 65 73 0a 09 20 20 54 48 45 4e 20 49 |eCases.. THEN I| 00001da0 46 20 43 61 70 69 74 61 6c 43 68 28 73 31 25 6a |F CapitalCh(s1%j| 00001db0 29 7e 3d 43 61 70 69 74 61 6c 43 68 28 73 32 25 |)~=CapitalCh(s2%| 00001dc0 6a 29 0a 09 20 20 20 20 54 48 45 4e 20 52 45 53 |j).. THEN RES| 00001dd0 55 4c 54 49 53 20 46 41 4c 53 45 0a 09 20 20 45 |ULTIS FALSE.. E| 00001de0 4c 53 45 20 49 46 20 73 31 25 6a 7e 3d 73 32 25 |LSE IF s1%j~=s2%| 00001df0 6a 0a 09 20 20 20 20 54 48 45 4e 20 52 45 53 55 |j.. THEN RESU| 00001e00 4c 54 49 53 20 46 41 4c 53 45 0a 0a 20 20 20 20 |LTIS FALSE.. | 00001e10 20 20 52 45 53 55 4c 54 49 53 20 54 52 55 45 0a | RESULTIS TRUE.| 00001e20 20 20 20 24 29 0a 20 20 20 4c 45 54 20 69 20 3d | $). LET i =| 00001e30 20 30 0a 20 20 20 77 6f 72 64 4e 6f 64 65 20 3a | 0. wordNode :| 00001e40 3d 20 6e 61 6d 65 74 61 62 6c 65 21 68 61 73 68 |= nametable!hash| 00001e50 76 61 6c 0a 0a 20 20 20 57 48 49 4c 45 20 77 6f |val.. WHILE wo| 00001e60 72 64 4e 6f 64 65 7e 3d 30 20 26 20 7e 43 53 74 |rdNode~=0 & ~CSt| 00001e70 72 69 6e 67 28 77 6f 72 64 4e 6f 64 65 2b 32 2c |ring(wordNode+2,| 00001e80 20 77 6f 72 64 76 29 20 44 4f 0a 20 20 20 20 20 | wordv) DO. | 00001e90 77 6f 72 64 4e 6f 64 65 20 3a 3d 20 68 32 21 77 |wordNode := h2!w| 00001ea0 6f 72 64 4e 6f 64 65 0a 0a 20 20 20 49 46 20 77 |ordNode.. IF w| 00001eb0 6f 72 64 4e 6f 64 65 3d 30 20 54 48 45 4e 0a 20 |ordNode=0 THEN. | 00001ec0 20 20 24 28 20 4c 45 54 20 73 69 7a 65 20 3d 20 | $( LET size = | 00001ed0 77 6f 72 64 76 25 30 20 2f 20 42 79 74 65 73 50 |wordv%0 / BytesP| 00001ee0 65 72 57 6f 72 64 0a 0a 20 20 20 20 20 20 77 6f |erWord.. wo| 00001ef0 72 64 4e 6f 64 65 20 3a 3d 20 67 65 74 62 6c 6b |rdNode := getblk| 00001f00 28 73 69 7a 65 2b 33 29 0a 20 20 20 20 20 20 77 |(size+3). w| 00001f10 6f 72 64 4e 6f 64 65 21 30 20 3a 3d 20 73 2e 6e |ordNode!0 := s.n| 00001f20 61 6d 65 0a 20 20 20 20 20 20 77 6f 72 64 4e 6f |ame. wordNo| 00001f30 64 65 21 31 20 3a 3d 20 6e 61 6d 65 74 61 62 6c |de!1 := nametabl| 00001f40 65 21 68 61 73 68 76 61 6c 0a 0a 20 20 20 20 20 |e!hashval.. | 00001f50 20 46 4f 52 20 69 20 3d 20 30 20 54 4f 20 73 69 | FOR i = 0 TO si| 00001f60 7a 65 20 44 4f 20 77 6f 72 64 4e 6f 64 65 21 28 |ze DO wordNode!(| 00001f70 69 2b 32 29 20 3a 3d 20 77 6f 72 64 76 21 69 0a |i+2) := wordv!i.| 00001f80 20 20 20 20 20 20 6e 61 6d 65 74 61 62 6c 65 21 | nametable!| 00001f90 68 61 73 68 76 61 6c 20 3a 3d 20 77 6f 72 64 4e |hashval := wordN| 00001fa0 6f 64 65 20 24 29 0a 20 20 20 52 45 53 55 4c 54 |ode $). RESULT| 00001fb0 49 53 20 68 31 21 77 6f 72 64 4e 6f 64 65 0a 24 |IS h1!wordNode.$| 00001fc0 29 0a 0a 41 4e 44 20 63 6f 6e 64 69 74 69 6f 6e |)..AND condition| 00001fd0 61 6c 2e 63 6f 6d 70 69 6c 61 74 69 6f 6e 28 73 |al.compilation(s| 00001fe0 74 61 72 74 63 6f 6e 64 2c 20 74 61 67 70 74 72 |tartcond, tagptr| 00001ff0 2c 20 69 6e 76 65 72 73 65 29 20 42 45 0a 20 20 |, inverse) BE. | 00002000 2f 2f 0a 20 20 2f 2f 20 43 61 6c 6c 65 64 20 61 |//. // Called a| 00002010 66 74 65 72 20 24 3c 74 61 67 20 6f 72 20 24 3e |fter $<tag or $>| 00002020 74 61 67 20 68 61 73 20 62 65 65 6e 20 72 65 63 |tag has been rec| 00002030 6f 67 6e 69 73 65 64 2e 0a 20 20 2f 2f 0a 20 20 |ognised.. //. | 00002040 2f 2f 20 20 73 74 61 72 74 63 6f 6e 64 20 09 74 |// startcond .t| 00002050 72 75 65 20 66 6f 72 20 24 3c 2c 20 66 61 6c 73 |rue for $<, fals| 00002060 65 20 66 6f 72 20 24 3e 0a 20 20 2f 2f 20 20 74 |e for $>. // t| 00002070 61 67 70 74 72 09 09 70 6f 69 6e 74 65 72 20 74 |agptr..pointer t| 00002080 6f 20 74 61 67 20 6f 62 6a 65 63 74 0a 20 20 2f |o tag object. /| 00002090 2f 20 20 69 6e 76 65 72 73 65 09 09 74 72 75 65 |/ inverse..true| 000020a0 20 69 66 20 74 61 67 20 77 61 73 20 66 6f 6c 6c | if tag was foll| 000020b0 6f 77 65 64 20 62 79 20 27 2e 0a 20 20 2f 2f 0a |owed by '.. //.| 000020c0 20 20 20 54 45 53 54 20 73 74 61 72 74 63 6f 6e | TEST startcon| 000020d0 64 20 54 48 45 4e 0a 20 20 20 20 20 20 54 45 53 |d THEN. TES| 000020e0 54 20 74 61 67 2e 76 61 6c 75 65 21 74 61 67 70 |T tag.value!tagp| 000020f0 74 72 7e 3d 69 6e 76 65 72 73 65 20 54 48 45 4e |tr~=inverse THEN| 00002100 20 24 28 0a 09 20 2f 2f 20 44 6f 20 6e 6f 74 20 | $(.. // Do not | 00002110 73 6b 69 70 3a 20 61 64 64 20 6e 65 77 20 69 74 |skip: add new it| 00002120 65 6d 20 74 6f 20 63 63 20 73 74 61 63 6b 2e 0a |em to cc stack..| 00002130 09 20 4c 45 54 20 73 20 3d 20 67 65 74 2e 63 63 |. LET s = get.cc| 00002140 73 74 61 63 6b 2e 69 74 65 6d 28 29 0a 09 20 63 |stack.item().. c| 00002150 63 2e 6c 69 6e 6b 21 73 20 3a 3d 20 63 63 73 74 |c.link!s := ccst| 00002160 61 63 6b 0a 09 20 63 63 73 74 61 63 6b 20 3a 3d |ack.. ccstack :=| 00002170 20 73 0a 09 20 63 63 2e 69 6e 76 65 72 73 65 21 | s.. cc.inverse!| 00002180 73 20 3a 3d 20 69 6e 76 65 72 73 65 0a 09 20 63 |s := inverse.. c| 00002190 63 2e 74 61 67 70 74 72 21 73 20 3a 3d 20 74 61 |c.tagptr!s := ta| 000021a0 67 70 74 72 20 24 29 0a 0a 20 20 20 20 20 20 45 |gptr $).. E| 000021b0 4c 53 45 20 24 28 20 2f 2f 20 53 6b 69 70 20 75 |LSE $( // Skip u| 000021c0 6e 74 69 6c 20 61 20 6d 61 74 63 68 69 6e 67 20 |ntil a matching | 000021d0 24 3e 74 61 67 20 69 73 20 66 6f 75 6e 64 2e 09 |$>tag is found..| 000021e0 54 68 65 20 71 75 6f 74 65 73 20 6d 75 73 74 20 |The quotes must | 000021f0 6d 61 74 63 68 0a 09 20 4c 45 54 20 69 6e 76 32 |match.. LET inv2| 00002200 20 3d 20 46 41 4c 53 45 0a 09 20 24 28 20 49 46 | = FALSE.. $( IF| 00002210 20 63 68 3d 45 6e 64 53 74 72 65 61 6d 43 68 20 | ch=EndStreamCh | 00002220 54 48 45 4e 20 53 79 6e 52 65 70 6f 72 74 28 33 |THEN SynReport(3| 00002230 29 0a 0a 09 20 20 20 20 49 46 20 63 68 3d 27 24 |)... IF ch='$| 00002240 27 20 54 48 45 4e 20 24 28 0a 09 20 20 20 20 20 |' THEN $(.. | 00002250 20 20 52 43 68 28 29 0a 09 20 20 20 20 20 20 20 | RCh().. | 00002260 49 46 20 63 68 3d 27 3e 27 20 54 48 45 4e 20 24 |IF ch='>' THEN $| 00002270 28 0a 09 09 20 20 4c 45 54 20 63 2c 20 64 20 3d |(... LET c, d =| 00002280 20 3f 2c 20 3f 0a 09 09 20 20 52 43 68 28 29 0a | ?, ?... RCh().| 00002290 09 09 20 20 64 20 3a 3d 20 63 68 0a 09 09 20 20 |.. d := ch... | 000022a0 63 20 3a 3d 20 43 61 70 69 74 61 6c 43 68 28 63 |c := CapitalCh(c| 000022b0 68 29 0a 0a 09 09 20 20 49 46 20 27 41 27 3c 3d |h).... IF 'A'<=| 000022c0 63 3c 3d 27 5a 27 20 7c 20 27 30 27 3c 3d 63 3c |c<='Z' | '0'<=c<| 000022d0 3d 27 39 27 20 54 48 45 4e 20 24 28 0a 09 09 20 |='9' THEN $(... | 000022e0 20 20 20 20 52 43 68 28 29 0a 09 09 20 20 20 20 | RCh()... | 000022f0 20 52 64 54 61 67 28 64 29 0a 09 09 20 20 20 20 | RdTag(d)... | 00002300 20 49 46 20 43 6f 6d 70 53 74 72 69 6e 67 28 77 | IF CompString(w| 00002310 6f 72 64 76 2c 20 74 61 67 2e 6e 61 6d 65 2b 74 |ordv, tag.name+t| 00002320 61 67 70 74 72 29 3d 30 20 54 48 45 4e 20 42 52 |agptr)=0 THEN BR| 00002330 45 41 4b 20 24 29 0a 09 09 20 20 4c 4f 4f 50 20 |EAK $)... LOOP | 00002340 24 29 0a 09 20 20 20 20 20 20 20 4c 4f 4f 50 20 |$).. LOOP | 00002350 24 29 0a 09 20 20 20 20 52 43 68 28 29 0a 09 20 |$).. RCh().. | 00002360 24 29 20 52 45 50 45 41 54 0a 0a 09 20 20 20 20 |$) REPEAT... | 00002370 20 20 2f 2f 20 53 6b 69 70 20 63 6f 6d 70 6c 65 | // Skip comple| 00002380 74 65 3a 20 63 68 65 63 6b 20 74 68 61 74 20 71 |te: check that q| 00002390 75 6f 74 65 73 20 6d 61 74 63 68 0a 09 20 49 46 |uotes match.. IF| 000023a0 20 63 68 3d 27 2a 27 27 20 54 48 45 4e 20 24 28 | ch='*'' THEN $(| 000023b0 0a 09 20 20 20 20 69 6e 76 32 20 3a 3d 20 54 52 |.. inv2 := TR| 000023c0 55 45 0a 09 20 20 20 20 52 43 68 28 29 20 24 29 |UE.. RCh() $)| 000023d0 0a 0a 09 20 49 46 20 69 6e 76 32 7e 3d 69 6e 76 |... IF inv2~=inv| 000023e0 65 72 73 65 20 54 48 45 4e 20 53 79 6e 52 65 70 |erse THEN SynRep| 000023f0 6f 72 74 28 34 29 20 24 29 0a 0a 20 20 20 45 4c |ort(4) $).. EL| 00002400 53 45 20 24 28 20 2f 2f 20 24 3e 74 61 67 3a 20 |SE $( // $>tag: | 00002410 20 63 68 65 63 6b 20 74 68 61 74 20 69 74 20 6d | check that it m| 00002420 61 74 63 68 65 73 20 74 68 65 20 6c 61 73 74 20 |atches the last | 00002430 24 3c 74 61 67 2e 0a 20 20 20 20 20 20 49 46 20 |$<tag.. IF | 00002440 63 63 73 74 61 63 6b 7e 3d 30 20 54 48 45 4e 0a |ccstack~=0 THEN.| 00002450 09 20 54 45 53 54 20 74 61 67 70 74 72 3d 63 63 |. TEST tagptr=cc| 00002460 2e 74 61 67 70 74 72 21 63 63 73 74 61 63 6b 20 |.tagptr!ccstack | 00002470 54 48 45 4e 20 24 28 0a 09 20 20 20 2f 2f 20 50 |THEN $(.. // P| 00002480 72 6f 70 65 72 20 6d 61 74 63 68 3a 20 75 6e 73 |roper match: uns| 00002490 74 61 63 6b 20 69 74 65 6d 20 61 6e 64 20 63 68 |tack item and ch| 000024a0 65 63 6b 20 71 75 6f 74 65 73 20 6d 61 74 63 68 |eck quotes match| 000024b0 2e 0a 09 20 20 20 20 4c 45 54 20 69 6e 76 31 20 |... LET inv1 | 000024c0 3d 20 63 63 2e 69 6e 76 65 72 73 65 21 63 63 73 |= cc.inverse!ccs| 000024d0 74 61 63 6b 0a 09 20 20 20 20 4c 45 54 20 6e 65 |tack.. LET ne| 000024e0 78 74 20 3d 20 63 63 2e 6c 69 6e 6b 21 63 63 73 |xt = cc.link!ccs| 000024f0 74 61 63 6b 0a 09 20 20 20 20 63 63 2e 6c 69 6e |tack.. cc.lin| 00002500 6b 21 63 63 73 74 61 63 6b 20 3a 3d 20 66 72 65 |k!ccstack := fre| 00002510 65 2e 63 63 73 74 61 63 6b 2e 63 68 61 69 6e 0a |e.ccstack.chain.| 00002520 09 20 20 20 20 66 72 65 65 2e 63 63 73 74 61 63 |. free.ccstac| 00002530 6b 2e 63 68 61 69 6e 20 3a 3d 20 63 63 73 74 61 |k.chain := ccsta| 00002540 63 6b 0a 09 20 20 20 20 63 63 73 74 61 63 6b 20 |ck.. ccstack | 00002550 3a 3d 20 6e 65 78 74 0a 0a 09 20 20 20 20 49 46 |:= next... IF| 00002560 20 69 6e 76 31 7e 3d 69 6e 76 65 72 73 65 20 54 | inv1~=inverse T| 00002570 48 45 4e 20 53 79 6e 52 65 70 6f 72 74 28 34 29 |HEN SynReport(4)| 00002580 0a 09 20 20 20 20 52 45 54 55 52 4e 20 24 29 0a |.. RETURN $).| 00002590 09 20 45 4c 53 45 20 24 28 20 2f 2f 20 54 61 67 |. ELSE $( // Tag| 000025a0 73 20 64 6f 20 6e 6f 74 20 6d 61 74 63 68 3a 20 |s do not match: | 000025b0 69 66 20 74 68 65 20 63 75 72 72 65 6e 74 20 74 |if the current t| 000025c0 61 67 20 6f 63 63 75 72 73 0a 09 09 20 2f 2f 20 |ag occurs... // | 000025d0 62 65 6c 6f 77 20 6f 6e 20 74 68 65 20 73 74 61 |below on the sta| 000025e0 63 6b 2c 20 72 65 6d 6f 76 65 20 74 68 6f 73 65 |ck, remove those| 000025f0 20 69 74 65 6d 73 20 61 62 6f 76 65 0a 09 09 20 | items above... | 00002600 2f 2f 20 69 74 2e 0a 09 20 20 20 20 4c 45 54 20 |// it... LET | 00002610 6d 20 3d 20 63 63 73 74 61 63 6b 0a 0a 09 20 20 |m = ccstack... | 00002620 20 20 57 48 49 4c 45 20 6d 7e 3d 30 20 26 20 63 | WHILE m~=0 & c| 00002630 63 2e 74 61 67 70 74 72 21 6d 7e 3d 74 61 67 70 |c.tagptr!m~=tagp| 00002640 74 72 20 44 4f 0a 09 09 20 20 6d 20 3a 3d 20 63 |tr DO... m := c| 00002650 63 2e 6c 69 6e 6b 21 6d 0a 0a 09 20 20 20 20 49 |c.link!m... I| 00002660 46 20 6d 7e 3d 30 20 54 48 45 4e 20 24 28 0a 09 |F m~=0 THEN $(..| 00002670 20 20 20 20 20 20 20 4c 45 54 20 6e 65 78 74 20 | LET next | 00002680 3d 20 63 63 2e 6c 69 6e 6b 21 6d 0a 09 20 20 20 |= cc.link!m.. | 00002690 20 20 20 20 63 63 2e 6c 69 6e 6b 21 6d 20 3a 3d | cc.link!m :=| 000026a0 20 66 72 65 65 2e 63 63 73 74 61 63 6b 2e 63 68 | free.ccstack.ch| 000026b0 61 69 6e 0a 09 20 20 20 20 20 20 20 66 72 65 65 |ain.. free| 000026c0 2e 63 63 73 74 61 63 6b 2e 63 68 61 69 6e 20 3a |.ccstack.chain :| 000026d0 3d 20 63 63 73 74 61 63 6b 0a 09 20 20 20 20 20 |= ccstack.. | 000026e0 20 20 63 63 73 74 61 63 6b 20 3a 3d 20 6e 65 78 | ccstack := nex| 000026f0 74 20 24 29 20 24 29 0a 0a 20 20 20 20 20 20 53 |t $) $).. S| 00002700 79 6e 52 65 70 6f 72 74 28 35 29 20 24 29 0a 0a |ynReport(5) $)..| 00002710 41 4e 44 20 67 65 74 2e 63 63 73 74 61 63 6b 2e |AND get.ccstack.| 00002720 69 74 65 6d 28 29 20 3d 20 56 41 4c 4f 46 0a 24 |item() = VALOF.$| 00002730 28 20 4c 45 54 20 63 20 3d 20 66 72 65 65 2e 63 |( LET c = free.c| 00002740 63 73 74 61 63 6b 2e 63 68 61 69 6e 0a 20 20 20 |cstack.chain. | 00002750 49 46 20 63 3d 30 20 54 48 45 4e 20 52 45 53 55 |IF c=0 THEN RESU| 00002760 4c 54 49 53 20 47 65 74 42 6c 6b 28 63 63 2e 73 |LTIS GetBlk(cc.s| 00002770 69 7a 65 29 0a 0a 20 20 20 66 72 65 65 2e 63 63 |ize).. free.cc| 00002780 73 74 61 63 6b 2e 63 68 61 69 6e 20 3a 3d 20 63 |stack.chain := c| 00002790 63 2e 6c 69 6e 6b 21 63 0a 20 20 20 52 45 53 55 |c.link!c. RESU| 000027a0 4c 54 49 53 20 63 0a 24 29 0a 0a 41 4e 44 20 44 |LTIS c.$)..AND D| 000027b0 65 63 6c 53 79 73 57 6f 72 64 73 28 29 20 42 45 |eclSysWords() BE| 000027c0 0a 24 28 20 4c 45 54 20 62 61 64 20 3d 20 54 41 |.$( LET bad = TA| 000027d0 42 4c 45 20 73 2e 62 61 64 2c 20 73 2e 62 61 64 |BLE s.bad, s.bad| 000027e0 0a 0a 20 20 20 73 79 6d 62 20 3a 3d 0a 20 20 20 |.. symb :=. | 000027f0 20 20 54 41 42 4c 45 0a 20 20 20 20 20 20 20 73 | TABLE. s| 00002800 2e 61 6e 64 2c 73 2e 61 62 73 2c 0a 20 20 20 20 |.and,s.abs,. | 00002810 20 20 20 73 2e 62 65 2c 73 2e 62 72 65 61 6b 2c | s.be,s.break,| 00002820 73 2e 62 79 2c 0a 20 20 20 20 20 20 20 73 2e 63 |s.by,. s.c| 00002830 61 73 65 2c 0a 20 20 20 20 20 20 20 73 2e 64 6f |ase,. s.do| 00002840 2c 73 2e 64 65 66 61 75 6c 74 2c 0a 20 20 20 20 |,s.default,. | 00002850 20 20 20 73 2e 65 71 2c 73 2e 65 71 76 2c 73 2e | s.eq,s.eqv,s.| 00002860 6f 72 2c 73 2e 65 6e 64 63 61 73 65 2c 0a 20 20 |or,s.endcase,. | 00002870 20 20 20 20 20 73 2e 66 61 6c 73 65 2c 73 2e 66 | s.false,s.f| 00002880 6f 72 2c 73 2e 66 69 6e 69 73 68 2c 0a 20 20 20 |or,s.finish,. | 00002890 20 20 20 20 73 2e 67 6f 74 6f 2c 73 2e 67 65 2c | s.goto,s.ge,| 000028a0 73 2e 67 72 2c 73 2e 67 6c 6f 62 61 6c 2c 73 2e |s.gr,s.global,s.| 000028b0 67 65 74 2c 0a 20 20 20 20 20 20 20 73 2e 69 66 |get,. s.if| 000028c0 2c 73 2e 69 6e 74 6f 2c 0a 20 20 20 20 20 20 20 |,s.into,. | 000028d0 73 2e 6c 65 74 2c 73 2e 6c 76 2c 73 2e 6c 65 2c |s.let,s.lv,s.le,| 000028e0 73 2e 6c 73 2c 73 2e 6c 6f 67 6f 72 2c 0a 20 20 |s.ls,s.logor,. | 000028f0 20 20 20 20 20 73 2e 6c 6f 67 61 6e 64 2c 73 2e | s.logand,s.| 00002900 6c 6f 6f 70 2c 73 2e 6c 73 68 69 66 74 2c 0a 20 |loop,s.lshift,. | 00002910 20 20 20 20 20 20 73 2e 6d 61 6e 69 66 65 73 74 | s.manifest| 00002920 2c 0a 20 20 20 20 20 20 20 73 2e 6e 65 2c 73 2e |,. s.ne,s.| 00002930 6e 6f 74 2c 73 2e 6e 65 71 76 2c 73 2e 6e 65 65 |not,s.neqv,s.nee| 00002940 64 73 2c 0a 20 20 20 20 20 20 20 73 2e 6f 72 2c |ds,. s.or,| 00002950 0a 20 20 20 20 20 20 20 73 2e 72 65 73 75 6c 74 |. s.result| 00002960 69 73 2c 73 2e 72 65 74 75 72 6e 2c 73 2e 72 65 |is,s.return,s.re| 00002970 6d 2c 73 2e 72 73 68 69 66 74 2c 73 2e 72 76 2c |m,s.rshift,s.rv,| 00002980 0a 20 20 20 20 20 20 20 73 2e 72 65 70 65 61 74 |. s.repeat| 00002990 2c 73 2e 72 65 70 65 61 74 77 68 69 6c 65 2c 73 |,s.repeatwhile,s| 000029a0 2e 72 65 70 65 61 74 75 6e 74 69 6c 2c 0a 20 20 |.repeatuntil,. | 000029b0 20 20 20 20 20 73 2e 73 77 69 74 63 68 6f 6e 2c | s.switchon,| 000029c0 73 2e 73 74 61 74 69 63 2c 73 2e 73 65 63 74 69 |s.static,s.secti| 000029d0 6f 6e 2c 0a 20 20 20 20 20 20 20 73 2e 74 6f 2c |on,. s.to,| 000029e0 73 2e 74 65 73 74 2c 73 2e 74 72 75 65 2c 73 2e |s.test,s.true,s.| 000029f0 64 6f 2c 73 2e 74 61 62 6c 65 2c 0a 20 20 20 20 |do,s.table,. | 00002a00 20 20 20 73 2e 75 6e 74 69 6c 2c 73 2e 75 6e 6c | s.until,s.unl| 00002a10 65 73 73 2c 0a 20 20 20 20 20 20 20 73 2e 76 65 |ess,. s.ve| 00002a20 63 2c 73 2e 76 61 6c 6f 66 2c 0a 20 20 20 20 20 |c,s.valof,. | 00002a30 20 20 73 2e 77 68 69 6c 65 2c 0a 20 20 20 20 20 | s.while,. | 00002a40 20 20 30 0a 0a 20 20 20 44 28 20 22 41 4e 44 20 | 0.. D( "AND | 00002a50 41 42 53 20 2a 0a 20 20 20 20 20 2a 42 45 20 42 |ABS *. *BE B| 00002a60 52 45 41 4b 20 42 59 20 2a 0a 20 20 20 20 20 2a |REAK BY *. *| 00002a70 43 41 53 45 20 2a 0a 20 20 20 20 20 2a 44 4f 20 |CASE *. *DO | 00002a80 44 45 46 41 55 4c 54 20 2a 0a 20 20 20 20 20 2a |DEFAULT *. *| 00002a90 45 51 20 45 51 56 20 45 4c 53 45 20 45 4e 44 43 |EQ EQV ELSE ENDC| 00002aa0 41 53 45 20 2a 0a 20 20 20 20 20 2a 46 41 4c 53 |ASE *. *FALS| 00002ab0 45 20 46 4f 52 20 46 49 4e 49 53 48 20 2a 0a 20 |E FOR FINISH *. | 00002ac0 20 20 20 20 2a 47 4f 54 4f 20 47 45 20 47 52 20 | *GOTO GE GR | 00002ad0 47 4c 4f 42 41 4c 20 47 45 54 20 2a 0a 20 20 20 |GLOBAL GET *. | 00002ae0 20 20 2a 49 46 20 49 4e 54 4f 20 2a 0a 20 20 20 | *IF INTO *. | 00002af0 20 20 2a 4c 45 54 20 4c 56 20 4c 45 20 4c 53 20 | *LET LV LE LS | 00002b00 4c 4f 47 4f 52 20 4c 4f 47 41 4e 44 20 4c 4f 4f |LOGOR LOGAND LOO| 00002b10 50 20 4c 53 48 49 46 54 22 29 0a 0a 20 20 20 44 |P LSHIFT").. D| 00002b20 28 22 4d 41 4e 49 46 45 53 54 20 2a 0a 20 20 20 |("MANIFEST *. | 00002b30 20 20 2a 4e 45 20 4e 4f 54 20 4e 45 51 56 20 4e | *NE NOT NEQV N| 00002b40 45 45 44 53 20 2a 0a 20 20 20 20 20 2a 4f 52 20 |EEDS *. *OR | 00002b50 2a 0a 20 20 20 20 20 2a 52 45 53 55 4c 54 49 53 |*. *RESULTIS| 00002b60 20 52 45 54 55 52 4e 20 52 45 4d 20 52 53 48 49 | RETURN REM RSHI| 00002b70 46 54 20 52 56 20 2a 0a 20 20 20 20 20 2a 52 45 |FT RV *. *RE| 00002b80 50 45 41 54 20 52 45 50 45 41 54 57 48 49 4c 45 |PEAT REPEATWHILE| 00002b90 20 52 45 50 45 41 54 55 4e 54 49 4c 20 2a 0a 20 | REPEATUNTIL *. | 00002ba0 20 20 20 20 2a 53 57 49 54 43 48 4f 4e 20 53 54 | *SWITCHON ST| 00002bb0 41 54 49 43 20 53 45 43 54 49 4f 4e 20 2a 0a 20 |ATIC SECTION *. | 00002bc0 20 20 20 20 2a 54 4f 20 54 45 53 54 20 54 52 55 | *TO TEST TRU| 00002bd0 45 20 54 48 45 4e 20 54 41 42 4c 45 20 2a 0a 20 |E THEN TABLE *. | 00002be0 20 20 20 20 2a 55 4e 54 49 4c 20 55 4e 4c 45 53 | *UNTIL UNLES| 00002bf0 53 20 2a 0a 20 20 20 20 20 2a 56 45 43 20 56 41 |S *. *VEC VA| 00002c00 4c 4f 46 20 2a 0a 20 20 20 20 20 2a 57 48 49 4c |LOF *. *WHIL| 00002c10 45 20 2a 0a 20 20 20 20 20 2a 24 22 29 0a 0a 20 |E *. *$").. | 00002c20 20 20 6e 75 6c 6c 74 61 67 20 3a 3d 20 77 6f 72 | nulltag := wor| 00002c30 64 4e 6f 64 65 0a 0a 20 20 20 49 46 20 6c 69 73 |dNode.. IF lis| 00002c40 70 45 78 74 65 6e 73 69 6f 6e 73 20 54 48 45 4e |pExtensions THEN| 00002c50 20 7b 0a 20 20 20 20 20 20 73 79 6d 62 20 3a 3d | {. symb :=| 00002c60 20 28 54 41 42 4c 45 20 73 2e 6e 69 6c 2c 20 73 | (TABLE s.nil, s| 00002c70 2e 63 61 72 2c 20 73 2e 63 64 72 2c 20 73 2e 76 |.car, s.cdr, s.v| 00002c80 63 61 72 2c 20 73 2e 76 63 64 72 2c 0a 09 09 20 |car, s.vcdr,... | 00002c90 20 20 20 20 73 2e 6c 6c 65 2c 73 2e 6c 67 65 2c | s.lle,s.lge,| 00002ca0 73 2e 6c 67 72 2c 73 2e 6c 6c 73 29 3b 0a 20 20 |s.lgr,s.lls);. | 00002cb0 20 20 20 20 44 28 22 4e 49 4c 20 43 41 52 20 43 | D("NIL CAR C| 00002cc0 44 52 20 56 43 41 52 20 56 43 44 52 20 4c 4c 45 |DR VCAR VCDR LLE| 00002cd0 20 4c 47 45 20 4c 47 52 20 4c 4c 53 22 29 20 7d | LGE LGR LLS") }| 00002ce0 0a 0a 20 20 20 2f 2f 20 49 66 20 74 68 65 20 65 |.. // If the e| 00002cf0 78 74 65 6e 73 69 6f 6e 20 6c 65 76 65 6c 20 69 |xtension level i| 00002d00 73 20 73 75 69 74 61 62 6c 65 2c 20 64 65 63 6c |s suitable, decl| 00002d10 61 72 65 20 74 68 65 0a 20 20 20 2f 2f 20 73 79 |are the. // sy| 00002d20 6d 62 6f 6c 73 20 53 4c 43 54 20 61 6e 64 20 4f |mbols SLCT and O| 00002d30 46 20 61 70 70 72 6f 70 72 69 61 74 65 6c 79 2e |F appropriately.| 00002d40 20 20 4f 74 68 65 72 77 69 73 65 2c 0a 20 20 20 | Otherwise,. | 00002d50 2f 2f 20 64 65 63 6c 61 72 65 20 74 68 65 6d 20 |// declare them | 00002d60 61 73 20 27 62 61 64 27 2c 20 73 6f 20 74 68 61 |as 'bad', so tha| 00002d70 74 20 74 68 65 79 20 61 72 65 20 73 74 69 6c 6c |t they are still| 00002d80 0a 20 20 20 2f 2f 20 72 65 73 65 72 76 65 64 20 |. // reserved | 00002d90 77 6f 72 64 73 2e 0a 0a 20 20 20 73 79 6d 62 20 |words... symb | 00002da0 3a 3d 20 65 78 74 65 6e 73 69 6f 6e 2e 6c 65 76 |:= extension.lev| 00002db0 65 6c 3e 3d 33 20 2d 3e 20 28 54 41 42 4c 45 20 |el>=3 -> (TABLE | 00002dc0 73 2e 73 6c 63 74 2c 73 2e 6f 66 2c 73 2e 66 69 |s.slct,s.of,s.fi| 00002dd0 78 2c 73 2e 66 6c 6f 61 74 29 2c 62 61 64 0a 20 |x,s.float),bad. | 00002de0 20 20 44 28 22 53 4c 43 54 20 4f 46 20 46 49 58 | D("SLCT OF FIX| 00002df0 20 46 4c 4f 41 54 22 29 0a 0a 20 20 20 2f 2f 20 | FLOAT").. // | 00002e00 45 58 54 45 52 4e 41 4c 20 69 73 20 64 65 63 6c |EXTERNAL is decl| 00002e10 61 72 65 64 20 73 69 6d 69 6c 61 72 6c 79 0a 0a |ared similarly..| 00002e20 20 20 20 73 79 6d 62 20 3a 3d 20 65 78 74 65 6e | symb := exten| 00002e30 73 69 6f 6e 2e 6c 65 76 65 6c 3e 3d 34 20 2d 3e |sion.level>=4 ->| 00002e40 20 28 54 41 42 4c 45 20 73 2e 65 78 74 65 72 6e | (TABLE s.extern| 00002e50 61 6c 29 2c 20 62 61 64 0a 20 20 20 44 28 22 45 |al), bad. D("E| 00002e60 58 54 45 52 4e 41 4c 22 29 0a 24 29 0a 0a 41 4e |XTERNAL").$)..AN| 00002e70 44 20 44 28 77 6f 72 64 73 29 20 42 45 0a 24 28 |D D(words) BE.$(| 00002e80 20 4c 45 54 20 69 20 3d 20 31 0a 20 20 20 4c 45 | LET i = 1. LE| 00002e90 54 20 6c 65 6e 67 74 68 20 3d 20 30 0a 0a 20 20 |T length = 0.. | 00002ea0 20 24 28 20 4c 45 54 20 63 68 20 3d 20 69 3e 77 | $( LET ch = i>w| 00002eb0 6f 72 64 73 25 30 20 2d 3e 20 27 20 27 2c 20 77 |ords%0 -> ' ', w| 00002ec0 6f 72 64 73 25 69 0a 0a 20 20 20 20 20 20 54 45 |ords%i.. TE| 00002ed0 53 54 20 63 68 3d 27 20 27 20 54 48 45 4e 20 24 |ST ch=' ' THEN $| 00002ee0 28 0a 09 20 49 46 20 6c 65 6e 67 74 68 3d 30 20 |(.. IF length=0 | 00002ef0 54 48 45 4e 20 52 45 54 55 52 4e 0a 09 20 77 6f |THEN RETURN.. wo| 00002f00 72 64 76 25 30 20 3a 3d 20 6c 65 6e 67 74 68 0a |rdv%0 := length.| 00002f10 09 20 4c 6f 6f 6b 55 70 57 6f 72 64 28 29 0a 09 |. LookUpWord()..| 00002f20 20 68 31 21 77 6f 72 64 4e 6f 64 65 20 3a 3d 21 | h1!wordNode :=!| 00002f30 73 79 6d 62 0a 09 20 73 79 6d 62 20 3a 3d 20 73 |symb.. symb := s| 00002f40 79 6d 62 2b 31 0a 09 20 6c 65 6e 67 74 68 20 3a |ymb+1.. length :| 00002f50 3d 20 30 20 24 29 0a 20 20 20 20 20 20 45 4c 53 |= 0 $). ELS| 00002f60 45 20 24 28 0a 09 20 6c 65 6e 67 74 68 20 3a 3d |E $(.. length :=| 00002f70 20 6c 65 6e 67 74 68 2b 31 0a 09 20 77 6f 72 64 | length+1.. word| 00002f80 76 25 6c 65 6e 67 74 68 20 3a 3d 20 63 68 20 24 |v%length := ch $| 00002f90 29 0a 20 20 20 20 20 20 69 20 3a 3d 20 69 2b 31 |). i := i+1| 00002fa0 0a 20 20 20 24 29 20 52 45 50 45 41 54 0a 24 29 |. $) REPEAT.$)| 00002fb0 0a 0a 0a 41 4e 44 20 52 43 68 28 29 20 42 45 0a |...AND RCh() BE.| 00002fc0 24 28 20 63 68 20 3a 3d 20 52 64 43 68 28 29 0a |$( ch := RdCh().| 00002fd0 0a 20 20 20 49 46 20 63 68 3d 27 2a 4e 27 20 7c |. IF ch='*N' || 00002fe0 20 63 68 3d 27 2a 50 27 20 7c 20 63 68 3d 27 2a | ch='*P' | ch='*| 00002ff0 43 27 20 54 48 45 4e 0a 20 20 20 24 28 20 63 68 |C' THEN. $( ch| 00003000 20 3a 3d 20 27 2a 4e 27 0a 20 20 20 20 20 20 6c | := '*N'. l| 00003010 69 6e 65 43 6f 75 6e 74 20 3a 3d 20 6c 69 6e 65 |ineCount := line| 00003020 43 6f 75 6e 74 2b 31 20 24 29 0a 20 20 20 63 68 |Count+1 $). ch| 00003030 63 6f 75 6e 74 20 3a 3d 20 63 68 63 6f 75 6e 74 |count := chcount| 00003040 2b 31 0a 20 20 20 63 68 62 75 66 21 28 63 68 63 |+1. chbuf!(chc| 00003050 6f 75 6e 74 20 26 20 36 33 29 20 3a 3d 20 63 68 |ount & 63) := ch| 00003060 0a 24 29 0a 0a 41 4e 44 20 52 64 54 61 67 28 63 |.$)..AND RdTag(c| 00003070 68 61 72 29 20 42 45 0a 24 28 20 4c 45 54 20 69 |har) BE.$( LET i| 00003080 20 3d 20 31 0a 20 20 20 77 6f 72 64 76 25 69 20 | = 1. wordv%i | 00003090 3a 3d 20 63 68 61 72 0a 0a 20 20 20 24 28 20 4c |:= char.. $( L| 000030a0 45 54 20 63 63 20 3d 20 43 61 70 69 74 61 6c 43 |ET cc = CapitalC| 000030b0 68 28 63 68 29 0a 0a 20 20 20 20 20 20 55 4e 4c |h(ch).. UNL| 000030c0 45 53 53 20 27 41 27 20 3c 3d 20 63 63 20 3c 3d |ESS 'A' <= cc <=| 000030d0 20 27 5a 27 20 7c 0a 09 20 20 20 20 20 27 30 27 | 'Z' |.. '0'| 000030e0 20 3c 3d 20 63 68 20 3c 3d 20 27 39 27 20 7c 20 | <= ch <= '9' | | 000030f0 63 68 3d 27 2e 27 20 7c 0a 09 20 20 20 20 20 28 |ch='.' |.. (| 00003100 63 68 3d 27 5f 27 20 26 20 65 78 74 65 6e 73 69 |ch='_' & extensi| 00003110 6f 6e 2e 6c 65 76 65 6c 3e 30 29 20 54 48 45 4e |on.level>0) THEN| 00003120 0a 09 42 52 45 41 4b 0a 0a 20 20 20 20 20 20 69 |..BREAK.. i| 00003130 20 3a 3d 20 69 2b 31 0a 20 20 20 20 20 20 77 6f | := i+1. wo| 00003140 72 64 76 25 69 20 3a 3d 20 63 68 0a 20 20 20 20 |rdv%i := ch. | 00003150 20 20 52 43 68 28 29 0a 20 20 20 24 29 20 52 45 | RCh(). $) RE| 00003160 50 45 41 54 0a 20 20 20 77 6f 72 64 76 25 30 20 |PEAT. wordv%0 | 00003170 3a 3d 20 69 0a 24 29 0a 0a 41 4e 44 20 50 65 72 |:= i.$)..AND Per| 00003180 66 6f 72 6d 47 65 74 28 29 20 42 45 0a 24 28 20 |formGet() BE.$( | 00003190 4c 45 54 20 73 20 3d 20 30 0a 20 20 20 4c 45 54 |LET s = 0. LET| 000031a0 20 74 20 3d 20 74 72 61 6e 73 63 68 61 72 73 0a | t = transchars.| 000031b0 0a 20 20 20 74 72 61 6e 73 63 68 61 72 73 20 3a |. transchars :| 000031c0 3d 20 46 41 4c 53 45 0a 20 20 20 4e 65 78 74 53 |= FALSE. NextS| 000031d0 79 6d 62 28 29 0a 20 20 20 74 72 61 6e 73 63 68 |ymb(). transch| 000031e0 61 72 73 20 3a 3d 20 74 0a 0a 20 20 20 49 46 20 |ars := t.. IF | 000031f0 73 79 6d 62 7e 3d 73 2e 73 74 72 69 6e 67 20 7c |symb~=s.string || 00003200 20 67 65 74 70 2b 32 3e 67 65 74 6d 61 78 20 54 | getp+2>getmax T| 00003210 48 45 4e 20 53 79 6e 52 65 70 6f 72 74 28 39 37 |HEN SynReport(97| 00003220 29 0a 0a 20 20 20 2f 2f 20 43 68 65 63 6b 20 66 |).. // Check f| 00003230 6f 72 20 47 45 54 20 22 22 20 66 69 72 73 74 20 |or GET "" first | 00003240 2d 20 74 68 65 20 6d 65 61 6e 69 6e 67 20 6f 66 |- the meaning of| 00003250 20 74 68 69 73 20 68 61 73 0a 20 20 20 2f 2f 20 | this has. // | 00003260 62 65 65 6e 20 63 68 61 6e 67 65 64 20 73 6f 20 |been changed so | 00003270 74 68 61 74 20 69 74 20 61 6c 77 61 79 73 20 72 |that it always r| 00003280 65 66 65 72 73 20 74 6f 20 74 68 65 20 73 6f 75 |efers to the sou| 00003290 72 63 65 0a 20 20 20 2f 2f 20 66 69 6c 65 2c 20 |rce. // file, | 000032a0 65 76 65 6e 20 69 66 20 61 20 48 44 52 20 70 61 |even if a HDR pa| 000032b0 72 61 6d 65 74 65 72 20 77 61 73 20 67 69 76 65 |rameter was give| 000032c0 6e 2e 0a 20 20 20 2f 2f 0a 20 20 20 2f 2f 20 4e |n.. //. // N| 000032d0 6f 74 65 20 74 68 61 74 20 47 45 54 20 22 22 20 |ote that GET "" | 000032e0 69 73 20 61 6e 20 65 78 74 65 6e 73 69 6f 6e 20 |is an extension | 000032f0 74 6f 20 73 74 61 6e 64 61 72 64 20 42 43 50 4c |to standard BCPL| 00003300 2e 0a 0a 20 20 20 54 45 53 54 20 77 6f 72 64 76 |... TEST wordv| 00003310 25 30 3d 30 20 54 48 45 4e 0a 20 20 20 20 20 20 |%0=0 THEN. | 00003320 49 46 20 65 78 74 65 6e 73 69 6f 6e 2e 6c 65 76 |IF extension.lev| 00003330 65 6c 3e 3d 32 20 54 48 45 4e 0a 09 20 73 20 3a |el>=2 THEN.. s :| 00003340 3d 20 4f 70 65 6e 28 66 72 6f 6d 66 69 6c 65 2c |= Open(fromfile,| 00003350 20 54 52 55 45 2c 20 46 41 4c 53 45 29 0a 20 20 | TRUE, FALSE). | 00003360 20 45 4c 53 45 20 54 45 53 54 20 68 65 61 64 65 | ELSE TEST heade| 00003370 72 73 3d 30 20 54 48 45 4e 20 24 28 0a 20 20 20 |rs=0 THEN $(. | 00003380 20 20 20 73 20 3a 3d 20 4f 70 65 6e 28 77 6f 72 | s := Open(wor| 00003390 64 76 2c 20 54 52 55 45 2c 20 46 41 4c 53 45 29 |dv, TRUE, FALSE)| 000033a0 0a 0a 20 20 20 20 20 20 49 46 20 73 3d 30 20 54 |.. IF s=0 T| 000033b0 48 45 4e 20 24 28 0a 09 20 4c 45 54 20 6c 65 6e |HEN $(.. LET len| 000033c0 77 20 3d 20 77 6f 72 64 76 25 30 0a 09 20 4c 45 |w = wordv%0.. LE| 000033d0 54 20 70 72 65 66 69 78 20 3d 20 22 24 2e 61 6c |T prefix = "$.al| 000033e0 69 62 2e 22 0a 09 20 4c 45 54 20 70 6c 65 6e 20 |ib.".. LET plen | 000033f0 3d 20 70 72 65 66 69 78 25 30 0a 09 20 4c 45 54 |= prefix%0.. LET| 00003400 20 76 20 3d 20 56 45 43 20 33 30 2f 42 79 74 65 | v = VEC 30/Byte| 00003410 73 50 65 72 57 6f 72 64 0a 0a 09 20 49 46 20 6c |sPerWord... IF l| 00003420 65 6e 77 3e 31 30 20 54 48 45 4e 20 6c 65 6e 77 |enw>10 THEN lenw| 00003430 20 3a 3d 20 31 30 0a 0a 09 20 46 4f 52 20 69 20 | := 10... FOR i | 00003440 3d 20 31 20 54 4f 20 6c 65 6e 77 20 44 4f 20 76 |= 1 TO lenw DO v| 00003450 25 28 69 2b 70 6c 65 6e 29 20 3a 3d 20 77 6f 72 |%(i+plen) := wor| 00003460 64 76 25 69 0a 09 20 46 4f 52 20 69 20 3d 20 31 |dv%i.. FOR i = 1| 00003470 20 54 4f 20 70 6c 65 6e 20 44 4f 20 76 25 69 20 | TO plen DO v%i | 00003480 3a 3d 20 70 72 65 66 69 78 25 69 0a 09 20 76 25 |:= prefix%i.. v%| 00003490 30 20 3a 3d 20 6c 65 6e 77 2b 70 6c 65 6e 0a 09 |0 := lenw+plen..| 000034a0 20 73 20 3a 3d 20 4f 70 65 6e 28 76 2c 20 54 52 | s := Open(v, TR| 000034b0 55 45 2c 20 46 41 4c 53 45 29 20 24 29 20 24 29 |UE, FALSE) $) $)| 000034c0 0a 0a 20 20 20 45 4c 53 45 20 24 28 0a 20 20 20 |.. ELSE $(. | 000034d0 20 20 20 4c 45 54 20 66 69 6c 65 20 3d 20 66 69 | LET file = fi| 000034e0 6e 64 2e 68 65 61 64 65 72 28 77 6f 72 64 76 29 |nd.header(wordv)| 000034f0 0a 0a 20 20 20 20 20 20 49 46 20 66 69 6c 65 7e |.. IF file~| 00003500 3d 30 20 54 48 45 4e 20 24 28 0a 09 20 73 20 3a |=0 THEN $(.. s :| 00003510 3d 20 4f 70 65 6e 28 66 69 6c 65 2c 20 54 52 55 |= Open(file, TRU| 00003520 45 2c 20 46 41 4c 53 45 29 0a 09 20 46 72 65 65 |E, FALSE).. Free| 00003530 56 65 63 74 6f 72 28 66 69 6c 65 29 20 24 29 20 |Vector(file) $) | 00003540 24 29 0a 0a 20 20 20 49 46 20 73 3d 30 20 54 48 |$).. IF s=0 TH| 00003550 45 4e 20 53 79 6e 52 65 70 6f 72 74 28 39 36 2c |EN SynReport(96,| 00003560 20 77 6f 72 64 76 29 0a 0a 20 20 20 67 65 74 76 | wordv).. getv| 00003570 21 67 65 74 70 20 3a 3d 20 73 6f 75 72 63 65 53 |!getp := sourceS| 00003580 74 72 65 61 6d 0a 20 20 20 67 65 74 76 21 28 67 |tream. getv!(g| 00003590 65 74 70 2b 31 29 20 3a 3d 20 6c 69 6e 65 43 6f |etp+1) := lineCo| 000035a0 75 6e 74 0a 20 20 20 67 65 74 76 21 28 67 65 74 |unt. getv!(get| 000035b0 70 2b 32 29 20 3a 3d 20 63 68 0a 20 20 20 67 65 |p+2) := ch. ge| 000035c0 74 70 20 3a 3d 20 67 65 74 70 2b 33 0a 0a 20 20 |tp := getp+3.. | 000035d0 20 6c 69 6e 65 43 6f 75 6e 74 20 3a 3d 20 31 0a | lineCount := 1.| 000035e0 0a 20 20 20 73 6f 75 72 63 65 53 74 72 65 61 6d |. sourceStream| 000035f0 20 3a 3d 20 73 0a 20 20 20 53 65 6c 65 63 74 49 | := s. SelectI| 00003600 6e 70 75 74 28 73 29 0a 20 20 20 52 43 68 28 29 |nput(s). RCh()| 00003610 0a 24 29 0a 0a 41 4e 44 20 66 69 6e 64 2e 68 65 |.$)..AND find.he| 00003620 61 64 65 72 28 73 74 72 69 6e 67 29 20 3d 20 56 |ader(string) = V| 00003630 41 4c 4f 46 0a 2f 2f 0a 2f 2f 20 46 69 6e 64 73 |ALOF.//.// Finds| 00003640 20 74 68 65 20 66 69 6c 65 20 61 73 73 6f 63 69 | the file associ| 00003650 61 74 65 64 20 77 69 74 68 20 74 68 65 20 67 69 |ated with the gi| 00003660 76 65 6e 20 68 65 61 64 65 72 20 6e 61 6d 65 0a |ven header name.| 00003670 2f 2f 20 69 6e 20 74 68 65 20 48 44 52 20 70 61 |// in the HDR pa| 00003680 72 61 6d 65 74 65 72 2e 0a 2f 2f 0a 2f 2f 20 54 |rameter..//.// T| 00003690 68 69 73 20 68 61 73 20 74 68 65 20 66 6f 72 6d |his has the form| 000036a0 61 74 3a 0a 2f 2f 0a 2f 2f 20 20 20 48 31 3d 46 |at:.//.// H1=F| 000036b0 31 2c 48 32 3d 46 32 2c 2e 2e 2e 2e 48 6e 3d 46 |1,H2=F2,....Hn=F| 000036c0 6e 0a 2f 2f 0a 2f 2f 20 45 61 63 68 20 48 69 20 |n.//.// Each Hi | 000036d0 69 73 20 61 20 68 65 61 64 65 72 20 6e 61 6d 65 |is a header name| 000036e0 20 28 65 67 2e 20 4c 49 42 48 44 52 29 2c 20 61 | (eg. LIBHDR), a| 000036f0 6e 64 20 65 61 63 68 20 46 69 20 69 73 20 61 0a |nd each Fi is a.| 00003700 2f 2f 20 66 69 6c 65 20 6e 61 6d 65 2e 0a 2f 2f |// file name..//| 00003710 0a 2f 2f 20 54 68 65 20 72 65 73 75 6c 74 20 69 |.// The result i| 00003720 73 20 61 20 6e 65 77 6c 79 2d 61 6c 6c 6f 63 61 |s a newly-alloca| 00003730 74 65 64 20 76 65 63 74 6f 72 20 68 6f 6c 64 69 |ted vector holdi| 00003740 6e 67 20 74 68 65 20 66 69 6c 65 0a 2f 2f 20 6e |ng the file.// n| 00003750 61 6d 65 2c 20 6f 72 20 7a 65 72 6f 20 69 66 20 |ame, or zero if | 00003760 74 68 65 20 68 65 61 64 65 72 20 6e 61 6d 65 20 |the header name | 00003770 77 61 73 20 6e 6f 74 20 66 6f 75 6e 64 2e 0a 2f |was not found../| 00003780 2f 0a 2f 2f 20 54 68 65 20 63 6f 6e 64 69 74 69 |/.// The conditi| 00003790 6f 6e 61 6c 20 63 6f 6d 70 69 6c 61 74 69 6f 6e |onal compilation| 000037a0 20 74 61 67 20 52 44 41 52 47 53 4c 20 69 73 20 | tag RDARGSL is | 000037b0 73 65 74 20 69 66 20 48 44 52 0a 2f 2f 20 77 61 |set if HDR.// wa| 000037c0 73 20 72 65 61 64 20 77 69 74 68 20 74 68 65 20 |s read with the | 000037d0 2f 4c 20 27 72 64 61 72 67 73 27 20 6f 70 74 69 |/L 'rdargs' opti| 000037e0 6f 6e 73 2c 20 69 6e 20 77 68 69 63 68 20 63 61 |ons, in which ca| 000037f0 73 65 0a 2f 2f 20 74 68 65 20 6c 65 6e 67 74 68 |se.// the length| 00003800 20 69 73 20 69 6e 20 74 68 65 20 66 69 72 73 74 | is in the first| 00003810 20 57 4f 52 44 2c 20 6e 6f 74 20 62 79 74 65 2e | WORD, not byte.| 00003820 0a 2f 2f 0a 24 28 20 4c 45 54 20 68 75 70 62 20 |.//.$( LET hupb | 00003830 3d 20 68 65 61 64 65 72 73 25 30 0a 20 20 20 4c |= headers%0. L| 00003840 45 54 20 68 6c 77 62 20 3d 20 31 0a 20 20 20 4c |ET hlwb = 1. L| 00003850 45 54 20 73 6c 65 6e 20 3d 20 73 74 72 69 6e 67 |ET slen = string| 00003860 25 30 0a 20 20 20 4c 45 54 20 68 70 6f 73 20 3d |%0. LET hpos =| 00003870 20 68 6c 77 62 0a 20 20 20 4c 45 54 20 66 70 6f | hlwb. LET fpo| 00003880 73 20 3d 20 30 0a 20 20 20 4c 45 54 20 76 20 3d |s = 0. LET v =| 00003890 20 30 0a 0a 20 20 20 2f 2f 20 53 65 61 72 63 68 | 0.. // Search| 000038a0 20 74 68 72 6f 75 67 68 20 74 68 65 20 48 44 52 | through the HDR| 000038b0 20 73 74 72 69 6e 67 20 74 6f 20 66 69 6e 64 20 | string to find | 000038c0 74 68 65 20 68 65 61 64 65 72 0a 20 20 20 2f 2f |the header. //| 000038d0 20 6e 61 6d 65 2e 0a 0a 20 20 20 46 4f 52 20 6a | name... FOR j| 000038e0 20 3d 20 68 6c 77 62 20 54 4f 20 68 75 70 62 20 | = hlwb TO hupb | 000038f0 44 4f 0a 20 20 20 24 28 20 4c 45 54 20 63 20 3d |DO. $( LET c =| 00003900 20 68 65 61 64 65 72 73 25 6a 0a 0a 20 20 20 20 | headers%j.. | 00003910 20 20 2f 2f 20 41 20 63 6f 6d 6d 61 20 69 6e 64 | // A comma ind| 00003920 69 63 61 74 65 73 20 74 68 65 20 73 74 61 72 74 |icates the start| 00003930 20 6f 66 20 61 20 68 65 61 64 65 72 20 6e 61 6d | of a header nam| 00003940 65 2c 0a 20 20 20 20 20 20 2f 2f 20 61 6e 20 65 |e,. // an e| 00003950 71 75 61 6c 73 20 73 69 67 6e 20 74 68 65 20 65 |quals sign the e| 00003960 6e 64 20 6f 66 20 6f 6e 65 2e 0a 0a 20 20 20 20 |nd of one... | 00003970 20 20 54 45 53 54 20 63 3d 27 2c 27 0a 09 20 54 | TEST c=','.. T| 00003980 48 45 4e 20 68 70 6f 73 20 3a 3d 20 6a 2b 31 0a |HEN hpos := j+1.| 00003990 09 20 45 4c 53 45 20 49 46 20 63 3d 27 3d 27 20 |. ELSE IF c='=' | 000039a0 54 48 45 4e 0a 09 20 20 2f 2f 0a 09 20 20 2f 2f |THEN.. //.. //| 000039b0 20 44 6f 65 73 20 74 68 65 20 63 75 72 72 65 6e | Does the curren| 000039c0 74 20 68 65 61 64 65 72 20 6e 61 6d 65 20 6d 61 |t header name ma| 000039d0 74 63 68 20 74 68 65 20 6f 6e 65 0a 09 20 20 2f |tch the one.. /| 000039e0 2f 20 74 68 61 74 20 69 73 20 62 65 69 6e 67 20 |/ that is being | 000039f0 73 6f 75 67 68 74 3f 0a 09 20 20 2f 2f 0a 09 20 |sought?.. //.. | 00003a00 20 49 46 20 6a 2d 68 70 6f 73 3d 73 6c 65 6e 20 | IF j-hpos=slen | 00003a10 54 48 45 4e 0a 09 20 20 24 28 20 4c 45 54 20 73 |THEN.. $( LET s| 00003a20 61 6d 65 20 3d 20 54 52 55 45 0a 0a 09 20 20 20 |ame = TRUE... | 00003a30 20 20 46 4f 52 20 6a 20 3d 20 31 20 54 4f 20 73 | FOR j = 1 TO s| 00003a40 6c 65 6e 20 44 4f 0a 09 20 20 20 20 20 20 20 49 |len DO.. I| 00003a50 46 20 43 6f 6d 70 43 68 28 68 65 61 64 65 72 73 |F CompCh(headers| 00003a60 25 28 6a 2b 68 70 6f 73 2d 31 29 2c 20 73 74 72 |%(j+hpos-1), str| 00003a70 69 6e 67 25 6a 29 7e 3d 30 20 54 48 45 4e 0a 09 |ing%j)~=0 THEN..| 00003a80 20 20 20 20 20 20 20 24 28 20 73 61 6d 65 20 3a | $( same :| 00003a90 3d 20 46 41 4c 53 45 0a 09 09 20 20 42 52 45 41 |= FALSE... BREA| 00003aa0 4b 20 24 29 0a 0a 09 20 20 20 20 20 20 20 2f 2f |K $)... //| 00003ab0 20 49 66 20 66 6f 75 6e 64 2c 20 72 65 6d 65 6d | If found, remem| 00003ac0 62 65 72 20 74 68 65 20 70 6f 73 69 74 69 6f 6e |ber the position| 00003ad0 20 61 74 0a 09 20 20 20 20 20 20 20 2f 2f 20 77 | at.. // w| 00003ae0 68 69 63 68 20 74 68 65 20 66 69 6c 65 20 6e 61 |hich the file na| 00003af0 6d 65 20 73 74 61 72 74 73 2e 0a 0a 09 20 20 20 |me starts.... | 00003b00 20 20 20 20 49 46 20 73 61 6d 65 20 54 48 45 4e | IF same THEN| 00003b10 0a 09 20 20 20 20 20 20 20 24 28 20 66 70 6f 73 |.. $( fpos| 00003b20 20 3a 3d 20 6a 2b 31 0a 09 09 20 20 42 52 45 41 | := j+1... BREA| 00003b30 4b 20 24 29 20 24 29 20 24 29 0a 0a 20 20 20 49 |K $) $) $).. I| 00003b40 46 20 66 70 6f 73 7e 3d 30 20 54 48 45 4e 0a 20 |F fpos~=0 THEN. | 00003b50 20 20 24 28 20 4c 45 54 20 66 6c 65 6e 20 3d 20 | $( LET flen = | 00003b60 30 0a 0a 20 20 20 20 20 20 46 4f 52 20 6a 20 3d |0.. FOR j =| 00003b70 20 66 70 6f 73 20 54 4f 20 68 75 70 62 20 44 4f | fpos TO hupb DO| 00003b80 0a 20 20 20 20 20 20 24 28 20 49 46 20 68 65 61 |. $( IF hea| 00003b90 64 65 72 73 25 6a 3d 27 2c 27 20 54 48 45 4e 20 |ders%j=',' THEN | 00003ba0 42 52 45 41 4b 0a 09 20 66 6c 65 6e 20 3a 3d 20 |BREAK.. flen := | 00003bb0 66 6c 65 6e 2b 31 20 24 29 0a 20 20 20 20 20 20 |flen+1 $). | 00003bc0 76 20 3a 3d 20 47 65 74 56 65 63 74 6f 72 28 66 |v := GetVector(f| 00003bd0 6c 65 6e 20 2f 20 42 79 74 65 73 50 65 72 57 6f |len / BytesPerWo| 00003be0 72 64 2b 31 29 0a 20 20 20 20 20 20 76 25 30 20 |rd+1). v%0 | 00003bf0 3a 3d 20 66 6c 65 6e 0a 0a 20 20 20 20 20 20 46 |:= flen.. F| 00003c00 4f 52 20 6a 20 3d 20 31 20 54 4f 20 66 6c 65 6e |OR j = 1 TO flen| 00003c10 20 44 4f 0a 09 20 76 25 6a 20 3a 3d 20 68 65 61 | DO.. v%j := hea| 00003c20 64 65 72 73 25 28 66 70 6f 73 2b 6a 2d 31 29 20 |ders%(fpos+j-1) | 00003c30 24 29 0a 20 20 20 52 45 53 55 4c 54 49 53 20 76 |$). RESULTIS v| 00003c40 0a 24 29 0a 0a 41 4e 44 20 52 65 61 64 4e 75 6d |.$)..AND ReadNum| 00003c50 62 65 72 28 72 61 64 69 78 29 20 42 45 0a 24 28 |ber(radix) BE.$(| 00003c60 20 4c 45 54 20 64 20 3d 20 56 61 6c 75 65 28 63 | LET d = Value(c| 00003c70 68 29 3b 0a 20 20 20 64 69 67 69 74 73 20 3a 3d |h);. digits :=| 00003c80 20 31 3b 0a 20 20 20 64 65 63 76 61 6c 20 3a 3d | 1;. decval :=| 00003c90 20 64 0a 20 20 20 49 46 20 64 3e 3d 72 61 64 69 | d. IF d>=radi| 00003ca0 78 20 54 48 45 4e 20 53 79 6e 52 65 70 6f 72 74 |x THEN SynReport| 00003cb0 28 33 33 29 0a 0a 20 20 20 24 28 20 52 43 68 28 |(33).. $( RCh(| 00003cc0 29 0a 20 20 20 20 20 20 64 20 3a 3d 20 56 61 6c |). d := Val| 00003cd0 75 65 28 63 68 29 0a 20 20 20 20 20 20 49 46 20 |ue(ch). IF | 00003ce0 64 3e 3d 72 61 64 69 78 20 54 48 45 4e 20 52 45 |d>=radix THEN RE| 00003cf0 54 55 52 4e 3b 0a 20 20 20 20 20 20 64 69 67 69 |TURN;. digi| 00003d00 74 73 20 3a 3d 20 64 69 67 69 74 73 2b 31 3b 0a |ts := digits+1;.| 00003d10 20 20 20 20 20 20 64 65 63 76 61 6c 20 3a 3d 20 | decval := | 00003d20 72 61 64 69 78 20 2a 20 64 65 63 76 61 6c 2b 64 |radix * decval+d| 00003d30 0a 20 20 20 24 29 20 52 45 50 45 41 54 0a 24 29 |. $) REPEAT.$)| 00003d40 0a 0a 41 4e 44 20 52 65 61 64 46 6c 6f 61 74 28 |..AND ReadFloat(| 00003d50 29 20 42 45 0a 24 28 20 4c 45 54 20 6e 65 67 61 |) BE.$( LET nega| 00003d60 74 69 76 65 45 78 70 6f 6e 65 6e 74 20 3d 20 46 |tiveExponent = F| 00003d70 41 4c 53 45 3b 0a 20 20 20 73 79 6d 62 20 3a 3d |ALSE;. symb :=| 00003d80 20 73 2e 66 63 6f 6e 73 74 3b 0a 20 20 20 6d 61 | s.fconst;. ma| 00003d90 6e 74 69 73 73 61 2c 20 65 78 70 6f 6e 65 6e 74 |ntissa, exponent| 00003da0 20 3a 3d 20 64 65 63 76 61 6c 2c 20 30 3b 0a 20 | := decval, 0;. | 00003db0 20 20 49 46 20 63 68 3d 27 2e 27 20 54 48 45 4e | IF ch='.' THEN| 00003dc0 0a 20 20 20 24 28 20 52 63 68 28 29 3b 0a 20 20 |. $( Rch();. | 00003dd0 20 20 20 20 55 4e 4c 45 53 53 20 27 30 27 3c 3d | UNLESS '0'<=| 00003de0 63 68 3c 3d 27 39 27 20 54 48 45 4e 20 53 79 6e |ch<='9' THEN Syn| 00003df0 52 65 70 6f 72 74 28 33 33 29 3b 0a 20 20 20 20 |Report(33);. | 00003e00 20 20 52 65 61 64 4e 75 6d 62 65 72 28 31 30 29 | ReadNumber(10)| 00003e10 3b 0a 20 20 20 20 20 20 49 46 20 64 65 63 76 61 |;. IF decva| 00003e20 6c 7e 3d 30 20 54 48 45 4e 0a 20 20 20 20 20 20 |l~=0 THEN. | 00003e30 24 28 20 65 78 70 6f 6e 65 6e 74 20 3a 3d 20 65 |$( exponent := e| 00003e40 78 70 6f 6e 65 6e 74 2d 64 69 67 69 74 73 3b 0a |xponent-digits;.| 00003e50 09 20 57 48 49 4c 45 20 64 69 67 69 74 73 7e 3d |. WHILE digits~=| 00003e60 30 20 44 4f 0a 09 20 24 28 20 6d 61 6e 74 69 73 |0 DO.. $( mantis| 00003e70 73 61 20 3a 3d 20 6d 61 6e 74 69 73 73 61 2a 31 |sa := mantissa*1| 00003e80 30 3b 0a 09 20 20 20 20 64 69 67 69 74 73 20 3a |0;.. digits :| 00003e90 3d 20 64 69 67 69 74 73 2d 31 20 24 29 3b 0a 09 |= digits-1 $);..| 00003ea0 20 6d 61 6e 74 69 73 73 61 20 3a 3d 20 6d 61 6e | mantissa := man| 00003eb0 74 69 73 73 61 2b 64 65 63 76 61 6c 20 24 29 20 |tissa+decval $) | 00003ec0 24 29 3b 0a 20 20 20 49 46 20 63 68 3d 27 45 27 |$);. IF ch='E'| 00003ed0 20 7c 20 63 68 3d 27 65 27 20 54 48 45 4e 0a 20 | | ch='e' THEN. | 00003ee0 20 20 24 28 20 52 63 68 28 29 3b 0a 20 20 20 20 | $( Rch();. | 00003ef0 20 20 49 46 20 63 68 3d 27 2d 27 20 54 48 45 4e | IF ch='-' THEN| 00003f00 20 24 28 20 6e 65 67 61 74 69 76 65 45 78 70 6f | $( negativeExpo| 00003f10 6e 65 6e 74 20 3a 3d 20 54 52 55 45 3b 20 52 63 |nent := TRUE; Rc| 00003f20 68 28 29 20 24 29 3b 0a 20 20 20 20 20 20 55 4e |h() $);. UN| 00003f30 4c 45 53 53 20 27 30 27 3c 3d 63 68 3c 3d 27 39 |LESS '0'<=ch<='9| 00003f40 27 20 54 48 45 4e 20 53 79 6e 52 65 70 6f 72 74 |' THEN SynReport| 00003f50 28 33 33 29 3b 0a 20 20 20 20 20 20 52 65 61 64 |(33);. Read| 00003f60 4e 75 6d 62 65 72 28 31 30 29 3b 0a 20 20 20 20 |Number(10);. | 00003f70 20 20 65 78 70 6f 6e 65 6e 74 20 3a 3d 20 6e 65 | exponent := ne| 00003f80 67 61 74 69 76 65 45 78 70 6f 6e 65 6e 74 20 2d |gativeExponent -| 00003f90 3e 20 65 78 70 6f 6e 65 6e 74 2d 64 65 63 76 61 |> exponent-decva| 00003fa0 6c 2c 0a 09 09 09 09 20 20 20 20 20 20 65 78 70 |l,..... exp| 00003fb0 6f 6e 65 6e 74 2b 64 65 63 76 61 6c 20 24 29 0a |onent+decval $).| 00003fc0 24 29 0a 0a 41 4e 44 20 56 61 6c 75 65 28 63 68 |$)..AND Value(ch| 00003fd0 29 20 3d 20 56 41 4c 4f 46 0a 24 28 20 4c 45 54 |) = VALOF.$( LET| 00003fe0 20 63 20 3d 20 43 61 70 69 74 61 6c 43 68 28 63 | c = CapitalCh(c| 00003ff0 68 29 0a 20 20 20 52 45 53 55 4c 54 49 53 20 27 |h). RESULTIS '| 00004000 30 27 3c 3d 63 3c 3d 27 39 27 20 2d 3e 20 63 2d |0'<=c<='9' -> c-| 00004010 27 30 27 2c 0a 09 20 20 20 20 27 41 27 3c 3d 63 |'0',.. 'A'<=c| 00004020 3c 3d 27 46 27 20 2d 3e 20 63 2d 27 41 27 2b 31 |<='F' -> c-'A'+1| 00004030 30 2c 20 31 30 30 0a 24 29 0a 0a 41 4e 44 20 52 |0, 100.$)..AND R| 00004040 64 53 74 72 43 68 28 74 65 72 6d 2c 20 6c 76 2e |dStrCh(term, lv.| 00004050 63 68 29 20 3d 20 56 41 4c 4f 46 0a 24 28 20 4c |ch) = VALOF.$( L| 00004060 45 54 20 74 72 61 6e 73 20 3d 20 74 72 61 6e 73 |ET trans = trans| 00004070 63 68 61 72 73 0a 20 20 20 52 43 68 28 29 0a 20 |chars. RCh(). | 00004080 20 20 49 46 20 63 68 3d 74 65 72 6d 20 54 48 45 | IF ch=term THE| 00004090 4e 20 52 45 53 55 4c 54 49 53 20 46 41 4c 53 45 |N RESULTIS FALSE| 000040a0 0a 20 20 20 49 46 20 63 68 3d 27 2a 4e 27 20 54 |. IF ch='*N' T| 000040b0 48 45 4e 20 53 79 6e 52 65 70 6f 72 74 28 33 34 |HEN SynReport(34| 000040c0 29 0a 0a 20 20 20 49 46 20 63 68 3d 27 2a 2a 27 |).. IF ch='**'| 000040d0 20 54 48 45 4e 0a 20 20 20 24 28 20 52 43 68 28 | THEN. $( RCh(| 000040e0 29 0a 20 20 20 20 20 20 49 46 20 63 68 3d 27 2a |). IF ch='*| 000040f0 4e 27 20 7c 20 63 68 3d 27 2a 53 27 20 7c 20 63 |N' | ch='*S' | c| 00004100 68 3d 27 2a 54 27 0a 09 20 54 48 45 4e 20 54 45 |h='*T'.. THEN TE| 00004110 53 54 20 74 65 72 6d 3d 27 2a 27 27 0a 09 20 20 |ST term='*''.. | 00004120 20 20 54 48 45 4e 20 53 79 6e 52 65 70 6f 72 74 | THEN SynReport| 00004130 28 33 34 29 0a 09 20 20 20 20 45 4c 53 45 20 24 |(34).. ELSE $| 00004140 28 20 57 48 49 4c 45 20 63 68 3d 27 2a 4e 27 20 |( WHILE ch='*N' | 00004150 7c 20 63 68 3d 27 2a 53 27 20 7c 20 63 68 3d 27 || ch='*S' | ch='| 00004160 2a 54 27 20 44 4f 20 52 43 68 28 29 0a 09 09 20 |*T' DO RCh()... | 00004170 20 20 20 49 46 20 63 68 7e 3d 27 2a 2a 27 20 54 | IF ch~='**' T| 00004180 48 45 4e 20 53 79 6e 52 65 70 6f 72 74 28 33 34 |HEN SynReport(34| 00004190 29 0a 09 09 20 20 20 20 4c 4f 4f 50 0a 09 09 20 |)... LOOP... | 000041a0 24 29 0a 0a 20 20 20 20 20 20 63 68 20 3a 3d 20 |$).. ch := | 000041b0 43 61 70 69 74 61 6c 43 68 28 63 68 29 0a 20 20 |CapitalCh(ch). | 000041c0 20 20 20 20 49 46 20 28 63 68 3d 27 45 27 20 7c | IF (ch='E' || 000041d0 20 63 68 3d 27 42 27 20 7c 20 63 68 3d 27 43 27 | ch='B' | ch='C'| 000041e0 29 20 26 20 65 78 74 65 6e 73 69 6f 6e 2e 6c 65 |) & extension.le| 000041f0 76 65 6c 3d 30 20 54 48 45 4e 0a 09 20 63 68 20 |vel=0 THEN.. ch | 00004200 3a 3d 20 2d 31 0a 0a 20 20 20 20 20 20 53 57 49 |:= -1.. SWI| 00004210 54 43 48 4f 4e 20 63 68 20 49 4e 54 4f 0a 20 20 |TCHON ch INTO. | 00004220 20 20 20 20 24 28 20 44 45 46 41 55 4c 54 3a 20 | $( DEFAULT: | 00004230 20 53 79 6e 52 65 70 6f 72 74 28 33 35 29 3b 20 | SynReport(35); | 00004240 45 4e 44 43 41 53 45 0a 0a 09 20 43 41 53 45 20 |ENDCASE... CASE | 00004250 27 54 27 3a 20 63 68 20 3a 3d 20 27 2a 54 27 3b |'T': ch := '*T';| 00004260 09 20 20 45 4e 44 43 41 53 45 0a 09 20 43 41 53 |. ENDCASE.. CAS| 00004270 45 20 27 53 27 3a 20 63 68 20 3a 3d 20 27 2a 53 |E 'S': ch := '*S| 00004280 27 3b 09 20 20 45 4e 44 43 41 53 45 0a 09 20 43 |';. ENDCASE.. C| 00004290 41 53 45 20 27 4e 27 3a 20 63 68 20 3a 3d 20 27 |ASE 'N': ch := '| 000042a0 2a 4e 27 3b 09 20 20 45 4e 44 43 41 53 45 0a 09 |*N';. ENDCASE..| 000042b0 20 43 41 53 45 20 27 50 27 3a 20 63 68 20 3a 3d | CASE 'P': ch :=| 000042c0 20 27 2a 50 27 3b 09 20 20 45 4e 44 43 41 53 45 | '*P';. ENDCASE| 000042d0 0a 09 20 43 41 53 45 20 27 42 27 3a 20 63 68 20 |.. CASE 'B': ch | 000042e0 3a 3d 20 27 2a 42 27 3b 09 20 20 45 4e 44 43 41 |:= '*B';. ENDCA| 000042f0 53 45 0a 09 20 43 41 53 45 20 27 43 27 3a 20 63 |SE.. CASE 'C': c| 00004300 68 20 3a 3d 20 27 2a 43 27 3b 09 20 20 45 4e 44 |h := '*C';. END| 00004310 43 41 53 45 0a 09 20 43 41 53 45 20 27 45 27 3a |CASE.. CASE 'E':| 00004320 20 63 68 20 3a 3d 20 23 58 31 42 0a 09 20 43 41 | ch := #X1B.. CA| 00004330 53 45 20 27 22 27 3a 20 20 20 20 20 20 20 20 20 |SE '"': | 00004340 20 20 20 20 20 20 20 45 4e 44 43 41 53 45 0a 09 | ENDCASE..| 00004350 20 43 41 53 45 20 27 2a 27 27 3a 09 09 20 20 45 | CASE '*'':.. E| 00004360 4e 44 43 41 53 45 0a 09 20 43 41 53 45 20 27 2a |NDCASE.. CASE '*| 00004370 2a 27 3a 09 09 20 20 45 4e 44 43 41 53 45 0a 0a |*':.. ENDCASE..| 00004380 09 20 43 41 53 45 20 27 58 27 3a 20 43 41 53 45 |. CASE 'X': CASE| 00004390 20 27 4f 27 3a 0a 09 20 43 41 53 45 20 27 30 27 | 'O':.. CASE '0'| 000043a0 3a 20 43 41 53 45 20 27 31 27 3a 20 43 41 53 45 |: CASE '1': CASE| 000043b0 20 27 32 27 3a 20 43 41 53 45 20 27 33 27 3a 0a | '2': CASE '3':.| 000043c0 09 20 43 41 53 45 20 27 34 27 3a 20 43 41 53 45 |. CASE '4': CASE| 000043d0 20 27 35 27 3a 20 43 41 53 45 20 27 36 27 3a 20 | '5': CASE '6': | 000043e0 43 41 53 45 20 27 37 27 3a 0a 09 20 20 20 24 28 |CASE '7':.. $(| 000043f0 20 4c 45 54 20 72 2c 20 6e 20 3d 20 38 2c 20 33 | LET r, n = 8, 3| 00004400 0a 09 20 20 20 20 20 20 49 46 20 63 68 3d 27 58 |.. IF ch='X| 00004410 27 20 54 48 45 4e 20 72 2c 20 6e 20 3a 3d 20 31 |' THEN r, n := 1| 00004420 36 2c 20 32 0a 0a 09 20 20 20 20 20 20 49 46 20 |6, 2... IF | 00004430 63 68 3d 27 58 27 20 7c 20 63 68 3d 27 4f 27 20 |ch='X' | ch='O' | 00004440 54 48 45 4e 20 52 43 68 28 29 0a 09 20 20 20 20 |THEN RCh().. | 00004450 20 20 63 68 20 3a 3d 20 52 65 61 64 4f 63 74 61 | ch := ReadOcta| 00004460 6c 4f 72 48 65 78 28 72 2c 20 6e 29 0a 0a 09 20 |lOrHex(r, n)... | 00004470 20 20 20 20 20 49 46 20 63 68 3e 32 35 35 20 54 | IF ch>255 T| 00004480 48 45 4e 20 53 79 6e 52 65 70 6f 72 74 28 33 34 |HEN SynReport(34| 00004490 29 0a 09 20 20 20 20 20 20 74 72 61 6e 73 20 3a |).. trans :| 000044a0 3d 20 46 41 4c 53 45 0a 09 20 20 20 20 20 20 45 |= FALSE.. E| 000044b0 4e 44 43 41 53 45 0a 09 20 20 20 24 29 0a 20 20 |NDCASE.. $). | 000044c0 20 20 20 20 24 29 0a 20 20 20 24 29 0a 20 20 20 | $). $). | 000044d0 21 6c 76 2e 63 68 20 3a 3d 20 74 72 61 6e 73 20 |!lv.ch := trans | 000044e0 2d 3e 20 63 68 61 72 63 6f 64 65 21 63 68 2c 20 |-> charcode!ch, | 000044f0 63 68 0a 20 20 20 52 45 53 55 4c 54 49 53 20 54 |ch. RESULTIS T| 00004500 52 55 45 0a 0a 24 29 20 52 45 50 45 41 54 0a 0a |RUE..$) REPEAT..| 00004510 0a 41 4e 44 20 52 65 61 64 4f 63 74 61 6c 4f 72 |.AND ReadOctalOr| 00004520 48 65 78 28 72 61 64 69 78 2c 20 64 69 67 69 74 |Hex(radix, digit| 00004530 73 29 20 3d 20 56 41 4c 4f 46 0a 24 28 20 4c 45 |s) = VALOF.$( LE| 00004540 54 20 61 6e 73 77 65 72 20 3d 20 30 0a 0a 20 20 |T answer = 0.. | 00004550 20 46 4f 52 20 6a 20 3d 20 31 20 54 4f 20 64 69 | FOR j = 1 TO di| 00004560 67 69 74 73 20 44 4f 0a 20 20 20 24 28 20 4c 45 |gits DO. $( LE| 00004570 54 20 76 61 6c 63 68 20 3d 20 76 61 6c 75 65 28 |T valch = value(| 00004580 63 68 29 0a 20 20 20 20 20 20 49 46 20 76 61 6c |ch). IF val| 00004590 63 68 3e 3d 72 61 64 69 78 20 54 48 45 4e 20 53 |ch>=radix THEN S| 000045a0 79 6e 52 65 70 6f 72 74 28 33 34 29 0a 0a 20 20 |ynReport(34).. | 000045b0 20 20 20 20 61 6e 73 77 65 72 20 3a 3d 20 61 6e | answer := an| 000045c0 73 77 65 72 2a 72 61 64 69 78 2b 76 61 6c 63 68 |swer*radix+valch| 000045d0 0a 20 20 20 20 20 20 49 46 20 6a 7e 3d 64 69 67 |. IF j~=dig| 000045e0 69 74 73 20 54 48 45 4e 20 52 43 68 28 29 0a 20 |its THEN RCh(). | 000045f0 20 20 24 29 0a 20 20 20 52 45 53 55 4c 54 49 53 | $). RESULTIS| 00004600 20 61 6e 73 77 65 72 0a 24 29 0a 0a 2e 0a 0a 53 | answer.$).....S| 00004610 45 43 54 49 4f 4e 20 22 53 79 6e 22 0a 0a 47 45 |ECTION "Syn"..GE| 00004620 54 20 22 62 2e 48 65 61 64 65 72 22 0a 0a 53 54 |T "b.Header"..ST| 00004630 41 54 49 43 0a 24 28 20 64 75 6d 6d 79 20 3d 20 |ATIC.$( dummy = | 00004640 56 65 72 73 69 6f 6e 4d 61 72 6b 3b 0a 20 20 20 |VersionMark;. | 00004650 76 65 72 73 69 6f 6e 20 3d 20 31 2a 32 35 36 2b |version = 1*256+| 00004660 32 0a 24 29 0a 0a 4c 45 54 20 62 63 70 6c 2e 73 |2.$)..LET bcpl.s| 00004670 79 6e 28 29 20 3d 20 20 56 41 4c 4f 46 0a 24 28 |yn() = VALOF.$(| 00004680 20 4c 45 54 20 61 20 3d 20 30 3b 0a 20 20 20 4c | LET a = 0;. L| 00004690 45 54 20 76 20 3d 20 47 65 74 56 65 63 74 6f 72 |ET v = GetVector| 000046a0 28 6e 61 6d 65 74 61 62 6c 65 73 69 7a 65 2b 36 |(nametablesize+6| 000046b0 34 2b 77 6f 72 64 6d 61 78 2b 67 65 74 6d 61 78 |4+wordmax+getmax| 000046c0 2b 31 29 3b 0a 0a 20 20 20 65 72 72 2e 70 20 3a |+1);.. err.p :| 000046d0 3d 20 4c 65 76 65 6c 28 29 3b 0a 20 20 20 65 72 |= Level();. er| 000046e0 72 2e 6c 20 3a 3d 20 65 78 69 74 3b 0a 20 20 20 |r.l := exit;. | 000046f0 67 65 74 70 20 3a 3d 20 30 3b 0a 20 20 20 63 68 |getp := 0;. ch| 00004700 63 6f 75 6e 74 20 3a 3d 20 30 3b 0a 20 20 20 65 |count := 0;. e| 00004710 78 74 65 72 6e 61 6c 73 2e 6c 69 73 74 20 3a 3d |xternals.list :=| 00004720 20 30 3b 0a 20 20 20 66 72 65 65 2e 6c 69 73 74 | 0;. free.list| 00004730 2e 65 6c 65 6d 65 6e 74 2e 63 68 61 69 6e 20 3a |.element.chain :| 00004740 3d 20 30 3b 0a 20 20 20 66 72 65 65 2e 63 63 73 |= 0;. free.ccs| 00004750 74 61 63 6b 2e 63 68 61 69 6e 20 3a 3d 20 30 3b |tack.chain := 0;| 00004760 0a 20 20 20 7a 65 72 6f 4e 6f 64 65 20 3a 3d 20 |. zeroNode := | 00004770 4c 69 73 74 32 28 73 2e 6e 75 6d 62 65 72 2c 20 |List2(s.number, | 00004780 30 29 3b 0a 0a 20 20 20 46 4f 52 20 69 20 3d 20 |0);.. FOR i = | 00004790 30 20 54 4f 20 4e 61 6d 65 54 61 62 6c 65 53 69 |0 TO NameTableSi| 000047a0 7a 65 2b 36 33 20 44 4f 20 76 21 69 20 3a 3d 20 |ze+63 DO v!i := | 000047b0 30 0a 0a 20 20 20 6e 61 6d 65 54 61 62 6c 65 20 |0.. nameTable | 000047c0 3a 3d 20 76 0a 20 20 20 63 68 62 75 66 20 3a 3d |:= v. chbuf :=| 000047d0 20 76 2b 4e 61 6d 65 54 61 62 6c 65 53 69 7a 65 | v+NameTableSize| 000047e0 0a 20 20 20 77 6f 72 64 76 20 3a 3d 20 63 68 62 |. wordv := chb| 000047f0 75 66 2b 36 34 0a 20 20 20 67 65 74 76 20 3a 3d |uf+64. getv :=| 00004800 20 77 6f 72 64 76 2b 77 6f 72 64 6d 61 78 0a 0a | wordv+wordmax..| 00004810 20 20 20 69 6e 69 74 69 61 6c 69 73 65 2e 6c 65 | initialise.le| 00004820 78 28 29 0a 0a 20 20 20 49 46 20 63 68 3d 45 6e |x().. IF ch=En| 00004830 64 53 74 72 65 61 6d 43 68 20 54 48 45 4e 20 47 |dStreamCh THEN G| 00004840 4f 54 4f 20 65 78 69 74 0a 0a 20 20 20 72 65 63 |OTO exit.. rec| 00004850 2e 70 2c 20 72 65 63 2e 6c 20 3a 3d 20 65 72 72 |.p, rec.l := err| 00004860 2e 70 2c 20 6c 0a 0a 6c 3a 20 4e 65 78 74 53 79 |.p, l..l: NextSy| 00004870 6d 62 28 29 0a 0a 20 20 20 24 28 20 4c 45 54 20 |mb().. $( LET | 00004880 52 50 72 6f 67 28 29 20 3d 20 56 41 4c 4f 46 0a |RProg() = VALOF.| 00004890 20 20 20 20 20 20 24 28 20 4c 45 54 20 6f 70 2c | $( LET op,| 000048a0 20 61 20 3d 20 73 79 6d 62 2c 20 30 0a 09 20 4c | a = symb, 0.. L| 000048b0 45 54 20 74 61 67 20 3d 20 3f 0a 0a 09 20 4e 65 |ET tag = ?... Ne| 000048c0 78 74 53 79 6d 62 28 29 0a 09 20 49 46 20 73 79 |xtSymb().. IF sy| 000048d0 6d 62 7e 3d 73 2e 73 74 72 69 6e 67 20 54 48 45 |mb~=s.string THE| 000048e0 4e 20 53 79 6e 52 65 70 6f 72 74 28 39 35 29 0a |N SynReport(95).| 000048f0 0a 09 20 74 61 67 20 3a 3d 20 4c 6f 6f 6b 55 70 |.. tag := LookUp| 00004900 54 61 67 28 77 6f 72 64 76 29 0a 09 20 74 61 67 |Tag(wordv).. tag| 00004910 2e 76 61 6c 75 65 21 74 61 67 20 3a 3d 20 54 52 |.value!tag := TR| 00004920 55 45 0a 0a 09 20 61 20 3a 3d 20 52 62 45 78 70 |UE... a := RbExp| 00004930 28 29 0a 0a 09 20 49 46 20 6f 70 3d 73 2e 73 65 |()... IF op=s.se| 00004940 63 74 69 6f 6e 20 54 48 45 4e 20 57 72 69 74 65 |ction THEN Write| 00004950 46 28 22 53 65 63 74 69 6f 6e 20 25 53 2a 4e 22 |F("Section %S*N"| 00004960 2c 20 61 2b 31 29 0a 0a 09 20 52 45 53 55 4c 54 |, a+1)... RESULT| 00004970 49 53 20 4c 69 73 74 33 28 6f 70 2c 20 61 2c 20 |IS List3(op, a, | 00004980 73 79 6d 62 3d 73 2e 6e 65 65 64 73 20 2d 3e 20 |symb=s.needs -> | 00004990 52 50 72 6f 67 28 29 2c 0a 09 09 09 09 09 20 20 |RProg(),...... | 000049a0 20 20 20 20 20 52 64 42 6c 6f 63 6b 42 6f 64 79 | RdBlockBody| 000049b0 28 29 29 0a 20 20 20 20 20 20 24 29 0a 0a 20 20 |()). $).. | 000049c0 20 20 20 20 61 20 3a 3d 20 65 78 74 65 6e 73 69 | a := extensi| 000049d0 6f 6e 2e 6c 65 76 65 6c 3e 3d 31 20 26 0a 09 20 |on.level>=1 &.. | 000049e0 20 20 5b 73 79 6d 62 3d 73 2e 73 65 63 74 69 6f | [symb=s.sectio| 000049f0 6e 20 7c 20 73 79 6d 62 3d 73 2e 6e 65 65 64 73 |n | symb=s.needs| 00004a00 5d 20 2d 3e 20 52 50 72 6f 67 28 29 2c 0a 09 09 |] -> RProg(),...| 00004a10 09 09 09 20 20 20 20 20 20 52 64 42 6c 6f 63 6b |... RdBlock| 00004a20 42 6f 64 79 28 29 0a 0a 20 20 20 20 20 20 49 46 |Body().. IF| 00004a30 20 73 79 6d 62 7e 3d 73 2e 65 6e 64 20 54 48 45 | symb~=s.end THE| 00004a40 4e 20 53 79 6e 52 65 70 6f 72 74 28 39 39 29 0a |N SynReport(99).| 00004a50 20 20 20 24 29 0a 20 20 20 55 6e 52 64 43 68 28 | $). UnRdCh(| 00004a60 29 0a 0a 65 78 69 74 3a 0a 20 20 20 46 72 65 65 |)..exit:. Free| 00004a70 56 65 63 74 6f 72 28 76 29 0a 20 20 20 52 45 53 |Vector(v). RES| 00004a80 55 4c 54 49 53 20 61 0a 24 29 0a 0a 41 4e 44 20 |ULTIS a.$)..AND | 00004a90 4c 69 73 74 31 28 78 29 20 3d 20 56 41 4c 4f 46 |List1(x) = VALOF| 00004aa0 0a 24 28 20 4c 45 54 20 70 20 3d 20 47 65 74 42 |.$( LET p = GetB| 00004ab0 6c 6b 28 31 29 0a 20 20 20 70 21 30 20 3a 3d 20 |lk(1). p!0 := | 00004ac0 78 0a 20 20 20 52 45 53 55 4c 54 49 53 20 70 0a |x. RESULTIS p.| 00004ad0 24 29 0a 0a 41 4e 44 20 4c 69 73 74 32 28 78 2c |$)..AND List2(x,| 00004ae0 20 79 29 20 3d 20 56 41 4c 4f 46 0a 24 28 20 4c | y) = VALOF.$( L| 00004af0 45 54 20 70 20 3d 20 47 65 74 42 6c 6b 28 32 29 |ET p = GetBlk(2)| 00004b00 0a 20 20 20 70 21 30 2c 20 70 21 31 20 3a 3d 20 |. p!0, p!1 := | 00004b10 78 2c 20 79 0a 20 20 20 52 45 53 55 4c 54 49 53 |x, y. RESULTIS| 00004b20 20 70 0a 24 29 0a 0a 41 4e 44 20 4c 69 73 74 33 | p.$)..AND List3| 00004b30 28 78 2c 20 79 2c 20 7a 29 20 3d 20 56 41 4c 4f |(x, y, z) = VALO| 00004b40 46 0a 24 28 20 4c 45 54 20 70 20 3d 20 47 65 74 |F.$( LET p = Get| 00004b50 42 6c 6b 28 33 29 0a 20 20 20 70 21 30 2c 20 70 |Blk(3). p!0, p| 00004b60 21 31 2c 20 70 21 32 20 3a 3d 20 78 2c 20 79 2c |!1, p!2 := x, y,| 00004b70 20 7a 0a 20 20 20 52 45 53 55 4c 54 49 53 20 70 | z. RESULTIS p| 00004b80 0a 24 29 0a 0a 41 4e 44 20 4c 69 73 74 34 28 78 |.$)..AND List4(x| 00004b90 2c 20 79 2c 20 7a 2c 20 74 29 20 3d 20 56 41 4c |, y, z, t) = VAL| 00004ba0 4f 46 0a 24 28 20 4c 45 54 20 70 20 3d 20 47 65 |OF.$( LET p = Ge| 00004bb0 74 42 6c 6b 28 34 29 0a 20 20 20 70 21 30 2c 20 |tBlk(4). p!0, | 00004bc0 70 21 31 2c 20 70 21 32 2c 20 70 21 33 20 3a 3d |p!1, p!2, p!3 :=| 00004bd0 20 78 2c 20 79 2c 20 7a 2c 20 74 0a 20 20 20 52 | x, y, z, t. R| 00004be0 45 53 55 4c 54 49 53 20 70 0a 24 29 0a 0a 41 4e |ESULTIS p.$)..AN| 00004bf0 44 20 4c 69 73 74 35 28 78 2c 20 79 2c 20 7a 2c |D List5(x, y, z,| 00004c00 20 74 2c 20 75 29 20 3d 20 56 41 4c 4f 46 0a 24 | t, u) = VALOF.$| 00004c10 28 20 4c 45 54 20 70 20 3d 20 47 65 74 42 6c 6b |( LET p = GetBlk| 00004c20 28 35 29 0a 20 20 20 70 21 30 2c 20 70 21 31 2c |(5). p!0, p!1,| 00004c30 20 70 21 32 2c 20 70 21 33 2c 20 70 21 34 20 3a | p!2, p!3, p!4 :| 00004c40 3d 20 78 2c 20 79 2c 20 7a 2c 20 74 2c 20 75 0a |= x, y, z, t, u.| 00004c50 20 20 20 52 45 53 55 4c 54 49 53 20 70 0a 24 29 | RESULTIS p.$)| 00004c60 0a 0a 41 4e 44 20 4c 69 73 74 36 28 78 2c 20 79 |..AND List6(x, y| 00004c70 2c 20 7a 2c 20 74 2c 20 75 2c 20 76 29 20 3d 20 |, z, t, u, v) = | 00004c80 56 41 4c 4f 46 0a 24 28 20 4c 45 54 20 70 20 3d |VALOF.$( LET p =| 00004c90 20 47 65 74 42 6c 6b 28 36 29 0a 20 20 20 70 21 | GetBlk(6). p!| 00004ca0 30 2c 20 70 21 31 2c 20 70 21 32 2c 20 70 21 33 |0, p!1, p!2, p!3| 00004cb0 2c 20 70 21 34 2c 20 70 21 35 20 3a 3d 20 78 2c |, p!4, p!5 := x,| 00004cc0 20 79 2c 20 7a 2c 20 74 2c 20 75 2c 20 76 0a 20 | y, z, t, u, v. | 00004cd0 20 20 52 45 53 55 4c 54 49 53 20 70 0a 24 29 0a | RESULTIS p.$).| 00004ce0 0a 41 4e 44 20 47 65 74 4c 69 73 74 45 6c 65 6d |.AND GetListElem| 00004cf0 65 6e 74 28 29 20 3d 20 56 41 4c 4f 46 0a 2f 2f |ent() = VALOF.//| 00004d00 20 47 65 74 73 20 61 20 6e 65 77 20 65 6c 65 6d | Gets a new elem| 00004d10 65 6e 74 20 66 6f 72 20 61 20 27 6d 61 6b 65 6c |ent for a 'makel| 00004d20 69 73 74 27 20 63 68 61 69 6e 2c 20 61 6e 64 0a |ist' chain, and.| 00004d30 2f 2f 20 69 6e 69 74 69 61 6c 69 73 65 73 20 74 |// initialises t| 00004d40 68 65 20 63 6f 75 6e 74 20 61 6e 64 20 6c 69 6e |he count and lin| 00004d50 6b 20 66 69 65 6c 64 73 20 74 6f 20 7a 65 72 6f |k fields to zero| 00004d60 2e 0a 2f 2f 0a 24 28 20 4c 45 54 20 71 20 3d 20 |..//.$( LET q = | 00004d70 66 72 65 65 2e 6c 69 73 74 2e 65 6c 65 6d 65 6e |free.list.elemen| 00004d80 74 2e 63 68 61 69 6e 0a 20 20 20 54 45 53 54 20 |t.chain. TEST | 00004d90 71 3d 30 0a 20 20 20 20 20 20 54 48 45 4e 20 71 |q=0. THEN q| 00004da0 20 3a 3d 20 47 65 74 42 6c 6b 28 6c 69 73 74 2e | := GetBlk(list.| 00004db0 65 6c 65 6d 65 6e 74 2e 73 69 7a 65 29 0a 20 20 |element.size). | 00004dc0 20 20 20 20 45 4c 53 45 20 66 72 65 65 2e 6c 69 | ELSE free.li| 00004dd0 73 74 2e 65 6c 65 6d 65 6e 74 2e 63 68 61 69 6e |st.element.chain| 00004de0 20 3a 3d 20 6c 69 73 74 2e 6c 69 6e 6b 21 71 0a | := list.link!q.| 00004df0 0a 20 20 20 6c 69 73 74 2e 6c 69 6e 6b 20 21 71 |. list.link !q| 00004e00 20 3a 3d 20 30 0a 20 20 20 6c 69 73 74 2e 63 6f | := 0. list.co| 00004e10 75 6e 74 21 71 20 3a 3d 20 30 0a 0a 20 20 20 52 |unt!q := 0.. R| 00004e20 45 53 55 4c 54 49 53 20 71 0a 24 29 0a 0a 41 4e |ESULTIS q.$)..AN| 00004e30 44 20 49 6e 73 65 72 74 49 6e 4c 69 73 74 45 6c |D InsertInListEl| 00004e40 65 6d 65 6e 74 28 6c 76 2e 65 6c 65 6d 65 6e 74 |ement(lv.element| 00004e50 2c 20 64 61 74 61 29 20 42 45 0a 2f 2f 20 49 6e |, data) BE.// In| 00004e60 73 65 72 74 73 20 74 68 65 20 64 61 74 61 20 69 |serts the data i| 00004e70 6e 20 74 68 65 20 6c 69 73 74 20 65 6c 65 6d 65 |n the list eleme| 00004e80 6e 74 20 61 64 64 72 65 73 73 65 64 20 62 79 0a |nt addressed by.| 00004e90 2f 2f 20 74 68 65 20 70 6f 69 6e 74 65 72 20 70 |// the pointer p| 00004ea0 61 72 61 6d 65 74 65 72 2e 0a 2f 2f 0a 24 28 20 |arameter..//.$( | 00004eb0 4c 45 54 20 65 6c 65 6d 65 6e 74 20 3d 20 21 6c |LET element = !l| 00004ec0 76 2e 65 6c 65 6d 65 6e 74 0a 20 20 20 4c 45 54 |v.element. LET| 00004ed0 20 63 20 3d 20 6c 69 73 74 2e 63 6f 75 6e 74 21 | c = list.count!| 00004ee0 65 6c 65 6d 65 6e 74 0a 0a 20 20 20 49 46 20 63 |element.. IF c| 00004ef0 3d 6c 69 73 74 2e 65 6c 65 6d 65 6e 74 2e 64 61 |=list.element.da| 00004f00 74 61 2e 73 69 7a 65 20 54 48 45 4e 0a 20 20 20 |ta.size THEN. | 00004f10 24 28 20 4c 45 54 20 6e 20 3d 20 47 65 74 4c 69 |$( LET n = GetLi| 00004f20 73 74 45 6c 65 6d 65 6e 74 28 29 0a 0a 20 20 20 |stElement().. | 00004f30 20 20 20 6c 69 73 74 2e 6c 69 6e 6b 21 65 6c 65 | list.link!ele| 00004f40 6d 65 6e 74 20 3a 3d 20 6e 0a 20 20 20 20 20 20 |ment := n. | 00004f50 21 6c 76 2e 65 6c 65 6d 65 6e 74 20 3a 3d 20 6e |!lv.element := n| 00004f60 0a 20 20 20 20 20 20 65 6c 65 6d 65 6e 74 20 3a |. element :| 00004f70 3d 20 6e 0a 0a 20 20 20 20 20 20 63 20 3a 3d 20 |= n.. c := | 00004f80 30 20 24 29 0a 20 20 20 28 6c 69 73 74 2e 64 61 |0 $). (list.da| 00004f90 74 61 2b 65 6c 65 6d 65 6e 74 29 21 63 20 3a 3d |ta+element)!c :=| 00004fa0 20 64 61 74 61 0a 20 20 20 6c 69 73 74 2e 63 6f | data. list.co| 00004fb0 75 6e 74 21 65 6c 65 6d 65 6e 74 20 3a 3d 20 63 |unt!element := c| 00004fc0 2b 31 0a 24 29 0a 0a 0a 41 4e 44 20 4d 61 6b 65 |+1.$)...AND Make| 00004fd0 4c 69 73 74 28 6c 69 73 74 2c 6c 69 73 74 65 6e |List(list,listen| 00004fe0 64 2c 74 79 70 65 31 2c 74 79 70 65 32 2c 63 6f |d,type1,type2,co| 00004ff0 75 6e 74 2c 75 6e 69 74 73 69 7a 65 29 3d 56 41 |unt,unitsize)=VA| 00005000 4c 4f 46 0a 2f 2f 20 43 6f 6e 76 65 72 74 73 20 |LOF.// Converts | 00005010 61 20 6c 69 73 74 20 66 6f 72 6d 65 64 20 6f 75 |a list formed ou| 00005020 74 20 6f 66 20 6c 69 73 74 20 65 6c 65 6d 65 6e |t of list elemen| 00005030 74 73 20 69 6e 74 6f 20 61 0a 2f 2f 20 73 74 72 |ts into a.// str| 00005040 61 69 67 68 74 20 74 61 62 6c 65 2e 0a 2f 2f 0a |aight table..//.| 00005050 2f 2f 20 20 20 6c 69 73 74 09 66 69 72 73 74 20 |// list.first | 00005060 65 6c 65 6d 65 6e 74 20 69 6e 20 6c 69 73 74 0a |element in list.| 00005070 2f 2f 20 20 20 6c 69 73 74 65 6e 64 09 6c 61 73 |// listend.las| 00005080 74 20 20 65 6c 65 6d 65 6e 74 20 69 6e 20 6c 69 |t element in li| 00005090 73 74 0a 2f 2f 20 20 20 74 79 70 65 31 09 74 72 |st.// type1.tr| 000050a0 65 65 20 74 79 70 65 20 66 6f 72 20 74 61 62 6c |ee type for tabl| 000050b0 65 0a 2f 2f 20 20 20 74 79 70 65 32 09 74 79 70 |e.// type2.typ| 000050c0 65 20 75 73 65 64 20 66 6f 72 20 70 61 69 72 20 |e used for pair | 000050d0 6f 66 20 75 6e 69 74 73 0a 2f 2f 20 20 20 63 6f |of units.// co| 000050e0 75 6e 74 09 6e 75 6d 62 65 72 20 6f 66 20 64 61 |unt.number of da| 000050f0 74 61 20 77 6f 72 64 73 0a 2f 2f 20 20 20 75 6e |ta words.// un| 00005100 69 74 73 69 7a 65 09 73 69 7a 65 20 6f 66 20 61 |itsize.size of a| 00005110 20 73 69 6e 67 6c 65 20 27 6f 62 6a 65 63 74 27 | single 'object'| 00005120 20 69 6e 20 74 68 65 20 6c 69 73 74 0a 2f 2f 0a | in the list.//.| 00005130 2f 2f 20 49 66 20 74 68 65 20 75 6e 69 74 73 69 |// If the unitsi| 00005140 7a 65 20 69 73 20 6f 6e 65 2c 20 61 6e 64 20 74 |ze is one, and t| 00005150 68 65 72 65 20 69 73 20 6f 6e 65 20 76 61 6c 75 |here is one valu| 00005160 65 20 69 6e 20 74 68 65 0a 2f 2f 20 6c 69 73 74 |e in the.// list| 00005170 2c 20 61 20 74 61 62 6c 65 20 69 73 20 6e 6f 74 |, a table is not| 00005180 20 63 6f 6e 73 74 72 75 63 74 65 64 2e 0a 2f 2f | constructed..//| 00005190 0a 2f 2f 20 49 66 20 74 68 65 72 65 20 61 72 65 |.// If there are| 000051a0 20 74 77 6f 20 6f 62 6a 65 63 74 73 20 61 6e 64 | two objects and| 000051b0 20 27 74 79 70 65 32 27 20 69 73 20 6e 6f 74 20 | 'type2' is not | 000051c0 7a 65 72 6f 2c 20 61 0a 2f 2f 20 70 61 69 72 20 |zero, a.// pair | 000051d0 6f 62 6a 65 63 74 20 69 73 20 72 65 74 75 72 6e |object is return| 000051e0 65 64 2e 0a 2f 2f 0a 24 28 20 4c 45 54 20 72 65 |ed..//.$( LET re| 000051f0 73 75 6c 74 20 3d 20 3f 0a 0a 20 20 20 54 45 53 |sult = ?.. TES| 00005200 54 20 63 6f 75 6e 74 3d 31 20 26 20 75 6e 69 74 |T count=1 & unit| 00005210 73 69 7a 65 3d 31 0a 20 20 20 20 20 20 54 48 45 |size=1. THE| 00005220 4e 20 72 65 73 75 6c 74 20 3a 3d 20 6c 69 73 74 |N result := list| 00005230 2e 64 61 74 61 21 6c 69 73 74 0a 20 20 20 20 20 |.data!list. | 00005240 20 45 4c 53 45 20 24 28 20 4c 45 54 20 6c 20 3d | ELSE $( LET l =| 00005250 20 6c 69 73 74 0a 09 20 20 20 20 20 20 4c 45 54 | list.. LET| 00005260 20 70 20 3d 20 31 0a 0a 09 20 20 20 20 20 20 54 | p = 1... T| 00005270 45 53 54 20 63 6f 75 6e 74 3d 32 2a 75 6e 69 74 |EST count=2*unit| 00005280 73 69 7a 65 20 26 20 74 79 70 65 32 7e 3d 30 0a |size & type2~=0.| 00005290 09 09 20 54 48 45 4e 20 24 28 20 72 65 73 75 6c |.. THEN $( resul| 000052a0 74 20 3a 3d 20 47 65 74 42 6c 6b 28 63 6f 75 6e |t := GetBlk(coun| 000052b0 74 2b 31 29 0a 09 09 09 20 68 31 21 72 65 73 75 |t+1).... h1!resu| 000052c0 6c 74 20 3a 3d 20 74 79 70 65 32 0a 09 09 20 20 |lt := type2... | 000052d0 20 20 20 20 24 29 0a 09 09 20 45 4c 53 45 20 24 | $)... ELSE $| 000052e0 28 20 72 65 73 75 6c 74 20 3a 3d 20 47 65 74 42 |( result := GetB| 000052f0 6c 6b 28 63 6f 75 6e 74 2b 32 29 0a 09 09 09 20 |lk(count+2).... | 00005300 68 31 21 72 65 73 75 6c 74 20 3a 3d 20 74 79 70 |h1!result := typ| 00005310 65 31 0a 09 09 09 20 68 32 21 72 65 73 75 6c 74 |e1.... h2!result| 00005320 20 3a 3d 20 63 6f 75 6e 74 0a 09 09 09 20 70 20 | := count.... p | 00005330 3a 3d 20 32 0a 09 09 20 20 20 20 20 20 24 29 0a |:= 2... $).| 00005340 0a 09 20 20 20 20 20 20 57 48 49 4c 45 20 6c 7e |.. WHILE l~| 00005350 3d 30 20 44 4f 0a 09 20 20 20 20 20 20 24 28 20 |=0 DO.. $( | 00005360 46 4f 52 20 6a 20 3d 20 30 20 54 4f 20 6c 69 73 |FOR j = 0 TO lis| 00005370 74 2e 63 6f 75 6e 74 21 6c 2d 31 20 44 4f 0a 09 |t.count!l-1 DO..| 00005380 09 20 24 28 20 72 65 73 75 6c 74 21 70 20 3a 3d |. $( result!p :=| 00005390 20 28 6c 69 73 74 2e 64 61 74 61 2b 6c 29 21 6a | (list.data+l)!j| 000053a0 0a 09 09 20 20 20 20 70 20 3a 3d 20 70 2b 31 0a |... p := p+1.| 000053b0 09 09 20 24 29 0a 09 09 20 6c 20 3a 3d 20 6c 69 |.. $)... l := li| 000053c0 73 74 2e 6c 69 6e 6b 21 6c 0a 09 20 20 20 20 20 |st.link!l.. | 000053d0 20 24 29 0a 09 20 20 20 24 29 0a 0a 20 20 20 2f | $).. $).. /| 000053e0 2f 20 41 64 64 20 6c 69 73 74 20 74 6f 20 63 68 |/ Add list to ch| 000053f0 61 69 6e 20 6f 66 20 66 72 65 65 20 65 6c 65 6d |ain of free elem| 00005400 65 6e 74 73 0a 0a 20 20 20 6c 69 73 74 2e 6c 69 |ents.. list.li| 00005410 6e 6b 21 6c 69 73 74 65 6e 64 20 3a 3d 20 66 72 |nk!listend := fr| 00005420 65 65 2e 6c 69 73 74 2e 65 6c 65 6d 65 6e 74 2e |ee.list.element.| 00005430 63 68 61 69 6e 0a 20 20 20 66 72 65 65 2e 6c 69 |chain. free.li| 00005440 73 74 2e 65 6c 65 6d 65 6e 74 2e 63 68 61 69 6e |st.element.chain| 00005450 20 3a 3d 20 6c 69 73 74 0a 0a 20 20 20 52 45 53 | := list.. RES| 00005460 55 4c 54 49 53 20 72 65 73 75 6c 74 0a 24 29 0a |ULTIS result.$).| 00005470 0a 41 4e 44 20 53 79 6e 52 65 70 6f 72 74 28 6e |.AND SynReport(n| 00005480 2c 20 61 29 20 42 45 0a 24 28 20 4c 45 54 20 73 |, a) BE.$( LET s| 00005490 20 3d 20 56 41 4c 4f 46 20 53 57 49 54 43 48 4f | = VALOF SWITCHO| 000054a0 4e 20 6e 20 49 4e 54 4f 0a 20 20 20 24 28 20 44 |N n INTO. $( D| 000054b0 45 46 41 55 4c 54 3a 20 61 20 3a 3d 20 6e 0a 09 |EFAULT: a := n..| 000054c0 20 20 20 20 20 20 20 52 45 53 55 4c 54 49 53 20 | RESULTIS | 000054d0 22 45 72 72 6f 72 20 25 4e 22 0a 0a 20 20 20 20 |"Error %N".. | 000054e0 20 20 43 41 53 45 20 31 3a 20 20 52 45 53 55 4c | CASE 1: RESUL| 000054f0 54 49 53 20 22 42 61 64 20 74 61 67 20 73 65 74 |TIS "Bad tag set| 00005500 74 69 6e 67 20 65 78 70 72 65 73 73 69 6f 6e 22 |ting expression"| 00005510 0a 20 20 20 20 20 20 43 41 53 45 20 32 3a 20 20 |. CASE 2: | 00005520 52 45 53 55 4c 54 49 53 20 22 42 61 64 20 74 61 |RESULTIS "Bad ta| 00005530 67 20 6e 61 6d 65 22 0a 20 20 20 20 20 20 43 41 |g name". CA| 00005540 53 45 20 33 3a 20 20 52 45 53 55 4c 54 49 53 20 |SE 3: RESULTIS | 00005550 22 45 6e 64 20 6f 66 20 66 69 6c 65 20 77 68 69 |"End of file whi| 00005560 6c 65 20 73 6b 69 70 70 69 6e 67 20 74 65 78 74 |le skipping text| 00005570 22 0a 20 20 20 20 20 20 43 41 53 45 20 34 3a 20 |". CASE 4: | 00005580 20 52 45 53 55 4c 54 49 53 20 22 54 61 67 20 63 | RESULTIS "Tag c| 00005590 6f 6e 64 69 74 69 6f 6e 73 20 64 6f 20 6e 6f 74 |onditions do not| 000055a0 20 6d 61 74 63 68 22 0a 20 20 20 20 20 20 43 41 | match". CA| 000055b0 53 45 20 35 3a 20 20 52 45 53 55 4c 54 49 53 20 |SE 5: RESULTIS | 000055c0 22 42 61 64 20 63 6f 6e 64 69 74 69 6f 6e 61 6c |"Bad conditional| 000055d0 20 63 6f 6d 70 69 6c 61 74 69 6f 6e 20 6e 65 73 | compilation nes| 000055e0 74 69 6e 67 22 0a 0a 20 20 20 20 20 20 43 41 53 |ting".. CAS| 000055f0 45 20 20 36 3a 20 52 45 53 55 4c 54 49 53 20 22 |E 6: RESULTIS "| 00005600 27 24 28 27 20 65 78 70 65 63 74 65 64 22 0a 20 |'$(' expected". | 00005610 20 20 20 20 20 43 41 53 45 20 20 37 3a 20 52 45 | CASE 7: RE| 00005620 53 55 4c 54 49 53 20 22 27 24 29 27 20 65 78 70 |SULTIS "'$)' exp| 00005630 65 63 74 65 64 22 0a 20 20 20 20 20 20 43 41 53 |ected". CAS| 00005640 45 20 20 38 3a 0a 20 20 20 20 20 20 43 41 53 45 |E 8:. CASE| 00005650 20 34 30 3a 0a 20 20 20 20 20 20 43 41 53 45 20 | 40:. CASE | 00005660 34 33 3a 20 52 45 53 55 4c 54 49 53 20 22 4e 61 |43: RESULTIS "Na| 00005670 6d 65 20 65 78 70 65 63 74 65 64 22 0a 20 20 20 |me expected". | 00005680 20 20 20 43 41 53 45 20 20 39 3a 20 52 45 53 55 | CASE 9: RESU| 00005690 4c 54 49 53 20 22 55 6e 74 61 67 67 65 64 20 27 |LTIS "Untagged '| 000056a0 24 29 27 20 6d 69 73 6d 61 74 63 68 22 0a 20 20 |$)' mismatch". | 000056b0 20 20 20 20 43 41 53 45 20 31 35 3a 0a 20 20 20 | CASE 15:. | 000056c0 20 20 20 43 41 53 45 20 31 39 3a 0a 20 20 20 20 | CASE 19:. | 000056d0 20 20 43 41 53 45 20 34 31 3a 20 52 45 53 55 4c | CASE 41: RESUL| 000056e0 54 49 53 20 22 27 29 27 20 6d 69 73 73 69 6e 67 |TIS "')' missing| 000056f0 22 0a 20 20 20 20 20 20 43 41 53 45 20 33 30 3a |". CASE 30:| 00005700 20 52 45 53 55 4c 54 49 53 20 22 42 61 64 20 63 | RESULTIS "Bad c| 00005710 6f 6e 64 69 74 69 6f 6e 61 6c 20 65 78 70 72 65 |onditional expre| 00005720 73 73 69 6f 6e 22 0a 20 20 20 20 20 20 43 41 53 |ssion". CAS| 00005730 45 20 33 32 3a 20 52 45 53 55 4c 54 49 53 20 22 |E 32: RESULTIS "| 00005740 49 6e 76 61 6c 69 64 20 65 78 70 72 65 73 73 69 |Invalid expressi| 00005750 6f 6e 22 0a 20 20 20 20 20 20 43 41 53 45 20 33 |on". CASE 3| 00005760 33 3a 20 52 45 53 55 4c 54 49 53 20 22 42 61 64 |3: RESULTIS "Bad| 00005770 20 6e 75 6d 62 65 72 22 0a 20 20 20 20 20 20 43 | number". C| 00005780 41 53 45 20 33 34 3a 20 52 45 53 55 4c 54 49 53 |ASE 34: RESULTIS| 00005790 20 22 42 61 64 20 73 74 72 69 6e 67 20 6f 72 20 | "Bad string or | 000057a0 63 68 61 72 61 63 74 65 72 20 63 6f 6e 73 74 61 |character consta| 000057b0 6e 74 22 0a 20 20 20 20 20 20 43 41 53 45 20 33 |nt". CASE 3| 000057c0 35 3a 20 52 45 53 55 4c 54 49 53 20 22 42 61 64 |5: RESULTIS "Bad| 000057d0 20 65 73 63 61 70 65 20 69 6e 20 73 74 72 69 6e | escape in strin| 000057e0 67 20 6f 72 20 63 68 61 72 61 63 74 65 72 22 0a |g or character".| 000057f0 20 20 20 20 20 20 43 41 53 45 20 34 32 3a 20 52 | CASE 42: R| 00005800 45 53 55 4c 54 49 53 20 22 42 61 64 20 70 72 6f |ESULTIS "Bad pro| 00005810 63 65 64 75 72 65 20 68 65 61 64 69 6e 67 22 0a |cedure heading".| 00005820 20 20 20 20 20 20 43 41 53 45 20 34 34 3a 0a 20 | CASE 44:. | 00005830 20 20 20 20 20 43 41 53 45 20 34 35 3a 20 52 45 | CASE 45: RE| 00005840 53 55 4c 54 49 53 20 22 42 61 64 20 64 65 63 6c |SULTIS "Bad decl| 00005850 61 72 61 74 69 6f 6e 22 0a 20 20 20 20 20 20 43 |aration". C| 00005860 41 53 45 20 35 30 3a 20 52 45 53 55 4c 54 49 53 |ASE 50: RESULTIS| 00005870 20 22 55 6e 65 78 70 65 63 74 65 64 20 27 3a 27 | "Unexpected ':'| 00005880 22 0a 20 20 20 20 20 20 43 41 53 45 20 35 31 3a |". CASE 51:| 00005890 20 52 45 53 55 4c 54 49 53 20 22 49 6e 76 61 6c | RESULTIS "Inval| 000058a0 69 64 20 63 6f 6d 6d 61 6e 64 22 0a 20 20 20 20 |id command". | 000058b0 20 20 43 41 53 45 20 35 34 3a 20 52 45 53 55 4c | CASE 54: RESUL| 000058c0 54 49 53 20 22 27 45 4c 53 45 27 20 65 78 70 65 |TIS "'ELSE' expe| 000058d0 63 74 65 64 22 0a 20 20 20 20 20 20 43 41 53 45 |cted". CASE| 000058e0 20 35 37 3a 0a 20 20 20 20 20 20 43 41 53 45 20 | 57:. CASE | 000058f0 35 38 3a 20 52 45 53 55 4c 54 49 53 20 22 42 61 |58: RESULTIS "Ba| 00005900 64 20 46 4f 52 20 6c 6f 6f 70 22 0a 20 20 20 20 |d FOR loop". | 00005910 20 20 43 41 53 45 20 36 30 3a 20 52 45 53 55 4c | CASE 60: RESUL| 00005920 54 49 53 20 22 27 49 4e 54 4f 27 20 65 78 70 65 |TIS "'INTO' expe| 00005930 63 74 65 64 22 0a 20 20 20 20 20 20 43 41 53 45 |cted". CASE| 00005940 20 36 31 3a 0a 20 20 20 20 20 20 43 41 53 45 20 | 61:. CASE | 00005950 36 32 3a 20 52 45 53 55 4c 54 49 53 20 22 27 3a |62: RESULTIS "':| 00005960 27 20 65 78 70 65 63 74 65 64 22 0a 20 20 20 20 |' expected". | 00005970 20 20 43 41 53 45 20 36 33 3a 20 52 45 53 55 4c | CASE 63: RESUL| 00005980 54 49 53 20 22 27 2a 2a 2f 27 20 6d 69 73 73 69 |TIS "'**/' missi| 00005990 6e 67 22 0a 20 20 20 20 20 20 43 41 53 45 20 39 |ng". CASE 9| 000059a0 31 3a 20 52 45 53 55 4c 54 49 53 20 22 27 24 27 |1: RESULTIS "'$'| 000059b0 20 6f 75 74 20 6f 66 20 63 6f 6e 74 65 78 74 22 | out of context"| 000059c0 0a 20 20 20 20 20 20 43 41 53 45 20 39 34 3a 20 |. CASE 94: | 000059d0 52 45 53 55 4c 54 49 53 20 22 49 6c 6c 65 67 61 |RESULTIS "Illega| 000059e0 6c 20 63 68 61 72 61 63 74 65 72 22 0a 20 20 20 |l character". | 000059f0 20 20 20 43 41 53 45 20 39 35 3a 20 52 45 53 55 | CASE 95: RESU| 00005a00 4c 54 49 53 20 22 49 6c 6c 65 67 61 6c 20 73 65 |LTIS "Illegal se| 00005a10 63 74 69 6f 6e 20 6e 61 6d 65 22 0a 20 20 20 20 |ction name". | 00005a20 20 20 43 41 53 45 20 39 36 3a 20 72 63 20 3a 3d | CASE 96: rc :=| 00005a30 20 32 30 0a 09 20 20 20 20 20 20 20 52 45 53 55 | 20.. RESU| 00005a40 4c 54 49 53 20 22 43 61 6e 27 74 20 47 45 54 20 |LTIS "Can't GET | 00005a50 2a 22 25 53 2a 22 20 2d 20 22 0a 20 20 20 20 20 |*"%S*" - ". | 00005a60 20 43 41 53 45 20 39 37 3a 20 52 45 53 55 4c 54 | CASE 97: RESULT| 00005a70 49 53 20 22 42 61 64 20 47 45 54 20 64 69 72 65 |IS "Bad GET dire| 00005a80 63 74 69 76 65 22 0a 20 20 20 20 20 20 43 41 53 |ctive". CAS| 00005a90 45 20 39 39 3a 20 52 45 53 55 4c 54 49 53 20 22 |E 99: RESULTIS "| 00005aa0 49 6e 63 6f 72 72 65 63 74 20 74 65 72 6d 69 6e |Incorrect termin| 00005ab0 61 74 69 6f 6e 22 0a 20 20 20 20 20 20 43 41 53 |ation". CAS| 00005ac0 45 20 31 30 30 3a 52 45 53 55 4c 54 49 53 20 22 |E 100:RESULTIS "| 00005ad0 42 61 64 20 65 78 74 65 72 6e 61 6c 20 6e 61 6d |Bad external nam| 00005ae0 65 20 73 74 72 69 6e 67 22 0a 20 20 20 20 20 20 |e string". | 00005af0 43 41 53 45 20 31 30 31 3a 52 45 53 55 4c 54 49 |CASE 101:RESULTI| 00005b00 53 20 22 49 6e 76 61 6c 69 64 20 75 73 65 20 6f |S "Invalid use o| 00005b10 66 20 73 79 6d 62 6f 6c 22 0a 20 20 20 24 29 0a |f symbol". $).| 00005b20 0a 20 20 20 49 46 20 72 63 3c 31 30 20 54 48 45 |. IF rc<10 THE| 00005b30 4e 20 72 63 20 3a 3d 20 31 30 0a 0a 20 20 20 57 |N rc := 10.. W| 00005b40 72 69 74 65 46 28 22 2a 4e 45 72 72 6f 72 20 6e |riteF("*NError n| 00005b50 65 61 72 20 6c 69 6e 65 20 25 4e 3a 20 20 22 2c |ear line %N: ",| 00005b60 20 6c 69 6e 65 43 6f 75 6e 74 29 0a 20 20 20 57 | lineCount). W| 00005b70 72 69 74 65 46 28 73 2c 20 61 29 0a 0a 62 72 6b |riteF(s, a)..brk| 00005b80 3a 0a 20 20 20 49 46 20 72 63 3e 3d 32 30 20 54 |:. IF rc>=20 T| 00005b90 48 45 4e 0a 20 20 20 24 28 20 57 72 69 74 65 53 |HEN. $( WriteS| 00005ba0 28 22 63 6f 6d 70 69 6c 61 74 69 6f 6e 20 61 62 |("compilation ab| 00005bb0 61 6e 64 6f 6e 65 64 2a 4e 22 29 0a 0a 20 20 20 |andoned*N").. | 00005bc0 20 20 20 57 48 49 4c 45 20 67 65 74 70 7e 3d 30 | WHILE getp~=0| 00005bd0 20 44 4f 0a 20 20 20 20 20 20 24 28 20 43 6c 6f | DO. $( Clo| 00005be0 73 65 28 73 6f 75 72 63 65 53 74 72 65 61 6d 29 |se(sourceStream)| 00005bf0 0a 09 20 67 65 74 70 20 3a 3d 20 67 65 74 70 2d |.. getp := getp-| 00005c00 33 0a 09 20 73 6f 75 72 63 65 53 74 72 65 61 6d |3.. sourceStream| 00005c10 20 3a 3d 20 67 65 74 76 21 67 65 74 70 0a 09 20 | := getv!getp.. | 00005c20 53 65 6c 65 63 74 49 6e 70 75 74 28 73 6f 75 72 |SelectInput(sour| 00005c30 63 65 53 74 72 65 61 6d 29 0a 20 20 20 20 20 20 |ceStream). | 00005c40 24 29 0a 20 20 20 20 20 20 4c 6f 6e 67 4a 75 6d |$). LongJum| 00005c50 70 28 65 72 72 2e 70 2c 65 72 72 2e 6c 29 0a 20 |p(err.p,err.l). | 00005c60 20 20 24 29 0a 20 20 20 57 72 43 68 42 75 66 28 | $). WrChBuf(| 00005c70 29 0a 20 20 20 6e 6c 50 65 6e 64 69 6e 67 20 3a |). nlPending :| 00005c80 3d 20 46 41 4c 53 45 0a 0a 20 20 20 55 4e 54 49 |= FALSE.. UNTI| 00005c90 4c 20 73 79 6d 62 3d 73 2e 6c 73 65 63 74 20 7c |L symb=s.lsect || 00005ca0 20 73 79 6d 62 3d 73 2e 72 73 65 63 74 20 7c 0a | symb=s.rsect |.| 00005cb0 09 20 73 79 6d 62 3d 73 2e 6c 65 74 20 20 20 7c |. symb=s.let || 00005cc0 20 73 79 6d 62 3d 73 2e 61 6e 64 20 20 20 7c 0a | symb=s.and |.| 00005cd0 09 20 73 79 6d 62 3d 73 2e 65 6e 64 20 20 20 7c |. symb=s.end || 00005ce0 20 6e 6c 50 65 6e 64 69 6e 67 20 44 4f 20 4e 65 | nlPending DO Ne| 00005cf0 78 74 53 79 6d 62 28 29 0a 0a 20 20 20 4c 6f 6e |xtSymb().. Lon| 00005d00 67 4a 75 6d 70 28 72 65 63 2e 70 2c 20 72 65 63 |gJump(rec.p, rec| 00005d10 2e 6c 29 0a 24 29 0a 0a 41 4e 44 20 57 72 43 68 |.l).$)..AND WrCh| 00005d20 42 75 66 28 29 20 42 45 0a 24 28 20 57 72 69 74 |Buf() BE.$( Writ| 00005d30 65 53 28 22 2a 4e 2e 2e 2e 22 29 0a 0a 20 20 20 |eS("*N...").. | 00005d40 46 4f 52 20 70 20 3d 20 63 68 63 6f 75 6e 74 2d |FOR p = chcount-| 00005d50 36 33 20 54 4f 20 63 68 63 6f 75 6e 74 20 44 4f |63 TO chcount DO| 00005d60 0a 20 20 20 24 28 20 4c 45 54 20 6b 20 3d 20 63 |. $( LET k = c| 00005d70 68 62 75 66 21 28 70 26 36 33 29 0a 20 20 20 20 |hbuf!(p&63). | 00005d80 20 20 49 46 20 6b 3e 30 20 54 48 45 4e 20 57 72 | IF k>0 THEN Wr| 00005d90 43 68 28 6b 29 0a 20 20 20 24 29 0a 20 20 20 4e |Ch(k). $). N| 00005da0 65 77 4c 69 6e 65 28 29 0a 24 29 0a 0a 41 4e 44 |ewLine().$)..AND| 00005db0 20 52 64 42 6c 6f 63 6b 42 6f 64 79 28 29 20 3d | RdBlockBody() =| 00005dc0 20 56 41 4c 4f 46 0a 24 28 20 4c 45 54 20 70 2c | VALOF.$( LET p,| 00005dd0 20 6c 20 3d 20 72 65 63 2e 70 2c 20 72 65 63 2e | l = rec.p, rec.| 00005de0 6c 0a 20 20 20 4c 45 54 20 61 20 3d 20 30 0a 20 |l. LET a = 0. | 00005df0 20 20 4c 45 54 20 70 74 72 20 3d 20 40 61 0a 0a | LET ptr = @a..| 00005e00 20 20 20 24 28 20 4c 45 54 20 6f 70 20 3d 20 30 | $( LET op = 0| 00005e10 0a 20 20 20 20 20 20 72 65 63 2e 70 2c 20 72 65 |. rec.p, re| 00005e20 63 2e 6c 20 3a 3d 20 4c 65 76 65 6c 28 29 2c 20 |c.l := Level(), | 00005e30 72 65 63 6f 76 65 72 0a 20 20 20 20 20 20 49 67 |recover. Ig| 00005e40 6e 6f 72 65 28 73 2e 73 65 6d 69 63 6f 6c 6f 6e |nore(s.semicolon| 00005e50 29 0a 0a 20 20 20 20 20 20 53 57 49 54 43 48 4f |).. SWITCHO| 00005e60 4e 20 73 79 6d 62 20 49 4e 54 4f 0a 20 20 20 20 |N symb INTO. | 00005e70 20 20 24 28 20 43 41 53 45 20 73 2e 6d 61 6e 69 | $( CASE s.mani| 00005e80 66 65 73 74 3a 0a 09 20 43 41 53 45 20 73 2e 73 |fest:.. CASE s.s| 00005e90 74 61 74 69 63 3a 0a 09 20 43 41 53 45 20 73 2e |tatic:.. CASE s.| 00005ea0 67 6c 6f 62 61 6c 3a 0a 09 20 43 41 53 45 20 73 |global:.. CASE s| 00005eb0 2e 65 78 74 65 72 6e 61 6c 3a 0a 09 20 20 20 6f |.external:.. o| 00005ec0 70 20 3a 3d 20 73 79 6d 62 0a 09 20 20 20 4e 65 |p := symb.. Ne| 00005ed0 78 74 53 79 6d 62 28 29 0a 09 20 20 20 21 70 74 |xtSymb().. !pt| 00005ee0 72 20 3a 3d 20 52 64 53 65 63 74 28 52 64 43 44 |r := RdSect(RdCD| 00005ef0 65 66 73 2c 20 6f 70 29 0a 09 20 20 20 45 4e 44 |efs, op).. END| 00005f00 43 41 53 45 0a 0a 09 20 43 41 53 45 20 73 2e 6c |CASE... CASE s.l| 00005f10 65 74 3a 0a 09 20 20 20 4e 65 78 74 53 79 6d 62 |et:.. NextSymb| 00005f20 28 29 0a 09 20 20 20 21 70 74 72 20 3a 3d 20 52 |().. !ptr := R| 00005f30 44 65 66 28 29 0a 20 20 72 65 63 6f 76 65 72 3a |Def(). recover:| 00005f40 0a 09 20 20 20 24 28 20 4c 45 54 20 71 74 72 20 |.. $( LET qtr | 00005f50 3d 20 70 74 72 0a 0a 09 20 20 20 20 20 20 57 48 |= ptr... WH| 00005f60 49 4c 45 20 73 79 6d 62 3d 73 2e 61 6e 64 20 44 |ILE symb=s.and D| 00005f70 4f 0a 09 20 20 20 20 20 20 24 28 20 4e 65 78 74 |O.. $( Next| 00005f80 53 79 6d 62 28 29 0a 09 09 20 21 71 74 72 20 3a |Symb()... !qtr :| 00005f90 3d 20 4c 69 73 74 33 28 73 2e 61 6e 64 2c 20 21 |= List3(s.and, !| 00005fa0 71 74 72 2c 20 52 44 65 66 28 29 29 0a 09 09 20 |qtr, RDef())... | 00005fb0 71 74 72 20 3a 3d 20 40 68 33 21 28 21 71 74 72 |qtr := @h3!(!qtr| 00005fc0 29 0a 09 20 20 20 20 20 20 24 29 0a 09 20 20 20 |).. $).. | 00005fd0 20 20 20 6f 70 20 3a 3d 20 73 2e 6c 65 74 0a 09 | op := s.let..| 00005fe0 20 20 20 20 20 20 45 4e 44 43 41 53 45 0a 09 20 | ENDCASE.. | 00005ff0 20 20 24 29 0a 0a 09 20 44 45 46 41 55 4c 54 3a | $)... DEFAULT:| 00006000 0a 09 20 20 20 21 70 74 72 20 3a 3d 20 52 64 53 |.. !ptr := RdS| 00006010 65 71 28 29 0a 09 20 20 20 49 46 20 73 79 6d 62 |eq().. IF symb| 00006020 7e 3d 73 2e 72 73 65 63 74 20 26 20 73 79 6d 62 |~=s.rsect & symb| 00006030 7e 3d 73 2e 65 6e 64 20 54 48 45 4e 20 53 79 6e |~=s.end THEN Syn| 00006040 52 65 70 6f 72 74 28 35 31 29 0a 0a 09 20 43 41 |Report(51)... CA| 00006050 53 45 20 73 2e 72 73 65 63 74 3a 20 43 41 53 45 |SE s.rsect: CASE| 00006060 20 73 2e 65 6e 64 3a 0a 09 20 20 20 42 52 45 41 | s.end:.. BREA| 00006070 4b 0a 20 20 20 20 20 20 24 29 0a 20 20 20 20 20 |K. $). | 00006080 20 21 70 74 72 20 3a 3d 20 4c 69 73 74 33 28 6f | !ptr := List3(o| 00006090 70 2c 21 70 74 72 2c 20 30 29 0a 20 20 20 20 20 |p,!ptr, 0). | 000060a0 20 70 74 72 20 3a 3d 20 40 68 33 21 28 21 70 74 | ptr := @h3!(!pt| 000060b0 72 29 0a 0a 20 20 20 24 29 20 52 45 50 45 41 54 |r).. $) REPEAT| 000060c0 0a 20 20 20 72 65 63 2e 70 2c 20 72 65 63 2e 6c |. rec.p, rec.l| 000060d0 20 3a 3d 20 70 2c 20 6c 0a 20 20 20 52 45 53 55 | := p, l. RESU| 000060e0 4c 54 49 53 20 61 0a 24 29 0a 0a 41 4e 44 20 52 |LTIS a.$)..AND R| 000060f0 64 53 65 71 28 29 20 3d 20 56 41 4c 4f 46 0a 24 |dSeq() = VALOF.$| 00006100 28 20 4c 45 54 20 6e 20 3d 20 30 0a 20 20 20 4c |( LET n = 0. L| 00006110 45 54 20 6c 69 73 74 20 3d 20 47 65 74 4c 69 73 |ET list = GetLis| 00006120 74 45 6c 65 6d 65 6e 74 28 29 0a 20 20 20 4c 45 |tElement(). LE| 00006130 54 20 6c 69 73 74 65 20 3d 20 6c 69 73 74 0a 0a |T liste = list..| 00006140 20 20 20 24 28 20 4c 45 54 20 6c 63 20 3d 20 3f | $( LET lc = ?| 00006150 0a 20 20 20 20 20 20 49 67 6e 6f 72 65 28 73 2e |. Ignore(s.| 00006160 73 65 6d 69 63 6f 6c 6f 6e 29 0a 0a 20 20 20 20 |semicolon).. | 00006170 20 20 6c 63 20 3a 3d 20 6c 69 6e 65 43 6f 75 6e | lc := lineCoun| 00006180 74 0a 20 20 20 20 20 20 49 6e 73 65 72 74 49 6e |t. InsertIn| 00006190 4c 69 73 74 45 6c 65 6d 65 6e 74 28 40 6c 69 73 |ListElement(@lis| 000061a0 74 65 2c 20 72 63 6f 6d 28 29 29 0a 20 20 20 20 |te, rcom()). | 000061b0 20 20 49 6e 73 65 72 74 49 6e 4c 69 73 74 45 6c | InsertInListEl| 000061c0 65 6d 65 6e 74 28 40 6c 69 73 74 65 2c 20 6c 63 |ement(@liste, lc| 000061d0 29 0a 20 20 20 20 20 20 6e 20 3a 3d 20 20 6e 2b |). n := n+| 000061e0 32 0a 0a 20 20 20 24 29 20 52 45 50 45 41 54 55 |2.. $) REPEATU| 000061f0 4e 54 49 4c 20 73 79 6d 62 3d 73 2e 72 73 65 63 |NTIL symb=s.rsec| 00006200 74 20 7c 20 73 79 6d 62 3d 73 2e 65 6e 64 0a 0a |t | symb=s.end..| 00006210 20 20 20 52 45 53 55 4c 54 49 53 20 4d 61 6b 65 | RESULTIS Make| 00006220 4c 69 73 74 28 6c 69 73 74 2c 20 6c 69 73 74 65 |List(list, liste| 00006230 2c 20 73 2e 73 65 6d 69 63 6f 6c 6f 6e 6c 69 73 |, s.semicolonlis| 00006240 74 2c 0a 09 09 09 09 20 20 73 2e 73 65 6d 69 63 |t,..... s.semic| 00006250 6f 6c 6f 6e 2c 20 6e 2c 20 32 29 0a 24 29 0a 0a |olon, n, 2).$)..| 00006260 41 4e 44 20 52 64 43 44 65 66 73 28 6f 70 29 20 |AND RdCDefs(op) | 00006270 3d 20 56 41 4c 4f 46 0a 24 28 20 4c 45 54 20 6e |= VALOF.$( LET n| 00006280 20 3d 20 20 30 0a 20 20 20 4c 45 54 20 6c 69 73 | = 0. LET lis| 00006290 74 20 3d 20 47 65 74 4c 69 73 74 45 6c 65 6d 65 |t = GetListEleme| 000062a0 6e 74 28 29 0a 20 20 20 4c 45 54 20 6c 69 73 74 |nt(). LET list| 000062b0 65 20 3d 20 6c 69 73 74 0a 20 20 20 4c 45 54 20 |e = list. LET | 000062c0 70 2c 20 6c 20 3d 20 72 65 63 2e 70 2c 20 72 65 |p, l = rec.p, re| 000062d0 63 2e 6c 0a 0a 20 20 20 24 28 20 4c 45 54 20 6c |c.l.. $( LET l| 000062e0 63 20 3d 20 3f 0a 20 20 20 20 20 20 4c 45 54 20 |c = ?. LET | 000062f0 65 20 3d 20 30 0a 0a 20 20 20 20 20 20 72 65 63 |e = 0.. rec| 00006300 2e 70 2c 20 72 65 63 2e 6c 20 3a 3d 20 4c 65 76 |.p, rec.l := Lev| 00006310 65 6c 28 29 2c 20 72 65 63 0a 0a 20 20 20 20 20 |el(), rec.. | 00006320 20 49 6e 73 65 72 74 49 6e 4c 69 73 74 45 6c 65 | InsertInListEle| 00006330 6d 65 6e 74 28 40 6c 69 73 74 65 2c 20 52 4e 61 |ment(@liste, RNa| 00006340 6d 65 28 29 29 0a 20 20 20 20 20 20 6c 63 20 3a |me()). lc :| 00006350 3d 20 6c 69 6e 65 43 6f 75 6e 74 0a 0a 20 20 20 |= lineCount.. | 00006360 20 20 20 49 46 20 73 79 6d 62 7e 3d 73 2e 65 71 | IF symb~=s.eq| 00006370 20 26 20 73 79 6d 62 7e 3d 73 2e 63 6f 6c 6f 6e | & symb~=s.colon| 00006380 20 54 48 45 4e 20 53 79 6e 52 65 70 6f 72 74 28 | THEN SynReport(| 00006390 34 35 29 0a 0a 20 20 20 20 20 20 4e 65 78 74 53 |45).. NextS| 000063a0 79 6d 62 28 29 0a 0a 20 20 20 20 20 20 54 45 53 |ymb().. TES| 000063b0 54 20 6f 70 3d 73 2e 65 78 74 65 72 6e 61 6c 0a |T op=s.external.| 000063c0 09 20 54 48 45 4e 20 24 28 20 49 46 20 73 79 6d |. THEN $( IF sym| 000063d0 62 7e 3d 73 2e 73 74 72 69 6e 67 20 54 48 45 4e |b~=s.string THEN| 000063e0 20 53 79 6e 52 65 70 6f 72 74 28 31 30 30 29 0a | SynReport(100).| 000063f0 09 09 20 65 20 3a 3d 20 4c 69 73 74 34 28 65 78 |.. e := List4(ex| 00006400 74 65 72 6e 61 6c 73 2e 6c 69 73 74 2c 20 52 62 |ternals.list, Rb| 00006410 45 78 70 28 29 2b 31 2c 20 30 2c 20 30 29 0a 09 |Exp()+1, 0, 0)..| 00006420 09 20 65 78 74 65 72 6e 61 6c 73 2e 6c 69 73 74 |. externals.list| 00006430 20 3a 3d 20 65 0a 09 20 20 20 20 20 20 24 29 0a | := e.. $).| 00006440 09 20 45 4c 53 45 20 65 20 3a 3d 20 52 45 78 70 |. ELSE e := RExp| 00006450 28 30 29 0a 0a 72 65 63 3a 20 20 6e 20 3a 3d 20 |(0)..rec: n := | 00006460 6e 2b 33 0a 20 20 20 20 20 20 49 6e 73 65 72 74 |n+3. Insert| 00006470 49 6e 4c 69 73 74 45 6c 65 6d 65 6e 74 28 40 6c |InListElement(@l| 00006480 69 73 74 65 2c 20 65 29 0a 20 20 20 20 20 20 49 |iste, e). I| 00006490 67 6e 6f 72 65 28 73 2e 73 65 6d 69 63 6f 6c 6f |gnore(s.semicolo| 000064a0 6e 29 0a 20 20 20 20 20 20 49 6e 73 65 72 74 49 |n). InsertI| 000064b0 6e 4c 69 73 74 45 6c 65 6d 65 6e 74 28 40 6c 69 |nListElement(@li| 000064c0 73 74 65 2c 20 6c 63 29 0a 0a 20 20 20 24 29 20 |ste, lc).. $) | 000064d0 52 45 50 45 41 54 57 48 49 4c 45 20 73 79 6d 62 |REPEATWHILE symb| 000064e0 3d 73 2e 6e 61 6d 65 0a 0a 20 20 20 72 65 63 2e |=s.name.. rec.| 000064f0 70 2c 20 72 65 63 2e 6c 20 3a 3d 20 70 2c 20 6c |p, rec.l := p, l| 00006500 0a 0a 20 20 20 52 45 53 55 4c 54 49 53 20 4d 61 |.. RESULTIS Ma| 00006510 6b 65 4c 69 73 74 28 6c 69 73 74 2c 20 6c 69 73 |keList(list, lis| 00006520 74 65 2c 20 73 2e 73 65 6d 69 63 6f 6c 6f 6e 6c |te, s.semicolonl| 00006530 69 73 74 2c 20 30 2c 20 6e 2c 33 29 0a 24 29 0a |ist, 0, n,3).$).| 00006540 0a 41 4e 44 20 52 64 53 65 63 74 28 72 2c 20 61 |.AND RdSect(r, a| 00006550 72 67 29 20 3d 20 56 41 4c 4f 46 0a 24 28 20 4c |rg) = VALOF.$( L| 00006560 45 54 20 74 61 67 2c 20 61 20 3d 20 77 6f 72 64 |ET tag, a = word| 00006570 4e 6f 64 65 2c 20 30 0a 0a 20 20 20 43 68 65 63 |Node, 0.. Chec| 00006580 6b 46 6f 72 28 73 2e 6c 73 65 63 74 2c 20 36 29 |kFor(s.lsect, 6)| 00006590 0a 20 20 20 61 20 3a 3d 20 72 28 61 72 67 29 0a |. a := r(arg).| 000065a0 0a 20 20 20 49 46 20 73 79 6d 62 7e 3d 73 2e 72 |. IF symb~=s.r| 000065b0 73 65 63 74 20 54 48 45 4e 20 53 79 6e 52 65 70 |sect THEN SynRep| 000065c0 6f 72 74 28 37 29 0a 0a 20 20 20 54 45 53 54 20 |ort(7).. TEST | 000065d0 74 61 67 3d 77 6f 72 64 4e 6f 64 65 0a 20 20 20 |tag=wordNode. | 000065e0 20 20 20 54 48 45 4e 20 4e 65 78 74 53 79 6d 62 | THEN NextSymb| 000065f0 28 29 0a 20 20 20 20 20 20 45 4c 53 45 20 49 46 |(). ELSE IF| 00006600 20 77 6f 72 64 4e 6f 64 65 3d 6e 75 6c 6c 74 61 | wordNode=nullta| 00006610 67 20 54 48 45 4e 0a 20 20 20 20 20 20 20 24 28 |g THEN. $(| 00006620 20 73 79 6d 62 20 3a 3d 20 30 0a 09 20 20 53 79 | symb := 0.. Sy| 00006630 6e 52 65 70 6f 72 74 28 39 29 0a 20 20 20 20 20 |nReport(9). | 00006640 20 20 24 29 0a 20 20 20 52 45 53 55 4c 54 49 53 | $). RESULTIS| 00006650 20 61 0a 24 29 0a 0a 41 4e 44 20 52 4e 61 6d 65 | a.$)..AND RName| 00006660 6c 69 73 74 28 29 20 3d 20 56 41 4c 4f 46 0a 24 |list() = VALOF.$| 00006670 28 20 4c 45 54 20 6e 20 3d 20 20 30 0a 20 20 20 |( LET n = 0. | 00006680 4c 45 54 20 6c 69 73 74 20 3d 20 47 65 74 4c 69 |LET list = GetLi| 00006690 73 74 45 6c 65 6d 65 6e 74 28 29 0a 20 20 20 4c |stElement(). L| 000066a0 45 54 20 6c 69 73 74 65 20 3d 20 6c 69 73 74 0a |ET liste = list.| 000066b0 0a 20 20 20 24 28 20 49 6e 73 65 72 74 49 6e 4c |. $( InsertInL| 000066c0 69 73 74 45 6c 65 6d 65 6e 74 28 40 6c 69 73 74 |istElement(@list| 000066d0 65 2c 20 52 4e 61 6d 65 28 29 29 0a 20 20 20 20 |e, RName()). | 000066e0 20 20 6e 20 3a 3d 20 6e 2b 31 0a 20 20 20 20 20 | n := n+1. | 000066f0 20 49 46 20 73 79 6d 62 7e 3d 73 2e 63 6f 6d 6d | IF symb~=s.comm| 00006700 61 20 54 48 45 4e 20 42 52 45 41 4b 0a 20 20 20 |a THEN BREAK. | 00006710 20 20 20 4e 65 78 74 53 79 6d 62 28 29 0a 20 20 | NextSymb(). | 00006720 20 24 29 20 52 45 50 45 41 54 0a 0a 20 20 20 52 | $) REPEAT.. R| 00006730 45 53 55 4c 54 49 53 20 4d 61 6b 65 4c 69 73 74 |ESULTIS MakeList| 00006740 28 6c 69 73 74 2c 6c 69 73 74 65 2c 73 2e 63 6f |(list,liste,s.co| 00006750 6d 6d 61 6c 69 73 74 2c 73 2e 63 6f 6d 6d 61 2c |mmalist,s.comma,| 00006760 6e 2c 31 29 0a 24 29 0a 0a 41 4e 44 20 52 4e 61 |n,1).$)..AND RNa| 00006770 6d 65 28 29 20 3d 20 56 41 4c 4f 46 0a 24 28 20 |me() = VALOF.$( | 00006780 4c 45 54 20 61 20 3d 20 77 6f 72 64 4e 6f 64 65 |LET a = wordNode| 00006790 0a 20 20 20 43 68 65 63 6b 46 6f 72 28 73 2e 6e |. CheckFor(s.n| 000067a0 61 6d 65 2c 20 38 29 0a 20 20 20 52 45 53 55 4c |ame, 8). RESUL| 000067b0 54 49 53 20 61 0a 24 29 0a 0a 41 4e 44 20 49 67 |TIS a.$)..AND Ig| 000067c0 6e 6f 72 65 28 69 74 65 6d 29 20 42 45 0a 20 20 |nore(item) BE. | 000067d0 49 46 20 73 79 6d 62 3d 69 74 65 6d 20 54 48 45 |IF symb=item THE| 000067e0 4e 0a 20 20 20 20 4e 65 78 74 53 79 6d 62 28 29 |N. NextSymb()| 000067f0 0a 0a 41 4e 44 20 43 68 65 63 6b 46 6f 72 28 69 |..AND CheckFor(i| 00006800 74 65 6d 2c 20 6e 29 20 42 45 0a 24 28 20 49 46 |tem, n) BE.$( IF| 00006810 20 73 79 6d 62 7e 3d 69 74 65 6d 20 54 48 45 4e | symb~=item THEN| 00006820 20 53 79 6e 52 65 70 6f 72 74 28 6e 29 0a 20 20 | SynReport(n). | 00006830 20 4e 65 78 74 53 79 6d 62 28 29 0a 24 29 0a 0a | NextSymb().$)..| 00006840 41 4e 44 20 52 62 45 78 70 28 29 20 3d 20 56 41 |AND RbExp() = VA| 00006850 4c 4f 46 0a 24 28 20 4c 45 54 20 61 2c 20 6f 70 |LOF.$( LET a, op| 00006860 20 3d 20 30 2c 20 73 79 6d 62 0a 0a 20 20 20 53 | = 0, symb.. S| 00006870 57 49 54 43 48 4f 4e 20 73 79 6d 62 20 49 4e 54 |WITCHON symb INT| 00006880 4f 0a 20 20 20 24 28 20 44 45 46 41 55 4c 54 3a |O. $( DEFAULT:| 00006890 0a 09 53 79 6e 52 65 70 6f 72 74 28 33 32 29 0a |..SynReport(32).| 000068a0 0a 20 20 20 20 20 20 43 41 53 45 20 73 2e 62 61 |. CASE s.ba| 000068b0 64 3a 0a 09 53 79 6e 52 65 70 6f 72 74 28 31 30 |d:..SynReport(10| 000068c0 31 29 0a 0a 20 20 20 20 20 20 43 41 53 45 20 73 |1).. CASE s| 000068d0 2e 71 75 65 72 79 3a 0a 09 4e 65 78 74 53 79 6d |.query:..NextSym| 000068e0 62 28 29 0a 09 52 45 53 55 4c 54 49 53 20 4c 69 |b()..RESULTIS Li| 000068f0 73 74 31 28 73 2e 71 75 65 72 79 29 0a 0a 20 20 |st1(s.query).. | 00006900 20 20 20 20 43 41 53 45 20 73 2e 74 72 75 65 3a | CASE s.true:| 00006910 20 43 41 53 45 20 73 2e 66 61 6c 73 65 3a 0a 20 | CASE s.false:. | 00006920 20 20 20 20 20 43 41 53 45 20 73 2e 6e 61 6d 65 | CASE s.name| 00006930 3a 0a 20 20 20 20 20 20 43 41 53 45 20 73 2e 6e |:. CASE s.n| 00006940 69 6c 3a 0a 09 61 20 3a 3d 20 77 6f 72 64 4e 6f |il:..a := wordNo| 00006950 64 65 0a 09 4e 65 78 74 53 79 6d 62 28 29 0a 09 |de..NextSymb()..| 00006960 52 45 53 55 4c 54 49 53 20 61 0a 0a 20 20 20 20 |RESULTIS a.. | 00006970 20 20 43 41 53 45 20 73 2e 73 74 72 69 6e 67 3a | CASE s.string:| 00006980 0a 09 24 28 20 4c 45 54 20 77 6f 72 64 53 69 7a |..$( LET wordSiz| 00006990 65 20 3d 20 77 6f 72 64 76 25 30 20 2f 20 42 79 |e = wordv%0 / By| 000069a0 74 65 73 50 65 72 57 6f 72 64 0a 09 20 20 20 61 |tesPerWord.. a| 000069b0 20 3a 3d 20 47 65 74 42 6c 6b 28 77 6f 72 64 53 | := GetBlk(wordS| 000069c0 69 7a 65 2b 32 29 0a 09 20 20 20 61 21 30 20 3a |ize+2).. a!0 :| 000069d0 3d 20 73 2e 73 74 72 69 6e 67 0a 0a 09 20 20 20 |= s.string... | 000069e0 46 4f 52 20 69 20 3d 20 30 20 54 4f 20 77 6f 72 |FOR i = 0 TO wor| 000069f0 64 53 69 7a 65 20 44 4f 20 61 21 28 69 2b 31 29 |dSize DO a!(i+1)| 00006a00 20 3a 3d 20 77 6f 72 64 76 21 69 0a 09 20 20 20 | := wordv!i.. | 00006a10 4e 65 78 74 53 79 6d 62 28 29 0a 09 20 20 20 52 |NextSymb().. R| 00006a20 45 53 55 4c 54 49 53 20 61 0a 09 24 29 0a 0a 20 |ESULTIS a..$).. | 00006a30 20 20 20 20 20 43 41 53 45 20 73 2e 6e 75 6d 62 | CASE s.numb| 00006a40 65 72 3a 0a 09 24 28 20 4c 45 54 20 6b 20 3d 20 |er:..$( LET k = | 00006a50 64 65 63 76 61 6c 0a 09 20 20 20 4e 65 78 74 53 |decval.. NextS| 00006a60 79 6d 62 28 29 0a 0a 09 20 20 20 52 45 53 55 4c |ymb()... RESUL| 00006a70 54 49 53 20 6b 3d 30 20 20 20 20 20 2d 3e 20 7a |TIS k=0 -> z| 00006a80 65 72 6f 4e 6f 64 65 2c 0a 09 20 20 20 20 20 53 |eroNode,.. S| 00006a90 6d 61 6c 6c 4e 75 6d 62 65 72 28 6b 29 20 2d 3e |mallNumber(k) ->| 00006aa0 20 6b 2c 0a 09 09 09 20 20 20 20 20 20 20 4c 69 | k,.... Li| 00006ab0 73 74 32 28 73 2e 6e 75 6d 62 65 72 2c 20 6b 29 |st2(s.number, k)| 00006ac0 0a 09 24 29 0a 0a 20 20 20 20 20 20 43 41 53 45 |..$).. CASE| 00006ad0 20 73 2e 66 63 6f 6e 73 74 3a 0a 09 24 28 20 4c | s.fconst:..$( L| 00006ae0 45 54 20 69 2c 20 6a 20 3d 20 6d 61 6e 74 69 73 |ET i, j = mantis| 00006af0 73 61 2c 20 65 78 70 6f 6e 65 6e 74 3b 0a 09 20 |sa, exponent;.. | 00006b00 20 20 4e 65 78 74 53 79 6d 62 28 29 3b 0a 09 20 | NextSymb();.. | 00006b10 20 20 52 45 53 55 4c 54 49 53 20 4c 69 73 74 33 | RESULTIS List3| 00006b20 28 73 2e 66 63 6f 6e 73 74 2c 20 69 2c 20 6a 29 |(s.fconst, i, j)| 00006b30 0a 09 24 29 0a 0a 20 20 20 20 20 20 43 41 53 45 |..$).. CASE| 00006b40 20 73 2e 6c 70 61 72 65 6e 3a 0a 09 4e 65 78 74 | s.lparen:..Next| 00006b50 53 79 6d 62 28 29 0a 09 61 20 3a 3d 20 52 45 78 |Symb()..a := REx| 00006b60 70 28 30 29 0a 09 43 68 65 63 6b 46 6f 72 28 73 |p(0)..CheckFor(s| 00006b70 2e 72 70 61 72 65 6e 2c 20 31 35 29 0a 09 52 45 |.rparen, 15)..RE| 00006b80 53 55 4c 54 49 53 20 61 0a 0a 20 20 20 20 20 20 |SULTIS a.. | 00006b90 43 41 53 45 20 73 2e 76 61 6c 6f 66 3a 0a 09 4e |CASE s.valof:..N| 00006ba0 65 78 74 53 79 6d 62 28 29 0a 09 52 45 53 55 4c |extSymb()..RESUL| 00006bb0 54 49 53 20 4c 69 73 74 32 28 73 2e 76 61 6c 6f |TIS List2(s.valo| 00006bc0 66 2c 20 52 43 6f 6d 28 29 29 0a 0a 20 20 20 20 |f, RCom()).. | 00006bd0 20 20 43 41 53 45 20 73 2e 76 65 63 61 70 3a 0a | CASE s.vecap:.| 00006be0 09 6f 70 20 3a 3d 20 73 2e 72 76 0a 0a 20 20 20 |.op := s.rv.. | 00006bf0 20 20 20 43 41 53 45 20 73 2e 6c 76 3a 0a 20 20 | CASE s.lv:. | 00006c00 20 20 20 20 43 41 53 45 20 73 2e 72 76 3a 0a 20 | CASE s.rv:. | 00006c10 20 20 20 20 20 43 41 53 45 20 73 2e 63 61 72 3a | CASE s.car:| 00006c20 20 43 41 53 45 20 73 2e 76 63 61 72 3a 0a 20 20 | CASE s.vcar:. | 00006c30 20 20 20 20 43 41 53 45 20 73 2e 63 64 72 3a 20 | CASE s.cdr: | 00006c40 43 41 53 45 20 73 2e 76 63 64 72 3a 0a 09 4e 65 |CASE s.vcdr:..Ne| 00006c50 78 74 53 79 6d 62 28 29 0a 09 52 45 53 55 4c 54 |xtSymb()..RESULT| 00006c60 49 53 20 4c 69 73 74 32 28 6f 70 2c 20 52 45 78 |IS List2(op, REx| 00006c70 70 28 33 37 29 29 0a 0a 20 20 20 20 20 20 43 41 |p(37)).. CA| 00006c80 53 45 20 73 2e 70 6c 75 73 3a 0a 09 4e 65 78 74 |SE s.plus:..Next| 00006c90 53 79 6d 62 28 29 0a 09 52 45 53 55 4c 54 49 53 |Symb()..RESULTIS| 00006ca0 20 52 45 78 70 28 33 34 29 0a 0a 20 20 20 20 20 | RExp(34).. | 00006cb0 20 43 41 53 45 20 73 2e 6d 69 6e 75 73 3a 0a 09 | CASE s.minus:..| 00006cc0 4e 65 78 74 53 79 6d 62 28 29 0a 09 61 20 3a 3d |NextSymb()..a :=| 00006cd0 20 52 45 78 70 28 33 34 29 0a 0a 09 52 45 53 55 | RExp(34)...RESU| 00006ce0 4c 54 49 53 20 53 6d 61 6c 6c 4e 75 6d 62 65 72 |LTIS SmallNumber| 00006cf0 28 61 29 20 2d 3e 20 4c 69 73 74 32 28 73 2e 6e |(a) -> List2(s.n| 00006d00 75 6d 62 65 72 2c 20 2d 61 29 2c 0a 09 09 09 09 |umber, -a),.....| 00006d10 20 20 20 4c 69 73 74 32 28 73 2e 6e 65 67 2c 20 | List2(s.neg, | 00006d20 61 29 0a 0a 20 20 20 20 20 20 43 41 53 45 20 73 |a).. CASE s| 00006d30 2e 66 6d 69 6e 75 73 3a 0a 09 4e 65 78 74 53 79 |.fminus:..NextSy| 00006d40 6d 62 28 29 3b 0a 09 52 45 53 55 4c 54 49 53 20 |mb();..RESULTIS | 00006d50 4c 69 73 74 32 28 73 2e 66 6e 65 67 2c 20 52 45 |List2(s.fneg, RE| 00006d60 78 70 28 33 34 29 29 0a 0a 20 20 20 20 20 20 43 |xp(34)).. C| 00006d70 41 53 45 20 73 2e 6e 6f 74 3a 0a 09 4e 65 78 74 |ASE s.not:..Next| 00006d80 53 79 6d 62 28 29 0a 09 52 45 53 55 4c 54 49 53 |Symb()..RESULTIS| 00006d90 20 4c 69 73 74 32 28 73 2e 6e 6f 74 2c 20 52 45 | List2(s.not, RE| 00006da0 78 70 28 32 34 29 29 0a 0a 20 20 20 20 20 20 43 |xp(24)).. C| 00006db0 41 53 45 20 73 2e 61 62 73 3a 0a 20 20 20 20 20 |ASE s.abs:. | 00006dc0 20 43 41 53 45 20 73 2e 66 61 62 73 3a 0a 20 20 | CASE s.fabs:. | 00006dd0 20 20 20 20 43 41 53 45 20 73 2e 66 6c 6f 61 74 | CASE s.float| 00006de0 3a 20 43 41 53 45 20 73 2e 66 69 78 3a 0a 09 4e |: CASE s.fix:..N| 00006df0 65 78 74 53 79 6d 62 28 29 0a 09 52 45 53 55 4c |extSymb()..RESUL| 00006e00 54 49 53 20 4c 69 73 74 32 28 6f 70 2c 20 52 45 |TIS List2(op, RE| 00006e10 78 70 28 33 35 29 29 0a 0a 20 20 20 20 20 20 43 |xp(35)).. C| 00006e20 41 53 45 20 73 2e 74 61 62 6c 65 3a 0a 09 24 28 |ASE s.table:..$(| 00006e30 20 4c 45 54 20 6c 6e 20 3d 20 6c 69 6e 65 43 6f | LET ln = lineCo| 00006e40 75 6e 74 0a 09 20 20 20 4e 65 78 74 53 79 6d 62 |unt.. NextSymb| 00006e50 28 29 0a 09 20 20 20 52 45 53 55 4c 54 49 53 20 |().. RESULTIS | 00006e60 4c 69 73 74 34 28 73 2e 74 61 62 6c 65 2c 20 2d |List4(s.table, -| 00006e70 31 2c 20 6c 6e 2c 20 52 45 78 70 4c 69 73 74 28 |1, ln, RExpList(| 00006e80 29 29 0a 09 24 29 0a 0a 20 20 20 20 20 20 43 41 |))..$).. CA| 00006e90 53 45 20 73 2e 73 6c 63 74 3a 0a 09 24 28 20 4c |SE s.slct:..$( L| 00006ea0 45 54 20 6b 31 20 3d 20 7a 65 72 6f 4e 6f 64 65 |ET k1 = zeroNode| 00006eb0 0a 09 20 20 20 4c 45 54 20 6b 32 20 3d 20 7a 65 |.. LET k2 = ze| 00006ec0 72 6f 4e 6f 64 65 0a 09 20 20 20 4c 45 54 20 6b |roNode.. LET k| 00006ed0 33 20 3d 20 3f 0a 0a 09 20 20 20 4e 65 78 74 53 |3 = ?... NextS| 00006ee0 79 6d 62 28 29 0a 09 20 20 20 6b 33 20 3a 3d 20 |ymb().. k3 := | 00006ef0 52 45 78 70 28 30 29 0a 0a 09 20 20 20 49 46 20 |RExp(0)... IF | 00006f00 73 79 6d 62 3d 73 2e 63 6f 6c 6f 6e 20 54 48 45 |symb=s.colon THE| 00006f10 4e 0a 09 20 20 20 24 28 20 4e 65 78 74 53 79 6d |N.. $( NextSym| 00006f20 62 28 29 0a 09 20 20 20 20 20 20 6b 32 20 3a 3d |b().. k2 :=| 00006f30 20 6b 33 0a 09 20 20 20 20 20 20 6b 33 20 3a 3d | k3.. k3 :=| 00006f40 20 52 45 78 70 28 30 29 0a 09 20 20 20 24 29 0a | RExp(0).. $).| 00006f50 0a 09 20 20 20 49 46 20 73 79 6d 62 3d 73 2e 63 |.. IF symb=s.c| 00006f60 6f 6c 6f 6e 20 54 48 45 4e 0a 09 20 20 20 24 28 |olon THEN.. $(| 00006f70 20 4e 65 78 74 53 79 6d 62 28 29 0a 09 20 20 20 | NextSymb().. | 00006f80 20 20 20 6b 31 20 3a 3d 20 6b 32 0a 09 20 20 20 | k1 := k2.. | 00006f90 20 20 20 6b 32 20 3a 3d 20 6b 33 0a 09 20 20 20 | k2 := k3.. | 00006fa0 20 20 20 6b 33 20 3a 3d 20 52 45 78 70 28 30 29 | k3 := RExp(0)| 00006fb0 0a 09 20 20 20 24 29 0a 0a 09 20 20 20 52 45 53 |.. $)... RES| 00006fc0 55 4c 54 49 53 20 4c 69 73 74 34 28 73 2e 73 6c |ULTIS List4(s.sl| 00006fd0 63 74 2c 20 6b 31 2c 20 6b 32 2c 20 6b 33 29 0a |ct, k1, k2, k3).| 00006fe0 09 24 29 0a 20 20 20 24 29 0a 24 29 0a 0a 41 4e |.$). $).$)..AN| 00006ff0 44 20 52 45 78 70 28 6e 29 20 3d 20 56 41 4c 4f |D RExp(n) = VALO| 00007000 46 0a 24 28 20 4c 45 54 20 61 20 3d 20 52 62 45 |F.$( LET a = RbE| 00007010 78 70 28 29 0a 20 20 20 4c 45 54 20 62 2c 20 63 |xp(). LET b, c| 00007020 2c 20 70 2c 20 71 20 3d 20 30 2c 20 30 2c 20 30 |, p, q = 0, 0, 0| 00007030 2c 20 30 0a 0a 20 20 20 24 28 20 4c 45 54 20 6f |, 0.. $( LET o| 00007040 70 20 3d 20 73 79 6d 62 0a 20 20 20 20 20 20 49 |p = symb. I| 00007050 46 20 6e 6c 50 65 6e 64 69 6e 67 20 54 48 45 4e |F nlPending THEN| 00007060 20 52 45 53 55 4c 54 49 53 20 61 0a 0a 20 20 20 | RESULTIS a.. | 00007070 20 20 20 53 57 49 54 43 48 4f 4e 20 6f 70 20 49 | SWITCHON op I| 00007080 4e 54 4f 0a 20 20 20 20 20 20 24 28 20 44 45 46 |NTO. $( DEF| 00007090 41 55 4c 54 3a 0a 09 20 20 20 52 45 53 55 4c 54 |AULT:.. RESULT| 000070a0 49 53 20 61 0a 0a 09 20 43 41 53 45 20 73 2e 6c |IS a... CASE s.l| 000070b0 70 61 72 65 6e 3a 0a 09 20 20 20 4e 65 78 74 53 |paren:.. NextS| 000070c0 79 6d 62 28 29 0a 09 20 20 20 62 20 3a 3d 20 30 |ymb().. b := 0| 000070d0 0a 09 20 20 20 49 46 20 73 79 6d 62 7e 3d 73 2e |.. IF symb~=s.| 000070e0 72 70 61 72 65 6e 20 54 48 45 4e 20 62 20 3a 3d |rparen THEN b :=| 000070f0 20 52 45 78 70 4c 69 73 74 28 29 0a 0a 09 20 20 | RExpList()... | 00007100 20 43 68 65 63 6b 46 6f 72 28 73 2e 72 70 61 72 | CheckFor(s.rpar| 00007110 65 6e 2c 20 31 39 29 0a 09 20 20 20 61 20 3a 3d |en, 19).. a :=| 00007120 20 4c 69 73 74 33 28 73 2e 66 6e 61 70 2c 20 61 | List3(s.fnap, a| 00007130 2c 20 62 29 0a 09 20 20 20 4c 4f 4f 50 0a 0a 09 |, b).. LOOP...| 00007140 20 43 41 53 45 20 73 2e 76 65 63 61 70 3a 0a 09 | CASE s.vecap:..| 00007150 20 43 41 53 45 20 73 2e 6f 66 3a 09 70 20 3a 3d | CASE s.of:.p :=| 00007160 20 34 30 3b 20 47 4f 54 4f 20 6c 61 73 73 6f 63 | 40; GOTO lassoc| 00007170 0a 0a 09 20 43 41 53 45 20 73 2e 62 79 74 65 61 |... CASE s.bytea| 00007180 70 3a 20 70 20 3a 3d 20 33 36 3b 20 47 4f 54 4f |p: p := 36; GOTO| 00007190 20 6c 61 73 73 6f 63 0a 0a 09 20 43 41 53 45 20 | lassoc... CASE | 000071a0 73 2e 6d 75 6c 74 3a 20 43 41 53 45 20 73 2e 64 |s.mult: CASE s.d| 000071b0 69 76 3a 20 43 41 53 45 20 73 2e 72 65 6d 3a 0a |iv: CASE s.rem:.| 000071c0 09 20 43 41 53 45 20 73 2e 66 6d 75 6c 74 3a 43 |. CASE s.fmult:C| 000071d0 41 53 45 20 73 2e 66 64 69 76 3a 0a 09 09 09 70 |ASE s.fdiv:....p| 000071e0 20 3a 3d 20 33 35 3b 20 47 4f 54 4f 20 6c 61 73 | := 35; GOTO las| 000071f0 73 6f 63 0a 0a 09 20 43 41 53 45 20 73 2e 70 6c |soc... CASE s.pl| 00007200 75 73 3a 20 43 41 53 45 20 73 2e 6d 69 6e 75 73 |us: CASE s.minus| 00007210 3a 0a 09 20 43 41 53 45 20 73 2e 66 70 6c 75 73 |:.. CASE s.fplus| 00007220 3a 43 41 53 45 20 73 2e 66 6d 69 6e 75 73 3a 0a |:CASE s.fminus:.| 00007230 09 09 09 70 20 3a 3d 20 33 34 3b 20 47 4f 54 4f |...p := 34; GOTO| 00007240 20 6c 61 73 73 6f 63 0a 0a 09 20 43 41 53 45 20 | lassoc... CASE | 00007250 73 2e 6c 73 68 69 66 74 3a 0a 09 20 43 41 53 45 |s.lshift:.. CASE| 00007260 20 73 2e 72 73 68 69 66 74 3a 20 70 2c 20 71 20 | s.rshift: p, q | 00007270 3a 3d 20 32 35 2c 20 33 30 3b 20 47 4f 54 4f 20 |:= 25, 30; GOTO | 00007280 64 79 61 64 69 63 0a 0a 09 20 43 41 53 45 20 73 |dyadic... CASE s| 00007290 2e 6c 6f 67 61 6e 64 3a 20 70 20 3a 3d 20 32 33 |.logand: p := 23| 000072a0 3b 20 47 4f 54 4f 20 6c 61 73 73 6f 63 0a 0a 09 |; GOTO lassoc...| 000072b0 20 43 41 53 45 20 73 2e 6c 6f 67 6f 72 3a 09 70 | CASE s.logor:.p| 000072c0 20 3a 3d 20 32 32 3b 20 47 4f 54 4f 20 6c 61 73 | := 22; GOTO las| 000072d0 73 6f 63 0a 0a 09 20 43 41 53 45 20 73 2e 65 71 |soc... CASE s.eq| 000072e0 76 3a 0a 09 20 43 41 53 45 20 73 2e 6e 65 71 76 |v:.. CASE s.neqv| 000072f0 3a 09 70 20 3a 3d 20 32 31 3b 20 47 4f 54 4f 20 |:.p := 21; GOTO | 00007300 6c 61 73 73 6f 63 0a 0a 09 20 43 41 53 45 20 73 |lassoc... CASE s| 00007310 2e 65 71 3a 20 20 43 41 53 45 20 73 2e 6e 65 3a |.eq: CASE s.ne:| 00007320 0a 09 20 43 41 53 45 20 73 2e 6c 65 3a 20 20 43 |.. CASE s.le: C| 00007330 41 53 45 20 73 2e 67 65 3a 20 20 43 41 53 45 20 |ASE s.ge: CASE | 00007340 73 2e 6c 73 3a 20 20 43 41 53 45 20 73 2e 67 72 |s.ls: CASE s.gr| 00007350 3a 0a 09 20 43 41 53 45 20 73 2e 66 65 71 3a 20 |:.. CASE s.feq: | 00007360 43 41 53 45 20 73 2e 66 6e 65 3a 0a 09 20 43 41 |CASE s.fne:.. CA| 00007370 53 45 20 73 2e 66 6c 65 3a 20 43 41 53 45 20 73 |SE s.fle: CASE s| 00007380 2e 66 67 65 3a 20 43 41 53 45 20 73 2e 66 6c 73 |.fge: CASE s.fls| 00007390 3a 20 43 41 53 45 20 73 2e 66 67 72 3a 0a 09 20 |: CASE s.fgr:.. | 000073a0 43 41 53 45 20 73 2e 6c 6c 65 3a 20 43 41 53 45 |CASE s.lle: CASE| 000073b0 20 73 2e 6c 67 65 3a 20 43 41 53 45 20 73 2e 6c | s.lge: CASE s.l| 000073c0 6c 73 3a 20 43 41 53 45 20 73 2e 6c 67 72 3a 0a |ls: CASE s.lgr:.| 000073d0 09 20 20 20 49 46 20 6e 3e 3d 33 30 20 54 48 45 |. IF n>=30 THE| 000073e0 4e 20 52 45 53 55 4c 54 49 53 20 61 0a 0a 09 20 |N RESULTIS a... | 000073f0 20 20 24 28 20 4e 65 78 74 53 79 6d 62 28 29 0a | $( NextSymb().| 00007400 09 20 20 20 20 20 20 62 20 3a 3d 20 52 45 78 70 |. b := RExp| 00007410 28 33 30 29 0a 09 20 20 20 20 20 20 61 20 3a 3d |(30).. a :=| 00007420 20 4c 69 73 74 33 28 6f 70 2c 20 61 2c 20 62 29 | List3(op, a, b)| 00007430 0a 09 20 20 20 20 20 20 63 20 3a 3d 20 63 3d 30 |.. c := c=0| 00007440 20 2d 3e 20 61 2c 20 4c 69 73 74 33 28 73 2e 6c | -> a, List3(s.l| 00007450 6f 67 61 6e 64 2c 20 63 2c 20 61 29 0a 09 20 20 |ogand, c, a).. | 00007460 20 20 20 20 61 2c 20 6f 70 20 3a 3d 20 62 2c 20 | a, op := b, | 00007470 73 79 6d 62 0a 0a 09 20 20 20 24 29 20 52 45 50 |symb... $) REP| 00007480 45 41 54 57 48 49 4c 45 20 28 73 2e 65 71 3c 3d |EATWHILE (s.eq<=| 00007490 6f 70 3c 3d 73 2e 67 65 29 20 7c 0a 09 09 09 20 |op<=s.ge) |.... | 000074a0 20 28 73 2e 6c 6c 73 3c 3d 6f 70 3c 3d 73 2e 6c | (s.lls<=op<=s.l| 000074b0 67 65 29 20 7c 0a 09 09 09 20 20 28 73 2e 66 65 |ge) |.... (s.fe| 000074c0 71 3c 3d 6f 70 3c 3d 73 2e 66 67 65 29 0a 09 20 |q<=op<=s.fge).. | 000074d0 20 20 61 20 3a 3d 20 63 0a 09 20 20 20 4c 4f 4f | a := c.. LOO| 000074e0 50 0a 0a 09 20 43 41 53 45 20 73 2e 63 6f 6e 64 |P... CASE s.cond| 000074f0 3a 0a 09 20 20 20 49 46 20 6e 3e 3d 31 33 20 54 |:.. IF n>=13 T| 00007500 48 45 4e 20 52 45 53 55 4c 54 49 53 20 61 0a 0a |HEN RESULTIS a..| 00007510 09 20 20 20 4e 65 78 74 53 79 6d 62 28 29 0a 09 |. NextSymb()..| 00007520 20 20 20 62 20 3a 3d 20 52 45 78 70 28 30 29 0a | b := RExp(0).| 00007530 09 20 20 20 43 68 65 63 6b 46 6f 72 28 73 2e 63 |. CheckFor(s.c| 00007540 6f 6d 6d 61 2c 20 33 30 29 0a 09 20 20 20 61 20 |omma, 30).. a | 00007550 3a 3d 20 4c 69 73 74 34 28 73 2e 63 6f 6e 64 2c |:= List4(s.cond,| 00007560 20 61 2c 20 62 2c 20 52 45 78 70 28 30 29 29 0a | a, b, RExp(0)).| 00007570 09 20 20 20 4c 4f 4f 50 0a 20 20 20 20 20 20 24 |. LOOP. $| 00007580 29 0a 6c 61 73 73 6f 63 3a 0a 20 20 20 20 20 20 |).lassoc:. | 00007590 71 20 3a 3d 20 70 0a 64 79 61 64 69 63 3a 0a 20 |q := p.dyadic:. | 000075a0 20 20 20 20 20 49 46 20 6e 3e 3d 70 20 54 48 45 | IF n>=p THE| 000075b0 4e 20 52 45 53 55 4c 54 49 53 20 61 0a 20 20 20 |N RESULTIS a. | 000075c0 20 20 20 4e 65 78 74 53 79 6d 62 28 29 0a 20 20 | NextSymb(). | 000075d0 20 20 20 20 61 20 3a 3d 20 4c 69 73 74 33 28 6f | a := List3(o| 000075e0 70 2c 20 61 2c 20 52 45 78 70 28 71 29 29 0a 20 |p, a, RExp(q)). | 000075f0 20 20 24 29 20 52 45 50 45 41 54 0a 24 29 0a 0a | $) REPEAT.$)..| 00007600 41 4e 44 20 52 45 78 70 4c 69 73 74 28 29 20 3d |AND RExpList() =| 00007610 20 56 41 4c 4f 46 0a 24 28 20 4c 45 54 20 61 20 | VALOF.$( LET a | 00007620 3d 20 30 0a 20 20 20 4c 45 54 20 6e 20 3d 20 30 |= 0. LET n = 0| 00007630 0a 20 20 20 4c 45 54 20 6c 69 73 74 20 3d 20 47 |. LET list = G| 00007640 65 74 4c 69 73 74 45 6c 65 6d 65 6e 74 28 29 0a |etListElement().| 00007650 20 20 20 4c 45 54 20 6c 69 73 74 65 20 3d 20 6c | LET liste = l| 00007660 69 73 74 0a 0a 20 20 20 24 28 20 49 6e 73 65 72 |ist.. $( Inser| 00007670 74 49 6e 4c 69 73 74 45 6c 65 6d 65 6e 74 28 40 |tInListElement(@| 00007680 6c 69 73 74 65 2c 20 52 45 78 70 28 30 29 29 0a |liste, RExp(0)).| 00007690 20 20 20 20 20 20 6e 20 3a 3d 20 6e 2b 31 0a 20 | n := n+1. | 000076a0 20 20 20 20 20 49 46 20 73 79 6d 62 7e 3d 73 2e | IF symb~=s.| 000076b0 63 6f 6d 6d 61 20 54 48 45 4e 20 42 52 45 41 4b |comma THEN BREAK| 000076c0 0a 20 20 20 20 20 20 4e 65 78 74 53 79 6d 62 28 |. NextSymb(| 000076d0 29 0a 20 20 20 24 29 20 52 45 50 45 41 54 0a 0a |). $) REPEAT..| 000076e0 20 20 20 52 45 53 55 4c 54 49 53 20 4d 61 6b 65 | RESULTIS Make| 000076f0 4c 69 73 74 28 6c 69 73 74 2c 6c 69 73 74 65 2c |List(list,liste,| 00007700 73 2e 63 6f 6d 6d 61 6c 69 73 74 2c 73 2e 63 6f |s.commalist,s.co| 00007710 6d 6d 61 2c 6e 2c 31 29 0a 24 29 0a 0a 0a 41 4e |mma,n,1).$)...AN| 00007720 44 20 52 44 65 66 28 29 20 3d 20 56 41 4c 4f 46 |D RDef() = VALOF| 00007730 0a 24 28 20 4c 45 54 20 6e 20 3d 20 52 4e 61 6d |.$( LET n = RNam| 00007740 65 6c 69 73 74 28 29 0a 0a 20 20 20 53 57 49 54 |elist().. SWIT| 00007750 43 48 4f 4e 20 73 79 6d 62 20 49 4e 54 4f 0a 20 |CHON symb INTO. | 00007760 20 20 24 28 20 43 41 53 45 20 73 2e 6c 70 61 72 | $( CASE s.lpar| 00007770 65 6e 3a 0a 09 24 28 20 4c 45 54 20 61 20 3d 20 |en:..$( LET a = | 00007780 30 0a 09 20 20 20 4c 45 54 20 6c 6e 20 3d 20 6c |0.. LET ln = l| 00007790 69 6e 65 43 6f 75 6e 74 0a 09 20 20 20 4e 65 78 |ineCount.. Nex| 000077a0 74 53 79 6d 62 28 29 0a 0a 09 20 20 20 49 46 20 |tSymb()... IF | 000077b0 68 31 21 6e 7e 3d 73 2e 6e 61 6d 65 20 54 48 45 |h1!n~=s.name THE| 000077c0 4e 20 53 79 6e 52 65 70 6f 72 74 28 34 30 29 0a |N SynReport(40).| 000077d0 09 20 20 20 49 46 20 73 79 6d 62 3d 73 2e 6e 61 |. IF symb=s.na| 000077e0 6d 65 20 54 48 45 4e 20 61 20 3a 3d 20 52 4e 61 |me THEN a := RNa| 000077f0 6d 65 6c 69 73 74 28 29 0a 0a 09 20 20 20 43 68 |melist()... Ch| 00007800 65 63 6b 46 6f 72 28 73 2e 72 70 61 72 65 6e 2c |eckFor(s.rparen,| 00007810 20 34 31 29 0a 0a 09 20 20 20 49 46 20 73 79 6d | 41)... IF sym| 00007820 62 3d 73 2e 62 65 20 54 48 45 4e 0a 09 20 20 20 |b=s.be THEN.. | 00007830 24 28 20 4e 65 78 74 53 79 6d 62 28 29 0a 09 20 |$( NextSymb().. | 00007840 20 20 20 20 20 52 45 53 55 4c 54 49 53 20 4c 69 | RESULTIS Li| 00007850 73 74 36 28 73 2e 72 74 64 65 66 2c 20 6e 2c 20 |st6(s.rtdef, n, | 00007860 61 2c 20 52 43 6f 6d 28 29 2c 20 30 2c 20 6c 6e |a, RCom(), 0, ln| 00007870 29 20 24 29 0a 0a 09 20 20 20 49 46 20 73 79 6d |) $)... IF sym| 00007880 62 3d 73 2e 65 71 20 54 48 45 4e 0a 09 20 20 20 |b=s.eq THEN.. | 00007890 24 28 20 4e 65 78 74 53 79 6d 62 28 29 0a 09 20 |$( NextSymb().. | 000078a0 20 20 20 20 20 52 45 53 55 4c 54 49 53 20 4c 69 | RESULTIS Li| 000078b0 73 74 36 28 73 2e 66 6e 64 65 66 2c 20 6e 2c 20 |st6(s.fndef, n, | 000078c0 61 2c 20 52 45 78 70 28 30 29 2c 20 30 2c 20 6c |a, RExp(0), 0, l| 000078d0 6e 29 20 24 29 0a 09 20 20 20 53 79 6e 52 65 70 |n) $).. SynRep| 000078e0 6f 72 74 28 34 32 29 0a 09 24 29 0a 0a 20 20 20 |ort(42)..$).. | 000078f0 20 20 20 44 45 46 41 55 4c 54 3a 0a 09 53 79 6e | DEFAULT:..Syn| 00007900 52 65 70 6f 72 74 28 34 34 29 0a 0a 20 20 20 20 |Report(44).. | 00007910 20 20 43 41 53 45 20 73 2e 65 71 3a 0a 09 24 28 | CASE s.eq:..$(| 00007920 20 4c 45 54 20 6c 6e 20 3d 20 6c 69 6e 65 43 6f | LET ln = lineCo| 00007930 75 6e 74 0a 09 20 20 20 4e 65 78 74 53 79 6d 62 |unt.. NextSymb| 00007940 28 29 0a 0a 09 20 20 20 49 46 20 73 79 6d 62 3d |()... IF symb=| 00007950 73 2e 76 65 63 20 54 48 45 4e 0a 09 20 20 20 24 |s.vec THEN.. $| 00007960 28 20 4e 65 78 74 53 79 6d 62 28 29 0a 09 20 20 |( NextSymb().. | 00007970 20 20 20 20 49 46 20 68 31 21 6e 7e 3d 73 2e 6e | IF h1!n~=s.n| 00007980 61 6d 65 20 54 48 45 4e 20 53 79 6e 52 65 70 6f |ame THEN SynRepo| 00007990 72 74 28 34 33 29 0a 09 20 20 20 20 20 20 52 45 |rt(43).. RE| 000079a0 53 55 4c 54 49 53 20 4c 69 73 74 34 28 73 2e 76 |SULTIS List4(s.v| 000079b0 65 63 64 65 66 2c 20 6e 2c 20 52 45 78 70 28 30 |ecdef, n, RExp(0| 000079c0 29 2c 20 6c 6e 29 20 24 29 0a 0a 09 20 20 20 52 |), ln) $)... R| 000079d0 45 53 55 4c 54 49 53 20 4c 69 73 74 34 28 73 2e |ESULTIS List4(s.| 000079e0 76 61 6c 64 65 66 2c 20 6e 2c 20 52 45 78 70 4c |valdef, n, RExpL| 000079f0 69 73 74 28 29 2c 20 6c 6e 29 0a 09 24 29 0a 20 |ist(), ln)..$). | 00007a00 20 20 24 29 0a 24 29 0a 0a 0a 41 4e 44 20 52 62 | $).$)...AND Rb| 00007a10 43 6f 6d 28 29 20 3d 20 56 41 4c 4f 46 0a 24 28 |Com() = VALOF.$(| 00007a20 20 4c 45 54 20 61 2c 20 62 2c 20 6f 70 20 3d 20 | LET a, b, op = | 00007a30 30 2c 20 30 2c 20 73 79 6d 62 0a 0a 20 20 20 53 |0, 0, symb.. S| 00007a40 57 49 54 43 48 4f 4e 20 73 79 6d 62 20 49 4e 54 |WITCHON symb INT| 00007a50 4f 0a 20 20 20 24 28 20 44 45 46 41 55 4c 54 3a |O. $( DEFAULT:| 00007a60 0a 09 52 45 53 55 4c 54 49 53 20 30 0a 0a 20 20 |..RESULTIS 0.. | 00007a70 20 20 20 20 43 41 53 45 20 73 2e 62 61 64 3a 0a | CASE s.bad:.| 00007a80 09 53 79 6e 52 65 70 6f 72 74 28 31 30 31 29 0a |.SynReport(101).| 00007a90 0a 20 20 20 20 20 20 43 41 53 45 20 73 2e 6e 61 |. CASE s.na| 00007aa0 6d 65 3a 20 43 41 53 45 20 73 2e 6e 75 6d 62 65 |me: CASE s.numbe| 00007ab0 72 3a 20 43 41 53 45 20 73 2e 73 74 72 69 6e 67 |r: CASE s.string| 00007ac0 3a 0a 20 20 20 20 20 20 43 41 53 45 20 73 2e 74 |:. CASE s.t| 00007ad0 72 75 65 3a 20 43 41 53 45 20 73 2e 66 61 6c 73 |rue: CASE s.fals| 00007ae0 65 3a 20 20 43 41 53 45 20 73 2e 6c 76 3a 0a 20 |e: CASE s.lv:. | 00007af0 20 20 20 20 20 43 41 53 45 20 73 2e 72 76 3a 20 | CASE s.rv: | 00007b00 20 20 43 41 53 45 20 73 2e 76 65 63 61 70 3a 20 | CASE s.vecap: | 00007b10 20 43 41 53 45 20 73 2e 6c 70 61 72 65 6e 3a 0a | CASE s.lparen:.| 00007b20 20 20 20 20 20 20 43 41 53 45 20 73 2e 63 61 72 | CASE s.car| 00007b30 3a 20 20 43 41 53 45 20 73 2e 63 64 72 3a 0a 20 |: CASE s.cdr:. | 00007b40 20 20 20 20 20 43 41 53 45 20 73 2e 76 63 61 72 | CASE s.vcar| 00007b50 3a 20 43 41 53 45 20 73 2e 76 63 64 72 3a 0a 20 |: CASE s.vcdr:. | 00007b60 20 20 20 20 20 43 41 53 45 20 73 2e 6e 69 6c 3a | CASE s.nil:| 00007b70 0a 09 61 20 3a 3d 20 52 45 78 70 4c 69 73 74 28 |..a := RExpList(| 00007b80 29 0a 0a 09 49 46 20 73 79 6d 62 3d 73 2e 61 73 |)...IF symb=s.as| 00007b90 73 20 54 48 45 4e 0a 09 24 28 20 6f 70 20 3a 3d |s THEN..$( op :=| 00007ba0 20 73 79 6d 62 0a 09 20 20 20 4e 65 78 74 53 79 | symb.. NextSy| 00007bb0 6d 62 28 29 0a 09 20 20 20 52 45 53 55 4c 54 49 |mb().. RESULTI| 00007bc0 53 20 4c 69 73 74 33 28 6f 70 2c 20 61 2c 20 52 |S List3(op, a, R| 00007bd0 45 78 70 4c 69 73 74 28 29 29 20 24 29 0a 0a 09 |ExpList()) $)...| 00007be0 49 46 20 73 79 6d 62 3d 73 2e 6f 70 61 62 20 54 |IF symb=s.opab T| 00007bf0 48 45 4e 0a 09 20 20 2f 2f 0a 09 20 20 2f 2f 20 |HEN.. //.. // | 00007c00 54 68 65 20 6e 6f 64 65 20 69 73 20 6f 66 20 74 |The node is of t| 00007c10 79 70 65 20 27 4f 50 41 42 27 2c 20 77 69 74 68 |ype 'OPAB', with| 00007c20 20 74 68 65 0a 09 20 20 2f 2f 20 61 63 74 75 61 | the.. // actua| 00007c30 6c 20 6f 70 65 72 61 74 6f 72 20 69 6e 20 74 68 |l operator in th| 00007c40 65 20 73 65 63 6f 6e 64 20 66 69 65 6c 64 2e 0a |e second field..| 00007c50 09 20 20 2f 2f 0a 09 24 28 20 4c 45 54 20 64 79 |. //..$( LET dy| 00007c60 61 64 69 63 20 3d 20 6f 70 65 72 61 74 6f 72 0a |adic = operator.| 00007c70 09 20 20 20 6f 70 20 3a 3d 20 73 79 6d 62 0a 09 |. op := symb..| 00007c80 20 20 20 4e 65 78 74 53 79 6d 62 28 29 0a 09 20 | NextSymb().. | 00007c90 20 20 52 45 53 55 4c 54 49 53 20 4c 69 73 74 34 | RESULTIS List4| 00007ca0 28 6f 70 2c 20 64 79 61 64 69 63 2c 20 61 2c 20 |(op, dyadic, a, | 00007cb0 52 45 78 70 4c 69 73 74 28 29 29 20 24 29 0a 0a |RExpList()) $)..| 00007cc0 09 49 46 20 53 6d 61 6c 6c 4e 75 6d 62 65 72 28 |.IF SmallNumber(| 00007cd0 61 29 20 54 48 45 4e 20 53 79 6e 52 65 70 6f 72 |a) THEN SynRepor| 00007ce0 74 28 35 31 29 0a 0a 09 49 46 20 73 79 6d 62 3d |t(51)...IF symb=| 00007cf0 73 2e 63 6f 6c 6f 6e 20 54 48 45 4e 0a 09 24 28 |s.colon THEN..$(| 00007d00 20 49 46 20 68 31 21 61 7e 3d 73 2e 6e 61 6d 65 | IF h1!a~=s.name| 00007d10 20 54 48 45 4e 20 53 79 6e 52 65 70 6f 72 74 28 | THEN SynReport(| 00007d20 35 30 29 0a 09 20 20 20 4e 65 78 74 53 79 6d 62 |50).. NextSymb| 00007d30 28 29 0a 09 20 20 20 52 45 53 55 4c 54 49 53 20 |().. RESULTIS | 00007d40 4c 69 73 74 34 28 73 2e 63 6f 6c 6f 6e 2c 20 61 |List4(s.colon, a| 00007d50 2c 20 52 62 43 6f 6d 28 29 2c 20 30 29 20 24 29 |, RbCom(), 0) $)| 00007d60 0a 0a 09 49 46 20 68 31 21 61 3d 73 2e 66 6e 61 |...IF h1!a=s.fna| 00007d70 70 20 54 48 45 4e 0a 09 24 28 20 68 31 21 61 20 |p THEN..$( h1!a | 00007d80 3a 3d 20 73 2e 72 74 61 70 0a 09 20 20 20 52 45 |:= s.rtap.. RE| 00007d90 53 55 4c 54 49 53 20 61 20 24 29 0a 0a 09 53 79 |SULTIS a $)...Sy| 00007da0 6e 52 65 70 6f 72 74 28 35 31 29 0a 09 52 45 53 |nReport(51)..RES| 00007db0 55 4c 54 49 53 20 61 0a 0a 20 20 20 20 20 20 43 |ULTIS a.. C| 00007dc0 41 53 45 20 73 2e 67 6f 74 6f 3a 20 43 41 53 45 |ASE s.goto: CASE| 00007dd0 20 73 2e 72 65 73 75 6c 74 69 73 3a 0a 09 4e 65 | s.resultis:..Ne| 00007de0 78 74 53 79 6d 62 28 29 0a 09 52 45 53 55 4c 54 |xtSymb()..RESULT| 00007df0 49 53 20 4c 69 73 74 32 28 6f 70 2c 20 52 45 78 |IS List2(op, REx| 00007e00 70 28 30 29 29 0a 0a 20 20 20 20 20 20 43 41 53 |p(0)).. CAS| 00007e10 45 20 73 2e 69 66 3a 20 20 20 20 43 41 53 45 20 |E s.if: CASE | 00007e20 73 2e 75 6e 6c 65 73 73 3a 0a 20 20 20 20 20 20 |s.unless:. | 00007e30 43 41 53 45 20 73 2e 77 68 69 6c 65 3a 20 43 41 |CASE s.while: CA| 00007e40 53 45 20 73 2e 75 6e 74 69 6c 3a 0a 09 4e 65 78 |SE s.until:..Nex| 00007e50 74 53 79 6d 62 28 29 0a 09 61 20 3a 3d 20 52 45 |tSymb()..a := RE| 00007e60 78 70 28 30 29 0a 09 49 67 6e 6f 72 65 28 73 2e |xp(0)..Ignore(s.| 00007e70 64 6f 29 0a 09 52 45 53 55 4c 54 49 53 20 4c 69 |do)..RESULTIS Li| 00007e80 73 74 33 28 6f 70 2c 20 61 2c 20 52 43 6f 6d 28 |st3(op, a, RCom(| 00007e90 29 29 0a 0a 20 20 20 20 20 20 43 41 53 45 20 73 |)).. CASE s| 00007ea0 2e 74 65 73 74 3a 0a 09 4e 65 78 74 53 79 6d 62 |.test:..NextSymb| 00007eb0 28 29 0a 09 61 20 3a 3d 20 52 45 78 70 28 30 29 |()..a := RExp(0)| 00007ec0 0a 09 49 67 6e 6f 72 65 28 73 2e 64 6f 29 0a 09 |..Ignore(s.do)..| 00007ed0 62 20 3a 3d 20 52 43 6f 6d 28 29 0a 09 43 68 65 |b := RCom()..Che| 00007ee0 63 6b 46 6f 72 28 73 2e 6f 72 2c 20 35 34 29 0a |ckFor(s.or, 54).| 00007ef0 09 52 45 53 55 4c 54 49 53 20 4c 69 73 74 34 28 |.RESULTIS List4(| 00007f00 73 2e 74 65 73 74 2c 20 61 2c 20 62 2c 20 52 43 |s.test, a, b, RC| 00007f10 6f 6d 28 29 29 0a 0a 20 20 20 20 20 20 43 41 53 |om()).. CAS| 00007f20 45 20 73 2e 66 6f 72 3a 0a 09 24 28 20 4c 45 54 |E s.for:..$( LET| 00007f30 20 69 2c 20 6a 2c 20 6b 20 3d 20 30 2c 20 30 2c | i, j, k = 0, 0,| 00007f40 20 30 0a 0a 09 20 20 20 4e 65 78 74 53 79 6d 62 | 0... NextSymb| 00007f50 28 29 0a 09 20 20 20 61 20 3a 3d 20 52 4e 61 6d |().. a := RNam| 00007f60 65 28 29 0a 09 20 20 20 43 68 65 63 6b 46 6f 72 |e().. CheckFor| 00007f70 28 73 2e 65 71 2c 35 37 29 0a 0a 09 20 20 20 69 |(s.eq,57)... i| 00007f80 20 3a 3d 20 52 45 78 70 28 30 29 0a 09 20 20 20 | := RExp(0).. | 00007f90 43 68 65 63 6b 46 6f 72 28 73 2e 74 6f 2c 20 35 |CheckFor(s.to, 5| 00007fa0 38 29 0a 0a 09 20 20 20 6a 20 3a 3d 20 52 45 78 |8)... j := REx| 00007fb0 70 28 30 29 0a 0a 09 20 20 20 49 46 20 73 79 6d |p(0)... IF sym| 00007fc0 62 3d 73 2e 62 79 20 54 48 45 4e 0a 09 20 20 20 |b=s.by THEN.. | 00007fd0 24 28 20 4e 65 78 74 53 79 6d 62 28 29 0a 09 20 |$( NextSymb().. | 00007fe0 20 20 20 20 20 6b 20 3a 3d 20 52 45 78 70 28 30 | k := RExp(0| 00007ff0 29 20 24 29 0a 0a 09 20 20 20 49 67 6e 6f 72 65 |) $)... Ignore| 00008000 28 73 2e 64 6f 29 0a 09 20 20 20 52 45 53 55 4c |(s.do).. RESUL| 00008010 54 49 53 20 4c 69 73 74 36 28 73 2e 66 6f 72 2c |TIS List6(s.for,| 00008020 20 61 2c 20 69 2c 20 6a 2c 20 6b 2c 20 52 43 6f | a, i, j, k, RCo| 00008030 6d 28 29 29 0a 09 24 29 0a 0a 20 20 20 20 20 20 |m())..$).. | 00008040 43 41 53 45 20 73 2e 6c 6f 6f 70 3a 20 20 20 43 |CASE s.loop: C| 00008050 41 53 45 20 73 2e 62 72 65 61 6b 3a 20 43 41 53 |ASE s.break: CAS| 00008060 45 20 73 2e 65 6e 64 63 61 73 65 3a 0a 20 20 20 |E s.endcase:. | 00008070 20 20 20 43 41 53 45 20 73 2e 72 65 74 75 72 6e | CASE s.return| 00008080 3a 20 43 41 53 45 20 73 2e 66 69 6e 69 73 68 3a |: CASE s.finish:| 00008090 0a 09 61 20 3a 3d 20 77 6f 72 64 4e 6f 64 65 0a |..a := wordNode.| 000080a0 09 4e 65 78 74 53 79 6d 62 28 29 0a 09 52 45 53 |.NextSymb()..RES| 000080b0 55 4c 54 49 53 20 61 0a 0a 20 20 20 20 20 20 43 |ULTIS a.. C| 000080c0 41 53 45 20 73 2e 73 77 69 74 63 68 6f 6e 3a 0a |ASE s.switchon:.| 000080d0 09 24 28 20 4c 45 54 20 63 63 20 3d 20 63 61 73 |.$( LET cc = cas| 000080e0 65 43 6f 75 6e 74 0a 09 20 20 20 4c 45 54 20 72 |eCount.. LET r| 000080f0 65 73 20 3d 20 3f 0a 09 20 20 20 4c 45 54 20 73 |es = ?.. LET s| 00008100 65 63 74 20 3d 20 3f 0a 0a 09 20 20 20 4e 65 78 |ect = ?... Nex| 00008110 74 53 79 6d 62 28 29 0a 09 20 20 20 61 20 3a 3d |tSymb().. a :=| 00008120 20 52 45 78 70 28 30 29 0a 09 20 20 20 43 68 65 | RExp(0).. Che| 00008130 63 6b 46 6f 72 28 73 2e 69 6e 74 6f 2c 20 36 30 |ckFor(s.into, 60| 00008140 29 0a 0a 09 20 20 20 63 61 73 65 43 6f 75 6e 74 |)... caseCount| 00008150 20 3a 3d 20 30 0a 09 20 20 20 73 65 63 74 20 3a | := 0.. sect :| 00008160 3d 20 52 64 53 65 63 74 28 52 64 53 65 71 29 0a |= RdSect(RdSeq).| 00008170 09 20 20 20 72 65 73 20 3a 3d 20 4c 69 73 74 34 |. res := List4| 00008180 28 73 2e 73 77 69 74 63 68 6f 6e 2c 20 61 2c 20 |(s.switchon, a, | 00008190 73 65 63 74 2c 20 63 61 73 65 43 6f 75 6e 74 29 |sect, caseCount)| 000081a0 0a 09 20 20 20 63 61 73 65 43 6f 75 6e 74 20 3a |.. caseCount :| 000081b0 3d 20 63 63 0a 0a 09 20 20 20 52 45 53 55 4c 54 |= cc... RESULT| 000081c0 49 53 20 72 65 73 0a 09 24 29 0a 0a 20 20 20 20 |IS res..$).. | 000081d0 20 20 43 41 53 45 20 73 2e 63 61 73 65 3a 0a 09 | CASE s.case:..| 000081e0 4e 65 78 74 53 79 6d 62 28 29 0a 09 61 20 3a 3d |NextSymb()..a :=| 000081f0 20 52 45 78 70 28 30 29 0a 09 43 68 65 63 6b 46 | RExp(0)..CheckF| 00008200 6f 72 28 73 2e 63 6f 6c 6f 6e 2c 20 36 31 29 0a |or(s.colon, 61).| 00008210 09 63 61 73 65 43 6f 75 6e 74 20 3a 3d 20 63 61 |.caseCount := ca| 00008220 73 65 43 6f 75 6e 74 2b 31 0a 09 52 45 53 55 4c |seCount+1..RESUL| 00008230 54 49 53 20 4c 69 73 74 33 28 73 2e 63 61 73 65 |TIS List3(s.case| 00008240 2c 20 61 2c 20 52 62 43 6f 6d 28 29 29 0a 0a 20 |, a, RbCom()).. | 00008250 20 20 20 20 20 43 41 53 45 20 73 2e 64 65 66 61 | CASE s.defa| 00008260 75 6c 74 3a 0a 09 4e 65 78 74 53 79 6d 62 28 29 |ult:..NextSymb()| 00008270 0a 09 43 68 65 63 6b 46 6f 72 28 73 2e 63 6f 6c |..CheckFor(s.col| 00008280 6f 6e 2c 20 36 32 29 0a 09 52 45 53 55 4c 54 49 |on, 62)..RESULTI| 00008290 53 20 4c 69 73 74 32 28 73 2e 64 65 66 61 75 6c |S List2(s.defaul| 000082a0 74 2c 20 52 62 43 6f 6d 28 29 29 0a 0a 20 20 20 |t, RbCom()).. | 000082b0 20 20 20 43 41 53 45 20 73 2e 6c 73 65 63 74 3a | CASE s.lsect:| 000082c0 0a 09 52 45 53 55 4c 54 49 53 20 52 64 53 65 63 |..RESULTIS RdSec| 000082d0 74 28 52 64 42 6c 6f 63 6b 42 6f 64 79 29 0a 20 |t(RdBlockBody). | 000082e0 20 20 24 29 0a 24 29 0a 0a 41 4e 44 20 52 43 6f | $).$)..AND RCo| 000082f0 6d 28 29 20 3d 20 56 41 4c 4f 46 0a 24 28 20 4c |m() = VALOF.$( L| 00008300 45 54 20 61 20 3d 20 52 62 43 6f 6d 28 29 0a 0a |ET a = RbCom()..| 00008310 20 20 20 49 46 20 61 3d 30 20 54 48 45 4e 20 53 | IF a=0 THEN S| 00008320 79 6e 52 65 70 6f 72 74 28 35 31 29 0a 0a 20 20 |ynReport(51).. | 00008330 20 57 48 49 4c 45 20 73 79 6d 62 3d 73 2e 72 65 | WHILE symb=s.re| 00008340 70 65 61 74 20 7c 20 73 79 6d 62 3d 73 2e 72 65 |peat | symb=s.re| 00008350 70 65 61 74 77 68 69 6c 65 20 7c 20 73 79 6d 62 |peatwhile | symb| 00008360 3d 73 2e 72 65 70 65 61 74 75 6e 74 69 6c 20 44 |=s.repeatuntil D| 00008370 4f 0a 20 20 20 24 28 20 4c 45 54 20 6f 70 20 3d |O. $( LET op =| 00008380 20 73 79 6d 62 0a 20 20 20 20 20 20 4e 65 78 74 | symb. Next| 00008390 53 79 6d 62 28 29 0a 20 20 20 20 20 20 61 20 3a |Symb(). a :| 000083a0 3d 20 6f 70 3d 73 2e 72 65 70 65 61 74 20 2d 3e |= op=s.repeat ->| 000083b0 20 4c 69 73 74 32 28 6f 70 2c 20 61 29 2c 0a 09 | List2(op, a),..| 000083c0 09 09 20 20 4c 69 73 74 33 28 6f 70 2c 20 61 2c |.. List3(op, a,| 000083d0 20 52 45 78 70 28 30 29 29 20 24 29 0a 0a 20 20 | RExp(0)) $).. | 000083e0 20 52 45 53 55 4c 54 49 53 20 61 0a 24 29 0a 0a | RESULTIS a.$)..| 000083f0