home *** CD-ROM | disk | FTP | other *** search
open in:
MacOS 8.1
|
Win98
|
DOS
view JSON data
|
view as text
This file was processed as: Mailbox/MIME Entity
(archive/mbox).
You can browse this item here: XL-CL001.FIX
Confidence | Program | Detection | Match Type | Support
|
---|
100%
| dexvert
| Mailbox/MIME Entity (archive/mbox)
| magic
| Supported |
100%
| dexvert
| Internet Message Format (text/imf)
| magic
| Supported |
1%
| dexvert
| Text File (text/txt)
| fallback
| Supported |
100%
| file
| Mailbox text, 1st line "From sce!mitel!uunet!zephyr.ens.tek.com!tekcrl!tekgvs!toma Sat Sep 16 08:20:18 EDT 1989"
| default
| |
99%
| file
| C source, ASCII text, with CRLF line terminators
| default
| |
100%
| TrID
| E-Mail message (Var. 2)
| default
| |
100%
| checkBytes
| Printable ASCII
| default
| |
100%
| perlTextCheck
| Likely Text (Perl)
| default
| |
100%
| siegfried
| x-fmt/111 Plain Text File
| default
| |
100%
| detectItEasy
| Format: plain text[CRLF]
| default (weak)
| |
100%
| xdgMime
| application/mbox
| default
|
|
hex view+--------+-------------------------+-------------------------+--------+--------+
|00000000| 46 72 6f 6d 20 73 63 65 | 21 6d 69 74 65 6c 21 75 |From sce|!mitel!u|
|00000010| 75 6e 65 74 21 7a 65 70 | 68 79 72 2e 65 6e 73 2e |unet!zep|hyr.ens.|
|00000020| 74 65 6b 2e 63 6f 6d 21 | 74 65 6b 63 72 6c 21 74 |tek.com!|tekcrl!t|
|00000030| 65 6b 67 76 73 21 74 6f | 6d 61 20 53 61 74 20 53 |ekgvs!to|ma Sat S|
|00000040| 65 70 20 31 36 20 30 38 | 3a 32 30 3a 31 38 20 45 |ep 16 08|:20:18 E|
|00000050| 44 54 20 31 39 38 39 0d | 0a 41 72 74 69 63 6c 65 |DT 1989.|.Article|
|00000060| 3a 20 31 20 6f 66 20 63 | 6f 6d 70 2e 6c 61 6e 67 |: 1 of c|omp.lang|
|00000070| 2e 6c 69 73 70 2e 78 0d | 0a 50 61 74 68 3a 20 63 |.lisp.x.|.Path: c|
|00000080| 6f 67 6e 6f 73 21 73 63 | 65 21 6d 69 74 65 6c 21 |ognos!sc|e!mitel!|
|00000090| 75 75 6e 65 74 21 7a 65 | 70 68 79 72 2e 65 6e 73 |uunet!ze|phyr.ens|
|000000a0| 2e 74 65 6b 2e 63 6f 6d | 21 74 65 6b 63 72 6c 21 |.tek.com|!tekcrl!|
|000000b0| 74 65 6b 67 76 73 21 74 | 6f 6d 61 0d 0a 46 72 6f |tekgvs!t|oma..Fro|
|000000c0| 6d 3a 20 74 6f 6d 61 40 | 74 65 6b 67 76 73 2e 4c |m: toma@|tekgvs.L|
|000000d0| 41 42 53 2e 54 45 4b 2e | 43 4f 4d 20 28 54 6f 6d |ABS.TEK.|COM (Tom|
|000000e0| 20 41 6c 6d 79 29 0d 0a | 4e 65 77 73 67 72 6f 75 | Almy)..|Newsgrou|
|000000f0| 70 73 3a 20 63 6f 6d 70 | 2e 6c 61 6e 67 2e 6c 69 |ps: comp|.lang.li|
|00000100| 73 70 2e 78 0d 0a 53 75 | 62 6a 65 63 74 3a 20 58 |sp.x..Su|bject: X|
|00000110| 4c 49 53 50 20 32 2e 30 | 20 42 55 47 28 3f 29 0d |LISP 2.0| BUG(?).|
|00000120| 0a 4d 65 73 73 61 67 65 | 2d 49 44 3a 20 3c 35 39 |.Message|-ID: <59|
|00000130| 31 31 40 74 65 6b 67 76 | 73 2e 4c 41 42 53 2e 54 |11@tekgv|s.LABS.T|
|00000140| 45 4b 2e 43 4f 4d 3e 0d | 0a 44 61 74 65 3a 20 31 |EK.COM>.|.Date: 1|
|00000150| 31 20 53 65 70 20 38 39 | 20 31 34 3a 33 34 3a 31 |1 Sep 89| 14:34:1|
|00000160| 31 20 47 4d 54 0d 0a 52 | 65 70 6c 79 2d 54 6f 3a |1 GMT..R|eply-To:|
|00000170| 20 74 6f 6d 61 40 74 65 | 6b 67 76 73 2e 4c 41 42 | toma@te|kgvs.LAB|
|00000180| 53 2e 54 45 4b 2e 43 4f | 4d 20 28 54 6f 6d 20 41 |S.TEK.CO|M (Tom A|
|00000190| 6c 6d 79 29 0d 0a 4f 72 | 67 61 6e 69 7a 61 74 69 |lmy)..Or|ganizati|
|000001a0| 6f 6e 3a 20 54 65 6b 74 | 72 6f 6e 69 78 2c 20 49 |on: Tekt|ronix, I|
|000001b0| 6e 63 2e 2c 20 42 65 61 | 76 65 72 74 6f 6e 2c 20 |nc., Bea|verton, |
|000001c0| 20 4f 52 2e 0d 0a 4c 69 | 6e 65 73 3a 20 32 32 0d | OR...Li|nes: 22.|
|000001d0| 0a 0d 0a 0d 0a 50 61 72 | 74 20 6f 66 20 6d 79 20 |.....Par|t of my |
|000001e0| 65 66 66 6f 72 74 20 74 | 6f 20 6d 61 6b 65 20 78 |effort t|o make x|
|000001f0| 6c 69 73 70 20 6d 6f 72 | 65 20 63 6f 6d 70 61 74 |lisp mor|e compat|
|00000200| 69 62 6c 65 20 77 69 74 | 68 20 43 6f 6d 6d 6f 6e |ible wit|h Common|
|00000210| 20 4c 69 73 70 3a 0d 0a | 0d 0a 50 72 6f 62 6c 65 | Lisp:..|..Proble|
|00000220| 6d 3a 20 46 75 6e 63 74 | 69 6f 6e 73 20 77 68 69 |m: Funct|ions whi|
|00000230| 63 68 20 74 61 6b 65 20 | 74 68 65 20 3a 65 6e 64 |ch take |the :end|
|00000240| 20 6b 65 79 77 6f 72 64 | 20 61 72 67 75 6d 65 6e | keyword| argumen|
|00000250| 74 20 64 6f 20 6e 6f 74 | 20 61 6c 6c 6f 77 20 4e |t do not| allow N|
|00000260| 49 4c 0d 0a 09 74 6f 20 | 6d 65 61 6e 20 22 65 6e |IL...to |mean "en|
|00000270| 64 20 6f 66 20 6c 69 73 | 74 22 20 61 73 20 69 6e |d of lis|t" as in|
|00000280| 20 43 6f 6d 6d 6f 6e 20 | 4c 69 73 70 2e 0d 0a 0d | Common |Lisp....|
|00000290| 0a 45 78 61 6d 70 6c 65 | 3a 20 28 73 74 72 69 6e |.Example|: (strin|
|000002a0| 67 2d 64 6f 77 6e 63 61 | 73 65 20 22 41 42 43 20 |g-downca|se "ABC |
|000002b0| 44 45 46 22 20 3a 73 74 | 61 72 74 20 34 20 3a 65 |DEF" :st|art 4 :e|
|000002c0| 6e 64 20 4e 49 4c 29 20 | 67 69 76 65 73 20 61 6e |nd NIL) |gives an|
|000002d0| 20 65 72 72 6f 72 2e 0d | 0a 0d 0a 46 69 78 3a 20 | error..|...Fix: |
|000002e0| 69 6e 20 66 75 6e 63 74 | 69 6f 6e 20 67 65 74 62 |in funct|ion getb|
|000002f0| 6f 75 6e 64 73 28 29 20 | 69 6e 20 66 69 6c 65 20 |ounds() |in file |
|00000300| 78 6c 73 74 72 2e 63 2c | 20 63 68 61 6e 67 65 0d |xlstr.c,| change.|
|00000310| 0a 0d 0a 20 20 20 20 69 | 66 20 28 78 6c 67 6b 66 |... i|f (xlgkf|
|00000320| 69 78 6e 75 6d 28 65 6b | 65 79 2c 26 61 72 67 29 |ixnum(ek|ey,&arg)|
|00000330| 29 20 7b 0d 0a 20 20 20 | 20 20 20 20 20 2a 70 65 |) {.. | *pe|
|00000340| 6e 64 20 3d 20 28 69 6e | 74 29 67 65 74 66 69 78 |nd = (in|t)getfix|
|00000350| 6e 75 6d 28 61 72 67 29 | 3b 0d 0a 0d 0a 74 6f 0d |num(arg)|;....to.|
|00000360| 0a 20 20 20 20 69 66 20 | 28 78 6c 67 65 74 6b 65 |. if |(xlgetke|
|00000370| 79 61 72 67 28 65 6b 65 | 79 2c 20 26 61 72 67 29 |yarg(eke|y, &arg)|
|00000380| 20 26 26 20 61 72 67 20 | 21 3d 20 4e 49 4c 29 20 | && arg |!= NIL) |
|00000390| 7b 0d 0a 20 20 20 20 20 | 20 20 20 69 66 20 28 21 |{.. | if (!|
|000003a0| 66 69 78 70 28 61 72 67 | 29 29 20 78 6c 62 61 64 |fixp(arg|)) xlbad|
|000003b0| 74 79 70 65 28 61 72 67 | 29 3b 0d 0a 20 20 20 20 |type(arg|);.. |
|000003c0| 20 20 20 20 2a 70 65 6e | 64 20 3d 20 28 69 6e 74 | *pen|d = (int|
|000003d0| 29 67 65 74 66 69 78 6e | 75 6d 28 61 72 67 29 3b |)getfixn|um(arg);|
|000003e0| 0d 0a 0d 0a 0d 0a 54 6f | 6d 20 41 6c 6d 79 0d 0a |......To|m Almy..|
|000003f0| 74 6f 6d 61 40 74 65 6b | 67 76 73 2e 6c 61 62 73 |toma@tek|gvs.labs|
|00000400| 2e 74 65 6b 2e 63 6f 6d | 0d 0a 53 74 61 6e 64 61 |.tek.com|..Standa|
|00000410| 72 64 20 44 69 73 63 6c | 61 69 6d 65 72 73 20 41 |rd Discl|aimers A|
|00000420| 70 70 6c 79 0d 0a 0d 0a | 0d 0a 46 72 6f 6d 20 73 |pply....|..From s|
|00000430| 63 65 21 6d 69 74 65 6c | 21 75 75 6e 65 74 21 7a |ce!mitel|!uunet!z|
|00000440| 65 70 68 79 72 2e 65 6e | 73 2e 74 65 6b 2e 63 6f |ephyr.en|s.tek.co|
|00000450| 6d 21 74 65 6b 63 72 6c | 21 74 65 6b 67 76 73 21 |m!tekcrl|!tekgvs!|
|00000460| 74 6f 6d 61 20 53 61 74 | 20 53 65 70 20 31 36 20 |toma Sat| Sep 16 |
|00000470| 30 38 3a 32 30 3a 32 36 | 20 45 44 54 20 31 39 38 |08:20:26| EDT 198|
|00000480| 39 0d 0a 41 72 74 69 63 | 6c 65 3a 20 32 20 6f 66 |9..Artic|le: 2 of|
|00000490| 20 63 6f 6d 70 2e 6c 61 | 6e 67 2e 6c 69 73 70 2e | comp.la|ng.lisp.|
|000004a0| 78 0d 0a 50 61 74 68 3a | 20 63 6f 67 6e 6f 73 21 |x..Path:| cognos!|
|000004b0| 73 63 65 21 6d 69 74 65 | 6c 21 75 75 6e 65 74 21 |sce!mite|l!uunet!|
|000004c0| 7a 65 70 68 79 72 2e 65 | 6e 73 2e 74 65 6b 2e 63 |zephyr.e|ns.tek.c|
|000004d0| 6f 6d 21 74 65 6b 63 72 | 6c 21 74 65 6b 67 76 73 |om!tekcr|l!tekgvs|
|000004e0| 21 74 6f 6d 61 0d 0a 46 | 72 6f 6d 3a 20 74 6f 6d |!toma..F|rom: tom|
|000004f0| 61 40 74 65 6b 67 76 73 | 2e 4c 41 42 53 2e 54 45 |a@tekgvs|.LABS.TE|
|00000500| 4b 2e 43 4f 4d 20 28 54 | 6f 6d 20 41 6c 6d 79 29 |K.COM (T|om Almy)|
|00000510| 0d 0a 4e 65 77 73 67 72 | 6f 75 70 73 3a 20 63 6f |..Newsgr|oups: co|
|00000520| 6d 70 2e 6c 61 6e 67 2e | 6c 69 73 70 2e 78 0d 0a |mp.lang.|lisp.x..|
|00000530| 53 75 62 6a 65 63 74 3a | 20 58 4c 49 53 50 20 32 |Subject:| XLISP 2|
|00000540| 2e 30 20 4d 6f 64 69 66 | 69 63 61 74 69 6f 6e 73 |.0 Modif|ications|
|00000550| 20 28 31 20 6f 66 20 32 | 29 0d 0a 4d 65 73 73 61 | (1 of 2|)..Messa|
|00000560| 67 65 2d 49 44 3a 20 3c | 35 39 31 38 40 74 65 6b |ge-ID: <|5918@tek|
|00000570| 67 76 73 2e 4c 41 42 53 | 2e 54 45 4b 2e 43 4f 4d |gvs.LABS|.TEK.COM|
|00000580| 3e 0d 0a 44 61 74 65 3a | 20 31 31 20 53 65 70 20 |>..Date:| 11 Sep |
|00000590| 38 39 20 32 32 3a 32 35 | 3a 31 31 20 47 4d 54 0d |89 22:25|:11 GMT.|
|000005a0| 0a 52 65 70 6c 79 2d 54 | 6f 3a 20 74 6f 6d 61 40 |.Reply-T|o: toma@|
|000005b0| 74 65 6b 67 76 73 2e 4c | 41 42 53 2e 54 45 4b 2e |tekgvs.L|ABS.TEK.|
|000005c0| 43 4f 4d 20 28 54 6f 6d | 20 41 6c 6d 79 29 0d 0a |COM (Tom| Almy)..|
|000005d0| 4f 72 67 61 6e 69 7a 61 | 74 69 6f 6e 3a 20 54 65 |Organiza|tion: Te|
|000005e0| 6b 74 72 6f 6e 69 78 2c | 20 49 6e 63 2e 2c 20 42 |ktronix,| Inc., B|
|000005f0| 65 61 76 65 72 74 6f 6e | 2c 20 20 4f 52 2e 0d 0a |eaverton|, OR...|
|00000600| 4c 69 6e 65 73 3a 20 33 | 39 33 0d 0a 0d 0a 49 20 |Lines: 3|93....I |
|00000610| 68 61 76 65 20 72 65 63 | 65 6e 74 6c 79 20 62 65 |have rec|ently be|
|00000620| 65 6e 20 61 64 64 69 6e | 67 20 61 20 66 65 77 20 |en addin|g a few |
|00000630| 43 6f 6d 6d 6f 6e 20 4c | 69 73 70 20 66 75 6e 63 |Common L|isp func|
|00000640| 74 69 6f 6e 73 20 74 6f | 20 58 4c 49 53 50 20 32 |tions to| XLISP 2|
|00000650| 2e 30 2c 20 61 6e 64 0d | 0a 6d 61 6b 65 69 6e 67 |.0, and.|.makeing|
|00000660| 20 73 6f 6d 65 20 65 78 | 69 73 74 69 6e 67 20 66 | some ex|isting f|
|00000670| 75 6e 63 74 69 6f 6e 73 | 20 6d 6f 72 65 20 43 6f |unctions| more Co|
|00000680| 6d 6d 6f 6e 2d 4c 69 73 | 70 20 63 6f 6d 70 61 74 |mmon-Lis|p compat|
|00000690| 69 62 6c 65 20 28 70 61 | 72 74 69 63 75 6c 61 72 |ible (pa|rticular|
|000006a0| 6c 79 0d 0a 69 6e 20 6d | 61 6b 69 6e 67 20 66 75 |ly..in m|aking fu|
|000006b0| 6e 63 74 69 6f 6e 73 20 | 74 68 61 74 20 61 72 65 |nctions |that are|
|000006c0| 20 73 75 70 70 6f 73 65 | 64 20 74 6f 20 74 61 6b | suppose|d to tak|
|000006d0| 65 20 73 65 71 75 65 6e | 63 65 20 61 72 67 75 6d |e sequen|ce argum|
|000006e0| 65 6e 74 73 20 28 69 6e | 20 58 4c 49 53 50 0d 0a |ents (in| XLISP..|
|000006f0| 74 68 61 74 20 77 6f 75 | 6c 64 20 62 65 20 6c 69 |that wou|ld be li|
|00000700| 73 74 73 2c 20 61 72 72 | 61 79 73 2c 20 6f 72 20 |sts, arr|ays, or |
|00000710| 73 74 72 69 6e 67 73 29 | 20 61 63 74 75 61 6c 6c |strings)| actuall|
|00000720| 79 20 74 61 6b 65 20 74 | 68 65 6d 2e 0d 0a 0d 0a |y take t|hem.....|
|00000730| 54 68 65 73 65 20 63 68 | 61 6e 67 65 73 20 70 72 |These ch|anges pr|
|00000740| 6f 64 75 63 65 20 74 68 | 65 20 66 6f 6c 6c 6f 77 |oduce th|e follow|
|00000750| 69 6e 67 20 63 6f 6e 73 | 65 71 75 65 6e 63 65 73 |ing cons|equences|
|00000760| 3a 0d 0a 0d 0a 31 2e 20 | 20 46 75 6e 63 74 69 6f |:....1. | Functio|
|00000770| 6e 73 20 77 69 74 68 20 | 6e 61 6d 65 73 20 73 74 |ns with |names st|
|00000780| 61 72 74 69 6e 67 20 77 | 69 74 68 20 22 53 54 52 |arting w|ith "STR|
|00000790| 49 4e 47 22 20 77 69 6c | 6c 20 61 63 63 65 70 74 |ING" wil|l accept|
|000007a0| 20 61 20 73 79 6d 62 6f | 6c 20 61 73 0d 0a 20 20 | a symbo|l as.. |
|000007b0| 20 20 74 68 65 20 73 74 | 72 69 6e 67 20 61 72 67 | the st|ring arg|
|000007c0| 75 6d 65 6e 74 2e 20 20 | 54 68 65 20 73 79 6d 62 |ument. |The symb|
|000007d0| 6f 6c 73 20 70 72 69 6e | 74 6e 61 6d 65 20 73 74 |ols prin|tname st|
|000007e0| 72 69 6e 67 20 69 73 20 | 75 73 65 64 2e 0d 0a 0d |ring is |used....|
|000007f0| 0a 32 2e 20 20 53 54 52 | 43 41 54 20 69 73 20 65 |.2. STR|CAT is e|
|00000800| 6c 69 6d 69 6e 61 74 65 | 64 20 28 61 20 6d 61 63 |liminate|d (a mac|
|00000810| 72 6f 20 69 73 20 70 6c | 61 63 65 64 20 69 6e 20 |ro is pl|aced in |
|00000820| 69 6e 69 74 2e 6c 73 70 | 20 66 6f 72 20 62 61 63 |init.lsp| for bac|
|00000830| 6b 77 61 72 64 73 0d 0a | 20 20 20 20 63 6f 6d 70 |kwards..| comp|
|00000840| 61 74 69 62 69 6c 69 74 | 79 29 2e 20 20 54 68 65 |atibilit|y). The|
|00000850| 20 72 65 70 6c 61 63 65 | 6d 65 6e 74 20 66 75 6e | replace|ment fun|
|00000860| 63 74 69 6f 6e 20 69 73 | 20 43 4f 4e 43 41 54 45 |ction is| CONCATE|
|00000870| 4e 41 54 45 20 77 68 69 | 63 68 20 77 69 6c 6c 0d |NATE whi|ch will.|
|00000880| 0a 20 20 20 20 63 6f 6e | 63 61 74 65 6e 61 74 65 |. con|catenate|
|00000890| 20 73 65 71 75 65 6e 63 | 65 73 20 6f 66 20 61 6e | sequenc|es of an|
|000008a0| 79 20 74 79 70 65 28 73 | 29 20 69 6e 74 6f 20 61 |y type(s|) into a|
|000008b0| 20 72 65 73 75 6c 74 20 | 73 65 71 75 65 6e 63 65 | result |sequence|
|000008c0| 20 6f 66 20 61 6e 79 0d | 0a 20 20 20 20 74 79 70 | of any.|. typ|
|000008d0| 65 2e 20 20 49 74 20 69 | 73 20 75 73 65 64 3a 20 |e. It i|s used: |
|000008e0| 28 43 4f 4e 43 41 54 45 | 4e 41 54 45 20 3c 74 79 |(CONCATE|NATE <ty|
|000008f0| 70 65 3e 20 3c 73 65 71 | 31 3e 20 5b 3c 73 65 71 |pe> <seq|1> [<seq|
|00000900| 32 3e 20 2e 2e 2e 5d 29 | 20 77 68 65 72 65 20 0d |2> ...])| where .|
|00000910| 0a 20 20 20 20 74 79 70 | 65 20 69 73 20 74 68 65 |. typ|e is the|
|00000920| 20 72 65 73 75 6c 74 20 | 74 79 70 65 2c 20 6f 6e | result |type, on|
|00000930| 65 20 6f 66 20 43 4f 4e | 53 20 41 52 52 41 59 20 |e of CON|S ARRAY |
|00000940| 6f 72 20 53 54 52 49 4e | 47 2e 0d 0a 0d 0a 33 2e |or STRIN|G.....3.|
|00000950| 20 20 41 52 45 46 20 77 | 69 6c 6c 20 77 6f 72 6b | AREF w|ill work|
|00000960| 20 6f 6e 20 73 74 72 69 | 6e 67 73 20 61 73 20 77 | on stri|ngs as w|
|00000970| 65 6c 6c 20 61 73 20 61 | 72 72 61 79 73 2e 0d 0a |ell as a|rrays...|
|00000980| 0d 0a 34 2e 20 20 53 55 | 42 53 45 51 20 52 45 56 |..4. SU|BSEQ REV|
|00000990| 45 52 53 45 20 52 45 4d | 4f 56 45 2e 2e 2e 20 44 |ERSE REM|OVE... D|
|000009a0| 45 4c 45 54 45 2e 2e 2e | 20 74 61 6b 65 20 73 65 |ELETE...| take se|
|000009b0| 71 75 65 6e 63 65 20 61 | 72 67 75 6d 65 6e 74 73 |quence a|rguments|
|000009c0| 20 72 61 74 68 65 72 20 | 0d 0a 20 20 20 20 74 68 | rather |.. th|
|000009d0| 61 6e 20 6a 75 73 74 20 | 6c 69 73 74 20 61 72 67 |an just |list arg|
|000009e0| 75 6d 65 6e 74 73 2e 0d | 0a 0d 0a 35 2e 20 20 52 |uments..|...5. R|
|000009f0| 45 4d 4f 56 45 2e 2e 2e | 20 61 6e 64 20 44 45 4c |EMOVE...| and DEL|
|00000a00| 45 54 45 2e 2e 2e 20 61 | 63 63 65 70 74 20 3a 73 |ETE... a|ccept :s|
|00000a10| 74 61 72 74 20 61 6e 64 | 20 3a 65 6e 64 20 6b 65 |tart and| :end ke|
|00000a20| 79 77 6f 72 64 20 61 72 | 67 75 6d 65 6e 74 73 2e |yword ar|guments.|
|00000a30| 0d 0a 0d 0a 36 2e 20 20 | 41 64 64 65 64 20 66 75 |....6. |Added fu|
|00000a40| 6e 63 74 69 6f 6e 20 28 | 45 4c 54 20 3c 73 65 71 |nction (|ELT <seq|
|00000a50| 3e 20 3c 69 6e 64 65 78 | 3e 29 20 77 68 69 63 68 |> <index|>) which|
|00000a60| 20 63 6f 6d 62 69 6e 65 | 73 20 74 68 65 20 66 75 | combine|s the fu|
|00000a70| 6e 63 74 69 6f 6e 61 6c | 69 74 79 0d 0a 20 20 20 |nctional|ity.. |
|00000a80| 20 6f 66 20 41 52 45 46 | 20 61 6e 64 20 4e 54 48 | of AREF| and NTH|
|00000a90| 2e 0d 0a 0d 0a 37 2e 20 | 20 41 64 64 65 64 20 66 |.....7. | Added f|
|00000aa0| 75 6e 63 74 69 6f 6e 20 | 28 4d 41 50 20 3c 74 79 |unction |(MAP <ty|
|00000ab0| 70 65 3e 20 3c 66 63 6e | 3e 20 3c 73 65 71 31 3e |pe> <fcn|> <seq1>|
|00000ac0| 20 5b 3c 73 65 71 32 3e | 20 2e 2e 2e 5d 29 20 61 | [<seq2>| ...]) a|
|00000ad0| 20 6d 61 70 70 69 6e 67 | 0d 0a 20 20 20 20 66 75 | mapping|.. fu|
|00000ae0| 6e 63 74 69 6f 6e 20 6f | 76 65 72 20 73 65 71 75 |nction o|ver sequ|
|00000af0| 65 6e 63 65 73 2e 20 20 | 54 68 65 20 72 65 73 75 |ences. |The resu|
|00000b00| 6c 74 69 6e 67 20 73 65 | 71 75 65 6e 63 65 20 69 |lting se|quence i|
|00000b10| 73 20 6f 66 20 74 79 70 | 65 20 3c 74 79 70 65 3e |s of typ|e <type>|
|00000b20| 2c 0d 0a 20 20 20 20 77 | 68 69 63 68 20 69 73 20 |,.. w|hich is |
|00000b30| 6f 6e 65 20 6f 66 20 43 | 4f 4e 53 20 41 52 52 41 |one of C|ONS ARRA|
|00000b40| 59 20 53 54 52 49 4e 47 | 20 6f 72 20 4e 49 4c 20 |Y STRING| or NIL |
|00000b50| 28 6d 65 61 6e 69 6e 67 | 20 6e 6f 2c 20 6f 72 20 |(meaning| no, or |
|00000b60| 4e 49 4c 2c 20 72 65 73 | 75 6c 74 29 2e 0d 0a 0d |NIL, res|ult)....|
|00000b70| 0a 38 2e 20 20 41 64 64 | 65 64 20 66 75 6e 63 74 |.8. Add|ed funct|
|00000b80| 69 6f 6e 73 20 50 4f 53 | 49 54 49 4f 4e 2d 49 46 |ions POS|ITION-IF|
|00000b90| 2c 20 46 49 4e 44 2d 49 | 46 2c 20 61 6e 64 20 43 |, FIND-I|F, and C|
|00000ba0| 4f 55 4e 54 2d 49 46 2c | 20 77 68 69 63 68 20 77 |OUNT-IF,| which w|
|00000bb0| 6f 72 6b 0d 0a 20 20 20 | 20 61 6e 61 6c 6f 67 6f |ork.. | analogo|
|00000bc0| 75 73 6c 79 20 74 6f 20 | 52 45 4d 4f 56 45 2d 49 |usly to |REMOVE-I|
|00000bd0| 46 2c 20 62 75 74 20 72 | 65 74 75 72 6e 20 74 68 |F, but r|eturn th|
|00000be0| 65 20 70 6f 73 69 74 69 | 6f 6e 20 6f 66 20 74 68 |e positi|on of th|
|00000bf0| 65 20 66 69 72 73 74 20 | 6d 61 74 63 68 2c 0d 0a |e first |match,..|
|00000c00| 20 20 20 20 74 68 65 20 | 66 69 72 73 74 20 6d 61 | the |first ma|
|00000c10| 74 63 68 2c 20 61 6e 64 | 20 6e 75 6d 62 65 72 20 |tch, and| number |
|00000c20| 6f 66 20 6d 61 74 63 68 | 65 73 2c 20 72 65 73 70 |of match|es, resp|
|00000c30| 65 63 74 69 76 65 6c 79 | 2e 0d 0a 0d 0a 39 2e 20 |ectively|.....9. |
|00000c40| 20 41 64 64 65 64 20 66 | 75 6e 63 74 69 6f 6e 20 | Added f|unction |
|00000c50| 28 53 45 41 52 43 48 20 | 3c 73 65 71 31 3e 20 3c |(SEARCH |<seq1> <|
|00000c60| 73 65 71 32 3e 20 26 6b | 65 79 20 3a 74 65 73 74 |seq2> &k|ey :test|
|00000c70| 20 3a 74 65 73 74 2d 6e | 6f 74 20 3a 73 74 61 72 | :test-n|ot :star|
|00000c80| 74 31 0d 0a 20 20 20 20 | 3a 65 6e 64 31 20 3a 73 |t1.. |:end1 :s|
|00000c90| 74 61 72 74 32 20 3a 65 | 6e 64 32 29 20 77 68 69 |tart2 :e|nd2) whi|
|00000ca0| 63 68 20 72 65 74 75 72 | 6e 73 20 74 68 65 20 69 |ch retur|ns the i|
|00000cb0| 6e 64 65 78 20 6f 66 20 | 74 68 65 20 66 69 72 73 |ndex of |the firs|
|00000cc0| 74 20 6f 63 63 75 72 61 | 6e 63 65 0d 0a 20 20 20 |t occura|nce.. |
|00000cd0| 20 6f 66 20 73 65 71 31 | 20 69 6e 20 73 65 71 32 | of seq1| in seq2|
|00000ce0| 2e 20 46 6f 72 20 65 78 | 61 6d 70 6c 65 20 28 73 |. For ex|ample (s|
|00000cf0| 65 61 72 63 68 20 23 28 | 61 20 62 20 63 29 20 27 |earch #(|a b c) '|
|00000d00| 28 61 20 62 20 61 20 62 | 20 63 20 64 29 29 20 72 |(a b a b| c d)) r|
|00000d10| 65 74 75 72 6e 73 0d 0a | 20 20 20 20 32 2e 0d 0a |eturns..| 2...|
|00000d20| 0d 0a 31 30 2e 20 41 64 | 64 65 64 20 66 75 6e 63 |..10. Ad|ded func|
|00000d30| 74 69 6f 6e 20 28 43 4f | 45 52 43 45 20 3c 65 78 |tion (CO|ERCE <ex|
|00000d40| 70 72 3e 20 3c 74 79 70 | 65 3e 29 20 77 68 69 63 |pr> <typ|e>) whic|
|00000d50| 68 20 63 61 6e 20 63 6f | 65 72 63 65 20 62 65 74 |h can co|erce bet|
|00000d60| 77 65 65 6e 20 0d 0a 20 | 20 20 20 73 65 71 75 65 |ween .. | seque|
|00000d70| 6e 63 65 20 74 79 70 65 | 73 20 61 6e 64 20 69 6e |nce type|s and in|
|00000d80| 20 61 20 6c 69 6d 69 74 | 65 64 20 62 61 73 69 73 | a limit|ed basis|
|00000d90| 20 74 6f 20 63 68 61 72 | 61 63 74 65 72 73 20 6f | to char|acters o|
|00000da0| 72 20 66 6c 6f 61 74 69 | 6e 67 20 70 6f 69 6e 74 |r floati|ng point|
|00000db0| 0d 0a 20 20 20 20 6e 75 | 6d 62 65 72 73 2e 0d 0a |.. nu|mbers...|
|00000dc0| 0d 0a 0d 0a 54 68 69 73 | 20 69 73 20 74 68 65 20 |....This| is the |
|00000dd0| 66 69 72 73 74 20 6f 66 | 20 74 77 6f 20 70 61 72 |first of| two par|
|00000de0| 74 73 2e 20 20 54 68 65 | 20 66 69 6e 61 6c 20 6c |ts. The| final l|
|00000df0| 69 6e 65 20 69 6e 20 74 | 68 69 73 20 66 69 6c 65 |ine in t|his file|
|00000e00| 20 69 73 20 22 54 68 69 | 73 20 69 73 0d 0a 74 68 | is "Thi|s is..th|
|00000e10| 65 20 65 6e 64 20 6f 66 | 20 70 61 72 74 20 31 2e |e end of| part 1.|
|00000e20| 22 0d 0a 0d 0a 0d 0a 54 | 6f 6d 20 41 6c 6d 79 0d |"......T|om Almy.|
|00000e30| 0a 53 65 70 74 65 6d 62 | 65 72 20 31 31 2c 20 31 |.Septemb|er 11, 1|
|00000e40| 39 38 39 0d 0a 74 6f 6d | 61 40 74 65 6b 67 76 73 |989..tom|a@tekgvs|
|00000e50| 2e 6c 61 62 73 2e 74 65 | 6b 2e 63 6f 6d 0d 0a 53 |.labs.te|k.com..S|
|00000e60| 74 61 6e 64 61 72 64 20 | 44 69 73 63 6c 61 69 6d |tandard |Disclaim|
|00000e70| 65 72 73 20 41 70 70 6c | 79 0d 0a 0d 0a 0d 0a 2a |ers Appl|y......*|
|00000e80| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000e90| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000ea0| 2a 2a 2a 2a 2a 2a 0d 0a | 54 68 65 20 66 69 72 73 |******..|The firs|
|00000eb0| 74 20 63 68 61 6e 67 65 | 20 72 65 64 75 63 65 73 |t change| reduces|
|00000ec0| 20 74 68 65 20 61 6d 6f | 75 6e 74 20 6f 66 20 63 | the amo|unt of c|
|00000ed0| 6f 64 65 2e 0d 0a 0d 0a | 49 6e 20 78 6c 73 75 62 |ode.....|In xlsub|
|00000ee0| 72 2e 63 2c 20 61 64 64 | 20 74 68 65 20 66 6f 6c |r.c, add| the fol|
|00000ef0| 6c 6f 77 69 6e 67 20 64 | 65 66 69 6e 69 74 69 6f |lowing d|efinitio|
|00000f00| 6e 3a 0d 0a 0d 0a 2f 2a | 20 78 6c 62 61 64 74 79 |n:..../*| xlbadty|
|00000f10| 70 65 20 2d 20 72 65 70 | 6f 72 74 20 61 20 22 62 |pe - rep|ort a "b|
|00000f20| 61 64 20 61 72 67 75 6d | 65 6e 74 20 74 79 70 65 |ad argum|ent type|
|00000f30| 22 20 65 72 72 6f 72 20 | 2a 2f 0d 0a 4c 56 41 4c |" error |*/..LVAL|
|00000f40| 20 78 6c 62 61 64 74 79 | 70 65 28 61 72 67 29 0d | xlbadty|pe(arg).|
|00000f50| 0a 20 20 4c 56 41 4c 20 | 61 72 67 3b 0d 0a 7b 0d |. LVAL |arg;..{.|
|00000f60| 0a 20 20 20 20 72 65 74 | 75 72 6e 20 78 6c 65 72 |. ret|urn xler|
|00000f70| 72 6f 72 28 22 62 61 64 | 20 61 72 67 75 6d 65 6e |ror("bad| argumen|
|00000f80| 74 20 74 79 70 65 22 2c | 61 72 67 29 3b 0d 0a 7d |t type",|arg);..}|
|00000f90| 0d 0a 0d 0a 0d 0a 54 68 | 65 6e 20 72 65 70 6c 61 |......Th|en repla|
|00000fa0| 63 65 20 61 6c 6c 20 6f | 63 63 75 72 61 6e 63 65 |ce all o|ccurance|
|00000fb0| 73 20 6f 66 20 60 78 6c | 65 72 72 6f 72 28 22 62 |s of `xl|error("b|
|00000fc0| 61 64 20 61 72 67 75 6d | 65 6e 74 20 74 79 70 65 |ad argum|ent type|
|00000fd0| 22 2c 27 20 77 69 74 68 | 0d 0a 60 78 6c 62 61 64 |",' with|..`xlbad|
|00000fe0| 74 79 70 65 28 27 20 74 | 68 72 6f 75 67 68 6f 75 |type(' t|hroughou|
|00000ff0| 74 20 74 68 65 20 70 72 | 6f 67 72 61 6d 20 28 69 |t the pr|ogram (i|
|00001000| 6e 63 6c 75 64 69 6e 67 | 20 78 6c 69 73 70 2e 68 |ncluding| xlisp.h|
|00001010| 29 2e 0d 0a 0d 0a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |).....**|********|
|00001020| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00001030| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 0d 0a 0d |********|*****...|
|00001040| 0a 41 64 64 20 74 68 65 | 20 66 69 6c 65 20 78 6c |.Add the| file xl|
|00001050| 73 65 71 2e 63 20 74 6f | 20 79 6f 75 72 20 22 6d |seq.c to| your "m|
|00001060| 61 6b 65 66 69 6c 65 22 | 20 69 6e 20 61 6e 20 61 |akefile"| in an a|
|00001070| 70 70 72 6f 70 72 69 61 | 74 65 20 6d 61 6e 6e 65 |ppropria|te manne|
|00001080| 72 2e 0d 0a 0d 0a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |r.....**|********|
|00001090| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000010a0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 0d 0a 41 |********|*****..A|
|000010b0| 64 64 20 64 65 66 69 6e | 69 74 69 6f 6e 20 69 6e |dd defin|ition in|
|000010c0| 20 78 6c 69 73 70 2e 68 | 3a 0d 0a 0d 0a 23 64 65 | xlisp.h|:....#de|
|000010d0| 66 69 6e 65 20 78 6c 67 | 61 73 74 72 6f 72 73 79 |fine xlg|astrorsy|
|000010e0| 6d 28 29 20 20 28 74 65 | 73 74 61 72 67 28 73 79 |m() (te|starg(sy|
|000010f0| 6d 62 6f 6c 70 28 2a 78 | 6c 61 72 67 76 29 20 3f |mbolp(*x|largv) ?|
|00001100| 20 67 65 74 70 6e 61 6d | 65 28 6e 65 78 74 61 72 | getpnam|e(nextar|
|00001110| 67 28 29 29 20 3a 20 74 | 79 70 65 61 72 67 28 73 |g()) : t|ypearg(s|
|00001120| 74 72 69 6e 67 70 29 29 | 29 0d 0a 0d 0a 41 64 64 |tringp))|)....Add|
|00001130| 65 64 20 65 78 74 65 72 | 6e 61 6c 20 64 65 63 6c |ed exter|nal decl|
|00001140| 61 72 61 74 69 6f 6e 20 | 69 6e 20 78 6c 69 73 70 |aration |in xlisp|
|00001150| 2e 68 3a 0d 0a 65 78 74 | 65 72 6e 20 4c 56 41 4c |.h:..ext|ern LVAL|
|00001160| 20 78 6c 62 61 64 74 79 | 70 65 28 29 3b 20 20 20 | xlbadty|pe(); |
|00001170| 20 20 20 20 20 2f 2a 20 | 72 65 70 6f 72 74 20 22 | /* |report "|
|00001180| 62 61 64 20 61 72 67 75 | 6d 65 6e 74 20 74 79 70 |bad argu|ment typ|
|00001190| 65 22 20 65 72 72 6f 72 | 20 2a 2f 0d 0a 0d 0a 0d |e" error| */.....|
|000011a0| 0a 0d 0a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |...*****|********|
|000011b0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000011c0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 0d 0a 41 64 64 20 |********|**..Add |
|000011d0| 74 6f 20 69 6e 69 74 2e | 6c 73 70 3a 0d 0a 28 75 |to init.|lsp:..(u|
|000011e0| 6e 6c 65 73 73 20 28 66 | 62 6f 75 6e 64 70 20 27 |nless (f|boundp '|
|000011f0| 73 74 72 63 61 74 29 20 | 3b 20 62 61 63 6b 77 61 |strcat) |; backwa|
|00001200| 72 64 73 20 63 6f 6d 70 | 61 74 69 62 69 6c 69 74 |rds comp|atibilit|
|00001210| 79 20 0d 0a 20 20 20 20 | 28 64 65 66 6d 61 63 72 |y .. |(defmacr|
|00001220| 6f 20 73 74 72 63 61 74 | 20 28 26 72 65 73 74 20 |o strcat| (&rest |
|00001230| 73 74 72 29 20 60 28 63 | 6f 6e 63 61 74 65 6e 61 |str) `(c|oncatena|
|00001240| 74 65 20 27 73 74 72 69 | 6e 67 20 2c 40 73 74 72 |te 'stri|ng ,@str|
|00001250| 29 29 29 0d 0a 0d 0a 0d | 0a 0d 0a 2a 2a 2a 2a 2a |))).....|...*****|
|00001260| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00001270| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00001280| 2a 2a 0d 0a 49 6e 20 78 | 6c 66 74 61 62 2e 63 2c |**..In x|lftab.c,|
|00001290| 20 61 64 64 20 74 68 65 | 20 66 6f 6c 6c 6f 77 69 | add the| followi|
|000012a0| 6e 67 20 65 78 74 65 72 | 6e 61 6c 20 64 65 63 6c |ng exter|nal decl|
|000012b0| 61 72 61 74 69 6f 6e 3a | 0d 0a 65 78 74 65 72 6e |aration:|..extern|
|000012c0| 20 4c 56 41 4c 0d 0a 20 | 20 20 20 78 63 6f 65 72 | LVAL.. | xcoer|
|000012d0| 63 65 28 29 2c 20 78 63 | 6f 6e 63 61 74 65 6e 61 |ce(), xc|oncatena|
|000012e0| 74 65 28 29 2c 20 78 65 | 6c 74 28 29 2c 20 78 6d |te(), xe|lt(), xm|
|000012f0| 61 70 28 29 2c 20 78 73 | 65 61 72 63 68 28 29 2c |ap(), xs|earch(),|
|00001300| 20 78 70 6f 73 69 74 69 | 6f 6e 69 66 28 29 2c 0d | xpositi|onif(),.|
|00001310| 0a 20 20 20 20 78 63 6f | 75 6e 74 69 66 28 29 2c |. xco|untif(),|
|00001320| 78 66 69 6e 64 69 66 28 | 29 3b 0d 0a 0d 0a 64 65 |xfindif(|);....de|
|00001330| 6c 65 74 65 20 74 68 65 | 20 64 65 63 6c 61 72 61 |lete the| declara|
|00001340| 74 69 6f 6e 20 66 6f 72 | 20 78 73 74 72 63 61 74 |tion for| xstrcat|
|00001350| 2e 0d 0a 0d 0a 49 6e 20 | 66 75 6e 74 61 62 5b 5d |.....In |funtab[]|
|00001360| 2c 20 72 65 70 6c 61 63 | 65 20 74 68 65 20 64 65 |, replac|e the de|
|00001370| 66 69 6e 69 74 69 6f 6e | 20 66 6f 72 20 53 54 52 |finition| for STR|
|00001380| 43 41 54 20 77 69 74 68 | 3a 0d 0a 0d 0a 7b 20 20 |CAT with|:....{ |
|00001390| 20 22 43 4f 4e 43 41 54 | 45 4e 41 54 45 22 2c 20 | "CONCAT|ENATE", |
|000013a0| 20 20 20 20 20 53 2c 20 | 78 63 6f 6e 63 61 74 65 | S, |xconcate|
|000013b0| 6e 61 74 65 20 7d 2c 20 | 2f 2a 20 31 36 38 20 2a |nate }, |/* 168 *|
|000013c0| 2f 0d 0a 0d 0a 52 65 70 | 6c 61 63 65 20 4e 55 4c |/....Rep|lace NUL|
|000013d0| 4c 20 64 65 66 69 6e 69 | 74 69 6f 6e 73 20 61 74 |L defini|tions at|
|000013e0| 20 74 68 65 20 65 6e 64 | 20 6f 66 20 74 68 65 20 | the end| of the |
|000013f0| 74 61 62 6c 65 20 77 69 | 74 68 20 6e 65 77 20 64 |table wi|th new d|
|00001400| 65 66 69 6e 69 74 69 6f | 6e 73 2c 0d 0a 62 65 69 |efinitio|ns,..bei|
|00001410| 6e 67 20 73 75 72 65 20 | 74 6f 20 6b 65 65 70 20 |ng sure |to keep |
|00001420| 74 68 65 20 74 61 62 6c | 65 20 6c 65 6e 67 74 68 |the tabl|e length|
|00001430| 20 63 6f 6e 73 74 61 6e | 74 2e 0d 0a 0d 0a 7b 20 | constan|t.....{ |
|00001440| 20 20 22 43 4f 55 4e 54 | 2d 49 46 22 2c 20 20 20 | "COUNT|-IF", |
|00001450| 20 20 20 20 20 20 53 2c | 20 78 63 6f 75 6e 74 69 | S,| xcounti|
|00001460| 66 20 20 20 20 20 7d 2c | 20 2f 2a 20 32 38 37 20 |f },| /* 287 |
|00001470| 2a 2f 0d 0a 7b 20 20 20 | 22 46 49 4e 44 2d 49 46 |*/..{ |"FIND-IF|
|00001480| 22 2c 20 20 20 20 20 20 | 20 20 20 20 53 2c 20 78 |", | S, x|
|00001490| 66 69 6e 64 69 66 20 20 | 20 20 20 20 7d 2c 20 2f |findif | }, /|
|000014a0| 2a 20 32 38 38 20 2a 2f | 0d 0a 7b 20 20 20 22 43 |* 288 */|..{ "C|
|000014b0| 4f 45 52 43 45 22 2c 20 | 20 20 20 20 20 20 20 20 |OERCE", | |
|000014c0| 20 20 53 2c 20 78 63 6f | 65 72 63 65 20 20 20 20 | S, xco|erce |
|000014d0| 20 20 7d 2c 20 2f 2a 20 | 32 38 39 20 2a 2f 0d 0a | }, /* |289 */..|
|000014e0| 7b 20 20 20 22 45 4c 54 | 22 2c 20 20 20 20 20 20 |{ "ELT|", |
|000014f0| 20 20 20 20 20 20 20 20 | 53 2c 20 78 65 6c 74 20 | |S, xelt |
|00001500| 20 20 20 20 20 20 20 20 | 7d 2c 20 2f 2a 20 32 39 | |}, /* 29|
|00001510| 30 20 2a 2f 0d 0a 7b 20 | 20 20 22 4d 41 50 22 2c |0 */..{ | "MAP",|
|00001520| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 53 2c | | S,|
|00001530| 20 78 6d 61 70 20 20 20 | 20 20 20 20 20 20 7d 2c | xmap | },|
|00001540| 20 2f 2a 20 32 39 31 20 | 2a 2f 0d 0a 7b 20 20 20 | /* 291 |*/..{ |
|00001550| 22 50 4f 53 49 54 49 4f | 4e 2d 49 46 22 2c 20 20 |"POSITIO|N-IF", |
|00001560| 20 20 20 20 53 2c 20 78 | 70 6f 73 69 74 69 6f 6e | S, x|position|
|00001570| 69 66 20 20 7d 2c 20 2f | 2a 20 32 39 32 20 2a 2f |if }, /|* 292 */|
|00001580| 0d 0a 7b 20 20 20 22 53 | 45 41 52 43 48 22 2c 20 |..{ "S|EARCH", |
|00001590| 20 20 20 20 20 20 20 20 | 20 20 53 2c 20 78 73 65 | | S, xse|
|000015a0| 61 72 63 68 20 20 20 20 | 20 20 7d 2c 20 2f 2a 20 |arch | }, /* |
|000015b0| 32 39 33 20 2a 2f 0d 0a | 0d 0a 2a 2a 2a 2a 2a 2a |293 */..|..******|
|000015c0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000015d0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 0d 0a 0d 0a 49 6e 20 |********|*....In |
|000015e0| 66 69 6c 65 20 78 6c 67 | 6c 6f 62 2e 63 2c 20 61 |file xlg|lob.c, a|
|000015f0| 64 64 20 74 68 65 20 66 | 6f 6c 6c 6f 77 69 6e 67 |dd the f|ollowing|
|00001600| 20 64 65 66 69 6e 69 74 | 69 6f 6e 3a 0d 0a 0d 0a | definit|ion:....|
|00001610| 4c 56 41 4c 20 73 5f 65 | 6c 74 20 3d 20 4e 49 4c |LVAL s_e|lt = NIL|
|00001620| 3b 0d 0a 0d 0a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |;....***|********|
|00001630| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00001640| 2a 2a 2a 2a 0d 0a 0d 0a | 49 6e 20 66 69 6c 65 20 |****....|In file |
|00001650| 78 6c 69 6e 69 74 2e 63 | 2c 20 61 64 64 20 74 68 |xlinit.c|, add th|
|00001660| 65 20 66 6f 6c 6c 6f 77 | 69 6e 67 20 65 78 74 65 |e follow|ing exte|
|00001670| 72 6e 61 6c 20 64 65 63 | 6c 61 72 61 74 69 6f 6e |rnal dec|laration|
|00001680| 3a 0d 0a 0d 0a 65 78 74 | 65 72 6e 20 4c 56 41 4c |:....ext|ern LVAL|
|00001690| 20 73 5f 65 6c 74 3b 0d | 0a 0d 0a 69 6e 20 66 75 | s_elt;.|...in fu|
|000016a0| 6e 63 74 69 6f 6e 20 78 | 6c 73 79 6d 62 6f 6c 73 |nction x|lsymbols|
|000016b0| 28 29 2c 20 69 6e 20 73 | 65 63 74 69 6f 6e 20 22 |(), in s|ection "|
|000016c0| 65 6e 74 65 72 20 73 65 | 74 66 20 70 6c 61 63 65 |enter se|tf place|
|000016d0| 20 73 70 65 63 69 66 69 | 65 72 73 22 2c 20 61 64 | specifi|ers", ad|
|000016e0| 64 0d 0a 0d 0a 20 20 20 | 20 73 5f 65 6c 74 20 20 |d.... | s_elt |
|000016f0| 20 3d 20 78 6c 65 6e 74 | 65 72 28 22 45 4c 54 22 | = xlent|er("ELT"|
|00001700| 29 3b 0d 0a 0d 0a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |);....**|********|
|00001710| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00001720| 2a 2a 2a 2a 2a 0d 0a 0d | 0a 49 6e 20 66 69 6c 65 |*****...|.In file|
|00001730| 20 78 6c 62 66 75 6e 2e | 63 2c 20 66 75 6e 63 74 | xlbfun.|c, funct|
|00001740| 69 6f 6e 20 78 61 72 65 | 66 28 29 2c 20 63 68 61 |ion xare|f(), cha|
|00001750| 6e 67 65 0d 0a 0d 0a 20 | 20 20 20 61 72 72 61 79 |nge.... | array|
|00001760| 20 3d 20 78 6c 67 61 76 | 65 63 74 6f 72 28 29 3b | = xlgav|ector();|
|00001770| 0d 0a 0d 0a 74 6f 0d 0a | 0d 0a 20 20 20 20 61 72 |....to..|.. ar|
|00001780| 72 61 79 20 3d 20 78 6c | 67 65 74 61 72 67 28 29 |ray = xl|getarg()|
|00001790| 3b 0d 0a 0d 0a 42 65 66 | 6f 72 65 20 74 68 65 20 |;....Bef|ore the |
|000017a0| 73 65 63 74 69 6f 6e 20 | 74 69 74 6c 65 64 20 22 |section |titled "|
|000017b0| 72 61 6e 67 65 20 63 68 | 65 63 6b 20 74 68 65 20 |range ch|eck the |
|000017c0| 69 6e 64 65 78 22 20 61 | 64 64 3a 0d 0a 0d 0a 20 |index" a|dd:.... |
|000017d0| 20 20 20 69 66 20 28 73 | 74 72 69 6e 67 70 28 61 | if (s|tringp(a|
|000017e0| 72 72 61 79 29 29 20 7b | 20 20 20 2f 2a 20 65 78 |rray)) {| /* ex|
|000017f0| 74 65 6e 73 69 6f 6e 20 | 2d 2d 20 61 6c 6c 6f 77 |tension |-- allow|
|00001800| 20 66 65 74 63 68 69 6e | 67 20 63 68 61 72 73 20 | fetchin|g chars |
|00001810| 66 72 6f 6d 20 73 74 72 | 69 6e 67 2a 2f 0d 0a 20 |from str|ing*/.. |
|00001820| 20 20 20 20 20 20 20 69 | 66 20 28 69 20 3c 20 30 | i|f (i < 0|
|00001830| 20 7c 7c 20 69 20 3e 3d | 20 67 65 74 73 6c 65 6e | || i >=| getslen|
|00001840| 67 74 68 28 61 72 72 61 | 79 29 2d 31 29 0d 0a 20 |gth(arra|y)-1).. |
|00001850| 20 20 20 20 20 20 20 20 | 20 20 20 78 6c 65 72 72 | | xlerr|
|00001860| 6f 72 28 22 73 74 72 69 | 6e 67 20 69 6e 64 65 78 |or("stri|ng index|
|00001870| 20 6f 75 74 20 6f 66 20 | 62 6f 75 6e 64 73 22 2c | out of |bounds",|
|00001880| 69 6e 64 65 78 29 3b 0d | 0a 20 20 20 20 20 20 20 |index);.|. |
|00001890| 20 72 65 74 75 72 6e 20 | 28 63 76 63 68 61 72 28 | return |(cvchar(|
|000018a0| 61 72 72 61 79 2d 3e 6e | 5f 73 74 72 69 6e 67 5b |array->n|_string[|
|000018b0| 69 5d 29 29 3b 0d 0a 20 | 20 20 20 7d 0d 0a 20 20 |i]));.. | }.. |
|000018c0| 20 20 0d 0a 20 20 20 20 | 69 66 20 28 21 76 65 63 | .. |if (!vec|
|000018d0| 74 6f 72 70 28 61 72 72 | 61 79 29 29 20 78 6c 62 |torp(arr|ay)) xlb|
|000018e0| 61 64 74 79 70 65 28 61 | 72 72 61 79 29 3b 20 20 |adtype(a|rray); |
|000018f0| 2f 2a 20 74 79 70 65 20 | 6d 75 73 74 20 62 65 20 |/* type |must be |
|00001900| 61 72 72 61 79 20 2a 2f | 0d 0a 0d 0a 2a 2a 2a 2a |array */|....****|
|00001910| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00001920| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 0d 0a 49 6e 20 78 |********|**..In x|
|00001930| 6c 63 6f 6e 74 2e 63 2c | 20 61 64 64 20 74 68 65 |lcont.c,| add the|
|00001940| 20 66 6f 6c 6c 6f 77 69 | 6e 67 20 64 65 63 6c 61 | followi|ng decla|
|00001950| 72 61 74 69 6f 6e 3a 0d | 0a 0d 0a 65 78 74 65 72 |ration:.|...exter|
|00001960| 6e 20 4c 56 41 4c 20 73 | 5f 65 6c 74 3b 0d 0a 0d |n LVAL s|_elt;...|
|00001970| 0a 0d 0a 49 6e 20 66 75 | 6e 63 74 69 6f 6e 20 70 |...In fu|nction p|
|00001980| 6c 61 63 65 66 6f 72 6d | 28 29 2c 20 72 65 70 6c |laceform|(), repl|
|00001990| 61 63 65 20 74 68 65 20 | 66 75 6e 20 3d 3d 20 73 |ace the |fun == s|
|000019a0| 5f 61 72 65 66 20 63 6f | 64 65 20 77 69 74 68 3a |_aref co|de with:|
|000019b0| 0d 0a 0d 0a 20 20 20 20 | 20 20 20 20 78 6c 73 61 |.... | xlsa|
|000019c0| 76 65 31 28 61 72 67 31 | 29 3b 0d 0a 0d 0a 20 20 |ve1(arg1|);.... |
|000019d0| 20 20 20 20 20 20 61 72 | 67 31 20 3d 20 65 76 61 | ar|g1 = eva|
|000019e0| 72 67 28 26 70 6c 61 63 | 65 29 3b 20 20 20 2f 2a |rg(&plac|e); /*|
|000019f0| 20 61 6c 6c 6f 77 20 73 | 74 72 69 6e 67 20 61 72 | allow s|tring ar|
|00001a00| 67 75 6d 65 6e 74 20 2a | 2f 0d 0a 20 20 20 20 20 |gument *|/.. |
|00001a10| 20 20 20 61 72 67 32 20 | 3d 20 65 76 6d 61 74 63 | arg2 |= evmatc|
|00001a20| 68 28 46 49 58 4e 55 4d | 2c 26 70 6c 61 63 65 29 |h(FIXNUM|,&place)|
|00001a30| 3b 20 69 20 3d 20 67 65 | 74 66 69 78 6e 75 6d 28 |; i = ge|tfixnum(|
|00001a40| 61 72 67 32 29 3b 0d 0a | 20 20 20 20 20 20 20 20 |arg2);..| |
|00001a50| 69 66 20 28 70 6c 61 63 | 65 29 20 74 6f 6f 6d 61 |if (plac|e) tooma|
|00001a60| 6e 79 28 70 6c 61 63 65 | 29 3b 0d 0a 0d 0a 20 20 |ny(place|);.... |
|00001a70| 20 20 20 20 20 20 69 66 | 20 28 73 74 72 69 6e 67 | if| (string|
|00001a80| 70 28 61 72 67 31 29 29 | 20 7b 20 20 20 20 2f 2a |p(arg1))| { /*|
|00001a90| 20 65 78 74 65 6e 73 69 | 6f 6e 20 66 6f 72 20 73 | extensi|on for s|
|00001aa0| 74 72 69 6e 67 73 20 2a | 2f 0d 0a 20 20 20 20 20 |trings *|/.. |
|00001ab0| 20 20 20 20 20 20 20 69 | 66 20 28 69 20 3c 20 30 | i|f (i < 0|
|00001ac0| 20 7c 7c 20 69 20 3e 3d | 20 67 65 74 73 6c 65 6e | || i >=| getslen|
|00001ad0| 67 74 68 28 61 72 67 31 | 29 2d 31 29 0d 0a 20 20 |gth(arg1|)-1).. |
|00001ae0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 78 6c | | xl|
|00001af0| 65 72 72 6f 72 28 22 69 | 6e 64 65 78 20 6f 75 74 |error("i|ndex out|
|00001b00| 20 6f 66 20 72 61 6e 67 | 65 22 2c 61 72 67 32 29 | of rang|e",arg2)|
|00001b10| 3b 0d 0a 20 20 20 20 20 | 20 20 20 20 20 20 20 69 |;.. | i|
|00001b20| 66 20 28 21 63 68 61 72 | 70 28 76 61 6c 75 65 29 |f (!char|p(value)|
|00001b30| 29 20 0d 0a 20 20 20 20 | 20 20 20 20 20 20 20 20 |) .. | |
|00001b40| 20 20 20 20 78 6c 65 72 | 72 6f 72 28 22 73 74 72 | xler|ror("str|
|00001b50| 69 6e 67 73 20 6f 6e 6c | 79 20 63 6f 6e 74 61 69 |ings onl|y contai|
|00001b60| 6e 20 63 68 61 72 61 63 | 74 65 72 73 22 2c 76 61 |n charac|ters",va|
|00001b70| 6c 75 65 29 3b 0d 0a 20 | 20 20 20 20 20 20 20 20 |lue);.. | |
|00001b80| 20 20 20 61 72 67 31 2d | 3e 6e 5f 73 74 72 69 6e | arg1-|>n_strin|
|00001b90| 67 5b 69 5d 20 3d 20 67 | 65 74 63 68 63 6f 64 65 |g[i] = g|etchcode|
|00001ba0| 28 76 61 6c 75 65 29 3b | 0d 0a 20 20 20 20 20 20 |(value);|.. |
|00001bb0| 20 20 7d 0d 0a 20 20 20 | 20 20 20 20 20 65 6c 73 | }.. | els|
|00001bc0| 65 20 69 66 28 76 65 63 | 74 6f 72 70 28 61 72 67 |e if(vec|torp(arg|
|00001bd0| 31 29 29 20 7b 0d 0a 20 | 20 20 20 20 20 20 20 20 |1)) {.. | |
|00001be0| 20 20 20 69 66 20 28 69 | 20 3c 20 30 20 7c 7c 20 | if (i| < 0 || |
|00001bf0| 69 20 3e 3d 20 67 65 74 | 73 69 7a 65 28 61 72 67 |i >= get|size(arg|
|00001c00| 31 29 29 0d 0a 20 20 20 | 20 20 20 20 20 20 20 20 |1)).. | |
|00001c10| 20 20 20 20 20 78 6c 65 | 72 72 6f 72 28 22 69 6e | xle|rror("in|
|00001c20| 64 65 78 20 6f 75 74 20 | 6f 66 20 72 61 6e 67 65 |dex out |of range|
|00001c30| 22 2c 61 72 67 32 29 3b | 0d 0a 20 20 20 20 20 20 |",arg2);|.. |
|00001c40| 20 20 20 20 20 20 73 65 | 74 65 6c 65 6d 65 6e 74 | se|telement|
|00001c50| 28 61 72 67 31 2c 28 69 | 6e 74 29 69 2c 76 61 6c |(arg1,(i|nt)i,val|
|00001c60| 75 65 29 3b 0d 0a 20 20 | 20 20 20 20 20 20 7d 0d |ue);.. | }.|
|00001c70| 0a 20 20 20 20 20 20 20 | 20 65 6c 73 65 20 78 6c |. | else xl|
|00001c80| 62 61 64 74 79 70 65 28 | 61 72 67 31 29 3b 0d 0a |badtype(|arg1);..|
|00001c90| 20 20 20 20 20 20 20 20 | 78 6c 70 6f 70 28 29 3b | |xlpop();|
|00001ca0| 0d 0a 0d 0a 54 68 65 6e | 20 61 64 64 20 74 68 65 |....Then| add the|
|00001cb0| 20 66 6f 6c 6c 6f 77 69 | 6e 67 20 22 63 61 73 65 | followi|ng "case|
|00001cc0| 22 3a 0d 0a 0d 0a 20 20 | 20 20 65 6c 73 65 20 69 |":.... | else i|
|00001cd0| 66 20 28 66 75 6e 20 3d | 3d 20 73 5f 65 6c 74 29 |f (fun =|= s_elt)|
|00001ce0| 20 7b 0d 0a 20 20 20 20 | 20 20 20 20 78 6c 73 61 | {.. | xlsa|
|00001cf0| 76 65 31 28 61 72 67 31 | 29 3b 0d 0a 20 20 20 20 |ve1(arg1|);.. |
|00001d00| 20 20 20 20 61 72 67 31 | 20 3d 20 65 76 61 72 67 | arg1| = evarg|
|00001d10| 28 26 70 6c 61 63 65 29 | 3b 0d 0a 20 20 20 20 20 |(&place)|;.. |
|00001d20| 20 20 20 61 72 67 32 20 | 3d 20 65 76 6d 61 74 63 | arg2 |= evmatc|
|00001d30| 68 28 46 49 58 4e 55 4d | 2c 26 70 6c 61 63 65 29 |h(FIXNUM|,&place)|
|00001d40| 3b 20 69 20 3d 20 67 65 | 74 66 69 78 6e 75 6d 28 |; i = ge|tfixnum(|
|00001d50| 61 72 67 32 29 3b 0d 0a | 20 20 20 20 20 20 20 20 |arg2);..| |
|00001d60| 69 66 20 28 70 6c 61 63 | 65 29 20 74 6f 6f 6d 61 |if (plac|e) tooma|
|00001d70| 6e 79 28 70 6c 61 63 65 | 29 3b 0d 0a 20 20 20 20 |ny(place|);.. |
|00001d80| 20 20 20 20 69 66 20 28 | 6c 69 73 74 70 28 61 72 | if (|listp(ar|
|00001d90| 67 31 29 29 20 7b 0d 0a | 20 20 20 20 20 20 20 20 |g1)) {..| |
|00001da0| 20 20 20 20 66 6f 72 20 | 28 3b 20 69 20 3e 20 30 | for |(; i > 0|
|00001db0| 20 26 26 20 63 6f 6e 73 | 70 28 61 72 67 31 29 3b | && cons|p(arg1);|
|00001dc0| 20 2d 2d 69 29 0d 0a 20 | 20 20 20 20 20 20 20 20 | --i).. | |
|00001dd0| 20 20 20 20 20 20 20 61 | 72 67 31 20 3d 20 63 64 | a|rg1 = cd|
|00001de0| 72 28 61 72 67 31 29 3b | 0d 0a 20 20 20 20 20 20 |r(arg1);|.. |
|00001df0| 20 20 20 20 20 20 69 66 | 28 28 21 63 6f 6e 73 70 | if|((!consp|
|00001e00| 28 61 72 67 31 29 29 20 | 7c 7c 20 69 20 3c 20 30 |(arg1)) ||| i < 0|
|00001e10| 29 0d 0a 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |).. | |
|00001e20| 20 20 20 78 6c 65 72 72 | 6f 72 28 22 69 6e 64 65 | xlerr|or("inde|
|00001e30| 78 20 6f 75 74 20 6f 66 | 20 72 61 6e 67 65 22 2c |x out of| range",|
|00001e40| 61 72 67 32 29 3b 0d 0a | 20 20 20 20 20 20 20 20 |arg2);..| |
|00001e50| 20 20 20 20 72 70 6c 61 | 63 61 28 61 72 67 31 2c | rpla|ca(arg1,|
|00001e60| 76 61 6c 75 65 29 3b 0d | 0a 20 20 20 20 20 20 20 |value);.|. |
|00001e70| 20 7d 0d 0a 20 20 20 20 | 20 20 20 20 65 6c 73 65 | }.. | else|
|00001e80| 20 69 66 20 28 6e 74 79 | 70 65 28 61 72 67 31 29 | if (nty|pe(arg1)|
|00001e90| 20 3d 3d 20 53 54 52 49 | 4e 47 29 20 7b 0d 0a 20 | == STRI|NG) {.. |
|00001ea0| 20 20 20 20 20 20 20 20 | 20 20 20 69 66 20 28 69 | | if (i|
|00001eb0| 20 3c 20 30 20 7c 7c 20 | 69 20 3e 3d 20 67 65 74 | < 0 || |i >= get|
|00001ec0| 73 6c 65 6e 67 74 68 28 | 61 72 67 31 29 2d 31 29 |slength(|arg1)-1)|
|00001ed0| 0d 0a 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |.. | |
|00001ee0| 20 20 78 6c 65 72 72 6f | 72 28 22 69 6e 64 65 78 | xlerro|r("index|
|00001ef0| 20 6f 75 74 20 6f 66 20 | 72 61 6e 67 65 22 2c 61 | out of |range",a|
|00001f00| 72 67 32 29 3b 0d 0a 20 | 20 20 20 20 20 20 20 20 |rg2);.. | |
|00001f10| 20 20 20 69 66 20 28 21 | 63 68 61 72 70 28 76 61 | if (!|charp(va|
|00001f20| 6c 75 65 29 29 20 0d 0a | 20 20 20 20 20 20 20 20 |lue)) ..| |
|00001f30| 20 20 20 20 20 20 20 20 | 78 6c 65 72 72 6f 72 28 | |xlerror(|
|00001f40| 22 73 74 72 69 6e 67 73 | 20 6f 6e 6c 79 20 63 6f |"strings| only co|
|00001f50| 6e 74 61 69 6e 20 63 68 | 61 72 61 63 74 65 72 73 |ntain ch|aracters|
|00001f60| 22 2c 76 61 6c 75 65 29 | 3b 0d 0a 20 20 20 20 20 |",value)|;.. |
|00001f70| 20 20 20 20 20 20 20 61 | 72 67 31 2d 3e 6e 5f 73 | a|rg1->n_s|
|00001f80| 74 72 69 6e 67 5b 69 5d | 20 3d 20 67 65 74 63 68 |tring[i]| = getch|
|00001f90| 63 6f 64 65 28 76 61 6c | 75 65 29 3b 0d 0a 20 20 |code(val|ue);.. |
|00001fa0| 20 20 20 20 20 20 7d 0d | 0a 20 20 20 20 20 20 20 | }.|. |
|00001fb0| 20 65 6c 73 65 20 69 66 | 20 28 6e 74 79 70 65 28 | else if| (ntype(|
|00001fc0| 61 72 67 31 29 20 3d 3d | 20 56 45 43 54 4f 52 29 |arg1) ==| VECTOR)|
|00001fd0| 20 7b 0d 0a 20 20 20 20 | 20 20 20 20 20 20 20 20 | {.. | |
|00001fe0| 69 66 20 28 69 20 3c 20 | 30 20 7c 7c 20 69 20 3e |if (i < |0 || i >|
|00001ff0| 3d 20 67 65 74 73 69 7a | 65 28 61 72 67 31 29 29 |= getsiz|e(arg1))|
|00002000| 0d 0a 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |.. | |
|00002010| 20 20 78 6c 65 72 72 6f | 72 28 22 69 6e 64 65 78 | xlerro|r("index|
|00002020| 20 6f 75 74 20 6f 66 20 | 72 61 6e 67 65 22 2c 61 | out of |range",a|
|00002030| 72 67 32 29 3b 0d 0a 20 | 20 20 20 20 20 20 20 20 |rg2);.. | |
|00002040| 20 20 20 73 65 74 65 6c | 65 6d 65 6e 74 28 61 72 | setel|ement(ar|
|00002050| 67 31 2c 28 69 6e 74 29 | 69 2c 76 61 6c 75 65 29 |g1,(int)|i,value)|
|00002060| 3b 0d 0a 20 20 20 20 20 | 20 20 20 7d 0d 0a 20 20 |;.. | }.. |
|00002070| 20 20 20 20 20 20 65 6c | 73 65 20 78 6c 62 61 64 | el|se xlbad|
|00002080| 74 79 70 65 28 61 72 67 | 31 29 3b 0d 0a 20 20 20 |type(arg|1);.. |
|00002090| 20 20 20 20 20 78 6c 70 | 6f 70 28 29 3b 0d 0a 20 | xlp|op();.. |
|000020a0| 20 20 20 7d 0d 0a 0d 0a | 2a 2a 2a 2a 2a 2a 2a 2a | }....|********|
|000020b0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000020c0| 2a 2a 2a 0d 0a 0d 0a 49 | 6e 20 78 6c 73 74 72 2e |***....I|n xlstr.|
|000020d0| 63 2c 20 66 75 6e 63 74 | 69 6f 6e 20 63 68 61 6e |c, funct|ion chan|
|000020e0| 67 65 63 61 73 65 28 29 | 2c 20 63 68 61 6e 67 65 |gecase()|, change|
|000020f0| 0d 0a 0d 0a 20 20 20 20 | 73 72 63 20 3d 20 78 6c |.... |src = xl|
|00002100| 67 61 73 74 72 69 6e 67 | 28 29 3b 0d 0a 0d 0a 74 |gastring|();....t|
|00002110| 6f 0d 0a 0d 0a 20 20 20 | 20 73 72 63 20 3d 20 28 |o.... | src = (|
|00002120| 64 65 73 74 72 75 63 74 | 69 76 65 3f 20 78 6c 67 |destruct|ive? xlg|
|00002130| 61 73 74 72 69 6e 67 28 | 29 20 3a 20 78 6c 67 61 |astring(|) : xlga|
|00002140| 73 74 72 6f 72 73 79 6d | 28 29 29 3b 0d 0a 0d 0a |strorsym|());....|
|00002150| 0d 0a 49 6e 20 66 75 6e | 63 74 69 6f 6e 20 73 74 |..In fun|ction st|
|00002160| 72 63 6f 6d 70 61 72 65 | 28 29 2c 20 63 68 61 6e |rcompare|(), chan|
|00002170| 67 65 20 72 65 66 65 72 | 65 6e 63 65 73 20 74 6f |ge refer|ences to|
|00002180| 20 78 6c 67 61 73 74 72 | 69 6e 67 20 74 6f 20 78 | xlgastr|ing to x|
|00002190| 6c 67 61 73 74 72 6f 72 | 73 79 6d 2e 0d 0a 0d 0a |lgastror|sym.....|
|000021a0| 49 6e 20 66 75 6e 63 74 | 69 6f 6e 20 74 72 69 6d |In funct|ion trim|
|000021b0| 28 29 2c 20 63 68 61 6e | 67 65 20 72 65 66 65 72 |(), chan|ge refer|
|000021c0| 65 6e 63 65 73 20 74 6f | 20 78 6c 67 61 73 74 72 |ences to| xlgastr|
|000021d0| 69 6e 67 20 74 6f 20 78 | 6c 67 61 73 74 72 6f 72 |ing to x|lgastror|
|000021e0| 73 79 6d 2e 0d 0a 0d 0a | 0d 0a 44 65 6c 65 74 65 |sym.....|..Delete|
|000021f0| 20 66 75 6e 63 74 69 6f | 6e 73 20 78 73 74 72 63 | functio|ns xstrc|
|00002200| 61 74 28 29 20 61 6e 64 | 20 78 73 75 62 73 65 71 |at() and| xsubseq|
|00002210| 28 29 2e 20 20 54 68 65 | 20 6c 61 74 74 65 72 20 |(). The| latter |
|00002220| 69 73 20 72 65 77 72 69 | 74 74 65 6e 20 61 6e 64 |is rewri|tten and|
|00002230| 0d 0a 77 69 6c 6c 20 62 | 65 20 69 6e 20 61 20 6e |..will b|e in a n|
|00002240| 65 77 20 66 69 6c 65 2c | 20 78 6c 73 65 71 2e 63 |ew file,| xlseq.c|
|00002250| 0d 0a 0d 0a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |....****|********|
|00002260| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00002270| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 0d 0a 49 6e |********|****..In|
|00002280| 20 66 69 6c 65 20 78 6c | 73 79 73 2e 63 2c 20 61 | file xl|sys.c, a|
|00002290| 64 64 20 74 68 65 20 66 | 6f 6c 6c 6f 77 69 6e 67 |dd the f|ollowing|
|000022a0| 3a 0d 0a 0d 0a 69 6e 74 | 20 78 6c 63 76 74 74 79 |:....int| xlcvtty|
|000022b0| 70 65 28 61 72 67 29 20 | 20 2f 2a 20 66 69 6e 64 |pe(arg) | /* find|
|000022c0| 20 74 79 70 65 20 6f 66 | 20 61 72 67 75 6d 65 6e | type of| argumen|
|000022d0| 74 20 61 6e 64 20 72 65 | 74 75 72 6e 20 69 74 20 |t and re|turn it |
|000022e0| 2a 2f 0d 0a 4c 56 41 4c | 20 61 72 67 3b 0d 0a 7b |*/..LVAL| arg;..{|
|000022f0| 0d 0a 20 20 20 20 69 66 | 20 28 61 72 67 20 3d 3d |.. if| (arg ==|
|00002300| 20 61 5f 73 75 62 72 29 | 20 20 20 20 20 20 72 65 | a_subr)| re|
|00002310| 74 75 72 6e 20 53 55 42 | 52 3b 0d 0a 20 20 20 20 |turn SUB|R;.. |
|00002320| 69 66 20 28 61 72 67 20 | 3d 3d 20 61 5f 66 73 75 |if (arg |== a_fsu|
|00002330| 62 72 29 20 20 20 20 20 | 72 65 74 75 72 6e 20 46 |br) |return F|
|00002340| 53 55 42 52 3b 0d 0a 20 | 20 20 20 69 66 20 28 61 |SUBR;.. | if (a|
|00002350| 72 67 20 3d 3d 20 61 5f | 63 6f 6e 73 29 20 20 20 |rg == a_|cons) |
|00002360| 20 20 20 72 65 74 75 72 | 6e 20 43 4f 4e 53 3b 0d | retur|n CONS;.|
|00002370| 0a 20 20 20 20 69 66 20 | 28 61 72 67 20 3d 3d 20 |. if |(arg == |
|00002380| 61 5f 73 79 6d 62 6f 6c | 29 20 20 20 20 72 65 74 |a_symbol|) ret|
|00002390| 75 72 6e 20 53 59 4d 42 | 4f 4c 3b 0d 0a 20 20 20 |urn SYMB|OL;.. |
|000023a0| 20 69 66 20 28 61 72 67 | 20 3d 3d 20 61 5f 66 69 | if (arg| == a_fi|
|000023b0| 78 6e 75 6d 29 20 20 20 | 20 72 65 74 75 72 6e 20 |xnum) | return |
|000023c0| 46 49 58 4e 55 4d 3b 0d | 0a 20 20 20 20 69 66 20 |FIXNUM;.|. if |
|000023d0| 28 61 72 67 20 3d 3d 20 | 61 5f 66 6c 6f 6e 75 6d |(arg == |a_flonum|
|000023e0| 29 20 20 20 20 72 65 74 | 75 72 6e 20 46 4c 4f 4e |) ret|urn FLON|
|000023f0| 55 4d 3b 0d 0a 20 20 20 | 20 69 66 20 28 61 72 67 |UM;.. | if (arg|
|00002400| 20 3d 3d 20 61 5f 73 74 | 72 69 6e 67 29 20 20 20 | == a_st|ring) |
|00002410| 20 72 65 74 75 72 6e 20 | 53 54 52 49 4e 47 3b 0d | return |STRING;.|
|00002420| 0a 20 20 20 20 69 66 20 | 28 61 72 67 20 3d 3d 20 |. if |(arg == |
|00002430| 61 5f 6f 62 6a 65 63 74 | 29 20 20 20 20 72 65 74 |a_object|) ret|
|00002440| 75 72 6e 20 4f 42 4a 45 | 43 54 3b 0d 0a 20 20 20 |urn OBJE|CT;.. |
|00002450| 20 69 66 20 28 61 72 67 | 20 3d 3d 20 61 5f 73 74 | if (arg| == a_st|
|00002460| 72 65 61 6d 29 20 20 20 | 20 72 65 74 75 72 6e 20 |ream) | return |
|00002470| 53 54 52 45 41 4d 3b 0d | 0a 20 20 20 20 69 66 20 |STREAM;.|. if |
|00002480| 28 61 72 67 20 3d 3d 20 | 61 5f 76 65 63 74 6f 72 |(arg == |a_vector|
|00002490| 29 20 20 20 20 72 65 74 | 75 72 6e 20 56 45 43 54 |) ret|urn VECT|
|000024a0| 4f 52 3b 0d 0a 20 20 20 | 20 69 66 20 28 61 72 67 |OR;.. | if (arg|
|000024b0| 20 3d 3d 20 61 5f 63 6c | 6f 73 75 72 65 29 20 20 | == a_cl|osure) |
|000024c0| 20 72 65 74 75 72 6e 20 | 43 4c 4f 53 55 52 45 3b | return |CLOSURE;|
|000024d0| 0d 0a 20 20 20 20 69 66 | 20 28 61 72 67 20 3d 3d |.. if| (arg ==|
|000024e0| 20 61 5f 63 68 61 72 29 | 20 20 20 20 20 20 72 65 | a_char)| re|
|000024f0| 74 75 72 6e 20 43 48 41 | 52 3b 0d 0a 20 20 20 20 |turn CHA|R;.. |
|00002500| 69 66 20 28 61 72 67 20 | 3d 3d 20 61 5f 75 73 74 |if (arg |== a_ust|
|00002510| 72 65 61 6d 29 20 20 20 | 72 65 74 75 72 6e 20 55 |ream) |return U|
|00002520| 53 54 52 45 41 4d 3b 0d | 0a 20 20 20 20 72 65 74 |STREAM;.|. ret|
|00002530| 75 72 6e 20 30 3b 0d 0a | 7d 0d 0a 0d 0a 4c 4f 43 |urn 0;..|}....LOC|
|00002540| 41 4c 20 4c 56 41 4c 20 | 6c 69 73 74 69 66 79 28 |AL LVAL |listify(|
|00002550| 61 72 67 29 20 2f 2a 20 | 61 72 67 20 6d 75 73 74 |arg) /* |arg must|
|00002560| 20 62 65 20 76 65 63 74 | 6f 72 20 6f 72 20 73 74 | be vect|or or st|
|00002570| 72 69 6e 67 20 2a 2f 0d | 0a 4c 56 41 4c 20 61 72 |ring */.|.LVAL ar|
|00002580| 67 3b 0d 0a 7b 0d 0a 20 | 20 20 20 4c 56 41 4c 20 |g;..{.. | LVAL |
|00002590| 76 61 6c 3b 0d 0a 20 20 | 20 20 69 6e 74 20 69 3b |val;.. | int i;|
|000025a0| 0d 0a 20 20 20 20 0d 0a | 20 20 20 20 78 6c 73 61 |.. ..| xlsa|
|000025b0| 76 65 31 28 76 61 6c 29 | 3b 0d 0a 20 20 20 20 0d |ve1(val)|;.. .|
|000025c0| 0a 20 20 20 20 69 66 20 | 28 6e 74 79 70 65 28 61 |. if |(ntype(a|
|000025d0| 72 67 29 20 3d 3d 20 56 | 45 43 54 4f 52 29 20 7b |rg) == V|ECTOR) {|
|000025e0| 0d 0a 20 20 20 20 20 20 | 20 20 66 6f 72 20 28 69 |.. | for (i|
|000025f0| 20 3d 20 67 65 74 73 69 | 7a 65 28 61 72 67 29 3b | = getsi|ze(arg);|
|00002600| 20 69 2d 2d 20 3e 20 30 | 3b 20 29 20 0d 0a 20 20 | i-- > 0|; ) .. |
|00002610| 20 20 20 20 20 20 20 20 | 20 20 76 61 6c 20 3d 20 | | val = |
|00002620| 63 6f 6e 73 28 67 65 74 | 65 6c 65 6d 65 6e 74 28 |cons(get|element(|
|00002630| 61 72 67 2c 69 29 2c 76 | 61 6c 29 3b 0d 0a 20 20 |arg,i),v|al);.. |
|00002640| 20 20 7d 0d 0a 20 20 20 | 20 65 6c 73 65 20 7b 20 | }.. | else { |
|00002650| 20 2f 2a 20 61 20 73 74 | 72 69 6e 67 20 2a 2f 0d | /* a st|ring */.|
|00002660| 0a 20 20 20 20 20 20 20 | 20 66 6f 72 20 28 69 20 |. | for (i |
|00002670| 3d 20 67 65 74 73 6c 65 | 6e 67 74 68 28 61 72 67 |= getsle|ngth(arg|
|00002680| 29 2d 31 3b 20 69 2d 2d | 20 3e 20 30 3b 20 29 0d |)-1; i--| > 0; ).|
|00002690| 0a 20 20 20 20 20 20 20 | 20 20 20 20 20 76 61 6c |. | val|
|000026a0| 20 3d 20 63 6f 6e 73 28 | 63 76 63 68 61 72 28 61 | = cons(|cvchar(a|
|000026b0| 72 67 2d 3e 6e 5f 73 74 | 72 69 6e 67 5b 69 5d 29 |rg->n_st|ring[i])|
|000026c0| 2c 76 61 6c 29 3b 0d 0a | 20 20 20 20 7d 0d 0a 20 |,val);..| }.. |
|000026d0| 20 20 20 0d 0a 20 20 20 | 20 78 6c 70 6f 70 28 29 | .. | xlpop()|
|000026e0| 3b 0d 0a 20 20 20 20 72 | 65 74 75 72 6e 20 28 76 |;.. r|eturn (v|
|000026f0| 61 6c 29 3b 0d 0a 7d 0d | 0a 0d 0a 4c 4f 43 41 4c |al);..}.|...LOCAL|
|00002700| 20 4c 56 41 4c 20 76 65 | 63 74 69 66 79 28 61 72 | LVAL ve|ctify(ar|
|00002710| 67 29 20 2f 2a 20 61 72 | 67 20 6d 75 73 74 20 62 |g) /* ar|g must b|
|00002720| 65 20 73 74 72 69 6e 67 | 20 6f 72 20 63 6f 6e 73 |e string| or cons|
|00002730| 20 2a 2f 0d 0a 4c 56 41 | 4c 20 61 72 67 3b 0d 0a | */..LVA|L arg;..|
|00002740| 7b 0d 0a 20 20 20 20 4c | 56 41 4c 20 76 61 6c 2c |{.. L|VAL val,|
|00002750| 74 65 6d 70 3b 0d 0a 20 | 20 20 20 69 6e 74 20 69 |temp;.. | int i|
|00002760| 2c 6c 3b 0d 0a 20 20 20 | 20 0d 0a 20 20 20 20 69 |,l;.. | .. i|
|00002770| 66 20 28 6e 74 79 70 65 | 28 61 72 67 29 20 3d 3d |f (ntype|(arg) ==|
|00002780| 20 53 54 52 49 4e 47 29 | 20 7b 0d 0a 20 20 20 20 | STRING)| {.. |
|00002790| 20 20 20 20 6c 20 3d 20 | 67 65 74 73 6c 65 6e 67 | l = |getsleng|
|000027a0| 74 68 28 61 72 67 29 2d | 31 3b 0d 0a 20 20 20 20 |th(arg)-|1;.. |
|000027b0| 20 20 20 20 76 61 6c 20 | 3d 20 6e 65 77 76 65 63 | val |= newvec|
|000027c0| 74 6f 72 28 6c 29 3b 0d | 0a 20 20 20 20 20 20 20 |tor(l);.|. |
|000027d0| 20 66 6f 72 20 28 69 3d | 30 3b 20 69 20 3c 20 6c | for (i=|0; i < l|
|000027e0| 3b 20 69 2b 2b 29 20 73 | 65 74 65 6c 65 6d 65 6e |; i++) s|etelemen|
|000027f0| 74 28 76 61 6c 2c 69 2c | 63 76 63 68 61 72 28 61 |t(val,i,|cvchar(a|
|00002800| 72 67 2d 3e 6e 5f 73 74 | 72 69 6e 67 5b 69 5d 29 |rg->n_st|ring[i])|
|00002810| 29 3b 0d 0a 20 20 20 20 | 7d 0d 0a 20 20 20 20 65 |);.. |}.. e|
|00002820| 6c 73 65 20 7b 20 20 2f | 2a 20 61 20 63 6f 6e 73 |lse { /|* a cons|
|00002830| 20 2a 2f 0d 0a 20 20 20 | 20 20 20 20 20 76 61 6c | */.. | val|
|00002840| 20 3d 20 61 72 67 3b 0d | 0a 20 20 20 20 20 20 20 | = arg;.|. |
|00002850| 20 66 6f 72 20 28 6c 20 | 3d 20 30 3b 20 63 6f 6e | for (l |= 0; con|
|00002860| 73 70 28 76 61 6c 29 3b | 20 6c 2b 2b 29 20 76 61 |sp(val);| l++) va|
|00002870| 6c 20 3d 20 63 64 72 28 | 76 61 6c 29 3b 20 2f 2a |l = cdr(|val); /*|
|00002880| 20 67 65 74 20 6c 65 6e | 67 74 68 20 2a 2f 0d 0a | get len|gth */..|
|00002890| 20 20 20 20 20 20 20 20 | 76 61 6c 20 3d 20 6e 65 | |val = ne|
|000028a0| 77 76 65 63 74 6f 72 28 | 6c 29 3b 0d 0a 20 20 20 |wvector(|l);.. |
|000028b0| 20 20 20 20 20 74 65 6d | 70 20 3d 20 61 72 67 3b | tem|p = arg;|
|000028c0| 0d 0a 20 20 20 20 20 20 | 20 20 66 6f 72 20 28 69 |.. | for (i|
|000028d0| 20 3d 20 30 3b 20 69 20 | 3c 20 6c 3b 20 69 2b 2b | = 0; i |< l; i++|
|000028e0| 29 20 7b 0d 0a 20 20 20 | 20 20 20 20 20 20 20 20 |) {.. | |
|000028f0| 20 73 65 74 65 6c 65 6d | 65 6e 74 28 76 61 6c 2c | setelem|ent(val,|
|00002900| 69 2c 63 61 72 28 74 65 | 6d 70 29 29 3b 0d 0a 20 |i,car(te|mp));.. |
|00002910| 20 20 20 20 20 20 20 20 | 20 20 20 74 65 6d 70 20 | | temp |
|00002920| 3d 20 63 64 72 28 74 65 | 6d 70 29 3b 0d 0a 20 20 |= cdr(te|mp);.. |
|00002930| 20 20 20 20 20 20 7d 0d | 0a 20 20 20 20 7d 0d 0a | }.|. }..|
|00002940| 20 20 20 20 20 20 20 20 | 72 65 74 75 72 6e 20 76 | |return v|
|00002950| 61 6c 3b 0d 0a 7d 0d 0a | 0d 0a 0d 0a 4c 4f 43 41 |al;..}..|....LOCA|
|00002960| 4c 20 4c 56 41 4c 20 73 | 74 72 69 6e 67 69 66 79 |L LVAL s|tringify|
|00002970| 28 61 72 67 29 20 20 20 | 2f 2a 20 61 72 67 20 6d |(arg) |/* arg m|
|00002980| 75 73 74 20 62 65 20 76 | 65 63 74 6f 72 20 6f 72 |ust be v|ector or|
|00002990| 20 63 6f 6e 73 20 2a 2f | 0d 0a 4c 56 41 4c 20 61 | cons */|..LVAL a|
|000029a0| 72 67 3b 0d 0a 7b 0d 0a | 20 20 20 20 4c 56 41 4c |rg;..{..| LVAL|
|000029b0| 20 76 61 6c 2c 74 65 6d | 70 3b 0d 0a 20 20 20 20 | val,tem|p;.. |
|000029c0| 69 6e 74 20 69 2c 6c 3b | 0d 0a 20 20 20 20 0d 0a |int i,l;|.. ..|
|000029d0| 20 20 20 20 69 66 20 28 | 6e 74 79 70 65 28 61 72 | if (|ntype(ar|
|000029e0| 67 29 20 3d 3d 20 56 45 | 43 54 4f 52 29 20 7b 0d |g) == VE|CTOR) {.|
|000029f0| 0a 20 20 20 20 20 20 20 | 20 6c 20 3d 20 67 65 74 |. | l = get|
|00002a00| 73 69 7a 65 28 61 72 67 | 29 3b 0d 0a 20 20 20 20 |size(arg|);.. |
|00002a10| 20 20 20 20 76 61 6c 20 | 3d 20 6e 65 77 73 74 72 | val |= newstr|
|00002a20| 69 6e 67 28 6c 2b 31 29 | 3b 0d 0a 20 20 20 20 20 |ing(l+1)|;.. |
|00002a30| 20 20 20 66 6f 72 20 28 | 69 3d 30 3b 20 69 20 3c | for (|i=0; i <|
|00002a40| 20 6c 3b 20 69 2b 2b 29 | 20 7b 0d 0a 20 20 20 20 | l; i++)| {.. |
|00002a50| 20 20 20 20 20 20 20 20 | 74 65 6d 70 20 3d 20 67 | |temp = g|
|00002a60| 65 74 65 6c 65 6d 65 6e | 74 28 61 72 67 2c 69 29 |etelemen|t(arg,i)|
|00002a70| 3b 0d 0a 20 20 20 20 20 | 20 20 20 20 20 20 20 69 |;.. | i|
|00002a80| 66 20 28 6e 74 79 70 65 | 28 74 65 6d 70 29 20 21 |f (ntype|(temp) !|
|00002a90| 3d 20 43 48 41 52 29 20 | 67 6f 74 6f 20 66 61 69 |= CHAR) |goto fai|
|00002aa0| 6c 65 64 3b 0d 0a 20 20 | 20 20 20 20 20 20 20 20 |led;.. | |
|00002ab0| 20 20 76 61 6c 2d 3e 6e | 5f 73 74 72 69 6e 67 5b | val->n|_string[|
|00002ac0| 69 5d 20 3d 20 67 65 74 | 63 68 63 6f 64 65 28 74 |i] = get|chcode(t|
|00002ad0| 65 6d 70 29 3b 0d 0a 20 | 20 20 20 20 20 20 20 7d |emp);.. | }|
|00002ae0| 0d 0a 20 20 20 20 20 20 | 20 20 76 61 6c 2d 3e 6e |.. | val->n|
|00002af0| 5f 73 74 72 69 6e 67 5b | 6c 5d 20 3d 20 30 3b 0d |_string[|l] = 0;.|
|00002b00| 0a 20 20 20 20 20 20 20 | 20 72 65 74 75 72 6e 20 |. | return |
|00002b10| 76 61 6c 3b 0d 0a 20 20 | 20 20 7d 0d 0a 20 20 20 |val;.. | }.. |
|00002b20| 20 65 6c 73 65 20 7b 20 | 20 2f 2a 20 6d 75 73 74 | else { | /* must|
|00002b30| 20 62 65 20 63 6f 6e 73 | 20 2a 2f 0d 0a 20 20 20 | be cons| */.. |
|00002b40| 20 20 20 20 20 76 61 6c | 20 3d 20 61 72 67 3b 0d | val| = arg;.|
|00002b50| 0a 20 20 20 20 20 20 20 | 20 66 6f 72 20 28 6c 20 |. | for (l |
|00002b60| 3d 20 30 3b 20 63 6f 6e | 73 70 28 76 61 6c 29 3b |= 0; con|sp(val);|
|00002b70| 20 6c 2b 2b 29 20 7b 0d | 0a 20 20 20 20 20 20 20 | l++) {.|. |
|00002b80| 20 20 20 20 20 69 66 20 | 28 6e 74 79 70 65 28 63 | if |(ntype(c|
|00002b90| 61 72 28 76 61 6c 29 29 | 20 21 3d 20 43 48 41 52 |ar(val))| != CHAR|
|00002ba0| 29 20 67 6f 74 6f 20 66 | 61 69 6c 65 64 3b 0d 0a |) goto f|ailed;..|
|00002bb0| 20 20 20 20 20 20 20 20 | 20 20 20 20 76 61 6c 20 | | val |
|00002bc0| 3d 20 63 64 72 28 76 61 | 6c 29 3b 20 2f 2a 20 67 |= cdr(va|l); /* g|
|00002bd0| 65 74 20 6c 65 6e 67 74 | 68 20 2a 2f 0d 0a 20 20 |et lengt|h */.. |
|00002be0| 20 20 20 20 20 20 7d 0d | 0a 0d 0a 20 20 20 20 20 | }.|... |
|00002bf0| 20 20 20 76 61 6c 20 3d | 20 6e 65 77 73 74 72 69 | val =| newstri|
|00002c00| 6e 67 28 6c 2b 31 29 3b | 0d 0a 20 20 20 20 20 20 |ng(l+1);|.. |
|00002c10| 20 20 74 65 6d 70 20 3d | 20 61 72 67 3b 0d 0a 20 | temp =| arg;.. |
|00002c20| 20 20 20 20 20 20 20 66 | 6f 72 20 28 69 20 3d 20 | f|or (i = |
|00002c30| 30 3b 20 69 20 3c 20 6c | 3b 20 69 2b 2b 29 20 7b |0; i < l|; i++) {|
|00002c40| 0d 0a 20 20 20 20 20 20 | 20 20 20 20 20 20 76 61 |.. | va|
|00002c50| 6c 2d 3e 6e 5f 73 74 72 | 69 6e 67 5b 69 5d 20 3d |l->n_str|ing[i] =|
|00002c60| 20 67 65 74 63 68 63 6f | 64 65 28 63 61 72 28 74 | getchco|de(car(t|
|00002c70| 65 6d 70 29 29 3b 0d 0a | 20 20 20 20 20 20 20 20 |emp));..| |
|00002c80| 20 20 20 20 74 65 6d 70 | 20 3d 20 63 64 72 28 74 | temp| = cdr(t|
|00002c90| 65 6d 70 29 3b 0d 0a 20 | 20 20 20 20 20 20 20 7d |emp);.. | }|
|00002ca0| 0d 0a 20 20 20 20 20 20 | 20 20 76 61 6c 2d 3e 6e |.. | val->n|
|00002cb0| 5f 73 74 72 69 6e 67 5b | 6c 5d 20 3d 20 30 3b 0d |_string[|l] = 0;.|
|00002cc0| 0a 20 20 20 20 20 20 20 | 20 72 65 74 75 72 6e 20 |. | return |
|00002cd0| 76 61 6c 3b 0d 0a 20 20 | 20 20 7d 0d 0a 66 61 69 |val;.. | }..fai|
|00002ce0| 6c 65 64 3a 0d 0a 20 20 | 20 20 78 6c 65 72 72 6f |led:.. | xlerro|
|00002cf0| 72 28 22 63 61 6e 6e 6f | 74 20 6d 61 6b 65 20 69 |r("canno|t make i|
|00002d00| 6e 74 6f 20 73 74 72 69 | 6e 67 22 2c 20 61 72 67 |nto stri|ng", arg|
|00002d10| 29 3b 0d 0a 7d 0d 0a 0d | 0a 0d 0a 0d 0a 2f 2a 20 |);..}...|...../* |
|00002d20| 63 6f 65 72 63 65 20 66 | 75 6e 63 74 69 6f 6e 20 |coerce f|unction |
|00002d30| 2a 2f 0d 0a 4c 56 41 4c | 20 78 63 6f 65 72 63 65 |*/..LVAL| xcoerce|
|00002d40| 28 29 0d 0a 7b 0d 0a 20 | 20 20 20 4c 56 41 4c 20 |()..{.. | LVAL |
|00002d50| 74 79 70 65 2c 20 61 72 | 67 2c 20 74 65 6d 70 3b |type, ar|g, temp;|
|00002d60| 0d 0a 20 20 20 20 69 6e | 74 20 6e 65 77 74 79 70 |.. in|t newtyp|
|00002d70| 65 2c 6f 6c 64 74 79 70 | 65 3b 0d 0a 0d 0a 20 20 |e,oldtyp|e;.... |
|00002d80| 20 20 61 72 67 20 3d 20 | 78 6c 67 65 74 61 72 67 | arg = |xlgetarg|
|00002d90| 28 29 3b 0d 0a 20 20 20 | 20 74 79 70 65 20 3d 20 |();.. | type = |
|00002da0| 78 6c 67 65 74 61 72 67 | 28 29 3b 0d 0a 20 20 20 |xlgetarg|();.. |
|00002db0| 20 78 6c 6c 61 73 74 61 | 72 67 28 29 3b 0d 0a 20 | xllasta|rg();.. |
|00002dc0| 20 20 20 0d 0a 20 20 20 | 20 69 66 20 28 28 6e 65 | .. | if ((ne|
|00002dd0| 77 74 79 70 65 20 3d 20 | 78 6c 63 76 74 74 79 70 |wtype = |xlcvttyp|
|00002de0| 65 28 74 79 70 65 29 29 | 20 3d 3d 20 30 29 20 67 |e(type))| == 0) g|
|00002df0| 6f 74 6f 20 62 61 64 63 | 6f 6e 76 65 72 74 3b 0d |oto badc|onvert;.|
|00002e00| 0a 0d 0a 20 20 20 20 6f | 6c 64 74 79 70 65 20 3d |... o|ldtype =|
|00002e10| 20 6e 74 79 70 65 28 61 | 72 67 29 3b 0d 0a 20 20 | ntype(a|rg);.. |
|00002e20| 20 20 69 66 20 28 6f 6c | 64 74 79 70 65 20 3d 3d | if (ol|dtype ==|
|00002e30| 20 6e 65 77 74 79 70 65 | 29 20 72 65 74 75 72 6e | newtype|) return|
|00002e40| 20 28 61 72 67 29 3b 20 | 20 20 2f 2a 20 65 61 73 | (arg); | /* eas|
|00002e50| 79 20 63 61 73 65 21 20 | 2a 2f 0d 0a 20 20 20 20 |y case! |*/.. |
|00002e60| 0d 0a 20 20 20 20 73 77 | 69 74 63 68 20 28 6e 65 |.. sw|itch (ne|
|00002e70| 77 74 79 70 65 29 20 7b | 0d 0a 20 20 20 20 20 20 |wtype) {|.. |
|00002e80| 20 20 63 61 73 65 20 43 | 4f 4e 53 3a 20 69 66 20 | case C|ONS: if |
|00002e90| 28 28 6f 6c 64 74 79 70 | 65 20 3d 3d 20 53 54 52 |((oldtyp|e == STR|
|00002ea0| 49 4e 47 29 7c 28 6f 6c | 64 74 79 70 65 20 3d 3d |ING)|(ol|dtype ==|
|00002eb0| 20 56 45 43 54 4f 52 29 | 29 0d 0a 20 20 20 20 20 | VECTOR)|).. |
|00002ec0| 20 20 20 20 20 20 20 72 | 65 74 75 72 6e 20 28 6c | r|eturn (l|
|00002ed0| 69 73 74 69 66 79 28 61 | 72 67 29 29 3b 0d 0a 20 |istify(a|rg));.. |
|00002ee0| 20 20 20 20 20 20 20 20 | 20 20 20 62 72 65 61 6b | | break|
|00002ef0| 3b 0d 0a 20 20 20 20 20 | 20 20 20 63 61 73 65 20 |;.. | case |
|00002f00| 53 54 52 49 4e 47 3a 20 | 69 66 20 28 28 6f 6c 64 |STRING: |if ((old|
|00002f10| 74 79 70 65 20 3d 3d 20 | 43 4f 4e 53 29 7c 28 6f |type == |CONS)|(o|
|00002f20| 6c 64 74 79 70 65 20 3d | 3d 20 56 45 43 54 4f 52 |ldtype =|= VECTOR|
|00002f30| 29 29 0d 0a 20 20 20 20 | 20 20 20 20 20 20 20 20 |)).. | |
|00002f40| 72 65 74 75 72 6e 20 28 | 73 74 72 69 6e 67 69 66 |return (|stringif|
|00002f50| 79 28 61 72 67 29 29 3b | 0d 0a 20 20 20 20 20 20 |y(arg));|.. |
|00002f60| 20 20 20 20 20 20 62 72 | 65 61 6b 3b 0d 0a 20 20 | br|eak;.. |
|00002f70| 20 20 20 20 20 20 63 61 | 73 65 20 56 45 43 54 4f | ca|se VECTO|
|00002f80| 52 3a 20 69 66 20 28 28 | 6f 6c 64 74 79 70 65 20 |R: if ((|oldtype |
|00002f90| 3d 3d 20 53 54 52 49 4e | 47 29 20 7c 20 28 6f 6c |== STRIN|G) | (ol|
|00002fa0| 64 74 79 70 65 20 3d 3d | 20 43 4f 4e 53 29 29 0d |dtype ==| CONS)).|
|00002fb0| 0a 20 20 20 20 20 20 20 | 20 20 20 20 20 72 65 74 |. | ret|
|00002fc0| 75 72 6e 20 28 76 65 63 | 74 69 66 79 28 61 72 67 |urn (vec|tify(arg|
|00002fd0| 29 29 3b 0d 0a 20 20 20 | 20 20 20 20 20 20 20 20 |));.. | |
|00002fe0| 20 62 72 65 61 6b 3b 0d | 0a 20 20 20 20 20 20 20 | break;.|. |
|00002ff0| 20 63 61 73 65 20 43 48 | 41 52 3a 0d 0a 20 20 20 | case CH|AR:.. |
|00003000| 20 20 20 20 20 20 20 20 | 20 69 66 20 28 6f 6c 64 | | if (old|
|00003010| 74 79 70 65 20 3d 3d 20 | 46 49 58 4e 55 4d 29 20 |type == |FIXNUM) |
|00003020| 72 65 74 75 72 6e 20 63 | 76 63 68 61 72 28 28 69 |return c|vchar((i|
|00003030| 6e 74 29 67 65 74 66 69 | 78 6e 75 6d 28 61 72 67 |nt)getfi|xnum(arg|
|00003040| 29 29 3b 0d 0a 20 20 20 | 20 20 20 20 20 20 20 20 |));.. | |
|00003050| 20 65 6c 73 65 20 69 66 | 20 28 28 6f 6c 64 74 79 | else if| ((oldty|
|00003060| 70 65 20 3d 3d 20 53 54 | 52 49 4e 47 29 20 26 26 |pe == ST|RING) &&|
|00003070| 20 28 67 65 74 73 6c 65 | 6e 67 74 68 28 61 72 67 | (getsle|ngth(arg|
|00003080| 29 20 3d 3d 20 32 29 29 | 0d 0a 20 20 20 20 20 20 |) == 2))|.. |
|00003090| 20 20 20 20 20 20 20 20 | 20 20 72 65 74 75 72 6e | | return|
|000030a0| 20 63 76 63 68 61 72 28 | 61 72 67 2d 3e 6e 5f 73 | cvchar(|arg->n_s|
|000030b0| 74 72 69 6e 67 5b 30 5d | 29 3b 0d 0a 20 20 20 20 |tring[0]|);.. |
|000030c0| 20 20 20 20 20 20 20 20 | 65 6c 73 65 20 69 66 20 | |else if |
|000030d0| 28 6f 6c 64 74 79 70 65 | 20 3d 3d 20 53 59 4d 42 |(oldtype| == SYMB|
|000030e0| 4f 4c 29 20 7b 0d 0a 20 | 20 20 20 20 20 20 20 20 |OL) {.. | |
|000030f0| 20 20 20 20 20 20 20 74 | 65 6d 70 20 3d 20 67 65 | t|emp = ge|
|00003100| 74 70 6e 61 6d 65 28 61 | 72 67 29 3b 0d 0a 20 20 |tpname(a|rg);.. |
|00003110| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 69 66 | | if|
|00003120| 20 28 67 65 74 73 6c 65 | 6e 67 74 68 28 74 65 6d | (getsle|ngth(tem|
|00003130| 70 29 20 3d 3d 20 32 29 | 20 72 65 74 75 72 6e 20 |p) == 2)| return |
|00003140| 63 76 63 68 61 72 28 74 | 65 6d 70 2d 3e 6e 5f 73 |cvchar(t|emp->n_s|
|00003150| 74 72 69 6e 67 5b 30 5d | 29 3b 0d 0a 20 20 20 20 |tring[0]|);.. |
|00003160| 20 20 20 20 20 20 20 20 | 7d 0d 0a 20 20 20 20 20 | |}.. |
|00003170| 20 20 20 20 20 20 20 62 | 72 65 61 6b 3b 0d 0a 20 | b|reak;.. |
|00003180| 20 20 20 20 20 20 20 63 | 61 73 65 20 46 4c 4f 4e | c|ase FLON|
|00003190| 55 4d 3a 0d 0a 20 20 20 | 20 20 20 20 20 20 20 20 |UM:.. | |
|000031a0| 20 69 66 20 28 6f 6c 64 | 74 79 70 65 20 3d 3d 20 | if (old|type == |
|000031b0| 46 49 58 4e 55 4d 29 20 | 72 65 74 75 72 6e 20 28 |FIXNUM) |return (|
|000031c0| 63 76 66 6c 6f 6e 75 6d | 28 31 2e 30 2a 28 69 6e |cvflonum|(1.0*(in|
|000031d0| 74 29 67 65 74 66 69 78 | 6e 75 6d 28 61 72 67 29 |t)getfix|num(arg)|
|000031e0| 29 29 3b 0d 0a 20 20 20 | 20 20 20 20 20 20 20 20 |));.. | |
|000031f0| 20 62 72 65 61 6b 3b 0d | 0a 20 20 20 20 7d 0d 0a | break;.|. }..|
|00003200| 0d 0a 0d 0a 62 61 64 63 | 6f 6e 76 65 72 74 3a 0d |....badc|onvert:.|
|00003210| 0a 20 20 20 20 78 6c 65 | 72 72 6f 72 28 22 69 6c |. xle|rror("il|
|00003220| 6c 65 67 61 6c 20 63 6f | 65 72 73 69 6f 6e 22 2c |legal co|ersion",|
|00003230| 61 72 67 29 3b 0d 0a 0d | 0a 7d 0d 0a 0d 0a 0d 0a |arg);...|.}......|
|00003240| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00003250| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 0d 0a |********|******..|
|00003260| 0d 0a 49 6e 20 66 69 6c | 65 20 78 6c 6c 69 73 74 |..In fil|e xllist|
|00003270| 2e 63 2c 20 64 65 6c 65 | 74 65 20 74 68 65 20 66 |.c, dele|te the f|
|00003280| 75 6e 63 74 69 6f 6e 73 | 20 78 72 65 76 65 72 73 |unctions| xrevers|
|00003290| 65 28 29 2c 20 78 72 65 | 6d 6f 76 65 28 29 2c 20 |e(), xre|move(), |
|000032a0| 72 65 6d 69 66 28 29 2c | 20 0d 0a 78 72 65 6d 69 |remif(),| ..xremi|
|000032b0| 66 28 29 2c 20 78 72 65 | 6d 69 66 6e 6f 74 28 29 |f(), xre|mifnot()|
|000032c0| 2c 20 78 64 65 6c 65 74 | 65 28 29 2c 20 64 65 6c |, xdelet|e(), del|
|000032d0| 69 66 28 29 2c 20 78 64 | 65 6c 69 66 28 29 2c 20 |if(), xd|elif(), |
|000032e0| 78 64 65 6c 69 66 6e 6f | 74 28 29 2c 20 64 6f 74 |xdelifno|t(), dot|
|000032f0| 65 73 74 31 28 29 2e 0d | 0a 54 68 65 73 65 20 66 |est1()..|.These f|
|00003300| 75 6e 63 74 69 6f 6e 73 | 20 77 69 6c 6c 20 62 65 |unctions| will be|
|00003310| 20 69 6e 20 74 68 65 20 | 6e 65 77 20 66 69 6c 65 | in the |new file|
|00003320| 20 78 6c 73 65 71 2e 63 | 2e 0d 0a 0d 0a 52 65 6d | xlseq.c|.....Rem|
|00003330| 6f 76 65 20 61 6e 79 20 | 4c 4f 43 41 4c 20 61 74 |ove any |LOCAL at|
|00003340| 72 69 62 75 74 65 20 74 | 6f 20 66 75 6e 63 74 69 |ribute t|o functi|
|00003350| 6f 6e 20 64 6f 74 65 73 | 74 32 28 29 2e 0d 0a 0d |on dotes|t2()....|
|00003360| 0a 0d 0a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |...*****|********|
|00003370| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00003380| 2a 0d 0a 0d 0a 54 68 69 | 73 20 69 73 20 74 68 65 |*....Thi|s is the|
|00003390| 20 65 6e 64 20 6f 66 20 | 70 61 72 74 20 31 2e 0d | end of |part 1..|
|000033a0| 0a 0d 0a 0d 0a 46 72 6f | 6d 20 73 63 65 21 6d 69 |.....Fro|m sce!mi|
|000033b0| 74 65 6c 21 75 75 6e 65 | 74 21 7a 65 70 68 79 72 |tel!uune|t!zephyr|
|000033c0| 2e 65 6e 73 2e 74 65 6b | 2e 63 6f 6d 21 74 65 6b |.ens.tek|.com!tek|
|000033d0| 63 72 6c 21 74 65 6b 67 | 76 73 21 74 6f 6d 61 20 |crl!tekg|vs!toma |
|000033e0| 53 61 74 20 53 65 70 20 | 31 36 20 30 38 3a 32 30 |Sat Sep |16 08:20|
|000033f0| 3a 33 33 20 45 44 54 20 | 31 39 38 39 0d 0a 41 72 |:33 EDT |1989..Ar|
|00003400| 74 69 63 6c 65 3a 20 33 | 20 6f 66 20 63 6f 6d 70 |ticle: 3| of comp|
|00003410| 2e 6c 61 6e 67 2e 6c 69 | 73 70 2e 78 0d 0a 50 61 |.lang.li|sp.x..Pa|
|00003420| 74 68 3a 20 63 6f 67 6e | 6f 73 21 73 63 65 21 6d |th: cogn|os!sce!m|
|00003430| 69 74 65 6c 21 75 75 6e | 65 74 21 7a 65 70 68 79 |itel!uun|et!zephy|
|00003440| 72 2e 65 6e 73 2e 74 65 | 6b 2e 63 6f 6d 21 74 65 |r.ens.te|k.com!te|
|00003450| 6b 63 72 6c 21 74 65 6b | 67 76 73 21 74 6f 6d 61 |kcrl!tek|gvs!toma|
|00003460| 0d 0a 46 72 6f 6d 3a 20 | 74 6f 6d 61 40 74 65 6b |..From: |toma@tek|
|00003470| 67 76 73 2e 4c 41 42 53 | 2e 54 45 4b 2e 43 4f 4d |gvs.LABS|.TEK.COM|
|00003480| 20 28 54 6f 6d 20 41 6c | 6d 79 29 0d 0a 4e 65 77 | (Tom Al|my)..New|
|00003490| 73 67 72 6f 75 70 73 3a | 20 63 6f 6d 70 2e 6c 61 |sgroups:| comp.la|
|000034a0| 6e 67 2e 6c 69 73 70 2e | 78 0d 0a 53 75 62 6a 65 |ng.lisp.|x..Subje|
|000034b0| 63 74 3a 20 58 4c 49 53 | 50 20 32 2e 30 20 4d 4f |ct: XLIS|P 2.0 MO|
|000034c0| 44 49 46 49 43 41 54 49 | 4f 4e 53 20 28 32 20 6f |DIFICATI|ONS (2 o|
|000034d0| 66 20 32 29 0d 0a 4d 65 | 73 73 61 67 65 2d 49 44 |f 2)..Me|ssage-ID|
|000034e0| 3a 20 3c 35 39 31 39 40 | 74 65 6b 67 76 73 2e 4c |: <5919@|tekgvs.L|
|000034f0| 41 42 53 2e 54 45 4b 2e | 43 4f 4d 3e 0d 0a 44 61 |ABS.TEK.|COM>..Da|
|00003500| 74 65 3a 20 31 31 20 53 | 65 70 20 38 39 20 32 32 |te: 11 S|ep 89 22|
|00003510| 3a 32 36 3a 34 34 20 47 | 4d 54 0d 0a 52 65 70 6c |:26:44 G|MT..Repl|
|00003520| 79 2d 54 6f 3a 20 74 6f | 6d 61 40 74 65 6b 67 76 |y-To: to|ma@tekgv|
|00003530| 73 2e 4c 41 42 53 2e 54 | 45 4b 2e 43 4f 4d 20 28 |s.LABS.T|EK.COM (|
|00003540| 54 6f 6d 20 41 6c 6d 79 | 29 0d 0a 4f 72 67 61 6e |Tom Almy|)..Organ|
|00003550| 69 7a 61 74 69 6f 6e 3a | 20 54 65 6b 74 72 6f 6e |ization:| Tektron|
|00003560| 69 78 2c 20 49 6e 63 2e | 2c 20 42 65 61 76 65 72 |ix, Inc.|, Beaver|
|00003570| 74 6f 6e 2c 20 20 4f 52 | 2e 0d 0a 4c 69 6e 65 73 |ton, OR|...Lines|
|00003580| 3a 20 31 30 37 33 0d 0a | 0d 0a 54 68 65 20 72 65 |: 1073..|..The re|
|00003590| 6d 61 69 6e 64 65 72 20 | 6f 66 20 74 68 65 20 63 |mainder |of the c|
|000035a0| 68 61 6e 67 65 73 20 63 | 6f 6e 73 69 73 74 73 20 |hanges c|onsists |
|000035b0| 6f 66 20 74 68 65 20 66 | 69 6c 65 20 78 6c 73 65 |of the f|ile xlse|
|000035c0| 71 2e 63 2e 0d 0a 0d 0a | 0d 0a 54 6f 6d 20 41 6c |q.c.....|..Tom Al|
|000035d0| 6d 79 0d 0a 53 65 70 74 | 65 6d 62 65 72 20 31 31 |my..Sept|ember 11|
|000035e0| 2c 20 31 39 38 39 0d 0a | 74 6f 6d 61 40 74 65 6b |, 1989..|toma@tek|
|000035f0| 67 76 73 2e 6c 61 62 73 | 2e 74 65 6b 2e 63 6f 6d |gvs.labs|.tek.com|
|00003600| 0d 0a 53 74 61 6e 64 61 | 72 64 20 44 69 73 63 6c |..Standa|rd Discl|
|00003610| 61 69 6d 65 72 73 20 41 | 70 70 6c 79 0d 0a 0d 0a |aimers A|pply....|
|00003620| 0d 0a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |..******|********|
|00003630| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00003640| 0d 0a 0d 0a 2f 2a 20 78 | 6c 73 65 71 2e 63 20 2d |..../* x|lseq.c -|
|00003650| 20 78 6c 69 73 70 20 73 | 65 71 75 65 6e 63 65 20 | xlisp s|equence |
|00003660| 66 75 6e 63 74 69 6f 6e | 73 20 2a 2f 0d 0a 2f 2a |function|s */../*|
|00003670| 20 20 57 72 69 74 74 65 | 6e 20 62 79 20 54 68 6f | Writte|n by Tho|
|00003680| 6d 61 73 20 41 6c 6d 79 | 2c 20 62 61 73 65 64 20 |mas Almy|, based |
|00003690| 6f 6e 20 63 6f 64 65 3a | 0d 0a 20 20 20 20 43 6f |on code:|.. Co|
|000036a0| 70 79 72 69 67 68 74 20 | 28 63 29 20 31 39 38 35 |pyright |(c) 1985|
|000036b0| 2c 20 62 79 20 44 61 76 | 69 64 20 4d 69 63 68 61 |, by Dav|id Micha|
|000036c0| 65 6c 20 42 65 74 7a 0d | 0a 20 20 20 20 41 6c 6c |el Betz.|. All|
|000036d0| 20 52 69 67 68 74 73 20 | 52 65 73 65 72 76 65 64 | Rights |Reserved|
|000036e0| 0d 0a 20 20 20 20 50 65 | 72 6d 69 73 73 69 6f 6e |.. Pe|rmission|
|000036f0| 20 69 73 20 67 72 61 6e | 74 65 64 20 66 6f 72 20 | is gran|ted for |
|00003700| 75 6e 72 65 73 74 72 69 | 63 74 65 64 20 6e 6f 6e |unrestri|cted non|
|00003710| 2d 63 6f 6d 6d 65 72 63 | 69 61 6c 20 75 73 65 20 |-commerc|ial use |
|00003720| 20 20 2a 2f 0d 0a 0d 0a | 23 69 6e 63 6c 75 64 65 | */....|#include|
|00003730| 20 22 78 6c 69 73 70 2e | 68 22 0d 0a 0d 0a 2f 2a | "xlisp.|h"..../*|
|00003740| 20 65 78 74 65 72 6e 61 | 6c 20 70 72 6f 63 65 64 | externa|l proced|
|00003750| 75 72 65 73 20 2a 2f 0d | 0a 65 78 74 65 72 6e 20 |ures */.|.extern |
|00003760| 69 6e 74 20 78 6c 63 76 | 74 74 79 70 65 28 29 3b |int xlcv|ttype();|
|00003770| 0d 0a 65 78 74 65 72 6e | 20 69 6e 74 20 78 6c 67 |..extern| int xlg|
|00003780| 6b 66 69 78 6e 75 6d 28 | 29 3b 0d 0a 65 78 74 65 |kfixnum(|);..exte|
|00003790| 72 6e 20 69 6e 74 20 78 | 6c 67 65 74 6b 65 79 61 |rn int x|lgetkeya|
|000037a0| 72 67 28 29 3b 0d 0a 0d | 0a 2f 2a 20 65 78 74 65 |rg();...|./* exte|
|000037b0| 72 6e 61 6c 20 76 61 72 | 69 61 62 6c 65 73 20 2a |rnal var|iables *|
|000037c0| 2f 0d 0a 65 78 74 65 72 | 6e 20 4c 56 41 4c 20 6b |/..exter|n LVAL k|
|000037d0| 5f 73 74 61 72 74 2c 6b | 5f 65 6e 64 2c 6b 5f 31 |_start,k|_end,k_1|
|000037e0| 73 74 61 72 74 2c 6b 5f | 31 65 6e 64 2c 6b 5f 32 |start,k_|1end,k_2|
|000037f0| 73 74 61 72 74 2c 6b 5f | 32 65 6e 64 3b 0d 0a 0d |start,k_|2end;...|
|00003800| 0a 0d 0a 2f 2a 20 41 70 | 6f 6c 6f 67 69 65 73 20 |.../* Ap|ologies |
|00003810| 66 72 6f 6d 20 74 68 65 | 20 61 75 74 68 6f 72 20 |from the| author |
|00003820| 28 54 6f 6d 20 41 6c 6d | 79 29 3a 0d 0a 20 20 20 |(Tom Alm|y):.. |
|00003830| 3a 73 74 61 72 74 20 61 | 6e 64 20 3a 65 6e 64 20 |:start a|nd :end |
|00003840| 69 73 6e 27 74 20 71 75 | 69 74 65 20 4b 6f 73 68 |isn't qu|ite Kosh|
|00003850| 65 72 20 69 6e 0d 0a 20 | 20 20 74 68 61 74 20 69 |er in.. | that i|
|00003860| 74 20 64 6f 65 73 6e 27 | 74 20 61 6c 77 61 79 73 |t doesn'|t always|
|00003870| 20 73 69 67 6e 61 6c 20 | 61 6e 20 65 72 72 6f 72 | signal |an error|
|00003880| 20 66 6f 72 20 6f 75 74 | 20 6f 66 20 72 61 6e 67 | for out| of rang|
|00003890| 65 2e 0d 0a 20 20 20 46 | 69 78 69 6e 67 20 69 74 |e... F|ixing it|
|000038a0| 20 75 70 20 69 73 20 6c | 65 66 74 20 61 73 20 61 | up is l|eft as a|
|000038b0| 6e 20 65 78 65 72 63 69 | 73 65 20 66 6f 72 20 74 |n exerci|se for t|
|000038c0| 68 65 20 72 65 61 64 65 | 72 2e 2a 2f 0d 0a 0d 0a |he reade|r.*/....|
|000038d0| 2f 2a 20 49 20 64 65 73 | 70 61 72 61 74 65 6c 79 |/* I des|parately|
|000038e0| 20 6e 65 65 64 65 64 20 | 61 20 22 4d 41 58 49 4e | needed |a "MAXIN|
|000038f0| 54 22 20 6f 72 20 22 4d | 41 58 4c 4f 4e 47 22 20 |T" or "M|AXLONG" |
|00003900| 63 6f 6e 73 74 61 6e 74 | 2c 20 73 6f 20 49 20 66 |constant|, so I f|
|00003910| 61 6b 65 64 20 69 74 2a | 2f 0d 0a 0d 0a 2f 2a 20 |aked it*|/..../* |
|00003920| 41 6c 73 6f 2c 20 49 20 | 66 6f 75 6e 64 20 69 74 |Also, I |found it|
|00003930| 20 63 6f 6e 76 65 6e 69 | 65 6e 74 20 74 6f 20 75 | conveni|ent to u|
|00003940| 73 65 20 22 67 6f 74 6f | 22 20 73 74 61 74 65 6d |se "goto|" statem|
|00003950| 65 6e 74 73 20 74 6f 20 | 68 61 6e 64 6c 65 20 6e |ents to |handle n|
|00003960| 6f 6e 2d 6c 6f 63 61 6c | 0d 0a 20 20 20 6c 6f 6f |on-local|.. loo|
|00003970| 70 20 65 78 69 74 73 20 | 61 6e 64 20 6a 75 6d 70 |p exits |and jump|
|00003980| 73 20 74 6f 20 63 6f 6d | 6d 6f 6e 20 65 72 72 6f |s to com|mon erro|
|00003990| 72 20 72 6f 75 74 69 6e | 65 73 2e 20 20 41 20 70 |r routin|es. A p|
|000039a0| 75 72 69 73 74 20 6d 69 | 67 68 74 20 63 6f 6d 70 |urist mi|ght comp|
|000039b0| 6c 61 69 6e 2c 0d 0a 20 | 20 20 62 75 74 20 49 20 |lain,.. | but I |
|000039c0| 74 68 69 6e 6b 20 74 68 | 65 20 63 6f 64 65 20 69 |think th|e code i|
|000039d0| 73 20 63 6c 65 61 6e 65 | 72 20 61 6e 64 20 65 61 |s cleane|r and ea|
|000039e0| 73 69 65 72 20 74 6f 20 | 66 6f 6c 6c 6f 77 20 74 |sier to |follow t|
|000039f0| 68 69 73 20 77 61 79 2e | 20 2a 2f 0d 0a 0d 0a 23 |his way.| */....#|
|00003a00| 64 65 66 69 6e 65 20 4d | 41 58 53 49 5a 45 20 31 |define M|AXSIZE 1|
|00003a10| 30 30 30 30 30 30 30 4c | 20 20 20 2f 2a 20 61 20 |0000000L| /* a |
|00003a20| 6c 69 65 2c 20 62 75 74 | 20 67 6f 6f 64 20 65 6e |lie, but| good en|
|00003a30| 6f 75 67 68 20 2a 2f 0d | 0a 0d 0a 4c 4f 43 41 4c |ough */.|...LOCAL|
|00003a40| 20 56 4f 49 44 20 67 65 | 74 73 65 71 62 6f 75 6e | VOID ge|tseqboun|
|00003a50| 64 73 28 73 74 61 72 74 | 2c 65 6e 64 2c 6c 65 6e |ds(start|,end,len|
|00003a60| 67 74 68 2c 73 74 61 72 | 74 6b 65 79 2c 65 6e 64 |gth,star|tkey,end|
|00003a70| 6b 65 79 29 0d 0a 6c 6f | 6e 67 20 2a 73 74 61 72 |key)..lo|ng *star|
|00003a80| 74 2c 20 2a 65 6e 64 2c | 20 6c 65 6e 67 74 68 3b |t, *end,| length;|
|00003a90| 0d 0a 4c 56 41 4c 20 2a | 73 74 61 72 74 6b 65 79 |..LVAL *|startkey|
|00003aa0| 2c 20 2a 65 6e 64 6b 65 | 79 3b 0d 0a 7b 0d 0a 20 |, *endke|y;..{.. |
|00003ab0| 20 20 20 4c 56 41 4c 20 | 61 72 67 3b 0d 0a 20 20 | LVAL |arg;.. |
|00003ac0| 20 20 0d 0a 20 20 20 20 | 69 66 20 28 78 6c 67 6b | .. |if (xlgk|
|00003ad0| 66 69 78 6e 75 6d 28 2a | 73 74 61 72 74 6b 65 79 |fixnum(*|startkey|
|00003ae0| 2c 26 61 72 67 29 29 20 | 7b 0d 0a 20 20 20 20 20 |,&arg)) |{.. |
|00003af0| 20 20 20 2a 73 74 61 72 | 74 20 3d 20 28 6c 6f 6e | *star|t = (lon|
|00003b00| 67 29 67 65 74 66 69 78 | 6e 75 6d 28 61 72 67 29 |g)getfix|num(arg)|
|00003b10| 3b 0d 0a 20 20 20 20 20 | 20 20 20 69 66 20 28 2a |;.. | if (*|
|00003b20| 73 74 61 72 74 20 3c 20 | 30 20 7c 7c 20 2a 73 74 |start < |0 || *st|
|00003b30| 61 72 74 20 3e 20 6c 65 | 6e 67 74 68 20 29 20 67 |art > le|ngth ) g|
|00003b40| 6f 74 6f 20 72 61 6e 67 | 65 45 72 72 6f 72 3b 0d |oto rang|eError;.|
|00003b50| 0a 20 20 20 20 7d 0d 0a | 20 20 20 20 65 6c 73 65 |. }..| else|
|00003b60| 20 2a 73 74 61 72 74 20 | 3d 20 30 3b 0d 0a 20 20 | *start |= 0;.. |
|00003b70| 20 20 0d 0a 20 20 20 20 | 69 66 20 28 78 6c 67 65 | .. |if (xlge|
|00003b80| 74 6b 65 79 61 72 67 28 | 2a 65 6e 64 6b 65 79 2c |tkeyarg(|*endkey,|
|00003b90| 20 26 61 72 67 29 20 26 | 26 20 61 72 67 20 21 3d | &arg) &|& arg !=|
|00003ba0| 20 4e 49 4c 29 20 7b 0d | 0a 20 20 20 20 20 20 20 | NIL) {.|. |
|00003bb0| 20 69 66 20 28 21 66 69 | 78 70 28 61 72 67 29 29 | if (!fi|xp(arg))|
|00003bc0| 20 78 6c 62 61 64 74 79 | 70 65 28 61 72 67 29 3b | xlbadty|pe(arg);|
|00003bd0| 0d 0a 20 20 20 20 20 20 | 20 20 2a 65 6e 64 20 3d |.. | *end =|
|00003be0| 20 28 6c 6f 6e 67 29 67 | 65 74 66 69 78 6e 75 6d | (long)g|etfixnum|
|00003bf0| 28 61 72 67 29 3b 0d 0a | 20 20 20 20 20 20 20 20 |(arg);..| |
|00003c00| 69 66 20 28 2a 65 6e 64 | 20 3c 20 30 20 20 7c 7c |if (*end| < 0 |||
|00003c10| 20 2a 65 6e 64 20 3e 20 | 6c 65 6e 67 74 68 29 20 | *end > |length) |
|00003c20| 67 6f 74 6f 20 72 61 6e | 67 65 45 72 72 6f 72 3b |goto ran|geError;|
|00003c30| 0d 0a 20 20 20 20 7d 0d | 0a 20 20 20 20 65 6c 73 |.. }.|. els|
|00003c40| 65 20 2a 65 6e 64 20 3d | 20 6c 65 6e 67 74 68 3b |e *end =| length;|
|00003c50| 20 2f 2a 20 77 65 20 6e | 65 65 64 20 61 20 6d 61 | /* we n|eed a ma|
|00003c60| 78 69 6e 74 20 76 61 6c | 75 65 21 20 2a 2f 0d 0a |xint val|ue! */..|
|00003c70| 20 20 20 20 0d 0a 20 20 | 20 20 69 66 20 28 2a 73 | .. | if (*s|
|00003c80| 74 61 72 74 20 3c 3d 20 | 2a 65 6e 64 29 20 20 20 |tart <= |*end) |
|00003c90| 20 20 72 65 74 75 72 6e | 3b 0d 0a 20 20 20 20 2f | return|;.. /|
|00003ca0| 2a 20 65 6c 73 65 20 74 | 68 65 72 65 20 69 73 20 |* else t|here is |
|00003cb0| 61 20 72 61 6e 67 65 20 | 65 72 72 6f 72 20 2a 2f |a range |error */|
|00003cc0| 0d 0a 20 20 20 20 0d 0a | 72 61 6e 67 65 45 72 72 |.. ..|rangeErr|
|00003cd0| 6f 72 3a 0d 0a 20 20 20 | 20 78 6c 65 72 72 6f 72 |or:.. | xlerror|
|00003ce0| 28 22 72 61 6e 67 65 20 | 65 72 72 6f 72 22 2c 61 |("range |error",a|
|00003cf0| 72 67 29 3b 0d 0a 7d 0d | 0a 20 20 20 20 20 20 20 |rg);..}.|. |
|00003d00| 20 0d 0a 0d 0a 0d 0a 2f | 2a 20 64 6f 74 65 73 74 | ....../|* dotest|
|00003d10| 31 20 2d 20 63 61 6c 6c | 20 61 20 74 65 73 74 20 |1 - call| a test |
|00003d20| 66 75 6e 63 74 69 6f 6e | 20 77 69 74 68 20 6f 6e |function| with on|
|00003d30| 65 20 61 72 67 75 6d 65 | 6e 74 20 2a 2f 0d 0a 2f |e argume|nt */../|
|00003d40| 2a 20 74 68 69 73 20 66 | 75 6e 63 74 69 6f 6e 20 |* this f|unction |
|00003d50| 77 61 73 20 69 6e 20 78 | 6c 6c 69 73 74 2e 63 20 |was in x|llist.c |
|00003d60| 2a 2f 0d 0a 69 6e 74 20 | 64 6f 74 65 73 74 31 28 |*/..int |dotest1(|
|00003d70| 61 72 67 2c 66 75 6e 29 | 0d 0a 20 20 4c 56 41 4c |arg,fun)|.. LVAL|
|00003d80| 20 61 72 67 2c 66 75 6e | 3b 0d 0a 7b 0d 0a 20 20 | arg,fun|;..{.. |
|00003d90| 20 20 4c 56 41 4c 20 2a | 6e 65 77 66 70 3b 0d 0a | LVAL *|newfp;..|
|00003da0| 0d 0a 20 20 20 20 2f 2a | 20 63 72 65 61 74 65 20 |.. /*| create |
|00003db0| 74 68 65 20 6e 65 77 20 | 63 61 6c 6c 20 66 72 61 |the new |call fra|
|00003dc0| 6d 65 20 2a 2f 0d 0a 20 | 20 20 20 6e 65 77 66 70 |me */.. | newfp|
|00003dd0| 20 3d 20 78 6c 73 70 3b | 0d 0a 20 20 20 20 70 75 | = xlsp;|.. pu|
|00003de0| 73 68 61 72 67 28 63 76 | 66 69 78 6e 75 6d 28 28 |sharg(cv|fixnum((|
|00003df0| 46 49 58 54 59 50 45 29 | 28 6e 65 77 66 70 20 2d |FIXTYPE)|(newfp -|
|00003e00| 20 78 6c 66 70 29 29 29 | 3b 0d 0a 20 20 20 20 70 | xlfp)))|;.. p|
|00003e10| 75 73 68 61 72 67 28 66 | 75 6e 29 3b 0d 0a 20 20 |usharg(f|un);.. |
|00003e20| 20 20 70 75 73 68 61 72 | 67 28 63 76 66 69 78 6e | pushar|g(cvfixn|
|00003e30| 75 6d 28 28 46 49 58 54 | 59 50 45 29 31 29 29 3b |um((FIXT|YPE)1));|
|00003e40| 0d 0a 20 20 20 20 70 75 | 73 68 61 72 67 28 61 72 |.. pu|sharg(ar|
|00003e50| 67 29 3b 0d 0a 20 20 20 | 20 78 6c 66 70 20 3d 20 |g);.. | xlfp = |
|00003e60| 6e 65 77 66 70 3b 0d 0a | 0d 0a 20 20 20 20 2f 2a |newfp;..|.. /*|
|00003e70| 20 72 65 74 75 72 6e 20 | 74 68 65 20 72 65 73 75 | return |the resu|
|00003e80| 6c 74 20 6f 66 20 61 70 | 70 6c 79 69 6e 67 20 74 |lt of ap|plying t|
|00003e90| 68 65 20 74 65 73 74 20 | 66 75 6e 63 74 69 6f 6e |he test |function|
|00003ea0| 20 2a 2f 0d 0a 20 20 20 | 20 72 65 74 75 72 6e 20 | */.. | return |
|00003eb0| 28 78 6c 61 70 70 6c 79 | 28 31 29 20 21 3d 20 4e |(xlapply|(1) != N|
|00003ec0| 49 4c 29 3b 0d 0a 0d 0a | 7d 0d 0a 0d 0a 0d 0a 2f |IL);....|}....../|
|00003ed0| 2a 20 78 65 6c 74 20 2d | 20 73 65 71 75 65 6e 63 |* xelt -| sequenc|
|00003ee0| 65 20 72 65 66 65 72 65 | 6e 63 65 20 66 75 6e 63 |e refere|nce func|
|00003ef0| 74 69 6f 6e 20 2a 2f 0d | 0a 4c 56 41 4c 20 78 65 |tion */.|.LVAL xe|
|00003f00| 6c 74 28 29 0d 0a 7b 0d | 0a 20 20 20 20 4c 56 41 |lt()..{.|. LVA|
|00003f10| 4c 20 73 65 71 2c 69 6e | 64 65 78 3b 0d 0a 20 20 |L seq,in|dex;.. |
|00003f20| 20 20 46 49 58 54 59 50 | 45 20 69 3b 0d 0a 20 20 | FIXTYP|E i;.. |
|00003f30| 20 20 0d 0a 20 20 20 20 | 2f 2a 20 67 65 74 20 74 | .. |/* get t|
|00003f40| 68 65 20 73 65 71 75 65 | 6e 63 65 20 61 6e 64 20 |he seque|nce and |
|00003f50| 74 68 65 20 69 6e 64 65 | 78 20 2a 2f 0d 0a 0d 0a |the inde|x */....|
|00003f60| 20 20 20 20 73 65 71 20 | 3d 20 78 6c 67 65 74 61 | seq |= xlgeta|
|00003f70| 72 67 28 29 3b 0d 0a 0d | 0a 20 20 20 20 69 6e 64 |rg();...|. ind|
|00003f80| 65 78 20 3d 20 78 6c 67 | 61 66 69 78 6e 75 6d 28 |ex = xlg|afixnum(|
|00003f90| 29 3b 20 69 20 3d 20 67 | 65 74 66 69 78 6e 75 6d |); i = g|etfixnum|
|00003fa0| 28 69 6e 64 65 78 29 3b | 20 0d 0a 20 20 20 20 69 |(index);| .. i|
|00003fb0| 66 20 28 69 20 3c 20 30 | 29 20 67 6f 74 6f 20 62 |f (i < 0|) goto b|
|00003fc0| 61 64 69 6e 64 65 78 3b | 0d 0a 20 20 20 20 0d 0a |adindex;|.. ..|
|00003fd0| 20 20 20 20 78 6c 6c 61 | 73 74 61 72 67 28 29 3b | xlla|starg();|
|00003fe0| 0d 0a 0d 0a 20 20 20 20 | 69 66 20 28 6c 69 73 74 |.... |if (list|
|00003ff0| 70 28 73 65 71 29 29 20 | 7b 20 2f 2a 20 64 6f 20 |p(seq)) |{ /* do |
|00004000| 6c 69 6b 65 20 6e 74 68 | 2c 20 62 75 74 20 63 68 |like nth|, but ch|
|00004010| 65 63 6b 20 66 6f 72 20 | 69 6e 20 72 61 6e 67 65 |eck for |in range|
|00004020| 20 2a 2f 0d 0a 20 20 20 | 20 20 20 20 20 2f 2a 20 | */.. | /* |
|00004030| 66 69 6e 64 20 74 68 65 | 20 69 74 68 20 65 6c 65 |find the| ith ele|
|00004040| 6d 65 6e 74 20 2a 2f 0d | 0a 20 20 20 20 20 20 20 |ment */.|. |
|00004050| 20 77 68 69 6c 65 20 28 | 63 6f 6e 73 70 28 73 65 | while (|consp(se|
|00004060| 71 29 29 20 7b 0d 0a 20 | 20 20 20 20 20 20 20 20 |q)) {.. | |
|00004070| 20 20 20 69 66 20 28 69 | 2d 2d 20 3d 3d 20 30 29 | if (i|-- == 0)|
|00004080| 20 72 65 74 75 72 6e 20 | 28 63 61 72 28 73 65 71 | return |(car(seq|
|00004090| 29 29 3b 0d 0a 20 20 20 | 20 20 20 20 20 20 20 20 |));.. | |
|000040a0| 20 73 65 71 20 3d 20 63 | 64 72 28 73 65 71 29 3b | seq = c|dr(seq);|
|000040b0| 0d 0a 20 20 20 20 20 20 | 20 20 7d 0d 0a 20 20 20 |.. | }.. |
|000040c0| 20 20 20 20 20 67 6f 74 | 6f 20 62 61 64 69 6e 64 | got|o badind|
|000040d0| 65 78 3b 20 20 2f 2a 20 | 65 6e 64 20 6f 66 20 6c |ex; /* |end of l|
|000040e0| 69 73 74 20 72 65 61 63 | 68 65 64 20 66 69 72 73 |ist reac|hed firs|
|000040f0| 74 20 2a 2f 0d 0a 20 20 | 20 20 7d 0d 0a 20 20 20 |t */.. | }.. |
|00004100| 20 20 20 20 20 0d 0a 0d | 0a 20 20 20 20 69 66 20 | ...|. if |
|00004110| 28 6e 74 79 70 65 28 73 | 65 71 29 20 3d 3d 20 53 |(ntype(s|eq) == S|
|00004120| 54 52 49 4e 47 29 20 7b | 20 0d 0a 20 20 20 20 20 |TRING) {| .. |
|00004130| 20 20 20 69 66 20 28 69 | 20 3e 3d 20 67 65 74 73 | if (i| >= gets|
|00004140| 6c 65 6e 67 74 68 28 73 | 65 71 29 2d 31 29 20 67 |length(s|eq)-1) g|
|00004150| 6f 74 6f 20 62 61 64 69 | 6e 64 65 78 3b 0d 0a 20 |oto badi|ndex;.. |
|00004160| 20 20 20 20 20 20 20 72 | 65 74 75 72 6e 20 28 63 | r|eturn (c|
|00004170| 76 63 68 61 72 28 73 65 | 71 2d 3e 6e 5f 73 74 72 |vchar(se|q->n_str|
|00004180| 69 6e 67 5b 69 5d 29 29 | 3b 0d 0a 20 20 20 20 7d |ing[i]))|;.. }|
|00004190| 0d 0a 20 20 20 20 0d 0a | 20 20 20 20 69 66 20 28 |.. ..| if (|
|000041a0| 6e 74 79 70 65 28 73 65 | 71 29 21 3d 56 45 43 54 |ntype(se|q)!=VECT|
|000041b0| 4f 52 29 20 78 6c 62 61 | 64 74 79 70 65 28 73 65 |OR) xlba|dtype(se|
|000041c0| 71 29 3b 20 2f 2a 20 74 | 79 70 65 20 6d 75 73 74 |q); /* t|ype must|
|000041d0| 20 62 65 20 61 72 72 61 | 79 20 2a 2f 0d 0a 0d 0a | be arra|y */....|
|000041e0| 20 20 20 20 2f 2a 20 72 | 61 6e 67 65 20 63 68 65 | /* r|ange che|
|000041f0| 63 6b 20 74 68 65 20 69 | 6e 64 65 78 20 2a 2f 0d |ck the i|ndex */.|
|00004200| 0a 20 20 20 20 69 66 20 | 28 69 20 3e 3d 20 67 65 |. if |(i >= ge|
|00004210| 74 73 69 7a 65 28 73 65 | 71 29 29 20 67 6f 74 6f |tsize(se|q)) goto|
|00004220| 20 62 61 64 69 6e 64 65 | 78 3b 0d 0a 0d 0a 20 20 | badinde|x;.... |
|00004230| 20 20 2f 2a 20 72 65 74 | 75 72 6e 20 74 68 65 20 | /* ret|urn the |
|00004240| 61 72 72 61 79 20 65 6c | 65 6d 65 6e 74 20 2a 2f |array el|ement */|
|00004250| 0d 0a 20 20 20 20 72 65 | 74 75 72 6e 20 28 67 65 |.. re|turn (ge|
|00004260| 74 65 6c 65 6d 65 6e 74 | 28 73 65 71 2c 28 69 6e |telement|(seq,(in|
|00004270| 74 29 69 29 29 3b 0d 0a | 20 20 20 20 0d 0a 62 61 |t)i));..| ..ba|
|00004280| 64 69 6e 64 65 78 3a 0d | 0a 20 20 20 20 78 6c 65 |dindex:.|. xle|
|00004290| 72 72 6f 72 28 22 69 6e | 64 65 78 20 6f 75 74 20 |rror("in|dex out |
|000042a0| 6f 66 20 62 6f 75 6e 64 | 73 22 2c 69 6e 64 65 78 |of bound|s",index|
|000042b0| 29 3b 0d 0a 7d 0d 0a 0d | 0a 0d 0a 2f 2a 20 78 6d |);..}...|.../* xm|
|000042c0| 61 70 20 2d 2d 20 6d 61 | 70 20 66 75 6e 63 74 69 |ap -- ma|p functi|
|000042d0| 6f 6e 20 2a 2f 0d 0a 0d | 0a 4c 4f 43 41 4c 20 6c |on */...|.LOCAL l|
|000042e0| 6f 6e 67 20 67 65 74 6c | 65 6e 67 74 68 28 73 65 |ong getl|ength(se|
|000042f0| 71 29 0d 0a 4c 56 41 4c | 20 73 65 71 3b 0d 0a 7b |q)..LVAL| seq;..{|
|00004300| 0d 0a 20 20 20 20 6c 6f | 6e 67 20 6c 65 6e 3b 0d |.. lo|ng len;.|
|00004310| 0a 20 20 20 20 0d 0a 20 | 20 20 20 69 66 20 28 73 |. .. | if (s|
|00004320| 65 71 20 3d 3d 20 4e 49 | 4c 29 20 72 65 74 75 72 |eq == NI|L) retur|
|00004330| 6e 20 30 3b 0d 0a 20 20 | 20 20 0d 0a 20 20 20 20 |n 0;.. | .. |
|00004340| 73 77 69 74 63 68 20 28 | 6e 74 79 70 65 28 73 65 |switch (|ntype(se|
|00004350| 71 29 29 20 7b 0d 0a 20 | 20 20 20 20 20 20 20 63 |q)) {.. | c|
|00004360| 61 73 65 20 53 54 52 49 | 4e 47 3a 20 0d 0a 20 20 |ase STRI|NG: .. |
|00004370| 20 20 20 20 20 20 20 20 | 20 20 72 65 74 75 72 6e | | return|
|00004380| 20 28 6c 6f 6e 67 29 67 | 65 74 73 6c 65 6e 67 74 | (long)g|etslengt|
|00004390| 68 28 73 65 71 29 20 2d | 20 31 3b 0d 0a 20 20 20 |h(seq) -| 1;.. |
|000043a0| 20 20 20 20 20 63 61 73 | 65 20 56 45 43 54 4f 52 | cas|e VECTOR|
|000043b0| 3a 20 0d 0a 20 20 20 20 | 20 20 20 20 20 20 20 20 |: .. | |
|000043c0| 72 65 74 75 72 6e 20 28 | 6c 6f 6e 67 29 67 65 74 |return (|long)get|
|000043d0| 73 69 7a 65 28 73 65 71 | 29 3b 0d 0a 20 20 20 20 |size(seq|);.. |
|000043e0| 20 20 20 20 63 61 73 65 | 20 43 4f 4e 53 3a 20 0d | case| CONS: .|
|000043f0| 0a 20 20 20 20 20 20 20 | 20 20 20 20 20 6c 65 6e |. | len|
|00004400| 20 3d 20 30 3b 0d 0a 20 | 20 20 20 20 20 20 20 20 | = 0;.. | |
|00004410| 20 20 20 77 68 69 6c 65 | 20 28 63 6f 6e 73 70 28 | while| (consp(|
|00004420| 73 65 71 29 29 20 7b 0d | 0a 20 20 20 20 20 20 20 |seq)) {.|. |
|00004430| 20 20 20 20 20 20 20 20 | 20 6c 65 6e 2b 2b 3b 0d | | len++;.|
|00004440| 0a 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |. | |
|00004450| 20 73 65 71 20 3d 20 63 | 64 72 28 73 65 71 29 3b | seq = c|dr(seq);|
|00004460| 0d 0a 20 20 20 20 20 20 | 20 20 20 20 20 20 7d 0d |.. | }.|
|00004470| 0a 20 20 20 20 20 20 20 | 20 20 20 20 20 72 65 74 |. | ret|
|00004480| 75 72 6e 20 6c 65 6e 3b | 0d 0a 20 20 20 20 20 20 |urn len;|.. |
|00004490| 20 20 64 65 66 61 75 6c | 74 3a 20 0d 0a 20 20 20 | defaul|t: .. |
|000044a0| 20 20 20 20 20 20 20 20 | 20 78 6c 62 61 64 74 79 | | xlbadty|
|000044b0| 70 65 28 73 65 71 29 3b | 0d 0a 20 20 20 20 20 20 |pe(seq);|.. |
|000044c0| 20 20 20 20 20 20 72 65 | 74 75 72 6e 20 28 30 29 | re|turn (0)|
|000044d0| 3b 20 2f 2a 20 68 61 20 | 68 61 20 2a 2f 0d 0a 20 |; /* ha |ha */.. |
|000044e0| 20 20 20 20 20 20 20 7d | 0d 0a 7d 0d 0a 0d 0a 0d | }|..}.....|
|000044f0| 0a 4c 56 41 4c 20 78 6d | 61 70 28 29 0d 0a 7b 0d |.LVAL xm|ap()..{.|
|00004500| 0a 20 20 20 20 4c 56 41 | 4c 20 2a 6e 65 77 66 70 |. LVA|L *newfp|
|00004510| 2c 20 66 75 6e 2c 20 6c | 69 73 74 73 2c 20 76 61 |, fun, l|ists, va|
|00004520| 6c 2c 20 6c 61 73 74 2c | 20 78 2c 20 79 3b 0d 0a |l, last,| x, y;..|
|00004530| 20 20 20 20 6c 6f 6e 67 | 20 6c 65 6e 2c 74 65 6d | long| len,tem|
|00004540| 70 3b 0d 0a 20 20 20 20 | 69 6e 74 20 61 72 67 63 |p;.. |int argc|
|00004550| 2c 20 74 79 70 2c 20 69 | 3b 0d 0a 20 20 20 20 0d |, typ, i|;.. .|
|00004560| 0a 20 20 20 20 2f 2a 20 | 70 72 6f 74 65 63 74 20 |. /* |protect |
|00004570| 73 6f 6d 65 20 70 6f 69 | 6e 74 65 72 73 20 2a 2f |some poi|nters */|
|00004580| 0d 0a 20 20 20 20 78 6c | 73 74 6b 63 68 65 63 6b |.. xl|stkcheck|
|00004590| 28 33 29 3b 0d 0a 20 20 | 20 20 78 6c 73 61 76 65 |(3);.. | xlsave|
|000045a0| 28 66 75 6e 29 3b 0d 0a | 20 20 20 20 78 6c 73 61 |(fun);..| xlsa|
|000045b0| 76 65 28 6c 69 73 74 73 | 29 3b 0d 0a 20 20 20 20 |ve(lists|);.. |
|000045c0| 78 6c 73 61 76 65 28 76 | 61 6c 29 3b 0d 0a 0d 0a |xlsave(v|al);....|
|000045d0| 20 20 20 20 2f 2a 20 67 | 65 74 20 74 68 65 20 74 | /* g|et the t|
|000045e0| 79 70 65 20 6f 66 20 72 | 65 73 75 6c 74 61 6e 74 |ype of r|esultant|
|000045f0| 20 2a 2f 0d 0a 20 20 20 | 20 69 66 20 28 28 6c 61 | */.. | if ((la|
|00004600| 73 74 20 3d 20 78 6c 67 | 65 74 61 72 67 28 29 29 |st = xlg|etarg())|
|00004610| 20 3d 3d 20 4e 49 4c 29 | 20 7b 20 20 20 2f 2a 20 | == NIL)| { /* |
|00004620| 6e 6f 74 68 69 6e 67 20 | 69 73 20 72 65 74 75 72 |nothing |is retur|
|00004630| 6e 65 64 20 2a 2f 0d 0a | 20 20 20 20 20 20 20 20 |ned */..| |
|00004640| 74 79 70 20 3d 20 30 3b | 0d 0a 20 20 20 20 7d 0d |typ = 0;|.. }.|
|00004650| 0a 20 20 20 20 65 6c 73 | 65 20 69 66 20 28 28 74 |. els|e if ((t|
|00004660| 79 70 20 3d 20 78 6c 63 | 76 74 74 79 70 65 28 6c |yp = xlc|vttype(l|
|00004670| 61 73 74 29 29 20 21 3d | 20 43 4f 4e 53 20 26 26 |ast)) !=| CONS &&|
|00004680| 20 0d 0a 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | .. | |
|00004690| 20 20 20 74 79 70 20 21 | 3d 20 53 54 52 49 4e 47 | typ !|= STRING|
|000046a0| 20 26 26 20 74 79 70 20 | 21 3d 20 56 45 43 54 4f | && typ |!= VECTO|
|000046b0| 52 29 20 7b 0d 0a 20 20 | 20 20 20 20 20 20 78 6c |R) {.. | xl|
|000046c0| 65 72 72 6f 72 28 22 69 | 6e 76 61 6c 69 64 20 72 |error("i|nvalid r|
|000046d0| 65 73 75 6c 74 20 74 79 | 70 65 22 2c 20 6c 61 73 |esult ty|pe", las|
|000046e0| 74 29 3b 0d 0a 20 20 20 | 20 7d 0d 0a 20 20 20 20 |t);.. | }.. |
|000046f0| 0d 0a 20 20 20 20 2f 2a | 20 67 65 74 20 74 68 65 |.. /*| get the|
|00004700| 20 66 75 6e 63 74 69 6f | 6e 20 74 6f 20 61 70 70 | functio|n to app|
|00004710| 6c 79 20 61 6e 64 20 61 | 72 67 75 6d 65 6e 74 20 |ly and a|rgument |
|00004720| 73 65 71 75 65 6e 63 65 | 73 20 2a 2f 0d 0a 20 20 |sequence|s */.. |
|00004730| 20 20 66 75 6e 20 3d 20 | 78 6c 67 65 74 61 72 67 | fun = |xlgetarg|
|00004740| 28 29 3b 0d 0a 20 20 20 | 20 76 61 6c 20 3d 20 4e |();.. | val = N|
|00004750| 49 4c 3b 0d 0a 20 20 20 | 20 6c 69 73 74 73 20 3d |IL;.. | lists =|
|00004760| 20 78 6c 67 65 74 61 72 | 67 28 29 3b 0d 0a 20 20 | xlgetar|g();.. |
|00004770| 20 20 6c 65 6e 20 3d 20 | 67 65 74 6c 65 6e 67 74 | len = |getlengt|
|00004780| 68 28 6c 69 73 74 73 29 | 3b 0d 0a 20 20 20 20 61 |h(lists)|;.. a|
|00004790| 72 67 63 20 3d 20 31 3b | 0d 0a 0d 0a 20 20 20 20 |rgc = 1;|.... |
|000047a0| 2f 2a 20 62 75 69 6c 64 | 20 61 20 6c 69 73 74 20 |/* build| a list |
|000047b0| 6f 66 20 61 72 67 75 6d | 65 6e 74 20 6c 69 73 74 |of argum|ent list|
|000047c0| 73 20 2a 2f 0d 0a 20 20 | 20 20 66 6f 72 20 28 6c |s */.. | for (l|
|000047d0| 69 73 74 73 20 3d 20 6c | 61 73 74 20 3d 20 63 6f |ists = l|ast = co|
|000047e0| 6e 73 61 28 6c 69 73 74 | 73 29 3b 20 6d 6f 72 65 |nsa(list|s); more|
|000047f0| 61 72 67 73 28 29 3b 20 | 6c 61 73 74 20 3d 20 63 |args(); |last = c|
|00004800| 64 72 28 6c 61 73 74 29 | 29 20 7b 0d 0a 20 20 20 |dr(last)|) {.. |
|00004810| 20 20 20 20 20 76 61 6c | 20 3d 20 78 6c 67 65 74 | val| = xlget|
|00004820| 61 72 67 28 29 3b 0d 0a | 20 20 20 20 20 20 20 20 |arg();..| |
|00004830| 69 66 20 28 28 74 65 6d | 70 20 3d 20 67 65 74 6c |if ((tem|p = getl|
|00004840| 65 6e 67 74 68 28 76 61 | 6c 29 29 20 3c 20 6c 65 |ength(va|l)) < le|
|00004850| 6e 29 20 6c 65 6e 20 3d | 20 74 65 6d 70 3b 0d 0a |n) len =| temp;..|
|00004860| 20 20 20 20 20 20 20 20 | 61 72 67 63 2b 2b 3b 0d | |argc++;.|
|00004870| 0a 20 20 20 20 20 20 20 | 20 72 70 6c 61 63 64 28 |. | rplacd(|
|00004880| 6c 61 73 74 2c 28 63 6f | 6e 73 28 76 61 6c 2c 4e |last,(co|ns(val,N|
|00004890| 49 4c 29 29 29 3b 0d 0a | 20 20 20 20 7d 0d 0a 20 |IL)));..| }.. |
|000048a0| 20 20 20 0d 0a 20 20 20 | 20 2f 2a 20 69 6e 69 74 | .. | /* init|
|000048b0| 69 61 6c 69 7a 65 20 74 | 68 65 20 72 65 73 75 6c |ialize t|he resul|
|000048c0| 74 20 6c 69 73 74 20 2a | 2f 0d 0a 20 20 20 20 73 |t list *|/.. s|
|000048d0| 77 69 74 63 68 20 28 74 | 79 70 29 20 7b 0d 0a 20 |witch (t|yp) {.. |
|000048e0| 20 20 20 20 20 20 20 63 | 61 73 65 20 56 45 43 54 | c|ase VECT|
|000048f0| 4f 52 3a 20 76 61 6c 20 | 3d 20 6e 65 77 76 65 63 |OR: val |= newvec|
|00004900| 74 6f 72 28 6c 65 6e 29 | 3b 20 62 72 65 61 6b 3b |tor(len)|; break;|
|00004910| 0d 0a 20 20 20 20 20 20 | 20 20 63 61 73 65 20 53 |.. | case S|
|00004920| 54 52 49 4e 47 3a 20 76 | 61 6c 20 3d 20 6e 65 77 |TRING: v|al = new|
|00004930| 73 74 72 69 6e 67 28 6c | 65 6e 2b 31 29 3b 20 62 |string(l|en+1); b|
|00004940| 72 65 61 6b 3b 0d 0a 20 | 20 20 20 20 20 20 20 64 |reak;.. | d|
|00004950| 65 66 61 75 6c 74 3a 20 | 20 20 20 76 61 6c 20 3d |efault: | val =|
|00004960| 20 4e 49 4c 3b 20 62 72 | 65 61 6b 3b 0d 0a 20 20 | NIL; br|eak;.. |
|00004970| 20 20 7d 0d 0a 20 20 20 | 20 0d 0a 20 20 20 20 0d | }.. | .. .|
|00004980| 0a 20 20 20 20 2f 2a 20 | 6c 6f 6f 70 20 74 68 72 |. /* |loop thr|
|00004990| 6f 75 67 68 20 65 61 63 | 68 20 6f 66 20 74 68 65 |ough eac|h of the|
|000049a0| 20 61 72 67 75 6d 65 6e | 74 20 6c 69 73 74 73 20 | argumen|t lists |
|000049b0| 2a 2f 0d 0a 20 20 20 20 | 66 6f 72 20 28 69 3d 30 |*/.. |for (i=0|
|000049c0| 3b 69 3c 6c 65 6e 3b 69 | 2b 2b 29 20 7b 0d 0a 0d |;i<len;i|++) {...|
|000049d0| 0a 20 20 20 20 20 20 20 | 20 2f 2a 20 62 75 69 6c |. | /* buil|
|000049e0| 64 20 61 6e 20 61 72 67 | 75 6d 65 6e 74 20 6c 69 |d an arg|ument li|
|000049f0| 73 74 20 66 72 6f 6d 20 | 74 68 65 20 73 75 62 6c |st from |the subl|
|00004a00| 69 73 74 73 20 2a 2f 0d | 0a 20 20 20 20 20 20 20 |ists */.|. |
|00004a10| 20 6e 65 77 66 70 20 3d | 20 78 6c 73 70 3b 0d 0a | newfp =| xlsp;..|
|00004a20| 20 20 20 20 20 20 20 20 | 70 75 73 68 61 72 67 28 | |pusharg(|
|00004a30| 63 76 66 69 78 6e 75 6d | 28 28 46 49 58 54 59 50 |cvfixnum|((FIXTYP|
|00004a40| 45 29 28 6e 65 77 66 70 | 20 2d 20 78 6c 66 70 29 |E)(newfp| - xlfp)|
|00004a50| 29 29 3b 0d 0a 20 20 20 | 20 20 20 20 20 70 75 73 |));.. | pus|
|00004a60| 68 61 72 67 28 66 75 6e | 29 3b 0d 0a 20 20 20 20 |harg(fun|);.. |
|00004a70| 20 20 20 20 70 75 73 68 | 61 72 67 28 4e 49 4c 29 | push|arg(NIL)|
|00004a80| 3b 0d 0a 20 20 20 20 20 | 20 20 20 66 6f 72 20 28 |;.. | for (|
|00004a90| 78 20 3d 20 6c 69 73 74 | 73 3b 20 78 20 21 3d 20 |x = list|s; x != |
|00004aa0| 4e 49 4c 20 3b 20 78 20 | 3d 20 63 64 72 28 78 29 |NIL ; x |= cdr(x)|
|00004ab0| 29 20 7b 0d 0a 20 20 20 | 20 20 20 20 20 20 20 20 |) {.. | |
|00004ac0| 20 79 20 3d 20 63 61 72 | 28 78 29 3b 0d 0a 20 20 | y = car|(x);.. |
|00004ad0| 20 20 20 20 20 20 20 20 | 20 20 73 77 69 74 63 68 | | switch|
|00004ae0| 20 28 6e 74 79 70 65 28 | 79 29 29 20 7b 0d 0a 20 | (ntype(|y)) {.. |
|00004af0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 63 | | c|
|00004b00| 61 73 65 20 43 4f 4e 53 | 3a 20 0d 0a 20 20 20 20 |ase CONS|: .. |
|00004b10| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00004b20| 70 75 73 68 61 72 67 28 | 63 61 72 28 79 29 29 3b |pusharg(|car(y));|
|00004b30| 0d 0a 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |.. | |
|00004b40| 20 20 20 20 20 20 72 70 | 6c 61 63 61 28 78 2c 63 | rp|laca(x,c|
|00004b50| 64 72 28 79 29 29 3b 0d | 0a 20 20 20 20 20 20 20 |dr(y));.|. |
|00004b60| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 62 72 65 | | bre|
|00004b70| 61 6b 3b 0d 0a 20 20 20 | 20 20 20 20 20 20 20 20 |ak;.. | |
|00004b80| 20 20 20 20 20 63 61 73 | 65 20 56 45 43 54 4f 52 | cas|e VECTOR|
|00004b90| 3a 0d 0a 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |:.. | |
|00004ba0| 20 20 20 20 20 20 20 70 | 75 73 68 61 72 67 28 67 | p|usharg(g|
|00004bb0| 65 74 65 6c 65 6d 65 6e | 74 28 79 2c 69 29 29 3b |etelemen|t(y,i));|
|00004bc0| 0d 0a 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |.. | |
|00004bd0| 20 20 20 20 20 20 62 72 | 65 61 6b 3b 0d 0a 20 20 | br|eak;.. |
|00004be0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 63 61 | | ca|
|00004bf0| 73 65 20 53 54 52 49 4e | 47 3a 0d 0a 20 20 20 20 |se STRIN|G:.. |
|00004c00| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00004c10| 70 75 73 68 61 72 67 28 | 63 76 63 68 61 72 28 79 |pusharg(|cvchar(y|
|00004c20| 2d 3e 6e 5f 73 74 72 69 | 6e 67 5b 69 5d 29 29 3b |->n_stri|ng[i]));|
|00004c30| 0d 0a 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |.. | |
|00004c40| 20 20 20 20 20 20 62 72 | 65 61 6b 3b 0d 0a 20 20 | br|eak;.. |
|00004c50| 20 20 20 20 20 20 20 20 | 20 20 7d 0d 0a 20 20 20 | | }.. |
|00004c60| 20 20 20 20 20 7d 0d 0a | 0d 0a 20 20 20 20 20 20 | }..|.. |
|00004c70| 20 20 2f 2a 20 61 70 70 | 6c 79 20 74 68 65 20 66 | /* app|ly the f|
|00004c80| 75 6e 63 74 69 6f 6e 20 | 74 6f 20 74 68 65 20 61 |unction |to the a|
|00004c90| 72 67 75 6d 65 6e 74 73 | 20 2a 2f 0d 0a 20 20 20 |rguments| */.. |
|00004ca0| 20 20 20 20 20 6e 65 77 | 66 70 5b 32 5d 20 3d 20 | new|fp[2] = |
|00004cb0| 63 76 66 69 78 6e 75 6d | 28 28 46 49 58 54 59 50 |cvfixnum|((FIXTYP|
|00004cc0| 45 29 61 72 67 63 29 3b | 0d 0a 20 20 20 20 20 20 |E)argc);|.. |
|00004cd0| 20 20 78 6c 66 70 20 3d | 20 6e 65 77 66 70 3b 0d | xlfp =| newfp;.|
|00004ce0| 0a 20 20 20 20 20 20 20 | 20 78 20 3d 20 78 6c 61 |. | x = xla|
|00004cf0| 70 70 6c 79 28 61 72 67 | 63 29 3b 0d 0a 20 20 20 |pply(arg|c);.. |
|00004d00| 20 20 20 20 20 0d 0a 20 | 20 20 20 20 20 20 20 73 | .. | s|
|00004d10| 77 69 74 63 68 20 28 74 | 79 70 29 20 7b 0d 0a 20 |witch (t|yp) {.. |
|00004d20| 20 20 20 20 20 20 20 20 | 20 20 20 63 61 73 65 20 | | case |
|00004d30| 43 4f 4e 53 3a 0d 0a 20 | 20 20 20 20 20 20 20 20 |CONS:.. | |
|00004d40| 20 20 20 20 20 20 20 79 | 20 3d 20 63 6f 6e 73 61 | y| = consa|
|00004d50| 28 78 29 3b 0d 0a 20 20 | 20 20 20 20 20 20 20 20 |(x);.. | |
|00004d60| 20 20 20 20 20 20 69 66 | 20 28 76 61 6c 29 20 72 | if| (val) r|
|00004d70| 70 6c 61 63 64 28 6c 61 | 73 74 2c 79 29 3b 0d 0a |placd(la|st,y);..|
|00004d80| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00004d90| 65 6c 73 65 20 76 61 6c | 20 3d 20 79 3b 0d 0a 20 |else val| = y;.. |
|00004da0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 6c | | l|
|00004db0| 61 73 74 20 3d 20 79 3b | 0d 0a 20 20 20 20 20 20 |ast = y;|.. |
|00004dc0| 20 20 20 20 20 20 20 20 | 20 20 62 72 65 61 6b 3b | | break;|
|00004dd0| 0d 0a 20 20 20 20 20 20 | 20 20 20 20 20 20 63 61 |.. | ca|
|00004de0| 73 65 20 56 45 43 54 4f | 52 3a 0d 0a 20 20 20 20 |se VECTO|R:.. |
|00004df0| 20 20 20 20 20 20 20 20 | 20 20 20 20 73 65 74 65 | | sete|
|00004e00| 6c 65 6d 65 6e 74 28 76 | 61 6c 2c 69 2c 78 29 3b |lement(v|al,i,x);|
|00004e10| 0d 0a 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |.. | |
|00004e20| 20 20 62 72 65 61 6b 3b | 0d 0a 20 20 20 20 20 20 | break;|.. |
|00004e30| 20 20 20 20 20 20 63 61 | 73 65 20 53 54 52 49 4e | ca|se STRIN|
|00004e40| 47 3a 0d 0a 20 20 20 20 | 20 20 20 20 20 20 20 20 |G:.. | |
|00004e50| 20 20 20 20 69 66 20 28 | 21 63 68 61 72 70 28 78 | if (|!charp(x|
|00004e60| 29 29 20 0d 0a 20 20 20 | 20 20 20 20 20 20 20 20 |)) .. | |
|00004e70| 20 20 20 20 20 20 20 20 | 20 78 6c 65 72 72 6f 72 | | xlerror|
|00004e80| 28 22 6d 61 70 20 66 75 | 6e 63 74 69 6f 6e 20 72 |("map fu|nction r|
|00004e90| 65 74 75 72 6e 65 64 20 | 6e 6f 6e 2d 63 68 61 72 |eturned |non-char|
|00004ea0| 61 63 74 65 72 22 2c 78 | 29 3b 0d 0a 20 20 20 20 |acter",x|);.. |
|00004eb0| 20 20 20 20 20 20 20 20 | 20 20 20 20 76 61 6c 2d | | val-|
|00004ec0| 3e 6e 5f 73 74 72 69 6e | 67 5b 69 5d 20 3d 20 67 |>n_strin|g[i] = g|
|00004ed0| 65 74 63 68 63 6f 64 65 | 28 78 29 3b 0d 0a 20 20 |etchcode|(x);.. |
|00004ee0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 62 72 | | br|
|00004ef0| 65 61 6b 3b 0d 0a 20 20 | 20 20 20 20 20 20 7d 0d |eak;.. | }.|
|00004f00| 0a 20 20 20 20 20 20 20 | 20 20 20 20 20 0d 0a 20 |. | .. |
|00004f10| 20 20 20 7d 0d 0a 0d 0a | 20 20 20 20 2f 2a 20 72 | }....| /* r|
|00004f20| 65 73 74 6f 72 65 20 74 | 68 65 20 73 74 61 63 6b |estore t|he stack|
|00004f30| 20 2a 2f 0d 0a 20 20 20 | 20 78 6c 70 6f 70 6e 28 | */.. | xlpopn(|
|00004f40| 33 29 3b 0d 0a 0d 0a 20 | 20 20 20 2f 2a 20 72 65 |3);.... | /* re|
|00004f50| 74 75 72 6e 20 74 68 65 | 20 6c 61 73 74 20 74 65 |turn the| last te|
|00004f60| 73 74 20 65 78 70 72 65 | 73 73 69 6f 6e 20 76 61 |st expre|ssion va|
|00004f70| 6c 75 65 20 2a 2f 0d 0a | 20 20 20 20 72 65 74 75 |lue */..| retu|
|00004f80| 72 6e 20 28 76 61 6c 29 | 3b 0d 0a 20 20 20 20 7d |rn (val)|;.. }|
|00004f90| 0d 0a 0d 0a 0d 0a 0d 0a | 0d 0a 2f 2a 20 78 63 6f |........|../* xco|
|00004fa0| 6e 63 61 74 65 6e 61 74 | 65 20 2d 20 63 6f 6e 63 |ncatenat|e - conc|
|00004fb0| 61 74 65 6e 61 74 65 20 | 61 20 62 75 6e 63 68 20 |atenate |a bunch |
|00004fc0| 6f 66 20 73 65 71 75 65 | 6e 63 65 73 20 2a 2f 0d |of seque|nces */.|
|00004fd0| 0a 2f 2a 20 72 65 70 6c | 61 63 65 73 20 28 61 6e |./* repl|aces (an|
|00004fe0| 64 20 65 78 74 65 6e 64 | 73 29 20 73 74 72 63 61 |d extend|s) strca|
|00004ff0| 74 2c 20 6e 6f 77 20 61 | 20 6d 61 63 72 6f 20 2a |t, now a| macro *|
|00005000| 2f 0d 0a 4c 4f 43 41 4c | 20 69 6e 74 20 63 61 6c |/..LOCAL| int cal|
|00005010| 63 6c 65 6e 67 74 68 28 | 29 0d 0a 7b 0d 0a 20 20 |clength(|)..{.. |
|00005020| 20 20 4c 56 41 4c 20 74 | 6d 70 2c 20 2a 73 61 76 | LVAL t|mp, *sav|
|00005030| 65 61 72 67 76 3b 0d 0a | 20 20 20 20 69 6e 74 20 |eargv;..| int |
|00005040| 73 61 76 65 61 72 67 63 | 3b 0d 0a 20 20 20 20 69 |saveargc|;.. i|
|00005050| 6e 74 20 6c 65 6e 3b 0d | 0a 0d 0a 20 20 20 20 2f |nt len;.|... /|
|00005060| 2a 20 73 61 76 65 20 74 | 68 65 20 61 72 67 75 6d |* save t|he argum|
|00005070| 65 6e 74 20 6c 69 73 74 | 20 2a 2f 0d 0a 20 20 20 |ent list| */.. |
|00005080| 20 73 61 76 65 61 72 67 | 76 20 3d 20 78 6c 61 72 | savearg|v = xlar|
|00005090| 67 76 3b 0d 0a 20 20 20 | 20 73 61 76 65 61 72 67 |gv;.. | savearg|
|000050a0| 63 20 3d 20 78 6c 61 72 | 67 63 3b 0d 0a 0d 0a 20 |c = xlar|gc;.... |
|000050b0| 20 20 20 2f 2a 20 66 69 | 6e 64 20 74 68 65 20 6c | /* fi|nd the l|
|000050c0| 65 6e 67 74 68 20 6f 66 | 20 74 68 65 20 6e 65 77 |ength of| the new|
|000050d0| 20 73 74 72 69 6e 67 20 | 6f 72 20 76 65 63 74 6f | string |or vecto|
|000050e0| 72 20 2a 2f 0d 0a 20 20 | 20 20 66 6f 72 20 28 6c |r */.. | for (l|
|000050f0| 65 6e 20 3d 20 30 3b 20 | 6d 6f 72 65 61 72 67 73 |en = 0; |moreargs|
|00005100| 28 29 3b 20 29 20 7b 0d | 0a 20 20 20 20 20 20 20 |(); ) {.|. |
|00005110| 20 74 6d 70 20 3d 20 78 | 6c 67 65 74 61 72 67 28 | tmp = x|lgetarg(|
|00005120| 29 3b 0d 0a 20 20 20 20 | 20 20 20 20 6c 65 6e 20 |);.. | len |
|00005130| 2b 3d 20 67 65 74 6c 65 | 6e 67 74 68 28 74 6d 70 |+= getle|ngth(tmp|
|00005140| 29 3b 0d 0a 20 20 20 20 | 20 20 20 20 69 66 20 28 |);.. | if (|
|00005150| 6c 65 6e 20 3c 20 30 29 | 20 78 6c 65 72 72 6f 72 |len < 0)| xlerror|
|00005160| 28 22 74 6f 6f 20 6c 6f | 6e 67 22 2c 74 6d 70 29 |("too lo|ng",tmp)|
|00005170| 3b 0d 0a 20 20 20 20 7d | 0d 0a 0d 0a 20 20 20 20 |;.. }|.... |
|00005180| 2f 2a 20 72 65 73 74 6f | 72 65 20 74 68 65 20 61 |/* resto|re the a|
|00005190| 72 67 75 6d 65 6e 74 20 | 6c 69 73 74 20 2a 2f 0d |rgument |list */.|
|000051a0| 0a 20 20 20 20 78 6c 61 | 72 67 76 20 3d 20 73 61 |. xla|rgv = sa|
|000051b0| 76 65 61 72 67 76 3b 0d | 0a 20 20 20 20 78 6c 61 |veargv;.|. xla|
|000051c0| 72 67 63 20 3d 20 73 61 | 76 65 61 72 67 63 3b 0d |rgc = sa|veargc;.|
|000051d0| 0a 0d 0a 20 20 20 20 72 | 65 74 75 72 6e 20 6c 65 |... r|eturn le|
|000051e0| 6e 3b 0d 0a 7d 0d 0a 0d | 0a 0d 0a 4c 4f 43 41 4c |n;..}...|...LOCAL|
|000051f0| 20 4c 56 41 4c 20 63 61 | 74 74 6f 73 74 72 69 6e | LVAL ca|ttostrin|
|00005200| 67 28 29 0d 0a 7b 0d 0a | 20 20 20 20 4c 56 41 4c |g()..{..| LVAL|
|00005210| 20 74 6d 70 2c 74 65 6d | 70 2c 76 61 6c 3b 0d 0a | tmp,tem|p,val;..|
|00005220| 20 20 20 20 75 6e 73 69 | 67 6e 65 64 20 63 68 61 | unsi|gned cha|
|00005230| 72 20 2a 73 74 72 3b 0d | 0a 20 20 20 20 69 6e 74 |r *str;.|. int|
|00005240| 20 6c 65 6e 2c 69 3b 0d | 0a 20 20 20 20 0d 0a 20 | len,i;.|. .. |
|00005250| 20 20 20 2f 2a 20 66 69 | 6e 64 20 72 65 73 75 6c | /* fi|nd resul|
|00005260| 74 69 6e 67 20 6c 65 6e | 67 74 68 20 2d 2d 20 61 |ting len|gth -- a|
|00005270| 6c 73 6f 20 76 61 6c 69 | 64 61 74 65 73 20 61 72 |lso vali|dates ar|
|00005280| 67 75 6d 65 6e 74 20 74 | 79 70 65 73 20 2a 2f 0d |gument t|ypes */.|
|00005290| 0a 20 20 20 20 6c 65 6e | 20 3d 20 63 61 6c 63 6c |. len| = calcl|
|000052a0| 65 6e 67 74 68 28 29 3b | 0d 0a 0d 0a 20 20 20 20 |ength();|.... |
|000052b0| 2f 2a 20 63 72 65 61 74 | 65 20 74 68 65 20 72 65 |/* creat|e the re|
|000052c0| 73 75 6c 74 20 73 74 72 | 69 6e 67 20 2a 2f 0d 0a |sult str|ing */..|
|000052d0| 20 20 20 20 76 61 6c 20 | 3d 20 6e 65 77 73 74 72 | val |= newstr|
|000052e0| 69 6e 67 28 6c 65 6e 2b | 31 29 3b 0d 0a 20 20 20 |ing(len+|1);.. |
|000052f0| 20 73 74 72 20 3d 20 67 | 65 74 73 74 72 69 6e 67 | str = g|etstring|
|00005300| 28 76 61 6c 29 3b 0d 0a | 0d 0a 20 20 20 20 2f 2a |(val);..|.. /*|
|00005310| 20 63 6f 6d 62 69 6e 65 | 20 74 68 65 20 73 74 72 | combine| the str|
|00005320| 69 6e 67 73 20 2a 2f 0d | 0a 20 20 20 20 77 68 69 |ings */.|. whi|
|00005330| 6c 65 20 28 6d 6f 72 65 | 61 72 67 73 28 29 29 20 |le (more|args()) |
|00005340| 7b 0d 0a 20 20 20 20 20 | 20 20 20 74 6d 70 20 3d |{.. | tmp =|
|00005350| 20 6e 65 78 74 61 72 67 | 28 29 3b 0d 0a 20 20 20 | nextarg|();.. |
|00005360| 20 20 20 20 20 69 66 20 | 28 74 6d 70 20 21 3d 20 | if |(tmp != |
|00005370| 4e 49 4c 29 20 73 77 69 | 74 63 68 20 28 6e 74 79 |NIL) swi|tch (nty|
|00005380| 70 65 28 74 6d 70 29 29 | 20 7b 0d 0a 20 20 20 20 |pe(tmp))| {.. |
|00005390| 20 20 20 20 20 20 20 20 | 63 61 73 65 20 53 54 52 | |case STR|
|000053a0| 49 4e 47 3a 20 0d 0a 20 | 20 20 20 20 20 20 20 20 |ING: .. | |
|000053b0| 20 20 20 20 20 20 20 6c | 65 6e 20 3d 20 67 65 74 | l|en = get|
|000053c0| 73 6c 65 6e 67 74 68 28 | 74 6d 70 29 2d 31 3b 0d |slength(|tmp)-1;.|
|000053d0| 0a 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |. | |
|000053e0| 20 6d 65 6d 63 70 79 28 | 28 63 68 61 72 20 2a 29 | memcpy(|(char *)|
|000053f0| 73 74 72 2c 20 28 63 68 | 61 72 20 2a 29 67 65 74 |str, (ch|ar *)get|
|00005400| 73 74 72 69 6e 67 28 74 | 6d 70 29 2c 20 6c 65 6e |string(t|mp), len|
|00005410| 29 3b 0d 0a 20 20 20 20 | 20 20 20 20 20 20 20 20 |);.. | |
|00005420| 20 20 20 20 73 74 72 20 | 2b 3d 20 6c 65 6e 3b 0d | str |+= len;.|
|00005430| 0a 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |. | |
|00005440| 20 62 72 65 61 6b 3b 0d | 0a 20 20 20 20 20 20 20 | break;.|. |
|00005450| 20 20 20 20 20 63 61 73 | 65 20 56 45 43 54 4f 52 | cas|e VECTOR|
|00005460| 3a 0d 0a 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |:.. | |
|00005470| 20 20 20 6c 65 6e 20 3d | 20 67 65 74 73 69 7a 65 | len =| getsize|
|00005480| 28 74 6d 70 29 3b 0d 0a | 20 20 20 20 20 20 20 20 |(tmp);..| |
|00005490| 20 20 20 20 20 20 20 20 | 66 6f 72 20 28 69 20 3d | |for (i =|
|000054a0| 20 30 3b 20 69 20 3c 20 | 6c 65 6e 3b 20 69 2b 2b | 0; i < |len; i++|
|000054b0| 29 20 7b 0d 0a 20 20 20 | 20 20 20 20 20 20 20 20 |) {.. | |
|000054c0| 20 20 20 20 20 20 20 20 | 20 74 65 6d 70 20 3d 20 | | temp = |
|000054d0| 67 65 74 65 6c 65 6d 65 | 6e 74 28 74 6d 70 2c 69 |geteleme|nt(tmp,i|
|000054e0| 29 3b 0d 0a 20 20 20 20 | 20 20 20 20 20 20 20 20 |);.. | |
|000054f0| 20 20 20 20 20 20 20 20 | 69 66 20 28 21 63 68 61 | |if (!cha|
|00005500| 72 70 28 74 65 6d 70 29 | 29 20 67 6f 74 6f 20 66 |rp(temp)|) goto f|
|00005510| 61 69 6c 65 64 3b 0d 0a | 20 20 20 20 20 20 20 20 |ailed;..| |
|00005520| 20 20 20 20 20 20 20 20 | 20 20 20 20 2a 73 74 72 | | *str|
|00005530| 2b 2b 20 3d 20 67 65 74 | 63 68 63 6f 64 65 28 74 |++ = get|chcode(t|
|00005540| 65 6d 70 29 3b 0d 0a 20 | 20 20 20 20 20 20 20 20 |emp);.. | |
|00005550| 20 20 20 20 20 20 20 7d | 0d 0a 20 20 20 20 20 20 | }|.. |
|00005560| 20 20 20 20 20 20 20 20 | 20 20 62 72 65 61 6b 3b | | break;|
|00005570| 0d 0a 20 20 20 20 20 20 | 20 20 20 20 20 20 63 61 |.. | ca|
|00005580| 73 65 20 43 4f 4e 53 3a | 0d 0a 20 20 20 20 20 20 |se CONS:|.. |
|00005590| 20 20 20 20 20 20 20 20 | 20 20 77 68 69 6c 65 20 | | while |
|000055a0| 28 63 6f 6e 73 70 28 74 | 6d 70 29 29 20 7b 0d 0a |(consp(t|mp)) {..|
|000055b0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|000055c0| 20 20 20 20 74 65 6d 70 | 20 3d 20 63 61 72 28 74 | temp| = car(t|
|000055d0| 6d 70 29 3b 0d 0a 20 20 | 20 20 20 20 20 20 20 20 |mp);.. | |
|000055e0| 20 20 20 20 20 20 20 20 | 20 20 69 66 20 28 21 63 | | if (!c|
|000055f0| 68 61 72 70 28 74 65 6d | 70 29 29 20 67 6f 74 6f |harp(tem|p)) goto|
|00005600| 20 66 61 69 6c 65 64 3b | 0d 0a 20 20 20 20 20 20 | failed;|.. |
|00005610| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 2a 73 | | *s|
|00005620| 74 72 2b 2b 20 3d 20 67 | 65 74 63 68 63 6f 64 65 |tr++ = g|etchcode|
|00005630| 28 74 65 6d 70 29 3b 0d | 0a 20 20 20 20 20 20 20 |(temp);.|. |
|00005640| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 74 6d 70 | | tmp|
|00005650| 20 3d 20 63 64 72 28 74 | 6d 70 29 3b 0d 0a 20 20 | = cdr(t|mp);.. |
|00005660| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 7d 0d | | }.|
|00005670| 0a 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |. | |
|00005680| 20 62 72 65 61 6b 3b 0d | 0a 20 20 20 20 20 20 20 | break;.|. |
|00005690| 20 7d 0d 0a 20 20 20 20 | 7d 0d 0a 0d 0a 20 20 20 | }.. |}.... |
|000056a0| 20 2a 73 74 72 20 3d 20 | 30 3b 20 20 20 2f 2a 20 | *str = |0; /* |
|000056b0| 64 65 6c 69 6d 69 74 20 | 73 74 72 69 6e 67 20 28 |delimit |string (|
|000056c0| 77 68 79 2c 20 49 20 64 | 6f 6e 27 74 20 6b 6e 6f |why, I d|on't kno|
|000056d0| 77 21 29 20 2a 2f 0d 0a | 0d 0a 20 20 20 20 2f 2a |w!) */..|.. /*|
|000056e0| 20 72 65 74 75 72 6e 20 | 74 68 65 20 6e 65 77 20 | return |the new |
|000056f0| 73 74 72 69 6e 67 20 2a | 2f 0d 0a 20 20 20 20 72 |string *|/.. r|
|00005700| 65 74 75 72 6e 20 28 76 | 61 6c 29 3b 0d 0a 0d 0a |eturn (v|al);....|
|00005710| 66 61 69 6c 65 64 3a 0d | 0a 20 20 20 20 78 6c 65 |failed:.|. xle|
|00005720| 72 72 6f 72 28 22 63 61 | 6e 6e 6f 74 20 6d 61 6b |rror("ca|nnot mak|
|00005730| 65 20 69 6e 74 6f 20 73 | 74 72 69 6e 67 22 2c 20 |e into s|tring", |
|00005740| 74 6d 70 29 3b 0d 0a 7d | 0d 0a 0d 0a 4c 4f 43 41 |tmp);..}|....LOCA|
|00005750| 4c 20 4c 56 41 4c 20 63 | 61 74 74 6f 76 65 63 74 |L LVAL c|attovect|
|00005760| 6f 72 28 29 0d 0a 7b 0d | 0a 20 20 20 20 4c 56 41 |or()..{.|. LVA|
|00005770| 4c 20 74 6d 70 2c 76 61 | 6c 3b 0d 0a 20 20 20 20 |L tmp,va|l;.. |
|00005780| 4c 56 41 4c 20 2a 76 65 | 63 74 3b 0d 0a 20 20 20 |LVAL *ve|ct;.. |
|00005790| 20 69 6e 74 20 6c 65 6e | 2c 69 3b 0d 0a 20 20 20 | int len|,i;.. |
|000057a0| 20 0d 0a 20 20 20 20 2f | 2a 20 66 69 6e 64 20 72 | .. /|* find r|
|000057b0| 65 73 75 6c 74 69 6e 67 | 20 6c 65 6e 67 74 68 20 |esulting| length |
|000057c0| 2d 2d 20 61 6c 73 6f 20 | 76 61 6c 69 64 61 74 65 |-- also |validate|
|000057d0| 73 20 61 72 67 75 6d 65 | 6e 74 20 74 79 70 65 73 |s argume|nt types|
|000057e0| 20 2a 2f 0d 0a 20 20 20 | 20 6c 65 6e 20 3d 20 63 | */.. | len = c|
|000057f0| 61 6c 63 6c 65 6e 67 74 | 68 28 29 3b 0d 0a 0d 0a |alclengt|h();....|
|00005800| 20 20 20 20 2f 2a 20 63 | 72 65 61 74 65 20 74 68 | /* c|reate th|
|00005810| 65 20 72 65 73 75 6c 74 | 20 76 65 63 74 6f 72 20 |e result| vector |
|00005820| 2a 2f 0d 0a 20 20 20 20 | 76 61 6c 20 3d 20 6e 65 |*/.. |val = ne|
|00005830| 77 76 65 63 74 6f 72 28 | 6c 65 6e 29 3b 0d 0a 20 |wvector(|len);.. |
|00005840| 20 20 20 76 65 63 74 20 | 3d 20 26 76 61 6c 2d 3e | vect |= &val->|
|00005850| 6e 5f 76 64 61 74 61 5b | 30 5d 3b 0d 0a 0d 0a 20 |n_vdata[|0];.... |
|00005860| 20 20 20 2f 2a 20 63 6f | 6d 62 69 6e 65 20 74 68 | /* co|mbine th|
|00005870| 65 20 76 65 63 74 6f 72 | 73 20 2a 2f 0d 0a 20 20 |e vector|s */.. |
|00005880| 20 20 77 68 69 6c 65 20 | 28 6d 6f 72 65 61 72 67 | while |(morearg|
|00005890| 73 28 29 29 20 7b 0d 0a | 20 20 20 20 20 20 20 20 |s()) {..| |
|000058a0| 74 6d 70 20 3d 20 6e 65 | 78 74 61 72 67 28 29 3b |tmp = ne|xtarg();|
|000058b0| 0d 0a 20 20 20 20 20 20 | 20 20 69 66 20 28 74 6d |.. | if (tm|
|000058c0| 70 20 21 3d 20 4e 49 4c | 29 20 73 77 69 74 63 68 |p != NIL|) switch|
|000058d0| 20 28 6e 74 79 70 65 28 | 74 6d 70 29 29 20 7b 0d | (ntype(|tmp)) {.|
|000058e0| 0a 20 20 20 20 20 20 20 | 20 20 20 20 20 63 61 73 |. | cas|
|000058f0| 65 20 56 45 43 54 4f 52 | 3a 20 0d 0a 20 20 20 20 |e VECTOR|: .. |
|00005900| 20 20 20 20 20 20 20 20 | 20 20 20 20 6c 65 6e 20 | | len |
|00005910| 3d 20 67 65 74 73 69 7a | 65 28 74 6d 70 29 3b 0d |= getsiz|e(tmp);.|
|00005920| 0a 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |. | |
|00005930| 20 6d 65 6d 63 70 79 28 | 76 65 63 74 2c 20 26 67 | memcpy(|vect, &g|
|00005940| 65 74 65 6c 65 6d 65 6e | 74 28 74 6d 70 2c 30 29 |etelemen|t(tmp,0)|
|00005950| 2c 20 6c 65 6e 2a 73 69 | 7a 65 6f 66 28 4c 56 41 |, len*si|zeof(LVA|
|00005960| 4c 29 29 3b 0d 0a 20 20 | 20 20 20 20 20 20 20 20 |L));.. | |
|00005970| 20 20 20 20 20 20 76 65 | 63 74 20 2b 3d 20 6c 65 | ve|ct += le|
|00005980| 6e 3b 0d 0a 20 20 20 20 | 20 20 20 20 20 20 20 20 |n;.. | |
|00005990| 20 20 20 20 62 72 65 61 | 6b 3b 0d 0a 20 20 20 20 | brea|k;.. |
|000059a0| 20 20 20 20 20 20 20 20 | 63 61 73 65 20 53 54 52 | |case STR|
|000059b0| 49 4e 47 3a 0d 0a 20 20 | 20 20 20 20 20 20 20 20 |ING:.. | |
|000059c0| 20 20 20 20 20 20 6c 65 | 6e 20 3d 20 67 65 74 73 | le|n = gets|
|000059d0| 6c 65 6e 67 74 68 28 74 | 6d 70 29 2d 31 3b 0d 0a |length(t|mp)-1;..|
|000059e0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|000059f0| 66 6f 72 20 28 69 20 3d | 20 30 3b 20 69 20 3c 20 |for (i =| 0; i < |
|00005a00| 6c 65 6e 3b 20 69 2b 2b | 29 20 7b 0d 0a 20 20 20 |len; i++|) {.. |
|00005a10| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00005a20| 20 2a 76 65 63 74 2b 2b | 20 3d 20 63 76 63 68 61 | *vect++| = cvcha|
|00005a30| 72 28 74 6d 70 2d 3e 6e | 5f 73 74 72 69 6e 67 5b |r(tmp->n|_string[|
|00005a40| 69 5d 29 3b 0d 0a 20 20 | 20 20 20 20 20 20 20 20 |i]);.. | |
|00005a50| 20 20 20 20 20 20 7d 0d | 0a 20 20 20 20 20 20 20 | }.|. |
|00005a60| 20 20 20 20 20 20 20 20 | 20 62 72 65 61 6b 3b 0d | | break;.|
|00005a70| 0a 20 20 20 20 20 20 20 | 20 20 20 20 20 63 61 73 |. | cas|
|00005a80| 65 20 43 4f 4e 53 3a 0d | 0a 20 20 20 20 20 20 20 |e CONS:.|. |
|00005a90| 20 20 20 20 20 20 20 20 | 20 77 68 69 6c 65 20 28 | | while (|
|00005aa0| 63 6f 6e 73 70 28 74 6d | 70 29 29 20 7b 0d 0a 20 |consp(tm|p)) {.. |
|00005ab0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00005ac0| 20 20 20 2a 76 65 63 74 | 2b 2b 20 3d 20 63 61 72 | *vect|++ = car|
|00005ad0| 28 74 6d 70 29 3b 0d 0a | 20 20 20 20 20 20 20 20 |(tmp);..| |
|00005ae0| 20 20 20 20 20 20 20 20 | 20 20 20 20 74 6d 70 20 | | tmp |
|00005af0| 3d 20 63 64 72 28 74 6d | 70 29 3b 0d 0a 20 20 20 |= cdr(tm|p);.. |
|00005b00| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 7d 0d 0a | | }..|
|00005b10| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00005b20| 62 72 65 61 6b 3b 0d 0a | 20 20 20 20 20 20 20 20 |break;..| |
|00005b30| 7d 0d 0a 20 20 20 20 7d | 0d 0a 0d 0a 20 20 20 20 |}.. }|.... |
|00005b40| 2f 2a 20 72 65 74 75 72 | 6e 20 74 68 65 20 6e 65 |/* retur|n the ne|
|00005b50| 77 20 76 65 63 74 6f 72 | 20 2a 2f 0d 0a 20 20 20 |w vector| */.. |
|00005b60| 20 72 65 74 75 72 6e 20 | 28 76 61 6c 29 3b 0d 0a | return |(val);..|
|00005b70| 7d 0d 0a 0d 0a 4c 4f 43 | 41 4c 20 4c 56 41 4c 20 |}....LOC|AL LVAL |
|00005b80| 63 61 74 74 6f 63 6f 6e | 73 28 29 0d 0a 7b 0d 0a |cattocon|s()..{..|
|00005b90| 20 20 20 20 4c 56 41 4c | 20 76 61 6c 2c 74 6d 70 | LVAL| val,tmp|
|00005ba0| 2c 6e 65 78 74 2c 6c 61 | 73 74 3d 4e 49 4c 3b 0d |,next,la|st=NIL;.|
|00005bb0| 0a 20 20 20 20 69 6e 74 | 20 6c 65 6e 2c 69 3b 0d |. int| len,i;.|
|00005bc0| 0a 20 20 20 20 0d 0a 20 | 20 20 20 78 6c 73 61 76 |. .. | xlsav|
|00005bd0| 65 31 28 76 61 6c 29 3b | 20 20 20 20 20 20 20 2f |e1(val);| /|
|00005be0| 2a 20 70 72 6f 74 65 63 | 74 20 61 67 61 69 6e 73 |* protec|t agains|
|00005bf0| 74 20 47 43 20 2a 2f 0d | 0a 20 20 20 20 0d 0a 20 |t GC */.|. .. |
|00005c00| 20 20 20 2f 2a 20 63 6f | 6d 62 69 6e 65 20 74 68 | /* co|mbine th|
|00005c10| 65 20 6c 69 73 74 73 20 | 2a 2f 0d 0a 20 20 20 20 |e lists |*/.. |
|00005c20| 77 68 69 6c 65 20 28 6d | 6f 72 65 61 72 67 73 28 |while (m|oreargs(|
|00005c30| 29 29 20 7b 0d 0a 20 20 | 20 20 20 20 20 20 74 6d |)) {.. | tm|
|00005c40| 70 20 3d 20 6e 65 78 74 | 61 72 67 28 29 3b 0d 0a |p = next|arg();..|
|00005c50| 20 20 20 20 20 20 20 20 | 69 66 20 28 74 6d 70 20 | |if (tmp |
|00005c60| 21 3d 20 4e 49 4c 29 20 | 73 77 69 74 63 68 20 28 |!= NIL) |switch (|
|00005c70| 6e 74 79 70 65 28 74 6d | 70 29 29 20 7b 0d 0a 20 |ntype(tm|p)) {.. |
|00005c80| 20 20 20 20 20 20 20 20 | 20 20 20 63 61 73 65 20 | | case |
|00005c90| 43 4f 4e 53 3a 0d 0a 20 | 20 20 20 20 20 20 20 20 |CONS:.. | |
|00005ca0| 20 20 20 20 20 20 20 77 | 68 69 6c 65 20 28 63 6f | w|hile (co|
|00005cb0| 6e 73 70 28 74 6d 70 29 | 29 20 7b 0d 0a 20 20 20 |nsp(tmp)|) {.. |
|00005cc0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00005cd0| 20 6e 65 78 74 20 3d 20 | 63 6f 6e 73 61 28 63 61 | next = |consa(ca|
|00005ce0| 72 28 74 6d 70 29 29 3b | 0d 0a 20 20 20 20 20 20 |r(tmp));|.. |
|00005cf0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 69 66 | | if|
|00005d00| 20 28 76 61 6c 29 20 72 | 70 6c 61 63 64 28 6c 61 | (val) r|placd(la|
|00005d10| 73 74 2c 6e 65 78 74 29 | 3b 0d 0a 20 20 20 20 20 |st,next)|;.. |
|00005d20| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 65 | | e|
|00005d30| 6c 73 65 20 76 61 6c 20 | 3d 20 6e 65 78 74 3b 0d |lse val |= next;.|
|00005d40| 0a 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |. | |
|00005d50| 20 20 20 20 20 6c 61 73 | 74 20 3d 20 6e 65 78 74 | las|t = next|
|00005d60| 3b 0d 0a 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |;.. | |
|00005d70| 20 20 20 20 20 20 20 74 | 6d 70 20 3d 20 63 64 72 | t|mp = cdr|
|00005d80| 28 74 6d 70 29 3b 0d 0a | 20 20 20 20 20 20 20 20 |(tmp);..| |
|00005d90| 20 20 20 20 20 20 20 20 | 7d 0d 0a 20 20 20 20 20 | |}.. |
|00005da0| 20 20 20 20 20 20 20 20 | 20 20 20 62 72 65 61 6b | | break|
|00005db0| 3b 0d 0a 20 20 20 20 20 | 20 20 20 20 20 20 20 63 |;.. | c|
|00005dc0| 61 73 65 20 56 45 43 54 | 4f 52 3a 0d 0a 20 20 20 |ase VECT|OR:.. |
|00005dd0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 6c 65 6e | | len|
|00005de0| 20 3d 20 67 65 74 73 69 | 7a 65 28 74 6d 70 29 3b | = getsi|ze(tmp);|
|00005df0| 0d 0a 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |.. | |
|00005e00| 20 20 66 6f 72 20 28 69 | 20 3d 20 30 3b 20 69 3c | for (i| = 0; i<|
|00005e10| 6c 65 6e 3b 20 69 2b 2b | 29 20 7b 0d 0a 20 20 20 |len; i++|) {.. |
|00005e20| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00005e30| 20 6e 65 78 74 20 3d 20 | 63 6f 6e 73 61 28 67 65 | next = |consa(ge|
|00005e40| 74 65 6c 65 6d 65 6e 74 | 28 74 6d 70 2c 69 29 29 |telement|(tmp,i))|
|00005e50| 3b 0d 0a 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |;.. | |
|00005e60| 20 20 20 20 20 20 20 69 | 66 20 28 76 61 6c 29 20 | i|f (val) |
|00005e70| 72 70 6c 61 63 64 28 6c | 61 73 74 2c 6e 65 78 74 |rplacd(l|ast,next|
|00005e80| 29 3b 0d 0a 20 20 20 20 | 20 20 20 20 20 20 20 20 |);.. | |
|00005e90| 20 20 20 20 20 20 20 20 | 65 6c 73 65 20 76 61 6c | |else val|
|00005ea0| 20 3d 20 6e 65 78 74 3b | 0d 0a 20 20 20 20 20 20 | = next;|.. |
|00005eb0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 6c 61 | | la|
|00005ec0| 73 74 20 3d 20 6e 65 78 | 74 3b 0d 0a 20 20 20 20 |st = nex|t;.. |
|00005ed0| 20 20 20 20 20 20 20 20 | 20 20 20 20 7d 0d 0a 20 | | }.. |
|00005ee0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 62 | | b|
|00005ef0| 72 65 61 6b 3b 0d 0a 20 | 20 20 20 20 20 20 20 20 |reak;.. | |
|00005f00| 20 20 20 63 61 73 65 20 | 53 54 52 49 4e 47 3a 0d | case |STRING:.|
|00005f10| 0a 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |. | |
|00005f20| 20 6c 65 6e 20 3d 20 67 | 65 74 73 6c 65 6e 67 74 | len = g|etslengt|
|00005f30| 68 28 74 6d 70 29 20 2d | 20 31 3b 0d 0a 20 20 20 |h(tmp) -| 1;.. |
|00005f40| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 66 6f 72 | | for|
|00005f50| 20 28 69 20 3d 20 30 3b | 20 69 20 3c 20 6c 65 6e | (i = 0;| i < len|
|00005f60| 3b 20 69 2b 2b 29 20 7b | 0d 0a 20 20 20 20 20 20 |; i++) {|.. |
|00005f70| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 6e 65 | | ne|
|00005f80| 78 74 20 3d 20 63 6f 6e | 73 61 28 63 76 63 68 61 |xt = con|sa(cvcha|
|00005f90| 72 28 74 6d 70 2d 3e 6e | 5f 73 74 72 69 6e 67 5b |r(tmp->n|_string[|
|00005fa0| 69 5d 29 29 3b 0d 0a 20 | 20 20 20 20 20 20 20 20 |i]));.. | |
|00005fb0| 20 20 20 20 20 20 20 20 | 20 20 20 69 66 20 28 76 | | if (v|
|00005fc0| 61 6c 29 20 72 70 6c 61 | 63 64 28 6c 61 73 74 2c |al) rpla|cd(last,|
|00005fd0| 6e 65 78 74 29 3b 0d 0a | 20 20 20 20 20 20 20 20 |next);..| |
|00005fe0| 20 20 20 20 20 20 20 20 | 20 20 20 20 65 6c 73 65 | | else|
|00005ff0| 20 76 61 6c 20 3d 20 6e | 65 78 74 3b 0d 0a 20 20 | val = n|ext;.. |
|00006000| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00006010| 20 20 6c 61 73 74 20 3d | 20 6e 65 78 74 3b 0d 0a | last =| next;..|
|00006020| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00006030| 7d 0d 0a 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |}.. | |
|00006040| 20 20 20 62 72 65 61 6b | 3b 0d 0a 20 20 20 20 20 | break|;.. |
|00006050| 20 20 20 20 20 20 20 64 | 65 66 61 75 6c 74 3a 20 | d|efault: |
|00006060| 0d 0a 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |.. | |
|00006070| 20 20 78 6c 62 61 64 74 | 79 70 65 28 74 6d 70 29 | xlbadt|ype(tmp)|
|00006080| 3b 20 62 72 65 61 6b 3b | 20 2f 2a 20 6e 65 65 64 |; break;| /* need|
|00006090| 20 64 65 66 61 75 6c 74 | 20 62 65 63 61 75 73 65 | default| because|
|000060a0| 20 6e 6f 20 70 72 65 63 | 68 65 63 6b 2a 2f 0d 0a | no prec|heck*/..|
|000060b0| 20 20 20 20 20 20 20 20 | 7d 0d 0a 20 20 20 20 7d | |}.. }|
|000060c0| 0d 0a 20 20 20 20 0d 0a | 20 20 20 20 78 6c 70 6f |.. ..| xlpo|
|000060d0| 70 28 29 3b 0d 0a 20 20 | 20 20 0d 0a 20 20 20 20 |p();.. | .. |
|000060e0| 72 65 74 75 72 6e 20 28 | 76 61 6c 29 3b 0d 0a 0d |return (|val);...|
|000060f0| 0a 7d 0d 0a 20 20 20 20 | 0d 0a 0d 0a 4c 56 41 4c |.}.. |....LVAL|
|00006100| 20 78 63 6f 6e 63 61 74 | 65 6e 61 74 65 28 29 0d | xconcat|enate().|
|00006110| 0a 7b 0d 0a 20 20 20 20 | 4c 56 41 4c 20 74 6d 70 |.{.. |LVAL tmp|
|00006120| 3b 0d 0a 20 20 20 20 0d | 0a 20 20 20 20 73 77 69 |;.. .|. swi|
|00006130| 74 63 68 20 28 78 6c 63 | 76 74 74 79 70 65 28 74 |tch (xlc|vttype(t|
|00006140| 6d 70 20 3d 20 78 6c 67 | 65 74 61 72 67 28 29 29 |mp = xlg|etarg())|
|00006150| 29 20 7b 20 20 2f 2a 20 | 74 61 72 67 65 74 20 74 |) { /* |target t|
|00006160| 79 70 65 20 6f 66 20 64 | 61 74 61 20 2a 2f 0d 0a |ype of d|ata */..|
|00006170| 20 20 20 20 20 20 20 20 | 63 61 73 65 20 43 4f 4e | |case CON|
|00006180| 53 3a 20 20 20 20 20 20 | 72 65 74 75 72 6e 20 63 |S: |return c|
|00006190| 61 74 74 6f 63 6f 6e 73 | 28 29 3b 0d 0a 20 20 20 |attocons|();.. |
|000061a0| 20 20 20 20 20 63 61 73 | 65 20 53 54 52 49 4e 47 | cas|e STRING|
|000061b0| 3a 20 20 20 20 72 65 74 | 75 72 6e 20 63 61 74 74 |: ret|urn catt|
|000061c0| 6f 73 74 72 69 6e 67 28 | 29 3b 20 20 20 20 20 20 |ostring(|); |
|000061d0| 20 20 20 20 20 0d 0a 20 | 20 20 20 20 20 20 20 63 | .. | c|
|000061e0| 61 73 65 20 56 45 43 54 | 4f 52 3a 20 20 20 20 72 |ase VECT|OR: r|
|000061f0| 65 74 75 72 6e 20 63 61 | 74 74 6f 76 65 63 74 6f |eturn ca|ttovecto|
|00006200| 72 28 29 3b 0d 0a 20 20 | 20 20 20 20 20 20 64 65 |r();.. | de|
|00006210| 66 61 75 6c 74 3a 20 20 | 20 20 20 20 20 20 78 6c |fault: | xl|
|00006220| 65 72 72 6f 72 28 22 69 | 6e 76 61 6c 69 64 20 72 |error("i|nvalid r|
|00006230| 65 73 75 6c 74 20 74 79 | 70 65 22 2c 20 74 6d 70 |esult ty|pe", tmp|
|00006240| 29 3b 0d 0a 20 20 20 20 | 7d 0d 0a 7d 0d 0a 0d 0a |);.. |}..}....|
|00006250| 2f 2a 20 78 73 75 62 73 | 65 71 20 2d 20 72 65 74 |/* xsubs|eq - ret|
|00006260| 75 72 6e 20 61 20 73 75 | 62 73 65 71 75 65 6e 63 |urn a su|bsequenc|
|00006270| 65 20 2d 2d 20 6e 65 77 | 20 76 65 72 73 69 6f 6e |e -- new| version|
|00006280| 20 2a 2f 0d 0a 0d 0a 4c | 56 41 4c 20 78 73 75 62 | */....L|VAL xsub|
|00006290| 73 65 71 28 29 0d 0a 7b | 0d 0a 20 20 20 20 69 6e |seq()..{|.. in|
|000062a0| 74 20 73 74 61 72 74 2c | 65 6e 64 2c 6c 65 6e 3b |t start,|end,len;|
|000062b0| 0d 0a 20 20 20 20 69 6e | 74 20 73 72 63 74 79 70 |.. in|t srctyp|
|000062c0| 65 3b 0d 0a 20 20 20 20 | 4c 56 41 4c 20 73 72 63 |e;.. |LVAL src|
|000062d0| 2c 64 73 74 3b 0d 0a 20 | 20 20 20 4c 56 41 4c 20 |,dst;.. | LVAL |
|000062e0| 6e 65 78 74 2c 6c 61 73 | 74 3d 4e 49 4c 3b 0d 0a |next,las|t=NIL;..|
|000062f0| 0d 0a 20 20 20 20 2f 2a | 20 67 65 74 20 73 65 71 |.. /*| get seq|
|00006300| 75 65 6e 63 65 20 2a 2f | 0d 0a 20 20 20 20 73 72 |uence */|.. sr|
|00006310| 63 20 3d 20 78 6c 67 65 | 74 61 72 67 28 29 3b 0d |c = xlge|targ();.|
|00006320| 0a 20 20 20 20 69 66 20 | 28 6c 69 73 74 70 28 73 |. if |(listp(s|
|00006330| 72 63 29 29 20 73 72 63 | 74 79 70 65 20 3d 20 43 |rc)) src|type = C|
|00006340| 4f 4e 53 3b 0d 0a 20 20 | 20 20 65 6c 73 65 20 73 |ONS;.. | else s|
|00006350| 72 63 74 79 70 65 3d 6e | 74 79 70 65 28 73 72 63 |rctype=n|type(src|
|00006360| 29 3b 0d 0a 0d 0a 20 20 | 20 20 0d 0a 20 20 20 20 |);.... | .. |
|00006370| 2f 2a 20 67 65 74 20 6c | 65 6e 67 74 68 20 2a 2f |/* get l|ength */|
|00006380| 0d 0a 20 20 20 20 73 77 | 69 74 63 68 20 28 73 72 |.. sw|itch (sr|
|00006390| 63 74 79 70 65 29 20 7b | 0d 0a 20 20 20 20 20 20 |ctype) {|.. |
|000063a0| 20 20 63 61 73 65 20 53 | 54 52 49 4e 47 3a 0d 0a | case S|TRING:..|
|000063b0| 20 20 20 20 20 20 20 20 | 20 20 20 20 6c 65 6e 20 | | len |
|000063c0| 3d 20 67 65 74 73 6c 65 | 6e 67 74 68 28 73 72 63 |= getsle|ngth(src|
|000063d0| 29 20 2d 20 31 3b 0d 0a | 20 20 20 20 20 20 20 20 |) - 1;..| |
|000063e0| 20 20 20 20 62 72 65 61 | 6b 3b 0d 0a 20 20 20 20 | brea|k;.. |
|000063f0| 20 20 20 20 63 61 73 65 | 20 56 45 43 54 4f 52 3a | case| VECTOR:|
+--------+-------------------------+-------------------------+--------+--------+
Only 25.0 KB of data is shown above.