home *** CD-ROM | disk | FTP | other *** search
/ Usenet 1994 January / usenetsourcesnewsgroupsinfomagicjanuary1994.iso / sources / unix / volume2 / basic / part3 < prev    next >
SHell self-extracting ARchive  |  1986-11-30  |  59.7 KB

view JSON data     |     view as text     |     open on a Mac     |     open on a PC

This file was processed as: SHell self-extracting ARchive (archive/shar).

You can browse this item here: part3

ConfidenceProgramDetectionMatch TypeSupport
100% dexvert Newsgroup Content (archive/news) magic Supported
100% dexvert SHell self-extracting ARchive (archive/shar) magic Supported
100% dexvert Internet Message Format (text/imf) magic Supported
1% dexvert Text File (text/txt) fallback Supported
100% file news or mail text default
99% file C source text default
98% file C source, ASCII text default
100% checkBytes Printable ASCII default
100% perlTextCheck Likely Text (Perl) default
100% siegfried fmt/329 Shell Archive Format default
100% detectItEasy Format: plain text[LF] default (weak)
100% xdgMime message/rfc822 default



hex view
+--------+-------------------------+-------------------------+--------+--------+
|00000000| 46 72 6f 6d 3a 20 75 6b | 6d 61 21 64 61 76 69 64 |From: uk|ma!david|
|00000010| 20 28 44 61 76 69 64 20 | 48 65 72 72 6f 6e 2c 20 | (David |Herron, |
|00000020| 4e 50 52 20 4c 6f 76 65 | 72 29 0a 53 75 62 6a 65 |NPR Love|r).Subje|
|00000030| 63 74 3a 20 41 20 42 41 | 53 49 43 20 69 6e 74 65 |ct: A BA|SIC inte|
|00000040| 72 70 72 65 74 6f 72 20 | 28 50 61 72 74 20 33 20 |rpretor |(Part 3 |
|00000050| 6f 66 20 34 29 0a 4e 65 | 77 73 67 72 6f 75 70 73 |of 4).Ne|wsgroups|
|00000060| 3a 20 6d 6f 64 2e 73 6f | 75 72 63 65 73 0a 41 70 |: mod.so|urces.Ap|
|00000070| 70 72 6f 76 65 64 3a 20 | 6a 6f 68 6e 40 67 65 6e |proved: |john@gen|
|00000080| 72 61 64 2e 55 55 43 50 | 0a 0a 4d 6f 64 2e 73 6f |rad.UUCP|..Mod.so|
|00000090| 75 72 63 65 73 3a 20 20 | 56 6f 6c 75 6d 65 20 32 |urces: |Volume 2|
|000000a0| 2c 20 49 73 73 75 65 20 | 32 35 0a 53 75 62 6d 69 |, Issue |25.Submi|
|000000b0| 74 74 65 64 20 62 79 3a | 20 75 6b 6d 61 21 64 61 |tted by:| ukma!da|
|000000c0| 76 69 64 20 28 44 61 76 | 69 64 20 48 65 72 72 6f |vid (Dav|id Herro|
|000000d0| 6e 29 0a 0a 0a 23 21 20 | 2f 62 69 6e 2f 73 68 0a |n)...#! |/bin/sh.|
|000000e0| 23 20 54 68 69 73 20 69 | 73 20 61 20 73 68 65 6c |# This i|s a shel|
|000000f0| 6c 20 61 72 63 68 69 76 | 65 2c 20 6d 65 61 6e 69 |l archiv|e, meani|
|00000100| 6e 67 3a 0a 23 20 31 2e | 20 52 65 6d 6f 76 65 20 |ng:.# 1.| Remove |
|00000110| 65 76 65 72 79 74 68 69 | 6e 67 20 61 62 6f 76 65 |everythi|ng above|
|00000120| 20 74 68 65 20 23 21 20 | 2f 62 69 6e 2f 73 68 20 | the #! |/bin/sh |
|00000130| 6c 69 6e 65 2e 0a 23 20 | 32 2e 20 53 61 76 65 20 |line..# |2. Save |
|00000140| 74 68 65 20 72 65 73 75 | 6c 74 69 6e 67 20 74 65 |the resu|lting te|
|00000150| 78 74 20 69 6e 20 61 20 | 66 69 6c 65 2e 0a 23 20 |xt in a |file..# |
|00000160| 33 2e 20 45 78 65 63 75 | 74 65 20 74 68 65 20 66 |3. Execu|te the f|
|00000170| 69 6c 65 20 77 69 74 68 | 20 2f 62 69 6e 2f 73 68 |ile with| /bin/sh|
|00000180| 20 28 6e 6f 74 20 63 73 | 68 29 20 74 6f 20 63 72 | (not cs|h) to cr|
|00000190| 65 61 74 65 20 74 68 65 | 20 66 69 6c 65 73 3a 0a |eate the| files:.|
|000001a0| 23 09 62 73 32 2f 61 63 | 74 69 6f 6e 2e 63 0a 23 |#.bs2/ac|tion.c.#|
|000001b0| 09 62 73 32 2f 62 73 64 | 65 66 73 2e 68 0a 23 09 |.bs2/bsd|efs.h.#.|
|000001c0| 62 73 32 2f 62 73 67 72 | 61 6d 2e 79 0a 23 09 62 |bs2/bsgr|am.y.#.b|
|000001d0| 73 32 2f 62 73 67 72 61 | 6d 2e 79 2e 6f 72 69 67 |s2/bsgra|m.y.orig|
|000001e0| 0a 23 09 62 73 32 2f 62 | 73 69 6e 74 2e 63 0a 23 |.#.bs2/b|sint.c.#|
|000001f0| 09 62 73 32 2f 62 73 6c | 69 62 2e 63 0a 23 09 62 |.bs2/bsl|ib.c.#.b|
|00000200| 73 32 2f 65 72 72 6f 72 | 73 2e 63 0a 23 09 62 73 |s2/error|s.c.#.bs|
|00000210| 32 2f 6f 70 65 72 61 74 | 2e 63 0a 23 20 54 68 69 |2/operat|.c.# Thi|
|00000220| 73 20 61 72 63 68 69 76 | 65 20 63 72 65 61 74 65 |s archiv|e create|
|00000230| 64 3a 20 54 75 65 20 4a | 75 6c 20 33 30 20 31 33 |d: Tue J|ul 30 13|
|00000240| 3a 30 33 3a 30 34 20 31 | 39 38 35 0a 65 78 70 6f |:03:04 1|985.expo|
|00000250| 72 74 20 50 41 54 48 3b | 20 50 41 54 48 3d 2f 62 |rt PATH;| PATH=/b|
|00000260| 69 6e 3a 24 50 41 54 48 | 0a 69 66 20 74 65 73 74 |in:$PATH|.if test|
|00000270| 20 21 20 2d 64 20 27 62 | 73 32 27 0a 74 68 65 6e | ! -d 'b|s2'.then|
|00000280| 0a 09 65 63 68 6f 20 73 | 68 61 72 3a 20 63 72 65 |..echo s|har: cre|
|00000290| 61 74 69 6e 67 20 64 69 | 72 65 63 74 6f 72 79 20 |ating di|rectory |
|000002a0| 22 27 62 73 32 27 22 0a | 09 6d 6b 64 69 72 20 27 |"'bs2'".|.mkdir '|
|000002b0| 62 73 32 27 0a 66 69 0a | 65 63 68 6f 20 73 68 61 |bs2'.fi.|echo sha|
|000002c0| 72 3a 20 65 78 74 72 61 | 63 74 69 6e 67 20 22 27 |r: extra|cting "'|
|000002d0| 62 73 32 2f 61 63 74 69 | 6f 6e 2e 63 27 22 20 27 |bs2/acti|on.c'" '|
|000002e0| 28 31 34 30 37 33 20 63 | 68 61 72 61 63 74 65 72 |(14073 c|haracter|
|000002f0| 73 29 27 0a 69 66 20 74 | 65 73 74 20 2d 66 20 27 |s)'.if t|est -f '|
|00000300| 62 73 32 2f 61 63 74 69 | 6f 6e 2e 63 27 0a 74 68 |bs2/acti|on.c'.th|
|00000310| 65 6e 0a 09 65 63 68 6f | 20 73 68 61 72 3a 20 77 |en..echo| shar: w|
|00000320| 69 6c 6c 20 6e 6f 74 20 | 6f 76 65 72 2d 77 72 69 |ill not |over-wri|
|00000330| 74 65 20 65 78 69 73 74 | 69 6e 67 20 66 69 6c 65 |te exist|ing file|
|00000340| 20 22 27 62 73 32 2f 61 | 63 74 69 6f 6e 2e 63 27 | "'bs2/a|ction.c'|
|00000350| 22 0a 65 6c 73 65 0a 73 | 65 64 20 27 73 2f 5e 58 |".else.s|ed 's/^X|
|00000360| 2f 2f 27 20 3c 3c 20 5c | 53 48 41 52 5f 45 4f 46 |//' << \|SHAR_EOF|
|00000370| 20 3e 20 27 62 73 32 2f | 61 63 74 69 6f 6e 2e 63 | > 'bs2/|action.c|
|00000380| 27 0a 2f 2a 20 61 63 74 | 69 6f 6e 2e 63 20 2d 2d |'./* act|ion.c --|
|00000390| 20 22 61 63 74 69 6f 6e | 22 20 72 6f 75 74 69 6e | "action|" routin|
|000003a0| 65 73 20 66 6f 72 20 69 | 6e 74 65 72 70 72 65 74 |es for i|nterpret|
|000003b0| 6f 72 2e 20 20 54 68 65 | 73 65 20 61 72 65 20 74 |or. The|se are t|
|000003c0| 68 65 20 62 61 73 65 2d | 6c 65 76 65 6c 0a 20 2a |he base-|level. *|
|000003d0| 09 72 6f 75 74 69 6e 65 | 73 2c 20 70 6f 69 6e 74 |.routine|s, point|
|000003e0| 65 64 20 74 6f 20 62 79 | 20 74 68 65 20 63 6f 64 |ed to by| the cod|
|000003f0| 65 2d 6c 69 73 74 2e 0a | 20 2a 2f 0a 0a 23 69 6e |e-list..| */..#in|
|00000400| 63 6c 75 64 65 20 22 62 | 73 64 65 66 73 2e 68 22 |clude "b|sdefs.h"|
|00000410| 0a 0a 69 6e 74 20 73 74 | 61 74 75 73 20 3d 20 30 |..int st|atus = 0|
|00000420| 3b 0a 0a 2f 2a 20 4d 5f | 43 4f 4d 50 49 4c 45 3a |;../* M_|COMPILE:|
|00000430| 0a 20 2a 09 78 20 70 72 | 69 6e 74 20 78 20 20 20 |. *.x pr|int x |
|00000440| 2d 2d 74 6f 2d 2d 20 20 | 20 78 2c 5f 70 72 69 6e |--to-- | x,_prin|
|00000450| 74 2c 78 0a 20 2a 20 4d | 5f 45 58 45 43 55 54 45 |t,x. * M|_EXECUTE|
|00000460| 3a 0a 20 2a 09 73 74 61 | 63 6b 3a 20 73 74 72 69 |:. *.sta|ck: stri|
|00000470| 6e 67 2c 78 20 20 20 2d | 2d 74 6f 2d 2d 20 20 20 |ng,x -|-to-- |
|00000480| 78 0a 20 2a 09 6f 75 74 | 70 75 74 3a 20 22 73 74 |x. *.out|put: "st|
|00000490| 72 69 6e 67 5c 6e 22 0a | 20 2a 2f 0a 5f 70 72 69 |ring\n".| */._pri|
|000004a0| 6e 74 28 6c 2c 70 29 0a | 69 6e 74 20 28 2a 6c 5b |nt(l,p).|int (*l[|
|000004b0| 5d 29 28 29 2c 70 3b 0a | 7b 0a 20 20 20 20 75 6e |])(),p;.|{. un|
|000004c0| 69 6f 6e 20 76 61 6c 75 | 65 20 73 31 3b 0a 20 20 |ion valu|e s1;. |
|000004d0| 20 20 73 77 69 74 63 68 | 28 73 74 61 74 75 73 26 | switch|(status&|
|000004e0| 58 4d 4f 44 45 29 20 7b | 0a 09 63 61 73 65 20 4d |XMODE) {|..case M|
|000004f0| 5f 45 58 45 43 55 54 45 | 3a 0a 09 20 20 20 20 73 |_EXECUTE|:.. s|
|00000500| 31 20 3d 20 70 6f 70 28 | 29 3b 0a 09 20 20 20 20 |1 = pop(|);.. |
|00000510| 70 72 69 6e 74 66 28 22 | 25 73 22 2c 73 31 2e 73 |printf("|%s",s1.s|
|00000520| 76 61 6c 29 3b 0a 09 20 | 20 20 20 69 66 28 73 31 |val);.. | if(s1|
|00000530| 2e 73 76 61 6c 20 21 3d | 20 30 29 20 66 72 65 65 |.sval !=| 0) free|
|00000540| 28 73 31 2e 73 76 61 6c | 29 3b 0a 09 63 61 73 65 |(s1.sval|);..case|
|00000550| 20 4d 5f 46 49 58 55 50 | 3a 0a 09 63 61 73 65 20 | M_FIXUP|:..case |
|00000560| 4d 5f 43 4f 4d 50 49 4c | 45 3a 20 72 65 74 75 72 |M_COMPIL|E: retur|
|00000570| 6e 28 70 29 3b 0a 09 64 | 65 66 61 75 6c 74 3a 0a |n(p);..d|efault:.|
|00000580| 09 20 20 20 20 53 54 65 | 72 72 6f 72 28 22 70 72 |. STe|rror("pr|
|00000590| 69 6e 74 22 29 3b 0a 20 | 20 20 20 7d 0a 7d 0a 0a |int");. | }.}..|
|000005a0| 2f 2a 20 4d 5f 43 4f 4d | 50 49 4c 45 3a 0a 20 2a |/* M_COM|PILE:. *|
|000005b0| 09 78 20 72 6c 61 62 65 | 6c 20 6e 61 6d 65 20 67 |.x rlabe|l name g|
|000005c0| 6f 74 6f 20 78 20 20 20 | 20 20 2d 2d 74 6f 2d 2d |oto x | --to--|
|000005d0| 20 20 20 20 78 2c 72 6c | 61 62 65 6c 2c 6c 76 61 | x,rl|abel,lva|
|000005e0| 6c 2c 5f 67 6f 74 6f 2c | 30 2c 78 0a 20 2a 09 28 |l,_goto,|0,x. *.(|
|000005f0| 74 68 65 20 30 20 69 73 | 20 66 6f 72 20 74 68 65 |the 0 is| for the|
|00000600| 20 62 65 6e 65 66 69 74 | 20 6f 66 20 69 6e 74 65 | benefit| of inte|
|00000610| 72 70 28 29 29 0a 20 2a | 20 4d 5f 46 49 58 55 50 |rp()). *| M_FIXUP|
|00000620| 3a 20 6e 6f 74 68 69 6e | 67 2e 0a 20 2a 20 61 6e |: nothin|g.. * an|
|00000630| 79 20 6f 74 68 65 72 20 | 6d 6f 64 65 3a 0a 20 2a |y other |mode:. *|
|00000640| 09 73 74 61 63 6b 3a 20 | 6c 76 61 6c 2c 78 20 20 |.stack: |lval,x |
|00000650| 20 20 2d 2d 74 6f 2d 2d | 20 20 20 20 78 0a 20 2a | --to--| x. *|
|00000660| 09 6f 74 68 65 72 3a 20 | 54 68 69 73 6c 69 6e 65 |.other: |Thisline|
|00000670| 20 3d 20 6c 76 61 6c 2e | 6c 76 61 6c 2e 63 6f 64 | = lval.|lval.cod|
|00000680| 65 6c 69 73 74 3b 0a 20 | 2a 09 20 20 20 20 20 20 |elist;. |*. |
|00000690| 20 54 68 69 73 70 20 3d | 20 6c 76 61 6c 2e 6c 76 | Thisp =| lval.lv|
|000006a0| 61 6c 2e 70 6c 61 63 65 | 3b 0a 20 2a 2f 0a 5f 67 |al.place|;. */._g|
|000006b0| 6f 74 6f 28 6c 2c 70 29 | 20 69 6e 74 20 28 2a 6c |oto(l,p)| int (*l|
|000006c0| 5b 5d 29 28 29 2c 70 3b | 0a 7b 0a 20 20 20 20 75 |[])(),p;|.{. u|
|000006d0| 6e 69 6f 6e 20 76 61 6c | 75 65 20 6c 76 61 6c 3b |nion val|ue lval;|
|000006e0| 0a 0a 20 20 20 20 73 77 | 69 74 63 68 28 73 74 61 |.. sw|itch(sta|
|000006f0| 74 75 73 26 58 4d 4f 44 | 45 29 20 7b 0a 09 63 61 |tus&XMOD|E) {..ca|
|00000700| 73 65 20 4d 5f 43 4f 4d | 50 49 4c 45 3a 20 6c 5b |se M_COM|PILE: l[|
|00000710| 70 5d 20 3d 20 30 3b 0a | 09 63 61 73 65 20 4d 5f |p] = 0;.|.case M_|
|00000720| 46 49 58 55 50 3a 20 72 | 65 74 75 72 6e 28 2b 2b |FIXUP: r|eturn(++|
|00000730| 70 29 3b 0a 09 64 65 66 | 61 75 6c 74 3a 0a 09 20 |p);..def|ault:.. |
|00000740| 20 20 20 6c 76 61 6c 20 | 3d 20 70 6f 70 28 29 3b | lval |= pop();|
|00000750| 0a 09 20 20 20 20 69 66 | 28 6c 76 61 6c 2e 6c 76 |.. if|(lval.lv|
|00000760| 61 6c 2e 63 6f 64 65 6c | 69 73 74 20 3d 3d 20 30 |al.codel|ist == 0|
|00000770| 29 20 55 4c 65 72 72 6f | 72 28 6c 2c 70 29 3b 0a |) ULerro|r(l,p);.|
|00000780| 09 20 20 20 20 54 68 69 | 73 6c 69 6e 65 20 3d 20 |. Thi|sline = |
|00000790| 6c 76 61 6c 2e 6c 76 61 | 6c 2e 63 6f 64 65 6c 69 |lval.lva|l.codeli|
|000007a0| 73 74 3b 0a 09 20 20 20 | 20 54 68 69 73 6c 69 6e |st;.. | Thislin|
|000007b0| 65 2d 2d 3b 0a 09 20 20 | 20 20 54 68 69 73 70 20 |e--;.. | Thisp |
|000007c0| 3d 20 6c 76 61 6c 2e 6c | 76 61 6c 2e 70 6c 61 63 |= lval.l|val.plac|
|000007d0| 65 3b 0a 69 66 28 64 62 | 67 29 20 70 72 69 6e 74 |e;.if(db|g) print|
|000007e0| 66 28 22 5f 67 6f 74 6f | 3a 45 58 45 43 3a 74 6f |f("_goto|:EXEC:to|
|000007f0| 3a 6c 6c 65 6e 74 3a 25 | 6f 3a 70 6c 3a 25 64 3a |:llent:%|o:pl:%d:|
|00000800| 6e 75 6d 3a 25 75 5c 6e | 22 2c 6c 76 61 6c 2e 6c |num:%u\n|",lval.l|
|00000810| 76 61 6c 2e 63 6f 64 65 | 6c 69 73 74 2c 0a 09 6c |val.code|list,..l|
|00000820| 76 61 6c 2e 6c 76 61 6c | 2e 70 6c 61 63 65 2c 6c |val.lval|.place,l|
|00000830| 76 61 6c 2e 6c 76 61 6c | 2e 63 6f 64 65 6c 69 73 |val.lval|.codelis|
|00000840| 74 2d 3e 6e 75 6d 29 3b | 0a 09 20 20 20 20 72 65 |t->num);|.. re|
|00000850| 74 75 72 6e 28 70 29 3b | 0a 20 20 20 20 7d 0a 7d |turn(p);|. }.}|
|00000860| 0a 0a 2f 2a 20 4d 5f 43 | 4f 4d 50 49 4c 45 3a 0a |../* M_C|OMPILE:.|
|00000870| 20 2a 09 78 20 64 6c 61 | 62 65 6c 20 6e 61 6d 65 | *.x dla|bel name|
|00000880| 20 78 20 20 20 20 2d 2d | 74 6f 2d 2d 20 20 20 20 | x --|to-- |
|00000890| 78 2c 5f 64 6c 61 62 65 | 6c 2c 26 76 6c 69 73 74 |x,_dlabe|l,&vlist|
|000008a0| 20 65 6e 74 72 79 2c 78 | 0a 20 2a 20 4d 5f 46 49 | entry,x|. * M_FI|
|000008b0| 58 55 50 3a 0a 20 2a 09 | 4d 61 6b 65 20 76 6c 69 |XUP:. *.|Make vli|
|000008c0| 73 74 20 65 6e 74 72 79 | 20 66 6f 72 20 22 6e 61 |st entry| for "na|
|000008d0| 6d 65 22 20 70 6f 69 6e | 74 20 74 6f 20 63 75 72 |me" poin|t to cur|
|000008e0| 72 65 6e 74 20 70 6c 61 | 63 65 2e 0a 20 2a 2f 0a |rent pla|ce.. */.|
|000008f0| 5f 64 6c 61 62 65 6c 28 | 6c 2c 70 29 20 69 6e 74 |_dlabel(|l,p) int|
|00000900| 20 28 2a 6c 5b 5d 29 28 | 29 2c 70 3b 0a 7b 0a 20 | (*l[])(|),p;.{. |
|00000910| 20 20 20 73 74 72 75 63 | 74 20 64 69 63 74 6e 6f | struc|t dictno|
|00000920| 64 65 20 2a 76 70 3b 0a | 20 20 20 20 63 68 61 72 |de *vp;.| char|
|00000930| 20 2a 73 3b 0a 0a 20 20 | 20 20 73 77 69 74 63 68 | *s;.. | switch|
|00000940| 28 73 74 61 74 75 73 26 | 58 4d 4f 44 45 29 20 7b |(status&|XMODE) {|
|00000950| 0a 09 63 61 73 65 20 4d | 5f 43 4f 4d 50 49 4c 45 |..case M|_COMPILE|
|00000960| 3a 0a 09 20 20 20 20 73 | 3d 67 74 6f 6b 28 29 3b |:.. s|=gtok();|
|00000970| 0a 09 20 20 20 20 76 70 | 3d 67 76 61 64 72 28 73 |.. vp|=gvadr(s|
|00000980| 2c 54 5f 4c 42 4c 29 3b | 0a 09 20 20 20 20 6c 5b |,T_LBL);|.. l[|
|00000990| 70 2b 2b 5d 20 3d 20 76 | 70 3b 0a 09 20 20 20 20 |p++] = v|p;.. |
|000009a0| 72 65 74 75 72 6e 28 70 | 29 3b 0a 09 63 61 73 65 |return(p|);..case|
|000009b0| 20 4d 5f 46 49 58 55 50 | 3a 0a 09 20 20 20 20 76 | M_FIXUP|:.. v|
|000009c0| 70 3d 6c 5b 70 2b 2b 5d | 3b 0a 09 20 20 20 20 76 |p=l[p++]|;.. v|
|000009d0| 70 2d 3e 76 61 6c 2e 6c | 76 61 6c 2e 63 6f 64 65 |p->val.l|val.code|
|000009e0| 6c 69 73 74 20 3d 20 28 | 69 6e 74 20 2a 2a 29 67 |list = (|int **)g|
|000009f0| 6c 6c 65 6e 74 72 79 28 | 6c 29 3b 0a 09 20 20 20 |llentry(|l);.. |
|00000a00| 20 76 70 2d 3e 76 61 6c | 2e 6c 76 61 6c 2e 70 6c | vp->val|.lval.pl|
|00000a10| 61 63 65 20 3d 20 70 3b | 0a 09 20 20 20 20 72 65 |ace = p;|.. re|
|00000a20| 74 75 72 6e 28 70 29 3b | 0a 09 64 65 66 61 75 6c |turn(p);|..defaul|
|00000a30| 74 3a 20 72 65 74 75 72 | 6e 28 2b 2b 70 29 3b 0a |t: retur|n(++p);.|
|00000a40| 20 20 20 20 7d 0a 7d 0a | 0a 2f 2a 20 4d 5f 43 4f | }.}.|./* M_CO|
|00000a50| 4d 50 49 4c 45 3a 0a 20 | 2a 09 78 20 72 6c 61 62 |MPILE:. |*.x rlab|
|00000a60| 65 6c 20 6e 61 6d 65 20 | 78 20 20 20 20 2d 2d 74 |el name |x --t|
|00000a70| 6f 2d 2d 20 20 20 20 20 | 78 2c 72 6c 61 62 65 6c |o-- |x,rlabel|
|00000a80| 2c 26 76 6c 69 73 74 20 | 65 6e 74 72 79 2c 78 0a |,&vlist |entry,x.|
|00000a90| 20 2a 20 61 6e 79 20 6f | 74 68 65 72 20 6d 6f 64 | * any o|ther mod|
|00000aa0| 65 3a 0a 20 2a 09 70 75 | 73 68 28 76 70 2d 3e 76 |e:. *.pu|sh(vp->v|
|00000ab0| 61 6c 29 20 20 20 20 28 | 69 2e 65 2e 20 20 70 6f |al) (|i.e. po|
|00000ac0| 69 6e 74 65 72 20 74 6f | 20 6c 6f 63 61 74 69 6f |inter to| locatio|
|00000ad0| 6e 20 6f 66 20 6c 61 62 | 65 6c 29 0a 20 2a 2f 0a |n of lab|el). */.|
|00000ae0| 5f 72 6c 61 62 65 6c 28 | 6c 2c 70 29 20 69 6e 74 |_rlabel(|l,p) int|
|00000af0| 20 28 2a 6c 5b 5d 29 28 | 29 2c 70 3b 0a 7b 0a 20 | (*l[])(|),p;.{. |
|00000b00| 20 20 20 73 74 72 75 63 | 74 20 64 69 63 74 6e 6f | struc|t dictno|
|00000b10| 64 65 20 2a 76 70 3b 0a | 20 20 20 20 63 68 61 72 |de *vp;.| char|
|00000b20| 20 2a 73 3b 0a 0a 20 20 | 20 20 73 77 69 74 63 68 | *s;.. | switch|
|00000b30| 28 73 74 61 74 75 73 26 | 58 4d 4f 44 45 29 20 7b |(status&|XMODE) {|
|00000b40| 0a 09 63 61 73 65 20 4d | 5f 43 4f 4d 50 49 4c 45 |..case M|_COMPILE|
|00000b50| 3a 0a 09 20 20 20 20 73 | 3d 67 74 6f 6b 28 29 3b |:.. s|=gtok();|
|00000b60| 0a 09 20 20 20 20 76 70 | 3d 67 76 61 64 72 28 73 |.. vp|=gvadr(s|
|00000b70| 2c 54 5f 4c 42 4c 29 3b | 0a 09 20 20 20 20 6c 5b |,T_LBL);|.. l[|
|00000b80| 70 2b 2b 5d 20 3d 20 76 | 70 3b 0a 09 20 20 20 20 |p++] = v|p;.. |
|00000b90| 72 65 74 75 72 6e 28 70 | 29 3b 0a 09 63 61 73 65 |return(p|);..case|
|00000ba0| 20 4d 5f 46 49 58 55 50 | 3a 20 72 65 74 75 72 6e | M_FIXUP|: return|
|00000bb0| 28 2b 2b 70 29 3b 0a 09 | 64 65 66 61 75 6c 74 3a |(++p);..|default:|
|00000bc0| 0a 09 20 20 20 20 76 70 | 20 3d 20 6c 5b 70 2b 2b |.. vp| = l[p++|
|00000bd0| 5d 3b 0a 69 66 28 64 62 | 67 29 20 70 72 69 6e 74 |];.if(db|g) print|
|00000be0| 66 28 22 5f 72 6c 61 62 | 65 6c 3a 4d 5f 45 58 45 |f("_rlab|el:M_EXE|
|00000bf0| 43 55 54 45 3a 6e 61 6d | 65 3a 25 73 3a 6c 6c 65 |CUTE:nam|e:%s:lle|
|00000c00| 6e 74 3a 25 6f 3a 70 6c | 61 63 65 3a 25 64 5c 6e |nt:%o:pl|ace:%d\n|
|00000c10| 22 2c 76 70 2d 3e 6e 61 | 6d 65 2c 0a 09 76 70 2d |",vp->na|me,..vp-|
|00000c20| 3e 76 61 6c 2e 6c 76 61 | 6c 2e 63 6f 64 65 6c 69 |>val.lva|l.codeli|
|00000c30| 73 74 2c 76 70 2d 3e 76 | 61 6c 2e 6c 76 61 6c 2e |st,vp->v|al.lval.|
|00000c40| 70 6c 61 63 65 29 3b 0a | 09 20 20 20 20 70 75 73 |place);.|. pus|
|00000c50| 68 28 76 70 2d 3e 76 61 | 6c 29 3b 0a 09 20 20 20 |h(vp->va|l);.. |
|00000c60| 20 72 65 74 75 72 6e 28 | 70 29 3b 0a 20 20 20 20 | return(|p);. |
|00000c70| 7d 0a 7d 0a 0a 2f 2a 20 | 4d 5f 43 4f 4d 50 49 4c |}.}../* |M_COMPIL|
|00000c80| 45 3a 0a 20 2a 09 78 20 | 72 6c 61 62 65 6c 20 6e |E:. *.x |rlabel n|
|00000c90| 61 6d 65 20 67 6f 74 6f | 20 78 20 20 20 20 2d 2d |ame goto| x --|
|00000ca0| 74 6f 2d 2d 20 20 20 20 | 78 2c 5f 72 6c 61 62 65 |to-- |x,_rlabe|
|00000cb0| 6c 2c 6c 76 61 6c 2c 5f | 67 6f 73 75 62 2c 30 2c |l,lval,_|gosub,0,|
|00000cc0| 78 0a 20 2a 0a 20 2a 20 | 4d 5f 45 58 45 43 55 54 |x. *. * |M_EXECUT|
|00000cd0| 45 3a 0a 20 2a 09 73 74 | 61 63 6b 3a 20 6c 76 61 |E:. *.st|ack: lva|
|00000ce0| 6c 2c 78 20 20 20 2d 2d | 74 6f 2d 2d 20 20 20 78 |l,x --|to-- x|
|00000cf0| 0a 20 2a 09 6f 74 68 65 | 72 3a 20 73 61 76 65 73 |. *.othe|r: saves|
|00000d00| 20 63 75 72 72 65 6e 74 | 20 70 6c 61 63 65 20 28 | current| place (|
|00000d10| 6f 6e 20 73 74 61 63 6b | 29 20 61 6e 64 20 6a 75 |on stack|) and ju|
|00000d20| 6d 70 73 20 74 6f 20 6c | 76 61 6c 2e 0a 20 2a 2f |mps to l|val.. */|
|00000d30| 0a 5f 67 6f 73 75 62 28 | 6c 2c 70 29 20 69 6e 74 |._gosub(|l,p) int|
|00000d40| 28 2a 6c 5b 5d 29 28 29 | 2c 70 3b 0a 7b 0a 20 20 |(*l[])()|,p;.{. |
|00000d50| 20 20 75 6e 69 6f 6e 20 | 76 61 6c 75 65 20 68 65 | union |value he|
|00000d60| 72 65 2c 74 68 65 72 65 | 3b 0a 20 20 20 20 73 77 |re,there|;. sw|
|00000d70| 69 74 63 68 28 73 74 61 | 74 75 73 26 58 4d 4f 44 |itch(sta|tus&XMOD|
|00000d80| 45 29 20 7b 0a 09 63 61 | 73 65 20 4d 5f 43 4f 4d |E) {..ca|se M_COM|
|00000d90| 50 49 4c 45 3a 0a 09 63 | 61 73 65 20 4d 5f 46 49 |PILE:..c|ase M_FI|
|00000da0| 58 55 50 3a 0a 09 20 20 | 20 20 6c 5b 70 2b 2b 5d |XUP:.. | l[p++]|
|00000db0| 20 3d 20 30 3b 0a 09 20 | 20 20 20 72 65 74 75 72 | = 0;.. | retur|
|00000dc0| 6e 28 70 29 3b 0a 09 63 | 61 73 65 20 4d 5f 45 58 |n(p);..c|ase M_EX|
|00000dd0| 45 43 55 54 45 3a 0a 09 | 20 20 20 20 74 68 65 72 |ECUTE:..| ther|
|00000de0| 65 20 3d 20 70 6f 70 28 | 29 3b 0a 09 20 20 20 20 |e = pop(|);.. |
|00000df0| 68 65 72 65 2e 6c 76 61 | 6c 2e 63 6f 64 65 6c 69 |here.lva|l.codeli|
|00000e00| 73 74 20 3d 20 67 6c 6c | 65 6e 74 72 79 28 6c 29 |st = gll|entry(l)|
|00000e10| 3b 0a 09 20 20 20 20 68 | 65 72 65 2e 6c 76 61 6c |;.. h|ere.lval|
|00000e20| 2e 70 6c 61 63 65 20 3d | 20 70 2b 31 3b 0a 69 66 |.place =| p+1;.if|
|00000e30| 28 64 62 67 29 20 70 72 | 69 6e 74 66 28 22 5f 67 |(dbg) pr|intf("_g|
|00000e40| 6f 73 75 62 3a 45 58 45 | 43 3a 68 65 72 65 2e 6c |osub:EXE|C:here.l|
|00000e50| 3a 25 6f 3a 68 65 72 65 | 2e 70 6c 3a 25 64 3a 74 |:%o:here|.pl:%d:t|
|00000e60| 68 65 72 65 2e 6c 3a 25 | 6f 3a 74 68 65 72 65 2e |here.l:%|o:there.|
|00000e70| 70 6c 3a 25 64 5c 6e 22 | 2c 0a 09 68 65 72 65 2e |pl:%d\n"|,..here.|
|00000e80| 6c 76 61 6c 2e 63 6f 64 | 65 6c 69 73 74 2c 68 65 |lval.cod|elist,he|
|00000e90| 72 65 2e 6c 76 61 6c 2e | 70 6c 61 63 65 2c 74 68 |re.lval.|place,th|
|00000ea0| 65 72 65 2e 6c 76 61 6c | 2e 63 6f 64 65 6c 69 73 |ere.lval|.codelis|
|00000eb0| 74 2c 74 68 65 72 65 2e | 6c 76 61 6c 2e 70 6c 61 |t,there.|lval.pla|
|00000ec0| 63 65 29 3b 0a 09 20 20 | 20 20 70 75 73 68 28 68 |ce);.. | push(h|
|00000ed0| 65 72 65 29 3b 0a 09 20 | 20 20 20 54 68 69 73 6c |ere);.. | Thisl|
|00000ee0| 69 6e 65 20 3d 20 74 68 | 65 72 65 2e 6c 76 61 6c |ine = th|ere.lval|
|00000ef0| 2e 63 6f 64 65 6c 69 73 | 74 3b 0a 09 20 20 20 20 |.codelis|t;.. |
|00000f00| 54 68 69 73 6c 69 6e 65 | 2d 2d 3b 0a 09 20 20 20 |Thisline|--;.. |
|00000f10| 20 54 68 69 73 70 20 3d | 20 74 68 65 72 65 2e 6c | Thisp =| there.l|
|00000f20| 76 61 6c 2e 70 6c 61 63 | 65 3b 0a 09 20 20 20 20 |val.plac|e;.. |
|00000f30| 72 65 74 75 72 6e 28 70 | 29 3b 0a 09 64 65 66 61 |return(p|);..defa|
|00000f40| 75 6c 74 3a 20 53 54 65 | 72 72 6f 72 28 22 67 6f |ult: STe|rror("go|
|00000f50| 73 75 62 22 29 3b 0a 20 | 20 20 20 7d 0a 7d 0a 0a |sub");. | }.}..|
|00000f60| 5f 72 65 74 75 72 6e 28 | 6c 2c 70 29 20 69 6e 74 |_return(|l,p) int|
|00000f70| 28 2a 6c 5b 5d 29 28 29 | 2c 70 3b 0a 7b 0a 20 20 |(*l[])()|,p;.{. |
|00000f80| 20 20 75 6e 69 6f 6e 20 | 76 61 6c 75 65 20 6c 6f | union |value lo|
|00000f90| 63 3b 0a 20 20 20 20 73 | 77 69 74 63 68 28 73 74 |c;. s|witch(st|
|00000fa0| 61 74 75 73 26 58 4d 4f | 44 45 29 20 7b 0a 09 63 |atus&XMO|DE) {..c|
|00000fb0| 61 73 65 20 4d 5f 43 4f | 4d 50 49 4c 45 3a 0a 09 |ase M_CO|MPILE:..|
|00000fc0| 63 61 73 65 20 4d 5f 46 | 49 58 55 50 3a 0a 09 20 |case M_F|IXUP:.. |
|00000fd0| 20 20 20 6c 5b 70 2b 2b | 5d 20 3d 20 30 3b 0a 09 | l[p++|] = 0;..|
|00000fe0| 20 20 20 20 72 65 74 75 | 72 6e 28 70 29 3b 0a 09 | retu|rn(p);..|
|00000ff0| 63 61 73 65 20 4d 5f 45 | 58 45 43 55 54 45 3a 0a |case M_E|XECUTE:.|
|00001000| 09 20 20 20 20 6c 6f 63 | 20 3d 20 70 6f 70 28 29 |. loc| = pop()|
|00001010| 3b 0a 09 20 20 20 20 54 | 68 69 73 70 20 3d 20 6c |;.. T|hisp = l|
|00001020| 6f 63 2e 6c 76 61 6c 2e | 70 6c 61 63 65 3b 0a 09 |oc.lval.|place;..|
|00001030| 20 20 20 20 54 68 69 73 | 6c 69 6e 65 20 3d 20 6c | This|line = l|
|00001040| 6f 63 2e 6c 76 61 6c 2e | 63 6f 64 65 6c 69 73 74 |oc.lval.|codelist|
|00001050| 3b 0a 09 20 20 20 20 54 | 68 69 73 6c 69 6e 65 2d |;.. T|hisline-|
|00001060| 2d 3b 0a 09 20 20 20 20 | 72 65 74 75 72 6e 28 70 |-;.. |return(p|
|00001070| 29 3b 0a 09 64 65 66 61 | 75 6c 74 3a 0a 09 20 20 |);..defa|ult:.. |
|00001080| 20 20 53 54 65 72 72 6f | 72 28 22 72 65 74 75 72 | STerro|r("retur|
|00001090| 6e 22 29 3b 0a 20 20 20 | 20 7d 0a 7d 0a 0a 2f 2a |n");. | }.}../*|
|000010a0| 20 52 6f 75 74 69 6e 65 | 73 20 63 6f 6e 74 72 6f | Routine|s contro|
|000010b0| 6c 20 65 6e 74 65 72 69 | 6e 67 20 61 6e 64 20 6c |l enteri|ng and l|
|000010c0| 65 61 76 69 6e 67 20 6f | 66 20 6c 6f 6f 70 73 2e |eaving o|f loops.|
|000010d0| 0a 20 2a 0a 20 2a 09 65 | 6e 74 65 72 20 2d 2d 20 |. *. *.e|nter -- |
|000010e0| 6d 61 6b 65 73 20 61 20 | 6d 61 72 6b 20 74 68 61 |makes a |mark tha|
|000010f0| 74 20 77 65 20 68 61 76 | 65 20 65 6e 74 65 72 65 |t we hav|e entere|
|00001100| 64 20 61 20 6c 6f 6f 70 | 2c 20 61 6e 64 20 61 6c |d a loop|, and al|
|00001110| 73 6f 20 72 65 63 6f 72 | 64 73 0a 20 2a 09 09 20 |so recor|ds. *.. |
|00001120| 62 72 61 6e 63 68 20 70 | 6f 69 6e 74 73 20 66 6f |branch p|oints fo|
|00001130| 72 20 22 63 6f 6e 74 69 | 6e 75 65 22 20 61 6e 64 |r "conti|nue" and|
|00001140| 20 22 6c 65 61 76 65 22 | 2e 0a 20 2a 09 65 78 69 | "leave"|.. *.exi|
|00001150| 74 6c 70 20 2d 2d 20 75 | 6e 64 6f 65 73 20 74 68 |tlp -- u|ndoes th|
|00001160| 65 20 6d 61 72 6b 20 6d | 61 64 65 20 62 79 20 65 |e mark m|ade by e|
|00001170| 6e 74 65 72 2e 0a 20 2a | 09 63 6f 6e 74 69 6e 20 |nter.. *|.contin |
|00001180| 2d 2d 20 62 72 61 6e 63 | 68 65 73 20 74 6f 20 22 |-- branc|hes to "|
|00001190| 63 6f 6e 74 69 6e 75 65 | 22 20 70 6f 69 6e 74 2e |continue|" point.|
|000011a0| 0a 20 2a 09 6c 65 61 76 | 65 20 2d 2d 20 62 72 61 |. *.leav|e -- bra|
|000011b0| 6e 63 68 65 73 20 74 6f | 20 22 6c 65 61 76 65 22 |nches to| "leave"|
|000011c0| 20 70 6f 69 6e 74 2e 0a | 20 2a 0a 20 2a 20 54 68 | point..| *. * Th|
|000011d0| 65 20 66 6f 6c 6c 6f 77 | 69 6e 67 20 73 74 61 63 |e follow|ing stac|
|000011e0| 6b 20 73 74 72 75 63 74 | 75 72 65 20 69 73 20 75 |k struct|ure is u|
|000011f0| 73 65 64 20 74 6f 20 72 | 65 63 6f 72 64 20 74 68 |sed to r|ecord th|
|00001200| 65 73 65 20 6c 6f 6f 70 | 20 6d 61 72 6b 65 72 73 |ese loop| markers|
|00001210| 2e 0a 20 2a 2f 0a 0a 73 | 74 72 75 63 74 20 6c 6f |.. */..s|truct lo|
|00001220| 6f 70 73 74 61 63 6b 20 | 7b 0a 09 73 74 72 75 63 |opstack |{..struc|
|00001230| 74 20 6c 61 62 65 6c 20 | 63 6f 6e 74 6c 62 2c 6c |t label |contlb,l|
|00001240| 65 61 76 6c 62 3b 0a 7d | 3b 0a 0a 73 74 72 75 63 |eavlb;.}|;..struc|
|00001250| 74 20 6c 6f 6f 70 73 74 | 61 63 6b 20 6c 70 73 74 |t loopst|ack lpst|
|00001260| 6b 5b 32 30 5d 3b 0a 69 | 6e 74 20 6c 70 73 74 6b |k[20];.i|nt lpstk|
|00001270| 70 20 3d 20 2d 31 3b 09 | 2f 2a 20 2d 31 20 77 68 |p = -1;.|/* -1 wh|
|00001280| 65 6e 20 73 74 61 63 6b | 20 69 73 20 65 6d 70 74 |en stack| is empt|
|00001290| 79 2e 0a 09 09 09 20 2a | 20 61 6c 77 61 79 73 20 |y..... *| always |
|000012a0| 70 6f 69 6e 74 73 20 74 | 6f 20 43 55 52 52 45 4e |points t|o CURREN|
|000012b0| 54 20 6c 6f 6f 70 20 6d | 61 72 6b 65 72 2e 0a 09 |T loop m|arker...|
|000012c0| 09 09 20 2a 2f 0a 0a 2f | 2a 20 4d 5f 43 4f 4d 50 |.. */../|* M_COMP|
|000012d0| 49 4c 45 3a 0a 20 2a 09 | 78 20 72 6c 61 62 65 6c |ILE:. *.|x rlabel|
|000012e0| 20 63 6f 6e 74 6c 62 20 | 72 6c 61 62 65 6c 20 6c | contlb |rlabel l|
|000012f0| 65 61 76 6c 62 20 65 6e | 74 65 72 20 78 0a 20 2a |eavlb en|ter x. *|
|00001300| 2d 2d 74 6f 2d 2d 0a 20 | 2a 09 78 2c 5f 72 6c 61 |--to--. |*.x,_rla|
|00001310| 62 65 6c 2c 63 6f 6e 74 | 6c 62 2c 5f 72 6c 61 62 |bel,cont|lb,_rlab|
|00001320| 65 6c 2c 5f 6c 65 61 76 | 6c 62 2c 5f 65 6e 74 65 |el,_leav|lb,_ente|
|00001330| 72 2c 78 0a 20 2a 0a 20 | 2a 20 4d 5f 45 58 45 43 |r,x. *. |* M_EXEC|
|00001340| 55 54 45 3a 0a 20 2a 09 | 6c 6f 6f 70 73 74 61 63 |UTE:. *.|loopstac|
|00001350| 6b 3a 20 78 20 20 20 20 | 2d 2d 74 6f 2d 2d 20 20 |k: x |--to-- |
|00001360| 20 3c 63 6f 6e 74 6c 62 | 2c 6c 65 61 76 6c 62 3e | <contlb|,leavlb>|
|00001370| 2c 78 0a 20 2a 2f 0a 5f | 65 6e 74 65 72 28 6c 2c |,x. */._|enter(l,|
|00001380| 70 29 20 69 6e 74 20 28 | 2a 6c 5b 5d 29 28 29 2c |p) int (|*l[])(),|
|00001390| 70 3b 0a 7b 0a 20 20 20 | 20 75 6e 69 6f 6e 20 76 |p;.{. | union v|
|000013a0| 61 6c 75 65 20 6c 6f 63 | 3b 0a 0a 20 20 20 20 69 |alue loc|;.. i|
|000013b0| 66 28 28 73 74 61 74 75 | 73 26 58 4d 4f 44 45 29 |f((statu|s&XMODE)|
|000013c0| 20 3d 3d 20 4d 5f 45 58 | 45 43 55 54 45 29 20 7b | == M_EX|ECUTE) {|
|000013d0| 0a 09 6c 70 73 74 6b 70 | 2b 2b 3b 0a 09 6c 6f 63 |..lpstkp|++;..loc|
|000013e0| 20 3d 20 70 6f 70 28 29 | 3b 0a 69 66 28 64 62 67 | = pop()|;.if(dbg|
|000013f0| 29 20 70 72 69 6e 74 66 | 28 22 5f 65 6e 74 65 72 |) printf|("_enter|
|00001400| 3a 45 58 45 43 3a 6c 70 | 73 70 3a 25 64 3a 6c 65 |:EXEC:lp|sp:%d:le|
|00001410| 61 76 2e 6c 69 73 74 3a | 25 6f 3a 6c 65 61 76 2e |av.list:|%o:leav.|
|00001420| 70 6c 3a 25 64 22 2c 6c | 70 73 74 6b 70 2c 0a 09 |pl:%d",l|pstkp,..|
|00001430| 6c 6f 63 2e 6c 76 61 6c | 2e 63 6f 64 65 6c 69 73 |loc.lval|.codelis|
|00001440| 74 2c 6c 6f 63 2e 6c 76 | 61 6c 2e 70 6c 61 63 65 |t,loc.lv|al.place|
|00001450| 29 3b 0a 09 6c 70 73 74 | 6b 5b 6c 70 73 74 6b 70 |);..lpst|k[lpstkp|
|00001460| 5d 2e 6c 65 61 76 6c 62 | 2e 63 6f 64 65 6c 69 73 |].leavlb|.codelis|
|00001470| 74 20 3d 20 6c 6f 63 2e | 6c 76 61 6c 2e 63 6f 64 |t = loc.|lval.cod|
|00001480| 65 6c 69 73 74 3b 0a 09 | 6c 70 73 74 6b 5b 6c 70 |elist;..|lpstk[lp|
|00001490| 73 74 6b 70 5d 2e 6c 65 | 61 76 6c 62 2e 70 6c 61 |stkp].le|avlb.pla|
|000014a0| 63 65 20 3d 20 6c 6f 63 | 2e 6c 76 61 6c 2e 70 6c |ce = loc|.lval.pl|
|000014b0| 61 63 65 3b 0a 09 6c 6f | 63 20 3d 20 70 6f 70 28 |ace;..lo|c = pop(|
|000014c0| 29 3b 0a 69 66 28 64 62 | 67 29 20 70 72 69 6e 74 |);.if(db|g) print|
|000014d0| 66 28 22 3a 63 6f 6e 74 | 2e 6c 69 73 74 3a 25 6f |f(":cont|.list:%o|
|000014e0| 3a 63 6f 6e 74 2e 70 6c | 3a 25 64 5c 6e 22 2c 6c |:cont.pl|:%d\n",l|
|000014f0| 6f 63 2e 6c 76 61 6c 2e | 63 6f 64 65 6c 69 73 74 |oc.lval.|codelist|
|00001500| 2c 6c 6f 63 2e 6c 76 61 | 6c 2e 70 6c 61 63 65 29 |,loc.lva|l.place)|
|00001510| 3b 0a 09 6c 70 73 74 6b | 5b 6c 70 73 74 6b 70 5d |;..lpstk|[lpstkp]|
|00001520| 2e 63 6f 6e 74 6c 62 2e | 63 6f 64 65 6c 69 73 74 |.contlb.|codelist|
|00001530| 20 3d 20 6c 6f 63 2e 6c | 76 61 6c 2e 63 6f 64 65 | = loc.l|val.code|
|00001540| 6c 69 73 74 3b 0a 09 6c | 70 73 74 6b 5b 6c 70 73 |list;..l|pstk[lps|
|00001550| 74 6b 70 5d 2e 63 6f 6e | 74 6c 62 2e 70 6c 61 63 |tkp].con|tlb.plac|
|00001560| 65 20 3d 20 6c 6f 63 2e | 6c 76 61 6c 2e 70 6c 61 |e = loc.|lval.pla|
|00001570| 63 65 3b 0a 20 20 20 20 | 7d 0a 20 20 20 20 72 65 |ce;. |}. re|
|00001580| 74 75 72 6e 28 70 29 3b | 0a 7d 0a 0a 2f 2a 20 4d |turn(p);|.}../* M|
|00001590| 5f 45 58 45 43 55 54 45 | 3a 0a 20 2a 09 6c 6f 6f |_EXECUTE|:. *.loo|
|000015a0| 70 73 74 61 63 6b 3a 20 | 3c 63 6f 6e 74 6c 62 2c |pstack: |<contlb,|
|000015b0| 6c 65 61 76 6c 62 3e 2c | 78 20 20 20 20 2d 2d 74 |leavlb>,|x --t|
|000015c0| 6f 2d 2d 20 20 20 78 0a | 20 2a 09 6f 74 68 65 72 |o-- x.| *.other|
|000015d0| 3a 20 65 6e 73 75 72 65 | 73 20 74 68 61 74 20 6c |: ensure|s that l|
|000015e0| 70 73 74 6b 70 20 64 6f | 65 73 6e 74 20 67 65 74 |pstkp do|esnt get|
|000015f0| 20 6c 65 73 73 20 74 68 | 61 74 20 2d 31 3b 0a 20 | less th|at -1;. |
|00001600| 2a 2f 0a 5f 65 78 69 74 | 6c 70 28 6c 2c 70 29 20 |*/._exit|lp(l,p) |
|00001610| 69 6e 74 20 28 2a 6c 5b | 5d 29 28 29 2c 70 3b 0a |int (*l[|])(),p;.|
|00001620| 7b 0a 20 20 20 20 69 66 | 28 28 73 74 61 74 75 73 |{. if|((status|
|00001630| 26 58 4d 4f 44 45 29 20 | 3d 3d 20 4d 5f 45 58 45 |&XMODE) |== M_EXE|
|00001640| 43 55 54 45 29 0a 09 69 | 66 28 6c 70 73 74 6b 70 |CUTE)..i|f(lpstkp|
|00001650| 20 3e 3d 20 30 29 0a 09 | 20 20 20 20 6c 70 73 74 | >= 0)..| lpst|
|00001660| 6b 70 2d 2d 3b 0a 09 65 | 6c 73 65 0a 09 20 20 20 |kp--;..e|lse.. |
|00001670| 20 6c 70 73 74 6b 70 20 | 3d 20 2d 31 3b 0a 69 66 | lpstkp |= -1;.if|
|00001680| 28 64 62 67 29 20 70 72 | 69 6e 74 66 28 22 5f 65 |(dbg) pr|intf("_e|
|00001690| 78 69 74 6c 70 3a 4d 5f | 25 64 3a 6c 70 73 74 6b |xitlp:M_|%d:lpstk|
|000016a0| 70 3a 25 64 5c 6e 22 2c | 73 74 61 74 75 73 2c 6c |p:%d\n",|status,l|
|000016b0| 70 73 74 6b 70 29 3b 0a | 20 20 20 20 72 65 74 75 |pstkp);.| retu|
|000016c0| 72 6e 28 70 29 3b 0a 7d | 0a 0a 2f 2a 20 4d 5f 43 |rn(p);.}|../* M_C|
|000016d0| 4f 4d 50 49 4c 45 3a 0a | 20 2a 09 78 20 6c 65 61 |OMPILE:.| *.x lea|
|000016e0| 76 65 20 78 20 20 20 2d | 2d 74 6f 2d 2d 20 20 20 |ve x -|-to-- |
|000016f0| 78 2c 5f 6c 65 61 76 65 | 2c 30 2c 78 0a 20 2a 09 |x,_leave|,0,x. *.|
|00001700| 28 74 68 65 20 30 20 69 | 73 20 66 6f 72 20 74 68 |(the 0 i|s for th|
|00001710| 65 20 62 65 6e 65 66 69 | 74 20 6f 66 20 69 6e 74 |e benefi|t of int|
|00001720| 65 72 70 28 29 29 0a 20 | 2a 0a 20 2a 20 4d 5f 45 |erp()). |*. * M_E|
|00001730| 58 45 43 55 54 45 3a 0a | 20 2a 09 6c 6f 6f 70 73 |XECUTE:.| *.loops|
|00001740| 74 61 63 6b 3a 20 3c 63 | 6f 6e 74 6c 62 2c 6c 65 |tack: <c|ontlb,le|
|00001750| 61 76 6c 62 3e 2c 78 20 | 20 20 2d 2d 74 6f 2d 2d |avlb>,x | --to--|
|00001760| 20 20 20 3c 63 6f 6e 74 | 6c 62 2c 6c 65 61 76 6c | <cont|lb,leavl|
|00001770| 62 3e 2c 78 0a 20 2a 09 | 6f 74 68 65 72 3a 20 62 |b>,x. *.|other: b|
|00001780| 72 61 6e 63 68 65 73 20 | 74 6f 20 6c 65 61 76 6c |ranches |to leavl|
|00001790| 62 2e 20 20 65 78 69 74 | 6c 70 20 74 61 6b 65 73 |b. exit|lp takes|
|000017a0| 20 63 61 72 65 20 6f 66 | 20 63 6c 65 61 6e 69 6e | care of| cleanin|
|000017b0| 67 20 75 70 20 73 74 61 | 63 6b 2e 0a 20 2a 2f 0a |g up sta|ck.. */.|
|000017c0| 5f 6c 65 61 76 65 28 6c | 2c 70 29 20 69 6e 74 28 |_leave(l|,p) int(|
|000017d0| 2a 6c 5b 5d 29 28 29 2c | 70 3b 0a 7b 0a 20 20 20 |*l[])(),|p;.{. |
|000017e0| 20 73 77 69 74 63 68 28 | 73 74 61 74 75 73 26 58 | switch(|status&X|
|000017f0| 4d 4f 44 45 29 20 7b 0a | 09 63 61 73 65 20 4d 5f |MODE) {.|.case M_|
|00001800| 43 4f 4d 50 49 4c 45 3a | 0a 09 63 61 73 65 20 4d |COMPILE:|..case M|
|00001810| 5f 46 49 58 55 50 3a 20 | 6c 5b 70 2b 2b 5d 20 3d |_FIXUP: |l[p++] =|
|00001820| 20 30 3b 20 72 65 74 75 | 72 6e 28 70 29 3b 0a 09 | 0; retu|rn(p);..|
|00001830| 63 61 73 65 20 4d 5f 45 | 58 45 43 55 54 45 3a 0a |case M_E|XECUTE:.|
|00001840| 09 20 20 20 20 69 66 28 | 6c 70 73 74 6b 70 20 3d |. if(|lpstkp =|
|00001850| 3d 20 2d 31 29 20 2f 2a | 20 6e 6f 74 20 69 6e 73 |= -1) /*| not ins|
|00001860| 69 64 65 20 61 20 6c 6f | 6f 70 2c 20 65 72 67 6f |ide a lo|op, ergo|
|00001870| 20 63 61 6e 6e 6f 74 20 | 6c 65 61 76 65 20 61 20 | cannot |leave a |
|00001880| 6c 6f 6f 70 20 2a 2f 0a | 09 09 4c 56 65 72 72 6f |loop */.|..LVerro|
|00001890| 72 28 6c 2c 70 29 3b 0a | 09 20 20 20 20 54 68 69 |r(l,p);.|. Thi|
|000018a0| 73 6c 69 6e 65 20 3d 20 | 6c 70 73 74 6b 5b 6c 70 |sline = |lpstk[lp|
|000018b0| 73 74 6b 70 5d 2e 6c 65 | 61 76 6c 62 2e 63 6f 64 |stkp].le|avlb.cod|
|000018c0| 65 6c 69 73 74 3b 0a 09 | 20 20 20 20 54 68 69 73 |elist;..| This|
|000018d0| 6c 69 6e 65 2d 2d 3b 0a | 09 20 20 20 20 54 68 69 |line--;.|. Thi|
|000018e0| 73 70 20 3d 20 6c 70 73 | 74 6b 5b 6c 70 73 74 6b |sp = lps|tk[lpstk|
|000018f0| 70 5d 2e 6c 65 61 76 6c | 62 2e 70 6c 61 63 65 3b |p].leavl|b.place;|
|00001900| 0a 09 20 20 20 20 72 65 | 74 75 72 6e 28 70 29 3b |.. re|turn(p);|
|00001910| 0a 09 64 65 66 61 75 6c | 74 3a 20 53 54 65 72 72 |..defaul|t: STerr|
|00001920| 6f 72 28 22 6c 65 61 76 | 65 22 29 3b 0a 20 20 20 |or("leav|e");. |
|00001930| 20 7d 0a 7d 0a 0a 2f 2a | 20 4d 5f 43 4f 4d 50 49 | }.}../*| M_COMPI|
|00001940| 4c 45 3a 0a 20 2a 09 78 | 20 63 6f 6e 74 69 6e 20 |LE:. *.x| contin |
|00001950| 78 20 20 20 20 2d 2d 74 | 6f 2d 2d 20 20 20 20 78 |x --t|o-- x|
|00001960| 2c 5f 63 6f 6e 74 69 6e | 2c 30 2c 78 0a 20 2a 0a |,_contin|,0,x. *.|
|00001970| 20 2a 20 4d 5f 45 58 45 | 43 55 54 45 3a 0a 20 2a | * M_EXE|CUTE:. *|
|00001980| 09 6c 6f 6f 70 73 74 61 | 63 6b 3a 20 3c 63 6f 6e |.loopsta|ck: <con|
|00001990| 74 6c 62 2c 6c 65 61 76 | 6c 62 3e 2c 78 20 20 20 |tlb,leav|lb>,x |
|000019a0| 2d 2d 74 6f 2d 2d 20 20 | 20 3c 63 6f 6e 74 6c 62 |--to-- | <contlb|
|000019b0| 2c 6c 65 61 76 6c 62 3e | 2c 78 0a 20 2a 09 6f 74 |,leavlb>|,x. *.ot|
|000019c0| 68 65 72 3a 20 6a 75 6d | 70 73 20 74 6f 20 63 6f |her: jum|ps to co|
|000019d0| 6e 74 6c 62 2e 0a 20 2a | 2f 0a 5f 63 6f 6e 74 69 |ntlb.. *|/._conti|
|000019e0| 6e 28 6c 2c 70 29 20 69 | 6e 74 20 28 2a 6c 5b 5d |n(l,p) i|nt (*l[]|
|000019f0| 29 28 29 2c 70 3b 0a 7b | 0a 20 20 20 20 73 77 69 |)(),p;.{|. swi|
|00001a00| 74 63 68 28 73 74 61 74 | 75 73 26 58 4d 4f 44 45 |tch(stat|us&XMODE|
|00001a10| 29 20 7b 0a 09 63 61 73 | 65 20 4d 5f 43 4f 4d 50 |) {..cas|e M_COMP|
|00001a20| 49 4c 45 3a 0a 09 63 61 | 73 65 20 4d 5f 46 49 58 |ILE:..ca|se M_FIX|
|00001a30| 55 50 3a 20 6c 5b 70 2b | 2b 5d 20 3d 20 30 3b 20 |UP: l[p+|+] = 0; |
|00001a40| 72 65 74 75 72 6e 28 70 | 29 3b 0a 09 63 61 73 65 |return(p|);..case|
|00001a50| 20 4d 5f 45 58 45 43 55 | 54 45 3a 0a 09 20 20 20 | M_EXECU|TE:.. |
|00001a60| 20 69 66 28 6c 70 73 74 | 6b 70 20 3d 3d 20 2d 31 | if(lpst|kp == -1|
|00001a70| 29 20 2f 2a 20 63 61 6e | 6e 6f 74 20 63 6f 6e 74 |) /* can|not cont|
|00001a80| 69 6e 75 65 20 61 20 6c | 6f 6f 70 20 77 65 27 72 |inue a l|oop we'r|
|00001a90| 65 20 6e 6f 74 20 69 6e | 20 2a 2f 0a 09 09 43 4e |e not in| */...CN|
|00001aa0| 65 72 72 6f 72 28 6c 2c | 70 29 3b 0a 09 20 20 20 |error(l,|p);.. |
|00001ab0| 20 54 68 69 73 6c 69 6e | 65 20 3d 20 6c 70 73 74 | Thislin|e = lpst|
|00001ac0| 6b 5b 6c 70 73 74 6b 70 | 5d 2e 63 6f 6e 74 6c 62 |k[lpstkp|].contlb|
|00001ad0| 2e 63 6f 64 65 6c 69 73 | 74 3b 0a 09 20 20 20 20 |.codelis|t;.. |
|00001ae0| 54 68 69 73 6c 69 6e 65 | 2d 2d 3b 0a 09 20 20 20 |Thisline|--;.. |
|00001af0| 20 54 68 69 73 70 20 3d | 20 6c 70 73 74 6b 5b 6c | Thisp =| lpstk[l|
|00001b00| 70 73 74 6b 70 5d 2e 63 | 6f 6e 74 6c 62 2e 70 6c |pstkp].c|ontlb.pl|
|00001b10| 61 63 65 3b 0a 09 20 20 | 20 20 72 65 74 75 72 6e |ace;.. | return|
|00001b20| 28 70 29 3b 0a 09 64 65 | 66 61 75 6c 74 3a 20 53 |(p);..de|fault: S|
|00001b30| 54 65 72 72 6f 72 28 22 | 63 6f 6e 74 69 6e 22 29 |Terror("|contin")|
|00001b40| 3b 0a 20 20 20 20 7d 0a | 7d 0a 0a 0a 0a 2f 2a 20 |;. }.|}..../* |
|00001b50| 4d 5f 43 4f 4d 50 49 4c | 45 3a 0a 20 2a 09 78 20 |M_COMPIL|E:. *.x |
|00001b60| 72 6c 61 62 65 6c 20 6e | 61 6d 65 20 69 66 20 78 |rlabel n|ame if x|
|00001b70| 20 20 20 20 2d 2d 74 6f | 2d 2d 20 20 20 78 2c 5f | --to|-- x,_|
|00001b80| 72 6c 61 62 65 6c 2c 76 | 70 2c 69 66 2c 30 2c 78 |rlabel,v|p,if,0,x|
|00001b90| 0a 20 2a 09 28 74 68 65 | 20 30 20 69 73 20 66 6f |. *.(the| 0 is fo|
|00001ba0| 72 20 74 68 65 20 62 65 | 6e 65 66 69 74 20 66 6f |r the be|nefit fo|
|00001bb0| 72 20 69 6e 74 65 72 70 | 28 29 29 2e 0a 20 2a 20 |r interp|()).. * |
|00001bc0| 4d 5f 45 58 45 43 55 54 | 45 3a 0a 20 2a 09 73 74 |M_EXECUT|E:. *.st|
|00001bd0| 61 63 6b 3a 20 6c 6f 63 | 2c 62 6f 6f 6c 2c 78 20 |ack: loc|,bool,x |
|00001be0| 20 20 20 20 2d 2d 74 6f | 2d 2d 20 20 20 78 0a 20 | --to|-- x. |
|00001bf0| 2a 09 70 3a 20 69 66 20 | 62 6f 6f 6c 2c 20 70 3d |*.p: if |bool, p=|
|00001c00| 70 20 65 6c 73 65 20 70 | 3d 6c 6f 63 2d 3e 70 6c |p else p|=loc->pl|
|00001c10| 61 63 65 0a 20 2a 2f 0a | 5f 69 66 28 6c 2c 70 29 |ace. */.|_if(l,p)|
|00001c20| 0a 69 6e 74 20 28 2a 6c | 5b 5d 29 28 29 2c 70 3b |.int (*l|[])(),p;|
|00001c30| 0a 7b 0a 20 20 20 20 75 | 6e 69 6f 6e 20 76 61 6c |.{. u|nion val|
|00001c40| 75 65 20 62 76 2c 6c 76 | 3b 0a 0a 20 20 20 20 73 |ue bv,lv|;.. s|
|00001c50| 77 69 74 63 68 28 73 74 | 61 74 75 73 26 58 4d 4f |witch(st|atus&XMO|
|00001c60| 44 45 29 20 7b 0a 09 63 | 61 73 65 20 4d 5f 45 58 |DE) {..c|ase M_EX|
|00001c70| 45 43 55 54 45 3a 0a 09 | 20 20 20 20 6c 76 20 3d |ECUTE:..| lv =|
|00001c80| 20 70 6f 70 28 29 3b 0a | 09 20 20 20 20 62 76 20 | pop();.|. bv |
|00001c90| 3d 20 70 6f 70 28 29 3b | 0a 69 66 28 64 62 67 29 |= pop();|.if(dbg)|
|00001ca0| 20 70 72 69 6e 74 66 28 | 22 5f 69 66 3a 4d 5f 45 | printf(|"_if:M_E|
|00001cb0| 58 45 43 55 54 45 3a 6c | 76 2e 70 6c 3a 25 64 3a |XECUTE:l|v.pl:%d:|
|00001cc0| 70 3a 25 64 3a 62 76 2e | 69 76 3a 25 44 5c 6e 22 |p:%d:bv.|iv:%D\n"|
|00001cd0| 2c 6c 76 2e 6c 76 61 6c | 2e 70 6c 61 63 65 2c 0a |,lv.lval|.place,.|
|00001ce0| 09 70 2c 62 76 2e 69 76 | 61 6c 29 3b 0a 09 20 20 |.p,bv.iv|al);.. |
|00001cf0| 20 20 69 66 28 62 76 2e | 69 76 61 6c 20 3d 3d 20 | if(bv.|ival == |
|00001d00| 28 6c 6f 6e 67 29 30 29 | 20 7b 20 2f 2a 20 6a 75 |(long)0)| { /* ju|
|00001d10| 6d 70 20 74 6f 20 65 6c | 73 65 20 70 61 72 74 2e |mp to el|se part.|
|00001d20| 20 2a 2f 0a 09 09 54 68 | 69 73 6c 69 6e 65 20 3d | */...Th|isline =|
|00001d30| 20 6c 76 2e 6c 76 61 6c | 2e 63 6f 64 65 6c 69 73 | lv.lval|.codelis|
|00001d40| 74 3b 0a 09 09 54 68 69 | 73 6c 69 6e 65 2d 2d 3b |t;...Thi|sline--;|
|00001d50| 0a 09 09 54 68 69 73 70 | 20 3d 20 6c 76 2e 6c 76 |...Thisp| = lv.lv|
|00001d60| 61 6c 2e 70 6c 61 63 65 | 3b 0a 09 20 20 20 20 7d |al.place|;.. }|
|00001d70| 0a 09 20 20 20 20 65 6c | 73 65 20 70 2b 2b 3b 09 |.. el|se p++;.|
|00001d80| 2f 2a 20 73 6b 69 70 20 | 74 68 65 20 30 20 73 6f |/* skip |the 0 so|
|00001d90| 20 77 65 20 67 65 74 20 | 74 6f 20 74 68 65 20 74 | we get |to the t|
|00001da0| 68 65 6e 20 70 61 72 74 | 20 2a 2f 0a 09 20 20 20 |hen part| */.. |
|00001db0| 20 72 65 74 75 72 6e 28 | 70 29 3b 0a 09 63 61 73 | return(|p);..cas|
|00001dc0| 65 20 4d 5f 46 49 58 55 | 50 3a 0a 09 63 61 73 65 |e M_FIXU|P:..case|
|00001dd0| 20 4d 5f 43 4f 4d 50 49 | 4c 45 3a 20 6c 5b 70 2b | M_COMPI|LE: l[p+|
|00001de0| 2b 5d 20 3d 20 30 3b 20 | 72 65 74 75 72 6e 28 70 |+] = 0; |return(p|
|00001df0| 29 3b 0a 09 64 65 66 61 | 75 6c 74 3a 20 53 54 65 |);..defa|ult: STe|
|00001e00| 72 72 6f 72 28 22 69 66 | 22 29 3b 0a 20 20 20 20 |rror("if|");. |
|00001e10| 7d 0a 7d 0a 0a 2f 2a 20 | 4d 5f 43 4f 4d 50 49 4c |}.}../* |M_COMPIL|
|00001e20| 45 3a 0a 20 2a 09 76 61 | 72 20 6e 61 6d 65 20 3c |E:. *.va|r name <|
|00001e30| 66 72 6f 6d 3e 65 78 70 | 72 20 3c 74 6f 3e 65 78 |from>exp|r <to>ex|
|00001e40| 70 72 20 3c 73 74 65 70 | 3e 65 78 70 72 20 3c 66 |pr <step|>expr <f|
|00001e50| 6c 61 67 3e 63 6f 6e 20 | 30 20 64 6c 61 62 65 6c |lag>con |0 dlabel|
|00001e60| 20 46 4f 52 78 20 72 6c | 61 62 65 6c 20 46 4f 52 | FORx rl|abel FOR|
|00001e70| 78 2b 31 20 66 6f 72 0a | 20 2a 2d 2d 74 6f 2d 2d |x+1 for.| *--to--|
|00001e80| 0a 20 2a 09 5f 76 61 72 | 2c 76 70 2c 3c 66 72 6f |. *._var|,vp,<fro|
|00001e90| 6d 3e 2c 3c 74 6f 3e 2c | 3c 73 74 65 70 3e 2c 3c |m>,<to>,|<step>,<|
|00001ea0| 66 6c 61 67 3e 2c 30 2c | 5f 64 6c 61 62 65 6c 2c |flag>,0,|_dlabel,|
|00001eb0| 6c 62 6c 70 2c 5f 72 6c | 61 62 65 6c 2c 6c 62 6c |lblp,_rl|abel,lbl|
|00001ec0| 70 32 2c 5f 66 6f 72 0a | 20 2a 0a 20 2a 20 4d 5f |p2,_for.| *. * M_|
|00001ed0| 45 58 45 43 55 54 45 3a | 0a 20 2a 09 73 74 61 63 |EXECUTE:|. *.stac|
|00001ee0| 6b 3a 20 78 69 74 70 74 | 2c 76 69 7a 64 2c 73 74 |k: xitpt|,vizd,st|
|00001ef0| 65 70 2c 74 6f 2c 66 72 | 6f 6d 2c 76 70 2c 78 0a |ep,to,fr|om,vp,x.|
|00001f00| 20 2a 09 6f 74 68 65 72 | 3a 20 69 66 20 65 78 69 | *.other|: if exi|
|00001f10| 74 20 63 6f 6e 64 69 74 | 69 6f 6e 73 20 61 72 65 |t condit|ions are|
|00001f20| 20 63 6f 72 72 65 63 74 | 2c 20 6a 75 6d 70 20 74 | correct|, jump t|
|00001f30| 6f 20 65 78 69 74 20 70 | 6f 69 6e 74 2e 0a 20 2a |o exit p|oint.. *|
|00001f40| 09 09 76 69 7a 64 20 69 | 73 20 75 73 65 64 20 74 |..vizd i|s used t|
|00001f50| 6f 20 68 6f 6c 64 20 74 | 68 65 20 64 61 74 61 20 |o hold t|he data |
|00001f60| 74 79 70 65 20 66 6f 72 | 20 76 70 2e 20 20 44 61 |type for| vp. Da|
|00001f70| 74 61 20 74 79 70 65 73 | 0a 20 2a 09 09 61 72 65 |ta types|. *..are|
|00001f80| 20 61 6c 77 61 79 73 20 | 6e 6f 6e 2d 7a 65 72 6f | always |non-zero|
|00001f90| 20 73 6f 20 74 68 65 20 | 74 65 73 74 20 66 6f 72 | so the |test for|
|00001fa0| 20 74 68 65 20 66 69 72 | 73 74 20 76 69 73 69 74 | the fir|st visit|
|00001fb0| 20 74 6f 0a 20 2a 09 09 | 74 68 65 20 6c 6f 6f 70 | to. *..|the loop|
|00001fc0| 20 69 73 20 74 6f 20 73 | 65 65 20 69 66 20 76 69 | is to s|ee if vi|
|00001fd0| 7a 64 20 69 73 20 30 2e | 0a 20 2a 2f 0a 5f 66 6f |zd is 0.|. */._fo|
|00001fe0| 72 28 6c 2c 70 29 20 69 | 6e 74 28 2a 6c 5b 5d 29 |r(l,p) i|nt(*l[])|
|00001ff0| 28 29 2c 70 3b 0a 7b 0a | 20 20 20 20 75 6e 69 6f |(),p;.{.| unio|
|00002000| 6e 20 76 61 6c 75 65 20 | 78 69 74 70 74 2c 76 69 |n value |xitpt,vi|
|00002010| 7a 64 2c 66 72 6f 6d 2c | 74 6f 2c 73 74 65 70 2c |zd,from,|to,step,|
|00002020| 70 6c 61 63 65 3b 0a 0a | 20 20 20 20 73 77 69 74 |place;..| swit|
|00002030| 63 68 28 73 74 61 74 75 | 73 26 58 4d 4f 44 45 29 |ch(statu|s&XMODE)|
|00002040| 20 7b 0a 09 63 61 73 65 | 20 4d 5f 43 4f 4d 50 49 | {..case| M_COMPI|
|00002050| 4c 45 3a 0a 09 63 61 73 | 65 20 4d 5f 46 49 58 55 |LE:..cas|e M_FIXU|
|00002060| 50 3a 20 6c 5b 70 2b 2b | 5d 20 3d 20 30 3b 20 72 |P: l[p++|] = 0; r|
|00002070| 65 74 75 72 6e 28 70 29 | 3b 0a 09 63 61 73 65 20 |eturn(p)|;..case |
|00002080| 4d 5f 45 58 45 43 55 54 | 45 3a 0a 09 20 20 20 20 |M_EXECUT|E:.. |
|00002090| 78 69 74 70 74 20 3d 20 | 70 6f 70 28 29 3b 09 76 |xitpt = |pop();.v|
|000020a0| 69 7a 64 20 3d 20 70 6f | 70 28 29 3b 0a 09 20 20 |izd = po|p();.. |
|000020b0| 20 20 73 74 65 70 20 3d | 20 70 6f 70 28 29 3b 09 | step =| pop();.|
|000020c0| 74 6f 20 3d 20 70 6f 70 | 28 29 3b 0a 09 20 20 20 |to = pop|();.. |
|000020d0| 20 66 72 6f 6d 20 3d 20 | 70 6f 70 28 29 3b 0a 69 | from = |pop();.i|
|000020e0| 66 28 64 62 67 29 20 70 | 72 69 6e 74 66 28 22 5f |f(dbg) p|rintf("_|
|000020f0| 66 6f 72 3a 45 58 45 43 | 3a 78 69 74 2e 6c 3a 25 |for:EXEC|:xit.l:%|
|00002100| 6f 3a 78 69 74 2e 70 6c | 3a 25 64 3a 76 69 7a 2e |o:xit.pl|:%d:viz.|
|00002110| 69 76 3a 25 44 3a 73 74 | 65 70 2e 69 76 3a 25 44 |iv:%D:st|ep.iv:%D|
|00002120| 3a 74 6f 2e 69 76 3a 25 | 44 3a 66 72 6f 6d 2e 69 |:to.iv:%|D:from.i|
|00002130| 76 3a 25 44 3a 22 2c 0a | 09 78 69 74 70 74 2e 6c |v:%D:",.|.xitpt.l|
|00002140| 76 61 6c 2e 63 6f 64 65 | 6c 69 73 74 2c 78 69 74 |val.code|list,xit|
|00002150| 70 74 2e 6c 76 61 6c 2e | 70 6c 61 63 65 2c 28 6c |pt.lval.|place,(l|
|00002160| 6f 6e 67 29 76 69 7a 64 | 2e 69 76 61 6c 2c 28 6c |ong)vizd|.ival,(l|
|00002170| 6f 6e 67 29 73 74 65 70 | 2e 69 76 61 6c 2c 28 6c |ong)step|.ival,(l|
|00002180| 6f 6e 67 29 74 6f 2e 69 | 76 61 6c 2c 28 6c 6f 6e |ong)to.i|val,(lon|
|00002190| 67 29 66 72 6f 6d 2e 69 | 76 61 6c 29 3b 0a 09 20 |g)from.i|val);.. |
|000021a0| 20 20 20 69 66 28 76 69 | 7a 64 2e 69 76 61 6c 20 | if(vi|zd.ival |
|000021b0| 3d 3d 20 30 29 20 7b 20 | 2f 2a 20 66 69 72 73 74 |== 0) { |/* first|
|000021c0| 20 76 69 73 69 74 20 74 | 6f 20 6c 6f 6f 70 20 2a | visit t|o loop *|
|000021d0| 2f 0a 09 09 70 6c 61 63 | 65 20 3d 20 70 6f 70 28 |/...plac|e = pop(|
|000021e0| 29 3b 0a 69 66 28 64 62 | 67 29 20 70 72 69 6e 74 |);.if(db|g) print|
|000021f0| 66 28 22 66 69 72 73 74 | 20 74 69 6d 65 3a 76 61 |f("first| time:va|
|00002200| 72 3a 25 73 3a 22 2c 70 | 6c 61 63 65 2e 76 70 76 |r:%s:",p|lace.vpv|
|00002210| 61 6c 2d 3e 6e 61 6d 65 | 29 3b 0a 09 09 76 69 7a |al->name|);...viz|
|00002220| 64 2e 69 76 61 6c 20 3d | 20 70 6c 61 63 65 2e 76 |d.ival =| place.v|
|00002230| 70 76 61 6c 2d 3e 74 79 | 70 65 5f 6f 66 5f 76 61 |pval->ty|pe_of_va|
|00002240| 6c 75 65 26 54 5f 54 4d | 41 53 4b 3b 20 2f 2a 20 |lue&T_TM|ASK; /* |
|00002250| 21 3d 20 30 20 2a 2f 0a | 09 09 70 6c 61 63 65 2e |!= 0 */.|..place.|
|00002260| 70 6c 76 61 6c 20 3d 20 | 67 65 74 70 6c 61 63 65 |plval = |getplace|
|00002270| 28 70 6c 61 63 65 2e 76 | 70 76 61 6c 29 3b 0a 09 |(place.v|pval);..|
|00002280| 09 2a 28 70 6c 61 63 65 | 2e 70 6c 76 61 6c 29 20 |.*(place|.plval) |
|00002290| 3d 20 66 72 6f 6d 3b 09 | 2f 2a 20 73 69 6e 63 65 |= from;.|/* since|
|000022a0| 20 66 69 72 73 74 20 74 | 69 6d 65 2c 20 73 65 74 | first t|ime, set|
|000022b0| 20 73 74 61 72 74 69 6e | 67 20 76 61 6c 20 2a 2f | startin|g val */|
|000022c0| 0a 69 66 28 64 62 67 29 | 20 70 72 69 6e 74 66 28 |.if(dbg)| printf(|
|000022d0| 22 76 61 72 2e 70 6c 3a | 25 6f 3a 76 61 72 2e 76 |"var.pl:|%o:var.v|
|000022e0| 61 6c 3a 25 44 3a 22 2c | 70 6c 61 63 65 2e 70 6c |al:%D:",|place.pl|
|000022f0| 76 61 6c 2c 28 6c 6f 6e | 67 29 70 6c 61 63 65 2e |val,(lon|g)place.|
|00002300| 70 6c 76 61 6c 2d 3e 69 | 76 61 6c 29 3b 0a 09 09 |plval->i|val);...|
|00002310| 69 66 28 76 69 7a 64 2e | 69 76 61 6c 3d 3d 54 5f |if(vizd.|ival==T_|
|00002320| 49 4e 54 20 26 26 20 73 | 74 65 70 2e 69 76 61 6c |INT && s|tep.ival|
|00002330| 3d 3d 30 29 0a 09 09 09 | 69 66 28 74 6f 2e 69 76 |==0)....|if(to.iv|
|00002340| 61 6c 20 3c 20 66 72 6f | 6d 2e 69 76 61 6c 29 0a |al < fro|m.ival).|
|00002350| 09 09 09 09 73 74 65 70 | 2e 69 76 61 6c 20 3d 20 |....step|.ival = |
|00002360| 2d 31 3b 0a 09 09 09 65 | 6c 73 65 0a 09 09 09 09 |-1;....e|lse.....|
|00002370| 73 74 65 70 2e 69 76 61 | 6c 20 3d 20 31 3b 0a 09 |step.iva|l = 1;..|
|00002380| 09 65 6c 73 65 20 69 66 | 28 76 69 7a 64 2e 69 76 |.else if|(vizd.iv|
|00002390| 61 6c 3d 3d 54 5f 44 42 | 4c 20 26 26 20 73 74 65 |al==T_DB|L && ste|
|000023a0| 70 2e 72 76 61 6c 3d 3d | 30 29 0a 09 09 09 69 66 |p.rval==|0)....if|
|000023b0| 28 74 6f 2e 72 76 61 6c | 20 3c 20 66 72 6f 6d 2e |(to.rval| < from.|
|000023c0| 72 76 61 6c 29 0a 09 09 | 09 09 73 74 65 70 2e 72 |rval)...|..step.r|
|000023d0| 76 61 6c 20 3d 20 2d 31 | 3b 0a 09 09 09 65 6c 73 |val = -1|;....els|
|000023e0| 65 0a 09 09 09 09 73 74 | 65 70 2e 72 76 61 6c 20 |e.....st|ep.rval |
|000023f0| 3d 20 31 3b 0a 09 20 20 | 20 20 7d 0a 09 20 20 20 |= 1;.. | }.. |
|00002400| 20 65 6c 73 65 20 70 6c | 61 63 65 20 3d 20 70 6f | else pl|ace = po|
|00002410| 70 28 29 3b 0a 69 66 28 | 64 62 67 29 20 70 72 69 |p();.if(|dbg) pri|
|00002420| 6e 74 66 28 22 76 61 72 | 2e 70 6c 61 63 65 3a 25 |ntf("var|.place:%|
|00002430| 6f 3a 22 2c 70 6c 61 63 | 65 2e 70 6c 76 61 6c 29 |o:",plac|e.plval)|
|00002440| 3b 0a 0a 09 20 20 20 20 | 2f 2a 20 54 68 65 20 73 |;... |/* The s|
|00002450| 74 61 63 6b 20 66 72 61 | 6d 65 20 69 73 20 6e 6f |tack fra|me is no|
|00002460| 77 20 63 6f 72 72 65 63 | 74 6c 79 20 70 6f 70 70 |w correc|tly popp|
|00002470| 65 64 20 6f 66 66 2e 0a | 09 20 20 20 20 20 2a 20 |ed off..|. * |
|00002480| 4e 65 78 74 2c 20 77 65 | 20 63 68 65 63 6b 20 69 |Next, we| check i|
|00002490| 66 20 74 68 65 20 6c 6f | 6f 70 20 69 73 20 66 69 |f the lo|op is fi|
|000024a0| 6e 69 73 68 65 64 2e 0a | 09 20 20 20 20 20 2a 2f |nished..|. */|
|000024b0| 0a 0a 09 20 20 20 20 69 | 66 28 76 69 7a 64 2e 69 |... i|f(vizd.i|
|000024c0| 76 61 6c 20 3d 3d 20 54 | 5f 49 4e 54 29 0a 09 09 |val == T|_INT)...|
|000024d0| 69 66 28 73 74 65 70 2e | 69 76 61 6c 3c 30 20 26 |if(step.|ival<0 &|
|000024e0| 26 20 70 6c 61 63 65 2e | 70 6c 76 61 6c 2d 3e 69 |& place.|plval->i|
|000024f0| 76 61 6c 3c 74 6f 2e 69 | 76 61 6c 29 20 67 6f 74 |val<to.i|val) got|
|00002500| 6f 20 6c 6f 6f 70 5f 64 | 6f 6e 65 3b 0a 09 09 65 |o loop_d|one;...e|
|00002510| 6c 73 65 20 69 66 28 73 | 74 65 70 2e 69 76 61 6c |lse if(s|tep.ival|
|00002520| 3e 30 20 26 26 20 70 6c | 61 63 65 2e 70 6c 76 61 |>0 && pl|ace.plva|
|00002530| 6c 2d 3e 69 76 61 6c 3e | 74 6f 2e 69 76 61 6c 29 |l->ival>|to.ival)|
|00002540| 20 67 6f 74 6f 20 6c 6f | 6f 70 5f 64 6f 6e 65 3b | goto lo|op_done;|
|00002550| 0a 09 20 20 20 20 65 6c | 73 65 20 2f 2a 20 76 69 |.. el|se /* vi|
|00002560| 7a 64 2e 69 76 61 6c 20 | 3d 3d 20 54 5f 44 42 4c |zd.ival |== T_DBL|
|00002570| 20 2a 2f 0a 09 09 69 66 | 28 73 74 65 70 2e 72 76 | */...if|(step.rv|
|00002580| 61 6c 3c 30 20 26 26 20 | 70 6c 61 63 65 2e 70 6c |al<0 && |place.pl|
|00002590| 76 61 6c 2d 3e 72 76 61 | 6c 3c 74 6f 2e 72 76 61 |val->rva|l<to.rva|
|000025a0| 6c 29 20 67 6f 74 6f 20 | 6c 6f 6f 70 5f 64 6f 6e |l) goto |loop_don|
|000025b0| 65 3b 0a 09 09 65 6c 73 | 65 20 69 66 28 73 74 65 |e;...els|e if(ste|
|000025c0| 70 2e 72 76 61 6c 3e 30 | 20 26 26 20 70 6c 61 63 |p.rval>0| && plac|
|000025d0| 65 2e 70 6c 76 61 6c 2d | 3e 72 76 61 6c 3e 74 6f |e.plval-|>rval>to|
|000025e0| 2e 72 76 61 6c 29 20 67 | 6f 74 6f 20 6c 6f 6f 70 |.rval) g|oto loop|
|000025f0| 5f 64 6f 6e 65 3b 0a 0a | 09 20 20 20 20 2f 2a 20 |_done;..|. /* |
|00002600| 4c 6f 6f 70 20 69 73 20 | 6e 6f 74 20 64 6f 6e 65 |Loop is |not done|
|00002610| 20 79 65 74 2c 20 70 75 | 73 68 20 62 61 63 6b 20 | yet, pu|sh back |
|00002620| 73 74 61 63 6b 20 66 72 | 61 6d 65 2e 20 2a 2f 0a |stack fr|ame. */.|
|00002630| 0a 69 66 28 64 62 67 29 | 20 70 72 69 6e 74 66 28 |.if(dbg)| printf(|
|00002640| 22 6c 6f 6f 70 20 6e 6f | 74 20 64 6f 6e 65 2c 20 |"loop no|t done, |
|00002650| 70 75 73 68 20 65 76 65 | 72 79 74 68 69 6e 67 20 |push eve|rything |
|00002660| 62 61 63 6b 5c 6e 22 29 | 3b 0a 09 20 20 20 20 70 |back\n")|;.. p|
|00002670| 75 73 68 28 70 6c 61 63 | 65 29 3b 09 70 75 73 68 |ush(plac|e);.push|
|00002680| 28 66 72 6f 6d 29 3b 09 | 70 75 73 68 28 74 6f 29 |(from);.|push(to)|
|00002690| 3b 0a 09 20 20 20 20 70 | 75 73 68 28 73 74 65 70 |;.. p|ush(step|
|000026a0| 29 3b 09 09 70 75 73 68 | 28 76 69 7a 64 29 3b 09 |);..push|(vizd);.|
|000026b0| 70 75 73 68 28 78 69 74 | 70 74 29 3b 0a 09 20 20 |push(xit|pt);.. |
|000026c0| 20 20 72 65 74 75 72 6e | 28 70 29 3b 0a 0a 09 2f | return|(p);.../|
|000026d0| 2a 20 43 6f 6d 65 20 68 | 65 72 65 20 77 68 65 6e |* Come h|ere when|
|000026e0| 20 74 68 65 20 6c 6f 6f | 70 20 69 73 20 66 69 6e | the loo|p is fin|
|000026f0| 69 73 68 65 64 2e 20 2a | 2f 0a 6c 6f 6f 70 5f 64 |ished. *|/.loop_d|
|00002700| 6f 6e 65 3a 0a 69 66 28 | 64 62 67 29 20 70 72 69 |one:.if(|dbg) pri|
|00002710| 6e 74 66 28 22 6c 6f 6f | 70 20 64 6f 6e 65 2c 20 |ntf("loo|p done, |
|00002720| 6a 75 6d 70 20 74 6f 20 | 78 69 74 70 74 5c 6e 22 |jump to |xitpt\n"|
|00002730| 29 3b 0a 09 20 20 20 20 | 54 68 69 73 6c 69 6e 65 |);.. |Thisline|
|00002740| 20 3d 20 78 69 74 70 74 | 2e 6c 76 61 6c 2e 63 6f | = xitpt|.lval.co|
|00002750| 64 65 6c 69 73 74 3b 0a | 09 20 20 20 20 54 68 69 |delist;.|. Thi|
|00002760| 73 6c 69 6e 65 2d 2d 3b | 0a 09 20 20 20 20 54 68 |sline--;|.. Th|
|00002770| 69 73 70 20 3d 20 78 69 | 74 70 74 2e 6c 76 61 6c |isp = xi|tpt.lval|
|00002780| 2e 70 6c 61 63 65 3b 0a | 09 20 20 20 20 72 65 74 |.place;.|. ret|
|00002790| 75 72 6e 28 70 29 3b 0a | 09 64 65 66 61 75 6c 74 |urn(p);.|.default|
|000027a0| 3a 20 53 54 65 72 72 6f | 72 28 22 66 6f 72 22 29 |: STerro|r("for")|
|000027b0| 3b 0a 20 20 20 20 7d 0a | 7d 0a 0a 2f 2a 20 4d 5f |;. }.|}../* M_|
|000027c0| 43 4f 4d 50 49 4c 45 3a | 0a 20 2a 09 76 61 72 20 |COMPILE:|. *.var |
|000027d0| 6e 61 6d 65 20 6e 65 78 | 74 20 72 6c 61 62 65 6c |name nex|t rlabel|
|000027e0| 20 46 4f 52 78 20 67 6f | 40 20 64 6c 61 62 65 6c | FORx go|@ dlabel|
|000027f0| 20 46 4f 52 78 2b 31 0a | 20 2a 2d 2d 74 6f 2d 2d | FORx+1.| *--to--|
|00002800| 0a 20 2a 09 5f 76 61 72 | 2c 76 70 2c 5f 6e 65 78 |. *._var|,vp,_nex|
|00002810| 74 2c 5f 72 6c 61 62 65 | 6c 2c 6c 62 6c 70 2c 5f |t,_rlabe|l,lblp,_|
|00002820| 67 6f 5f 61 74 2c 64 6c | 61 62 65 6c 2c 6c 62 6c |go_at,dl|abel,lbl|
|00002830| 70 32 0a 20 2a 0a 20 2a | 20 4d 5f 45 58 45 43 55 |p2. *. *| M_EXECU|
|00002840| 54 45 3a 0a 20 2a 09 73 | 74 61 63 6b 3a 20 73 61 |TE:. *.s|tack: sa|
|00002850| 6d 65 20 61 73 20 4d 5f | 45 58 45 43 55 54 45 20 |me as M_|EXECUTE |
|00002860| 69 6e 20 5f 66 6f 72 2e | 0a 20 2a 09 6f 74 68 65 |in _for.|. *.othe|
|00002870| 72 3a 20 61 64 64 73 20 | 73 74 65 70 20 74 6f 20 |r: adds |step to |
|00002880| 28 63 6f 6e 74 72 6f 6c | 20 76 61 72 29 2d 3e 76 |(control| var)->v|
|00002890| 61 6c 2e 0a 20 2a 2f 0a | 5f 6e 65 78 74 28 6c 2c |al.. */.|_next(l,|
|000028a0| 70 29 20 69 6e 74 28 2a | 6c 5b 5d 29 28 29 2c 70 |p) int(*|l[])(),p|
|000028b0| 3b 0a 7b 0a 20 20 20 20 | 75 6e 69 6f 6e 20 76 61 |;.{. |union va|
|000028c0| 6c 75 65 20 76 70 2c 78 | 69 74 70 74 2c 76 69 7a |lue vp,x|itpt,viz|
|000028d0| 64 2c 73 74 65 70 2c 74 | 6f 2c 66 72 6f 6d 2c 70 |d,step,t|o,from,p|
|000028e0| 6c 61 63 65 3b 0a 0a 20 | 20 20 20 73 77 69 74 63 |lace;.. | switc|
|000028f0| 68 28 73 74 61 74 75 73 | 26 58 4d 4f 44 45 29 20 |h(status|&XMODE) |
|00002900| 7b 0a 09 63 61 73 65 20 | 4d 5f 43 4f 4d 50 49 4c |{..case |M_COMPIL|
|00002910| 45 3a 0a 09 63 61 73 65 | 20 4d 5f 46 49 58 55 50 |E:..case| M_FIXUP|
|00002920| 3a 20 72 65 74 75 72 6e | 28 70 29 3b 0a 09 63 61 |: return|(p);..ca|
|00002930| 73 65 20 4d 5f 45 58 45 | 43 55 54 45 3a 0a 09 20 |se M_EXE|CUTE:.. |
|00002940| 20 20 20 76 70 20 3d 20 | 70 6f 70 28 29 3b 0a 69 | vp = |pop();.i|
|00002950| 66 28 64 62 67 29 20 70 | 72 69 6e 74 66 28 22 5f |f(dbg) p|rintf("_|
|00002960| 6e 65 78 74 28 29 3a 45 | 58 45 43 3a 76 61 72 3a |next():E|XEC:var:|
|00002970| 25 73 22 2c 76 70 2e 76 | 70 76 61 6c 2d 3e 6e 61 |%s",vp.v|pval->na|
|00002980| 6d 65 29 3b 0a 09 20 20 | 20 20 76 70 2e 70 6c 76 |me);.. | vp.plv|
|00002990| 61 6c 20 3d 20 67 65 74 | 70 6c 61 63 65 28 76 70 |al = get|place(vp|
|000029a0| 2e 76 70 76 61 6c 29 3b | 0a 69 66 28 64 62 67 29 |.vpval);|.if(dbg)|
|000029b0| 20 70 72 69 6e 74 66 28 | 22 3a 76 70 2e 70 6c 3a | printf(|":vp.pl:|
|000029c0| 25 6f 3a 22 2c 76 70 2e | 70 6c 76 61 6c 29 3b 0a |%o:",vp.|plval);.|
|000029d0| 09 20 20 20 20 78 69 74 | 70 74 20 3d 20 70 6f 70 |. xit|pt = pop|
|000029e0| 28 29 3b 09 76 69 7a 64 | 20 3d 20 70 6f 70 28 29 |();.vizd| = pop()|
|000029f0| 3b 09 73 74 65 70 20 3d | 20 70 6f 70 28 29 3b 0a |;.step =| pop();.|
|00002a00| 09 20 20 20 20 74 6f 20 | 3d 20 70 6f 70 28 29 3b |. to |= pop();|
|00002a10| 09 09 66 72 6f 6d 20 3d | 20 70 6f 70 28 29 3b 09 |..from =| pop();.|
|00002a20| 70 6c 61 63 65 20 3d 20 | 70 6f 70 28 29 3b 0a 69 |place = |pop();.i|
|00002a30| 66 28 64 62 67 29 20 70 | 72 69 6e 74 66 28 22 70 |f(dbg) p|rintf("p|
|00002a40| 6c 2e 70 6c 3a 25 6f 3a | 66 72 6f 6d 2e 69 76 3a |l.pl:%o:|from.iv:|
|00002a50| 25 44 3a 74 6f 2e 69 76 | 3a 25 44 3a 73 74 65 70 |%D:to.iv|:%D:step|
|00002a60| 2e 69 76 3a 25 44 3a 76 | 69 7a 2e 69 76 3a 25 44 |.iv:%D:v|iz.iv:%D|
|00002a70| 3a 22 2c 0a 09 70 6c 61 | 63 65 2e 70 6c 76 61 6c |:",..pla|ce.plval|
|00002a80| 2c 28 6c 6f 6e 67 29 66 | 72 6f 6d 2e 69 76 61 6c |,(long)f|rom.ival|
|00002a90| 2c 28 6c 6f 6e 67 29 74 | 6f 2e 69 76 61 6c 2c 28 |,(long)t|o.ival,(|
|00002aa0| 6c 6f 6e 67 29 73 74 65 | 70 2e 69 76 61 6c 2c 28 |long)ste|p.ival,(|
|00002ab0| 6c 6f 6e 67 29 76 69 7a | 64 2e 69 76 61 6c 29 3b |long)viz|d.ival);|
|00002ac0| 0a 69 66 28 64 62 67 29 | 20 70 72 69 6e 74 66 28 |.if(dbg)| printf(|
|00002ad0| 22 78 69 74 2e 6c 69 73 | 74 3a 25 6f 3a 78 69 74 |"xit.lis|t:%o:xit|
|00002ae0| 2e 70 6c 3a 25 64 3a 78 | 69 74 2e 6e 75 6d 3a 25 |.pl:%d:x|it.num:%|
|00002af0| 75 5c 6e 22 2c 78 69 74 | 70 74 2e 6c 76 61 6c 2e |u\n",xit|pt.lval.|
|00002b00| 63 6f 64 65 6c 69 73 74 | 2c 0a 09 78 69 74 70 74 |codelist|,..xitpt|
|00002b10| 2e 6c 76 61 6c 2e 70 6c | 61 63 65 2c 78 69 74 70 |.lval.pl|ace,xitp|
|00002b20| 74 2e 6c 76 61 6c 2e 63 | 6f 64 65 6c 69 73 74 2d |t.lval.c|odelist-|
|00002b30| 3e 6e 75 6d 29 3b 0a 09 | 20 20 20 20 69 66 28 70 |>num);..| if(p|
|00002b40| 6c 61 63 65 2e 70 6c 76 | 61 6c 20 21 3d 20 76 70 |lace.plv|al != vp|
|00002b50| 2e 70 6c 76 61 6c 29 20 | 46 4e 65 72 72 6f 72 28 |.plval) |FNerror(|
|00002b60| 6c 2c 70 29 3b 0a 09 20 | 20 20 20 69 66 28 76 69 |l,p);.. | if(vi|
|00002b70| 7a 64 2e 69 76 61 6c 20 | 3d 3d 20 54 5f 49 4e 54 |zd.ival |== T_INT|
|00002b80| 29 0a 09 09 70 6c 61 63 | 65 2e 70 6c 76 61 6c 2d |)...plac|e.plval-|
|00002b90| 3e 69 76 61 6c 20 2b 3d | 20 73 74 65 70 2e 69 76 |>ival +=| step.iv|
|00002ba0| 61 6c 3b 0a 09 20 20 20 | 20 65 6c 73 65 0a 09 09 |al;.. | else...|
|00002bb0| 70 6c 61 63 65 2e 70 6c | 76 61 6c 2d 3e 72 76 61 |place.pl|val->rva|
|00002bc0| 6c 20 2b 3d 20 73 74 65 | 70 2e 72 76 61 6c 3b 0a |l += ste|p.rval;.|
|00002bd0| 09 20 20 20 20 70 75 73 | 68 28 70 6c 61 63 65 29 |. pus|h(place)|
|00002be0| 3b 09 70 75 73 68 28 66 | 72 6f 6d 29 3b 09 70 75 |;.push(f|rom);.pu|
|00002bf0| 73 68 28 74 6f 29 3b 09 | 0a 09 20 20 20 20 70 75 |sh(to);.|.. pu|
|00002c00| 73 68 28 73 74 65 70 29 | 3b 09 09 70 75 73 68 28 |sh(step)|;..push(|
|00002c10| 76 69 7a 64 29 3b 09 70 | 75 73 68 28 78 69 74 70 |vizd);.p|ush(xitp|
|00002c20| 74 29 3b 0a 09 20 20 20 | 20 72 65 74 75 72 6e 28 |t);.. | return(|
|00002c30| 70 29 3b 0a 09 64 65 66 | 61 75 6c 74 3a 20 53 54 |p);..def|ault: ST|
|00002c40| 65 72 72 6f 72 28 22 6e | 65 78 74 22 29 3b 0a 20 |error("n|ext");. |
|00002c50| 20 20 20 7d 0a 7d 0a 0a | 2f 2a 20 76 61 72 69 61 | }.}..|/* varia|
|00002c60| 62 6c 65 73 20 6e 65 65 | 64 65 64 20 66 6f 72 20 |bles nee|ded for |
|00002c70| 4d 5f 52 45 41 44 2e 20 | 2a 2f 0a 0a 73 74 72 75 |M_READ. |*/..stru|
|00002c80| 63 74 20 6c 69 6e 65 20 | 2a 64 6c 69 73 74 5b 44 |ct line |*dlist[D|
|00002c90| 4c 53 49 5a 5d 3b 0a 69 | 6e 74 20 64 6c 70 20 3d |LSIZ];.i|nt dlp =|
|00002ca0| 20 30 3b 0a 69 6e 74 20 | 64 6c 69 6e 64 78 20 3d | 0;.int |dlindx =|
|00002cb0| 20 32 3b 09 09 2f 2a 20 | 73 6b 69 70 73 20 3c 5f | 2;../* |skips <_|
|00002cc0| 64 61 74 61 2c 30 3e 20 | 2a 2f 0a 69 6e 74 20 64 |data,0> |*/.int d|
|00002cd0| 74 79 70 65 3b 09 09 2f | 2a 20 74 79 70 65 20 6f |type;../|* type o|
|00002ce0| 66 20 6c 61 73 74 20 6f | 70 65 72 61 74 69 6f 6e |f last o|peration|
|00002cf0| 2e 20 2a 2f 0a 0a 0a 2f | 2a 20 4d 5f 43 4f 4d 50 |. */.../|* M_COMP|
|00002d00| 49 4c 45 3a 0a 20 2a 09 | 78 20 64 61 74 61 20 78 |ILE:. *.|x data x|
|00002d10| 20 20 20 20 20 2d 2d 74 | 6f 2d 2d 20 20 20 20 78 | --t|o-- x|
|00002d20| 2c 5f 64 61 74 61 2c 30 | 2c 78 20 20 20 20 20 28 |,_data,0|,x (|
|00002d30| 30 20 69 73 20 66 6f 72 | 20 69 6e 74 65 72 70 28 |0 is for| interp(|
|00002d40| 29 29 0a 20 2a 20 4d 5f | 46 49 58 55 50 3a 0a 20 |)). * M_|FIXUP:. |
|00002d50| 2a 09 61 6c 6c 6f 63 61 | 74 65 73 20 61 20 73 70 |*.alloca|tes a sp|
|00002d60| 6f 74 20 69 6e 20 64 6c | 69 73 74 2c 20 73 74 6f |ot in dl|ist, sto|
|00002d70| 72 65 73 20 70 6f 69 6e | 74 65 72 20 74 6f 20 6c |res poin|ter to l|
|00002d80| 6c 69 73 74 20 65 6e 74 | 72 79 20 66 6f 72 0a 20 |list ent|ry for. |
|00002d90| 2a 09 74 68 69 73 20 6c | 69 6e 65 20 61 74 20 74 |*.this l|ine at t|
|00002da0| 68 61 74 20 73 70 6f 74 | 2e 0a 20 2a 20 4d 5f 45 |hat spot|.. * M_E|
|00002db0| 58 45 43 55 54 45 3a 0a | 20 2a 09 52 65 74 75 72 |XECUTE:.| *.Retur|
|00002dc0| 6e 73 2c 20 77 69 74 68 | 20 70 20 70 6f 69 6e 74 |ns, with| p point|
|00002dd0| 69 6e 67 20 61 74 20 74 | 68 65 20 7a 65 72 6f 2c |ing at t|he zero,|
|00002de0| 20 6d 61 6b 69 6e 67 20 | 69 6e 74 65 72 70 28 29 | making |interp()|
|00002df0| 20 72 65 74 75 72 6e 2e | 0a 20 2a 2f 0a 5f 64 61 | return.|. */._da|
|00002e00| 74 61 28 6c 2c 70 29 20 | 69 6e 74 28 2a 6c 5b 5d |ta(l,p) |int(*l[]|
|00002e10| 29 28 29 2c 70 3b 0a 7b | 0a 20 20 20 20 73 77 69 |)(),p;.{|. swi|
|00002e20| 74 63 68 28 73 74 61 74 | 75 73 26 58 4d 4f 44 45 |tch(stat|us&XMODE|
|00002e30| 29 20 7b 0a 09 63 61 73 | 65 20 4d 5f 43 4f 4d 50 |) {..cas|e M_COMP|
|00002e40| 49 4c 45 3a 0a 09 20 20 | 20 20 6c 5b 70 2b 2b 5d |ILE:.. | l[p++]|
|00002e50| 20 3d 20 30 3b 0a 09 20 | 20 20 20 72 65 74 75 72 | = 0;.. | retur|
|00002e60| 6e 28 70 29 3b 0a 09 63 | 61 73 65 20 4d 5f 46 49 |n(p);..c|ase M_FI|
|00002e70| 58 55 50 3a 0a 09 20 20 | 20 20 64 6c 69 73 74 5b |XUP:.. | dlist[|
|00002e80| 64 6c 70 2b 2b 5d 20 3d | 20 67 6c 6c 65 6e 74 72 |dlp++] =| gllentr|
|00002e90| 79 28 6c 29 3b 0a 09 20 | 20 20 20 70 2b 2b 3b 0a |y(l);.. | p++;.|
|00002ea0| 09 63 61 73 65 20 4d 5f | 45 58 45 43 55 54 45 3a |.case M_|EXECUTE:|
|00002eb0| 20 72 65 74 75 72 6e 28 | 70 29 3b 0a 09 64 65 66 | return(|p);..def|
|00002ec0| 61 75 6c 74 3a 0a 09 20 | 20 20 20 53 54 65 72 72 |ault:.. | STerr|
|00002ed0| 6f 72 28 22 64 61 74 61 | 22 29 3b 0a 20 20 20 20 |or("data|");. |
|00002ee0| 7d 0a 7d 0a 0a 2f 2a 20 | 4d 5f 43 4f 4d 50 49 4c |}.}../* |M_COMPIL|
|00002ef0| 45 3a 20 20 78 20 64 73 | 65 70 20 78 20 20 20 2d |E: x ds|ep x -|
|00002f00| 2d 74 6f 2d 2d 20 20 20 | 78 2c 5f 64 73 65 70 2c |-to-- |x,_dsep,|
|00002f10| 30 2c 78 0a 20 2a 2f 0a | 5f 64 73 65 70 28 6c 2c |0,x. */.|_dsep(l,|
|00002f20| 70 29 20 69 6e 74 28 2a | 6c 5b 5d 29 28 29 2c 70 |p) int(*|l[])(),p|
|00002f30| 3b 0a 7b 0a 20 20 20 20 | 73 77 69 74 63 68 28 73 |;.{. |switch(s|
|00002f40| 74 61 74 75 73 26 58 4d | 4f 44 45 29 20 7b 0a 09 |tatus&XM|ODE) {..|
|00002f50| 63 61 73 65 20 4d 5f 43 | 4f 4d 50 49 4c 45 3a 0a |case M_C|OMPILE:.|
|00002f60| 09 63 61 73 65 20 4d 5f | 46 49 58 55 50 3a 0a 09 |.case M_|FIXUP:..|
|00002f70| 20 20 20 20 6c 5b 70 2b | 2b 5d 20 3d 20 30 3b 0a | l[p+|+] = 0;.|
|00002f80| 09 63 61 73 65 20 4d 5f | 52 45 41 44 3a 0a 09 63 |.case M_|READ:..c|
|00002f90| 61 73 65 20 4d 5f 45 58 | 45 43 55 54 45 3a 20 72 |ase M_EX|ECUTE: r|
|00002fa0| 65 74 75 72 6e 28 70 29 | 3b 0a 09 64 65 66 61 75 |eturn(p)|;..defau|
|00002fb0| 6c 74 3a 20 53 54 65 72 | 72 6f 72 28 22 64 73 65 |lt: STer|ror("dse|
|00002fc0| 70 22 29 3b 0a 20 20 20 | 20 7d 0a 7d 0a 0a 2f 2a |p");. | }.}../*|
|00002fd0| 20 72 6f 75 74 69 6e 65 | 73 20 66 6f 72 20 63 68 | routine|s for ch|
|00002fe0| 61 6e 67 69 6e 67 20 74 | 68 65 20 69 6e 74 65 72 |anging t|he inter|
|00002ff0| 70 72 65 74 6f 72 73 20 | 73 74 61 74 65 2e 20 2a |pretors |state. *|
|00003000| 2f 0a 0a 73 74 72 75 63 | 74 20 73 74 61 74 73 74 |/..struc|t statst|
|00003010| 6b 20 7b 09 2f 2a 20 66 | 6f 72 20 73 61 76 69 6e |k {./* f|or savin|
|00003020| 67 20 6f 6c 64 20 73 74 | 61 74 65 73 20 2a 2f 0a |g old st|ates */.|
|00003030| 09 69 6e 74 20 73 74 6b | 70 3b 0a 09 69 6e 74 20 |.int stk|p;..int |
|00003040| 73 74 61 74 3b 0a 7d 20 | 73 73 74 6b 5b 33 30 5d |stat;.} |sstk[30]|
|00003050| 3b 0a 69 6e 74 20 73 73 | 74 6b 74 6f 70 20 3d 20 |;.int ss|tktop = |
|00003060| 30 3b 0a 0a 2f 2a 20 4d | 5f 43 4f 4d 50 49 4c 45 |0;../* M|_COMPILE|
|00003070| 3a 0a 20 2a 09 78 20 70 | 75 73 68 73 74 61 74 65 |:. *.x p|ushstate|
|00003080| 20 3c 73 74 61 74 65 3e | 20 78 20 20 20 20 2d 2d | <state>| x --|
|00003090| 74 6f 2d 2d 20 20 20 20 | 78 2c 70 75 73 68 73 74 |to-- |x,pushst|
|000030a0| 61 74 65 2c 3c 73 74 61 | 74 65 3e 2c 78 0a 20 2a |ate,<sta|te>,x. *|
|000030b0| 20 4d 5f 46 49 58 55 50 | 3a 0a 20 2a 09 73 6b 69 | M_FIXUP|:. *.ski|
|000030c0| 70 20 3c 73 74 61 74 65 | 3e 0a 20 2a 20 61 6e 79 |p <state|>. * any|
|000030d0| 20 6f 74 68 65 72 20 73 | 74 61 74 65 3a 0a 20 2a | other s|tate:. *|
|000030e0| 09 73 61 76 65 20 6f 6c | 64 20 73 74 61 74 65 20 |.save ol|d state |
|000030f0| 61 6e 64 20 73 74 61 63 | 6b 20 70 6f 69 6e 74 65 |and stac|k pointe|
|00003100| 72 2e 0a 20 2a 09 73 65 | 74 20 73 74 61 74 65 20 |r.. *.se|t state |
|00003110| 74 6f 20 3c 73 74 61 74 | 65 3e 2e 0a 20 2a 2f 0a |to <stat|e>.. */.|
|00003120| 5f 70 75 73 68 73 74 61 | 74 65 28 6c 2c 70 29 20 |_pushsta|te(l,p) |
|00003130| 69 6e 74 20 28 2a 6c 5b | 5d 29 28 29 2c 70 3b 0a |int (*l[|])(),p;.|
|00003140| 7b 0a 20 20 20 20 73 77 | 69 74 63 68 28 73 74 61 |{. sw|itch(sta|
|00003150| 74 75 73 26 58 4d 4f 44 | 45 29 20 7b 0a 09 63 61 |tus&XMOD|E) {..ca|
|00003160| 73 65 20 4d 5f 43 4f 4d | 50 49 4c 45 3a 0a 09 20 |se M_COM|PILE:.. |
|00003170| 20 20 20 6c 5b 70 2b 2b | 5d 20 3d 20 61 74 6f 69 | l[p++|] = atoi|
|00003180| 28 69 6e 74 5f 69 6e 28 | 29 29 3b 0a 09 20 20 20 |(int_in(|));.. |
|00003190| 20 72 65 74 75 72 6e 28 | 70 29 3b 0a 09 63 61 73 | return(|p);..cas|
|000031a0| 65 20 4d 5f 46 49 58 55 | 50 3a 20 72 65 74 75 72 |e M_FIXU|P: retur|
|000031b0| 6e 28 2b 2b 70 29 3b 0a | 09 64 65 66 61 75 6c 74 |n(++p);.|.default|
|000031c0| 3a 0a 09 20 20 20 20 73 | 73 74 6b 5b 73 73 74 6b |:.. s|stk[sstk|
|000031d0| 74 6f 70 5d 2e 73 74 6b | 70 20 3d 20 73 74 61 63 |top].stk|p = stac|
|000031e0| 6b 70 3b 0a 09 20 20 20 | 20 73 73 74 6b 5b 73 73 |kp;.. | sstk[ss|
|000031f0| 74 6b 74 6f 70 5d 2e 73 | 74 61 74 20 3d 20 73 74 |tktop].s|tat = st|
|00003200| 61 74 75 73 3b 0a 09 20 | 20 20 20 73 73 74 6b 74 |atus;.. | sstkt|
|00003210| 6f 70 2b 2b 3b 0a 09 20 | 20 20 20 73 74 61 74 75 |op++;.. | statu|
|00003220| 73 20 3d 20 6c 5b 70 2b | 2b 5d 3b 0a 09 20 20 20 |s = l[p+|+];.. |
|00003230| 20 72 65 74 75 72 6e 28 | 70 29 3b 0a 20 20 20 20 | return(|p);. |
|00003240| 7d 0a 7d 0a 5f 70 6f 70 | 73 74 61 74 65 28 6c 2c |}.}._pop|state(l,|
|00003250| 70 29 20 69 6e 74 20 28 | 2a 6c 5b 5d 29 28 29 2c |p) int (|*l[])(),|
|00003260| 70 3b 0a 7b 0a 20 20 20 | 20 73 77 69 74 63 68 28 |p;.{. | switch(|
|00003270| 73 74 61 74 75 73 26 58 | 4d 4f 44 45 29 20 7b 0a |status&X|MODE) {.|
|00003280| 09 63 61 73 65 20 4d 5f | 43 4f 4d 50 49 4c 45 3a |.case M_|COMPILE:|
|00003290| 0a 09 63 61 73 65 20 4d | 5f 46 49 58 55 50 3a 20 |..case M|_FIXUP: |
|000032a0| 72 65 74 75 72 6e 28 70 | 29 3b 0a 09 64 65 66 61 |return(p|);..defa|
|000032b0| 75 6c 74 3a 0a 09 20 20 | 20 20 73 73 74 6b 74 6f |ult:.. | sstkto|
|000032c0| 70 2d 2d 3b 0a 09 20 20 | 20 20 73 74 61 63 6b 70 |p--;.. | stackp|
|000032d0| 20 3d 20 73 73 74 6b 5b | 73 73 74 6b 74 6f 70 5d | = sstk[|sstktop]|
|000032e0| 2e 73 74 6b 70 3b 0a 09 | 20 20 20 20 73 74 61 74 |.stkp;..| stat|
|000032f0| 75 73 20 3d 20 73 73 74 | 6b 5b 73 73 74 6b 74 6f |us = sst|k[sstkto|
|00003300| 70 5d 2e 73 74 61 74 26 | 58 4d 4f 44 45 3b 0a 09 |p].stat&|XMODE;..|
|00003310| 20 20 20 20 72 65 74 75 | 72 6e 28 70 29 3b 0a 20 | retu|rn(p);. |
|00003320| 20 20 20 7d 0a 7d 0a 0a | 0a 2f 2a 20 73 74 61 63 | }.}..|./* stac|
|00003330| 6b 20 6d 61 69 6e 74 61 | 6e 65 6e 63 65 20 72 6f |k mainta|nence ro|
|00003340| 75 74 69 6e 65 73 2e 0a | 20 2a 2f 0a 0a 0a 2f 2a |utines..| */.../*|
|00003350| 20 4d 5f 43 4f 4d 50 49 | 4c 45 3a 0a 20 2a 09 78 | M_COMPI|LE:. *.x|
|00003360| 20 73 70 6f 70 20 78 20 | 20 20 20 2d 2d 74 6f 2d | spop x | --to-|
|00003370| 2d 20 20 20 20 78 2c 5f | 73 70 6f 70 2c 78 0a 20 |- x,_|spop,x. |
|00003380| 2a 20 4d 5f 45 58 45 43 | 55 54 45 3a 0a 20 2a 09 |* M_EXEC|UTE:. *.|
|00003390| 73 74 61 63 6b 3a 20 73 | 74 72 69 6e 67 2c 78 20 |stack: s|tring,x |
|000033a0| 20 20 2d 2d 74 6f 2d 2d | 20 20 20 78 0a 20 2a 09 | --to--| x. *.|
|000033b0| 6f 74 68 65 72 3a 20 66 | 72 65 65 73 20 73 74 6f |other: f|rees sto|
|000033c0| 72 61 67 65 20 75 73 65 | 64 20 62 79 20 73 74 72 |rage use|d by str|
|000033d0| 69 6e 67 20 28 69 66 20 | 61 6e 79 29 2e 0a 20 2a |ing (if |any).. *|
|000033e0| 2f 0a 5f 73 70 6f 70 28 | 6c 2c 70 29 20 69 6e 74 |/._spop(|l,p) int|
|000033f0| 28 2a 6c 5b 5d 29 28 29 | 2c 70 3b 0a 7b 0a 20 20 |(*l[])()|,p;.{. |
|00003400| 20 20 75 6e 69 6f 6e 20 | 76 61 6c 75 65 20 73 3b | union |value s;|
|00003410| 0a 0a 20 20 20 20 73 77 | 69 74 63 68 28 73 74 61 |.. sw|itch(sta|
|00003420| 74 75 73 26 58 4d 4f 44 | 45 29 20 7b 0a 09 63 61 |tus&XMOD|E) {..ca|
|00003430| 73 65 20 4d 5f 45 58 45 | 43 55 54 45 3a 0a 09 20 |se M_EXE|CUTE:.. |
|00003440| 20 20 20 73 3d 70 6f 70 | 28 29 3b 0a 09 20 20 20 | s=pop|();.. |
|00003450| 20 69 66 28 73 2e 73 76 | 61 6c 20 21 3d 20 30 29 | if(s.sv|al != 0)|
|00003460| 20 66 72 65 65 28 73 2e | 73 76 61 6c 29 3b 0a 09 | free(s.|sval);..|
|00003470| 63 61 73 65 20 4d 5f 43 | 4f 4d 50 49 4c 45 3a 20 |case M_C|OMPILE: |
|00003480| 72 65 74 75 72 6e 28 70 | 29 3b 0a 09 63 61 73 65 |return(p|);..case|
|00003490| 20 4d 5f 46 49 58 55 50 | 3a 20 72 65 74 75 72 6e | M_FIXUP|: return|
|000034a0| 28 70 29 3b 0a 09 64 65 | 66 61 75 6c 74 3a 0a 09 |(p);..de|fault:..|
|000034b0| 20 20 20 20 53 54 65 72 | 72 6f 72 28 22 73 70 6f | STer|ror("spo|
|000034c0| 70 22 29 3b 0a 20 20 20 | 20 7d 0a 7d 0a 0a 2f 2a |p");. | }.}../*|
|000034d0| 20 4d 5f 43 4f 4d 50 49 | 4c 45 3a 0a 20 2a 09 78 | M_COMPI|LE:. *.x|
|000034e0| 20 70 6f 70 20 78 20 20 | 20 20 2d 2d 74 6f 2d 2d | pop x | --to--|
|000034f0| 20 20 20 20 78 2c 5f 70 | 6f 70 2c 78 0a 20 2a 20 | x,_p|op,x. * |
|00003500| 4d 5f 45 58 45 43 55 54 | 45 3a 0a 20 2a 09 73 74 |M_EXECUT|E:. *.st|
|00003510| 61 63 6b 3a 20 69 6e 74 | 2c 78 20 20 20 20 2d 2d |ack: int|,x --|
|00003520| 74 6f 2d 2d 20 20 20 78 | 0a 20 2a 2f 0a 5f 70 6f |to-- x|. */._po|
|00003530| 70 28 6c 2c 70 29 20 69 | 6e 74 28 2a 6c 5b 5d 29 |p(l,p) i|nt(*l[])|
|00003540| 28 29 2c 70 3b 0a 7b 0a | 20 20 20 20 73 77 69 74 |(),p;.{.| swit|
|00003550| 63 68 28 73 74 61 74 75 | 73 26 58 4d 4f 44 45 29 |ch(statu|s&XMODE)|
|00003560| 20 7b 0a 09 63 61 73 65 | 20 4d 5f 46 49 58 55 50 | {..case| M_FIXUP|
|00003570| 3a 0a 09 63 61 73 65 20 | 4d 5f 43 4f 4d 50 49 4c |:..case |M_COMPIL|
|00003580| 45 3a 20 72 65 74 75 72 | 6e 28 70 29 3b 0a 09 63 |E: retur|n(p);..c|
|00003590| 61 73 65 20 4d 5f 45 58 | 45 43 55 54 45 3a 20 70 |ase M_EX|ECUTE: p|
|000035a0| 6f 70 28 29 3b 20 72 65 | 74 75 72 6e 28 70 29 3b |op(); re|turn(p);|
|000035b0| 0a 09 64 65 66 61 75 6c | 74 3a 0a 09 20 20 20 20 |..defaul|t:.. |
|000035c0| 53 54 65 72 72 6f 72 28 | 22 70 6f 70 22 29 3b 0a |STerror(|"pop");.|
|000035d0| 20 20 20 20 7d 0a 7d 0a | 0a 5f 73 74 6f 70 28 6c | }.}.|._stop(l|
|000035e0| 2c 70 29 20 69 6e 74 28 | 2a 6c 5b 5d 29 28 29 2c |,p) int(|*l[])(),|
|000035f0| 70 3b 0a 7b 0a 20 20 20 | 20 73 77 69 74 63 68 28 |p;.{. | switch(|
|00003600| 73 74 61 74 75 73 26 58 | 4d 4f 44 45 29 20 7b 0a |status&X|MODE) {.|
|00003610| 09 63 61 73 65 20 4d 5f | 46 49 58 55 50 3a 0a 09 |.case M_|FIXUP:..|
|00003620| 63 61 73 65 20 4d 5f 43 | 4f 4d 50 49 4c 45 3a 20 |case M_C|OMPILE: |
|00003630| 72 65 74 75 72 6e 28 70 | 29 3b 0a 09 63 61 73 65 |return(p|);..case|
|00003640| 20 4d 5f 45 58 45 43 55 | 54 45 3a 20 65 78 69 74 | M_EXECU|TE: exit|
|00003650| 28 31 29 3b 0a 09 64 65 | 66 61 75 6c 74 3a 0a 09 |(1);..de|fault:..|
|00003660| 20 20 20 20 53 54 65 72 | 72 6f 72 28 22 73 74 6f | STer|ror("sto|
|00003670| 70 22 29 3b 0a 20 20 20 | 20 7d 0a 7d 0a 5f 65 6e |p");. | }.}._en|
|00003680| 64 28 6c 2c 70 29 20 69 | 6e 74 20 28 2a 6c 5b 5d |d(l,p) i|nt (*l[]|
|00003690| 29 28 29 2c 70 3b 20 7b | 20 72 65 74 75 72 6e 28 |)(),p; {| return(|
|000036a0| 5f 73 74 6f 70 28 6c 2c | 70 29 29 3b 20 7d 0a 0a |_stop(l,|p)); }..|
|000036b0| 0a 2f 2a 20 6f 70 65 72 | 61 74 6f 72 20 6c 69 73 |./* oper|ator lis|
|000036c0| 74 20 66 6f 72 20 74 68 | 65 20 69 6e 74 65 72 6d |t for th|e interm|
|000036d0| 65 64 69 61 74 65 20 6c | 61 6e 67 75 61 67 65 2e |ediate l|anguage.|
|000036e0| 20 2a 2f 0a 73 74 72 75 | 63 74 20 77 6c 6e 6f 64 | */.stru|ct wlnod|
|000036f0| 65 20 77 6c 69 73 74 5b | 5d 20 3d 20 7b 0a 09 22 |e wlist[|] = {.."|
|00003700| 69 74 6f 61 22 2c 5f 69 | 74 6f 61 2c 09 22 70 72 |itoa",_i|toa,."pr|
|00003710| 69 6e 74 22 2c 5f 70 72 | 69 6e 74 2c 09 22 67 6f |int",_pr|int,."go|
|00003720| 74 6f 22 2c 5f 67 6f 74 | 6f 2c 09 22 69 66 22 2c |to",_got|o,."if",|
|00003730| 5f 69 66 2c 20 20 22 72 | 74 6f 61 22 2c 5f 72 74 |_if, "r|toa",_rt|
|00003740| 6f 61 2c 0a 09 22 69 74 | 6f 72 22 2c 5f 69 74 6f |oa,.."it|or",_ito|
|00003750| 72 2c 09 22 72 74 6f 69 | 22 2c 5f 72 74 6f 69 2c |r,."rtoi|",_rtoi,|
|00003760| 09 22 67 6f 73 75 62 22 | 2c 5f 67 6f 73 75 62 2c |."gosub"|,_gosub,|
|00003770| 20 20 22 72 65 74 75 72 | 6e 22 2c 5f 72 65 74 75 | "retur|n",_retu|
|00003780| 72 6e 2c 0a 09 22 73 63 | 6f 6e 22 2c 5f 73 63 6f |rn,.."sc|on",_sco|
|00003790| 6e 2c 09 22 69 63 6f 6e | 22 2c 5f 69 63 6f 6e 2c |n,."icon|",_icon,|
|000037a0| 09 22 69 2b 22 2c 5f 69 | 61 64 64 2c 09 22 2d 22 |."i+",_i|add,."-"|
|000037b0| 2c 5f 69 73 75 62 2c 0a | 09 22 72 63 6f 6e 22 2c |,_isub,.|."rcon",|
|000037c0| 5f 72 63 6f 6e 2c 09 22 | 72 2b 22 2c 5f 72 61 64 |_rcon,."|r+",_rad|
|000037d0| 64 2c 09 22 72 2d 22 2c | 5f 72 73 75 62 2c 0a 09 |d,."r-",|_rsub,..|
|000037e0| 22 69 2a 22 2c 5f 69 6d | 75 6c 74 2c 09 22 69 2f |"i*",_im|ult,."i/|
|000037f0| 22 2c 5f 69 64 69 76 2c | 09 22 69 25 22 2c 5f 69 |",_idiv,|."i%",_i|
|00003800| 6d 6f 64 2c 09 22 2c 22 | 2c 5f 63 6f 6d 6d 61 2c |mod,.","|,_comma,|
|00003810| 0a 09 22 72 2a 22 2c 5f | 72 6d 75 6c 74 2c 09 22 |.."r*",_|rmult,."|
|00003820| 72 2f 22 2c 5f 72 64 69 | 76 2c 09 22 3b 22 2c 5f |r/",_rdi|v,.";",_|
|00003830| 73 63 6f 6c 6f 6e 2c 0a | 09 22 69 3d 3d 22 2c 5f |scolon,.|."i==",_|
|00003840| 69 65 71 2c 09 22 73 3d | 3d 22 2c 5f 73 65 71 2c |ieq,."s=|=",_seq,|
|00003850| 09 22 72 3d 3d 22 2c 5f | 72 65 71 2c 0a 09 22 69 |."r==",_|req,.."i|
|00003860| 3c 3e 22 2c 5f 69 6e 65 | 71 2c 09 22 72 3c 3e 22 |<>",_ine|q,."r<>"|
|00003870| 2c 5f 72 6e 65 71 2c 09 | 22 73 3c 3e 22 2c 5f 73 |,_rneq,.|"s<>",_s|
|00003880| 6e 65 71 2c 0a 09 22 69 | 3c 3d 22 2c 5f 69 6c 65 |neq,.."i|<=",_ile|
|00003890| 71 2c 09 22 73 3c 3d 22 | 2c 5f 73 6c 65 71 2c 09 |q,."s<="|,_sleq,.|
|000038a0| 22 72 3c 3d 22 2c 5f 72 | 6c 65 71 2c 0a 09 22 69 |"r<=",_r|leq,.."i|
|000038b0| 3c 22 2c 5f 69 6c 74 2c | 09 22 73 3c 22 2c 5f 73 |<",_ilt,|."s<",_s|
|000038c0| 6c 74 2c 09 22 72 3c 22 | 2c 5f 72 6c 74 2c 0a 09 |lt,."r<"|,_rlt,..|
|000038d0| 22 69 3e 3d 22 2c 5f 69 | 67 65 71 2c 09 22 73 3e |"i>=",_i|geq,."s>|
|000038e0| 3d 22 2c 5f 73 67 65 71 | 2c 09 22 72 3e 3d 22 2c |=",_sgeq|,."r>=",|
|000038f0| 5f 72 67 65 71 2c 0a 09 | 22 69 3e 22 2c 5f 69 67 |_rgeq,..|"i>",_ig|
|00003900| 74 2c 09 22 73 3e 22 2c | 5f 73 67 74 2c 09 22 72 |t,."s>",|_sgt,."r|
|00003910| 3e 22 2c 5f 72 67 74 2c | 0a 09 22 6f 72 22 2c 5f |>",_rgt,|.."or",_|
|00003920| 6f 72 2c 09 22 61 6e 64 | 22 2c 5f 61 6e 64 2c 09 |or,."and|",_and,.|
|00003930| 22 76 61 6c 22 2c 5f 76 | 61 6c 2c 09 22 6e 6f 74 |"val",_v|al,."not|
|00003940| 22 2c 5f 6e 6f 74 2c 0a | 09 22 70 6f 70 22 2c 5f |",_not,.|."pop",_|
|00003950| 70 6f 70 2c 09 22 73 70 | 6f 70 22 2c 5f 73 70 6f |pop,."sp|op",_spo|
|00003960| 70 2c 0a 09 22 73 74 6f | 70 22 2c 5f 73 74 6f 70 |p,.."sto|p",_stop|
|00003970| 2c 09 22 65 6e 64 22 2c | 5f 65 6e 64 2c 09 22 76 |,."end",|_end,."v|
|00003980| 61 72 22 2c 5f 76 61 72 | 2c 09 22 73 74 6f 72 65 |ar",_var|,."store|
|00003990| 22 2c 5f 73 74 6f 72 65 | 2c 0a 09 22 66 6f 72 22 |",_store|,.."for"|
|000039a0| 2c 5f 66 6f 72 2c 09 22 | 6e 65 78 74 22 2c 5f 6e |,_for,."|next",_n|
|000039b0| 65 78 74 2c 0a 09 22 64 | 6c 61 62 65 6c 22 2c 5f |ext,.."d|label",_|
|000039c0| 64 6c 61 62 65 6c 2c 09 | 22 72 6c 61 62 65 6c 22 |dlabel,.|"rlabel"|
|000039d0| 2c 5f 72 6c 61 62 65 6c | 2c 0a 09 22 63 6f 6e 74 |,_rlabel|,.."cont|
|000039e0| 69 6e 22 2c 5f 63 6f 6e | 74 69 6e 2c 20 20 22 6c |in",_con|tin, "l|
|000039f0| 65 61 76 65 22 2c 5f 6c | 65 61 76 65 2c 20 20 22 |eave",_l|eave, "|
|00003a00| 65 6e 74 65 72 22 2c 5f | 65 6e 74 65 72 2c 20 20 |enter",_|enter, |
|00003a10| 22 65 78 69 74 6c 70 22 | 2c 5f 65 78 69 74 6c 70 |"exitlp"|,_exitlp|
|00003a20| 2c 0a 09 22 64 61 74 61 | 22 2c 5f 64 61 74 61 2c |,.."data|",_data,|
|00003a30| 09 22 64 73 65 70 22 2c | 5f 64 73 65 70 2c 0a 09 |."dsep",|_dsep,..|
|00003a40| 22 70 75 73 68 73 74 61 | 74 65 22 2c 5f 70 75 73 |"pushsta|te",_pus|
|00003a50| 68 73 74 61 74 65 2c 09 | 09 22 70 6f 70 73 74 61 |hstate,.|."popsta|
|00003a60| 74 65 22 2c 5f 70 6f 70 | 73 74 61 74 65 2c 0a 20 |te",_pop|state,. |
|00003a70| 20 20 20 30 2c 30 0a 7d | 3b 0a 0a 53 48 41 52 5f | 0,0.}|;..SHAR_|
|00003a80| 45 4f 46 0a 69 66 20 74 | 65 73 74 20 31 34 30 37 |EOF.if t|est 1407|
|00003a90| 33 20 2d 6e 65 20 22 60 | 77 63 20 2d 63 20 3c 20 |3 -ne "`|wc -c < |
|00003aa0| 27 62 73 32 2f 61 63 74 | 69 6f 6e 2e 63 27 60 22 |'bs2/act|ion.c'`"|
|00003ab0| 0a 74 68 65 6e 0a 09 65 | 63 68 6f 20 73 68 61 72 |.then..e|cho shar|
|00003ac0| 3a 20 65 72 72 6f 72 20 | 74 72 61 6e 73 6d 69 74 |: error |transmit|
|00003ad0| 74 69 6e 67 20 22 27 62 | 73 32 2f 61 63 74 69 6f |ting "'b|s2/actio|
|00003ae0| 6e 2e 63 27 22 20 27 28 | 73 68 6f 75 6c 64 20 68 |n.c'" '(|should h|
|00003af0| 61 76 65 20 62 65 65 6e | 20 31 34 30 37 33 20 63 |ave been| 14073 c|
|00003b00| 68 61 72 61 63 74 65 72 | 73 29 27 0a 66 69 0a 66 |haracter|s)'.fi.f|
|00003b10| 69 20 23 20 65 6e 64 20 | 6f 66 20 6f 76 65 72 77 |i # end |of overw|
|00003b20| 72 69 74 69 6e 67 20 63 | 68 65 63 6b 0a 65 63 68 |riting c|heck.ech|
|00003b30| 6f 20 73 68 61 72 3a 20 | 65 78 74 72 61 63 74 69 |o shar: |extracti|
|00003b40| 6e 67 20 22 27 62 73 32 | 2f 62 73 64 65 66 73 2e |ng "'bs2|/bsdefs.|
|00003b50| 68 27 22 20 27 28 34 34 | 37 32 20 63 68 61 72 61 |h'" '(44|72 chara|
|00003b60| 63 74 65 72 73 29 27 0a | 69 66 20 74 65 73 74 20 |cters)'.|if test |
|00003b70| 2d 66 20 27 62 73 32 2f | 62 73 64 65 66 73 2e 68 |-f 'bs2/|bsdefs.h|
|00003b80| 27 0a 74 68 65 6e 0a 09 | 65 63 68 6f 20 73 68 61 |'.then..|echo sha|
|00003b90| 72 3a 20 77 69 6c 6c 20 | 6e 6f 74 20 6f 76 65 72 |r: will |not over|
|00003ba0| 2d 77 72 69 74 65 20 65 | 78 69 73 74 69 6e 67 20 |-write e|xisting |
|00003bb0| 66 69 6c 65 20 22 27 62 | 73 32 2f 62 73 64 65 66 |file "'b|s2/bsdef|
|00003bc0| 73 2e 68 27 22 0a 65 6c | 73 65 0a 73 65 64 20 27 |s.h'".el|se.sed '|
|00003bd0| 73 2f 5e 58 2f 2f 27 20 | 3c 3c 20 5c 53 48 41 52 |s/^X//' |<< \SHAR|
|00003be0| 5f 45 4f 46 20 3e 20 27 | 62 73 32 2f 62 73 64 65 |_EOF > '|bs2/bsde|
|00003bf0| 66 73 2e 68 27 0a 2f 2a | 20 62 73 64 65 66 73 2e |fs.h'./*| bsdefs.|
|00003c00| 68 20 2d 2d 20 64 65 66 | 69 6e 69 74 69 6f 6e 20 |h -- def|inition |
|00003c10| 66 69 6c 65 20 66 6f 72 | 20 62 73 2e 0a 20 2a 2f |file for| bs.. */|
|00003c20| 0a 0a 23 69 6e 63 6c 75 | 64 65 20 3c 73 74 64 69 |..#inclu|de <stdi|
|00003c30| 6f 2e 68 3e 0a 23 69 6e | 63 6c 75 64 65 20 3c 63 |o.h>.#in|clude <c|
|00003c40| 74 79 70 65 2e 68 3e 0a | 0a 2f 2a 20 27 4d 61 63 |type.h>.|./* 'Mac|
|00003c50| 68 69 6e 65 27 20 73 74 | 61 74 75 73 20 2a 2f 0a |hine' st|atus */.|
|00003c60| 65 78 74 65 72 6e 20 69 | 6e 74 20 73 74 61 74 75 |extern i|nt statu|
|00003c70| 73 3b 0a 23 64 65 66 69 | 6e 65 20 4d 5f 43 4f 4d |s;.#defi|ne M_COM|
|00003c80| 50 49 4c 45 09 28 31 3c | 3c 30 29 0a 23 64 65 66 |PILE.(1<|<0).#def|
|00003c90| 69 6e 65 20 4d 5f 45 58 | 45 43 55 54 45 09 28 31 |ine M_EX|ECUTE.(1|
|00003ca0| 3c 3c 31 29 0a 23 64 65 | 66 69 6e 65 20 4d 5f 49 |<<1).#de|fine M_I|
|00003cb0| 4e 50 55 54 09 09 28 31 | 3c 3c 32 29 0a 23 64 65 |NPUT..(1|<<2).#de|
|00003cc0| 66 69 6e 65 20 4d 5f 46 | 49 58 55 50 09 09 28 31 |fine M_F|IXUP..(1|
|00003cd0| 3c 3c 33 29 0a 23 64 65 | 66 69 6e 65 20 4d 5f 52 |<<3).#de|fine M_R|
|00003ce0| 45 41 44 09 09 28 31 3c | 3c 34 29 0a 0a 23 64 65 |EAD..(1<|<4)..#de|
|00003cf0| 66 69 6e 65 20 58 4d 4f | 44 45 09 28 4d 5f 43 4f |fine XMO|DE.(M_CO|
|00003d00| 4d 50 49 4c 45 7c 4d 5f | 45 58 45 43 55 54 45 7c |MPILE|M_|EXECUTE||
|00003d10| 4d 5f 49 4e 50 55 54 7c | 4d 5f 46 49 58 55 50 7c |M_INPUT||M_FIXUP||
|00003d20| 4d 5f 52 45 41 44 29 0a | 0a 0a 2f 2a 20 6c 69 6e |M_READ).|../* lin|
|00003d30| 65 20 74 61 62 6c 65 2e | 20 2a 2f 0a 23 64 65 66 |e table.| */.#def|
|00003d40| 69 6e 65 20 4d 41 58 4c | 4e 09 28 28 75 6e 73 69 |ine MAXL|N.((unsi|
|00003d50| 67 6e 65 64 29 36 35 35 | 33 35 29 0a 23 64 65 66 |gned)655|35).#def|
|00003d60| 69 6e 65 20 4e 55 4d 4c | 49 4e 45 53 09 31 30 30 |ine NUML|INES.100|
|00003d70| 30 0a 23 64 65 66 69 6e | 65 20 4c 41 53 54 4c 49 |0.#defin|e LASTLI|
|00003d80| 4e 45 09 28 26 6c 6c 69 | 73 74 5b 4e 55 4d 4c 49 |NE.(&lli|st[NUMLI|
|00003d90| 4e 45 53 2d 31 5d 29 0a | 0a 65 78 74 65 72 6e 20 |NES-1]).|.extern |
|00003da0| 69 6e 74 20 28 2a 5f 6e | 75 6c 6c 5b 5d 29 28 29 |int (*_n|ull[])()|
|00003db0| 3b 0a 0a 73 74 72 75 63 | 74 20 6c 69 6e 65 20 7b |;..struc|t line {|
|00003dc0| 0a 20 20 20 20 75 6e 73 | 69 67 6e 65 64 20 6e 75 |. uns|igned nu|
|00003dd0| 6d 3b 0a 20 20 20 20 69 | 6e 74 20 28 2a 2a 63 6f |m;. i|nt (**co|
|00003de0| 64 65 29 28 29 3b 0a 20 | 20 20 20 63 68 61 72 20 |de)();. | char |
|00003df0| 2a 74 65 78 74 3b 0a 7d | 3b 0a 0a 65 78 74 65 72 |*text;.}|;..exter|
|00003e00| 6e 20 73 74 72 75 63 74 | 20 6c 69 6e 65 20 6c 6c |n struct| line ll|
|00003e10| 69 73 74 5b 5d 3b 0a 65 | 78 74 65 72 6e 20 73 74 |ist[];.e|xtern st|
|00003e20| 72 75 63 74 20 6c 69 6e | 65 20 2a 6c 61 73 74 6c |ruct lin|e *lastl|
|00003e30| 69 6e 65 3b 0a 65 78 74 | 65 72 6e 20 73 74 72 75 |ine;.ext|ern stru|
|00003e40| 63 74 20 6c 69 6e 65 20 | 2a 54 68 69 73 6c 69 6e |ct line |*Thislin|
|00003e50| 65 3b 0a 65 78 74 65 72 | 6e 20 69 6e 74 20 54 68 |e;.exter|n int Th|
|00003e60| 69 73 70 3b 0a 0a 0a 2f | 2a 20 56 61 72 69 61 62 |isp;.../|* Variab|
|00003e70| 6c 65 20 74 79 70 65 73 | 20 2a 2f 0a 23 64 65 66 |le types| */.#def|
|00003e80| 69 6e 65 20 51 5f 4e 52 | 4d 09 30 09 2f 2a 20 6e |ine Q_NR|M.0./* n|
|00003e90| 69 63 65 2c 20 6f 72 64 | 69 6e 61 72 79 20 76 61 |ice, ord|inary va|
|00003ea0| 72 69 61 62 6c 65 20 2a | 2f 0a 23 64 65 66 69 6e |riable *|/.#defin|
|00003eb0| 65 20 51 5f 41 52 59 09 | 31 09 2f 2a 20 61 72 72 |e Q_ARY.|1./* arr|
|00003ec0| 61 79 20 2a 2f 0a 23 64 | 65 66 69 6e 65 20 51 5f |ay */.#d|efine Q_|
|00003ed0| 42 46 09 32 09 2f 2a 20 | 62 75 69 6c 74 69 6e 2d |BF.2./* |builtin-|
|00003ee0| 66 75 6e 63 74 69 6f 6e | 20 2a 2f 0a 23 64 65 66 |function| */.#def|
|00003ef0| 69 6e 65 20 51 5f 55 46 | 4c 09 33 09 2f 2a 20 6c |ine Q_UF|L.3./* l|
|00003f00| 6f 6e 67 20 75 73 65 72 | 20 66 75 6e 63 74 69 6f |ong user| functio|
|00003f10| 6e 20 2a 2f 0a 23 64 65 | 66 69 6e 65 20 51 5f 55 |n */.#de|fine Q_U|
|00003f20| 46 53 09 34 09 2f 2a 20 | 73 68 6f 72 74 20 75 73 |FS.4./* |short us|
|00003f30| 65 72 20 66 75 6e 63 74 | 69 6f 6e 20 2a 2f 0a 0a |er funct|ion */..|
|00003f40| 09 09 09 2f 2a 20 69 6e | 20 74 79 70 65 20 70 61 |.../* in| type pa|
|00003f50| 72 74 2c 20 61 20 7a 65 | 72 6f 20 76 61 6c 75 65 |rt, a ze|ro value|
|00003f60| 20 69 73 20 61 6e 20 75 | 6e 64 65 66 69 6e 65 64 | is an u|ndefined|
|00003f70| 20 74 79 70 65 2e 20 2a | 2f 0a 23 64 65 66 69 6e | type. *|/.#defin|
|00003f80| 65 20 54 5f 49 4e 54 09 | 28 31 3c 3c 36 29 0a 23 |e T_INT.|(1<<6).#|
|00003f90| 64 65 66 69 6e 65 20 54 | 5f 43 48 52 09 28 32 3c |define T|_CHR.(2<|
|00003fa0| 3c 36 29 0a 23 64 65 66 | 69 6e 65 20 54 5f 44 42 |<6).#def|ine T_DB|
|00003fb0| 4c 09 28 33 3c 3c 36 29 | 0a 23 64 65 66 69 6e 65 |L.(3<<6)|.#define|
|00003fc0| 20 54 5f 4c 42 4c 09 28 | 34 3c 3c 36 29 0a 0a 23 | T_LBL.(|4<<6)..#|
|00003fd0| 64 65 66 69 6e 65 20 54 | 5f 51 4d 41 53 4b 09 09 |define T|_QMASK..|
|00003fe0| 30 33 37 09 09 2f 2a 20 | 6c 6f 77 65 72 20 35 20 |037../* |lower 5 |
|00003ff0| 62 69 74 73 20 66 6f 72 | 20 74 79 70 65 20 71 75 |bits for| type qu|
|00004000| 61 6c 69 66 69 65 72 20 | 2a 2f 0a 23 64 65 66 69 |alifier |*/.#defi|
|00004010| 6e 65 20 54 5f 54 4d 41 | 53 4b 09 09 28 54 5f 49 |ne T_TMA|SK..(T_I|
|00004020| 4e 54 7c 54 5f 43 48 52 | 7c 54 5f 44 42 4c 7c 54 |NT|T_CHR||T_DBL|T|
|00004030| 5f 4c 42 4c 29 0a 0a 2f | 2a 20 76 61 72 69 61 62 |_LBL)../|* variab|
|00004040| 6c 65 20 74 61 62 6c 65 | 20 2a 2f 0a 23 64 65 66 |le table| */.#def|
|00004050| 69 6e 65 20 56 4c 53 49 | 5a 09 31 35 30 0a 0a 73 |ine VLSI|Z.150..s|
|00004060| 74 72 75 63 74 20 6c 61 | 62 65 6c 20 7b 0a 20 20 |truct la|bel {. |
|00004070| 20 20 63 68 61 72 20 2a | 6e 61 6d 65 3b 0a 20 20 | char *|name;. |
|00004080| 20 20 69 6e 74 20 28 2a | 2a 63 6f 64 65 6c 69 73 | int (*|*codelis|
|00004090| 74 29 28 29 3b 09 09 2f | 2a 20 77 68 61 74 20 6c |t)();../|* what l|
|000040a0| 69 6e 65 20 69 74 20 69 | 73 20 6f 6e 20 2a 2f 0a |ine it i|s on */.|
|000040b0| 20 20 20 20 69 6e 74 20 | 70 6c 61 63 65 3b 09 09 | int |place;..|
|000040c0| 09 2f 2a 20 77 68 65 72 | 65 20 6f 6e 20 74 68 65 |./* wher|e on the|
|000040d0| 20 6c 69 6e 65 20 69 74 | 20 69 73 2e 20 2a 2f 0a | line it| is. */.|
|000040e0| 7d 3b 0a 2f 2a 20 46 6f | 72 20 61 72 72 61 79 73 |};./* Fo|r arrays|
|000040f0| 2c 20 73 74 6f 72 61 67 | 65 20 6f 66 20 74 68 65 |, storag|e of the|
|00004100| 6d 20 69 73 20 64 65 66 | 69 6e 65 64 20 61 73 20 |m is def|ined as |
|00004110| 66 6f 6c 6c 6f 77 73 3a | 0a 20 2a 0a 20 2a 20 20 |follows:|. *. * |
|00004120| 20 31 73 74 20 69 74 65 | 6d 3a 20 6e 75 6d 62 65 | 1st ite|m: numbe|
|00004130| 72 20 6f 66 20 64 69 6d | 65 6e 73 69 6f 6e 73 20 |r of dim|ensions |
|00004140| 69 6e 20 61 72 72 61 79 | 20 3c 4e 44 49 4d 53 3e |in array| <NDIMS>|
|00004150| 2e 0a 20 2a 20 20 20 6e | 65 78 74 20 3c 4e 44 49 |.. * n|ext <NDI|
|00004160| 4d 53 3e 20 69 74 65 6d | 73 3a 20 73 69 7a 65 20 |MS> item|s: size |
|00004170| 6f 66 20 65 61 63 68 20 | 64 69 6d 65 6e 73 69 6f |of each |dimensio|
|00004180| 6e 2e 0a 20 2a 20 20 20 | 72 65 73 74 20 6f 66 20 |n.. * |rest of |
|00004190| 69 74 65 6d 73 3a 20 74 | 68 65 20 61 63 74 75 61 |items: t|he actua|
|000041a0| 6c 20 76 61 6c 75 65 73 | 2e 0a 20 2a 0a 20 2a 20 |l values|.. *. * |
|000041b0| 55 6e 74 69 6c 20 77 65 | 20 63 61 6e 20 73 75 70 |Until we| can sup|
|000041c0| 70 6f 72 74 20 76 61 72 | 72 79 69 6e 67 20 73 69 |port var|rying si|
|000041d0| 7a 65 64 20 61 72 72 61 | 79 73 20 74 68 69 73 20 |zed arra|ys this |
|000041e0| 69 73 20 74 68 65 20 73 | 65 74 75 70 3a 0a 20 2a |is the s|etup:. *|
|000041f0| 0a 20 2a 20 20 20 31 2c | 31 30 2c 78 30 2c 78 31 |. * 1,|10,x0,x1|
|00004200| 2c 78 32 2c 78 33 2c 78 | 34 2c 78 35 2c 78 36 2c |,x2,x3,x|4,x5,x6,|
|00004210| 78 37 2c 78 38 2c 78 39 | 2c 78 31 30 0a 20 2a 0a |x7,x8,x9|,x10. *.|
|00004220| 20 2a 20 66 6f 72 20 61 | 20 74 6f 74 61 6c 20 73 | * for a| total s|
|00004230| 69 7a 65 20 6f 66 20 31 | 33 20 69 74 65 6d 73 2e |ize of 1|3 items.|
|00004240| 0a 20 2a 2f 0a 75 6e 69 | 6f 6e 20 76 61 6c 75 65 |. */.uni|on value|
|00004250| 20 7b 0a 20 20 20 20 6c | 6f 6e 67 20 69 76 61 6c | {. l|ong ival|
|00004260| 3b 09 09 2f 2a 20 54 5f | 49 4e 54 20 2a 2f 0a 20 |;../* T_|INT */. |
|00004270| 20 20 20 64 6f 75 62 6c | 65 20 72 76 61 6c 3b 09 | doubl|e rval;.|
|00004280| 2f 2a 20 54 5f 44 42 4c | 20 2a 2f 0a 20 20 20 20 |/* T_DBL| */. |
|00004290| 63 68 61 72 20 2a 73 76 | 61 6c 3b 09 09 2f 2a 20 |char *sv|al;../* |
|000042a0| 54 5f 43 48 52 20 2a 2f | 0a 20 20 20 20 73 74 72 |T_CHR */|. str|
|000042b0| 75 63 74 20 6c 61 62 65 | 6c 20 6c 76 61 6c 3b 20 |uct labe|l lval; |
|000042c0| 20 2f 2a 20 54 5f 4c 42 | 4c 20 2a 2f 0a 20 20 20 | /* T_LB|L */. |
|000042d0| 20 75 6e 69 6f 6e 20 76 | 61 6c 75 65 20 2a 61 72 | union v|alue *ar|
|000042e0| 76 61 6c 3b 20 2f 2a 20 | 61 6e 79 2b 51 5f 41 52 |val; /* |any+Q_AR|
|000042f0| 59 20 2a 2f 0a 20 20 20 | 20 73 74 72 75 63 74 20 |Y */. | struct |
|00004300| 64 69 63 74 6e 6f 64 65 | 20 2a 76 70 76 61 6c 3b |dictnode| *vpval;|
|00004310| 20 2f 2a 20 66 6f 72 20 | 75 73 65 20 77 68 65 6e | /* for |use when|
|00004320| 20 70 75 73 68 69 6e 67 | 20 76 61 72 69 61 62 6c | pushing| variabl|
|00004330| 65 20 70 6f 69 6e 74 65 | 72 73 20 2a 2f 0a 20 20 |e pointe|rs */. |
|00004340| 20 20 75 6e 69 6f 6e 20 | 76 61 6c 75 65 20 2a 70 | union |value *p|
|00004350| 6c 76 61 6c 3b 20 2f 2a | 20 66 6f 72 20 75 73 65 |lval; /*| for use|
|00004360| 20 77 68 65 6e 20 70 75 | 73 68 69 6e 67 20 70 6f | when pu|shing po|
|00004370| 69 6e 74 65 72 73 20 74 | 6f 20 61 20 76 61 6c 75 |inters t|o a valu|
|00004380| 65 20 2a 2f 0a 7d 3b 0a | 0a 73 74 72 75 63 74 20 |e */.};.|.struct |
|00004390| 64 69 63 74 6e 6f 64 65 | 20 7b 09 2f 2a 20 66 6f |dictnode| {./* fo|
|000043a0| 72 6d 61 74 20 6f 66 20 | 76 6c 69 73 74 20 65 6e |rmat of |vlist en|
|000043b0| 74 72 79 20 2a 2f 0a 20 | 20 20 20 63 68 61 72 20 |try */. | char |
|000043c0| 2a 6e 61 6d 65 3b 0a 20 | 20 20 20 69 6e 74 20 74 |*name;. | int t|
|000043d0| 79 70 65 5f 6f 66 5f 76 | 61 6c 75 65 3b 0a 20 20 |ype_of_v|alue;. |
|000043e0| 20 20 75 6e 69 6f 6e 20 | 76 61 6c 75 65 20 76 61 | union |value va|
|000043f0| 6c 3b 0a 7d 3b 0a 0a 65 | 78 74 65 72 6e 20 73 74 |l;.};..e|xtern st|
|00004400| 72 75 63 74 20 64 69 63 | 74 6e 6f 64 65 20 76 6c |ruct dic|tnode vl|
|00004410| 69 73 74 5b 5d 3b 0a 0a | 2f 2a 20 27 5f 27 20 46 |ist[];..|/* '_' F|
|00004420| 75 6e 63 74 69 6f 6e 20 | 74 61 62 6c 65 20 2a 2f |unction |table */|
|00004430| 0a 65 78 74 65 72 6e 0a | 09 5f 70 72 69 6e 74 28 |.extern.|._print(|
|00004440| 29 2c 20 20 20 5f 67 6f | 74 6f 28 29 2c 09 5f 69 |), _go|to(),._i|
|00004450| 66 28 29 2c 09 5f 65 6c | 73 65 28 29 2c 20 20 20 |f(),._el|se(), |
|00004460| 5f 66 6f 72 28 29 2c 0a | 09 5f 6e 65 78 74 28 29 |_for(),.|._next()|
|00004470| 2c 20 20 20 5f 72 65 61 | 64 28 29 2c 09 5f 64 61 |, _rea|d(),._da|
|00004480| 74 61 28 29 2c 20 20 20 | 5f 64 73 65 70 28 29 2c |ta(), |_dsep(),|
|00004490| 20 20 20 5f 73 70 6f 70 | 28 29 2c 0a 09 5f 70 6f | _spop|(),.._po|
|000044a0| 70 28 29 2c 20 20 20 5f | 73 74 6f 70 28 29 2c 20 |p(), _|stop(), |
|000044b0| 20 20 5f 65 6e 64 28 29 | 2c 20 20 20 5f 64 6c 61 | _end()|, _dla|
|000044c0| 62 65 6c 28 29 2c 20 20 | 20 5f 72 6c 61 62 65 6c |bel(), | _rlabel|
|000044d0| 28 29 2c 0a 09 5f 63 6f | 6e 74 69 6e 28 29 2c 20 |(),.._co|ntin(), |
|000044e0| 20 5f 6c 65 61 76 65 28 | 29 2c 20 20 5f 65 6e 74 | _leave(|), _ent|
|000044f0| 65 72 28 29 2c 20 20 5f | 65 78 69 74 6c 70 28 29 |er(), _|exitlp()|
|00004500| 2c 0a 09 5f 69 61 64 64 | 28 29 2c 20 20 20 5f 69 |,.._iadd|(), _i|
|00004510| 73 75 62 28 29 2c 20 20 | 20 5f 69 6d 75 6c 74 28 |sub(), | _imult(|
|00004520| 29 2c 20 20 20 5f 69 64 | 69 76 28 29 2c 20 20 20 |), _id|iv(), |
|00004530| 5f 69 6d 6f 64 28 29 2c | 20 20 20 5f 63 6f 6d 6d |_imod(),| _comm|
|00004540| 61 28 29 2c 0a 09 5f 72 | 61 64 64 28 29 2c 20 20 |a(),.._r|add(), |
|00004550| 20 5f 72 73 75 62 28 29 | 2c 20 20 20 5f 72 6d 75 | _rsub()|, _rmu|
|00004560| 6c 74 28 29 2c 20 20 20 | 5f 72 64 69 76 28 29 2c |lt(), |_rdiv(),|
|00004570| 0a 09 5f 73 63 6f 6c 6f | 6e 28 29 2c 20 20 20 5f |.._scolo|n(), _|
|00004580| 67 6f 73 75 62 28 29 2c | 20 20 20 5f 72 65 74 75 |gosub(),| _retu|
|00004590| 72 6e 28 29 2c 09 5f 6e | 6f 74 28 29 2c 0a 09 5f |rn(),._n|ot(),.._|
|000045a0| 69 65 71 28 29 2c 09 09 | 5f 72 65 71 28 29 2c 09 |ieq(),..|_req(),.|
|000045b0| 09 5f 73 65 71 28 29 2c | 0a 09 5f 69 6e 65 71 28 |._seq(),|.._ineq(|
|000045c0| 29 2c 09 5f 72 6e 65 71 | 28 29 2c 09 5f 73 6e 65 |),._rneq|(),._sne|
|000045d0| 71 28 29 2c 0a 09 5f 69 | 6c 65 71 28 29 2c 09 5f |q(),.._i|leq(),._|
|000045e0| 72 6c 65 71 28 29 2c 09 | 5f 73 6c 65 71 28 29 2c |rleq(),.|_sleq(),|
|000045f0| 0a 09 5f 69 6c 74 28 29 | 2c 09 09 5f 72 6c 74 28 |.._ilt()|,.._rlt(|
|00004600| 29 2c 09 09 5f 73 6c 74 | 28 29 2c 0a 09 5f 69 67 |),.._slt|(),.._ig|
|00004610| 65 71 28 29 2c 09 5f 72 | 67 65 71 28 29 2c 09 5f |eq(),._r|geq(),._|
|00004620| 73 67 65 71 28 29 2c 0a | 09 5f 69 67 74 28 29 2c |sgeq(),.|._igt(),|
|00004630| 09 09 5f 72 67 74 28 29 | 2c 09 09 5f 73 67 74 28 |.._rgt()|,.._sgt(|
|00004640| 29 2c 09 5f 6f 72 28 29 | 2c 09 09 5f 61 6e 64 28 |),._or()|,.._and(|
|00004650| 29 2c 0a 09 5f 69 74 6f | 61 28 29 2c 09 5f 72 74 |),.._ito|a(),._rt|
|00004660| 6f 61 28 29 2c 09 5f 69 | 74 6f 72 28 29 2c 09 5f |oa(),._i|tor(),._|
|00004670| 72 74 6f 69 28 29 2c 0a | 09 5f 70 75 73 68 73 74 |rtoi(),.|._pushst|
|00004680| 61 74 65 28 29 2c 09 5f | 70 6f 70 73 74 61 74 65 |ate(),._|popstate|
|00004690| 28 29 2c 0a 09 5f 73 63 | 6f 6e 28 29 2c 09 5f 72 |(),.._sc|on(),._r|
|000046a0| 63 6f 6e 28 29 2c 20 20 | 20 5f 69 63 6f 6e 28 29 |con(), | _icon()|
|000046b0| 2c 20 20 20 5f 76 61 6c | 28 29 2c 20 20 20 5f 73 |, _val|(), _s|
|000046c0| 74 6f 72 65 28 29 2c 20 | 20 20 5f 76 61 72 28 29 |tore(), | _var()|
|000046d0| 3b 0a 0a 2f 2a 20 69 6e | 74 65 72 70 72 65 74 6f |;../* in|terpreto|
|000046e0| 72 20 6f 70 65 72 61 74 | 6f 72 20 74 61 62 6c 65 |r operat|or table|
|000046f0| 20 2a 2f 0a 73 74 72 75 | 63 74 20 77 6c 6e 6f 64 | */.stru|ct wlnod|
|00004700| 65 20 7b 0a 20 20 20 20 | 63 68 61 72 20 2a 6e 61 |e {. |char *na|
|00004710| 6d 65 3b 0a 20 20 20 20 | 69 6e 74 20 28 2a 66 75 |me;. |int (*fu|
|00004720| 6e 63 74 29 28 29 3b 0a | 7d 3b 0a 0a 65 78 74 65 |nct)();.|};..exte|
|00004730| 72 6e 20 73 74 72 75 63 | 74 20 77 6c 6e 6f 64 65 |rn struc|t wlnode|
|00004740| 20 77 6c 69 73 74 5b 5d | 3b 0a 0a 2f 2a 20 44 61 | wlist[]|;../* Da|
|00004750| 74 61 20 74 61 62 6c 65 | 2e 20 20 41 72 72 61 79 |ta table|. Array|
|00004760| 20 6f 66 20 70 6f 69 6e | 74 65 72 73 20 69 6e 74 | of poin|ters int|
|00004770| 6f 20 6c 6c 69 73 74 2e | 20 20 45 61 63 68 20 69 |o llist.| Each i|
|00004780| 73 20 61 20 6c 69 6e 65 | 20 77 69 63 68 20 68 61 |s a line| wich ha|
|00004790| 73 20 64 61 74 61 2e 20 | 2a 2f 0a 23 64 65 66 69 |s data. |*/.#defi|
|000047a0| 6e 65 20 44 4c 53 49 5a | 09 31 30 30 0a 65 78 74 |ne DLSIZ|.100.ext|
|000047b0| 65 72 6e 20 73 74 72 75 | 63 74 20 6c 69 6e 65 20 |ern stru|ct line |
|000047c0| 2a 64 6c 69 73 74 5b 5d | 3b 20 2f 2a 20 61 63 74 |*dlist[]|; /* act|
|000047d0| 75 61 6c 20 74 61 62 6c | 65 2c 20 6e 75 6d 62 65 |ual tabl|e, numbe|
|000047e0| 72 20 6f 66 20 65 6c 65 | 6d 73 2e 20 69 73 20 44 |r of ele|ms. is D|
|000047f0| 4c 53 49 5a 20 2a 2f 0a | 65 78 74 65 72 6e 20 69 |LSIZ */.|extern i|
|00004800| 6e 74 20 64 6c 70 3b 09 | 09 2f 2a 20 69 6e 64 65 |nt dlp;.|./* inde|
|00004810| 78 20 69 6e 74 6f 20 64 | 6c 69 73 74 20 66 6f 72 |x into d|list for|
|00004820| 20 63 75 72 72 65 6e 74 | 20 6c 69 6e 65 20 6f 66 | current| line of|
|00004830| 20 64 61 74 61 20 2a 2f | 0a 65 78 74 65 72 6e 20 | data */|.extern |
|00004840| 69 6e 74 20 64 6c 69 6e | 64 78 3b 09 2f 2a 20 69 |int dlin|dx;./* i|
|00004850| 6e 64 65 78 20 69 6e 74 | 6f 20 63 75 72 72 65 6e |ndex int|o curren|
|00004860| 74 20 6c 69 6e 65 20 66 | 6f 72 20 63 75 72 72 65 |t line f|or curre|
|00004870| 6e 74 20 64 61 74 61 20 | 69 74 65 6d 2e 20 2a 2f |nt data |item. */|
|00004880| 0a 65 78 74 65 72 6e 20 | 69 6e 74 20 64 74 79 70 |.extern |int dtyp|
|00004890| 65 3b 09 2f 2a 20 69 6e | 20 4d 5f 52 45 41 44 2c |e;./* in| M_READ,|
|000048a0| 20 6f 70 65 72 61 74 6f | 72 73 20 73 65 74 20 74 | operato|rs set t|
|000048b0| 68 69 73 20 74 6f 20 74 | 68 65 20 74 79 70 65 20 |his to t|he type |
|000048c0| 6f 66 20 0a 09 09 09 20 | 2a 20 74 68 65 69 72 20 |of .... |* their |
|000048d0| 6f 70 65 72 61 74 69 6f | 6e 2e 20 20 57 68 65 6e |operatio|n. When|
|000048e0| 20 74 68 65 20 65 78 70 | 72 65 73 73 69 6f 6e 20 | the exp|ression |
|000048f0| 69 73 20 64 6f 6e 65 0a | 09 09 09 20 2a 20 65 78 |is done.|... * ex|
|00004900| 65 63 75 74 69 6e 67 2c | 20 74 68 69 73 20 76 61 |ecuting,| this va|
|00004910| 72 69 61 62 6c 65 20 77 | 69 6c 6c 20 69 6e 64 69 |riable w|ill indi|
|00004920| 63 61 74 65 20 69 74 73 | 20 74 79 70 65 2e 0a 09 |cate its| type...|
|00004930| 09 09 20 2a 2f 0a 0a 2f | 2a 20 65 72 72 6f 72 20 |.. */../|* error |
|00004940| 72 6f 75 74 69 6e 65 73 | 20 2a 2f 0a 65 78 74 65 |routines| */.exte|
|00004950| 72 6e 20 69 6e 74 20 55 | 4c 65 72 72 6f 72 28 29 |rn int U|Lerror()|
|00004960| 3b 0a 65 78 74 65 72 6e | 20 69 6e 74 20 53 54 65 |;.extern| int STe|
|00004970| 72 72 6f 72 28 29 3b 0a | 65 78 74 65 72 6e 20 69 |rror();.|extern i|
|00004980| 6e 74 20 46 4e 65 72 72 | 6f 72 28 29 3b 0a 65 78 |nt FNerr|or();.ex|
|00004990| 74 65 72 6e 20 69 6e 74 | 20 4f 44 65 72 72 6f 72 |tern int| ODerror|
|000049a0| 28 29 3b 0a 65 78 74 65 | 72 6e 20 69 6e 74 20 42 |();.exte|rn int B|
|000049b0| 44 65 72 72 6f 72 28 29 | 3b 0a 65 78 74 65 72 6e |Derror()|;.extern|
|000049c0| 20 69 6e 74 20 56 54 65 | 72 72 6f 72 28 29 3b 0a | int VTe|rror();.|
|000049d0| 0a 0a 2f 2a 20 75 6e 69 | 6f 6e 73 20 66 6f 72 20 |../* uni|ons for |
|000049e0| 73 74 6f 72 69 6e 67 20 | 64 61 74 61 20 74 79 70 |storing |data typ|
|000049f0| 65 73 20 69 6e 20 74 68 | 65 20 63 6f 64 65 20 6c |es in th|e code l|
|00004a00| 69 73 74 20 2a 2f 0a 0a | 75 6e 69 6f 6e 20 64 6f |ist */..|union do|
|00004a10| 6e 69 20 7b 0a 20 20 20 | 20 64 6f 75 62 6c 65 20 |ni {. | double |
|00004a20| 64 5f 69 6e 5f 64 6f 6e | 69 3b 0a 20 20 20 20 69 |d_in_don|i;. i|
|00004a30| 6e 74 20 69 5f 69 6e 5f | 64 6f 6e 69 5b 73 69 7a |nt i_in_|doni[siz|
|00004a40| 65 6f 66 28 64 6f 75 62 | 6c 65 29 2f 73 69 7a 65 |eof(doub|le)/size|
|00004a50| 6f 66 28 69 6e 74 29 5d | 3b 0a 7d 3b 0a 75 6e 69 |of(int)]|;.};.uni|
|00004a60| 6f 6e 20 6c 6f 6e 69 20 | 7b 0a 20 20 20 20 6c 6f |on loni |{. lo|
|00004a70| 6e 67 20 6c 5f 69 6e 5f | 6c 6f 6e 69 3b 0a 20 20 |ng l_in_|loni;. |
|00004a80| 20 20 69 6e 74 20 69 5f | 69 6e 5f 6c 6f 6e 69 5b | int i_|in_loni[|
|00004a90| 73 69 7a 65 6f 66 28 6c | 6f 6e 67 29 2f 73 69 7a |sizeof(l|ong)/siz|
|00004aa0| 65 6f 66 28 69 6e 74 29 | 5d 3b 0a 7d 3b 0a 75 6e |eof(int)|];.};.un|
|00004ab0| 69 6f 6e 20 76 6f 6e 69 | 20 7b 0a 20 20 20 20 75 |ion voni| {. u|
|00004ac0| 6e 69 6f 6e 20 76 61 6c | 75 65 20 76 5f 69 6e 5f |nion val|ue v_in_|
|00004ad0| 76 6f 6e 69 3b 0a 20 20 | 20 20 69 6e 74 20 69 5f |voni;. | int i_|
|00004ae0| 69 6e 5f 76 6f 6e 69 5b | 73 69 7a 65 6f 66 28 75 |in_voni[|sizeof(u|
|00004af0| 6e 69 6f 6e 20 76 61 6c | 75 65 29 2f 73 69 7a 65 |nion val|ue)/size|
|00004b00| 6f 66 28 69 6e 74 29 5d | 3b 0a 7d 3b 0a 0a 0a 2f |of(int)]|;.};.../|
|00004b10| 2a 20 6d 69 73 63 65 6c | 6c 61 6e 65 6f 75 73 20 |* miscel|laneous |
|00004b20| 64 65 66 69 6e 69 74 69 | 6f 6e 73 2e 20 2a 2f 0a |definiti|ons. */.|
|00004b30| 0a 23 64 65 66 69 6e 65 | 20 53 54 4b 53 49 5a 09 |.#define| STKSIZ.|
|00004b40| 35 30 30 0a 65 78 74 65 | 72 6e 20 75 6e 69 6f 6e |500.exte|rn union|
|00004b50| 20 76 61 6c 75 65 20 73 | 74 61 63 6b 5b 5d 3b 0a | value s|tack[];.|
|00004b60| 65 78 74 65 72 6e 20 69 | 6e 74 20 73 74 61 63 6b |extern i|nt stack|
|00004b70| 70 3b 0a 65 78 74 65 72 | 6e 20 69 6e 74 20 70 75 |p;.exter|n int pu|
|00004b80| 73 68 28 29 3b 0a 65 78 | 74 65 72 6e 20 75 6e 69 |sh();.ex|tern uni|
|00004b90| 6f 6e 20 76 61 6c 75 65 | 20 70 6f 70 28 29 3b 0a |on value| pop();.|
|00004ba0| 0a 23 64 65 66 69 6e 65 | 20 43 53 54 4b 53 49 5a |.#define| CSTKSIZ|
|00004bb0| 09 35 0a 23 64 65 66 69 | 6e 65 20 42 46 53 49 5a |.5.#defi|ne BFSIZ|
|00004bc0| 09 32 30 30 09 2f 2a 20 | 69 6e 70 75 74 20 62 75 |.200./* |input bu|
|00004bd0| 66 66 65 72 20 2a 2f 0a | 65 78 74 65 72 6e 20 63 |ffer */.|extern c|
|00004be0| 68 61 72 20 70 62 62 75 | 66 5b 5d 3b 09 2f 2a 20 |har pbbu|f[];./* |
|00004bf0| 75 6e 70 75 74 28 29 20 | 62 75 66 66 65 72 20 2a |unput() |buffer *|
|00004c00| 2f 0a 65 78 74 65 72 6e | 20 63 68 61 72 20 69 62 |/.extern| char ib|
|00004c10| 75 66 5b 5d 3b 0a 65 78 | 74 65 72 6e 20 69 6e 74 |uf[];.ex|tern int|
|00004c20| 20 69 70 74 72 2c 70 62 | 70 74 72 3b 0a 65 78 74 | iptr,pb|ptr;.ext|
|00004c30| 65 72 6e 20 63 68 61 72 | 20 69 6e 70 75 74 28 29 |ern char| input()|
|00004c40| 3b 0a 65 78 74 65 72 6e | 20 72 64 6c 69 6e 28 29 |;.extern| rdlin()|
|00004c50| 2c 75 6e 70 75 74 28 29 | 3b 0a 0a 65 78 74 65 72 |,unput()|;..exter|
|00004c60| 6e 20 62 6c 63 70 79 28 | 29 3b 0a 0a 65 78 74 65 |n blcpy(|);..exte|
|00004c70| 72 6e 20 63 68 61 72 20 | 62 73 6c 61 73 68 28 29 |rn char |bslash()|
|00004c80| 3b 0a 65 78 74 65 72 6e | 20 63 68 61 72 20 2a 73 |;.extern| char *s|
|00004c90| 63 6f 6e 5f 69 6e 28 29 | 3b 0a 65 78 74 65 72 6e |con_in()|;.extern|
|00004ca0| 20 69 6e 74 20 6e 75 6d | 5f 69 6e 28 29 3b 0a 0a | int num|_in();..|
|00004cb0| 65 78 74 65 72 6e 20 63 | 68 61 72 20 2a 6d 79 61 |extern c|har *mya|
|00004cc0| 6c 6c 6f 63 28 29 3b 0a | 65 78 74 65 72 6e 20 75 |lloc();.|extern u|
|00004cd0| 6e 69 6f 6e 20 76 61 6c | 75 65 20 2a 67 65 74 70 |nion val|ue *getp|
|00004ce0| 6c 61 63 65 28 29 3b 0a | 65 78 74 65 72 6e 20 73 |lace();.|extern s|
|00004cf0| 74 72 75 63 74 20 6c 69 | 6e 65 20 2a 67 6c 6c 65 |truct li|ne *glle|
|00004d00| 6e 74 72 79 28 29 3b 0a | 0a 65 78 74 65 72 6e 20 |ntry();.|.extern |
|00004d10| 46 49 4c 45 20 2a 62 73 | 69 6e 3b 0a 0a 65 78 74 |FILE *bs|in;..ext|
|00004d20| 65 72 6e 20 69 6e 74 20 | 64 62 67 3b 09 09 2f 2a |ern int |dbg;../*|
|00004d30| 20 64 65 62 75 67 67 69 | 6e 67 20 66 6c 61 67 2e | debuggi|ng flag.|
|00004d40| 20 2a 2f 0a 65 78 74 65 | 72 6e 20 6c 6f 6e 67 20 | */.exte|rn long |
|00004d50| 61 74 6f 6c 28 29 3b 0a | 65 78 74 65 72 6e 20 64 |atol();.|extern d|
|00004d60| 6f 75 62 6c 65 20 61 74 | 6f 66 28 29 3b 0a 53 48 |ouble at|of();.SH|
|00004d70| 41 52 5f 45 4f 46 0a 69 | 66 20 74 65 73 74 20 34 |AR_EOF.i|f test 4|
|00004d80| 34 37 32 20 2d 6e 65 20 | 22 60 77 63 20 2d 63 20 |472 -ne |"`wc -c |
|00004d90| 3c 20 27 62 73 32 2f 62 | 73 64 65 66 73 2e 68 27 |< 'bs2/b|sdefs.h'|
|00004da0| 60 22 0a 74 68 65 6e 0a | 09 65 63 68 6f 20 73 68 |`".then.|.echo sh|
|00004db0| 61 72 3a 20 65 72 72 6f | 72 20 74 72 61 6e 73 6d |ar: erro|r transm|
|00004dc0| 69 74 74 69 6e 67 20 22 | 27 62 73 32 2f 62 73 64 |itting "|'bs2/bsd|
|00004dd0| 65 66 73 2e 68 27 22 20 | 27 28 73 68 6f 75 6c 64 |efs.h'" |'(should|
|00004de0| 20 68 61 76 65 20 62 65 | 65 6e 20 34 34 37 32 20 | have be|en 4472 |
|00004df0| 63 68 61 72 61 63 74 65 | 72 73 29 27 0a 66 69 0a |characte|rs)'.fi.|
|00004e00| 66 69 20 23 20 65 6e 64 | 20 6f 66 20 6f 76 65 72 |fi # end| of over|
|00004e10| 77 72 69 74 69 6e 67 20 | 63 68 65 63 6b 0a 65 63 |writing |check.ec|
|00004e20| 68 6f 20 73 68 61 72 3a | 20 65 78 74 72 61 63 74 |ho shar:| extract|
|00004e30| 69 6e 67 20 22 27 62 73 | 32 2f 62 73 67 72 61 6d |ing "'bs|2/bsgram|
|00004e40| 2e 79 27 22 20 27 28 36 | 37 36 31 20 63 68 61 72 |.y'" '(6|761 char|
|00004e50| 61 63 74 65 72 73 29 27 | 0a 69 66 20 74 65 73 74 |acters)'|.if test|
|00004e60| 20 2d 66 20 27 62 73 32 | 2f 62 73 67 72 61 6d 2e | -f 'bs2|/bsgram.|
|00004e70| 79 27 0a 74 68 65 6e 0a | 09 65 63 68 6f 20 73 68 |y'.then.|.echo sh|
|00004e80| 61 72 3a 20 77 69 6c 6c | 20 6e 6f 74 20 6f 76 65 |ar: will| not ove|
|00004e90| 72 2d 77 72 69 74 65 20 | 65 78 69 73 74 69 6e 67 |r-write |existing|
|00004ea0| 20 66 69 6c 65 20 22 27 | 62 73 32 2f 62 73 67 72 | file "'|bs2/bsgr|
|00004eb0| 61 6d 2e 79 27 22 0a 65 | 6c 73 65 0a 73 65 64 20 |am.y'".e|lse.sed |
|00004ec0| 27 73 2f 5e 58 2f 2f 27 | 20 3c 3c 20 5c 53 48 41 |'s/^X//'| << \SHA|
|00004ed0| 52 5f 45 4f 46 20 3e 20 | 27 62 73 32 2f 62 73 67 |R_EOF > |'bs2/bsg|
|00004ee0| 72 61 6d 2e 79 27 0a 09 | 2f 2a 20 62 73 67 72 61 |ram.y'..|/* bsgra|
|00004ef0| 6d 2e 79 20 2d 2d 20 67 | 72 61 6d 6d 65 72 20 73 |m.y -- g|rammer s|
|00004f00| 70 65 63 69 66 69 63 61 | 74 69 6f 6e 20 66 6f 72 |pecifica|tion for|
|00004f10| 20 62 73 2e 0a 09 20 2a | 2f 0a 25 7b 0a 23 69 6e | bs... *|/.%{.#in|
|00004f20| 63 6c 75 64 65 20 22 62 | 73 64 65 66 73 2e 68 22 |clude "b|sdefs.h"|
|00004f30| 0a 0a 63 68 61 72 20 2a | 70 3b 09 09 2f 2a 20 74 |..char *|p;../* t|
|00004f40| 68 65 20 67 65 6e 65 72 | 69 63 20 70 6f 69 6e 74 |he gener|ic point|
|00004f50| 65 72 20 2a 2f 0a 69 6e | 74 20 69 3b 09 09 09 2f |er */.in|t i;.../|
|00004f60| 2a 20 74 68 65 20 67 65 | 6e 65 72 69 63 20 63 6f |* the ge|neric co|
|00004f70| 75 6e 74 65 72 20 2a 2f | 0a 0a 73 74 72 75 63 74 |unter */|..struct|
|00004f80| 20 73 74 6b 20 7b 0a 20 | 20 20 20 69 6e 74 20 73 | stk {. | int s|
|00004f90| 74 61 63 6b 5b 34 30 5d | 3b 0a 20 20 20 20 69 6e |tack[40]|;. in|
|00004fa0| 74 20 73 74 6b 70 3b 0a | 7d 3b 0a 0a 73 74 72 75 |t stkp;.|};..stru|
|00004fb0| 63 74 20 73 74 6b 20 69 | 66 73 74 6b 2c 77 68 73 |ct stk i|fstk,whs|
|00004fc0| 74 6b 2c 66 6f 72 73 74 | 6b 2c 72 65 70 73 74 6b |tk,forst|k,repstk|
|00004fd0| 2c 6c 70 73 74 6b 3b 0a | 69 6e 74 20 67 6f 6d 61 |,lpstk;.|int goma|
|00004fe0| 78 3d 30 3b 20 69 6e 74 | 20 69 66 6d 61 78 3d 30 |x=0; int| ifmax=0|
|00004ff0| 3b 20 69 6e 74 20 77 68 | 6d 61 78 3d 30 3b 20 69 |; int wh|max=0; i|
|00005000| 6e 74 20 66 6f 72 6d 61 | 78 3d 30 3b 20 69 6e 74 |nt forma|x=0; int|
|00005010| 20 72 65 70 6d 61 78 3d | 30 3b 20 69 6e 74 20 6c | repmax=|0; int l|
|00005020| 70 6d 61 78 3d 30 3b 0a | 0a 65 78 74 65 72 6e 20 |pmax=0;.|.extern |
|00005030| 63 68 61 72 20 2a 79 79 | 74 65 78 74 3b 0a 65 78 |char *yy|text;.ex|
|00005040| 74 65 72 6e 20 63 68 61 | 72 20 2a 62 73 79 79 73 |tern cha|r *bsyys|
|00005050| 76 61 6c 3b 0a 65 78 74 | 65 72 6e 20 69 6e 74 20 |val;.ext|ern int |
|00005060| 79 79 6c 65 6e 67 3b 0a | 25 7d 0a 0a 25 74 65 72 |yyleng;.|%}..%ter|
|00005070| 6d 20 45 51 55 41 4c 09 | 4e 45 51 09 4c 45 09 4c |m EQUAL.|NEQ.LE.L|
|00005080| 54 09 47 45 09 57 48 49 | 4c 45 0a 25 74 65 72 6d |T.GE.WHI|LE.%term|
|00005090| 20 47 54 09 4f 52 09 41 | 4e 44 09 4e 4f 54 09 52 | GT.OR.A|ND.NOT.R|
|000050a0| 45 54 09 52 45 50 45 41 | 54 0a 25 74 65 72 6d 20 |ET.REPEA|T.%term |
|000050b0| 49 46 09 54 48 45 4e 09 | 45 4c 53 45 09 47 4f 54 |IF.THEN.|ELSE.GOT|
|000050c0| 4f 09 47 4f 53 55 42 09 | 55 4e 54 49 4c 0a 25 74 |O.GOSUB.|UNTIL.%t|
|000050d0| 65 72 6d 20 53 54 4f 50 | 09 45 4e 44 09 49 4e 54 |erm STOP|.END.INT|
|000050e0| 45 47 45 52 09 52 45 41 | 4c 09 53 43 4f 4e 53 54 |EGER.REA|L.SCONST|
|000050f0| 09 45 4c 49 48 57 0a 25 | 74 65 72 6d 20 4c 45 54 |.ELIHW.%|term LET|
|00005100| 09 53 57 4f 52 44 09 50 | 52 49 4e 54 09 49 4e 50 |.SWORD.P|RINT.INP|
|00005110| 55 54 09 44 41 54 41 09 | 43 46 4f 52 0a 25 74 65 |UT.DATA.|CFOR.%te|
|00005120| 72 6d 20 46 4f 52 09 54 | 4f 09 53 54 45 50 09 52 |rm FOR.T|O.STEP.R|
|00005130| 45 41 44 09 57 52 49 54 | 45 09 4e 45 58 54 0a 25 |EAD.WRIT|E.NEXT.%|
|00005140| 74 65 72 6d 20 44 45 46 | 49 4e 45 09 4c 46 55 4e |term DEF|INE.LFUN|
|00005150| 09 53 46 55 4e 09 46 44 | 45 46 09 53 59 4d 42 4f |.SFUN.FD|EF.SYMBO|
|00005160| 4c 09 44 49 4d 0a 25 74 | 65 72 6d 20 56 41 4c 55 |L.DIM.%t|erm VALU|
|00005170| 45 09 49 57 4f 52 44 09 | 52 57 4f 52 44 09 52 4f |E.IWORD.|RWORD.RO|
|00005180| 46 43 09 4c 4f 4f 50 09 | 45 58 49 54 49 46 0a 25 |FC.LOOP.|EXITIF.%|
|00005190| 74 65 72 6d 20 49 54 4f | 52 09 52 54 4f 49 09 49 |term ITO|R.RTOI.I|
|000051a0| 54 4f 41 09 52 54 4f 41 | 09 4c 45 41 56 45 09 43 |TOA.RTOA|.LEAVE.C|
|000051b0| 4f 4e 54 49 4e 55 45 0a | 25 74 65 72 6d 20 50 4f |ONTINUE.|%term PO|
|000051c0| 4f 4c 0a 0a 25 6c 65 66 | 74 20 27 2c 27 20 27 3b |OL..%lef|t ',' ';|
|000051d0| 27 0a 25 72 69 67 68 74 | 20 27 3d 27 0a 25 6e 6f |'.%right| '='.%no|
|000051e0| 6e 61 73 73 6f 63 20 4f | 52 20 41 4e 44 0a 25 6e |nassoc O|R AND.%n|
|000051f0| 6f 6e 61 73 73 6f 63 20 | 4c 45 20 4c 54 20 47 45 |onassoc |LE LT GE|
|00005200| 20 47 54 20 45 51 55 41 | 4c 20 4e 45 51 0a 25 6c | GT EQUA|L NEQ.%l|
|00005210| 65 66 74 20 27 2b 27 20 | 27 2d 27 0a 25 6c 65 66 |eft '+' |'-'.%lef|
|00005220| 74 20 27 2a 27 20 27 2f | 27 20 27 25 27 0a 25 6c |t '*' '/|' '%'.%l|
|00005230| 65 66 74 20 55 4e 41 52 | 59 0a 25 6c 65 66 74 20 |eft UNAR|Y.%left |
|00005240| 27 28 27 0a 0a 0a 25 73 | 74 61 72 74 20 6c 69 6e |'('...%s|tart lin|
|00005250| 65 73 0a 0a 25 25 0a 0a | 6c 69 6e 65 73 09 09 3a |es..%%..|lines..:|
|00005260| 20 2f 2a 20 65 6d 70 74 | 79 20 2a 2f 0a 09 09 7c | /* empt|y */...||
|00005270| 20 6c 69 6e 65 73 20 6c | 69 6e 65 0a 09 09 3b 0a | lines l|ine...;.|
|00005280| 0a 6c 69 6e 65 09 09 3a | 20 6c 6e 75 6d 20 73 74 |.line..:| lnum st|
|00005290| 61 74 20 27 5c 6e 27 0a | 09 09 09 7b 20 70 72 69 |at '\n'.|...{ pri|
|000052a0| 6e 74 66 28 22 5c 6e 22 | 29 3b 20 7d 0a 09 09 7c |ntf("\n"|); }...||
|000052b0| 20 27 5c 6e 27 0a 09 09 | 3b 0a 0a 6c 6e 75 6d 09 | '\n'...|;..lnum.|
|000052c0| 09 3a 20 49 4e 54 45 47 | 45 52 0a 09 09 09 7b 20 |.: INTEG|ER....{ |
|000052d0| 70 72 69 6e 74 66 28 22 | 20 6c 69 6e 65 20 25 73 |printf("| line %s|
|000052e0| 20 22 2c 24 31 29 3b 20 | 7d 0a 09 09 3b 0a 0a 73 | ",$1); |}...;..s|
|000052f0| 74 61 74 09 09 3a 20 4c | 45 54 20 6c 65 74 5f 78 |tat..: L|ET let_x|
|00005300| 70 72 0a 09 09 7c 20 6c | 65 74 5f 78 70 72 0a 09 |pr...| l|et_xpr..|
|00005310| 09 7c 20 50 52 49 4e 54 | 20 70 65 0a 09 09 09 7b |.| PRINT| pe....{|
|00005320| 20 70 72 69 6e 74 66 28 | 22 20 70 72 69 6e 74 20 | printf(|" print |
|00005330| 22 29 3b 20 7d 0a 09 09 | 7c 20 47 4f 54 4f 20 49 |"); }...|| GOTO I|
|00005340| 4e 54 45 47 45 52 0a 09 | 09 09 7b 20 70 72 69 6e |NTEGER..|..{ prin|
|00005350| 74 66 28 22 20 72 6c 61 | 62 65 6c 20 4c 4e 25 73 |tf(" rla|bel LN%s|
|00005360| 20 67 6f 74 6f 20 22 2c | 24 32 29 3b 20 7d 0a 09 | goto ",|$2); }..|
|00005370| 09 7c 20 47 4f 53 55 42 | 20 49 4e 54 45 47 45 52 |.| GOSUB| INTEGER|
|00005380| 0a 09 09 09 7b 20 70 72 | 69 6e 74 66 28 22 20 72 |....{ pr|intf(" r|
|00005390| 6c 61 62 65 6c 20 4c 4e | 25 73 20 67 6f 73 75 62 |label LN|%s gosub|
|000053a0| 20 22 2c 24 32 29 3b 20 | 7d 0a 09 09 7c 20 4c 45 | ",$2); |}...| LE|
|000053b0| 41 56 45 0a 09 09 09 7b | 20 70 72 69 6e 74 66 28 |AVE....{| printf(|
|000053c0| 22 20 6c 65 61 76 65 20 | 22 29 3b 20 7d 0a 09 09 |" leave |"); }...|
|000053d0| 7c 20 43 4f 4e 54 49 4e | 55 45 0a 09 09 09 7b 20 || CONTIN|UE....{ |
|000053e0| 70 72 69 6e 74 66 28 22 | 20 63 6f 6e 74 69 6e 20 |printf("| contin |
|000053f0| 22 29 3b 20 7d 0a 09 09 | 7c 20 52 45 54 0a 09 09 |"); }...|| RET...|
|00005400| 09 7b 20 70 72 69 6e 74 | 66 28 22 20 72 65 74 75 |.{ print|f(" retu|
|00005410| 72 6e 20 22 29 3b 20 7d | 0a 09 09 7c 20 49 46 20 |rn "); }|...| IF |
|00005420| 62 65 78 70 72 0a 09 09 | 09 7b 0a 09 09 09 09 6c |bexpr...|.{.....l|
|00005430| 70 75 73 68 28 26 69 66 | 73 74 6b 2c 69 66 6d 61 |push(&if|stk,ifma|
|00005440| 78 29 3b 0a 09 09 09 09 | 70 72 69 6e 74 66 28 22 |x);.....|printf("|
|00005450| 20 72 6c 61 62 65 6c 20 | 49 46 25 64 20 69 66 20 | rlabel |IF%d if |
|00005460| 22 2c 69 66 6d 61 78 29 | 3b 0a 09 09 09 09 69 66 |",ifmax)|;.....if|
|00005470| 6d 61 78 20 2b 3d 20 32 | 3b 0a 09 09 09 7d 0a 09 |max += 2|;....}..|
|00005480| 09 20 20 54 48 45 4e 20 | 73 74 61 74 0a 09 09 09 |. THEN |stat....|
|00005490| 7b 0a 09 09 09 09 69 20 | 3d 20 6c 74 6f 70 28 26 |{.....i |= ltop(&|
|000054a0| 69 66 73 74 6b 29 3b 0a | 09 09 09 09 70 72 69 6e |ifstk);.|....prin|
|000054b0| 74 66 28 22 20 72 6c 61 | 62 65 6c 20 49 46 25 64 |tf(" rla|bel IF%d|
|000054c0| 20 67 6f 74 6f 20 22 2c | 69 2b 31 29 3b 0a 09 09 | goto ",|i+1);...|
|000054d0| 09 7d 0a 09 09 20 20 69 | 66 5f 65 6c 73 65 0a 09 |.}... i|f_else..|
|000054e0| 09 7c 20 49 4e 50 55 54 | 20 0a 09 09 09 7b 20 70 |.| INPUT| ....{ p|
|000054f0| 72 69 6e 74 66 28 22 20 | 70 75 73 68 73 74 61 74 |rintf(" |pushstat|
|00005500| 65 20 25 64 20 22 2c 4d | 5f 49 4e 50 55 54 29 3b |e %d ",M|_INPUT);|
|00005510| 20 7d 0a 09 09 20 20 76 | 61 72 5f 6c 73 74 0a 09 | }... v|ar_lst..|
|00005520| 09 09 7b 20 70 72 69 6e | 74 66 28 22 20 70 6f 70 |..{ prin|tf(" pop|
|00005530| 73 74 61 74 65 20 22 29 | 3b 20 7d 0a 09 09 7c 20 |state ")|; }...| |
|00005540| 53 54 4f 50 0a 09 09 09 | 7b 20 70 72 69 6e 74 66 |STOP....|{ printf|
|00005550| 28 22 20 73 74 6f 70 20 | 22 29 3b 20 7d 0a 09 09 |(" stop |"); }...|
|00005560| 7c 20 45 4e 44 0a 09 09 | 09 7b 20 70 72 69 6e 74 || END...|.{ print|
|00005570| 66 28 22 20 65 6e 64 20 | 22 29 3b 20 7d 0a 09 09 |f(" end |"); }...|
|00005580| 7c 20 46 4f 52 20 69 76 | 61 72 20 27 3d 27 20 72 || FOR iv|ar '=' r|
|00005590| 65 78 70 72 20 54 4f 20 | 72 65 78 70 72 20 66 6f |expr TO |rexpr fo|
|000055a0| 72 5f 73 74 65 70 0a 09 | 09 09 7b 0a 09 09 09 09 |r_step..|..{.....|
|000055b0| 6c 70 75 73 68 28 26 66 | 6f 72 73 74 6b 2c 66 6f |lpush(&f|orstk,fo|
|000055c0| 72 6d 61 78 29 3b 0a 09 | 09 09 09 70 72 69 6e 74 |rmax);..|...print|
|000055d0| 66 28 22 20 72 6c 61 62 | 65 6c 20 46 4f 52 25 64 |f(" rlab|el FOR%d|
|000055e0| 20 72 6c 61 62 65 6c 20 | 46 4f 52 25 64 20 65 6e | rlabel |FOR%d en|
|000055f0| 74 65 72 22 2c 0a 09 09 | 09 09 09 66 6f 72 6d 61 |ter",...|...forma|
|00005600| 78 2b 32 2c 66 6f 72 6d | 61 78 2b 31 29 3b 0a 09 |x+2,form|ax+1);..|
|00005610| 09 09 09 70 72 69 6e 74 | 66 28 22 20 69 63 6f 6e |...print|f(" icon|
|00005620| 20 30 20 72 6c 61 62 65 | 6c 20 46 4f 52 25 64 20 | 0 rlabe|l FOR%d |
|00005630| 64 6c 61 62 65 6c 20 46 | 4f 52 25 64 20 66 6f 72 |dlabel F|OR%d for|
|00005640| 20 22 2c 0a 09 09 09 09 | 09 66 6f 72 6d 61 78 2b | ",.....|.formax+|
|00005650| 31 2c 66 6f 72 6d 61 78 | 29 3b 0a 09 09 09 09 66 |1,formax|);.....f|
|00005660| 6f 72 6d 61 78 20 2b 3d | 20 33 3b 0a 09 09 09 7d |ormax +=| 3;....}|
|00005670| 0a 09 09 7c 20 4e 45 58 | 54 0a 09 09 09 7b 0a 09 |...| NEX|T....{..|
|00005680| 09 09 09 69 20 3d 20 6c | 74 6f 70 28 26 66 6f 72 |...i = l|top(&for|
|00005690| 73 74 6b 29 3b 0a 09 09 | 09 09 70 72 69 6e 74 66 |stk);...|..printf|
|000056a0| 28 22 20 64 6c 61 62 65 | 6c 20 46 4f 52 25 64 20 |(" dlabe|l FOR%d |
|000056b0| 22 2c 69 2b 32 29 3b 0a | 09 09 09 7d 0a 09 09 20 |",i+2);.|...}... |
|000056c0| 20 69 76 61 72 0a 09 09 | 09 7b 0a 09 09 09 09 69 | ivar...|.{.....i|
|000056d0| 20 3d 20 6c 70 6f 70 28 | 26 66 6f 72 73 74 6b 29 | = lpop(|&forstk)|
|000056e0| 3b 0a 09 09 09 09 70 72 | 69 6e 74 66 28 22 20 6e |;.....pr|intf(" n|
|000056f0| 65 78 74 20 72 6c 61 62 | 65 6c 20 46 4f 52 25 64 |ext rlab|el FOR%d|
|00005700| 20 67 6f 74 6f 20 64 6c | 61 62 65 6c 20 46 4f 52 | goto dl|abel FOR|
|00005710| 25 64 20 22 2c 0a 09 09 | 09 09 09 69 2c 69 2b 31 |%d ",...|...i,i+1|
|00005720| 29 3b 0a 09 09 09 09 70 | 72 69 6e 74 66 28 22 65 |);.....p|rintf("e|
|00005730| 78 69 74 6c 70 20 22 29 | 3b 0a 09 09 09 7d 0a 09 |xitlp ")|;....}..|
|00005740| 09 7c 20 52 45 41 44 20 | 7b 20 70 72 69 6e 74 66 |.| READ |{ printf|
|00005750| 28 22 20 70 75 73 68 73 | 74 61 74 65 20 25 64 20 |(" pushs|tate %d |
|00005760| 22 2c 4d 5f 52 45 41 44 | 29 3b 20 7d 20 76 61 72 |",M_READ|); } var|
|00005770| 5f 6c 73 74 0a 09 09 09 | 7b 20 70 72 69 6e 74 66 |_lst....|{ printf|
|00005780| 28 22 20 70 6f 70 73 74 | 61 74 65 20 22 29 3b 20 |(" popst|ate "); |
|00005790| 7d 0a 09 09 7c 20 44 41 | 54 41 20 7b 20 70 72 69 |}...| DA|TA { pri|
|000057a0| 6e 74 66 28 22 20 64 61 | 74 61 20 22 29 3b 20 7d |ntf(" da|ta "); }|
|000057b0| 20 64 61 74 61 5f 6c 73 | 74 0a 09 09 7c 20 4c 4f | data_ls|t...| LO|
|000057c0| 4f 50 0a 09 09 09 7b 0a | 09 09 09 09 6c 70 75 73 |OP....{.|....lpus|
|000057d0| 68 28 26 6c 70 73 74 6b | 2c 6c 70 6d 61 78 29 3b |h(&lpstk|,lpmax);|
|000057e0| 0a 09 09 09 09 70 72 69 | 6e 74 66 28 22 20 72 6c |.....pri|ntf(" rl|
|000057f0| 61 62 65 6c 20 4c 50 25 | 64 20 72 6c 61 62 65 6c |abel LP%|d rlabel|
|00005800| 20 4c 50 25 64 20 65 6e | 74 65 72 22 2c 0a 09 09 | LP%d en|ter",...|
|00005810| 09 09 09 6c 70 6d 61 78 | 2b 32 2c 6c 70 6d 61 78 |...lpmax|+2,lpmax|
|00005820| 2b 31 29 3b 0a 09 09 09 | 09 70 72 69 6e 74 66 28 |+1);....|.printf(|
|00005830| 22 20 64 6c 61 62 65 6c | 20 4c 50 25 64 20 22 2c |" dlabel| LP%d ",|
|00005840| 6c 70 6d 61 78 29 3b 0a | 09 09 09 09 6c 70 6d 61 |lpmax);.|....lpma|
|00005850| 78 20 2b 3d 20 33 3b 0a | 09 09 09 7d 0a 09 09 7c |x += 3;.|...}...||
|00005860| 20 45 58 49 54 49 46 20 | 62 65 78 70 72 0a 09 09 | EXITIF |bexpr...|
|00005870| 09 7b 0a 09 09 09 09 69 | 20 3d 20 6c 74 6f 70 28 |.{.....i| = ltop(|
|00005880| 26 6c 70 73 74 6b 29 3b | 0a 09 09 09 09 70 72 69 |&lpstk);|.....pri|
|00005890| 6e 74 66 28 22 20 6e 6f | 74 20 72 6c 61 62 65 6c |ntf(" no|t rlabel|
|000058a0| 20 4c 50 25 64 20 69 66 | 20 22 2c 69 2b 31 29 3b | LP%d if| ",i+1);|
|000058b0| 0a 09 09 09 7d 0a 09 09 | 7c 20 50 4f 4f 4c 0a 09 |....}...|| POOL..|
|000058c0| 09 09 7b 0a 09 09 09 09 | 69 20 3d 20 6c 70 6f 70 |..{.....|i = lpop|
|000058d0| 28 26 6c 70 73 74 6b 29 | 3b 0a 09 09 09 09 70 72 |(&lpstk)|;.....pr|
|000058e0| 69 6e 74 66 28 22 20 64 | 6c 61 62 65 6c 20 4c 50 |intf(" d|label LP|
|000058f0| 25 64 20 72 6c 61 62 65 | 6c 20 4c 50 25 64 20 67 |%d rlabe|l LP%d g|
|00005900| 6f 74 6f 22 2c 69 2b 32 | 2c 69 29 3b 0a 09 09 09 |oto",i+2|,i);....|
|00005910| 09 70 72 69 6e 74 66 28 | 22 20 64 6c 61 62 65 6c |.printf(|" dlabel|
|00005920| 20 4c 50 25 64 20 65 78 | 69 74 6c 70 20 22 2c 69 | LP%d ex|itlp ",i|
|00005930| 2b 31 29 3b 0a 09 09 09 | 7d 0a 09 09 7c 20 57 48 |+1);....|}...| WH|
|00005940| 49 4c 45 0a 09 09 09 7b | 0a 09 09 09 09 6c 70 75 |ILE....{|.....lpu|
|00005950| 73 68 28 26 77 68 73 74 | 6b 2c 77 68 6d 61 78 29 |sh(&whst|k,whmax)|
|00005960| 3b 0a 09 09 09 09 70 72 | 69 6e 74 66 28 22 20 72 |;.....pr|intf(" r|
|00005970| 6c 61 62 65 6c 20 57 48 | 25 64 20 72 6c 61 62 65 |label WH|%d rlabe|
|00005980| 6c 20 57 48 25 64 20 65 | 6e 74 65 72 22 2c 0a 09 |l WH%d e|nter",..|
|00005990| 09 09 09 09 77 68 6d 61 | 78 2b 32 2c 77 68 6d 61 |....whma|x+2,whma|
|000059a0| 78 2b 31 29 3b 0a 09 09 | 09 09 70 72 69 6e 74 66 |x+1);...|..printf|
|000059b0| 28 22 20 64 6c 61 62 65 | 6c 20 57 48 25 64 20 22 |(" dlabe|l WH%d "|
|000059c0| 2c 77 68 6d 61 78 29 3b | 0a 09 09 09 09 77 68 6d |,whmax);|.....whm|
|000059d0| 61 78 20 2b 3d 20 33 3b | 0a 09 09 09 7d 0a 09 09 |ax += 3;|....}...|
|000059e0| 20 20 62 65 78 70 72 0a | 09 09 09 7b 0a 09 09 09 | bexpr.|...{....|
|000059f0| 09 69 20 3d 20 6c 74 6f | 70 28 26 77 68 73 74 6b |.i = lto|p(&whstk|
|00005a00| 29 3b 0a 09 09 09 09 70 | 72 69 6e 74 66 28 22 20 |);.....p|rintf(" |
|00005a10| 72 6c 61 62 65 6c 20 57 | 48 25 64 20 69 66 20 22 |rlabel W|H%d if "|
|00005a20| 2c 69 2b 31 29 3b 0a 09 | 09 09 7d 0a 09 09 7c 20 |,i+1);..|..}...| |
|00005a30| 45 4c 49 48 57 0a 09 09 | 09 7b 0a 09 09 09 09 69 |ELIHW...|.{.....i|
|00005a40| 20 3d 20 6c 70 6f 70 28 | 26 77 68 73 74 6b 29 3b | = lpop(|&whstk);|
|00005a50| 0a 09 09 09 09 70 72 69 | 6e 74 66 28 22 20 64 6c |.....pri|ntf(" dl|
|00005a60| 61 62 65 6c 20 57 48 25 | 64 22 2c 69 2b 32 29 3b |abel WH%|d",i+2);|
|00005a70| 0a 09 09 09 09 70 72 69 | 6e 74 66 28 22 20 72 6c |.....pri|ntf(" rl|
|00005a80| 61 62 65 6c 20 57 48 25 | 64 20 67 6f 74 6f 20 64 |abel WH%|d goto d|
|00005a90| 6c 61 62 65 6c 20 57 48 | 25 64 20 65 78 69 74 6c |label WH|%d exitl|
|00005aa0| 70 20 22 2c 69 2c 69 2b | 31 29 3b 0a 09 09 09 7d |p ",i,i+|1);....}|
|00005ab0| 0a 09 09 7c 20 52 45 50 | 45 41 54 0a 09 09 09 7b |...| REP|EAT....{|
|00005ac0| 0a 09 09 09 09 6c 70 75 | 73 68 28 26 72 65 70 73 |.....lpu|sh(&reps|
|00005ad0| 74 6b 2c 72 65 70 6d 61 | 78 29 3b 0a 09 09 09 09 |tk,repma|x);.....|
|00005ae0| 70 72 69 6e 74 66 28 22 | 20 72 6c 61 62 65 6c 20 |printf("| rlabel |
|00005af0| 52 45 50 25 64 20 72 6c | 61 62 65 6c 20 52 45 50 |REP%d rl|abel REP|
|00005b00| 25 64 20 65 6e 74 65 72 | 22 2c 0a 09 09 09 09 09 |%d enter|",......|
|00005b10| 72 65 70 6d 61 78 2b 31 | 2c 72 65 70 6d 61 78 2b |repmax+1|,repmax+|
|00005b20| 32 29 3b 0a 09 09 09 09 | 70 72 69 6e 74 66 28 22 |2);.....|printf("|
|00005b30| 20 64 6c 61 62 65 6c 20 | 52 45 50 25 64 20 22 2c | dlabel |REP%d ",|
|00005b40| 72 65 70 6d 61 78 29 3b | 0a 09 09 09 09 72 65 70 |repmax);|.....rep|
|00005b50| 6d 61 78 20 2b 3d 20 33 | 3b 0a 09 09 09 7d 0a 09 |max += 3|;....}..|
|00005b60| 09 7c 20 55 4e 54 49 4c | 0a 09 09 09 7b 0a 09 09 |.| UNTIL|....{...|
|00005b70| 09 09 69 20 3d 20 6c 74 | 6f 70 28 26 72 65 70 73 |..i = lt|op(&reps|
|00005b80| 74 6b 29 3b 0a 09 09 09 | 09 70 72 69 6e 74 66 28 |tk);....|.printf(|
|00005b90| 22 20 64 6c 61 62 65 6c | 20 52 45 50 25 64 20 22 |" dlabel| REP%d "|
|00005ba0| 2c 69 2b 31 29 3b 0a 09 | 09 09 7d 0a 09 09 20 20 |,i+1);..|..}... |
|00005bb0| 62 65 78 70 72 0a 09 09 | 09 7b 0a 09 09 09 09 69 |bexpr...|.{.....i|
|00005bc0| 20 3d 20 6c 70 6f 70 28 | 26 72 65 70 73 74 6b 29 | = lpop(|&repstk)|
|00005bd0| 3b 0a 09 09 09 09 70 72 | 69 6e 74 66 28 22 20 6e |;.....pr|intf(" n|
|00005be0| 6f 74 20 72 6c 61 62 65 | 6c 20 52 45 50 25 64 20 |ot rlabe|l REP%d |
|00005bf0| 69 66 22 2c 69 29 3b 0a | 09 09 09 09 70 72 69 6e |if",i);.|....prin|
|00005c00| 74 66 28 22 20 64 6c 61 | 62 65 6c 20 52 45 50 25 |tf(" dla|bel REP%|
|00005c10| 64 20 65 78 69 74 6c 70 | 20 22 2c 69 2b 32 29 3b |d exitlp| ",i+2);|
|00005c20| 0a 09 09 09 7d 0a 09 09 | 3b 0a 0a 6c 65 74 5f 78 |....}...|;..let_x|
|00005c30| 70 72 09 09 3a 20 69 76 | 61 72 20 27 3d 27 20 72 |pr..: iv|ar '=' r|
|00005c40| 65 78 70 72 0a 09 09 09 | 7b 20 70 72 69 6e 74 66 |expr....|{ printf|
|00005c50| 28 22 20 72 74 6f 69 20 | 73 74 6f 72 65 20 25 64 |(" rtoi |store %d|
|00005c60| 20 70 6f 70 20 22 2c 54 | 5f 49 4e 54 29 3b 20 7d | pop ",T|_INT); }|
|00005c70| 0a 09 09 7c 20 72 76 61 | 72 20 27 3d 27 20 72 65 |...| rva|r '=' re|
|00005c80| 78 70 72 0a 09 09 09 7b | 20 70 72 69 6e 74 66 28 |xpr....{| printf(|
|00005c90| 22 20 73 74 6f 72 65 20 | 25 64 20 70 6f 70 20 22 |" store |%d pop "|
|00005ca0| 2c 54 5f 44 42 4c 29 3b | 20 7d 0a 09 09 7c 20 73 |,T_DBL);| }...| s|
|00005cb0| 76 61 72 20 27 3d 27 20 | 73 65 78 70 72 0a 09 09 |var '=' |sexpr...|
|00005cc0| 09 7b 20 70 72 69 6e 74 | 66 28 22 20 73 74 6f 72 |.{ print|f(" stor|
|00005cd0| 65 20 25 64 20 73 70 6f | 70 20 22 2c 54 5f 43 48 |e %d spo|p ",T_CH|
|00005ce0| 52 29 3b 20 7d 0a 09 09 | 3b 0a 0a 64 61 74 61 5f |R); }...|;..data_|
|00005cf0| 6c 73 74 09 3a 20 72 65 | 78 70 72 0a 09 09 09 7b |lst.: re|xpr....{|
|00005d00| 20 70 72 69 6e 74 66 28 | 22 20 64 73 65 70 20 22 | printf(|" dsep "|
|00005d10| 29 3b 20 7d 0a 09 09 7c | 20 73 65 78 70 72 0a 09 |); }...|| sexpr..|
|00005d20| 09 09 7b 20 70 72 69 6e | 74 66 28 22 20 64 73 65 |..{ prin|tf(" dse|
|00005d30| 70 20 22 29 3b 20 7d 0a | 09 09 7c 20 64 61 74 61 |p "); }.|..| data|
|00005d40| 5f 6c 73 74 20 27 2c 27 | 20 72 65 78 70 72 0a 09 |_lst ','| rexpr..|
|00005d50| 09 09 7b 20 70 72 69 6e | 74 66 28 22 20 64 73 65 |..{ prin|tf(" dse|
|00005d60| 70 20 22 29 3b 20 7d 0a | 09 09 7c 20 64 61 74 61 |p "); }.|..| data|
|00005d70| 5f 6c 73 74 20 27 2c 27 | 20 73 65 78 70 72 0a 09 |_lst ','| sexpr..|
|00005d80| 09 09 7b 20 70 72 69 6e | 74 66 28 22 20 64 73 65 |..{ prin|tf(" dse|
|00005d90| 70 20 22 29 3b 20 7d 0a | 09 09 3b 0a 0a 69 6e 64 |p "); }.|..;..ind|
|00005da0| 5f 6c 73 74 09 09 3a 20 | 72 65 78 70 72 0a 09 09 |_lst..: |rexpr...|
|00005db0| 7c 20 69 6e 64 5f 6c 73 | 74 20 27 2c 27 20 72 65 || ind_ls|t ',' re|
|00005dc0| 78 70 72 0a 09 09 3b 0a | 0a 66 6f 72 5f 73 74 65 |xpr...;.|.for_ste|
|00005dd0| 70 09 3a 20 2f 2a 20 65 | 6d 70 74 79 20 2a 2f 0a |p.: /* e|mpty */.|
|00005de0| 09 09 09 7b 20 70 72 69 | 6e 74 66 28 22 20 69 63 |...{ pri|ntf(" ic|
|00005df0| 6f 6e 20 30 20 22 29 3b | 20 7d 0a 09 09 7c 20 53 |on 0 ");| }...| S|
|00005e00| 54 45 50 20 72 65 78 70 | 72 0a 09 09 3b 0a 0a 69 |TEP rexp|r...;..i|
|00005e10| 66 5f 65 6c 73 65 09 09 | 3a 20 2f 2a 20 65 6d 70 |f_else..|: /* emp|
|00005e20| 74 79 20 2a 2f 0a 09 09 | 09 7b 0a 09 09 09 09 69 |ty */...|.{.....i|
|00005e30| 20 3d 20 6c 70 6f 70 28 | 26 69 66 73 74 6b 29 3b | = lpop(|&ifstk);|
|00005e40| 0a 09 09 09 09 70 72 69 | 6e 74 66 28 22 20 64 6c |.....pri|ntf(" dl|
|00005e50| 61 62 65 6c 20 49 46 25 | 64 20 64 6c 61 62 65 6c |abel IF%|d dlabel|
|00005e60| 20 49 46 25 64 20 22 2c | 69 2c 69 2b 31 29 3b 0a | IF%d ",|i,i+1);.|
|00005e70| 09 09 09 7d 0a 09 09 7c | 20 45 4c 53 45 20 7b 20 |...}...|| ELSE { |
|00005e80| 69 3d 6c 74 6f 70 28 26 | 69 66 73 74 6b 29 3b 20 |i=ltop(&|ifstk); |
|00005e90| 70 72 69 6e 74 66 28 22 | 20 64 6c 61 62 65 6c 20 |printf("| dlabel |
|00005ea0| 49 46 25 64 20 22 2c 69 | 29 3b 20 7d 20 73 74 61 |IF%d ",i|); } sta|
|00005eb0| 74 0a 09 09 09 7b 20 69 | 3d 6c 70 6f 70 28 26 69 |t....{ i|=lpop(&i|
|00005ec0| 66 73 74 6b 29 3b 20 70 | 72 69 6e 74 66 28 22 20 |fstk); p|rintf(" |
|00005ed0| 64 6c 61 62 65 6c 20 49 | 46 25 64 20 22 2c 69 2b |dlabel I|F%d ",i+|
|00005ee0| 31 29 3b 20 7d 0a 09 09 | 3b 0a 0a 0a 70 65 09 09 |1); }...|;...pe..|
|00005ef0| 3a 20 73 65 78 70 72 20 | 27 2c 27 0a 09 09 09 7b |: sexpr |','....{|
|00005f00| 20 70 72 69 6e 74 66 28 | 22 20 73 63 6f 6e 20 5c | printf(|" scon \|
|00005f10| 22 5c 22 20 2c 20 22 29 | 3b 20 7d 0a 09 09 7c 20 |"\" , ")|; }...| |
|00005f20| 73 65 78 70 72 20 27 3b | 27 0a 09 09 7c 20 73 65 |sexpr ';|'...| se|
|00005f30| 78 70 72 0a 09 09 09 7b | 20 70 72 69 6e 74 66 28 |xpr....{| printf(|
|00005f40| 22 20 73 63 6f 6e 20 5c | 22 5c 5c 6e 5c 22 20 3b |" scon \|"\\n\" ;|
|00005f50| 20 22 29 3b 20 7d 0a 09 | 09 7c 20 2f 2a 20 65 6d | "); }..|.| /* em|
|00005f60| 70 74 79 20 2a 2f 0a 09 | 09 09 7b 20 70 72 69 6e |pty */..|..{ prin|
|00005f70| 74 66 28 22 20 73 63 6f | 6e 20 5c 22 5c 5c 6e 5c |tf(" sco|n \"\\n\|
|00005f80| 22 20 22 29 3b 20 7d 0a | 09 09 3b 0a 0a 0a 76 61 |" "); }.|..;...va|
|00005f90| 72 5f 6c 73 74 09 09 3a | 20 69 76 61 72 0a 09 09 |r_lst..:| ivar...|
|00005fa0| 7c 20 72 76 61 72 0a 09 | 09 7c 20 73 76 61 72 0a || rvar..|.| svar.|
|00005fb0| 09 09 7c 20 76 61 72 5f | 6c 73 74 20 27 2c 27 20 |..| var_|lst ',' |
|00005fc0| 76 61 72 5f 6c 73 74 0a | 09 09 3b 0a 0a 73 65 78 |var_lst.|..;..sex|
|00005fd0| 70 72 09 09 3a 20 53 43 | 4f 4e 53 54 0a 09 09 09 |pr..: SC|ONST....|
|00005fe0| 7b 20 70 72 69 6e 74 66 | 28 22 20 73 63 6f 6e 20 |{ printf|(" scon |
|00005ff0| 5c 22 25 73 5c 22 20 22 | 2c 24 31 29 3b 20 7d 0a |\"%s\" "|,$1); }.|
|00006000| 09 09 7c 20 73 76 61 72 | 0a 09 09 09 7b 20 70 72 |..| svar|....{ pr|
|00006010| 69 6e 74 66 28 22 20 76 | 61 6c 20 25 64 20 22 2c |intf(" v|al %d ",|
|00006020| 54 5f 43 48 52 29 3b 20 | 7d 0a 09 09 7c 20 72 65 |T_CHR); |}...| re|
|00006030| 78 70 72 0a 09 09 09 7b | 20 70 72 69 6e 74 66 28 |xpr....{| printf(|
|00006040| 22 20 72 74 6f 61 20 22 | 29 3b 20 7d 0a 09 09 7c |" rtoa "|); }...||
|00006050| 20 73 76 61 72 20 27 3d | 27 20 73 65 78 70 72 0a | svar '=|' sexpr.|
|00006060| 09 09 09 7b 20 70 72 69 | 6e 74 66 28 22 20 73 74 |...{ pri|ntf(" st|
|00006070| 6f 72 65 20 25 64 20 22 | 2c 54 5f 43 48 52 29 3b |ore %d "|,T_CHR);|
|00006080| 20 7d 0a 09 09 7c 20 73 | 65 78 70 72 20 27 3b 27 | }...| s|expr ';'|
|00006090| 20 73 65 78 70 72 0a 09 | 09 09 7b 20 70 72 69 6e | sexpr..|..{ prin|
|000060a0| 74 66 28 22 20 3b 20 22 | 29 3b 20 7d 0a 09 09 7c |tf(" ; "|); }...||
|000060b0| 20 73 65 78 70 72 20 27 | 2b 27 20 73 65 78 70 72 | sexpr '|+' sexpr|
|000060c0| 0a 09 09 09 7b 20 70 72 | 69 6e 74 66 28 22 20 3b |....{ pr|intf(" ;|
|000060d0| 20 22 29 3b 20 7d 0a 09 | 09 7c 20 73 65 78 70 72 | "); }..|.| sexpr|
|000060e0| 20 27 2c 27 20 73 65 78 | 70 72 0a 09 09 09 7b 20 | ',' sex|pr....{ |
|000060f0| 70 72 69 6e 74 66 28 22 | 20 2c 20 22 29 3b 20 7d |printf("| , "); }|
|00006100| 0a 09 09 7c 20 27 28 27 | 20 73 65 78 70 72 20 27 |...| '('| sexpr '|
|00006110| 29 27 0a 09 09 3b 0a 73 | 62 65 09 09 3a 20 73 65 |)'...;.s|be..: se|
|00006120| 78 70 72 20 45 51 55 41 | 4c 20 73 65 78 70 72 0a |xpr EQUA|L sexpr.|
|00006130| 09 09 09 7b 20 70 72 69 | 6e 74 66 28 22 20 73 3d |...{ pri|ntf(" s=|
|00006140| 3d 20 22 29 3b 20 7d 0a | 09 09 7c 20 73 65 78 70 |= "); }.|..| sexp|
|00006150| 72 20 4e 45 51 20 73 65 | 78 70 72 0a 09 09 09 7b |r NEQ se|xpr....{|
|00006160| 20 70 72 69 6e 74 66 28 | 22 20 73 3c 3e 20 22 29 | printf(|" s<> ")|
|00006170| 3b 20 7d 0a 09 09 7c 20 | 73 65 78 70 72 20 4c 45 |; }...| |sexpr LE|
|00006180| 20 73 65 78 70 72 0a 09 | 09 09 7b 20 70 72 69 6e | sexpr..|..{ prin|
|00006190| 74 66 28 22 20 73 3c 3d | 20 22 29 3b 20 7d 0a 09 |tf(" s<=| "); }..|
|000061a0| 09 7c 20 73 65 78 70 72 | 20 4c 54 20 73 65 78 70 |.| sexpr| LT sexp|
|000061b0| 72 0a 09 09 09 7b 20 70 | 72 69 6e 74 66 28 22 20 |r....{ p|rintf(" |
|000061c0| 73 3c 20 22 29 3b 20 7d | 0a 09 09 7c 20 73 65 78 |s< "); }|...| sex|
|000061d0| 70 72 20 47 45 20 73 65 | 78 70 72 0a 09 09 09 7b |pr GE se|xpr....{|
|000061e0| 20 70 72 69 6e 74 66 28 | 22 20 73 3e 3d 20 22 29 | printf(|" s>= ")|
|000061f0| 3b 20 7d 0a 09 09 7c 20 | 73 65 78 70 72 20 47 54 |; }...| |sexpr GT|
|00006200| 20 73 65 78 70 72 0a 09 | 09 09 7b 20 70 72 69 6e | sexpr..|..{ prin|
|00006210| 74 66 28 22 20 73 3e 20 | 22 29 3b 20 7d 0a 09 09 |tf(" s> |"); }...|
|00006220| 3b 0a 0a 69 76 61 72 09 | 09 3a 20 49 57 4f 52 44 |;..ivar.|.: IWORD|
|00006230| 0a 09 09 09 7b 20 70 72 | 69 6e 74 66 28 22 20 76 |....{ pr|intf(" v|
|00006240| 61 72 20 25 64 20 25 73 | 20 22 2c 54 5f 49 4e 54 |ar %d %s| ",T_INT|
|00006250| 2c 24 31 29 3b 20 7d 0a | 09 09 7c 20 49 57 4f 52 |,$1); }.|..| IWOR|
|00006260| 44 20 27 28 27 20 7b 70 | 72 69 6e 74 66 28 22 20 |D '(' {p|rintf(" |
|00006270| 70 75 73 68 73 74 61 74 | 65 20 25 64 20 22 2c 4d |pushstat|e %d ",M|
|00006280| 5f 45 58 45 43 55 54 45 | 29 3b 20 7d 20 69 6e 64 |_EXECUTE|); } ind|
|00006290| 5f 6c 73 74 20 27 29 27 | 0a 09 09 09 7b 20 70 72 |_lst ')'|....{ pr|
|000062a0| 69 6e 74 66 28 22 20 70 | 6f 70 73 74 61 74 65 20 |intf(" p|opstate |
|000062b0| 76 61 72 20 25 64 20 25 | 73 20 22 2c 54 5f 49 4e |var %d %|s ",T_IN|
|000062c0| 54 2b 51 5f 41 52 59 2c | 24 31 29 3b 20 7d 0a 09 |T+Q_ARY,|$1); }..|
|000062d0| 09 3b 0a 72 76 61 72 09 | 09 3a 20 52 57 4f 52 44 |.;.rvar.|.: RWORD|
|000062e0| 0a 09 09 09 7b 20 70 72 | 69 6e 74 66 28 22 20 76 |....{ pr|intf(" v|
|000062f0| 61 72 20 25 64 20 25 73 | 20 22 2c 54 5f 44 42 4c |ar %d %s| ",T_DBL|
|00006300| 2c 24 31 29 3b 20 7d 0a | 09 09 7c 20 52 57 4f 52 |,$1); }.|..| RWOR|
|00006310| 44 20 27 28 27 20 7b 20 | 70 72 69 6e 74 66 28 22 |D '(' { |printf("|
|00006320| 20 70 75 73 68 73 74 61 | 74 65 20 25 64 20 22 2c | pushsta|te %d ",|
|00006330| 4d 5f 45 58 45 43 55 54 | 45 29 3b 20 7d 20 69 6e |M_EXECUT|E); } in|
|00006340| 64 5f 6c 73 74 20 27 29 | 27 0a 09 09 09 7b 20 70 |d_lst ')|'....{ p|
|00006350| 72 69 6e 74 66 28 22 20 | 70 6f 70 73 74 61 74 65 |rintf(" |popstate|
|00006360| 20 76 61 72 20 25 64 20 | 25 73 20 22 2c 54 5f 44 | var %d |%s ",T_D|
|00006370| 42 4c 2b 51 5f 41 52 59 | 2c 24 31 29 3b 20 7d 0a |BL+Q_ARY|,$1); }.|
|00006380| 09 09 3b 0a 0a 73 76 61 | 72 09 09 3a 20 53 57 4f |..;..sva|r..: SWO|
|00006390| 52 44 0a 09 09 09 7b 20 | 70 72 69 6e 74 66 28 22 |RD....{ |printf("|
|000063a0| 20 76 61 72 20 25 64 20 | 25 73 20 22 2c 54 5f 43 | var %d |%s ",T_C|
|000063b0| 48 52 2c 24 31 29 3b 20 | 7d 0a 09 09 7c 20 53 57 |HR,$1); |}...| SW|
|000063c0| 4f 52 44 20 27 28 27 20 | 7b 20 70 72 69 6e 74 66 |ORD '(' |{ printf|
|000063d0| 28 22 20 70 75 73 68 73 | 74 61 74 65 20 25 64 20 |(" pushs|tate %d |
|000063e0| 22 2c 4d 5f 45 58 45 43 | 55 54 45 29 3b 20 7d 20 |",M_EXEC|UTE); } |
|000063f0| 69 6e 64 5f 6c 73 74 20 | 27 29 27 0a 09 09 09 7b |ind_lst |')'....{|
+--------+-------------------------+-------------------------+--------+--------+
Only 25.0 KB of data is shown above.