home *** CD-ROM | disk | FTP | other *** search
open in:
MacOS 8.1
|
Win98
|
DOS
view JSON data
|
view as text
This file was processed as: SHell self-extracting ARchive
(archive/shar).
You can browse this item here: tracer
hex view+--------+-------------------------+-------------------------+--------+--------+
|00000000| 46 72 6f 6d 20 64 65 63 | 77 72 6c 21 6c 61 62 72 |From dec|wrl!labr|
|00000010| 65 61 21 72 75 74 67 65 | 72 73 21 6d 61 69 6c 72 |ea!rutge|rs!mailr|
|00000020| 75 73 21 6e 63 61 72 21 | 74 61 6e 6b 21 6e 69 63 |us!ncar!|tank!nic|
|00000030| 2e 4d 52 2e 4e 45 54 21 | 68 61 6c 21 6e 63 6f 61 |.MR.NET!|hal!ncoa|
|00000040| 73 74 21 61 6c 6c 62 65 | 72 79 20 53 75 6e 20 4e |st!allbe|ry Sun N|
|00000050| 6f 76 20 31 33 20 30 30 | 3a 34 34 3a 32 36 20 50 |ov 13 00|:44:26 P|
|00000060| 53 54 20 31 39 38 38 0a | 41 72 74 69 63 6c 65 20 |ST 1988.|Article |
|00000070| 37 32 33 20 6f 66 20 63 | 6f 6d 70 2e 73 6f 75 72 |723 of c|omp.sour|
|00000080| 63 65 73 2e 6d 69 73 63 | 3a 0a 50 61 74 68 3a 20 |ces.misc|:.Path: |
|00000090| 67 72 61 6e 69 74 65 21 | 64 65 63 77 72 6c 21 6c |granite!|decwrl!l|
|000000a0| 61 62 72 65 61 21 72 75 | 74 67 65 72 73 21 6d 61 |abrea!ru|tgers!ma|
|000000b0| 69 6c 72 75 73 21 6e 63 | 61 72 21 74 61 6e 6b 21 |ilrus!nc|ar!tank!|
|000000c0| 6e 69 63 2e 4d 52 2e 4e | 45 54 21 68 61 6c 21 6e |nic.MR.N|ET!hal!n|
|000000d0| 63 6f 61 73 74 21 61 6c | 6c 62 65 72 79 0a 46 72 |coast!al|lbery.Fr|
|000000e0| 6f 6d 3a 20 73 69 64 40 | 63 68 69 6e 65 74 2e 55 |om: sid@|chinet.U|
|000000f0| 55 43 50 20 28 53 69 64 | 20 47 72 61 6e 67 65 29 |UCP (Sid| Grange)|
|00000100| 0a 4e 65 77 73 67 72 6f | 75 70 73 3a 20 63 6f 6d |.Newsgro|ups: com|
|00000110| 70 2e 73 6f 75 72 63 65 | 73 2e 6d 69 73 63 0a 53 |p.source|s.misc.S|
|00000120| 75 62 6a 65 63 74 3a 20 | 76 30 35 69 30 34 36 3a |ubject: |v05i046:|
|00000130| 20 72 61 79 20 74 72 61 | 63 69 6e 67 20 70 72 6f | ray tra|cing pro|
|00000140| 67 72 61 6d 20 66 6f 72 | 20 33 62 31 0a 4d 65 73 |gram for| 3b1.Mes|
|00000150| 73 61 67 65 2d 49 44 3a | 20 3c 31 32 38 38 33 40 |sage-ID:| <12883@|
|00000160| 6e 63 6f 61 73 74 2e 55 | 55 43 50 3e 0a 44 61 74 |ncoast.U|UCP>.Dat|
|00000170| 65 3a 20 39 20 4e 6f 76 | 20 38 38 20 30 33 3a 33 |e: 9 Nov| 88 03:3|
|00000180| 39 3a 32 37 20 47 4d 54 | 0a 53 65 6e 64 65 72 3a |9:27 GMT|.Sender:|
|00000190| 20 61 6c 6c 62 65 72 79 | 40 6e 63 6f 61 73 74 2e | allbery|@ncoast.|
|000001a0| 55 55 43 50 0a 52 65 70 | 6c 79 2d 54 6f 3a 20 73 |UUCP.Rep|ly-To: s|
|000001b0| 69 64 40 63 68 69 6e 65 | 74 2e 55 55 43 50 20 28 |id@chine|t.UUCP (|
|000001c0| 53 69 64 20 47 72 61 6e | 67 65 29 0a 4c 69 6e 65 |Sid Gran|ge).Line|
|000001d0| 73 3a 20 31 30 30 30 0a | 41 70 70 72 6f 76 65 64 |s: 1000.|Approved|
|000001e0| 3a 20 61 6c 6c 62 65 72 | 79 40 6e 63 6f 61 73 74 |: allber|y@ncoast|
|000001f0| 2e 55 55 43 50 0a 0a 50 | 6f 73 74 69 6e 67 2d 6e |.UUCP..P|osting-n|
|00000200| 75 6d 62 65 72 3a 20 56 | 6f 6c 75 6d 65 20 35 2c |umber: V|olume 5,|
|00000210| 20 49 73 73 75 65 20 34 | 36 0a 53 75 62 6d 69 74 | Issue 4|6.Submit|
|00000220| 74 65 64 2d 62 79 3a 20 | 22 53 69 64 20 47 72 61 |ted-by: |"Sid Gra|
|00000230| 6e 67 65 22 20 3c 73 69 | 64 40 63 68 69 6e 65 74 |nge" <si|d@chinet|
|00000240| 2e 55 55 43 50 3e 0a 41 | 72 63 68 69 76 65 2d 6e |.UUCP>.A|rchive-n|
|00000250| 61 6d 65 3a 20 74 72 61 | 63 65 72 0a 0a 5b 54 68 |ame: tra|cer..[Th|
|00000260| 65 20 61 75 74 68 6f 72 | 20 63 6c 61 69 6d 73 20 |e author| claims |
|00000270| 74 68 61 74 20 69 74 20 | 73 68 6f 75 6c 64 20 62 |that it |should b|
|00000280| 65 20 70 6f 72 74 61 62 | 6c 65 20 74 6f 20 6f 74 |e portab|le to ot|
|00000290| 68 65 72 20 67 72 61 70 | 68 69 63 61 6c 20 55 6e |her grap|hical Un|
|000002a0| 2a 78 20 73 79 73 74 65 | 6d 73 2e 0a 53 69 6e 63 |*x syste|ms..Sinc|
|000002b0| 65 20 49 20 64 6f 6e 27 | 74 20 68 61 76 65 20 6f |e I don'|t have o|
|000002c0| 6e 65 20 68 61 6e 64 79 | 2c 20 49 27 76 65 20 6e |ne handy|, I've n|
|000002d0| 6f 20 77 61 79 20 74 6f | 20 74 65 73 74 20 74 68 |o way to| test th|
|000002e0| 61 74 2e 20 20 2b 2b 62 | 73 61 5d 0a 0a 23 21 20 |at. ++b|sa]..#! |
|000002f0| 2f 62 69 6e 2f 73 68 0a | 23 20 54 68 69 73 20 69 |/bin/sh.|# This i|
|00000300| 73 20 61 20 73 68 65 6c | 6c 20 61 72 63 68 69 76 |s a shel|l archiv|
|00000310| 65 2e 20 20 52 65 6d 6f | 76 65 20 61 6e 79 74 68 |e. Remo|ve anyth|
|00000320| 69 6e 67 20 62 65 66 6f | 72 65 20 74 68 69 73 20 |ing befo|re this |
|00000330| 6c 69 6e 65 2c 20 74 68 | 65 6e 20 75 6e 70 61 63 |line, th|en unpac|
|00000340| 6b 0a 23 20 69 74 20 62 | 79 20 73 61 76 69 6e 67 |k.# it b|y saving|
|00000350| 20 69 74 20 69 6e 74 6f | 20 61 20 66 69 6c 65 20 | it into| a file |
|00000360| 61 6e 64 20 74 79 70 69 | 6e 67 20 22 73 68 20 66 |and typi|ng "sh f|
|00000370| 69 6c 65 22 2e 20 20 54 | 6f 20 6f 76 65 72 77 72 |ile". T|o overwr|
|00000380| 69 74 65 20 65 78 69 73 | 74 69 6e 67 0a 23 20 66 |ite exis|ting.# f|
|00000390| 69 6c 65 73 2c 20 74 79 | 70 65 20 22 73 68 20 66 |iles, ty|pe "sh f|
|000003a0| 69 6c 65 20 2d 63 22 2e | 20 20 59 6f 75 20 63 61 |ile -c".| You ca|
|000003b0| 6e 20 61 6c 73 6f 20 66 | 65 65 64 20 74 68 69 73 |n also f|eed this|
|000003c0| 20 61 73 20 73 74 61 6e | 64 61 72 64 20 69 6e 70 | as stan|dard inp|
|000003d0| 75 74 20 76 69 61 0a 23 | 20 75 6e 73 68 61 72 2c |ut via.#| unshar,|
|000003e0| 20 6f 72 20 62 79 20 74 | 79 70 69 6e 67 20 22 73 | or by t|yping "s|
|000003f0| 68 20 3c 66 69 6c 65 22 | 2c 20 65 2e 67 2e 2e 20 |h <file"|, e.g.. |
|00000400| 20 49 66 20 74 68 69 73 | 20 61 72 63 68 69 76 65 | If this| archive|
|00000410| 20 69 73 20 63 6f 6d 70 | 6c 65 74 65 2c 20 79 6f | is comp|lete, yo|
|00000420| 75 0a 23 20 77 69 6c 6c | 20 73 65 65 20 74 68 65 |u.# will| see the|
|00000430| 20 66 6f 6c 6c 6f 77 69 | 6e 67 20 6d 65 73 73 61 | followi|ng messa|
|00000440| 67 65 20 61 74 20 74 68 | 65 20 65 6e 64 3a 0a 23 |ge at th|e end:.#|
|00000450| 09 09 22 45 6e 64 20 6f | 66 20 73 68 65 6c 6c 20 |.."End o|f shell |
|00000460| 61 72 63 68 69 76 65 2e | 22 0a 23 20 43 6f 6e 74 |archive.|".# Cont|
|00000470| 65 6e 74 73 3a 20 20 4d | 61 6b 65 66 69 6c 65 20 |ents: M|akefile |
|00000480| 52 45 41 44 4d 45 2e 44 | 4f 43 20 52 45 41 44 4d |README.D|OC READM|
|00000490| 45 2e 48 41 4b 20 62 64 | 61 74 61 2e 69 20 63 6f |E.HAK bd|ata.i co|
|000004a0| 6e 76 2e 63 20 65 78 74 | 65 72 6e 2e 68 0a 23 20 |nv.c ext|ern.h.# |
|000004b0| 20 20 66 69 6e 64 2e 63 | 20 67 5f 62 61 6c 2e 63 | find.c| g_bal.c|
|000004c0| 20 67 5f 62 6f 64 2e 63 | 20 6d 61 63 72 6f 73 2e | g_bod.c| macros.|
|000004d0| 68 20 72 65 66 72 61 63 | 74 2e 63 20 72 74 64 2e |h refrac|t.c rtd.|
|000004e0| 68 20 73 68 61 64 65 2e | 63 20 73 75 70 70 6f 72 |h shade.|c suppor|
|000004f0| 74 2e 63 0a 23 20 20 20 | 74 72 61 63 65 72 2e 63 |t.c.# |tracer.c|
|00000500| 0a 23 20 57 72 61 70 70 | 65 64 20 62 79 20 73 69 |.# Wrapp|ed by si|
|00000510| 64 40 63 68 69 6e 65 74 | 20 6f 6e 20 4d 6f 6e 20 |d@chinet| on Mon |
|00000520| 46 65 62 20 20 38 20 32 | 30 3a 30 33 3a 30 37 20 |Feb 8 2|0:03:07 |
|00000530| 31 39 38 38 0a 50 41 54 | 48 3d 2f 62 69 6e 3a 2f |1988.PAT|H=/bin:/|
|00000540| 75 73 72 2f 62 69 6e 3a | 2f 75 73 72 2f 75 63 62 |usr/bin:|/usr/ucb|
|00000550| 20 3b 20 65 78 70 6f 72 | 74 20 50 41 54 48 0a 69 | ; expor|t PATH.i|
|00000560| 66 20 74 65 73 74 20 2d | 66 20 4d 61 6b 65 66 69 |f test -|f Makefi|
|00000570| 6c 65 20 2d 61 20 22 24 | 7b 31 7d 22 20 21 3d 20 |le -a "$|{1}" != |
|00000580| 22 2d 63 22 20 3b 20 74 | 68 65 6e 20 0a 20 20 65 |"-c" ; t|hen . e|
|00000590| 63 68 6f 20 73 68 61 72 | 3a 20 57 69 6c 6c 20 6e |cho shar|: Will n|
|000005a0| 6f 74 20 6f 76 65 72 2d | 77 72 69 74 65 20 65 78 |ot over-|write ex|
|000005b0| 69 73 74 69 6e 67 20 66 | 69 6c 65 20 5c 22 4d 61 |isting f|ile \"Ma|
|000005c0| 6b 65 66 69 6c 65 5c 22 | 0a 65 6c 73 65 0a 65 63 |kefile\"|.else.ec|
|000005d0| 68 6f 20 73 68 61 72 3a | 20 45 78 74 72 61 63 74 |ho shar:| Extract|
|000005e0| 69 6e 67 20 5c 22 4d 61 | 6b 65 66 69 6c 65 5c 22 |ing \"Ma|kefile\"|
|000005f0| 20 5c 28 35 33 36 20 63 | 68 61 72 61 63 74 65 72 | \(536 c|haracter|
|00000600| 73 5c 29 0a 73 65 64 20 | 22 73 2f 5e 58 2f 2f 22 |s\).sed |"s/^X//"|
|00000610| 20 3e 4d 61 6b 65 66 69 | 6c 65 20 3c 3c 27 45 4e | >Makefi|le <<'EN|
|00000620| 44 5f 4f 46 5f 4d 61 6b | 65 66 69 6c 65 27 0a 58 |D_OF_Mak|efile'.X|
|00000630| 74 72 61 63 65 72 3a 20 | 74 72 61 63 65 72 2e 6f |tracer: |tracer.o|
|00000640| 20 73 68 61 64 65 2e 6f | 20 66 69 6e 64 2e 6f 20 | shade.o| find.o |
|00000650| 73 75 70 70 6f 72 74 2e | 6f 20 72 65 66 72 61 63 |support.|o refrac|
|00000660| 74 2e 6f 20 67 5f 62 6f | 64 2e 6f 20 67 5f 62 61 |t.o g_bo|d.o g_ba|
|00000670| 6c 2e 6f 0a 58 09 63 63 | 20 74 72 61 63 65 72 2e |l.o.X.cc| tracer.|
|00000680| 6f 20 73 68 61 64 65 2e | 6f 20 66 69 6e 64 2e 6f |o shade.|o find.o|
|00000690| 20 73 75 70 70 6f 72 74 | 2e 6f 20 72 65 66 72 61 | support|.o refra|
|000006a0| 63 74 2e 6f 20 67 5f 62 | 6f 64 2e 6f 20 67 5f 62 |ct.o g_b|od.o g_b|
|000006b0| 61 6c 2e 6f 20 2d 6c 6d | 20 2d 6f 20 74 72 61 63 |al.o -lm| -o trac|
|000006c0| 65 72 0a 58 66 69 6e 64 | 2e 6f 3a 20 66 69 6e 64 |er.Xfind|.o: find|
|000006d0| 2e 63 20 72 74 64 2e 68 | 20 65 78 74 65 72 6e 2e |.c rtd.h| extern.|
|000006e0| 68 20 6d 61 63 72 6f 73 | 2e 68 0a 58 09 63 63 20 |h macros|.h.X.cc |
|000006f0| 2d 63 20 66 69 6e 64 2e | 63 20 0a 58 73 68 61 64 |-c find.|c .Xshad|
|00000700| 65 2e 6f 3a 20 73 68 61 | 64 65 2e 63 20 72 74 64 |e.o: sha|de.c rtd|
|00000710| 2e 68 20 65 78 74 65 72 | 6e 2e 68 20 6d 61 63 72 |.h exter|n.h macr|
|00000720| 6f 73 2e 68 0a 58 09 63 | 63 20 2d 63 20 73 68 61 |os.h.X.c|c -c sha|
|00000730| 64 65 2e 63 20 0a 58 73 | 75 70 70 6f 72 74 2e 6f |de.c .Xs|upport.o|
|00000740| 3a 20 73 75 70 70 6f 72 | 74 2e 63 20 72 74 64 2e |: suppor|t.c rtd.|
|00000750| 68 20 65 78 74 65 72 6e | 2e 68 0a 58 09 63 63 20 |h extern|.h.X.cc |
|00000760| 2d 63 20 73 75 70 70 6f | 72 74 2e 63 20 0a 58 74 |-c suppo|rt.c .Xt|
|00000770| 72 61 63 65 72 2e 6f 3a | 20 74 72 61 63 65 72 2e |racer.o:| tracer.|
|00000780| 63 20 72 74 64 2e 68 20 | 62 64 61 74 61 2e 69 20 |c rtd.h |bdata.i |
|00000790| 6d 61 63 72 6f 73 2e 68 | 0a 58 09 63 63 20 2d 63 |macros.h|.X.cc -c|
|000007a0| 20 74 72 61 63 65 72 2e | 63 20 20 0a 58 72 65 66 | tracer.|c .Xref|
|000007b0| 72 61 63 74 2e 6f 3a 20 | 72 65 66 72 61 63 74 2e |ract.o: |refract.|
|000007c0| 63 20 72 74 64 2e 68 20 | 65 78 74 65 72 6e 2e 68 |c rtd.h |extern.h|
|000007d0| 20 6d 61 63 72 6f 73 2e | 68 0a 58 09 63 63 20 2d | macros.|h.X.cc -|
|000007e0| 63 20 72 65 66 72 61 63 | 74 2e 63 20 20 0a 58 67 |c refrac|t.c .Xg|
|000007f0| 5f 62 6f 64 2e 6f 3a 20 | 67 5f 62 6f 64 2e 63 20 |_bod.o: |g_bod.c |
|00000800| 65 78 74 65 72 6e 2e 68 | 20 6d 61 63 72 6f 73 2e |extern.h| macros.|
|00000810| 68 0a 58 09 63 63 20 2d | 63 20 67 5f 62 6f 64 2e |h.X.cc -|c g_bod.|
|00000820| 63 20 20 0a 58 67 5f 62 | 61 6c 2e 6f 3a 20 67 5f |c .Xg_b|al.o: g_|
|00000830| 62 61 6c 2e 63 20 65 78 | 74 65 72 6e 2e 68 20 72 |bal.c ex|tern.h r|
|00000840| 74 64 2e 68 0a 58 09 63 | 63 20 2d 63 20 67 5f 62 |td.h.X.c|c -c g_b|
|00000850| 61 6c 2e 63 20 20 0a 45 | 4e 44 5f 4f 46 5f 4d 61 |al.c .E|ND_OF_Ma|
|00000860| 6b 65 66 69 6c 65 0a 69 | 66 20 74 65 73 74 20 35 |kefile.i|f test 5|
|00000870| 33 36 20 2d 6e 65 20 60 | 77 63 20 2d 63 20 3c 4d |36 -ne `|wc -c <M|
|00000880| 61 6b 65 66 69 6c 65 60 | 3b 20 74 68 65 6e 0a 20 |akefile`|; then. |
|00000890| 20 20 20 65 63 68 6f 20 | 73 68 61 72 3a 20 5c 22 | echo |shar: \"|
|000008a0| 4d 61 6b 65 66 69 6c 65 | 5c 22 20 75 6e 70 61 63 |Makefile|\" unpac|
|000008b0| 6b 65 64 20 77 69 74 68 | 20 77 72 6f 6e 67 20 73 |ked with| wrong s|
|000008c0| 69 7a 65 21 0a 66 69 0a | 23 20 65 6e 64 20 6f 66 |ize!.fi.|# end of|
|000008d0| 20 6f 76 65 72 77 72 69 | 74 69 6e 67 20 63 68 65 | overwri|ting che|
|000008e0| 63 6b 0a 66 69 0a 69 66 | 20 74 65 73 74 20 2d 66 |ck.fi.if| test -f|
|000008f0| 20 52 45 41 44 4d 45 2e | 44 4f 43 20 2d 61 20 22 | README.|DOC -a "|
|00000900| 24 7b 31 7d 22 20 21 3d | 20 22 2d 63 22 20 3b 20 |${1}" !=| "-c" ; |
|00000910| 74 68 65 6e 20 0a 20 20 | 65 63 68 6f 20 73 68 61 |then . |echo sha|
|00000920| 72 3a 20 57 69 6c 6c 20 | 6e 6f 74 20 6f 76 65 72 |r: Will |not over|
|00000930| 2d 77 72 69 74 65 20 65 | 78 69 73 74 69 6e 67 20 |-write e|xisting |
|00000940| 66 69 6c 65 20 5c 22 52 | 45 41 44 4d 45 2e 44 4f |file \"R|EADME.DO|
|00000950| 43 5c 22 0a 65 6c 73 65 | 0a 65 63 68 6f 20 73 68 |C\".else|.echo sh|
|00000960| 61 72 3a 20 45 78 74 72 | 61 63 74 69 6e 67 20 5c |ar: Extr|acting \|
|00000970| 22 52 45 41 44 4d 45 2e | 44 4f 43 5c 22 20 5c 28 |"README.|DOC\" \(|
|00000980| 32 32 35 32 20 63 68 61 | 72 61 63 74 65 72 73 5c |2252 cha|racters\|
|00000990| 29 0a 73 65 64 20 22 73 | 2f 5e 58 2f 2f 22 20 3e |).sed "s|/^X//" >|
|000009a0| 52 45 41 44 4d 45 2e 44 | 4f 43 20 3c 3c 27 45 4e |README.D|OC <<'EN|
|000009b0| 44 5f 4f 46 5f 52 45 41 | 44 4d 45 2e 44 4f 43 27 |D_OF_REA|DME.DOC'|
|000009c0| 0a 58 0a 58 0a 58 0a 58 | 54 52 41 43 45 52 28 39 |.X.X.X.X|TRACER(9|
|000009d0| 39 29 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |9) | |
|000009e0| 20 20 20 20 46 52 49 54 | 5a 5a 20 47 52 41 50 48 | FRIT|ZZ GRAPH|
|000009f0| 49 43 53 20 20 20 20 20 | 20 20 20 20 20 20 20 54 |ICS | T|
|00000a00| 52 41 43 45 52 28 39 39 | 29 0a 58 0a 58 0a 58 0a |RACER(99|).X.X.X.|
|00000a10| 58 4e 41 4d 45 0a 58 20 | 20 20 20 20 74 72 61 63 |XNAME.X | trac|
|00000a20| 65 72 2d 20 72 75 6e 20 | 61 20 73 69 6d 70 6c 65 |er- run |a simple|
|00000a30| 20 72 61 79 20 74 72 61 | 63 69 6e 67 20 70 72 6f | ray tra|cing pro|
|00000a40| 63 65 64 75 72 65 0a 58 | 0a 58 53 59 4e 4f 50 53 |cedure.X|.XSYNOPS|
|00000a50| 49 53 0a 58 20 20 20 20 | 20 74 72 61 63 65 72 20 |IS.X | tracer |
|00000a60| 2d 6f 20 5b 66 69 6c 65 | 6e 61 6d 65 5d 20 2d 69 |-o [file|name] -i|
|00000a70| 20 5b 66 69 6c 65 6e 61 | 6d 65 5d 20 2d 73 20 3c | [filena|me] -s <|
|00000a80| 66 69 6c 65 6e 61 6d 65 | 3e 20 2d 53 3c 6e 75 6d |filename|> -S<num|
|00000a90| 62 65 72 3e 0a 58 0a 58 | 44 45 53 43 52 49 50 54 |ber>.X.X|DESCRIPT|
|00000aa0| 49 4f 4e 0a 58 20 20 20 | 20 20 54 72 61 63 65 72 |ION.X | Tracer|
|00000ab0| 20 69 73 20 61 20 70 72 | 6f 67 72 61 6d 20 64 65 | is a pr|ogram de|
|00000ac0| 76 65 6c 6f 70 65 64 20 | 6f 72 69 67 69 6e 61 6c |veloped |original|
|00000ad0| 6c 79 20 74 6f 20 73 74 | 75 64 79 20 68 6f 77 0a |ly to st|udy how.|
|00000ae0| 58 20 20 20 20 20 72 61 | 79 20 74 72 61 63 69 6e |X ra|y tracin|
|00000af0| 67 20 77 6f 72 6b 73 2c | 20 61 6e 64 20 77 61 73 |g works,| and was|
|00000b00| 20 6c 61 74 65 72 20 6d | 6f 64 69 66 69 65 64 20 | later m|odified |
|00000b10| 74 6f 20 74 68 65 20 70 | 72 65 73 65 6e 74 20 73 |to the p|resent s|
|00000b20| 74 61 74 65 0a 58 20 20 | 20 20 20 74 6f 20 6d 61 |tate.X | to ma|
|00000b30| 6b 65 20 69 74 20 6d 6f | 72 65 20 63 6f 6d 70 61 |ke it mo|re compa|
|00000b40| 74 69 62 6c 65 20 66 6f | 72 20 61 6e 69 6d 61 74 |tible fo|r animat|
|00000b50| 65 64 20 66 69 6c 6d 20 | 70 72 6f 64 75 63 74 69 |ed film |producti|
|00000b60| 6f 6e 2e 0a 58 0a 58 20 | 20 20 20 20 49 74 20 69 |on..X.X | It i|
|00000b70| 73 20 63 61 70 61 62 6c | 65 20 6f 66 20 64 65 70 |s capabl|e of dep|
|00000b80| 69 63 74 69 6e 67 20 61 | 20 6e 75 6d 62 65 72 20 |icting a| number |
|00000b90| 6f 66 20 62 61 6c 6c 73 | 20 28 75 70 20 74 6f 20 |of balls| (up to |
|00000ba0| 31 35 30 29 0a 58 20 20 | 20 20 20 61 6e 64 20 61 |150).X | and a|
|00000bb0| 20 70 6c 61 6e 65 20 74 | 68 61 74 20 69 73 20 63 | plane t|hat is c|
|00000bc0| 6f 76 65 72 65 64 20 77 | 69 74 68 20 61 20 74 69 |overed w|ith a ti|
|00000bd0| 6c 69 6e 67 20 6f 66 20 | 61 6e 79 20 62 69 74 6d |ling of |any bitm|
|00000be0| 61 70 70 65 64 20 70 69 | 63 74 75 72 65 2e 0a 58 |apped pi|cture..X|
|00000bf0| 0a 58 0a 58 4f 50 54 49 | 4f 4e 53 0a 58 20 20 20 |.X.XOPTI|ONS.X |
|00000c00| 20 20 2d 6f 20 43 68 6f | 6f 73 65 73 20 74 68 65 | -o Cho|oses the|
|00000c10| 20 6f 75 74 70 75 74 20 | 64 61 74 61 20 66 69 6c | output |data fil|
|00000c20| 65 2e 20 49 66 20 6e 6f | 20 61 72 67 75 6d 65 6e |e. If no| argumen|
|00000c30| 74 20 69 73 20 67 69 76 | 69 6e 2c 20 73 74 64 6f |t is giv|in, stdo|
|00000c40| 75 74 0a 58 20 20 20 20 | 20 20 20 20 69 73 20 75 |ut.X | is u|
|00000c50| 73 65 64 2e 20 49 66 20 | 74 68 65 20 6f 70 74 69 |sed. If |the opti|
|00000c60| 6f 6e 20 69 73 20 6e 6f | 74 20 75 73 65 64 20 74 |on is no|t used t|
|00000c70| 68 65 20 64 65 66 61 75 | 6c 74 20 69 73 20 64 61 |he defau|lt is da|
|00000c80| 74 61 2e 64 69 73 2e 0a | 58 0a 58 20 20 20 20 20 |ta.dis..|X.X |
|00000c90| 2d 69 20 43 68 6f 6f 73 | 65 73 20 74 68 65 20 69 |-i Choos|es the i|
|00000ca0| 6e 70 75 74 20 28 62 61 | 6c 6c 29 20 64 61 74 61 |nput (ba|ll) data|
|00000cb0| 20 66 69 6c 65 2e 20 49 | 66 20 6e 6f 20 61 72 67 | file. I|f no arg|
|00000cc0| 75 6d 65 6e 74 20 69 73 | 20 67 69 76 65 6e 2c 20 |ument is| given, |
|00000cd0| 73 74 64 69 6e 0a 58 20 | 20 20 20 20 20 20 20 69 |stdin.X | i|
|00000ce0| 73 20 75 73 65 64 2e 20 | 49 66 20 74 68 65 20 6f |s used. |If the o|
|00000cf0| 70 74 69 6f 6e 20 69 73 | 20 6e 6f 74 20 75 73 65 |ption is| not use|
|00000d00| 64 20 74 68 65 20 64 65 | 66 61 75 6c 74 20 69 73 |d the de|fault is|
|00000d10| 20 62 64 61 74 61 2e 69 | 2e 0a 58 20 0a 58 20 20 | bdata.i|..X .X |
|00000d20| 20 20 20 2d 73 20 43 68 | 6f 6f 73 65 73 20 74 68 | -s Ch|ooses th|
|00000d30| 65 20 66 69 6c 65 20 63 | 6f 6e 74 61 69 6e 69 6e |e file c|ontainin|
|00000d40| 67 20 74 68 65 20 74 69 | 6c 69 6e 67 20 62 69 74 |g the ti|ling bit|
|00000d50| 6d 61 70 2e 20 49 74 20 | 72 65 71 75 69 72 65 73 |map. It |requires|
|00000d60| 20 61 6e 0a 58 20 20 20 | 20 20 20 20 20 61 6e 20 | an.X | an |
|00000d70| 61 72 67 75 6d 65 6e 74 | 2e 20 49 66 20 74 68 65 |argument|. If the|
|00000d80| 20 6f 70 74 69 6f 6e 20 | 69 73 20 6e 6f 74 20 75 | option |is not u|
|00000d90| 73 65 64 20 74 68 65 20 | 64 65 66 61 75 6c 74 20 |sed the |default |
|00000da0| 69 73 20 70 61 74 2e 64 | 65 66 2e 0a 58 0a 58 20 |is pat.d|ef..X.X |
|00000db0| 20 20 20 20 2d 53 20 43 | 68 6f 6f 73 65 73 20 63 | -S C|hooses c|
|00000dc0| 6f 6e 74 72 61 73 74 20 | 6f 66 20 74 68 65 20 70 |ontrast |of the p|
|00000dd0| 61 74 74 65 72 6e 2e 20 | 30 2e 30 20 69 73 20 6e |attern. |0.0 is n|
|00000de0| 6f 20 63 6f 6e 74 72 61 | 73 74 2c 20 31 2e 30 20 |o contra|st, 1.0 |
|00000df0| 69 73 20 6d 61 78 69 6d | 75 6d 0a 58 20 20 20 20 |is maxim|um.X |
|00000e00| 20 20 20 20 63 6f 6e 74 | 72 61 73 74 2e 20 31 2e | cont|rast. 1.|
|00000e10| 30 20 69 73 20 74 68 65 | 20 64 65 66 61 75 6c 74 |0 is the| default|
|00000e20| 2e 20 28 75 73 65 66 75 | 6c 20 66 6f 72 20 66 61 |. (usefu|l for fa|
|00000e30| 64 69 6e 67 20 64 75 72 | 69 6e 67 20 61 6e 69 6d |ding dur|ing anim|
|00000e40| 61 74 69 6f 6e 29 0a 58 | 0a 58 50 52 4f 47 52 41 |ation).X|.XPROGRA|
|00000e50| 4d 20 4e 4f 54 45 53 0a | 58 20 20 20 20 20 54 68 |M NOTES.|X Th|
|00000e60| 69 73 20 70 72 6f 67 72 | 61 6d 20 67 65 6e 65 72 |is progr|am gener|
|00000e70| 61 74 65 73 20 61 20 66 | 69 6c 65 20 63 6f 6e 74 |ates a f|ile cont|
|00000e80| 61 69 6e 69 6e 67 20 61 | 20 68 65 61 64 65 72 20 |aining a| header |
|00000e90| 77 69 74 68 20 78 20 61 | 6e 64 20 79 20 73 69 7a |with x a|nd y siz|
|00000ea0| 65 73 2c 0a 58 20 20 20 | 20 20 66 6f 6c 6c 6f 77 |es,.X | follow|
|00000eb0| 65 64 20 62 79 20 74 68 | 65 20 64 61 74 61 20 69 |ed by th|e data i|
|00000ec0| 6e 20 38 2d 62 69 74 20 | 67 72 65 79 73 63 61 6c |n 8-bit |greyscal|
|00000ed0| 65 2c 20 6f 6e 65 20 70 | 69 78 65 6c 20 74 6f 20 |e, one p|ixel to |
|00000ee0| 61 20 63 68 61 72 61 63 | 74 65 72 2c 20 69 6e 20 |a charac|ter, in |
|00000ef0| 0a 58 20 20 20 20 20 73 | 63 61 6e 6c 69 6e 65 73 |.X s|canlines|
|00000f00| 2e 0a 58 20 20 20 20 20 | 54 68 65 72 65 20 61 72 |..X |There ar|
|00000f10| 65 20 74 77 6f 20 6e 65 | 63 63 65 73 73 61 72 79 |e two ne|ccessary|
|00000f20| 20 69 6e 70 75 74 20 66 | 69 6c 65 73 3a 20 62 61 | input f|iles: ba|
|00000f30| 6c 6c 20 64 61 74 61 2c | 20 61 6e 64 20 61 20 70 |ll data,| and a p|
|00000f40| 61 74 74 65 72 6e 20 62 | 69 74 6d 61 70 2e 0a 58 |attern b|itmap..X|
|00000f50| 20 20 20 20 20 54 68 65 | 20 74 69 6c 69 6e 67 20 | The| tiling |
|00000f60| 62 69 74 6d 61 70 20 63 | 61 6e 20 62 65 20 64 69 |bitmap c|an be di|
|00000f70| 67 69 74 69 7a 65 64 20 | 64 61 74 61 2c 20 69 74 |gitized |data, it|
|00000f80| 20 6d 75 73 74 20 62 65 | 20 69 6e 20 74 68 65 20 | must be| in the |
|00000f90| 66 6f 72 6d 20 6f 66 20 | 0a 58 20 20 20 20 20 73 |form of |.X s|
|00000fa0| 63 61 6e 20 6c 69 6e 65 | 73 20 6e 6f 20 6c 6f 6e |can line|s no lon|
|00000fb0| 67 65 72 20 74 68 61 6e | 20 35 31 32 20 62 79 74 |ger than| 512 byt|
|00000fc0| 65 73 20 66 6f 6c 6c 6f | 77 65 64 20 62 79 20 6e |es follo|wed by n|
|00000fd0| 65 77 6c 69 6e 65 73 2e | 0a 58 20 20 20 20 20 74 |ewlines.|.X t|
|00000fe0| 68 65 20 62 61 6c 6c 20 | 64 61 74 61 20 69 73 20 |he ball |data is |
|00000ff0| 6f 66 20 74 68 65 20 66 | 6f 6c 6c 6f 77 69 6e 67 |of the f|ollowing|
|00001000| 20 66 6f 72 6d 3a 0a 58 | 0a 58 20 20 20 20 20 78 | form:.X|.X x|
|00001010| 20 79 20 7a 20 72 61 64 | 20 69 6f 72 20 72 65 66 | y z rad| ior ref|
|00001020| 72 61 63 74 20 72 65 66 | 6c 65 63 74 20 64 69 66 |ract ref|lect dif|
|00001030| 66 75 73 65 20 61 6d 62 | 69 65 6e 74 0a 58 0a 58 |fuse amb|ient.X.X|
|00001040| 20 20 20 20 20 6f 6e 20 | 65 61 63 68 20 6c 69 6e | on |each lin|
|00001050| 65 20 77 68 65 72 65 20 | 78 20 79 20 26 20 7a 20 |e where |x y & z |
|00001060| 61 72 65 20 74 68 65 20 | 63 6f 6f 72 64 69 6e 61 |are the |coordina|
|00001070| 74 65 73 20 6f 66 20 74 | 68 65 20 63 65 6e 74 65 |tes of t|he cente|
|00001080| 72 20 6f 66 20 0a 58 20 | 20 20 20 20 74 68 65 20 |r of .X | the |
|00001090| 62 61 6c 6c 2c 20 72 61 | 64 20 69 73 20 74 68 65 |ball, ra|d is the|
|000010a0| 20 72 61 64 69 75 73 20 | 6f 66 20 74 68 65 20 62 | radius |of the b|
|000010b0| 61 6c 6c 2c 20 69 6f 72 | 20 69 73 20 74 68 65 20 |all, ior| is the |
|000010c0| 69 6e 64 65 78 20 6f 66 | 20 72 65 66 72 61 63 74 |index of| refract|
|000010d0| 69 6f 6e 0a 58 20 20 20 | 20 20 66 6f 72 20 74 72 |ion.X | for tr|
|000010e0| 61 6e 73 6c 75 63 65 6e | 74 20 6d 61 74 65 72 69 |anslucen|t materi|
|000010f0| 61 6c 73 20 28 69 6e 64 | 65 78 20 6f 66 20 72 65 |als (ind|ex of re|
|00001100| 66 72 61 63 74 69 6f 6e | 20 66 6f 72 20 67 6c 61 |fraction| for gla|
|00001110| 73 73 20 69 73 20 61 62 | 6f 75 74 20 31 2e 35 29 |ss is ab|out 1.5)|
|00001120| 0a 58 20 20 20 20 20 74 | 68 65 20 6c 61 73 74 20 |.X t|he last |
|00001130| 66 6f 75 72 20 6e 75 6d | 62 65 72 73 20 64 65 74 |four num|bers det|
|00001140| 65 72 6d 69 6e 65 20 68 | 6f 77 20 6d 75 63 68 20 |ermine h|ow much |
|00001150| 6f 66 20 65 61 63 68 20 | 61 74 72 72 69 62 75 74 |of each |atrribut|
|00001160| 65 20 69 73 20 75 73 65 | 64 2e 0a 58 20 20 20 20 |e is use|d..X |
|00001170| 20 54 68 75 73 20 61 20 | 70 75 72 65 20 73 69 6c | Thus a |pure sil|
|00001180| 76 65 72 20 62 61 6c 6c | 20 77 6f 75 6c 64 20 68 |ver ball| would h|
|00001190| 61 76 65 20 30 2e 30 20 | 31 2e 30 20 30 2e 30 20 |ave 0.0 |1.0 0.0 |
|000011a0| 30 2e 30 20 61 73 20 74 | 68 65 20 6c 61 73 74 20 |0.0 as t|he last |
|000011b0| 6e 75 6d 62 65 72 73 2c | 0a 58 20 20 20 20 20 61 |numbers,|.X a|
|000011c0| 6e 64 20 61 20 70 75 72 | 65 20 67 6c 61 73 73 20 |nd a pur|e glass |
|000011d0| 62 61 6c 6c 20 77 6f 75 | 6c 64 20 68 61 76 65 20 |ball wou|ld have |
|000011e0| 31 2e 30 20 30 2e 30 20 | 30 2e 30 20 30 2e 30 20 |1.0 0.0 |0.0 0.0 |
|000011f0| 2e 0a 58 0a 58 0a 58 46 | 49 4c 45 53 0a 58 20 20 |..X.X.XF|ILES.X |
|00001200| 20 20 20 2e 2f 62 64 61 | 74 61 2e 69 09 64 65 66 | ./bda|ta.i.def|
|00001210| 61 75 6c 74 20 62 61 6c | 6c 20 64 61 74 61 0a 58 |ault bal|l data.X|
|00001220| 20 20 20 20 20 2e 2f 70 | 61 74 2e 64 65 66 20 20 | ./p|at.def |
|00001230| 64 65 66 61 75 6c 74 20 | 66 6c 6f 6f 72 20 70 61 |default |floor pa|
|00001240| 74 74 65 72 6e 0a 58 20 | 20 20 20 20 2e 2f 64 61 |ttern.X | ./da|
|00001250| 74 61 2e 64 69 73 20 64 | 65 66 61 75 6c 74 20 6f |ta.dis d|efault o|
|00001260| 75 74 70 75 74 20 66 69 | 6c 65 0a 58 0a 58 42 55 |utput fi|le.X.XBU|
|00001270| 47 53 0a 58 20 20 20 20 | 20 41 73 20 77 69 74 68 |GS.X | As with|
|00001280| 20 61 6e 79 20 67 6f 6f | 64 20 73 6f 66 74 77 61 | any goo|d softwa|
|00001290| 72 65 2c 20 74 68 65 20 | 63 6f 6d 70 6c 65 78 69 |re, the |complexi|
|000012a0| 74 79 20 6f 66 20 74 68 | 69 73 20 70 72 6f 67 72 |ty of th|is progr|
|000012b0| 61 6d 20 68 69 64 65 73 | 20 0a 58 20 20 20 20 20 |am hides| .X |
|000012c0| 61 6c 6c 20 62 75 67 73 | 2e 0a 58 0a 45 4e 44 5f |all bugs|..X.END_|
|000012d0| 4f 46 5f 52 45 41 44 4d | 45 2e 44 4f 43 0a 69 66 |OF_READM|E.DOC.if|
|000012e0| 20 74 65 73 74 20 32 32 | 35 32 20 2d 6e 65 20 60 | test 22|52 -ne `|
|000012f0| 77 63 20 2d 63 20 3c 52 | 45 41 44 4d 45 2e 44 4f |wc -c <R|EADME.DO|
|00001300| 43 60 3b 20 74 68 65 6e | 0a 20 20 20 20 65 63 68 |C`; then|. ech|
|00001310| 6f 20 73 68 61 72 3a 20 | 5c 22 52 45 41 44 4d 45 |o shar: |\"README|
|00001320| 2e 44 4f 43 5c 22 20 75 | 6e 70 61 63 6b 65 64 20 |.DOC\" u|npacked |
|00001330| 77 69 74 68 20 77 72 6f | 6e 67 20 73 69 7a 65 21 |with wro|ng size!|
|00001340| 0a 66 69 0a 23 20 65 6e | 64 20 6f 66 20 6f 76 65 |.fi.# en|d of ove|
|00001350| 72 77 72 69 74 69 6e 67 | 20 63 68 65 63 6b 0a 66 |rwriting| check.f|
|00001360| 69 0a 69 66 20 74 65 73 | 74 20 2d 66 20 52 45 41 |i.if tes|t -f REA|
|00001370| 44 4d 45 2e 48 41 4b 20 | 2d 61 20 22 24 7b 31 7d |DME.HAK |-a "${1}|
|00001380| 22 20 21 3d 20 22 2d 63 | 22 20 3b 20 74 68 65 6e |" != "-c|" ; then|
|00001390| 20 0a 20 20 65 63 68 6f | 20 73 68 61 72 3a 20 57 | . echo| shar: W|
|000013a0| 69 6c 6c 20 6e 6f 74 20 | 6f 76 65 72 2d 77 72 69 |ill not |over-wri|
|000013b0| 74 65 20 65 78 69 73 74 | 69 6e 67 20 66 69 6c 65 |te exist|ing file|
|000013c0| 20 5c 22 52 45 41 44 4d | 45 2e 48 41 4b 5c 22 0a | \"READM|E.HAK\".|
|000013d0| 65 6c 73 65 0a 65 63 68 | 6f 20 73 68 61 72 3a 20 |else.ech|o shar: |
|000013e0| 45 78 74 72 61 63 74 69 | 6e 67 20 5c 22 52 45 41 |Extracti|ng \"REA|
|000013f0| 44 4d 45 2e 48 41 4b 5c | 22 20 5c 28 31 32 35 39 |DME.HAK\|" \(1259|
|00001400| 20 63 68 61 72 61 63 74 | 65 72 73 5c 29 0a 73 65 | charact|ers\).se|
|00001410| 64 20 22 73 2f 5e 58 2f | 2f 22 20 3e 52 45 41 44 |d "s/^X/|/" >READ|
|00001420| 4d 45 2e 48 41 4b 20 3c | 3c 27 45 4e 44 5f 4f 46 |ME.HAK <|<'END_OF|
|00001430| 5f 52 45 41 44 4d 45 2e | 48 41 4b 27 0a 58 2a 2a |_README.|HAK'.X**|
|00001440| 2a 2a 2a 20 41 20 48 61 | 63 6b 65 72 73 20 47 75 |*** A Ha|ckers Gu|
|00001450| 69 64 65 20 74 6f 20 54 | 72 61 63 65 72 20 2a 2a |ide to T|racer **|
|00001460| 2a 2a 2a 0a 58 74 72 61 | 63 65 72 20 63 6f 6e 73 |***.Xtra|cer cons|
|00001470| 69 73 74 73 20 6f 66 20 | 61 20 62 75 6e 63 68 20 |ists of |a bunch |
|00001480| 6f 66 20 66 69 6c 65 73 | 20 63 6f 6e 74 61 69 6e |of files| contain|
|00001490| 69 6e 67 20 61 20 70 72 | 6f 67 72 61 6d 20 74 68 |ing a pr|ogram th|
|000014a0| 61 74 20 64 6f 65 73 20 | 0a 58 72 61 79 20 74 72 |at does |.Xray tr|
|000014b0| 61 63 69 6e 67 20 28 4e | 6f 20 73 68 69 74 20 73 |acing (N|o shit s|
|000014c0| 68 65 72 6c 6f 63 6b 29 | 2e 0a 58 54 68 65 73 20 |herlock)|..XThes |
|000014d0| 66 69 6c 65 73 20 61 72 | 65 20 61 73 20 66 6f 6c |files ar|e as fol|
|000014e0| 6c 6f 77 73 3a 0a 58 74 | 72 61 63 65 72 2e 63 3a |lows:.Xt|racer.c:|
|000014f0| 09 6d 61 69 6e 28 29 20 | 73 65 74 73 20 75 70 20 |.main() |sets up |
|00001500| 74 68 65 20 69 6e 69 74 | 69 61 6c 20 72 61 79 73 |the init|ial rays|
|00001510| 20 61 6e 64 20 73 74 6f | 72 65 73 20 76 61 6c 75 | and sto|res valu|
|00001520| 65 73 0a 58 09 09 69 6e | 20 61 20 66 69 6c 65 2e |es.X..in| a file.|
|00001530| 20 62 6f 6f 62 6f 6f 20 | 70 72 69 6e 74 73 20 61 | booboo |prints a|
|00001540| 6e 20 65 72 72 6f 72 20 | 6d 65 73 73 61 67 65 20 |n error |message |
|00001550| 61 6e 64 20 71 75 69 74 | 73 2e 0a 58 73 68 61 64 |and quit|s..Xshad|
|00001560| 65 2e 63 3a 09 73 68 61 | 64 65 28 29 20 63 61 6c |e.c:.sha|de() cal|
|00001570| 63 75 6c 61 74 65 73 20 | 74 68 65 20 69 6e 74 65 |culates |the inte|
|00001580| 6e 73 69 74 79 20 72 65 | 74 75 72 6e 65 64 20 62 |nsity re|turned b|
|00001590| 79 20 61 20 72 61 79 2e | 20 49 74 20 69 73 0a 58 |y a ray.| It is.X|
|000015a0| 09 20 09 72 65 63 75 72 | 73 69 76 65 2c 20 61 6e |. .recur|sive, an|
|000015b0| 64 20 61 6c 73 6f 20 6d | 61 6b 65 73 20 61 20 63 |d also m|akes a c|
|000015c0| 61 6c 6c 20 74 6f 20 72 | 65 66 72 61 63 74 28 29 |all to r|efract()|
|000015d0| 2e 0a 58 72 65 66 72 61 | 63 74 2e 63 3a 09 54 68 |..Xrefra|ct.c:.Th|
|000015e0| 65 20 6d 6f 73 74 20 64 | 69 66 66 69 63 75 6c 74 |e most d|ifficult|
|000015f0| 20 70 61 72 74 20 6f 66 | 20 74 68 65 20 70 72 6f | part of| the pro|
|00001600| 67 72 61 6d 2e 20 54 68 | 69 73 20 66 69 6c 65 20 |gram. Th|is file |
|00001610| 63 6f 6e 74 61 69 6e 73 | 0a 58 09 09 72 65 66 72 |contains|.X..refr|
|00001620| 61 63 74 28 29 2c 20 69 | 6e 73 69 64 65 28 29 2c |act(), i|nside(),|
|00001630| 20 72 65 66 6b 28 29 20 | 61 6e 64 20 67 65 74 63 | refk() |and getc|
|00001640| 61 70 74 28 29 2e 0a 58 | 09 09 61 6e 64 20 74 68 |apt()..X|..and th|
|00001650| 65 73 65 20 64 6f 20 61 | 6c 6c 20 74 68 65 20 72 |ese do a|ll the r|
|00001660| 65 66 72 61 63 74 69 6f | 6e 20 63 61 6c 63 75 6c |efractio|n calcul|
|00001670| 61 74 69 6f 6e 73 2e 0a | 58 66 69 6e 64 2e 63 3a |ations..|Xfind.c:|
|00001680| 09 09 63 6f 6e 74 61 69 | 6e 73 20 66 69 6e 64 28 |..contai|ns find(|
|00001690| 29 2c 66 69 6e 64 6f 28 | 29 20 28 66 6f 72 20 77 |),findo(|) (for w|
|000016a0| 68 65 6e 20 61 20 72 61 | 79 20 69 73 20 69 6e 73 |hen a ra|y is ins|
|000016b0| 69 64 65 20 61 20 62 61 | 6c 6c 29 0a 58 09 09 61 |ide a ba|ll).X..a|
|000016c0| 6e 64 20 73 68 61 64 6f | 77 28 29 20 61 6e 64 20 |nd shado|w() and |
|000016d0| 66 69 6e 64 73 28 29 20 | 66 6f 72 20 73 68 61 64 |finds() |for shad|
|000016e0| 6f 77 73 2e 0a 58 73 75 | 70 70 6f 72 74 2e 63 3a |ows..Xsu|pport.c:|
|000016f0| 09 73 75 70 70 6f 72 74 | 69 76 65 20 73 75 62 72 |.support|ive subr|
|00001700| 6f 75 74 69 6e 65 73 2e | 20 72 69 67 68 74 20 6e |outines.| right n|
|00001710| 6f 77 20 6f 6e 6c 79 20 | 63 6f 6e 74 61 69 6e 73 |ow only |contains|
|00001720| 20 6d 74 5f 76 65 63 0a | 58 09 09 61 73 20 61 6c | mt_vec.|X..as al|
|00001730| 6c 20 74 68 65 20 6f 74 | 68 65 72 73 20 77 65 72 |l the ot|hers wer|
|00001740| 65 20 65 69 74 68 65 72 | 20 64 69 73 63 61 72 64 |e either| discard|
|00001750| 65 64 20 6f 72 20 63 6f | 6e 76 65 72 74 65 64 20 |ed or co|nverted |
|00001760| 74 6f 20 0a 58 09 09 6d | 61 63 72 6f 73 2e 0a 58 |to .X..m|acros..X|
|00001770| 67 5f 62 61 6c 2e 63 09 | 09 67 5f 62 61 6c 28 29 |g_bal.c.|.g_bal()|
|00001780| 20 67 65 74 73 20 74 68 | 65 20 62 61 6c 6c 20 64 | gets th|e ball d|
|00001790| 61 74 61 20 61 6e 64 20 | 70 6f 69 6e 74 73 20 62 |ata and |points b|
|000017a0| 6c 5b 5d 20 61 74 20 74 | 68 65 6d 2e 0a 58 67 5f |l[] at t|hem..Xg_|
|000017b0| 62 6f 64 2e 63 09 09 67 | 5f 62 6f 64 28 29 20 6c |bod.c..g|_bod() l|
|000017c0| 6f 61 64 73 20 74 68 65 | 20 66 6c 6f 6f 72 20 70 |oads the| floor p|
|000017d0| 61 74 74 65 72 6e 20 69 | 6e 74 6f 20 73 75 7a 69 |attern i|nto suzi|
|000017e0| 65 2e 0a 58 0a 58 6d 61 | 63 72 6f 73 2e 68 09 63 |e..X.Xma|cros.h.c|
|000017f0| 6f 6e 74 61 69 6e 73 20 | 61 6c 6c 20 74 68 65 20 |ontains |all the |
|00001800| 6d 61 63 72 6f 20 64 65 | 66 69 6e 69 74 69 6f 6e |macro de|finition|
|00001810| 73 2e 20 44 65 66 69 6e | 69 74 65 6c 79 20 74 6f |s. Defin|itely to|
|00001820| 20 62 65 20 6c 6f 6f 6b | 65 64 20 61 74 2e 0a 58 | be look|ed at..X|
|00001830| 72 74 64 2e 68 09 09 68 | 65 61 64 65 72 20 66 69 |rtd.h..h|eader fi|
|00001840| 6c 65 20 63 6f 6e 74 61 | 69 6e 69 6e 67 20 61 6c |le conta|ining al|
|00001850| 6c 20 74 68 65 20 73 74 | 72 75 63 74 75 72 65 20 |l the st|ructure |
|00001860| 64 65 66 69 6e 69 74 69 | 6f 6e 73 2e 0a 58 65 78 |definiti|ons..Xex|
|00001870| 74 65 72 6e 2e 68 09 6b | 65 65 70 73 20 74 72 61 |tern.h.k|eeps tra|
|00001880| 63 6b 20 6f 66 20 61 6c | 6c 20 67 6c 6f 62 61 6c |ck of al|l global|
|00001890| 20 76 61 72 69 61 62 6c | 65 73 20 75 73 65 64 20 | variabl|es used |
|000018a0| 74 68 72 6f 75 67 68 20 | 74 68 65 20 70 72 6f 67 |through |the prog|
|000018b0| 72 61 6d 2e 0a 58 0a 58 | 62 64 61 74 61 2e 69 09 |ram..X.X|bdata.i.|
|000018c0| 09 73 61 6d 70 6c 65 20 | 62 61 6c 6c 20 64 61 74 |.sample |ball dat|
|000018d0| 61 20 66 69 6c 65 2e 0a | 58 0a 58 70 61 74 2e 64 |a file..|X.Xpat.d|
|000018e0| 65 66 20 5c 0a 58 63 68 | 65 63 6b 2e 70 61 74 5c |ef \.Xch|eck.pat\|
|000018f0| 0a 58 73 75 73 69 65 2e | 70 61 74 20 3e 2d 20 20 |.Xsusie.|pat >- |
|00001900| 20 20 73 61 6d 70 6c 65 | 20 70 61 74 74 65 72 6e | sample| pattern|
|00001910| 20 66 69 6c 65 73 2e 20 | 28 73 75 73 69 65 20 69 | files. |(susie i|
|00001920| 73 20 6e 6f 74 20 66 6f | 72 20 74 68 65 20 70 75 |s not fo|r the pu|
|00001930| 72 69 65 6e 74 29 2e 0a | 58 73 68 69 70 2e 70 61 |rient)..|Xship.pa|
|00001940| 74 20 2f 0a 58 0a 45 4e | 44 5f 4f 46 5f 52 45 41 |t /.X.EN|D_OF_REA|
|00001950| 44 4d 45 2e 48 41 4b 0a | 69 66 20 74 65 73 74 20 |DME.HAK.|if test |
|00001960| 31 32 35 39 20 2d 6e 65 | 20 60 77 63 20 2d 63 20 |1259 -ne| `wc -c |
|00001970| 3c 52 45 41 44 4d 45 2e | 48 41 4b 60 3b 20 74 68 |<README.|HAK`; th|
|00001980| 65 6e 0a 20 20 20 20 65 | 63 68 6f 20 73 68 61 72 |en. e|cho shar|
|00001990| 3a 20 5c 22 52 45 41 44 | 4d 45 2e 48 41 4b 5c 22 |: \"READ|ME.HAK\"|
|000019a0| 20 75 6e 70 61 63 6b 65 | 64 20 77 69 74 68 20 77 | unpacke|d with w|
|000019b0| 72 6f 6e 67 20 73 69 7a | 65 21 0a 66 69 0a 23 20 |rong siz|e!.fi.# |
|000019c0| 65 6e 64 20 6f 66 20 6f | 76 65 72 77 72 69 74 69 |end of o|verwriti|
|000019d0| 6e 67 20 63 68 65 63 6b | 0a 66 69 0a 69 66 20 74 |ng check|.fi.if t|
|000019e0| 65 73 74 20 2d 66 20 62 | 64 61 74 61 2e 69 20 2d |est -f b|data.i -|
|000019f0| 61 20 22 24 7b 31 7d 22 | 20 21 3d 20 22 2d 63 22 |a "${1}"| != "-c"|
|00001a00| 20 3b 20 74 68 65 6e 20 | 0a 20 20 65 63 68 6f 20 | ; then |. echo |
|00001a10| 73 68 61 72 3a 20 57 69 | 6c 6c 20 6e 6f 74 20 6f |shar: Wi|ll not o|
|00001a20| 76 65 72 2d 77 72 69 74 | 65 20 65 78 69 73 74 69 |ver-writ|e existi|
|00001a30| 6e 67 20 66 69 6c 65 20 | 5c 22 62 64 61 74 61 2e |ng file |\"bdata.|
|00001a40| 69 5c 22 0a 65 6c 73 65 | 0a 65 63 68 6f 20 73 68 |i\".else|.echo sh|
|00001a50| 61 72 3a 20 45 78 74 72 | 61 63 74 69 6e 67 20 5c |ar: Extr|acting \|
|00001a60| 22 62 64 61 74 61 2e 69 | 5c 22 20 5c 28 32 31 33 |"bdata.i|\" \(213|
|00001a70| 20 63 68 61 72 61 63 74 | 65 72 73 5c 29 0a 73 65 | charact|ers\).se|
|00001a80| 64 20 22 73 2f 5e 58 2f | 2f 22 20 3e 62 64 61 74 |d "s/^X/|/" >bdat|
|00001a90| 61 2e 69 20 3c 3c 27 45 | 4e 44 5f 4f 46 5f 62 64 |a.i <<'E|ND_OF_bd|
|00001aa0| 61 74 61 2e 69 27 0a 58 | 0a 58 2d 33 30 2e 30 20 |ata.i'.X|.X-30.0 |
|00001ab0| 31 30 2e 30 20 34 30 30 | 2e 30 20 35 30 2e 30 20 |10.0 400|.0 50.0 |
|00001ac0| 30 2e 30 20 30 2e 30 20 | 30 2e 30 20 30 2e 39 20 |0.0 0.0 |0.0 0.9 |
|00001ad0| 30 2e 31 0a 58 32 31 30 | 2e 30 20 31 37 35 2e 30 |0.1.X210|.0 175.0|
|00001ae0| 20 34 30 30 2e 30 20 35 | 30 2e 30 20 30 2e 30 20 | 400.0 5|0.0 0.0 |
|00001af0| 30 2e 30 20 30 2e 33 20 | 30 2e 36 20 30 2e 31 0a |0.0 0.3 |0.6 0.1.|
|00001b00| 58 34 30 2e 30 20 31 31 | 30 2e 30 20 34 35 30 2e |X40.0 11|0.0 450.|
|00001b10| 30 20 35 30 2e 30 20 30 | 2e 30 20 30 2e 30 20 30 |0 50.0 0|.0 0.0 0|
|00001b20| 2e 36 20 30 2e 33 20 30 | 2e 31 0a 58 31 34 30 2e |.6 0.3 0|.1.X140.|
|00001b30| 30 20 36 35 2e 30 20 34 | 35 30 2e 30 20 35 30 2e |0 65.0 4|50.0 50.|
|00001b40| 30 20 30 2e 30 20 30 2e | 30 20 30 2e 39 20 30 2e |0 0.0 0.|0 0.9 0.|
|00001b50| 30 20 30 2e 31 0a 58 0a | 58 32 32 30 2e 30 20 37 |0 0.1.X.|X220.0 7|
|00001b60| 30 2e 30 20 31 30 30 2e | 30 20 36 30 2e 30 20 31 |0.0 100.|0 60.0 1|
|00001b70| 2e 34 20 30 2e 39 20 30 | 2e 30 20 30 2e 30 20 30 |.4 0.9 0|.0 0.0 0|
|00001b80| 2e 31 0a 45 4e 44 5f 4f | 46 5f 62 64 61 74 61 2e |.1.END_O|F_bdata.|
|00001b90| 69 0a 69 66 20 74 65 73 | 74 20 32 31 33 20 2d 6e |i.if tes|t 213 -n|
|00001ba0| 65 20 60 77 63 20 2d 63 | 20 3c 62 64 61 74 61 2e |e `wc -c| <bdata.|
|00001bb0| 69 60 3b 20 74 68 65 6e | 0a 20 20 20 20 65 63 68 |i`; then|. ech|
|00001bc0| 6f 20 73 68 61 72 3a 20 | 5c 22 62 64 61 74 61 2e |o shar: |\"bdata.|
|00001bd0| 69 5c 22 20 75 6e 70 61 | 63 6b 65 64 20 77 69 74 |i\" unpa|cked wit|
|00001be0| 68 20 77 72 6f 6e 67 20 | 73 69 7a 65 21 0a 66 69 |h wrong |size!.fi|
|00001bf0| 0a 23 20 65 6e 64 20 6f | 66 20 6f 76 65 72 77 72 |.# end o|f overwr|
|00001c00| 69 74 69 6e 67 20 63 68 | 65 63 6b 0a 66 69 0a 69 |iting ch|eck.fi.i|
|00001c10| 66 20 74 65 73 74 20 2d | 66 20 63 6f 6e 76 2e 63 |f test -|f conv.c|
|00001c20| 20 2d 61 20 22 24 7b 31 | 7d 22 20 21 3d 20 22 2d | -a "${1|}" != "-|
|00001c30| 63 22 20 3b 20 74 68 65 | 6e 20 0a 20 20 65 63 68 |c" ; the|n . ech|
|00001c40| 6f 20 73 68 61 72 3a 20 | 57 69 6c 6c 20 6e 6f 74 |o shar: |Will not|
|00001c50| 20 6f 76 65 72 2d 77 72 | 69 74 65 20 65 78 69 73 | over-wr|ite exis|
|00001c60| 74 69 6e 67 20 66 69 6c | 65 20 5c 22 63 6f 6e 76 |ting fil|e \"conv|
|00001c70| 2e 63 5c 22 0a 65 6c 73 | 65 0a 65 63 68 6f 20 73 |.c\".els|e.echo s|
|00001c80| 68 61 72 3a 20 45 78 74 | 72 61 63 74 69 6e 67 20 |har: Ext|racting |
|00001c90| 5c 22 63 6f 6e 76 2e 63 | 5c 22 20 5c 28 38 32 34 |\"conv.c|\" \(824|
|00001ca0| 20 63 68 61 72 61 63 74 | 65 72 73 5c 29 0a 73 65 | charact|ers\).se|
|00001cb0| 64 20 22 73 2f 5e 58 2f | 2f 22 20 3e 63 6f 6e 76 |d "s/^X/|/" >conv|
|00001cc0| 2e 63 20 3c 3c 27 45 4e | 44 5f 4f 46 5f 63 6f 6e |.c <<'EN|D_OF_con|
|00001cd0| 76 2e 63 27 0a 58 23 69 | 6e 63 6c 75 64 65 20 3c |v.c'.X#i|nclude <|
|00001ce0| 73 74 64 69 6f 2e 68 3e | 0a 58 23 69 6e 63 6c 75 |stdio.h>|.X#inclu|
|00001cf0| 64 65 20 3c 74 61 6d 2e | 68 3e 0a 58 23 69 6e 63 |de <tam.|h>.X#inc|
|00001d00| 6c 75 64 65 20 3c 66 63 | 6e 74 6c 2e 68 3e 0a 58 |lude <fc|ntl.h>.X|
|00001d10| 20 20 0a 58 65 78 74 65 | 72 6e 20 65 72 72 6e 6f | .Xexte|rn errno|
|00001d20| 3b 0a 58 0a 58 6d 61 69 | 6e 28 61 72 67 63 2c 20 |;.X.Xmai|n(argc, |
|00001d30| 61 72 67 76 29 0a 58 69 | 6e 74 20 61 72 67 63 3b |argv).Xi|nt argc;|
|00001d40| 0a 58 63 68 61 72 20 2a | 61 72 67 76 5b 5d 3b 0a |.Xchar *|argv[];.|
|00001d50| 58 0a 58 7b 0a 58 20 20 | 63 68 61 72 20 2a 6d 61 |X.X{.X |char *ma|
|00001d60| 6c 6c 6f 63 28 29 3b 0a | 58 20 20 63 68 61 72 20 |lloc();.|X char |
|00001d70| 2a 63 64 2c 2a 64 3b 0a | 58 20 20 73 68 6f 72 74 |*cd,*d;.|X short|
|00001d80| 20 2a 62 6d 2c 2a 63 3b | 0a 58 20 20 69 6e 74 20 | *bm,*c;|.X int |
|00001d90| 66 64 2c 20 63 6f 6e 74 | 3b 0a 58 20 72 65 67 69 |fd, cont|;.X regi|
|00001da0| 73 74 65 72 20 69 6e 74 | 20 61 2c 62 3b 0a 58 0a |ster int| a,b;.X.|
|00001db0| 58 09 63 6f 6e 74 20 3d | 20 36 30 3b 20 0a 58 2f |X.cont =| 60; .X/|
|00001dc0| 2a 09 69 66 28 28 61 72 | 67 63 20 3d 3d 20 32 29 |*.if((ar|gc == 2)|
|00001dd0| 20 26 26 20 28 61 74 6f | 69 28 61 72 67 76 5b 31 | && (ato|i(argv[1|
|00001de0| 5d 29 20 3e 31 29 20 26 | 26 20 28 61 74 6f 69 28 |]) >1) &|& (atoi(|
|00001df0| 61 72 67 76 5b 31 5d 29 | 20 3c 31 30 30 29 29 0a |argv[1])| <100)).|
|00001e00| 58 09 09 63 6f 6e 74 20 | 3d 20 61 74 6f 69 28 61 |X..cont |= atoi(a|
|00001e10| 72 67 76 5b 31 5d 29 3b | 2a 2f 0a 58 20 0a 58 20 |rgv[1]);|*/.X .X |
|00001e20| 20 20 20 69 66 20 28 28 | 66 64 3d 6f 70 65 6e 28 | if ((|fd=open(|
|00001e30| 61 72 67 76 5b 31 5d 2c | 4f 5f 52 44 4f 4e 4c 59 |argv[1],|O_RDONLY|
|00001e40| 7c 4f 5f 4e 44 45 4c 41 | 59 29 29 3d 3d 30 29 20 ||O_NDELA|Y))==0) |
|00001e50| 7b 0a 58 20 20 20 20 20 | 20 66 70 72 69 6e 74 66 |{.X | fprintf|
|00001e60| 28 22 63 6f 75 6c 64 6e | 27 74 20 6f 70 65 6e 20 |("couldn|'t open |
|00001e70| 25 73 20 66 6f 72 20 72 | 65 61 64 5c 6e 22 2c 20 |%s for r|ead\n", |
|00001e80| 61 72 67 76 5b 31 5d 29 | 3b 0a 58 20 20 20 20 20 |argv[1])|;.X |
|00001e90| 20 65 78 69 74 28 2d 31 | 29 3b 0a 58 20 20 20 20 | exit(-1|);.X |
|00001ea0| 7d 0a 58 20 20 20 20 69 | 66 28 6c 73 65 65 6b 28 |}.X i|f(lseek(|
|00001eb0| 66 64 2c 38 2c 30 29 3c | 30 29 0a 58 20 20 20 20 |fd,8,0)<|0).X |
|00001ec0| 20 20 65 78 69 74 28 2d | 31 29 3b 0a 58 20 20 20 | exit(-|1);.X |
|00001ed0| 20 63 64 3d 6d 61 6c 6c | 6f 63 28 31 33 34 34 30 | cd=mall|oc(13440|
|00001ee0| 30 29 3b 0a 58 20 20 20 | 20 69 66 28 72 65 61 64 |0);.X | if(read|
|00001ef0| 28 66 64 2c 63 64 2c 31 | 33 34 34 30 30 29 21 3d |(fd,cd,1|34400)!=|
|00001f00| 31 33 34 34 30 30 29 0a | 58 20 20 20 20 20 20 65 |134400).|X e|
|00001f10| 78 69 74 28 2d 31 29 3b | 0a 58 20 20 20 20 62 6d |xit(-1);|.X bm|
|00001f20| 3d 6d 61 6c 6c 6f 63 28 | 31 34 39 37 34 29 3b 0a |=malloc(|14974);.|
|00001f30| 58 20 20 20 20 63 3d 62 | 6d 2b 37 34 38 37 3b 0a |X c=b|m+7487;.|
|00001f40| 58 20 20 20 20 66 6f 72 | 28 61 3d 32 38 37 3b 61 |X for|(a=287;a|
|00001f50| 3e 3d 30 3b 61 2d 2d 29 | 20 7b 0a 58 20 20 20 20 |>=0;a--)| {.X |
|00001f60| 20 20 64 3d 61 2a 34 32 | 30 2b 63 64 3b 0a 58 20 | d=a*42|0+cd;.X |
|00001f70| 20 20 20 20 20 66 6f 72 | 28 62 3d 34 31 35 3b 62 | for|(b=415;b|
|00001f80| 3e 3d 30 3b 62 2d 2d 29 | 20 7b 0a 58 20 20 20 20 |>=0;b--)| {.X |
|00001f90| 20 20 20 20 69 66 28 21 | 28 62 26 31 35 29 29 0a | if(!|(b&15)).|
|00001fa0| 58 20 20 20 20 20 20 20 | 20 20 20 63 2d 3d 31 3b |X | c-=1;|
|00001fb0| 0a 58 20 20 20 20 20 20 | 20 20 2a 63 3d 28 2a 63 |.X | *c=(*c|
|00001fc0| 3c 3c 31 29 7c 28 2a 28 | 64 2b 62 29 3e 36 30 29 |<<1)|(*(|d+b)>60)|
|00001fd0| 3b 0a 58 20 20 20 20 20 | 20 7d 0a 58 20 20 20 20 |;.X | }.X |
|00001fe0| 7d 0a 58 20 20 20 20 63 | 64 3d 62 6d 3b 0a 58 20 |}.X c|d=bm;.X |
|00001ff0| 20 20 20 61 20 3d 20 30 | 3b 0a 58 20 20 20 20 77 | a = 0|;.X w|
|00002000| 68 69 6c 65 28 61 2b 2b | 20 21 3d 20 31 34 39 37 |hile(a++| != 1497|
|00002010| 34 29 0a 58 09 20 20 20 | 20 66 70 72 69 6e 74 66 |4).X. | fprintf|
|00002020| 28 73 74 64 6f 75 74 2c | 20 22 25 63 22 2c 20 2a |(stdout,| "%c", *|
|00002030| 63 64 2b 2b 29 3b 0a 58 | 7d 0a 45 4e 44 5f 4f 46 |cd++);.X|}.END_OF|
|00002040| 5f 63 6f 6e 76 2e 63 0a | 69 66 20 74 65 73 74 20 |_conv.c.|if test |
|00002050| 38 32 34 20 2d 6e 65 20 | 60 77 63 20 2d 63 20 3c |824 -ne |`wc -c <|
|00002060| 63 6f 6e 76 2e 63 60 3b | 20 74 68 65 6e 0a 20 20 |conv.c`;| then. |
|00002070| 20 20 65 63 68 6f 20 73 | 68 61 72 3a 20 5c 22 63 | echo s|har: \"c|
|00002080| 6f 6e 76 2e 63 5c 22 20 | 75 6e 70 61 63 6b 65 64 |onv.c\" |unpacked|
|00002090| 20 77 69 74 68 20 77 72 | 6f 6e 67 20 73 69 7a 65 | with wr|ong size|
|000020a0| 21 0a 66 69 0a 23 20 65 | 6e 64 20 6f 66 20 6f 76 |!.fi.# e|nd of ov|
|000020b0| 65 72 77 72 69 74 69 6e | 67 20 63 68 65 63 6b 0a |erwritin|g check.|
|000020c0| 66 69 0a 69 66 20 74 65 | 73 74 20 2d 66 20 65 78 |fi.if te|st -f ex|
|000020d0| 74 65 72 6e 2e 68 20 2d | 61 20 22 24 7b 31 7d 22 |tern.h -|a "${1}"|
|000020e0| 20 21 3d 20 22 2d 63 22 | 20 3b 20 74 68 65 6e 20 | != "-c"| ; then |
|000020f0| 0a 20 20 65 63 68 6f 20 | 73 68 61 72 3a 20 57 69 |. echo |shar: Wi|
|00002100| 6c 6c 20 6e 6f 74 20 6f | 76 65 72 2d 77 72 69 74 |ll not o|ver-writ|
|00002110| 65 20 65 78 69 73 74 69 | 6e 67 20 66 69 6c 65 20 |e existi|ng file |
|00002120| 5c 22 65 78 74 65 72 6e | 2e 68 5c 22 0a 65 6c 73 |\"extern|.h\".els|
|00002130| 65 0a 65 63 68 6f 20 73 | 68 61 72 3a 20 45 78 74 |e.echo s|har: Ext|
|00002140| 72 61 63 74 69 6e 67 20 | 5c 22 65 78 74 65 72 6e |racting |\"extern|
|00002150| 2e 68 5c 22 20 5c 28 31 | 33 30 20 63 68 61 72 61 |.h\" \(1|30 chara|
|00002160| 63 74 65 72 73 5c 29 0a | 73 65 64 20 22 73 2f 5e |cters\).|sed "s/^|
|00002170| 58 2f 2f 22 20 3e 65 78 | 74 65 72 6e 2e 68 20 3c |X//" >ex|tern.h <|
|00002180| 3c 27 45 4e 44 5f 4f 46 | 5f 65 78 74 65 72 6e 2e |<'END_OF|_extern.|
|00002190| 68 27 0a 58 65 78 74 65 | 72 6e 20 64 6f 75 62 6c |h'.Xexte|rn doubl|
|000021a0| 65 20 73 75 7a 69 65 5b | 33 30 30 5d 5b 33 30 30 |e suzie[|300][300|
|000021b0| 5d 2c 73 61 6d 3b 0a 58 | 65 78 74 65 72 6e 20 73 |],sam;.X|extern s|
|000021c0| 74 72 75 63 74 20 62 61 | 6c 6c 20 2a 62 6c 5b 5d |truct ba|ll *bl[]|
|000021d0| 3b 0a 58 65 78 74 65 72 | 6e 20 73 74 72 75 63 74 |;.Xexter|n struct|
|000021e0| 20 73 70 68 65 72 65 20 | 6c 73 3b 0a 58 65 78 74 | sphere |ls;.Xext|
|000021f0| 65 72 6e 20 69 6e 74 20 | 6c 65 76 65 6c 2c 6e 6f |ern int |level,no|
|00002200| 62 3b 0a 58 65 78 74 65 | 72 6e 20 69 6e 74 20 78 |b;.Xexte|rn int x|
|00002210| 73 75 65 2c 79 73 75 65 | 3b 0a 45 4e 44 5f 4f 46 |sue,ysue|;.END_OF|
|00002220| 5f 65 78 74 65 72 6e 2e | 68 0a 69 66 20 74 65 73 |_extern.|h.if tes|
|00002230| 74 20 31 33 30 20 2d 6e | 65 20 60 77 63 20 2d 63 |t 130 -n|e `wc -c|
|00002240| 20 3c 65 78 74 65 72 6e | 2e 68 60 3b 20 74 68 65 | <extern|.h`; the|
|00002250| 6e 0a 20 20 20 20 65 63 | 68 6f 20 73 68 61 72 3a |n. ec|ho shar:|
|00002260| 20 5c 22 65 78 74 65 72 | 6e 2e 68 5c 22 20 75 6e | \"exter|n.h\" un|
|00002270| 70 61 63 6b 65 64 20 77 | 69 74 68 20 77 72 6f 6e |packed w|ith wron|
|00002280| 67 20 73 69 7a 65 21 0a | 66 69 0a 23 20 65 6e 64 |g size!.|fi.# end|
|00002290| 20 6f 66 20 6f 76 65 72 | 77 72 69 74 69 6e 67 20 | of over|writing |
|000022a0| 63 68 65 63 6b 0a 66 69 | 0a 69 66 20 74 65 73 74 |check.fi|.if test|
|000022b0| 20 2d 66 20 66 69 6e 64 | 2e 63 20 2d 61 20 22 24 | -f find|.c -a "$|
|000022c0| 7b 31 7d 22 20 21 3d 20 | 22 2d 63 22 20 3b 20 74 |{1}" != |"-c" ; t|
|000022d0| 68 65 6e 20 0a 20 20 65 | 63 68 6f 20 73 68 61 72 |hen . e|cho shar|
|000022e0| 3a 20 57 69 6c 6c 20 6e | 6f 74 20 6f 76 65 72 2d |: Will n|ot over-|
|000022f0| 77 72 69 74 65 20 65 78 | 69 73 74 69 6e 67 20 66 |write ex|isting f|
|00002300| 69 6c 65 20 5c 22 66 69 | 6e 64 2e 63 5c 22 0a 65 |ile \"fi|nd.c\".e|
|00002310| 6c 73 65 0a 65 63 68 6f | 20 73 68 61 72 3a 20 45 |lse.echo| shar: E|
|00002320| 78 74 72 61 63 74 69 6e | 67 20 5c 22 66 69 6e 64 |xtractin|g \"find|
|00002330| 2e 63 5c 22 20 5c 28 31 | 39 34 32 20 63 68 61 72 |.c\" \(1|942 char|
|00002340| 61 63 74 65 72 73 5c 29 | 0a 73 65 64 20 22 73 2f |acters\)|.sed "s/|
|00002350| 5e 58 2f 2f 22 20 3e 66 | 69 6e 64 2e 63 20 3c 3c |^X//" >f|ind.c <<|
|00002360| 27 45 4e 44 5f 4f 46 5f | 66 69 6e 64 2e 63 27 0a |'END_OF_|find.c'.|
|00002370| 58 23 69 6e 63 6c 75 64 | 65 20 3c 6d 61 74 68 2e |X#includ|e <math.|
|00002380| 68 3e 0a 58 23 69 6e 63 | 6c 75 64 65 20 22 72 74 |h>.X#inc|lude "rt|
|00002390| 64 2e 68 22 0a 58 23 69 | 6e 63 6c 75 64 65 20 22 |d.h".X#i|nclude "|
|000023a0| 65 78 74 65 72 6e 2e 68 | 22 0a 58 23 69 6e 63 6c |extern.h|".X#incl|
|000023b0| 75 64 65 20 22 6d 61 63 | 72 6f 73 2e 68 22 0a 58 |ude "mac|ros.h".X|
|000023c0| 0a 58 0a 58 64 6f 75 62 | 6c 65 20 20 66 69 6e 64 |.X.Xdoub|le find|
|000023d0| 6f 20 28 6d 2c 20 73 29 | 20 2f 2a 20 66 69 6e 64 |o (m, s)| /* find|
|000023e0| 73 20 77 68 65 72 65 20 | 61 20 72 61 79 20 69 6e |s where |a ray in|
|000023f0| 73 69 64 65 20 74 68 65 | 20 62 61 6c 6c 20 65 78 |side the| ball ex|
|00002400| 69 74 73 2e 20 2a 2f 0a | 58 73 74 72 75 63 74 20 |its. */.|Xstruct |
|00002410| 6d 61 74 20 2a 6d 3b 0a | 58 73 74 72 75 63 74 20 |mat *m;.|Xstruct |
|00002420| 73 70 68 65 72 65 20 20 | 2a 73 3b 0a 58 7b 0a 58 |sphere |*s;.X{.X|
|00002430| 2f 2a 20 66 6f 6f 70 73 | 20 69 64 20 74 68 65 20 |/* foops| id the |
|00002440| 72 6f 74 61 74 65 64 20 | 70 6f 73 69 74 69 6f 6e |rotated |position|
|00002450| 20 76 65 63 74 6f 72 2e | 20 2a 2f 0a 58 20 20 20 | vector.| */.X |
|00002460| 20 73 74 72 75 63 74 20 | 76 65 63 74 6f 72 20 20 | struct |vector |
|00002470| 20 66 6f 6f 70 73 3b 0a | 58 20 20 20 20 64 6f 75 | foops;.|X dou|
|00002480| 62 6c 65 20 20 74 3b 0a | 58 20 20 20 20 4d 54 56 |ble t;.|X MTV|
|00002490| 20 28 66 6f 6f 70 73 2c | 20 28 2a 6d 29 2c 20 73 | (foops,| (*m), s|
|000024a0| 20 2d 3e 20 63 65 6e 74 | 29 3b 0a 58 2f 2a 20 73 | -> cent|);.X/* s|
|000024b0| 65 65 20 69 66 20 69 74 | 20 68 69 74 73 20 74 68 |ee if it| hits th|
|000024c0| 65 20 62 61 6c 6c 20 28 | 69 74 20 62 65 74 74 65 |e ball (|it bette|
|000024d0| 72 29 2a 2f 0a 58 20 20 | 20 20 74 20 3d 20 73 20 |r)*/.X | t = s |
|000024e0| 2d 3e 20 72 61 64 20 2a | 20 73 20 2d 3e 20 72 61 |-> rad *| s -> ra|
|000024f0| 64 20 2d 20 66 6f 6f 70 | 73 2e 79 20 2a 20 66 6f |d - foop|s.y * fo|
|00002500| 6f 70 73 2e 79 20 2d 20 | 66 6f 6f 70 73 2e 7a 20 |ops.y - |foops.z |
|00002510| 2a 20 66 6f 6f 70 73 2e | 7a 3b 0a 58 20 20 20 20 |* foops.|z;.X |
|00002520| 69 66 20 28 74 20 3e 20 | 30 29 0a 58 09 74 20 3d |if (t > |0).X.t =|
|00002530| 20 66 6f 6f 70 73 2e 78 | 20 2b 20 73 71 72 74 20 | foops.x| + sqrt |
|00002540| 28 74 29 3b 0a 58 20 20 | 20 20 65 6c 73 65 0a 58 |(t);.X | else.X|
|00002550| 09 74 20 3d 20 30 3b 0a | 58 2f 2a 20 72 65 74 75 |.t = 0;.|X/* retu|
|00002560| 72 6e 20 68 6f 77 20 66 | 61 72 20 61 6c 6f 6e 67 |rn how f|ar along|
|00002570| 20 74 68 65 20 72 61 79 | 20 79 6f 75 20 77 65 72 | the ray| you wer|
|00002580| 65 20 77 68 65 6e 20 79 | 6f 75 20 68 69 74 20 2a |e when y|ou hit *|
|00002590| 2f 0a 58 20 20 20 20 72 | 65 74 75 72 6e 20 28 74 |/.X r|eturn (t|
|000025a0| 29 3b 0a 58 7d 0a 58 0a | 58 64 6f 75 62 6c 65 20 |);.X}.X.|Xdouble |
|000025b0| 20 66 69 6e 64 20 28 6d | 2c 20 73 29 2f 2a 20 66 | find (m|, s)/* f|
|000025c0| 69 6e 64 73 20 77 68 65 | 74 68 65 72 20 61 20 72 |inds whe|ther a r|
|000025d0| 61 79 20 68 69 74 73 20 | 61 20 62 61 6c 6c 2a 2f |ay hits |a ball*/|
|000025e0| 0a 58 73 74 72 75 63 74 | 20 6d 61 74 20 2a 6d 3b |.Xstruct| mat *m;|
|000025f0| 0a 58 73 74 72 75 63 74 | 20 73 70 68 65 72 65 20 |.Xstruct| sphere |
|00002600| 20 2a 73 3b 0a 58 7b 0a | 58 20 20 20 20 73 74 72 | *s;.X{.|X str|
|00002610| 75 63 74 20 76 65 63 74 | 6f 72 20 20 20 66 6f 6f |uct vect|or foo|
|00002620| 70 73 3b 0a 58 20 20 20 | 20 64 6f 75 62 6c 65 20 |ps;.X | double |
|00002630| 20 74 3b 0a 58 20 20 20 | 20 4d 54 56 20 28 66 6f | t;.X | MTV (fo|
|00002640| 6f 70 73 2c 20 28 2a 6d | 29 2c 20 73 20 2d 3e 20 |ops, (*m|), s -> |
|00002650| 63 65 6e 74 29 3b 0a 58 | 20 20 20 20 74 20 3d 20 |cent);.X| t = |
|00002660| 73 20 2d 3e 20 72 61 64 | 20 2a 20 73 20 2d 3e 20 |s -> rad| * s -> |
|00002670| 72 61 64 20 2d 20 66 6f | 6f 70 73 2e 79 20 2a 20 |rad - fo|ops.y * |
|00002680| 66 6f 6f 70 73 2e 79 20 | 2d 20 66 6f 6f 70 73 2e |foops.y |- foops.|
|00002690| 7a 20 2a 20 66 6f 6f 70 | 73 2e 7a 3b 0a 58 20 20 |z * foop|s.z;.X |
|000026a0| 20 20 69 66 20 28 74 20 | 3e 20 30 29 0a 58 09 74 | if (t |> 0).X.t|
|000026b0| 20 3d 20 66 6f 6f 70 73 | 2e 78 20 2d 20 73 71 72 | = foops|.x - sqr|
|000026c0| 74 20 28 74 29 3b 0a 58 | 20 20 20 20 65 6c 73 65 |t (t);.X| else|
|000026d0| 0a 58 09 74 20 3d 20 30 | 3b 0a 58 20 20 20 20 72 |.X.t = 0|;.X r|
|000026e0| 65 74 75 72 6e 20 28 74 | 29 3b 0a 58 7d 0a 58 0a |eturn (t|);.X}.X.|
|000026f0| 58 64 6f 75 62 6c 65 20 | 20 66 69 6e 64 73 20 28 |Xdouble | finds (|
|00002700| 6d 2c 20 73 29 2f 2a 20 | 66 69 6e 64 73 20 69 66 |m, s)/* |finds if|
|00002710| 20 61 20 62 61 6c 6c 20 | 69 73 20 62 65 74 77 65 | a ball |is betwe|
|00002720| 65 6e 20 61 20 70 6f 69 | 6e 74 20 61 6e 64 20 61 |en a poi|nt and a|
|00002730| 20 0a 58 09 09 09 6c 69 | 67 68 74 73 6f 75 72 63 | .X...li|ghtsourc|
|00002740| 65 2e 20 52 65 74 75 72 | 6e 73 20 68 6f 77 20 6f |e. Retur|ns how o|
|00002750| 62 73 63 75 72 69 6e 67 | 20 74 68 65 20 62 61 6c |bscuring| the bal|
|00002760| 6c 20 69 73 20 2a 2f 0a | 58 73 74 72 75 63 74 20 |l is */.|Xstruct |
|00002770| 6d 61 74 20 2a 6d 3b 0a | 58 73 74 72 75 63 74 20 |mat *m;.|Xstruct |
|00002780| 73 70 68 65 72 65 20 20 | 2a 73 3b 0a 58 7b 0a 58 |sphere |*s;.X{.X|
|00002790| 20 20 20 20 73 74 72 75 | 63 74 20 76 65 63 74 6f | stru|ct vecto|
|000027a0| 72 20 20 20 66 6f 6f 70 | 73 3b 0a 58 20 20 20 20 |r foop|s;.X |
|000027b0| 64 6f 75 62 6c 65 20 20 | 74 3b 0a 58 20 20 20 20 |double |t;.X |
|000027c0| 4d 54 56 20 28 66 6f 6f | 70 73 2c 20 28 2a 6d 29 |MTV (foo|ps, (*m)|
|000027d0| 2c 20 73 20 2d 3e 20 63 | 65 6e 74 29 3b 0a 58 20 |, s -> c|ent);.X |
|000027e0| 20 20 20 74 20 3d 20 73 | 20 2d 3e 20 72 61 64 20 | t = s| -> rad |
|000027f0| 2d 20 73 71 72 74 20 28 | 66 6f 6f 70 73 2e 79 20 |- sqrt (|foops.y |
|00002800| 2a 20 66 6f 6f 70 73 2e | 79 20 2b 20 66 6f 6f 70 |* foops.|y + foop|
|00002810| 73 2e 7a 20 2a 20 66 6f | 6f 70 73 2e 7a 29 3b 0a |s.z * fo|ops.z);.|
|00002820| 58 20 20 20 20 69 66 20 | 28 74 20 3e 20 30 29 0a |X if |(t > 0).|
|00002830| 58 09 74 20 3d 20 74 20 | 2f 20 66 6f 6f 70 73 2e |X.t = t |/ foops.|
|00002840| 78 3b 0a 58 20 20 20 20 | 65 6c 73 65 0a 58 09 74 |x;.X |else.X.t|
|00002850| 20 3d 20 30 3b 0a 58 20 | 20 20 20 72 65 74 75 72 | = 0;.X | retur|
|00002860| 6e 20 28 74 29 3b 0a 58 | 7d 0a 58 0a 58 0a 58 0a |n (t);.X|}.X.X.X.|
|00002870| 58 0a 58 64 6f 75 62 6c | 65 20 20 73 68 61 64 6f |X.Xdoubl|e shado|
|00002880| 77 20 28 70 29 2f 2a 20 | 66 69 6e 64 73 20 69 66 |w (p)/* |finds if|
|00002890| 20 61 20 70 6f 69 6e 74 | 20 69 73 20 69 6e 20 61 | a point| is in a|
|000028a0| 20 73 68 61 64 6f 77 2c | 20 6f 72 20 69 66 20 69 | shadow,| or if i|
|000028b0| 74 20 69 73 20 6f 6e 20 | 65 64 67 65 20 2a 2f 0a |t is on |edge */.|
|000028c0| 58 73 74 72 75 63 74 20 | 76 65 63 74 6f 72 20 20 |Xstruct |vector |
|000028d0| 2a 70 3b 0a 58 7b 0a 58 | 20 20 20 20 73 74 72 75 |*p;.X{.X| stru|
|000028e0| 63 74 20 6d 61 74 20 20 | 74 72 61 6e 73 3b 0a 58 |ct mat |trans;.X|
|000028f0| 20 20 20 20 73 74 72 75 | 63 74 20 73 70 68 65 72 | stru|ct spher|
|00002900| 65 20 20 20 73 73 3b 0a | 58 20 20 20 20 73 74 72 |e ss;.|X str|
|00002910| 75 63 74 20 76 65 63 74 | 6f 72 20 20 20 64 3b 0a |uct vect|or d;.|
|00002920| 58 20 20 20 20 69 6e 74 | 20 20 20 20 20 63 2c 0a |X int| c,.|
|00002930| 58 20 20 20 20 20 20 20 | 20 20 20 20 20 69 3b 0a |X | i;.|
|00002940| 58 20 20 20 20 64 6f 75 | 62 6c 65 20 20 6c 2c 0a |X dou|ble l,.|
|00002950| 58 20 20 20 20 20 20 20 | 20 20 20 20 20 6b 2c 0a |X | k,.|
|00002960| 58 20 20 20 20 20 20 20 | 20 20 20 20 20 78 2c 0a |X | x,.|
|00002970| 58 20 20 20 20 20 20 20 | 20 20 20 20 20 79 2c 0a |X | y,.|
|00002980| 58 20 20 20 20 20 20 20 | 20 20 20 20 20 7a 2c 0a |X | z,.|
|00002990| 58 20 20 20 20 20 20 20 | 20 20 20 20 20 66 69 6e |X | fin|
|000029a0| 64 73 20 28 29 3b 0a 58 | 20 20 20 20 6c 20 3d 20 |ds ();.X| l = |
|000029b0| 30 2e 30 3b 0a 58 20 20 | 20 20 63 20 3d 20 2d 31 |0.0;.X | c = -1|
|000029c0| 3b 0a 58 20 20 20 20 53 | 56 20 28 64 2c 20 6c 73 |;.X S|V (d, ls|
|000029d0| 2e 63 65 6e 74 2c 20 28 | 2a 70 29 29 3b 0a 58 20 |.cent, (|*p));.X |
|000029e0| 20 20 20 64 2e 6c 20 3d | 20 4c 45 4e 20 28 64 29 | d.l =| LEN (d)|
|000029f0| 3b 0a 58 20 20 20 20 64 | 2e 78 7a 6c 20 3d 20 58 |;.X d|.xzl = X|
|00002a00| 5a 4c 20 28 64 29 3b 0a | 58 20 20 20 20 6d 74 20 |ZL (d);.|X mt |
|00002a10| 28 26 28 64 29 2c 20 26 | 74 72 61 6e 73 29 3b 0a |(&(d), &|trans);.|
|00002a20| 58 0a 58 20 20 20 20 66 | 6f 72 20 28 69 20 3d 20 |X.X f|or (i = |
|00002a30| 30 3b 20 69 20 3c 20 6e | 6f 62 3b 20 69 2b 2b 29 |0; i < n|ob; i++)|
|00002a40| 20 7b 0a 58 09 73 73 2e | 72 61 64 20 3d 20 62 6c | {.X.ss.|rad = bl|
|00002a50| 5b 69 5d 20 2d 3e 20 73 | 2e 72 61 64 3b 0a 58 09 |[i] -> s|.rad;.X.|
|00002a60| 53 56 20 28 73 73 2e 63 | 65 6e 74 2c 20 62 6c 5b |SV (ss.c|ent, bl[|
|00002a70| 69 5d 20 2d 3e 20 73 2e | 63 65 6e 74 2c 20 28 2a |i] -> s.|cent, (*|
|00002a80| 70 29 29 3b 0a 58 09 69 | 66 20 28 28 6b 20 3d 20 |p));.X.i|f ((k = |
|00002a90| 66 69 6e 64 73 20 28 26 | 74 72 61 6e 73 2c 20 26 |finds (&|trans, &|
|00002aa0| 73 73 29 29 20 3e 20 6c | 29 20 7b 0a 58 09 20 20 |ss)) > l|) {.X. |
|00002ab0| 20 20 63 20 3d 20 69 3b | 0a 58 09 20 20 20 20 6c | c = i;|.X. l|
|00002ac0| 20 3d 20 6b 3b 0a 58 09 | 7d 0a 58 20 20 20 20 7d | = k;.X.|}.X }|
|00002ad0| 0a 58 20 20 20 20 69 66 | 20 28 63 20 3d 3d 20 2d |.X if| (c == -|
|00002ae0| 31 29 0a 58 09 6b 20 3d | 20 32 30 30 2e 30 3b 0a |1).X.k =| 200.0;.|
|00002af0| 58 20 20 20 20 65 6c 73 | 65 20 7b 0a 58 09 6b 20 |X els|e {.X.k |
|00002b00| 3d 20 31 2e 30 20 2d 20 | 6c 20 2f 20 28 28 6c 73 |= 1.0 - |l / ((ls|
|00002b10| 2e 72 61 64 29 20 2f 20 | 28 64 2e 6c 29 29 3b 0a |.rad) / |(d.l));.|
|00002b20| 58 09 69 66 20 28 6b 20 | 3c 20 30 2e 30 29 0a 58 |X.if (k |< 0.0).X|
|00002b30| 09 20 20 20 20 6b 20 3d | 20 30 2e 30 3b 0a 58 09 |. k =| 0.0;.X.|
|00002b40| 6b 20 2a 3d 20 32 30 30 | 2e 30 3b 0a 58 20 20 20 |k *= 200|.0;.X |
|00002b50| 20 7d 0a 58 20 20 20 20 | 72 65 74 75 72 6e 20 28 | }.X |return (|
|00002b60| 6b 29 3b 0a 58 7d 0a 45 | 4e 44 5f 4f 46 5f 66 69 |k);.X}.E|ND_OF_fi|
|00002b70| 6e 64 2e 63 0a 69 66 20 | 74 65 73 74 20 31 39 34 |nd.c.if |test 194|
|00002b80| 32 20 2d 6e 65 20 60 77 | 63 20 2d 63 20 3c 66 69 |2 -ne `w|c -c <fi|
|00002b90| 6e 64 2e 63 60 3b 20 74 | 68 65 6e 0a 20 20 20 20 |nd.c`; t|hen. |
|00002ba0| 65 63 68 6f 20 73 68 61 | 72 3a 20 5c 22 66 69 6e |echo sha|r: \"fin|
|00002bb0| 64 2e 63 5c 22 20 75 6e | 70 61 63 6b 65 64 20 77 |d.c\" un|packed w|
|00002bc0| 69 74 68 20 77 72 6f 6e | 67 20 73 69 7a 65 21 0a |ith wron|g size!.|
|00002bd0| 66 69 0a 23 20 65 6e 64 | 20 6f 66 20 6f 76 65 72 |fi.# end| of over|
|00002be0| 77 72 69 74 69 6e 67 20 | 63 68 65 63 6b 0a 66 69 |writing |check.fi|
|00002bf0| 0a 69 66 20 74 65 73 74 | 20 2d 66 20 67 5f 62 61 |.if test| -f g_ba|
|00002c00| 6c 2e 63 20 2d 61 20 22 | 24 7b 31 7d 22 20 21 3d |l.c -a "|${1}" !=|
|00002c10| 20 22 2d 63 22 20 3b 20 | 74 68 65 6e 20 0a 20 20 | "-c" ; |then . |
|00002c20| 65 63 68 6f 20 73 68 61 | 72 3a 20 57 69 6c 6c 20 |echo sha|r: Will |
|00002c30| 6e 6f 74 20 6f 76 65 72 | 2d 77 72 69 74 65 20 65 |not over|-write e|
|00002c40| 78 69 73 74 69 6e 67 20 | 66 69 6c 65 20 5c 22 67 |xisting |file \"g|
|00002c50| 5f 62 61 6c 2e 63 5c 22 | 0a 65 6c 73 65 0a 65 63 |_bal.c\"|.else.ec|
|00002c60| 68 6f 20 73 68 61 72 3a | 20 45 78 74 72 61 63 74 |ho shar:| Extract|
|00002c70| 69 6e 67 20 5c 22 67 5f | 62 61 6c 2e 63 5c 22 20 |ing \"g_|bal.c\" |
|00002c80| 5c 28 36 35 32 20 63 68 | 61 72 61 63 74 65 72 73 |\(652 ch|aracters|
|00002c90| 5c 29 0a 73 65 64 20 22 | 73 2f 5e 58 2f 2f 22 20 |\).sed "|s/^X//" |
|00002ca0| 3e 67 5f 62 61 6c 2e 63 | 20 3c 3c 27 45 4e 44 5f |>g_bal.c| <<'END_|
|00002cb0| 4f 46 5f 67 5f 62 61 6c | 2e 63 27 0a 58 23 69 6e |OF_g_bal|.c'.X#in|
|00002cc0| 63 6c 75 64 65 20 3c 73 | 74 64 69 6f 2e 68 3e 0a |clude <s|tdio.h>.|
|00002cd0| 58 23 69 6e 63 6c 75 64 | 65 20 22 72 74 64 2e 68 |X#includ|e "rtd.h|
|00002ce0| 22 0a 58 23 69 6e 63 6c | 75 64 65 20 22 65 78 74 |".X#incl|ude "ext|
|00002cf0| 65 72 6e 2e 68 22 0a 58 | 67 5f 62 61 6c 20 28 64 |ern.h".X|g_bal (d|
|00002d00| 66 29 0a 58 46 49 4c 45 | 20 2a 20 64 66 3b 0a 58 |f).XFILE| * df;.X|
|00002d10| 7b 0a 58 20 20 20 20 69 | 6e 74 20 20 20 20 20 69 |{.X i|nt i|
|00002d20| 3b 0a 58 20 20 20 20 64 | 6f 75 62 6c 65 20 20 78 |;.X d|ouble x|
|00002d30| 2c 0a 58 20 20 20 20 20 | 20 20 20 20 20 20 20 79 |,.X | y|
|00002d40| 2c 0a 58 20 20 20 20 20 | 20 20 20 20 20 20 20 7a |,.X | z|
|00002d50| 2c 0a 58 20 20 20 20 20 | 20 20 20 20 20 20 20 72 |,.X | r|
|00002d60| 2c 0a 58 20 20 20 20 20 | 20 20 20 20 20 20 20 69 |,.X | i|
|00002d70| 6f 72 2c 0a 58 20 20 20 | 20 20 20 20 20 20 20 20 |or,.X | |
|00002d80| 20 72 66 72 2c 0a 58 20 | 20 20 20 20 20 20 20 20 | rfr,.X | |
|00002d90| 20 20 20 72 66 6c 2c 0a | 58 20 20 20 20 20 20 20 | rfl,.|X |
|00002da0| 20 20 20 20 20 64 69 66 | 2c 0a 58 20 20 20 20 20 | dif|,.X |
|00002db0| 20 20 20 20 20 20 20 61 | 6d 62 3b 0a 58 20 20 20 | a|mb;.X |
|00002dc0| 20 66 6f 72 20 28 69 20 | 3d 20 30 3b 0a 58 09 20 | for (i |= 0;.X. |
|00002dd0| 20 20 20 66 73 63 61 6e | 66 20 28 64 66 2c 20 22 | fscan|f (df, "|
|00002de0| 25 46 20 25 46 20 25 46 | 20 25 46 20 25 46 20 25 |%F %F %F| %F %F %|
|00002df0| 46 20 25 46 20 25 46 20 | 25 46 22 2c 0a 58 09 09 |F %F %F |%F",.X..|
|00002e00| 26 78 2c 20 26 79 2c 20 | 26 7a 2c 20 26 72 2c 20 |&x, &y, |&z, &r, |
|00002e10| 26 69 6f 72 2c 20 26 72 | 66 72 2c 20 26 72 66 6c |&ior, &r|fr, &rfl|
|00002e20| 2c 20 26 64 69 66 2c 20 | 26 61 6d 62 29 20 21 3d |, &dif, |&amb) !=|
|00002e30| 20 45 4f 46 3b 0a 58 09 | 20 20 20 20 69 2b 2b 29 | EOF;.X.| i++)|
|00002e40| 20 7b 0a 58 09 62 6c 5b | 69 5d 20 3d 20 28 73 74 | {.X.bl[|i] = (st|
|00002e50| 72 75 63 74 20 62 61 6c | 6c 20 20 20 2a 29 20 6d |ruct bal|l *) m|
|00002e60| 61 6c 6c 6f 63 20 28 73 | 69 7a 65 6f 66 20 28 73 |alloc (s|izeof (s|
|00002e70| 74 72 75 63 74 20 62 61 | 6c 6c 29 29 3b 0a 58 09 |truct ba|ll));.X.|
|00002e80| 62 6c 5b 69 5d 20 2d 3e | 20 73 2e 63 65 6e 74 2e |bl[i] ->| s.cent.|
|00002e90| 78 20 3d 20 78 3b 0a 58 | 09 62 6c 5b 69 5d 20 2d |x = x;.X|.bl[i] -|
|00002ea0| 3e 20 73 2e 63 65 6e 74 | 2e 79 20 3d 20 79 3b 0a |> s.cent|.y = y;.|
|00002eb0| 58 09 62 6c 5b 69 5d 20 | 2d 3e 20 73 2e 63 65 6e |X.bl[i] |-> s.cen|
|00002ec0| 74 2e 7a 20 3d 20 7a 3b | 0a 58 09 62 6c 5b 69 5d |t.z = z;|.X.bl[i]|
|00002ed0| 20 2d 3e 20 73 2e 72 61 | 64 20 3d 20 72 3b 0a 58 | -> s.ra|d = r;.X|
|00002ee0| 09 62 6c 5b 69 5d 20 2d | 3e 20 69 6f 72 20 3d 20 |.bl[i] -|> ior = |
|00002ef0| 69 6f 72 3b 0a 58 09 62 | 6c 5b 69 5d 20 2d 3e 20 |ior;.X.b|l[i] -> |
|00002f00| 72 66 72 20 3d 20 72 66 | 72 3b 0a 58 09 62 6c 5b |rfr = rf|r;.X.bl[|
|00002f10| 69 5d 20 2d 3e 20 72 66 | 6c 20 3d 20 72 66 6c 3b |i] -> rf|l = rfl;|
|00002f20| 0a 58 09 62 6c 5b 69 5d | 20 2d 3e 20 64 69 66 20 |.X.bl[i]| -> dif |
|00002f30| 3d 20 64 69 66 3b 0a 58 | 09 62 6c 5b 69 5d 20 2d |= dif;.X|.bl[i] -|
|00002f40| 3e 20 61 6d 62 20 3d 20 | 61 6d 62 3b 0a 58 20 20 |> amb = |amb;.X |
|00002f50| 20 20 7d 0a 58 20 20 20 | 20 72 65 74 75 72 6e 20 | }.X | return |
|00002f60| 28 69 29 3b 0a 58 7d 0a | 58 0a 45 4e 44 5f 4f 46 |(i);.X}.|X.END_OF|
|00002f70| 5f 67 5f 62 61 6c 2e 63 | 0a 69 66 20 74 65 73 74 |_g_bal.c|.if test|
|00002f80| 20 36 35 32 20 2d 6e 65 | 20 60 77 63 20 2d 63 20 | 652 -ne| `wc -c |
|00002f90| 3c 67 5f 62 61 6c 2e 63 | 60 3b 20 74 68 65 6e 0a |<g_bal.c|`; then.|
|00002fa0| 20 20 20 20 65 63 68 6f | 20 73 68 61 72 3a 20 5c | echo| shar: \|
|00002fb0| 22 67 5f 62 61 6c 2e 63 | 5c 22 20 75 6e 70 61 63 |"g_bal.c|\" unpac|
|00002fc0| 6b 65 64 20 77 69 74 68 | 20 77 72 6f 6e 67 20 73 |ked with| wrong s|
|00002fd0| 69 7a 65 21 0a 66 69 0a | 23 20 65 6e 64 20 6f 66 |ize!.fi.|# end of|
|00002fe0| 20 6f 76 65 72 77 72 69 | 74 69 6e 67 20 63 68 65 | overwri|ting che|
|00002ff0| 63 6b 0a 66 69 0a 69 66 | 20 74 65 73 74 20 2d 66 |ck.fi.if| test -f|
|00003000| 20 67 5f 62 6f 64 2e 63 | 20 2d 61 20 22 24 7b 31 | g_bod.c| -a "${1|
|00003010| 7d 22 20 21 3d 20 22 2d | 63 22 20 3b 20 74 68 65 |}" != "-|c" ; the|
|00003020| 6e 20 0a 20 20 65 63 68 | 6f 20 73 68 61 72 3a 20 |n . ech|o shar: |
|00003030| 57 69 6c 6c 20 6e 6f 74 | 20 6f 76 65 72 2d 77 72 |Will not| over-wr|
|00003040| 69 74 65 20 65 78 69 73 | 74 69 6e 67 20 66 69 6c |ite exis|ting fil|
|00003050| 65 20 5c 22 67 5f 62 6f | 64 2e 63 5c 22 0a 65 6c |e \"g_bo|d.c\".el|
|00003060| 73 65 0a 65 63 68 6f 20 | 73 68 61 72 3a 20 45 78 |se.echo |shar: Ex|
|00003070| 74 72 61 63 74 69 6e 67 | 20 5c 22 67 5f 62 6f 64 |tracting| \"g_bod|
|00003080| 2e 63 5c 22 20 5c 28 35 | 39 35 20 63 68 61 72 61 |.c\" \(5|95 chara|
|00003090| 63 74 65 72 73 5c 29 0a | 73 65 64 20 22 73 2f 5e |cters\).|sed "s/^|
|000030a0| 58 2f 2f 22 20 3e 67 5f | 62 6f 64 2e 63 20 3c 3c |X//" >g_|bod.c <<|
|000030b0| 27 45 4e 44 5f 4f 46 5f | 67 5f 62 6f 64 2e 63 27 |'END_OF_|g_bod.c'|
|000030c0| 0a 58 23 69 6e 63 6c 75 | 64 65 20 3c 73 74 64 69 |.X#inclu|de <stdi|
|000030d0| 6f 2e 68 3e 0a 58 23 69 | 6e 63 6c 75 64 65 20 3c |o.h>.X#i|nclude <|
|000030e0| 6d 61 74 68 2e 68 3e 0a | 58 23 69 6e 63 6c 75 64 |math.h>.|X#includ|
|000030f0| 65 20 22 65 78 74 65 72 | 6e 2e 68 22 0a 58 23 69 |e "exter|n.h".X#i|
|00003100| 6e 63 6c 75 64 65 20 22 | 6d 61 63 72 6f 73 2e 68 |nclude "|macros.h|
|00003110| 22 0a 58 0a 58 0a 58 67 | 5f 62 6f 64 20 28 66 29 |".X.X.Xg|_bod (f)|
|00003120| 0a 58 46 49 4c 45 20 2a | 20 66 3b 0a 58 7b 0a 58 |.XFILE *| f;.X{.X|
|00003130| 20 20 20 20 69 6e 74 20 | 20 20 20 20 6b 2c 0a 58 | int | k,.X|
|00003140| 20 20 20 20 20 20 20 20 | 20 20 20 20 78 3b 0a 58 | | x;.X|
|00003150| 20 20 20 20 64 6f 75 62 | 6c 65 20 20 62 69 67 20 | doub|le big |
|00003160| 3d 20 30 2e 30 2c 0a 58 | 20 20 20 20 20 20 20 20 |= 0.0,.X| |
|00003170| 20 20 20 20 6c 69 74 74 | 6c 65 20 3d 20 48 55 47 | litt|le = HUG|
|00003180| 45 3b 0a 58 20 20 20 20 | 63 68 61 72 20 20 20 20 |E;.X |char |
|00003190| 62 75 66 5b 35 31 32 5d | 3b 0a 58 0a 58 0a 58 20 |buf[512]|;.X.X.X |
|000031a0| 20 20 20 66 6f 72 20 28 | 79 73 75 65 20 3d 20 30 | for (|ysue = 0|
|000031b0| 3b 3b 20 79 73 75 65 2b | 2b 29 20 7b 0a 58 09 69 |;; ysue+|+) {.X.i|
|000031c0| 66 20 28 66 67 65 74 73 | 20 28 62 75 66 2c 20 35 |f (fgets| (buf, 5|
|000031d0| 31 32 2c 20 66 29 20 3d | 3d 20 4e 55 4c 4c 29 0a |12, f) =|= NULL).|
|000031e0| 58 09 20 20 20 20 62 72 | 65 61 6b 3b 0a 58 09 78 |X. br|eak;.X.x|
|000031f0| 73 75 65 20 3d 20 73 74 | 72 6c 65 6e 20 28 62 75 |sue = st|rlen (bu|
|00003200| 66 29 20 2d 20 31 3b 0a | 58 09 66 6f 72 20 28 78 |f) - 1;.|X.for (x|
|00003210| 20 3d 20 30 3b 20 78 20 | 3c 20 78 73 75 65 3b 20 | = 0; x |< xsue; |
|00003220| 78 2b 2b 29 20 7b 0a 58 | 09 20 20 20 20 6b 20 3d |x++) {.X|. k =|
|00003230| 20 62 75 66 5b 78 5d 3b | 0a 58 09 20 20 20 20 73 | buf[x];|.X. s|
|00003240| 75 7a 69 65 5b 78 5d 5b | 79 73 75 65 5d 20 3d 20 |uzie[x][|ysue] = |
|00003250| 28 64 6f 75 62 6c 65 29 | 20 6b 3b 0a 58 09 20 20 |(double)| k;.X. |
|00003260| 20 20 69 66 20 28 62 69 | 67 20 3c 20 6b 29 0a 58 | if (bi|g < k).X|
|00003270| 09 09 62 69 67 20 3d 20 | 6b 3b 0a 58 09 20 20 20 |..big = |k;.X. |
|00003280| 20 69 66 20 28 6c 69 74 | 74 6c 65 20 3e 20 6b 29 | if (lit|tle > k)|
|00003290| 0a 58 09 09 6c 69 74 74 | 6c 65 20 3d 20 6b 3b 0a |.X..litt|le = k;.|
|000032a0| 58 09 7d 0a 58 20 20 20 | 20 7d 0a 58 20 20 20 20 |X.}.X | }.X |
|000032b0| 62 69 67 20 3d 20 62 69 | 67 20 2d 20 6c 69 74 74 |big = bi|g - litt|
|000032c0| 6c 65 3b 0a 58 20 20 20 | 20 66 6f 72 20 28 6b 20 |le;.X | for (k |
|000032d0| 3d 20 30 3b 20 6b 20 3c | 20 79 73 75 65 3b 20 6b |= 0; k <| ysue; k|
|000032e0| 2b 2b 29 0a 58 09 66 6f | 72 20 28 78 20 3d 20 30 |++).X.fo|r (x = 0|
|000032f0| 3b 20 78 20 3c 20 78 73 | 75 65 3b 20 78 2b 2b 29 |; x < xs|ue; x++)|
|00003300| 0a 58 09 20 20 20 20 73 | 75 7a 69 65 5b 78 5d 5b |.X. s|uzie[x][|
|00003310| 6b 5d 20 3d 20 28 73 75 | 7a 69 65 5b 78 5d 5b 6b |k] = (su|zie[x][k|
|00003320| 5d 20 2d 20 6c 69 74 74 | 6c 65 29 20 2f 20 62 69 |] - litt|le) / bi|
|00003330| 67 3b 0a 58 7d 0a 45 4e | 44 5f 4f 46 5f 67 5f 62 |g;.X}.EN|D_OF_g_b|
|00003340| 6f 64 2e 63 0a 69 66 20 | 74 65 73 74 20 35 39 35 |od.c.if |test 595|
|00003350| 20 2d 6e 65 20 60 77 63 | 20 2d 63 20 3c 67 5f 62 | -ne `wc| -c <g_b|
|00003360| 6f 64 2e 63 60 3b 20 74 | 68 65 6e 0a 20 20 20 20 |od.c`; t|hen. |
|00003370| 65 63 68 6f 20 73 68 61 | 72 3a 20 5c 22 67 5f 62 |echo sha|r: \"g_b|
|00003380| 6f 64 2e 63 5c 22 20 75 | 6e 70 61 63 6b 65 64 20 |od.c\" u|npacked |
|00003390| 77 69 74 68 20 77 72 6f | 6e 67 20 73 69 7a 65 21 |with wro|ng size!|
|000033a0| 0a 66 69 0a 23 20 65 6e | 64 20 6f 66 20 6f 76 65 |.fi.# en|d of ove|
|000033b0| 72 77 72 69 74 69 6e 67 | 20 63 68 65 63 6b 0a 66 |rwriting| check.f|
|000033c0| 69 0a 69 66 20 74 65 73 | 74 20 2d 66 20 6d 61 63 |i.if tes|t -f mac|
|000033d0| 72 6f 73 2e 68 20 2d 61 | 20 22 24 7b 31 7d 22 20 |ros.h -a| "${1}" |
|000033e0| 21 3d 20 22 2d 63 22 20 | 3b 20 74 68 65 6e 20 0a |!= "-c" |; then .|
|000033f0| 20 20 65 63 68 6f 20 73 | 68 61 72 3a 20 57 69 6c | echo s|har: Wil|
|00003400| 6c 20 6e 6f 74 20 6f 76 | 65 72 2d 77 72 69 74 65 |l not ov|er-write|
|00003410| 20 65 78 69 73 74 69 6e | 67 20 66 69 6c 65 20 5c | existin|g file \|
|00003420| 22 6d 61 63 72 6f 73 2e | 68 5c 22 0a 65 6c 73 65 |"macros.|h\".else|
|00003430| 0a 65 63 68 6f 20 73 68 | 61 72 3a 20 45 78 74 72 |.echo sh|ar: Extr|
|00003440| 61 63 74 69 6e 67 20 5c | 22 6d 61 63 72 6f 73 2e |acting \|"macros.|
|00003450| 68 5c 22 20 5c 28 31 31 | 31 36 20 63 68 61 72 61 |h\" \(11|16 chara|
|00003460| 63 74 65 72 73 5c 29 0a | 73 65 64 20 22 73 2f 5e |cters\).|sed "s/^|
|00003470| 58 2f 2f 22 20 3e 6d 61 | 63 72 6f 73 2e 68 20 3c |X//" >ma|cros.h <|
|00003480| 3c 27 45 4e 44 5f 4f 46 | 5f 6d 61 63 72 6f 73 2e |<'END_OF|_macros.|
|00003490| 68 27 0a 58 2f 2a 20 73 | 6f 6d 65 20 6f 66 20 74 |h'.X/* s|ome of t|
|000034a0| 68 65 20 6d 6f 73 74 20 | 69 6d 70 6f 72 74 61 6e |he most |importan|
|000034b0| 74 20 73 74 75 66 66 20 | 69 6e 20 74 68 65 20 70 |t stuff |in the p|
|000034c0| 72 6f 67 72 61 6d 20 2a | 2f 0a 58 23 64 65 66 69 |rogram *|/.X#defi|
|000034d0| 6e 65 20 44 4f 54 28 76 | 31 2c 76 32 29 20 28 76 |ne DOT(v|1,v2) (v|
|000034e0| 31 2e 78 2a 76 32 2e 78 | 2b 76 31 2e 79 2a 76 32 |1.x*v2.x|+v1.y*v2|
|000034f0| 2e 79 2b 76 31 2e 7a 2a | 76 32 2e 7a 29 0a 58 2f |.y+v1.z*|v2.z).X/|
|00003500| 2a 20 72 65 74 75 72 6e | 73 20 64 6f 74 20 70 72 |* return|s dot pr|
|00003510| 6f 64 75 63 74 20 6f 66 | 20 74 77 6f 20 76 65 63 |oduct of| two vec|
|00003520| 74 6f 72 73 20 2a 2f 0a | 58 23 64 65 66 69 6e 65 |tors */.|X#define|
|00003530| 20 4c 4e 32 28 76 29 09 | 20 20 20 28 44 4f 54 28 | LN2(v).| (DOT(|
|00003540| 76 2c 76 29 29 0a 58 2f | 2a 20 72 65 74 75 72 6e |v,v)).X/|* return|
|00003550| 73 20 74 68 65 20 73 71 | 75 61 72 65 20 6f 66 20 |s the sq|uare of |
|00003560| 74 68 65 20 6c 65 6e 67 | 74 68 20 6f 66 20 61 20 |the leng|th of a |
|00003570| 76 65 63 74 6f 72 20 2a | 2f 0a 58 23 64 65 66 69 |vector *|/.X#defi|
|00003580| 6e 65 20 4c 45 4e 28 76 | 29 09 20 20 20 73 71 72 |ne LEN(v|). sqr|
|00003590| 74 28 4c 4e 32 28 76 29 | 29 0a 58 2f 2a 20 67 75 |t(LN2(v)|).X/* gu|
|000035a0| 65 73 73 20 2a 2f 0a 58 | 23 64 65 66 69 6e 65 20 |ess */.X|#define |
|000035b0| 58 5a 4c 28 76 29 09 20 | 20 20 73 71 72 74 28 76 |XZL(v). | sqrt(v|
|000035c0| 2e 78 2a 76 2e 78 2b 76 | 2e 7a 2a 76 2e 7a 29 0a |.x*v.x+v|.z*v.z).|
|000035d0| 58 2f 2a 20 72 65 74 75 | 72 6e 73 20 74 68 65 20 |X/* retu|rns the |
|000035e0| 63 6f 6d 70 6f 6e 65 6e | 74 20 69 6e 20 74 68 65 |componen|t in the|
|000035f0| 20 78 7a 20 70 6c 61 6e | 65 20 6f 66 20 61 20 76 | xz plan|e of a v|
|00003600| 65 63 74 6f 72 20 2a 2f | 0a 58 23 64 65 66 69 6e |ector */|.X#defin|
|00003610| 65 20 53 43 4d 4c 54 28 | 73 63 2c 76 63 74 29 20 |e SCMLT(|sc,vct) |
|00003620| 76 63 74 2e 78 2a 3d 20 | 73 63 3b 76 63 74 2e 79 |vct.x*= |sc;vct.y|
|00003630| 2a 3d 20 73 63 3b 76 63 | 74 2e 7a 2a 3d 20 73 63 |*= sc;vc|t.z*= sc|
|00003640| 3b 76 63 74 2e 6c 2a 3d | 20 73 63 3b 0a 58 2f 2a |;vct.l*=| sc;.X/*|
|00003650| 20 6d 75 6c 74 69 70 6c | 69 65 73 20 61 20 76 65 | multipl|ies a ve|
|00003660| 74 6f 72 20 62 79 20 61 | 20 73 63 61 6c 61 72 20 |tor by a| scalar |
|00003670| 2a 2f 0a 58 23 64 65 66 | 69 6e 65 20 4d 56 28 61 |*/.X#def|ine MV(a|
|00003680| 2c 62 2c 63 2c 76 29 20 | 20 20 76 2e 78 3d 20 61 |,b,c,v) | v.x= a|
|00003690| 3b 76 2e 79 3d 20 62 3b | 76 2e 7a 3d 20 63 3b 0a |;v.y= b;|v.z= c;.|
|000036a0| 58 2f 2a 20 6d 61 6b 65 | 73 20 61 20 76 65 63 74 |X/* make|s a vect|
|000036b0| 6f 72 2e 20 77 6f 75 6c | 64 6e 27 74 20 6e 65 65 |or. woul|dn't nee|
|000036c0| 64 20 74 68 69 73 20 77 | 69 74 68 20 63 2b 2b 20 |d this w|ith c++ |
|000036d0| 2a 2f 0a 58 23 64 65 66 | 69 6e 65 20 53 56 28 74 |*/.X#def|ine SV(t|
|000036e0| 2c 75 2c 76 29 20 20 74 | 2e 78 3d 75 2e 78 2d 76 |,u,v) t|.x=u.x-v|
|000036f0| 2e 78 3b 74 2e 79 3d 75 | 2e 79 2d 76 2e 79 3b 74 |.x;t.y=u|.y-v.y;t|
|00003700| 2e 7a 3d 75 2e 7a 2d 76 | 2e 7a 3b 0a 58 2f 2a 73 |.z=u.z-v|.z;.X/*s|
|00003710| 75 62 74 72 61 63 74 20 | 76 65 63 74 6f 72 20 74 |ubtract |vector t|
|00003720| 3d 75 2d 76 20 2a 2f 0a | 58 23 64 65 66 69 6e 65 |=u-v */.|X#define|
|00003730| 20 41 56 28 74 2c 75 2c | 76 29 20 20 74 2e 78 3d | AV(t,u,|v) t.x=|
|00003740| 75 2e 78 2b 76 2e 78 3b | 74 2e 79 3d 75 2e 79 2b |u.x+v.x;|t.y=u.y+|
|00003750| 76 2e 79 3b 74 2e 7a 3d | 75 2e 7a 2b 76 2e 7a 3b |v.y;t.z=|u.z+v.z;|
|00003760| 0a 58 2f 2a 20 61 64 64 | 20 76 65 63 74 6f 72 20 |.X/* add| vector |
|00003770| 74 3d 75 2b 76 20 2a 2f | 0a 58 23 64 65 66 69 6e |t=u+v */|.X#defin|
|00003780| 65 20 4d 54 56 28 76 31 | 2c 6d 2c 76 32 29 20 4d |e MTV(v1|,m,v2) M|
|00003790| 56 28 44 4f 54 28 6d 2e | 78 2c 76 32 29 2c 44 4f |V(DOT(m.|x,v2),DO|
|000037a0| 54 28 6d 2e 79 2c 76 32 | 29 2c 44 4f 54 28 6d 2e |T(m.y,v2|),DOT(m.|
|000037b0| 7a 2c 76 32 29 2c 76 31 | 29 0a 58 2f 2a 20 6d 75 |z,v2),v1|).X/* mu|
|000037c0| 6c 74 69 70 6c 79 20 74 | 72 61 6e 73 70 6f 73 65 |ltiply t|ranspose|
|000037d0| 20 6d 61 74 72 69 78 20 | 62 79 20 76 65 63 74 6f | matrix |by vecto|
|000037e0| 72 2e 20 76 31 3d 6d 2a | 76 32 20 2a 2f 0a 58 0a |r. v1=m*|v2 */.X.|
|000037f0| 58 23 64 65 66 69 6e 65 | 20 4c 45 56 45 4c 20 35 |X#define| LEVEL 5|
|00003800| 2f 2a 20 6c 65 76 65 6c | 73 20 6f 66 20 72 65 63 |/* level|s of rec|
|00003810| 75 72 73 69 6f 6e 20 2a | 2f 0a 58 23 64 65 66 69 |ursion *|/.X#defi|
|00003820| 6e 65 20 52 4c 45 56 20 | 20 33 2f 2a 64 6f 6e 27 |ne RLEV | 3/*don'|
|00003830| 74 20 77 61 6e 74 20 61 | 73 20 6d 61 6e 79 20 69 |t want a|s many i|
|00003840| 6e 73 69 64 65 20 74 68 | 65 20 62 61 6c 6c 2c 20 |nside th|e ball, |
|00003850| 74 61 6b 65 73 20 66 6f | 72 65 76 65 72 20 61 73 |takes fo|rever as|
|00003860| 20 69 74 20 69 73 2a 2f | 0a 58 0a 58 23 64 65 66 | it is*/|.X.X#def|
|00003870| 69 6e 65 20 58 4d 49 4e | 20 31 30 2e 30 0a 58 23 |ine XMIN| 10.0.X#|
|00003880| 64 65 66 69 6e 65 20 58 | 4d 41 58 20 32 32 30 2e |define X|MAX 220.|
|00003890| 30 0a 58 23 64 65 66 69 | 6e 65 20 59 4d 49 4e 20 |0.X#defi|ne YMIN |
|000038a0| 31 30 2e 30 0a 58 23 64 | 65 66 69 6e 65 20 59 4d |10.0.X#d|efine YM|
|000038b0| 41 58 20 31 37 30 2e 30 | 0a 58 2f 2a 20 77 69 6e |AX 170.0|.X/* win|
|000038c0| 64 6f 77 20 73 69 7a 65 | 2c 20 20 76 69 72 74 75 |dow size|, virtu|
|000038d0| 61 6c 20 75 6e 69 74 73 | 20 2a 2f 0a 58 23 64 65 |al units| */.X#de|
|000038e0| 66 69 6e 65 20 53 43 41 | 4c 45 20 20 32 2e 30 0a |fine SCA|LE 2.0.|
|000038f0| 58 2f 2a 20 6d 61 67 69 | 6e 69 66 69 63 61 74 69 |X/* magi|nificati|
|00003900| 6f 6e 20 66 61 63 74 6f | 72 20 2a 2f 0a 45 4e 44 |on facto|r */.END|
|00003910| 5f 4f 46 5f 6d 61 63 72 | 6f 73 2e 68 0a 69 66 20 |_OF_macr|os.h.if |
|00003920| 74 65 73 74 20 31 31 31 | 36 20 2d 6e 65 20 60 77 |test 111|6 -ne `w|
|00003930| 63 20 2d 63 20 3c 6d 61 | 63 72 6f 73 2e 68 60 3b |c -c <ma|cros.h`;|
|00003940| 20 74 68 65 6e 0a 20 20 | 20 20 65 63 68 6f 20 73 | then. | echo s|
|00003950| 68 61 72 3a 20 5c 22 6d | 61 63 72 6f 73 2e 68 5c |har: \"m|acros.h\|
|00003960| 22 20 75 6e 70 61 63 6b | 65 64 20 77 69 74 68 20 |" unpack|ed with |
|00003970| 77 72 6f 6e 67 20 73 69 | 7a 65 21 0a 66 69 0a 23 |wrong si|ze!.fi.#|
|00003980| 20 65 6e 64 20 6f 66 20 | 6f 76 65 72 77 72 69 74 | end of |overwrit|
|00003990| 69 6e 67 20 63 68 65 63 | 6b 0a 66 69 0a 69 66 20 |ing chec|k.fi.if |
|000039a0| 74 65 73 74 20 2d 66 20 | 72 65 66 72 61 63 74 2e |test -f |refract.|
|000039b0| 63 20 2d 61 20 22 24 7b | 31 7d 22 20 21 3d 20 22 |c -a "${|1}" != "|
|000039c0| 2d 63 22 20 3b 20 74 68 | 65 6e 20 0a 20 20 65 63 |-c" ; th|en . ec|
|000039d0| 68 6f 20 73 68 61 72 3a | 20 57 69 6c 6c 20 6e 6f |ho shar:| Will no|
|000039e0| 74 20 6f 76 65 72 2d 77 | 72 69 74 65 20 65 78 69 |t over-w|rite exi|
|000039f0| 73 74 69 6e 67 20 66 69 | 6c 65 20 5c 22 72 65 66 |sting fi|le \"ref|
|00003a00| 72 61 63 74 2e 63 5c 22 | 0a 65 6c 73 65 0a 65 63 |ract.c\"|.else.ec|
|00003a10| 68 6f 20 73 68 61 72 3a | 20 45 78 74 72 61 63 74 |ho shar:| Extract|
|00003a20| 69 6e 67 20 5c 22 72 65 | 66 72 61 63 74 2e 63 5c |ing \"re|fract.c\|
|00003a30| 22 20 5c 28 32 39 36 35 | 20 63 68 61 72 61 63 74 |" \(2965| charact|
|00003a40| 65 72 73 5c 29 0a 73 65 | 64 20 22 73 2f 5e 58 2f |ers\).se|d "s/^X/|
|00003a50| 2f 22 20 3e 72 65 66 72 | 61 63 74 2e 63 20 3c 3c |/" >refr|act.c <<|
|00003a60| 27 45 4e 44 5f 4f 46 5f | 72 65 66 72 61 63 74 2e |'END_OF_|refract.|
|00003a70| 63 27 0a 58 23 69 6e 63 | 6c 75 64 65 20 3c 6d 61 |c'.X#inc|lude <ma|
|00003a80| 74 68 2e 68 3e 0a 58 23 | 69 6e 63 6c 75 64 65 20 |th.h>.X#|include |
|00003a90| 22 72 74 64 2e 68 22 0a | 58 23 69 6e 63 6c 75 64 |"rtd.h".|X#includ|
|00003aa0| 65 20 22 6d 61 63 72 6f | 73 2e 68 22 0a 58 23 69 |e "macro|s.h".X#i|
|00003ab0| 6e 63 6c 75 64 65 20 22 | 65 78 74 65 72 6e 2e 68 |nclude "|extern.h|
|00003ac0| 22 0a 58 0a 58 69 6e 74 | 09 72 6c 65 76 3b 0a 58 |".X.Xint|.rlev;.X|
|00003ad0| 69 6e 74 20 20 20 20 20 | 72 65 66 72 61 63 74 20 |int |refract |
|00003ae0| 28 72 2c 20 62 6c 6c 29 | 0a 58 73 74 72 75 63 74 |(r, bll)|.Xstruct|
|00003af0| 20 72 61 79 20 2a 72 3b | 0a 58 73 74 72 75 63 74 | ray *r;|.Xstruct|
|00003b00| 20 62 61 6c 6c 20 2a 62 | 6c 6c 3b 0a 58 7b 0a 58 | ball *b|ll;.X{.X|
|00003b10| 20 20 20 20 73 74 72 75 | 63 74 20 76 65 63 74 6f | stru|ct vecto|
|00003b20| 72 20 20 20 6e 65 77 2c | 0a 58 20 20 20 20 20 20 |r new,|.X |
|00003b30| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 6e 6f | | no|
|00003b40| 72 6d 3b 0a 58 20 20 20 | 20 73 74 72 75 63 74 20 |rm;.X | struct |
|00003b50| 6d 61 74 20 20 74 72 61 | 6e 73 3b 0a 58 20 20 20 |mat tra|ns;.X |
|00003b60| 20 73 74 72 75 63 74 20 | 72 61 79 20 20 69 72 3b | struct |ray ir;|
|00003b70| 0a 58 20 20 20 20 64 6f | 75 62 6c 65 20 20 6c 2c |.X do|uble l,|
|00003b80| 0a 58 20 20 20 20 20 20 | 20 20 20 20 20 20 72 65 |.X | re|
|00003b90| 66 6b 20 28 29 2c 20 67 | 65 74 63 61 70 74 20 28 |fk (), g|etcapt (|
|00003ba0| 29 2c 20 63 61 70 74 2c | 20 69 6e 73 69 64 65 20 |), capt,| inside |
|00003bb0| 28 29 3b 0a 58 20 20 20 | 20 64 6f 75 62 6c 65 20 |();.X | double |
|00003bc0| 20 73 74 75 70 69 64 3b | 0a 58 20 20 20 20 73 74 | stupid;|.X st|
|00003bd0| 72 75 63 74 20 73 70 68 | 65 72 65 20 20 20 73 73 |ruct sph|ere ss|
|00003be0| 3b 0a 58 0a 58 20 20 20 | 20 53 56 20 28 6e 6f 72 |;.X.X | SV (nor|
|00003bf0| 6d 2c 20 72 20 2d 3e 20 | 6f 72 67 2c 20 62 6c 6c |m, r -> |org, bll|
|00003c00| 20 2d 3e 20 73 2e 63 65 | 6e 74 29 3b 0a 58 20 20 | -> s.ce|nt);.X |
|00003c10| 20 20 6e 6f 72 6d 2e 6c | 20 3d 20 62 6c 6c 2d 3e | norm.l| = bll->|
|00003c20| 20 73 2e 72 61 64 3b 0a | 58 0a 58 20 20 20 20 63 | s.rad;.|X.X c|
|00003c30| 61 70 74 20 3d 20 67 65 | 74 63 61 70 74 20 28 26 |apt = ge|tcapt (&|
|00003c40| 6e 6f 72 6d 2c 20 26 28 | 72 20 2d 3e 20 64 69 72 |norm, &(|r -> dir|
|00003c50| 29 2c 20 62 6c 6c 20 2d | 3e 20 69 6f 72 29 3b 0a |), bll -|> ior);.|
|00003c60| 58 0a 58 0a 58 2f 2a 20 | 67 65 74 20 74 68 65 20 |X.X.X/* |get the |
|00003c70| 61 64 64 69 74 69 6f 6e | 20 66 61 63 74 6f 72 20 |addition| factor |
|00003c80| 66 6f 72 20 74 68 65 20 | 6e 6f 72 6d 61 6c 20 66 |for the |normal f|
|00003c90| 6f 72 20 72 65 66 72 61 | 63 74 69 6f 6e 2a 2f 0a |or refra|ction*/.|
|00003ca0| 58 20 20 20 20 73 74 75 | 70 69 64 20 3d 20 72 65 |X stu|pid = re|
|00003cb0| 66 6b 20 28 26 28 6e 6f | 72 6d 29 2c 20 26 28 72 |fk (&(no|rm), &(r|
|00003cc0| 20 2d 3e 20 64 69 72 29 | 2c 20 62 6c 6c 20 2d 3e | -> dir)|, bll ->|
|00003cd0| 20 69 6f 72 29 3b 0a 58 | 20 20 20 20 53 43 4d 4c | ior);.X| SCML|
|00003ce0| 54 20 28 73 74 75 70 69 | 64 2c 20 6e 6f 72 6d 29 |T (stupi|d, norm)|
|00003cf0| 3b 0a 58 0a 58 20 20 20 | 20 41 56 20 28 69 72 2e |;.X.X | AV (ir.|
|00003d00| 64 69 72 2c 20 72 20 2d | 3e 20 64 69 72 2c 20 6e |dir, r -|> dir, n|
|00003d10| 6f 72 6d 29 3b 0a 58 20 | 20 20 20 4d 56 20 28 72 |orm);.X | MV (r|
|00003d20| 20 2d 3e 20 6f 72 67 2e | 78 2c 20 72 20 2d 3e 20 | -> org.|x, r -> |
|00003d30| 6f 72 67 2e 79 2c 20 72 | 20 2d 3e 20 6f 72 67 2e |org.y, r| -> org.|
|00003d40| 7a 2c 20 69 72 2e 6f 72 | 67 29 3b 0a 58 0a 58 2f |z, ir.or|g);.X.X/|
|00003d50| 2a 20 6e 6f 77 20 67 65 | 74 20 69 74 20 66 6f 72 |* now ge|t it for|
|00003d60| 20 72 65 66 6c 65 63 74 | 69 6f 6e 20 2a 2f 0a 58 | reflect|ion */.X|
|00003d70| 20 20 20 20 53 56 20 28 | 6e 6f 72 6d 2c 20 72 20 | SV (|norm, r |
|00003d80| 2d 3e 20 6f 72 67 2c 20 | 62 6c 6c 20 2d 3e 20 73 |-> org, |bll -> s|
|00003d90| 2e 63 65 6e 74 29 3b 0a | 58 20 20 20 20 6e 6f 72 |.cent);.|X nor|
|00003da0| 6d 2e 6c 20 3d 20 62 6c | 6c 20 2d 3e 20 73 2e 72 |m.l = bl|l -> s.r|
|00003db0| 61 64 3b 0a 58 20 20 20 | 20 53 43 4d 4c 54 20 28 |ad;.X | SCMLT (|
|00003dc0| 31 2e 30 20 2f 20 6e 6f | 72 6d 2e 6c 2c 20 6e 6f |1.0 / no|rm.l, no|
|00003dd0| 72 6d 29 3b 0a 58 20 20 | 20 20 73 74 75 70 69 64 |rm);.X | stupid|
|00003de0| 20 3d 20 32 2e 30 20 2a | 20 44 4f 54 20 28 6e 6f | = 2.0 *| DOT (no|
|00003df0| 72 6d 2c 20 72 20 2d 3e | 20 64 69 72 29 3b 0a 58 |rm, r ->| dir);.X|
|00003e00| 20 20 20 20 53 43 4d 4c | 54 20 28 73 74 75 70 69 | SCML|T (stupi|
|00003e10| 64 2c 20 6e 6f 72 6d 29 | 3b 0a 58 20 20 20 20 53 |d, norm)|;.X S|
|00003e20| 56 20 28 72 20 2d 3e 20 | 64 69 72 2c 20 72 20 2d |V (r -> |dir, r -|
|00003e30| 3e 20 64 69 72 2c 20 6e | 6f 72 6d 29 3b 0a 58 0a |> dir, n|orm);.X.|
|00003e40| 58 20 20 20 20 72 65 74 | 75 72 6e 20 28 28 69 6e |X ret|urn ((in|
|00003e50| 74 29 20 28 28 31 2e 30 | 20 2d 20 63 61 70 74 29 |t) ((1.0| - capt)|
|00003e60| 20 2a 20 28 64 6f 75 62 | 6c 65 29 20 73 68 61 64 | * (doub|le) shad|
|00003e70| 65 20 28 72 29 20 2b 20 | 28 28 63 61 70 74 29 20 |e (r) + |((capt) |
|00003e80| 2a 20 69 6e 73 69 64 65 | 20 28 26 69 72 2c 20 62 |* inside| (&ir, b|
|00003e90| 6c 6c 29 29 29 29 3b 0a | 58 7d 0a 58 0a 58 64 6f |ll))));.|X}.X.Xdo|
|00003ea0| 75 62 6c 65 20 20 69 6e | 73 69 64 65 20 28 72 2c |uble in|side (r,|
|00003eb0| 20 62 6c 6c 29 0a 58 73 | 74 72 75 63 74 20 72 61 | bll).Xs|truct ra|
|00003ec0| 79 20 2a 72 3b 0a 58 73 | 74 72 75 63 74 20 62 61 |y *r;.Xs|truct ba|
|00003ed0| 6c 6c 20 2a 62 6c 6c 3b | 0a 58 7b 0a 58 20 20 20 |ll *bll;|.X{.X |
|00003ee0| 20 73 74 72 75 63 74 20 | 76 65 63 74 6f 72 20 20 | struct |vector |
|00003ef0| 20 6e 65 77 2c 0a 58 20 | 20 20 20 20 20 20 20 20 | new,.X | |
|00003f00| 20 20 20 20 20 20 20 20 | 20 20 20 6e 6f 72 6d 3b | | norm;|
|00003f10| 0a 58 20 20 20 20 73 74 | 72 75 63 74 20 6d 61 74 |.X st|ruct mat|
|00003f20| 20 20 74 72 61 6e 73 3b | 0a 58 20 20 20 20 73 74 | trans;|.X st|
|00003f30| 72 75 63 74 20 72 61 79 | 20 20 65 72 3b 0a 58 20 |ruct ray| er;.X |
|00003f40| 20 20 20 64 6f 75 62 6c | 65 20 20 66 69 6e 64 6f | doubl|e findo|
|00003f50| 20 28 29 2c 20 6c 67 68 | 74 2c 20 6c 2c 20 72 65 | (), lgh|t, l, re|
|00003f60| 66 6b 20 28 29 2c 20 67 | 65 74 63 61 70 74 20 28 |fk (), g|etcapt (|
|00003f70| 29 2c 20 63 61 70 74 3b | 0a 58 20 20 20 20 64 6f |), capt;|.X do|
|00003f80| 75 62 6c 65 20 20 73 74 | 75 70 69 64 3b 0a 58 20 |uble st|upid;.X |
|00003f90| 20 20 20 73 74 72 75 63 | 74 20 73 70 68 65 72 65 | struc|t sphere|
|00003fa0| 20 20 20 73 73 3b 0a 58 | 0a 58 0a 58 20 20 20 20 | ss;.X|.X.X |
|00003fb0| 69 66 20 28 2b 2b 72 6c | 65 76 20 3c 20 52 4c 45 |if (++rl|ev < RLE|
|00003fc0| 56 29 20 7b 0a 58 09 72 | 20 2d 3e 20 64 69 72 2e |V) {.X.r| -> dir.|
|00003fd0| 6c 20 3d 20 4c 45 4e 20 | 28 72 20 2d 3e 20 64 69 |l = LEN |(r -> di|
|00003fe0| 72 29 3b 0a 58 09 72 20 | 2d 3e 20 64 69 72 2e 78 |r);.X.r |-> dir.x|
|00003ff0| 7a 6c 20 3d 20 58 5a 4c | 20 28 72 20 2d 3e 20 64 |zl = XZL| (r -> d|
|00004000| 69 72 29 3b 0a 58 09 6d | 74 20 28 26 28 72 20 2d |ir);.X.m|t (&(r -|
|00004010| 3e 20 64 69 72 29 2c 20 | 26 74 72 61 6e 73 29 3b |> dir), |&trans);|
|00004020| 0a 58 09 73 73 2e 72 61 | 64 20 3d 20 62 6c 6c 20 |.X.ss.ra|d = bll |
|00004030| 2d 3e 20 73 2e 72 61 64 | 3b 0a 58 09 53 56 20 28 |-> s.rad|;.X.SV (|
|00004040| 73 73 2e 63 65 6e 74 2c | 20 62 6c 6c 20 2d 3e 20 |ss.cent,| bll -> |
|00004050| 73 2e 63 65 6e 74 2c 20 | 72 20 2d 3e 20 6f 72 67 |s.cent, |r -> org|
|00004060| 29 3b 0a 58 0a 58 09 6c | 20 3d 20 66 69 6e 64 6f |);.X.X.l| = findo|
|00004070| 20 28 26 74 72 61 6e 73 | 2c 20 26 73 73 29 3b 0a | (&trans|, &ss);.|
|00004080| 58 09 4d 56 20 28 6c 20 | 2a 20 74 72 61 6e 73 2e |X.MV (l |* trans.|
|00004090| 78 2e 78 2c 20 6c 20 2a | 20 74 72 61 6e 73 2e 78 |x.x, l *| trans.x|
|000040a0| 2e 79 2c 20 6c 20 2a 20 | 74 72 61 6e 73 2e 78 2e |.y, l * |trans.x.|
|000040b0| 7a 2c 20 6e 65 77 29 3b | 0a 58 09 41 56 20 28 65 |z, new);|.X.AV (e|
|000040c0| 72 2e 6f 72 67 2c 20 72 | 20 2d 3e 20 6f 72 67 2c |r.org, r| -> org,|
|000040d0| 20 6e 65 77 29 3b 0a 58 | 09 41 56 20 28 72 20 2d | new);.X|.AV (r -|
|000040e0| 3e 20 6f 72 67 2c 20 72 | 20 2d 3e 20 6f 72 67 2c |> org, r| -> org,|
|000040f0| 20 6e 65 77 29 3b 0a 58 | 09 53 56 20 28 6e 6f 72 | new);.X|.SV (nor|
|00004100| 6d 2c 20 65 72 2e 6f 72 | 67 2c 20 62 6c 6c 20 2d |m, er.or|g, bll -|
|00004110| 3e 20 73 2e 63 65 6e 74 | 29 3b 0a 58 0a 58 09 6e |> s.cent|);.X.X.n|
|00004120| 6f 72 6d 2e 6c 20 3d 20 | 62 6c 6c 20 2d 3e 20 73 |orm.l = |bll -> s|
|00004130| 2e 72 61 64 3b 0a 58 09 | 63 61 70 74 20 3d 20 67 |.rad;.X.|capt = g|
|00004140| 65 74 63 61 70 74 20 28 | 26 6e 6f 72 6d 2c 20 26 |etcapt (|&norm, &|
|00004150| 28 72 20 2d 3e 20 64 69 | 72 29 2c 20 31 2e 30 20 |(r -> di|r), 1.0 |
|00004160| 2f 20 62 6c 6c 20 2d 3e | 20 69 6f 72 29 3b 0a 58 |/ bll ->| ior);.X|
|00004170| 0a 58 09 73 74 75 70 69 | 64 20 3d 20 72 65 66 6b |.X.stupi|d = refk|
|00004180| 20 28 26 6e 6f 72 6d 2c | 20 26 28 72 20 2d 3e 20 | (&norm,| &(r -> |
|00004190| 64 69 72 29 2c 20 31 2e | 30 20 2f 20 62 6c 6c 20 |dir), 1.|0 / bll |
|000041a0| 2d 3e 20 69 6f 72 29 3b | 0a 58 09 53 43 4d 4c 54 |-> ior);|.X.SCMLT|
|000041b0| 20 28 73 74 75 70 69 64 | 2c 20 6e 6f 72 6d 29 3b | (stupid|, norm);|
|000041c0| 0a 58 09 41 56 20 28 65 | 72 2e 64 69 72 2c 20 6e |.X.AV (e|r.dir, n|
|000041d0| 6f 72 6d 2c 20 72 20 2d | 3e 20 64 69 72 29 3b 0a |orm, r -|> dir);.|
|000041e0| 58 0a 58 09 53 43 4d 4c | 54 20 28 31 2e 30 20 2f |X.X.SCML|T (1.0 /|
|000041f0| 20 6e 6f 72 6d 2e 6c 2c | 20 6e 6f 72 6d 29 3b 0a | norm.l,| norm);.|
|00004200| 58 09 73 74 75 70 69 64 | 20 3d 20 32 2e 30 20 2a |X.stupid| = 2.0 *|
|00004210| 20 44 4f 54 20 28 6e 6f | 72 6d 2c 20 72 20 2d 3e | DOT (no|rm, r ->|
|00004220| 20 64 69 72 29 3b 0a 58 | 09 53 43 4d 4c 54 20 28 | dir);.X|.SCMLT (|
|00004230| 73 74 75 70 69 64 2c 20 | 6e 6f 72 6d 29 3b 0a 58 |stupid, |norm);.X|
|00004240| 09 53 56 20 28 72 20 2d | 3e 20 64 69 72 2c 20 72 |.SV (r -|> dir, r|
|00004250| 20 2d 3e 20 64 69 72 2c | 20 6e 6f 72 6d 29 3b 0a | -> dir,| norm);.|
|00004260| 58 09 6c 67 68 74 20 3d | 20 28 31 2e 30 20 2d 20 |X.lght =| (1.0 - |
|00004270| 63 61 70 74 29 20 2a 20 | 69 6e 73 69 64 65 20 28 |capt) * |inside (|
|00004280| 72 2c 20 62 6c 6c 29 20 | 2b 20 28 63 61 70 74 20 |r, bll) |+ (capt |
|00004290| 2a 20 28 64 6f 75 62 6c | 65 29 20 73 68 61 64 65 |* (doubl|e) shade|
|000042a0| 20 28 26 65 72 29 29 3b | 0a 58 20 20 20 20 7d 0a | (&er));|.X }.|
|000042b0| 58 20 20 20 20 65 6c 73 | 65 0a 58 09 6c 67 68 74 |X els|e.X.lght|
|000042c0| 20 3d 20 30 2e 30 3b 0a | 58 20 20 20 20 72 6c 65 | = 0.0;.|X rle|
|000042d0| 76 2d 2d 3b 0a 58 20 20 | 20 20 20 69 66 20 28 6c |v--;.X | if (l|
|000042e0| 67 68 74 3c 30 2e 30 29 | 20 6c 67 68 74 3d 30 2e |ght<0.0)| lght=0.|
|000042f0| 30 3b 0a 58 20 20 20 20 | 20 69 66 20 28 6c 67 68 |0;.X | if (lgh|
|00004300| 74 3e 32 35 35 2e 30 29 | 20 6c 67 68 74 3d 32 35 |t>255.0)| lght=25|
|00004310| 35 2e 30 3b 0a 58 20 20 | 20 20 72 65 74 75 72 6e |5.0;.X | return|
|00004320| 20 28 6c 67 68 74 29 3b | 0a 58 7d 0a 58 0a 58 0a | (lght);|.X}.X.X.|
|00004330| 58 0a 58 64 6f 75 62 6c | 65 20 20 72 65 66 6b 20 |X.Xdoubl|e refk |
|00004340| 28 6e 72 6d 2c 20 69 6e | 2c 20 69 6f 72 29 0a 58 |(nrm, in|, ior).X|
|00004350| 73 74 72 75 63 74 20 76 | 65 63 74 6f 72 20 20 2a |struct v|ector *|
|00004360| 6e 72 6d 2c 0a 58 20 20 | 20 20 20 20 20 20 20 20 |nrm,.X | |
|00004370| 20 20 20 20 20 2a 69 6e | 3b 0a 58 64 6f 75 62 6c | *in|;.Xdoubl|
|00004380| 65 20 20 69 6f 72 3b 0a | 58 7b 0a 58 20 20 20 20 |e ior;.|X{.X |
|00004390| 64 6f 75 62 6c 65 20 20 | 64 74 2c 0a 58 20 20 20 |double |dt,.X |
|000043a0| 20 20 20 20 20 20 20 20 | 20 6c 6e 2c 0a 58 20 20 | | ln,.X |
|000043b0| 20 20 20 20 20 20 20 20 | 20 20 6c 69 2c 0a 58 20 | | li,.X |
|000043c0| 20 20 20 20 20 20 20 20 | 20 20 20 72 65 74 3b 0a | | ret;.|
|000043d0| 58 0a 58 20 20 20 20 69 | 6f 72 20 3d 20 69 6f 72 |X.X i|or = ior|
|000043e0| 20 2a 20 69 6f 72 3b 0a | 58 20 20 20 20 64 74 20 | * ior;.|X dt |
|000043f0| 3d 20 44 4f 54 20 28 28 | 2a 6e 72 6d 29 2c 20 28 |= DOT ((|*nrm), (|
|00004400| 2a 69 6e 29 29 3b 0a 58 | 20 20 20 20 6c 6e 20 3d |*in));.X| ln =|
|00004410| 20 4c 4e 32 20 28 28 2a | 6e 72 6d 29 29 3b 0a 58 | LN2 ((*|nrm));.X|
|00004420| 20 20 20 20 6c 69 20 3d | 20 4c 4e 32 20 28 28 2a | li =| LN2 ((*|
|00004430| 69 6e 29 29 3b 0a 58 20 | 20 20 20 69 66 20 28 64 |in));.X | if (d|
|00004440| 74 20 3c 20 30 29 0a 58 | 09 72 65 74 20 3d 20 28 |t < 0).X|.ret = (|
|00004450| 2d 64 74 20 2d 20 73 71 | 72 74 20 28 64 74 20 2a |-dt - sq|rt (dt *|
|00004460| 20 64 74 20 2d 20 6c 6e | 20 2a 20 6c 69 20 2a 20 | dt - ln| * li * |
|00004470| 28 31 20 2d 20 69 6f 72 | 29 29 29 20 2f 20 6c 6e |(1 - ior|))) / ln|
|00004480| 3b 0a 58 20 20 20 20 65 | 6c 73 65 0a 58 09 72 65 |;.X e|lse.X.re|
|00004490| 74 20 3d 20 28 2d 64 74 | 20 2b 20 73 71 72 74 20 |t = (-dt| + sqrt |
|000044a0| 28 64 74 20 2a 20 64 74 | 20 2d 20 6c 6e 20 2a 20 |(dt * dt| - ln * |
|000044b0| 6c 69 20 2a 20 28 31 20 | 2d 20 69 6f 72 29 29 29 |li * (1 |- ior)))|
|000044c0| 20 2f 20 6c 6e 3b 0a 58 | 20 20 20 20 72 65 74 75 | / ln;.X| retu|
|000044d0| 72 6e 20 28 72 65 74 29 | 3b 0a 58 7d 0a 58 0a 58 |rn (ret)|;.X}.X.X|
|000044e0| 64 6f 75 62 6c 65 20 20 | 67 65 74 63 61 70 74 20 |double |getcapt |
|000044f0| 28 6e 72 6d 2c 20 64 72 | 2c 20 69 6f 72 29 0a 58 |(nrm, dr|, ior).X|
|00004500| 73 74 72 75 63 74 20 76 | 65 63 74 6f 72 20 20 2a |struct v|ector *|
|00004510| 6e 72 6d 2c 0a 58 20 20 | 20 20 20 20 20 20 20 20 |nrm,.X | |
|00004520| 20 20 20 20 20 2a 64 72 | 3b 0a 58 64 6f 75 62 6c | *dr|;.Xdoubl|
|00004530| 65 20 20 69 6f 72 3b 0a | 58 7b 0a 58 20 20 20 20 |e ior;.|X{.X |
|00004540| 64 6f 75 62 6c 65 20 20 | 64 74 2c 0a 58 20 20 20 |double |dt,.X |
|00004550| 20 20 20 20 20 20 20 20 | 20 63 73 31 2c 0a 58 20 | | cs1,.X |
|00004560| 20 20 20 20 20 20 20 20 | 20 20 20 63 73 32 2c 0a | | cs2,.|
|00004570| 58 20 20 20 20 20 20 20 | 20 20 20 20 20 70 2c 0a |X | p,.|
|00004580| 58 20 20 20 20 20 20 20 | 20 20 20 20 20 73 3b 0a |X | s;.|
|00004590| 58 20 20 20 20 64 74 20 | 3d 20 44 4f 54 20 28 28 |X dt |= DOT ((|
|000045a0| 2a 6e 72 6d 29 2c 20 28 | 2a 64 72 29 29 3b 0a 58 |*nrm), (|*dr));.X|
|000045b0| 20 20 20 20 64 74 20 3d | 20 64 74 20 2a 20 64 74 | dt =| dt * dt|
|000045c0| 20 2f 20 4c 4e 32 20 28 | 28 2a 6e 72 6d 29 29 20 | / LN2 (|(*nrm)) |
|000045d0| 2f 20 4c 4e 32 20 28 28 | 2a 64 72 29 29 3b 0a 58 |/ LN2 ((|*dr));.X|
|000045e0| 20 20 20 20 63 73 31 20 | 3d 20 73 71 72 74 20 28 | cs1 |= sqrt (|
|000045f0| 64 74 29 3b 0a 58 20 20 | 20 20 63 73 32 20 3d 20 |dt);.X | cs2 = |
|00004600| 73 71 72 74 20 28 31 2e | 30 20 2d 20 28 31 2e 30 |sqrt (1.|0 - (1.0|
|00004610| 20 2d 20 64 74 29 20 2f | 20 69 6f 72 29 3b 0a 58 | - dt) /| ior);.X|
|00004620| 20 20 20 20 70 20 3d 20 | 63 73 31 20 2f 20 28 63 | p = |cs1 / (c|
|00004630| 73 31 20 2b 20 69 6f 72 | 20 2a 20 63 73 32 29 3b |s1 + ior| * cs2);|
|00004640| 0a 58 20 20 20 20 73 20 | 3d 20 63 73 31 20 2f 20 |.X s |= cs1 / |
|00004650| 28 69 6f 72 20 2a 20 63 | 73 31 20 2b 20 63 73 32 |(ior * c|s1 + cs2|
|00004660| 29 3b 0a 58 20 20 20 20 | 72 65 74 75 72 6e 20 28 |);.X |return (|
|00004670| 32 2e 30 20 2a 20 28 70 | 20 2a 20 70 20 2b 20 73 |2.0 * (p| * p + s|
|00004680| 20 2a 20 73 29 29 3b 0a | 58 7d 0a 45 4e 44 5f 4f | * s));.|X}.END_O|
|00004690| 46 5f 72 65 66 72 61 63 | 74 2e 63 0a 69 66 20 74 |F_refrac|t.c.if t|
|000046a0| 65 73 74 20 32 39 36 35 | 20 2d 6e 65 20 60 77 63 |est 2965| -ne `wc|
|000046b0| 20 2d 63 20 3c 72 65 66 | 72 61 63 74 2e 63 60 3b | -c <ref|ract.c`;|
|000046c0| 20 74 68 65 6e 0a 20 20 | 20 20 65 63 68 6f 20 73 | then. | echo s|
|000046d0| 68 61 72 3a 20 5c 22 72 | 65 66 72 61 63 74 2e 63 |har: \"r|efract.c|
|000046e0| 5c 22 20 75 6e 70 61 63 | 6b 65 64 20 77 69 74 68 |\" unpac|ked with|
|000046f0| 20 77 72 6f 6e 67 20 73 | 69 7a 65 21 0a 66 69 0a | wrong s|ize!.fi.|
|00004700| 23 20 65 6e 64 20 6f 66 | 20 6f 76 65 72 77 72 69 |# end of| overwri|
|00004710| 74 69 6e 67 20 63 68 65 | 63 6b 0a 66 69 0a 69 66 |ting che|ck.fi.if|
|00004720| 20 74 65 73 74 20 2d 66 | 20 72 74 64 2e 68 20 2d | test -f| rtd.h -|
|00004730| 61 20 22 24 7b 31 7d 22 | 20 21 3d 20 22 2d 63 22 |a "${1}"| != "-c"|
|00004740| 20 3b 20 74 68 65 6e 20 | 0a 20 20 65 63 68 6f 20 | ; then |. echo |
|00004750| 73 68 61 72 3a 20 57 69 | 6c 6c 20 6e 6f 74 20 6f |shar: Wi|ll not o|
|00004760| 76 65 72 2d 77 72 69 74 | 65 20 65 78 69 73 74 69 |ver-writ|e existi|
|00004770| 6e 67 20 66 69 6c 65 20 | 5c 22 72 74 64 2e 68 5c |ng file |\"rtd.h\|
|00004780| 22 0a 65 6c 73 65 0a 65 | 63 68 6f 20 73 68 61 72 |".else.e|cho shar|
|00004790| 3a 20 45 78 74 72 61 63 | 74 69 6e 67 20 5c 22 72 |: Extrac|ting \"r|
|000047a0| 74 64 2e 68 5c 22 20 5c | 28 34 33 34 20 63 68 61 |td.h\" \|(434 cha|
|000047b0| 72 61 63 74 65 72 73 5c | 29 0a 73 65 64 20 22 73 |racters\|).sed "s|
|000047c0| 2f 5e 58 2f 2f 22 20 3e | 72 74 64 2e 68 20 3c 3c |/^X//" >|rtd.h <<|
|000047d0| 27 45 4e 44 5f 4f 46 5f | 72 74 64 2e 68 27 0a 58 |'END_OF_|rtd.h'.X|
|000047e0| 73 74 72 75 63 74 20 63 | 6f 6c 6f 72 20 7b 0a 58 |struct c|olor {.X|
|000047f0| 69 6e 74 20 72 3b 69 6e | 74 20 67 3b 69 6e 74 20 |int r;in|t g;int |
|00004800| 62 3b 7d 3b 0a 58 0a 58 | 73 74 72 75 63 74 20 76 |b;};.X.X|struct v|
|00004810| 65 63 74 6f 72 20 7b 0a | 58 64 6f 75 62 6c 65 20 |ector {.|Xdouble |
|00004820| 78 3b 0a 58 64 6f 75 62 | 6c 65 20 79 3b 0a 58 64 |x;.Xdoub|le y;.Xd|
|00004830| 6f 75 62 6c 65 20 7a 3b | 0a 58 64 6f 75 62 6c 65 |ouble z;|.Xdouble|
|00004840| 20 6c 3b 0a 58 64 6f 75 | 62 6c 65 20 78 7a 6c 3b | l;.Xdou|ble xzl;|
|00004850| 7d 20 3b 0a 58 0a 58 73 | 74 72 75 63 74 20 72 61 |} ;.X.Xs|truct ra|
|00004860| 79 20 7b 0a 58 73 74 72 | 75 63 74 20 76 65 63 74 |y {.Xstr|uct vect|
|00004870| 6f 72 20 6f 72 67 3b 0a | 58 73 74 72 75 63 74 20 |or org;.|Xstruct |
|00004880| 76 65 63 74 6f 72 20 64 | 69 72 3b 7d 20 3b 0a 58 |vector d|ir;} ;.X|
|00004890| 0a 58 73 74 72 75 63 74 | 20 73 70 68 65 72 65 20 |.Xstruct| sphere |
|000048a0| 7b 0a 58 73 74 72 75 63 | 74 20 76 65 63 74 6f 72 |{.Xstruc|t vector|
|000048b0| 20 63 65 6e 74 3b 0a 58 | 64 6f 75 62 6c 65 20 72 | cent;.X|double r|
|000048c0| 61 64 3b 7d 20 3b 0a 58 | 0a 58 73 74 72 75 63 74 |ad;} ;.X|.Xstruct|
|000048d0| 20 62 61 6c 6c 20 7b 0a | 58 73 74 72 75 63 74 20 | ball {.|Xstruct |
|000048e0| 73 70 68 65 72 65 20 73 | 3b 0a 58 64 6f 75 62 6c |sphere s|;.Xdoubl|
|000048f0| 65 20 69 6f 72 3b 0a 58 | 64 6f 75 62 6c 65 20 72 |e ior;.X|double r|
|00004900| 66 72 3b 0a 58 64 6f 75 | 62 6c 65 20 72 66 6c 3b |fr;.Xdou|ble rfl;|
|00004910| 0a 58 64 6f 75 62 6c 65 | 20 64 69 66 3b 0a 58 64 |.Xdouble| dif;.Xd|
|00004920| 6f 75 62 6c 65 20 61 6d | 62 3b 0a 58 7d 3b 0a 58 |ouble am|b;.X};.X|
|00004930| 0a 58 73 74 72 75 63 74 | 20 6d 61 74 20 7b 0a 58 |.Xstruct| mat {.X|
|00004940| 73 74 72 75 63 74 20 76 | 65 63 74 6f 72 20 78 3b |struct v|ector x;|
|00004950| 20 20 2f 2a 20 66 69 72 | 73 74 20 21 72 6f 77 21 | /* fir|st !row!|
|00004960| 20 2a 2f 0a 58 73 74 72 | 75 63 74 20 76 65 63 74 | */.Xstr|uct vect|
|00004970| 6f 72 20 79 3b 20 20 2f | 2a 73 65 63 6f 6e 64 20 |or y; /|*second |
|00004980| 21 72 6f 77 21 20 2a 2f | 0a 58 73 74 72 75 63 74 |!row! */|.Xstruct|
|00004990| 20 76 65 63 74 6f 72 20 | 7a 3b 7d 3b 20 2f 2a 20 | vector |z;}; /* |
|000049a0| 74 68 69 72 64 20 21 72 | 6f 77 21 20 2a 2f 0a 58 |third !r|ow! */.X|
|000049b0| 0a 45 4e 44 5f 4f 46 5f | 72 74 64 2e 68 0a 69 66 |.END_OF_|rtd.h.if|
|000049c0| 20 74 65 73 74 20 34 33 | 34 20 2d 6e 65 20 60 77 | test 43|4 -ne `w|
|000049d0| 63 20 2d 63 20 3c 72 74 | 64 2e 68 60 3b 20 74 68 |c -c <rt|d.h`; th|
|000049e0| 65 6e 0a 20 20 20 20 65 | 63 68 6f 20 73 68 61 72 |en. e|cho shar|
|000049f0| 3a 20 5c 22 72 74 64 2e | 68 5c 22 20 75 6e 70 61 |: \"rtd.|h\" unpa|
|00004a00| 63 6b 65 64 20 77 69 74 | 68 20 77 72 6f 6e 67 20 |cked wit|h wrong |
|00004a10| 73 69 7a 65 21 0a 66 69 | 0a 23 20 65 6e 64 20 6f |size!.fi|.# end o|
|00004a20| 66 20 6f 76 65 72 77 72 | 69 74 69 6e 67 20 63 68 |f overwr|iting ch|
|00004a30| 65 63 6b 0a 66 69 0a 69 | 66 20 74 65 73 74 20 2d |eck.fi.i|f test -|
|00004a40| 66 20 73 68 61 64 65 2e | 63 20 2d 61 20 22 24 7b |f shade.|c -a "${|
|00004a50| 31 7d 22 20 21 3d 20 22 | 2d 63 22 20 3b 20 74 68 |1}" != "|-c" ; th|
|00004a60| 65 6e 20 0a 20 20 65 63 | 68 6f 20 73 68 61 72 3a |en . ec|ho shar:|
|00004a70| 20 57 69 6c 6c 20 6e 6f | 74 20 6f 76 65 72 2d 77 | Will no|t over-w|
|00004a80| 72 69 74 65 20 65 78 69 | 73 74 69 6e 67 20 66 69 |rite exi|sting fi|
|00004a90| 6c 65 20 5c 22 73 68 61 | 64 65 2e 63 5c 22 0a 65 |le \"sha|de.c\".e|
|00004aa0| 6c 73 65 0a 65 63 68 6f | 20 73 68 61 72 3a 20 45 |lse.echo| shar: E|
|00004ab0| 78 74 72 61 63 74 69 6e | 67 20 5c 22 73 68 61 64 |xtractin|g \"shad|
|00004ac0| 65 2e 63 5c 22 20 5c 28 | 33 34 35 34 20 63 68 61 |e.c\" \(|3454 cha|
|00004ad0| 72 61 63 74 65 72 73 5c | 29 0a 73 65 64 20 22 73 |racters\|).sed "s|
|00004ae0| 2f 5e 58 2f 2f 22 20 3e | 73 68 61 64 65 2e 63 20 |/^X//" >|shade.c |
|00004af0| 3c 3c 27 45 4e 44 5f 4f | 46 5f 73 68 61 64 65 2e |<<'END_O|F_shade.|
|00004b00| 63 27 0a 58 2f 2a 0a 58 | 20 2a 20 74 68 69 73 20 |c'.X/*.X| * this |
|00004b10| 73 75 62 72 6f 75 74 69 | 6e 65 20 64 6f 65 73 20 |subrouti|ne does |
|00004b20| 61 6c 6c 20 74 68 65 20 | 67 72 69 74 74 79 20 77 |all the |gritty w|
|00004b30| 6f 72 6b 2d 20 69 74 20 | 63 61 6c 63 75 6c 61 74 |ork- it |calculat|
|00004b40| 65 73 20 0a 58 20 2a 20 | 77 68 61 74 20 73 68 61 |es .X * |what sha|
|00004b50| 64 65 20 65 61 63 68 20 | 70 69 78 65 6c 20 73 68 |de each |pixel sh|
|00004b60| 6f 75 6c 64 20 62 65 2e | 20 49 20 6c 69 6b 65 20 |ould be.| I like |
|00004b70| 72 65 63 75 72 73 69 6f | 6e 2e 0a 58 20 2a 2f 0a |recursio|n..X */.|
|00004b80| 58 23 69 6e 63 6c 75 64 | 65 20 3c 6d 61 74 68 2e |X#includ|e <math.|
|00004b90| 68 3e 0a 58 23 69 6e 63 | 6c 75 64 65 20 22 72 74 |h>.X#inc|lude "rt|
|00004ba0| 64 2e 68 22 0a 58 23 69 | 6e 63 6c 75 64 65 20 22 |d.h".X#i|nclude "|
|00004bb0| 6d 61 63 72 6f 73 2e 68 | 22 0a 58 23 69 6e 63 6c |macros.h|".X#incl|
|00004bc0| 75 64 65 20 22 65 78 74 | 65 72 6e 2e 68 22 0a 58 |ude "ext|ern.h".X|
|00004bd0| 0a 58 69 6e 74 20 20 20 | 20 20 73 68 61 64 65 20 |.Xint | shade |
|00004be0| 28 72 29 0a 58 73 74 72 | 75 63 74 20 72 61 79 20 |(r).Xstr|uct ray |
|00004bf0| 2a 72 3b 0a 58 7b 0a 58 | 20 20 20 20 69 6e 74 20 |*r;.X{.X| int |
|00004c00| 20 20 20 20 69 2c 0a 58 | 20 20 20 20 20 20 20 20 | i,.X| |
|00004c10| 20 20 20 20 63 2c 0a 58 | 20 20 20 20 20 20 20 20 | c,.X| |
|00004c20| 20 20 20 20 72 65 66 72 | 61 63 74 20 28 29 3b 0a | refr|act ();.|
|00004c30| 58 20 20 20 20 73 74 72 | 75 63 74 20 72 61 79 20 |X str|uct ray |
|00004c40| 20 72 65 66 72 3b 0a 58 | 20 20 20 20 64 6f 75 62 | refr;.X| doub|
|00004c50| 6c 65 20 20 6c 67 68 74 | 2c 0a 58 20 20 20 20 20 |le lght|,.X |
|00004c60| 20 20 20 20 20 20 20 78 | 2c 0a 58 20 20 20 20 20 | x|,.X |
|00004c70| 20 20 20 20 20 20 20 79 | 2c 0a 58 20 20 20 20 20 | y|,.X |
|00004c80| 20 20 20 20 20 20 20 7a | 2c 0a 58 20 20 20 20 20 | z|,.X |
|00004c90| 20 20 20 20 20 20 20 6c | 2c 0a 58 20 20 20 20 20 | l|,.X |
|00004ca0| 20 20 20 20 20 20 20 6b | 2c 0a 58 20 20 20 20 20 | k|,.X |
|00004cb0| 20 20 20 20 20 20 20 64 | 6f 74 20 28 29 2c 20 66 | d|ot (), f|
|00004cc0| 69 6e 64 20 28 29 2c 20 | 73 68 61 64 6f 77 20 28 |ind (), |shadow (|
|00004cd0| 29 3b 0a 58 20 20 20 20 | 69 6e 74 20 20 20 20 20 |);.X |int |
|00004ce0| 73 78 2c 0a 58 20 20 20 | 20 20 20 20 20 20 20 20 |sx,.X | |
|00004cf0| 20 73 79 3b 0a 58 20 20 | 20 20 64 6f 75 62 6c 65 | sy;.X | double|
|00004d00| 20 20 73 74 75 70 69 64 | 3b 0a 58 20 20 20 20 73 | stupid|;.X s|
|00004d10| 74 72 75 63 74 20 76 65 | 63 74 6f 72 20 20 20 6e |truct ve|ctor n|
|00004d20| 65 77 2c 0a 58 20 20 20 | 20 20 20 20 20 20 20 20 |ew,.X | |
|00004d30| 20 20 20 20 20 20 20 20 | 20 6e 6f 72 6d 3b 0a 58 | | norm;.X|
|00004d40| 20 20 20 20 73 74 72 75 | 63 74 20 6d 61 74 20 20 | stru|ct mat |
|00004d50| 74 72 61 6e 73 3b 0a 58 | 20 20 20 20 73 74 72 75 |trans;.X| stru|
|00004d60| 63 74 20 73 70 68 65 72 | 65 20 20 20 73 73 3b 0a |ct spher|e ss;.|
|00004d70| 58 20 20 20 20 69 66 20 | 28 2b 2b 6c 65 76 65 6c |X if |(++level|
|00004d80| 20 3c 3d 20 4c 45 56 45 | 4c 29 20 7b 0a 58 09 63 | <= LEVE|L) {.X.c|
|00004d90| 20 3d 20 2d 31 3b 0a 58 | 09 6c 20 3d 20 48 55 47 | = -1;.X|.l = HUG|
|00004da0| 45 3b 0a 58 2f 2a 20 67 | 65 74 20 76 65 63 74 6f |E;.X/* g|et vecto|
|00004db0| 72 20 6c 65 6e 67 74 68 | 20 61 6e 64 20 78 7a 20 |r length| and xz |
|00004dc0| 63 6f 6d 70 6f 6e 65 6e | 74 20 66 6f 72 20 6d 74 |componen|t for mt|
|00004dd0| 28 29 20 2a 2f 0a 58 09 | 72 20 2d 3e 20 64 69 72 |() */.X.|r -> dir|
|00004de0| 2e 6c 20 3d 20 4c 45 4e | 20 28 72 20 2d 3e 20 64 |.l = LEN| (r -> d|
|00004df0| 69 72 29 3b 0a 58 09 72 | 20 2d 3e 20 64 69 72 2e |ir);.X.r| -> dir.|
|00004e00| 78 7a 6c 20 3d 20 58 5a | 4c 20 28 72 20 2d 3e 20 |xzl = XZ|L (r -> |
|00004e10| 64 69 72 29 3b 0a 58 2f | 2a 20 6d 61 6b 65 20 61 |dir);.X/|* make a|
|00004e20| 20 74 72 61 6e 73 66 6f | 72 6d 20 6d 61 74 72 69 | transfo|rm matri|
|00004e30| 78 20 74 68 61 74 20 72 | 6f 74 61 74 65 73 20 73 |x that r|otates s|
|00004e40| 6f 6d 65 74 68 69 6e 67 | 20 69 6e 20 73 70 61 63 |omething| in spac|
|00004e50| 65 20 73 6f 0a 58 20 20 | 20 74 68 61 74 20 74 68 |e so.X | that th|
|00004e60| 65 20 72 61 79 20 77 69 | 6c 6c 20 62 65 20 61 6c |e ray wi|ll be al|
|00004e70| 69 67 6e 65 64 20 77 69 | 74 68 20 74 68 65 20 78 |igned wi|th the x|
|00004e80| 20 61 78 69 73 20 2a 2f | 0a 58 09 6d 74 20 28 26 | axis */|.X.mt (&|
|00004e90| 28 72 20 2d 3e 20 64 69 | 72 29 2c 20 26 74 72 61 |(r -> di|r), &tra|
|00004ea0| 6e 73 29 3b 0a 58 0a 58 | 2f 2a 20 66 6f 72 20 73 |ns);.X.X|/* for s|
|00004eb0| 74 61 72 74 65 72 73 20 | 77 65 20 66 69 6e 64 20 |tarters |we find |
|00004ec0| 6f 75 74 20 77 68 65 74 | 68 65 72 20 77 65 20 68 |out whet|her we h|
|00004ed0| 69 74 20 61 6e 79 74 68 | 69 6e 67 2e 20 2a 2f 0a |it anyth|ing. */.|
|00004ee0| 58 09 66 6f 72 20 28 69 | 20 3d 20 30 3b 20 69 20 |X.for (i| = 0; i |
|00004ef0| 3c 20 6e 6f 62 3b 20 69 | 2b 2b 29 20 7b 0a 58 09 |< nob; i|++) {.X.|
|00004f00| 20 20 20 20 73 73 2e 72 | 61 64 20 3d 20 62 6c 5b | ss.r|ad = bl[|
|00004f10| 69 5d 20 2d 3e 20 73 2e | 72 61 64 3b 0a 58 09 20 |i] -> s.|rad;.X. |
|00004f20| 20 20 20 53 56 20 28 73 | 73 2e 63 65 6e 74 2c 20 | SV (s|s.cent, |
|00004f30| 62 6c 5b 69 5d 20 2d 3e | 20 73 2e 63 65 6e 74 2c |bl[i] ->| s.cent,|
|00004f40| 20 72 20 2d 3e 20 6f 72 | 67 29 3b 0a 58 09 20 20 | r -> or|g);.X. |
|00004f50| 20 20 69 66 20 28 28 6b | 20 3d 20 66 69 6e 64 20 | if ((k| = find |
|00004f60| 28 26 74 72 61 6e 73 2c | 20 26 73 73 29 29 20 3e |(&trans,| &ss)) >|
|00004f70| 20 30 2e 30 20 26 26 20 | 6b 20 3c 20 6c 29 20 7b | 0.0 && |k < l) {|
|00004f80| 0a 58 09 09 63 20 3d 20 | 69 3b 0a 58 09 09 6c 20 |.X..c = |i;.X..l |
|00004f90| 3d 20 6b 3b 0a 58 09 20 | 20 20 20 7d 0a 58 09 7d |= k;.X. | }.X.}|
|00004fa0| 0a 58 09 69 66 20 28 63 | 20 3e 3d 20 30 20 26 26 |.X.if (c| >= 0 &&|
|00004fb0| 20 28 6c 20 2a 20 74 72 | 61 6e 73 2e 78 2e 79 20 | (l * tr|ans.x.y |
|00004fc0| 2b 20 72 20 2d 3e 20 6f | 72 67 2e 79 29 20 3e 20 |+ r -> o|rg.y) > |
|00004fd0| 30 2e 30 29 20 7b 0a 58 | 09 09 09 09 2f 2a 20 57 |0.0) {.X|..../* W|
|00004fe0| 45 20 48 49 54 20 53 4f | 4d 45 54 48 49 4e 47 20 |E HIT SO|METHING |
|00004ff0| 2a 2f 0a 58 09 20 20 20 | 20 4d 56 20 28 6c 20 2a |*/.X. | MV (l *|
|00005000| 20 74 72 61 6e 73 2e 78 | 2e 78 2c 20 6c 20 2a 20 | trans.x|.x, l * |
|00005010| 74 72 61 6e 73 2e 78 2e | 79 2c 20 6c 20 2a 20 74 |trans.x.|y, l * t|
|00005020| 72 61 6e 73 2e 78 2e 7a | 2c 20 6e 65 77 29 3b 0a |rans.x.z|, new);.|
|00005030| 58 09 20 20 20 20 6e 65 | 77 2e 6c 3d 6c 3b 0a 58 |X. ne|w.l=l;.X|
|00005040| 2f 2a 20 6d 6f 76 65 20 | 74 68 65 20 6e 65 77 20 |/* move |the new |
|00005050| 6f 72 67 69 6e 20 6f 66 | 20 74 68 65 20 72 61 79 |orgin of| the ray|
|00005060| 20 74 6f 20 74 68 65 20 | 69 6e 74 65 72 73 65 63 | to the |intersec|
|00005070| 74 69 6f 6e 20 2a 2f 0a | 58 09 20 20 20 20 41 56 |tion */.|X. AV|
|00005080| 20 28 72 65 66 72 2e 6f | 72 67 2c 20 6e 65 77 2c | (refr.o|rg, new,|
|00005090| 20 72 20 2d 3e 20 6f 72 | 67 29 3b 0a 58 09 20 20 | r -> or|g);.X. |
|000050a0| 20 20 41 56 20 28 72 20 | 2d 3e 20 6f 72 67 2c 20 | AV (r |-> org, |
|000050b0| 6e 65 77 2c 20 72 20 2d | 3e 20 6f 72 67 29 3b 0a |new, r -|> org);.|
|000050c0| 58 09 20 20 20 20 4d 56 | 20 28 72 20 2d 3e 20 64 |X. MV| (r -> d|
|000050d0| 69 72 2e 78 2c 20 72 20 | 2d 3e 20 64 69 72 2e 79 |ir.x, r |-> dir.y|
|000050e0| 2c 20 72 20 2d 3e 20 64 | 69 72 2e 7a 2c 20 72 65 |, r -> d|ir.z, re|
|000050f0| 66 72 2e 64 69 72 29 3b | 0a 58 2f 2a 20 67 65 74 |fr.dir);|.X/* get|
|00005100| 20 61 20 6e 6f 72 6d 61 | 6c 20 76 65 63 74 6f 72 | a norma|l vector|
|00005110| 20 66 6f 72 20 74 68 65 | 20 69 6e 74 65 72 73 65 | for the| interse|
|00005120| 63 74 69 6f 6e 20 70 6f | 69 6e 74 20 2a 2f 0a 58 |ction po|int */.X|
|00005130| 09 20 20 20 20 53 56 20 | 28 6e 6f 72 6d 2c 20 72 |. SV |(norm, r|
|00005140| 20 2d 3e 20 6f 72 67 2c | 20 62 6c 5b 63 5d 20 2d | -> org,| bl[c] -|
|00005150| 3e 20 73 2e 63 65 6e 74 | 29 3b 0a 58 09 20 20 20 |> s.cent|);.X. |
|00005160| 20 6e 6f 72 6d 2e 6c 3d | 62 6c 5b 63 5d 20 2d 3e | norm.l=|bl[c] ->|
|00005170| 73 2e 72 61 64 3b 0a 58 | 0a 58 2f 2a 20 61 6d 62 |s.rad;.X|.X/* amb|
|00005180| 69 65 6e 74 20 6c 69 67 | 68 74 69 6e 67 20 2a 2f |ient lig|hting */|
|00005190| 0a 58 09 20 20 20 20 6c | 67 68 74 20 3d 20 32 30 |.X. l|ght = 20|
|000051a0| 30 2e 30 20 2a 20 62 6c | 5b 63 5d 20 2d 3e 20 61 |0.0 * bl|[c] -> a|
|000051b0| 6d 62 3b 0a 58 0a 58 2f | 2a 20 73 68 61 64 65 64 |mb;.X.X/|* shaded|
|000051c0| 20 6c 69 67 68 74 69 6e | 67 20 28 64 69 66 66 75 | lightin|g (diffu|
|000051d0| 73 65 29 2e 20 73 75 62 | 72 6f 75 74 69 6e 65 20 |se). sub|routine |
|000051e0| 73 68 61 64 6f 77 20 69 | 73 20 69 6e 20 66 69 6e |shadow i|s in fin|
|000051f0| 64 2e 63 20 2a 2f 0a 58 | 09 20 20 20 20 69 66 20 |d.c */.X|. if |
|00005200| 28 62 6c 5b 63 5d 20 2d | 3e 20 64 69 66 20 21 3d |(bl[c] -|> dif !=|
|00005210| 20 30 2e 30 29 20 7b 0a | 58 09 09 53 56 20 28 6e | 0.0) {.|X..SV (n|
|00005220| 65 77 2c 20 6c 73 2e 63 | 65 6e 74 2c 20 72 20 2d |ew, ls.c|ent, r -|
|00005230| 3e 20 6f 72 67 29 3b 0a | 58 09 09 6e 65 77 2e 6c |> org);.|X..new.l|
|00005240| 20 3d 20 4c 45 4e 28 6e | 65 77 29 3b 0a 58 09 09 | = LEN(n|ew);.X..|
|00005250| 69 66 20 28 28 6b 20 3d | 20 44 4f 54 20 28 6e 65 |if ((k =| DOT (ne|
|00005260| 77 2c 20 6e 6f 72 6d 29 | 29 20 3e 20 30 2e 30 29 |w, norm)|) > 0.0)|
|00005270| 0a 58 09 09 20 20 20 20 | 6c 67 68 74 20 2b 3d 20 |.X.. |lght += |
|00005280| 62 6c 5b 63 5d 20 2d 3e | 20 64 69 66 20 2a 20 73 |bl[c] ->| dif * s|
|00005290| 68 61 64 6f 77 20 28 26 | 28 72 20 2d 3e 20 6f 72 |hadow (&|(r -> or|
|000052a0| 67 29 29 20 2a 20 6b 20 | 2f 20 28 6e 65 77 2e 6c |g)) * k |/ (new.l|
|000052b0| 29 20 2f 20 28 6e 6f 72 | 6d 2e 6c 29 3b 0a 58 09 |) / (nor|m.l);.X.|
|000052c0| 20 20 20 20 7d 0a 58 0a | 58 2f 2a 72 65 66 6c 65 | }.X.|X/*refle|
|000052d0| 63 74 69 6f 6e 2e 2e 2e | 20 65 61 73 79 20 2a 2f |ction...| easy */|
|000052e0| 0a 58 09 20 20 20 20 69 | 66 20 28 62 6c 5b 63 5d |.X. i|f (bl[c]|
|000052f0| 20 2d 3e 20 72 66 6c 20 | 21 3d 20 30 2e 30 29 20 | -> rfl |!= 0.0) |
|00005300| 7b 0a 58 2f 2a 20 6d 61 | 6b 65 20 74 68 65 20 6e |{.X/* ma|ke the n|
|00005310| 6f 72 6d 61 6c 20 75 6e | 69 74 20 6c 65 6e 67 74 |ormal un|it lengt|
|00005320| 68 20 2a 2f 0a 58 09 09 | 53 43 4d 4c 54 20 28 28 |h */.X..|SCMLT ((|
|00005330| 31 2e 30 20 2f 20 6e 6f | 72 6d 2e 6c 29 2c 20 6e |1.0 / no|rm.l), n|
|00005340| 6f 72 6d 29 3b 0a 58 2f | 2a 20 67 65 74 20 74 68 |orm);.X/|* get th|
|00005350| 65 20 6c 65 6e 67 74 68 | 20 6f 66 20 74 68 65 20 |e length| of the |
|00005360| 72 61 79 27 73 20 63 6f | 6d 70 6f 6e 65 6e 74 20 |ray's co|mponent |
|00005370| 69 6e 20 74 68 65 20 6e | 6f 72 6d 61 6c 20 64 69 |in the n|ormal di|
|00005380| 72 65 63 74 69 6f 6e 20 | 2a 2f 0a 58 09 09 73 74 |rection |*/.X..st|
|00005390| 75 70 69 64 20 3d 20 32 | 2e 30 20 2a 20 44 4f 54 |upid = 2|.0 * DOT|
|000053a0| 20 28 6e 6f 72 6d 2c 20 | 72 20 2d 3e 20 64 69 72 | (norm, |r -> dir|
|000053b0| 29 3b 0a 58 09 09 53 43 | 4d 4c 54 20 28 73 74 75 |);.X..SC|MLT (stu|
|000053c0| 70 69 64 2c 20 6e 6f 72 | 6d 29 3b 0a 58 2f 2a 20 |pid, nor|m);.X/* |
|000053d0| 73 75 62 74 72 61 63 74 | 20 64 6f 75 62 6c 65 20 |subtract| double |
|000053e0| 74 68 65 20 6e 6f 72 6d | 61 6c 20 63 6f 6d 70 6f |the norm|al compo|
|000053f0| 6e 65 6e 74 2d 20 21 72 | 65 66 6c 65 63 74 69 6f |nent- !r|eflectio|
|00005400| 6e 21 20 2a 2f 0a 58 09 | 09 53 56 20 28 72 20 2d |n! */.X.|.SV (r -|
|00005410| 3e 20 64 69 72 2c 20 72 | 20 2d 3e 20 64 69 72 2c |> dir, r| -> dir,|
|00005420| 20 6e 6f 72 6d 29 3b 0a | 58 09 09 6c 67 68 74 20 | norm);.|X..lght |
|00005430| 2b 3d 20 62 6c 5b 63 5d | 20 2d 3e 20 72 66 6c 20 |+= bl[c]| -> rfl |
|00005440| 2a 20 28 64 6f 75 62 6c | 65 29 20 73 68 61 64 65 |* (doubl|e) shade|
|00005450| 20 28 72 29 3b 0a 58 09 | 20 20 20 20 7d 0a 58 0a | (r);.X.| }.X.|
|00005460| 58 2f 2a 20 72 65 66 72 | 61 63 74 69 6f 6e 2e 20 |X/* refr|action. |
|00005470| 74 68 69 73 20 69 73 20 | 75 67 6c 79 2c 20 77 68 |this is |ugly, wh|
|00005480| 69 63 68 20 69 73 20 77 | 68 79 20 49 20 63 68 6f |ich is w|hy I cho|
|00005490| 6f 73 65 20 74 6f 20 64 | 65 61 6c 20 77 69 74 68 |ose to d|eal with|
|000054a0| 0a 58 20 20 20 69 74 20 | 69 6e 20 69 74 27 73 20 |.X it |in it's |
|000054b0| 6f 77 6e 20 73 75 62 72 | 6f 75 74 69 6e 65 20 77 |own subr|outine w|
|000054c0| 68 69 63 68 20 63 6f 6d | 65 73 20 61 66 74 65 72 |hich com|es after|
|000054d0| 20 74 68 69 73 20 6f 6e | 65 20 2a 2f 0a 58 09 20 | this on|e */.X. |
|000054e0| 20 20 20 69 66 20 28 62 | 6c 5b 63 5d 20 2d 3e 20 | if (b|l[c] -> |
|000054f0| 72 66 72 20 21 3d 20 30 | 2e 30 29 20 7b 0a 58 09 |rfr != 0|.0) {.X.|
|00005500| 09 6c 67 68 74 20 2b 3d | 20 62 6c 5b 63 5d 20 2d |.lght +=| bl[c] -|
|00005510| 3e 20 72 66 72 20 2a 20 | 28 64 6f 75 62 6c 65 29 |> rfr * |(double)|
|00005520| 20 72 65 66 72 61 63 74 | 20 28 26 72 65 66 72 2c | refract| (&refr,|
|00005530| 20 62 6c 5b 63 5d 29 3b | 0a 58 09 20 20 20 20 7d | bl[c]);|.X. }|
|00005540| 0a 58 0a 58 0a 58 0a 58 | 09 7d 0a 58 09 65 6c 73 |.X.X.X.X|.}.X.els|
|00005550| 65 20 7b 09 09 09 2f 2a | 20 68 69 74 20 6e 6f 20 |e {.../*| hit no |
|00005560| 6f 62 6a 65 63 74 73 2e | 2e 2e 20 2a 2f 0a 58 09 |objects.|.. */.X.|
|00005570| 20 20 20 20 69 66 20 28 | 28 72 20 2d 3e 20 64 69 | if (|(r -> di|
|00005580| 72 2e 79 29 20 3c 20 30 | 2e 30 29 20 7b 2f 2a 20 |r.y) < 0|.0) {/* |
|00005590| 63 72 6f 73 73 65 73 20 | 66 6c 6f 6f 72 20 2a 2f |crosses |floor */|
|000055a0| 0a 58 09 09 7a 20 3d 20 | 2d 28 72 20 2d 3e 20 6f |.X..z = |-(r -> o|
|000055b0| 72 67 2e 79 29 20 2f 20 | 28 72 20 2d 3e 20 64 69 |rg.y) / |(r -> di|
|000055c0| 72 2e 79 29 3b 0a 58 09 | 09 28 72 20 2d 3e 20 6f |r.y);.X.|.(r -> o|
|000055d0| 72 67 2e 78 29 20 2b 3d | 20 7a 20 2a 20 28 72 20 |rg.x) +=| z * (r |
|000055e0| 2d 3e 20 64 69 72 2e 78 | 29 3b 0a 58 09 09 28 72 |-> dir.x|);.X..(r|
|000055f0| 20 2d 3e 20 6f 72 67 2e | 7a 29 20 2b 3d 20 7a 20 | -> org.|z) += z |
|00005600| 2a 20 28 72 20 2d 3e 20 | 64 69 72 2e 7a 29 3b 0a |* (r -> |dir.z);.|
|00005610| 58 09 09 28 72 20 2d 3e | 20 6f 72 67 2e 79 29 20 |X..(r ->| org.y) |
|00005620| 3d 20 30 2e 30 3b 0a 58 | 0a 58 09 09 53 56 20 28 |= 0.0;.X|.X..SV (|
|00005630| 6e 65 77 2c 20 6c 73 2e | 63 65 6e 74 2c 20 72 20 |new, ls.|cent, r |
|00005640| 2d 3e 20 6f 72 67 29 3b | 0a 58 09 09 6e 65 77 2e |-> org);|.X..new.|
|00005650| 6c 20 3d 20 4c 45 4e 28 | 6e 65 77 29 3b 0a 58 09 |l = LEN(|new);.X.|
|00005660| 09 73 78 20 3d 20 28 69 | 6e 74 29 20 28 72 20 2d |.sx = (i|nt) (r -|
|00005670| 3e 20 6f 72 67 2e 78 20 | 2f 20 31 2e 35 29 20 25 |> org.x |/ 1.5) %|
|00005680| 20 78 73 75 65 3b 0a 58 | 09 09 69 66 20 28 73 78 | xsue;.X|..if (sx|
|00005690| 20 3c 20 30 29 0a 58 09 | 09 20 20 20 20 73 78 20 | < 0).X.|. sx |
|000056a0| 2b 3d 20 78 73 75 65 3b | 0a 58 09 09 73 79 20 3d |+= xsue;|.X..sy =|
|000056b0| 20 2d 28 69 6e 74 29 20 | 28 72 20 2d 3e 20 6f 72 | -(int) |(r -> or|
|000056c0| 67 2e 7a 20 2f 20 31 2e | 35 29 20 25 20 79 73 75 |g.z / 1.|5) % ysu|
|000056d0| 65 3b 0a 58 09 09 69 66 | 20 28 73 79 20 3c 20 30 |e;.X..if| (sy < 0|
|000056e0| 29 0a 58 09 09 20 20 20 | 20 73 79 20 2b 3d 20 79 |).X.. | sy += y|
|000056f0| 73 75 65 3b 0a 58 09 09 | 6c 67 68 74 20 3d 20 28 |sue;.X..|lght = (|
|00005700| 73 61 6d 20 2a 20 73 75 | 7a 69 65 5b 73 78 5d 5b |sam * su|zie[sx][|
|00005710| 73 79 5d 20 2b 20 31 2e | 30 20 2d 20 73 61 6d 29 |sy] + 1.|0 - sam)|
|00005720| 20 2a 20 28 30 2e 38 20 | 2a 0a 58 09 09 09 73 68 | * (0.8 |*.X...sh|
|00005730| 61 64 6f 77 20 28 26 28 | 72 20 2d 3e 20 6f 72 67 |adow (&(|r -> org|
|00005740| 29 29 20 2a 20 28 6e 65 | 77 2e 79 29 20 2f 20 28 |)) * (ne|w.y) / (|
|00005750| 6e 65 77 2e 6c 29 20 2b | 20 34 30 2e 30 29 3b 0a |new.l) +| 40.0);.|
|00005760| 58 0a 58 0a 58 09 20 20 | 20 20 7d 0a 58 09 20 20 |X.X.X. | }.X. |
|00005770| 20 20 65 6c 73 65 20 7b | 09 09 2f 2a 20 63 68 65 | else {|../* che|
|00005780| 63 6b 20 74 6f 20 73 65 | 65 20 69 66 20 69 74 20 |ck to se|e if it |
|00005790| 68 69 74 20 6c 69 67 68 | 74 73 6f 75 72 63 65 20 |hit ligh|tsource |
|000057a0| 2a 2f 0a 58 09 09 53 56 | 20 28 73 73 2e 63 65 6e |*/.X..SV| (ss.cen|
|000057b0| 74 2c 20 6c 73 2e 63 65 | 6e 74 2c 20 72 20 2d 3e |t, ls.ce|nt, r ->|
|000057c0| 20 6f 72 67 29 3b 0a 58 | 09 09 73 73 2e 72 61 64 | org);.X|..ss.rad|
|000057d0| 20 3d 20 6c 73 2e 72 61 | 64 3b 0a 58 09 09 69 66 | = ls.ra|d;.X..if|
|000057e0| 20 28 66 69 6e 64 20 28 | 26 74 72 61 6e 73 2c 20 | (find (|&trans, |
|000057f0| 26 28 73 73 2e 63 65 6e | 74 29 29 20 3e 20 30 2e |&(ss.cen|t)) > 0.|
|00005800| 30 29 0a 58 09 09 20 20 | 20 20 6c 67 68 74 20 3d |0).X.. | lght =|
|00005810| 20 32 35 35 3b 0a 58 09 | 09 65 6c 73 65 0a 58 09 | 255;.X.|.else.X.|
|00005820| 09 20 20 20 20 6c 67 68 | 74 20 3d 20 30 3b 0a 58 |. lgh|t = 0;.X|
|00005830| 09 20 20 20 20 7d 0a 58 | 09 7d 0a 58 20 20 20 20 |. }.X|.}.X |
|00005840| 7d 0a 58 2f 2a 20 74 6f | 20 6d 61 6e 79 20 6c 65 |}.X/* to| many le|
|00005850| 76 65 6c 73 20 72 65 74 | 75 72 6e 20 30 20 63 61 |vels ret|urn 0 ca|
|00005860| 75 73 65 20 69 74 20 73 | 68 6f 75 6c 64 6e 27 74 |use it s|houldn't|
|00005870| 20 6d 61 74 74 65 72 20 | 2a 2f 0a 58 20 20 20 20 | matter |*/.X |
|00005880| 65 6c 73 65 0a 58 09 6c | 67 68 74 20 3d 20 30 3b |else.X.l|ght = 0;|
|00005890| 0a 58 20 20 20 20 6c 65 | 76 65 6c 2d 2d 3b 0a 58 |.X le|vel--;.X|
|000058a0| 20 20 20 20 69 66 20 28 | 6c 67 68 74 20 3c 20 30 | if (|lght < 0|
|000058b0| 2e 30 29 0a 58 09 6c 67 | 68 74 20 3d 20 30 2e 30 |.0).X.lg|ht = 0.0|
|000058c0| 3b 0a 58 20 20 20 20 69 | 66 20 28 6c 67 68 74 20 |;.X i|f (lght |
|000058d0| 3e 20 32 35 35 2e 30 29 | 0a 58 09 6c 67 68 74 20 |> 255.0)|.X.lght |
|000058e0| 3d 20 32 35 35 2e 30 3b | 0a 58 20 20 20 20 72 65 |= 255.0;|.X re|
|000058f0| 74 75 72 6e 20 28 28 69 | 6e 74 29 20 6c 67 68 74 |turn ((i|nt) lght|
|00005900| 29 3b 0a 58 7d 0a 45 4e | 44 5f 4f 46 5f 73 68 61 |);.X}.EN|D_OF_sha|
|00005910| 64 65 2e 63 0a 69 66 20 | 74 65 73 74 20 33 34 35 |de.c.if |test 345|
|00005920| 34 20 2d 6e 65 20 60 77 | 63 20 2d 63 20 3c 73 68 |4 -ne `w|c -c <sh|
|00005930| 61 64 65 2e 63 60 3b 20 | 74 68 65 6e 0a 20 20 20 |ade.c`; |then. |
|00005940| 20 65 63 68 6f 20 73 68 | 61 72 3a 20 5c 22 73 68 | echo sh|ar: \"sh|
|00005950| 61 64 65 2e 63 5c 22 20 | 75 6e 70 61 63 6b 65 64 |ade.c\" |unpacked|
|00005960| 20 77 69 74 68 20 77 72 | 6f 6e 67 20 73 69 7a 65 | with wr|ong size|
|00005970| 21 0a 66 69 0a 23 20 65 | 6e 64 20 6f 66 20 6f 76 |!.fi.# e|nd of ov|
|00005980| 65 72 77 72 69 74 69 6e | 67 20 63 68 65 63 6b 0a |erwritin|g check.|
|00005990| 66 69 0a 69 66 20 74 65 | 73 74 20 2d 66 20 73 75 |fi.if te|st -f su|
|000059a0| 70 70 6f 72 74 2e 63 20 | 2d 61 20 22 24 7b 31 7d |pport.c |-a "${1}|
|000059b0| 22 20 21 3d 20 22 2d 63 | 22 20 3b 20 74 68 65 6e |" != "-c|" ; then|
|000059c0| 20 0a 20 20 65 63 68 6f | 20 73 68 61 72 3a 20 57 | . echo| shar: W|
|000059d0| 69 6c 6c 20 6e 6f 74 20 | 6f 76 65 72 2d 77 72 69 |ill not |over-wri|
|000059e0| 74 65 20 65 78 69 73 74 | 69 6e 67 20 66 69 6c 65 |te exist|ing file|
|000059f0| 20 5c 22 73 75 70 70 6f | 72 74 2e 63 5c 22 0a 65 | \"suppo|rt.c\".e|
|00005a00| 6c 73 65 0a 65 63 68 6f | 20 73 68 61 72 3a 20 45 |lse.echo| shar: E|
|00005a10| 78 74 72 61 63 74 69 6e | 67 20 5c 22 73 75 70 70 |xtractin|g \"supp|
|00005a20| 6f 72 74 2e 63 5c 22 20 | 5c 28 38 33 34 20 63 68 |ort.c\" |\(834 ch|
|00005a30| 61 72 61 63 74 65 72 73 | 5c 29 0a 73 65 64 20 22 |aracters|\).sed "|
|00005a40| 73 2f 5e 58 2f 2f 22 20 | 3e 73 75 70 70 6f 72 74 |s/^X//" |>support|
|00005a50| 2e 63 20 3c 3c 27 45 4e | 44 5f 4f 46 5f 73 75 70 |.c <<'EN|D_OF_sup|
|00005a60| 70 6f 72 74 2e 63 27 0a | 58 2f 2a 0a 58 20 2a 20 |port.c'.|X/*.X * |
|00005a70| 20 20 20 73 75 70 70 6f | 72 74 69 76 65 20 73 75 | suppo|rtive su|
|00005a80| 62 72 6f 75 74 69 6e 65 | 73 2e 2e 2e 0a 58 20 2a |broutine|s....X *|
|00005a90| 2f 0a 58 0a 58 23 69 6e | 63 6c 75 64 65 20 3c 6d |/.X.X#in|clude <m|
|00005aa0| 61 74 68 2e 68 3e 0a 58 | 23 69 6e 63 6c 75 64 65 |ath.h>.X|#include|
|00005ab0| 20 3c 73 74 64 69 6f 2e | 68 3e 0a 58 23 69 6e 63 | <stdio.|h>.X#inc|
|00005ac0| 6c 75 64 65 20 22 72 74 | 64 2e 68 22 0a 58 23 69 |lude "rt|d.h".X#i|
|00005ad0| 6e 63 6c 75 64 65 20 22 | 65 78 74 65 72 6e 2e 68 |nclude "|extern.h|
|00005ae0| 22 0a 58 0a 58 0a 58 6d | 74 20 28 76 65 63 2c 20 |".X.X.Xm|t (vec, |
|00005af0| 74 72 61 6e 73 29 0a 58 | 73 74 72 75 63 74 20 76 |trans).X|struct v|
|00005b00| 65 63 74 6f 72 20 20 2a | 76 65 63 3b 0a 58 73 74 |ector *|vec;.Xst|
|00005b10| 72 75 63 74 20 6d 61 74 | 20 2a 74 72 61 6e 73 3b |ruct mat| *trans;|
|00005b20| 0a 58 7b 0a 58 20 20 20 | 20 69 66 20 28 76 65 63 |.X{.X | if (vec|
|00005b30| 20 2d 3e 20 78 7a 6c 20 | 3d 3d 20 30 2e 30 29 20 | -> xzl |== 0.0) |
|00005b40| 7b 0a 58 09 74 72 61 6e | 73 20 2d 3e 20 78 2e 78 |{.X.tran|s -> x.x|
|00005b50| 20 3d 20 30 2e 30 3b 0a | 58 09 74 72 61 6e 73 20 | = 0.0;.|X.trans |
|00005b60| 2d 3e 20 78 2e 79 20 3d | 20 31 2e 30 3b 0a 58 09 |-> x.y =| 1.0;.X.|
|00005b70| 74 72 61 6e 73 20 2d 3e | 20 78 2e 7a 20 3d 20 30 |trans ->| x.z = 0|
|00005b80| 2e 30 3b 0a 58 09 74 72 | 61 6e 73 20 2d 3e 20 79 |.0;.X.tr|ans -> y|
|00005b90| 2e 78 20 3d 20 2d 31 2e | 30 3b 0a 58 09 74 72 61 |.x = -1.|0;.X.tra|
|00005ba0| 6e 73 20 2d 3e 20 79 2e | 79 20 3d 20 30 2e 30 3b |ns -> y.|y = 0.0;|
|00005bb0| 0a 58 09 74 72 61 6e 73 | 20 2d 3e 20 79 2e 7a 20 |.X.trans| -> y.z |
|00005bc0| 3d 20 30 2e 30 3b 0a 58 | 09 74 72 61 6e 73 20 2d |= 0.0;.X|.trans -|
|00005bd0| 3e 20 7a 2e 78 20 3d 20 | 30 2e 30 3b 0a 58 09 74 |> z.x = |0.0;.X.t|
|00005be0| 72 61 6e 73 20 2d 3e 20 | 7a 2e 79 20 3d 20 30 2e |rans -> |z.y = 0.|
|00005bf0| 30 3b 0a 58 09 74 72 61 | 6e 73 20 2d 3e 20 7a 2e |0;.X.tra|ns -> z.|
|00005c00| 7a 20 3d 20 31 2e 30 3b | 0a 58 20 20 20 20 7d 0a |z = 1.0;|.X }.|
|00005c10| 58 20 20 20 20 65 6c 73 | 65 20 7b 0a 58 09 74 72 |X els|e {.X.tr|
|00005c20| 61 6e 73 20 2d 3e 20 78 | 2e 78 20 3d 20 28 76 65 |ans -> x|.x = (ve|
|00005c30| 63 20 2d 3e 20 78 29 20 | 2f 20 28 76 65 63 20 2d |c -> x) |/ (vec -|
|00005c40| 3e 20 6c 29 3b 0a 58 09 | 74 72 61 6e 73 20 2d 3e |> l);.X.|trans ->|
|00005c50| 20 78 2e 79 20 3d 20 28 | 76 65 63 20 2d 3e 20 79 | x.y = (|vec -> y|
|00005c60| 29 20 2f 20 28 76 65 63 | 20 2d 3e 20 6c 29 3b 0a |) / (vec| -> l);.|
|00005c70| 58 09 74 72 61 6e 73 20 | 2d 3e 20 78 2e 7a 20 3d |X.trans |-> x.z =|
|00005c80| 20 28 76 65 63 20 2d 3e | 20 7a 29 20 2f 20 28 76 | (vec ->| z) / (v|
|00005c90| 65 63 20 2d 3e 20 6c 29 | 3b 0a 58 09 74 72 61 6e |ec -> l)|;.X.tran|
|00005ca0| 73 20 2d 3e 20 79 2e 78 | 20 3d 20 2d 28 76 65 63 |s -> y.x| = -(vec|
|00005cb0| 20 2d 3e 20 78 29 20 2a | 20 28 76 65 63 20 2d 3e | -> x) *| (vec ->|
|00005cc0| 20 79 29 20 2f 20 28 28 | 76 65 63 20 2d 3e 20 6c | y) / ((|vec -> l|
|00005cd0| 29 20 2a 20 28 76 65 63 | 20 2d 3e 20 78 7a 6c 29 |) * (vec| -> xzl)|
|00005ce0| 29 3b 0a 58 09 74 72 61 | 6e 73 20 2d 3e 20 79 2e |);.X.tra|ns -> y.|
|00005cf0| 79 20 3d 20 28 76 65 63 | 20 2d 3e 20 78 7a 6c 29 |y = (vec| -> xzl)|
|00005d00| 20 2f 20 28 76 65 63 20 | 2d 3e 20 6c 29 3b 0a 58 | / (vec |-> l);.X|
|00005d10| 09 74 72 61 6e 73 20 2d | 3e 20 79 2e 7a 20 3d 20 |.trans -|> y.z = |
|00005d20| 2d 28 76 65 63 20 2d 3e | 20 7a 29 20 2a 20 28 76 |-(vec ->| z) * (v|
|00005d30| 65 63 20 2d 3e 20 79 29 | 20 2f 20 28 28 76 65 63 |ec -> y)| / ((vec|
|00005d40| 20 2d 3e 20 6c 29 20 2a | 20 28 76 65 63 20 2d 3e | -> l) *| (vec ->|
|00005d50| 20 78 7a 6c 29 29 3b 0a | 58 09 74 72 61 6e 73 20 | xzl));.|X.trans |
|00005d60| 2d 3e 20 7a 2e 78 20 3d | 20 2d 28 76 65 63 20 2d |-> z.x =| -(vec -|
|00005d70| 3e 20 7a 29 20 2f 20 28 | 76 65 63 20 2d 3e 20 78 |> z) / (|vec -> x|
|00005d80| 7a 6c 29 3b 0a 58 09 74 | 72 61 6e 73 20 2d 3e 20 |zl);.X.t|rans -> |
|00005d90| 7a 2e 79 20 3d 20 30 3b | 0a 58 09 74 72 61 6e 73 |z.y = 0;|.X.trans|
|00005da0| 20 2d 3e 20 7a 2e 7a 20 | 3d 20 28 76 65 63 20 2d | -> z.z |= (vec -|
|00005db0| 3e 20 78 29 20 2f 20 28 | 76 65 63 20 2d 3e 20 78 |> x) / (|vec -> x|
|00005dc0| 7a 6c 29 3b 0a 58 20 20 | 20 20 7d 0a 58 7d 0a 45 |zl);.X | }.X}.E|
|00005dd0| 4e 44 5f 4f 46 5f 73 75 | 70 70 6f 72 74 2e 63 0a |ND_OF_su|pport.c.|
|00005de0| 69 66 20 74 65 73 74 20 | 38 33 34 20 2d 6e 65 20 |if test |834 -ne |
|00005df0| 60 77 63 20 2d 63 20 3c | 73 75 70 70 6f 72 74 2e |`wc -c <|support.|
|00005e00| 63 60 3b 20 74 68 65 6e | 0a 20 20 20 20 65 63 68 |c`; then|. ech|
|00005e10| 6f 20 73 68 61 72 3a 20 | 5c 22 73 75 70 70 6f 72 |o shar: |\"suppor|
|00005e20| 74 2e 63 5c 22 20 75 6e | 70 61 63 6b 65 64 20 77 |t.c\" un|packed w|
|00005e30| 69 74 68 20 77 72 6f 6e | 67 20 73 69 7a 65 21 0a |ith wron|g size!.|
|00005e40| 66 69 0a 23 20 65 6e 64 | 20 6f 66 20 6f 76 65 72 |fi.# end| of over|
|00005e50| 77 72 69 74 69 6e 67 20 | 63 68 65 63 6b 0a 66 69 |writing |check.fi|
|00005e60| 0a 69 66 20 74 65 73 74 | 20 2d 66 20 74 72 61 63 |.if test| -f trac|
|00005e70| 65 72 2e 63 20 2d 61 20 | 22 24 7b 31 7d 22 20 21 |er.c -a |"${1}" !|
|00005e80| 3d 20 22 2d 63 22 20 3b | 20 74 68 65 6e 20 0a 20 |= "-c" ;| then . |
|00005e90| 20 65 63 68 6f 20 73 68 | 61 72 3a 20 57 69 6c 6c | echo sh|ar: Will|
|00005ea0| 20 6e 6f 74 20 6f 76 65 | 72 2d 77 72 69 74 65 20 | not ove|r-write |
|00005eb0| 65 78 69 73 74 69 6e 67 | 20 66 69 6c 65 20 5c 22 |existing| file \"|
|00005ec0| 74 72 61 63 65 72 2e 63 | 5c 22 0a 65 6c 73 65 0a |tracer.c|\".else.|
|00005ed0| 65 63 68 6f 20 73 68 61 | 72 3a 20 45 78 74 72 61 |echo sha|r: Extra|
|00005ee0| 63 74 69 6e 67 20 5c 22 | 74 72 61 63 65 72 2e 63 |cting \"|tracer.c|
|00005ef0| 5c 22 20 5c 28 32 36 32 | 34 20 63 68 61 72 61 63 |\" \(262|4 charac|
|00005f00| 74 65 72 73 5c 29 0a 73 | 65 64 20 22 73 2f 5e 58 |ters\).s|ed "s/^X|
|00005f10| 2f 2f 22 20 3e 74 72 61 | 63 65 72 2e 63 20 3c 3c |//" >tra|cer.c <<|
|00005f20| 27 45 4e 44 5f 4f 46 5f | 74 72 61 63 65 72 2e 63 |'END_OF_|tracer.c|
|00005f30| 27 0a 58 0a 58 0a 58 2f | 2a 20 74 72 61 63 65 72 |'.X.X.X/|* tracer|
|00005f40| 20 76 65 72 73 69 6f 6e | 20 32 2e 31 20 2a 2f 0a | version| 2.1 */.|
|00005f50| 58 23 69 6e 63 6c 75 64 | 65 20 3c 73 74 64 69 6f |X#includ|e <stdio|
|00005f60| 2e 68 3e 0a 58 23 69 6e | 63 6c 75 64 65 20 3c 6d |.h>.X#in|clude <m|
|00005f70| 61 74 68 2e 68 3e 0a 58 | 23 69 6e 63 6c 75 64 65 |ath.h>.X|#include|
|00005f80| 20 22 72 74 64 2e 68 22 | 0a 58 23 69 6e 63 6c 75 | "rtd.h"|.X#inclu|
|00005f90| 64 65 20 22 6d 61 63 72 | 6f 73 2e 68 22 0a 58 0a |de "macr|os.h".X.|
|00005fa0| 58 0a 58 46 49 4c 45 20 | 2a 20 66 70 3b 0a 58 64 |X.XFILE |* fp;.Xd|
|00005fb0| 6f 75 62 6c 65 20 20 73 | 75 7a 69 65 5b 33 30 30 |ouble s|uzie[300|
|00005fc0| 5d 5b 33 30 30 5d 2c 0a | 58 20 20 20 20 20 20 20 |][300],.|X |
|00005fd0| 20 73 61 6d 20 3d 20 31 | 2e 30 3b 0a 58 69 6e 74 | sam = 1|.0;.Xint|
|00005fe0| 20 20 20 20 20 78 73 75 | 65 2c 0a 58 20 20 20 20 | xsu|e,.X |
|00005ff0| 20 20 20 20 79 73 75 65 | 3b 0a 58 73 74 72 75 63 | ysue|;.Xstruc|
|00006000| 74 20 62 61 6c 6c 20 2a | 62 6c 5b 31 35 30 5d 3b |t ball *|bl[150];|
|00006010| 0a 58 69 6e 74 20 20 20 | 20 20 6c 65 76 65 6c 2c |.Xint | level,|
|00006020| 0a 58 20 20 20 20 20 20 | 20 20 6e 6f 62 3b 0a 58 |.X | nob;.X|
|00006030| 73 74 72 75 63 74 20 73 | 70 68 65 72 65 20 20 20 |struct s|phere |
|00006040| 6c 73 3b 0a 58 0a 58 6d | 61 69 6e 20 28 61 72 67 |ls;.X.Xm|ain (arg|
|00006050| 63 2c 20 61 72 67 76 29 | 0a 58 69 6e 74 20 20 20 |c, argv)|.Xint |
|00006060| 20 20 61 72 67 63 3b 0a | 58 63 68 61 72 20 20 2a | argc;.|Xchar *|
|00006070| 2a 61 72 67 76 3b 0a 58 | 7b 0a 58 20 20 20 20 46 |*argv;.X|{.X F|
|00006080| 49 4c 45 20 2a 20 64 66 | 2c 20 2a 74 65 78 66 69 |ILE * df|, *texfi|
|00006090| 6c 65 3b 0a 58 20 20 20 | 20 73 74 61 74 69 63 20 |le;.X | static |
|000060a0| 64 6f 75 62 6c 65 20 20 | 20 78 63 6f 2c 0a 58 20 |double | xco,.X |
|000060b0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|000060c0| 20 20 20 79 63 6f 3b 0a | 58 20 20 20 20 73 74 72 | yco;.|X str|
|000060d0| 75 63 74 20 72 61 79 20 | 20 72 72 3b 0a 58 20 20 |uct ray | rr;.X |
|000060e0| 20 20 73 74 72 75 63 74 | 20 76 65 63 74 6f 72 20 | struct| vector |
|000060f0| 20 20 76 70 3b 0a 58 20 | 20 20 20 64 6f 75 62 6c | vp;.X | doubl|
|00006100| 65 20 20 78 2c 0a 58 20 | 20 20 20 20 20 20 20 20 |e x,.X | |
|00006110| 20 20 20 79 2c 0a 58 20 | 20 20 20 20 20 20 20 20 | y,.X | |
|00006120| 20 20 20 7a 3b 0a 58 20 | 20 20 20 69 6e 74 20 20 | z;.X | int |
|00006130| 20 20 20 69 2c 0a 58 20 | 20 20 20 20 20 20 20 20 | i,.X | |
|00006140| 20 20 20 69 6e 20 3d 20 | 30 2c 0a 58 20 20 20 20 | in = |0,.X |
|00006150| 20 20 20 20 20 20 20 20 | 6f 75 74 20 3d 20 30 2c | |out = 0,|
|00006160| 0a 58 20 20 20 20 20 20 | 20 20 20 20 20 20 74 65 |.X | te|
|00006170| 78 20 3d 20 30 3b 0a 58 | 20 20 20 20 69 6e 74 20 |x = 0;.X| int |
|00006180| 20 20 20 20 63 3b 0a 58 | 0a 58 2f 2a 20 63 6f 6d | c;.X|.X/* com|
|00006190| 6d 61 6e 64 20 69 6e 74 | 65 72 70 20 2a 2f 0a 58 |mand int|erp */.X|
|000061a0| 0a 58 20 20 20 20 66 6f | 72 20 28 69 20 3d 20 31 |.X fo|r (i = 1|
|000061b0| 3b 20 69 20 3c 20 61 72 | 67 63 3b 20 69 2b 2b 29 |; i < ar|gc; i++)|
|000061c0| 20 7b 0a 58 09 69 66 20 | 28 61 72 67 76 5b 69 5d | {.X.if |(argv[i]|
|000061d0| 5b 30 5d 20 21 3d 20 27 | 2d 27 29 0a 58 09 20 20 |[0] != '|-').X. |
|000061e0| 20 20 62 6f 6f 62 6f 6f | 20 28 22 4f 70 74 69 6f | booboo| ("Optio|
|000061f0| 6e 73 20 73 74 72 74 20 | 77 69 74 68 20 61 20 27 |ns strt |with a '|
|00006200| 2d 27 20 62 6f 7a 6f 22 | 29 3b 0a 58 09 63 20 3d |-' bozo"|);.X.c =|
|00006210| 20 61 72 67 76 5b 69 5d | 5b 31 5d 3b 0a 58 0a 58 | argv[i]|[1];.X.X|
|00006220| 09 73 77 69 74 63 68 20 | 28 63 29 20 7b 0a 58 09 |.switch |(c) {.X.|
|00006230| 20 20 20 20 63 61 73 65 | 20 28 27 69 27 29 3a 20 | case| ('i'): |
|00006240| 0a 58 09 09 69 66 20 28 | 69 6e 29 0a 58 09 09 20 |.X..if (|in).X.. |
|00006250| 20 20 20 62 6f 6f 62 6f | 6f 20 28 22 53 6f 72 72 | boobo|o ("Sorr|
|00006260| 79 2c 20 62 75 74 20 79 | 6f 75 20 6d 61 79 20 6f |y, but y|ou may o|
|00006270| 6e 6c 79 20 68 61 76 65 | 20 6f 6e 65 20 69 6e 70 |nly have| one inp|
|00006280| 75 74 20 66 69 6c 65 22 | 29 3b 0a 58 09 09 69 6e |ut file"|);.X..in|
|00006290| 20 3d 20 31 3b 0a 58 09 | 09 69 66 20 28 28 69 20 | = 1;.X.|.if ((i |
|000062a0| 2b 20 31 29 20 3e 3d 20 | 61 72 67 63 20 7c 7c 20 |+ 1) >= |argc || |
|000062b0| 61 72 67 76 5b 69 20 2b | 20 31 5d 5b 30 5d 20 3d |argv[i +| 1][0] =|
|000062c0| 3d 20 27 2d 27 29 2f 2a | 20 6e 6f 20 61 72 67 20 |= '-')/*| no arg |
|000062d0| 2a 2f 0a 58 09 09 20 20 | 20 20 64 66 20 3d 20 73 |*/.X.. | df = s|
|000062e0| 74 64 69 6e 3b 0a 58 09 | 09 65 6c 73 65 0a 58 09 |tdin;.X.|.else.X.|
|000062f0| 09 20 20 20 20 69 66 20 | 28 28 64 66 20 3d 20 66 |. if |((df = f|
|00006300| 6f 70 65 6e 20 28 61 72 | 67 76 5b 2b 2b 69 5d 2c |open (ar|gv[++i],|
|00006310| 20 22 72 22 29 29 20 3d | 3d 20 4e 55 4c 4c 29 0a | "r")) =|= NULL).|
|00006320| 58 09 09 09 62 6f 6f 62 | 6f 6f 20 28 22 69 6e 70 |X...boob|oo ("inp|
|00006330| 75 74 20 66 69 6c 65 20 | 6e 6f 74 20 66 6f 75 6e |ut file |not foun|
|00006340| 64 22 29 3b 0a 58 09 09 | 62 72 65 61 6b 3b 0a 58 |d");.X..|break;.X|
|00006350| 09 20 20 20 20 63 61 73 | 65 20 28 27 6f 27 29 3a |. cas|e ('o'):|
|00006360| 20 0a 58 09 09 69 66 20 | 28 6f 75 74 29 0a 58 09 | .X..if |(out).X.|
|00006370| 09 20 20 20 20 62 6f 6f | 62 6f 6f 20 28 22 53 6f |. boo|boo ("So|
|00006380| 72 72 79 2c 20 62 75 74 | 20 79 6f 75 20 6d 61 79 |rry, but| you may|
|00006390| 20 68 61 76 65 20 6f 6e | 6c 79 20 6f 6e 65 20 6f | have on|ly one o|
|000063a0| 75 74 70 75 74 20 66 69 | 6c 65 22 29 3b 0a 58 09 |utput fi|le");.X.|
|000063b0| 09 6f 75 74 20 3d 20 31 | 3b 0a 58 09 09 69 66 20 |.out = 1|;.X..if |
|000063c0| 28 28 69 20 2b 20 31 29 | 20 3e 3d 20 61 72 67 63 |((i + 1)| >= argc|
|000063d0| 20 7c 7c 20 61 72 67 76 | 5b 69 20 2b 20 31 5d 5b | || argv|[i + 1][|
|000063e0| 30 5d 20 3d 3d 20 27 2d | 27 29 2f 2a 20 6e 6f 20 |0] == '-|')/* no |
|000063f0| 61 72 67 20 2a 2f 0a 58 | 09 09 20 20 20 20 66 70 |arg */.X|.. fp|
+--------+-------------------------+-------------------------+--------+--------+
Only 25.0 KB of data is shown above.