home *** CD-ROM | disk | FTP | other *** search
open in:
MacOS 8.1
|
Win98
|
DOS
view JSON data
|
view as text
This file was processed as: SHell self-extracting ARchive
(archive/shar).
You can browse this item here: tile.3
Confidence | Program | Detection | Match Type | Support
|
---|
100%
| dexvert
| SHell self-extracting ARchive (archive/shar)
| magic
| Supported |
1%
| dexvert
| Text File (text/txt)
| fallback
| Supported |
100%
| file
| 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
| application/x-shellscript
| default (weak)
|
|
hex view+--------+-------------------------+-------------------------+--------+--------+
|00000000| 0a 23 21 20 2f 62 69 6e | 2f 73 68 0a 23 20 54 68 |.#! /bin|/sh.# Th|
|00000010| 69 73 20 69 73 20 61 20 | 73 68 65 6c 6c 20 61 72 |is is a |shell ar|
|00000020| 63 68 69 76 65 2e 20 20 | 52 65 6d 6f 76 65 20 61 |chive. |Remove a|
|00000030| 6e 79 74 68 69 6e 67 20 | 62 65 66 6f 72 65 20 74 |nything |before t|
|00000040| 68 69 73 20 6c 69 6e 65 | 2c 20 74 68 65 6e 20 75 |his line|, then u|
|00000050| 6e 70 61 63 6b 0a 23 20 | 69 74 20 62 79 20 73 61 |npack.# |it by sa|
|00000060| 76 69 6e 67 20 69 74 20 | 69 6e 74 6f 20 61 20 66 |ving it |into a f|
|00000070| 69 6c 65 20 61 6e 64 20 | 74 79 70 69 6e 67 20 22 |ile and |typing "|
|00000080| 73 68 20 66 69 6c 65 22 | 2e 20 20 54 6f 20 6f 76 |sh file"|. To ov|
|00000090| 65 72 77 72 69 74 65 20 | 65 78 69 73 74 69 6e 67 |erwrite |existing|
|000000a0| 0a 23 20 66 69 6c 65 73 | 2c 20 74 79 70 65 20 22 |.# files|, type "|
|000000b0| 73 68 20 66 69 6c 65 20 | 2d 63 22 2e 20 20 59 6f |sh file |-c". Yo|
|000000c0| 75 20 63 61 6e 20 61 6c | 73 6f 20 66 65 65 64 20 |u can al|so feed |
|000000d0| 74 68 69 73 20 61 73 20 | 73 74 61 6e 64 61 72 64 |this as |standard|
|000000e0| 20 69 6e 70 75 74 20 76 | 69 61 0a 23 20 75 6e 73 | input v|ia.# uns|
|000000f0| 68 61 72 2c 20 6f 72 20 | 62 79 20 74 79 70 69 6e |har, or |by typin|
|00000100| 67 20 22 73 68 20 3c 66 | 69 6c 65 22 2c 20 65 2e |g "sh <f|ile", e.|
|00000110| 67 2e 2e 20 20 49 66 20 | 74 68 69 73 20 61 72 63 |g.. If |this arc|
|00000120| 68 69 76 65 20 69 73 20 | 63 6f 6d 70 6c 65 74 65 |hive is |complete|
|00000130| 2c 20 79 6f 75 0a 23 20 | 77 69 6c 6c 20 73 65 65 |, you.# |will see|
|00000140| 20 74 68 65 20 66 6f 6c | 6c 6f 77 69 6e 67 20 6d | the fol|lowing m|
|00000150| 65 73 73 61 67 65 20 61 | 74 20 74 68 65 20 65 6e |essage a|t the en|
|00000160| 64 3a 0a 23 09 09 22 45 | 6e 64 20 6f 66 20 61 72 |d:.#.."E|nd of ar|
|00000170| 63 68 69 76 65 20 33 20 | 28 6f 66 20 36 29 2e 22 |chive 3 |(of 6)."|
|00000180| 0a 23 20 43 6f 6e 74 65 | 6e 74 73 3a 20 20 50 4f |.# Conte|nts: PO|
|00000190| 52 54 49 4e 47 20 6c 69 | 62 2f 64 65 62 75 67 67 |RTING li|b/debugg|
|000001a0| 65 72 2e 66 38 33 20 6c | 69 62 2f 69 6e 74 65 72 |er.f83 l|ib/inter|
|000001b0| 6e 61 6c 73 2e 66 38 33 | 20 6c 69 62 2f 71 75 65 |nals.f83| lib/que|
|000001c0| 75 65 73 2e 66 38 33 0a | 23 20 20 20 6c 69 62 2f |ues.f83.|# lib/|
|000001d0| 73 74 72 75 63 74 75 72 | 65 73 2e 66 38 33 20 73 |structur|es.f83 s|
|000001e0| 72 63 2f 63 6f 6d 70 69 | 6c 65 72 2e 76 20 73 72 |rc/compi|ler.v sr|
|000001f0| 63 2f 65 72 72 6f 72 2e | 63 20 73 72 63 2f 66 6f |c/error.|c src/fo|
|00000200| 72 74 68 2e 63 0a 23 20 | 20 20 73 72 63 2f 6c 6f |rth.c.# | src/lo|
|00000210| 63 61 6c 73 2e 76 20 73 | 72 63 2f 6d 75 6c 74 69 |cals.v s|rc/multi|
|00000220| 2d 74 61 73 6b 69 6e 67 | 2e 76 0a 23 20 57 72 61 |-tasking|.v.# Wra|
|00000230| 70 70 65 64 20 62 79 20 | 6d 69 70 40 6d 69 6e 61 |pped by |mip@mina|
|00000240| 20 6f 6e 20 46 72 69 20 | 4a 75 6e 20 32 39 20 31 | on Fri |Jun 29 1|
|00000250| 36 3a 34 39 3a 30 39 20 | 31 39 39 30 0a 50 41 54 |6:49:09 |1990.PAT|
|00000260| 48 3d 2f 62 69 6e 3a 2f | 75 73 72 2f 62 69 6e 3a |H=/bin:/|usr/bin:|
|00000270| 2f 75 73 72 2f 75 63 62 | 20 3b 20 65 78 70 6f 72 |/usr/ucb| ; expor|
|00000280| 74 20 50 41 54 48 0a 69 | 66 20 74 65 73 74 20 2d |t PATH.i|f test -|
|00000290| 66 20 50 4f 52 54 49 4e | 47 20 2d 61 20 22 24 7b |f PORTIN|G -a "${|
|000002a0| 31 7d 22 20 21 3d 20 22 | 2d 63 22 20 3b 20 74 68 |1}" != "|-c" ; th|
|000002b0| 65 6e 20 0a 20 20 65 63 | 68 6f 20 73 68 61 72 3a |en . ec|ho shar:|
|000002c0| 20 57 69 6c 6c 20 6e 6f | 74 20 6f 76 65 72 2d 77 | Will no|t over-w|
|000002d0| 72 69 74 65 20 65 78 69 | 73 74 69 6e 67 20 66 69 |rite exi|sting fi|
|000002e0| 6c 65 20 5c 22 50 4f 52 | 54 49 4e 47 5c 22 0a 65 |le \"POR|TING\".e|
|000002f0| 6c 73 65 0a 65 63 68 6f | 20 73 68 61 72 3a 20 45 |lse.echo| shar: E|
|00000300| 78 74 72 61 63 74 69 6e | 67 20 5c 22 50 4f 52 54 |xtractin|g \"PORT|
|00000310| 49 4e 47 5c 22 20 5c 28 | 36 32 33 32 20 63 68 61 |ING\" \(|6232 cha|
|00000320| 72 61 63 74 65 72 73 5c | 29 0a 73 65 64 20 22 73 |racters\|).sed "s|
|00000330| 2f 5e 58 2f 2f 22 20 3e | 50 4f 52 54 49 4e 47 20 |/^X//" >|PORTING |
|00000340| 3c 3c 27 45 4e 44 5f 4f | 46 5f 50 4f 52 54 49 4e |<<'END_O|F_PORTIN|
|00000350| 47 27 0a 58 54 48 52 45 | 41 44 45 44 20 49 4e 54 |G'.XTHRE|ADED INT|
|00000360| 45 52 50 52 45 54 49 56 | 45 20 4c 41 4e 47 55 41 |ERPRETIV|E LANGUA|
|00000370| 47 45 20 45 4e 56 49 52 | 4f 4e 4d 45 4e 54 20 28 |GE ENVIR|ONMENT (|
|00000380| 54 49 4c 45 29 20 50 4f | 52 54 49 4e 47 20 5b 52 |TILE) PO|RTING [R|
|00000390| 45 4c 45 41 53 45 20 32 | 2e 30 5d 0a 58 0a 58 4a |ELEASE 2|.0].X.XJ|
|000003a0| 75 6e 65 20 32 38 2c 20 | 31 39 39 30 0a 58 0a 58 |une 28, |1990.X.X|
|000003b0| 4d 69 6b 61 65 6c 20 52 | 2e 4b 2e 20 50 61 74 65 |Mikael R|.K. Pate|
|000003c0| 6c 0a 58 43 6f 6d 70 75 | 74 65 72 20 41 69 64 65 |l.XCompu|ter Aide|
|000003d0| 64 20 44 65 73 69 67 6e | 20 4c 61 62 6f 72 61 74 |d Design| Laborat|
|000003e0| 6f 72 79 20 28 43 41 44 | 4c 41 42 29 0a 58 44 65 |ory (CAD|LAB).XDe|
|000003f0| 70 61 72 74 6d 65 6e 74 | 20 6f 66 20 43 6f 6d 70 |partment| of Comp|
|00000400| 75 74 65 72 20 61 6e 64 | 20 49 6e 66 6f 72 6d 61 |uter and| Informa|
|00000410| 74 69 6f 6e 20 53 63 69 | 65 6e 63 65 0a 58 4c 69 |tion Sci|ence.XLi|
|00000420| 6e 6b 6f 70 69 6e 67 20 | 55 6e 69 76 65 72 73 69 |nkoping |Universi|
|00000430| 74 79 0a 58 53 2d 35 38 | 31 20 38 33 20 4c 49 4e |ty.XS-58|1 83 LIN|
|00000440| 4b 4f 50 49 4e 47 0a 58 | 53 57 45 44 45 4e 0a 58 |KOPING.X|SWEDEN.X|
|00000450| 45 6d 61 69 6c 3a 20 6d | 69 70 40 69 64 61 2e 6c |Email: m|ip@ida.l|
|00000460| 69 75 2e 73 65 0a 58 0a | 58 0a 58 49 4e 54 52 4f |iu.se.X.|X.XINTRO|
|00000470| 44 55 43 54 49 4f 4e 0a | 58 0a 58 54 68 69 73 20 |DUCTION.|X.XThis |
|00000480| 62 72 69 65 66 20 64 6f | 63 75 6d 65 6e 74 20 64 |brief do|cument d|
|00000490| 65 73 63 72 69 62 65 73 | 20 73 6f 6d 65 20 74 6f |escribes| some to|
|000004a0| 20 74 68 65 20 73 65 63 | 74 69 6f 6e 20 69 6e 20 | the sec|tion in |
|000004b0| 74 68 65 20 74 69 6c 65 | 20 66 6f 72 74 68 0a 58 |the tile| forth.X|
|000004c0| 6b 65 72 6e 65 6c 20 77 | 68 69 63 68 20 6d 61 79 |kernel w|hich may|
|000004d0| 20 68 61 76 65 20 74 6f | 20 62 65 20 63 68 61 6e | have to| be chan|
|000004e0| 67 65 64 20 74 6f 20 70 | 6f 72 74 20 74 68 65 20 |ged to p|ort the |
|000004f0| 63 6f 64 65 20 74 6f 20 | 6f 74 68 65 72 20 6d 61 |code to |other ma|
|00000500| 63 68 69 6e 65 73 2e 0a | 58 41 6e 79 20 63 68 61 |chines..|XAny cha|
|00000510| 6e 67 65 73 20 6d 61 64 | 65 20 73 68 6f 75 6c 64 |nges mad|e should|
|00000520| 20 62 65 20 6d 61 64 65 | 20 69 6e 20 61 20 22 23 | be made| in a "#|
|00000530| 69 66 64 65 66 22 20 73 | 65 63 74 69 6f 6e 20 61 |ifdef" s|ection a|
|00000540| 6e 64 20 72 65 70 6f 72 | 74 65 64 2e 0a 58 0a 58 |nd repor|ted..X.X|
|00000550| 0a 58 31 2e 20 4b 45 52 | 4e 45 4c 20 44 45 46 49 |.X1. KER|NEL DEFI|
|00000560| 4e 49 54 49 4f 4e 53 0a | 58 0a 58 31 2e 31 09 56 |NITIONS.|X.X1.1.V|
|00000570| 6f 63 61 62 75 6c 61 72 | 79 20 6c 69 73 74 69 6e |ocabular|y listin|
|00000580| 67 20 70 61 72 61 6d 65 | 74 65 72 73 20 28 46 69 |g parame|ters (Fi|
|00000590| 6c 65 3a 20 6b 65 72 6e | 65 6c 2e 63 29 0a 58 0a |le: kern|el.c).X.|
|000005a0| 58 54 68 65 20 63 6f 6c | 75 6d 6e 20 61 6e 64 20 |XThe col|umn and |
|000005b0| 6c 69 6e 65 20 77 69 64 | 74 68 20 75 73 65 64 20 |line wid|th used |
|000005c0| 62 79 20 22 77 6f 72 64 | 73 22 20 6d 61 79 20 62 |by "word|s" may b|
|000005d0| 65 20 61 6c 74 65 72 65 | 64 20 62 79 20 63 68 61 |e altere|d by cha|
|000005e0| 6e 67 69 6e 67 0a 58 74 | 68 65 20 6c 69 6e 65 73 |nging.Xt|he lines|
|000005f0| 3a 0a 58 0a 58 23 64 65 | 66 69 6e 65 20 43 4f 4c |:.X.X#de|fine COL|
|00000600| 55 4d 4e 57 49 44 54 48 | 20 31 35 0a 58 23 64 65 |UMNWIDTH| 15.X#de|
|00000610| 66 69 6e 65 20 4c 49 4e | 45 57 49 44 54 48 20 37 |fine LIN|EWIDTH 7|
|00000620| 35 0a 58 0a 58 0a 58 31 | 2e 32 09 53 65 74 20 6f |5.X.X.X1|.2.Set o|
|00000630| 66 20 73 65 61 72 63 68 | 20 76 6f 63 61 62 75 6c |f search| vocabul|
|00000640| 61 72 69 65 73 20 28 46 | 69 6c 65 3a 20 6b 65 72 |aries (F|ile: ker|
|00000650| 6e 65 6c 2e 63 29 0a 58 | 0a 58 54 68 65 20 73 65 |nel.c).X|.XThe se|
|00000660| 74 20 6f 66 20 73 65 61 | 72 63 68 20 76 6f 63 61 |t of sea|rch voca|
|00000670| 62 75 6c 61 72 69 65 73 | 2c 20 22 63 6f 6e 74 65 |bularies|, "conte|
|00000680| 78 74 22 2c 20 69 73 20 | 72 65 61 6c 69 7a 65 64 |xt", is |realized|
|00000690| 20 61 73 20 61 20 76 65 | 63 74 6f 72 2e 0a 58 54 | as a ve|ctor..XT|
|000006a0| 68 65 20 6d 61 78 69 6d | 75 6d 20 6e 75 6d 62 65 |he maxim|um numbe|
|000006b0| 72 20 6f 66 20 76 6f 63 | 61 62 75 6c 61 72 69 65 |r of voc|abularie|
|000006c0| 73 20 69 6e 20 69 73 20 | 64 65 66 69 6e 65 64 20 |s in is |defined |
|000006d0| 62 79 3a 0a 58 0a 58 23 | 64 65 66 69 6e 65 20 43 |by:.X.X#|define C|
|000006e0| 4f 4e 54 45 58 54 53 49 | 5a 45 20 36 34 0a 58 0a |ONTEXTSI|ZE 64.X.|
|000006f0| 58 41 6e 20 65 72 72 6f | 72 20 77 69 6c 6c 20 6f |XAn erro|r will o|
|00000700| 63 63 75 72 20 69 74 20 | 74 68 65 20 73 65 74 20 |ccur it |the set |
|00000710| 69 73 20 66 69 6c 6c 65 | 64 2e 20 4e 6f 20 63 68 |is fille|d. No ch|
|00000720| 65 63 6b 69 6e 67 20 69 | 73 20 63 75 72 72 65 6e |ecking i|s curren|
|00000730| 74 6c 79 20 0a 58 70 65 | 72 66 6f 72 6d 65 64 2e |tly .Xpe|rformed.|
|00000740| 0a 58 0a 58 0a 58 31 2e | 33 09 4c 6f 6f 6b 75 70 |.X.X.X1.|3.Lookup|
|00000750| 20 63 61 63 68 65 20 28 | 46 69 6c 65 3a 20 6b 65 | cache (|File: ke|
|00000760| 72 6e 65 6c 2e 63 29 0a | 58 0a 58 54 68 65 20 6c |rnel.c).|X.XThe l|
|00000770| 6f 6f 6b 75 70 20 66 75 | 6e 63 74 69 6f 6e 20 69 |ookup fu|nction i|
|00000780| 6e 20 74 68 65 20 6b 65 | 72 6e 65 6c 20 69 73 20 |n the ke|rnel is |
|00000790| 73 75 70 70 6f 72 74 65 | 64 20 62 79 20 61 20 73 |supporte|d by a s|
|000007a0| 69 6d 70 6c 65 20 63 61 | 63 68 65 2e 0a 58 41 20 |imple ca|che..XA |
|000007b0| 68 61 73 68 20 66 75 6e | 63 74 69 6f 6e 20 28 73 |hash fun|ction (s|
|000007c0| 65 65 20 62 65 6c 6f 77 | 29 20 69 73 20 75 73 65 |ee below|) is use|
|000007d0| 64 20 74 6f 20 6d 61 70 | 20 61 20 73 74 72 69 6e |d to map| a strin|
|000007e0| 67 20 69 6e 74 6f 20 74 | 68 65 20 63 61 63 68 65 |g into t|he cache|
|000007f0| 0a 58 61 6e 64 20 74 68 | 65 72 65 2c 20 69 66 20 |.Xand th|ere, if |
|00000800| 70 6f 73 73 69 62 6c 65 | 2c 20 66 69 6e 64 20 74 |possible|, find t|
|00000810| 68 65 20 65 6e 74 72 79 | 2e 20 54 68 65 20 73 69 |he entry|. The si|
|00000820| 7a 65 20 6f 66 20 74 68 | 65 20 63 61 63 68 65 0a |ze of th|e cache.|
|00000830| 58 69 73 20 67 69 76 65 | 6e 20 62 79 3a 0a 58 0a |Xis give|n by:.X.|
|00000840| 58 23 64 65 66 69 6e 65 | 20 43 41 43 48 45 53 49 |X#define| CACHESI|
|00000850| 5a 45 20 32 35 36 0a 58 | 23 64 65 66 69 6e 65 20 |ZE 256.X|#define |
|00000860| 68 61 73 68 28 73 29 20 | 28 28 73 5b 30 5d 20 2b |hash(s) |((s[0] +|
|00000870| 20 28 73 5b 31 5d 20 3c | 3c 20 34 29 29 20 26 20 | (s[1] <|< 4)) & |
|00000880| 28 43 41 43 48 45 53 49 | 5a 45 20 2d 20 31 29 29 |(CACHESI|ZE - 1))|
|00000890| 0a 58 0a 58 54 68 65 20 | 68 61 73 68 20 66 75 6e |.X.XThe |hash fun|
|000008a0| 63 74 69 6f 6e 20 69 73 | 20 74 61 69 6c 6f 72 65 |ction is| tailore|
|000008b0| 64 20 66 6f 72 20 74 68 | 65 20 63 75 72 72 65 6e |d for th|e curren|
|000008c0| 74 20 63 61 63 68 65 20 | 73 69 7a 65 20 61 6e 64 |t cache |size and|
|000008d0| 20 74 68 75 73 0a 58 73 | 70 65 63 69 61 6c 20 63 | thus.Xs|pecial c|
|000008e0| 61 72 65 20 6d 75 73 74 | 20 62 65 20 74 61 6b 65 |are must| be take|
|000008f0| 6e 20 77 68 65 6e 20 61 | 6c 74 65 72 69 6e 67 20 |n when a|ltering |
|00000900| 74 68 65 73 65 2e 0a 58 | 0a 58 0a 58 31 2e 34 09 |these..X|.X.X1.4.|
|00000910| 49 6e 74 65 72 6e 61 6c | 20 73 74 72 75 63 74 75 |Internal| structu|
|00000920| 72 65 73 20 28 46 69 6c | 65 3a 20 6b 65 72 6e 65 |res (Fil|e: kerne|
|00000930| 6c 2e 63 29 0a 58 0a 58 | 54 68 65 20 22 70 61 64 |l.c).X.X|The "pad|
|00000940| 22 20 61 6e 64 20 74 68 | 65 20 22 74 69 62 22 20 |" and th|e "tib" |
|00000950| 6d 61 79 20 62 65 20 63 | 68 61 6e 67 65 64 20 62 |may be c|hanged b|
|00000960| 79 20 61 6c 74 65 72 69 | 6e 67 3a 0a 58 0a 58 23 |y alteri|ng:.X.X#|
|00000970| 64 65 66 69 6e 65 20 50 | 41 44 53 49 5a 45 20 38 |define P|ADSIZE 8|
|00000980| 34 0a 58 23 64 65 66 69 | 6e 65 20 54 49 42 53 49 |4.X#defi|ne TIBSI|
|00000990| 5a 45 20 32 35 36 0a 58 | 0a 58 0a 58 31 2e 35 09 |ZE 256.X|.X.X1.5.|
|000009a0| 57 6f 72 64 20 61 6c 69 | 67 6e 6d 65 6e 74 20 28 |Word ali|gnment (|
|000009b0| 46 69 6c 65 3a 20 6b 65 | 72 6e 65 6c 2e 68 29 0a |File: ke|rnel.h).|
|000009c0| 58 0a 58 41 6c 69 67 6e | 6d 65 6e 74 20 6f 66 20 |X.XAlign|ment of |
|000009d0| 74 68 72 65 61 64 65 64 | 20 63 6f 64 65 20 61 6e |threaded| code an|
|000009e0| 64 20 64 61 74 61 20 73 | 74 72 75 63 74 75 72 65 |d data s|tructure|
|000009f0| 73 20 61 72 65 20 70 65 | 72 66 6f 72 6d 65 64 20 |s are pe|rformed |
|00000a00| 62 79 20 74 68 65 0a 58 | 6d 61 63 72 6f 3a 0a 58 |by the.X|macro:.X|
|00000a10| 0a 58 23 64 65 66 69 6e | 65 20 61 6c 69 67 6e 28 |.X#defin|e align(|
|00000a20| 70 29 20 70 20 3d 20 28 | 50 54 52 33 32 29 20 28 |p) p = (|PTR32) (|
|00000a30| 28 49 4e 54 33 32 29 20 | 28 28 50 54 52 38 29 20 |(INT32) |((PTR8) |
|00000a40| 70 20 2b 20 33 29 20 26 | 20 2d 34 29 0a 58 0a 58 |p + 3) &| -4).X.X|
|00000a50| 54 68 69 73 20 6d 61 63 | 72 6f 20 63 75 72 72 65 |This mac|ro curre|
|00000a60| 6e 74 6c 79 20 61 6c 69 | 67 6e 73 20 74 6f 20 77 |ntly ali|gns to w|
|00000a70| 6f 72 64 20 28 6c 6f 6e | 67 29 20 62 6f 75 6e 64 |ord (lon|g) bound|
|00000a80| 61 72 69 65 73 20 61 6e | 64 20 69 73 20 75 73 65 |aries an|d is use|
|00000a90| 64 20 62 79 0a 58 22 63 | 6f 6c 6f 6e 22 20 61 6e |d by.X"c|olon" an|
|00000aa0| 64 20 22 63 72 65 61 74 | 65 22 2e 0a 58 0a 58 0a |d "creat|e"..X.X.|
|00000ab0| 58 31 2e 36 09 54 79 70 | 69 6e 67 20 73 79 73 74 |X1.6.Typ|ing syst|
|00000ac0| 65 6d 20 28 46 69 6c 65 | 3a 20 6b 65 72 6e 65 6c |em (File|: kernel|
|00000ad0| 2e 68 29 0a 58 0a 58 54 | 68 65 20 6b 65 72 6e 65 |.h).X.XT|he kerne|
|00000ae0| 6c 20 69 73 20 77 72 69 | 74 74 65 6e 20 69 6e 20 |l is wri|tten in |
|00000af0| 69 74 73 20 6f 77 6e 20 | 74 79 70 69 6e 67 20 73 |its own |typing s|
|00000b00| 79 73 74 65 6d 2e 20 54 | 68 65 20 74 79 70 69 6e |ystem. T|he typin|
|00000b10| 67 20 73 79 73 74 65 6d | 20 6d 61 79 0a 58 62 65 |g system| may.Xbe|
|00000b20| 20 65 78 74 65 6e 64 65 | 64 20 74 6f 20 61 6c 6c | extende|d to all|
|00000b30| 6f 77 20 6f 74 68 65 72 | 20 64 61 74 61 20 74 79 |ow other| data ty|
|00000b40| 70 65 73 20 65 74 63 2e | 20 41 6c 6c 20 74 79 70 |pes etc.| All typ|
|00000b50| 65 73 20 69 6e 20 74 68 | 65 20 6b 65 72 6e 65 6c |es in th|e kernel|
|00000b60| 0a 58 61 72 65 20 77 72 | 69 74 74 65 6e 20 77 69 |.Xare wr|itten wi|
|00000b70| 74 68 20 75 70 70 65 72 | 63 61 73 65 20 77 6f 72 |th upper|case wor|
|00000b80| 64 73 2e 0a 58 0a 58 23 | 64 65 66 69 6e 65 20 56 |ds..X.X#|define V|
|00000b90| 4f 49 44 20 76 6f 69 64 | 0a 58 0a 58 74 79 70 65 |OID void|.X.Xtype|
|00000ba0| 64 65 66 20 63 68 61 72 | 2a 20 20 50 54 52 38 3b |def char|* PTR8;|
|00000bb0| 0a 58 74 79 70 65 64 65 | 66 20 73 68 6f 72 74 2a |.Xtypede|f short*|
|00000bc0| 20 50 54 52 31 36 3b 0a | 58 74 79 70 65 64 65 66 | PTR16;.|Xtypedef|
|00000bd0| 20 6c 6f 6e 67 2a 20 20 | 50 54 52 33 32 3b 0a 58 | long* |PTR32;.X|
|00000be0| 0a 58 74 79 70 65 64 65 | 66 20 56 4f 49 44 20 28 |.Xtypede|f VOID (|
|00000bf0| 2a 53 55 42 52 29 28 29 | 3b 0a 58 0a 58 23 64 65 |*SUBR)()|;.X.X#de|
|00000c00| 66 69 6e 65 20 4e 49 4c | 20 30 0a 58 0a 58 74 79 |fine NIL| 0.X.Xty|
|00000c10| 70 65 64 65 66 20 6c 6f | 6e 67 20 42 4f 4f 4c 3b |pedef lo|ng BOOL;|
|00000c20| 0a 58 0a 58 23 64 65 66 | 69 6e 65 20 54 52 55 45 |.X.X#def|ine TRUE|
|00000c30| 20 20 28 28 42 4f 4f 4c | 29 20 2d 31 29 0a 58 23 | ((BOOL|) -1).X#|
|00000c40| 64 65 66 69 6e 65 20 46 | 41 4c 53 45 20 28 28 42 |define F|ALSE ((B|
|00000c50| 4f 4f 4c 29 20 20 30 29 | 0a 58 0a 58 74 79 70 65 |OOL) 0)|.X.Xtype|
|00000c60| 64 65 66 20 75 6e 73 69 | 67 6e 65 64 20 20 20 20 |def unsi|gned |
|00000c70| 20 20 20 4e 55 4d 3b 0a | 58 74 79 70 65 64 65 66 | NUM;.|Xtypedef|
|00000c80| 20 75 6e 73 69 67 6e 65 | 64 20 63 68 61 72 20 20 | unsigne|d char |
|00000c90| 4e 55 4d 38 3b 0a 58 74 | 79 70 65 64 65 66 20 75 |NUM8;.Xt|ypedef u|
|00000ca0| 6e 73 69 67 6e 65 64 20 | 73 68 6f 72 74 20 4e 55 |nsigned |short NU|
|00000cb0| 4d 31 36 3b 0a 58 74 79 | 70 65 64 65 66 20 75 6e |M16;.Xty|pedef un|
|00000cc0| 73 69 67 6e 65 64 20 6c | 6f 6e 67 20 20 4e 55 4d |signed l|ong NUM|
|00000cd0| 33 32 3b 0a 58 0a 58 74 | 79 70 65 64 65 66 20 69 |32;.X.Xt|ypedef i|
|00000ce0| 6e 74 20 20 20 49 4e 54 | 3b 0a 58 74 79 70 65 64 |nt INT|;.Xtyped|
|00000cf0| 65 66 20 63 68 61 72 20 | 20 49 4e 54 38 3b 0a 58 |ef char | INT8;.X|
|00000d00| 74 79 70 65 64 65 66 20 | 73 68 6f 72 74 20 49 4e |typedef |short IN|
|00000d10| 54 31 36 3b 0a 58 74 79 | 70 65 64 65 66 20 6c 6f |T16;.Xty|pedef lo|
|00000d20| 6e 67 20 20 49 4e 54 33 | 32 3b 0a 58 0a 58 74 79 |ng INT3|2;.X.Xty|
|00000d30| 70 65 64 65 66 20 66 6c | 6f 61 74 20 20 46 4c 4f |pedef fl|oat FLO|
|00000d40| 41 54 33 32 3b 0a 58 74 | 79 70 65 64 65 66 20 64 |AT32;.Xt|ypedef d|
|00000d50| 6f 75 62 6c 65 20 46 4c | 4f 41 54 36 34 3b 0a 58 |ouble FL|OAT64;.X|
|00000d60| 0a 58 74 79 70 65 64 65 | 66 20 63 68 61 72 20 20 |.Xtypede|f char |
|00000d70| 43 48 41 52 3b 0a 58 74 | 79 70 65 64 65 66 20 63 |CHAR;.Xt|ypedef c|
|00000d80| 68 61 72 2a 20 43 53 54 | 52 3b 0a 58 74 79 70 65 |har* CST|R;.Xtype|
|00000d90| 64 65 66 20 63 68 61 72 | 2a 20 50 53 54 52 3b 0a |def char|* PSTR;.|
|00000da0| 58 0a 58 74 79 70 65 64 | 65 66 20 75 6e 69 6f 6e |X.Xtyped|ef union|
|00000db0| 20 7b 0a 58 20 20 20 20 | 42 4f 4f 4c 20 20 20 20 | {.X |BOOL |
|00000dc0| 20 20 20 20 20 20 20 20 | 20 42 4f 4f 4c 3b 0a 58 | | BOOL;.X|
|00000dd0| 20 20 20 20 4e 55 4d 33 | 32 20 20 20 20 20 20 20 | NUM3|2 |
|00000de0| 20 20 20 20 20 4e 55 4d | 33 32 3b 0a 58 20 20 20 | NUM|32;.X |
|00000df0| 20 49 4e 54 33 32 20 20 | 20 20 20 20 20 20 20 20 | INT32 | |
|00000e00| 20 20 49 4e 54 33 32 3b | 0a 58 20 20 20 20 46 4c | INT32;|.X FL|
|00000e10| 4f 41 54 33 32 20 20 20 | 20 20 20 20 20 20 20 46 |OAT32 | F|
|00000e20| 4c 4f 41 54 33 32 3b 0a | 58 20 20 20 20 43 53 54 |LOAT32;.|X CST|
|00000e30| 52 20 20 20 20 20 20 20 | 20 20 20 20 20 20 43 53 |R | CS|
|00000e40| 54 52 3b 0a 58 20 20 20 | 20 50 54 52 38 20 20 20 |TR;.X | PTR8 |
|00000e50| 20 20 20 20 20 20 20 20 | 20 20 50 54 52 38 3b 0a | | PTR8;.|
|00000e60| 58 20 20 20 20 50 54 52 | 31 36 20 20 20 20 20 20 |X PTR|16 |
|00000e70| 20 20 20 20 20 20 50 54 | 52 31 36 3b 0a 58 20 20 | PT|R16;.X |
|00000e80| 20 20 50 54 52 33 32 20 | 20 20 20 20 20 20 20 20 | PTR32 | |
|00000e90| 20 20 20 50 54 52 33 32 | 3b 0a 58 20 20 20 20 53 | PTR32|;.X S|
|00000ea0| 55 42 52 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |UBR | |
|00000eb0| 53 55 42 52 3b 0a 58 20 | 20 20 20 51 55 45 55 45 |SUBR;.X | QUEUE|
|00000ec0| 20 20 20 20 20 20 20 20 | 20 20 20 20 51 55 45 55 | | QUEU|
|00000ed0| 45 3b 0a 58 20 20 20 20 | 54 41 53 4b 20 20 20 20 |E;.X |TASK |
|00000ee0| 20 20 20 20 20 20 20 20 | 20 54 41 53 4b 3b 0a 58 | | TASK;.X|
|00000ef0| 20 20 20 20 45 4e 54 52 | 59 20 20 20 20 20 20 20 | ENTR|Y |
|00000f00| 20 20 20 20 20 45 4e 54 | 52 59 3b 0a 58 20 20 20 | ENT|RY;.X |
|00000f10| 20 43 4f 44 45 5f 45 4e | 54 52 59 20 20 20 20 20 | CODE_EN|TRY |
|00000f20| 20 20 43 4f 44 45 5f 45 | 4e 54 52 59 3b 0a 58 20 | CODE_E|NTRY;.X |
|00000f30| 20 20 20 56 4f 43 41 42 | 55 4c 41 52 59 5f 45 4e | VOCAB|ULARY_EN|
|00000f40| 54 52 59 20 56 4f 43 41 | 42 55 4c 41 52 59 5f 45 |TRY VOCA|BULARY_E|
|00000f50| 4e 54 52 59 3b 0a 58 7d | 20 55 4e 49 56 2c 20 2a |NTRY;.X}| UNIV, *|
|00000f60| 50 54 52 3b 0a 58 0a 58 | 0a 58 31 2e 37 09 49 6e |PTR;.X.X|.X1.7.In|
|00000f70| 69 74 69 61 6c 69 7a 61 | 74 69 6f 6e 20 6f 66 20 |itializa|tion of |
|00000f80| 74 68 65 20 6b 65 72 6e | 65 6c 20 28 46 69 6c 65 |the kern|el (File|
|00000f90| 3a 20 6b 65 72 6e 65 6c | 2e 63 29 0a 58 0a 58 54 |: kernel|.c).X.XT|
|00000fa0| 68 65 20 69 6e 69 74 69 | 61 6c 69 7a 61 74 69 6f |he initi|alizatio|
|00000fb0| 6e 20 66 75 6e 63 74 69 | 6f 6e 20 66 6f 72 20 74 |n functi|on for t|
|00000fc0| 68 65 20 6b 65 72 6e 65 | 6c 20 72 65 71 75 69 72 |he kerne|l requir|
|00000fd0| 65 73 20 66 69 76 65 20 | 70 61 72 61 6d 65 74 65 |es five |paramete|
|00000fe0| 72 73 2e 0a 58 54 68 65 | 20 74 77 6f 20 66 69 72 |rs..XThe| two fir|
|00000ff0| 73 74 20 61 6c 6c 6f 77 | 73 20 74 68 65 20 61 70 |st allow|s the ap|
|00001000| 70 6c 69 63 61 74 69 6f | 6e 20 73 75 63 68 20 61 |plicatio|n such a|
|00001010| 73 20 66 6f 72 74 68 2e | 63 20 74 6f 20 65 78 74 |s forth.|c to ext|
|00001020| 65 6e 64 20 74 68 65 0a | 58 62 61 73 69 63 20 66 |end the.|Xbasic f|
|00001030| 6f 72 74 68 20 76 6f 63 | 61 62 75 6c 61 72 79 20 |orth voc|abulary |
|00001040| 62 79 20 67 69 76 69 6e | 67 20 74 68 65 20 66 69 |by givin|g the fi|
|00001050| 72 73 74 20 61 6e 64 20 | 6c 61 73 74 20 65 6e 74 |rst and |last ent|
|00001060| 72 79 20 69 6e 20 74 68 | 65 20 0a 58 61 70 70 6c |ry in th|e .Xappl|
|00001070| 69 63 61 74 69 6f 6e 20 | 76 6f 63 61 62 75 6c 61 |ication |vocabula|
|00001080| 72 79 2e 20 54 68 65 20 | 74 68 72 65 65 20 66 6f |ry. The |three fo|
|00001090| 6c 6c 6f 77 69 6e 67 20 | 70 61 72 61 6d 65 74 65 |llowing |paramete|
|000010a0| 72 73 20 73 70 65 63 69 | 66 79 20 74 68 65 0a 58 |rs speci|fy the.X|
|000010b0| 73 69 7a 65 20 6f 66 20 | 74 68 65 20 66 6f 72 65 |size of |the fore|
|000010c0| 67 72 6f 75 6e 64 20 74 | 61 73 6b 2c 20 74 68 65 |ground t|ask, the|
|000010d0| 20 66 6f 72 74 68 20 69 | 6e 74 65 72 70 72 65 74 | forth i|nterpret|
|000010e0| 65 72 2e 20 53 65 65 20 | 74 68 65 20 66 69 6c 65 |er. See |the file|
|000010f0| 0a 58 66 6f 72 74 68 2e | 63 20 66 6f 72 20 61 6e |.Xforth.|c for an|
|00001100| 20 65 78 61 6d 70 6c 65 | 2e 0a 58 0a 58 0a 58 32 | example|..X.X.X2|
|00001110| 2e 20 09 49 4f 20 4d 41 | 4e 41 47 45 4d 45 4e 54 |. .IO MA|NAGEMENT|
|00001120| 0a 58 0a 58 32 2e 31 09 | 46 69 6c 65 20 61 6e 64 |.X.X2.1.|File and|
|00001130| 20 70 61 74 68 20 6e 61 | 6d 65 20 73 69 7a 65 20 | path na|me size |
|00001140| 28 46 69 6c 65 3a 20 69 | 6f 2e 63 29 0a 58 0a 58 |(File: i|o.c).X.X|
|00001150| 54 68 65 20 6d 61 78 69 | 6d 75 6d 20 6c 65 6e 67 |The maxi|mum leng|
|00001160| 74 68 20 6f 66 20 61 20 | 66 69 6c 65 20 6f 72 20 |th of a |file or |
|00001170| 70 61 74 68 20 6e 61 6d | 65 20 69 73 20 64 65 66 |path nam|e is def|
|00001180| 69 6e 65 64 20 61 73 3a | 0a 58 0a 58 23 64 65 66 |ined as:|.X.X#def|
|00001190| 69 6e 65 20 46 49 4c 45 | 4e 41 4d 45 53 49 5a 45 |ine FILE|NAMESIZE|
|000011a0| 20 31 32 38 0a 58 23 64 | 65 66 69 6e 65 20 50 41 | 128.X#d|efine PA|
|000011b0| 54 48 4e 41 4d 45 53 49 | 5a 45 20 31 32 38 0a 58 |THNAMESI|ZE 128.X|
|000011c0| 0a 58 54 68 65 73 65 20 | 6c 65 6e 67 74 68 20 61 |.XThese |length a|
|000011d0| 72 65 20 6e 6f 74 20 74 | 65 73 74 20 66 6f 72 20 |re not t|est for |
|000011e0| 63 75 72 72 65 6e 74 6c | 79 2e 20 41 6e 20 65 72 |currentl|y. An er|
|000011f0| 72 6f 72 20 6d 61 79 20 | 6f 63 63 75 72 20 69 66 |ror may |occur if|
|00001200| 0a 58 61 20 66 69 6c 65 | 20 6f 72 20 70 61 74 68 |.Xa file| or path|
|00001210| 20 6e 61 6d 65 20 69 73 | 20 6c 6f 6e 67 65 72 20 | name is| longer |
|00001220| 74 68 61 6e 20 74 68 65 | 20 67 69 76 65 6e 20 73 |than the| given s|
|00001230| 69 7a 65 73 2e 0a 58 0a | 58 0a 58 32 2e 32 09 46 |izes..X.|X.X2.2.F|
|00001240| 69 6c 65 20 62 75 66 66 | 65 72 20 73 74 61 63 6b |ile buff|er stack|
|00001250| 20 28 46 69 6c 65 3a 20 | 69 6f 2e 63 29 0a 58 0a | (File: |io.c).X.|
|00001260| 58 54 68 65 20 69 6f 20 | 6d 61 6e 61 67 65 6d 65 |XThe io |manageme|
|00001270| 6e 74 20 70 61 63 6b 61 | 67 65 20 69 6d 70 6c 65 |nt packa|ge imple|
|00001280| 6d 65 6e 74 73 20 61 20 | 73 74 61 63 6b 20 6f 66 |ments a |stack of|
|00001290| 20 69 6e 70 75 74 20 66 | 69 6c 65 20 62 75 66 66 | input f|ile buff|
|000012a0| 65 72 73 20 74 6f 0a 58 | 61 6c 6c 6f 77 20 6c 6f |ers to.X|allow lo|
|000012b0| 61 64 69 6e 67 20 6f 66 | 20 66 69 6c 65 73 20 66 |ading of| files f|
|000012c0| 72 6f 6d 20 77 69 74 68 | 69 6e 20 6f 74 68 65 72 |rom with|in other|
|000012d0| 20 66 69 6c 65 73 20 65 | 74 63 2e 20 54 68 65 20 | files e|tc. The |
|000012e0| 6d 61 78 69 6d 75 6d 20 | 64 65 70 74 68 0a 58 6f |maximum |depth.Xo|
|000012f0| 66 20 74 68 69 73 20 73 | 74 61 63 6b 20 69 73 20 |f this s|tack is |
|00001300| 64 65 66 69 6e 65 64 20 | 61 73 3a 0a 58 0a 58 23 |defined |as:.X.X#|
|00001310| 64 65 66 69 6e 65 20 49 | 4e 46 53 54 41 43 4b 53 |define I|NFSTACKS|
|00001320| 49 5a 45 20 33 32 0a 58 | 0a 58 54 68 65 20 64 65 |IZE 32.X|.XThe de|
|00001330| 70 74 68 20 73 68 6f 75 | 6c 64 20 62 65 20 63 68 |pth shou|ld be ch|
|00001340| 6f 73 65 6e 20 74 6f 20 | 74 68 65 20 6d 61 78 69 |osen to |the maxi|
|00001350| 6d 75 6d 20 6e 75 6d 62 | 65 72 20 6f 66 20 6f 70 |mum numb|er of op|
|00001360| 65 6e 20 66 69 6c 65 73 | 2e 0a 58 0a 58 0a 58 32 |en files|..X.X.X2|
|00001370| 2e 33 09 53 65 74 20 6f | 66 20 6c 6f 61 64 65 64 |.3.Set o|f loaded|
|00001380| 20 66 69 6c 65 73 20 28 | 46 69 6c 65 3a 20 69 6f | files (|File: io|
|00001390| 2e 63 29 0a 58 0a 58 54 | 68 65 20 66 69 6c 65 20 |.c).X.XT|he file |
|000013a0| 6c 6f 61 64 69 6e 67 20 | 6d 65 63 68 61 6e 69 73 |loading |mechanis|
|000013b0| 6d 20 61 75 74 6f 6d 61 | 74 69 63 61 6c 6c 79 20 |m automa|tically |
|000013c0| 6c 6f 6f 6b 73 20 69 66 | 20 74 68 65 20 66 69 6c |looks if| the fil|
|000013d0| 65 20 61 6c 72 65 61 64 | 79 0a 58 68 61 73 20 62 |e alread|y.Xhas b|
|000013e0| 65 65 6e 20 6f 70 65 6e | 65 64 2e 20 54 68 65 20 |een open|ed. The |
|000013f0| 73 65 74 20 6f 66 20 6f | 70 65 6e 65 64 20 66 69 |set of o|pened fi|
|00001400| 6c 65 73 20 69 73 20 6d | 61 69 6e 74 61 69 6e 65 |les is m|aintaine|
|00001410| 64 20 61 73 20 61 20 76 | 65 63 74 6f 72 2e 0a 58 |d as a v|ector..X|
|00001420| 54 68 65 20 6d 61 78 69 | 6d 75 6d 20 6e 75 6d 62 |The maxi|mum numb|
|00001430| 65 72 20 6f 66 20 6c 6f | 61 64 65 64 20 66 69 6c |er of lo|aded fil|
|00001440| 65 73 20 69 73 3a 0a 58 | 0a 58 23 64 65 66 69 6e |es is:.X|.X#defin|
|00001450| 65 20 49 4e 46 49 4c 45 | 53 53 49 5a 45 20 36 34 |e INFILE|SSIZE 64|
|00001460| 0a 58 0a 58 54 68 65 20 | 76 65 63 74 6f 72 20 63 |.X.XThe |vector c|
|00001470| 6f 6e 74 61 69 6e 73 20 | 74 68 65 20 66 75 6c 6c |ontains |the full|
|00001480| 79 20 65 78 70 61 6e 64 | 65 64 20 6e 61 6d 65 73 |y expand|ed names|
|00001490| 20 6f 66 20 74 68 65 20 | 6c 6f 61 64 65 64 20 66 | of the |loaded f|
|000014a0| 69 6c 65 73 2e 0a 58 41 | 6e 20 65 72 72 6f 72 20 |iles..XA|n error |
|000014b0| 6d 61 79 20 6f 63 63 75 | 72 20 69 66 20 74 68 69 |may occu|r if thi|
|000014c0| 73 20 6c 69 6d 69 74 20 | 69 73 20 73 75 63 63 65 |s limit |is succe|
|000014d0| 65 64 65 64 2e 20 49 74 | 20 69 73 20 6e 6f 74 20 |eded. It| is not |
|000014e0| 63 68 65 63 6b 65 64 20 | 66 6f 72 0a 58 63 75 72 |checked |for.Xcur|
|000014f0| 72 65 6e 74 6c 79 2e 0a | 58 0a 58 0a 58 32 2e 34 |rently..|X.X.X2.4|
|00001500| 09 53 65 74 20 6f 66 20 | 70 61 74 68 73 20 28 46 |.Set of |paths (F|
|00001510| 69 6c 65 3a 20 69 6f 2e | 63 29 0a 58 0a 58 54 68 |ile: io.|c).X.XTh|
|00001520| 65 20 69 6f 20 70 61 63 | 6b 61 67 65 73 20 61 6c |e io pac|kages al|
|00001530| 73 6f 20 6d 61 69 6e 74 | 61 69 6e 73 20 61 6e 20 |so maint|ains an |
|00001540| 6f 72 64 65 72 65 64 20 | 63 6f 6c 6c 65 63 74 69 |ordered |collecti|
|00001550| 6f 6e 20 6f 66 20 70 61 | 74 68 73 20 77 68 69 63 |on of pa|ths whic|
|00001560| 68 0a 58 61 72 65 20 75 | 73 65 64 20 74 6f 20 65 |h.Xare u|sed to e|
|00001570| 78 70 61 6e 64 20 66 69 | 6c 65 20 6e 61 6d 65 73 |xpand fi|le names|
|00001580| 20 77 69 74 68 20 77 68 | 65 6e 20 73 65 61 72 63 | with wh|en searc|
|00001590| 68 20 66 6f 72 20 74 68 | 65 20 66 69 6c 65 2e 20 |h for th|e file. |
|000015a0| 54 68 65 0a 58 6d 61 78 | 69 6d 75 6d 20 73 69 7a |The.Xmax|imum siz|
|000015b0| 65 20 6f 66 20 74 68 69 | 73 20 63 6f 6c 6c 65 63 |e of thi|s collec|
|000015c0| 74 69 6f 6e 20 69 73 20 | 64 65 66 69 6e 65 64 20 |tion is |defined |
|000015d0| 62 79 3a 0a 58 0a 58 23 | 64 65 66 69 6e 65 20 50 |by:.X.X#|define P|
|000015e0| 41 54 48 53 53 49 5a 45 | 20 33 32 0a 58 0a 58 54 |ATHSSIZE| 32.X.XT|
|000015f0| 68 69 73 20 63 6f 6c 6c | 65 63 74 69 6f 6e 20 69 |his coll|ection i|
|00001600| 73 20 61 75 74 6f 6d 61 | 74 69 63 61 6c 6c 79 20 |s automa|tically |
|00001610| 61 70 70 65 6e 64 65 64 | 20 62 79 20 74 68 65 20 |appended| by the |
|00001620| 24 54 49 4c 45 50 41 54 | 48 20 65 6e 76 69 72 6f |$TILEPAT|H enviro|
|00001630| 6e 2d 0a 58 6d 65 6e 74 | 20 76 61 72 69 61 62 6c |n-.Xment| variabl|
|00001640| 65 20 77 68 65 6e 20 74 | 68 65 20 69 6f 20 70 61 |e when t|he io pa|
|00001650| 63 6b 61 67 65 20 69 73 | 20 69 6e 69 74 69 61 74 |ckage is| initiat|
|00001660| 65 64 2e 0a 58 0a 58 0a | 58 32 2e 35 09 57 68 69 |ed..X.X.|X2.5.Whi|
|00001670| 74 65 20 73 70 61 63 65 | 20 28 46 69 6c 65 3a 20 |te space| (File: |
|00001680| 69 6f 2e 68 29 0a 58 0a | 58 54 68 65 20 64 65 66 |io.h).X.|XThe def|
|00001690| 69 6e 69 74 69 6f 6e 20 | 6f 66 20 22 77 68 69 74 |inition |of "whit|
|000016a0| 65 22 20 73 70 61 63 65 | 20 69 73 20 64 65 66 69 |e" space| is defi|
|000016b0| 6e 65 64 20 61 73 3a 0a | 58 0a 58 23 64 65 66 69 |ned as:.|X.X#defi|
|000016c0| 6e 65 20 49 53 53 50 41 | 43 45 28 63 29 20 28 28 |ne ISSPA|CE(c) ((|
|000016d0| 63 29 20 3c 3d 20 27 20 | 27 29 0a 58 0a 58 54 68 |c) <= ' |').X.XTh|
|000016e0| 69 73 20 65 6c 69 6d 69 | 6e 61 74 65 73 20 73 70 |is elimi|nates sp|
|000016f0| 61 63 65 20 61 6e 64 20 | 61 6e 79 20 63 6f 6e 74 |ace and |any cont|
|00001700| 72 6f 6c 20 63 68 61 72 | 61 63 74 65 72 73 2e 20 |rol char|acters. |
|00001710| 53 6f 6d 65 20 61 70 70 | 6c 69 63 61 74 69 6f 6e |Some app|lication|
|00001720| 0a 58 6d 69 67 68 74 20 | 77 61 6e 74 20 74 6f 20 |.Xmight |want to |
|00001730| 72 65 64 65 66 69 6e 65 | 20 74 68 69 73 2e 20 0a |redefine| this. .|
|00001740| 58 0a 58 0a 58 32 2e 36 | 2e 09 44 69 72 65 63 74 |X.X.X2.6|..Direct|
|00001750| 6f 72 79 20 73 65 70 61 | 72 61 74 6f 72 20 63 68 |ory sepa|rator ch|
|00001760| 61 72 61 63 74 65 72 20 | 28 46 69 6c 65 3a 20 69 |aracter |(File: i|
|00001770| 6f 2e 68 29 0a 58 0a 58 | 54 68 65 20 64 69 72 65 |o.h).X.X|The dire|
|00001780| 63 74 6f 72 79 20 73 65 | 70 61 72 61 74 6f 72 20 |ctory se|parator |
|00001790| 63 68 61 72 61 63 74 65 | 72 20 69 73 20 64 65 66 |characte|r is def|
|000017a0| 69 6e 65 64 20 61 73 3a | 0a 58 0a 58 23 64 65 66 |ined as:|.X.X#def|
|000017b0| 69 6e 65 20 44 49 52 53 | 45 50 43 48 41 52 20 27 |ine DIRS|EPCHAR '|
|000017c0| 2f 27 0a 58 0a 58 54 68 | 69 73 20 6d 61 6b 65 73 |/'.X.XTh|is makes|
|000017d0| 20 74 68 65 20 63 6f 64 | 65 20 6d 6f 72 65 20 70 | the cod|e more p|
|000017e0| 6f 72 74 61 62 6c 65 20 | 74 6f 20 6f 74 68 65 72 |ortable |to other|
|000017f0| 20 6d 61 63 68 69 6e 65 | 73 2e 0a 58 0a 58 0a 58 | machine|s..X.X.X|
|00001800| 32 2e 36 09 4e 6f 6e 2d | 62 6c 6f 63 6b 69 6e 67 |2.6.Non-|blocking|
|00001810| 20 72 65 61 64 20 6f 70 | 65 72 61 74 69 6f 6e 20 | read op|eration |
|00001820| 28 46 69 6c 65 3a 20 69 | 6f 2e 63 29 0a 58 0a 58 |(File: i|o.c).X.X|
|00001830| 54 6f 20 61 63 68 69 65 | 76 65 20 6d 75 6c 74 69 |To achie|ve multi|
|00001840| 2d 74 61 73 6b 69 6e 67 | 20 64 75 72 69 6e 67 20 |-tasking| during |
|00001850| 69 6e 70 75 74 20 77 61 | 69 74 20 74 68 65 20 69 |input wa|it the i|
|00001860| 6e 70 75 74 20 70 61 63 | 6b 61 67 65 20 66 75 6e |nput pac|kage fun|
|00001870| 63 74 69 6f 6e 0a 58 22 | 69 6f 5f 66 69 6c 6c 62 |ction.X"|io_fillb|
|00001880| 75 66 22 20 75 73 65 73 | 20 61 20 6e 6f 6e 2d 62 |uf" uses| a non-b|
|00001890| 6c 6f 63 6b 69 6e 67 20 | 72 65 61 64 20 6f 70 65 |locking |read ope|
|000018a0| 72 61 74 69 6f 6e 2e 20 | 53 6f 6d 65 20 65 6e 76 |ration. |Some env|
|000018b0| 69 72 6f 6e 6d 65 6e 74 | 73 0a 58 64 6f 20 6e 6f |ironment|s.Xdo no|
|000018c0| 74 20 73 75 70 70 6f 72 | 74 20 74 68 69 73 2e 20 |t suppor|t this. |
|000018d0| 54 68 75 73 20 74 68 69 | 73 20 6d 61 79 20 72 65 |Thus thi|s may re|
|000018e0| 71 75 69 72 65 20 72 65 | 2d 69 6d 70 6c 65 6d 65 |quire re|-impleme|
|000018f0| 6e 74 61 74 69 6f 6e 2e | 0a 58 0a 58 0a 58 33 2e |ntation.|.X.X.X3.|
|00001900| 20 09 45 52 52 4f 52 20 | 4d 41 4e 41 47 45 4d 45 | .ERROR |MANAGEME|
|00001910| 4e 54 0a 58 0a 58 33 2e | 31 09 53 69 67 6e 61 6c |NT.X.X3.|1.Signal|
|00001920| 73 20 28 46 69 6c 65 3a | 20 65 72 72 6f 72 2e 63 |s (File:| error.c|
|00001930| 29 0a 58 0a 58 45 72 72 | 6f 72 20 68 61 6e 64 69 |).X.XErr|or handi|
|00001940| 6e 67 20 69 73 20 72 65 | 61 6c 69 7a 65 64 20 75 |ng is re|alized u|
|00001950| 73 69 6e 67 20 74 77 6f | 20 62 61 73 69 63 20 6d |sing two| basic m|
|00001960| 65 63 68 61 6e 69 73 6d | 73 3b 20 66 69 72 73 74 |echanism|s; first|
|00001970| 20 73 69 67 6e 61 6c 73 | 20 66 72 6f 6d 0a 58 74 | signals| from.Xt|
|00001980| 68 65 20 65 78 65 63 75 | 74 69 6f 6e 20 65 6e 76 |he execu|tion env|
|00001990| 69 72 6f 6e 6d 65 6e 74 | 20 61 6e 64 20 73 65 63 |ironment| and sec|
|000019a0| 6f 6e 64 20 62 79 20 75 | 73 65 72 20 64 65 66 69 |ond by u|ser defi|
|000019b0| 6e 65 64 20 65 78 63 65 | 70 74 69 6f 6e 73 20 69 |ned exce|ptions i|
|000019c0| 6e 0a 58 74 68 65 20 6b | 65 72 6e 65 6c 20 28 68 |n.Xthe k|ernel (h|
|000019d0| 69 67 68 20 6c 65 76 65 | 6c 20 63 6f 64 65 29 2e |igh leve|l code).|
|000019e0| 0a 58 0a 58 54 68 65 20 | 73 69 67 6e 61 6c 20 6d |.X.XThe |signal m|
|000019f0| 65 73 73 61 67 65 20 74 | 61 62 6c 65 20 61 6e 64 |essage t|able and|
|00001a00| 20 74 68 65 20 61 70 70 | 72 6f 70 72 69 61 74 65 | the app|ropriate|
|00001a10| 20 6f 70 65 72 61 74 69 | 6f 6e 73 2c 20 22 65 72 | operati|ons, "er|
|00001a20| 72 6f 72 5f 72 65 73 74 | 61 72 74 22 2c 0a 58 6f |ror_rest|art",.Xo|
|00001a30| 72 20 22 65 72 72 6f 72 | 5f 66 61 74 61 6c 22 2c |r "error|_fatal",|
|00001a40| 20 6d 61 79 20 68 61 76 | 65 20 74 6f 20 62 65 20 | may hav|e to be |
|00001a50| 63 68 61 6e 67 65 64 20 | 74 6f 20 67 69 76 65 20 |changed |to give |
|00001a60| 74 68 65 20 72 69 67 68 | 74 20 70 65 72 66 6f 72 |the righ|t perfor|
|00001a70| 6d 61 6e 63 65 2e 0a 58 | 0a 58 50 6c 65 61 73 65 |mance..X|.XPlease|
|00001a80| 20 73 65 65 20 74 68 65 | 73 65 20 66 75 6e 63 74 | see the|se funct|
|00001a90| 69 6f 6e 73 20 61 6e 64 | 20 22 65 72 72 6f 72 5f |ions and| "error_|
|00001aa0| 69 6e 69 74 69 61 74 65 | 22 20 77 68 65 72 65 20 |initiate|" where |
|00001ab0| 74 68 65 20 61 63 74 75 | 61 6c 20 62 69 6e 64 69 |the actu|al bindi|
|00001ac0| 6e 67 0a 58 6f 66 20 73 | 69 67 6e 61 6c 73 20 61 |ng.Xof s|ignals a|
|00001ad0| 6e 64 20 61 63 74 69 6f | 6e 73 20 69 73 20 70 65 |nd actio|ns is pe|
|00001ae0| 72 66 6f 72 6d 65 64 2e | 0a 58 0a 58 0a 58 34 2e |rformed.|.X.X.X4.|
|00001af0| 09 4d 45 4d 4f 52 59 20 | 4d 41 4e 41 47 45 4d 45 |.MEMORY |MANAGEME|
|00001b00| 4e 54 0a 58 0a 58 34 2e | 31 09 4d 65 6d 6f 72 79 |NT.X.X4.|1.Memory|
|00001b10| 20 61 6c 6c 6f 63 61 74 | 69 6f 6e 20 28 46 69 6c | allocat|ion (Fil|
|00001b20| 65 3a 20 66 6f 72 74 68 | 2e 63 29 0a 58 0a 58 43 |e: forth|.c).X.XC|
|00001b30| 75 72 72 65 6e 74 6c 79 | 20 6d 65 6d 6f 72 79 20 |urrently| memory |
|00001b40| 66 6f 72 20 74 68 65 20 | 64 69 63 74 69 6f 6e 61 |for the |dictiona|
|00001b50| 72 79 2c 20 73 74 72 69 | 6e 67 73 2c 20 65 6e 74 |ry, stri|ngs, ent|
|00001b60| 72 69 65 73 2c 20 61 6e | 64 20 74 61 73 6b 20 62 |ries, an|d task b|
|00001b70| 6c 6f 63 6b 73 0a 58 61 | 72 65 20 61 6c 6c 6f 63 |locks.Xa|re alloc|
|00001b80| 61 74 65 64 20 75 73 69 | 6e 67 20 22 6d 61 6c 6c |ated usi|ng "mall|
|00001b90| 6f 63 22 2e 0a 58 0a 58 | 54 68 65 20 73 69 7a 65 |oc"..X.X|The size|
|00001ba0| 20 6f 66 20 74 68 65 20 | 64 69 63 74 69 6f 6e 61 | of the |dictiona|
|00001bb0| 72 79 20 69 73 20 64 65 | 74 65 72 6d 69 6e 65 64 |ry is de|termined|
|00001bc0| 20 77 68 65 6e 20 63 61 | 6c 6c 69 6e 67 20 74 68 | when ca|lling th|
|00001bd0| 65 20 69 6e 69 74 69 61 | 6c 69 7a 61 74 69 6f 6e |e initia|lization|
|00001be0| 0a 58 66 75 6e 63 74 69 | 6f 6e 20 69 6e 20 74 68 |.Xfuncti|on in th|
|00001bf0| 65 20 6d 65 6d 6f 72 79 | 20 6d 61 6e 61 67 65 6d |e memory| managem|
|00001c00| 65 6e 74 20 70 61 63 6b | 61 67 65 2c 20 22 6d 65 |ent pack|age, "me|
|00001c10| 6d 6f 72 79 5f 69 6e 69 | 74 69 61 74 65 22 2e 20 |mory_ini|tiate". |
|00001c20| 54 68 65 0a 58 63 75 72 | 72 65 6e 74 20 64 65 66 |The.Xcur|rent def|
|00001c30| 61 75 6c 74 20 73 69 7a | 65 20 69 73 20 64 65 66 |ault siz|e is def|
|00001c40| 69 6e 65 64 20 61 73 3a | 0a 58 0a 58 23 64 65 66 |ined as:|.X.X#def|
|00001c50| 69 6e 65 20 44 49 43 54 | 49 4f 4e 41 52 59 53 49 |ine DICT|IONARYSI|
|00001c60| 5a 45 20 31 30 32 34 4c | 20 2a 20 31 30 32 34 4c |ZE 1024L| * 1024L|
|00001c70| 0a 58 0a 58 41 6e 64 20 | 6d 61 79 20 62 65 20 74 |.X.XAnd |may be t|
|00001c80| 6f 6f 20 6c 61 72 67 65 | 20 66 6f 72 20 22 73 6d |oo large| for "sm|
|00001c90| 61 6c 6c 22 20 6d 61 63 | 68 69 6e 65 73 2e 20 0a |all" mac|hines. .|
|00001ca0| 45 4e 44 5f 4f 46 5f 50 | 4f 52 54 49 4e 47 0a 69 |END_OF_P|ORTING.i|
|00001cb0| 66 20 74 65 73 74 20 36 | 32 33 32 20 2d 6e 65 20 |f test 6|232 -ne |
|00001cc0| 60 77 63 20 2d 63 20 3c | 50 4f 52 54 49 4e 47 60 |`wc -c <|PORTING`|
|00001cd0| 3b 20 74 68 65 6e 0a 20 | 20 20 20 65 63 68 6f 20 |; then. | echo |
|00001ce0| 73 68 61 72 3a 20 5c 22 | 50 4f 52 54 49 4e 47 5c |shar: \"|PORTING\|
|00001cf0| 22 20 75 6e 70 61 63 6b | 65 64 20 77 69 74 68 20 |" unpack|ed with |
|00001d00| 77 72 6f 6e 67 20 73 69 | 7a 65 21 0a 66 69 0a 23 |wrong si|ze!.fi.#|
|00001d10| 20 65 6e 64 20 6f 66 20 | 6f 76 65 72 77 72 69 74 | end of |overwrit|
|00001d20| 69 6e 67 20 63 68 65 63 | 6b 0a 66 69 0a 69 66 20 |ing chec|k.fi.if |
|00001d30| 74 65 73 74 20 2d 66 20 | 6c 69 62 2f 64 65 62 75 |test -f |lib/debu|
|00001d40| 67 67 65 72 2e 66 38 33 | 20 2d 61 20 22 24 7b 31 |gger.f83| -a "${1|
|00001d50| 7d 22 20 21 3d 20 22 2d | 63 22 20 3b 20 74 68 65 |}" != "-|c" ; the|
|00001d60| 6e 20 0a 20 20 65 63 68 | 6f 20 73 68 61 72 3a 20 |n . ech|o shar: |
|00001d70| 57 69 6c 6c 20 6e 6f 74 | 20 6f 76 65 72 2d 77 72 |Will not| over-wr|
|00001d80| 69 74 65 20 65 78 69 73 | 74 69 6e 67 20 66 69 6c |ite exis|ting fil|
|00001d90| 65 20 5c 22 6c 69 62 2f | 64 65 62 75 67 67 65 72 |e \"lib/|debugger|
|00001da0| 2e 66 38 33 5c 22 0a 65 | 6c 73 65 0a 65 63 68 6f |.f83\".e|lse.echo|
|00001db0| 20 73 68 61 72 3a 20 45 | 78 74 72 61 63 74 69 6e | shar: E|xtractin|
|00001dc0| 67 20 5c 22 6c 69 62 2f | 64 65 62 75 67 67 65 72 |g \"lib/|debugger|
|00001dd0| 2e 66 38 33 5c 22 20 5c | 28 34 36 35 32 20 63 68 |.f83\" \|(4652 ch|
|00001de0| 61 72 61 63 74 65 72 73 | 5c 29 0a 73 65 64 20 22 |aracters|\).sed "|
|00001df0| 73 2f 5e 58 2f 2f 22 20 | 3e 6c 69 62 2f 64 65 62 |s/^X//" |>lib/deb|
|00001e00| 75 67 67 65 72 2e 66 38 | 33 20 3c 3c 27 45 4e 44 |ugger.f8|3 <<'END|
|00001e10| 5f 4f 46 5f 6c 69 62 2f | 64 65 62 75 67 67 65 72 |_OF_lib/|debugger|
|00001e20| 2e 66 38 33 27 0a 58 5c | 0a 58 5c 20 20 46 4f 52 |.f83'.X\|.X\ FOR|
|00001e30| 54 48 20 44 45 42 55 47 | 47 45 52 20 44 45 46 49 |TH DEBUG|GER DEFI|
|00001e40| 4e 49 54 49 4f 4e 53 0a | 58 5c 0a 58 5c 20 20 43 |NITIONS.|X\.X\ C|
|00001e50| 6f 70 79 72 69 67 68 74 | 20 28 63 29 20 31 39 38 |opyright| (c) 198|
|00001e60| 38 2d 31 39 39 30 20 62 | 79 20 4d 69 6b 61 65 6c |8-1990 b|y Mikael|
|00001e70| 20 52 2e 4b 2e 20 50 61 | 74 65 6c 0a 58 5c 0a 58 | R.K. Pa|tel.X\.X|
|00001e80| 5c 20 20 43 6f 6d 70 75 | 74 65 72 20 41 69 64 65 |\ Compu|ter Aide|
|00001e90| 64 20 44 65 73 69 67 6e | 20 4c 61 62 6f 72 61 74 |d Design| Laborat|
|00001ea0| 6f 72 79 20 28 43 41 44 | 4c 41 42 29 0a 58 5c 20 |ory (CAD|LAB).X\ |
|00001eb0| 20 44 65 70 61 72 74 6d | 65 6e 74 20 6f 66 20 43 | Departm|ent of C|
|00001ec0| 6f 6d 70 75 74 65 72 20 | 61 6e 64 20 49 6e 66 6f |omputer |and Info|
|00001ed0| 72 6d 61 74 69 6f 6e 20 | 53 63 69 65 6e 63 65 0a |rmation |Science.|
|00001ee0| 58 5c 20 20 4c 69 6e 6b | 6f 70 69 6e 67 20 55 6e |X\ Link|oping Un|
|00001ef0| 69 76 65 72 73 69 74 79 | 0a 58 5c 20 20 53 2d 35 |iversity|.X\ S-5|
|00001f00| 38 31 20 38 33 20 4c 49 | 4e 4b 4f 50 49 4e 47 0a |81 83 LI|NKOPING.|
|00001f10| 58 5c 20 20 53 57 45 44 | 45 4e 0a 58 5c 0a 58 5c |X\ SWED|EN.X\.X\|
|00001f20| 20 20 45 6d 61 69 6c 3a | 20 6d 69 70 40 69 64 61 | Email:| mip@ida|
|00001f30| 2e 6c 69 75 2e 73 65 0a | 58 5c 0a 58 5c 20 20 53 |.liu.se.|X\.X\ S|
|00001f40| 74 61 72 74 65 64 20 6f | 6e 3a 20 33 30 20 4a 75 |tarted o|n: 30 Ju|
|00001f50| 6e 65 20 31 39 38 38 0a | 58 5c 0a 58 5c 20 20 4c |ne 1988.|X\.X\ L|
|00001f60| 61 73 74 20 75 70 64 61 | 74 65 64 20 6f 6e 3a 20 |ast upda|ted on: |
|00001f70| 32 38 20 4a 75 6e 65 20 | 31 39 39 30 0a 58 5c 0a |28 June |1990.X\.|
|00001f80| 58 5c 20 20 44 65 70 65 | 6e 64 65 6e 63 69 65 73 |X\ Depe|ndencies|
|00001f90| 3a 0a 58 5c 20 20 20 20 | 20 20 20 28 66 6f 72 74 |:.X\ | (fort|
|00001fa0| 68 29 20 66 6f 72 74 68 | 2c 20 63 6f 6d 70 69 6c |h) forth|, compil|
|00001fb0| 65 72 2c 20 73 74 72 75 | 63 74 75 72 65 73 2c 20 |er, stru|ctures, |
|00001fc0| 62 6c 6f 63 6b 73 20 61 | 6e 64 20 6c 69 73 74 73 |blocks a|nd lists|
|00001fd0| 2e 0a 58 5c 0a 58 5c 20 | 20 44 65 73 63 72 69 70 |..X\.X\ | Descrip|
|00001fe0| 74 69 6f 6e 3a 0a 58 5c | 20 20 20 20 20 20 20 42 |tion:.X\| B|
|00001ff0| 61 73 69 63 20 64 65 62 | 75 67 67 69 6e 67 20 66 |asic deb|ugging f|
|00002000| 75 6e 63 74 69 6f 6e 20 | 62 75 69 6c 74 20 6f 6e |unction |built on|
|00002010| 20 61 20 67 65 6e 65 72 | 61 6c 20 61 64 76 69 63 | a gener|al advic|
|00002020| 65 20 66 75 6e 63 74 69 | 6f 6e 0a 58 5c 20 20 20 |e functi|on.X\ |
|00002030| 20 20 20 20 6d 61 6e 61 | 67 65 6d 65 6e 74 2e 20 | mana|gement. |
|00002040| 41 6c 6c 6f 77 73 20 62 | 6c 61 63 6b 2d 62 6f 78 |Allows b|lack-box|
|00002050| 20 74 72 61 63 69 6e 67 | 2c 20 62 72 65 61 6b 20 | tracing|, break |
|00002060| 70 6f 69 6e 74 73 20 61 | 6e 64 0a 58 5c 20 20 20 |points a|nd.X\ |
|00002070| 20 20 20 20 63 6f 6c 6f | 6e 20 64 65 66 69 6e 69 | colo|n defini|
|00002080| 74 69 6f 6e 73 20 63 61 | 6c 6c 20 70 72 6f 66 69 |tions ca|ll profi|
|00002090| 6c 69 6e 67 2e 0a 58 5c | 0a 58 5c 20 20 43 6f 70 |ling..X\|.X\ Cop|
|000020a0| 79 69 6e 67 3a 0a 58 5c | 20 20 20 20 20 20 20 54 |ying:.X\| T|
|000020b0| 68 69 73 20 70 72 6f 67 | 72 61 6d 20 69 73 20 66 |his prog|ram is f|
|000020c0| 72 65 65 20 73 6f 66 74 | 77 61 72 65 3b 20 79 6f |ree soft|ware; yo|
|000020d0| 75 20 63 61 6e 20 72 65 | 64 69 73 74 72 69 62 75 |u can re|distribu|
|000020e0| 74 65 20 69 74 20 61 6e | 64 5c 6f 72 20 6d 6f 64 |te it an|d\or mod|
|000020f0| 69 66 79 0a 58 5c 20 20 | 20 20 20 20 20 69 74 20 |ify.X\ | it |
|00002100| 75 6e 64 65 72 20 74 68 | 65 20 74 65 72 6d 73 20 |under th|e terms |
|00002110| 6f 66 20 74 68 65 20 47 | 4e 55 20 47 65 6e 65 72 |of the G|NU Gener|
|00002120| 61 6c 20 50 75 62 6c 69 | 63 20 4c 69 63 65 6e 73 |al Publi|c Licens|
|00002130| 65 20 61 73 20 70 75 62 | 6c 69 73 68 65 64 20 62 |e as pub|lished b|
|00002140| 79 0a 58 5c 20 20 20 20 | 20 20 20 74 68 65 20 46 |y.X\ | the F|
|00002150| 72 65 65 20 53 6f 66 74 | 77 61 72 65 20 46 6f 75 |ree Soft|ware Fou|
|00002160| 6e 64 61 74 69 6f 6e 3b | 20 65 69 74 68 65 72 20 |ndation;| either |
|00002170| 76 65 72 73 69 6f 6e 20 | 31 2c 20 6f 72 20 28 61 |version |1, or (a|
|00002180| 74 20 79 6f 75 72 20 6f | 70 74 69 6f 6e 29 0a 58 |t your o|ption).X|
|00002190| 5c 20 20 20 20 20 20 20 | 61 6e 79 20 6c 61 74 65 |\ |any late|
|000021a0| 72 20 76 65 72 73 69 6f | 6e 2e 0a 58 5c 0a 58 5c |r versio|n..X\.X\|
|000021b0| 20 20 20 20 20 20 20 54 | 68 69 73 20 70 72 6f 67 | T|his prog|
|000021c0| 72 61 6d 20 69 73 20 64 | 69 73 74 72 69 62 75 74 |ram is d|istribut|
|000021d0| 65 64 20 69 6e 20 74 68 | 65 20 68 6f 70 65 20 74 |ed in th|e hope t|
|000021e0| 68 61 74 20 69 74 20 77 | 69 6c 6c 20 62 65 20 75 |hat it w|ill be u|
|000021f0| 73 65 66 75 6c 2c 0a 58 | 5c 20 20 20 20 20 20 20 |seful,.X|\ |
|00002200| 62 75 74 20 57 49 54 48 | 4f 55 54 20 41 4e 59 20 |but WITH|OUT ANY |
|00002210| 57 41 52 52 41 4e 54 59 | 3b 20 77 69 74 68 6f 75 |WARRANTY|; withou|
|00002220| 74 20 65 76 65 6e 20 74 | 68 65 20 69 6d 70 6c 69 |t even t|he impli|
|00002230| 65 64 20 77 61 72 72 61 | 6e 74 79 20 6f 66 0a 58 |ed warra|nty of.X|
|00002240| 5c 20 20 20 20 20 20 20 | 4d 45 52 43 48 41 4e 54 |\ |MERCHANT|
|00002250| 41 42 49 4c 49 54 59 20 | 6f 72 20 46 49 54 4e 45 |ABILITY |or FITNE|
|00002260| 53 53 20 46 4f 52 20 41 | 20 50 41 52 54 49 43 55 |SS FOR A| PARTICU|
|00002270| 4c 41 52 20 50 55 52 50 | 4f 53 45 2e 20 20 53 65 |LAR PURP|OSE. Se|
|00002280| 65 20 74 68 65 0a 58 5c | 20 20 20 20 20 20 20 47 |e the.X\| G|
|00002290| 4e 55 20 47 65 6e 65 72 | 61 6c 20 50 75 62 6c 69 |NU Gener|al Publi|
|000022a0| 63 20 4c 69 63 65 6e 73 | 65 20 66 6f 72 20 6d 6f |c Licens|e for mo|
|000022b0| 72 65 20 64 65 74 61 69 | 6c 73 2e 0a 58 5c 0a 58 |re detai|ls..X\.X|
|000022c0| 5c 20 20 20 20 20 20 20 | 59 6f 75 20 73 68 6f 75 |\ |You shou|
|000022d0| 6c 64 20 68 61 76 65 20 | 72 65 63 65 69 76 65 64 |ld have |received|
|000022e0| 20 61 20 63 6f 70 79 20 | 6f 66 20 74 68 65 20 47 | a copy |of the G|
|000022f0| 4e 55 20 47 65 6e 65 72 | 61 6c 20 50 75 62 6c 69 |NU Gener|al Publi|
|00002300| 63 20 4c 69 63 65 6e 73 | 65 0a 58 5c 20 20 20 20 |c Licens|e.X\ |
|00002310| 20 20 20 61 6c 6f 6e 67 | 20 77 69 74 68 20 74 68 | along| with th|
|00002320| 69 73 20 70 72 6f 67 72 | 61 6d 3b 20 73 65 65 20 |is progr|am; see |
|00002330| 74 68 65 20 66 69 6c 65 | 20 43 4f 50 59 49 4e 47 |the file| COPYING|
|00002340| 2e 20 20 49 66 20 6e 6f | 74 2c 20 77 72 69 74 65 |. If no|t, write|
|00002350| 20 74 6f 0a 58 5c 20 20 | 20 20 20 20 20 74 68 65 | to.X\ | the|
|00002360| 20 46 72 65 65 20 53 6f | 66 74 77 61 72 65 20 46 | Free So|ftware F|
|00002370| 6f 75 6e 64 61 74 69 6f | 6e 2c 20 36 37 35 20 4d |oundatio|n, 675 M|
|00002380| 61 73 73 20 41 76 65 2c | 20 43 61 6d 62 72 69 64 |ass Ave,| Cambrid|
|00002390| 67 65 2c 20 4d 41 20 30 | 32 31 33 39 2c 20 55 53 |ge, MA 0|2139, US|
|000023a0| 41 2e 20 0a 58 0a 58 2e | 28 20 4c 6f 61 64 69 6e |A. .X.X.|( Loadin|
|000023b0| 67 20 44 65 62 75 67 67 | 65 72 20 64 65 66 69 6e |g Debugg|er defin|
|000023c0| 69 74 69 6f 6e 73 2e 2e | 2e 29 20 63 72 0a 58 0a |itions..|.) cr.X.|
|000023d0| 58 23 69 6e 63 6c 75 64 | 65 20 69 6e 74 65 72 6e |X#includ|e intern|
|000023e0| 61 6c 73 2e 66 38 33 0a | 58 23 69 6e 63 6c 75 64 |als.f83.|X#includ|
|000023f0| 65 20 62 6c 6f 63 6b 73 | 2e 66 38 33 0a 58 23 69 |e blocks|.f83.X#i|
|00002400| 6e 63 6c 75 64 65 20 6c | 69 73 74 73 2e 66 38 33 |nclude l|ists.f83|
|00002410| 0a 58 23 69 6e 63 6c 75 | 64 65 20 73 74 72 75 63 |.X#inclu|de struc|
|00002420| 74 75 72 65 73 2e 66 38 | 33 0a 58 0a 58 76 6f 63 |tures.f8|3.X.Xvoc|
|00002430| 61 62 75 6c 61 72 79 20 | 64 65 62 75 67 67 65 72 |abulary |debugger|
|00002440| 0a 58 0a 58 62 6c 6f 63 | 6b 73 20 73 74 72 75 63 |.X.Xbloc|ks struc|
|00002450| 74 75 72 65 73 20 6c 69 | 73 74 73 20 63 6f 6d 70 |tures li|sts comp|
|00002460| 69 6c 65 72 20 66 6f 72 | 74 68 20 64 65 62 75 67 |iler for|th debug|
|00002470| 67 65 72 20 64 65 66 69 | 6e 69 74 69 6f 6e 73 0a |ger defi|nitions.|
|00002480| 58 0a 58 73 74 72 75 63 | 74 2e 74 79 70 65 20 41 |X.Xstruc|t.type A|
|00002490| 44 56 49 43 45 20 28 20 | 2d 2d 20 29 0a 58 20 20 |DVICE ( |-- ).X |
|000024a0| 70 74 72 20 20 2b 62 6c | 6f 63 6b 20 70 72 69 76 |ptr +bl|ock priv|
|000024b0| 61 74 65 09 09 09 28 20 | 50 6f 69 6e 74 65 72 20 |ate...( |Pointer |
|000024c0| 74 6f 20 63 6f 64 65 20 | 64 65 66 69 6e 69 74 69 |to code |definiti|
|000024d0| 6f 6e 29 0a 58 20 20 70 | 74 72 20 20 2b 65 6e 74 |on).X p|tr +ent|
|000024e0| 72 79 20 70 72 69 76 61 | 74 65 09 09 09 28 20 50 |ry priva|te...( P|
|000024f0| 6f 69 6e 74 65 72 20 74 | 6f 20 65 6e 74 72 79 20 |ointer t|o entry |
|00002500| 73 74 72 75 63 74 75 72 | 65 29 0a 58 20 20 70 74 |structur|e).X pt|
|00002510| 72 20 20 2b 61 64 76 69 | 63 65 20 70 72 69 76 61 |r +advi|ce priva|
|00002520| 74 65 09 09 09 28 20 50 | 6f 69 6e 74 65 72 20 74 |te...( P|ointer t|
|00002530| 6f 20 61 64 76 69 63 65 | 20 66 75 6e 63 74 69 6f |o advice| functio|
|00002540| 6e 29 0a 58 20 20 6c 6f | 6e 67 20 2b 70 72 6f 66 |n).X lo|ng +prof|
|00002550| 69 6c 65 20 70 72 69 76 | 61 74 65 09 09 09 28 20 |ile priv|ate...( |
|00002560| 43 61 6c 6c 20 63 6f 75 | 6e 74 65 72 20 66 6f 72 |Call cou|nter for|
|00002570| 20 70 72 6f 66 69 6c 69 | 6e 67 29 0a 58 73 74 72 | profili|ng).Xstr|
|00002580| 75 63 74 2e 65 6e 64 0a | 58 0a 58 3a 20 5b 61 64 |uct.end.|X.X: [ad|
|00002590| 76 69 63 65 5d 20 28 20 | 61 64 76 69 63 65 20 2d |vice] ( |advice -|
|000025a0| 2d 20 29 0a 58 20 20 64 | 75 70 20 2b 61 64 76 69 |- ).X d|up +advi|
|000025b0| 63 65 20 40 20 65 78 65 | 63 75 74 65 09 09 09 28 |ce @ exe|cute...(|
|000025c0| 20 41 63 63 65 73 73 20 | 61 6e 64 20 65 78 65 63 | Access |and exec|
|000025d0| 75 74 65 20 74 68 65 20 | 61 64 76 69 63 65 29 0a |ute the |advice).|
|000025e0| 58 3b 20 70 72 69 76 61 | 74 65 0a 58 0a 58 3a 20 |X; priva|te.X.X: |
|000025f0| 5b 63 6f 6c 6f 6e 5d 20 | 28 20 61 64 76 69 63 65 |[colon] |( advice|
|00002600| 20 2d 2d 20 29 0a 58 20 | 20 31 20 6f 76 65 72 20 | -- ).X | 1 over |
|00002610| 2b 70 72 6f 66 69 6c 65 | 20 2b 21 09 09 09 28 20 |+profile| +!...( |
|00002620| 49 6e 63 72 65 6d 65 6e | 74 20 70 72 6f 66 69 6c |Incremen|t profil|
|00002630| 65 20 63 6f 75 6e 74 65 | 72 29 0a 58 20 20 2b 62 |e counte|r).X +b|
|00002640| 6c 6f 63 6b 20 40 20 63 | 61 6c 6c 09 09 09 09 28 |lock @ c|all....(|
|00002650| 20 43 61 6c 6c 20 74 68 | 65 20 63 6f 64 65 20 64 | Call th|e code d|
|00002660| 65 66 69 6e 69 74 69 6f | 6e 29 0a 58 3b 20 70 72 |efinitio|n).X; pr|
|00002670| 69 76 61 74 65 0a 58 0a | 58 3a 20 5b 74 72 61 63 |ivate.X.|X: [trac|
|00002680| 65 5d 20 28 20 61 64 76 | 69 63 65 20 2d 2d 20 29 |e] ( adv|ice -- )|
|00002690| 0a 58 20 20 2e 22 20 2d | 2d 3e 20 22 20 64 75 70 |.X ." -|-> " dup|
|000026a0| 20 3e 72 20 2b 65 6e 74 | 72 79 20 40 20 2e 6e 61 | >r +ent|ry @ .na|
|000026b0| 6d 65 20 2e 73 20 63 72 | 09 28 20 50 72 69 6e 74 |me .s cr|.( Print|
|000026c0| 20 66 75 6e 63 74 69 6f | 6e 20 65 6e 74 72 79 29 | functio|n entry)|
|000026d0| 0a 58 20 20 72 40 20 5b | 63 6f 6c 6f 6e 5d 09 09 |.X r@ [|colon]..|
|000026e0| 09 09 28 20 43 61 6c 6c | 20 74 68 65 20 63 6f 64 |..( Call| the cod|
|000026f0| 65 20 64 65 66 69 6e 69 | 74 69 6f 6e 29 0a 58 20 |e defini|tion).X |
|00002700| 20 2e 22 20 3c 2d 2d 20 | 22 20 72 3e 20 2b 65 6e | ." <-- |" r> +en|
|00002710| 74 72 79 20 40 20 2e 6e | 61 6d 65 20 2e 73 20 63 |try @ .n|ame .s c|
|00002720| 72 20 09 28 20 50 72 69 | 6e 74 20 66 75 6e 63 74 |r .( Pri|nt funct|
|00002730| 69 6f 6e 20 65 78 69 74 | 29 0a 58 3b 20 70 72 69 |ion exit|).X; pri|
|00002740| 76 61 74 65 0a 58 0a 58 | 3a 20 5b 62 72 65 61 6b |vate.X.X|: [break|
|00002750| 5d 20 28 20 61 64 76 69 | 63 65 20 2d 2d 20 29 0a |] ( advi|ce -- ).|
|00002760| 58 20 20 3e 72 09 09 09 | 09 09 28 20 53 61 76 65 |X >r...|..( Save|
|00002770| 20 70 6f 69 6e 74 65 72 | 20 74 6f 20 61 64 76 69 | pointer| to advi|
|00002780| 63 65 20 62 6c 6f 63 6b | 29 0a 58 20 20 62 65 67 |ce block|).X beg|
|00002790| 69 6e 0a 58 20 20 20 20 | 2e 73 20 2e 22 20 20 42 |in.X |.s ." B|
|000027a0| 72 65 61 6b 20 61 74 3a | 20 22 09 09 09 28 20 50 |reak at:| "...( P|
|000027b0| 72 69 6e 74 20 73 74 61 | 63 6b 20 73 74 61 74 75 |rint sta|ck statu|
|000027c0| 73 20 61 6e 64 20 62 72 | 65 61 6b 29 0a 58 20 20 |s and br|eak).X |
|000027d0| 20 20 72 40 20 2b 65 6e | 74 72 79 20 40 20 2e 6e | r@ +en|try @ .n|
|000027e0| 61 6d 65 20 63 72 09 09 | 28 20 50 72 69 6e 74 20 |ame cr..|( Print |
|000027f0| 6e 61 6d 65 20 6f 66 20 | 65 6e 74 72 79 29 0a 58 |name of |entry).X|
|00002800| 20 20 20 20 5b 63 6f 6d | 70 69 6c 65 5d 20 61 73 | [com|pile] as|
|00002810| 63 69 69 09 09 09 28 20 | 53 63 61 6e 20 61 20 63 |cii...( |Scan a c|
|00002820| 6f 6d 6d 61 6e 64 29 0a | 58 20 20 20 20 63 61 73 |ommand).|X cas|
|00002830| 65 0a 58 20 20 20 20 20 | 20 61 73 63 69 69 20 61 |e.X | ascii a|
|00002840| 09 09 09 09 28 20 41 62 | 6f 72 74 20 63 6f 6d 6d |....( Ab|ort comm|
|00002850| 61 6e 64 29 0a 58 20 20 | 20 20 20 20 20 20 6f 66 |and).X | of|
|00002860| 20 61 62 6f 72 74 20 65 | 6e 64 6f 66 0a 58 20 20 | abort e|ndof.X |
|00002870| 20 20 20 20 61 73 63 69 | 69 20 63 09 09 09 09 28 | asci|i c....(|
|00002880| 20 43 61 6c 6c 20 63 6f | 6d 6d 61 6e 64 29 0a 58 | Call co|mmand).X|
|00002890| 09 6f 66 20 72 3e 20 5b | 63 6f 6c 6f 6e 5d 20 65 |.of r> [|colon] e|
|000028a0| 78 69 74 20 65 6e 64 6f | 66 0a 58 20 20 20 20 20 |xit endo|f.X |
|000028b0| 20 61 73 63 69 69 20 65 | 09 09 09 09 28 20 45 78 | ascii e|....( Ex|
|000028c0| 65 63 75 74 65 20 63 6f | 6d 6d 61 6e 64 29 0a 58 |ecute co|mmand).X|
|000028d0| 20 20 20 20 20 20 20 20 | 6f 66 20 72 40 20 5b 63 | |of r@ [c|
|000028e0| 6f 6c 6f 6e 5d 20 65 6e | 64 6f 66 0a 58 20 20 20 |olon] en|dof.X |
|000028f0| 20 20 20 61 73 63 69 69 | 20 66 09 09 09 09 28 20 | ascii| f....( |
|00002900| 46 6f 72 74 68 20 63 6f | 6d 6d 61 6e 64 29 0a 58 |Forth co|mmand).X|
|00002910| 20 20 20 20 20 20 20 20 | 6f 66 20 69 6e 74 65 72 | |of inter|
|00002920| 70 72 65 74 20 65 6e 64 | 6f 66 0a 58 20 20 20 20 |pret end|of.X |
|00002930| 20 20 61 73 63 69 69 20 | 70 09 09 09 09 28 20 50 | ascii |p....( P|
|00002940| 72 6f 66 69 6c 65 20 63 | 6f 6d 6d 61 6e 64 29 0a |rofile c|ommand).|
|00002950| 58 20 20 20 20 20 20 20 | 20 6f 66 20 72 40 20 2b |X | of r@ +|
|00002960| 70 72 6f 66 69 6c 65 20 | 40 20 2e 20 63 72 20 65 |profile |@ . cr e|
|00002970| 6e 64 6f 66 0a 58 20 20 | 20 20 20 20 61 73 63 69 |ndof.X | asci|
|00002980| 69 20 72 09 09 09 09 28 | 20 52 65 74 75 72 6e 20 |i r....(| Return |
|00002990| 63 6f 6d 6d 61 6e 64 29 | 0a 58 09 6f 66 20 72 3e |command)|.X.of r>|
|000029a0| 20 64 72 6f 70 20 65 78 | 69 74 20 65 6e 64 6f 66 | drop ex|it endof|
|000029b0| 0a 58 20 20 20 20 20 20 | 2e 22 20 61 28 62 6f 72 |.X |." a(bor|
|000029c0| 74 29 2c 20 63 28 6f 6e | 74 69 6e 75 65 29 2c 20 |t), c(on|tinue), |
|000029d0| 65 28 78 65 63 75 74 65 | 29 2c 20 70 28 72 6f 66 |e(xecute|), p(rof|
|000029e0| 69 6c 65 29 20 6f 72 20 | 72 28 65 74 75 72 6e 29 |ile) or |r(eturn)|
|000029f0| 22 20 63 72 0a 58 20 20 | 20 65 6e 64 63 61 73 65 |" cr.X | endcase|
|00002a00| 0a 58 20 20 20 61 67 61 | 69 6e 0a 58 3b 20 70 72 |.X aga|in.X; pr|
|00002a10| 69 76 61 74 65 0a 58 0a | 58 3a 20 74 61 69 6c 2d |ivate.X.|X: tail-|
|00002a20| 72 65 63 75 72 73 65 20 | 28 20 2d 2d 20 29 0a 58 |recurse |( -- ).X|
|00002a30| 20 20 63 6f 6d 70 69 6c | 65 20 28 62 72 61 6e 63 | compil|e (branc|
|00002a40| 68 29 09 09 09 28 20 43 | 6f 6d 70 69 6c 65 20 61 |h)...( C|ompile a|
|00002a50| 20 62 72 61 6e 63 68 20 | 74 6f 20 74 68 65 20 62 | branch |to the b|
|00002a60| 65 67 69 6e 6e 69 6e 67 | 29 0a 58 20 20 6c 61 73 |eginning|).X las|
|00002a70| 74 20 3e 62 6f 64 79 20 | 2b 62 6c 6f 63 6b 20 40 |t >body |+block @|
|00002a80| 20 3c 72 65 73 6f 6c 76 | 65 09 09 28 20 41 6e 64 | <resolv|e..( And|
|00002a90| 20 72 65 73 6f 6c 76 65 | 20 74 68 65 20 61 64 64 | resolve| the add|
|00002aa0| 72 65 73 73 29 0a 58 3b | 20 63 6f 6d 70 69 6c 61 |ress).X;| compila|
|00002ab0| 74 69 6f 6e 20 69 6d 6d | 65 64 69 61 74 65 0a 58 |tion imm|ediate.X|
|00002ac0| 0a 58 3a 20 3f 61 64 76 | 69 63 65 20 28 20 65 6e |.X: ?adv|ice ( en|
|00002ad0| 74 72 79 20 2d 2d 20 66 | 6c 61 67 29 0a 58 20 20 |try -- f|lag).X |
|00002ae0| 2b 63 6f 64 65 20 40 20 | 5b 27 5d 20 5b 61 64 76 |+code @ |['] [adv|
|00002af0| 69 63 65 5d 20 3e 62 6f | 64 79 20 3d 09 09 28 20 |ice] >bo|dy =..( |
|00002b00| 43 68 65 63 6b 20 66 6f | 72 20 61 64 76 69 63 65 |Check fo|r advice|
|00002b10| 20 68 61 6e 64 6c 65 72 | 29 0a 58 3b 0a 58 0a 58 | handler|).X;.X.X|
|00002b20| 3a 20 61 64 76 69 63 65 | 20 28 20 61 63 74 69 6f |: advice| ( actio|
|00002b30| 6e 20 2d 2d 20 29 0a 58 | 20 20 27 20 64 75 70 20 |n -- ).X| ' dup |
|00002b40| 3f 61 64 76 69 63 65 20 | 6e 6f 74 09 09 09 28 20 |?advice |not...( |
|00002b50| 41 63 63 65 73 73 20 65 | 6e 74 72 79 20 61 6e 64 |Access e|ntry and|
|00002b60| 20 63 68 65 63 6b 20 63 | 6f 64 69 6e 67 29 0a 58 | check c|oding).X|
|00002b70| 20 20 61 62 6f 72 74 22 | 20 61 64 76 69 63 65 3a | abort"| advice:|
|00002b80| 20 6e 6f 74 20 61 6e 20 | 61 64 76 69 63 65 64 20 | not an |adviced |
|00002b90| 64 65 66 69 6e 69 74 69 | 6f 6e 22 20 28 20 41 62 |definiti|on" ( Ab|
|00002ba0| 6f 72 74 20 69 66 20 77 | 72 6f 6e 67 20 63 6f 64 |ort if w|rong cod|
|00002bb0| 65 20 74 79 70 65 29 0a | 58 20 20 3e 62 6f 64 79 |e type).|X >body|
|00002bc0| 09 09 09 09 09 28 20 41 | 63 63 65 73 73 20 61 64 |.....( A|ccess ad|
|00002bd0| 76 69 63 65 20 62 6c 6f | 63 6b 29 0a 58 20 20 30 |vice blo|ck).X 0|
|00002be0| 20 6f 76 65 72 20 2b 70 | 72 6f 66 69 6c 65 20 21 | over +p|rofile !|
|00002bf0| 09 09 09 28 20 49 6e 69 | 74 69 61 74 65 20 74 68 |...( Ini|tiate th|
|00002c00| 65 20 70 72 6f 66 69 6c | 65 20 63 6f 75 6e 74 65 |e profil|e counte|
|00002c10| 72 29 0a 58 20 20 2b 61 | 64 76 69 63 65 20 21 20 |r).X +a|dvice ! |
|00002c20| 09 09 09 09 28 20 44 65 | 66 69 6e 65 20 61 20 6e |....( De|fine a n|
|00002c30| 65 77 20 61 64 76 69 63 | 65 20 61 63 74 69 6f 6e |ew advic|e action|
|00002c40| 29 0a 58 3b 0a 58 0a 58 | 3a 20 63 6f 6c 6f 6e 20 |).X;.X.X|: colon |
|00002c50| 28 20 2d 2d 20 29 0a 58 | 20 20 5b 27 5d 20 5b 63 |( -- ).X| ['] [c|
|00002c60| 6f 6c 6f 6e 5d 20 61 64 | 76 69 63 65 20 09 09 09 |olon] ad|vice ...|
|00002c70| 28 20 55 73 65 20 63 6f | 6c 6f 6e 20 61 73 20 74 |( Use co|lon as t|
|00002c80| 68 65 20 61 64 76 69 63 | 65 20 61 63 74 69 6f 6e |he advic|e action|
|00002c90| 29 0a 58 3b 0a 58 0a 58 | 3a 20 74 72 61 63 65 20 |).X;.X.X|: trace |
|00002ca0| 28 20 2d 2d 20 29 0a 58 | 20 20 5b 27 5d 20 5b 74 |( -- ).X| ['] [t|
|00002cb0| 72 61 63 65 5d 20 61 64 | 76 69 63 65 20 09 09 09 |race] ad|vice ...|
|00002cc0| 28 20 55 73 65 20 74 72 | 61 63 65 20 61 73 20 74 |( Use tr|ace as t|
|00002cd0| 68 65 20 61 64 76 69 63 | 65 20 61 63 74 69 6f 6e |he advic|e action|
|00002ce0| 29 0a 58 3b 0a 58 0a 58 | 3a 20 62 72 65 61 6b 20 |).X;.X.X|: break |
|00002cf0| 28 20 2d 2d 20 29 0a 58 | 20 20 5b 27 5d 20 5b 62 |( -- ).X| ['] [b|
|00002d00| 72 65 61 6b 5d 20 61 64 | 76 69 63 65 20 09 09 09 |reak] ad|vice ...|
|00002d10| 28 20 55 73 65 20 62 72 | 65 61 6b 20 61 73 20 74 |( Use br|eak as t|
|00002d20| 68 65 20 61 64 76 69 63 | 65 20 61 63 74 69 6f 6e |he advic|e action|
|00002d30| 29 0a 58 3b 0a 58 0a 58 | 3a 20 2e 70 72 6f 66 69 |).X;.X.X|: .profi|
|00002d40| 6c 65 20 28 20 2d 2d 20 | 29 0a 58 20 20 35 20 73 |le ( -- |).X 5 s|
|00002d50| 70 61 63 65 73 20 2e 22 | 20 43 61 6c 6c 73 22 09 |paces ."| Calls".|
|00002d60| 09 09 28 20 50 72 69 6e | 74 20 61 20 70 72 6f 66 |..( Prin|t a prof|
|00002d70| 69 6c 65 20 68 65 61 64 | 65 72 20 77 69 74 68 20 |ile head|er with |
|00002d80| 63 61 6c 6c 73 29 0a 58 | 20 20 31 20 73 70 61 63 |calls).X| 1 spac|
|00002d90| 65 73 20 2e 22 20 46 75 | 6e 63 74 69 6f 6e 22 20 |es ." Fu|nction" |
|00002da0| 63 72 09 09 28 20 41 6e | 64 20 74 68 65 20 6e 61 |cr..( An|d the na|
|00002db0| 6d 65 20 6f 66 20 74 68 | 65 20 66 75 6e 63 74 69 |me of th|e functi|
|00002dc0| 6f 6e 29 0a 58 20 20 6c | 61 73 74 09 09 09 09 09 |on).X l|ast.....|
|00002dd0| 28 20 50 72 69 6e 74 20 | 70 72 6f 66 69 6c 65 20 |( Print |profile |
|00002de0| 66 6f 72 20 61 6c 6c 20 | 64 65 66 69 6e 69 74 69 |for all |definiti|
|00002df0| 6f 6e 73 29 0a 58 20 20 | 62 6c 6f 63 6b 5b 20 28 |ons).X |block[ (|
|00002e00| 20 65 6e 74 72 79 20 2d | 2d 20 29 0a 58 20 20 20 | entry -|- ).X |
|00002e10| 20 64 75 70 20 3f 61 64 | 76 69 63 65 09 09 09 09 | dup ?ad|vice....|
|00002e20| 28 20 43 68 65 63 6b 20 | 66 6f 72 20 61 64 76 69 |( Check |for advi|
|00002e30| 63 65 64 20 66 75 6e 63 | 74 69 6f 6e 29 0a 58 20 |ced func|tion).X |
|00002e40| 20 20 20 69 66 20 64 75 | 70 20 3e 62 6f 64 79 20 | if du|p >body |
|00002e50| 2b 70 72 6f 66 69 6c 65 | 20 40 09 09 28 20 41 63 |+profile| @..( Ac|
|00002e60| 63 65 73 73 20 70 72 6f | 66 69 6c 65 20 69 6e 66 |cess pro|file inf|
|00002e70| 6f 72 6d 61 74 69 6f 6e | 29 0a 58 20 20 20 20 20 |ormation|).X |
|00002e80| 20 31 30 20 2e 72 20 73 | 70 61 63 65 09 09 09 28 | 10 .r s|pace...(|
|00002e90| 20 50 72 69 6e 74 20 69 | 6e 20 61 20 6e 69 63 65 | Print i|n a nice|
|00002ea0| 20 66 6f 72 6d 61 74 29 | 0a 58 20 20 20 20 20 20 | format)|.X |
|00002eb0| 2e 6e 61 6d 65 20 63 72 | 09 09 09 09 28 20 50 72 |.name cr|....( Pr|
|00002ec0| 69 6e 74 20 6e 61 6d 65 | 29 0a 58 20 20 20 20 65 |int name|).X e|
|00002ed0| 6c 73 65 0a 58 20 20 20 | 20 20 20 64 72 6f 70 0a |lse.X | drop.|
|00002ee0| 58 20 20 20 20 74 68 65 | 6e 0a 58 20 20 5d 3b 20 |X the|n.X ]; |
|00002ef0| 6d 61 70 2d 6c 69 73 74 | 0a 58 3b 0a 58 0a 58 3a |map-list|.X;.X.X:|
|00002f00| 20 3a 20 28 20 2d 2d 20 | 29 0a 58 20 20 3a 09 09 | : ( -- |).X :..|
|00002f10| 09 09 09 28 20 55 73 65 | 20 74 68 65 20 6f 6c 64 |...( Use| the old|
|00002f20| 20 63 6f 6c 6f 6e 20 64 | 65 66 69 6e 69 74 69 6f | colon d|efinitio|
|00002f30| 6e 29 0a 58 20 20 6e 65 | 77 20 41 44 56 49 43 45 |n).X ne|w ADVICE|
|00002f40| 09 09 09 09 28 20 43 72 | 65 61 74 65 20 61 6e 20 |....( Cr|eate an |
|00002f50| 61 64 76 69 63 65 20 62 | 6c 6f 63 6b 29 0a 58 20 |advice b|lock).X |
|00002f60| 20 64 75 70 20 6c 61 73 | 74 20 2b 70 61 72 61 6d | dup las|t +param|
|00002f70| 65 74 65 72 20 21 09 09 | 09 28 20 53 74 6f 72 65 |eter !..|.( Store|
|00002f80| 20 74 68 65 20 61 64 76 | 69 63 65 20 62 6c 6f 63 | the adv|ice bloc|
|00002f90| 6b 20 69 6e 74 6f 20 74 | 68 65 20 6c 61 73 74 29 |k into t|he last)|
|00002fa0| 0a 58 20 20 5b 27 5d 20 | 5b 61 64 76 69 63 65 5d |.X ['] |[advice]|
|00002fb0| 20 3e 62 6f 64 79 20 6c | 61 73 74 20 2b 63 6f 64 | >body l|ast +cod|
|00002fc0| 65 20 21 09 28 20 4d 61 | 6b 65 20 74 68 65 20 6c |e !.( Ma|ke the l|
|00002fd0| 61 73 74 20 65 6e 74 72 | 79 20 75 73 65 20 74 68 |ast entr|y use th|
|00002fe0| 65 20 61 64 76 69 63 65 | 29 0a 58 20 20 6c 61 73 |e advice|).X las|
|00002ff0| 74 20 6f 76 65 72 20 2b | 65 6e 74 72 79 20 21 09 |t over +|entry !.|
|00003000| 09 09 28 20 53 61 76 65 | 20 70 6f 69 6e 74 65 72 |..( Save| pointer|
|00003010| 20 74 6f 20 74 68 65 20 | 65 6e 74 72 79 29 0a 58 | to the |entry).X|
|00003020| 20 20 5b 27 5d 20 5b 63 | 6f 6c 6f 6e 5d 20 6f 76 | ['] [c|olon] ov|
|00003030| 65 72 20 2b 61 64 76 69 | 63 65 20 21 09 09 28 20 |er +advi|ce !..( |
|00003040| 43 6f 6c 6f 6e 20 69 73 | 20 74 68 65 20 69 6e 69 |Colon is| the ini|
|00003050| 74 69 61 74 65 20 61 64 | 76 69 63 65 20 61 63 74 |tiate ad|vice act|
|00003060| 69 6f 6e 29 0a 58 20 20 | 30 20 6f 76 65 72 20 2b |ion).X |0 over +|
|00003070| 70 72 6f 66 69 6c 65 20 | 21 09 09 09 28 20 49 6e |profile |!...( In|
|00003080| 69 74 69 61 74 65 20 74 | 68 65 20 70 72 6f 66 69 |itiate t|he profi|
|00003090| 6c 65 20 63 6f 75 6e 74 | 65 72 29 0a 58 20 20 68 |le count|er).X h|
|000030a0| 65 72 65 20 73 77 61 70 | 20 2b 62 6c 6f 63 6b 20 |ere swap| +block |
|000030b0| 21 20 09 09 09 28 20 53 | 65 74 75 70 20 70 6f 69 |! ...( S|etup poi|
|000030c0| 6e 74 65 72 20 74 6f 20 | 62 6c 6f 63 6b 20 64 65 |nter to |block de|
|000030d0| 66 69 6e 69 74 69 6f 6e | 29 0a 58 3b 0a 58 0a 58 |finition|).X;.X.X|
|000030e0| 66 6f 72 74 68 20 6f 6e | 6c 79 0a 45 4e 44 5f 4f |forth on|ly.END_O|
|000030f0| 46 5f 6c 69 62 2f 64 65 | 62 75 67 67 65 72 2e 66 |F_lib/de|bugger.f|
|00003100| 38 33 0a 69 66 20 74 65 | 73 74 20 34 36 35 32 20 |83.if te|st 4652 |
|00003110| 2d 6e 65 20 60 77 63 20 | 2d 63 20 3c 6c 69 62 2f |-ne `wc |-c <lib/|
|00003120| 64 65 62 75 67 67 65 72 | 2e 66 38 33 60 3b 20 74 |debugger|.f83`; t|
|00003130| 68 65 6e 0a 20 20 20 20 | 65 63 68 6f 20 73 68 61 |hen. |echo sha|
|00003140| 72 3a 20 5c 22 6c 69 62 | 2f 64 65 62 75 67 67 65 |r: \"lib|/debugge|
|00003150| 72 2e 66 38 33 5c 22 20 | 75 6e 70 61 63 6b 65 64 |r.f83\" |unpacked|
|00003160| 20 77 69 74 68 20 77 72 | 6f 6e 67 20 73 69 7a 65 | with wr|ong size|
|00003170| 21 0a 66 69 0a 23 20 65 | 6e 64 20 6f 66 20 6f 76 |!.fi.# e|nd of ov|
|00003180| 65 72 77 72 69 74 69 6e | 67 20 63 68 65 63 6b 0a |erwritin|g check.|
|00003190| 66 69 0a 69 66 20 74 65 | 73 74 20 2d 66 20 6c 69 |fi.if te|st -f li|
|000031a0| 62 2f 69 6e 74 65 72 6e | 61 6c 73 2e 66 38 33 20 |b/intern|als.f83 |
|000031b0| 2d 61 20 22 24 7b 31 7d | 22 20 21 3d 20 22 2d 63 |-a "${1}|" != "-c|
|000031c0| 22 20 3b 20 74 68 65 6e | 20 0a 20 20 65 63 68 6f |" ; then| . echo|
|000031d0| 20 73 68 61 72 3a 20 57 | 69 6c 6c 20 6e 6f 74 20 | shar: W|ill not |
|000031e0| 6f 76 65 72 2d 77 72 69 | 74 65 20 65 78 69 73 74 |over-wri|te exist|
|000031f0| 69 6e 67 20 66 69 6c 65 | 20 5c 22 6c 69 62 2f 69 |ing file| \"lib/i|
|00003200| 6e 74 65 72 6e 61 6c 73 | 2e 66 38 33 5c 22 0a 65 |nternals|.f83\".e|
|00003210| 6c 73 65 0a 65 63 68 6f | 20 73 68 61 72 3a 20 45 |lse.echo| shar: E|
|00003220| 78 74 72 61 63 74 69 6e | 67 20 5c 22 6c 69 62 2f |xtractin|g \"lib/|
|00003230| 69 6e 74 65 72 6e 61 6c | 73 2e 66 38 33 5c 22 20 |internal|s.f83\" |
|00003240| 5c 28 33 38 39 33 20 63 | 68 61 72 61 63 74 65 72 |\(3893 c|haracter|
|00003250| 73 5c 29 0a 73 65 64 20 | 22 73 2f 5e 58 2f 2f 22 |s\).sed |"s/^X//"|
|00003260| 20 3e 6c 69 62 2f 69 6e | 74 65 72 6e 61 6c 73 2e | >lib/in|ternals.|
|00003270| 66 38 33 20 3c 3c 27 45 | 4e 44 5f 4f 46 5f 6c 69 |f83 <<'E|ND_OF_li|
|00003280| 62 2f 69 6e 74 65 72 6e | 61 6c 73 2e 66 38 33 27 |b/intern|als.f83'|
|00003290| 0a 58 5c 0a 58 5c 20 20 | 49 4e 54 45 52 4e 41 4c |.X\.X\ |INTERNAL|
|000032a0| 20 54 49 4c 45 20 46 4f | 52 54 48 20 44 41 54 41 | TILE FO|RTH DATA|
|000032b0| 20 53 54 52 55 43 54 55 | 52 45 53 0a 58 5c 0a 58 | STRUCTU|RES.X\.X|
|000032c0| 5c 20 20 43 6f 70 79 72 | 69 67 68 74 20 28 63 29 |\ Copyr|ight (c)|
|000032d0| 20 31 39 38 38 2d 31 39 | 39 30 20 62 79 20 4d 69 | 1988-19|90 by Mi|
|000032e0| 6b 61 65 6c 20 52 2e 4b | 2e 20 50 61 74 65 6c 0a |kael R.K|. Patel.|
|000032f0| 58 5c 0a 58 5c 20 20 43 | 6f 6d 70 75 74 65 72 20 |X\.X\ C|omputer |
|00003300| 41 69 64 65 64 20 44 65 | 73 69 67 6e 20 4c 61 62 |Aided De|sign Lab|
|00003310| 6f 72 61 74 6f 72 79 20 | 28 43 41 44 4c 41 42 29 |oratory |(CADLAB)|
|00003320| 0a 58 5c 20 20 44 65 70 | 61 72 74 6d 65 6e 74 20 |.X\ Dep|artment |
|00003330| 6f 66 20 43 6f 6d 70 75 | 74 65 72 20 61 6e 64 20 |of Compu|ter and |
|00003340| 49 6e 66 6f 72 6d 61 74 | 69 6f 6e 20 53 63 69 65 |Informat|ion Scie|
|00003350| 6e 63 65 0a 58 5c 20 20 | 4c 69 6e 6b 6f 70 69 6e |nce.X\ |Linkopin|
|00003360| 67 20 55 6e 69 76 65 72 | 73 69 74 79 0a 58 5c 20 |g Univer|sity.X\ |
|00003370| 20 53 2d 35 38 31 20 38 | 33 20 4c 49 4e 4b 4f 50 | S-581 8|3 LINKOP|
|00003380| 49 4e 47 0a 58 5c 20 20 | 53 57 45 44 45 4e 0a 58 |ING.X\ |SWEDEN.X|
|00003390| 5c 0a 58 5c 20 20 45 6d | 61 69 6c 3a 20 6d 69 70 |\.X\ Em|ail: mip|
|000033a0| 40 69 64 61 2e 6c 69 75 | 2e 73 65 0a 58 5c 0a 58 |@ida.liu|.se.X\.X|
|000033b0| 5c 20 20 53 74 61 72 74 | 65 64 20 6f 6e 3a 20 33 |\ Start|ed on: 3|
|000033c0| 30 20 4a 75 6e 65 20 31 | 39 38 38 0a 58 5c 0a 58 |0 June 1|988.X\.X|
|000033d0| 5c 20 20 4c 61 73 74 20 | 75 70 64 61 74 65 64 20 |\ Last |updated |
|000033e0| 6f 6e 3a 20 31 39 20 4a | 75 6e 65 20 31 39 39 30 |on: 19 J|une 1990|
|000033f0| 0a 58 5c 0a 58 5c 20 20 | 44 65 70 65 6e 64 65 6e |.X\.X\ |Dependen|
|00003400| 63 69 65 73 3a 0a 58 5c | 20 20 20 20 20 20 20 28 |cies:.X\| (|
|00003410| 66 6f 72 74 68 29 20 66 | 6f 72 74 68 2c 20 73 74 |forth) f|orth, st|
|00003420| 72 69 6e 67 2c 20 65 6e | 75 6d 65 72 61 74 65 73 |ring, en|umerates|
|00003430| 2c 20 62 69 74 66 69 65 | 6c 64 73 2c 20 73 74 72 |, bitfie|lds, str|
|00003440| 75 63 74 75 72 65 73 2c | 0a 58 5c 20 20 20 20 20 |uctures,|.X\ |
|00003450| 20 20 20 20 20 20 20 20 | 20 20 62 6c 6f 63 6b 73 | | blocks|
|00003460| 2c 20 6c 69 73 74 73 2c | 20 61 6e 64 20 73 65 74 |, lists,| and set|
|00003470| 73 2e 0a 58 5c 0a 58 5c | 20 20 44 65 73 63 72 69 |s..X\.X\| Descri|
|00003480| 70 74 69 6f 6e 3a 0a 58 | 5c 20 20 20 20 20 20 20 |ption:.X|\ |
|00003490| 48 69 67 68 20 6c 65 76 | 65 6c 20 65 78 74 65 6e |High lev|el exten|
|000034a0| 73 69 6f 6e 73 20 74 6f | 20 74 68 65 20 66 6f 72 |sions to| the for|
|000034b0| 74 68 20 6b 65 72 6e 65 | 6c 2e 20 49 6d 70 6c 65 |th kerne|l. Imple|
|000034c0| 6d 65 6e 74 61 74 69 6f | 6e 0a 58 5c 20 20 20 20 |mentatio|n.X\ |
|000034d0| 20 20 20 64 65 70 65 6e | 64 65 6e 74 20 73 65 63 | depen|dent sec|
|000034e0| 74 69 6f 6e 73 20 73 75 | 63 68 20 61 73 20 65 6e |tions su|ch as en|
|000034f0| 74 72 79 20 61 6e 64 20 | 76 6f 63 61 62 75 6c 61 |try and |vocabula|
|00003500| 72 79 20 73 74 72 75 63 | 74 75 72 65 73 2e 0a 58 |ry struc|tures..X|
|00003510| 5c 0a 58 5c 20 20 43 6f | 70 79 69 6e 67 3a 0a 58 |\.X\ Co|pying:.X|
|00003520| 5c 20 20 20 20 20 20 20 | 54 68 69 73 20 70 72 6f |\ |This pro|
|00003530| 67 72 61 6d 20 69 73 20 | 66 72 65 65 20 73 6f 66 |gram is |free sof|
|00003540| 74 77 61 72 65 3b 20 79 | 6f 75 20 63 61 6e 20 72 |tware; y|ou can r|
|00003550| 65 64 69 73 74 72 69 62 | 75 74 65 20 69 74 20 61 |edistrib|ute it a|
|00003560| 6e 64 5c 6f 72 20 6d 6f | 64 69 66 79 0a 58 5c 20 |nd\or mo|dify.X\ |
|00003570| 20 20 20 20 20 20 69 74 | 20 75 6e 64 65 72 20 74 | it| under t|
|00003580| 68 65 20 74 65 72 6d 73 | 20 6f 66 20 74 68 65 20 |he terms| of the |
|00003590| 47 4e 55 20 47 65 6e 65 | 72 61 6c 20 50 75 62 6c |GNU Gene|ral Publ|
|000035a0| 69 63 20 4c 69 63 65 6e | 73 65 20 61 73 20 70 75 |ic Licen|se as pu|
|000035b0| 62 6c 69 73 68 65 64 20 | 62 79 0a 58 5c 20 20 20 |blished |by.X\ |
|000035c0| 20 20 20 20 74 68 65 20 | 46 72 65 65 20 53 6f 66 | the |Free Sof|
|000035d0| 74 77 61 72 65 20 46 6f | 75 6e 64 61 74 69 6f 6e |tware Fo|undation|
|000035e0| 3b 20 65 69 74 68 65 72 | 20 76 65 72 73 69 6f 6e |; either| version|
|000035f0| 20 31 2c 20 6f 72 20 28 | 61 74 20 79 6f 75 72 20 | 1, or (|at your |
|00003600| 6f 70 74 69 6f 6e 29 0a | 58 5c 20 20 20 20 20 20 |option).|X\ |
|00003610| 20 61 6e 79 20 6c 61 74 | 65 72 20 76 65 72 73 69 | any lat|er versi|
|00003620| 6f 6e 2e 0a 58 5c 0a 58 | 5c 20 20 20 20 20 20 20 |on..X\.X|\ |
|00003630| 54 68 69 73 20 70 72 6f | 67 72 61 6d 20 69 73 20 |This pro|gram is |
|00003640| 64 69 73 74 72 69 62 75 | 74 65 64 20 69 6e 20 74 |distribu|ted in t|
|00003650| 68 65 20 68 6f 70 65 20 | 74 68 61 74 20 69 74 20 |he hope |that it |
|00003660| 77 69 6c 6c 20 62 65 20 | 75 73 65 66 75 6c 2c 0a |will be |useful,.|
|00003670| 58 5c 20 20 20 20 20 20 | 20 62 75 74 20 57 49 54 |X\ | but WIT|
|00003680| 48 4f 55 54 20 41 4e 59 | 20 57 41 52 52 41 4e 54 |HOUT ANY| WARRANT|
|00003690| 59 3b 20 77 69 74 68 6f | 75 74 20 65 76 65 6e 20 |Y; witho|ut even |
|000036a0| 74 68 65 20 69 6d 70 6c | 69 65 64 20 77 61 72 72 |the impl|ied warr|
|000036b0| 61 6e 74 79 20 6f 66 0a | 58 5c 20 20 20 20 20 20 |anty of.|X\ |
|000036c0| 20 4d 45 52 43 48 41 4e | 54 41 42 49 4c 49 54 59 | MERCHAN|TABILITY|
|000036d0| 20 6f 72 20 46 49 54 4e | 45 53 53 20 46 4f 52 20 | or FITN|ESS FOR |
|000036e0| 41 20 50 41 52 54 49 43 | 55 4c 41 52 20 50 55 52 |A PARTIC|ULAR PUR|
|000036f0| 50 4f 53 45 2e 20 20 53 | 65 65 20 74 68 65 0a 58 |POSE. S|ee the.X|
|00003700| 5c 20 20 20 20 20 20 20 | 47 4e 55 20 47 65 6e 65 |\ |GNU Gene|
|00003710| 72 61 6c 20 50 75 62 6c | 69 63 20 4c 69 63 65 6e |ral Publ|ic Licen|
|00003720| 73 65 20 66 6f 72 20 6d | 6f 72 65 20 64 65 74 61 |se for m|ore deta|
|00003730| 69 6c 73 2e 0a 58 5c 0a | 58 5c 20 20 20 20 20 20 |ils..X\.|X\ |
|00003740| 20 59 6f 75 20 73 68 6f | 75 6c 64 20 68 61 76 65 | You sho|uld have|
|00003750| 20 72 65 63 65 69 76 65 | 64 20 61 20 63 6f 70 79 | receive|d a copy|
|00003760| 20 6f 66 20 74 68 65 20 | 47 4e 55 20 47 65 6e 65 | of the |GNU Gene|
|00003770| 72 61 6c 20 50 75 62 6c | 69 63 20 4c 69 63 65 6e |ral Publ|ic Licen|
|00003780| 73 65 0a 58 5c 20 20 20 | 20 20 20 20 61 6c 6f 6e |se.X\ | alon|
|00003790| 67 20 77 69 74 68 20 74 | 68 69 73 20 70 72 6f 67 |g with t|his prog|
|000037a0| 72 61 6d 3b 20 73 65 65 | 20 74 68 65 20 66 69 6c |ram; see| the fil|
|000037b0| 65 20 43 4f 50 59 49 4e | 47 2e 20 20 49 66 20 6e |e COPYIN|G. If n|
|000037c0| 6f 74 2c 20 77 72 69 74 | 65 20 74 6f 0a 58 5c 20 |ot, writ|e to.X\ |
|000037d0| 20 20 20 20 20 20 74 68 | 65 20 46 72 65 65 20 53 | th|e Free S|
|000037e0| 6f 66 74 77 61 72 65 20 | 46 6f 75 6e 64 61 74 69 |oftware |Foundati|
|000037f0| 6f 6e 2c 20 36 37 35 20 | 4d 61 73 73 20 41 76 65 |on, 675 |Mass Ave|
|00003800| 2c 20 43 61 6d 62 72 69 | 64 67 65 2c 20 4d 41 20 |, Cambri|dge, MA |
|00003810| 30 32 31 33 39 2c 20 55 | 53 41 2e 20 0a 58 0a 58 |02139, U|SA. .X.X|
|00003820| 2e 28 20 4c 6f 61 64 69 | 6e 67 20 49 6e 74 65 72 |.( Loadi|ng Inter|
|00003830| 6e 61 6c 20 64 65 66 69 | 6e 69 74 69 6f 6e 73 2e |nal defi|nitions.|
|00003840| 2e 2e 29 20 63 72 0a 58 | 0a 58 23 69 6e 63 6c 75 |..) cr.X|.X#inclu|
|00003850| 64 65 20 65 6e 75 6d 65 | 72 61 74 65 73 2e 66 38 |de enume|rates.f8|
|00003860| 33 0a 58 23 69 6e 63 6c | 75 64 65 20 62 69 74 66 |3.X#incl|ude bitf|
|00003870| 69 65 6c 64 73 2e 66 38 | 33 0a 58 23 69 6e 63 6c |ields.f8|3.X#incl|
|00003880| 75 64 65 20 73 74 72 75 | 63 74 75 72 65 73 2e 66 |ude stru|ctures.f|
|00003890| 38 33 0a 58 23 69 6e 63 | 6c 75 64 65 20 62 6c 6f |83.X#inc|lude blo|
|000038a0| 63 6b 73 2e 66 38 33 0a | 58 23 69 6e 63 6c 75 64 |cks.f83.|X#includ|
|000038b0| 65 20 6c 69 73 74 73 2e | 66 38 33 0a 58 23 69 6e |e lists.|f83.X#in|
|000038c0| 63 6c 75 64 65 20 73 65 | 74 73 2e 66 38 33 0a 58 |clude se|ts.f83.X|
|000038d0| 0a 58 73 65 74 73 20 6c | 69 73 74 73 20 62 6c 6f |.Xsets l|ists blo|
|000038e0| 63 6b 73 20 62 69 74 66 | 69 65 6c 64 73 20 73 74 |cks bitf|ields st|
|000038f0| 72 75 63 74 75 72 65 73 | 20 65 6e 75 6d 65 72 61 |ructures| enumera|
|00003900| 74 65 73 20 73 74 72 69 | 6e 67 20 66 6f 72 74 68 |tes stri|ng forth|
|00003910| 20 64 65 66 69 6e 69 74 | 69 6f 6e 73 0a 58 0a 58 | definit|ions.X.X|
|00003920| 28 20 4d 65 6d 6f 72 79 | 20 77 6f 72 64 20 73 69 |( Memory| word si|
|00003930| 7a 65 20 61 6e 64 20 69 | 6e 74 65 67 65 72 20 72 |ze and i|nteger r|
|00003940| 61 6e 67 65 29 0a 58 0a | 58 38 20 20 20 20 20 20 |ange).X.|X8 |
|00003950| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00003960| 63 6f 6e 73 74 61 6e 74 | 20 42 49 54 53 2f 42 59 |constant| BITS/BY|
|00003970| 54 45 0a 58 63 65 6c 6c | 20 20 20 20 20 20 20 20 |TE.Xcell| |
|00003980| 20 20 20 20 20 20 20 20 | 20 20 20 63 6f 6e 73 74 | | const|
|00003990| 61 6e 74 20 42 59 54 45 | 53 2f 57 4f 52 44 0a 58 |ant BYTE|S/WORD.X|
|000039a0| 42 59 54 45 53 2f 57 4f | 52 44 20 42 49 54 53 2f |BYTES/WO|RD BITS/|
|000039b0| 42 59 54 45 20 2a 20 63 | 6f 6e 73 74 61 6e 74 20 |BYTE * c|onstant |
|000039c0| 42 49 54 53 2f 57 4f 52 | 44 0a 58 0a 58 31 20 42 |BITS/WOR|D.X.X1 B|
|000039d0| 49 54 53 2f 57 4f 52 44 | 20 31 2d 20 3c 3c 20 63 |ITS/WORD| 1- << c|
|000039e0| 6f 6e 73 74 61 6e 74 20 | 4d 49 4e 5f 49 4e 54 0a |onstant |MIN_INT.|
|000039f0| 58 4d 49 4e 5f 49 4e 54 | 20 31 2d 20 20 20 20 20 |XMIN_INT| 1- |
|00003a00| 20 20 20 63 6f 6e 73 74 | 61 6e 74 20 4d 41 58 5f | const|ant MAX_|
|00003a10| 49 4e 54 0a 58 0a 58 28 | 20 45 6e 74 72 79 20 61 |INT.X.X(| Entry a|
|00003a20| 6e 64 20 76 6f 63 61 62 | 75 6c 61 72 79 20 73 74 |nd vocab|ulary st|
|00003a30| 72 75 63 74 75 72 65 73 | 29 0a 58 0a 58 73 74 72 |ructures|).X.Xstr|
|00003a40| 75 63 74 2e 74 79 70 65 | 20 45 4e 54 52 59 20 28 |uct.type| ENTRY (|
|00003a50| 20 2d 2d 20 29 0a 58 20 | 20 70 74 72 20 20 2b 6c | -- ).X | ptr +l|
|00003a60| 69 6e 6b 09 09 09 09 28 | 20 50 6f 69 6e 74 65 72 |ink....(| Pointer|
|00003a70| 20 74 6f 20 70 72 65 76 | 69 6f 75 73 20 65 6e 74 | to prev|ious ent|
|00003a80| 72 79 29 0a 58 20 20 70 | 74 72 20 20 2b 6e 61 6d |ry).X p|tr +nam|
|00003a90| 65 09 09 09 09 28 20 50 | 6f 69 6e 74 65 72 20 74 |e....( P|ointer t|
|00003aa0| 6f 20 6e 75 6c 6c 2d 65 | 6e 64 65 64 20 73 74 72 |o null-e|nded str|
|00003ab0| 69 6e 67 29 0a 58 20 20 | 6c 6f 6e 67 20 2b 6d 6f |ing).X |long +mo|
|00003ac0| 64 65 09 09 09 09 28 20 | 4d 6f 64 65 20 62 69 74 |de....( |Mode bit|
|00003ad0| 20 66 69 65 6c 64 29 0a | 58 20 20 6c 6f 6e 67 20 | field).|X long |
|00003ae0| 2b 63 6f 64 65 09 09 09 | 09 28 20 43 6f 64 65 20 |+code...|.( Code |
|00003af0| 74 79 70 65 20 6f 72 20 | 70 6f 69 6e 74 65 72 20 |type or |pointer |
|00003b00| 74 6f 20 63 6f 64 65 29 | 0a 58 20 20 6c 6f 6e 67 |to code)|.X long|
|00003b10| 20 2b 70 61 72 61 6d 65 | 74 65 72 09 09 09 28 20 | +parame|ter...( |
|00003b20| 50 61 72 61 6d 65 74 65 | 72 20 66 69 65 6c 64 20 |Paramete|r field |
|00003b30| 6f 72 20 70 6f 69 6e 74 | 65 72 20 74 6f 20 64 69 |or point|er to di|
|00003b40| 74 6f 29 0a 58 73 74 72 | 75 63 74 2e 65 6e 64 0a |to).Xstr|uct.end.|
|00003b50| 58 0a 58 62 69 74 66 69 | 65 6c 64 2e 74 79 70 65 |X.Xbitfi|eld.type|
|00003b60| 20 4d 4f 44 45 53 20 28 | 20 2d 2d 20 29 0a 58 20 | MODES (| -- ).X |
|00003b70| 20 62 69 74 20 20 49 4d | 4d 45 44 49 41 54 45 09 | bit IM|MEDIATE.|
|00003b80| 09 09 28 20 45 78 65 63 | 75 74 69 6f 6e 20 61 6c |..( Exec|ution al|
|00003b90| 77 61 79 73 29 0a 58 20 | 20 62 69 74 20 20 45 58 |ways).X | bit EX|
|00003ba0| 45 43 55 54 49 4f 4e 09 | 09 09 28 20 45 78 65 63 |ECUTION.|..( Exec|
|00003bb0| 75 74 69 6f 6e 20 6f 6e | 6c 79 29 0a 58 20 20 62 |ution on|ly).X b|
|00003bc0| 69 74 20 20 43 4f 4d 50 | 49 4c 41 54 49 4f 4e 09 |it COMP|ILATION.|
|00003bd0| 09 09 28 20 43 6f 6d 70 | 69 6c 61 74 69 6f 6e 20 |..( Comp|ilation |
|00003be0| 6f 6e 6c 79 29 0a 58 20 | 20 62 69 74 20 20 50 52 |only).X | bit PR|
|00003bf0| 49 56 41 54 45 09 09 09 | 09 28 20 50 72 69 76 61 |IVATE...|.( Priva|
|00003c00| 74 65 20 6f 6e 6c 79 29 | 0a 58 34 20 62 69 74 73 |te only)|.X4 bits|
|00003c10| 20 52 45 53 45 52 56 45 | 44 09 09 09 09 28 20 42 | RESERVE|D....( B|
|00003c20| 69 74 20 66 69 65 6c 64 | 73 20 72 65 73 65 72 76 |it field|s reserv|
|00003c30| 65 64 20 66 6f 72 20 66 | 75 74 75 72 65 20 75 73 |ed for f|uture us|
|00003c40| 65 29 0a 58 62 69 74 66 | 69 65 6c 64 2e 65 6e 64 |e).Xbitf|ield.end|
|00003c50| 09 09 09 09 28 20 42 69 | 74 20 38 2d 33 31 20 61 |....( Bi|t 8-31 a|
|00003c60| 72 65 20 66 72 65 65 20 | 66 6f 72 20 61 70 70 6c |re free |for appl|
|00003c70| 69 63 61 74 69 6f 6e 73 | 29 0a 58 20 0a 58 65 6e |ications|).X .Xen|
|00003c80| 75 6d 2e 74 79 70 65 20 | 43 4f 44 45 53 20 28 20 |um.type |CODES ( |
|00003c90| 2d 2d 20 29 0a 58 20 20 | 65 6e 75 6d 20 43 4f 44 |-- ).X |enum COD|
|00003ca0| 45 09 09 09 09 28 20 50 | 72 69 6d 69 74 69 76 65 |E....( P|rimitive|
|00003cb0| 20 63 6f 64 65 29 0a 58 | 20 20 65 6e 75 6d 20 43 | code).X| enum C|
|00003cc0| 4f 4c 4f 4e 09 09 09 09 | 28 20 43 6f 6c 6f 6e 20 |OLON....|( Colon |
|00003cd0| 64 65 66 69 6e 69 74 69 | 6f 6e 29 0a 58 20 20 65 |definiti|on).X e|
|00003ce0| 6e 75 6d 20 56 41 52 49 | 41 42 4c 45 09 09 09 09 |num VARI|ABLE....|
|00003cf0| 28 20 56 61 72 69 61 62 | 6c 65 29 0a 58 20 20 65 |( Variab|le).X e|
|00003d00| 6e 75 6d 20 43 4f 4e 53 | 54 41 4e 54 09 09 09 09 |num CONS|TANT....|
|00003d10| 28 20 43 6f 6e 73 74 61 | 6e 74 29 0a 58 20 20 65 |( Consta|nt).X e|
|00003d20| 6e 75 6d 20 56 4f 43 41 | 42 55 4c 41 52 59 09 09 |num VOCA|BULARY..|
|00003d30| 09 28 20 56 6f 63 61 62 | 75 6c 61 72 79 29 0a 58 |.( Vocab|ulary).X|
|00003d40| 20 20 65 6e 75 6d 20 43 | 52 45 41 54 45 09 09 09 | enum C|REATE...|
|00003d50| 09 28 20 43 72 65 61 74 | 65 64 20 73 79 6d 62 6f |.( Creat|ed symbo|
|00003d60| 6c 29 0a 58 20 20 65 6e | 75 6d 20 55 53 45 52 09 |l).X en|um USER.|
|00003d70| 09 09 09 28 20 55 73 65 | 72 20 76 61 72 69 61 62 |...( Use|r variab|
|00003d80| 6c 65 20 6c 6f 63 61 6c | 20 74 6f 20 74 61 73 6b |le local| to task|
|00003d90| 29 0a 58 20 20 65 6e 75 | 6d 20 4c 4f 43 41 4c 09 |).X enu|m LOCAL.|
|00003da0| 09 09 09 28 20 4c 6f 63 | 61 6c 20 66 72 61 6d 65 |...( Loc|al frame|
|00003db0| 20 76 61 72 69 61 62 6c | 65 29 0a 58 20 20 65 6e | variabl|e).X en|
|00003dc0| 75 6d 20 46 4f 52 57 41 | 52 44 09 09 09 09 28 20 |um FORWA|RD....( |
|00003dd0| 46 6f 72 77 61 72 64 20 | 72 65 66 65 72 65 6e 63 |Forward |referenc|
|00003de0| 65 29 0a 58 20 20 65 6e | 75 6d 20 46 49 45 4c 44 |e).X en|um FIELD|
|00003df0| 09 09 09 09 28 20 46 69 | 65 6c 64 20 61 63 63 65 |....( Fi|eld acce|
|00003e00| 73 73 20 76 61 72 69 61 | 62 6c 65 29 0a 58 20 20 |ss varia|ble).X |
|00003e10| 65 6e 75 6d 20 45 58 43 | 45 50 54 49 4f 4e 09 09 |enum EXC|EPTION..|
|00003e20| 09 28 20 45 78 63 65 70 | 74 69 6f 6e 20 76 61 72 |.( Excep|tion var|
|00003e30| 69 61 62 6c 65 29 0a 58 | 65 6e 75 6d 2e 65 6e 64 |iable).X|enum.end|
|00003e40| 09 09 09 09 28 20 4f 74 | 68 65 72 77 69 73 65 20 |....( Ot|herwise |
|00003e50| 66 6f 72 74 68 20 6c 65 | 76 65 6c 20 6d 61 6e 61 |forth le|vel mana|
|00003e60| 67 65 72 29 0a 58 20 20 | 0a 58 3a 20 2e 65 6e 74 |ger).X |.X: .ent|
|00003e70| 72 79 20 28 20 65 6e 74 | 72 79 20 2d 2d 20 29 0a |ry ( ent|ry -- ).|
|00003e80| 58 20 20 2e 22 20 65 6e | 74 72 79 23 22 20 64 75 |X ." en|try#" du|
|00003e90| 70 20 2e 20 63 72 09 09 | 09 28 20 50 72 69 6e 74 |p . cr..|.( Print|
|00003ea0| 20 65 6e 74 72 79 20 61 | 64 64 72 65 73 73 29 0a | entry a|ddress).|
|00003eb0| 58 20 20 2e 22 20 6c 69 | 6e 6b 3a 20 22 20 64 75 |X ." li|nk: " du|
|00003ec0| 70 20 2b 6c 69 6e 6b 20 | 40 20 2e 20 63 72 09 09 |p +link |@ . cr..|
|00003ed0| 28 20 50 72 69 6e 74 20 | 6c 69 6e 6b 29 0a 58 20 |( Print |link).X |
|00003ee0| 20 2e 22 20 6e 61 6d 65 | 3a 20 22 20 64 75 70 20 | ." name|: " dup |
|00003ef0| 2b 6e 61 6d 65 20 40 20 | 24 2e 20 63 72 09 09 28 |+name @ |$. cr..(|
|00003f00| 20 50 72 69 6e 74 20 6e | 61 6d 65 29 0a 58 20 20 | Print n|ame).X |
|00003f10| 2e 22 20 6d 6f 64 65 3a | 20 22 20 64 75 70 20 2b |." mode:| " dup +|
|00003f20| 6d 6f 64 65 20 40 20 2e | 20 63 72 09 09 28 20 50 |mode @ .| cr..( P|
|00003f30| 72 69 6e 74 20 6d 6f 64 | 65 29 0a 58 20 20 2e 22 |rint mod|e).X ."|
|00003f40| 20 63 6f 64 65 3a 20 22 | 20 64 75 70 20 2b 63 6f | code: "| dup +co|
|00003f50| 64 65 20 40 20 2e 20 63 | 72 09 09 28 20 50 72 69 |de @ . c|r..( Pri|
|00003f60| 6e 74 20 63 6f 64 65 29 | 0a 58 20 20 2e 22 20 70 |nt code)|.X ." p|
|00003f70| 61 72 61 6d 65 74 65 72 | 3a 20 22 20 2b 70 61 72 |arameter|: " +par|
|00003f80| 61 6d 65 74 65 72 20 40 | 20 2e 20 09 28 20 50 72 |ameter @| . .( Pr|
|00003f90| 69 6e 74 20 70 61 72 61 | 6d 65 74 65 72 20 66 69 |int para|meter fi|
|00003fa0| 65 6c 64 29 0a 58 3b 0a | 58 0a 58 3a 20 2e 63 6f |eld).X;.|X.X: .co|
|00003fb0| 6e 74 65 78 74 20 28 20 | 2d 2d 20 29 0a 58 20 20 |ntext ( |-- ).X |
|00003fc0| 2e 22 20 63 6f 6e 74 65 | 78 74 3a 20 22 20 63 6f |." conte|xt: " co|
|00003fd0| 6e 74 65 78 74 09 09 09 | 28 20 41 63 63 65 73 73 |ntext...|( Access|
|00003fe0| 20 63 6f 6e 74 65 78 74 | 20 76 6f 63 61 62 75 6c | context| vocabul|
|00003ff0| 61 72 79 20 73 65 74 29 | 0a 58 20 20 62 6c 6f 63 |ary set)|.X bloc|
|00004000| 6b 5b 20 28 20 65 6e 74 | 72 79 20 2d 2d 20 29 0a |k[ ( ent|ry -- ).|
|00004010| 58 20 20 20 20 2e 6e 61 | 6d 65 20 73 70 61 63 65 |X .na|me space|
|00004020| 09 09 09 09 28 20 50 72 | 69 6e 74 20 6e 61 6d 65 |....( Pr|int name|
|00004030| 20 6f 66 20 61 6c 6c 20 | 76 6f 63 61 62 75 6c 61 | of all |vocabula|
|00004040| 72 69 65 73 29 0a 58 20 | 20 5d 3b 20 0a 58 20 20 |ries).X | ]; .X |
|00004050| 6d 61 70 2d 73 65 74 0a | 58 3b 0a 58 0a 58 3a 20 |map-set.|X;.X.X: |
|00004060| 2e 63 75 72 72 65 6e 74 | 20 28 20 2d 2d 20 29 0a |.current| ( -- ).|
|00004070| 58 20 20 2e 22 20 63 75 | 72 72 65 6e 74 3a 20 22 |X ." cu|rrent: "|
|00004080| 20 63 75 72 72 65 6e 74 | 20 40 20 2e 6e 61 6d 65 | current| @ .name|
|00004090| 20 73 70 61 63 65 20 09 | 28 20 50 72 69 6e 74 20 | space .|( Print |
|000040a0| 6e 61 6d 65 20 6f 66 20 | 63 75 72 72 65 6e 74 20 |name of |current |
|000040b0| 76 6f 63 61 62 75 6c 61 | 72 79 29 0a 58 3b 0a 58 |vocabula|ry).X;.X|
|000040c0| 0a 58 3a 20 2e 65 6e 74 | 72 69 65 73 20 28 20 74 |.X: .ent|ries ( t|
|000040d0| 79 70 65 20 2d 2d 20 29 | 0a 58 20 20 63 6f 6e 74 |ype -- )|.X cont|
|000040e0| 65 78 74 09 09 09 09 28 | 20 41 63 63 65 73 73 20 |ext....(| Access |
|000040f0| 73 65 61 72 63 68 20 76 | 6f 63 61 62 75 6c 61 72 |search v|ocabular|
|00004100| 69 65 73 29 0a 58 20 20 | 62 6c 6f 63 6b 5b 20 28 |ies).X |block[ (|
|00004110| 20 74 79 70 65 20 76 6f | 63 61 62 75 6c 61 72 79 | type vo|cabulary|
|00004120| 20 2d 2d 20 74 79 70 65 | 29 0a 58 20 20 20 20 2b | -- type|).X +|
|00004130| 70 61 72 61 6d 65 74 65 | 72 20 40 09 09 09 28 20 |paramete|r @...( |
|00004140| 41 63 63 65 73 73 20 6c | 69 73 74 20 6f 66 20 65 |Access l|ist of e|
|00004150| 6e 74 72 69 65 73 29 0a | 58 20 20 20 20 62 6c 6f |ntries).|X blo|
|00004160| 63 6b 5b 20 28 20 74 79 | 70 65 20 65 6e 74 72 79 |ck[ ( ty|pe entry|
|00004170| 20 2d 2d 20 74 79 70 65 | 29 0a 58 20 20 20 20 20 | -- type|).X |
|00004180| 20 32 64 75 70 20 2b 63 | 6f 64 65 20 40 20 3d 09 | 2dup +c|ode @ =.|
|00004190| 09 09 28 20 43 68 65 63 | 6b 20 69 66 20 74 68 65 |..( Chec|k if the|
|000041a0| 20 65 6e 74 72 79 20 69 | 73 20 61 20 76 6f 63 61 | entry i|s a voca|
|000041b0| 62 75 6c 61 72 79 29 0a | 58 20 20 20 20 20 20 69 |bulary).|X i|
|000041c0| 66 20 2e 6e 61 6d 65 20 | 73 70 61 63 65 09 09 09 |f .name |space...|
|000041d0| 28 20 50 72 69 6e 74 20 | 69 74 73 20 6e 61 6d 65 |( Print |its name|
|000041e0| 20 61 6e 64 20 63 6f 6e | 74 69 6e 75 65 29 0a 58 | and con|tinue).X|
|000041f0| 20 20 20 20 20 20 65 6c | 73 65 20 64 72 6f 70 20 | el|se drop |
|00004200| 74 68 65 6e 09 0a 58 20 | 20 20 20 5d 3b 20 0a 58 |then..X | ]; .X|
|00004210| 20 20 20 20 6d 61 70 2d | 6c 69 73 74 0a 58 20 20 | map-|list.X |
|00004220| 5d 3b 0a 58 20 20 6d 61 | 70 2d 73 65 74 0a 58 20 |];.X ma|p-set.X |
|00004230| 20 64 72 6f 70 0a 58 3b | 0a 58 0a 58 66 6f 72 74 | drop.X;|.X.Xfort|
|00004240| 68 20 6f 6e 6c 79 0a 45 | 4e 44 5f 4f 46 5f 6c 69 |h only.E|ND_OF_li|
|00004250| 62 2f 69 6e 74 65 72 6e | 61 6c 73 2e 66 38 33 0a |b/intern|als.f83.|
|00004260| 69 66 20 74 65 73 74 20 | 33 38 39 33 20 2d 6e 65 |if test |3893 -ne|
|00004270| 20 60 77 63 20 2d 63 20 | 3c 6c 69 62 2f 69 6e 74 | `wc -c |<lib/int|
|00004280| 65 72 6e 61 6c 73 2e 66 | 38 33 60 3b 20 74 68 65 |ernals.f|83`; the|
|00004290| 6e 0a 20 20 20 20 65 63 | 68 6f 20 73 68 61 72 3a |n. ec|ho shar:|
|000042a0| 20 5c 22 6c 69 62 2f 69 | 6e 74 65 72 6e 61 6c 73 | \"lib/i|nternals|
|000042b0| 2e 66 38 33 5c 22 20 75 | 6e 70 61 63 6b 65 64 20 |.f83\" u|npacked |
|000042c0| 77 69 74 68 20 77 72 6f | 6e 67 20 73 69 7a 65 21 |with wro|ng size!|
|000042d0| 0a 66 69 0a 23 20 65 6e | 64 20 6f 66 20 6f 76 65 |.fi.# en|d of ove|
|000042e0| 72 77 72 69 74 69 6e 67 | 20 63 68 65 63 6b 0a 66 |rwriting| check.f|
|000042f0| 69 0a 69 66 20 74 65 73 | 74 20 2d 66 20 6c 69 62 |i.if tes|t -f lib|
|00004300| 2f 71 75 65 75 65 73 2e | 66 38 33 20 2d 61 20 22 |/queues.|f83 -a "|
|00004310| 24 7b 31 7d 22 20 21 3d | 20 22 2d 63 22 20 3b 20 |${1}" !=| "-c" ; |
|00004320| 74 68 65 6e 20 0a 20 20 | 65 63 68 6f 20 73 68 61 |then . |echo sha|
|00004330| 72 3a 20 57 69 6c 6c 20 | 6e 6f 74 20 6f 76 65 72 |r: Will |not over|
|00004340| 2d 77 72 69 74 65 20 65 | 78 69 73 74 69 6e 67 20 |-write e|xisting |
|00004350| 66 69 6c 65 20 5c 22 6c | 69 62 2f 71 75 65 75 65 |file \"l|ib/queue|
|00004360| 73 2e 66 38 33 5c 22 0a | 65 6c 73 65 0a 65 63 68 |s.f83\".|else.ech|
|00004370| 6f 20 73 68 61 72 3a 20 | 45 78 74 72 61 63 74 69 |o shar: |Extracti|
|00004380| 6e 67 20 5c 22 6c 69 62 | 2f 71 75 65 75 65 73 2e |ng \"lib|/queues.|
|00004390| 66 38 33 5c 22 20 5c 28 | 33 38 36 30 20 63 68 61 |f83\" \(|3860 cha|
|000043a0| 72 61 63 74 65 72 73 5c | 29 0a 73 65 64 20 22 73 |racters\|).sed "s|
|000043b0| 2f 5e 58 2f 2f 22 20 3e | 6c 69 62 2f 71 75 65 75 |/^X//" >|lib/queu|
|000043c0| 65 73 2e 66 38 33 20 3c | 3c 27 45 4e 44 5f 4f 46 |es.f83 <|<'END_OF|
|000043d0| 5f 6c 69 62 2f 71 75 65 | 75 65 73 2e 66 38 33 27 |_lib/que|ues.f83'|
|000043e0| 0a 58 5c 0a 58 5c 20 20 | 44 4f 55 42 4c 45 20 4c |.X\.X\ |DOUBLE L|
|000043f0| 49 4e 4b 45 44 20 4c 49 | 53 54 53 0a 58 5c 0a 58 |INKED LI|STS.X\.X|
|00004400| 5c 20 20 43 6f 70 79 72 | 69 67 68 74 20 28 63 29 |\ Copyr|ight (c)|
|00004410| 20 31 39 38 38 2d 31 39 | 39 30 20 62 79 20 4d 69 | 1988-19|90 by Mi|
|00004420| 6b 61 65 6c 20 52 2e 4b | 2e 20 50 61 74 65 6c 0a |kael R.K|. Patel.|
|00004430| 58 5c 0a 58 5c 20 20 43 | 6f 6d 70 75 74 65 72 20 |X\.X\ C|omputer |
|00004440| 41 69 64 65 64 20 44 65 | 73 69 67 6e 20 4c 61 62 |Aided De|sign Lab|
|00004450| 6f 72 61 74 6f 72 79 20 | 28 43 41 44 4c 41 42 29 |oratory |(CADLAB)|
|00004460| 0a 58 5c 20 20 44 65 70 | 61 72 74 6d 65 6e 74 20 |.X\ Dep|artment |
|00004470| 6f 66 20 43 6f 6d 70 75 | 74 65 72 20 61 6e 64 20 |of Compu|ter and |
|00004480| 49 6e 66 6f 72 6d 61 74 | 69 6f 6e 20 53 63 69 65 |Informat|ion Scie|
|00004490| 6e 63 65 0a 58 5c 20 20 | 4c 69 6e 6b 6f 70 69 6e |nce.X\ |Linkopin|
|000044a0| 67 20 55 6e 69 76 65 72 | 73 69 74 79 0a 58 5c 20 |g Univer|sity.X\ |
|000044b0| 20 53 2d 35 38 31 20 38 | 33 20 4c 49 4e 4b 4f 50 | S-581 8|3 LINKOP|
|000044c0| 49 4e 47 0a 58 5c 20 20 | 53 57 45 44 45 4e 0a 58 |ING.X\ |SWEDEN.X|
|000044d0| 5c 0a 58 5c 20 20 45 6d | 61 69 6c 3a 20 6d 69 70 |\.X\ Em|ail: mip|
|000044e0| 40 69 64 61 2e 6c 69 75 | 2e 73 65 0a 58 5c 0a 58 |@ida.liu|.se.X\.X|
|000044f0| 5c 20 20 53 74 61 72 74 | 65 64 20 6f 6e 3a 20 33 |\ Start|ed on: 3|
|00004500| 30 20 4a 75 6e 65 20 31 | 39 38 38 0a 58 5c 0a 58 |0 June 1|988.X\.X|
|00004510| 5c 20 20 4c 61 73 74 20 | 75 70 64 61 74 65 64 20 |\ Last |updated |
|00004520| 6f 6e 3a 20 32 36 20 46 | 65 62 72 75 61 72 79 20 |on: 26 F|ebruary |
|00004530| 31 39 39 30 0a 58 5c 0a | 58 5c 20 20 44 65 70 65 |1990.X\.|X\ Depe|
|00004540| 6e 64 65 6e 63 69 65 73 | 3a 0a 58 5c 20 20 20 20 |ndencies|:.X\ |
|00004550| 20 20 20 28 66 6f 72 74 | 68 29 20 66 6f 72 74 68 | (fort|h) forth|
|00004560| 2c 20 73 74 72 75 63 74 | 75 72 65 73 2c 20 62 6c |, struct|ures, bl|
|00004570| 6f 63 6b 73 0a 58 5c 0a | 58 5c 20 20 44 65 73 63 |ocks.X\.|X\ Desc|
|00004580| 72 69 70 74 69 6f 6e 3a | 0a 58 5c 20 20 20 20 20 |ription:|.X\ |
|00004590| 20 20 41 6c 6c 6f 77 73 | 20 64 65 66 69 6e 69 74 | Allows| definit|
|000045a0| 69 6f 6e 20 61 6e 64 20 | 62 61 73 69 63 20 6d 61 |ion and |basic ma|
|000045b0| 6e 69 70 75 6c 61 74 69 | 6f 6e 20 6f 66 20 71 75 |nipulati|on of qu|
|000045c0| 65 75 65 20 64 61 74 61 | 20 73 74 72 75 63 74 75 |eue data| structu|
|000045d0| 72 65 73 2e 0a 58 5c 0a | 58 5c 20 20 43 6f 70 79 |res..X\.|X\ Copy|
|000045e0| 69 6e 67 3a 0a 58 5c 20 | 20 20 20 20 20 20 54 68 |ing:.X\ | Th|
|000045f0| 69 73 20 70 72 6f 67 72 | 61 6d 20 69 73 20 66 72 |is progr|am is fr|
|00004600| 65 65 20 73 6f 66 74 77 | 61 72 65 3b 20 79 6f 75 |ee softw|are; you|
|00004610| 20 63 61 6e 20 72 65 64 | 69 73 74 72 69 62 75 74 | can red|istribut|
|00004620| 65 20 69 74 20 61 6e 64 | 5c 6f 72 20 6d 6f 64 69 |e it and|\or modi|
|00004630| 66 79 0a 58 5c 20 20 20 | 20 20 20 20 69 74 20 75 |fy.X\ | it u|
|00004640| 6e 64 65 72 20 74 68 65 | 20 74 65 72 6d 73 20 6f |nder the| terms o|
|00004650| 66 20 74 68 65 20 47 4e | 55 20 47 65 6e 65 72 61 |f the GN|U Genera|
|00004660| 6c 20 50 75 62 6c 69 63 | 20 4c 69 63 65 6e 73 65 |l Public| License|
|00004670| 20 61 73 20 70 75 62 6c | 69 73 68 65 64 20 62 79 | as publ|ished by|
|00004680| 0a 58 5c 20 20 20 20 20 | 20 20 74 68 65 20 46 72 |.X\ | the Fr|
|00004690| 65 65 20 53 6f 66 74 77 | 61 72 65 20 46 6f 75 6e |ee Softw|are Foun|
|000046a0| 64 61 74 69 6f 6e 3b 20 | 65 69 74 68 65 72 20 76 |dation; |either v|
|000046b0| 65 72 73 69 6f 6e 20 31 | 2c 20 6f 72 20 28 61 74 |ersion 1|, or (at|
|000046c0| 20 79 6f 75 72 20 6f 70 | 74 69 6f 6e 29 0a 58 5c | your op|tion).X\|
|000046d0| 20 20 20 20 20 20 20 61 | 6e 79 20 6c 61 74 65 72 | a|ny later|
|000046e0| 20 76 65 72 73 69 6f 6e | 2e 0a 58 5c 0a 58 5c 20 | version|..X\.X\ |
|000046f0| 20 20 20 20 20 20 54 68 | 69 73 20 70 72 6f 67 72 | Th|is progr|
|00004700| 61 6d 20 69 73 20 64 69 | 73 74 72 69 62 75 74 65 |am is di|stribute|
|00004710| 64 20 69 6e 20 74 68 65 | 20 68 6f 70 65 20 74 68 |d in the| hope th|
|00004720| 61 74 20 69 74 20 77 69 | 6c 6c 20 62 65 20 75 73 |at it wi|ll be us|
|00004730| 65 66 75 6c 2c 0a 58 5c | 20 20 20 20 20 20 20 62 |eful,.X\| b|
|00004740| 75 74 20 57 49 54 48 4f | 55 54 20 41 4e 59 20 57 |ut WITHO|UT ANY W|
|00004750| 41 52 52 41 4e 54 59 3b | 20 77 69 74 68 6f 75 74 |ARRANTY;| without|
|00004760| 20 65 76 65 6e 20 74 68 | 65 20 69 6d 70 6c 69 65 | even th|e implie|
|00004770| 64 20 77 61 72 72 61 6e | 74 79 20 6f 66 0a 58 5c |d warran|ty of.X\|
|00004780| 20 20 20 20 20 20 20 4d | 45 52 43 48 41 4e 54 41 | M|ERCHANTA|
|00004790| 42 49 4c 49 54 59 20 6f | 72 20 46 49 54 4e 45 53 |BILITY o|r FITNES|
|000047a0| 53 20 46 4f 52 20 41 20 | 50 41 52 54 49 43 55 4c |S FOR A |PARTICUL|
|000047b0| 41 52 20 50 55 52 50 4f | 53 45 2e 20 20 53 65 65 |AR PURPO|SE. See|
|000047c0| 20 74 68 65 0a 58 5c 20 | 20 20 20 20 20 20 47 4e | the.X\ | GN|
|000047d0| 55 20 47 65 6e 65 72 61 | 6c 20 50 75 62 6c 69 63 |U Genera|l Public|
|000047e0| 20 4c 69 63 65 6e 73 65 | 20 66 6f 72 20 6d 6f 72 | License| for mor|
|000047f0| 65 20 64 65 74 61 69 6c | 73 2e 0a 58 5c 0a 58 5c |e detail|s..X\.X\|
|00004800| 20 20 20 20 20 20 20 59 | 6f 75 20 73 68 6f 75 6c | Y|ou shoul|
|00004810| 64 20 68 61 76 65 20 72 | 65 63 65 69 76 65 64 20 |d have r|eceived |
|00004820| 61 20 63 6f 70 79 20 6f | 66 20 74 68 65 20 47 4e |a copy o|f the GN|
|00004830| 55 20 47 65 6e 65 72 61 | 6c 20 50 75 62 6c 69 63 |U Genera|l Public|
|00004840| 20 4c 69 63 65 6e 73 65 | 0a 58 5c 20 20 20 20 20 | License|.X\ |
|00004850| 20 20 61 6c 6f 6e 67 20 | 77 69 74 68 20 74 68 69 | along |with thi|
|00004860| 73 20 70 72 6f 67 72 61 | 6d 3b 20 73 65 65 20 74 |s progra|m; see t|
|00004870| 68 65 20 66 69 6c 65 20 | 43 4f 50 59 49 4e 47 2e |he file |COPYING.|
|00004880| 20 20 49 66 20 6e 6f 74 | 2c 20 77 72 69 74 65 20 | If not|, write |
|00004890| 74 6f 0a 58 5c 20 20 20 | 20 20 20 20 74 68 65 20 |to.X\ | the |
|000048a0| 46 72 65 65 20 53 6f 66 | 74 77 61 72 65 20 46 6f |Free Sof|tware Fo|
|000048b0| 75 6e 64 61 74 69 6f 6e | 2c 20 36 37 35 20 4d 61 |undation|, 675 Ma|
|000048c0| 73 73 20 41 76 65 2c 20 | 43 61 6d 62 72 69 64 67 |ss Ave, |Cambridg|
|000048d0| 65 2c 20 4d 41 20 30 32 | 31 33 39 2c 20 55 53 41 |e, MA 02|139, USA|
|000048e0| 2e 20 0a 58 0a 58 2e 28 | 20 4c 6f 61 64 69 6e 67 |. .X.X.(| Loading|
|000048f0| 20 51 75 65 75 65 20 64 | 65 66 69 6e 69 74 69 6f | Queue d|efinitio|
|00004900| 6e 73 2e 2e 2e 20 29 20 | 63 72 0a 58 0a 58 23 69 |ns... ) |cr.X.X#i|
|00004910| 6e 63 6c 75 64 65 20 73 | 74 72 75 63 74 75 72 65 |nclude s|tructure|
|00004920| 73 2e 66 38 33 0a 58 23 | 69 6e 63 6c 75 64 65 20 |s.f83.X#|include |
|00004930| 62 6c 6f 63 6b 73 2e 66 | 38 33 0a 58 0a 58 62 6c |blocks.f|83.X.Xbl|
|00004940| 6f 63 6b 73 20 73 74 72 | 75 63 74 75 72 65 73 20 |ocks str|uctures |
|00004950| 71 75 65 75 65 73 20 64 | 65 66 69 6e 69 74 69 6f |queues d|efinitio|
|00004960| 6e 73 0a 58 0a 58 73 74 | 72 75 63 74 2e 74 79 70 |ns.X.Xst|ruct.typ|
|00004970| 65 20 51 55 45 55 45 20 | 28 20 2d 2d 20 29 0a 58 |e QUEUE |( -- ).X|
|00004980| 20 20 70 74 72 20 2b 73 | 75 63 63 20 70 72 69 76 | ptr +s|ucc priv|
|00004990| 61 74 65 09 09 09 28 20 | 50 6f 69 6e 74 65 72 20 |ate...( |Pointer |
|000049a0| 74 6f 20 73 75 63 63 65 | 73 73 6f 72 29 0a 58 20 |to succe|ssor).X |
|000049b0| 20 70 74 72 20 2b 70 72 | 65 64 20 70 72 69 76 61 | ptr +pr|ed priva|
|000049c0| 74 65 09 09 09 28 20 50 | 6f 69 6e 74 65 72 20 74 |te...( P|ointer t|
|000049d0| 6f 20 70 72 65 64 65 63 | 65 73 73 6f 72 29 0a 58 |o predec|essor).X|
|000049e0| 73 74 72 75 63 74 2e 69 | 6e 69 74 20 28 20 71 75 |struct.i|nit ( qu|
|000049f0| 65 75 65 20 2d 2d 20 29 | 0a 58 20 20 64 75 70 20 |eue -- )|.X dup |
|00004a00| 6f 76 65 72 20 2b 73 75 | 63 63 20 21 09 09 09 28 |over +su|cc !...(|
|00004a10| 20 49 6e 69 74 69 61 74 | 65 20 61 73 20 61 6e 20 | Initiat|e as an |
|00004a20| 65 6d 70 74 79 20 71 75 | 65 75 65 29 0a 58 20 20 |empty qu|eue).X |
|00004a30| 64 75 70 20 2b 70 72 65 | 64 20 21 0a 58 73 74 72 |dup +pre|d !.Xstr|
|00004a40| 75 63 74 2e 65 6e 64 20 | 0a 58 0a 58 3a 20 73 75 |uct.end |.X.X: su|
|00004a50| 63 63 20 28 20 71 75 65 | 75 65 20 2d 2d 20 73 75 |cc ( que|ue -- su|
|00004a60| 63 63 29 0a 58 20 20 2b | 73 75 63 63 20 40 20 09 |cc).X +|succ @ .|
|00004a70| 09 09 09 28 20 41 63 63 | 65 73 73 20 73 75 63 63 |...( Acc|ess succ|
|00004a80| 65 73 73 6f 72 20 69 74 | 65 6d 29 0a 58 3b 0a 58 |essor it|em).X;.X|
|00004a90| 0a 58 3a 20 70 72 65 64 | 20 28 20 71 75 65 75 65 |.X: pred| ( queue|
|00004aa0| 20 2d 2d 20 70 72 65 64 | 29 0a 58 20 20 2b 70 72 | -- pred|).X +pr|
|00004ab0| 65 64 20 40 20 09 09 09 | 09 28 20 41 63 63 65 73 |ed @ ...|.( Acces|
|00004ac0| 73 20 70 72 65 64 65 63 | 65 73 73 6f 72 20 69 74 |s predec|essor it|
|00004ad0| 65 6d 29 0a 58 3b 0a 58 | 0a 58 23 69 66 75 6e 64 |em).X;.X|.X#ifund|
|00004ae0| 65 66 20 3f 65 6d 70 74 | 79 2d 71 75 65 75 65 09 |ef ?empt|y-queue.|
|00004af0| 28 20 43 68 65 63 6b 20 | 69 66 20 74 68 65 20 6b |( Check |if the k|
|00004b00| 65 72 6e 65 6c 20 73 75 | 70 70 6f 72 74 73 20 71 |ernel su|pports q|
|00004b10| 75 65 75 65 73 29 0a 58 | 0a 58 3a 20 3f 65 6d 70 |ueues).X|.X: ?emp|
|00004b20| 74 79 2d 71 75 65 75 65 | 20 28 20 71 75 65 75 65 |ty-queue| ( queue|
|00004b30| 20 2d 2d 20 62 6f 6f 6c | 29 0a 58 20 20 64 75 70 | -- bool|).X dup|
|00004b40| 20 2b 73 75 63 63 20 40 | 20 3d 20 09 09 09 28 20 | +succ @| = ...( |
|00004b50| 50 6f 69 6e 74 65 72 20 | 74 6f 20 69 74 73 65 6c |Pointer |to itsel|
|00004b60| 66 29 0a 58 3b 0a 58 0a | 58 3a 20 65 6e 71 75 65 |f).X;.X.|X: enque|
|00004b70| 75 65 20 28 20 69 74 65 | 6d 20 71 75 65 75 65 20 |ue ( ite|m queue |
|00004b80| 2d 2d 20 29 0a 58 20 20 | 32 64 75 70 20 2b 70 72 |-- ).X |2dup +pr|
|00004b90| 65 64 20 40 20 73 77 61 | 70 20 2b 70 72 65 64 20 |ed @ swa|p +pred |
|00004ba0| 21 09 09 28 20 69 74 65 | 6d 2e 70 72 65 64 20 3d |!..( ite|m.pred =|
|00004bb0| 20 71 75 65 75 65 2e 70 | 72 65 64 29 0a 58 20 20 | queue.p|red).X |
|00004bc0| 32 64 75 70 20 73 77 61 | 70 20 2b 73 75 63 63 20 |2dup swa|p +succ |
|00004bd0| 21 09 09 09 28 20 69 74 | 65 6d 2e 73 75 63 63 20 |!...( it|em.succ |
|00004be0| 3d 20 71 75 65 75 65 29 | 0a 58 20 20 32 64 75 70 |= queue)|.X 2dup|
|00004bf0| 20 2b 70 72 65 64 20 40 | 20 2b 73 75 63 63 20 21 | +pred @| +succ !|
|00004c00| 09 09 09 28 20 71 75 65 | 75 65 2e 70 72 65 64 2e |...( que|ue.pred.|
|00004c10| 73 75 63 63 20 3d 20 69 | 74 65 6d 29 0a 58 20 20 |succ = i|tem).X |
|00004c20| 2b 70 72 65 64 20 21 20 | 09 09 09 09 28 20 71 75 |+pred ! |....( qu|
|00004c30| 65 75 65 2e 70 72 65 64 | 20 3d 20 69 74 65 6d 29 |eue.pred| = item)|
|00004c40| 0a 58 3b 0a 58 0a 58 3a | 20 64 65 71 75 65 75 65 |.X;.X.X:| dequeue|
|00004c50| 20 28 20 69 74 65 6d 20 | 2d 2d 20 29 0a 58 20 20 | ( item |-- ).X |
|00004c60| 64 75 70 20 2b 73 75 63 | 63 20 40 20 6f 76 65 72 |dup +suc|c @ over|
|00004c70| 20 2b 70 72 65 64 20 40 | 20 2b 73 75 63 63 20 21 | +pred @| +succ !|
|00004c80| 09 28 20 69 74 65 6d 2e | 70 72 65 64 2e 73 75 63 |.( item.|pred.suc|
|00004c90| 63 20 3d 20 69 74 65 6d | 2e 73 75 63 63 29 0a 58 |c = item|.succ).X|
|00004ca0| 20 20 64 75 70 20 2b 70 | 72 65 64 20 40 20 6f 76 | dup +p|red @ ov|
|00004cb0| 65 72 20 2b 73 75 63 63 | 20 40 20 2b 70 72 65 64 |er +succ| @ +pred|
|00004cc0| 20 21 09 28 20 69 74 65 | 6d 2e 73 75 63 63 2e 70 | !.( ite|m.succ.p|
|00004cd0| 72 65 64 20 3d 20 69 74 | 65 6d 2e 70 72 65 64 29 |red = it|em.pred)|
|00004ce0| 0a 58 20 20 64 75 70 20 | 6f 76 65 72 20 2b 73 75 |.X dup |over +su|
|00004cf0| 63 63 20 21 09 09 09 28 | 20 69 74 65 6d 2e 73 75 |cc !...(| item.su|
|00004d00| 63 63 20 3d 20 69 74 65 | 6d 29 0a 58 20 20 64 75 |cc = ite|m).X du|
|00004d10| 70 20 2b 70 72 65 64 20 | 21 09 09 09 09 28 20 69 |p +pred |!....( i|
|00004d20| 74 65 6d 2e 70 72 65 64 | 20 3d 20 69 74 65 6d 29 |tem.pred| = item)|
|00004d30| 0a 58 3b 0a 58 0a 58 23 | 74 68 65 6e 0a 58 0a 58 |.X;.X.X#|then.X.X|
|00004d40| 3a 20 73 69 7a 65 2d 71 | 75 65 75 65 20 28 20 71 |: size-q|ueue ( q|
|00004d50| 75 65 75 65 20 2d 2d 20 | 69 6e 74 29 0a 58 20 20 |ueue -- |int).X |
|00004d60| 30 20 73 77 61 70 20 64 | 75 70 20 3e 72 09 09 09 |0 swap d|up >r...|
|00004d70| 09 28 20 53 61 76 65 20 | 70 6f 69 6e 74 65 72 20 |.( Save |pointer |
|00004d80| 74 6f 20 71 75 65 75 65 | 20 68 65 61 64 65 72 29 |to queue| header)|
|00004d90| 0a 58 20 20 62 65 67 69 | 6e 0a 58 20 20 20 20 73 |.X begi|n.X s|
|00004da0| 77 61 70 20 31 2b 20 73 | 77 61 70 20 2b 73 75 63 |wap 1+ s|wap +suc|
|00004db0| 63 20 40 09 09 28 20 49 | 6e 63 72 65 6d 65 6e 74 |c @..( I|ncrement|
|00004dc0| 20 73 69 7a 65 20 61 6e | 64 20 73 74 65 70 20 74 | size an|d step t|
|00004dd0| 6f 20 6e 65 78 74 29 0a | 58 20 20 20 20 64 75 70 |o next).|X dup|
|00004de0| 20 72 40 20 3d 09 09 09 | 09 28 20 49 73 20 74 68 | r@ =...|.( Is th|
|00004df0| 69 73 20 74 68 65 20 6c | 61 73 74 20 65 6c 65 6d |is the l|ast elem|
|00004e00| 65 6e 74 3f 29 0a 58 20 | 20 75 6e 74 69 6c 0a 58 |ent?).X | until.X|
|00004e10| 20 20 72 3e 20 32 64 72 | 6f 70 09 09 09 09 28 20 | r> 2dr|op....( |
|00004e20| 44 72 6f 70 20 70 61 72 | 61 6d 65 74 65 72 73 20 |Drop par|ameters |
|00004e30| 61 6e 64 20 72 65 74 75 | 72 6e 20 73 69 7a 65 29 |and retu|rn size)|
|00004e40| 0a 58 3b 0a 58 0a 58 3a | 20 6d 61 70 2d 71 75 65 |.X;.X.X:| map-que|
|00004e50| 75 65 20 28 20 71 75 65 | 75 65 20 62 6c 6f 63 6b |ue ( que|ue block|
|00004e60| 5b 69 74 65 6d 20 2d 2d | 20 5d 20 2d 2d 20 29 0a |[item --| ] -- ).|
|00004e70| 58 20 20 6f 76 65 72 20 | 3e 72 09 09 09 09 28 20 |X over |>r....( |
|00004e80| 53 61 76 65 20 70 6f 69 | 6e 74 65 72 20 74 6f 20 |Save poi|nter to |
|00004e90| 71 75 65 75 65 20 68 65 | 61 64 65 72 29 0a 58 20 |queue he|ader).X |
|00004ea0| 20 62 65 67 69 6e 0a 58 | 20 20 20 20 6f 76 65 72 | begin.X| over|
|00004eb0| 20 2b 73 75 63 63 20 40 | 20 3e 72 09 09 09 28 20 | +succ @| >r...( |
|00004ec0| 53 61 76 65 20 70 6f 69 | 6e 74 65 72 20 74 6f 20 |Save poi|nter to |
|00004ed0| 6e 65 78 74 20 69 74 65 | 6d 29 0a 58 20 20 20 20 |next ite|m).X |
|00004ee0| 64 75 70 20 3e 72 09 09 | 09 09 28 20 53 61 76 65 |dup >r..|..( Save|
|00004ef0| 20 62 6c 6f 63 6b 20 6f | 6e 20 72 65 74 75 72 6e | block o|n return|
|00004f00| 20 73 74 61 63 6b 29 0a | 58 20 20 20 20 63 61 6c | stack).|X cal|
|00004f10| 6c 09 09 09 09 28 20 43 | 61 6c 6c 20 74 68 65 20 |l....( C|all the |
|00004f20| 62 6c 6f 63 6b 20 77 69 | 74 68 20 74 68 65 20 69 |block wi|th the i|
|00004f30| 74 65 6d 29 0a 58 20 20 | 20 20 32 72 3e 20 74 75 |tem).X | 2r> tu|
|00004f40| 63 6b 09 09 09 09 28 20 | 52 65 73 74 6f 72 65 20 |ck....( |Restore |
|00004f50| 74 68 65 20 70 61 72 61 | 6d 65 74 65 72 73 29 0a |the para|meters).|
|00004f60| 58 20 20 20 20 72 40 20 | 3d 09 09 09 09 28 20 43 |X r@ |=....( C|
|00004f70| 68 65 63 6b 20 69 66 20 | 65 6e 64 20 6f 66 20 71 |heck if |end of q|
|00004f80| 75 65 75 65 29 0a 58 20 | 20 75 6e 74 69 6c 0a 58 |ueue).X | until.X|
|00004f90| 20 20 72 3e 20 64 72 6f | 70 20 32 64 72 6f 70 20 | r> dro|p 2drop |
|00004fa0| 09 09 09 28 20 44 72 6f | 70 20 61 6c 6c 20 74 65 |...( Dro|p all te|
|00004fb0| 6d 70 6f 72 61 72 79 20 | 70 61 72 61 6d 65 74 65 |mporary |paramete|
|00004fc0| 72 73 29 0a 58 3b 0a 58 | 0a 58 3a 20 3f 6d 61 70 |rs).X;.X|.X: ?map|
|00004fd0| 2d 71 75 65 75 65 20 28 | 20 71 75 65 75 65 20 62 |-queue (| queue b|
|00004fe0| 6c 6f 63 6b 5b 69 74 65 | 6d 20 2d 2d 20 62 6f 6f |lock[ite|m -- boo|
|00004ff0| 6c 5d 20 2d 2d 20 29 0a | 58 20 20 6f 76 65 72 20 |l] -- ).|X over |
|00005000| 3e 72 09 09 09 09 28 20 | 53 61 76 65 20 70 6f 69 |>r....( |Save poi|
|00005010| 6e 74 65 72 20 74 6f 20 | 71 75 65 75 65 20 68 65 |nter to |queue he|
|00005020| 61 64 65 72 29 0a 58 20 | 20 62 65 67 69 6e 0a 58 |ader).X | begin.X|
|00005030| 20 20 20 20 6f 76 65 72 | 20 2b 73 75 63 63 20 40 | over| +succ @|
|00005040| 20 3e 72 09 09 09 28 20 | 53 61 76 65 20 70 6f 69 | >r...( |Save poi|
|00005050| 6e 74 65 72 20 74 6f 20 | 6e 65 78 74 20 69 74 65 |nter to |next ite|
|00005060| 6d 29 0a 58 20 20 20 20 | 64 75 70 20 3e 72 09 09 |m).X |dup >r..|
|00005070| 09 09 28 20 53 61 76 65 | 20 62 6c 6f 63 6b 20 6f |..( Save| block o|
|00005080| 6e 20 72 65 74 75 72 6e | 20 73 74 61 63 6b 29 0a |n return| stack).|
|00005090| 58 20 20 20 20 63 61 6c | 6c 09 09 09 09 28 20 43 |X cal|l....( C|
|000050a0| 61 6c 6c 20 74 68 65 20 | 62 6c 6f 63 6b 20 77 69 |all the |block wi|
|000050b0| 74 68 20 74 68 65 20 69 | 74 65 6d 29 0a 58 20 20 |th the i|tem).X |
|000050c0| 20 20 69 66 20 32 72 3e | 20 74 72 75 65 09 09 09 | if 2r>| true...|
|000050d0| 09 28 20 45 78 69 74 20 | 74 68 65 20 69 74 65 72 |.( Exit |the iter|
|000050e0| 61 74 69 6f 6e 29 0a 58 | 20 20 20 20 65 6c 73 65 |ation).X| else|
|000050f0| 0a 58 20 20 20 20 20 20 | 32 72 3e 20 74 75 63 6b |.X |2r> tuck|
|00005100| 09 09 09 09 28 20 52 65 | 73 74 6f 72 65 20 74 68 |....( Re|store th|
|00005110| 65 20 70 61 72 61 6d 65 | 74 65 72 73 29 0a 58 20 |e parame|ters).X |
|00005120| 20 20 20 20 20 72 40 20 | 3d 09 09 09 09 28 20 43 | r@ |=....( C|
|00005130| 68 65 63 6b 20 69 66 20 | 65 6e 64 20 6f 66 20 71 |heck if |end of q|
|00005140| 75 65 75 65 29 0a 58 20 | 20 20 20 74 68 65 6e 0a |ueue).X | then.|
|00005150| 58 20 20 75 6e 74 69 6c | 0a 58 20 20 72 3e 20 64 |X until|.X r> d|
|00005160| 72 6f 70 20 32 64 72 6f | 70 20 09 09 09 28 20 44 |rop 2dro|p ...( D|
|00005170| 72 6f 70 20 61 6c 6c 20 | 74 65 6d 70 6f 72 61 72 |rop all |temporar|
|00005180| 79 20 70 61 72 61 6d 65 | 74 65 72 73 29 0a 58 3b |y parame|ters).X;|
|00005190| 0a 58 0a 58 3a 20 3f 6d | 65 6d 62 65 72 2d 71 75 |.X.X: ?m|ember-qu|
|000051a0| 65 75 65 20 28 20 65 6c | 65 6d 65 6e 74 20 71 75 |eue ( el|ement qu|
|000051b0| 65 75 65 20 2d 2d 20 62 | 6f 6f 6c 29 0a 58 20 20 |eue -- b|ool).X |
|000051c0| 64 75 70 20 3e 72 09 09 | 09 09 28 20 53 61 76 65 |dup >r..|..( Save|
|000051d0| 20 70 6f 69 6e 74 65 72 | 20 74 6f 20 71 75 65 75 | pointer| to queu|
|000051e0| 65 20 68 65 61 64 65 72 | 29 0a 58 20 20 62 65 67 |e header|).X beg|
|000051f0| 69 6e 0a 58 20 20 20 20 | 32 64 75 70 20 3d 09 09 |in.X |2dup =..|
|00005200| 09 09 28 20 49 73 20 74 | 68 69 73 20 74 68 65 20 |..( Is t|his the |
|00005210| 65 6c 65 6d 65 6e 74 3f | 29 0a 58 20 20 20 20 69 |element?|).X i|
|00005220| 66 20 32 64 72 6f 70 20 | 72 3e 20 64 72 6f 70 20 |f 2drop |r> drop |
|00005230| 74 72 75 65 20 65 78 69 | 74 20 74 68 65 6e 09 28 |true exi|t then.(|
|00005240| 20 57 65 6c 6c 20 64 72 | 6f 70 20 74 68 65 20 70 | Well dr|op the p|
|00005250| 61 72 61 6d 65 74 65 72 | 73 20 61 6e 64 20 72 65 |arameter|s and re|
|00005260| 74 75 72 6e 29 0a 58 20 | 20 20 20 2b 73 75 63 63 |turn).X | +succ|
|00005270| 20 40 20 64 75 70 20 72 | 40 20 3d 09 09 09 28 20 | @ dup r|@ =...( |
|00005280| 53 74 65 70 20 74 6f 20 | 74 68 65 20 6e 65 78 74 |Step to |the next|
|00005290| 2e 20 4c 61 73 74 20 65 | 6c 65 6d 65 6e 74 3f 29 |. Last e|lement?)|
|000052a0| 0a 58 20 20 75 6e 74 69 | 6c 0a 58 20 20 32 64 72 |.X unti|l.X 2dr|
|000052b0| 6f 70 20 72 3e 20 64 72 | 6f 70 20 66 61 6c 73 65 |op r> dr|op false|
|000052c0| 0a 58 3b 0a 58 0a 58 3a | 20 2e 71 75 65 75 65 20 |.X;.X.X:| .queue |
|000052d0| 28 20 71 75 65 75 65 20 | 2d 2d 20 29 0a 58 20 20 |( queue |-- ).X |
|000052e0| 2e 22 20 71 75 65 75 65 | 23 22 20 64 75 70 20 2e |." queue|#" dup .|
|000052f0| 09 09 09 28 20 50 72 69 | 6e 74 20 61 64 64 72 65 |...( Pri|nt addre|
|00005300| 73 73 20 6f 66 20 71 75 | 65 75 65 29 0a 58 20 20 |ss of qu|eue).X |
|00005310| 2e 22 20 73 75 63 63 3a | 20 22 20 64 75 70 20 2b |." succ:| " dup +|
|00005320| 73 75 63 63 20 40 20 2e | 09 09 28 20 50 72 69 6e |succ @ .|..( Prin|
|00005330| 74 20 73 75 63 63 65 73 | 73 6f 72 29 0a 58 20 20 |t succes|sor).X |
|00005340| 2e 22 20 70 72 65 64 3a | 20 22 20 2b 70 72 65 64 |." pred:| " +pred|
|00005350| 20 40 20 2e 09 09 09 28 | 20 50 72 69 6e 74 20 70 | @ ....(| Print p|
|00005360| 72 65 64 65 63 65 73 73 | 6f 72 29 0a 58 3b 0a 58 |redecess|or).X;.X|
|00005370| 0a 58 66 6f 72 74 68 20 | 6f 6e 6c 79 0a 45 4e 44 |.Xforth |only.END|
|00005380| 5f 4f 46 5f 6c 69 62 2f | 71 75 65 75 65 73 2e 66 |_OF_lib/|queues.f|
|00005390| 38 33 0a 69 66 20 74 65 | 73 74 20 33 38 36 30 20 |83.if te|st 3860 |
|000053a0| 2d 6e 65 20 60 77 63 20 | 2d 63 20 3c 6c 69 62 2f |-ne `wc |-c <lib/|
|000053b0| 71 75 65 75 65 73 2e 66 | 38 33 60 3b 20 74 68 65 |queues.f|83`; the|
|000053c0| 6e 0a 20 20 20 20 65 63 | 68 6f 20 73 68 61 72 3a |n. ec|ho shar:|
|000053d0| 20 5c 22 6c 69 62 2f 71 | 75 65 75 65 73 2e 66 38 | \"lib/q|ueues.f8|
|000053e0| 33 5c 22 20 75 6e 70 61 | 63 6b 65 64 20 77 69 74 |3\" unpa|cked wit|
|000053f0| 68 20 77 72 6f 6e 67 20 | 73 69 7a 65 21 0a 66 69 |h wrong |size!.fi|
|00005400| 0a 23 20 65 6e 64 20 6f | 66 20 6f 76 65 72 77 72 |.# end o|f overwr|
|00005410| 69 74 69 6e 67 20 63 68 | 65 63 6b 0a 66 69 0a 69 |iting ch|eck.fi.i|
|00005420| 66 20 74 65 73 74 20 2d | 66 20 6c 69 62 2f 73 74 |f test -|f lib/st|
|00005430| 72 75 63 74 75 72 65 73 | 2e 66 38 33 20 2d 61 20 |ructures|.f83 -a |
|00005440| 22 24 7b 31 7d 22 20 21 | 3d 20 22 2d 63 22 20 3b |"${1}" !|= "-c" ;|
|00005450| 20 74 68 65 6e 20 0a 20 | 20 65 63 68 6f 20 73 68 | then . | echo sh|
|00005460| 61 72 3a 20 57 69 6c 6c | 20 6e 6f 74 20 6f 76 65 |ar: Will| not ove|
|00005470| 72 2d 77 72 69 74 65 20 | 65 78 69 73 74 69 6e 67 |r-write |existing|
|00005480| 20 66 69 6c 65 20 5c 22 | 6c 69 62 2f 73 74 72 75 | file \"|lib/stru|
|00005490| 63 74 75 72 65 73 2e 66 | 38 33 5c 22 0a 65 6c 73 |ctures.f|83\".els|
|000054a0| 65 0a 65 63 68 6f 20 73 | 68 61 72 3a 20 45 78 74 |e.echo s|har: Ext|
|000054b0| 72 61 63 74 69 6e 67 20 | 5c 22 6c 69 62 2f 73 74 |racting |\"lib/st|
|000054c0| 72 75 63 74 75 72 65 73 | 2e 66 38 33 5c 22 20 5c |ructures|.f83\" \|
|000054d0| 28 33 39 37 31 20 63 68 | 61 72 61 63 74 65 72 73 |(3971 ch|aracters|
|000054e0| 5c 29 0a 73 65 64 20 22 | 73 2f 5e 58 2f 2f 22 20 |\).sed "|s/^X//" |
|000054f0| 3e 6c 69 62 2f 73 74 72 | 75 63 74 75 72 65 73 2e |>lib/str|uctures.|
|00005500| 66 38 33 20 3c 3c 27 45 | 4e 44 5f 4f 46 5f 6c 69 |f83 <<'E|ND_OF_li|
|00005510| 62 2f 73 74 72 75 63 74 | 75 72 65 73 2e 66 38 33 |b/struct|ures.f83|
|00005520| 27 0a 58 5c 0a 58 5c 20 | 20 53 54 52 55 43 54 55 |'.X\.X\ | STRUCTU|
|00005530| 52 45 20 44 45 46 49 4e | 49 54 49 4f 4e 53 0a 58 |RE DEFIN|ITIONS.X|
|00005540| 5c 0a 58 5c 20 20 43 6f | 70 79 72 69 67 68 74 20 |\.X\ Co|pyright |
|00005550| 28 63 29 20 31 39 38 38 | 2d 31 39 39 30 20 62 79 |(c) 1988|-1990 by|
|00005560| 20 4d 69 6b 61 65 6c 20 | 52 2e 4b 2e 20 50 61 74 | Mikael |R.K. Pat|
|00005570| 65 6c 0a 58 5c 0a 58 5c | 20 20 43 6f 6d 70 75 74 |el.X\.X\| Comput|
|00005580| 65 72 20 41 69 64 65 64 | 20 44 65 73 69 67 6e 20 |er Aided| Design |
|00005590| 4c 61 62 6f 72 61 74 6f | 72 79 20 28 43 41 44 4c |Laborato|ry (CADL|
|000055a0| 41 42 29 0a 58 5c 20 20 | 44 65 70 61 72 74 6d 65 |AB).X\ |Departme|
|000055b0| 6e 74 20 6f 66 20 43 6f | 6d 70 75 74 65 72 20 61 |nt of Co|mputer a|
|000055c0| 6e 64 20 49 6e 66 6f 72 | 6d 61 74 69 6f 6e 20 53 |nd Infor|mation S|
|000055d0| 63 69 65 6e 63 65 0a 58 | 5c 20 20 4c 69 6e 6b 6f |cience.X|\ Linko|
|000055e0| 70 69 6e 67 20 55 6e 69 | 76 65 72 73 69 74 79 0a |ping Uni|versity.|
|000055f0| 58 5c 20 20 53 2d 35 38 | 31 20 38 33 20 4c 49 4e |X\ S-58|1 83 LIN|
|00005600| 4b 4f 50 49 4e 47 0a 58 | 5c 20 20 53 57 45 44 45 |KOPING.X|\ SWEDE|
|00005610| 4e 0a 58 5c 0a 58 5c 20 | 20 45 6d 61 69 6c 3a 20 |N.X\.X\ | Email: |
|00005620| 6d 69 70 40 69 64 61 2e | 6c 69 75 2e 73 65 0a 58 |mip@ida.|liu.se.X|
|00005630| 5c 0a 58 5c 20 20 53 74 | 61 72 74 65 64 20 6f 6e |\.X\ St|arted on|
|00005640| 3a 20 33 30 20 4a 75 6e | 65 20 31 39 38 38 0a 58 |: 30 Jun|e 1988.X|
|00005650| 5c 0a 58 5c 20 20 4c 61 | 73 74 20 75 70 64 61 74 |\.X\ La|st updat|
|00005660| 65 64 20 6f 6e 3a 20 32 | 36 20 46 65 62 72 75 61 |ed on: 2|6 Februa|
|00005670| 72 79 20 31 39 39 30 0a | 58 5c 0a 58 5c 20 20 44 |ry 1990.|X\.X\ D|
|00005680| 65 70 65 6e 64 65 6e 63 | 69 65 73 3a 0a 58 5c 20 |ependenc|ies:.X\ |
|00005690| 20 20 20 20 20 20 28 66 | 6f 72 74 68 29 20 6e 6f | (f|orth) no|
|000056a0| 6e 65 0a 58 5c 0a 58 5c | 20 20 44 65 73 63 72 69 |ne.X\.X\| Descri|
|000056b0| 70 74 69 6f 6e 3a 0a 58 | 5c 20 20 20 20 20 20 20 |ption:.X|\ |
|000056c0| 41 6c 6c 6f 77 73 20 61 | 67 67 72 65 67 61 74 65 |Allows a|ggregate|
|000056d0| 73 20 6f 66 20 64 61 74 | 61 20 74 6f 20 62 65 20 |s of dat|a to be |
|000056e0| 64 65 73 63 72 69 62 65 | 64 20 61 73 20 73 74 72 |describe|d as str|
|000056f0| 75 63 74 75 72 65 73 2e | 20 47 65 6e 65 72 61 6c |uctures.| General|
|00005700| 2d 0a 58 5c 20 20 20 20 | 20 20 20 69 7a 61 74 69 |-.X\ | izati|
|00005710| 6f 6e 20 6f 66 20 73 74 | 72 75 63 74 75 72 65 73 |on of st|ructures|
|00005720| 20 69 6e 20 74 72 61 64 | 69 74 69 6f 6e 61 6c 20 | in trad|itional |
|00005730| 70 72 6f 67 72 61 6d 6d | 69 6e 67 20 6c 61 6e 67 |programm|ing lang|
|00005740| 75 61 67 65 73 2e 20 41 | 6c 6c 6f 77 73 0a 58 5c |uages. A|llows.X\|
|00005750| 20 20 20 20 20 20 20 64 | 65 66 69 6e 69 74 69 6f | d|efinitio|
|00005760| 6e 2c 20 69 6e 69 74 69 | 61 6c 69 7a 61 74 69 6f |n, initi|alizatio|
|00005770| 6e 20 61 6e 64 20 61 63 | 74 69 6f 6e 20 70 61 72 |n and ac|tion par|
|00005780| 74 2e 20 42 61 73 69 63 | 20 6f 62 6a 65 63 74 20 |t. Basic| object |
|00005790| 62 61 73 65 64 0a 58 5c | 20 20 20 20 20 20 20 61 |based.X\| a|
|000057a0| 63 74 69 6f 6e 20 6d 61 | 79 20 62 65 20 64 65 66 |ction ma|y be def|
|000057b0| 69 6e 65 64 20 69 6e 20 | 61 20 73 74 79 6c 65 20 |ined in |a style |
|000057c0| 73 69 6d 69 6c 61 72 20 | 74 6f 20 74 68 65 20 22 |similar |to the "|
|000057d0| 64 6f 65 73 22 20 73 65 | 63 74 69 6f 6e 20 6f 66 |does" se|ction of|
|000057e0| 0a 58 5c 20 20 20 20 20 | 20 20 61 20 63 72 65 61 |.X\ | a crea|
|000057f0| 74 69 6e 67 20 77 6f 72 | 64 2e 0a 58 5c 0a 58 5c |ting wor|d..X\.X\|
|00005800| 20 20 43 6f 70 79 69 6e | 67 3a 0a 58 5c 20 20 20 | Copyin|g:.X\ |
|00005810| 20 20 20 20 54 68 69 73 | 20 70 72 6f 67 72 61 6d | This| program|
|00005820| 20 69 73 20 66 72 65 65 | 20 73 6f 66 74 77 61 72 | is free| softwar|
|00005830| 65 3b 20 79 6f 75 20 63 | 61 6e 20 72 65 64 69 73 |e; you c|an redis|
|00005840| 74 72 69 62 75 74 65 20 | 69 74 20 61 6e 64 5c 6f |tribute |it and\o|
|00005850| 72 20 6d 6f 64 69 66 79 | 0a 58 5c 20 20 20 20 20 |r modify|.X\ |
|00005860| 20 20 69 74 20 75 6e 64 | 65 72 20 74 68 65 20 74 | it und|er the t|
|00005870| 65 72 6d 73 20 6f 66 20 | 74 68 65 20 47 4e 55 20 |erms of |the GNU |
|00005880| 47 65 6e 65 72 61 6c 20 | 50 75 62 6c 69 63 20 4c |General |Public L|
|00005890| 69 63 65 6e 73 65 20 61 | 73 20 70 75 62 6c 69 73 |icense a|s publis|
|000058a0| 68 65 64 20 62 79 0a 58 | 5c 20 20 20 20 20 20 20 |hed by.X|\ |
|000058b0| 74 68 65 20 46 72 65 65 | 20 53 6f 66 74 77 61 72 |the Free| Softwar|
|000058c0| 65 20 46 6f 75 6e 64 61 | 74 69 6f 6e 3b 20 65 69 |e Founda|tion; ei|
|000058d0| 74 68 65 72 20 76 65 72 | 73 69 6f 6e 20 31 2c 20 |ther ver|sion 1, |
|000058e0| 6f 72 20 28 61 74 20 79 | 6f 75 72 20 6f 70 74 69 |or (at y|our opti|
|000058f0| 6f 6e 29 0a 58 5c 20 20 | 20 20 20 20 20 61 6e 79 |on).X\ | any|
|00005900| 20 6c 61 74 65 72 20 76 | 65 72 73 69 6f 6e 2e 0a | later v|ersion..|
|00005910| 58 5c 0a 58 5c 20 20 20 | 20 20 20 20 54 68 69 73 |X\.X\ | This|
|00005920| 20 70 72 6f 67 72 61 6d | 20 69 73 20 64 69 73 74 | program| is dist|
|00005930| 72 69 62 75 74 65 64 20 | 69 6e 20 74 68 65 20 68 |ributed |in the h|
|00005940| 6f 70 65 20 74 68 61 74 | 20 69 74 20 77 69 6c 6c |ope that| it will|
|00005950| 20 62 65 20 75 73 65 66 | 75 6c 2c 0a 58 5c 20 20 | be usef|ul,.X\ |
|00005960| 20 20 20 20 20 62 75 74 | 20 57 49 54 48 4f 55 54 | but| WITHOUT|
|00005970| 20 41 4e 59 20 57 41 52 | 52 41 4e 54 59 3b 20 77 | ANY WAR|RANTY; w|
|00005980| 69 74 68 6f 75 74 20 65 | 76 65 6e 20 74 68 65 20 |ithout e|ven the |
|00005990| 69 6d 70 6c 69 65 64 20 | 77 61 72 72 61 6e 74 79 |implied |warranty|
|000059a0| 20 6f 66 0a 58 5c 20 20 | 20 20 20 20 20 4d 45 52 | of.X\ | MER|
|000059b0| 43 48 41 4e 54 41 42 49 | 4c 49 54 59 20 6f 72 20 |CHANTABI|LITY or |
|000059c0| 46 49 54 4e 45 53 53 20 | 46 4f 52 20 41 20 50 41 |FITNESS |FOR A PA|
|000059d0| 52 54 49 43 55 4c 41 52 | 20 50 55 52 50 4f 53 45 |RTICULAR| PURPOSE|
|000059e0| 2e 20 20 53 65 65 20 74 | 68 65 0a 58 5c 20 20 20 |. See t|he.X\ |
|000059f0| 20 20 20 20 47 4e 55 20 | 47 65 6e 65 72 61 6c 20 | GNU |General |
|00005a00| 50 75 62 6c 69 63 20 4c | 69 63 65 6e 73 65 20 66 |Public L|icense f|
|00005a10| 6f 72 20 6d 6f 72 65 20 | 64 65 74 61 69 6c 73 2e |or more |details.|
|00005a20| 0a 58 5c 0a 58 5c 20 20 | 20 20 20 20 20 59 6f 75 |.X\.X\ | You|
|00005a30| 20 73 68 6f 75 6c 64 20 | 68 61 76 65 20 72 65 63 | should |have rec|
|00005a40| 65 69 76 65 64 20 61 20 | 63 6f 70 79 20 6f 66 20 |eived a |copy of |
|00005a50| 74 68 65 20 47 4e 55 20 | 47 65 6e 65 72 61 6c 20 |the GNU |General |
|00005a60| 50 75 62 6c 69 63 20 4c | 69 63 65 6e 73 65 0a 58 |Public L|icense.X|
|00005a70| 5c 20 20 20 20 20 20 20 | 61 6c 6f 6e 67 20 77 69 |\ |along wi|
|00005a80| 74 68 20 74 68 69 73 20 | 70 72 6f 67 72 61 6d 3b |th this |program;|
|00005a90| 20 73 65 65 20 74 68 65 | 20 66 69 6c 65 20 43 4f | see the| file CO|
|00005aa0| 50 59 49 4e 47 2e 20 20 | 49 66 20 6e 6f 74 2c 20 |PYING. |If not, |
|00005ab0| 77 72 69 74 65 20 74 6f | 0a 58 5c 20 20 20 20 20 |write to|.X\ |
|00005ac0| 20 20 74 68 65 20 46 72 | 65 65 20 53 6f 66 74 77 | the Fr|ee Softw|
|00005ad0| 61 72 65 20 46 6f 75 6e | 64 61 74 69 6f 6e 2c 20 |are Foun|dation, |
|00005ae0| 36 37 35 20 4d 61 73 73 | 20 41 76 65 2c 20 43 61 |675 Mass| Ave, Ca|
|00005af0| 6d 62 72 69 64 67 65 2c | 20 4d 41 20 30 32 31 33 |mbridge,| MA 0213|
|00005b00| 39 2c 20 55 53 41 2e 20 | 0a 58 0a 58 2e 28 20 4c |9, USA. |.X.X.( L|
|00005b10| 6f 61 64 69 6e 67 20 53 | 74 72 75 63 74 75 72 65 |oading S|tructure|
|00005b20| 20 64 65 66 69 6e 69 74 | 69 6f 6e 73 2e 2e 2e 29 | definit|ions...)|
|00005b30| 20 63 72 0a 58 0a 58 76 | 6f 63 61 62 75 6c 61 72 | cr.X.Xv|ocabular|
|00005b40| 79 20 73 74 72 75 63 74 | 75 72 65 73 0a 58 0a 58 |y struct|ures.X.X|
|00005b50| 73 74 72 75 63 74 75 72 | 65 73 20 64 65 66 69 6e |structur|es defin|
|00005b60| 69 74 69 6f 6e 73 20 0a | 58 0a 58 30 20 20 20 20 |itions .|X.X0 |
|00005b70| 66 69 65 6c 64 20 2b 73 | 69 7a 65 20 28 20 73 74 |field +s|ize ( st|
|00005b80| 72 75 63 74 20 2d 2d 20 | 73 69 7a 65 29 20 70 72 |ruct -- |size) pr|
|00005b90| 69 76 61 74 65 0a 58 63 | 65 6c 6c 20 66 69 65 6c |ivate.Xc|ell fiel|
|00005ba0| 64 20 2b 69 6e 69 74 69 | 61 74 65 20 28 20 73 74 |d +initi|ate ( st|
|00005bb0| 72 75 63 74 20 2d 2d 20 | 69 6e 69 74 69 61 74 65 |ruct -- |initiate|
|00005bc0| 29 20 70 72 69 76 61 74 | 65 0a 58 0a 58 3a 20 61 |) privat|e.X.X: a|
|00005bd0| 73 20 28 20 2d 2d 20 73 | 74 72 75 63 74 29 20 20 |s ( -- s|truct) |
|00005be0| 0a 58 20 20 27 20 3e 62 | 6f 64 79 20 09 09 09 09 |.X ' >b|ody ....|
|00005bf0| 28 20 51 75 6f 74 65 20 | 6e 65 78 74 20 73 79 6d |( Quote |next sym|
|00005c00| 62 6f 6c 20 61 6e 64 20 | 61 63 63 65 73 73 20 62 |bol and |access b|
|00005c10| 6f 64 79 29 0a 58 20 20 | 5b 63 6f 6d 70 69 6c 65 |ody).X |[compile|
|00005c20| 5d 20 6c 69 74 65 72 61 | 6c 09 09 09 28 20 49 66 |] litera|l...( If|
|00005c30| 20 63 6f 6d 70 69 6c 69 | 6e 67 20 67 65 6e 65 72 | compili|ng gener|
|00005c40| 61 74 65 20 61 20 6c 69 | 74 65 72 61 6c 29 0a 58 |ate a li|teral).X|
|00005c50| 3b 20 69 6d 6d 65 64 69 | 61 74 65 09 09 09 09 0a |; immedi|ate.....|
|00005c60| 58 0a 58 3a 20 74 68 69 | 73 20 28 20 2d 2d 20 70 |X.X: thi|s ( -- p|
|00005c70| 74 72 29 20 20 0a 58 20 | 20 6c 61 73 74 20 3e 62 |tr) .X | last >b|
|00005c80| 6f 64 79 20 09 09 09 09 | 28 20 41 63 63 65 73 73 |ody ....|( Access|
|00005c90| 20 74 68 65 20 62 6f 64 | 79 20 6f 66 20 74 68 65 | the bod|y of the|
|00005ca0| 20 6c 61 73 74 20 73 79 | 6d 62 6f 6c 29 0a 58 3b | last sy|mbol).X;|
|00005cb0| 0a 58 0a 58 3a 20 69 6e | 69 74 69 61 74 65 20 28 |.X.X: in|itiate (|
|00005cc0| 20 70 74 72 20 73 74 72 | 75 63 74 20 2d 2d 20 29 | ptr str|uct -- )|
|00005cd0| 20 20 0a 58 20 20 2b 69 | 6e 69 74 69 61 74 65 20 | .X +i|nitiate |
|00005ce0| 40 20 3f 64 75 70 09 09 | 09 28 20 41 63 63 65 73 |@ ?dup..|.( Acces|
|00005cf0| 73 20 69 6e 69 74 69 61 | 74 65 2e 20 63 6f 64 65 |s initia|te. code|
|00005d00| 20 70 6f 69 6e 74 65 72 | 29 0a 58 20 20 69 66 20 | pointer|).X if |
|00005d10| 3e 72 20 65 6c 73 65 20 | 64 72 6f 70 20 74 68 65 |>r else |drop the|
|00005d20| 6e 09 09 09 28 20 49 66 | 20 61 76 61 69 6c 61 62 |n...( If| availab|
|00005d30| 6c 65 20 70 65 72 66 6f | 72 6d 20 69 6e 69 74 69 |le perfo|rm initi|
|00005d40| 61 6c 69 7a 61 74 69 6f | 6e 29 0a 58 3b 0a 58 0a |alizatio|n).X;.X.|
|00005d50| 58 3a 20 6d 61 6b 65 20 | 28 20 73 74 72 75 63 74 |X: make |( struct|
|00005d60| 20 2d 2d 20 70 74 72 29 | 20 0a 58 20 20 68 65 72 | -- ptr)| .X her|
|00005d70| 65 20 64 75 70 20 3e 72 | 20 09 09 09 09 28 20 53 |e dup >r| ....( S|
|00005d80| 61 76 65 20 70 6f 69 6e | 74 65 72 20 74 6f 20 69 |ave poin|ter to i|
|00005d90| 6e 73 74 61 6e 63 65 29 | 0a 58 20 20 6f 76 65 72 |nstance)|.X over|
|00005da0| 20 2b 73 69 7a 65 20 40 | 20 61 6c 6c 6f 74 20 09 | +size @| allot .|
|00005db0| 09 09 28 20 41 63 63 65 | 73 73 20 73 69 7a 65 20 |..( Acce|ss size |
|00005dc0| 61 6e 64 20 61 6c 6c 6f | 63 61 74 65 20 6d 65 6d |and allo|cate mem|
|00005dd0| 6f 72 79 29 0a 58 20 20 | 73 77 61 70 20 69 6e 69 |ory).X |swap ini|
|00005de0| 74 69 61 74 65 20 72 3e | 20 09 09 09 28 20 50 65 |tiate r>| ...( Pe|
|00005df0| 72 66 6f 72 6d 20 69 6e | 69 74 69 61 6c 69 7a 61 |rform in|itializa|
|00005e00| 74 69 6f 6e 29 0a 58 3b | 0a 58 0a 58 3a 20 6e 65 |tion).X;|.X.X: ne|
|00005e10| 77 20 28 20 2d 2d 20 70 | 74 72 29 20 20 0a 58 20 |w ( -- p|tr) .X |
|00005e20| 20 5b 63 6f 6d 70 69 6c | 65 5d 20 61 73 20 09 09 | [compil|e] as ..|
|00005e30| 09 09 28 20 54 61 6b 65 | 20 74 68 65 20 6e 65 78 |..( Take| the nex|
|00005e40| 74 20 73 79 6d 62 6f 6c | 2c 20 22 61 73 22 29 0a |t symbol|, "as").|
|00005e50| 58 20 20 3f 63 6f 6d 70 | 69 6c 65 20 6d 61 6b 65 |X ?comp|ile make|
|00005e60| 09 09 09 09 28 20 41 6e | 64 20 22 6d 61 6b 65 22 |....( An|d "make"|
|00005e70| 20 61 6e 20 69 6e 73 74 | 61 6e 63 65 29 0a 58 3b | an inst|ance).X;|
|00005e80| 20 69 6d 6d 65 64 69 61 | 74 65 09 09 09 09 0a 58 | immedia|te.....X|
|00005e90| 0a 58 3a 20 73 69 7a 65 | 6f 66 20 28 20 2d 2d 20 |.X: size|of ( -- |
|00005ea0| 73 69 7a 65 29 20 20 0a | 58 20 20 27 20 3e 62 6f |size) .|X ' >bo|
|00005eb0| 64 79 20 2b 73 69 7a 65 | 20 40 20 09 09 09 28 20 |dy +size| @ ...( |
|00005ec0| 41 63 63 65 73 73 20 73 | 69 7a 65 20 6f 66 20 73 |Access s|ize of s|
|00005ed0| 74 72 75 63 74 75 72 65 | 29 0a 58 20 20 5b 63 6f |tructure|).X [co|
|00005ee0| 6d 70 69 6c 65 5d 20 6c | 69 74 65 72 61 6c 09 09 |mpile] l|iteral..|
|00005ef0| 09 28 20 41 6e 64 20 6d | 61 6b 65 20 6c 69 74 65 |.( And m|ake lite|
|00005f00| 72 61 6c 20 69 66 20 63 | 6f 6d 70 69 6c 69 6e 67 |ral if c|ompiling|
|00005f10| 29 0a 58 3b 20 69 6d 6d | 65 64 69 61 74 65 0a 58 |).X; imm|ediate.X|
|00005f20| 0a 58 3a 20 61 73 73 69 | 67 6e 20 28 20 61 20 62 |.X: assi|gn ( a b|
|00005f30| 20 2d 2d 20 29 20 20 0a | 58 20 20 5b 63 6f 6d 70 | -- ) .|X [comp|
|00005f40| 69 6c 65 5d 20 73 69 7a | 65 6f 66 20 3f 63 6f 6d |ile] siz|eof ?com|
|00005f50| 70 69 6c 65 20 63 6d 6f | 76 65 09 28 20 41 63 63 |pile cmo|ve.( Acc|
|00005f60| 65 73 73 20 73 69 7a 65 | 20 61 6e 64 20 61 73 73 |ess size| and ass|
|00005f70| 69 67 6e 20 69 6e 73 74 | 61 6e 63 65 29 0a 58 3b |ign inst|ance).X;|
|00005f80| 20 69 6d 6d 65 64 69 61 | 74 65 0a 58 0a 58 3a 20 | immedia|te.X.X: |
|00005f90| 73 74 72 75 63 74 2e 74 | 79 70 65 20 28 20 2d 2d |struct.t|ype ( --|
|00005fa0| 20 73 74 72 75 63 74 20 | 6f 66 66 73 65 74 30 29 | struct |offset0)|
|00005fb0| 20 20 0a 58 20 20 63 72 | 65 61 74 65 20 68 65 72 | .X cr|eate her|
|00005fc0| 65 20 30 20 30 20 2c 20 | 30 20 2c 20 09 09 28 20 |e 0 0 , |0 , ..( |
|00005fd0| 41 6c 6c 6f 63 61 74 65 | 20 69 6e 69 74 69 61 6c |Allocate| initial|
|00005fe0| 20 73 74 72 75 63 74 20 | 69 6e 66 6f 72 6d 61 74 | struct |informat|
|00005ff0| 69 6f 6e 29 0a 58 64 6f | 65 73 3e 20 28 20 73 74 |ion).Xdo|es> ( st|
|00006000| 72 75 63 74 2e 74 79 70 | 65 20 2d 2d 20 29 0a 58 |ruct.typ|e -- ).X|
|00006010| 20 20 63 72 65 61 74 65 | 20 6d 61 6b 65 20 64 72 | create| make dr|
|00006020| 6f 70 09 09 09 28 20 43 | 72 65 61 74 65 20 61 20 |op...( C|reate a |
|00006030| 6e 65 77 20 69 6e 73 74 | 61 6e 63 65 29 0a 58 3b |new inst|ance).X;|
|00006040| 0a 58 0a 58 3a 20 62 79 | 74 65 73 20 28 20 6f 66 |.X.X: by|tes ( of|
|00006050| 66 73 65 74 31 20 6e 20 | 2d 2d 20 6f 66 66 73 65 |fset1 n |-- offse|
|00006060| 74 32 29 20 20 0a 58 20 | 20 6f 76 65 72 20 64 75 |t2) .X | over du|
|00006070| 70 09 09 09 09 28 20 43 | 68 65 63 6b 20 66 6f 72 |p....( C|heck for|
|00006080| 20 7a 65 72 6f 20 6f 66 | 66 73 65 74 29 0a 58 20 | zero of|fset).X |
|00006090| 20 69 66 20 66 69 65 6c | 64 20 2b 09 09 09 09 28 | if fiel|d +....(|
|000060a0| 20 43 72 65 61 74 65 20 | 61 6e 20 61 63 63 65 73 | Create |an acces|
|000060b0| 73 20 66 69 65 6c 64 20 | 6f 66 20 22 6e 22 20 62 |s field |of "n" b|
|000060c0| 79 74 65 73 29 0a 58 20 | 20 65 6c 73 65 0a 58 20 |ytes).X | else.X |
|000060d0| 20 20 20 63 72 65 61 74 | 65 20 2c 20 2b 20 69 6d | creat|e , + im|
|000060e0| 6d 65 64 69 61 74 65 09 | 09 28 20 43 72 65 61 74 |mediate.|.( Creat|
|000060f0| 65 20 61 6e 20 65 66 66 | 69 63 69 65 6e 74 20 66 |e an eff|icient f|
|00006100| 69 65 6c 64 29 0a 58 20 | 20 20 20 64 6f 65 73 3e |ield).X | does>|
|00006110| 20 28 20 66 69 65 6c 64 | 20 2d 2d 20 29 0a 58 20 | ( field| -- ).X |
|00006120| 20 20 20 20 20 64 72 6f | 70 09 09 09 09 28 20 44 | dro|p....( D|
|00006130| 6f 65 73 20 6e 6f 74 68 | 69 6e 67 20 61 74 20 72 |oes noth|ing at r|
|00006140| 75 6e 74 69 6d 65 20 29 | 0a 58 20 20 74 68 65 6e |untime )|.X then|
|00006150| 0a 58 3b 0a 58 0a 58 3a | 20 61 6c 69 67 6e 20 28 |.X;.X.X:| align (|
|00006160| 20 6f 66 66 73 65 74 31 | 20 2d 2d 20 6f 66 66 73 | offset1| -- offs|
|00006170| 65 74 32 29 20 20 0a 58 | 20 20 64 75 70 20 31 20 |et2) .X| dup 1 |
|00006180| 61 6e 64 20 2b 20 09 09 | 09 09 28 20 41 6c 69 67 |and + ..|..( Alig|
|00006190| 6e 20 66 69 65 6c 64 20 | 6f 66 66 73 65 74 20 74 |n field |offset t|
|000061a0| 6f 20 65 76 65 6e 20 61 | 64 64 72 65 73 73 29 0a |o even a|ddress).|
|000061b0| 58 3b 0a 58 0a 58 3a 20 | 66 69 65 6c 64 20 28 20 |X;.X.X: |field ( |
|000061c0| 62 79 74 65 73 20 2d 2d | 20 29 20 20 0a 58 20 20 |bytes --| ) .X |
|000061d0| 63 72 65 61 74 65 20 2c | 20 6e 69 6c 20 2c 09 09 |create ,| nil ,..|
|000061e0| 09 28 20 43 72 65 61 74 | 65 20 61 20 70 72 65 64 |.( Creat|e a pred|
|000061f0| 65 66 69 6e 65 64 20 66 | 69 65 6c 64 20 74 79 70 |efined f|ield typ|
|00006200| 65 29 0a 58 64 6f 65 73 | 3e 20 28 20 66 69 65 6c |e).Xdoes|> ( fiel|
|00006210| 64 20 2d 2d 20 29 0a 58 | 20 20 40 20 62 79 74 65 |d -- ).X| @ byte|
|00006220| 73 09 09 09 09 28 20 41 | 74 20 72 75 6e 2d 74 69 |s....( A|t run-ti|
|00006230| 6d 65 20 63 72 65 61 74 | 65 20 66 69 65 6c 64 20 |me creat|e field |
|00006240| 6e 61 6d 65 73 29 0a 58 | 3b 20 70 72 69 76 61 74 |names).X|; privat|
|00006250| 65 0a 58 0a 58 3a 20 73 | 74 72 75 63 74 20 28 20 |e.X.X: s|truct ( |
|00006260| 2d 2d 20 29 20 20 0a 58 | 20 20 5b 63 6f 6d 70 69 |-- ) .X| [compi|
|00006270| 6c 65 5d 20 73 69 7a 65 | 6f 66 20 62 79 74 65 73 |le] size|of bytes|
|00006280| 20 09 09 28 20 43 72 65 | 61 74 65 20 61 20 73 74 | ..( Cre|ate a st|
|00006290| 72 75 63 74 75 72 65 20 | 73 69 7a 65 64 20 66 69 |ructure |sized fi|
|000062a0| 65 6c 64 20 6e 61 6d 65 | 29 0a 58 3b 0a 58 0a 58 |eld name|).X;.X.X|
|000062b0| 28 20 49 6e 69 74 69 61 | 6c 20 73 65 74 20 6f 66 |( Initia|l set of|
|000062c0| 20 66 69 65 6c 64 20 6e | 61 6d 65 73 29 0a 58 31 | field n|ames).X1|
|000062d0| 20 66 69 65 6c 64 20 62 | 79 74 65 20 28 20 2d 2d | field b|yte ( --|
|000062e0| 20 29 0a 58 32 20 66 69 | 65 6c 64 20 77 6f 72 64 | ).X2 fi|eld word|
|000062f0| 20 28 20 2d 2d 20 29 0a | 58 34 20 66 69 65 6c 64 | ( -- ).|X4 field|
|00006300| 20 6c 6f 6e 67 20 28 20 | 2d 2d 20 29 0a 58 34 20 | long ( |-- ).X4 |
|00006310| 66 69 65 6c 64 20 70 74 | 72 20 20 28 20 2d 2d 20 |field pt|r ( -- |
|00006320| 29 0a 58 34 20 66 69 65 | 6c 64 20 65 6e 75 6d 20 |).X4 fie|ld enum |
|00006330| 28 20 2d 2d 20 29 0a 58 | 0a 58 3a 20 73 74 72 75 |( -- ).X|.X: stru|
|00006340| 63 74 2e 69 6e 69 74 20 | 28 20 73 74 72 75 63 74 |ct.init |( struct|
|00006350| 20 6f 66 66 73 65 74 33 | 20 2d 2d 20 29 0a 58 20 | offset3| -- ).X |
|00006360| 20 61 6c 69 67 6e 20 6f | 76 65 72 20 2b 73 69 7a | align o|ver +siz|
|00006370| 65 20 21 20 20 09 09 09 | 28 20 41 73 73 69 67 6e |e ! ...|( Assign|
|00006380| 20 73 69 7a 65 20 6f 66 | 20 73 74 72 75 63 74 75 | size of| structu|
|00006390| 72 65 20 74 79 70 65 29 | 0a 58 20 20 68 65 72 65 |re type)|.X here|
|000063a0| 20 73 77 61 70 20 2b 69 | 6e 69 74 69 61 74 65 20 | swap +i|nitiate |
|000063b0| 21 20 5d 20 09 09 28 20 | 41 6e 64 20 70 6f 69 6e |! ] ..( |And poin|
|000063c0| 74 65 72 20 74 6f 20 69 | 6e 69 74 69 61 6c 69 7a |ter to i|nitializ|
|000063d0| 61 74 69 6f 6e 20 63 6f | 64 65 29 0a 58 3b 0a 58 |ation co|de).X;.X|
|000063e0| 0a 58 3a 20 73 74 72 75 | 63 74 2e 64 6f 65 73 20 |.X: stru|ct.does |
|000063f0| 28 20 2d 2d 20 29 20 0a | 58 20 20 5b 63 6f 6d 70 |( -- ) .|X [comp|
+--------+-------------------------+-------------------------+--------+--------+
Only 25.0 KB of data is shown above.