home *** CD-ROM | disk | FTP | other *** search
/ The Datafile PD-CD 3 / PDCD_3.iso / languages / siod_v2 < prev    next >
ArcFS Archive  |  1995-09-16  |  148.8 KB

open in: MacOS 8.1     |     Win98     |     DOS

browse contents    |     view JSON data     |     view as text


This file was processed as: ArcFS Archive (archive/arcFS).

ConfidenceProgramDetectionMatch TypeSupport
100% dexvert ArcFS Archive (archive/arcFS) magic Supported
100% file RISC OS archive (ArcFS format) default
99% file data default
100% TrID Acorn ArcFS Archive default
100% gt2 Kopftext: 'Archive' default (weak)
100% detectItEasy Archive: ArcFS default



hex view
+--------+-------------------------+-------------------------+--------+--------+
|00000000| 41 72 63 68 69 76 65 00 | f4 02 00 00 54 03 00 00 |Archive.|....T...|
|00000010| 28 00 00 00 64 00 00 00 | 00 00 00 00 00 00 00 00 |(...d...|........|
|00000020| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000030| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000040| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000050| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000060| 82 21 43 73 74 61 72 74 | 00 00 00 00 3c 04 00 00 |.!Cstart|....<...|
|00000070| 43 eb ff ff b1 2a 8c f2 | 03 00 b1 ec 3c 04 00 00 |C....*..|....<...|
|00000080| 24 00 00 00 82 63 00 00 | 00 00 00 00 00 00 00 00 |$....c..|........|
|00000090| ff ff ff ff 46 ff ff ff | b3 b2 27 52 30 00 00 00 |....F...|..'R0...|
|000000a0| ff ff ff ff b4 00 00 80 | 83 73 69 6f 64 00 00 00 |........|.siod...|
|000000b0| 00 00 00 00 19 11 00 00 | 43 ff ff ff c8 cd 6a f2 |........|C.....j.|
|000000c0| 33 00 46 96 85 10 00 00 | 84 04 00 00 83 73 6c 69 |3.F.....|.....sli|
|000000d0| 62 00 00 00 00 00 00 00 | 74 97 00 00 43 ff ff ff |b.......|t...C...|
|000000e0| 85 d9 92 f2 03 00 00 00 | 86 93 00 00 2d 15 00 00 |........|....-...|
|000000f0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000100| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000110| ac fc ff ff 82 68 00 00 | 00 00 00 00 00 00 00 00 |.....h..|........|
|00000120| ff ff ff ff 46 ff ff ff | 4e b3 27 52 30 00 00 00 |....F...|N.'R0...|
|00000130| ff ff ff ff 20 01 00 80 | 83 73 69 6f 64 00 00 00 |.... ...|.siod...|
|00000140| 00 00 00 00 c0 0b 00 00 | 43 ff ff ff c8 cd 6a f2 |........|C.....j.|
|00000150| 33 00 2d d2 73 0b 00 00 | d7 a8 00 00 00 00 00 00 |3.-.s...|........|
|00000160| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000170| 00 00 00 00 00 00 00 00 | 00 00 00 00 ac fc ff ff |........|........|
|00000180| 83 6d 61 6b 65 66 69 6c | 65 00 00 00 ee 00 00 00 |.makefil|e.......|
|00000190| 43 ff ff ff 90 fb 8c f2 | 03 00 4f f0 da 00 00 00 |C.......|..O.....|
|000001a0| 6e b4 00 00 82 6f 00 00 | 00 00 00 00 00 00 00 00 |n....o..|........|
|000001b0| ff ff ff ff 46 ff ff ff | d3 b3 27 52 30 00 00 00 |....F...|..'R0...|
|000001c0| ff ff ff ff d4 01 00 80 | 83 73 69 6f 64 00 00 00 |........|.siod...|
|000001d0| 00 00 00 00 10 11 00 00 | 43 fd ff ff b3 c2 91 f2 |........|C.......|
|000001e0| 03 00 07 4d 9c 0f 00 00 | 6c b5 00 00 83 73 6c 69 |...M....|l....sli|
|000001f0| 62 00 00 00 00 00 00 00 | 40 81 00 00 43 fd ff ff |b.......|@...C...|
|00000200| 67 a3 92 f2 03 00 00 00 | 23 7e 00 00 2c c5 00 00 |g.......|#~..,...|
|00000210| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000220| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000230| ac fc ff ff 83 70 72 61 | 74 74 5f 73 63 6d 00 00 |.....pra|tt_scm..|
|00000240| 4e 1b 00 00 43 ff ff ff | c8 cd 6a f2 33 00 95 e1 |N...C...|..j.3...|
|00000250| ef 19 00 00 73 43 01 00 | 83 72 65 61 64 6d 65 00 |....sC..|.readme.|
|00000260| 00 00 00 00 2e 04 00 00 | 44 ff ff ff 20 f0 2b b2 |........|D... .+.|
|00000270| 11 00 1a 58 25 04 00 00 | 86 5d 01 00 83 73 69 6f |...X%...|.]...sio|
|00000280| 64 00 00 00 00 00 00 00 | 9f 87 00 00 43 f8 ff ff |d.......|....C...|
|00000290| 60 a4 92 f2 03 00 00 00 | 8f 87 00 00 cf 61 01 00 |`.......|.....a..|
|000002a0| 83 73 69 6f 64 5f 31 00 | 00 00 00 00 e5 05 00 00 |.siod_1.|........|
|000002b0| 43 ff ff ff c8 cd 6a f2 | 33 00 32 03 d3 05 00 00 |C.....j.|3.2.....|
|000002c0| 82 e9 01 00 83 73 69 6f | 64 5f 64 6f 63 00 00 00 |.....sio|d_doc...|
|000002d0| 92 47 00 00 43 ff ff ff | 53 2b 0c f3 03 00 a4 f2 |.G..C...|S+......|
|000002e0| 57 46 00 00 79 ef 01 00 | 83 73 69 6f 64 5f 73 63 |WF..y...|.siod_sc|
|000002f0| 6d 00 00 00 be 15 00 00 | 43 ff ff ff c8 cd 6a f2 |m.......|C.....j.|
|00000300| 33 00 98 e9 b6 14 00 00 | f4 35 02 00 83 73 69 6f |3.......|.5...sio|
|00000310| 64 5f 74 69 6d 00 00 00 | 81 05 00 00 43 ff ff ff |d_tim...|....C...|
|00000320| c8 cd 6a f2 33 00 ca a7 | f9 04 00 00 ce 4a 02 00 |..j.3...|.....J..|
|00000330| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000340| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000350| 00 00 00 00 46 69 6c 65 | 44 61 74 61 82 21 43 73 |....File|Data.!Cs|
|00000360| 74 61 72 74 00 00 00 00 | 3c 04 00 00 43 eb ff ff |tart....|<...C...|
|00000370| b1 2a 8c f2 03 00 b1 ec | 7c 20 3e 20 21 43 73 74 |.*......|| > !Cst|
|00000380| 61 72 74 0a 7c 0a 73 65 | 74 20 63 6c 69 62 24 66 |art.|.se|t clib$f|
|00000390| 6c 61 67 20 30 0a 52 4d | 65 6e 73 75 72 65 20 53 |lag 0.RM|ensure S|
|000003a0| 68 61 72 65 64 43 6c 69 | 62 72 61 72 79 20 33 2e |haredCli|brary 3.|
|000003b0| 35 30 20 73 65 74 20 63 | 6c 69 62 24 66 6c 61 67 |50 set c|lib$flag|
|000003c0| 20 31 0a 52 4d 65 6e 73 | 75 72 65 20 53 68 61 72 | 1.RMens|ure Shar|
|000003d0| 65 64 43 6c 69 62 72 61 | 72 79 20 30 20 73 65 74 |edClibra|ry 0 set|
|000003e0| 20 63 6c 69 62 24 66 6c | 61 67 20 30 0a 69 66 20 | clib$fl|ag 0.if |
|000003f0| 22 3c 63 6c 69 62 24 66 | 6c 61 67 3e 22 3d 22 31 |"<clib$f|lag>"="1|
|00000400| 22 20 74 68 65 6e 20 45 | 72 72 6f 72 20 21 21 21 |" then E|rror !!!|
|00000410| 20 4f 6c 64 20 73 68 61 | 72 65 64 20 43 20 6c 69 | Old sha|red C li|
|00000420| 62 72 61 72 79 20 21 21 | 21 20 41 6e 20 6f 6c 64 |brary !!|! An old|
|00000430| 20 76 65 72 73 69 6f 6e | 20 6f 66 20 74 68 65 20 | version| of the |
|00000440| 73 68 61 72 65 64 20 43 | 20 6c 69 62 72 61 72 79 |shared C| library|
|00000450| 20 28 63 6c 69 62 29 20 | 69 73 20 72 65 73 69 64 | (clib) |is resid|
|00000460| 65 6e 74 20 69 6e 20 6d | 65 6d 6f 72 79 2e 20 53 |ent in m|emory. S|
|00000470| 65 65 20 70 61 67 65 20 | 34 34 2d 34 35 20 6f 66 |ee page |44-45 of|
|00000480| 20 74 68 65 20 41 63 6f | 72 6e 20 43 20 6d 61 6e | the Aco|rn C man|
|00000490| 75 61 6c 2e 0a 75 6e 73 | 65 74 20 63 6c 69 62 24 |ual..uns|et clib$|
|000004a0| 66 6c 61 67 0a 7c 0a 45 | 63 68 6f 20 21 43 73 74 |flag.|.E|cho !Cst|
|000004b0| 61 72 74 20 70 72 6f 63 | 65 64 75 72 65 20 66 6f |art proc|edure fo|
|000004c0| 72 20 67 65 74 74 69 6e | 67 20 73 74 61 72 74 65 |r gettin|g starte|
|000004d0| 64 0a 45 63 68 6f 20 0a | 7c 0a 61 64 66 73 0a 45 |d.Echo .||.adfs.E|
|000004e0| 63 68 6f 20 41 64 76 61 | 6e 63 65 64 20 44 69 73 |cho Adva|nced Dis|
|000004f0| 63 20 46 69 6c 69 6e 67 | 20 53 79 73 74 65 6d 20 |c Filing| System |
|00000500| 73 65 6c 65 63 74 65 64 | 0a 45 63 68 6f 0a 7c 0a |selected|.Echo.|.|
|00000510| 73 65 74 20 63 24 6c 6f | 63 20 3a 49 44 45 44 69 |set c$lo|c :IDEDi|
|00000520| 73 63 34 2e 24 0a 7c 0a | 52 4d 65 6e 73 75 72 65 |sc4.$.|.|RMensure|
|00000530| 20 53 68 61 72 65 64 43 | 6c 69 62 72 61 72 79 20 | SharedC|library |
|00000540| 33 2e 35 30 20 52 4d 6c | 6f 61 64 20 3c 63 24 6c |3.50 RMl|oad <c$l|
|00000550| 6f 63 3e 2e 21 53 79 73 | 74 65 6d 2e 6d 6f 64 75 |oc>.!Sys|tem.modu|
|00000560| 6c 65 73 2e 63 6c 69 62 | 0a 52 4d 65 6e 73 75 72 |les.clib|.RMensur|
|00000570| 65 20 53 68 61 72 65 64 | 43 6c 69 62 72 61 72 79 |e Shared|Clibrary|
|00000580| 20 33 2e 35 30 20 45 72 | 72 6f 72 20 59 6f 75 20 | 3.50 Er|ror You |
|00000590| 6e 65 65 64 20 61 74 20 | 6c 65 61 73 74 20 76 65 |need at |least ve|
|000005a0| 72 73 69 6f 6e 20 33 2e | 35 30 20 6f 66 20 74 68 |rsion 3.|50 of th|
|000005b0| 65 20 73 68 61 72 65 64 | 20 43 20 6c 69 62 72 61 |e shared| C libra|
|000005c0| 72 79 0a 45 63 68 6f 20 | 56 65 72 73 69 6f 6e 20 |ry.Echo |Version |
|000005d0| 33 2e 35 30 2c 20 6f 72 | 20 6c 61 74 65 72 2c 20 |3.50, or| later, |
|000005e0| 6f 66 20 74 68 65 20 73 | 68 61 72 65 64 20 43 20 |of the s|hared C |
|000005f0| 6c 69 62 72 61 72 79 20 | 69 6e 73 74 61 6c 6c 65 |library |installe|
|00000600| 64 0a 7c 0a 52 4d 65 6e | 73 75 72 65 20 46 50 45 |d.|.RMen|sure FPE|
|00000610| 6d 75 6c 61 74 6f 72 20 | 32 2e 38 30 20 52 4d 6c |mulator |2.80 RMl|
|00000620| 6f 61 64 20 3c 63 24 6c | 6f 63 3e 2e 21 53 79 73 |oad <c$l|oc>.!Sys|
|00000630| 74 65 6d 2e 6d 6f 64 75 | 6c 65 73 2e 46 50 45 32 |tem.modu|les.FPE2|
|00000640| 38 30 0a 52 4d 65 6e 73 | 75 72 65 20 46 50 45 6d |80.RMens|ure FPEm|
|00000650| 75 6c 61 74 6f 72 20 32 | 2e 38 30 20 45 72 72 6f |ulator 2|.80 Erro|
|00000660| 72 20 59 6f 75 20 6e 65 | 65 64 20 61 74 20 6c 65 |r You ne|ed at le|
|00000670| 61 73 74 20 76 65 72 73 | 69 6f 6e 20 32 2e 38 30 |ast vers|ion 2.80|
|00000680| 20 6f 66 20 74 68 65 20 | 66 6c 6f 61 74 69 6e 67 | of the |floating|
|00000690| 20 70 6f 69 6e 74 20 65 | 6d 75 6c 61 74 6f 72 0a | point e|mulator.|
|000006a0| 45 63 68 6f 20 46 50 45 | 20 32 2e 38 30 20 28 6f |Echo FPE| 2.80 (o|
|000006b0| 72 20 6c 61 74 65 72 29 | 20 69 6e 73 74 61 6c 6c |r later)| install|
|000006c0| 65 64 0a 45 63 68 6f 0a | 7c 0a 4c 49 42 20 3c 63 |ed.Echo.||.LIB <c|
|000006d0| 24 6c 6f 63 3e 2e 43 2d | 43 6f 6d 70 69 6c 65 72 |$loc>.C-|Compiler|
|000006e0| 2e 6c 69 62 72 61 72 79 | 0a 45 63 68 6f 20 3c 63 |.library|.Echo <c|
|000006f0| 24 6c 6f 63 3e 2e 43 2d | 43 6f 6d 70 69 6c 65 72 |$loc>.C-|Compiler|
|00000700| 2e 4c 69 62 72 61 72 79 | 20 73 65 74 20 61 73 20 |.Library| set as |
|00000710| 74 68 65 20 63 75 72 72 | 65 6e 74 20 6c 69 62 72 |the curr|ent libr|
|00000720| 61 72 79 0a 44 49 52 20 | 3c 63 24 6c 6f 63 3e 2e |ary.DIR |<c$loc>.|
|00000730| 73 69 6f 64 2d 76 32 5f | 34 0a 45 63 68 6f 20 3c |siod-v2_|4.Echo <|
|00000740| 63 24 6c 6f 63 3e 2e 73 | 69 6f 64 2d 76 32 5f 34 |c$loc>.s|iod-v2_4|
|00000750| 20 73 65 6c 65 63 74 65 | 64 20 61 73 20 74 68 65 | selecte|d as the|
|00000760| 20 63 75 72 72 65 6e 74 | 20 64 69 72 65 63 74 6f | current| directo|
|00000770| 72 79 0a 45 63 68 6f 0a | 7c 0a 75 6e 73 65 74 20 |ry.Echo.||.unset |
|00000780| 63 24 6c 6f 63 0a 45 63 | 68 6f 20 21 43 73 74 61 |c$loc.Ec|ho !Csta|
|00000790| 72 74 20 70 72 6f 63 65 | 64 75 72 65 20 73 75 63 |rt proce|dure suc|
|000007a0| 63 65 73 73 66 75 6c 6c | 79 20 63 6f 6d 70 6c 65 |cessfull|y comple|
|000007b0| 74 65 64 0a 46 69 6c 65 | 44 61 74 61 83 73 69 6f |ted.File|Data.sio|
|000007c0| 64 00 00 00 00 00 00 00 | 19 11 00 00 43 ff ff ff |d.......|....C...|
|000007d0| c8 cd 6a f2 03 00 46 96 | 2f 2a 20 53 63 68 65 6d |..j...F.|/* Schem|
|000007e0| 65 20 49 6e 20 4f 6e 65 | 20 44 65 66 75 6e 2c 20 |e In One| Defun, |
|000007f0| 62 75 74 20 69 6e 20 43 | 20 74 68 69 73 20 74 69 |but in C| this ti|
|00000800| 6d 65 2e 0a 20 0a 20 2a | 20 90 18 43 4f 50 59 52 |me.. . *| ..COPYR|
|00000810| 49 47 48 54 20 28 63 29 | 20 31 39 38 39 20 42 59 |IGHT (c)| 1989 BY|
|00000820| 20 90 1d 2a 0a 20 2a 20 | 90 08 50 41 52 41 44 49 | ..*. * |..PARADI|
|00000830| 47 4d 20 41 53 53 4f 43 | 49 41 54 45 53 20 49 4e |GM ASSOC|IATES IN|
|00000840| 43 4f 52 50 4f 52 41 54 | 45 44 2c 20 43 41 4d 42 |CORPORAT|ED, CAMB|
|00000850| 52 49 44 47 45 2c 20 4d | 41 53 53 41 43 48 55 53 |RIDGE, M|ASSACHUS|
|00000860| 45 54 54 53 2e 20 90 07 | 2a 0a 20 2a 20 90 08 53 |ETTS. ..|*. * ..S|
|00000870| 65 65 20 74 68 65 20 73 | 6f 75 72 63 65 20 66 69 |ee the s|ource fi|
|00000880| 6c 65 20 53 4c 49 42 2e | 43 20 66 6f 72 20 6d 6f |le SLIB.|C for mo|
|00000890| 72 65 20 69 6e 66 6f 72 | 6d 61 74 69 6f 6e 2e 20 |re infor|mation. |
|000008a0| 90 12 2a 0a 0a 2a 2f 0a | 0a 2f 2a 0a 0a 67 6a 63 |..*..*/.|./*..gjc|
|000008b0| 40 70 61 72 61 64 69 67 | 6d 2e 63 6f 6d 0a 0a 50 |@paradig|m.com..P|
|000008c0| 61 72 61 64 69 67 6d 20 | 41 73 73 6f 63 69 61 74 |aradigm |Associat|
|000008d0| 65 73 20 49 6e 63 20 90 | 0a 50 68 6f 6e 65 3a 20 |es Inc .|.Phone: |
|000008e0| 36 31 37 2d 34 39 32 2d | 36 30 37 39 0a 32 39 20 |617-492-|6079.29 |
|000008f0| 50 75 74 6e 61 6d 20 41 | 76 65 2c 20 53 75 69 74 |Putnam A|ve, Suit|
|00000900| 65 20 36 0a 43 61 6d 62 | 72 69 64 67 65 2c 20 4d |e 6.Camb|ridge, M|
|00000910| 41 20 30 32 31 33 38 0a | 0a 20 20 2a 2f 0a 0a 23 |A 02138.|. */..#|
|00000920| 69 6e 63 6c 75 64 65 20 | 3c 73 74 64 69 6f 2e 68 |include |<stdio.h|
|00000930| 3e 0a 0a 23 69 6e 63 6c | 75 64 65 20 22 73 69 6f |>..#incl|ude "sio|
|00000940| 64 2e 68 22 0a 0a 2f 2a | 20 54 68 69 73 20 69 6c |d.h"../*| This il|
|00000950| 6c 75 73 74 72 61 74 65 | 73 20 63 61 6c 6c 69 6e |lustrate|s callin|
|00000960| 67 20 74 68 65 20 6d 61 | 69 6e 20 70 72 6f 67 72 |g the ma|in progr|
|00000970| 61 6d 20 65 6e 74 72 79 | 20 70 6f 69 6e 74 73 20 |am entry| points |
|00000980| 61 6e 64 20 65 6e 61 62 | 6c 69 6e 67 20 6f 75 72 |and enab|ling our|
|00000990| 0a 20 90 03 6f 77 6e 20 | 65 78 61 6d 70 6c 65 20 |. ..own |example |
|000009a0| 73 75 62 72 73 20 2a 2f | 0a 0a 4c 49 53 50 20 6f |subrs */|..LISP o|
|000009b0| 75 72 5f 67 63 5f 6d 61 | 72 6b 28 29 3b 0a 76 6f |ur_gc_ma|rk();.vo|
|000009c0| 69 64 20 6f 75 72 5f 67 | 63 5f 66 72 65 65 28 29 |id our_g|c_free()|
|000009d0| 3b 0a 76 6f 69 64 20 6f | 75 72 5f 70 72 69 6e 74 |;.void o|ur_print|
|000009e0| 28 29 3b 0a 4c 49 53 50 | 20 6f 75 72 5f 72 65 61 |();.LISP| our_rea|
|000009f0| 64 6d 28 29 3b 0a 4c 49 | 53 50 20 6f 75 72 5f 65 |dm();.LI|SP our_e|
|00000a00| 76 61 6c 28 29 3b 0a 0a | 6d 61 69 6e 28 61 72 67 |val();..|main(arg|
|00000a10| 63 2c 61 72 67 76 29 0a | 20 69 6e 74 20 61 72 67 |c,argv).| int arg|
|00000a20| 63 3b 20 63 68 61 72 20 | 2a 2a 61 72 67 76 3b 0a |c; char |**argv;.|
|00000a30| 7b 6c 6f 6e 67 20 67 63 | 5f 6b 69 6e 64 3b 0a 20 |{long gc|_kind;. |
|00000a40| 70 72 69 6e 74 5f 77 65 | 6c 63 6f 6d 65 28 29 3b |print_we|lcome();|
|00000a50| 0a 20 70 72 6f 63 65 73 | 73 5f 63 6c 61 28 61 72 |. proces|s_cla(ar|
|00000a60| 67 63 2c 61 72 67 76 2c | 31 29 3b 0a 20 73 65 74 |gc,argv,|1);. set|
|00000a70| 5f 67 63 5f 68 6f 6f 6b | 73 28 4e 55 4c 4c 2c 4e |_gc_hook|s(NULL,N|
|00000a80| 55 4c 4c 2c 4e 55 4c 4c | 2c 4e 55 4c 4c 2c 26 67 |ULL,NULL|,NULL,&g|
|00000a90| 63 5f 6b 69 6e 64 29 3b | 0a 20 70 72 69 6e 74 5f |c_kind);|. print_|
|00000aa0| 68 73 5f 31 28 29 3b 0a | 20 69 6e 69 74 5f 73 74 |hs_1();.| init_st|
|00000ab0| 6f 72 61 67 65 28 29 3b | 0a 20 69 6e 69 74 5f 73 |orage();|. init_s|
|00000ac0| 75 62 72 73 28 29 3b 0a | 20 69 66 20 28 67 63 5f |ubrs();.| if (gc_|
|00000ad0| 6b 69 6e 64 20 3d 3d 20 | 30 29 0a 20 90 03 7b 73 |kind == |0). ..{s|
|00000ae0| 65 74 5f 67 63 5f 68 6f | 6f 6b 73 28 4e 55 4c 4c |et_gc_ho|oks(NULL|
|00000af0| 2c 4e 55 4c 4c 2c 6f 75 | 72 5f 67 63 5f 6d 61 72 |,NULL,ou|r_gc_mar|
|00000b00| 6b 2c 6f 75 72 5f 67 63 | 5f 66 72 65 65 2c 26 67 |k,our_gc|_free,&g|
|00000b10| 63 5f 6b 69 6e 64 29 3b | 0a 20 90 04 73 65 74 5f |c_kind);|. ..set_|
|00000b20| 72 65 61 64 5f 68 6f 6f | 6b 73 28 22 5c 22 22 2c |read_hoo|ks("\"",|
|00000b30| 22 5c 22 22 2c 6f 75 72 | 5f 72 65 61 64 6d 2c 4e |"\"",our|_readm,N|
|00000b40| 55 4c 4c 29 3b 0a 20 90 | 04 73 65 74 5f 65 76 61 |ULL);. .|.set_eva|
|00000b50| 6c 5f 68 6f 6f 6b 73 28 | 6f 75 72 5f 65 76 61 6c |l_hooks(|our_eval|
|00000b60| 29 3b 0a 20 90 04 73 65 | 74 5f 70 72 69 6e 74 5f |);. ..se|t_print_|
|00000b70| 68 6f 6f 6b 73 28 6f 75 | 72 5f 70 72 69 6e 74 29 |hooks(ou|r_print)|
|00000b80| 3b 7d 0a 20 6f 75 72 5f | 73 75 62 72 73 28 28 67 |;}. our_|subrs((g|
|00000b90| 63 5f 6b 69 6e 64 20 3d | 3d 20 30 29 20 3f 20 31 |c_kind =|= 0) ? 1|
|00000ba0| 20 3a 20 30 29 3b 0a 20 | 72 65 70 6c 5f 64 72 69 | : 0);. |repl_dri|
|00000bb0| 76 65 72 28 31 2c 31 29 | 3b 0a 20 70 72 69 6e 74 |ver(1,1)|;. print|
|00000bc0| 66 28 22 45 58 49 54 5c | 6e 22 29 3b 7d 0a 0a 2f |f("EXIT\|n");}../|
|00000bd0| 2a 20 54 68 69 73 20 69 | 73 20 63 66 69 62 2c 20 |* This i|s cfib, |
|00000be0| 66 6f 72 20 63 6f 6d 70 | 69 6c 65 64 20 66 69 62 |for comp|iled fib|
|00000bf0| 2e 20 54 65 73 74 20 74 | 6f 20 73 65 65 20 77 68 |. Test t|o see wh|
|00000c00| 61 74 20 74 68 65 20 6f | 76 65 72 68 65 61 64 0a |at the o|verhead.|
|00000c10| 20 90 03 6f 66 20 69 6e | 74 65 72 70 72 65 74 61 | ..of in|terpreta|
|00000c20| 74 69 6f 6e 20 61 63 74 | 75 61 6c 6c 79 20 69 73 |tion act|ually is|
|00000c30| 20 69 6e 20 61 20 67 69 | 76 65 6e 20 69 6d 70 6c | in a gi|ven impl|
|00000c40| 65 6d 65 6e 74 61 74 69 | 6f 6e 20 0a 20 2a 2f 0a |ementati|on . */.|
|00000c50| 0a 4c 49 53 50 20 6d 79 | 5f 6f 6e 65 3b 0a 4c 49 |.LISP my|_one;.LI|
|00000c60| 53 50 20 6d 79 5f 74 77 | 6f 3b 0a 0a 2f 2a 20 90 |SP my_tw|o;../* .|
|00000c70| 03 28 64 65 66 69 6e 65 | 20 28 73 74 61 6e 64 61 |.(define| (standa|
|00000c80| 72 64 2d 66 69 62 20 78 | 29 0a 20 90 07 28 69 66 |rd-fib x|). ..(if|
|00000c90| 20 28 3c 20 78 20 32 29 | 0a 20 90 09 78 0a 20 90 | (< x 2)|. ..x. .|
|00000ca0| 09 28 2b 20 28 73 74 61 | 6e 64 61 72 64 2d 66 69 |.(+ (sta|ndard-fi|
|00000cb0| 62 20 28 2d 20 78 20 31 | 29 29 0a 09 20 90 04 28 |b (- x 1|)).. ..(|
|00000cc0| 73 74 61 6e 64 61 72 64 | 2d 66 69 62 20 28 2d 20 |standard|-fib (- |
|00000cd0| 78 20 32 29 90 05 20 20 | 0a 2a 2f 0a 0a 4c 49 53 |x 2).. |.*/..LIS|
|00000ce0| 50 20 63 66 69 62 28 78 | 29 0a 20 90 05 4c 49 53 |P cfib(x|). ..LIS|
|00000cf0| 50 20 78 3b 0a 7b 69 66 | 20 4e 4e 55 4c 4c 50 28 |P x;.{if| NNULLP(|
|00000d00| 6c 65 73 73 70 28 78 2c | 6d 79 5f 74 77 6f 29 29 |lessp(x,|my_two))|
|00000d10| 0a 20 90 03 72 65 74 75 | 72 6e 28 78 29 3b 0a 20 |. ..retu|rn(x);. |
|00000d20| 65 6c 73 65 0a 20 90 03 | 72 65 74 75 72 6e 28 70 |else. ..|return(p|
|00000d30| 6c 75 73 28 63 66 69 62 | 28 64 69 66 66 65 72 65 |lus(cfib|(differe|
|00000d40| 6e 63 65 28 78 2c 6d 79 | 5f 6f 6e 65 29 29 2c 0a |nce(x,my|_one)),.|
|00000d50| 09 20 90 07 63 66 69 62 | 28 64 69 66 66 65 72 65 |. ..cfib|(differe|
|00000d60| 6e 63 65 28 78 2c 6d 79 | 5f 74 77 6f 29 90 04 3b |nce(x,my|_two)..;|
|00000d70| 7d 0a 90 03 23 69 66 64 | 65 66 20 76 6d 73 0a 23 |}...#ifd|ef vms.#|
|00000d80| 69 6e 63 6c 75 64 65 20 | 3c 64 65 73 63 72 69 70 |include |<descrip|
|00000d90| 2e 68 3e 0a 23 69 6e 63 | 6c 75 64 65 20 3c 73 73 |.h>.#inc|lude <ss|
|00000da0| 64 65 66 2e 68 3e 0a 4c | 49 53 50 20 73 79 73 5f |def.h>.L|ISP sys_|
|00000db0| 65 64 69 74 28 66 6e 61 | 6d 65 29 0a 20 4c 49 53 |edit(fna|me). LIS|
|00000dc0| 50 20 66 6e 61 6d 65 3b | 0a 7b 73 74 72 75 63 74 |P fname;|.{struct|
|00000dd0| 20 64 73 63 24 64 65 73 | 63 72 69 70 74 6f 72 5f | dsc$des|criptor_|
|00000de0| 73 20 64 3b 0a 20 6c 6f | 6e 67 20 69 66 6c 61 67 |s d;. lo|ng iflag|
|00000df0| 3b 0a 20 69 66 20 4e 54 | 59 50 45 50 28 66 6e 61 |;. if NT|YPEP(fna|
|00000e00| 6d 65 2c 74 63 5f 73 79 | 6d 62 6f 6c 29 20 65 72 |me,tc_sy|mbol) er|
|00000e10| 72 28 22 66 69 6c 65 6e | 61 6d 65 20 6e 6f 74 20 |r("filen|ame not |
|00000e20| 61 20 73 79 6d 62 6f 6c | 22 2c 66 6e 61 6d 65 29 |a symbol|",fname)|
|00000e30| 3b 0a 20 64 2e 64 73 63 | 24 62 5f 64 74 79 70 65 |;. d.dsc|$b_dtype|
|00000e40| 20 3d 20 44 53 43 24 4b | 5f 44 54 59 50 45 5f 54 | = DSC$K|_DTYPE_T|
|00000e50| 3b 0a 20 64 2e 64 73 63 | 24 62 5f 63 6c 61 73 73 |;. d.dsc|$b_class|
|00000e60| 20 3d 20 44 53 43 24 4b | 5f 43 4c 41 53 53 5f 53 | = DSC$K|_CLASS_S|
|00000e70| 3b 0a 20 64 2e 64 73 63 | 24 77 5f 6c 65 6e 67 74 |;. d.dsc|$w_lengt|
|00000e80| 68 20 3d 20 73 74 72 6c | 65 6e 28 50 4e 41 4d 45 |h = strl|en(PNAME|
|00000e90| 28 66 6e 61 6d 65 29 29 | 3b 0a 20 64 2e 64 73 63 |(fname))|;. d.dsc|
|00000ea0| 24 61 5f 70 6f 69 6e 74 | 65 72 20 3d 20 50 4e 41 |$a_point|er = PNA|
|00000eb0| 4d 45 28 66 6e 61 6d 65 | 29 3b 0a 20 69 66 6c 61 |ME(fname|);. ifla|
|00000ec0| 67 20 3d 20 6e 6f 5f 69 | 6e 74 65 72 72 75 70 74 |g = no_i|nterrupt|
|00000ed0| 28 31 29 3b 0a 20 65 64 | 74 24 65 64 69 74 28 26 |(1);. ed|t$edit(&|
|00000ee0| 64 29 3b 0a 20 6e 6f 5f | 69 6e 74 65 72 72 75 70 |d);. no_|interrup|
|00000ef0| 74 28 69 66 6c 61 67 29 | 3b 0a 20 72 65 74 75 72 |t(iflag)|;. retur|
|00000f00| 6e 28 66 6e 61 6d 65 29 | 3b 7d 0a 0a 4c 49 53 50 |n(fname)|;}..LISP|
|00000f10| 20 76 6d 73 5f 64 65 62 | 75 67 28 76 29 0a 20 90 | vms_deb|ug(v). .|
|00000f20| 05 4c 49 53 50 20 76 3b | 0a 7b 6c 69 62 24 73 69 |.LISP v;|.{lib$si|
|00000f30| 67 6e 61 6c 28 53 53 24 | 5f 44 45 42 55 47 29 3b |gnal(SS$|_DEBUG);|
|00000f40| 0a 20 72 65 74 75 72 6e | 28 76 29 3b 7d 0a 0a 23 |. return|(v);}..#|
|00000f50| 65 6e 64 69 66 0a 0a 4c | 49 53 50 20 6f 75 72 5f |endif..L|ISP our_|
|00000f60| 67 63 5f 6d 61 72 6b 28 | 70 74 72 29 0a 20 90 05 |gc_mark(|ptr). ..|
|00000f70| 4c 49 53 50 20 70 74 72 | 3b 0a 7b 72 65 74 75 72 |LISP ptr|;.{retur|
|00000f80| 6e 28 4e 49 4c 29 3b 7d | 0a 0a 76 6f 69 64 20 6f |n(NIL);}|..void o|
|00000f90| 75 72 5f 67 63 5f 66 72 | 65 65 28 70 74 72 29 0a |ur_gc_fr|ee(ptr).|
|00000fa0| 20 90 05 4c 49 53 50 20 | 70 74 72 3b 0a 7b 66 72 | ..LISP |ptr;.{fr|
|00000fb0| 65 65 28 50 4e 41 4d 45 | 28 70 74 72 29 29 3b 0a |ee(PNAME|(ptr));.|
|00000fc0| 20 50 4e 41 4d 45 28 70 | 74 72 29 20 3d 20 30 3b | PNAME(p|tr) = 0;|
|00000fd0| 7d 0a 0a 76 6f 69 64 20 | 6f 75 72 5f 70 72 69 6e |}..void |our_prin|
|00000fe0| 74 28 70 74 72 2c 66 29 | 0a 20 90 05 4c 49 53 50 |t(ptr,f)|. ..LISP|
|00000ff0| 20 70 74 72 3b 0a 20 90 | 05 46 49 4c 45 20 2a 66 | ptr;. .|.FILE *f|
|00001000| 3b 0a 7b 66 70 75 74 5f | 73 74 28 66 2c 22 5c 22 |;.{fput_|st(f,"\"|
|00001010| 22 29 3b 0a 20 66 70 75 | 74 5f 73 74 28 66 2c 50 |");. fpu|t_st(f,P|
|00001020| 4e 41 4d 45 28 70 74 72 | 29 29 3b 0a 20 66 70 75 |NAME(ptr|));. fpu|
|00001030| 74 5f 73 74 28 66 2c 22 | 5c 22 22 29 3b 7d 0a 0a |t_st(f,"|\"");}..|
|00001040| 23 64 65 66 69 6e 65 20 | 74 63 5f 73 74 72 69 6e |#define |tc_strin|
|00001050| 67 20 74 63 5f 75 73 65 | 72 5f 31 0a 0a 4c 49 53 |g tc_use|r_1..LIS|
|00001060| 50 20 73 74 72 63 6f 6e | 73 28 6c 65 6e 67 74 68 |P strcon|s(length|
|00001070| 29 0a 20 90 05 6c 6f 6e | 67 20 6c 65 6e 67 74 68 |). ..lon|g length|
|00001080| 3b 0a 7b 6c 6f 6e 67 20 | 66 6c 61 67 3b 0a 20 4c |;.{long |flag;. L|
|00001090| 49 53 50 20 73 3b 0a 20 | 73 20 3d 20 73 79 6d 63 |ISP s;. |s = symc|
|000010a0| 6f 6e 73 28 22 22 2c 4e | 49 4c 29 3b 0a 20 66 6c |ons("",N|IL);. fl|
|000010b0| 61 67 20 3d 20 6e 6f 5f | 69 6e 74 65 72 72 75 70 |ag = no_|interrup|
|000010c0| 74 28 31 29 3b 0a 20 50 | 4e 41 4d 45 28 73 29 20 |t(1);. P|NAME(s) |
|000010d0| 3d 20 6d 75 73 74 5f 6d | 61 6c 6c 6f 63 28 6c 65 |= must_m|alloc(le|
|000010e0| 6e 67 74 68 29 3b 0a 20 | 6e 6f 5f 69 6e 74 65 72 |ngth);. |no_inter|
|000010f0| 72 75 70 74 28 66 6c 61 | 67 29 3b 0a 20 28 2a 73 |rupt(fla|g);. (*s|
|00001100| 29 2e 74 79 70 65 20 3d | 20 74 63 5f 73 74 72 69 |).type =| tc_stri|
|00001110| 6e 67 3b 0a 20 72 65 74 | 75 72 6e 28 73 29 3b 7d |ng;. ret|urn(s);}|
|00001120| 0a 0a 4c 49 53 50 20 73 | 74 72 69 6e 67 5f 61 70 |..LISP s|tring_ap|
|00001130| 70 65 6e 64 28 61 72 67 | 73 29 0a 20 90 05 4c 49 |pend(arg|s). ..LI|
|00001140| 53 50 20 61 72 67 73 3b | 0a 7b 6c 6f 6e 67 20 73 |SP args;|.{long s|
|00001150| 69 7a 65 3b 0a 20 4c 49 | 53 50 20 6c 2c 73 3b 0a |ize;. LI|SP l,s;.|
|00001160| 20 63 68 61 72 20 2a 64 | 61 74 61 3b 0a 20 73 69 | char *d|ata;. si|
|00001170| 7a 65 20 3d 20 30 3b 0a | 20 66 6f 72 28 6c 3d 61 |ze = 0;.| for(l=a|
|00001180| 72 67 73 3b 4e 4e 55 4c | 4c 50 28 6c 29 3b 6c 3d |rgs;NNUL|LP(l);l=|
|00001190| 63 64 72 28 6c 29 29 0a | 20 90 03 7b 73 20 3d 20 |cdr(l)).| ..{s = |
|000011a0| 63 61 72 28 6c 29 3b 0a | 20 90 04 69 66 20 28 4e |car(l);.| ..if (N|
|000011b0| 54 59 50 45 50 28 73 2c | 74 63 5f 73 79 6d 62 6f |TYPEP(s,|tc_symbo|
|000011c0| 6c 29 20 26 26 20 4e 54 | 59 50 45 50 28 73 2c 74 |l) && NT|YPEP(s,t|
|000011d0| 63 5f 73 74 72 69 6e 67 | 29 29 0a 20 90 06 65 72 |c_string|)). ..er|
|000011e0| 72 28 22 77 74 61 20 74 | 6f 20 73 74 72 69 6e 67 |r("wta t|o string|
|000011f0| 2d 61 70 70 65 6e 64 22 | 2c 73 29 3b 0a 20 90 04 |-append"|,s);. ..|
|00001200| 73 69 7a 65 20 3d 20 73 | 69 7a 65 20 2b 20 73 74 |size = s|ize + st|
|00001210| 72 6c 65 6e 28 50 4e 41 | 4d 45 28 73 29 29 3b 7d |rlen(PNA|ME(s));}|
|00001220| 0a 20 73 20 3d 20 73 74 | 72 63 6f 6e 73 28 73 69 |. s = st|rcons(si|
|00001230| 7a 65 2b 31 29 3b 0a 20 | 64 61 74 61 20 3d 20 50 |ze+1);. |data = P|
|00001240| 4e 41 4d 45 28 73 29 3b | 0a 20 64 61 74 61 5b 30 |NAME(s);|. data[0|
|00001250| 5d 20 3d 20 30 3b 0a 20 | 66 6f 72 28 6c 3d 61 72 |] = 0;. |for(l=ar|
|00001260| 67 73 3b 4e 4e 55 4c 4c | 50 28 6c 29 3b 6c 3d 63 |gs;NNULL|P(l);l=c|
|00001270| 64 72 28 6c 29 29 0a 20 | 90 03 73 74 72 63 61 74 |dr(l)). |..strcat|
|00001280| 28 64 61 74 61 2c 50 4e | 41 4d 45 28 63 61 72 28 |(data,PN|AME(car(|
|00001290| 6c 29 90 03 3b 0a 20 72 | 65 74 75 72 6e 28 73 29 |l)..;. r|eturn(s)|
|000012a0| 3b 7d 0a 0a 4c 49 53 50 | 20 6f 75 72 5f 72 65 61 |;}..LISP| our_rea|
|000012b0| 64 6d 28 74 63 2c 66 29 | 0a 20 90 05 69 6e 74 20 |dm(tc,f)|. ..int |
|000012c0| 74 63 3b 0a 20 90 05 73 | 74 72 75 63 74 20 67 65 |tc;. ..s|truct ge|
|000012d0| 6e 5f 72 65 61 64 69 6f | 20 2a 66 3b 0a 7b 63 68 |n_readio| *f;.{ch|
|000012e0| 61 72 20 74 65 6d 70 5b | 31 30 30 5d 3b 0a 20 69 |ar temp[|100];. i|
|000012f0| 6e 74 20 63 3b 0a 20 6c | 6f 6e 67 20 6a 3b 0a 20 |nt c;. l|ong j;. |
|00001300| 4c 49 53 50 20 73 3b 0a | 20 6a 20 3d 20 30 3b 0a |LISP s;.| j = 0;.|
|00001310| 20 77 68 69 6c 65 28 90 | 03 63 20 3d 20 47 45 54 | while(.|.c = GET|
|00001320| 43 5f 46 43 4e 28 66 29 | 29 20 21 3d 20 74 63 29 |C_FCN(f)|) != tc)|
|00001330| 20 26 26 20 28 63 20 21 | 3d 20 45 4f 46 29 29 0a | && (c !|= EOF)).|
|00001340| 20 90 03 7b 69 66 20 28 | 28 6a 20 2b 20 32 29 20 | ..{if (|(j + 2) |
|00001350| 3e 20 73 69 7a 65 6f 66 | 28 74 65 6d 70 29 29 20 |> sizeof|(temp)) |
|00001360| 65 72 72 28 22 72 65 61 | 64 20 73 74 72 69 6e 67 |err("rea|d string|
|00001370| 20 6f 76 65 72 66 6c 6f | 77 22 2c 4e 49 4c 29 3b | overflo|w",NIL);|
|00001380| 0a 20 90 04 74 65 6d 70 | 5b 6a 5d 20 3d 20 63 3b |. ..temp|[j] = c;|
|00001390| 0a 20 90 04 2b 2b 6a 3b | 7d 0a 20 73 20 3d 20 73 |. ..++j;|}. s = s|
|000013a0| 74 72 63 6f 6e 73 28 6a | 2b 31 29 3b 0a 20 74 65 |trcons(j|+1);. te|
|000013b0| 6d 70 5b 6a 5d 20 3d 20 | 30 3b 0a 20 73 74 72 63 |mp[j] = |0;. strc|
|000013c0| 70 79 28 50 4e 41 4d 45 | 28 73 29 2c 74 65 6d 70 |py(PNAME|(s),temp|
|000013d0| 29 3b 0a 20 72 65 74 75 | 72 6e 28 73 29 3b 7d 0a |);. retu|rn(s);}.|
|000013e0| 0a 4c 49 53 50 20 6f 75 | 72 5f 65 76 61 6c 28 6f |.LISP ou|r_eval(o|
|000013f0| 62 6a 2c 66 6f 72 6d 70 | 2c 65 6e 76 70 29 0a 20 |bj,formp|,envp). |
|00001400| 90 05 4c 49 53 50 20 6f | 62 6a 2c 2a 66 6f 72 6d |..LISP o|bj,*form|
|00001410| 70 2c 2a 65 6e 76 70 3b | 0a 7b 4c 49 53 50 20 69 |p,*envp;|.{LISP i|
|00001420| 6e 64 3b 0a 20 63 68 61 | 72 20 62 75 66 66 5b 32 |nd;. cha|r buff[2|
|00001430| 5d 3b 0a 20 6c 6f 6e 67 | 20 6e 2c 6a 3b 0a 20 69 |];. long| n,j;. i|
|00001440| 66 20 4e 54 59 50 45 50 | 28 6f 62 6a 2c 74 63 5f |f NTYPEP|(obj,tc_|
|00001450| 73 74 72 69 6e 67 29 20 | 65 72 72 28 22 65 76 61 |string) |err("eva|
|00001460| 6c 20 62 75 67 22 2c 6f | 62 6a 29 3b 0a 20 6e 20 |l bug",o|bj);. n |
|00001470| 3d 20 73 74 72 6c 65 6e | 28 50 4e 41 4d 45 28 6f |= strlen|(PNAME(o|
|00001480| 62 6a 29 29 3b 0a 20 69 | 6e 64 20 3d 20 6c 65 76 |bj));. i|nd = lev|
|00001490| 61 6c 28 63 61 72 28 63 | 64 72 28 2a 66 6f 72 6d |al(car(c|dr(*form|
|000014a0| 70 29 29 2c 2a 65 6e 76 | 70 29 3b 0a 20 69 66 20 |p)),*env|p);. if |
|000014b0| 4e 46 4c 4f 4e 55 4d 50 | 28 69 6e 64 29 20 65 72 |NFLONUMP|(ind) er|
|000014c0| 72 28 22 6e 6f 6e 20 6e | 75 6d 65 72 69 63 20 73 |r("non n|umeric s|
|000014d0| 74 72 69 6e 67 20 69 6e | 64 65 78 22 2c 69 6e 64 |tring in|dex",ind|
|000014e0| 29 3b 0a 20 6a 20 3d 20 | 28 6c 6f 6e 67 29 20 46 |);. j = |(long) F|
|000014f0| 4c 4f 4e 4d 28 69 6e 64 | 29 3b 0a 20 69 66 20 28 |LONM(ind|);. if (|
|00001500| 28 6a 20 3c 20 30 29 20 | 7c 7c 20 28 6a 20 3e 3d |(j < 0) ||| (j >=|
|00001510| 20 6e 29 29 20 65 72 72 | 28 22 73 74 72 69 6e 67 | n)) err|("string|
|00001520| 20 69 6e 64 65 78 20 6f | 75 74 20 6f 66 20 72 61 | index o|ut of ra|
|00001530| 6e 67 65 22 2c 69 6e 64 | 29 3b 0a 20 62 75 66 66 |nge",ind|);. buff|
|00001540| 5b 30 5d 20 3d 20 50 4e | 41 4d 45 28 6f 62 6a 29 |[0] = PN|AME(obj)|
|00001550| 5b 6a 5d 3b 0a 20 62 75 | 66 66 5b 31 5d 20 3d 20 |[j];. bu|ff[1] = |
|00001560| 30 3b 0a 20 2a 66 6f 72 | 6d 70 20 3d 20 72 69 6e |0;. *for|mp = rin|
|00001570| 74 65 72 6e 28 62 75 66 | 66 29 3b 0a 20 72 65 74 |tern(buf|f);. ret|
|00001580| 75 72 6e 28 4e 49 4c 29 | 3b 7d 0a 0a 69 6e 74 20 |urn(NIL)|;}..int |
|00001590| 72 66 73 5f 67 65 74 63 | 28 70 29 0a 20 90 05 75 |rfs_getc|(p). ..u|
|000015a0| 6e 73 69 67 6e 65 64 20 | 63 68 61 72 20 2a 2a 70 |nsigned |char **p|
|000015b0| 3b 0a 7b 69 6e 74 20 69 | 3b 0a 20 69 20 3d 20 2a |;.{int i|;. i = *|
|000015c0| 2a 70 3b 0a 20 69 66 20 | 28 21 69 29 20 72 65 74 |*p;. if |(!i) ret|
|000015d0| 75 72 6e 28 45 4f 46 29 | 3b 0a 20 2a 70 20 3d 20 |urn(EOF)|;. *p = |
|000015e0| 2a 70 20 2b 20 31 3b 0a | 20 72 65 74 75 72 6e 28 |*p + 1;.| return(|
|000015f0| 69 29 3b 7d 0a 0a 76 6f | 69 64 20 72 66 73 5f 70 |i);}..vo|id rfs_p|
|00001600| 75 74 63 28 63 2c 70 29 | 0a 20 90 05 75 6e 73 69 |utc(c,p)|. ..unsi|
|00001610| 67 6e 65 64 20 63 68 61 | 72 20 63 2c 2a 2a 70 3b |gned cha|r c,**p;|
|00001620| 0a 7b 2a 70 20 3d 20 2a | 70 20 2d 20 31 3b 7d 0a |.{*p = *|p - 1;}.|
|00001630| 0a 4c 49 53 50 20 72 65 | 61 64 5f 66 72 6f 6d 5f |.LISP re|ad_from_|
|00001640| 73 74 72 69 6e 67 28 78 | 29 0a 20 90 05 4c 49 53 |string(x|). ..LIS|
|00001650| 50 20 78 3b 0a 7b 63 68 | 61 72 20 2a 70 3b 0a 20 |P x;.{ch|ar *p;. |
|00001660| 69 66 20 4e 54 59 50 45 | 50 28 78 2c 74 63 5f 73 |if NTYPE|P(x,tc_s|
|00001670| 74 72 69 6e 67 29 20 65 | 72 72 28 22 6e 6f 74 20 |tring) e|rr("not |
|00001680| 61 20 73 74 72 69 6e 67 | 22 2c 78 29 3b 0a 20 70 |a string|",x);. p|
|00001690| 20 3d 20 50 4e 41 4d 45 | 28 78 29 3b 0a 20 72 65 | = PNAME|(x);. re|
|000016a0| 74 75 72 6e 28 67 65 6e | 5f 72 65 61 64 28 72 66 |turn(gen|_read(rf|
|000016b0| 73 5f 67 65 74 63 2c 72 | 66 73 5f 70 75 74 63 2c |s_getc,r|fs_putc,|
|000016c0| 26 70 29 29 3b 7d 0a 0a | 6f 75 72 5f 73 75 62 72 |&p));}..|our_subr|
|000016d0| 73 28 66 6c 61 67 29 0a | 20 90 05 69 6e 74 20 66 |s(flag).| ..int f|
|000016e0| 6c 61 67 3b 0a 7b 6d 79 | 5f 6f 6e 65 20 3d 20 66 |lag;.{my|_one = f|
|000016f0| 6c 6f 63 6f 6e 73 28 28 | 64 6f 75 62 6c 65 29 20 |locons((|double) |
|00001700| 31 2e 30 29 3b 0a 20 6d | 79 5f 74 77 6f 20 3d 20 |1.0);. m|y_two = |
|00001710| 66 6c 6f 63 6f 6e 73 28 | 28 64 6f 75 62 6c 65 29 |flocons(|(double)|
|00001720| 20 32 2e 30 29 3b 0a 20 | 67 63 5f 70 72 6f 74 65 | 2.0);. |gc_prote|
|00001730| 63 74 28 26 6d 79 5f 6f | 6e 65 29 3b 0a 20 67 63 |ct(&my_o|ne);. gc|
|00001740| 5f 70 72 6f 74 65 63 74 | 28 26 6d 79 5f 74 77 6f |_protect|(&my_two|
|00001750| 29 3b 0a 20 69 6e 69 74 | 5f 73 75 62 72 28 22 63 |);. init|_subr("c|
|00001760| 66 69 62 22 2c 74 63 5f | 73 75 62 72 5f 31 2c 63 |fib",tc_|subr_1,c|
|00001770| 66 69 62 29 3b 0a 23 69 | 66 64 65 66 20 76 6d 73 |fib);.#i|fdef vms|
|00001780| 0a 20 69 6e 69 74 5f 73 | 75 62 72 28 22 65 64 69 |. init_s|ubr("edi|
|00001790| 74 22 2c 74 63 5f 73 75 | 62 72 5f 31 2c 73 79 73 |t",tc_su|br_1,sys|
|000017a0| 5f 65 64 69 74 29 3b 0a | 20 69 6e 69 74 5f 73 75 |_edit);.| init_su|
|000017b0| 62 72 28 22 76 6d 73 2d | 64 65 62 75 67 22 2c 74 |br("vms-|debug",t|
|000017c0| 63 5f 73 75 62 72 5f 31 | 2c 76 6d 73 5f 64 65 62 |c_subr_1|,vms_deb|
|000017d0| 75 67 29 3b 0a 23 65 6e | 64 69 66 0a 20 69 66 20 |ug);.#en|dif. if |
|000017e0| 28 66 6c 61 67 29 0a 20 | 90 03 7b 69 6e 69 74 5f |(flag). |..{init_|
|000017f0| 73 75 62 72 28 22 73 74 | 72 69 6e 67 2d 61 70 70 |subr("st|ring-app|
|00001800| 65 6e 64 22 2c 74 63 5f | 6c 73 75 62 72 2c 73 74 |end",tc_|lsubr,st|
|00001810| 72 69 6e 67 5f 61 70 70 | 65 6e 64 29 3b 0a 20 90 |ring_app|end);. .|
|00001820| 04 69 6e 69 74 5f 73 75 | 62 72 28 22 72 65 61 64 |.init_su|br("read|
|00001830| 2d 66 72 6f 6d 2d 73 74 | 72 69 6e 67 22 2c 74 63 |-from-st|ring",tc|
|00001840| 5f 73 75 62 72 5f 31 2c | 72 65 61 64 5f 66 72 6f |_subr_1,|read_fro|
|00001850| 6d 5f 73 74 72 69 6e 67 | 29 3b 7d 7d 0a 46 69 6c |m_string|);}}.Fil|
|00001860| 65 44 61 74 61 83 73 6c | 69 62 00 00 00 00 00 00 |eData.sl|ib......|
|00001870| 00 74 97 00 00 46 fd ff | ff 16 b3 27 52 03 00 00 |.t...F..|...'R...|
|00001880| 00 2f 2a 20 53 63 68 65 | 6d 65 20 49 6e 20 4f 6e |./* Sche|me In On|
|00001890| 65 20 44 65 66 75 6e 2c | 20 62 75 74 20 69 6e 20 |e Defun,| but in |
|000018a0| 43 20 74 68 69 73 20 74 | 69 6d 65 2e 0a 20 0a 20 |C this t|ime.. . |
|000018b0| 2a 20 90 18 43 4f 50 59 | 52 49 47 48 54 20 28 63 |* ..COPY|RIGHT (c|
|000018c0| 29 20 31 39 38 39 20 42 | 59 20 90 1d 2a 0a 20 2a |) 1989 B|Y ..*. *|
|000018d0| 20 90 08 50 41 52 41 44 | 49 47 4d 20 41 53 53 4f | ..PARAD|IGM ASSO|
|000018e0| 43 49 41 54 45 53 20 49 | 4e 43 4f 52 50 4f 52 41 |CIATES I|NCORPORA|
|000018f0| 54 45 44 2c 20 43 41 4d | 42 52 49 44 47 45 2c 20 |TED, CAM|BRIDGE, |
|00001900| 4d 41 53 53 41 43 48 55 | 53 45 54 54 53 2e 20 90 |MASSACHU|SETTS. .|
|00001910| 07 2a 0a 20 2a 09 90 03 | 20 90 03 41 4c 4c 20 52 |.*. *...| ..ALL R|
|00001920| 49 47 48 54 53 20 52 45 | 53 45 52 56 45 44 20 90 |IGHTS RE|SERVED .|
|00001930| 1e 2a 0a 0a 50 65 72 6d | 69 73 73 69 6f 6e 20 74 |.*..Perm|ission t|
|00001940| 6f 20 75 73 65 2c 20 63 | 6f 70 79 2c 20 6d 6f 64 |o use, c|opy, mod|
|00001950| 69 66 79 2c 20 64 69 73 | 74 72 69 62 75 74 65 20 |ify, dis|tribute |
|00001960| 61 6e 64 20 73 65 6c 6c | 20 74 68 69 73 20 73 6f |and sell| this so|
|00001970| 66 74 77 61 72 65 0a 61 | 6e 64 20 69 74 73 20 64 |ftware.a|nd its d|
|00001980| 6f 63 75 6d 65 6e 74 61 | 74 69 6f 6e 20 66 6f 72 |ocumenta|tion for|
|00001990| 20 61 6e 79 20 70 75 72 | 70 6f 73 65 20 61 6e 64 | any pur|pose and|
|000019a0| 20 77 69 74 68 6f 75 74 | 20 66 65 65 20 69 73 20 | without| fee is |
|000019b0| 68 65 72 65 62 79 0a 67 | 72 61 6e 74 65 64 2c 20 |hereby.g|ranted, |
|000019c0| 70 72 6f 76 69 64 65 64 | 20 74 68 61 74 20 74 68 |provided| that th|
|000019d0| 65 20 61 62 6f 76 65 20 | 63 6f 70 79 72 69 67 68 |e above |copyrigh|
|000019e0| 74 20 6e 6f 74 69 63 65 | 20 61 70 70 65 61 72 20 |t notice| appear |
|000019f0| 69 6e 20 61 6c 6c 20 63 | 6f 70 69 65 73 0a 61 6e |in all c|opies.an|
|00001a00| 64 20 74 68 61 74 20 62 | 6f 74 68 20 74 68 61 74 |d that b|oth that|
|00001a10| 20 63 6f 70 79 72 69 67 | 68 74 20 6e 6f 74 69 63 | copyrig|ht notic|
|00001a20| 65 20 61 6e 64 20 74 68 | 69 73 20 70 65 72 6d 69 |e and th|is permi|
|00001a30| 73 73 69 6f 6e 20 6e 6f | 74 69 63 65 20 61 70 70 |ssion no|tice app|
|00001a40| 65 61 72 0a 69 6e 20 73 | 75 70 70 6f 72 74 69 6e |ear.in s|upportin|
|00001a50| 67 20 64 6f 63 75 6d 65 | 6e 74 61 74 69 6f 6e 2c |g docume|ntation,|
|00001a60| 20 61 6e 64 20 74 68 61 | 74 20 74 68 65 20 6e 61 | and tha|t the na|
|00001a70| 6d 65 20 6f 66 20 50 61 | 72 61 64 69 67 6d 20 41 |me of Pa|radigm A|
|00001a80| 73 73 6f 63 69 61 74 65 | 73 0a 49 6e 63 20 6e 6f |ssociate|s.Inc no|
|00001a90| 74 20 62 65 20 75 73 65 | 64 20 69 6e 20 61 64 76 |t be use|d in adv|
|00001aa0| 65 72 74 69 73 69 6e 67 | 20 6f 72 20 70 75 62 6c |ertising| or publ|
|00001ab0| 69 63 69 74 79 20 70 65 | 72 74 61 69 6e 69 6e 67 |icity pe|rtaining|
|00001ac0| 20 74 6f 20 64 69 73 74 | 72 69 62 75 74 69 6f 6e | to dist|ribution|
|00001ad0| 0a 6f 66 20 74 68 65 20 | 73 6f 66 74 77 61 72 65 |.of the |software|
|00001ae0| 20 77 69 74 68 6f 75 74 | 20 73 70 65 63 69 66 69 | without| specifi|
|00001af0| 63 2c 20 77 72 69 74 74 | 65 6e 20 70 72 69 6f 72 |c, writt|en prior|
|00001b00| 20 70 65 72 6d 69 73 73 | 69 6f 6e 2e 0a 0a 50 41 | permiss|ion...PA|
|00001b10| 52 41 44 49 47 4d 20 44 | 49 53 43 4c 41 49 4d 53 |RADIGM D|ISCLAIMS|
|00001b20| 20 41 4c 4c 20 57 41 52 | 52 41 4e 54 49 45 53 20 | ALL WAR|RANTIES |
|00001b30| 57 49 54 48 20 52 45 47 | 41 52 44 20 54 4f 20 54 |WITH REG|ARD TO T|
|00001b40| 48 49 53 20 53 4f 46 54 | 57 41 52 45 2c 20 49 4e |HIS SOFT|WARE, IN|
|00001b50| 43 4c 55 44 49 4e 47 0a | 41 4c 4c 20 49 4d 50 4c |CLUDING.|ALL IMPL|
|00001b60| 49 45 44 20 57 41 52 52 | 41 4e 54 49 45 53 20 4f |IED WARR|ANTIES O|
|00001b70| 46 20 4d 45 52 43 48 41 | 4e 54 41 42 49 4c 49 54 |F MERCHA|NTABILIT|
|00001b80| 59 20 41 4e 44 20 46 49 | 54 4e 45 53 53 2c 20 49 |Y AND FI|TNESS, I|
|00001b90| 4e 20 4e 4f 20 45 56 45 | 4e 54 20 53 48 41 4c 4c |N NO EVE|NT SHALL|
|00001ba0| 0a 50 41 52 41 44 49 47 | 4d 20 42 45 20 4c 49 41 |.PARADIG|M BE LIA|
|00001bb0| 42 4c 45 20 46 4f 52 20 | 41 4e 59 20 53 50 45 43 |BLE FOR |ANY SPEC|
|00001bc0| 49 41 4c 2c 20 49 4e 44 | 49 52 45 43 54 20 4f 52 |IAL, IND|IRECT OR|
|00001bd0| 20 43 4f 4e 53 45 51 55 | 45 4e 54 49 41 4c 20 44 | CONSEQU|ENTIAL D|
|00001be0| 41 4d 41 47 45 53 20 4f | 52 0a 41 4e 59 20 44 41 |AMAGES O|R.ANY DA|
|00001bf0| 4d 41 47 45 53 20 57 48 | 41 54 53 4f 45 56 45 52 |MAGES WH|ATSOEVER|
|00001c00| 20 52 45 53 55 4c 54 49 | 4e 47 20 46 52 4f 4d 20 | RESULTI|NG FROM |
|00001c10| 4c 4f 53 53 20 4f 46 20 | 55 53 45 2c 20 44 41 54 |LOSS OF |USE, DAT|
|00001c20| 41 20 4f 52 20 50 52 4f | 46 49 54 53 2c 0a 57 48 |A OR PRO|FITS,.WH|
|00001c30| 45 54 48 45 52 20 49 4e | 20 41 4e 20 41 43 54 49 |ETHER IN| AN ACTI|
|00001c40| 4f 4e 20 4f 46 20 43 4f | 4e 54 52 41 43 54 2c 20 |ON OF CO|NTRACT, |
|00001c50| 4e 45 47 4c 49 47 45 4e | 43 45 20 4f 52 20 4f 54 |NEGLIGEN|CE OR OT|
|00001c60| 48 45 52 20 54 4f 52 54 | 49 4f 55 53 20 41 43 54 |HER TORT|IOUS ACT|
|00001c70| 49 4f 4e 2c 0a 41 52 49 | 53 49 4e 47 20 4f 55 54 |ION,.ARI|SING OUT|
|00001c80| 20 4f 46 20 4f 52 20 49 | 4e 20 43 4f 4e 4e 45 43 | OF OR I|N CONNEC|
|00001c90| 54 49 4f 4e 20 57 49 54 | 48 20 54 48 45 20 55 53 |TION WIT|H THE US|
|00001ca0| 45 20 4f 52 20 50 45 52 | 46 4f 52 4d 41 4e 43 45 |E OR PER|FORMANCE|
|00001cb0| 20 4f 46 20 54 48 49 53 | 0a 53 4f 46 54 57 41 52 | OF THIS|.SOFTWAR|
|00001cc0| 45 2e 0a 0a 2a 2f 0a 0a | 2f 2a 0a 0a 67 6a 63 40 |E...*/..|/*..gjc@|
|00001cd0| 70 61 72 61 64 69 67 6d | 2e 63 6f 6d 0a 0a 50 61 |paradigm|.com..Pa|
|00001ce0| 72 61 64 69 67 6d 20 41 | 73 73 6f 63 69 61 74 65 |radigm A|ssociate|
|00001cf0| 73 20 49 6e 63 20 90 0a | 50 68 6f 6e 65 3a 20 36 |s Inc ..|Phone: 6|
|00001d00| 31 37 2d 34 39 32 2d 36 | 30 37 39 0a 32 39 20 50 |17-492-6|079.29 P|
|00001d10| 75 74 6e 61 6d 20 41 76 | 65 2c 20 53 75 69 74 65 |utnam Av|e, Suite|
|00001d20| 20 36 0a 43 61 6d 62 72 | 69 64 67 65 2c 20 4d 41 | 6.Cambr|idge, MA|
|00001d30| 20 30 32 31 33 38 0a 90 | 03 20 90 03 52 65 6c 65 | 02138..|. ..Rele|
|00001d40| 61 73 65 20 31 2e 30 3a | 20 32 34 2d 41 50 52 2d |ase 1.0:| 24-APR-|
|00001d50| 38 38 0a 20 90 03 52 65 | 6c 65 61 73 65 20 31 2e |88. ..Re|lease 1.|
|00001d60| 31 3a 20 32 35 2d 41 50 | 52 2d 38 38 2c 20 61 64 |1: 25-AP|R-88, ad|
|00001d70| 64 65 64 3a 20 6d 61 63 | 72 6f 73 2c 20 70 72 65 |ded: mac|ros, pre|
|00001d80| 64 69 63 61 74 65 73 2c | 20 6c 6f 61 64 2e 20 57 |dicates,| load. W|
|00001d90| 69 74 68 20 61 64 64 69 | 74 69 6f 6e 73 20 62 79 |ith addi|tions by|
|00001da0| 0a 20 90 04 42 61 72 61 | 6b 2e 50 65 61 72 6c 6d |. ..Bara|k.Pearlm|
|00001db0| 75 74 74 65 72 40 44 4f | 47 48 45 4e 2e 42 4f 4c |utter@DO|GHEN.BOL|
|00001dc0| 54 5a 2e 43 53 2e 43 4d | 55 2e 45 44 55 3a 20 46 |TZ.CS.CM|U.EDU: F|
|00001dd0| 75 6c 6c 20 66 6c 6f 6e | 75 6d 20 72 65 63 6f 67 |ull flon|um recog|
|00001de0| 6e 69 7a 65 72 2c 0a 20 | 90 04 63 6c 65 61 6e 65 |nizer,. |..cleane|
|00001df0| 64 20 75 70 20 75 73 65 | 73 20 6f 66 20 4e 55 4c |d up use|s of NUL|
|00001e00| 4c 2f 30 2e 20 4e 6f 77 | 20 64 69 73 74 72 69 62 |L/0. Now| distrib|
|00001e10| 75 74 65 64 20 77 69 74 | 68 20 73 69 6f 64 2e 73 |uted wit|h siod.s|
|00001e20| 63 6d 2e 0a 20 90 03 52 | 65 6c 65 61 73 65 20 31 |cm.. ..R|elease 1|
|00001e30| 2e 32 3a 20 32 38 2d 41 | 50 52 2d 38 38 2c 20 6e |.2: 28-A|PR-88, n|
|00001e40| 61 6d 65 20 63 68 61 6e | 67 65 73 20 61 73 20 72 |ame chan|ges as r|
|00001e50| 65 71 75 65 73 74 65 64 | 20 62 79 20 4a 41 52 40 |equested| by JAR@|
|00001e60| 41 49 2e 41 49 2e 4d 49 | 54 2e 45 44 55 2c 0a 20 |AI.AI.MI|T.EDU,. |
|00001e70| 90 04 70 6c 75 73 20 73 | 6f 6d 65 20 62 75 67 20 |..plus s|ome bug |
|00001e80| 66 69 78 65 73 2e 0a 20 | 90 03 52 65 6c 65 61 73 |fixes.. |..Releas|
|00001e90| 65 20 31 2e 33 3a 20 31 | 2d 4d 41 59 2d 38 38 2c |e 1.3: 1|-MAY-88,|
|00001ea0| 20 63 68 61 6e 67 65 64 | 20 65 6e 76 20 74 6f 20 | changed| env to |
|00001eb0| 75 73 65 20 66 72 61 6d | 65 73 20 69 6e 73 74 65 |use fram|es inste|
|00001ec0| 61 64 20 6f 66 20 61 6c | 69 73 74 2e 0a 20 90 04 |ad of al|ist.. ..|
|00001ed0| 64 65 66 69 6e 65 20 6e | 6f 77 20 77 6f 72 6b 73 |define n|ow works|
|00001ee0| 20 70 72 6f 70 65 72 6c | 79 2e 20 76 6d 73 20 73 | properl|y. vms s|
|00001ef0| 70 65 63 69 66 69 63 20 | 66 75 6e 63 74 69 6f 6e |pecific |function|
|00001f00| 20 65 64 69 74 2e 0a 20 | 90 03 52 65 6c 65 61 73 | edit.. |..Releas|
|00001f10| 65 20 31 2e 34 20 32 30 | 2d 4e 4f 56 2d 38 39 2e |e 1.4 20|-NOV-89.|
|00001f20| 20 4d 69 6e 6f 72 20 43 | 6c 65 61 6e 75 70 20 61 | Minor C|leanup a|
|00001f30| 6e 64 20 72 65 6d 6f 64 | 75 6c 61 72 69 7a 61 74 |nd remod|ularizat|
|00001f40| 69 6f 6e 2e 0a 20 90 04 | 4e 6f 77 20 69 6e 20 33 |ion.. ..|Now in 3|
|00001f50| 20 66 69 6c 65 73 2c 20 | 73 69 6f 64 2e 68 2c 20 | files, |siod.h, |
|00001f60| 73 6c 69 62 2e 63 2c 20 | 73 69 6f 64 2e 63 2e 20 |slib.c, |siod.c. |
|00001f70| 4d 61 6b 65 73 20 69 74 | 20 65 61 73 69 65 72 20 |Makes it| easier |
|00001f80| 74 6f 20 77 72 69 74 65 | 20 79 6f 75 72 0a 20 90 |to write| your. .|
|00001f90| 04 6f 77 6e 20 6d 61 69 | 6e 20 6c 6f 6f 70 73 2e |.own mai|n loops.|
|00001fa0| 20 53 6f 6d 65 20 73 68 | 6f 72 74 2d 69 6e 74 20 | Some sh|ort-int |
|00001fb0| 63 68 61 6e 67 65 73 20 | 66 6f 72 20 6c 69 67 68 |changes |for ligh|
|00001fc0| 74 73 70 65 65 64 20 43 | 20 69 6e 63 6c 75 64 65 |tspeed C| include|
|00001fd0| 64 2e 0a 20 90 03 52 65 | 6c 65 61 73 65 20 31 2e |d.. ..Re|lease 1.|
|00001fe0| 35 20 32 39 2d 4e 4f 56 | 2d 38 39 2e 20 41 64 64 |5 29-NOV|-89. Add|
|00001ff0| 65 64 20 73 74 61 72 74 | 75 70 20 66 6c 61 67 20 |ed start|up flag |
|00002000| 2d 67 2c 20 73 65 6c 65 | 63 74 20 73 74 6f 70 20 |-g, sele|ct stop |
|00002010| 61 6e 64 20 63 6f 70 79 | 0a 20 90 04 6f 72 20 6d |and copy|. ..or m|
|00002020| 61 72 6b 2d 61 6e 64 2d | 73 77 65 65 70 20 67 61 |ark-and-|sweep ga|
|00002030| 72 62 61 67 65 20 63 6f | 6c 6c 65 63 74 69 6f 6e |rbage co|llection|
|00002040| 2c 20 77 68 69 63 68 20 | 61 73 73 75 6d 65 73 20 |, which |assumes |
|00002050| 74 68 61 74 20 74 68 65 | 20 73 74 61 63 6b 2f 72 |that the| stack/r|
|00002060| 65 67 69 73 74 65 72 0a | 20 90 04 6d 61 72 6b 69 |egister.| ..marki|
|00002070| 6e 67 20 63 6f 64 65 20 | 69 73 20 63 6f 72 72 65 |ng code |is corre|
|00002080| 63 74 20 66 6f 72 20 79 | 6f 75 72 20 61 72 63 68 |ct for y|our arch|
|00002090| 69 74 65 63 74 75 72 65 | 2e 20 0a 20 90 03 52 65 |itecture|. . ..Re|
|000020a0| 6c 65 61 73 65 20 32 2e | 30 20 31 2d 44 45 43 2d |lease 2.|0 1-DEC-|
|000020b0| 38 39 2e 20 41 64 64 65 | 64 20 72 65 70 6c 5f 68 |89. Adde|d repl_h|
|000020c0| 6f 6f 6b 73 2c 20 43 61 | 74 63 68 2c 20 54 68 72 |ooks, Ca|tch, Thr|
|000020d0| 6f 77 2e 20 54 68 69 73 | 20 69 73 20 73 69 67 6e |ow. This| is sign|
|000020e0| 69 66 69 63 61 6e 74 6c | 79 0a 20 90 04 64 69 66 |ificantl|y. ..dif|
|000020f0| 66 65 72 65 6e 74 20 65 | 6e 6f 75 67 68 20 28 66 |ferent e|nough (f|
|00002100| 72 6f 6d 20 31 2e 33 29 | 20 6e 6f 77 20 74 68 61 |rom 1.3)| now tha|
|00002110| 74 20 49 27 6d 20 63 61 | 6c 6c 69 6e 67 20 69 74 |t I'm ca|lling it|
|00002120| 20 61 20 6d 61 6a 6f 72 | 20 72 65 6c 65 61 73 65 | a major| release|
|00002130| 2e 0a 20 90 03 52 65 6c | 65 61 73 65 20 32 2e 31 |.. ..Rel|ease 2.1|
|00002140| 20 34 2d 44 45 43 2d 38 | 39 2e 20 53 6d 61 6c 6c | 4-DEC-8|9. Small|
|00002150| 20 72 65 61 64 65 72 20 | 66 65 61 74 75 72 65 73 | reader |features|
|00002160| 2c 20 64 6f 74 2c 20 62 | 61 63 6b 71 75 6f 74 65 |, dot, b|ackquote|
|00002170| 2c 20 63 6f 6d 6d 61 2e | 0a 20 90 03 52 65 6c 65 |, comma.|. ..Rele|
|00002180| 61 73 65 20 32 2e 32 20 | 35 2d 44 45 43 2d 38 39 |ase 2.2 |5-DEC-89|
|00002190| 2e 20 67 63 2c 72 65 61 | 64 2c 70 72 69 6e 74 2c |. gc,rea|d,print,|
|000021a0| 65 76 61 6c 2c 20 68 6f | 6f 6b 73 20 66 6f 72 20 |eval, ho|oks for |
|000021b0| 75 73 65 72 20 64 65 66 | 69 6e 65 64 20 64 61 74 |user def|ined dat|
|000021c0| 61 74 79 70 65 73 2e 0a | 20 90 03 52 65 6c 65 61 |atypes..| ..Relea|
|000021d0| 73 65 20 32 2e 33 20 36 | 2d 44 45 43 2d 38 39 2e |se 2.3 6|-DEC-89.|
|000021e0| 20 73 61 76 65 5f 66 6f | 72 6d 73 2c 20 6f 62 61 | save_fo|rms, oba|
|000021f0| 72 72 61 79 20 69 6e 74 | 65 72 6e 20 6d 65 63 68 |rray int|ern mech|
|00002200| 61 6e 69 73 6d 2e 20 63 | 6f 6d 6d 65 6e 74 20 63 |anism. c|omment c|
|00002210| 68 61 72 2e 0a 20 90 03 | 52 65 6c 65 61 73 65 20 |har.. ..|Release |
|00002220| 32 2e 33 61 2e 90 09 20 | 6d 69 6e 6f 72 20 73 70 |2.3a... |minor sp|
|00002230| 65 65 64 2d 75 70 73 2e | 20 69 2f 6f 20 69 6e 74 |eed-ups.| i/o int|
|00002240| 65 72 72 75 70 74 20 63 | 6f 6e 73 69 64 65 72 61 |errupt c|onsidera|
|00002250| 74 69 6f 6e 73 2e 0a 20 | 90 03 52 65 6c 65 61 73 |tions.. |..Releas|
|00002260| 65 20 32 2e 34 20 32 37 | 2d 41 50 52 2d 39 30 20 |e 2.4 27|-APR-90 |
|00002270| 67 65 6e 5f 72 65 61 64 | 72 2c 20 66 6f 72 20 72 |gen_read|r, for r|
|00002280| 65 61 64 2d 66 72 6f 6d | 2d 73 74 72 69 6e 67 2e |ead-from|-string.|
|00002290| 0a 0a 20 20 2a 2f 0a 0a | 23 69 6e 63 6c 75 64 65 |.. */..|#include|
|000022a0| 20 3c 73 74 64 69 6f 2e | 68 3e 0a 23 69 6e 63 6c | <stdio.|h>.#incl|
|000022b0| 75 64 65 20 3c 73 74 72 | 69 6e 67 2e 68 3e 0a 23 |ude <str|ing.h>.#|
|000022c0| 69 6e 63 6c 75 64 65 20 | 3c 63 74 79 70 65 2e 68 |include |<ctype.h|
|000022d0| 3e 0a 23 69 6e 63 6c 75 | 64 65 20 3c 73 65 74 6a |>.#inclu|de <setj|
|000022e0| 6d 70 2e 68 3e 0a 23 69 | 6e 63 6c 75 64 65 20 3c |mp.h>.#i|nclude <|
|000022f0| 73 69 67 6e 61 6c 2e 68 | 3e 0a 23 69 6e 63 6c 75 |signal.h|>.#inclu|
|00002300| 64 65 20 3c 6d 61 74 68 | 2e 68 3e 0a 23 69 66 64 |de <math|.h>.#ifd|
|00002310| 65 66 20 76 6d 73 0a 23 | 69 6e 63 6c 75 64 65 20 |ef vms.#|include |
|00002320| 3c 73 74 64 6c 69 62 2e | 68 3e 0a 23 65 6e 64 69 |<stdlib.|h>.#endi|
|00002330| 66 0a 0a 23 69 66 64 65 | 66 20 41 52 4d 0a 23 69 |f..#ifde|f ARM.#i|
|00002340| 6e 63 6c 75 64 65 20 3c | 73 74 64 6c 69 62 2e 68 |nclude <|stdlib.h|
|00002350| 3e 0a 23 65 6e 64 69 66 | 0a 90 05 23 69 6e 63 6c |>.#endif|...#incl|
|00002360| 75 64 65 20 22 73 69 6f | 64 2e 68 22 0a 0a 4c 49 |ude "sio|d.h"..LI|
|00002370| 53 50 20 68 65 61 70 5f | 31 2c 68 65 61 70 5f 32 |SP heap_|1,heap_2|
|00002380| 3b 0a 4c 49 53 50 20 68 | 65 61 70 2c 68 65 61 70 |;.LISP h|eap,heap|
|00002390| 5f 65 6e 64 2c 68 65 61 | 70 5f 6f 72 67 3b 0a 0a |_end,hea|p_org;..|
|000023a0| 6c 6f 6e 67 20 68 65 61 | 70 5f 73 69 7a 65 20 3d |long hea|p_size =|
|000023b0| 20 35 30 90 03 3b 0a 6c | 6f 6e 67 20 6f 6c 64 5f | 50..;.l|ong old_|
|000023c0| 68 65 61 70 5f 75 73 65 | 64 3b 0a 6c 6f 6e 67 20 |heap_use|d;.long |
|000023d0| 77 68 69 63 68 5f 68 65 | 61 70 3b 0a 6c 6f 6e 67 |which_he|ap;.long|
|000023e0| 20 67 63 5f 73 74 61 74 | 75 73 5f 66 6c 61 67 20 | gc_stat|us_flag |
|000023f0| 3d 20 31 3b 0a 63 68 61 | 72 20 2a 69 6e 69 74 5f |= 1;.cha|r *init_|
|00002400| 66 69 6c 65 20 3d 20 28 | 63 68 61 72 20 2a 29 20 |file = (|char *) |
|00002410| 4e 55 4c 4c 3b 0a 63 68 | 61 72 20 74 6b 62 75 66 |NULL;.ch|ar tkbuf|
|00002420| 66 65 72 5b 54 4b 42 55 | 46 46 45 52 4e 5d 3b 0a |fer[TKBU|FFERN];.|
|00002430| 0a 6c 6f 6e 67 20 67 63 | 5f 6b 69 6e 64 5f 63 6f |.long gc|_kind_co|
|00002440| 70 79 69 6e 67 20 3d 20 | 31 3b 0a 0a 6c 6f 6e 67 |pying = |1;..long|
|00002450| 20 67 63 5f 63 65 6c 6c | 73 5f 61 6c 6c 6f 63 61 | gc_cell|s_alloca|
|00002460| 74 65 64 20 3d 20 30 3b | 0a 64 6f 75 62 6c 65 20 |ted = 0;|.double |
|00002470| 67 63 5f 74 69 6d 65 5f | 74 61 6b 65 6e 3b 0a 4c |gc_time_|taken;.L|
|00002480| 49 53 50 20 2a 73 74 61 | 63 6b 5f 73 74 61 72 74 |ISP *sta|ck_start|
|00002490| 5f 70 74 72 3b 0a 4c 49 | 53 50 20 66 72 65 65 6c |_ptr;.LI|SP freel|
|000024a0| 69 73 74 3b 0a 0a 6a 6d | 70 5f 62 75 66 20 65 72 |ist;..jm|p_buf er|
|000024b0| 72 6a 6d 70 3b 0a 6c 6f | 6e 67 20 65 72 72 6a 6d |rjmp;.lo|ng errjm|
|000024c0| 70 5f 6f 6b 20 3d 20 30 | 3b 0a 6c 6f 6e 67 20 6e |p_ok = 0|;.long n|
|000024d0| 6f 69 6e 74 65 72 72 75 | 70 74 20 3d 20 31 3b 0a |ointerru|pt = 1;.|
|000024e0| 6c 6f 6e 67 20 69 6e 74 | 65 72 72 75 70 74 5f 64 |long int|errupt_d|
|000024f0| 69 66 66 65 72 65 64 20 | 3d 20 30 3b 0a 0a 4c 49 |iffered |= 0;..LI|
|00002500| 53 50 20 6f 62 6c 69 73 | 74 76 61 72 20 3d 20 4e |SP oblis|tvar = N|
|00002510| 49 4c 3b 0a 4c 49 53 50 | 20 74 72 75 74 68 20 3d |IL;.LISP| truth =|
|00002520| 20 4e 49 4c 3b 0a 4c 49 | 53 50 20 65 6f 66 5f 76 | NIL;.LI|SP eof_v|
|00002530| 61 6c 20 3d 20 4e 49 4c | 3b 0a 4c 49 53 50 20 73 |al = NIL|;.LISP s|
|00002540| 79 6d 5f 65 72 72 6f 62 | 6a 20 3d 20 4e 49 4c 3b |ym_errob|j = NIL;|
|00002550| 0a 4c 49 53 50 20 73 79 | 6d 5f 70 72 6f 67 6e 20 |.LISP sy|m_progn |
|00002560| 3d 20 4e 49 4c 3b 0a 4c | 49 53 50 20 73 79 6d 5f |= NIL;.L|ISP sym_|
|00002570| 6c 61 6d 62 64 61 20 3d | 20 4e 49 4c 3b 0a 4c 49 |lambda =| NIL;.LI|
|00002580| 53 50 20 73 79 6d 5f 71 | 75 6f 74 65 20 3d 20 4e |SP sym_q|uote = N|
|00002590| 49 4c 3b 0a 4c 49 53 50 | 20 73 79 6d 5f 64 6f 74 |IL;.LISP| sym_dot|
|000025a0| 20 3d 20 4e 49 4c 3b 0a | 4c 49 53 50 20 6f 70 65 | = NIL;.|LISP ope|
|000025b0| 6e 5f 66 69 6c 65 73 20 | 3d 20 4e 49 4c 3b 0a 4c |n_files |= NIL;.L|
|000025c0| 49 53 50 20 75 6e 62 6f | 75 6e 64 5f 6d 61 72 6b |ISP unbo|und_mark|
|000025d0| 65 72 20 3d 20 4e 49 4c | 3b 0a 0a 4c 49 53 50 20 |er = NIL|;..LISP |
|000025e0| 2a 6f 62 61 72 72 61 79 | 3b 0a 6c 6f 6e 67 20 6f |*obarray|;.long o|
|000025f0| 62 61 72 72 61 79 5f 64 | 69 6d 20 3d 20 31 30 30 |barray_d|im = 100|
|00002600| 3b 0a 0a 73 74 72 75 63 | 74 20 63 61 74 63 68 5f |;..struc|t catch_|
|00002610| 66 72 61 6d 65 0a 7b 4c | 49 53 50 20 74 61 67 3b |frame.{L|ISP tag;|
|00002620| 0a 20 4c 49 53 50 20 72 | 65 74 76 61 6c 3b 0a 20 |. LISP r|etval;. |
|00002630| 6a 6d 70 5f 62 75 66 20 | 63 66 72 61 6d 65 3b 0a |jmp_buf |cframe;.|
|00002640| 20 73 74 72 75 63 74 20 | 63 61 74 63 68 5f 66 72 | struct |catch_fr|
|00002650| 61 6d 65 20 2a 6e 65 78 | 74 3b 7d 3b 0a 0a 73 74 |ame *nex|t;};..st|
|00002660| 72 75 63 74 20 67 63 5f | 70 72 6f 74 65 63 74 65 |ruct gc_|protecte|
|00002670| 64 0a 7b 4c 49 53 50 20 | 2a 6c 6f 63 61 74 69 6f |d.{LISP |*locatio|
|00002680| 6e 3b 0a 20 6c 6f 6e 67 | 20 6c 65 6e 67 74 68 3b |n;. long| length;|
|00002690| 0a 20 73 74 72 75 63 74 | 20 67 63 5f 70 72 6f 74 |. struct| gc_prot|
|000026a0| 65 63 74 65 64 20 2a 6e | 65 78 74 3b 7d 3b 0a 0a |ected *n|ext;};..|
|000026b0| 73 74 72 75 63 74 20 63 | 61 74 63 68 5f 66 72 61 |struct c|atch_fra|
|000026c0| 6d 65 20 2a 63 61 74 63 | 68 5f 66 72 61 6d 65 70 |me *catc|h_framep|
|000026d0| 20 3d 20 28 73 74 72 75 | 63 74 20 63 61 74 63 68 | = (stru|ct catch|
|000026e0| 5f 66 72 61 6d 65 20 2a | 29 20 4e 55 4c 4c 3b 0a |_frame *|) NULL;.|
|000026f0| 90 03 70 72 6f 63 65 73 | 73 5f 63 6c 61 28 61 72 |..proces|s_cla(ar|
|00002700| 67 63 2c 61 72 67 76 2c | 77 61 72 6e 66 6c 61 67 |gc,argv,|warnflag|
|00002710| 29 0a 20 69 6e 74 20 61 | 72 67 63 2c 77 61 72 6e |). int a|rgc,warn|
|00002720| 66 6c 61 67 3b 20 63 68 | 61 72 20 2a 2a 61 72 67 |flag; ch|ar **arg|
|00002730| 76 3b 0a 7b 69 6e 74 20 | 6b 3b 0a 20 66 6f 72 28 |v;.{int |k;. for(|
|00002740| 6b 3d 31 3b 6b 3c 61 72 | 67 63 3b 2b 2b 6b 29 0a |k=1;k<ar|gc;++k).|
|00002750| 20 90 03 7b 69 66 20 28 | 73 74 72 6c 65 6e 28 61 | ..{if (|strlen(a|
|00002760| 72 67 76 5b 6b 5d 29 3c | 32 29 20 63 6f 6e 74 69 |rgv[k])<|2) conti|
|00002770| 6e 75 65 3b 0a 20 90 04 | 69 66 20 28 61 72 67 76 |nue;. ..|if (argv|
|00002780| 5b 6b 5d 5b 30 5d 20 21 | 3d 20 27 2d 27 29 0a 20 |[k][0] !|= '-'). |
|00002790| 90 06 7b 69 66 20 28 77 | 61 72 6e 66 6c 61 67 29 |..{if (w|arnflag)|
|000027a0| 20 70 72 69 6e 74 66 28 | 22 62 61 64 20 61 72 67 | printf(|"bad arg|
|000027b0| 3a 20 25 73 5c 6e 22 2c | 61 72 67 76 5b 6b 5d 29 |: %s\n",|argv[k])|
|000027c0| 3b 63 6f 6e 74 69 6e 75 | 65 3b 7d 0a 20 90 04 73 |;continu|e;}. ..s|
|000027d0| 77 69 74 63 68 28 61 72 | 67 76 5b 6b 5d 5b 31 5d |witch(ar|gv[k][1]|
|000027e0| 29 0a 20 90 06 7b 63 61 | 73 65 20 27 68 27 3a 0a |). ..{ca|se 'h':.|
|000027f0| 09 20 68 65 61 70 5f 73 | 69 7a 65 20 3d 20 61 74 |. heap_s|ize = at|
|00002800| 6f 6c 28 26 28 61 72 67 | 76 5b 6b 5d 5b 32 5d 29 |ol(&(arg|v[k][2])|
|00002810| 29 3b 20 62 72 65 61 6b | 3b 0a 20 90 07 63 61 73 |); break|;. ..cas|
|00002820| 65 20 27 6f 27 3a 0a 09 | 20 6f 62 61 72 72 61 79 |e 'o':..| obarray|
|00002830| 5f 64 69 6d 20 3d 20 61 | 74 6f 6c 28 26 28 61 72 |_dim = a|tol(&(ar|
|00002840| 67 76 5b 6b 5d 5b 32 5d | 29 29 3b 20 62 72 65 61 |gv[k][2]|)); brea|
|00002850| 6b 3b 0a 20 90 07 63 61 | 73 65 20 27 69 27 3a 0a |k;. ..ca|se 'i':.|
|00002860| 09 20 69 6e 69 74 5f 66 | 69 6c 65 20 3d 20 26 28 |. init_f|ile = &(|
|00002870| 61 72 67 76 5b 6b 5d 5b | 32 5d 29 3b 20 62 72 65 |argv[k][|2]); bre|
|00002880| 61 6b 3b 0a 20 90 07 63 | 61 73 65 20 27 67 27 3a |ak;. ..c|ase 'g':|
|00002890| 0a 09 20 67 63 5f 6b 69 | 6e 64 5f 63 6f 70 79 69 |.. gc_ki|nd_copyi|
|000028a0| 6e 67 20 3d 20 61 74 6f | 6c 28 26 28 61 72 67 76 |ng = ato|l(&(argv|
|000028b0| 5b 6b 5d 5b 32 5d 29 29 | 3b 20 62 72 65 61 6b 3b |[k][2]))|; break;|
|000028c0| 0a 20 90 07 64 65 66 61 | 75 6c 74 3a 20 69 66 20 |. ..defa|ult: if |
|000028d0| 28 77 61 72 6e 66 6c 61 | 67 29 20 70 72 69 6e 74 |(warnfla|g) print|
|000028e0| 66 28 22 62 61 64 20 61 | 72 67 3a 20 25 73 5c 6e |f("bad a|rg: %s\n|
|000028f0| 22 2c 61 72 67 76 5b 6b | 5d 29 3b 7d 90 03 0a 0a |",argv[k|]);}....|
|00002900| 70 72 69 6e 74 5f 77 65 | 6c 63 6f 6d 65 28 29 0a |print_we|lcome().|
|00002910| 7b 70 72 69 6e 74 66 28 | 22 57 65 6c 63 6f 6d 65 |{printf(|"Welcome|
|00002920| 20 74 6f 20 53 49 4f 44 | 2c 20 53 63 68 65 6d 65 | to SIOD|, Scheme|
|00002930| 20 49 6e 20 4f 6e 65 20 | 44 65 66 75 6e 2c 20 56 | In One |Defun, V|
|00002940| 65 72 73 69 6f 6e 20 32 | 2e 34 5c 6e 22 29 3b 0a |ersion 2|.4\n");.|
|00002950| 20 70 72 69 6e 74 66 28 | 22 28 43 29 20 43 6f 70 | printf(|"(C) Cop|
|00002960| 79 72 69 67 68 74 20 31 | 39 38 38 2c 20 31 39 38 |yright 1|988, 198|
|00002970| 39 2c 20 31 39 39 30 20 | 50 61 72 61 64 69 67 6d |9, 1990 |Paradigm|
|00002980| 20 41 73 73 6f 63 69 61 | 74 65 73 20 49 6e 63 2e | Associa|tes Inc.|
|00002990| 5c 6e 22 29 3b 7d 0a 0a | 70 72 69 6e 74 5f 68 73 |\n");}..|print_hs|
|000029a0| 5f 31 28 29 0a 7b 70 72 | 69 6e 74 66 28 22 68 65 |_1().{pr|intf("he|
|000029b0| 61 70 5f 73 69 7a 65 20 | 3d 20 25 6c 64 20 63 65 |ap_size |= %ld ce|
|000029c0| 6c 6c 73 2c 20 25 6c 64 | 20 62 79 74 65 73 2e 20 |lls, %ld| bytes. |
|000029d0| 47 43 20 69 73 20 25 73 | 5c 6e 22 2c 0a 20 90 08 |GC is %s|\n",. ..|
|000029e0| 68 65 61 70 5f 73 69 7a | 65 2c 68 65 61 70 5f 73 |heap_siz|e,heap_s|
|000029f0| 69 7a 65 2a 73 69 7a 65 | 6f 66 28 73 74 72 75 63 |ize*size|of(struc|
|00002a00| 74 20 6f 62 6a 29 2c 0a | 09 28 67 63 5f 6b 69 6e |t obj),.|.(gc_kin|
|00002a10| 64 5f 63 6f 70 79 69 6e | 67 20 3d 3d 20 31 29 20 |d_copyin|g == 1) |
|00002a20| 3f 20 22 73 74 6f 70 20 | 61 6e 64 20 63 6f 70 79 |? "stop |and copy|
|00002a30| 22 20 3a 20 22 6d 61 72 | 6b 20 61 6e 64 20 73 77 |" : "mar|k and sw|
|00002a40| 65 65 70 22 29 3b 7d 0a | 0a 70 72 69 6e 74 5f 68 |eep");}.|.print_h|
|00002a50| 73 5f 32 28 29 0a 7b 69 | 66 20 28 67 63 5f 6b 69 |s_2().{i|f (gc_ki|
|00002a60| 6e 64 5f 63 6f 70 79 69 | 6e 67 20 3d 3d 20 31 29 |nd_copyi|ng == 1)|
|00002a70| 0a 20 90 03 70 72 69 6e | 74 66 28 22 68 65 61 70 |. ..prin|tf("heap|
|00002a80| 5f 31 20 61 74 20 30 78 | 25 6c 58 2c 20 68 65 61 |_1 at 0x|%lX, hea|
|00002a90| 70 5f 32 20 61 74 20 30 | 78 25 6c 58 5c 6e 22 2c |p_2 at 0|x%lX\n",|
|00002aa0| 68 65 61 70 5f 31 2c 68 | 65 61 70 5f 32 29 3b 0a |heap_1,h|eap_2);.|
|00002ab0| 20 65 6c 73 65 0a 20 90 | 03 70 72 69 6e 74 66 28 | else. .|.printf(|
|00002ac0| 22 68 65 61 70 5f 31 20 | 61 74 20 30 78 25 6c 58 |"heap_1 |at 0x%lX|
|00002ad0| 5c 6e 22 2c 68 65 61 70 | 5f 31 29 3b 7d 0a 0a 6c |\n",heap|_1);}..l|
|00002ae0| 6f 6e 67 20 6e 6f 5f 69 | 6e 74 65 72 72 75 70 74 |ong no_i|nterrupt|
|00002af0| 28 6e 29 0a 20 90 05 6c | 6f 6e 67 20 6e 3b 0a 7b |(n). ..l|ong n;.{|
|00002b00| 6c 6f 6e 67 20 78 3b 0a | 20 78 20 3d 20 6e 6f 69 |long x;.| x = noi|
|00002b10| 6e 74 65 72 72 75 70 74 | 3b 0a 20 6e 6f 69 6e 74 |nterrupt|;. noint|
|00002b20| 65 72 72 75 70 74 20 3d | 20 6e 3b 0a 20 69 66 20 |errupt =| n;. if |
|00002b30| 28 28 6e 6f 69 6e 74 65 | 72 72 75 70 74 20 3d 3d |((nointe|rrupt ==|
|00002b40| 20 30 29 20 26 26 20 28 | 69 6e 74 65 72 72 75 70 | 0) && (|interrup|
|00002b50| 74 5f 64 69 66 66 65 72 | 65 64 20 3d 3d 20 31 29 |t_differ|ed == 1)|
|00002b60| 29 0a 20 90 03 7b 69 6e | 74 65 72 72 75 70 74 5f |). ..{in|terrupt_|
|00002b70| 64 69 66 66 65 72 65 64 | 20 3d 20 30 3b 0a 20 90 |differed| = 0;. .|
|00002b80| 04 65 72 72 5f 63 74 72 | 6c 5f 63 28 29 3b 7d 0a |.err_ctr|l_c();}.|
|00002b90| 20 72 65 74 75 72 6e 28 | 78 29 3b 7d 0a 90 04 76 | return(|x);}...v|
|00002ba0| 6f 69 64 20 68 61 6e 64 | 6c 65 5f 73 69 67 66 70 |oid hand|le_sigfp|
|00002bb0| 65 28 73 69 67 2c 63 6f | 64 65 2c 73 63 70 29 0a |e(sig,co|de,scp).|
|00002bc0| 20 6c 6f 6e 67 20 73 69 | 67 2c 63 6f 64 65 3b 20 | long si|g,code; |
|00002bd0| 73 74 72 75 63 74 20 73 | 69 67 63 6f 6e 74 65 78 |struct s|igcontex|
|00002be0| 74 20 2a 73 63 70 3b 0a | 7b 73 69 67 6e 61 6c 28 |t *scp;.|{signal(|
|00002bf0| 53 49 47 46 50 45 2c 68 | 61 6e 64 6c 65 5f 73 69 |SIGFPE,h|andle_si|
|00002c00| 67 66 70 65 29 3b 0a 20 | 65 72 72 28 22 66 6c 6f |gfpe);. |err("flo|
|00002c10| 61 74 69 6e 67 20 70 6f | 69 6e 74 20 65 78 63 65 |ating po|int exce|
|00002c20| 70 74 69 6f 6e 22 2c 4e | 49 4c 29 3b 7d 0a 0a 76 |ption",N|IL);}..v|
|00002c30| 6f 69 64 20 68 61 6e 64 | 6c 65 5f 73 69 67 69 6e |oid hand|le_sigin|
|00002c40| 74 28 73 69 67 2c 63 6f | 64 65 2c 73 63 70 29 0a |t(sig,co|de,scp).|
|00002c50| 20 6c 6f 6e 67 20 73 69 | 67 2c 63 6f 64 65 3b 20 | long si|g,code; |
|00002c60| 73 74 72 75 63 74 20 73 | 69 67 63 6f 6e 74 65 78 |struct s|igcontex|
|00002c70| 74 20 2a 73 63 70 3b 0a | 7b 73 69 67 6e 61 6c 28 |t *scp;.|{signal(|
|00002c80| 53 49 47 49 4e 54 2c 68 | 61 6e 64 6c 65 5f 73 69 |SIGINT,h|andle_si|
|00002c90| 67 69 6e 74 29 3b 0a 20 | 69 66 20 28 6e 6f 69 6e |gint);. |if (noin|
|00002ca0| 74 65 72 72 75 70 74 20 | 3d 3d 20 31 29 0a 20 90 |terrupt |== 1). .|
|00002cb0| 03 69 6e 74 65 72 72 75 | 70 74 5f 64 69 66 66 65 |.interru|pt_diffe|
|00002cc0| 72 65 64 20 3d 20 31 3b | 0a 20 65 6c 73 65 0a 20 |red = 1;|. else. |
|00002cd0| 90 03 65 72 72 5f 63 74 | 72 6c 5f 63 28 29 3b 7d |..err_ct|rl_c();}|
|00002ce0| 0a 0a 65 72 72 5f 63 74 | 72 6c 5f 63 28 29 0a 7b |..err_ct|rl_c().{|
|00002cf0| 65 72 72 28 22 63 6f 6e | 74 72 6f 6c 2d 63 20 69 |err("con|trol-c i|
|00002d00| 6e 74 65 72 72 75 70 74 | 22 2c 4e 49 4c 29 3b 7d |nterrupt|",NIL);}|
|00002d10| 0a 0a 4c 49 53 50 20 67 | 65 74 5f 65 6f 66 5f 76 |..LISP g|et_eof_v|
|00002d20| 61 6c 28 29 0a 7b 72 65 | 74 75 72 6e 28 65 6f 66 |al().{re|turn(eof|
|00002d30| 5f 76 61 6c 29 3b 7d 0a | 0a 72 65 70 6c 5f 64 72 |_val);}.|.repl_dr|
|00002d40| 69 76 65 72 28 77 61 6e | 74 5f 73 69 67 69 6e 74 |iver(wan|t_sigint|
|00002d50| 2c 77 61 6e 74 5f 69 6e | 69 74 29 0a 20 90 05 6c |,want_in|it). ..l|
|00002d60| 6f 6e 67 20 77 61 6e 74 | 5f 73 69 67 69 6e 74 2c |ong want|_sigint,|
|00002d70| 77 61 6e 74 5f 69 6e 69 | 74 3b 0a 7b 69 6e 74 20 |want_ini|t;.{int |
|00002d80| 6b 3b 0a 20 4c 49 53 50 | 20 73 74 61 63 6b 5f 73 |k;. LISP| stack_s|
|00002d90| 74 61 72 74 3b 0a 20 73 | 74 61 63 6b 5f 73 74 61 |tart;. s|tack_sta|
|00002da0| 72 74 5f 70 74 72 20 3d | 20 26 73 74 61 63 6b 5f |rt_ptr =| &stack_|
|00002db0| 73 74 61 72 74 3b 0a 20 | 6b 20 3d 20 73 65 74 6a |start;. |k = setj|
|00002dc0| 6d 70 28 65 72 72 6a 6d | 70 29 3b 0a 20 69 66 20 |mp(errjm|p);. if |
|00002dd0| 28 6b 20 3d 3d 20 32 29 | 20 72 65 74 75 72 6e 3b |(k == 2)| return;|
|00002de0| 0a 20 69 66 20 28 77 61 | 6e 74 5f 73 69 67 69 6e |. if (wa|nt_sigin|
|00002df0| 74 29 20 73 69 67 6e 61 | 6c 28 53 49 47 46 50 45 |t) signa|l(SIGFPE|
|00002e00| 2c 68 61 6e 64 6c 65 5f | 73 69 67 66 70 65 29 3b |,handle_|sigfpe);|
|00002e10| 0a 20 73 69 67 6e 61 6c | 28 53 49 47 49 4e 54 2c |. signal|(SIGINT,|
|00002e20| 68 61 6e 64 6c 65 5f 73 | 69 67 69 6e 74 29 3b 0a |handle_s|igint);.|
|00002e30| 20 63 6c 6f 73 65 5f 6f | 70 65 6e 5f 66 69 6c 65 | close_o|pen_file|
|00002e40| 73 28 29 3b 0a 20 63 61 | 74 63 68 5f 66 72 61 6d |s();. ca|tch_fram|
|00002e50| 65 70 20 3d 20 28 73 74 | 72 75 63 74 20 63 61 74 |ep = (st|ruct cat|
|00002e60| 63 68 5f 66 72 61 6d 65 | 20 2a 29 20 4e 55 4c 4c |ch_frame| *) NULL|
|00002e70| 3b 0a 20 65 72 72 6a 6d | 70 5f 6f 6b 20 3d 20 31 |;. errjm|p_ok = 1|
|00002e80| 3b 0a 20 69 6e 74 65 72 | 72 75 70 74 5f 64 69 66 |;. inter|rupt_dif|
|00002e90| 66 65 72 65 64 20 3d 20 | 30 3b 0a 20 6e 6f 69 6e |fered = |0;. noin|
|00002ea0| 74 65 72 72 75 70 74 20 | 3d 20 30 3b 0a 20 69 66 |terrupt |= 0;. if|
|00002eb0| 20 28 77 61 6e 74 5f 69 | 6e 69 74 20 26 26 20 69 | (want_i|nit && i|
|00002ec0| 6e 69 74 5f 66 69 6c 65 | 20 26 26 20 28 6b 20 3d |nit_file| && (k =|
|00002ed0| 3d 20 30 29 29 20 76 6c | 6f 61 64 28 69 6e 69 74 |= 0)) vl|oad(init|
|00002ee0| 5f 66 69 6c 65 2c 30 29 | 3b 0a 20 72 65 70 6c 28 |_file,0)|;. repl(|
|00002ef0| 29 3b 7d 0a 0a 23 69 66 | 64 65 66 20 75 6e 69 78 |);}..#if|def unix|
|00002f00| 0a 23 69 6e 63 6c 75 64 | 65 20 3c 73 79 73 2f 74 |.#includ|e <sys/t|
|00002f10| 79 70 65 73 2e 68 3e 0a | 23 69 6e 63 6c 75 64 65 |ypes.h>.|#include|
|00002f20| 20 3c 73 79 73 2f 74 69 | 6d 65 73 2e 68 3e 0a 73 | <sys/ti|mes.h>.s|
|00002f30| 74 72 75 63 74 20 74 6d | 73 20 74 69 6d 65 5f 62 |truct tm|s time_b|
|00002f40| 75 66 66 65 72 3b 0a 64 | 6f 75 62 6c 65 20 6d 79 |uffer;.d|ouble my|
|00002f50| 72 75 6e 74 69 6d 65 28 | 29 0a 7b 74 69 6d 65 73 |runtime(|).{times|
|00002f60| 28 26 74 69 6d 65 5f 62 | 75 66 66 65 72 29 3b 0a |(&time_b|uffer);.|
|00002f70| 20 72 65 74 75 72 6e 28 | 74 69 6d 65 5f 62 75 66 | return(|time_buf|
|00002f80| 66 65 72 2e 74 6d 73 5f | 75 74 69 6d 65 2f 36 30 |fer.tms_|utime/60|
|00002f90| 2e 30 29 3b 7d 0a 23 65 | 6c 73 65 0a 23 69 66 64 |.0);}.#e|lse.#ifd|
|00002fa0| 65 66 20 76 6d 73 0a 23 | 69 6e 63 6c 75 64 65 20 |ef vms.#|include |
|00002fb0| 3c 74 69 6d 65 2e 68 3e | 0a 64 6f 75 62 6c 65 20 |<time.h>|.double |
|00002fc0| 6d 79 72 75 6e 74 69 6d | 65 28 29 0a 7b 72 65 74 |myruntim|e().{ret|
|00002fd0| 75 72 6e 28 63 6c 6f 63 | 6b 28 29 20 2a 20 31 2e |urn(cloc|k() * 1.|
|00002fe0| 30 65 2d 32 29 3b 7d 0a | 23 65 6c 73 65 0a 23 69 |0e-2);}.|#else.#i|
|00002ff0| 66 64 65 66 20 41 52 4d | 0a 2f 2a 20 74 68 69 73 |fdef ARM|./* this|
|00003000| 20 69 73 20 73 74 69 6c | 6c 20 77 72 6f 6e 67 20 | is stil|l wrong |
|00003010| 2a 2f 0a 23 69 6e 63 6c | 75 64 65 20 3c 74 69 6d |*/.#incl|ude <tim|
|00003020| 65 2e 68 3e 0a 64 6f 75 | 62 6c 65 20 6d 79 72 75 |e.h>.dou|ble myru|
|00003030| 6e 74 69 6d 65 28 29 0a | 7b 63 6c 6f 63 6b 5f 74 |ntime().|{clock_t|
|00003040| 20 78 3b 0a 20 78 20 3d | 20 63 6c 6f 63 6b 28 29 | x;. x =| clock()|
|00003050| 3b 0a 20 72 65 74 75 72 | 6e 28 90 03 64 6f 75 62 |;. retur|n(..doub|
|00003060| 6c 65 29 20 78 29 2f 28 | 28 64 6f 75 62 6c 65 29 |le) x)/(|(double)|
|00003070| 20 43 4c 4f 43 4b 53 5f | 50 45 52 5f 53 45 43 29 | CLOCKS_|PER_SEC)|
|00003080| 29 3b 7d 0a 23 65 6c 73 | 65 0a 64 6f 75 62 6c 65 |);}.#els|e.double|
|00003090| 20 6d 79 72 75 6e 74 69 | 6d 65 28 29 0a 7b 6c 6f | myrunti|me().{lo|
|000030a0| 6e 67 20 78 3b 0a 20 6c | 6f 6e 67 20 74 69 6d 65 |ng x;. l|ong time|
|000030b0| 28 29 3b 0a 20 74 69 6d | 65 28 26 78 29 3b 0a 20 |();. tim|e(&x);. |
|000030c0| 72 65 74 75 72 6e 28 28 | 64 6f 75 62 6c 65 29 20 |return((|double) |
|000030d0| 78 29 3b 7d 0a 23 65 6e | 64 69 66 0a 23 65 6e 64 |x);}.#en|dif.#end|
|000030e0| 69 66 0a 23 65 6e 64 69 | 66 0a 90 03 76 6f 69 64 |if.#endi|f...void|
|000030f0| 20 28 2a 72 65 70 6c 5f | 70 75 74 73 29 28 29 20 | (*repl_|puts)() |
|00003100| 3d 20 4e 55 4c 4c 3b 0a | 4c 49 53 50 20 28 2a 72 |= NULL;.|LISP (*r|
|00003110| 65 70 6c 5f 72 65 61 64 | 29 28 29 20 3d 20 4e 55 |epl_read|)() = NU|
|00003120| 4c 4c 3b 0a 4c 49 53 50 | 20 28 2a 72 65 70 6c 5f |LL;.LISP| (*repl_|
|00003130| 65 76 61 6c 29 28 29 20 | 3d 20 4e 55 4c 4c 3b 0a |eval)() |= NULL;.|
|00003140| 76 6f 69 64 20 28 2a 72 | 65 70 6c 5f 70 72 69 6e |void (*r|epl_prin|
|00003150| 74 29 28 29 20 3d 20 4e | 55 4c 4c 3b 0a 0a 76 6f |t)() = N|ULL;..vo|
|00003160| 69 64 20 73 65 74 5f 72 | 65 70 6c 5f 68 6f 6f 6b |id set_r|epl_hook|
|00003170| 73 28 70 75 74 73 5f 66 | 2c 72 65 61 64 5f 66 2c |s(puts_f|,read_f,|
|00003180| 65 76 61 6c 5f 66 2c 70 | 72 69 6e 74 5f 66 29 0a |eval_f,p|rint_f).|
|00003190| 20 90 05 76 6f 69 64 20 | 28 2a 70 75 74 73 5f 66 | ..void |(*puts_f|
|000031a0| 29 28 29 3b 0a 20 90 05 | 4c 49 53 50 20 28 2a 72 |)();. ..|LISP (*r|
|000031b0| 65 61 64 5f 66 29 28 29 | 3b 0a 20 90 05 4c 49 53 |ead_f)()|;. ..LIS|
|000031c0| 50 20 28 2a 65 76 61 6c | 5f 66 29 28 29 3b 0a 20 |P (*eval|_f)();. |
|000031d0| 90 05 76 6f 69 64 20 28 | 2a 70 72 69 6e 74 5f 66 |..void (|*print_f|
|000031e0| 29 28 29 3b 0a 7b 72 65 | 70 6c 5f 70 75 74 73 20 |)();.{re|pl_puts |
|000031f0| 3d 20 70 75 74 73 5f 66 | 3b 0a 20 72 65 70 6c 5f |= puts_f|;. repl_|
|00003200| 72 65 61 64 20 3d 20 72 | 65 61 64 5f 66 3b 0a 20 |read = r|ead_f;. |
|00003210| 72 65 70 6c 5f 65 76 61 | 6c 20 3d 20 65 76 61 6c |repl_eva|l = eval|
|00003220| 5f 66 3b 0a 20 72 65 70 | 6c 5f 70 72 69 6e 74 20 |_f;. rep|l_print |
|00003230| 3d 20 70 72 69 6e 74 5f | 66 3b 7d 0a 0a 66 70 75 |= print_|f;}..fpu|
|00003240| 74 5f 73 74 28 66 2c 73 | 74 29 0a 20 90 05 46 49 |t_st(f,s|t). ..FI|
|00003250| 4c 45 20 2a 66 3b 0a 20 | 90 05 63 68 61 72 20 2a |LE *f;. |..char *|
|00003260| 73 74 3b 0a 7b 6c 6f 6e | 67 20 66 6c 61 67 3b 0a |st;.{lon|g flag;.|
|00003270| 20 66 6c 61 67 20 3d 20 | 6e 6f 5f 69 6e 74 65 72 | flag = |no_inter|
|00003280| 72 75 70 74 28 31 29 3b | 0a 20 66 70 72 69 6e 74 |rupt(1);|. fprint|
|00003290| 66 28 66 2c 22 25 73 22 | 2c 73 74 29 3b 0a 20 6e |f(f,"%s"|,st);. n|
|000032a0| 6f 5f 69 6e 74 65 72 72 | 75 70 74 28 66 6c 61 67 |o_interr|upt(flag|
|000032b0| 29 3b 7d 0a 0a 70 75 74 | 5f 73 74 28 73 74 29 0a |);}..put|_st(st).|
|000032c0| 20 90 05 63 68 61 72 20 | 2a 73 74 3b 0a 7b 66 70 | ..char |*st;.{fp|
|000032d0| 75 74 5f 73 74 28 73 74 | 64 6f 75 74 2c 73 74 29 |ut_st(st|dout,st)|
|000032e0| 3b 7d 0a 20 90 05 0a 67 | 72 65 70 6c 5f 70 75 74 |;}. ...g|repl_put|
|000032f0| 73 28 73 74 29 0a 20 90 | 05 63 68 61 72 20 2a 73 |s(st). .|.char *s|
|00003300| 74 3b 0a 7b 69 66 20 28 | 72 65 70 6c 5f 70 75 74 |t;.{if (|repl_put|
|00003310| 73 20 3d 3d 20 4e 55 4c | 4c 29 0a 20 90 03 70 75 |s == NUL|L). ..pu|
|00003320| 74 5f 73 74 28 73 74 29 | 3b 0a 20 65 6c 73 65 0a |t_st(st)|;. else.|
|00003330| 20 90 03 28 2a 72 65 70 | 6c 5f 70 75 74 73 29 28 | ..(*rep|l_puts)(|
|00003340| 73 74 29 3b 7d 0a 20 90 | 05 0a 72 65 70 6c 28 29 |st);}. .|..repl()|
|00003350| 20 0a 7b 4c 49 53 50 20 | 78 2c 63 77 3b 0a 20 64 | .{LISP |x,cw;. d|
|00003360| 6f 75 62 6c 65 20 72 74 | 3b 0a 20 77 68 69 6c 65 |ouble rt|;. while|
|00003370| 28 31 29 0a 20 90 03 7b | 69 66 20 28 28 67 63 5f |(1). ..{|if ((gc_|
|00003380| 6b 69 6e 64 5f 63 6f 70 | 79 69 6e 67 20 3d 3d 20 |kind_cop|ying == |
|00003390| 31 29 20 26 26 20 28 28 | 67 63 5f 73 74 61 74 75 |1) && ((|gc_statu|
|000033a0| 73 5f 66 6c 61 67 29 20 | 7c 7c 20 68 65 61 70 20 |s_flag) ||| heap |
|000033b0| 3e 3d 20 68 65 61 70 5f | 65 6e 64 29 29 0a 20 90 |>= heap_|end)). .|
|000033c0| 05 7b 72 74 20 3d 20 6d | 79 72 75 6e 74 69 6d 65 |.{rt = m|yruntime|
|000033d0| 28 29 3b 0a 20 90 06 67 | 63 5f 73 74 6f 70 5f 61 |();. ..g|c_stop_a|
|000033e0| 6e 64 5f 63 6f 70 79 28 | 29 3b 0a 20 90 06 73 70 |nd_copy(|);. ..sp|
|000033f0| 72 69 6e 74 66 28 74 6b | 62 75 66 66 65 72 2c 0a |rintf(tk|buffer,.|
|00003400| 09 20 90 06 22 47 43 20 | 74 6f 6f 6b 20 25 67 20 |. .."GC |took %g |
|00003410| 73 65 63 6f 6e 64 73 2c | 20 25 6c 64 20 63 6f 6d |seconds,| %ld com|
|00003420| 70 72 65 73 73 65 64 20 | 74 6f 20 25 6c 64 2c 20 |pressed |to %ld, |
|00003430| 25 6c 64 20 66 72 65 65 | 5c 6e 22 2c 0a 09 20 90 |%ld free|\n",.. .|
|00003440| 06 6d 79 72 75 6e 74 69 | 6d 65 28 29 2d 72 74 2c |.myrunti|me()-rt,|
|00003450| 6f 6c 64 5f 68 65 61 70 | 5f 75 73 65 64 2c 68 65 |old_heap|_used,he|
|00003460| 61 70 2d 68 65 61 70 5f | 6f 72 67 2c 68 65 61 70 |ap-heap_|org,heap|
|00003470| 5f 65 6e 64 2d 68 65 61 | 70 29 3b 0a 20 90 06 67 |_end-hea|p);. ..g|
|00003480| 72 65 70 6c 5f 70 75 74 | 73 28 74 6b 62 75 66 66 |repl_put|s(tkbuff|
|00003490| 65 72 29 3b 7d 0a 20 90 | 04 67 72 65 70 6c 5f 70 |er);}. .|.grepl_p|
|000034a0| 75 74 73 28 22 3e 20 22 | 29 3b 0a 20 90 04 69 66 |uts("> "|);. ..if|
|000034b0| 20 28 72 65 70 6c 5f 72 | 65 61 64 20 3d 3d 20 4e | (repl_r|ead == N|
|000034c0| 55 4c 4c 29 20 78 20 3d | 20 6c 72 65 61 64 28 29 |ULL) x =| lread()|
|000034d0| 3b 0a 20 90 04 65 6c 73 | 65 20 78 20 3d 20 28 2a |;. ..els|e x = (*|
|000034e0| 72 65 70 6c 5f 72 65 61 | 64 29 28 29 3b 0a 20 90 |repl_rea|d)();. .|
|000034f0| 04 69 66 20 45 51 28 78 | 2c 65 6f 66 5f 76 61 6c |.if EQ(x|,eof_val|
|00003500| 29 20 62 72 65 61 6b 3b | 0a 20 90 04 72 74 20 3d |) break;|. ..rt =|
|00003510| 20 6d 79 72 75 6e 74 69 | 6d 65 28 29 3b 0a 20 90 | myrunti|me();. .|
|00003520| 04 69 66 20 28 67 63 5f | 6b 69 6e 64 5f 63 6f 70 |.if (gc_|kind_cop|
|00003530| 79 69 6e 67 20 3d 3d 20 | 31 29 0a 20 90 06 63 77 |ying == |1). ..cw|
|00003540| 20 3d 20 68 65 61 70 3b | 0a 20 90 04 65 6c 73 65 | = heap;|. ..else|
|00003550| 0a 20 90 06 7b 67 63 5f | 63 65 6c 6c 73 5f 61 6c |. ..{gc_|cells_al|
|00003560| 6c 6f 63 61 74 65 64 20 | 3d 20 30 3b 0a 20 90 07 |located |= 0;. ..|
|00003570| 67 63 5f 74 69 6d 65 5f | 74 61 6b 65 6e 20 3d 20 |gc_time_|taken = |
|00003580| 30 2e 30 3b 7d 0a 20 90 | 04 69 66 20 28 72 65 70 |0.0;}. .|.if (rep|
|00003590| 6c 5f 65 76 61 6c 20 3d | 3d 20 4e 55 4c 4c 29 20 |l_eval =|= NULL) |
|000035a0| 78 20 3d 20 6c 65 76 61 | 6c 28 78 2c 4e 49 4c 29 |x = leva|l(x,NIL)|
|000035b0| 3b 0a 20 90 04 65 6c 73 | 65 20 78 20 3d 20 28 2a |;. ..els|e x = (*|
|000035c0| 72 65 70 6c 5f 65 76 61 | 6c 29 28 29 3b 0a 20 90 |repl_eva|l)();. .|
|000035d0| 04 69 66 20 28 67 63 5f | 6b 69 6e 64 5f 63 6f 70 |.if (gc_|kind_cop|
|000035e0| 79 69 6e 67 20 3d 3d 20 | 31 29 0a 20 90 06 73 70 |ying == |1). ..sp|
|000035f0| 72 69 6e 74 66 28 74 6b | 62 75 66 66 65 72 2c 0a |rintf(tk|buffer,.|
|00003600| 09 20 90 06 22 45 76 61 | 6c 75 61 74 69 6f 6e 20 |. .."Eva|luation |
|00003610| 74 6f 6f 6b 20 25 67 20 | 73 65 63 6f 6e 64 73 20 |took %g |seconds |
|00003620| 25 6c 64 20 63 6f 6e 73 | 20 77 6f 72 6b 5c 6e 22 |%ld cons| work\n"|
|00003630| 2c 0a 09 20 90 06 6d 79 | 72 75 6e 74 69 6d 65 28 |,.. ..my|runtime(|
|00003640| 29 2d 72 74 2c 0a 09 20 | 90 06 68 65 61 70 2d 63 |)-rt,.. |..heap-c|
|00003650| 77 29 3b 0a 20 90 04 65 | 6c 73 65 0a 20 90 06 73 |w);. ..e|lse. ..s|
|00003660| 70 72 69 6e 74 66 28 74 | 6b 62 75 66 66 65 72 2c |printf(t|kbuffer,|
|00003670| 0a 09 20 90 06 22 45 76 | 61 6c 75 61 74 69 6f 6e |.. .."Ev|aluation|
|00003680| 20 74 6f 6f 6b 20 25 67 | 20 73 65 63 6f 6e 64 73 | took %g| seconds|
|00003690| 20 28 25 67 20 69 6e 20 | 67 63 29 20 25 6c 64 20 | (%g in |gc) %ld |
|000036a0| 63 6f 6e 73 20 77 6f 72 | 6b 5c 6e 22 2c 0a 09 20 |cons wor|k\n",.. |
|000036b0| 90 06 6d 79 72 75 6e 74 | 69 6d 65 28 29 2d 72 74 |..myrunt|ime()-rt|
|000036c0| 2c 0a 09 20 90 06 67 63 | 5f 74 69 6d 65 5f 74 61 |,.. ..gc|_time_ta|
|000036d0| 6b 65 6e 2c 0a 09 20 90 | 06 67 63 5f 63 65 6c 6c |ken,.. .|.gc_cell|
|000036e0| 73 5f 61 6c 6c 6f 63 61 | 74 65 64 29 3b 0a 20 90 |s_alloca|ted);. .|
|000036f0| 04 67 72 65 70 6c 5f 70 | 75 74 73 28 74 6b 62 75 |.grepl_p|uts(tkbu|
|00003700| 66 66 65 72 29 3b 0a 20 | 90 04 69 66 20 28 72 65 |ffer);. |..if (re|
|00003710| 70 6c 5f 70 72 69 6e 74 | 20 3d 3d 20 4e 55 4c 4c |pl_print| == NULL|
|00003720| 29 20 6c 70 72 69 6e 74 | 28 78 29 3b 0a 20 90 04 |) lprint|(x);. ..|
|00003730| 65 6c 73 65 20 28 2a 72 | 65 70 6c 5f 70 72 69 6e |else (*r|epl_prin|
|00003740| 74 29 28 78 29 3b 7d 7d | 0a 0a 65 72 72 28 6d 65 |t)(x);}}|..err(me|
|00003750| 73 73 61 67 65 2c 78 29 | 0a 20 63 68 61 72 20 2a |ssage,x)|. char *|
|00003760| 6d 65 73 73 61 67 65 3b | 20 4c 49 53 50 20 78 3b |message;| LISP x;|
|00003770| 0a 7b 6e 6f 69 6e 74 65 | 72 72 75 70 74 20 3d 20 |.{nointe|rrupt = |
|00003780| 31 3b 0a 20 69 66 20 4e | 4e 55 4c 4c 50 28 78 29 |1;. if N|NULLP(x)|
|00003790| 20 0a 20 90 04 70 72 69 | 6e 74 66 28 22 45 52 52 | . ..pri|ntf("ERR|
|000037a0| 4f 52 3a 20 25 73 20 28 | 73 65 65 20 65 72 72 6f |OR: %s (|see erro|
|000037b0| 62 6a 29 5c 6e 22 2c 6d | 65 73 73 61 67 65 29 3b |bj)\n",m|essage);|
|000037c0| 0a 20 20 65 6c 73 65 20 | 70 72 69 6e 74 66 28 22 |. else |printf("|
|000037d0| 45 52 52 4f 52 3a 20 25 | 73 5c 6e 22 2c 6d 65 73 |ERROR: %|s\n",mes|
|000037e0| 73 61 67 65 29 3b 0a 20 | 69 66 20 28 65 72 72 6a |sage);. |if (errj|
|000037f0| 6d 70 5f 6f 6b 20 3d 3d | 20 31 29 20 7b 73 65 74 |mp_ok ==| 1) {set|
|00003800| 76 61 72 28 73 79 6d 5f | 65 72 72 6f 62 6a 2c 78 |var(sym_|errobj,x|
|00003810| 2c 4e 49 4c 29 3b 20 6c | 6f 6e 67 6a 6d 70 28 65 |,NIL); l|ongjmp(e|
|00003820| 72 72 6a 6d 70 2c 31 29 | 3b 7d 0a 20 70 72 69 6e |rrjmp,1)|;}. prin|
|00003830| 74 66 28 22 46 41 54 41 | 4c 20 45 52 52 4f 52 20 |tf("FATA|L ERROR |
|00003840| 44 55 52 49 4e 47 20 53 | 54 41 52 54 55 50 20 4f |DURING S|TARTUP O|
|00003850| 52 20 43 52 49 54 49 43 | 41 4c 20 43 4f 44 45 20 |R CRITIC|AL CODE |
|00003860| 53 45 43 54 49 4f 4e 5c | 6e 22 29 3b 0a 20 65 78 |SECTION\|n");. ex|
|00003870| 69 74 28 31 29 3b 7d 0a | 90 03 4c 49 53 50 20 6c |it(1);}.|..LISP l|
|00003880| 65 72 72 28 6d 65 73 73 | 61 67 65 2c 78 29 0a 20 |err(mess|age,x). |
|00003890| 90 05 4c 49 53 50 20 6d | 65 73 73 61 67 65 2c 78 |..LISP m|essage,x|
|000038a0| 3b 0a 7b 69 66 20 4e 53 | 59 4d 42 4f 4c 50 28 6d |;.{if NS|YMBOLP(m|
|000038b0| 65 73 73 61 67 65 29 20 | 65 72 72 28 22 61 72 67 |essage) |err("arg|
|000038c0| 75 6d 65 6e 74 20 74 6f | 20 65 72 72 6f 72 20 6e |ument to| error n|
|000038d0| 6f 74 20 61 20 73 79 6d | 62 6f 6c 22 2c 6d 65 73 |ot a sym|bol",mes|
|000038e0| 73 61 67 65 29 3b 0a 20 | 65 72 72 28 50 4e 41 4d |sage);. |err(PNAM|
|000038f0| 45 28 6d 65 73 73 61 67 | 65 29 2c 78 29 3b 0a 20 |E(messag|e),x);. |
|00003900| 72 65 74 75 72 6e 28 4e | 49 4c 29 3b 7d 0a 0a 76 |return(N|IL);}..v|
|00003910| 6f 69 64 20 67 63 5f 66 | 61 74 61 6c 5f 65 72 72 |oid gc_f|atal_err|
|00003920| 6f 72 28 29 0a 7b 65 72 | 72 28 22 72 61 6e 20 6f |or().{er|r("ran o|
|00003930| 75 74 20 6f 66 20 73 74 | 6f 72 61 67 65 22 2c 4e |ut of st|orage",N|
|00003940| 49 4c 29 3b 7d 0a 0a 23 | 64 65 66 69 6e 65 20 4e |IL);}..#|define N|
|00003950| 45 57 43 45 4c 4c 28 5f | 69 6e 74 6f 2c 5f 74 79 |EWCELL(_|into,_ty|
|00003960| 70 65 29 20 90 0a 5c 0a | 7b 69 66 20 28 67 63 5f |pe) ..\.|{if (gc_|
|00003970| 6b 69 6e 64 5f 63 6f 70 | 79 69 6e 67 20 3d 3d 20 |kind_cop|ying == |
|00003980| 31 29 20 90 0c 5c 0a 20 | 90 03 7b 69 66 20 28 28 |1) ..\. |..{if ((|
|00003990| 5f 69 6e 74 6f 20 3d 20 | 68 65 61 70 29 20 3e 3d |_into = |heap) >=|
|000039a0| 20 68 65 61 70 5f 65 6e | 64 29 20 90 03 5c 0a 20 | heap_en|d) ..\. |
|000039b0| 90 06 67 63 5f 66 61 74 | 61 6c 5f 65 72 72 6f 72 |..gc_fat|al_error|
|000039c0| 28 29 3b 20 90 0f 5c 0a | 20 90 04 68 65 61 70 20 |(); ..\.| ..heap |
|000039d0| 3d 20 5f 69 6e 74 6f 2b | 31 3b 7d 20 90 12 5c 0a |= _into+|1;} ..\.|
|000039e0| 20 65 6c 73 65 20 90 21 | 5c 0a 20 90 03 7b 69 66 | else .!|\. ..{if|
|000039f0| 20 4e 55 4c 4c 50 28 66 | 72 65 65 6c 69 73 74 29 | NULLP(f|reelist)|
|00003a00| 20 90 10 5c 0a 20 90 06 | 67 63 5f 66 6f 72 5f 6e | ..\. ..|gc_for_n|
|00003a10| 65 77 63 65 6c 6c 28 29 | 3b 20 90 0f 5c 0a 20 90 |ewcell()|; ..\. .|
|00003a20| 04 5f 69 6e 74 6f 20 3d | 20 66 72 65 65 6c 69 73 |._into =| freelis|
|00003a30| 74 3b 20 90 11 5c 0a 20 | 90 04 66 72 65 65 6c 69 |t; ..\. |..freeli|
|00003a40| 73 74 20 3d 20 43 44 52 | 28 66 72 65 65 6c 69 73 |st = CDR|(freelis|
|00003a50| 74 29 3b 20 90 09 5c 0a | 20 90 04 2b 2b 67 63 5f |t); ..\.| ..++gc_|
|00003a60| 63 65 6c 6c 73 5f 61 6c | 6c 6f 63 61 74 65 64 3b |cells_al|located;|
|00003a70| 7d 20 90 0c 5c 0a 20 28 | 2a 5f 69 6e 74 6f 29 2e |} ..\. (|*_into).|
|00003a80| 67 63 5f 6d 61 72 6b 20 | 3d 20 30 3b 20 90 10 5c |gc_mark |= 0; ..\|
|00003a90| 0a 20 28 2a 5f 69 6e 74 | 6f 29 2e 74 79 70 65 20 |. (*_int|o).type |
|00003aa0| 3d 20 5f 74 79 70 65 3b | 7d 0a 0a 4c 49 53 50 20 |= _type;|}..LISP |
|00003ab0| 6e 65 77 63 65 6c 6c 28 | 74 79 70 65 29 0a 20 90 |newcell(|type). .|
|00003ac0| 05 6c 6f 6e 67 20 74 79 | 70 65 3b 0a 7b 4c 49 53 |.long ty|pe;.{LIS|
|00003ad0| 50 20 7a 3b 0a 20 4e 45 | 57 43 45 4c 4c 28 7a 2c |P z;. NE|WCELL(z,|
|00003ae0| 74 79 70 65 29 3b 0a 20 | 72 65 74 75 72 6e 28 7a |type);. |return(z|
|00003af0| 29 3b 7d 0a 0a 4c 49 53 | 50 20 63 6f 6e 73 28 78 |);}..LIS|P cons(x|
|00003b00| 2c 79 29 0a 20 90 05 4c | 49 53 50 20 78 2c 79 3b |,y). ..L|ISP x,y;|
|00003b10| 0a 7b 4c 49 53 50 20 7a | 3b 0a 20 4e 45 57 43 45 |.{LISP z|;. NEWCE|
|00003b20| 4c 4c 28 7a 2c 74 63 5f | 63 6f 6e 73 29 3b 0a 20 |LL(z,tc_|cons);. |
|00003b30| 43 41 52 28 7a 29 20 3d | 20 78 3b 0a 20 43 44 52 |CAR(z) =| x;. CDR|
|00003b40| 28 7a 29 20 3d 20 79 3b | 0a 20 72 65 74 75 72 6e |(z) = y;|. return|
|00003b50| 28 7a 29 3b 7d 0a 0a 4c | 49 53 50 20 63 6f 6e 73 |(z);}..L|ISP cons|
|00003b60| 70 28 78 29 0a 20 90 05 | 4c 49 53 50 20 78 3b 0a |p(x). ..|LISP x;.|
|00003b70| 7b 69 66 20 43 4f 4e 53 | 50 28 78 29 20 72 65 74 |{if CONS|P(x) ret|
|00003b80| 75 72 6e 28 74 72 75 74 | 68 29 3b 20 65 6c 73 65 |urn(trut|h); else|
|00003b90| 20 72 65 74 75 72 6e 28 | 4e 49 4c 29 3b 7d 0a 0a | return(|NIL);}..|
|00003ba0| 4c 49 53 50 20 63 61 72 | 28 78 29 0a 20 90 05 4c |LISP car|(x). ..L|
|00003bb0| 49 53 50 20 78 3b 0a 7b | 73 77 69 74 63 68 20 54 |ISP x;.{|switch T|
|00003bc0| 59 50 45 28 78 29 0a 20 | 90 03 7b 63 61 73 65 20 |YPE(x). |..{case |
|00003bd0| 74 63 5f 6e 69 6c 3a 0a | 20 90 06 72 65 74 75 72 |tc_nil:.| ..retur|
|00003be0| 6e 28 4e 49 4c 29 3b 0a | 20 90 04 63 61 73 65 20 |n(NIL);.| ..case |
|00003bf0| 74 63 5f 63 6f 6e 73 3a | 0a 20 90 06 72 65 74 75 |tc_cons:|. ..retu|
|00003c00| 72 6e 28 43 41 52 28 78 | 29 29 3b 0a 20 90 04 64 |rn(CAR(x|));. ..d|
|00003c10| 65 66 61 75 6c 74 3a 0a | 20 90 06 65 72 72 28 22 |efault:.| ..err("|
|00003c20| 77 74 61 20 74 6f 20 63 | 61 72 22 2c 78 29 3b 7d |wta to c|ar",x);}|
|00003c30| 7d 0a 0a 4c 49 53 50 20 | 63 64 72 28 78 29 0a 20 |}..LISP |cdr(x). |
|00003c40| 90 05 4c 49 53 50 20 78 | 3b 0a 7b 73 77 69 74 63 |..LISP x|;.{switc|
|00003c50| 68 20 54 59 50 45 28 78 | 29 0a 20 90 03 7b 63 61 |h TYPE(x|). ..{ca|
|00003c60| 73 65 20 74 63 5f 6e 69 | 6c 3a 0a 20 90 06 72 65 |se tc_ni|l:. ..re|
|00003c70| 74 75 72 6e 28 4e 49 4c | 29 3b 0a 20 90 04 63 61 |turn(NIL|);. ..ca|
|00003c80| 73 65 20 74 63 5f 63 6f | 6e 73 3a 0a 20 90 06 72 |se tc_co|ns:. ..r|
|00003c90| 65 74 75 72 6e 28 43 44 | 52 28 78 29 29 3b 0a 20 |eturn(CD|R(x));. |
|00003ca0| 90 04 64 65 66 61 75 6c | 74 3a 0a 20 90 06 65 72 |..defaul|t:. ..er|
|00003cb0| 72 28 22 77 74 61 20 74 | 6f 20 63 64 72 22 2c 78 |r("wta t|o cdr",x|
|00003cc0| 29 3b 7d 7d 0a 90 03 4c | 49 53 50 20 73 65 74 63 |);}}...L|ISP setc|
|00003cd0| 61 72 28 63 65 6c 6c 2c | 76 61 6c 75 65 29 0a 20 |ar(cell,|value). |
|00003ce0| 90 05 4c 49 53 50 20 63 | 65 6c 6c 2c 20 76 61 6c |..LISP c|ell, val|
|00003cf0| 75 65 3b 0a 7b 69 66 20 | 4e 43 4f 4e 53 50 28 63 |ue;.{if |NCONSP(c|
|00003d00| 65 6c 6c 29 20 65 72 72 | 28 22 77 74 61 20 74 6f |ell) err|("wta to|
|00003d10| 20 73 65 74 63 61 72 22 | 2c 63 65 6c 6c 29 3b 0a | setcar"|,cell);.|
|00003d20| 20 72 65 74 75 72 6e 28 | 43 41 52 28 63 65 6c 6c | return(|CAR(cell|
|00003d30| 29 20 3d 20 76 61 6c 75 | 65 29 3b 7d 0a 0a 4c 49 |) = valu|e);}..LI|
|00003d40| 53 50 20 73 65 74 63 64 | 72 28 63 65 6c 6c 2c 76 |SP setcd|r(cell,v|
|00003d50| 61 6c 75 65 29 0a 20 90 | 05 4c 49 53 50 20 63 65 |alue). .|.LISP ce|
|00003d60| 6c 6c 2c 20 76 61 6c 75 | 65 3b 0a 7b 69 66 20 4e |ll, valu|e;.{if N|
|00003d70| 43 4f 4e 53 50 28 63 65 | 6c 6c 29 20 65 72 72 28 |CONSP(ce|ll) err(|
|00003d80| 22 77 74 61 20 74 6f 20 | 73 65 74 63 64 72 22 2c |"wta to |setcdr",|
|00003d90| 63 65 6c 6c 29 3b 0a 20 | 72 65 74 75 72 6e 28 43 |cell);. |return(C|
|00003da0| 44 52 28 63 65 6c 6c 29 | 20 3d 20 76 61 6c 75 65 |DR(cell)| = value|
|00003db0| 29 3b 7d 0a 0a 4c 49 53 | 50 20 66 6c 6f 63 6f 6e |);}..LIS|P flocon|
|00003dc0| 73 28 78 29 0a 20 64 6f | 75 62 6c 65 20 78 3b 0a |s(x). do|uble x;.|
|00003dd0| 7b 4c 49 53 50 20 7a 3b | 0a 20 4e 45 57 43 45 4c |{LISP z;|. NEWCEL|
|00003de0| 4c 28 7a 2c 74 63 5f 66 | 6c 6f 6e 75 6d 29 3b 0a |L(z,tc_f|lonum);.|
|00003df0| 20 46 4c 4f 4e 4d 28 7a | 29 20 3d 20 78 3b 0a 20 | FLONM(z|) = x;. |
|00003e00| 72 65 74 75 72 6e 28 7a | 29 3b 7d 0a 0a 4c 49 53 |return(z|);}..LIS|
|00003e10| 50 20 6e 75 6d 62 65 72 | 70 28 78 29 0a 20 90 05 |P number|p(x). ..|
|00003e20| 4c 49 53 50 20 78 3b 0a | 7b 69 66 20 46 4c 4f 4e |LISP x;.|{if FLON|
|00003e30| 55 4d 50 28 78 29 20 72 | 65 74 75 72 6e 28 74 72 |UMP(x) r|eturn(tr|
|00003e40| 75 74 68 29 3b 20 65 6c | 73 65 20 72 65 74 75 72 |uth); el|se retur|
|00003e50| 6e 28 4e 49 4c 29 3b 7d | 0a 0a 4c 49 53 50 20 70 |n(NIL);}|..LISP p|
|00003e60| 6c 75 73 28 78 2c 79 29 | 0a 20 90 05 4c 49 53 50 |lus(x,y)|. ..LISP|
|00003e70| 20 78 2c 79 3b 0a 7b 4c | 49 53 50 20 7a 3b 0a 20 | x,y;.{L|ISP z;. |
|00003e80| 69 66 20 4e 46 4c 4f 4e | 55 4d 50 28 78 29 20 65 |if NFLON|UMP(x) e|
|00003e90| 72 72 28 22 77 74 61 28 | 31 73 74 29 20 74 6f 20 |rr("wta(|1st) to |
|00003ea0| 70 6c 75 73 22 2c 78 29 | 3b 0a 20 69 66 20 4e 46 |plus",x)|;. if NF|
|00003eb0| 4c 4f 4e 55 4d 50 28 79 | 29 20 65 72 72 28 22 77 |LONUMP(y|) err("w|
|00003ec0| 74 61 28 32 6e 64 29 20 | 74 6f 20 70 6c 75 73 22 |ta(2nd) |to plus"|
|00003ed0| 2c 79 29 3b 0a 20 4e 45 | 57 43 45 4c 4c 28 7a 2c |,y);. NE|WCELL(z,|
|00003ee0| 74 63 5f 66 6c 6f 6e 75 | 6d 29 3b 0a 20 46 4c 4f |tc_flonu|m);. FLO|
|00003ef0| 4e 4d 28 7a 29 20 3d 20 | 46 4c 4f 4e 4d 28 78 29 |NM(z) = |FLONM(x)|
|00003f00| 20 2b 20 46 4c 4f 4e 4d | 28 79 29 3b 0a 20 72 65 | + FLONM|(y);. re|
|00003f10| 74 75 72 6e 28 7a 29 3b | 7d 0a 0a 4c 49 53 50 20 |turn(z);|}..LISP |
|00003f20| 6c 74 69 6d 65 73 28 78 | 2c 79 29 0a 20 4c 49 53 |ltimes(x|,y). LIS|
|00003f30| 50 20 78 2c 79 3b 0a 7b | 4c 49 53 50 20 7a 3b 0a |P x,y;.{|LISP z;.|
|00003f40| 20 69 66 20 4e 46 4c 4f | 4e 55 4d 50 28 78 29 20 | if NFLO|NUMP(x) |
|00003f50| 65 72 72 28 22 77 74 61 | 28 31 73 74 29 20 74 6f |err("wta|(1st) to|
|00003f60| 20 74 69 6d 65 73 22 2c | 78 29 3b 0a 20 69 66 20 | times",|x);. if |
|00003f70| 4e 46 4c 4f 4e 55 4d 50 | 28 79 29 20 65 72 72 28 |NFLONUMP|(y) err(|
|00003f80| 22 77 74 61 28 32 6e 64 | 29 20 74 6f 20 74 69 6d |"wta(2nd|) to tim|
|00003f90| 65 73 22 2c 79 29 3b 0a | 20 4e 45 57 43 45 4c 4c |es",y);.| NEWCELL|
|00003fa0| 28 7a 2c 74 63 5f 66 6c | 6f 6e 75 6d 29 3b 0a 20 |(z,tc_fl|onum);. |
|00003fb0| 46 4c 4f 4e 4d 28 7a 29 | 20 3d 20 46 4c 4f 4e 4d |FLONM(z)| = FLONM|
|00003fc0| 28 78 29 2a 46 4c 4f 4e | 4d 28 79 29 3b 0a 20 72 |(x)*FLON|M(y);. r|
|00003fd0| 65 74 75 72 6e 28 7a 29 | 3b 7d 0a 0a 4c 49 53 50 |eturn(z)|;}..LISP|
|00003fe0| 20 64 69 66 66 65 72 65 | 6e 63 65 28 78 2c 79 29 | differe|nce(x,y)|
|00003ff0| 0a 20 4c 49 53 50 20 78 | 2c 79 3b 0a 7b 4c 49 53 |. LISP x|,y;.{LIS|
|00004000| 50 20 7a 3b 0a 20 69 66 | 20 4e 46 4c 4f 4e 55 4d |P z;. if| NFLONUM|
|00004010| 50 28 78 29 20 65 72 72 | 28 22 77 74 61 28 31 73 |P(x) err|("wta(1s|
|00004020| 74 29 20 74 6f 20 64 69 | 66 66 65 72 65 6e 63 65 |t) to di|fference|
|00004030| 22 2c 78 29 3b 0a 20 69 | 66 20 4e 46 4c 4f 4e 55 |",x);. i|f NFLONU|
|00004040| 4d 50 28 79 29 20 65 72 | 72 28 22 77 74 61 28 32 |MP(y) er|r("wta(2|
|00004050| 6e 64 29 20 74 6f 20 64 | 69 66 66 65 72 65 6e 63 |nd) to d|ifferenc|
|00004060| 65 22 2c 79 29 3b 0a 20 | 4e 45 57 43 45 4c 4c 28 |e",y);. |NEWCELL(|
|00004070| 7a 2c 74 63 5f 66 6c 6f | 6e 75 6d 29 3b 0a 20 46 |z,tc_flo|num);. F|
|00004080| 4c 4f 4e 4d 28 7a 29 20 | 3d 20 46 4c 4f 4e 4d 28 |LONM(z) |= FLONM(|
|00004090| 78 29 20 2d 20 46 4c 4f | 4e 4d 28 79 29 3b 0a 20 |x) - FLO|NM(y);. |
|000040a0| 72 65 74 75 72 6e 28 7a | 29 3b 7d 0a 90 03 4c 49 |return(z|);}...LI|
|000040b0| 53 50 20 71 75 6f 74 69 | 65 6e 74 28 78 2c 79 29 |SP quoti|ent(x,y)|
|000040c0| 0a 20 4c 49 53 50 20 78 | 2c 79 3b 0a 7b 4c 49 53 |. LISP x|,y;.{LIS|
|000040d0| 50 20 7a 3b 0a 20 69 66 | 20 4e 46 4c 4f 4e 55 4d |P z;. if| NFLONUM|
|000040e0| 50 28 78 29 20 65 72 72 | 28 22 77 74 61 28 31 73 |P(x) err|("wta(1s|
|000040f0| 74 29 20 74 6f 20 71 75 | 6f 74 69 65 6e 74 22 2c |t) to qu|otient",|
|00004100| 78 29 3b 0a 20 69 66 20 | 4e 46 4c 4f 4e 55 4d 50 |x);. if |NFLONUMP|
|00004110| 28 79 29 20 65 72 72 28 | 22 77 74 61 28 32 6e 64 |(y) err(|"wta(2nd|
|00004120| 29 20 74 6f 20 71 75 6f | 74 69 65 6e 74 22 2c 79 |) to quo|tient",y|
|00004130| 29 3b 0a 20 4e 45 57 43 | 45 4c 4c 28 7a 2c 74 63 |);. NEWC|ELL(z,tc|
|00004140| 5f 66 6c 6f 6e 75 6d 29 | 3b 0a 20 46 4c 4f 4e 4d |_flonum)|;. FLONM|
|00004150| 28 7a 29 20 3d 20 46 4c | 4f 4e 4d 28 78 29 2f 46 |(z) = FL|ONM(x)/F|
|00004160| 4c 4f 4e 4d 28 79 29 3b | 0a 20 72 65 74 75 72 6e |LONM(y);|. return|
|00004170| 28 7a 29 3b 7d 0a 0a 4c | 49 53 50 20 67 72 65 61 |(z);}..L|ISP grea|
|00004180| 74 65 72 70 28 78 2c 79 | 29 0a 20 4c 49 53 50 20 |terp(x,y|). LISP |
|00004190| 78 2c 79 3b 0a 7b 69 66 | 20 4e 46 4c 4f 4e 55 4d |x,y;.{if| NFLONUM|
|000041a0| 50 28 78 29 20 65 72 72 | 28 22 77 74 61 28 31 73 |P(x) err|("wta(1s|
|000041b0| 74 29 20 74 6f 20 67 72 | 65 61 74 65 72 70 22 2c |t) to gr|eaterp",|
|000041c0| 78 29 3b 0a 20 69 66 20 | 4e 46 4c 4f 4e 55 4d 50 |x);. if |NFLONUMP|
|000041d0| 28 79 29 20 65 72 72 28 | 22 77 74 61 28 32 6e 64 |(y) err(|"wta(2nd|
|000041e0| 29 20 74 6f 20 67 72 65 | 61 74 65 72 70 22 2c 79 |) to gre|aterp",y|
|000041f0| 29 3b 0a 20 69 66 20 28 | 46 4c 4f 4e 4d 28 78 29 |);. if (|FLONM(x)|
|00004200| 3e 46 4c 4f 4e 4d 28 79 | 29 29 20 72 65 74 75 72 |>FLONM(y|)) retur|
|00004210| 6e 28 74 72 75 74 68 29 | 3b 0a 20 72 65 74 75 72 |n(truth)|;. retur|
|00004220| 6e 28 4e 49 4c 29 3b 7d | 0a 0a 4c 49 53 50 20 6c |n(NIL);}|..LISP l|
|00004230| 65 73 73 70 28 78 2c 79 | 29 0a 20 4c 49 53 50 20 |essp(x,y|). LISP |
|00004240| 78 2c 79 3b 0a 7b 69 66 | 20 4e 46 4c 4f 4e 55 4d |x,y;.{if| NFLONUM|
|00004250| 50 28 78 29 20 65 72 72 | 28 22 77 74 61 28 31 73 |P(x) err|("wta(1s|
|00004260| 74 29 20 74 6f 20 6c 65 | 73 73 70 22 2c 78 29 3b |t) to le|ssp",x);|
|00004270| 0a 20 69 66 20 4e 46 4c | 4f 4e 55 4d 50 28 79 29 |. if NFL|ONUMP(y)|
|00004280| 20 65 72 72 28 22 77 74 | 61 28 32 6e 64 29 20 74 | err("wt|a(2nd) t|
|00004290| 6f 20 6c 65 73 73 70 22 | 2c 79 29 3b 0a 20 69 66 |o lessp"|,y);. if|
|000042a0| 20 28 46 4c 4f 4e 4d 28 | 78 29 3c 46 4c 4f 4e 4d | (FLONM(|x)<FLONM|
|000042b0| 28 79 29 29 20 72 65 74 | 75 72 6e 28 74 72 75 74 |(y)) ret|urn(trut|
|000042c0| 68 29 3b 0a 20 72 65 74 | 75 72 6e 28 4e 49 4c 29 |h);. ret|urn(NIL)|
|000042d0| 3b 7d 0a 0a 4c 49 53 50 | 20 65 71 28 78 2c 79 29 |;}..LISP| eq(x,y)|
|000042e0| 0a 20 4c 49 53 50 20 78 | 2c 79 3b 0a 7b 69 66 20 |. LISP x|,y;.{if |
|000042f0| 45 51 28 78 2c 79 29 20 | 72 65 74 75 72 6e 28 74 |EQ(x,y) |return(t|
|00004300| 72 75 74 68 29 3b 20 65 | 6c 73 65 20 72 65 74 75 |ruth); e|lse retu|
|00004310| 72 6e 28 4e 49 4c 29 3b | 7d 0a 0a 4c 49 53 50 20 |rn(NIL);|}..LISP |
|00004320| 65 71 6c 28 78 2c 79 29 | 0a 20 4c 49 53 50 20 78 |eql(x,y)|. LISP x|
|00004330| 2c 79 3b 0a 7b 69 66 20 | 45 51 28 78 2c 79 29 20 |,y;.{if |EQ(x,y) |
|00004340| 72 65 74 75 72 6e 28 74 | 72 75 74 68 29 3b 20 65 |return(t|ruth); e|
|00004350| 6c 73 65 20 0a 20 69 66 | 20 4e 46 4c 4f 4e 55 4d |lse . if| NFLONUM|
|00004360| 50 28 78 29 20 72 65 74 | 75 72 6e 28 4e 49 4c 29 |P(x) ret|urn(NIL)|
|00004370| 3b 20 65 6c 73 65 0a 20 | 69 66 20 4e 46 4c 4f 4e |; else. |if NFLON|
|00004380| 55 4d 50 28 79 29 20 72 | 65 74 75 72 6e 28 4e 49 |UMP(y) r|eturn(NI|
|00004390| 4c 29 3b 20 65 6c 73 65 | 0a 20 69 66 20 28 46 4c |L); else|. if (FL|
|000043a0| 4f 4e 4d 28 78 29 20 3d | 3d 20 46 4c 4f 4e 4d 28 |ONM(x) =|= FLONM(|
|000043b0| 79 29 29 20 72 65 74 75 | 72 6e 28 74 72 75 74 68 |y)) retu|rn(truth|
|000043c0| 29 3b 0a 20 72 65 74 75 | 72 6e 28 4e 49 4c 29 3b |);. retu|rn(NIL);|
|000043d0| 7d 0a 0a 4c 49 53 50 20 | 73 79 6d 63 6f 6e 73 28 |}..LISP |symcons(|
|000043e0| 70 6e 61 6d 65 2c 76 63 | 65 6c 6c 29 0a 20 63 68 |pname,vc|ell). ch|
|000043f0| 61 72 20 2a 70 6e 61 6d | 65 3b 20 4c 49 53 50 20 |ar *pnam|e; LISP |
|00004400| 76 63 65 6c 6c 3b 0a 7b | 4c 49 53 50 20 7a 3b 0a |vcell;.{|LISP z;.|
|00004410| 20 4e 45 57 43 45 4c 4c | 28 7a 2c 74 63 5f 73 79 | NEWCELL|(z,tc_sy|
|00004420| 6d 62 6f 6c 29 3b 0a 20 | 50 4e 41 4d 45 28 7a 29 |mbol);. |PNAME(z)|
|00004430| 20 3d 20 70 6e 61 6d 65 | 3b 0a 20 56 43 45 4c 4c | = pname|;. VCELL|
|00004440| 28 7a 29 20 3d 20 76 63 | 65 6c 6c 3b 0a 20 72 65 |(z) = vc|ell;. re|
|00004450| 74 75 72 6e 28 7a 29 3b | 7d 0a 0a 4c 49 53 50 20 |turn(z);|}..LISP |
|00004460| 73 79 6d 62 6f 6c 70 28 | 78 29 0a 20 90 05 4c 49 |symbolp(|x). ..LI|
|00004470| 53 50 20 78 3b 0a 7b 69 | 66 20 53 59 4d 42 4f 4c |SP x;.{i|f SYMBOL|
|00004480| 50 28 78 29 20 72 65 74 | 75 72 6e 28 74 72 75 74 |P(x) ret|urn(trut|
|00004490| 68 29 3b 20 65 6c 73 65 | 20 72 65 74 75 72 6e 28 |h); else| return(|
|000044a0| 4e 49 4c 29 3b 7d 0a 0a | 4c 49 53 50 20 73 79 6d |NIL);}..|LISP sym|
|000044b0| 62 6f 6c 5f 62 6f 75 6e | 64 70 28 78 2c 65 6e 76 |bol_boun|dp(x,env|
|000044c0| 29 0a 20 4c 49 53 50 20 | 78 2c 65 6e 76 3b 0a 7b |). LISP |x,env;.{|
|000044d0| 4c 49 53 50 20 74 6d 70 | 3b 0a 20 69 66 20 4e 53 |LISP tmp|;. if NS|
|000044e0| 59 4d 42 4f 4c 50 28 78 | 29 20 65 72 72 28 22 6e |YMBOLP(x|) err("n|
|000044f0| 6f 74 20 61 20 73 79 6d | 62 6f 6c 22 2c 78 29 3b |ot a sym|bol",x);|
|00004500| 0a 20 74 6d 70 20 3d 20 | 65 6e 76 6c 6f 6f 6b 75 |. tmp = |envlooku|
|00004510| 70 28 78 2c 65 6e 76 29 | 3b 0a 20 69 66 20 4e 4e |p(x,env)|;. if NN|
|00004520| 55 4c 4c 50 28 74 6d 70 | 29 20 72 65 74 75 72 6e |ULLP(tmp|) return|
|00004530| 28 74 72 75 74 68 29 3b | 0a 20 69 66 20 45 51 28 |(truth);|. if EQ(|
|00004540| 56 43 45 4c 4c 28 78 29 | 2c 75 6e 62 6f 75 6e 64 |VCELL(x)|,unbound|
|00004550| 5f 6d 61 72 6b 65 72 29 | 20 72 65 74 75 72 6e 28 |_marker)| return(|
|00004560| 4e 49 4c 29 3b 20 65 6c | 73 65 20 72 65 74 75 72 |NIL); el|se retur|
|00004570| 6e 28 74 72 75 74 68 29 | 3b 7d 0a 0a 4c 49 53 50 |n(truth)|;}..LISP|
|00004580| 20 73 79 6d 62 6f 6c 5f | 76 61 6c 75 65 28 78 2c | symbol_|value(x,|
|00004590| 65 6e 76 29 0a 20 4c 49 | 53 50 20 78 2c 65 6e 76 |env). LI|SP x,env|
|000045a0| 3b 0a 7b 4c 49 53 50 20 | 74 6d 70 3b 0a 20 69 66 |;.{LISP |tmp;. if|
|000045b0| 20 4e 53 59 4d 42 4f 4c | 50 28 78 29 20 65 72 72 | NSYMBOL|P(x) err|
|000045c0| 28 22 6e 6f 74 20 61 20 | 73 79 6d 62 6f 6c 22 2c |("not a |symbol",|
|000045d0| 78 29 3b 0a 20 74 6d 70 | 20 3d 20 65 6e 76 6c 6f |x);. tmp| = envlo|
|000045e0| 6f 6b 75 70 28 78 2c 65 | 6e 76 29 3b 0a 20 69 66 |okup(x,e|nv);. if|
|000045f0| 20 4e 4e 55 4c 4c 50 28 | 74 6d 70 29 20 72 65 74 | NNULLP(|tmp) ret|
|00004600| 75 72 6e 28 43 41 52 28 | 74 6d 70 29 29 3b 0a 20 |urn(CAR(|tmp));. |
|00004610| 74 6d 70 20 3d 20 56 43 | 45 4c 4c 28 78 29 3b 0a |tmp = VC|ELL(x);.|
|00004620| 20 69 66 20 45 51 28 74 | 6d 70 2c 75 6e 62 6f 75 | if EQ(t|mp,unbou|
|00004630| 6e 64 5f 6d 61 72 6b 65 | 72 29 20 65 72 72 28 22 |nd_marke|r) err("|
|00004640| 75 6e 62 6f 75 6e 64 20 | 76 61 72 69 61 62 6c 65 |unbound |variable|
|00004650| 22 2c 78 29 3b 0a 20 72 | 65 74 75 72 6e 28 74 6d |",x);. r|eturn(tm|
|00004660| 70 29 3b 7d 0a 0a 63 68 | 61 72 20 2a 20 6d 75 73 |p);}..ch|ar * mus|
|00004670| 74 5f 6d 61 6c 6c 6f 63 | 28 73 69 7a 65 29 0a 20 |t_malloc|(size). |
|00004680| 90 05 75 6e 73 69 67 6e | 65 64 20 6c 6f 6e 67 20 |..unsign|ed long |
|00004690| 73 69 7a 65 3b 0a 7b 63 | 68 61 72 20 2a 74 6d 70 |size;.{c|har *tmp|
|000046a0| 3b 0a 20 74 6d 70 20 3d | 20 28 63 68 61 72 20 2a |;. tmp =| (char *|
|000046b0| 29 20 6d 61 6c 6c 6f 63 | 28 73 69 7a 65 29 3b 0a |) malloc|(size);.|
|000046c0| 20 69 66 20 28 74 6d 70 | 20 3d 3d 20 28 63 68 61 | if (tmp| == (cha|
|000046d0| 72 20 2a 29 4e 55 4c 4c | 29 20 65 72 72 28 22 66 |r *)NULL|) err("f|
|000046e0| 61 69 6c 65 64 20 74 6f | 20 61 6c 6c 6f 63 61 74 |ailed to| allocat|
|000046f0| 65 20 73 74 6f 72 61 67 | 65 20 66 72 6f 6d 20 73 |e storag|e from s|
|00004700| 79 73 74 65 6d 22 2c 4e | 49 4c 29 3b 0a 20 72 65 |ystem",N|IL);. re|
|00004710| 74 75 72 6e 28 74 6d 70 | 29 3b 7d 0a 0a 4c 49 53 |turn(tmp|);}..LIS|
|00004720| 50 20 67 65 6e 5f 69 6e | 74 65 72 6e 28 6e 61 6d |P gen_in|tern(nam|
|00004730| 65 2c 63 6f 70 79 70 29 | 0a 20 90 05 63 68 61 72 |e,copyp)|. ..char|
|00004740| 20 2a 6e 61 6d 65 3b 0a | 20 90 05 6c 6f 6e 67 20 | *name;.| ..long |
|00004750| 63 6f 70 79 70 3b 0a 7b | 4c 49 53 50 20 6c 2c 73 |copyp;.{|LISP l,s|
|00004760| 79 6d 2c 73 6c 3b 0a 20 | 63 68 61 72 20 2a 63 6e |ym,sl;. |char *cn|
|00004770| 61 6d 65 3b 0a 20 6c 6f | 6e 67 20 68 61 73 68 2c |ame;. lo|ng hash,|
|00004780| 6e 2c 63 2c 66 6c 61 67 | 3b 0a 20 66 6c 61 67 20 |n,c,flag|;. flag |
|00004790| 3d 20 6e 6f 5f 69 6e 74 | 65 72 72 75 70 74 28 31 |= no_int|errupt(1|
|000047a0| 29 3b 0a 20 69 66 20 28 | 6f 62 61 72 72 61 79 5f |);. if (|obarray_|
|000047b0| 64 69 6d 20 3e 20 31 29 | 0a 20 90 03 7b 68 61 73 |dim > 1)|. ..{has|
|000047c0| 68 20 3d 20 30 3b 0a 20 | 90 04 6e 20 3d 20 6f 62 |h = 0;. |..n = ob|
|000047d0| 61 72 72 61 79 5f 64 69 | 6d 3b 0a 20 90 04 63 6e |array_di|m;. ..cn|
|000047e0| 61 6d 65 20 3d 20 6e 61 | 6d 65 3b 0a 20 90 04 77 |ame = na|me;. ..w|
|000047f0| 68 69 6c 65 28 63 20 3d | 20 2a 63 6e 61 6d 65 2b |hile(c =| *cname+|
|00004800| 2b 29 20 68 61 73 68 20 | 3d 20 28 28 68 61 73 68 |+) hash |= ((hash|
|00004810| 20 2a 20 31 37 29 20 5e | 20 63 29 20 25 20 6e 3b | * 17) ^| c) % n;|
|00004820| 0a 20 90 04 73 6c 20 3d | 20 6f 62 61 72 72 61 79 |. ..sl =| obarray|
|00004830| 5b 68 61 73 68 5d 3b 7d | 0a 20 65 6c 73 65 0a 20 |[hash];}|. else. |
|00004840| 90 03 73 6c 20 3d 20 6f | 62 6c 69 73 74 76 61 72 |..sl = o|blistvar|
|00004850| 3b 0a 20 66 6f 72 28 6c | 3d 73 6c 3b 4e 4e 55 4c |;. for(l|=sl;NNUL|
|00004860| 4c 50 28 6c 29 3b 6c 3d | 43 44 52 28 6c 29 29 0a |LP(l);l=|CDR(l)).|
|00004870| 20 90 03 69 66 20 28 73 | 74 72 63 6d 70 28 6e 61 | ..if (s|trcmp(na|
|00004880| 6d 65 2c 50 4e 41 4d 45 | 28 43 41 52 28 6c 29 90 |me,PNAME|(CAR(l).|
|00004890| 03 20 3d 3d 20 30 29 0a | 20 90 05 7b 6e 6f 5f 69 |. == 0).| ..{no_i|
|000048a0| 6e 74 65 72 72 75 70 74 | 28 66 6c 61 67 29 3b 0a |nterrupt|(flag);.|
|000048b0| 20 90 06 72 65 74 75 72 | 6e 28 43 41 52 28 6c 29 | ..retur|n(CAR(l)|
|000048c0| 29 3b 7d 0a 20 69 66 20 | 28 63 6f 70 79 70 20 3d |);}. if |(copyp =|
|000048d0| 3d 20 31 29 0a 20 90 03 | 7b 63 6e 61 6d 65 20 3d |= 1). ..|{cname =|
|000048e0| 20 6d 75 73 74 5f 6d 61 | 6c 6c 6f 63 28 73 74 72 | must_ma|lloc(str|
|000048f0| 6c 65 6e 28 6e 61 6d 65 | 29 2b 31 29 3b 0a 20 90 |len(name|)+1);. .|
|00004900| 04 73 74 72 63 70 79 28 | 63 6e 61 6d 65 2c 6e 61 |.strcpy(|cname,na|
|00004910| 6d 65 29 3b 7d 0a 20 65 | 6c 73 65 0a 20 90 03 63 |me);}. e|lse. ..c|
|00004920| 6e 61 6d 65 20 3d 20 6e | 61 6d 65 3b 0a 20 73 79 |name = n|ame;. sy|
|00004930| 6d 20 3d 20 73 79 6d 63 | 6f 6e 73 28 63 6e 61 6d |m = symc|ons(cnam|
|00004940| 65 2c 75 6e 62 6f 75 6e | 64 5f 6d 61 72 6b 65 72 |e,unboun|d_marker|
|00004950| 29 3b 0a 20 69 66 20 28 | 6f 62 61 72 72 61 79 5f |);. if (|obarray_|
|00004960| 64 69 6d 20 3e 20 31 29 | 20 6f 62 61 72 72 61 79 |dim > 1)| obarray|
|00004970| 5b 68 61 73 68 5d 20 3d | 20 63 6f 6e 73 28 73 79 |[hash] =| cons(sy|
|00004980| 6d 2c 73 6c 29 3b 0a 20 | 6f 62 6c 69 73 74 76 61 |m,sl);. |oblistva|
|00004990| 72 20 3d 20 63 6f 6e 73 | 28 73 79 6d 2c 6f 62 6c |r = cons|(sym,obl|
|000049a0| 69 73 74 76 61 72 29 3b | 0a 20 6e 6f 5f 69 6e 74 |istvar);|. no_int|
|000049b0| 65 72 72 75 70 74 28 66 | 6c 61 67 29 3b 0a 20 72 |errupt(f|lag);. r|
|000049c0| 65 74 75 72 6e 28 73 79 | 6d 29 3b 7d 0a 0a 4c 49 |eturn(sy|m);}..LI|
|000049d0| 53 50 20 63 69 6e 74 65 | 72 6e 28 6e 61 6d 65 29 |SP cinte|rn(name)|
|000049e0| 0a 20 63 68 61 72 20 2a | 6e 61 6d 65 3b 0a 7b 72 |. char *|name;.{r|
|000049f0| 65 74 75 72 6e 28 67 65 | 6e 5f 69 6e 74 65 72 6e |eturn(ge|n_intern|
|00004a00| 28 6e 61 6d 65 2c 30 29 | 29 3b 7d 0a 0a 4c 49 53 |(name,0)|);}..LIS|
|00004a10| 50 20 72 69 6e 74 65 72 | 6e 28 6e 61 6d 65 29 0a |P rinter|n(name).|
|00004a20| 20 63 68 61 72 20 2a 6e | 61 6d 65 3b 0a 7b 72 65 | char *n|ame;.{re|
|00004a30| 74 75 72 6e 28 67 65 6e | 5f 69 6e 74 65 72 6e 28 |turn(gen|_intern(|
|00004a40| 6e 61 6d 65 2c 31 29 29 | 3b 7d 0a 0a 4c 49 53 50 |name,1))|;}..LISP|
|00004a50| 20 73 75 62 72 63 6f 6e | 73 28 74 79 70 65 2c 6e | subrcon|s(type,n|
|00004a60| 61 6d 65 2c 66 29 0a 20 | 6c 6f 6e 67 20 74 79 70 |ame,f). |long typ|
|00004a70| 65 3b 20 63 68 61 72 20 | 2a 6e 61 6d 65 3b 20 4c |e; char |*name; L|
|00004a80| 49 53 50 20 28 2a 66 29 | 28 29 3b 0a 7b 4c 49 53 |ISP (*f)|();.{LIS|
|00004a90| 50 20 7a 3b 0a 20 4e 45 | 57 43 45 4c 4c 28 7a 2c |P z;. NE|WCELL(z,|
|00004aa0| 74 79 70 65 29 3b 0a 20 | 28 2a 7a 29 2e 73 74 6f |type);. |(*z).sto|
|00004ab0| 72 61 67 65 5f 61 73 2e | 73 75 62 72 2e 6e 61 6d |rage_as.|subr.nam|
|00004ac0| 65 20 3d 20 6e 61 6d 65 | 3b 0a 20 28 2a 7a 29 2e |e = name|;. (*z).|
|00004ad0| 73 74 6f 72 61 67 65 5f | 61 73 2e 73 75 62 72 2e |storage_|as.subr.|
|00004ae0| 66 20 3d 20 66 3b 0a 20 | 72 65 74 75 72 6e 28 7a |f = f;. |return(z|
|00004af0| 29 3b 7d 0a 90 03 4c 49 | 53 50 20 63 6c 6f 73 75 |);}...LI|SP closu|
|00004b00| 72 65 28 65 6e 76 2c 63 | 6f 64 65 29 0a 20 90 05 |re(env,c|ode). ..|
|00004b10| 4c 49 53 50 20 65 6e 76 | 2c 63 6f 64 65 3b 0a 7b |LISP env|,code;.{|
|00004b20| 4c 49 53 50 20 7a 3b 0a | 20 4e 45 57 43 45 4c 4c |LISP z;.| NEWCELL|
|00004b30| 28 7a 2c 74 63 5f 63 6c | 6f 73 75 72 65 29 3b 0a |(z,tc_cl|osure);.|
|00004b40| 20 28 2a 7a 29 2e 73 74 | 6f 72 61 67 65 5f 61 73 | (*z).st|orage_as|
|00004b50| 2e 63 6c 6f 73 75 72 65 | 2e 65 6e 76 20 3d 20 65 |.closure|.env = e|
|00004b60| 6e 76 3b 0a 20 28 2a 7a | 29 2e 73 74 6f 72 61 67 |nv;. (*z|).storag|
|00004b70| 65 5f 61 73 2e 63 6c 6f | 73 75 72 65 2e 63 6f 64 |e_as.clo|sure.cod|
|00004b80| 65 20 3d 20 63 6f 64 65 | 3b 0a 20 72 65 74 75 72 |e = code|;. retur|
|00004b90| 6e 28 7a 29 3b 7d 0a 90 | 03 73 74 72 75 63 74 20 |n(z);}..|.struct |
|00004ba0| 67 63 5f 70 72 6f 74 65 | 63 74 65 64 20 2a 70 72 |gc_prote|cted *pr|
|00004bb0| 6f 74 65 63 74 65 64 5f | 72 65 67 69 73 74 65 72 |otected_|register|
|00004bc0| 73 20 3d 20 4e 55 4c 4c | 3b 0a 0a 76 6f 69 64 20 |s = NULL|;..void |
|00004bd0| 67 63 5f 70 72 6f 74 65 | 63 74 28 6c 6f 63 61 74 |gc_prote|ct(locat|
|00004be0| 69 6f 6e 29 0a 20 90 05 | 4c 49 53 50 20 2a 6c 6f |ion). ..|LISP *lo|
|00004bf0| 63 61 74 69 6f 6e 3b 0a | 7b 67 63 5f 70 72 6f 74 |cation;.|{gc_prot|
|00004c00| 65 63 74 5f 6e 28 6c 6f | 63 61 74 69 6f 6e 2c 31 |ect_n(lo|cation,1|
|00004c10| 29 3b 7d 0a 0a 76 6f 69 | 64 20 67 63 5f 70 72 6f |);}..voi|d gc_pro|
|00004c20| 74 65 63 74 5f 6e 28 6c | 6f 63 61 74 69 6f 6e 2c |tect_n(l|ocation,|
|00004c30| 6e 29 0a 20 90 05 4c 49 | 53 50 20 2a 6c 6f 63 61 |n). ..LI|SP *loca|
|00004c40| 74 69 6f 6e 3b 0a 20 90 | 05 6c 6f 6e 67 20 6e 3b |tion;. .|.long n;|
|00004c50| 0a 7b 73 74 72 75 63 74 | 20 67 63 5f 70 72 6f 74 |.{struct| gc_prot|
|00004c60| 65 63 74 65 64 20 2a 72 | 65 67 3b 0a 20 72 65 67 |ected *r|eg;. reg|
|00004c70| 20 3d 20 28 73 74 72 75 | 63 74 20 67 63 5f 70 72 | = (stru|ct gc_pr|
|00004c80| 6f 74 65 63 74 65 64 20 | 2a 29 20 6d 75 73 74 5f |otected |*) must_|
|00004c90| 6d 61 6c 6c 6f 63 28 73 | 69 7a 65 6f 66 28 73 74 |malloc(s|izeof(st|
|00004ca0| 72 75 63 74 20 67 63 5f | 70 72 6f 74 65 63 74 65 |ruct gc_|protecte|
|00004cb0| 64 29 29 3b 0a 20 28 2a | 72 65 67 29 2e 6c 6f 63 |d));. (*|reg).loc|
|00004cc0| 61 74 69 6f 6e 20 3d 20 | 6c 6f 63 61 74 69 6f 6e |ation = |location|
|00004cd0| 3b 0a 20 28 2a 72 65 67 | 29 2e 6c 65 6e 67 74 68 |;. (*reg|).length|
|00004ce0| 20 3d 20 6e 3b 0a 20 28 | 2a 72 65 67 29 2e 6e 65 | = n;. (|*reg).ne|
|00004cf0| 78 74 20 3d 20 70 72 6f | 74 65 63 74 65 64 5f 72 |xt = pro|tected_r|
|00004d00| 65 67 69 73 74 65 72 73 | 3b 0a 20 20 70 72 6f 74 |egisters|;. prot|
|00004d10| 65 63 74 65 64 5f 72 65 | 67 69 73 74 65 72 73 20 |ected_re|gisters |
|00004d20| 3d 20 72 65 67 3b 7d 0a | 0a 76 6f 69 64 20 67 63 |= reg;}.|.void gc|
|00004d30| 5f 70 72 6f 74 65 63 74 | 5f 73 79 6d 28 6c 6f 63 |_protect|_sym(loc|
|00004d40| 61 74 69 6f 6e 2c 73 74 | 29 0a 20 90 05 4c 49 53 |ation,st|). ..LIS|
|00004d50| 50 20 2a 6c 6f 63 61 74 | 69 6f 6e 3b 0a 20 90 05 |P *locat|ion;. ..|
|00004d60| 63 68 61 72 20 2a 73 74 | 3b 0a 7b 2a 6c 6f 63 61 |char *st|;.{*loca|
|00004d70| 74 69 6f 6e 20 3d 20 63 | 69 6e 74 65 72 6e 28 73 |tion = c|intern(s|
|00004d80| 74 29 3b 0a 20 67 63 5f | 70 72 6f 74 65 63 74 28 |t);. gc_|protect(|
|00004d90| 6c 6f 63 61 74 69 6f 6e | 29 3b 7d 0a 0a 73 63 61 |location|);}..sca|
|00004da0| 6e 5f 72 65 67 69 73 74 | 65 72 73 28 29 0a 7b 73 |n_regist|ers().{s|
|00004db0| 74 72 75 63 74 20 67 63 | 5f 70 72 6f 74 65 63 74 |truct gc|_protect|
|00004dc0| 65 64 20 2a 72 65 67 3b | 0a 20 4c 49 53 50 20 2a |ed *reg;|. LISP *|
|00004dd0| 6c 6f 63 61 74 69 6f 6e | 3b 0a 20 6c 6f 6e 67 20 |location|;. long |
|00004de0| 6a 2c 6e 3b 0a 20 66 6f | 72 28 72 65 67 20 3d 20 |j,n;. fo|r(reg = |
|00004df0| 70 72 6f 74 65 63 74 65 | 64 5f 72 65 67 69 73 74 |protecte|d_regist|
|00004e00| 65 72 73 3b 20 72 65 67 | 3b 20 72 65 67 20 3d 20 |ers; reg|; reg = |
|00004e10| 28 2a 72 65 67 29 2e 6e | 65 78 74 29 0a 20 90 03 |(*reg).n|ext). ..|
|00004e20| 7b 6c 6f 63 61 74 69 6f | 6e 20 3d 20 28 2a 72 65 |{locatio|n = (*re|
|00004e30| 67 29 2e 6c 6f 63 61 74 | 69 6f 6e 3b 0a 20 90 04 |g).locat|ion;. ..|
|00004e40| 6e 20 3d 20 28 2a 72 65 | 67 29 2e 6c 65 6e 67 74 |n = (*re|g).lengt|
|00004e50| 68 3b 0a 20 90 04 66 6f | 72 28 6a 3d 30 3b 6a 3c |h;. ..fo|r(j=0;j<|
|00004e60| 6e 3b 2b 2b 6a 29 0a 20 | 90 06 6c 6f 63 61 74 69 |n;++j). |..locati|
|00004e70| 6f 6e 5b 6a 5d 20 3d 20 | 67 63 5f 72 65 6c 6f 63 |on[j] = |gc_reloc|
|00004e80| 61 74 65 28 6c 6f 63 61 | 74 69 6f 6e 5b 6a 5d 29 |ate(loca|tion[j])|
|00004e90| 3b 7d 7d 0a 0a 69 6e 69 | 74 5f 73 74 6f 72 61 67 |;}}..ini|t_storag|
|00004ea0| 65 28 29 0a 7b 4c 49 53 | 50 20 70 74 72 2c 6e 65 |e().{LIS|P ptr,ne|
|00004eb0| 78 74 2c 65 6e 64 3b 0a | 20 6c 6f 6e 67 20 6a 3b |xt,end;.| long j;|
|00004ec0| 0a 20 68 65 61 70 5f 31 | 20 3d 20 28 4c 49 53 50 |. heap_1| = (LISP|
|00004ed0| 29 20 6d 75 73 74 5f 6d | 61 6c 6c 6f 63 28 73 69 |) must_m|alloc(si|
|00004ee0| 7a 65 6f 66 28 73 74 72 | 75 63 74 20 6f 62 6a 29 |zeof(str|uct obj)|
|00004ef0| 2a 68 65 61 70 5f 73 69 | 7a 65 29 3b 0a 20 68 65 |*heap_si|ze);. he|
|00004f00| 61 70 20 3d 20 68 65 61 | 70 5f 31 3b 0a 20 77 68 |ap = hea|p_1;. wh|
|00004f10| 69 63 68 5f 68 65 61 70 | 20 3d 20 31 3b 0a 20 68 |ich_heap| = 1;. h|
|00004f20| 65 61 70 5f 6f 72 67 20 | 3d 20 68 65 61 70 3b 0a |eap_org |= heap;.|
|00004f30| 20 68 65 61 70 5f 65 6e | 64 20 3d 20 68 65 61 70 | heap_en|d = heap|
|00004f40| 20 2b 20 68 65 61 70 5f | 73 69 7a 65 3b 0a 20 69 | + heap_|size;. i|
|00004f50| 66 20 28 67 63 5f 6b 69 | 6e 64 5f 63 6f 70 79 69 |f (gc_ki|nd_copyi|
|00004f60| 6e 67 20 3d 3d 20 31 29 | 0a 20 90 03 68 65 61 70 |ng == 1)|. ..heap|
|00004f70| 5f 32 20 3d 20 28 4c 49 | 53 50 29 20 6d 75 73 74 |_2 = (LI|SP) must|
|00004f80| 5f 6d 61 6c 6c 6f 63 28 | 73 69 7a 65 6f 66 28 73 |_malloc(|sizeof(s|
|00004f90| 74 72 75 63 74 20 6f 62 | 6a 29 2a 68 65 61 70 5f |truct ob|j)*heap_|
|00004fa0| 73 69 7a 65 29 3b 0a 20 | 65 6c 73 65 0a 20 90 03 |size);. |else. ..|
|00004fb0| 7b 70 74 72 20 3d 20 68 | 65 61 70 5f 6f 72 67 3b |{ptr = h|eap_org;|
|00004fc0| 0a 20 90 04 65 6e 64 20 | 3d 20 68 65 61 70 5f 65 |. ..end |= heap_e|
|00004fd0| 6e 64 3b 0a 20 90 04 77 | 68 69 6c 65 28 31 29 0a |nd;. ..w|hile(1).|
|00004fe0| 20 90 06 7b 28 2a 70 74 | 72 29 2e 74 79 70 65 20 | ..{(*pt|r).type |
|00004ff0| 3d 20 74 63 5f 66 72 65 | 65 5f 63 65 6c 6c 3b 0a |= tc_fre|e_cell;.|
|00005000| 20 90 07 6e 65 78 74 20 | 3d 20 70 74 72 20 2b 20 | ..next |= ptr + |
|00005010| 31 3b 0a 20 90 07 69 66 | 20 28 6e 65 78 74 20 3c |1;. ..if| (next <|
|00005020| 20 65 6e 64 29 0a 09 20 | 7b 43 44 52 28 70 74 72 | end).. |{CDR(ptr|
|00005030| 29 20 3d 20 6e 65 78 74 | 3b 0a 09 20 20 70 74 72 |) = next|;.. ptr|
|00005040| 20 3d 20 6e 65 78 74 3b | 7d 0a 20 90 07 65 6c 73 | = next;|}. ..els|
|00005050| 65 0a 09 20 7b 43 44 52 | 28 70 74 72 29 20 3d 20 |e.. {CDR|(ptr) = |
|00005060| 4e 49 4c 3b 0a 09 20 20 | 62 72 65 61 6b 3b 7d 7d |NIL;.. |break;}}|
|00005070| 0a 20 90 04 66 72 65 65 | 6c 69 73 74 20 3d 20 68 |. ..free|list = h|
|00005080| 65 61 70 5f 6f 72 67 3b | 7d 0a 20 67 63 5f 70 72 |eap_org;|}. gc_pr|
|00005090| 6f 74 65 63 74 28 26 6f | 62 6c 69 73 74 76 61 72 |otect(&o|blistvar|
|000050a0| 29 3b 0a 20 69 66 20 28 | 6f 62 61 72 72 61 79 5f |);. if (|obarray_|
|000050b0| 64 69 6d 20 3e 20 31 29 | 0a 20 90 03 7b 6f 62 61 |dim > 1)|. ..{oba|
|000050c0| 72 72 61 79 20 3d 20 28 | 4c 49 53 50 20 2a 29 20 |rray = (|LISP *) |
|000050d0| 6d 75 73 74 5f 6d 61 6c | 6c 6f 63 28 73 69 7a 65 |must_mal|loc(size|
|000050e0| 6f 66 28 4c 49 53 50 29 | 20 2a 20 6f 62 61 72 72 |of(LISP)| * obarr|
|000050f0| 61 79 5f 64 69 6d 29 3b | 0a 20 90 04 66 6f 72 28 |ay_dim);|. ..for(|
|00005100| 6a 3d 30 3b 6a 3c 6f 62 | 61 72 72 61 79 5f 64 69 |j=0;j<ob|array_di|
|00005110| 6d 3b 2b 2b 6a 29 0a 20 | 90 06 6f 62 61 72 72 61 |m;++j). |..obarra|
|00005120| 79 5b 6a 5d 20 3d 20 4e | 49 4c 3b 0a 20 90 04 67 |y[j] = N|IL;. ..g|
|00005130| 63 5f 70 72 6f 74 65 63 | 74 5f 6e 28 6f 62 61 72 |c_protec|t_n(obar|
|00005140| 72 61 79 2c 6f 62 61 72 | 72 61 79 5f 64 69 6d 29 |ray,obar|ray_dim)|
|00005150| 3b 7d 0a 20 75 6e 62 6f | 75 6e 64 5f 6d 61 72 6b |;}. unbo|und_mark|
|00005160| 65 72 20 3d 20 63 6f 6e | 73 28 63 69 6e 74 65 72 |er = con|s(cinter|
|00005170| 6e 28 22 2a 2a 75 6e 62 | 6f 75 6e 64 2d 6d 61 72 |n("**unb|ound-mar|
|00005180| 6b 65 72 2a 2a 22 29 2c | 4e 49 4c 29 3b 0a 20 67 |ker**"),|NIL);. g|
|00005190| 63 5f 70 72 6f 74 65 63 | 74 28 26 75 6e 62 6f 75 |c_protec|t(&unbou|
|000051a0| 6e 64 5f 6d 61 72 6b 65 | 72 29 3b 0a 20 65 6f 66 |nd_marke|r);. eof|
|000051b0| 5f 76 61 6c 20 3d 20 63 | 6f 6e 73 28 63 69 6e 74 |_val = c|ons(cint|
|000051c0| 65 72 6e 28 22 65 6f 66 | 22 29 2c 4e 49 4c 29 3b |ern("eof|"),NIL);|
|000051d0| 0a 20 67 63 5f 70 72 6f | 74 65 63 74 28 26 65 6f |. gc_pro|tect(&eo|
|000051e0| 66 5f 76 61 6c 29 3b 0a | 20 67 63 5f 70 72 6f 74 |f_val);.| gc_prot|
|000051f0| 65 63 74 5f 73 79 6d 28 | 26 74 72 75 74 68 2c 22 |ect_sym(|&truth,"|
|00005200| 74 22 29 3b 0a 20 73 65 | 74 76 61 72 28 74 72 75 |t");. se|tvar(tru|
|00005210| 74 68 2c 74 72 75 74 68 | 2c 4e 49 4c 29 3b 0a 20 |th,truth|,NIL);. |
|00005220| 73 65 74 76 61 72 28 63 | 69 6e 74 65 72 6e 28 22 |setvar(c|intern("|
|00005230| 6e 69 6c 22 29 2c 4e 49 | 4c 2c 4e 49 4c 29 3b 0a |nil"),NI|L,NIL);.|
|00005240| 20 73 65 74 76 61 72 28 | 63 69 6e 74 65 72 6e 28 | setvar(|cintern(|
|00005250| 22 6c 65 74 22 29 2c 63 | 69 6e 74 65 72 6e 28 22 |"let"),c|intern("|
|00005260| 6c 65 74 2d 69 6e 74 65 | 72 6e 61 6c 2d 6d 61 63 |let-inte|rnal-mac|
|00005270| 72 6f 22 29 2c 4e 49 4c | 29 3b 0a 20 67 63 5f 70 |ro"),NIL|);. gc_p|
|00005280| 72 6f 74 65 63 74 5f 73 | 79 6d 28 26 73 79 6d 5f |rotect_s|ym(&sym_|
|00005290| 65 72 72 6f 62 6a 2c 22 | 65 72 72 6f 62 6a 22 29 |errobj,"|errobj")|
|000052a0| 3b 0a 20 73 65 74 76 61 | 72 28 73 79 6d 5f 65 72 |;. setva|r(sym_er|
|000052b0| 72 6f 62 6a 2c 4e 49 4c | 2c 4e 49 4c 29 3b 0a 20 |robj,NIL|,NIL);. |
|000052c0| 67 63 5f 70 72 6f 74 65 | 63 74 5f 73 79 6d 28 26 |gc_prote|ct_sym(&|
|000052d0| 73 79 6d 5f 70 72 6f 67 | 6e 2c 22 62 65 67 69 6e |sym_prog|n,"begin|
|000052e0| 22 29 3b 0a 20 67 63 5f | 70 72 6f 74 65 63 74 5f |");. gc_|protect_|
|000052f0| 73 79 6d 28 26 73 79 6d | 5f 6c 61 6d 62 64 61 2c |sym(&sym|_lambda,|
|00005300| 22 6c 61 6d 62 64 61 22 | 29 3b 0a 20 67 63 5f 70 |"lambda"|);. gc_p|
|00005310| 72 6f 74 65 63 74 5f 73 | 79 6d 28 26 73 79 6d 5f |rotect_s|ym(&sym_|
|00005320| 71 75 6f 74 65 2c 22 71 | 75 6f 74 65 22 29 3b 0a |quote,"q|uote");.|
|00005330| 20 67 63 5f 70 72 6f 74 | 65 63 74 5f 73 79 6d 28 | gc_prot|ect_sym(|
|00005340| 26 73 79 6d 5f 64 6f 74 | 2c 22 2e 22 29 3b 0a 20 |&sym_dot|,".");. |
|00005350| 67 63 5f 70 72 6f 74 65 | 63 74 28 26 6f 70 65 6e |gc_prote|ct(&open|
|00005360| 5f 66 69 6c 65 73 29 3b | 7d 0a 20 0a 76 6f 69 64 |_files);|}. .void|
|00005370| 20 69 6e 69 74 5f 73 75 | 62 72 28 6e 61 6d 65 2c | init_su|br(name,|
|00005380| 74 79 70 65 2c 66 63 6e | 29 0a 20 63 68 61 72 20 |type,fcn|). char |
|00005390| 2a 6e 61 6d 65 3b 20 6c | 6f 6e 67 20 74 79 70 65 |*name; l|ong type|
|000053a0| 3b 20 4c 49 53 50 20 28 | 2a 66 63 6e 29 28 29 3b |; LISP (|*fcn)();|
|000053b0| 0a 7b 73 65 74 76 61 72 | 28 63 69 6e 74 65 72 6e |.{setvar|(cintern|
|000053c0| 28 6e 61 6d 65 29 2c 73 | 75 62 72 63 6f 6e 73 28 |(name),s|ubrcons(|
|000053d0| 74 79 70 65 2c 6e 61 6d | 65 2c 66 63 6e 29 2c 4e |type,nam|e,fcn),N|
|000053e0| 49 4c 29 3b 7d 0a 0a 4c | 49 53 50 20 61 73 73 71 |IL);}..L|ISP assq|
|000053f0| 28 78 2c 61 6c 69 73 74 | 29 0a 20 90 05 4c 49 53 |(x,alist|). ..LIS|
|00005400| 50 20 78 2c 61 6c 69 73 | 74 3b 0a 7b 4c 49 53 50 |P x,alis|t;.{LISP|
|00005410| 20 6c 2c 74 6d 70 3b 0a | 20 66 6f 72 28 6c 3d 61 | l,tmp;.| for(l=a|
|00005420| 6c 69 73 74 3b 43 4f 4e | 53 50 28 6c 29 3b 6c 3d |list;CON|SP(l);l=|
|00005430| 43 44 52 28 6c 29 29 0a | 20 90 03 7b 74 6d 70 20 |CDR(l)).| ..{tmp |
|00005440| 3d 20 43 41 52 28 6c 29 | 3b 0a 20 90 04 69 66 20 |= CAR(l)|;. ..if |
|00005450| 28 43 4f 4e 53 50 28 74 | 6d 70 29 20 26 26 20 45 |(CONSP(t|mp) && E|
|00005460| 51 28 43 41 52 28 74 6d | 70 29 2c 78 29 29 20 72 |Q(CAR(tm|p),x)) r|
|00005470| 65 74 75 72 6e 28 74 6d | 70 29 3b 7d 0a 20 69 66 |eturn(tm|p);}. if|
|00005480| 20 45 51 28 6c 2c 4e 49 | 4c 29 20 72 65 74 75 72 | EQ(l,NI|L) retur|
|00005490| 6e 28 4e 49 4c 29 3b 0a | 20 65 72 72 28 22 69 6d |n(NIL);.| err("im|
|000054a0| 70 72 6f 70 65 72 20 6c | 69 73 74 20 74 6f 20 61 |proper l|ist to a|
|000054b0| 73 73 71 22 2c 61 6c 69 | 73 74 29 3b 7d 0a 0a 4c |ssq",ali|st);}..L|
|000054c0| 49 53 50 20 28 2a 75 73 | 65 72 5f 67 63 5f 72 65 |ISP (*us|er_gc_re|
|000054d0| 6c 6f 63 61 74 65 29 28 | 29 20 3d 20 4e 55 4c 4c |locate)(|) = NULL|
|000054e0| 3b 0a 76 6f 69 64 20 28 | 2a 75 73 65 72 5f 67 63 |;.void (|*user_gc|
|000054f0| 5f 73 63 61 6e 29 28 29 | 20 3d 20 4e 55 4c 4c 3b |_scan)()| = NULL;|
|00005500| 0a 4c 49 53 50 20 28 2a | 75 73 65 72 5f 67 63 5f |.LISP (*|user_gc_|
|00005510| 6d 61 72 6b 29 28 29 20 | 3d 20 4e 55 4c 4c 3b 0a |mark)() |= NULL;.|
|00005520| 76 6f 69 64 20 28 2a 75 | 73 65 72 5f 67 63 5f 66 |void (*u|ser_gc_f|
|00005530| 72 65 65 29 28 29 20 3d | 20 4e 55 4c 4c 3b 0a 0a |ree)() =| NULL;..|
|00005540| 76 6f 69 64 20 73 65 74 | 5f 67 63 5f 68 6f 6f 6b |void set|_gc_hook|
|00005550| 73 28 72 65 6c 2c 73 63 | 61 6e 2c 6d 61 72 6b 2c |s(rel,sc|an,mark,|
|00005560| 66 72 65 65 2c 6b 69 6e | 64 29 0a 20 90 05 4c 49 |free,kin|d). ..LI|
|00005570| 53 50 20 28 2a 72 65 6c | 29 28 29 2c 28 2a 6d 61 |SP (*rel|)(),(*ma|
|00005580| 72 6b 29 28 29 3b 0a 20 | 90 05 76 6f 69 64 20 28 |rk)();. |..void (|
|00005590| 2a 73 63 61 6e 29 28 29 | 2c 28 2a 66 72 65 65 29 |*scan)()|,(*free)|
|000055a0| 28 29 3b 0a 20 90 05 6c | 6f 6e 67 20 2a 6b 69 6e |();. ..l|ong *kin|
|000055b0| 64 3b 0a 7b 75 73 65 72 | 5f 67 63 5f 72 65 6c 6f |d;.{user|_gc_relo|
|000055c0| 63 61 74 65 20 3d 20 72 | 65 6c 3b 0a 20 75 73 65 |cate = r|el;. use|
|000055d0| 72 5f 67 63 5f 73 63 61 | 6e 20 3d 20 73 63 61 6e |r_gc_sca|n = scan|
|000055e0| 3b 0a 20 75 73 65 72 5f | 67 63 5f 6d 61 72 6b 20 |;. user_|gc_mark |
|000055f0| 3d 20 6d 61 72 6b 3b 0a | 20 75 73 65 72 5f 67 63 |= mark;.| user_gc|
|00005600| 5f 66 72 65 65 20 3d 20 | 66 72 65 65 3b 0a 20 2a |_free = |free;. *|
|00005610| 6b 69 6e 64 20 3d 20 67 | 63 5f 6b 69 6e 64 5f 63 |kind = g|c_kind_c|
|00005620| 6f 70 79 69 6e 67 3b 7d | 0a 0a 4c 49 53 50 20 67 |opying;}|..LISP g|
|00005630| 63 5f 72 65 6c 6f 63 61 | 74 65 28 78 29 0a 20 90 |c_reloca|te(x). .|
|00005640| 05 4c 49 53 50 20 78 3b | 0a 7b 4c 49 53 50 20 6e |.LISP x;|.{LISP n|
|00005650| 65 77 3b 0a 20 69 66 20 | 45 51 28 78 2c 4e 49 4c |ew;. if |EQ(x,NIL|
|00005660| 29 20 72 65 74 75 72 6e | 28 4e 49 4c 29 3b 0a 20 |) return|(NIL);. |
|00005670| 69 66 20 28 28 2a 78 29 | 2e 67 63 5f 6d 61 72 6b |if ((*x)|.gc_mark|
|00005680| 20 3d 3d 20 31 29 20 72 | 65 74 75 72 6e 28 43 41 | == 1) r|eturn(CA|
|00005690| 52 28 78 29 29 3b 0a 20 | 73 77 69 74 63 68 20 54 |R(x));. |switch T|
|000056a0| 59 50 45 28 78 29 0a 20 | 90 03 7b 63 61 73 65 20 |YPE(x). |..{case |
|000056b0| 74 63 5f 66 6c 6f 6e 75 | 6d 3a 0a 20 90 04 63 61 |tc_flonu|m:. ..ca|
|000056c0| 73 65 20 74 63 5f 63 6f | 6e 73 3a 0a 20 90 04 63 |se tc_co|ns:. ..c|
|000056d0| 61 73 65 20 74 63 5f 73 | 79 6d 62 6f 6c 3a 0a 20 |ase tc_s|ymbol:. |
|000056e0| 90 04 63 61 73 65 20 74 | 63 5f 63 6c 6f 73 75 72 |..case t|c_closur|
|000056f0| 65 3a 0a 20 90 04 63 61 | 73 65 20 74 63 5f 73 75 |e:. ..ca|se tc_su|
|00005700| 62 72 5f 30 3a 0a 20 90 | 04 63 61 73 65 20 74 63 |br_0:. .|.case tc|
|00005710| 5f 73 75 62 72 5f 31 3a | 0a 20 90 04 63 61 73 65 |_subr_1:|. ..case|
|00005720| 20 74 63 5f 73 75 62 72 | 5f 32 3a 0a 20 90 04 63 | tc_subr|_2:. ..c|
|00005730| 61 73 65 20 74 63 5f 73 | 75 62 72 5f 33 3a 0a 20 |ase tc_s|ubr_3:. |
|00005740| 90 04 63 61 73 65 20 74 | 63 5f 6c 73 75 62 72 3a |..case t|c_lsubr:|
|00005750| 0a 20 90 04 63 61 73 65 | 20 74 63 5f 66 73 75 62 |. ..case| tc_fsub|
|00005760| 72 3a 0a 20 90 04 63 61 | 73 65 20 74 63 5f 6d 73 |r:. ..ca|se tc_ms|
|00005770| 75 62 72 3a 0a 20 90 06 | 69 66 20 28 28 6e 65 77 |ubr:. ..|if ((new|
|00005780| 20 3d 20 68 65 61 70 29 | 20 3e 3d 20 68 65 61 70 | = heap)| >= heap|
|00005790| 5f 65 6e 64 29 20 67 63 | 5f 66 61 74 61 6c 5f 65 |_end) gc|_fatal_e|
|000057a0| 72 72 6f 72 28 29 3b 0a | 20 90 06 68 65 61 70 20 |rror();.| ..heap |
|000057b0| 3d 20 6e 65 77 2b 31 3b | 0a 20 90 06 6d 65 6d 63 |= new+1;|. ..memc|
|000057c0| 70 79 28 6e 65 77 2c 78 | 2c 73 69 7a 65 6f 66 28 |py(new,x|,sizeof(|
|000057d0| 73 74 72 75 63 74 20 6f | 62 6a 29 29 3b 0a 20 90 |struct o|bj));. .|
|000057e0| 06 62 72 65 61 6b 3b 0a | 20 90 04 63 61 73 65 20 |.break;.| ..case |
|000057f0| 74 63 5f 75 73 65 72 5f | 31 3a 0a 20 90 04 63 61 |tc_user_|1:. ..ca|
|00005800| 73 65 20 74 63 5f 75 73 | 65 72 5f 32 3a 0a 20 90 |se tc_us|er_2:. .|
|00005810| 04 63 61 73 65 20 74 63 | 5f 75 73 65 72 5f 33 3a |.case tc|_user_3:|
|00005820| 0a 20 90 04 63 61 73 65 | 20 74 63 5f 75 73 65 72 |. ..case| tc_user|
|00005830| 5f 34 3a 0a 20 90 04 63 | 61 73 65 20 74 63 5f 75 |_4:. ..c|ase tc_u|
|00005840| 73 65 72 5f 35 3a 0a 20 | 90 06 69 66 20 28 75 73 |ser_5:. |..if (us|
|00005850| 65 72 5f 67 63 5f 72 65 | 6c 6f 63 61 74 65 20 21 |er_gc_re|locate !|
|00005860| 3d 20 4e 55 4c 4c 29 0a | 09 7b 6e 65 77 20 3d 20 |= NULL).|.{new = |
|00005870| 28 2a 75 73 65 72 5f 67 | 63 5f 72 65 6c 6f 63 61 |(*user_g|c_reloca|
|00005880| 74 65 29 28 78 29 3b 0a | 09 20 62 72 65 61 6b 3b |te)(x);.|. break;|
|00005890| 7d 0a 20 90 04 64 65 66 | 61 75 6c 74 3a 20 65 72 |}. ..def|ault: er|
|000058a0| 72 28 22 42 55 47 20 49 | 4e 20 47 41 52 42 41 47 |r("BUG I|N GARBAG|
|000058b0| 45 20 43 4f 4c 4c 45 43 | 54 4f 52 20 67 63 5f 72 |E COLLEC|TOR gc_r|
|000058c0| 65 6c 6f 63 61 74 65 22 | 2c 4e 49 4c 29 3b 7d 0a |elocate"|,NIL);}.|
|000058d0| 20 28 2a 78 29 2e 67 63 | 5f 6d 61 72 6b 20 3d 20 | (*x).gc|_mark = |
|000058e0| 31 3b 0a 20 43 41 52 28 | 78 29 20 3d 20 6e 65 77 |1;. CAR(|x) = new|
|000058f0| 3b 0a 20 72 65 74 75 72 | 6e 28 6e 65 77 29 3b 7d |;. retur|n(new);}|
|00005900| 0a 0a 4c 49 53 50 20 67 | 65 74 5f 6e 65 77 73 70 |..LISP g|et_newsp|
|00005910| 61 63 65 28 29 0a 7b 4c | 49 53 50 20 6e 65 77 73 |ace().{L|ISP news|
|00005920| 70 61 63 65 3b 0a 20 69 | 66 20 28 77 68 69 63 68 |pace;. i|f (which|
|00005930| 5f 68 65 61 70 20 3d 3d | 20 31 29 0a 20 90 03 7b |_heap ==| 1). ..{|
|00005940| 6e 65 77 73 70 61 63 65 | 20 3d 20 68 65 61 70 5f |newspace| = heap_|
|00005950| 32 3b 0a 20 90 04 77 68 | 69 63 68 5f 68 65 61 70 |2;. ..wh|ich_heap|
|00005960| 20 3d 20 32 3b 7d 0a 20 | 65 6c 73 65 0a 20 90 03 | = 2;}. |else. ..|
|00005970| 7b 6e 65 77 73 70 61 63 | 65 20 3d 20 68 65 61 70 |{newspac|e = heap|
|00005980| 5f 31 3b 0a 20 90 04 77 | 68 69 63 68 5f 68 65 61 |_1;. ..w|hich_hea|
|00005990| 70 20 3d 20 31 3b 7d 0a | 20 68 65 61 70 20 3d 20 |p = 1;}.| heap = |
|000059a0| 6e 65 77 73 70 61 63 65 | 3b 0a 20 68 65 61 70 5f |newspace|;. heap_|
|000059b0| 6f 72 67 20 3d 20 68 65 | 61 70 3b 0a 20 68 65 61 |org = he|ap;. hea|
|000059c0| 70 5f 65 6e 64 20 3d 20 | 68 65 61 70 20 2b 20 68 |p_end = |heap + h|
|000059d0| 65 61 70 5f 73 69 7a 65 | 3b 0a 20 72 65 74 75 72 |eap_size|;. retur|
|000059e0| 6e 28 6e 65 77 73 70 61 | 63 65 29 3b 7d 0a 0a 73 |n(newspa|ce);}..s|
|000059f0| 63 61 6e 5f 6e 65 77 73 | 70 61 63 65 28 6e 65 77 |can_news|pace(new|
|00005a00| 73 70 61 63 65 29 0a 20 | 90 05 4c 49 53 50 20 6e |space). |..LISP n|
|00005a10| 65 77 73 70 61 63 65 3b | 0a 7b 4c 49 53 50 20 70 |ewspace;|.{LISP p|
|00005a20| 74 72 3b 0a 20 66 6f 72 | 28 70 74 72 3d 6e 65 77 |tr;. for|(ptr=new|
|00005a30| 73 70 61 63 65 3b 20 70 | 74 72 20 3c 20 68 65 61 |space; p|tr < hea|
|00005a40| 70 3b 20 2b 2b 70 74 72 | 29 0a 20 90 03 7b 73 77 |p; ++ptr|). ..{sw|
|00005a50| 69 74 63 68 20 54 59 50 | 45 28 70 74 72 29 0a 20 |itch TYP|E(ptr). |
|00005a60| 90 06 7b 63 61 73 65 20 | 74 63 5f 63 6f 6e 73 3a |..{case |tc_cons:|
|00005a70| 0a 20 90 07 63 61 73 65 | 20 74 63 5f 63 6c 6f 73 |. ..case| tc_clos|
|00005a80| 75 72 65 3a 0a 09 20 43 | 41 52 28 70 74 72 29 20 |ure:.. C|AR(ptr) |
|00005a90| 3d 20 67 63 5f 72 65 6c | 6f 63 61 74 65 28 43 41 |= gc_rel|ocate(CA|
|00005aa0| 52 28 70 74 72 29 29 3b | 0a 09 20 43 44 52 28 70 |R(ptr));|.. CDR(p|
|00005ab0| 74 72 29 20 3d 20 67 63 | 5f 72 65 6c 6f 63 61 74 |tr) = gc|_relocat|
|00005ac0| 65 28 43 44 52 28 70 74 | 72 29 29 3b 0a 09 20 62 |e(CDR(pt|r));.. b|
|00005ad0| 72 65 61 6b 3b 0a 20 90 | 07 63 61 73 65 20 74 63 |reak;. .|.case tc|
|00005ae0| 5f 73 79 6d 62 6f 6c 3a | 0a 09 20 56 43 45 4c 4c |_symbol:|.. VCELL|
|00005af0| 28 70 74 72 29 20 3d 20 | 67 63 5f 72 65 6c 6f 63 |(ptr) = |gc_reloc|
|00005b00| 61 74 65 28 56 43 45 4c | 4c 28 70 74 72 29 29 3b |ate(VCEL|L(ptr));|
|00005b10| 0a 09 20 62 72 65 61 6b | 3b 0a 20 90 07 63 61 73 |.. break|;. ..cas|
|00005b20| 65 20 74 63 5f 75 73 65 | 72 5f 31 3a 0a 20 90 07 |e tc_use|r_1:. ..|
|00005b30| 63 61 73 65 20 74 63 5f | 75 73 65 72 5f 32 3a 0a |case tc_|user_2:.|
|00005b40| 20 90 07 63 61 73 65 20 | 74 63 5f 75 73 65 72 5f | ..case |tc_user_|
|00005b50| 33 3a 0a 20 90 07 63 61 | 73 65 20 74 63 5f 75 73 |3:. ..ca|se tc_us|
|00005b60| 65 72 5f 34 3a 0a 20 90 | 07 63 61 73 65 20 74 63 |er_4:. .|.case tc|
|00005b70| 5f 75 73 65 72 5f 35 3a | 0a 09 20 69 66 20 28 75 |_user_5:|.. if (u|
|00005b80| 73 65 72 5f 67 63 5f 73 | 63 61 6e 20 21 3d 20 4e |ser_gc_s|can != N|
|00005b90| 55 4c 4c 29 20 28 2a 75 | 73 65 72 5f 67 63 5f 73 |ULL) (*u|ser_gc_s|
|00005ba0| 63 61 6e 29 28 70 74 72 | 29 3b 0a 09 20 62 72 65 |can)(ptr|);.. bre|
|00005bb0| 61 6b 3b 0a 20 90 07 64 | 65 66 61 75 6c 74 3a 0a |ak;. ..d|efault:.|
|00005bc0| 09 20 62 72 65 61 6b 3b | 7d 90 03 0a 20 90 06 0a |. break;|}... ...|
|00005bd0| 67 63 5f 73 74 6f 70 5f | 61 6e 64 5f 63 6f 70 79 |gc_stop_|and_copy|
|00005be0| 28 29 0a 7b 4c 49 53 50 | 20 6e 65 77 73 70 61 63 |().{LISP| newspac|
|00005bf0| 65 3b 0a 20 6c 6f 6e 67 | 20 66 6c 61 67 3b 0a 20 |e;. long| flag;. |
|00005c00| 66 6c 61 67 20 3d 20 6e | 6f 5f 69 6e 74 65 72 72 |flag = n|o_interr|
|00005c10| 75 70 74 28 31 29 3b 0a | 20 65 72 72 6a 6d 70 5f |upt(1);.| errjmp_|
|00005c20| 6f 6b 20 3d 20 30 3b 0a | 20 6f 6c 64 5f 68 65 61 |ok = 0;.| old_hea|
|00005c30| 70 5f 75 73 65 64 20 3d | 20 68 65 61 70 20 2d 20 |p_used =| heap - |
|00005c40| 68 65 61 70 5f 6f 72 67 | 3b 0a 20 6e 65 77 73 70 |heap_org|;. newsp|
|00005c50| 61 63 65 20 3d 20 67 65 | 74 5f 6e 65 77 73 70 61 |ace = ge|t_newspa|
|00005c60| 63 65 28 29 3b 0a 20 73 | 63 61 6e 5f 72 65 67 69 |ce();. s|can_regi|
|00005c70| 73 74 65 72 73 28 29 3b | 0a 20 73 63 61 6e 5f 6e |sters();|. scan_n|
|00005c80| 65 77 73 70 61 63 65 28 | 6e 65 77 73 70 61 63 65 |ewspace(|newspace|
|00005c90| 29 3b 0a 20 65 72 72 6a | 6d 70 5f 6f 6b 20 3d 20 |);. errj|mp_ok = |
|00005ca0| 31 3b 0a 20 6e 6f 5f 69 | 6e 74 65 72 72 75 70 74 |1;. no_i|nterrupt|
|00005cb0| 28 66 6c 61 67 29 3b 7d | 0a 0a 67 63 5f 66 6f 72 |(flag);}|..gc_for|
|00005cc0| 5f 6e 65 77 63 65 6c 6c | 28 29 0a 7b 6c 6f 6e 67 |_newcell|().{long|
|00005cd0| 20 66 6c 61 67 3b 0a 20 | 69 66 20 28 65 72 72 6a | flag;. |if (errj|
|00005ce0| 6d 70 5f 6f 6b 20 3d 3d | 20 30 29 20 67 63 5f 66 |mp_ok ==| 0) gc_f|
|00005cf0| 61 74 61 6c 5f 65 72 72 | 6f 72 28 29 3b 0a 20 66 |atal_err|or();. f|
|00005d00| 6c 61 67 20 3d 20 6e 6f | 5f 69 6e 74 65 72 72 75 |lag = no|_interru|
|00005d10| 70 74 28 31 29 3b 0a 20 | 65 72 72 6a 6d 70 5f 6f |pt(1);. |errjmp_o|
|00005d20| 6b 20 3d 20 30 3b 0a 20 | 67 63 5f 6d 61 72 6b 5f |k = 0;. |gc_mark_|
|00005d30| 61 6e 64 5f 73 77 65 65 | 70 28 29 3b 0a 20 65 72 |and_swee|p();. er|
|00005d40| 72 6a 6d 70 5f 6f 6b 20 | 3d 20 31 3b 0a 20 6e 6f |rjmp_ok |= 1;. no|
|00005d50| 5f 69 6e 74 65 72 72 75 | 70 74 28 66 6c 61 67 29 |_interru|pt(flag)|
|00005d60| 3b 0a 20 69 66 20 4e 55 | 4c 4c 50 28 66 72 65 65 |;. if NU|LLP(free|
|00005d70| 6c 69 73 74 29 20 67 63 | 5f 66 61 74 61 6c 5f 65 |list) gc|_fatal_e|
|00005d80| 72 72 6f 72 28 29 3b 7d | 0a 0a 6a 6d 70 5f 62 75 |rror();}|..jmp_bu|
|00005d90| 66 20 73 61 76 65 5f 72 | 65 67 73 5f 67 63 5f 6d |f save_r|egs_gc_m|
|00005da0| 61 72 6b 3b 0a 0a 67 63 | 5f 6d 61 72 6b 5f 61 6e |ark;..gc|_mark_an|
|00005db0| 64 5f 73 77 65 65 70 28 | 29 0a 7b 4c 49 53 50 20 |d_sweep(|).{LISP |
|00005dc0| 73 74 61 63 6b 5f 65 6e | 64 3b 0a 20 67 63 5f 6d |stack_en|d;. gc_m|
|00005dd0| 73 5f 73 74 61 74 73 5f | 73 74 61 72 74 28 29 3b |s_stats_|start();|
|00005de0| 0a 20 2f 2a 20 54 68 69 | 73 20 61 73 73 75 6d 65 |. /* Thi|s assume|
|00005df0| 73 20 74 68 61 74 20 61 | 6c 6c 20 72 65 67 69 73 |s that a|ll regis|
|00005e00| 74 65 72 73 20 61 72 65 | 20 73 61 76 65 64 20 69 |ters are| saved i|
|00005e10| 6e 74 6f 20 74 68 65 20 | 6a 6d 70 5f 62 75 66 66 |nto the |jmp_buff|
|00005e20| 20 2a 2f 0a 20 73 65 74 | 6a 6d 70 28 73 61 76 65 | */. set|jmp(save|
|00005e30| 5f 72 65 67 73 5f 67 63 | 5f 6d 61 72 6b 29 3b 0a |_regs_gc|_mark);.|
|00005e40| 20 6d 61 72 6b 5f 6c 6f | 63 61 74 69 6f 6e 73 28 | mark_lo|cations(|
|00005e50| 28 4c 49 53 50 20 2a 29 | 20 73 61 76 65 5f 72 65 |(LISP *)| save_re|
|00005e60| 67 73 5f 67 63 5f 6d 61 | 72 6b 2c 0a 09 09 28 4c |gs_gc_ma|rk,...(L|
|00005e70| 49 53 50 20 2a 29 20 28 | 28 63 68 61 72 20 2a 29 |ISP *) (|(char *)|
|00005e80| 20 73 61 76 65 5f 72 65 | 67 73 5f 67 63 5f 6d 61 | save_re|gs_gc_ma|
|00005e90| 72 6b 29 20 2b 20 73 69 | 7a 65 6f 66 28 73 61 76 |rk) + si|zeof(sav|
|00005ea0| 65 5f 72 65 67 73 5f 67 | 63 5f 6d 61 72 6b 29 29 |e_regs_g|c_mark))|
|00005eb0| 3b 0a 20 6d 61 72 6b 5f | 70 72 6f 74 65 63 74 65 |;. mark_|protecte|
|00005ec0| 64 5f 72 65 67 69 73 74 | 65 72 73 28 29 3b 0a 20 |d_regist|ers();. |
|00005ed0| 6d 61 72 6b 5f 6c 6f 63 | 61 74 69 6f 6e 73 28 28 |mark_loc|ations((|
|00005ee0| 4c 49 53 50 20 2a 29 20 | 73 74 61 63 6b 5f 73 74 |LISP *) |stack_st|
|00005ef0| 61 72 74 5f 70 74 72 2c | 0a 09 09 28 4c 49 53 50 |art_ptr,|...(LISP|
|00005f00| 20 2a 29 20 26 73 74 61 | 63 6b 5f 65 6e 64 29 3b | *) &sta|ck_end);|
|00005f10| 0a 23 69 66 20 54 48 49 | 4e 4b 5f 43 0a 20 6d 61 |.#if THI|NK_C. ma|
|00005f20| 72 6b 5f 6c 6f 63 61 74 | 69 6f 6e 73 28 28 4c 49 |rk_locat|ions((LI|
|00005f30| 53 50 20 2a 29 20 28 28 | 63 68 61 72 20 2a 29 20 |SP *) ((|char *) |
|00005f40| 73 74 61 63 6b 5f 73 74 | 61 72 74 5f 70 74 72 20 |stack_st|art_ptr |
|00005f50| 2b 20 32 29 2c 0a 09 09 | 28 4c 49 53 50 20 2a 29 |+ 2),...|(LISP *)|
|00005f60| 20 28 28 63 68 61 72 20 | 2a 29 20 26 73 74 61 63 | ((char |*) &stac|
|00005f70| 6b 5f 65 6e 64 20 2b 20 | 32 29 29 3b 0a 23 65 6e |k_end + |2));.#en|
|00005f80| 64 69 66 0a 20 67 63 5f | 73 77 65 65 70 28 29 3b |dif. gc_|sweep();|
|00005f90| 0a 20 67 63 5f 6d 73 5f | 73 74 61 74 73 5f 65 6e |. gc_ms_|stats_en|
|00005fa0| 64 28 29 3b 7d 0a 0a 64 | 6f 75 62 6c 65 20 67 63 |d();}..d|ouble gc|
|00005fb0| 5f 72 74 3b 0a 6c 6f 6e | 67 20 67 63 5f 63 65 6c |_rt;.lon|g gc_cel|
|00005fc0| 6c 73 5f 63 6f 6c 6c 65 | 63 74 65 64 3b 0a 0a 67 |ls_colle|cted;..g|
|00005fd0| 63 5f 6d 73 5f 73 74 61 | 74 73 5f 73 74 61 72 74 |c_ms_sta|ts_start|
|00005fe0| 28 29 0a 7b 67 63 5f 72 | 74 20 3d 20 6d 79 72 75 |().{gc_r|t = myru|
|00005ff0| 6e 74 69 6d 65 28 29 3b | 0a 20 67 63 5f 63 65 6c |ntime();|. gc_cel|
|00006000| 6c 73 5f 63 6f 6c 6c 65 | 63 74 65 64 20 3d 20 30 |ls_colle|cted = 0|
|00006010| 3b 0a 20 69 66 20 28 67 | 63 5f 73 74 61 74 75 73 |;. if (g|c_status|
|00006020| 5f 66 6c 61 67 29 0a 20 | 90 03 70 72 69 6e 74 66 |_flag). |..printf|
|00006030| 28 22 5b 73 74 61 72 74 | 69 6e 67 20 47 43 5d 5c |("[start|ing GC]\|
|00006040| 6e 22 29 3b 7d 0a 0a 67 | 63 5f 6d 73 5f 73 74 61 |n");}..g|c_ms_sta|
|00006050| 74 73 5f 65 6e 64 28 29 | 0a 7b 67 63 5f 72 74 20 |ts_end()|.{gc_rt |
|00006060| 3d 20 6d 79 72 75 6e 74 | 69 6d 65 28 29 20 2d 20 |= myrunt|ime() - |
|00006070| 67 63 5f 72 74 3b 0a 20 | 67 63 5f 74 69 6d 65 5f |gc_rt;. |gc_time_|
|00006080| 74 61 6b 65 6e 20 3d 20 | 67 63 5f 74 69 6d 65 5f |taken = |gc_time_|
|00006090| 74 61 6b 65 6e 20 2b 20 | 67 63 5f 72 74 3b 0a 20 |taken + |gc_rt;. |
|000060a0| 69 66 20 28 67 63 5f 73 | 74 61 74 75 73 5f 66 6c |if (gc_s|tatus_fl|
|000060b0| 61 67 29 0a 20 90 03 70 | 72 69 6e 74 66 28 22 5b |ag). ..p|rintf("[|
|000060c0| 47 43 20 74 6f 6f 6b 20 | 25 67 20 63 70 75 20 73 |GC took |%g cpu s|
|000060d0| 65 63 6f 6e 64 73 2c 20 | 25 6c 64 20 63 65 6c 6c |econds, |%ld cell|
|000060e0| 73 20 63 6f 6c 6c 65 63 | 74 65 64 5d 5c 6e 22 2c |s collec|ted]\n",|
|000060f0| 0a 09 20 20 67 63 5f 72 | 74 2c 0a 09 20 20 67 63 |.. gc_r|t,.. gc|
|00006100| 5f 63 65 6c 6c 73 5f 63 | 6f 6c 6c 65 63 74 65 64 |_cells_c|ollected|
|00006110| 29 3b 7d 0a 90 03 76 6f | 69 64 20 67 63 5f 6d 61 |);}...vo|id gc_ma|
|00006120| 72 6b 28 70 74 72 29 0a | 20 90 05 4c 49 53 50 20 |rk(ptr).| ..LISP |
|00006130| 70 74 72 3b 0a 7b 67 63 | 5f 6d 61 72 6b 5f 6c 6f |ptr;.{gc|_mark_lo|
|00006140| 6f 70 3a 0a 20 69 66 20 | 4e 55 4c 4c 50 28 70 74 |op:. if |NULLP(pt|
|00006150| 72 29 20 72 65 74 75 72 | 6e 3b 0a 20 69 66 20 28 |r) retur|n;. if (|
|00006160| 28 2a 70 74 72 29 2e 67 | 63 5f 6d 61 72 6b 29 20 |(*ptr).g|c_mark) |
|00006170| 72 65 74 75 72 6e 3b 0a | 20 28 2a 70 74 72 29 2e |return;.| (*ptr).|
|00006180| 67 63 5f 6d 61 72 6b 20 | 3d 20 31 3b 0a 20 73 77 |gc_mark |= 1;. sw|
|00006190| 69 74 63 68 20 28 28 2a | 70 74 72 29 2e 74 79 70 |itch ((*|ptr).typ|
|000061a0| 65 29 0a 20 90 03 7b 63 | 61 73 65 20 74 63 5f 66 |e). ..{c|ase tc_f|
|000061b0| 6c 6f 6e 75 6d 3a 0a 20 | 90 06 62 72 65 61 6b 3b |lonum:. |..break;|
|000061c0| 0a 20 90 04 63 61 73 65 | 20 74 63 5f 63 6f 6e 73 |. ..case| tc_cons|
|000061d0| 3a 0a 20 90 06 67 63 5f | 6d 61 72 6b 28 43 41 52 |:. ..gc_|mark(CAR|
|000061e0| 28 70 74 72 29 29 3b 0a | 20 90 06 70 74 72 20 3d |(ptr));.| ..ptr =|
|000061f0| 20 43 44 52 28 70 74 72 | 29 3b 0a 20 90 06 67 6f | CDR(ptr|);. ..go|
|00006200| 74 6f 20 67 63 5f 6d 61 | 72 6b 5f 6c 6f 6f 70 3b |to gc_ma|rk_loop;|
|00006210| 0a 20 90 04 63 61 73 65 | 20 74 63 5f 73 79 6d 62 |. ..case| tc_symb|
|00006220| 6f 6c 3a 0a 20 90 06 70 | 74 72 20 3d 20 56 43 45 |ol:. ..p|tr = VCE|
|00006230| 4c 4c 28 70 74 72 29 3b | 0a 20 90 06 67 6f 74 6f |LL(ptr);|. ..goto|
|00006240| 20 67 63 5f 6d 61 72 6b | 5f 6c 6f 6f 70 3b 0a 20 | gc_mark|_loop;. |
|00006250| 90 04 63 61 73 65 20 74 | 63 5f 63 6c 6f 73 75 72 |..case t|c_closur|
|00006260| 65 3a 0a 20 90 06 67 63 | 5f 6d 61 72 6b 28 28 2a |e:. ..gc|_mark((*|
|00006270| 70 74 72 29 2e 73 74 6f | 72 61 67 65 5f 61 73 2e |ptr).sto|rage_as.|
|00006280| 63 6c 6f 73 75 72 65 2e | 63 6f 64 65 29 3b 0a 20 |closure.|code);. |
|00006290| 90 06 70 74 72 20 3d 20 | 28 2a 70 74 72 29 2e 73 |..ptr = |(*ptr).s|
|000062a0| 74 6f 72 61 67 65 5f 61 | 73 2e 63 6c 6f 73 75 72 |torage_a|s.closur|
|000062b0| 65 2e 65 6e 76 3b 0a 20 | 90 06 67 6f 74 6f 20 67 |e.env;. |..goto g|
|000062c0| 63 5f 6d 61 72 6b 5f 6c | 6f 6f 70 3b 0a 20 90 04 |c_mark_l|oop;. ..|
|000062d0| 63 61 73 65 20 74 63 5f | 73 75 62 72 5f 30 3a 0a |case tc_|subr_0:.|
|000062e0| 20 90 04 63 61 73 65 20 | 74 63 5f 73 75 62 72 5f | ..case |tc_subr_|
|000062f0| 31 3a 0a 20 90 04 63 61 | 73 65 20 74 63 5f 73 75 |1:. ..ca|se tc_su|
|00006300| 62 72 5f 32 3a 0a 20 90 | 04 63 61 73 65 20 74 63 |br_2:. .|.case tc|
|00006310| 5f 73 75 62 72 5f 33 3a | 0a 20 90 04 63 61 73 65 |_subr_3:|. ..case|
|00006320| 20 74 63 5f 6c 73 75 62 | 72 3a 0a 20 90 04 63 61 | tc_lsub|r:. ..ca|
|00006330| 73 65 20 74 63 5f 66 73 | 75 62 72 3a 0a 20 90 04 |se tc_fs|ubr:. ..|
|00006340| 63 61 73 65 20 74 63 5f | 6d 73 75 62 72 3a 0a 20 |case tc_|msubr:. |
|00006350| 90 06 72 65 74 75 72 6e | 3b 0a 20 90 04 63 61 73 |..return|;. ..cas|
|00006360| 65 20 74 63 5f 75 73 65 | 72 5f 31 3a 0a 20 90 04 |e tc_use|r_1:. ..|
|00006370| 63 61 73 65 20 74 63 5f | 75 73 65 72 5f 32 3a 0a |case tc_|user_2:.|
|00006380| 20 90 04 63 61 73 65 20 | 74 63 5f 75 73 65 72 5f | ..case |tc_user_|
|00006390| 33 3a 0a 20 90 04 63 61 | 73 65 20 74 63 5f 75 73 |3:. ..ca|se tc_us|
|000063a0| 65 72 5f 34 3a 0a 20 90 | 04 63 61 73 65 20 74 63 |er_4:. .|.case tc|
|000063b0| 5f 75 73 65 72 5f 35 3a | 0a 20 90 06 69 66 20 28 |_user_5:|. ..if (|
|000063c0| 75 73 65 72 5f 67 63 5f | 6d 61 72 6b 20 21 3d 20 |user_gc_|mark != |
|000063d0| 4e 55 4c 4c 29 0a 09 7b | 70 74 72 20 3d 20 28 2a |NULL)..{|ptr = (*|
|000063e0| 75 73 65 72 5f 67 63 5f | 6d 61 72 6b 29 28 70 74 |user_gc_|mark)(pt|
|000063f0| 72 29 3b 0a 09 20 67 6f | 74 6f 20 67 63 5f 6d 61 |r);.. go|to gc_ma|
+--------+-------------------------+-------------------------+--------+--------+
Only 25.0 KB of data is shown above.