home *** CD-ROM | disk | FTP | other *** search
/ Usenet 1994 January / usenetsourcesnewsgroupsinfomagicjanuary1994.iso / sources / unix / volume21 / rayshade / part02 < prev    next >
SHell self-extracting ARchive  |  1990-03-21  |  56.4 KB

open in: MacOS 8.1     |     Win98     |     DOS

browse contents    |     view JSON data     |     view as text


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

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



hex view
+--------+-------------------------+-------------------------+--------+--------+
|00000000| 53 75 62 6a 65 63 74 3a | 20 20 76 32 31 69 30 30 |Subject:| v21i00|
|00000010| 39 3a 20 20 41 20 72 61 | 79 20 74 72 61 63 69 6e |9: A ra|y tracin|
|00000020| 67 20 70 72 6f 67 72 61 | 6d 2c 20 50 61 72 74 30 |g progra|m, Part0|
|00000030| 32 2f 30 38 0a 4e 65 77 | 73 67 72 6f 75 70 73 3a |2/08.New|sgroups:|
|00000040| 20 63 6f 6d 70 2e 73 6f | 75 72 63 65 73 2e 75 6e | comp.so|urces.un|
|00000050| 69 78 0a 53 65 6e 64 65 | 72 3a 20 73 6f 75 72 63 |ix.Sende|r: sourc|
|00000060| 65 73 0a 41 70 70 72 6f | 76 65 64 3a 20 72 73 61 |es.Appro|ved: rsa|
|00000070| 6c 7a 40 75 75 6e 65 74 | 2e 55 55 2e 4e 45 54 0a |lz@uunet|.UU.NET.|
|00000080| 0a 53 75 62 6d 69 74 74 | 65 64 2d 62 79 3a 20 43 |.Submitt|ed-by: C|
|00000090| 72 61 69 67 20 4b 6f 6c | 62 20 3c 63 72 61 69 67 |raig Kol|b <craig|
|000000a0| 40 77 65 65 64 65 61 74 | 65 72 2e 6d 61 74 68 2e |@weedeat|er.math.|
|000000b0| 79 61 6c 65 2e 65 64 75 | 3e 0a 50 6f 73 74 69 6e |yale.edu|>.Postin|
|000000c0| 67 2d 6e 75 6d 62 65 72 | 3a 20 56 6f 6c 75 6d 65 |g-number|: Volume|
|000000d0| 20 32 31 2c 20 49 73 73 | 75 65 20 39 0a 41 72 63 | 21, Iss|ue 9.Arc|
|000000e0| 68 69 76 65 2d 6e 61 6d | 65 3a 20 72 61 79 73 68 |hive-nam|e: raysh|
|000000f0| 61 64 65 2f 70 61 72 74 | 30 32 0a 0a 23 21 20 2f |ade/part|02..#! /|
|00000100| 62 69 6e 2f 73 68 0a 23 | 20 54 68 69 73 20 69 73 |bin/sh.#| This is|
|00000110| 20 61 20 73 68 65 6c 6c | 20 61 72 63 68 69 76 65 | a shell| archive|
|00000120| 2e 20 20 52 65 6d 6f 76 | 65 20 61 6e 79 74 68 69 |. Remov|e anythi|
|00000130| 6e 67 20 62 65 66 6f 72 | 65 20 74 68 69 73 20 6c |ng befor|e this l|
|00000140| 69 6e 65 2c 20 74 68 65 | 6e 20 75 6e 70 61 63 6b |ine, the|n unpack|
|00000150| 0a 23 20 69 74 20 62 79 | 20 73 61 76 69 6e 67 20 |.# it by| saving |
|00000160| 69 74 20 69 6e 74 6f 20 | 61 20 66 69 6c 65 20 61 |it into |a file a|
|00000170| 6e 64 20 74 79 70 69 6e | 67 20 22 73 68 20 66 69 |nd typin|g "sh fi|
|00000180| 6c 65 22 2e 20 20 54 6f | 20 6f 76 65 72 77 72 69 |le". To| overwri|
|00000190| 74 65 20 65 78 69 73 74 | 69 6e 67 0a 23 20 66 69 |te exist|ing.# fi|
|000001a0| 6c 65 73 2c 20 74 79 70 | 65 20 22 73 68 20 66 69 |les, typ|e "sh fi|
|000001b0| 6c 65 20 2d 63 22 2e 20 | 20 59 6f 75 20 63 61 6e |le -c". | You can|
|000001c0| 20 61 6c 73 6f 20 66 65 | 65 64 20 74 68 69 73 20 | also fe|ed this |
|000001d0| 61 73 20 73 74 61 6e 64 | 61 72 64 20 69 6e 70 75 |as stand|ard inpu|
|000001e0| 74 20 76 69 61 0a 23 20 | 75 6e 73 68 61 72 2c 20 |t via.# |unshar, |
|000001f0| 6f 72 20 62 79 20 74 79 | 70 69 6e 67 20 22 73 68 |or by ty|ping "sh|
|00000200| 20 3c 66 69 6c 65 22 2c | 20 65 2e 67 2e 2e 20 20 | <file",| e.g.. |
|00000210| 49 66 20 74 68 69 73 20 | 61 72 63 68 69 76 65 20 |If this |archive |
|00000220| 69 73 20 63 6f 6d 70 6c | 65 74 65 2c 20 79 6f 75 |is compl|ete, you|
|00000230| 0a 23 20 77 69 6c 6c 20 | 73 65 65 20 74 68 65 20 |.# will |see the |
|00000240| 66 6f 6c 6c 6f 77 69 6e | 67 20 6d 65 73 73 61 67 |followin|g messag|
|00000250| 65 20 61 74 20 74 68 65 | 20 65 6e 64 3a 0a 23 09 |e at the| end:.#.|
|00000260| 09 22 45 6e 64 20 6f 66 | 20 61 72 63 68 69 76 65 |."End of| archive|
|00000270| 20 32 20 28 6f 66 20 38 | 29 2e 22 0a 23 20 43 6f | 2 (of 8|).".# Co|
|00000280| 6e 74 65 6e 74 73 3a 20 | 20 45 78 61 6d 70 6c 65 |ntents: | Example|
|00000290| 73 2f 70 6f 6f 6c 2e 72 | 61 79 20 6e 66 66 32 73 |s/pool.r|ay nff2s|
|000002a0| 68 61 64 65 2e 61 77 6b | 20 73 72 63 2f 64 61 74 |hade.awk| src/dat|
|000002b0| 61 74 79 70 65 73 2e 68 | 0a 23 20 20 20 73 72 63 |atypes.h|.# src|
|000002c0| 2f 66 75 6e 63 64 65 66 | 73 2e 68 20 73 72 63 2f |/funcdef|s.h src/|
|000002d0| 69 6e 70 75 74 2e 63 20 | 73 72 63 2f 6c 69 73 74 |input.c |src/list|
|000002e0| 2e 63 20 73 72 63 2f 6d | 61 69 6e 2e 63 20 73 72 |.c src/m|ain.c sr|
|000002f0| 63 2f 6f 75 74 70 75 74 | 70 2e 63 0a 23 20 20 20 |c/output|p.c.# |
|00000300| 73 72 63 2f 70 72 69 6d | 6f 62 6a 2e 68 20 73 72 |src/prim|obj.h sr|
|00000310| 63 2f 73 65 74 75 70 2e | 63 20 73 72 63 2f 73 70 |c/setup.|c src/sp|
|00000320| 68 65 72 65 2e 63 20 73 | 72 63 2f 73 75 70 65 72 |here.c s|rc/super|
|00000330| 71 2e 63 20 73 72 63 2f | 73 75 72 66 61 63 65 2e |q.c src/|surface.|
|00000340| 63 0a 50 41 54 48 3d 2f | 62 69 6e 3a 2f 75 73 72 |c.PATH=/|bin:/usr|
|00000350| 2f 62 69 6e 3a 2f 75 73 | 72 2f 75 63 62 20 3b 20 |/bin:/us|r/ucb ; |
|00000360| 65 78 70 6f 72 74 20 50 | 41 54 48 0a 69 66 20 74 |export P|ATH.if t|
|00000370| 65 73 74 20 2d 66 20 27 | 45 78 61 6d 70 6c 65 73 |est -f '|Examples|
|00000380| 2f 70 6f 6f 6c 2e 72 61 | 79 27 20 2d 61 20 22 24 |/pool.ra|y' -a "$|
|00000390| 7b 31 7d 22 20 21 3d 20 | 22 2d 63 22 20 3b 20 74 |{1}" != |"-c" ; t|
|000003a0| 68 65 6e 20 0a 20 20 65 | 63 68 6f 20 73 68 61 72 |hen . e|cho shar|
|000003b0| 3a 20 57 69 6c 6c 20 6e | 6f 74 20 63 6c 6f 62 62 |: Will n|ot clobb|
|000003c0| 65 72 20 65 78 69 73 74 | 69 6e 67 20 66 69 6c 65 |er exist|ing file|
|000003d0| 20 5c 22 27 45 78 61 6d | 70 6c 65 73 2f 70 6f 6f | \"'Exam|ples/poo|
|000003e0| 6c 2e 72 61 79 27 5c 22 | 0a 65 6c 73 65 0a 65 63 |l.ray'\"|.else.ec|
|000003f0| 68 6f 20 73 68 61 72 3a | 20 45 78 74 72 61 63 74 |ho shar:| Extract|
|00000400| 69 6e 67 20 5c 22 27 45 | 78 61 6d 70 6c 65 73 2f |ing \"'E|xamples/|
|00000410| 70 6f 6f 6c 2e 72 61 79 | 27 5c 22 20 5c 28 33 35 |pool.ray|'\" \(35|
|00000420| 37 39 20 63 68 61 72 61 | 63 74 65 72 73 5c 29 0a |79 chara|cters\).|
|00000430| 73 65 64 20 22 73 2f 5e | 58 2f 2f 22 20 3e 27 45 |sed "s/^|X//" >'E|
|00000440| 78 61 6d 70 6c 65 73 2f | 70 6f 6f 6c 2e 72 61 79 |xamples/|pool.ray|
|00000450| 27 20 3c 3c 27 45 4e 44 | 5f 4f 46 5f 46 49 4c 45 |' <<'END|_OF_FILE|
|00000460| 27 0a 58 2f 2a 0a 58 20 | 2a 20 45 78 61 6d 70 6c |'.X/*.X |* Exampl|
|00000470| 65 20 72 61 79 73 68 61 | 64 65 20 69 6e 70 75 74 |e raysha|de input|
|00000480| 20 66 69 6c 65 0a 58 20 | 2a 0a 58 20 2a 20 70 6f | file.X |*.X * po|
|00000490| 6f 6c 20 74 61 62 6c 65 | 20 66 72 6f 6d 20 22 52 |ol table| from "R|
|000004a0| 65 64 73 27 20 4e 69 67 | 68 74 6d 61 72 65 22 0a |eds' Nig|htmare".|
|000004b0| 58 20 2a 0a 58 20 2a 20 | 57 61 72 6e 69 6e 67 3a |X *.X * |Warning:|
|000004c0| 20 20 74 68 69 73 20 77 | 69 6c 6c 20 74 61 6b 65 | this w|ill take|
|000004d0| 20 61 20 77 68 69 6c 65 | 20 74 6f 20 72 65 6e 64 | a while| to rend|
|000004e0| 65 72 2c 20 61 73 20 69 | 74 20 75 73 65 73 20 39 |er, as i|t uses 9|
|000004f0| 20 72 61 79 73 2f 70 69 | 78 65 6c 0a 58 20 2a 20 | rays/pi|xel.X * |
|00000500| 61 6e 64 20 6d 61 6b 65 | 73 20 68 65 61 76 79 20 |and make|s heavy |
|00000510| 75 73 65 20 6f 66 20 74 | 65 78 74 75 72 69 6e 67 |use of t|exturing|
|00000520| 20 72 6f 75 74 69 6e 65 | 73 2e 0a 58 20 2a 0a 58 | routine|s..X *.X|
|00000530| 20 2a 20 54 6f 20 73 70 | 65 65 64 20 72 65 6e 64 | * To sp|eed rend|
|00000540| 65 72 69 6e 67 2c 20 75 | 73 65 20 2d 50 20 6f 72 |ering, u|se -P or|
|00000550| 20 2d 53 20 6f 70 74 69 | 6f 6e 73 2e 0a 58 20 2a | -S opti|ons..X *|
|00000560| 0a 58 20 2a 20 43 2e 20 | 4b 6f 6c 62 20 32 2f 38 |.X * C. |Kolb 2/8|
|00000570| 38 0a 58 20 2a 2f 0a 58 | 75 70 20 30 2e 30 20 30 |8.X */.X|up 0.0 0|
|00000580| 2e 30 20 31 2e 0a 58 66 | 6f 76 20 34 35 0a 58 73 |.0 1..Xf|ov 45.Xs|
|00000590| 63 72 65 65 6e 20 35 31 | 32 20 35 31 32 0a 58 6d |creen 51|2 512.Xm|
|000005a0| 61 78 64 65 70 74 68 20 | 32 0a 58 62 61 63 6b 67 |axdepth |2.Xbackg|
|000005b0| 72 6f 75 6e 64 20 30 20 | 30 20 30 0a 58 6c 69 67 |round 0 |0 0.Xlig|
|000005c0| 68 74 20 31 2e 34 20 70 | 6f 69 6e 74 20 32 30 2e |ht 1.4 p|oint 20.|
|000005d0| 30 20 30 2e 30 20 36 36 | 2e 30 0a 58 73 75 72 66 |0 0.0 66|.0.Xsurf|
|000005e0| 61 63 65 20 62 6c 61 63 | 6b 74 69 6c 65 20 30 2e |ace blac|ktile 0.|
|000005f0| 30 31 20 30 2e 30 31 20 | 30 2e 30 31 20 20 30 2e |01 0.01 |0.01 0.|
|00000600| 30 31 20 30 2e 30 31 20 | 30 2e 30 31 20 30 2e 20 |01 0.01 |0.01 0. |
|00000610| 30 2e 20 30 2e 20 30 2e | 20 30 2e 20 30 20 30 0a |0. 0. 0.| 0. 0 0.|
|00000620| 58 73 75 72 66 61 63 65 | 20 73 30 20 20 30 2e 38 |Xsurface| s0 0.8|
|00000630| 36 32 37 34 35 20 30 2e | 38 36 32 37 34 35 20 30 |62745 0.|862745 0|
|00000640| 2e 38 36 32 37 34 35 20 | 20 30 2e 30 33 39 32 31 |.862745 | 0.03921|
|00000650| 36 20 30 2e 30 33 39 32 | 31 36 20 30 2e 30 33 39 |6 0.0392|16 0.039|
|00000660| 32 31 36 20 20 30 2e 20 | 30 2e 20 30 2e 0a 58 09 |216 0. |0. 0..X.|
|00000670| 09 37 2e 20 30 2e 20 30 | 2e 20 31 2e 0a 58 73 75 |.7. 0. 0|. 1..Xsu|
|00000680| 72 66 61 63 65 20 73 31 | 20 20 30 2e 34 37 30 35 |rface s1| 0.4705|
|00000690| 38 38 20 30 2e 31 35 36 | 38 36 33 20 30 2e 33 39 |88 0.156|863 0.39|
|000006a0| 32 31 35 37 20 20 30 2e | 34 37 30 35 38 38 20 30 |2157 0.|470588 0|
|000006b0| 2e 31 35 36 38 36 33 20 | 30 2e 33 39 32 31 35 37 |.156863 |0.392157|
|000006c0| 20 20 30 2e 20 30 2e 20 | 30 2e 0a 58 09 09 32 35 | 0. 0. |0..X..25|
|000006d0| 2e 20 31 2e 20 30 2e 20 | 31 2e 0a 58 73 75 72 66 |. 1. 0. |1..Xsurf|
|000006e0| 61 63 65 20 73 32 20 20 | 30 2e 31 31 37 36 34 37 |ace s2 |0.117647|
|000006f0| 20 30 2e 31 31 37 36 34 | 37 20 30 2e 33 39 32 31 | 0.11764|7 0.3921|
|00000700| 35 37 20 20 30 2e 31 31 | 37 36 34 37 20 30 2e 31 |57 0.11|7647 0.1|
|00000710| 31 37 36 34 37 20 30 2e | 33 39 32 31 35 37 20 20 |17647 0.|392157 |
|00000720| 30 2e 20 30 2e 20 30 2e | 0a 58 09 09 32 35 2e 20 |0. 0. 0.|.X..25. |
|00000730| 30 2e 20 30 2e 20 31 2e | 0a 58 73 75 72 66 61 63 |0. 0. 1.|.Xsurfac|
|00000740| 65 20 73 33 20 20 30 2e | 37 38 34 33 31 34 20 30 |e s3 0.|784314 0|
|00000750| 2e 30 37 38 34 33 31 20 | 30 2e 30 37 38 34 33 31 |.078431 |0.078431|
|00000760| 20 20 30 2e 34 37 30 35 | 38 38 20 30 2e 30 33 39 | 0.4705|88 0.039|
|00000770| 32 31 36 20 30 2e 30 33 | 39 32 31 36 20 20 30 2e |216 0.03|9216 0.|
|00000780| 20 30 2e 20 30 2e 0a 58 | 09 09 32 35 2e 20 30 2e | 0. 0..X|..25. 0.|
|00000790| 20 30 2e 20 31 2e 0a 58 | 73 75 72 66 61 63 65 20 | 0. 1..X|surface |
|000007a0| 73 34 20 30 20 2e 32 32 | 33 35 20 2e 31 34 35 20 |s4 0 .22|35 .145 |
|000007b0| 30 20 2e 32 32 33 35 20 | 2e 31 34 35 20 30 20 30 |0 .2235 |.145 0 0|
|000007c0| 20 30 20 30 2e 30 20 30 | 2e 20 30 2e 20 31 2e 0a | 0 0.0 0|. 0. 1..|
|000007d0| 58 73 75 72 66 61 63 65 | 20 6d 69 72 72 6f 72 20 |Xsurface| mirror |
|000007e0| 30 2e 30 34 20 30 2e 30 | 34 20 30 2e 30 34 20 30 |0.04 0.0|4 0.04 0|
|000007f0| 2e 30 35 20 30 2e 30 35 | 20 30 2e 30 35 20 20 31 |.05 0.05| 0.05 1|
|00000800| 2e 20 31 2e 20 31 2e 20 | 20 36 30 2e 20 30 2e 39 |. 1. 1. | 60. 0.9|
|00000810| 35 20 30 2e 20 31 2e 0a | 58 73 75 72 66 61 63 65 |5 0. 1..|Xsurface|
|00000820| 20 73 35 20 20 30 2e 31 | 39 36 30 37 38 20 30 2e | s5 0.1|96078 0.|
|00000830| 33 39 32 31 35 37 20 30 | 2e 31 31 37 36 34 37 20 |392157 0|.117647 |
|00000840| 20 30 2e 31 39 36 30 37 | 38 20 30 2e 33 39 32 31 | 0.19607|8 0.3921|
|00000850| 35 37 20 30 2e 31 31 37 | 36 34 37 0a 58 09 09 30 |57 0.117|647.X..0|
|00000860| 2e 31 35 36 38 36 33 20 | 30 2e 31 35 36 38 36 33 |.156863 |0.156863|
|00000870| 20 30 2e 31 35 36 38 36 | 33 20 20 37 2e 20 30 2e | 0.15686|3 7. 0.|
|00000880| 31 20 30 2e 20 31 2e 0a | 58 73 75 72 66 61 63 65 |1 0. 1..|Xsurface|
|00000890| 20 73 36 20 20 30 2e 35 | 38 38 32 33 35 20 30 2e | s6 0.5|88235 0.|
|000008a0| 33 39 32 31 35 37 20 30 | 2e 31 31 37 36 34 37 20 |392157 0|.117647 |
|000008b0| 20 30 2e 31 39 36 30 37 | 38 20 30 2e 33 39 32 31 | 0.19607|8 0.3921|
|000008c0| 35 37 20 30 2e 31 31 37 | 36 34 37 0a 58 09 09 30 |57 0.117|647.X..0|
|000008d0| 2e 31 35 36 38 36 33 20 | 30 2e 31 35 36 38 36 33 |.156863 |0.156863|
|000008e0| 20 30 2e 31 35 36 38 36 | 33 20 20 37 2e 20 30 2e | 0.15686|3 7. 0.|
|000008f0| 31 20 30 2e 20 31 2e 0a | 58 73 75 72 66 61 63 65 |1 0. 1..|Xsurface|
|00000900| 20 73 37 20 20 30 2e 31 | 39 36 30 37 38 20 30 2e | s7 0.1|96078 0.|
|00000910| 33 39 32 31 35 37 20 30 | 2e 35 30 39 38 30 34 20 |392157 0|.509804 |
|00000920| 20 30 2e 31 39 36 30 37 | 38 20 30 2e 33 39 32 31 | 0.19607|8 0.3921|
|00000930| 35 37 20 30 2e 31 31 37 | 36 34 37 0a 58 09 09 30 |57 0.117|647.X..0|
|00000940| 2e 31 35 36 38 36 33 20 | 30 2e 31 35 36 38 36 33 |.156863 |0.156863|
|00000950| 20 30 2e 31 35 36 38 36 | 33 20 20 37 2e 20 30 2e | 0.15686|3 7. 0.|
|00000960| 31 20 30 2e 20 31 2e 0a | 58 73 75 72 66 61 63 65 |1 0. 1..|Xsurface|
|00000970| 20 73 38 20 20 30 2e 39 | 38 30 33 39 32 20 30 2e | s8 0.9|80392 0.|
|00000980| 31 39 36 30 37 38 20 30 | 2e 31 31 37 36 34 37 20 |196078 0|.117647 |
|00000990| 20 30 2e 31 39 36 30 37 | 38 20 30 2e 33 39 32 31 | 0.19607|8 0.3921|
|000009a0| 35 37 20 30 2e 31 31 37 | 36 34 37 0a 58 09 09 30 |57 0.117|647.X..0|
|000009b0| 2e 31 35 36 38 36 33 20 | 30 2e 31 35 36 38 36 33 |.156863 |0.156863|
|000009c0| 20 30 2e 31 35 36 38 36 | 33 20 20 37 2e 20 30 2e | 0.15686|3 7. 0.|
|000009d0| 31 20 30 2e 20 31 2e 0a | 58 73 75 72 66 61 63 65 |1 0. 1..|Xsurface|
|000009e0| 20 73 39 20 20 30 2e 31 | 39 36 30 37 38 20 30 2e | s9 0.1|96078 0.|
|000009f0| 33 39 32 31 35 37 20 30 | 2e 39 30 31 39 36 31 20 |392157 0|.901961 |
|00000a00| 20 30 2e 31 39 36 30 37 | 38 20 30 2e 20 30 2e 31 | 0.19607|8 0. 0.1|
|00000a10| 31 37 36 34 37 0a 58 09 | 09 30 2e 31 35 36 38 36 |17647.X.|.0.15686|
|00000a20| 33 20 30 2e 31 35 36 38 | 36 33 20 30 2e 31 35 36 |3 0.1568|63 0.156|
|00000a30| 38 36 33 20 20 37 2e 20 | 30 2e 31 20 30 2e 20 31 |863 7. |0.1 0. 1|
|00000a40| 2e 0a 58 73 75 72 66 61 | 63 65 20 73 31 30 20 20 |..Xsurfa|ce s10 |
|00000a50| 30 2e 34 31 31 37 36 35 | 20 30 2e 34 31 31 37 36 |0.411765| 0.41176|
|00000a60| 35 20 30 2e 31 37 36 34 | 37 31 20 20 30 2e 34 31 |5 0.1764|71 0.41|
|00000a70| 31 37 36 35 20 30 2e 34 | 31 31 37 36 35 20 30 2e |1765 0.4|11765 0.|
|00000a80| 31 37 36 34 37 31 20 20 | 30 2e 20 30 2e 20 30 2e |176471 |0. 0. 0.|
|00000a90| 0a 58 09 09 30 2e 20 30 | 2e 20 30 2e 20 31 2e 0a |.X..0. 0|. 0. 1..|
|00000aa0| 58 73 75 72 66 61 63 65 | 20 66 6c 6f 6f 72 20 2e |Xsurface| floor .|
|00000ab0| 31 20 2e 31 20 2e 31 20 | 2e 35 20 2e 35 20 2e 34 |1 .1 .1 |.5 .5 .4|
|00000ac0| 35 20 30 2e 38 20 30 2e | 38 20 30 2e 38 20 31 38 |5 0.8 0.|8 0.8 18|
|00000ad0| 20 30 2e 30 20 30 20 30 | 0a 58 2f 2a 73 75 72 66 | 0.0 0 0|.X/*surf|
|00000ae0| 61 63 65 20 66 6c 6f 6f | 72 20 30 2e 35 20 30 2e |ace floo|r 0.5 0.|
|00000af0| 35 20 30 2e 35 20 20 30 | 2e 38 20 30 2e 37 38 20 |5 0.5 0|.8 0.78 |
|00000b00| 30 2e 37 38 0a 58 09 09 | 30 2e 38 20 30 2e 37 36 |0.78.X..|0.8 0.76|
|00000b10| 20 30 2e 37 36 20 20 31 | 30 2e 20 30 2e 30 20 30 | 0.76 1|0. 0.0 0|
|00000b20| 2e 20 31 2e 20 2a 2f 0a | 58 73 75 72 66 61 63 65 |. 1. */.|Xsurface|
|00000b30| 20 73 31 32 20 20 30 2e | 33 31 33 37 32 35 20 30 | s12 0.|313725 0|
|00000b40| 2e 33 31 33 37 32 35 20 | 30 2e 33 31 33 37 32 35 |.313725 |0.313725|
|00000b50| 20 20 30 2e 37 34 35 30 | 39 38 20 30 2e 37 34 35 | 0.7450|98 0.745|
|00000b60| 30 39 38 20 30 2e 37 34 | 35 30 39 38 0a 58 09 09 |098 0.74|5098.X..|
|00000b70| 30 2e 20 30 2e 20 30 2e | 20 20 30 2e 20 30 2e 20 |0. 0. 0.| 0. 0. |
|00000b80| 30 2e 20 31 2e 0a 58 73 | 75 72 66 61 63 65 20 73 |0. 1..Xs|urface s|
|00000b90| 31 33 20 20 30 2e 30 37 | 38 34 33 31 20 30 2e 38 |13 0.07|8431 0.8|
|00000ba0| 36 32 37 34 35 20 30 2e | 30 37 38 34 33 31 20 20 |62745 0.|078431 |
|00000bb0| 30 2e 30 33 39 32 31 36 | 20 30 2e 30 33 39 32 31 |0.039216| 0.03921|
|00000bc0| 36 20 30 2e 30 33 39 32 | 31 36 0a 58 09 09 30 2e |6 0.0392|16.X..0.|
|00000bd0| 31 35 36 38 36 33 20 30 | 2e 31 35 36 38 36 33 20 |156863 0|.156863 |
|00000be0| 30 2e 31 35 36 38 36 33 | 20 20 37 2e 20 30 2e 20 |0.156863| 7. 0. |
|00000bf0| 30 2e 20 31 2e 0a 58 73 | 75 72 66 61 63 65 20 73 |0. 1..Xs|urface s|
|00000c00| 31 34 20 20 30 2e 37 38 | 34 33 31 34 20 30 2e 30 |14 0.78|4314 0.0|
|00000c10| 37 38 34 33 31 20 30 2e | 30 37 38 34 33 31 20 20 |78431 0.|078431 |
|00000c20| 30 2e 34 37 30 35 38 38 | 20 30 2e 30 33 39 32 31 |0.470588| 0.03921|
|00000c30| 36 20 30 2e 30 33 39 32 | 31 36 0a 58 09 09 30 2e |6 0.0392|16.X..0.|
|00000c40| 20 30 2e 20 30 2e 20 20 | 32 35 2e 20 30 2e 20 30 | 0. 0. |25. 0. 0|
|00000c50| 2e 20 31 2e 0a 58 73 75 | 72 66 61 63 65 20 73 31 |. 1..Xsu|rface s1|
|00000c60| 35 20 20 30 2e 33 39 32 | 31 35 37 20 30 2e 30 39 |5 0.392|157 0.09|
|00000c70| 38 30 33 39 20 30 2e 30 | 34 37 30 35 39 20 20 30 |8039 0.0|47059 0|
|00000c80| 2e 33 39 32 31 35 37 20 | 30 2e 30 39 38 30 33 39 |.392157 |0.098039|
|00000c90| 20 30 2e 30 34 37 30 35 | 39 0a 58 09 09 30 2e 30 | 0.04705|9.X..0.0|
|00000ca0| 33 39 32 31 36 20 30 2e | 30 33 39 32 31 36 20 30 |39216 0.|039216 0|
|00000cb0| 2e 30 33 39 32 31 36 20 | 20 33 2e 20 30 2e 20 30 |.039216 | 3. 0. 0|
|00000cc0| 2e 20 31 2e 0a 58 73 75 | 72 66 61 63 65 20 73 31 |. 1..Xsu|rface s1|
|00000cd0| 36 20 20 30 2e 35 30 39 | 38 30 34 20 30 2e 35 30 |6 0.509|804 0.50|
|00000ce0| 39 38 30 34 20 30 2e 35 | 30 39 38 30 34 20 20 30 |9804 0.5|09804 0|
|00000cf0| 2e 35 30 39 38 30 34 20 | 30 2e 35 30 39 38 30 34 |.509804 |0.509804|
|00000d00| 20 30 2e 35 30 39 38 30 | 34 0a 58 09 09 30 2e 31 | 0.50980|4.X..0.1|
|00000d10| 35 36 38 36 33 20 30 2e | 31 35 36 38 36 33 20 30 |56863 0.|156863 0|
|00000d20| 2e 31 35 36 38 36 33 20 | 20 37 2e 20 30 2e 31 20 |.156863 | 7. 0.1 |
|00000d30| 30 2e 20 31 2e 0a 58 0a | 58 09 73 70 68 65 72 65 |0. 1..X.|X.sphere|
|00000d40| 20 73 35 20 31 2e 35 20 | 20 30 2e 30 09 2d 32 31 | s5 1.5 | 0.0.-21|
|00000d50| 2e 09 09 31 2e 35 0a 58 | 09 73 70 68 65 72 65 20 |...1.5.X|.sphere |
|00000d60| 73 36 20 31 2e 35 20 20 | 31 2e 35 09 2d 32 33 2e |s6 1.5 |1.5.-23.|
|00000d70| 35 39 38 30 32 36 09 31 | 2e 35 0a 58 09 73 70 68 |598026.1|.5.X.sph|
|00000d80| 65 72 65 20 73 37 20 31 | 2e 35 20 2d 31 2e 35 09 |ere s7 1|.5 -1.5.|
|00000d90| 2d 32 33 2e 35 39 38 30 | 32 36 09 31 2e 35 0a 58 |-23.5980|26.1.5.X|
|00000da0| 09 73 70 68 65 72 65 20 | 73 38 20 31 2e 35 20 20 |.sphere |s8 1.5 |
|00000db0| 33 2e 30 09 2d 32 36 2e | 31 39 36 31 35 32 09 31 |3.0.-26.|196152.1|
|00000dc0| 2e 35 0a 58 09 73 70 68 | 65 72 65 20 73 39 20 31 |.5.X.sph|ere s9 1|
|00000dd0| 2e 35 20 20 30 2e 30 09 | 2d 32 36 2e 31 39 36 31 |.5 0.0.|-26.1961|
|00000de0| 35 32 09 31 2e 35 0a 58 | 09 73 70 68 65 72 65 20 |52.1.5.X|.sphere |
|00000df0| 73 35 20 31 2e 35 20 2d | 33 2e 30 09 2d 32 36 2e |s5 1.5 -|3.0.-26.|
|00000e00| 31 39 36 31 35 32 09 31 | 2e 35 0a 58 09 73 70 68 |196152.1|.5.X.sph|
|00000e10| 65 72 65 20 73 36 20 31 | 2e 35 20 20 34 2e 35 09 |ere s6 1|.5 4.5.|
|00000e20| 2d 32 38 2e 37 39 34 32 | 32 39 09 31 2e 35 0a 58 |-28.7942|29.1.5.X|
|00000e30| 09 73 70 68 65 72 65 20 | 73 37 20 31 2e 35 20 20 |.sphere |s7 1.5 |
|00000e40| 31 2e 35 09 2d 32 38 2e | 37 39 34 32 32 39 09 31 |1.5.-28.|794229.1|
|00000e50| 2e 35 0a 58 09 73 70 68 | 65 72 65 20 73 38 20 31 |.5.X.sph|ere s8 1|
|00000e60| 2e 35 20 2d 31 2e 35 09 | 2d 32 38 2e 37 39 34 32 |.5 -1.5.|-28.7942|
|00000e70| 32 39 09 31 2e 35 0a 58 | 09 73 70 68 65 72 65 20 |29.1.5.X|.sphere |
|00000e80| 73 39 20 31 2e 35 20 2d | 34 2e 35 09 2d 32 38 2e |s9 1.5 -|4.5.-28.|
|00000e90| 37 39 34 32 32 39 09 31 | 2e 35 0a 58 09 73 70 68 |794229.1|.5.X.sph|
|00000ea0| 65 72 65 20 73 35 20 31 | 2e 35 20 20 36 2e 30 09 |ere s5 1|.5 6.0.|
|00000eb0| 2d 33 31 2e 33 39 32 33 | 30 35 09 31 2e 35 0a 58 |-31.3923|05.1.5.X|
|00000ec0| 09 73 70 68 65 72 65 20 | 73 36 20 31 2e 35 20 20 |.sphere |s6 1.5 |
|00000ed0| 33 2e 30 09 2d 33 31 2e | 33 39 32 33 30 35 09 31 |3.0.-31.|392305.1|
|00000ee0| 2e 35 0a 58 09 73 70 68 | 65 72 65 20 73 37 20 31 |.5.X.sph|ere s7 1|
|00000ef0| 2e 35 20 20 30 2e 30 09 | 2d 33 31 2e 33 39 32 33 |.5 0.0.|-31.3923|
|00000f00| 30 35 09 31 2e 35 0a 58 | 09 73 70 68 65 72 65 20 |05.1.5.X|.sphere |
|00000f10| 73 38 20 31 2e 35 20 2d | 33 2e 30 09 2d 33 31 2e |s8 1.5 -|3.0.-31.|
|00000f20| 33 39 32 33 30 35 09 31 | 2e 35 0a 58 09 73 70 68 |392305.1|.5.X.sph|
|00000f30| 65 72 65 20 73 39 20 31 | 2e 35 20 2d 36 2e 30 09 |ere s9 1|.5 -6.0.|
|00000f40| 2d 33 31 2e 33 39 32 33 | 30 35 09 31 2e 35 0a 58 |-31.3923|05.1.5.X|
|00000f50| 0a 58 09 62 6f 78 20 73 | 34 20 30 2e 20 30 2e 20 |.X.box s|4 0. 0. |
|00000f60| 2d 31 2e 20 33 30 2e 20 | 35 37 2e 20 31 2e 0a 58 |-1. 30. |57. 1..X|
|00000f70| 09 62 6f 78 20 73 31 35 | 20 33 30 2e 20 30 2e 20 |.box s15| 30. 0. |
|00000f80| 30 2e 20 33 2e 20 35 34 | 2e 20 31 2e 35 20 74 65 |0. 3. 54|. 1.5 te|
|00000f90| 78 74 75 72 65 20 77 6f | 6f 64 20 73 63 61 6c 65 |xture wo|od scale|
|00000fa0| 20 35 2e 20 35 2e 20 35 | 2e 0a 58 09 62 6f 78 20 | 5. 5. 5|..X.box |
|00000fb0| 73 31 35 20 2d 33 30 2e | 20 30 2e 20 30 2e 20 33 |s15 -30.| 0. 0. 3|
|00000fc0| 2e 20 35 34 2e 20 31 2e | 35 20 74 65 78 74 75 72 |. 54. 1.|5 textur|
|00000fd0| 65 20 77 6f 6f 64 20 73 | 63 61 6c 65 20 35 2e 20 |e wood s|cale 5. |
|00000fe0| 35 2e 20 35 2e 0a 58 09 | 62 6f 78 20 73 31 35 20 |5. 5..X.|box s15 |
|00000ff0| 30 2e 20 35 37 2e 20 30 | 2e 20 33 33 2e 20 33 2e |0. 57. 0|. 33. 3.|
|00001000| 20 31 2e 35 20 74 65 78 | 74 75 72 65 20 77 6f 6f | 1.5 tex|ture woo|
|00001010| 64 20 73 63 61 6c 65 20 | 35 2e 20 35 2e 20 35 2e |d scale |5. 5. 5.|
|00001020| 0a 58 09 62 6f 78 20 73 | 31 35 20 30 2e 20 2d 35 |.X.box s|15 0. -5|
|00001030| 37 2e 20 30 2e 20 33 33 | 2e 20 33 2e 20 31 2e 35 |7. 0. 33|. 3. 1.5|
|00001040| 20 74 65 78 74 75 72 65 | 20 77 6f 6f 64 20 73 63 | texture| wood sc|
|00001050| 61 6c 65 20 35 2e 20 35 | 2e 20 35 2e 0a 58 09 73 |ale 5. 5|. 5..X.s|
|00001060| 70 68 65 72 65 20 73 31 | 36 20 31 2e 35 20 30 2e |phere s1|6 1.5 0.|
|00001070| 20 30 2e 20 30 2e 20 74 | 72 61 6e 73 6c 61 74 65 | 0. 0. t|ranslate|
|00001080| 20 30 2e 20 32 31 2e 20 | 31 2e 35 0a 58 09 62 6f | 0. 21. |1.5.X.bo|
|00001090| 78 20 6d 69 72 72 6f 72 | 20 31 30 2e 20 2d 31 34 |x mirror| 10. -14|
|000010a0| 34 2e 20 33 30 2e 20 32 | 31 2e 33 33 33 33 20 2e |4. 30. 2|1.3333 .|
|000010b0| 31 20 32 30 2e 09 2f 2a | 20 77 61 73 20 34 30 2e |1 20../*| was 40.|
|000010c0| 20 2d 31 34 34 20 33 30 | 2e 20 2a 2f 0a 58 09 2f | -144 30|. */.X./|
|000010d0| 2a 0a 58 09 20 2a 20 57 | 61 6c 6c 73 0a 58 09 20 |*.X. * W|alls.X. |
|000010e0| 2a 2f 0a 58 09 70 6c 61 | 6e 65 20 73 31 30 20 20 |*/.X.pla|ne s10 |
|000010f0| 20 20 30 2e 09 20 31 2e | 09 30 2e 20 09 30 2e 09 | 0.. 1.|.0. .0..|
|00001100| 2d 31 34 34 2e 09 30 2e | 0a 58 09 70 6c 61 6e 65 |-144..0.|.X.plane|
|00001110| 20 73 31 30 20 20 20 20 | 31 2e 09 20 30 2e 09 30 | s10 |1.. 0..0|
|00001120| 2e 20 20 20 2d 31 38 30 | 2e 09 20 20 20 30 2e 09 |. -180|.. 0..|
|00001130| 30 2e 0a 58 09 70 6c 61 | 6e 65 20 73 31 30 20 20 |0..X.pla|ne s10 |
|00001140| 20 2d 31 2e 09 20 30 2e | 09 30 2e 20 20 20 20 31 | -1.. 0.|.0. 1|
|00001150| 38 30 2e 09 20 20 20 30 | 2e 20 20 20 30 2e 0a 58 |80.. 0|. 0..X|
|00001160| 09 70 6c 61 6e 65 20 73 | 31 30 20 20 20 20 30 2e |.plane s|10 0.|
|00001170| 20 20 20 2d 31 2e 20 20 | 20 20 20 30 2e 09 30 2e | -1. | 0..0.|
|00001180| 09 20 31 34 34 2e 09 30 | 2e 0a 58 09 2f 2a 0a 58 |. 144..0|..X./*.X|
|00001190| 09 20 2a 20 46 6c 6f 6f | 72 0a 58 09 20 2a 2f 0a |. * Floo|r.X. */.|
|000011a0| 58 09 70 6c 61 6e 65 20 | 66 6c 6f 6f 72 20 20 20 |X.plane |floor |
|000011b0| 30 2e 09 20 30 2e 09 31 | 2e 09 30 2e 09 20 20 20 |0.. 0..1|..0.. |
|000011c0| 30 2e 20 2d 33 30 2e 0a | 58 09 09 74 65 78 74 75 |0. -30..|X..textu|
|000011d0| 72 65 20 6d 61 72 62 6c | 65 20 73 63 61 6c 65 20 |re marbl|e scale |
|000011e0| 34 2e 20 34 2e 20 34 2e | 20 74 72 61 6e 73 6c 61 |4. 4. 4.| transla|
|000011f0| 74 65 20 30 2e 20 30 2e | 20 2d 34 2e 33 37 36 20 |te 0. 0.| -4.376 |
|00001200| 0a 58 09 09 74 65 78 74 | 75 72 65 20 63 68 65 63 |.X..text|ure chec|
|00001210| 6b 65 72 20 62 6c 61 63 | 6b 74 69 6c 65 20 73 63 |ker blac|ktile sc|
|00001220| 61 6c 65 20 31 32 2e 33 | 20 31 32 2e 33 20 31 32 |ale 12.3| 12.3 12|
|00001230| 2e 33 0a 58 09 2f 2a 0a | 58 09 20 2a 20 43 65 69 |.3.X./*.|X. * Cei|
|00001240| 6c 69 6e 67 0a 58 09 20 | 2a 2f 0a 58 09 70 6c 61 |ling.X. |*/.X.pla|
|00001250| 6e 65 20 73 31 32 20 20 | 20 20 30 2e 20 20 20 30 |ne s12 | 0. 0|
|00001260| 2e 20 20 20 20 2d 31 2e | 20 20 09 30 2e 09 20 20 |. -1.| .0.. |
|00001270| 20 30 2e 20 20 37 32 2e | 0a 58 0a 58 65 79 65 70 | 0. 72.|.X.Xeyep|
|00001280| 20 33 38 2e 20 31 30 30 | 2e 20 34 33 2e 0a 58 6c | 38. 100|. 43..Xl|
|00001290| 6f 6f 6b 70 20 30 2e 20 | 30 2e 20 30 2e 0a 58 67 |ookp 0. |0. 0..Xg|
|000012a0| 72 69 64 20 32 30 20 32 | 30 20 31 30 0a 58 6a 69 |rid 20 2|0 10.Xji|
|000012b0| 74 74 65 72 65 64 0a 58 | 73 61 6d 70 6c 65 73 20 |ttered.X|samples |
|000012c0| 33 0a 45 4e 44 5f 4f 46 | 5f 46 49 4c 45 0a 69 66 |3.END_OF|_FILE.if|
|000012d0| 20 74 65 73 74 20 33 35 | 37 39 20 2d 6e 65 20 60 | test 35|79 -ne `|
|000012e0| 77 63 20 2d 63 20 3c 27 | 45 78 61 6d 70 6c 65 73 |wc -c <'|Examples|
|000012f0| 2f 70 6f 6f 6c 2e 72 61 | 79 27 60 3b 20 74 68 65 |/pool.ra|y'`; the|
|00001300| 6e 0a 20 20 20 20 65 63 | 68 6f 20 73 68 61 72 3a |n. ec|ho shar:|
|00001310| 20 5c 22 27 45 78 61 6d | 70 6c 65 73 2f 70 6f 6f | \"'Exam|ples/poo|
|00001320| 6c 2e 72 61 79 27 5c 22 | 20 75 6e 70 61 63 6b 65 |l.ray'\"| unpacke|
|00001330| 64 20 77 69 74 68 20 77 | 72 6f 6e 67 20 73 69 7a |d with w|rong siz|
|00001340| 65 21 0a 66 69 0a 23 20 | 65 6e 64 20 6f 66 20 27 |e!.fi.# |end of '|
|00001350| 45 78 61 6d 70 6c 65 73 | 2f 70 6f 6f 6c 2e 72 61 |Examples|/pool.ra|
|00001360| 79 27 0a 66 69 0a 69 66 | 20 74 65 73 74 20 2d 66 |y'.fi.if| test -f|
|00001370| 20 27 6e 66 66 32 73 68 | 61 64 65 2e 61 77 6b 27 | 'nff2sh|ade.awk'|
|00001380| 20 2d 61 20 22 24 7b 31 | 7d 22 20 21 3d 20 22 2d | -a "${1|}" != "-|
|00001390| 63 22 20 3b 20 74 68 65 | 6e 20 0a 20 20 65 63 68 |c" ; the|n . ech|
|000013a0| 6f 20 73 68 61 72 3a 20 | 57 69 6c 6c 20 6e 6f 74 |o shar: |Will not|
|000013b0| 20 63 6c 6f 62 62 65 72 | 20 65 78 69 73 74 69 6e | clobber| existin|
|000013c0| 67 20 66 69 6c 65 20 5c | 22 27 6e 66 66 32 73 68 |g file \|"'nff2sh|
|000013d0| 61 64 65 2e 61 77 6b 27 | 5c 22 0a 65 6c 73 65 0a |ade.awk'|\".else.|
|000013e0| 65 63 68 6f 20 73 68 61 | 72 3a 20 45 78 74 72 61 |echo sha|r: Extra|
|000013f0| 63 74 69 6e 67 20 5c 22 | 27 6e 66 66 32 73 68 61 |cting \"|'nff2sha|
|00001400| 64 65 2e 61 77 6b 27 5c | 22 20 5c 28 33 32 32 33 |de.awk'\|" \(3223|
|00001410| 20 63 68 61 72 61 63 74 | 65 72 73 5c 29 0a 73 65 | charact|ers\).se|
|00001420| 64 20 22 73 2f 5e 58 2f | 2f 22 20 3e 27 6e 66 66 |d "s/^X/|/" >'nff|
|00001430| 32 73 68 61 64 65 2e 61 | 77 6b 27 20 3c 3c 27 45 |2shade.a|wk' <<'E|
|00001440| 4e 44 5f 4f 46 5f 46 49 | 4c 45 27 0a 58 23 0a 58 |ND_OF_FI|LE'.X#.X|
|00001450| 23 20 54 68 69 73 20 61 | 77 6b 20 73 63 72 69 70 |# This a|wk scrip|
|00001460| 74 20 77 69 6c 6c 20 63 | 6f 6e 76 65 72 74 20 61 |t will c|onvert a|
|00001470| 6e 20 4e 46 46 2d 66 6f | 72 6d 61 74 20 69 6e 70 |n NFF-fo|rmat inp|
|00001480| 75 74 20 66 69 6c 65 20 | 28 61 73 20 6f 75 74 70 |ut file |(as outp|
|00001490| 75 74 20 62 79 0a 58 23 | 20 45 72 69 63 20 48 61 |ut by.X#| Eric Ha|
|000014a0| 69 6e 65 73 27 20 53 50 | 44 29 20 74 6f 20 73 6f |ines' SP|D) to so|
|000014b0| 6d 65 74 68 69 6e 67 20 | 72 61 79 73 68 61 64 65 |mething |rayshade|
|000014c0| 20 63 61 6e 20 75 6e 64 | 65 72 73 74 61 6e 64 2e | can und|erstand.|
|000014d0| 0a 58 23 20 54 68 65 20 | 57 6f 72 6c 64 20 6f 62 |.X# The |World ob|
|000014e0| 6a 65 63 74 20 77 69 6c | 6c 20 62 65 20 65 6e 63 |ject wil|l be enc|
|000014f0| 6c 6f 73 65 64 20 69 6e | 20 61 20 73 69 6e 67 6c |losed in| a singl|
|00001500| 65 20 67 72 69 64 20 6f | 66 20 32 32 2a 32 32 2a |e grid o|f 22*22*|
|00001510| 32 32 20 76 6f 78 65 6c | 73 2e 0a 58 23 0a 58 23 |22 voxel|s..X#.X#|
|00001520| 20 45 78 61 6d 70 6c 65 | 20 75 73 61 67 65 3a 0a | Example| usage:.|
|00001530| 58 23 09 6d 6f 75 6e 74 | 61 69 6e 73 20 7c 20 61 |X#.mount|ains | a|
|00001540| 77 6b 20 2d 66 20 6e 66 | 66 32 73 68 61 64 65 2e |wk -f nf|f2shade.|
|00001550| 61 77 6b 20 7c 20 72 61 | 79 73 68 61 64 65 20 3e |awk | ra|yshade >|
|00001560| 20 6d 6f 75 6e 74 61 69 | 6e 73 2e 72 6c 65 0a 58 | mountai|ns.rle.X|
|00001570| 23 0a 58 23 20 46 6f 72 | 20 62 65 73 74 20 72 65 |#.X# For| best re|
|00001580| 73 75 6c 74 73 2c 20 6f | 6e 65 20 73 68 6f 75 6c |sults, o|ne shoul|
|00001590| 64 20 6d 6f 64 69 66 79 | 20 74 68 65 20 6f 75 74 |d modify| the out|
|000015a0| 70 75 74 20 66 6f 72 20 | 61 6c 6c 20 62 75 74 20 |put for |all but |
|000015b0| 74 68 65 20 74 65 74 72 | 61 0a 58 23 20 61 6e 64 |the tetr|a.X# and|
|000015c0| 20 6d 6f 75 6e 74 61 69 | 6e 20 64 61 74 61 62 61 | mountai|n databa|
|000015d0| 73 65 73 20 74 6f 20 70 | 72 6f 76 69 64 65 20 61 |ses to p|rovide a|
|000015e0| 20 74 69 67 68 74 65 72 | 20 62 6f 75 6e 64 69 6e | tighter| boundin|
|000015f0| 67 20 62 6f 78 20 61 72 | 6f 75 6e 64 20 74 68 65 |g box ar|ound the|
|00001600| 0a 58 23 20 6f 62 6a 65 | 63 74 20 6f 66 20 69 6e |.X# obje|ct of in|
|00001610| 74 65 72 65 73 74 20 28 | 74 72 65 65 2c 20 67 65 |terest (|tree, ge|
|00001620| 61 72 73 2c 20 65 74 63 | 2e 29 2e 20 20 54 68 69 |ars, etc|.). Thi|
|00001630| 73 20 69 73 20 64 6f 6e | 65 20 62 79 20 70 6c 61 |s is don|e by pla|
|00001640| 63 69 6e 67 0a 58 23 20 | 61 6c 6c 20 70 72 69 6d |cing.X# |all prim|
|00001650| 69 74 69 76 65 73 20 62 | 75 74 20 74 68 65 20 67 |itives b|ut the g|
|00001660| 72 6f 75 6e 64 20 70 6f | 6c 6f 67 6f 6e 20 69 6e |round po|logon in|
|00001670| 74 6f 20 61 6e 20 6f 62 | 6a 65 63 74 20 73 74 6f |to an ob|ject sto|
|00001680| 72 65 64 20 61 73 20 61 | 20 47 72 69 64 2c 0a 58 |red as a| Grid,.X|
|00001690| 23 20 61 6e 64 20 74 68 | 65 6e 20 69 6e 73 74 61 |# and th|en insta|
|000016a0| 6e 74 69 61 74 69 6e 67 | 20 74 68 61 74 20 6f 62 |ntiating| that ob|
|000016b0| 6a 65 63 74 20 6f 6e 63 | 65 2e 20 20 54 68 69 73 |ject onc|e. This|
|000016c0| 20 77 69 6c 6c 20 64 65 | 63 72 65 61 73 65 20 72 | will de|crease r|
|000016d0| 61 79 2d 74 72 61 63 69 | 6e 67 0a 58 23 20 74 69 |ay-traci|ng.X# ti|
|000016e0| 6d 65 20 64 72 61 6d 61 | 74 69 63 61 6c 6c 79 2e |me drama|tically.|
|000016f0| 0a 58 23 0a 58 23 20 24 | 49 64 3a 20 6e 66 66 32 |.X#.X# $|Id: nff2|
|00001700| 73 68 61 64 65 2e 61 77 | 6b 2c 76 20 33 2e 30 20 |shade.aw|k,v 3.0 |
|00001710| 38 39 2f 31 30 2f 32 37 | 20 30 31 3a 33 30 3a 32 |89/10/27| 01:30:2|
|00001720| 34 20 63 72 61 69 67 20 | 45 78 70 20 24 0a 58 23 |4 craig |Exp $.X#|
|00001730| 0a 58 23 20 24 4c 6f 67 | 3a 09 6e 66 66 32 73 68 |.X# $Log|:.nff2sh|
|00001740| 61 64 65 2e 61 77 6b 2c | 76 20 24 0a 58 23 20 52 |ade.awk,|v $.X# R|
|00001750| 65 76 69 73 69 6f 6e 20 | 33 2e 30 20 20 38 39 2f |evision |3.0 89/|
|00001760| 31 30 2f 32 37 20 20 30 | 31 3a 33 30 3a 32 34 20 |10/27 0|1:30:24 |
|00001770| 20 63 72 61 69 67 0a 58 | 23 20 42 61 73 65 6c 69 | craig.X|# Baseli|
|00001780| 6e 65 20 66 6f 72 20 66 | 69 72 73 74 20 6f 66 66 |ne for f|irst off|
|00001790| 69 63 69 61 6c 20 72 65 | 6c 65 61 73 65 2e 0a 58 |icial re|lease..X|
|000017a0| 23 20 0a 58 23 20 43 2e | 20 4b 6f 6c 62 20 39 2f |# .X# C.| Kolb 9/|
|000017b0| 32 31 2f 38 39 0a 58 23 | 20 46 69 78 65 64 20 63 |21/89.X#| Fixed c|
|000017c0| 6f 6d 6d 65 6e 74 20 62 | 75 67 3b 20 63 68 65 63 |omment b|ug; chec|
|000017d0| 6b 20 66 69 72 73 74 20 | 63 68 61 72 61 63 74 65 |k first |characte|
|000017e0| 72 20 72 61 74 68 65 72 | 20 74 68 61 6e 20 66 69 |r rather| than fi|
|000017f0| 72 73 74 20 66 69 65 6c | 64 20 66 6f 72 20 22 23 |rst fiel|d for "#|
|00001800| 22 2e 0a 58 23 20 4b 65 | 65 70 20 74 72 61 63 6b |"..X# Ke|ep track|
|00001810| 20 6f 66 20 64 65 66 69 | 6e 65 64 20 73 75 72 66 | of defi|ned surf|
|00001820| 61 63 65 73 20 69 6e 20 | 61 73 73 6f 63 69 61 74 |aces in |associat|
|00001830| 69 76 65 20 61 72 72 61 | 79 20 73 6f 20 69 66 20 |ive arra|y so if |
|00001840| 6f 6e 65 20 69 73 20 75 | 73 65 64 0a 58 23 20 61 |one is u|sed.X# a|
|00001850| 67 61 69 6e 20 77 65 20 | 64 6f 6e 27 74 20 63 72 |gain we |don't cr|
|00001860| 65 61 74 65 20 61 6e 6f | 74 68 65 72 20 63 6f 70 |eate ano|ther cop|
|00001870| 79 2e 0a 58 23 20 48 61 | 6c 76 65 64 20 61 6d 62 |y..X# Ha|lved amb|
|00001880| 69 65 6e 74 20 69 6e 74 | 65 6e 73 69 74 79 20 6f |ient int|ensity o|
|00001890| 66 20 73 75 72 66 61 63 | 65 73 2e 0a 58 23 20 43 |f surfac|es..X# C|
|000018a0| 2e 20 4b 6f 6c 62 20 31 | 30 2f 31 32 2f 38 39 0a |. Kolb 1|0/12/89.|
|000018b0| 58 23 20 41 64 64 65 64 | 20 22 61 64 61 70 74 69 |X# Added| "adapti|
|000018c0| 76 65 20 30 22 20 61 6e | 64 20 22 63 75 74 6f 66 |ve 0" an|d "cutof|
|000018d0| 66 20 30 22 20 74 6f 20 | 42 45 47 49 4e 20 61 6e |f 0" to |BEGIN an|
|000018e0| 64 20 72 65 6d 6f 76 65 | 64 20 22 65 6e 64 66 69 |d remove|d "endfi|
|000018f0| 6c 65 22 20 66 72 6f 6d | 20 45 4e 44 2e 0a 58 23 |le" from| END..X#|
|00001900| 20 43 2e 20 4b 6f 6c 62 | 20 32 2f 38 39 0a 58 23 | C. Kolb| 2/89.X#|
|00001910| 20 46 69 72 73 74 20 76 | 65 72 73 69 6f 6e 2e 0a | First v|ersion..|
|00001920| 58 23 0a 58 42 45 47 49 | 4e 7b 0a 58 09 6c 69 67 |X#.XBEGI|N{.X.lig|
|00001930| 68 74 73 20 3d 20 30 3b | 0a 58 09 73 75 72 66 73 |hts = 0;|.X.surfs|
|00001940| 20 3d 20 30 3b 0a 58 09 | 70 72 69 6e 74 20 22 6d | = 0;.X.|print "m|
|00001950| 61 78 64 65 70 74 68 20 | 34 22 0a 58 09 70 72 69 |axdepth |4".X.pri|
|00001960| 6e 74 20 22 61 64 61 70 | 74 69 76 65 20 30 22 0a |nt "adap|tive 0".|
|00001970| 58 09 70 72 69 6e 74 20 | 22 63 75 74 6f 66 66 20 |X.print |"cutoff |
|00001980| 30 2e 22 0a 58 7d 0a 58 | 73 75 62 73 74 72 28 24 |0.".X}.X|substr($|
|00001990| 31 2c 20 31 2c 20 31 29 | 20 3d 3d 20 22 23 22 20 |1, 1, 1)| == "#" |
|000019a0| 7b 20 70 72 69 6e 74 20 | 22 2f 2a 20 22 20 24 30 |{ print |"/* " $0|
|000019b0| 20 22 20 2a 2f 22 3b 20 | 6e 65 78 74 3b 7d 0a 58 | " */"; |next;}.X|
|000019c0| 24 31 20 3d 3d 20 22 76 | 22 20 7b 20 6e 65 78 74 |$1 == "v|" { next|
|000019d0| 3b 7d 0a 58 24 31 20 3d | 3d 20 22 66 72 6f 6d 22 |;}.X$1 =|= "from"|
|000019e0| 20 7b 20 70 72 69 6e 74 | 20 22 65 79 65 70 20 22 | { print| "eyep "|
|000019f0| 20 24 32 20 22 20 22 24 | 33 20 22 20 22 20 24 34 | $2 " "$|3 " " $4|
|00001a00| 3b 20 6e 65 78 74 3b 7d | 0a 58 24 31 20 3d 3d 20 |; next;}|.X$1 == |
|00001a10| 22 61 74 22 20 7b 70 72 | 69 6e 74 20 22 6c 6f 6f |"at" {pr|int "loo|
|00001a20| 6b 70 20 22 20 24 32 20 | 22 20 22 24 33 20 22 20 |kp " $2 |" "$3 " |
|00001a30| 22 24 34 3b 20 6e 65 78 | 74 3b 7d 0a 58 24 31 20 |"$4; nex|t;}.X$1 |
|00001a40| 3d 3d 20 22 75 70 22 20 | 7b 70 72 69 6e 74 3b 20 |== "up" |{print; |
|00001a50| 6e 65 78 74 3b 7d 0a 58 | 24 31 20 3d 3d 20 22 61 |next;}.X|$1 == "a|
|00001a60| 6e 67 6c 65 22 20 7b 20 | 70 72 69 6e 74 20 22 66 |ngle" { |print "f|
|00001a70| 6f 76 20 22 20 24 32 3b | 20 6e 65 78 74 3b 7d 0a |ov " $2;| next;}.|
|00001a80| 58 24 31 20 3d 3d 20 22 | 68 69 74 68 65 72 22 20 |X$1 == "|hither" |
|00001a90| 7b 6e 65 78 74 3b 7d 0a | 58 24 31 20 3d 3d 20 22 |{next;}.|X$1 == "|
|00001aa0| 72 65 73 6f 6c 75 74 69 | 6f 6e 22 20 7b 70 72 69 |resoluti|on" {pri|
|00001ab0| 6e 74 20 22 73 63 72 65 | 65 6e 20 22 20 24 32 20 |nt "scre|en " $2 |
|00001ac0| 22 20 22 24 33 3b 20 6e | 65 78 74 3b 7d 0a 58 0a |" "$3; n|ext;}.X.|
|00001ad0| 58 24 31 20 3d 3d 20 22 | 6c 22 20 7b 20 6c 69 67 |X$1 == "|l" { lig|
|00001ae0| 68 74 64 5b 6c 69 67 68 | 74 73 5d 20 3d 20 24 32 |htd[ligh|ts] = $2|
|00001af0| 20 22 20 22 24 33 20 22 | 20 22 24 34 3b 20 6c 69 | " "$3 "| "$4; li|
|00001b00| 67 68 74 73 2b 2b 3b 20 | 6e 65 78 74 3b 20 7d 0a |ghts++; |next; }.|
|00001b10| 58 24 31 20 3d 3d 20 22 | 62 22 20 7b 70 72 69 6e |X$1 == "|b" {prin|
|00001b20| 74 20 22 62 61 63 6b 67 | 72 6f 75 6e 64 20 22 20 |t "backg|round " |
|00001b30| 24 32 20 22 20 22 24 33 | 20 22 20 22 24 34 3b 20 |$2 " "$3| " "$4; |
|00001b40| 6e 65 78 74 3b 20 7d 0a | 58 24 31 20 3d 3d 20 22 |next; }.|X$1 == "|
|00001b50| 66 22 20 7b 0a 58 09 69 | 66 20 28 73 75 72 66 61 |f" {.X.i|f (surfa|
|00001b60| 63 65 73 5b 24 32 20 24 | 33 20 24 34 20 24 35 20 |ces[$2 $|3 $4 $5 |
|00001b70| 24 36 20 24 37 20 24 38 | 5d 20 21 3d 20 30 29 20 |$6 $7 $8|] != 0) |
|00001b80| 7b 0a 58 09 09 63 75 72 | 73 75 72 66 20 3d 20 73 |{.X..cur|surf = s|
|00001b90| 75 72 66 61 63 65 73 5b | 24 32 20 24 33 20 24 34 |urfaces[|$2 $3 $4|
|00001ba0| 20 24 35 20 24 36 20 24 | 37 20 24 38 5d 3b 0a 58 | $5 $6 $|7 $8];.X|
|00001bb0| 09 09 6e 65 78 74 3b 0a | 58 09 7d 0a 58 09 73 75 |..next;.|X.}.X.su|
|00001bc0| 72 66 73 2b 2b 3b 0a 58 | 09 73 75 72 66 61 63 65 |rfs++;.X|.surface|
|00001bd0| 73 5b 24 32 20 24 33 20 | 24 34 20 24 35 20 24 36 |s[$2 $3 |$4 $5 $6|
|00001be0| 20 24 37 20 24 38 5d 20 | 3d 20 73 75 72 66 73 3b | $7 $8] |= surfs;|
|00001bf0| 0a 58 09 63 75 72 73 75 | 72 66 20 3d 20 73 75 72 |.X.cursu|rf = sur|
|00001c00| 66 73 3b 0a 58 09 61 69 | 6e 74 65 6e 73 20 3d 20 |fs;.X.ai|ntens = |
|00001c10| 73 71 72 74 28 6c 69 67 | 68 74 73 29 20 2f 20 28 |sqrt(lig|hts) / (|
|00001c20| 34 2a 6c 69 67 68 74 73 | 29 3b 0a 58 09 64 72 20 |4*lights|);.X.dr |
|00001c30| 3d 20 24 32 2a 24 35 3b | 0a 58 09 64 67 20 3d 20 |= $2*$5;|.X.dg = |
|00001c40| 24 33 2a 24 35 3b 0a 58 | 09 64 62 20 3d 20 24 34 |$3*$5;.X|.db = $4|
|00001c50| 2a 24 35 3b 0a 58 23 20 | 74 68 69 73 20 69 73 20 |*$5;.X# |this is |
|00001c60| 61 20 67 6f 6f 64 20 67 | 75 65 73 73 2e 2e 2e 2e |a good g|uess....|
|00001c70| 0a 58 09 61 72 20 3d 20 | 61 69 6e 74 65 6e 73 2a |.X.ar = |aintens*|
|00001c80| 64 72 3b 0a 58 09 61 67 | 20 3d 20 61 69 6e 74 65 |dr;.X.ag| = ainte|
|00001c90| 6e 73 2a 64 67 3b 0a 58 | 09 61 62 20 3d 20 61 69 |ns*dg;.X|.ab = ai|
|00001ca0| 6e 74 65 6e 73 2a 64 62 | 3b 0a 58 23 0a 58 23 20 |ntens*db|;.X#.X# |
|00001cb0| 57 65 20 73 65 74 20 22 | 72 65 66 6c 65 63 74 61 |We set "|reflecta|
|00001cc0| 6e 63 65 22 20 74 6f 20 | 74 68 65 20 6d 69 6e 69 |nce" to |the mini|
|00001cd0| 6d 75 6d 20 6f 66 20 4b | 73 20 61 6e 64 20 31 2e |mum of K|s and 1.|
|00001ce0| 20 2d 20 54 2c 20 61 73 | 0a 58 23 20 45 72 69 63 | - T, as|.X# Eric|
|00001cf0| 20 48 61 69 6e 65 73 27 | 20 53 50 44 20 69 6e 63 | Haines'| SPD inc|
|00001d00| 6c 75 64 65 73 20 73 65 | 76 65 72 61 6c 20 6f 62 |ludes se|veral ob|
|00001d10| 6a 65 63 74 73 20 77 68 | 69 63 68 20 68 61 76 65 |jects wh|ich have|
|00001d20| 20 4b 73 20 2b 20 54 20 | 3e 20 31 2e 0a 58 23 0a | Ks + T |> 1..X#.|
|00001d30| 58 09 69 66 20 28 24 36 | 20 3c 20 31 2e 20 2d 20 |X.if ($6| < 1. - |
|00001d40| 24 38 29 0a 58 09 09 72 | 65 66 6c 65 63 74 20 3d |$8).X..r|eflect =|
|00001d50| 20 24 36 3b 0a 58 09 65 | 6c 73 65 0a 58 09 09 72 | $6;.X.e|lse.X..r|
|00001d60| 65 66 6c 65 63 74 20 3d | 20 31 2e 20 2d 20 24 38 |eflect =| 1. - $8|
|00001d70| 3b 0a 58 09 70 72 69 6e | 74 66 28 22 73 75 72 66 |;.X.prin|tf("surf|
|00001d80| 61 63 65 20 73 25 64 20 | 20 25 66 20 25 66 20 25 |ace s%d | %f %f %|
|00001d90| 66 20 20 25 66 20 25 66 | 20 25 66 20 20 25 66 20 |f %f %f| %f %f |
|00001da0| 25 66 20 25 66 20 20 25 | 66 20 25 66 20 25 66 20 |%f %f %|f %f %f |
|00001db0| 25 66 5c 6e 22 2c 20 5c | 0a 58 09 09 63 75 72 73 |%f\n", \|.X..curs|
|00001dc0| 75 72 66 2c 20 61 72 2c | 20 61 67 2c 20 61 62 2c |urf, ar,| ag, ab,|
|00001dd0| 20 64 72 2c 20 64 67 2c | 20 64 62 2c 20 24 36 2c | dr, dg,| db, $6,|
|00001de0| 20 24 36 2c 20 24 36 2c | 20 24 37 2c 20 72 65 66 | $6, $6,| $7, ref|
|00001df0| 6c 65 63 74 2c 20 24 38 | 2c 20 24 39 29 3b 0a 58 |lect, $8|, $9);.X|
|00001e00| 09 6e 65 78 74 3b 0a 58 | 7d 0a 58 0a 58 24 31 20 |.next;.X|}.X.X$1 |
|00001e10| 3d 3d 20 22 63 22 20 7b | 0a 58 09 67 65 74 6c 69 |== "c" {|.X.getli|
|00001e20| 6e 65 3b 0a 58 09 78 31 | 20 3d 20 24 31 3b 0a 58 |ne;.X.x1| = $1;.X|
|00001e30| 09 79 31 20 3d 20 24 32 | 3b 0a 58 09 7a 31 20 3d |.y1 = $2|;.X.z1 =|
|00001e40| 20 24 33 3b 0a 58 09 62 | 72 20 3d 20 24 34 3b 0a | $3;.X.b|r = $4;.|
|00001e50| 58 09 67 65 74 6c 69 6e | 65 3b 0a 58 09 70 72 69 |X.getlin|e;.X.pri|
|00001e60| 6e 74 66 28 22 63 6f 6e | 65 20 73 25 64 20 25 66 |ntf("con|e s%d %f|
|00001e70| 20 25 66 20 25 66 20 25 | 66 20 25 66 20 25 66 20 | %f %f %|f %f %f |
|00001e80| 25 66 20 25 66 5c 6e 22 | 2c 20 5c 0a 58 09 09 63 |%f %f\n"|, \.X..c|
|00001e90| 75 72 73 75 72 66 2c 20 | 78 31 2c 20 79 31 2c 20 |ursurf, |x1, y1, |
|00001ea0| 7a 31 2c 20 24 31 2c 20 | 24 32 2c 20 24 33 2c 20 |z1, $1, |$2, $3, |
|00001eb0| 62 72 2c 20 24 34 29 3b | 0a 58 09 6e 65 78 74 3b |br, $4);|.X.next;|
|00001ec0| 0a 58 7d 0a 58 24 31 20 | 3d 3d 20 22 73 22 20 7b |.X}.X$1 |== "s" {|
|00001ed0| 0a 58 09 70 72 69 6e 74 | 20 22 73 70 68 65 72 65 |.X.print| "sphere|
|00001ee0| 20 73 22 63 75 72 73 75 | 72 66 20 22 20 22 24 35 | s"cursu|rf " "$5|
|00001ef0| 20 22 20 22 24 32 20 22 | 20 22 24 33 20 22 20 22 | " "$2 "| "$3 " "|
|00001f00| 24 34 3b 0a 58 09 6e 65 | 78 74 3b 0a 58 7d 0a 58 |$4;.X.ne|xt;.X}.X|
|00001f10| 24 31 20 3d 3d 20 22 70 | 70 22 20 7b 0a 58 09 69 |$1 == "p|p" {.X.i|
|00001f20| 66 20 28 24 32 20 3d 3d | 20 33 29 0a 58 09 09 70 |f ($2 ==| 3).X..p|
|00001f30| 72 69 6e 74 20 22 74 72 | 69 61 6e 67 6c 65 20 73 |rint "tr|iangle s|
|00001f40| 22 63 75 72 73 75 72 66 | 3b 0a 58 09 65 6c 73 65 |"cursurf|;.X.else|
|00001f50| 0a 58 09 09 70 72 69 6e | 74 20 22 70 6f 6c 79 20 |.X..prin|t "poly |
|00001f60| 73 22 63 75 72 73 75 72 | 66 3b 0a 58 09 6e 65 78 |s"cursur|f;.X.nex|
|00001f70| 74 3b 0a 58 7d 0a 58 24 | 31 20 3d 3d 20 22 70 22 |t;.X}.X$|1 == "p"|
|00001f80| 20 7b 0a 58 23 0a 58 23 | 20 50 6f 6c 79 67 6f 6e | {.X#.X#| Polygon|
|00001f90| 20 2d 2d 20 74 68 65 20 | 76 65 72 74 69 63 65 73 | -- the |vertices|
|00001fa0| 20 77 69 6c 6c 20 70 72 | 69 6e 74 20 6f 75 74 20 | will pr|int out |
|00001fb0| 69 6e 20 74 68 65 20 64 | 65 66 61 75 6c 74 20 73 |in the d|efault s|
|00001fc0| 74 61 74 65 6d 65 6e 74 | 2e 0a 58 23 20 49 66 20 |tatement|..X# If |
|00001fd0| 74 68 65 72 65 20 61 72 | 65 20 74 68 72 65 65 20 |there ar|e three |
|00001fe0| 76 65 72 74 69 63 65 73 | 2c 20 6d 61 6b 65 20 69 |vertices|, make i|
|00001ff0| 74 20 61 20 74 72 69 61 | 6e 67 6c 65 2e 0a 58 23 |t a tria|ngle..X#|
|00002000| 0a 58 09 69 66 20 28 24 | 32 20 3d 3d 20 33 29 0a |.X.if ($|2 == 3).|
|00002010| 58 09 09 70 72 69 6e 74 | 20 22 74 72 69 61 6e 67 |X..print| "triang|
|00002020| 6c 65 20 73 22 63 75 72 | 73 75 72 66 3b 0a 58 09 |le s"cur|surf;.X.|
|00002030| 65 6c 73 65 0a 58 09 09 | 70 72 69 6e 74 20 22 70 |else.X..|print "p|
|00002040| 6f 6c 79 20 73 22 63 75 | 72 73 75 72 66 3b 0a 58 |oly s"cu|rsurf;.X|
|00002050| 09 6e 65 78 74 3b 0a 58 | 7d 0a 58 7b 0a 58 23 20 |.next;.X|}.X{.X# |
|00002060| 4d 61 74 63 68 65 64 20 | 6e 6f 74 68 69 6e 67 20 |Matched |nothing |
|00002070| 28 6f 72 20 69 73 20 61 | 20 76 65 72 74 65 78 20 |(or is a| vertex |
|00002080| 64 61 74 61 29 20 2d 2d | 20 70 72 69 6e 74 20 69 |data) --| print i|
|00002090| 74 2e 0a 58 09 70 72 69 | 6e 74 3b 0a 58 09 6e 65 |t..X.pri|nt;.X.ne|
|000020a0| 78 74 3b 0a 58 7d 0a 58 | 45 4e 44 7b 0a 58 23 0a |xt;.X}.X|END{.X#.|
|000020b0| 58 23 20 4f 75 74 70 75 | 74 20 6c 69 67 68 74 20 |X# Outpu|t light |
|000020c0| 64 65 66 69 6e 69 74 69 | 6f 6e 73 2e 0a 58 23 0a |definiti|ons..X#.|
|000020d0| 58 09 69 6e 74 65 6e 73 | 20 3d 20 73 71 72 74 28 |X.intens| = sqrt(|
|000020e0| 6c 69 67 68 74 73 29 20 | 2f 20 28 6c 69 67 68 74 |lights) |/ (light|
|000020f0| 73 29 3b 0a 58 09 66 6f | 72 20 28 69 20 3d 20 30 |s);.X.fo|r (i = 0|
|00002100| 3b 20 69 20 3c 20 6c 69 | 67 68 74 73 3b 20 69 2b |; i < li|ghts; i+|
|00002110| 2b 29 20 7b 0a 58 09 09 | 70 72 69 6e 74 20 22 6c |+) {.X..|print "l|
|00002120| 69 67 68 74 20 22 20 69 | 6e 74 65 6e 73 20 22 20 |ight " i|ntens " |
|00002130| 70 6f 69 6e 74 20 22 20 | 6c 69 67 68 74 64 5b 69 |point " |lightd[i|
|00002140| 5d 0a 58 09 7d 0a 58 09 | 70 72 69 6e 74 20 22 67 |].X.}.X.|print "g|
|00002150| 72 69 64 20 32 32 20 32 | 32 20 32 32 22 0a 58 7d |rid 22 2|2 22".X}|
|00002160| 0a 45 4e 44 5f 4f 46 5f | 46 49 4c 45 0a 69 66 20 |.END_OF_|FILE.if |
|00002170| 74 65 73 74 20 33 32 32 | 33 20 2d 6e 65 20 60 77 |test 322|3 -ne `w|
|00002180| 63 20 2d 63 20 3c 27 6e | 66 66 32 73 68 61 64 65 |c -c <'n|ff2shade|
|00002190| 2e 61 77 6b 27 60 3b 20 | 74 68 65 6e 0a 20 20 20 |.awk'`; |then. |
|000021a0| 20 65 63 68 6f 20 73 68 | 61 72 3a 20 5c 22 27 6e | echo sh|ar: \"'n|
|000021b0| 66 66 32 73 68 61 64 65 | 2e 61 77 6b 27 5c 22 20 |ff2shade|.awk'\" |
|000021c0| 75 6e 70 61 63 6b 65 64 | 20 77 69 74 68 20 77 72 |unpacked| with wr|
|000021d0| 6f 6e 67 20 73 69 7a 65 | 21 0a 66 69 0a 23 20 65 |ong size|!.fi.# e|
|000021e0| 6e 64 20 6f 66 20 27 6e | 66 66 32 73 68 61 64 65 |nd of 'n|ff2shade|
|000021f0| 2e 61 77 6b 27 0a 66 69 | 0a 69 66 20 74 65 73 74 |.awk'.fi|.if test|
|00002200| 20 2d 66 20 27 73 72 63 | 2f 64 61 74 61 74 79 70 | -f 'src|/datatyp|
|00002210| 65 73 2e 68 27 20 2d 61 | 20 22 24 7b 31 7d 22 20 |es.h' -a| "${1}" |
|00002220| 21 3d 20 22 2d 63 22 20 | 3b 20 74 68 65 6e 20 0a |!= "-c" |; then .|
|00002230| 20 20 65 63 68 6f 20 73 | 68 61 72 3a 20 57 69 6c | echo s|har: Wil|
|00002240| 6c 20 6e 6f 74 20 63 6c | 6f 62 62 65 72 20 65 78 |l not cl|obber ex|
|00002250| 69 73 74 69 6e 67 20 66 | 69 6c 65 20 5c 22 27 73 |isting f|ile \"'s|
|00002260| 72 63 2f 64 61 74 61 74 | 79 70 65 73 2e 68 27 5c |rc/datat|ypes.h'\|
|00002270| 22 0a 65 6c 73 65 0a 65 | 63 68 6f 20 73 68 61 72 |".else.e|cho shar|
|00002280| 3a 20 45 78 74 72 61 63 | 74 69 6e 67 20 5c 22 27 |: Extrac|ting \"'|
|00002290| 73 72 63 2f 64 61 74 61 | 74 79 70 65 73 2e 68 27 |src/data|types.h'|
|000022a0| 5c 22 20 5c 28 33 39 31 | 34 20 63 68 61 72 61 63 |\" \(391|4 charac|
|000022b0| 74 65 72 73 5c 29 0a 73 | 65 64 20 22 73 2f 5e 58 |ters\).s|ed "s/^X|
|000022c0| 2f 2f 22 20 3e 27 73 72 | 63 2f 64 61 74 61 74 79 |//" >'sr|c/dataty|
|000022d0| 70 65 73 2e 68 27 20 3c | 3c 27 45 4e 44 5f 4f 46 |pes.h' <|<'END_OF|
|000022e0| 5f 46 49 4c 45 27 0a 58 | 2f 2a 0a 58 20 2a 20 64 |_FILE'.X|/*.X * d|
|000022f0| 61 74 61 74 79 70 65 73 | 2e 68 0a 58 20 2a 0a 58 |atatypes|.h.X *.X|
|00002300| 20 2a 20 43 6f 70 79 72 | 69 67 68 74 20 28 43 29 | * Copyr|ight (C)|
|00002310| 20 31 39 38 39 2c 20 43 | 72 61 69 67 20 45 2e 20 | 1989, C|raig E. |
|00002320| 4b 6f 6c 62 0a 58 20 2a | 0a 58 20 2a 20 54 68 69 |Kolb.X *|.X * Thi|
|00002330| 73 20 73 6f 66 74 77 61 | 72 65 20 6d 61 79 20 62 |s softwa|re may b|
|00002340| 65 20 66 72 65 65 6c 79 | 20 63 6f 70 69 65 64 2c |e freely| copied,|
|00002350| 20 6d 6f 64 69 66 69 65 | 64 2c 20 61 6e 64 20 72 | modifie|d, and r|
|00002360| 65 64 69 73 74 72 69 62 | 75 74 65 64 2c 0a 58 20 |edistrib|uted,.X |
|00002370| 2a 20 70 72 6f 76 69 64 | 65 64 20 74 68 61 74 20 |* provid|ed that |
|00002380| 74 68 69 73 20 63 6f 70 | 79 72 69 67 68 74 20 6e |this cop|yright n|
|00002390| 6f 74 69 63 65 20 69 73 | 20 70 72 65 73 65 72 76 |otice is| preserv|
|000023a0| 65 64 20 6f 6e 20 61 6c | 6c 20 63 6f 70 69 65 73 |ed on al|l copies|
|000023b0| 2e 0a 58 20 2a 0a 58 20 | 2a 20 54 68 65 72 65 20 |..X *.X |* There |
|000023c0| 69 73 20 6e 6f 20 77 61 | 72 72 61 6e 74 79 20 6f |is no wa|rranty o|
|000023d0| 72 20 6f 74 68 65 72 20 | 67 75 61 72 61 6e 74 65 |r other |guarante|
|000023e0| 65 20 6f 66 20 66 69 74 | 6e 65 73 73 20 66 6f 72 |e of fit|ness for|
|000023f0| 20 74 68 69 73 20 73 6f | 66 74 77 61 72 65 2c 0a | this so|ftware,.|
|00002400| 58 20 2a 20 69 74 20 69 | 73 20 70 72 6f 76 69 64 |X * it i|s provid|
|00002410| 65 64 20 73 6f 6c 65 6c | 79 20 2e 20 20 42 75 67 |ed solel|y . Bug|
|00002420| 20 72 65 70 6f 72 74 73 | 20 6f 72 20 66 69 78 65 | reports| or fixe|
|00002430| 73 20 6d 61 79 20 62 65 | 20 73 65 6e 74 0a 58 20 |s may be| sent.X |
|00002440| 2a 20 74 6f 20 74 68 65 | 20 61 75 74 68 6f 72 2c |* to the| author,|
|00002450| 20 77 68 6f 20 6d 61 79 | 20 6f 72 20 6d 61 79 20 | who may| or may |
|00002460| 6e 6f 74 20 61 63 74 20 | 6f 6e 20 74 68 65 6d 20 |not act |on them |
|00002470| 61 73 20 68 65 20 64 65 | 73 69 72 65 73 2e 0a 58 |as he de|sires..X|
|00002480| 20 2a 0a 58 20 2a 20 59 | 6f 75 20 6d 61 79 20 6e | *.X * Y|ou may n|
|00002490| 6f 74 20 69 6e 63 6c 75 | 64 65 20 74 68 69 73 20 |ot inclu|de this |
|000024a0| 73 6f 66 74 77 61 72 65 | 20 69 6e 20 61 20 70 72 |software| in a pr|
|000024b0| 6f 67 72 61 6d 20 6f 72 | 20 6f 74 68 65 72 20 73 |ogram or| other s|
|000024c0| 6f 66 74 77 61 72 65 20 | 70 72 6f 64 75 63 74 0a |oftware |product.|
|000024d0| 58 20 2a 20 77 69 74 68 | 6f 75 74 20 73 75 70 70 |X * with|out supp|
|000024e0| 6c 79 69 6e 67 20 74 68 | 65 20 73 6f 75 72 63 65 |lying th|e source|
|000024f0| 2c 20 6f 72 20 77 69 74 | 68 6f 75 74 20 69 6e 66 |, or wit|hout inf|
|00002500| 6f 72 6d 69 6e 67 20 74 | 68 65 20 65 6e 64 2d 75 |orming t|he end-u|
|00002510| 73 65 72 20 74 68 61 74 | 20 74 68 65 0a 58 20 2a |ser that| the.X *|
|00002520| 20 73 6f 75 72 63 65 20 | 69 73 20 61 76 61 69 6c | source |is avail|
|00002530| 61 62 6c 65 20 66 6f 72 | 20 6e 6f 20 65 78 74 72 |able for| no extr|
|00002540| 61 20 63 68 61 72 67 65 | 2e 0a 58 20 2a 0a 58 20 |a charge|..X *.X |
|00002550| 2a 20 49 66 20 79 6f 75 | 20 6d 6f 64 69 66 79 20 |* If you| modify |
|00002560| 74 68 69 73 20 73 6f 66 | 74 77 61 72 65 2c 20 79 |this sof|tware, y|
|00002570| 6f 75 20 73 68 6f 75 6c | 64 20 69 6e 63 6c 75 64 |ou shoul|d includ|
|00002580| 65 20 61 20 6e 6f 74 69 | 63 65 20 67 69 76 69 6e |e a noti|ce givin|
|00002590| 67 20 74 68 65 0a 58 20 | 2a 20 6e 61 6d 65 20 6f |g the.X |* name o|
|000025a0| 66 20 74 68 65 20 70 65 | 72 73 6f 6e 20 70 65 72 |f the pe|rson per|
|000025b0| 66 6f 72 6d 69 6e 67 20 | 74 68 65 20 6d 6f 64 69 |forming |the modi|
|000025c0| 66 69 63 61 74 69 6f 6e | 2c 20 74 68 65 20 64 61 |fication|, the da|
|000025d0| 74 65 20 6f 66 20 6d 6f | 64 69 66 69 63 61 74 69 |te of mo|dificati|
|000025e0| 6f 6e 2c 0a 58 20 2a 20 | 61 6e 64 20 74 68 65 20 |on,.X * |and the |
|000025f0| 72 65 61 73 6f 6e 20 66 | 6f 72 20 73 75 63 68 20 |reason f|or such |
|00002600| 6d 6f 64 69 66 69 63 61 | 74 69 6f 6e 2e 0a 58 20 |modifica|tion..X |
|00002610| 2a 0a 58 20 2a 20 24 49 | 64 3a 20 64 61 74 61 74 |*.X * $I|d: datat|
|00002620| 79 70 65 73 2e 68 2c 76 | 20 33 2e 30 20 38 39 2f |ypes.h,v| 3.0 89/|
|00002630| 31 30 2f 32 37 20 30 32 | 3a 30 35 3a 34 39 20 63 |10/27 02|:05:49 c|
|00002640| 72 61 69 67 20 45 78 70 | 20 24 0a 58 20 2a 0a 58 |raig Exp| $.X *.X|
|00002650| 20 2a 20 24 4c 6f 67 3a | 09 64 61 74 61 74 79 70 | * $Log:|.datatyp|
|00002660| 65 73 2e 68 2c 76 20 24 | 0a 58 20 2a 20 52 65 76 |es.h,v $|.X * Rev|
|00002670| 69 73 69 6f 6e 20 33 2e | 30 20 20 38 39 2f 31 30 |ision 3.|0 89/10|
|00002680| 2f 32 37 20 20 30 32 3a | 30 35 3a 34 39 20 20 63 |/27 02:|05:49 c|
|00002690| 72 61 69 67 0a 58 20 2a | 20 42 61 73 65 6c 69 6e |raig.X *| Baselin|
|000026a0| 65 20 66 6f 72 20 66 69 | 72 73 74 20 6f 66 66 69 |e for fi|rst offi|
|000026b0| 63 69 61 6c 20 72 65 6c | 65 61 73 65 2e 0a 58 20 |cial rel|ease..X |
|000026c0| 2a 20 0a 58 20 2a 2f 0a | 58 0a 58 23 69 66 64 65 |* .X */.|X.X#ifde|
|000026d0| 66 20 4e 4f 56 4f 49 44 | 0a 58 74 79 70 65 64 65 |f NOVOID|.Xtypede|
|000026e0| 66 20 69 6e 74 20 76 6f | 69 64 3b 0a 58 23 65 6e |f int vo|id;.X#en|
|000026f0| 64 69 66 0a 58 0a 58 74 | 79 70 65 64 65 66 20 73 |dif.X.Xt|ypedef s|
|00002700| 74 72 75 63 74 20 7b 0a | 58 09 64 6f 75 62 6c 65 |truct {.|X.double|
|00002710| 20 75 2c 20 76 3b 09 09 | 09 2f 2a 20 32 44 20 70 | u, v;..|./* 2D p|
|00002720| 6f 69 6e 74 20 2a 2f 0a | 58 7d 20 56 65 63 32 64 |oint */.|X} Vec2d|
|00002730| 3b 0a 58 0a 58 74 79 70 | 65 64 65 66 20 73 74 72 |;.X.Xtyp|edef str|
|00002740| 75 63 74 20 56 65 63 74 | 6f 72 20 7b 0a 58 09 64 |uct Vect|or {.X.d|
|00002750| 6f 75 62 6c 65 20 78 2c | 20 79 2c 20 7a 3b 09 09 |ouble x,| y, z;..|
|00002760| 09 2f 2a 20 33 44 20 70 | 6f 69 6e 74 20 2a 2f 0a |./* 3D p|oint */.|
|00002770| 58 7d 20 56 65 63 74 6f | 72 3b 0a 58 0a 58 74 79 |X} Vecto|r;.X.Xty|
|00002780| 70 65 64 65 66 20 73 74 | 72 75 63 74 20 52 61 79 |pedef st|ruct Ray|
|00002790| 20 7b 0a 58 09 56 65 63 | 74 6f 72 20 70 6f 73 3b | {.X.Vec|tor pos;|
|000027a0| 09 09 09 2f 2a 20 4f 72 | 69 67 69 6e 20 2a 2f 0a |.../* Or|igin */.|
|000027b0| 58 09 56 65 63 74 6f 72 | 20 09 64 69 72 3b 09 09 |X.Vector| .dir;..|
|000027c0| 09 2f 2a 20 44 69 72 65 | 63 74 69 6f 6e 20 2a 2f |./* Dire|ction */|
|000027d0| 0a 58 09 63 68 61 72 20 | 73 68 61 64 6f 77 3b 0a |.X.char |shadow;.|
|000027e0| 58 09 73 74 72 75 63 74 | 20 53 75 72 66 61 63 65 |X.struct| Surface|
|000027f0| 4c 69 73 74 20 2a 6d 65 | 64 69 61 3b 09 2f 2a 20 |List *me|dia;./* |
|00002800| 4d 65 64 69 75 6d 20 72 | 61 79 20 69 73 20 70 61 |Medium r|ay is pa|
|00002810| 73 73 69 6e 67 20 74 68 | 72 6f 75 67 68 20 2a 2f |ssing th|rough */|
|00002820| 0a 58 7d 20 52 61 79 3b | 0a 58 0a 58 74 79 70 65 |.X} Ray;|.X.Xtype|
|00002830| 64 65 66 20 73 74 72 75 | 63 74 20 43 6f 6c 6f 72 |def stru|ct Color|
|00002840| 20 7b 0a 58 09 64 6f 75 | 62 6c 65 20 72 2c 20 67 | {.X.dou|ble r, g|
|00002850| 2c 20 62 3b 09 09 09 2f | 2a 20 52 65 64 2c 20 67 |, b;.../|* Red, g|
|00002860| 72 65 65 6e 2c 20 62 6c | 75 65 2e 20 2a 2f 0a 58 |reen, bl|ue. */.X|
|00002870| 7d 20 43 6f 6c 6f 72 3b | 0a 58 0a 58 74 79 70 65 |} Color;|.X.Xtype|
|00002880| 64 65 66 20 73 74 72 75 | 63 74 20 7b 0a 58 09 64 |def stru|ct {.X.d|
|00002890| 6f 75 62 6c 65 20 6d 61 | 74 72 69 78 5b 33 5d 5b |ouble ma|trix[3][|
|000028a0| 33 5d 3b 09 09 2f 2a 20 | 52 6f 74 61 74 69 6f 6e |3];../* |Rotation|
|000028b0| 20 6d 61 74 72 69 78 20 | 2a 2f 0a 58 09 56 65 63 | matrix |*/.X.Vec|
|000028c0| 74 6f 72 20 74 72 61 6e | 73 6c 61 74 65 3b 09 09 |tor tran|slate;..|
|000028d0| 2f 2a 20 54 72 61 6e 73 | 6c 61 74 69 6f 6e 20 2a |/* Trans|lation *|
|000028e0| 2f 0a 58 7d 20 54 72 61 | 6e 73 49 6e 66 6f 3b 0a |/.X} Tra|nsInfo;.|
|000028f0| 58 0a 58 74 79 70 65 64 | 65 66 20 73 74 72 75 63 |X.Xtyped|ef struc|
|00002900| 74 20 54 72 61 6e 73 20 | 7b 0a 58 09 54 72 61 6e |t Trans |{.X.Tran|
|00002910| 73 49 6e 66 6f 20 77 6f | 72 6c 64 32 6f 62 6a 2c |sInfo wo|rld2obj,|
|00002920| 09 2f 2a 20 77 6f 72 6c | 64 73 70 61 63 65 20 2d |./* worl|dspace -|
|00002930| 2d 3e 20 6f 62 6a 65 63 | 74 20 73 70 61 63 65 20 |-> objec|t space |
|00002940| 2a 2f 0a 58 09 09 20 20 | 6f 62 6a 32 77 6f 72 6c |*/.X.. |obj2worl|
|00002950| 64 3b 09 2f 2a 20 6f 62 | 6a 65 63 74 20 73 70 61 |d;./* ob|ject spa|
|00002960| 63 65 20 2d 2d 3e 20 77 | 6f 72 6c 64 20 73 70 61 |ce --> w|orld spa|
|00002970| 63 65 20 2a 2f 0a 58 7d | 20 54 72 61 6e 73 3b 0a |ce */.X}| Trans;.|
|00002980| 58 0a 58 74 79 70 65 64 | 65 66 20 73 74 72 75 63 |X.Xtyped|ef struc|
|00002990| 74 20 7b 0a 58 09 73 74 | 72 75 63 74 20 4f 62 6a |t {.X.st|ruct Obj|
|000029a0| 4c 69 73 74 20 2a 6c 69 | 73 74 3b 09 09 2f 2a 20 |List *li|st;../* |
|000029b0| 4c 69 73 74 20 6f 66 20 | 70 72 69 6d 73 2f 6f 62 |List of |prims/ob|
|000029c0| 6a 73 2e 20 69 6e 20 6f | 62 6a 65 63 74 20 2a 2f |js. in o|bject */|
|000029d0| 0a 58 09 73 74 72 75 63 | 74 20 4f 62 6a 4c 69 73 |.X.struc|t ObjLis|
|000029e0| 74 20 2a 75 6e 62 6f 75 | 6e 64 65 64 3b 09 2f 2a |t *unbou|nded;./*|
|000029f0| 20 4c 69 73 74 20 6f 66 | 20 75 6e 62 6f 75 6e 64 | List of| unbound|
|00002a00| 65 64 20 70 72 69 6d 73 | 2e 20 2a 2f 0a 58 09 64 |ed prims|. */.X.d|
|00002a10| 6f 75 62 6c 65 20 62 6f | 75 6e 64 73 5b 32 5d 5b |ouble bo|unds[2][|
|00002a20| 33 5d 3b 09 09 2f 2a 20 | 42 6f 75 6e 64 69 6e 67 |3];../* |Bounding|
|00002a30| 20 62 6f 78 20 6f 66 20 | 6f 62 6a 65 63 74 20 2a | box of |object *|
|00002a40| 2f 0a 58 7d 20 4c 69 73 | 74 3b 0a 58 0a 58 74 79 |/.X} Lis|t;.X.Xty|
|00002a50| 70 65 64 65 66 20 73 74 | 72 75 63 74 20 7b 0a 58 |pedef st|ruct {.X|
|00002a60| 09 73 68 6f 72 74 20 78 | 73 69 7a 65 2c 20 79 73 |.short x|size, ys|
|00002a70| 69 7a 65 2c 20 7a 73 69 | 7a 65 3b 09 2f 2a 20 23 |ize, zsi|ze;./* #|
|00002a80| 20 6f 66 20 76 6f 78 65 | 6c 73 20 61 6c 6f 6e 67 | of voxe|ls along|
|00002a90| 20 65 61 63 68 20 61 78 | 69 73 20 2a 2f 0a 58 09 | each ax|is */.X.|
|00002aa0| 64 6f 75 62 6c 65 20 62 | 6f 75 6e 64 73 5b 32 5d |double b|ounds[2]|
|00002ab0| 5b 33 5d 3b 09 09 2f 2a | 20 62 6f 75 6e 64 69 6e |[3];../*| boundin|
|00002ac0| 67 20 62 6f 78 20 2a 2f | 0a 58 09 64 6f 75 62 6c |g box */|.X.doubl|
|00002ad0| 65 20 76 6f 78 73 69 7a | 65 5b 33 5d 3b 09 09 2f |e voxsiz|e[3];../|
|00002ae0| 2a 20 73 69 7a 65 20 6f | 66 20 61 20 76 6f 78 65 |* size o|f a voxe|
|00002af0| 6c 20 2a 2f 0a 58 09 73 | 74 72 75 63 74 20 4f 62 |l */.X.s|truct Ob|
|00002b00| 6a 4c 69 73 74 20 2a 2a | 2a 2a 63 65 6c 6c 73 3b |jList **|**cells;|
|00002b10| 09 2f 2a 20 56 6f 78 65 | 6c 73 20 2a 2f 0a 58 09 |./* Voxe|ls */.X.|
|00002b20| 73 74 72 75 63 74 20 4f | 62 6a 4c 69 73 74 20 2a |struct O|bjList *|
|00002b30| 75 6e 62 6f 75 6e 64 65 | 64 3b 09 2f 2a 20 55 6e |unbounde|d;./* Un|
|00002b40| 62 6f 75 6e 64 65 64 20 | 6f 62 6a 65 63 74 73 20 |bounded |objects |
|00002b50| 2a 2f 0a 58 7d 20 47 72 | 69 64 3b 0a 58 0a 58 2f |*/.X} Gr|id;.X.X/|
|00002b60| 2a 0a 58 20 2a 20 53 75 | 72 66 61 63 65 20 64 65 |*.X * Su|rface de|
|00002b70| 66 69 6e 69 74 69 6f 6e | 2e 0a 58 20 2a 2f 0a 58 |finition|..X */.X|
|00002b80| 74 79 70 65 64 65 66 20 | 73 74 72 75 63 74 20 53 |typedef |struct S|
|00002b90| 75 72 66 61 63 65 20 7b | 0a 58 09 63 68 61 72 20 |urface {|.X.char |
|00002ba0| 2a 6e 61 6d 65 3b 09 09 | 09 2f 2a 20 4e 61 6d 65 |*name;..|./* Name|
|00002bb0| 20 2a 2f 0a 58 09 73 74 | 72 75 63 74 20 43 6f 6c | */.X.st|ruct Col|
|00002bc0| 6f 72 20 61 6d 62 3b 09 | 09 2f 2a 20 41 6d 62 69 |or amb;.|./* Ambi|
|00002bd0| 65 6e 74 20 63 6f 6c 6f | 72 20 2a 2f 0a 58 09 73 |ent colo|r */.X.s|
|00002be0| 74 72 75 63 74 20 43 6f | 6c 6f 72 20 64 69 66 66 |truct Co|lor diff|
|00002bf0| 3b 09 09 2f 2a 20 44 69 | 66 66 75 73 65 20 63 6f |;../* Di|ffuse co|
|00002c00| 6c 6f 72 20 2a 2f 0a 58 | 09 73 74 72 75 63 74 20 |lor */.X|.struct |
|00002c10| 43 6f 6c 6f 72 20 73 70 | 65 63 3b 09 09 2f 2a 20 |Color sp|ec;../* |
|00002c20| 53 70 65 63 75 6c 61 72 | 20 63 6f 6c 6f 72 20 2a |Specular| color *|
|00002c30| 2f 0a 58 09 64 6f 75 62 | 6c 65 20 63 6f 65 66 3b |/.X.doub|le coef;|
|00002c40| 09 09 09 2f 2a 20 50 68 | 6f 6e 67 20 73 68 61 64 |.../* Ph|ong shad|
|00002c50| 69 6e 67 20 63 6f 65 66 | 2e 20 2a 2f 0a 58 09 64 |ing coef|. */.X.d|
|00002c60| 6f 75 62 6c 65 20 72 65 | 66 6c 3b 09 09 09 2f 2a |ouble re|fl;.../*|
|00002c70| 20 52 65 66 6c 65 63 74 | 69 76 69 74 79 20 28 30 | Reflect|ivity (0|
|00002c80| 2d 31 29 20 2a 2f 0a 58 | 09 64 6f 75 62 6c 65 20 |-1) */.X|.double |
|00002c90| 74 72 61 6e 73 70 3b 09 | 09 09 2f 2a 20 54 72 61 |transp;.|../* Tra|
|00002ca0| 6e 73 70 61 72 65 6e 63 | 79 20 28 30 2d 31 29 20 |nsparenc|y (0-1) |
|00002cb0| 2a 2f 0a 58 09 64 6f 75 | 62 6c 65 20 6b 72 65 66 |*/.X.dou|ble kref|
|00002cc0| 3b 09 09 09 2f 2a 20 49 | 6e 64 65 78 20 6f 66 20 |;.../* I|ndex of |
|00002cd0| 72 65 66 72 61 63 74 69 | 6f 6e 20 2a 2f 0a 58 09 |refracti|on */.X.|
|00002ce0| 64 6f 75 62 6c 65 20 74 | 72 61 6e 73 6c 75 63 65 |double t|ransluce|
|00002cf0| 6e 63 79 3b 09 09 2f 2a | 20 74 72 61 6e 73 6c 75 |ncy;../*| translu|
|00002d00| 63 65 6e 63 79 20 28 30 | 2d 31 29 20 2a 2f 0a 58 |cency (0|-1) */.X|
|00002d10| 09 64 6f 75 62 6c 65 20 | 73 74 63 6f 65 66 3b 09 |.double |stcoef;.|
|00002d20| 09 09 2f 2a 20 50 68 6f | 6e 67 20 63 6f 65 66 2e |../* Pho|ng coef.|
|00002d30| 20 66 6f 72 20 74 72 61 | 6e 73 6d 69 74 74 65 64 | for tra|nsmitted|
|00002d40| 20 6c 69 67 68 74 20 2a | 2f 0a 58 7d 20 53 75 72 | light *|/.X} Sur|
|00002d50| 66 61 63 65 3b 0a 58 0a | 58 74 79 70 65 64 65 66 |face;.X.|Xtypedef|
|00002d60| 20 73 74 72 75 63 74 20 | 53 75 72 66 61 63 65 4c | struct |SurfaceL|
|00002d70| 69 73 74 20 7b 0a 58 09 | 53 75 72 66 61 63 65 20 |ist {.X.|Surface |
|00002d80| 2a 73 75 72 66 3b 0a 58 | 09 73 74 72 75 63 74 20 |*surf;.X|.struct |
|00002d90| 53 75 72 66 61 63 65 4c | 69 73 74 20 2a 6e 65 78 |SurfaceL|ist *nex|
|00002da0| 74 3b 0a 58 7d 20 53 75 | 72 66 61 63 65 4c 69 73 |t;.X} Su|rfaceLis|
|00002db0| 74 3b 0a 58 0a 58 74 79 | 70 65 64 65 66 20 73 74 |t;.X.Xty|pedef st|
|00002dc0| 72 75 63 74 20 4f 62 6a | 4c 69 73 74 20 7b 0a 58 |ruct Obj|List {.X|
|00002dd0| 09 73 74 72 75 63 74 20 | 4f 62 6a 65 63 74 20 2a |.struct |Object *|
|00002de0| 64 61 74 61 3b 09 09 2f | 2a 20 50 6f 69 6e 74 65 |data;../|* Pointe|
|00002df0| 72 20 74 6f 20 6f 62 6a | 65 63 74 20 64 61 74 61 |r to obj|ect data|
|00002e00| 20 2a 2f 0a 58 09 73 74 | 72 75 63 74 20 4f 62 6a | */.X.st|ruct Obj|
|00002e10| 4c 69 73 74 20 2a 6e 65 | 78 74 3b 09 09 2f 2a 20 |List *ne|xt;../* |
|00002e20| 4e 65 78 74 20 69 6e 20 | 6c 69 73 74 20 2a 2f 0a |Next in |list */.|
|00002e30| 58 7d 20 4f 62 6a 4c 69 | 73 74 3b 0a 58 0a 58 74 |X} ObjLi|st;.X.Xt|
|00002e40| 79 70 65 64 65 66 20 73 | 74 72 75 63 74 20 50 6f |ypedef s|truct Po|
|00002e50| 69 6e 74 4c 69 73 74 20 | 7b 0a 58 09 56 65 63 74 |intList |{.X.Vect|
|00002e60| 6f 72 20 76 65 63 3b 09 | 09 09 2f 2a 20 56 65 63 |or vec;.|../* Vec|
|00002e70| 74 6f 72 20 64 61 74 61 | 20 2a 2f 0a 58 09 73 74 |tor data| */.X.st|
|00002e80| 72 75 63 74 20 50 6f 69 | 6e 74 4c 69 73 74 20 2a |ruct Poi|ntList *|
|00002e90| 6e 65 78 74 3b 09 09 2f | 2a 20 4e 65 78 74 20 69 |next;../|* Next i|
|00002ea0| 6e 20 6c 69 73 74 20 2a | 2f 0a 58 7d 20 50 6f 69 |n list *|/.X} Poi|
|00002eb0| 6e 74 4c 69 73 74 3b 0a | 58 0a 58 2f 2a 0a 58 20 |ntList;.|X.X/*.X |
|00002ec0| 2a 20 44 61 74 61 20 61 | 62 6f 75 74 20 70 6f 69 |* Data a|bout poi|
|00002ed0| 6e 74 20 6f 66 20 69 6e | 74 65 72 73 65 63 74 69 |nt of in|tersecti|
|00002ee0| 6f 6e 2e 0a 58 20 2a 20 | 28 4d 61 79 20 62 65 20 |on..X * |(May be |
|00002ef0| 6d 6f 64 69 66 69 65 64 | 20 62 79 20 74 65 78 74 |modified| by text|
|00002f00| 75 72 65 20 6d 61 70 70 | 69 6e 67 2e 29 0a 58 20 |ure mapp|ing.).X |
|00002f10| 2a 2f 0a 58 74 79 70 65 | 64 65 66 20 73 74 72 75 |*/.Xtype|def stru|
|00002f20| 63 74 20 48 69 74 49 6e | 66 6f 20 7b 0a 58 09 56 |ct HitIn|fo {.X.V|
|00002f30| 65 63 74 6f 72 09 70 6f | 73 2c 09 09 2f 2a 20 4c |ector.po|s,../* L|
|00002f40| 6f 63 61 74 69 6f 6e 20 | 6f 66 20 69 6e 74 65 72 |ocation |of inter|
|00002f50| 73 65 63 74 69 6f 6e 20 | 2a 2f 0a 58 09 09 6e 6f |section |*/.X..no|
|00002f60| 72 6d 3b 09 09 2f 2a 20 | 4e 6f 72 6d 61 6c 20 74 |rm;../* |Normal t|
|00002f70| 6f 20 73 75 72 66 61 63 | 65 20 61 74 20 69 6e 74 |o surfac|e at int|
|00002f80| 2e 20 70 6f 69 6e 74 20 | 2a 2f 0a 58 09 73 74 72 |. point |*/.X.str|
|00002f90| 75 63 74 20 50 72 69 6d | 69 74 69 76 65 20 2a 70 |uct Prim|itive *p|
|00002fa0| 72 69 6d 3b 20 2f 2a 20 | 50 6f 69 6e 74 65 72 20 |rim; /* |Pointer |
|00002fb0| 74 6f 20 70 72 69 6d 69 | 74 69 76 65 20 68 69 74 |to primi|tive hit|
|00002fc0| 2e 20 2a 2f 0a 58 09 73 | 74 72 75 63 74 20 53 75 |. */.X.s|truct Su|
|00002fd0| 72 66 61 63 65 20 73 75 | 72 66 3b 09 2f 2a 20 53 |rface su|rf;./* S|
|00002fe0| 75 72 66 61 63 65 20 74 | 6f 20 62 65 20 75 73 65 |urface t|o be use|
|00002ff0| 64 2e 20 2a 2f 0a 58 09 | 54 72 61 6e 73 49 6e 66 |d. */.X.|TransInf|
|00003000| 6f 20 2a 74 6f 74 61 6c | 74 72 61 6e 73 3b 0a 58 |o *total|trans;.X|
|00003010| 7d 20 48 69 74 49 6e 66 | 6f 3b 0a 58 0a 58 2f 2a |} HitInf|o;.X.X/*|
|00003020| 0a 58 20 2a 20 47 65 6e | 65 72 61 6c 2d 70 75 72 |.X * Gen|eral-pur|
|00003030| 70 6f 73 65 20 74 65 78 | 74 75 72 65 20 73 74 72 |pose tex|ture str|
|00003040| 75 63 74 75 72 65 2e 20 | 20 54 68 65 20 28 62 61 |ucture. | The (ba|
|00003050| 64 29 20 69 64 65 61 20 | 69 73 20 74 6f 0a 58 20 |d) idea |is to.X |
|00003060| 2a 20 68 61 76 65 20 6f | 6e 65 20 73 74 72 75 63 |* have o|ne struc|
|00003070| 74 75 72 65 20 77 68 69 | 63 68 20 65 76 65 72 79 |ture whi|ch every|
|00003080| 20 74 65 78 74 75 72 69 | 6e 67 20 66 75 6e 63 74 | texturi|ng funct|
|00003090| 69 6f 6e 20 77 69 6c 6c | 20 75 73 65 2e 0a 58 20 |ion will| use..X |
|000030a0| 2a 2f 0a 58 74 79 70 65 | 64 65 66 20 73 74 72 75 |*/.Xtype|def stru|
|000030b0| 63 74 20 54 65 78 74 75 | 72 65 20 7b 0a 58 09 63 |ct Textu|re {.X.c|
|000030c0| 68 61 72 20 74 79 70 65 | 3b 09 09 2f 2a 20 54 65 |har type|;../* Te|
|000030d0| 78 74 75 72 65 20 74 79 | 70 65 20 2a 2f 0a 58 09 |xture ty|pe */.X.|
|000030e0| 53 75 72 66 61 63 65 20 | 2a 73 75 72 66 31 3b 09 |Surface |*surf1;.|
|000030f0| 09 2f 2a 20 41 6c 74 65 | 72 6e 61 74 65 20 73 75 |./* Alte|rnate su|
|00003100| 72 66 61 63 65 20 2a 2f | 0a 58 09 64 6f 75 62 6c |rface */|.X.doubl|
|00003110| 65 20 73 69 7a 65 3b 09 | 09 2f 2a 20 53 63 61 6c |e size;.|./* Scal|
|00003120| 65 2f 73 69 7a 65 20 66 | 61 63 74 6f 72 20 2a 2f |e/size f|actor */|
|00003130| 0a 58 09 64 6f 75 62 6c | 65 20 2a 61 72 67 73 3b |.X.doubl|e *args;|
|00003140| 09 09 2f 2a 20 52 61 6e | 64 6f 6d 20 61 72 67 75 |../* Ran|dom argu|
|00003150| 6d 65 6e 74 73 2e 20 2a | 2f 0a 58 09 43 6f 6c 6f |ments. *|/.X.Colo|
|00003160| 72 20 2a 63 6f 6c 6f 72 | 6d 61 70 3b 09 2f 2a 20 |r *color|map;./* |
|00003170| 43 6f 6c 6f 72 6d 61 70 | 20 2a 2f 0a 58 09 54 72 |Colormap| */.X.Tr|
|00003180| 61 6e 73 20 2a 74 72 61 | 6e 73 3b 09 09 2f 2a 20 |ans *tra|ns;../* |
|00003190| 54 72 61 6e 73 66 6f 72 | 6d 61 74 69 6f 6e 20 6d |Transfor|mation m|
|000031a0| 61 74 72 69 63 65 73 2e | 20 2a 2f 0a 58 09 73 74 |atrices.| */.X.st|
|000031b0| 72 75 63 74 20 54 65 78 | 74 75 72 65 20 2a 6e 65 |ruct Tex|ture *ne|
|000031c0| 78 74 3b 09 2f 2a 20 50 | 6f 69 6e 74 65 72 20 74 |xt;./* P|ointer t|
|000031d0| 6f 20 6e 65 78 74 20 74 | 65 78 74 75 72 65 2e 20 |o next t|exture. |
|000031e0| 2a 2f 0a 58 7d 20 54 65 | 78 74 75 72 65 3b 0a 58 |*/.X} Te|xture;.X|
|000031f0| 0a 58 74 79 70 65 64 65 | 66 20 73 74 72 75 63 74 |.Xtypede|f struct|
|00003200| 20 7b 0a 58 09 43 6f 6c | 6f 72 20 63 6f 6c 6f 72 | {.X.Col|or color|
|00003210| 3b 0a 58 09 64 6f 75 62 | 6c 65 20 74 72 61 6e 73 |;.X.doub|le trans|
|00003220| 3b 0a 58 7d 20 46 6f 67 | 3b 0a 58 0a 58 74 79 70 |;.X} Fog|;.X.Xtyp|
|00003230| 65 64 65 66 20 73 74 72 | 75 63 74 20 7b 0a 58 09 |edef str|uct {.X.|
|00003240| 43 6f 6c 6f 72 20 63 6f | 6c 6f 72 3b 09 09 2f 2a |Color co|lor;../*|
|00003250| 20 4d 69 73 74 20 63 6f | 6c 6f 72 20 2a 2f 0a 58 | Mist co|lor */.X|
|00003260| 09 43 6f 6c 6f 72 20 74 | 72 61 6e 73 3b 09 09 2f |.Color t|rans;../|
|00003270| 2a 20 52 2c 20 47 2c 20 | 42 20 74 72 61 6e 73 2e |* R, G, |B trans.|
|00003280| 20 2a 2f 0a 58 09 64 6f | 75 62 6c 65 20 73 63 61 | */.X.do|uble sca|
|00003290| 6c 65 2c 20 7a 65 72 6f | 3b 09 2f 2a 20 48 65 69 |le, zero|;./* Hei|
|000032a0| 67 68 74 20 73 63 61 6c | 65 2c 20 73 74 61 72 74 |ght scal|e, start|
|000032b0| 20 5a 20 2a 2f 0a 58 7d | 20 4d 69 73 74 3b 0a 45 | Z */.X}| Mist;.E|
|000032c0| 4e 44 5f 4f 46 5f 46 49 | 4c 45 0a 69 66 20 74 65 |ND_OF_FI|LE.if te|
|000032d0| 73 74 20 33 39 31 34 20 | 2d 6e 65 20 60 77 63 20 |st 3914 |-ne `wc |
|000032e0| 2d 63 20 3c 27 73 72 63 | 2f 64 61 74 61 74 79 70 |-c <'src|/datatyp|
|000032f0| 65 73 2e 68 27 60 3b 20 | 74 68 65 6e 0a 20 20 20 |es.h'`; |then. |
|00003300| 20 65 63 68 6f 20 73 68 | 61 72 3a 20 5c 22 27 73 | echo sh|ar: \"'s|
|00003310| 72 63 2f 64 61 74 61 74 | 79 70 65 73 2e 68 27 5c |rc/datat|ypes.h'\|
|00003320| 22 20 75 6e 70 61 63 6b | 65 64 20 77 69 74 68 20 |" unpack|ed with |
|00003330| 77 72 6f 6e 67 20 73 69 | 7a 65 21 0a 66 69 0a 23 |wrong si|ze!.fi.#|
|00003340| 20 65 6e 64 20 6f 66 20 | 27 73 72 63 2f 64 61 74 | end of |'src/dat|
|00003350| 61 74 79 70 65 73 2e 68 | 27 0a 66 69 0a 69 66 20 |atypes.h|'.fi.if |
|00003360| 74 65 73 74 20 2d 66 20 | 27 73 72 63 2f 66 75 6e |test -f |'src/fun|
|00003370| 63 64 65 66 73 2e 68 27 | 20 2d 61 20 22 24 7b 31 |cdefs.h'| -a "${1|
|00003380| 7d 22 20 21 3d 20 22 2d | 63 22 20 3b 20 74 68 65 |}" != "-|c" ; the|
|00003390| 6e 20 0a 20 20 65 63 68 | 6f 20 73 68 61 72 3a 20 |n . ech|o shar: |
|000033a0| 57 69 6c 6c 20 6e 6f 74 | 20 63 6c 6f 62 62 65 72 |Will not| clobber|
|000033b0| 20 65 78 69 73 74 69 6e | 67 20 66 69 6c 65 20 5c | existin|g file \|
|000033c0| 22 27 73 72 63 2f 66 75 | 6e 63 64 65 66 73 2e 68 |"'src/fu|ncdefs.h|
|000033d0| 27 5c 22 0a 65 6c 73 65 | 0a 65 63 68 6f 20 73 68 |'\".else|.echo sh|
|000033e0| 61 72 3a 20 45 78 74 72 | 61 63 74 69 6e 67 20 5c |ar: Extr|acting \|
|000033f0| 22 27 73 72 63 2f 66 75 | 6e 63 64 65 66 73 2e 68 |"'src/fu|ncdefs.h|
|00003400| 27 5c 22 20 5c 28 34 37 | 36 32 20 63 68 61 72 61 |'\" \(47|62 chara|
|00003410| 63 74 65 72 73 5c 29 0a | 73 65 64 20 22 73 2f 5e |cters\).|sed "s/^|
|00003420| 58 2f 2f 22 20 3e 27 73 | 72 63 2f 66 75 6e 63 64 |X//" >'s|rc/funcd|
|00003430| 65 66 73 2e 68 27 20 3c | 3c 27 45 4e 44 5f 4f 46 |efs.h' <|<'END_OF|
|00003440| 5f 46 49 4c 45 27 0a 58 | 2f 2a 0a 58 20 2a 20 66 |_FILE'.X|/*.X * f|
|00003450| 75 6e 63 64 65 66 73 2e | 68 0a 58 20 2a 0a 58 20 |uncdefs.|h.X *.X |
|00003460| 2a 20 43 6f 70 79 72 69 | 67 68 74 20 28 43 29 20 |* Copyri|ght (C) |
|00003470| 31 39 38 39 2c 20 43 72 | 61 69 67 20 45 2e 20 4b |1989, Cr|aig E. K|
|00003480| 6f 6c 62 0a 58 20 2a 0a | 58 20 2a 20 54 68 69 73 |olb.X *.|X * This|
|00003490| 20 73 6f 66 74 77 61 72 | 65 20 6d 61 79 20 62 65 | softwar|e may be|
|000034a0| 20 66 72 65 65 6c 79 20 | 63 6f 70 69 65 64 2c 20 | freely |copied, |
|000034b0| 6d 6f 64 69 66 69 65 64 | 2c 20 61 6e 64 20 72 65 |modified|, and re|
|000034c0| 64 69 73 74 72 69 62 75 | 74 65 64 2c 0a 58 20 2a |distribu|ted,.X *|
|000034d0| 20 70 72 6f 76 69 64 65 | 64 20 74 68 61 74 20 74 | provide|d that t|
|000034e0| 68 69 73 20 63 6f 70 79 | 72 69 67 68 74 20 6e 6f |his copy|right no|
|000034f0| 74 69 63 65 20 69 73 20 | 70 72 65 73 65 72 76 65 |tice is |preserve|
|00003500| 64 20 6f 6e 20 61 6c 6c | 20 63 6f 70 69 65 73 2e |d on all| copies.|
|00003510| 0a 58 20 2a 0a 58 20 2a | 20 54 68 65 72 65 20 69 |.X *.X *| There i|
|00003520| 73 20 6e 6f 20 77 61 72 | 72 61 6e 74 79 20 6f 72 |s no war|ranty or|
|00003530| 20 6f 74 68 65 72 20 67 | 75 61 72 61 6e 74 65 65 | other g|uarantee|
|00003540| 20 6f 66 20 66 69 74 6e | 65 73 73 20 66 6f 72 20 | of fitn|ess for |
|00003550| 74 68 69 73 20 73 6f 66 | 74 77 61 72 65 2c 0a 58 |this sof|tware,.X|
|00003560| 20 2a 20 69 74 20 69 73 | 20 70 72 6f 76 69 64 65 | * it is| provide|
|00003570| 64 20 73 6f 6c 65 6c 79 | 20 2e 20 20 42 75 67 20 |d solely| . Bug |
|00003580| 72 65 70 6f 72 74 73 20 | 6f 72 20 66 69 78 65 73 |reports |or fixes|
|00003590| 20 6d 61 79 20 62 65 20 | 73 65 6e 74 0a 58 20 2a | may be |sent.X *|
|000035a0| 20 74 6f 20 74 68 65 20 | 61 75 74 68 6f 72 2c 20 | to the |author, |
|000035b0| 77 68 6f 20 6d 61 79 20 | 6f 72 20 6d 61 79 20 6e |who may |or may n|
|000035c0| 6f 74 20 61 63 74 20 6f | 6e 20 74 68 65 6d 20 61 |ot act o|n them a|
|000035d0| 73 20 68 65 20 64 65 73 | 69 72 65 73 2e 0a 58 20 |s he des|ires..X |
|000035e0| 2a 0a 58 20 2a 20 59 6f | 75 20 6d 61 79 20 6e 6f |*.X * Yo|u may no|
|000035f0| 74 20 69 6e 63 6c 75 64 | 65 20 74 68 69 73 20 73 |t includ|e this s|
|00003600| 6f 66 74 77 61 72 65 20 | 69 6e 20 61 20 70 72 6f |oftware |in a pro|
|00003610| 67 72 61 6d 20 6f 72 20 | 6f 74 68 65 72 20 73 6f |gram or |other so|
|00003620| 66 74 77 61 72 65 20 70 | 72 6f 64 75 63 74 0a 58 |ftware p|roduct.X|
|00003630| 20 2a 20 77 69 74 68 6f | 75 74 20 73 75 70 70 6c | * witho|ut suppl|
|00003640| 79 69 6e 67 20 74 68 65 | 20 73 6f 75 72 63 65 2c |ying the| source,|
|00003650| 20 6f 72 20 77 69 74 68 | 6f 75 74 20 69 6e 66 6f | or with|out info|
|00003660| 72 6d 69 6e 67 20 74 68 | 65 20 65 6e 64 2d 75 73 |rming th|e end-us|
|00003670| 65 72 20 74 68 61 74 20 | 74 68 65 0a 58 20 2a 20 |er that |the.X * |
|00003680| 73 6f 75 72 63 65 20 69 | 73 20 61 76 61 69 6c 61 |source i|s availa|
|00003690| 62 6c 65 20 66 6f 72 20 | 6e 6f 20 65 78 74 72 61 |ble for |no extra|
|000036a0| 20 63 68 61 72 67 65 2e | 0a 58 20 2a 0a 58 20 2a | charge.|.X *.X *|
|000036b0| 20 49 66 20 79 6f 75 20 | 6d 6f 64 69 66 79 20 74 | If you |modify t|
|000036c0| 68 69 73 20 73 6f 66 74 | 77 61 72 65 2c 20 79 6f |his soft|ware, yo|
|000036d0| 75 20 73 68 6f 75 6c 64 | 20 69 6e 63 6c 75 64 65 |u should| include|
|000036e0| 20 61 20 6e 6f 74 69 63 | 65 20 67 69 76 69 6e 67 | a notic|e giving|
|000036f0| 20 74 68 65 0a 58 20 2a | 20 6e 61 6d 65 20 6f 66 | the.X *| name of|
|00003700| 20 74 68 65 20 70 65 72 | 73 6f 6e 20 70 65 72 66 | the per|son perf|
|00003710| 6f 72 6d 69 6e 67 20 74 | 68 65 20 6d 6f 64 69 66 |orming t|he modif|
|00003720| 69 63 61 74 69 6f 6e 2c | 20 74 68 65 20 64 61 74 |ication,| the dat|
|00003730| 65 20 6f 66 20 6d 6f 64 | 69 66 69 63 61 74 69 6f |e of mod|ificatio|
|00003740| 6e 2c 0a 58 20 2a 20 61 | 6e 64 20 74 68 65 20 72 |n,.X * a|nd the r|
|00003750| 65 61 73 6f 6e 20 66 6f | 72 20 73 75 63 68 20 6d |eason fo|r such m|
|00003760| 6f 64 69 66 69 63 61 74 | 69 6f 6e 2e 0a 58 20 2a |odificat|ion..X *|
|00003770| 0a 58 20 2a 20 24 49 64 | 3a 20 66 75 6e 63 64 65 |.X * $Id|: funcde|
|00003780| 66 73 2e 68 2c 76 20 33 | 2e 30 20 38 39 2f 31 30 |fs.h,v 3|.0 89/10|
|00003790| 2f 32 37 20 30 32 3a 30 | 35 3a 35 30 20 63 72 61 |/27 02:0|5:50 cra|
|000037a0| 69 67 20 45 78 70 20 24 | 0a 58 20 2a 0a 58 20 2a |ig Exp $|.X *.X *|
|000037b0| 20 24 4c 6f 67 3a 09 66 | 75 6e 63 64 65 66 73 2e | $Log:.f|uncdefs.|
|000037c0| 68 2c 76 20 24 0a 58 20 | 2a 20 52 65 76 69 73 69 |h,v $.X |* Revisi|
|000037d0| 6f 6e 20 33 2e 30 20 20 | 38 39 2f 31 30 2f 32 37 |on 3.0 |89/10/27|
|000037e0| 20 20 30 32 3a 30 35 3a | 35 30 20 20 63 72 61 69 | 02:05:|50 crai|
|000037f0| 67 0a 58 20 2a 20 42 61 | 73 65 6c 69 6e 65 20 66 |g.X * Ba|seline f|
|00003800| 6f 72 20 66 69 72 73 74 | 20 6f 66 66 69 63 69 61 |or first| officia|
|00003810| 6c 20 72 65 6c 65 61 73 | 65 2e 0a 58 20 2a 20 0a |l releas|e..X * .|
|00003820| 58 20 2a 2f 0a 58 0a 58 | 2f 2a 0a 58 20 2a 20 54 |X */.X.X|/*.X * T|
|00003830| 68 69 73 20 66 69 6c 65 | 20 73 68 6f 75 6c 64 20 |his file| should |
|00003840| 65 76 65 6e 74 75 61 6c | 6c 79 20 64 69 73 61 70 |eventual|ly disap|
|00003850| 70 65 61 72 3b 20 66 75 | 6e 63 74 69 6f 6e 20 64 |pear; fu|nction d|
|00003860| 65 63 6c 61 72 61 74 69 | 6f 6e 73 20 73 68 6f 75 |eclarati|ons shou|
|00003870| 6c 64 0a 58 20 2a 20 61 | 70 70 65 61 72 20 61 73 |ld.X * a|ppear as|
|00003880| 20 65 78 74 65 72 6e 73 | 20 77 68 65 72 65 20 6e | externs| where n|
|00003890| 65 65 64 65 64 2e 20 20 | 4d 61 63 72 6f 73 20 73 |eeded. |Macros s|
|000038a0| 68 6f 75 6c 64 20 62 65 | 20 6d 6f 76 65 64 20 74 |hould be| moved t|
|000038b0| 6f 20 61 20 73 65 70 61 | 72 61 74 65 20 66 69 6c |o a sepa|rate fil|
|000038c0| 65 2e 0a 58 20 2a 2f 0a | 58 2f 2a 0a 58 20 2a 20 |e..X */.|X/*.X * |
|000038d0| 4e 6f 72 6d 61 6c 20 72 | 6f 75 74 69 6e 65 73 0a |Normal r|outines.|
|000038e0| 58 20 2a 2f 0a 58 69 6e | 74 09 6e 72 6d 73 70 68 |X */.Xin|t.nrmsph|
|000038f0| 28 29 2c 20 6e 72 6d 62 | 6f 78 28 29 2c 20 6e 72 |(), nrmb|ox(), nr|
|00003900| 6d 74 72 69 28 29 2c 20 | 6e 72 6d 73 75 70 28 29 |mtri(), |nrmsup()|
|00003910| 2c 6e 72 6d 70 6c 61 6e | 65 28 29 2c 20 6e 72 6d |,nrmplan|e(), nrm|
|00003920| 63 79 6c 28 29 2c 0a 58 | 09 09 6e 72 6d 70 6f 6c |cyl(),.X|..nrmpol|
|00003930| 79 28 29 2c 20 6e 72 6d | 63 6f 6e 65 28 29 2c 20 |y(), nrm|cone(), |
|00003940| 6e 72 6d 68 66 28 29 3b | 0a 58 2f 2a 0a 58 20 2a |nrmhf();|.X/*.X *|
|00003950| 20 49 6e 74 65 72 73 65 | 63 74 69 6f 6e 20 72 6f | Interse|ction ro|
|00003960| 75 74 69 6e 65 73 0a 58 | 20 2a 2f 0a 58 64 6f 75 |utines.X| */.Xdou|
|00003970| 62 6c 65 20 09 69 6e 74 | 73 70 68 28 29 2c 20 69 |ble .int|sph(), i|
|00003980| 6e 74 62 6f 78 28 29 2c | 20 69 6e 74 74 72 69 28 |ntbox(),| inttri(|
|00003990| 29 2c 20 69 6e 74 73 75 | 70 28 29 2c 69 6e 74 70 |), intsu|p(),intp|
|000039a0| 6c 61 6e 65 28 29 2c 20 | 63 72 6f 73 73 70 28 29 |lane(), |crossp()|
|000039b0| 2c 20 69 6e 74 63 79 6c | 28 29 2c 0a 58 09 09 69 |, intcyl|(),.X..i|
|000039c0| 6e 74 70 6f 6c 79 28 29 | 2c 20 69 6e 74 63 6f 6e |ntpoly()|, intcon|
|000039d0| 65 28 29 2c 20 69 6e 74 | 68 66 28 29 3b 0a 58 2f |e(), int|hf();.X/|
|000039e0| 2a 0a 58 20 2a 20 45 78 | 74 65 6e 74 2d 62 6f 78 |*.X * Ex|tent-box|
|000039f0| 20 66 69 6e 64 69 6e 67 | 20 72 6f 75 74 69 6e 65 | finding| routine|
|00003a00| 73 0a 58 20 2a 2f 0a 58 | 69 6e 74 09 73 70 68 65 |s.X */.X|int.sphe|
|00003a10| 78 74 65 6e 74 28 29 2c | 62 6f 78 65 78 74 65 6e |xtent(),|boxexten|
|00003a20| 74 28 29 2c 74 72 69 65 | 78 74 65 6e 74 28 29 2c |t(),trie|xtent(),|
|00003a30| 73 75 70 65 78 74 65 6e | 74 28 29 2c 70 6c 61 6e |supexten|t(),plan|
|00003a40| 65 65 78 74 65 6e 74 28 | 29 2c 0a 58 09 09 63 79 |eextent(|),.X..cy|
|00003a50| 6c 65 78 74 65 6e 74 28 | 29 2c 20 70 6f 6c 79 65 |lextent(|), polye|
|00003a60| 78 74 65 6e 74 28 29 2c | 20 63 6f 6e 65 65 78 74 |xtent(),| coneext|
|00003a70| 65 6e 74 28 29 2c 20 68 | 66 65 78 74 65 6e 74 28 |ent(), h|fextent(|
|00003a80| 29 3b 0a 58 0a 58 2f 2a | 0a 58 20 2a 20 4f 62 6a |);.X.X/*|.X * Obj|
|00003a90| 65 63 74 20 63 72 65 61 | 74 69 6f 6e 20 72 6f 75 |ect crea|tion rou|
|00003aa0| 74 69 6e 65 73 0a 58 20 | 2a 2f 0a 58 4f 62 6a 65 |tines.X |*/.XObje|
|00003ab0| 63 74 20 2a 6d 61 6b 73 | 70 68 28 29 2c 20 2a 6d |ct *maks|ph(), *m|
|00003ac0| 61 6b 62 6f 78 28 29 2c | 20 2a 6d 61 6b 74 72 69 |akbox(),| *maktri|
|00003ad0| 28 29 2c 20 2a 6d 61 6b | 73 75 70 28 29 2c 20 2a |(), *mak|sup(), *|
|00003ae0| 6d 61 6b 70 6c 61 6e 65 | 28 29 2c 20 2a 6d 61 6b |makplane|(), *mak|
|00003af0| 63 79 6c 28 29 2c 0a 58 | 09 20 20 2a 6d 61 6b 70 |cyl(),.X|. *makp|
|00003b00| 6f 6c 79 28 29 2c 20 2a | 6d 61 6b 63 6f 6e 65 28 |oly(), *|makcone(|
|00003b10| 29 2c 20 2a 6d 61 6b 68 | 66 28 29 2c 20 2a 6e 65 |), *makh|f(), *ne|
|00003b20| 77 5f 6f 62 6a 65 63 74 | 28 29 3b 0a 58 2f 2a 0a |w_object|();.X/*.|
|00003b30| 58 20 2a 20 49 6e 74 65 | 72 73 65 63 74 69 6f 6e |X * Inte|rsection|
|00003b40| 20 72 6f 75 74 69 6e 65 | 73 2e 0a 58 20 2a 2f 0a | routine|s..X */.|
|00003b50| 58 64 6f 75 62 6c 65 09 | 69 6e 74 5f 67 72 69 64 |Xdouble.|int_grid|
|00003b60| 28 29 2c 20 69 6e 74 5f | 6c 69 73 74 28 29 2c 20 |(), int_|list(), |
|00003b70| 69 6e 74 5f 70 72 69 6d | 69 74 69 76 65 28 29 2c |int_prim|itive(),|
|00003b80| 20 49 6e 74 42 6f 75 6e | 64 73 28 29 3b 0a 58 0a | IntBoun|ds();.X.|
|00003b90| 58 2f 2a 0a 58 20 2a 20 | 4d 69 73 63 2e 0a 58 20 |X/*.X * |Misc..X |
|00003ba0| 2a 2f 0a 58 63 68 61 72 | 20 2a 4d 61 6c 6c 6f 63 |*/.Xchar| *Malloc|
|00003bb0| 28 29 2c 20 2a 43 61 6c | 6c 6f 63 28 29 2c 20 2a |(), *Cal|loc(), *|
|00003bc0| 73 74 72 73 61 76 65 28 | 29 3b 0a 58 64 6f 75 62 |strsave(|);.Xdoub|
|00003bd0| 6c 65 09 6e 6f 72 6d 61 | 6c 69 7a 65 28 29 2c 20 |le.norma|lize(), |
|00003be0| 4e 6f 69 73 65 28 29 3b | 0a 58 0a 58 2f 2a 0a 58 |Noise();|.X.X/*.X|
|00003bf0| 20 2a 20 54 72 61 6e 73 | 66 6f 72 6d 61 74 69 6f | * Trans|formatio|
|00003c00| 6e 73 0a 58 20 2a 2f 0a | 58 54 72 61 6e 73 20 2a |ns.X */.|XTrans *|
|00003c10| 6e 65 77 5f 74 72 61 6e | 73 28 29 3b 0a 58 54 72 |new_tran|s();.XTr|
|00003c20| 61 6e 73 49 6e 66 6f 20 | 2a 6e 65 77 5f 74 72 61 |ansInfo |*new_tra|
|00003c30| 6e 73 69 6e 66 6f 28 29 | 3b 0a 58 0a 58 2f 2a 0a |nsinfo()|;.X.X/*.|
|00003c40| 58 20 2a 20 53 75 72 66 | 61 63 65 73 0a 58 20 2a |X * Surf|aces.X *|
|00003c50| 2f 0a 58 53 75 72 66 61 | 63 65 09 2a 66 69 6e 64 |/.XSurfa|ce.*find|
|00003c60| 5f 73 75 72 66 61 63 65 | 28 29 2c 20 2a 6d 61 6b |_surface|(), *mak|
|00003c70| 65 5f 73 75 72 66 61 63 | 65 28 29 2c 20 2a 67 65 |e_surfac|e(), *ge|
|00003c80| 74 5f 73 75 72 66 61 63 | 65 28 29 3b 0a 58 53 75 |t_surfac|e();.XSu|
|00003c90| 72 66 61 63 65 4c 69 73 | 74 20 2a 61 64 64 5f 73 |rfaceLis|t *add_s|
|00003ca0| 75 72 66 61 63 65 28 29 | 3b 0a 58 2f 2a 0a 58 20 |urface()|;.X/*.X |
|00003cb0| 2a 20 4f 62 6a 65 63 74 | 73 0a 58 20 2a 2f 0a 58 |* Object|s.X */.X|
|00003cc0| 4f 62 6a 65 63 74 20 2a | 61 64 64 5f 63 68 69 6c |Object *|add_chil|
|00003cd0| 64 5f 6e 61 6d 65 64 28 | 29 2c 20 2a 61 64 64 5f |d_named(|), *add_|
|00003ce0| 63 68 69 6c 64 28 29 2c | 20 2a 67 65 74 5f 6f 62 |child(),| *get_ob|
|00003cf0| 6a 65 63 74 5f 6e 61 6d | 65 64 28 29 3b 0a 58 0a |ject_nam|ed();.X.|
|00003d00| 58 65 78 74 65 72 6e 20 | 64 6f 75 62 6c 65 20 66 |Xextern |double f|
|00003d10| 74 6d 70 3b 20 20 2f 2a | 20 59 69 63 6b 20 2d 2d |tmp; /*| Yick --|
|00003d20| 20 6b 65 65 70 73 20 75 | 73 20 66 72 6f 6d 20 65 | keeps u|s from e|
|00003d30| 76 61 6c 75 61 74 69 6e | 67 20 74 77 69 63 65 20 |valuatin|g twice |
|00003d40| 64 75 72 69 6e 67 20 66 | 61 62 73 2e 20 2a 2f 0a |during f|abs. */.|
|00003d50| 58 0a 58 2f 2a 0a 58 20 | 2a 20 4d 61 63 72 6f 73 |X.X/*.X |* Macros|
|00003d60| 0a 58 20 2a 2f 0a 58 0a | 58 2f 2a 0a 58 20 2a 20 |.X */.X.|X/*.X * |
|00003d70| 41 62 73 6f 6c 75 74 65 | 20 76 61 6c 75 65 20 2d |Absolute| value -|
|00003d80| 2d 20 75 73 65 73 20 22 | 66 74 6d 70 22 20 74 6f |- uses "|ftmp" to|
|00003d90| 20 73 74 6f 72 65 20 76 | 61 6c 75 65 20 6f 66 20 | store v|alue of |
|00003da0| 61 72 67 75 6d 65 6e 74 | 2c 20 77 68 69 63 68 0a |argument|, which.|
|00003db0| 58 20 2a 20 6b 65 65 70 | 73 20 75 73 20 66 72 6f |X * keep|s us fro|
|00003dc0| 6d 20 65 76 61 6c 75 61 | 74 69 6e 67 20 65 78 70 |m evalua|ting exp|
|00003dd0| 72 65 73 73 69 6f 6e 73 | 20 6d 6f 72 65 20 74 68 |ressions| more th|
|00003de0| 61 6e 20 6f 6e 63 65 2e | 0a 58 20 2a 2f 0a 58 23 |an once.|.X */.X#|
|00003df0| 64 65 66 69 6e 65 09 66 | 61 62 73 28 78 29 09 09 |define.f|abs(x)..|
|00003e00| 09 28 28 66 74 6d 70 3d | 28 78 29 29 20 3c 20 30 |.((ftmp=|(x)) < 0|
|00003e10| 2e 20 3f 20 2d 28 66 74 | 6d 70 29 20 3a 20 28 66 |. ? -(ft|mp) : (f|
|00003e20| 74 6d 70 29 29 0a 58 23 | 64 65 66 69 6e 65 20 61 |tmp)).X#|define a|
|00003e30| 62 73 28 78 29 20 09 09 | 09 28 28 78 29 20 3c 20 |bs(x) ..|.((x) < |
|00003e40| 30 20 3f 20 2d 28 78 29 | 20 3a 20 28 78 29 29 0a |0 ? -(x)| : (x)).|
|00003e50| 58 0a 58 23 69 66 64 65 | 66 20 53 59 53 56 0a 58 |X.X#ifde|f SYSV.X|
|00003e60| 64 6f 75 62 6c 65 20 64 | 72 61 6e 64 34 38 28 29 |double d|rand48()|
|00003e70| 3b 0a 58 2f 2a 0a 58 20 | 2a 20 6e 72 61 6e 64 28 |;.X/*.X |* nrand(|
|00003e80| 29 20 72 65 74 75 72 6e | 73 20 61 20 75 6e 69 66 |) return|s a unif|
|00003e90| 6f 72 6d 6c 79 20 64 69 | 73 74 72 69 62 75 74 65 |ormly di|stribute|
|00003ea0| 64 20 72 61 6e 64 6f 6d | 20 76 61 72 69 61 62 6c |d random| variabl|
|00003eb0| 65 20 62 65 74 77 65 65 | 6e 20 30 20 61 6e 64 20 |e betwee|n 0 and |
|00003ec0| 31 2e 0a 58 20 2a 2f 0a | 58 23 64 65 66 69 6e 65 |1..X */.|X#define|
|00003ed0| 20 6e 72 61 6e 64 28 29 | 09 09 09 28 64 72 61 6e | nrand()|...(dran|
|00003ee0| 64 34 38 28 29 29 0a 58 | 23 65 6c 73 65 0a 58 6c |d48()).X|#else.Xl|
|00003ef0| 6f 6e 67 20 72 61 6e 64 | 6f 6d 28 29 3b 0a 58 23 |ong rand|om();.X#|
|00003f00| 64 65 66 69 6e 65 20 6e | 72 61 6e 64 28 29 09 09 |define n|rand()..|
|00003f10| 09 28 28 64 6f 75 62 6c | 65 29 72 61 6e 64 6f 6d |.((doubl|e)random|
|00003f20| 28 29 20 2f 20 28 64 6f | 75 62 6c 65 29 28 28 31 |() / (do|uble)((1|
|00003f30| 20 3c 3c 20 33 31 29 20 | 2d 20 31 29 29 0a 58 23 | << 31) |- 1)).X#|
|00003f40| 65 6e 64 69 66 0a 58 0a | 58 23 69 66 64 65 66 20 |endif.X.|X#ifdef |
|00003f50| 4d 55 4c 54 49 4d 41 58 | 0a 58 2f 2a 0a 58 20 2a |MULTIMAX|.X/*.X *|
|00003f60| 20 4f 6e 20 74 68 65 20 | 6d 75 6c 74 69 6d 61 78 | On the |multimax|
|00003f70| 2c 20 61 6c 6c 6f 63 61 | 74 65 20 6c 61 72 67 65 |, alloca|te large|
|00003f80| 20 70 69 65 63 65 73 20 | 6f 66 20 6d 65 6d 6f 72 | pieces |of memor|
|00003f90| 79 20 61 73 20 73 68 61 | 72 65 64 20 6d 65 6d 6f |y as sha|red memo|
|00003fa0| 72 79 2e 0a 58 20 2a 2f | 0a 58 65 78 74 65 72 6e |ry..X */|.Xextern|
|00003fb0| 20 63 68 61 72 20 2a 73 | 68 61 72 65 5f 6d 61 6c | char *s|hare_mal|
|00003fc0| 6c 6f 63 28 29 2c 20 2a | 73 68 61 72 65 5f 63 61 |loc(), *|share_ca|
|00003fd0| 6c 6c 6f 63 28 29 3b 0a | 58 23 64 65 66 69 6e 65 |lloc();.|X#define|
|00003fe0| 20 6d 61 6c 6c 6f 63 70 | 72 69 6d 28 29 09 09 28 | mallocp|rim()..(|
|00003ff0| 50 72 69 6d 69 74 69 76 | 65 20 2a 29 73 68 61 72 |Primitiv|e *)shar|
|00004000| 65 5f 6d 61 6c 6c 6f 63 | 28 73 69 7a 65 6f 66 28 |e_malloc|(sizeof(|
|00004010| 50 72 69 6d 69 74 69 76 | 65 29 29 0a 58 23 65 6c |Primitiv|e)).X#el|
|00004020| 73 65 0a 58 2f 2a 0a 58 | 20 2a 20 4f 74 68 65 72 |se.X/*.X| * Other|
|00004030| 77 69 73 65 2c 20 6d 61 | 6c 6c 6f 63 20 69 73 20 |wise, ma|lloc is |
|00004040| 6d 61 6c 6c 6f 63 2c 20 | 65 74 63 2e 0a 58 20 2a |malloc, |etc..X *|
|00004050| 2f 0a 58 23 64 65 66 69 | 6e 65 20 73 68 61 72 65 |/.X#defi|ne share|
|00004060| 5f 6d 61 6c 6c 6f 63 28 | 78 29 09 09 4d 61 6c 6c |_malloc(|x)..Mall|
|00004070| 6f 63 28 78 29 0a 58 23 | 64 65 66 69 6e 65 20 73 |oc(x).X#|define s|
|00004080| 68 61 72 65 5f 63 61 6c | 6c 6f 63 28 78 2c 79 29 |hare_cal|loc(x,y)|
|00004090| 09 43 61 6c 6c 6f 63 28 | 78 2c 79 29 0a 58 23 64 |.Calloc(|x,y).X#d|
|000040a0| 65 66 69 6e 65 20 6d 61 | 6c 6c 6f 63 70 72 69 6d |efine ma|llocprim|
|000040b0| 28 29 09 09 28 50 72 69 | 6d 69 74 69 76 65 20 2a |()..(Pri|mitive *|
|000040c0| 29 4d 61 6c 6c 6f 63 28 | 73 69 7a 65 6f 66 28 50 |)Malloc(|sizeof(P|
|000040d0| 72 69 6d 69 74 69 76 65 | 29 29 0a 58 23 65 6e 64 |rimitive|)).X#end|
|000040e0| 69 66 0a 58 0a 58 2f 2a | 0a 58 20 2a 20 52 65 74 |if.X.X/*|.X * Ret|
|000040f0| 75 72 6e 20 61 20 75 6e | 69 66 6f 72 6d 6c 79 20 |urn a un|iformly |
|00004100| 64 69 73 74 72 69 62 75 | 74 65 64 20 72 61 6e 64 |distribu|ted rand|
|00004110| 6f 6d 20 76 61 72 69 61 | 62 6c 65 20 62 65 74 77 |om varia|ble betw|
|00004120| 65 65 6e 20 2d 73 2f 32 | 20 61 6e 64 20 73 2f 32 |een -s/2| and s/2|
|00004130| 2e 0a 58 20 2a 2f 0a 58 | 23 64 65 66 69 6e 65 20 |..X */.X|#define |
|00004140| 6a 69 74 74 65 72 28 73 | 29 09 09 28 28 6e 72 61 |jitter(s|)..((nra|
|00004150| 6e 64 28 29 20 2a 20 28 | 73 29 29 20 2d 20 28 73 |nd() * (|s)) - (s|
|00004160| 29 2f 32 2e 29 0a 58 2f | 2a 0a 58 20 2a 20 44 6f |)/2.).X/|*.X * Do|
|00004170| 74 20 70 72 6f 64 75 63 | 74 0a 58 20 2a 2f 0a 58 |t produc|t.X */.X|
|00004180| 23 64 65 66 69 6e 65 20 | 64 6f 74 70 28 61 2c 20 |#define |dotp(a, |
|00004190| 62 29 09 09 28 28 28 61 | 29 2d 3e 78 2a 28 62 29 |b)..(((a|)->x*(b)|
|000041a0| 2d 3e 78 29 2b 28 28 61 | 29 2d 3e 79 2a 28 62 29 |->x)+((a|)->y*(b)|
|000041b0| 2d 3e 79 29 2b 28 28 61 | 29 2d 3e 7a 2a 28 62 29 |->y)+((a|)->z*(b)|
|000041c0| 2d 3e 7a 29 29 0a 58 2f | 2a 0a 58 20 2a 20 43 6c |->z)).X/|*.X * Cl|
|000041d0| 6f 73 65 20 65 6e 6f 75 | 67 68 20 66 6f 72 20 75 |ose enou|gh for u|
|000041e0| 73 2e 0a 58 20 2a 2f 0a | 58 23 64 65 66 69 6e 65 |s..X */.|X#define|
|000041f0| 20 65 71 75 61 6c 28 61 | 2c 20 62 29 09 09 28 66 | equal(a|, b)..(f|
|00004200| 61 62 73 28 28 61 29 20 | 2d 20 28 62 29 29 20 3c |abs((a) |- (b)) <|
|00004210| 20 45 50 53 49 4c 4f 4e | 29 0a 58 2f 2a 0a 58 20 | EPSILON|).X/*.X |
|00004220| 2a 20 4d 61 78 69 6d 75 | 6d 2f 4d 69 6e 69 6d 75 |* Maximu|m/Minimu|
|00004230| 6d 20 66 75 6e 63 74 69 | 6f 6e 73 0a 58 20 2a 2f |m functi|ons.X */|
|00004240| 0a 58 23 64 65 66 69 6e | 65 20 6d 61 78 28 61 2c |.X#defin|e max(a,|
|00004250| 20 62 29 09 09 28 28 61 | 29 20 3e 20 28 62 29 20 | b)..((a|) > (b) |
|00004260| 3f 20 28 61 29 20 3a 20 | 28 62 29 29 0a 58 23 64 |? (a) : |(b)).X#d|
|00004270| 65 66 69 6e 65 20 6d 69 | 6e 28 61 2c 20 62 29 09 |efine mi|n(a, b).|
|00004280| 09 28 28 61 29 20 3c 20 | 28 62 29 20 3f 20 28 61 |.((a) < |(b) ? (a|
|00004290| 29 20 3a 20 28 62 29 29 | 0a 58 2f 2a 0a 58 20 2a |) : (b))|.X/*.X *|
|000042a0| 20 43 6f 6e 76 65 72 74 | 20 66 72 6f 6d 20 76 6f | Convert| from vo|
|000042b0| 78 65 6c 20 6e 75 6d 62 | 65 72 20 61 6c 6f 6e 67 |xel numb|er along|
|000042c0| 20 58 2f 59 2f 5a 20 74 | 6f 20 63 6f 72 72 65 73 | X/Y/Z t|o corres|
|000042d0| 70 6f 6e 64 69 6e 67 20 | 63 6f 6f 72 64 69 6e 61 |ponding |coordina|
|000042e0| 74 65 2e 0a 58 20 2a 2f | 0a 58 23 64 65 66 69 6e |te..X */|.X#defin|
|000042f0| 65 20 76 6f 78 65 6c 32 | 78 28 67 2c 78 29 09 09 |e voxel2|x(g,x)..|
|00004300| 28 28 78 29 20 2a 20 67 | 2d 3e 76 6f 78 73 69 7a |((x) * g|->voxsiz|
|00004310| 65 5b 30 5d 2b 20 67 2d | 3e 62 6f 75 6e 64 73 5b |e[0]+ g-|>bounds[|
|00004320| 30 5d 5b 30 5d 29 0a 58 | 23 64 65 66 69 6e 65 20 |0][0]).X|#define |
|00004330| 76 6f 78 65 6c 32 79 28 | 67 2c 79 29 09 09 28 28 |voxel2y(|g,y)..((|
|00004340| 79 29 20 2a 20 67 2d 3e | 76 6f 78 73 69 7a 65 5b |y) * g->|voxsize[|
|00004350| 31 5d 20 2b 20 67 2d 3e | 62 6f 75 6e 64 73 5b 30 |1] + g->|bounds[0|
|00004360| 5d 5b 31 5d 29 0a 58 23 | 64 65 66 69 6e 65 20 76 |][1]).X#|define v|
|00004370| 6f 78 65 6c 32 7a 28 67 | 2c 7a 29 09 09 28 28 7a |oxel2z(g|,z)..((z|
|00004380| 29 20 2a 20 67 2d 3e 76 | 6f 78 73 69 7a 65 5b 32 |) * g->v|oxsize[2|
|00004390| 5d 20 2b 20 67 2d 3e 62 | 6f 75 6e 64 73 5b 30 5d |] + g->b|ounds[0]|
|000043a0| 5b 32 5d 29 0a 58 2f 2a | 0a 58 20 2a 20 41 6e 64 |[2]).X/*|.X * And|
|000043b0| 20 76 69 63 65 2d 76 65 | 72 73 61 2e 0a 58 20 2a | vice-ve|rsa..X *|
|000043c0| 2f 0a 58 23 64 65 66 69 | 6e 65 20 78 32 76 6f 78 |/.X#defi|ne x2vox|
|000043d0| 65 6c 28 67 2c 78 29 09 | 09 28 28 28 78 29 20 2d |el(g,x).|.(((x) -|
|000043e0| 20 67 2d 3e 62 6f 75 6e | 64 73 5b 30 5d 5b 30 5d | g->boun|ds[0][0]|
|000043f0| 29 20 2f 20 67 2d 3e 76 | 6f 78 73 69 7a 65 5b 30 |) / g->v|oxsize[0|
|00004400| 5d 29 0a 58 23 64 65 66 | 69 6e 65 20 79 32 76 6f |]).X#def|ine y2vo|
|00004410| 78 65 6c 28 67 2c 79 29 | 09 09 28 28 28 79 29 20 |xel(g,y)|..(((y) |
|00004420| 2d 20 67 2d 3e 62 6f 75 | 6e 64 73 5b 30 5d 5b 31 |- g->bou|nds[0][1|
|00004430| 5d 29 20 2f 20 67 2d 3e | 76 6f 78 73 69 7a 65 5b |]) / g->|voxsize[|
|00004440| 31 5d 29 0a 58 23 64 65 | 66 69 6e 65 20 7a 32 76 |1]).X#de|fine z2v|
|00004450| 6f 78 65 6c 28 67 2c 7a | 29 09 09 28 28 28 7a 29 |oxel(g,z|)..(((z)|
|00004460| 20 2d 20 67 2d 3e 62 6f | 75 6e 64 73 5b 30 5d 5b | - g->bo|unds[0][|
|00004470| 32 5d 29 20 2f 20 67 2d | 3e 76 6f 78 73 69 7a 65 |2]) / g-|>voxsize|
|00004480| 5b 32 5d 29 0a 58 2f 2a | 0a 58 20 2a 20 49 73 20 |[2]).X/*|.X * Is |
|00004490| 74 68 65 20 70 6f 69 6e | 74 20 22 70 22 20 6f 75 |the poin|t "p" ou|
|000044a0| 74 69 73 64 65 20 6f 66 | 20 74 68 65 20 62 6f 75 |tisde of| the bou|
|000044b0| 6e 64 69 6e 67 20 62 6f | 78 20 22 62 22 3f 0a 58 |nding bo|x "b"?.X|
|000044c0| 20 2a 2f 0a 58 23 64 65 | 66 69 6e 65 20 4f 75 74 | */.X#de|fine Out|
|000044d0| 4f 66 42 6f 75 6e 64 73 | 28 70 2c 62 29 20 28 28 |OfBounds|(p,b) ((|
|000044e0| 70 29 2d 3e 78 20 3c 20 | 62 5b 30 5d 5b 30 5d 20 |p)->x < |b[0][0] |
|000044f0| 7c 7c 20 28 70 29 2d 3e | 78 20 3e 20 62 5b 31 5d ||| (p)->|x > b[1]|
|00004500| 5b 30 5d 20 7c 7c 5c 0a | 58 09 09 09 20 20 28 70 |[0] ||\.|X... (p|
|00004510| 29 2d 3e 79 20 3c 20 62 | 5b 30 5d 5b 31 5d 20 7c |)->y < b|[0][1] ||
|00004520| 7c 20 28 70 29 2d 3e 79 | 20 3e 20 62 5b 31 5d 5b || (p)->y| > b[1][|
|00004530| 31 5d 20 7c 7c 5c 0a 58 | 09 09 09 20 20 28 70 29 |1] ||\.X|... (p)|
|00004540| 2d 3e 7a 20 3c 20 62 5b | 30 5d 5b 32 5d 20 7c 7c |->z < b[|0][2] |||
|00004550| 20 28 70 29 2d 3e 7a 20 | 3e 20 62 5b 31 5d 5b 32 | (p)->z |> b[1][2|
|00004560| 5d 29 0a 58 0a 58 23 69 | 66 6e 64 65 66 20 44 55 |]).X.X#i|fndef DU|
|00004570| 4d 42 5f 43 50 50 0a 58 | 0a 58 23 64 65 66 69 6e |MB_CPP.X|.X#defin|
|00004580| 65 20 76 65 63 73 75 62 | 28 61 2c 62 2c 72 29 09 |e vecsub|(a,b,r).|
|00004590| 28 72 29 2d 3e 78 3d 20 | 28 61 29 2e 78 2d 28 62 |(r)->x= |(a).x-(b|
|000045a0| 29 2e 78 3b 28 72 29 2d | 3e 79 3d 20 28 61 29 2e |).x;(r)-|>y= (a).|
|000045b0| 79 2d 28 62 29 2e 79 3b | 28 72 29 2d 3e 7a 3d 20 |y-(b).y;|(r)->z= |
|000045c0| 28 61 29 2e 7a 2d 28 62 | 29 2e 7a 0a 58 23 64 65 |(a).z-(b|).z.X#de|
|000045d0| 66 69 6e 65 20 76 65 63 | 61 64 64 28 61 2c 62 2c |fine vec|add(a,b,|
|000045e0| 72 29 09 28 72 29 2d 3e | 78 3d 20 28 61 29 2e 78 |r).(r)->|x= (a).x|
|000045f0| 2b 28 62 29 2e 78 3b 28 | 72 29 2d 3e 79 3d 20 28 |+(b).x;(|r)->y= (|
|00004600| 61 29 2e 79 2b 28 62 29 | 2e 79 3b 28 72 29 2d 3e |a).y+(b)|.y;(r)->|
|00004610| 7a 3d 20 28 61 29 2e 7a | 2b 28 62 29 2e 7a 0a 58 |z= (a).z|+(b).z.X|
|00004620| 23 64 65 66 69 6e 65 20 | 73 63 61 6c 61 72 5f 70 |#define |scalar_p|
|00004630| 72 6f 64 28 73 2c 61 2c | 72 29 09 28 72 29 2d 3e |rod(s,a,|r).(r)->|
|00004640| 78 3d 20 73 2a 28 61 29 | 2e 78 3b 28 72 29 2d 3e |x= s*(a)|.x;(r)->|
|00004650| 79 3d 20 73 2a 28 61 29 | 2e 79 3b 28 72 29 2d 3e |y= s*(a)|.y;(r)->|
|00004660| 7a 3d 20 73 2a 28 61 29 | 2e 7a 0a 58 23 64 65 66 |z= s*(a)|.z.X#def|
|00004670| 69 6e 65 20 76 65 63 63 | 6f 6d 62 28 73 31 2c 76 |ine vecc|omb(s1,v|
|00004680| 31 2c 73 32 2c 76 32 2c | 72 29 09 28 72 29 2d 3e |1,s2,v2,|r).(r)->|
|00004690| 78 20 3d 20 73 31 2a 28 | 76 31 29 2e 78 20 2b 20 |x = s1*(|v1).x + |
|000046a0| 73 32 2a 28 76 32 29 2e | 78 3b 20 5c 0a 58 09 09 |s2*(v2).|x; \.X..|
|000046b0| 09 09 20 28 72 29 2d 3e | 79 20 3d 20 73 31 2a 28 |.. (r)->|y = s1*(|
|000046c0| 76 31 29 2e 79 20 2b 20 | 73 32 2a 28 76 32 29 2e |v1).y + |s2*(v2).|
|000046d0| 79 3b 20 5c 0a 58 09 09 | 09 09 20 28 72 29 2d 3e |y; \.X..|.. (r)->|
|000046e0| 7a 20 3d 20 73 31 2a 28 | 76 31 29 2e 7a 20 2b 20 |z = s1*(|v1).z + |
|000046f0| 73 32 2a 28 76 32 29 2e | 7a 3b 0a 58 23 64 65 66 |s2*(v2).|z;.X#def|
|00004700| 69 6e 65 20 61 64 64 73 | 63 61 6c 65 64 76 65 63 |ine adds|caledvec|
|00004710| 28 76 31 2c 73 2c 76 32 | 2c 72 29 09 28 72 29 2d |(v1,s,v2|,r).(r)-|
|00004720| 3e 78 20 3d 20 28 76 31 | 29 2e 78 20 2b 20 73 2a |>x = (v1|).x + s*|
|00004730| 28 76 32 29 2e 78 3b 20 | 5c 0a 58 09 09 09 09 20 |(v2).x; |\.X.... |
|00004740| 28 72 29 2d 3e 79 20 3d | 20 28 76 31 29 2e 79 20 |(r)->y =| (v1).y |
|00004750| 2b 20 73 2a 28 76 32 29 | 2e 79 3b 20 5c 0a 58 09 |+ s*(v2)|.y; \.X.|
|00004760| 09 09 09 20 28 72 29 2d | 3e 7a 20 3d 20 28 76 31 |... (r)-|>z = (v1|
|00004770| 29 2e 7a 20 2b 20 73 2a | 28 76 32 29 2e 7a 3b 0a |).z + s*|(v2).z;.|
|00004780| 58 23 65 6e 64 69 66 0a | 45 4e 44 5f 4f 46 5f 46 |X#endif.|END_OF_F|
|00004790| 49 4c 45 0a 69 66 20 74 | 65 73 74 20 34 37 36 32 |ILE.if t|est 4762|
|000047a0| 20 2d 6e 65 20 60 77 63 | 20 2d 63 20 3c 27 73 72 | -ne `wc| -c <'sr|
|000047b0| 63 2f 66 75 6e 63 64 65 | 66 73 2e 68 27 60 3b 20 |c/funcde|fs.h'`; |
|000047c0| 74 68 65 6e 0a 20 20 20 | 20 65 63 68 6f 20 73 68 |then. | echo sh|
|000047d0| 61 72 3a 20 5c 22 27 73 | 72 63 2f 66 75 6e 63 64 |ar: \"'s|rc/funcd|
|000047e0| 65 66 73 2e 68 27 5c 22 | 20 75 6e 70 61 63 6b 65 |efs.h'\"| unpacke|
|000047f0| 64 20 77 69 74 68 20 77 | 72 6f 6e 67 20 73 69 7a |d with w|rong siz|
|00004800| 65 21 0a 66 69 0a 23 20 | 65 6e 64 20 6f 66 20 27 |e!.fi.# |end of '|
|00004810| 73 72 63 2f 66 75 6e 63 | 64 65 66 73 2e 68 27 0a |src/func|defs.h'.|
|00004820| 66 69 0a 69 66 20 74 65 | 73 74 20 2d 66 20 27 73 |fi.if te|st -f 's|
|00004830| 72 63 2f 69 6e 70 75 74 | 2e 63 27 20 2d 61 20 22 |rc/input|.c' -a "|
|00004840| 24 7b 31 7d 22 20 21 3d | 20 22 2d 63 22 20 3b 20 |${1}" !=| "-c" ; |
|00004850| 74 68 65 6e 20 0a 20 20 | 65 63 68 6f 20 73 68 61 |then . |echo sha|
|00004860| 72 3a 20 57 69 6c 6c 20 | 6e 6f 74 20 63 6c 6f 62 |r: Will |not clob|
|00004870| 62 65 72 20 65 78 69 73 | 74 69 6e 67 20 66 69 6c |ber exis|ting fil|
|00004880| 65 20 5c 22 27 73 72 63 | 2f 69 6e 70 75 74 2e 63 |e \"'src|/input.c|
|00004890| 27 5c 22 0a 65 6c 73 65 | 0a 65 63 68 6f 20 73 68 |'\".else|.echo sh|
|000048a0| 61 72 3a 20 45 78 74 72 | 61 63 74 69 6e 67 20 5c |ar: Extr|acting \|
|000048b0| 22 27 73 72 63 2f 69 6e | 70 75 74 2e 63 27 5c 22 |"'src/in|put.c'\"|
|000048c0| 20 5c 28 33 33 34 32 20 | 63 68 61 72 61 63 74 65 | \(3342 |characte|
|000048d0| 72 73 5c 29 0a 73 65 64 | 20 22 73 2f 5e 58 2f 2f |rs\).sed| "s/^X//|
|000048e0| 22 20 3e 27 73 72 63 2f | 69 6e 70 75 74 2e 63 27 |" >'src/|input.c'|
|000048f0| 20 3c 3c 27 45 4e 44 5f | 4f 46 5f 46 49 4c 45 27 | <<'END_|OF_FILE'|
|00004900| 0a 58 2f 2a 0a 58 20 2a | 20 69 6e 70 75 74 2e 63 |.X/*.X *| input.c|
|00004910| 0a 58 20 2a 0a 58 20 2a | 20 43 6f 70 79 72 69 67 |.X *.X *| Copyrig|
|00004920| 68 74 20 28 43 29 20 31 | 39 38 39 2c 20 43 72 61 |ht (C) 1|989, Cra|
|00004930| 69 67 20 45 2e 20 4b 6f | 6c 62 0a 58 20 2a 0a 58 |ig E. Ko|lb.X *.X|
|00004940| 20 2a 20 54 68 69 73 20 | 73 6f 66 74 77 61 72 65 | * This |software|
|00004950| 20 6d 61 79 20 62 65 20 | 66 72 65 65 6c 79 20 63 | may be |freely c|
|00004960| 6f 70 69 65 64 2c 20 6d | 6f 64 69 66 69 65 64 2c |opied, m|odified,|
|00004970| 20 61 6e 64 20 72 65 64 | 69 73 74 72 69 62 75 74 | and red|istribut|
|00004980| 65 64 2c 0a 58 20 2a 20 | 70 72 6f 76 69 64 65 64 |ed,.X * |provided|
|00004990| 20 74 68 61 74 20 74 68 | 69 73 20 63 6f 70 79 72 | that th|is copyr|
|000049a0| 69 67 68 74 20 6e 6f 74 | 69 63 65 20 69 73 20 70 |ight not|ice is p|
|000049b0| 72 65 73 65 72 76 65 64 | 20 6f 6e 20 61 6c 6c 20 |reserved| on all |
|000049c0| 63 6f 70 69 65 73 2e 0a | 58 20 2a 0a 58 20 2a 20 |copies..|X *.X * |
|000049d0| 54 68 65 72 65 20 69 73 | 20 6e 6f 20 77 61 72 72 |There is| no warr|
|000049e0| 61 6e 74 79 20 6f 72 20 | 6f 74 68 65 72 20 67 75 |anty or |other gu|
|000049f0| 61 72 61 6e 74 65 65 20 | 6f 66 20 66 69 74 6e 65 |arantee |of fitne|
|00004a00| 73 73 20 66 6f 72 20 74 | 68 69 73 20 73 6f 66 74 |ss for t|his soft|
|00004a10| 77 61 72 65 2c 0a 58 20 | 2a 20 69 74 20 69 73 20 |ware,.X |* it is |
|00004a20| 70 72 6f 76 69 64 65 64 | 20 73 6f 6c 65 6c 79 20 |provided| solely |
|00004a30| 2e 20 20 42 75 67 20 72 | 65 70 6f 72 74 73 20 6f |. Bug r|eports o|
|00004a40| 72 20 66 69 78 65 73 20 | 6d 61 79 20 62 65 20 73 |r fixes |may be s|
|00004a50| 65 6e 74 0a 58 20 2a 20 | 74 6f 20 74 68 65 20 61 |ent.X * |to the a|
|00004a60| 75 74 68 6f 72 2c 20 77 | 68 6f 20 6d 61 79 20 6f |uthor, w|ho may o|
|00004a70| 72 20 6d 61 79 20 6e 6f | 74 20 61 63 74 20 6f 6e |r may no|t act on|
|00004a80| 20 74 68 65 6d 20 61 73 | 20 68 65 20 64 65 73 69 | them as| he desi|
|00004a90| 72 65 73 2e 0a 58 20 2a | 0a 58 20 2a 20 59 6f 75 |res..X *|.X * You|
|00004aa0| 20 6d 61 79 20 6e 6f 74 | 20 69 6e 63 6c 75 64 65 | may not| include|
|00004ab0| 20 74 68 69 73 20 73 6f | 66 74 77 61 72 65 20 69 | this so|ftware i|
|00004ac0| 6e 20 61 20 70 72 6f 67 | 72 61 6d 20 6f 72 20 6f |n a prog|ram or o|
|00004ad0| 74 68 65 72 20 73 6f 66 | 74 77 61 72 65 20 70 72 |ther sof|tware pr|
|00004ae0| 6f 64 75 63 74 0a 58 20 | 2a 20 77 69 74 68 6f 75 |oduct.X |* withou|
|00004af0| 74 20 73 75 70 70 6c 79 | 69 6e 67 20 74 68 65 20 |t supply|ing the |
|00004b00| 73 6f 75 72 63 65 2c 20 | 6f 72 20 77 69 74 68 6f |source, |or witho|
|00004b10| 75 74 20 69 6e 66 6f 72 | 6d 69 6e 67 20 74 68 65 |ut infor|ming the|
|00004b20| 20 65 6e 64 2d 75 73 65 | 72 20 74 68 61 74 20 74 | end-use|r that t|
|00004b30| 68 65 0a 58 20 2a 20 73 | 6f 75 72 63 65 20 69 73 |he.X * s|ource is|
|00004b40| 20 61 76 61 69 6c 61 62 | 6c 65 20 66 6f 72 20 6e | availab|le for n|
|00004b50| 6f 20 65 78 74 72 61 20 | 63 68 61 72 67 65 2e 0a |o extra |charge..|
|00004b60| 58 20 2a 0a 58 20 2a 20 | 49 66 20 79 6f 75 20 6d |X *.X * |If you m|
|00004b70| 6f 64 69 66 79 20 74 68 | 69 73 20 73 6f 66 74 77 |odify th|is softw|
|00004b80| 61 72 65 2c 20 79 6f 75 | 20 73 68 6f 75 6c 64 20 |are, you| should |
|00004b90| 69 6e 63 6c 75 64 65 20 | 61 20 6e 6f 74 69 63 65 |include |a notice|
|00004ba0| 20 67 69 76 69 6e 67 20 | 74 68 65 0a 58 20 2a 20 | giving |the.X * |
|00004bb0| 6e 61 6d 65 20 6f 66 20 | 74 68 65 20 70 65 72 73 |name of |the pers|
|00004bc0| 6f 6e 20 70 65 72 66 6f | 72 6d 69 6e 67 20 74 68 |on perfo|rming th|
|00004bd0| 65 20 6d 6f 64 69 66 69 | 63 61 74 69 6f 6e 2c 20 |e modifi|cation, |
|00004be0| 74 68 65 20 64 61 74 65 | 20 6f 66 20 6d 6f 64 69 |the date| of modi|
|00004bf0| 66 69 63 61 74 69 6f 6e | 2c 0a 58 20 2a 20 61 6e |fication|,.X * an|
|00004c00| 64 20 74 68 65 20 72 65 | 61 73 6f 6e 20 66 6f 72 |d the re|ason for|
|00004c10| 20 73 75 63 68 20 6d 6f | 64 69 66 69 63 61 74 69 | such mo|dificati|
|00004c20| 6f 6e 2e 0a 58 20 2a 0a | 58 20 2a 20 24 49 64 3a |on..X *.|X * $Id:|
|00004c30| 20 69 6e 70 75 74 2e 63 | 2c 76 20 33 2e 30 20 38 | input.c|,v 3.0 8|
|00004c40| 39 2f 31 30 2f 32 37 20 | 30 32 3a 30 35 3a 35 31 |9/10/27 |02:05:51|
|00004c50| 20 63 72 61 69 67 20 45 | 78 70 20 24 0a 58 20 2a | craig E|xp $.X *|
|00004c60| 0a 58 20 2a 20 24 4c 6f | 67 3a 09 69 6e 70 75 74 |.X * $Lo|g:.input|
|00004c70| 2e 63 2c 76 20 24 0a 58 | 20 2a 20 52 65 76 69 73 |.c,v $.X| * Revis|
|00004c80| 69 6f 6e 20 33 2e 30 20 | 20 38 39 2f 31 30 2f 32 |ion 3.0 | 89/10/2|
|00004c90| 37 20 20 30 32 3a 30 35 | 3a 35 31 20 20 63 72 61 |7 02:05|:51 cra|
|00004ca0| 69 67 0a 58 20 2a 20 42 | 61 73 65 6c 69 6e 65 20 |ig.X * B|aseline |
|00004cb0| 66 6f 72 20 66 69 72 73 | 74 20 6f 66 66 69 63 69 |for firs|t offici|
|00004cc0| 61 6c 20 72 65 6c 65 61 | 73 65 2e 0a 58 20 2a 20 |al relea|se..X * |
|00004cd0| 0a 58 20 2a 2f 0a 58 23 | 69 6e 63 6c 75 64 65 20 |.X */.X#|include |
|00004ce0| 3c 73 74 64 69 6f 2e 68 | 3e 0a 58 23 69 66 64 65 |<stdio.h|>.X#ifde|
|00004cf0| 66 20 53 59 53 56 0a 58 | 23 69 6e 63 6c 75 64 65 |f SYSV.X|#include|
|00004d00| 20 3c 73 74 72 69 6e 67 | 2e 68 3e 0a 58 23 65 6c | <string|.h>.X#el|
|00004d10| 73 65 0a 58 23 69 66 6e | 64 65 66 20 41 5a 54 45 |se.X#ifn|def AZTE|
|00004d20| 43 5f 43 0a 58 23 69 6e | 63 6c 75 64 65 20 3c 73 |C_C.X#in|clude <s|
|00004d30| 74 72 69 6e 67 73 2e 68 | 3e 0a 58 23 65 6c 73 65 |trings.h|>.X#else|
|00004d40| 20 2f 2a 20 41 5a 54 45 | 43 5f 43 20 2a 2f 0a 58 | /* AZTE|C_C */.X|
|00004d50| 0a 58 67 65 74 70 69 64 | 28 29 0a 58 7b 0a 58 09 |.Xgetpid|().X{.X.|
|00004d60| 72 65 74 75 72 6e 20 31 | 32 33 3b 0a 58 7d 0a 58 |return 1|23;.X}.X|
|00004d70| 23 65 6e 64 69 66 0a 58 | 23 65 6e 64 69 66 0a 58 |#endif.X|#endif.X|
|00004d80| 23 69 6e 63 6c 75 64 65 | 20 22 63 6f 6e 73 74 61 |#include| "consta|
|00004d90| 6e 74 73 2e 68 22 0a 58 | 23 69 6e 63 6c 75 64 65 |nts.h".X|#include|
|00004da0| 20 22 74 79 70 65 64 65 | 66 73 2e 68 22 0a 58 0a | "typede|fs.h".X.|
|00004db0| 58 23 64 65 66 69 6e 65 | 20 49 4e 43 4c 55 44 45 |X#define| INCLUDE|
|00004dc0| 5f 53 54 52 09 22 23 69 | 6e 63 6c 75 64 65 20 22 |_STR."#i|nclude "|
|00004dd0| 0a 58 0a 58 63 68 61 72 | 20 2a 69 6e 66 69 6c 65 |.X.Xchar| *infile|
|00004de0| 6e 61 6d 65 3b 09 2f 2a | 20 4e 61 6d 65 20 6f 66 |name;./*| Name of|
|00004df0| 20 69 6e 70 75 74 20 66 | 69 6c 65 2e 20 20 4e 55 | input f|ile. NU|
|00004e00| 4c 4c 20 73 69 67 6e 69 | 66 69 65 73 20 73 74 64 |LL signi|fies std|
|00004e10| 69 6e 2e 20 2a 2f 0a 58 | 63 68 61 72 20 74 6d 70 |in. */.X|char tmp|
|00004e20| 6e 61 6d 65 5b 42 55 46 | 53 49 5a 5d 3b 09 2f 2a |name[BUF|SIZ];./*|
|00004e30| 20 6e 61 6d 65 20 6f 66 | 20 74 65 6d 70 6f 72 61 | name of| tempora|
|00004e40| 72 79 20 66 69 6c 65 20 | 2a 2f 0a 58 65 78 74 65 |ry file |*/.Xexte|
|00004e50| 72 6e 20 46 49 4c 45 20 | 2a 79 79 69 6e 3b 09 2f |rn FILE |*yyin;./|
|00004e60| 2a 20 6c 65 78 2f 79 61 | 63 63 20 66 69 6c 65 20 |* lex/ya|cc file |
|00004e70| 70 6f 69 6e 74 65 72 20 | 2a 2f 0a 58 0a 58 72 65 |pointer |*/.X.Xre|
|00004e80| 61 64 5f 69 6e 70 75 74 | 5f 66 69 6c 65 28 29 0a |ad_input|_file().|
|00004e90| 58 7b 0a 58 09 65 78 74 | 65 72 6e 20 63 68 61 72 |X{.X.ext|ern char|
|00004ea0| 20 2a 69 6e 66 69 6c 65 | 6e 61 6d 65 3b 0a 58 0a | *infile|name;.X.|
|00004eb0| 58 09 2f 2a 0a 58 09 20 | 2a 20 4f 70 65 6e 20 74 |X./*.X. |* Open t|
|00004ec0| 65 6d 70 6f 72 61 72 79 | 20 66 69 6c 65 2e 0a 58 |emporary| file..X|
|00004ed0| 09 20 2a 2f 0a 58 09 73 | 70 72 69 6e 74 66 28 74 |. */.X.s|printf(t|
|00004ee0| 6d 70 6e 61 6d 65 2c 22 | 25 73 2f 72 61 79 74 6d |mpname,"|%s/raytm|
|00004ef0| 70 2e 25 64 22 2c 54 4d | 50 44 49 52 2c 20 67 65 |p.%d",TM|PDIR, ge|
|00004f00| 74 70 69 64 28 29 29 3b | 0a 58 09 79 79 69 6e 20 |tpid());|.X.yyin |
|00004f10| 3d 20 66 6f 70 65 6e 28 | 74 6d 70 6e 61 6d 65 2c |= fopen(|tmpname,|
|00004f20| 20 22 77 22 29 3b 0a 58 | 0a 58 09 69 66 20 28 79 | "w");.X|.X.if (y|
|00004f30| 79 69 6e 20 3d 3d 20 28 | 46 49 4c 45 20 2a 29 4e |yin == (|FILE *)N|
|00004f40| 55 4c 4c 29 20 7b 0a 58 | 09 09 66 70 72 69 6e 74 |ULL) {.X|..fprint|
|00004f50| 66 28 73 74 64 65 72 72 | 2c 22 43 61 6e 6e 6f 74 |f(stderr|,"Cannot|
|00004f60| 20 77 72 69 74 65 20 74 | 6f 20 74 65 6d 70 20 66 | write t|o temp f|
|00004f70| 69 6c 65 20 25 73 5c 6e | 22 2c 74 6d 70 6e 61 6d |ile %s\n|",tmpnam|
|00004f80| 65 29 3b 0a 58 09 09 65 | 78 69 74 28 31 29 3b 0a |e);.X..e|xit(1);.|
|00004f90| 58 09 7d 0a 58 0a 58 09 | 69 66 20 28 21 70 72 6f |X.}.X.X.|if (!pro|
|00004fa0| 63 65 73 73 5f 66 69 6c | 65 28 69 6e 66 69 6c 65 |cess_fil|e(infile|
|00004fb0| 6e 61 6d 65 29 29 20 7b | 0a 58 09 09 2f 2a 0a 58 |name)) {|.X../*.X|
|00004fc0| 09 09 20 2a 20 53 6f 6d | 65 20 6b 69 6e 64 20 6f |.. * Som|e kind o|
|00004fd0| 66 20 65 72 72 6f 72 20 | 6f 63 63 75 72 72 65 64 |f error |occurred|
|00004fe0| 20 2d 2d 20 75 6e 6c 69 | 6e 6b 0a 58 09 09 20 2a | -- unli|nk.X.. *|
|00004ff0| 20 74 65 6d 70 6f 72 61 | 72 79 20 66 69 6c 65 20 | tempora|ry file |
|00005000| 61 6e 64 20 65 78 69 74 | 2e 0a 58 09 09 20 2a 2f |and exit|..X.. */|
|00005010| 0a 58 09 09 66 63 6c 6f | 73 65 28 79 79 69 6e 29 |.X..fclo|se(yyin)|
|00005020| 3b 0a 58 09 09 75 6e 6c | 69 6e 6b 28 74 6d 70 6e |;.X..unl|ink(tmpn|
|00005030| 61 6d 65 29 3b 0a 58 09 | 09 65 78 69 74 28 31 29 |ame);.X.|.exit(1)|
|00005040| 3b 0a 58 09 7d 0a 58 09 | 2f 2a 0a 58 09 20 2a 20 |;.X.}.X.|/*.X. * |
|00005050| 46 69 6c 65 20 70 72 6f | 63 65 73 73 65 64 20 6f |File pro|cessed o|
|00005060| 6b 61 79 2e 20 20 43 6c | 6f 73 65 20 74 68 65 20 |kay. Cl|ose the |
|00005070| 66 69 6c 65 2c 20 6f 70 | 65 6e 20 69 74 20 61 67 |file, op|en it ag|
|00005080| 61 69 6e 20 66 6f 72 0a | 58 09 20 2a 20 72 65 61 |ain for.|X. * rea|
|00005090| 64 69 6e 67 2c 20 61 6e | 64 20 63 61 6c 6c 20 6c |ding, an|d call l|
|000050a0| 65 78 2f 79 61 63 63 2e | 0a 58 09 20 2a 2f 0a 58 |ex/yacc.|.X. */.X|
|000050b0| 09 66 63 6c 6f 73 65 28 | 79 79 69 6e 29 3b 0a 58 |.fclose(|yyin);.X|
|000050c0| 09 79 79 69 6e 20 3d 20 | 66 6f 70 65 6e 28 74 6d |.yyin = |fopen(tm|
|000050d0| 70 6e 61 6d 65 2c 20 22 | 72 22 29 3b 0a 58 09 79 |pname, "|r");.X.y|
|000050e0| 79 70 61 72 73 65 28 29 | 3b 0a 58 09 2f 2a 0a 58 |yparse()|;.X./*.X|
|000050f0| 09 20 2a 20 41 6c 6c 20 | 64 6f 6e 65 20 2d 2d 20 |. * All |done -- |
|00005100| 75 6e 6c 69 6e 6b 20 74 | 65 6d 70 6f 72 61 72 79 |unlink t|emporary|
|00005110| 20 66 69 6c 65 2e 0a 58 | 09 20 2a 2f 0a 58 09 75 | file..X|. */.X.u|
|00005120| 6e 6c 69 6e 6b 28 74 6d | 70 6e 61 6d 65 29 3b 0a |nlink(tm|pname);.|
|00005130| 58 7d 0a 58 0a 58 2f 2a | 0a 58 20 2a 20 4f 70 65 |X}.X.X/*|.X * Ope|
|00005140| 6e 20 74 68 65 20 6e 61 | 6d 65 64 20 66 69 6c 65 |n the na|med file|
|00005150| 20 61 6e 64 20 63 6f 70 | 79 20 69 74 73 20 63 6f | and cop|y its co|
|00005160| 6e 74 65 6e 74 73 20 69 | 6e 74 6f 20 74 68 65 20 |ntents i|nto the |
|00005170| 74 65 6d 70 6f 72 61 72 | 79 20 66 69 6c 65 2e 0a |temporar|y file..|
|00005180| 58 20 2a 20 49 66 20 77 | 65 20 72 75 6e 20 61 63 |X * If w|e run ac|
|00005190| 72 6f 73 73 20 61 20 23 | 69 6e 63 6c 75 64 65 20 |ross a #|include |
|000051a0| 64 69 72 65 63 74 69 76 | 65 2c 20 72 65 63 75 72 |directiv|e, recur|
|000051b0| 73 65 20 6f 6e 20 74 68 | 65 20 64 65 73 69 72 65 |se on th|e desire|
|000051c0| 64 0a 58 20 2a 20 66 69 | 6c 65 2e 20 20 4e 6f 74 |d.X * fi|le. Not|
|000051d0| 65 20 74 68 61 74 20 2a | 6e 6f 20 63 68 65 63 6b |e that *|no check|
|000051e0| 69 6e 67 20 69 73 20 70 | 65 72 66 6f 72 6d 65 64 |ing is p|erformed|
|000051f0| 2a 20 2d 2d 20 61 20 66 | 69 6c 65 20 63 6f 75 6c |* -- a f|ile coul|
|00005200| 64 2c 0a 58 20 2a 20 66 | 6f 72 20 65 78 61 6d 70 |d,.X * f|or examp|
|00005210| 6c 65 2c 20 69 6e 63 6c | 75 64 65 20 69 74 73 65 |le, incl|ude itse|
|00005220| 6c 66 2e 20 20 52 61 79 | 73 68 61 64 65 20 77 69 |lf. Ray|shade wi|
|00005230| 6c 6c 20 68 61 70 70 69 | 6c 79 20 67 6f 20 6f 6e |ll happi|ly go on|
|00005240| 0a 58 20 2a 20 63 6f 70 | 79 69 6e 67 20 64 61 74 |.X * cop|ying dat|
|00005250| 61 20 69 6e 74 6f 20 74 | 68 65 20 74 65 6d 70 6f |a into t|he tempo|
|00005260| 72 61 72 79 20 66 69 6c | 65 20 75 6e 74 69 6c 20 |rary fil|e until |
|00005270| 69 74 20 72 75 6e 73 20 | 6f 75 74 0a 58 20 2a 20 |it runs |out.X * |
|00005280| 6f 66 20 66 69 6c 65 20 | 70 6f 69 6e 74 65 72 73 |of file |pointers|
|00005290| 20 28 61 6e 20 66 6f 70 | 65 6e 20 77 69 6c 6c 20 | (an fop|en will |
|000052a0| 66 61 69 6c 29 2c 20 6f | 72 20 79 6f 75 20 72 75 |fail), o|r you ru|
|000052b0| 6e 20 6f 75 74 20 6f 66 | 20 64 69 73 6b 20 73 70 |n out of| disk sp|
|000052c0| 61 63 65 2e 2e 2e 0a 58 | 20 2a 2f 0a 58 70 72 6f |ace....X| */.Xpro|
|000052d0| 63 65 73 73 5f 66 69 6c | 65 28 66 69 6c 65 6e 61 |cess_fil|e(filena|
|000052e0| 6d 65 29 0a 58 63 68 61 | 72 20 2a 66 69 6c 65 6e |me).Xcha|r *filen|
|000052f0| 61 6d 65 3b 0a 58 7b 0a | 58 09 46 49 4c 45 20 2a |ame;.X{.|X.FILE *|
|00005300| 66 70 3b 0a 58 09 63 68 | 61 72 20 62 75 66 5b 42 |fp;.X.ch|ar buf[B|
|00005310| 55 46 53 49 5a 5d 2c 20 | 2a 6e 61 6d 65 2c 20 2a |UFSIZ], |*name, *|
|00005320| 6e 70 3b 0a 58 09 65 78 | 74 65 72 6e 20 69 6e 74 |np;.X.ex|tern int|
|00005330| 20 79 79 6c 69 6e 65 6e | 6f 3b 0a 58 0a 58 09 69 | yylinen|o;.X.X.i|
|00005340| 66 20 28 66 69 6c 65 6e | 61 6d 65 20 3d 3d 20 28 |f (filen|ame == (|
|00005350| 63 68 61 72 20 2a 29 4e | 55 4c 4c 29 0a 58 09 09 |char *)N|ULL).X..|
|00005360| 66 70 20 3d 20 73 74 64 | 69 6e 3b 0a 58 09 65 6c |fp = std|in;.X.el|
|00005370| 73 65 20 7b 0a 58 09 09 | 66 70 20 3d 20 66 6f 70 |se {.X..|fp = fop|
|00005380| 65 6e 28 66 69 6c 65 6e | 61 6d 65 2c 20 22 72 22 |en(filen|ame, "r"|
|00005390| 29 3b 0a 58 09 09 69 66 | 20 28 66 70 20 3d 3d 20 |);.X..if| (fp == |
|000053a0| 28 46 49 4c 45 20 2a 29 | 4e 55 4c 4c 29 20 7b 0a |(FILE *)|NULL) {.|
|000053b0| 58 09 09 09 66 70 72 69 | 6e 74 66 28 73 74 64 65 |X...fpri|ntf(stde|
|000053c0| 72 72 2c 22 43 61 6e 6e | 6f 74 20 6f 70 65 6e 20 |rr,"Cann|ot open |
|000053d0| 25 73 20 66 6f 72 20 72 | 65 61 64 69 6e 67 2e 5c |%s for r|eading.\|
|000053e0| 6e 22 2c 66 69 6c 65 6e | 61 6d 65 29 3b 0a 58 09 |n",filen|ame);.X.|
|000053f0| 09 09 72 65 74 75 72 6e | 20 46 41 4c 53 45 3b 0a |..return| FALSE;.|
|00005400| 58 09 09 7d 0a 58 09 7d | 0a 58 0a 58 09 77 68 69 |X..}.X.}|.X.X.whi|
|00005410| 6c 65 28 66 67 65 74 73 | 28 62 75 66 2c 20 42 55 |le(fgets|(buf, BU|
|00005420| 46 53 49 5a 2c 20 66 70 | 29 20 21 3d 20 4e 55 4c |FSIZ, fp|) != NUL|
|00005430| 4c 29 20 7b 0a 58 09 09 | 69 66 20 28 73 74 72 6e |L) {.X..|if (strn|
|00005440| 63 6d 70 28 62 75 66 2c | 20 49 4e 43 4c 55 44 45 |cmp(buf,| INCLUDE|
|00005450| 5f 53 54 52 2c 20 73 74 | 72 6c 65 6e 28 49 4e 43 |_STR, st|rlen(INC|
|00005460| 4c 55 44 45 5f 53 54 52 | 29 29 20 3d 3d 20 30 29 |LUDE_STR|)) == 0)|
|00005470| 20 7b 0a 58 09 09 09 2f | 2a 0a 58 09 09 09 20 2a | {.X.../|*.X... *|
|00005480| 20 47 6f 74 20 61 6e 20 | 22 23 69 6e 63 6c 75 64 | Got an |"#includ|
|00005490| 65 20 22 2e 2e 2e 0a 58 | 09 09 09 20 2a 2f 0a 58 |e "....X|... */.X|
|000054a0| 23 69 66 64 65 66 20 53 | 59 53 56 0a 58 09 09 09 |#ifdef S|YSV.X...|
|000054b0| 6e 61 6d 65 20 3d 20 73 | 74 72 63 68 72 28 62 75 |name = s|trchr(bu|
|000054c0| 66 2c 20 27 22 27 29 3b | 0a 58 09 09 09 6e 70 20 |f, '"');|.X...np |
|000054d0| 3d 20 73 74 72 72 63 68 | 72 28 62 75 66 2c 20 27 |= strrch|r(buf, '|
|000054e0| 22 27 29 3b 0a 58 23 65 | 6c 73 65 0a 58 09 09 09 |"');.X#e|lse.X...|
|000054f0| 6e 61 6d 65 20 3d 20 69 | 6e 64 65 78 28 62 75 66 |name = i|ndex(buf|
|00005500| 2c 20 27 22 27 29 3b 0a | 58 09 09 09 6e 70 20 3d |, '"');.|X...np =|
|00005510| 20 72 69 6e 64 65 78 28 | 62 75 66 2c 20 27 22 27 | rindex(|buf, '"'|
|00005520| 29 3b 0a 58 23 65 6e 64 | 69 66 0a 58 09 09 09 2f |);.X#end|if.X.../|
|00005530| 2a 0a 58 09 09 09 20 2a | 20 47 65 74 20 6e 61 6d |*.X... *| Get nam|
|00005540| 65 20 62 65 74 77 65 65 | 6e 20 71 75 6f 74 65 73 |e betwee|n quotes|
|00005550| 2e 20 20 49 66 20 6e 6f | 20 6f 72 0a 58 09 09 09 |. If no| or.X...|
|00005560| 20 2a 20 6f 6e 65 20 71 | 75 6f 74 65 2c 20 63 6f | * one q|uote, co|
|00005570| 6d 70 6c 61 69 6e 2e 0a | 58 09 09 09 20 2a 2f 0a |mplain..|X... */.|
|00005580| 58 09 09 09 69 66 20 28 | 6e 61 6d 65 20 3d 3d 20 |X...if (|name == |
|00005590| 28 63 68 61 72 20 2a 29 | 30 20 7c 7c 20 6e 61 6d |(char *)|0 || nam|
|000055a0| 65 20 3d 3d 20 6e 70 29 | 20 7b 0a 58 09 09 09 09 |e == np)| {.X....|
|000055b0| 66 70 72 69 6e 74 66 28 | 73 74 64 65 72 72 2c 22 |fprintf(|stderr,"|
|000055c0| 49 6e 76 61 6c 69 64 20 | 69 6e 63 6c 75 64 65 20 |Invalid |include |
|000055d0| 64 69 72 65 63 74 69 76 | 65 20 28 6c 69 6e 65 20 |directiv|e (line |
|000055e0| 25 64 29 5c 6e 22 2c 20 | 79 79 6c 69 6e 65 6e 6f |%d)\n", |yylineno|
|000055f0| 29 3b 0a 58 09 09 09 09 | 72 65 74 75 72 6e 20 46 |);.X....|return F|
|00005600| 41 4c 53 45 3b 0a 58 09 | 09 09 7d 0a 58 09 09 09 |ALSE;.X.|..}.X...|
|00005610| 6e 61 6d 65 2b 2b 3b 0a | 58 09 09 09 2a 6e 70 20 |name++;.|X...*np |
|00005620| 3d 20 28 63 68 61 72 29 | 4e 55 4c 4c 3b 0a 58 09 |= (char)|NULL;.X.|
|00005630| 09 09 69 66 20 28 70 72 | 6f 63 65 73 73 5f 66 69 |..if (pr|ocess_fi|
|00005640| 6c 65 28 6e 61 6d 65 29 | 20 3d 3d 20 46 41 4c 53 |le(name)| == FALS|
|00005650| 45 29 0a 58 09 09 09 09 | 72 65 74 75 72 6e 20 46 |E).X....|return F|
|00005660| 41 4c 53 45 3b 0a 58 09 | 09 7d 20 65 6c 73 65 0a |ALSE;.X.|.} else.|
|00005670| 58 09 09 09 66 70 75 74 | 73 28 62 75 66 2c 20 79 |X...fput|s(buf, y|
|00005680| 79 69 6e 29 3b 0a 58 09 | 7d 0a 58 09 72 65 74 75 |yin);.X.|}.X.retu|
|00005690| 72 6e 20 54 52 55 45 3b | 0a 58 7d 0a 45 4e 44 5f |rn TRUE;|.X}.END_|
|000056a0| 4f 46 5f 46 49 4c 45 0a | 69 66 20 74 65 73 74 20 |OF_FILE.|if test |
|000056b0| 33 33 34 32 20 2d 6e 65 | 20 60 77 63 20 2d 63 20 |3342 -ne| `wc -c |
|000056c0| 3c 27 73 72 63 2f 69 6e | 70 75 74 2e 63 27 60 3b |<'src/in|put.c'`;|
|000056d0| 20 74 68 65 6e 0a 20 20 | 20 20 65 63 68 6f 20 73 | then. | echo s|
|000056e0| 68 61 72 3a 20 5c 22 27 | 73 72 63 2f 69 6e 70 75 |har: \"'|src/inpu|
|000056f0| 74 2e 63 27 5c 22 20 75 | 6e 70 61 63 6b 65 64 20 |t.c'\" u|npacked |
|00005700| 77 69 74 68 20 77 72 6f | 6e 67 20 73 69 7a 65 21 |with wro|ng size!|
|00005710| 0a 66 69 0a 23 20 65 6e | 64 20 6f 66 20 27 73 72 |.fi.# en|d of 'sr|
|00005720| 63 2f 69 6e 70 75 74 2e | 63 27 0a 66 69 0a 69 66 |c/input.|c'.fi.if|
|00005730| 20 74 65 73 74 20 2d 66 | 20 27 73 72 63 2f 6c 69 | test -f| 'src/li|
|00005740| 73 74 2e 63 27 20 2d 61 | 20 22 24 7b 31 7d 22 20 |st.c' -a| "${1}" |
|00005750| 21 3d 20 22 2d 63 22 20 | 3b 20 74 68 65 6e 20 0a |!= "-c" |; then .|
|00005760| 20 20 65 63 68 6f 20 73 | 68 61 72 3a 20 57 69 6c | echo s|har: Wil|
|00005770| 6c 20 6e 6f 74 20 63 6c | 6f 62 62 65 72 20 65 78 |l not cl|obber ex|
|00005780| 69 73 74 69 6e 67 20 66 | 69 6c 65 20 5c 22 27 73 |isting f|ile \"'s|
|00005790| 72 63 2f 6c 69 73 74 2e | 63 27 5c 22 0a 65 6c 73 |rc/list.|c'\".els|
|000057a0| 65 0a 65 63 68 6f 20 73 | 68 61 72 3a 20 45 78 74 |e.echo s|har: Ext|
|000057b0| 72 61 63 74 69 6e 67 20 | 5c 22 27 73 72 63 2f 6c |racting |\"'src/l|
|000057c0| 69 73 74 2e 63 27 5c 22 | 20 5c 28 33 31 38 35 20 |ist.c'\"| \(3185 |
|000057d0| 63 68 61 72 61 63 74 65 | 72 73 5c 29 0a 73 65 64 |characte|rs\).sed|
|000057e0| 20 22 73 2f 5e 58 2f 2f | 22 20 3e 27 73 72 63 2f | "s/^X//|" >'src/|
|000057f0| 6c 69 73 74 2e 63 27 20 | 3c 3c 27 45 4e 44 5f 4f |list.c' |<<'END_O|
|00005800| 46 5f 46 49 4c 45 27 0a | 58 2f 2a 0a 58 20 2a 20 |F_FILE'.|X/*.X * |
|00005810| 6c 69 73 74 2e 63 0a 58 | 20 2a 0a 58 20 2a 20 43 |list.c.X| *.X * C|
|00005820| 6f 70 79 72 69 67 68 74 | 20 28 43 29 20 31 39 38 |opyright| (C) 198|
|00005830| 39 2c 20 43 72 61 69 67 | 20 45 2e 20 4b 6f 6c 62 |9, Craig| E. Kolb|
|00005840| 0a 58 20 2a 0a 58 20 2a | 20 54 68 69 73 20 73 6f |.X *.X *| This so|
|00005850| 66 74 77 61 72 65 20 6d | 61 79 20 62 65 20 66 72 |ftware m|ay be fr|
|00005860| 65 65 6c 79 20 63 6f 70 | 69 65 64 2c 20 6d 6f 64 |eely cop|ied, mod|
|00005870| 69 66 69 65 64 2c 20 61 | 6e 64 20 72 65 64 69 73 |ified, a|nd redis|
|00005880| 74 72 69 62 75 74 65 64 | 2c 0a 58 20 2a 20 70 72 |tributed|,.X * pr|
|00005890| 6f 76 69 64 65 64 20 74 | 68 61 74 20 74 68 69 73 |ovided t|hat this|
|000058a0| 20 63 6f 70 79 72 69 67 | 68 74 20 6e 6f 74 69 63 | copyrig|ht notic|
|000058b0| 65 20 69 73 20 70 72 65 | 73 65 72 76 65 64 20 6f |e is pre|served o|
|000058c0| 6e 20 61 6c 6c 20 63 6f | 70 69 65 73 2e 0a 58 20 |n all co|pies..X |
|000058d0| 2a 0a 58 20 2a 20 54 68 | 65 72 65 20 69 73 20 6e |*.X * Th|ere is n|
|000058e0| 6f 20 77 61 72 72 61 6e | 74 79 20 6f 72 20 6f 74 |o warran|ty or ot|
|000058f0| 68 65 72 20 67 75 61 72 | 61 6e 74 65 65 20 6f 66 |her guar|antee of|
|00005900| 20 66 69 74 6e 65 73 73 | 20 66 6f 72 20 74 68 69 | fitness| for thi|
|00005910| 73 20 73 6f 66 74 77 61 | 72 65 2c 0a 58 20 2a 20 |s softwa|re,.X * |
|00005920| 69 74 20 69 73 20 70 72 | 6f 76 69 64 65 64 20 73 |it is pr|ovided s|
|00005930| 6f 6c 65 6c 79 20 2e 20 | 20 42 75 67 20 72 65 70 |olely . | Bug rep|
|00005940| 6f 72 74 73 20 6f 72 20 | 66 69 78 65 73 20 6d 61 |orts or |fixes ma|
|00005950| 79 20 62 65 20 73 65 6e | 74 0a 58 20 2a 20 74 6f |y be sen|t.X * to|
|00005960| 20 74 68 65 20 61 75 74 | 68 6f 72 2c 20 77 68 6f | the aut|hor, who|
|00005970| 20 6d 61 79 20 6f 72 20 | 6d 61 79 20 6e 6f 74 20 | may or |may not |
|00005980| 61 63 74 20 6f 6e 20 74 | 68 65 6d 20 61 73 20 68 |act on t|hem as h|
|00005990| 65 20 64 65 73 69 72 65 | 73 2e 0a 58 20 2a 0a 58 |e desire|s..X *.X|
|000059a0| 20 2a 20 59 6f 75 20 6d | 61 79 20 6e 6f 74 20 69 | * You m|ay not i|
|000059b0| 6e 63 6c 75 64 65 20 74 | 68 69 73 20 73 6f 66 74 |nclude t|his soft|
|000059c0| 77 61 72 65 20 69 6e 20 | 61 20 70 72 6f 67 72 61 |ware in |a progra|
|000059d0| 6d 20 6f 72 20 6f 74 68 | 65 72 20 73 6f 66 74 77 |m or oth|er softw|
|000059e0| 61 72 65 20 70 72 6f 64 | 75 63 74 0a 58 20 2a 20 |are prod|uct.X * |
|000059f0| 77 69 74 68 6f 75 74 20 | 73 75 70 70 6c 79 69 6e |without |supplyin|
|00005a00| 67 20 74 68 65 20 73 6f | 75 72 63 65 2c 20 6f 72 |g the so|urce, or|
|00005a10| 20 77 69 74 68 6f 75 74 | 20 69 6e 66 6f 72 6d 69 | without| informi|
|00005a20| 6e 67 20 74 68 65 20 65 | 6e 64 2d 75 73 65 72 20 |ng the e|nd-user |
|00005a30| 74 68 61 74 20 74 68 65 | 0a 58 20 2a 20 73 6f 75 |that the|.X * sou|
|00005a40| 72 63 65 20 69 73 20 61 | 76 61 69 6c 61 62 6c 65 |rce is a|vailable|
|00005a50| 20 66 6f 72 20 6e 6f 20 | 65 78 74 72 61 20 63 68 | for no |extra ch|
|00005a60| 61 72 67 65 2e 0a 58 20 | 2a 0a 58 20 2a 20 49 66 |arge..X |*.X * If|
|00005a70| 20 79 6f 75 20 6d 6f 64 | 69 66 79 20 74 68 69 73 | you mod|ify this|
|00005a80| 20 73 6f 66 74 77 61 72 | 65 2c 20 79 6f 75 20 73 | softwar|e, you s|
|00005a90| 68 6f 75 6c 64 20 69 6e | 63 6c 75 64 65 20 61 20 |hould in|clude a |
|00005aa0| 6e 6f 74 69 63 65 20 67 | 69 76 69 6e 67 20 74 68 |notice g|iving th|
|00005ab0| 65 0a 58 20 2a 20 6e 61 | 6d 65 20 6f 66 20 74 68 |e.X * na|me of th|
|00005ac0| 65 20 70 65 72 73 6f 6e | 20 70 65 72 66 6f 72 6d |e person| perform|
|00005ad0| 69 6e 67 20 74 68 65 20 | 6d 6f 64 69 66 69 63 61 |ing the |modifica|
|00005ae0| 74 69 6f 6e 2c 20 74 68 | 65 20 64 61 74 65 20 6f |tion, th|e date o|
|00005af0| 66 20 6d 6f 64 69 66 69 | 63 61 74 69 6f 6e 2c 0a |f modifi|cation,.|
|00005b00| 58 20 2a 20 61 6e 64 20 | 74 68 65 20 72 65 61 73 |X * and |the reas|
|00005b10| 6f 6e 20 66 6f 72 20 73 | 75 63 68 20 6d 6f 64 69 |on for s|uch modi|
|00005b20| 66 69 63 61 74 69 6f 6e | 2e 0a 58 20 2a 0a 58 20 |fication|..X *.X |
|00005b30| 2a 20 24 49 64 3a 20 6c | 69 73 74 2e 63 2c 76 20 |* $Id: l|ist.c,v |
|00005b40| 33 2e 30 20 38 39 2f 31 | 30 2f 32 37 20 30 32 3a |3.0 89/1|0/27 02:|
|00005b50| 30 35 3a 35 34 20 63 72 | 61 69 67 20 45 78 70 20 |05:54 cr|aig Exp |
|00005b60| 24 0a 58 20 2a 0a 58 20 | 2a 20 24 4c 6f 67 3a 09 |$.X *.X |* $Log:.|
|00005b70| 6c 69 73 74 2e 63 2c 76 | 20 24 0a 58 20 2a 20 52 |list.c,v| $.X * R|
|00005b80| 65 76 69 73 69 6f 6e 20 | 33 2e 30 20 20 38 39 2f |evision |3.0 89/|
|00005b90| 31 30 2f 32 37 20 20 30 | 32 3a 30 35 3a 35 34 20 |10/27 0|2:05:54 |
|00005ba0| 20 63 72 61 69 67 0a 58 | 20 2a 20 42 61 73 65 6c | craig.X| * Basel|
|00005bb0| 69 6e 65 20 66 6f 72 20 | 66 69 72 73 74 20 6f 66 |ine for |first of|
|00005bc0| 66 69 63 69 61 6c 20 72 | 65 6c 65 61 73 65 2e 0a |ficial r|elease..|
|00005bd0| 58 20 2a 20 0a 58 20 2a | 2f 0a 58 23 69 6e 63 6c |X * .X *|/.X#incl|
|00005be0| 75 64 65 20 3c 73 74 64 | 69 6f 2e 68 3e 0a 58 23 |ude <std|io.h>.X#|
|00005bf0| 69 6e 63 6c 75 64 65 20 | 22 63 6f 6e 73 74 61 6e |include |"constan|
|00005c00| 74 73 2e 68 22 0a 58 23 | 69 6e 63 6c 75 64 65 20 |ts.h".X#|include |
|00005c10| 22 74 79 70 65 64 65 66 | 73 2e 68 22 0a 58 23 69 |"typedef|s.h".X#i|
|00005c20| 6e 63 6c 75 64 65 20 22 | 66 75 6e 63 64 65 66 73 |nclude "|funcdefs|
|00005c30| 2e 68 22 0a 58 2f 2a 0a | 58 20 2a 20 54 61 6b 65 |.h".X/*.|X * Take|
|00005c40| 20 61 20 6c 69 73 74 20 | 77 68 6f 73 65 20 44 41 | a list |whose DA|
|00005c50| 54 41 20 66 69 65 6c 64 | 20 70 6f 69 6e 74 73 20 |TA field| points |
|00005c60| 74 6f 20 61 20 6c 69 6e | 6b 65 64 20 6c 69 73 74 |to a lin|ked list|
|00005c70| 20 6f 66 20 6f 62 6a 65 | 63 74 73 20 61 6e 64 0a | of obje|cts and.|
|00005c80| 58 20 2a 20 74 75 72 6e | 20 69 74 20 69 6e 74 6f |X * turn| it into|
|00005c90| 20 61 20 4c 69 73 74 2e | 0a 58 20 2a 2f 0a 58 6d | a List.|.X */.Xm|
|00005ca0| 61 6b 65 5f 6c 69 73 74 | 28 6f 62 6a 29 0a 58 4f |ake_list|(obj).XO|
|00005cb0| 62 6a 65 63 74 20 2a 6f | 62 6a 3b 0a 58 7b 0a 58 |bject *o|bj;.X{.X|
|00005cc0| 09 69 6e 74 20 69 3b 0a | 58 09 4c 69 73 74 20 2a |.int i;.|X.List *|
|00005cd0| 6c 69 73 74 3b 0a 58 09 | 65 78 74 65 72 6e 20 4f |list;.X.|extern O|
|00005ce0| 62 6a 4c 69 73 74 20 2a | 66 69 6e 64 5f 62 6f 75 |bjList *|find_bou|
|00005cf0| 6e 64 73 28 29 3b 0a 58 | 0a 58 09 6c 69 73 74 20 |nds();.X|.X.list |
|00005d00| 3d 20 28 4c 69 73 74 20 | 2a 29 4d 61 6c 6c 6f 63 |= (List |*)Malloc|
|00005d10| 28 73 69 7a 65 6f 66 28 | 4c 69 73 74 29 29 3b 0a |(sizeof(|List));.|
|00005d20| 58 09 2f 2a 0a 58 09 20 | 2a 20 46 69 6e 64 20 74 |X./*.X. |* Find t|
|00005d30| 68 65 20 75 6e 62 6f 75 | 6e 64 65 64 20 6f 62 6a |he unbou|nded obj|
|00005d40| 65 63 74 73 20 6f 6e 20 | 74 68 65 20 6c 69 73 74 |ects on |the list|
|00005d50| 20 61 73 20 77 65 6c 6c | 20 61 73 20 74 68 65 0a | as well| as the.|
|00005d60| 58 09 20 2a 20 62 6f 75 | 6e 64 69 6e 67 20 62 6f |X. * bou|nding bo|
|00005d70| 78 20 6f 66 20 74 68 65 | 20 6c 69 73 74 2e 0a 58 |x of the| list..X|
|00005d80| 09 20 2a 2f 0a 58 09 6c | 69 73 74 2d 3e 75 6e 62 |. */.X.l|ist->unb|
|00005d90| 6f 75 6e 64 65 64 20 3d | 20 66 69 6e 64 5f 62 6f |ounded =| find_bo|
|00005da0| 75 6e 64 73 28 28 4f 62 | 6a 4c 69 73 74 20 2a 2a |unds((Ob|jList **|
|00005db0| 29 26 6f 62 6a 2d 3e 64 | 61 74 61 2c 20 6f 62 6a |)&obj->d|ata, obj|
|00005dc0| 2d 3e 62 6f 75 6e 64 73 | 29 3b 0a 58 09 2f 2a 0a |->bounds|);.X./*.|
|00005dd0| 58 09 20 2a 20 54 72 61 | 6e 73 66 6f 72 6d 20 62 |X. * Tra|nsform b|
|00005de0| 6f 75 6e 64 69 6e 67 20 | 62 6f 78 20 69 66 20 6e |ounding |box if n|
|00005df0| 65 63 65 73 73 61 72 79 | 2e 0a 58 09 20 2a 2f 0a |ecessary|..X. */.|
|00005e00| 58 09 69 66 20 28 6f 62 | 6a 2d 3e 74 72 61 6e 73 |X.if (ob|j->trans|
|00005e10| 29 0a 58 09 09 74 72 61 | 6e 73 66 6f 72 6d 5f 62 |).X..tra|nsform_b|
|00005e20| 6f 75 6e 64 73 28 26 6f | 62 6a 2d 3e 74 72 61 6e |ounds(&o|bj->tran|
|00005e30| 73 2d 3e 6f 62 6a 32 77 | 6f 72 6c 64 2c 20 6f 62 |s->obj2w|orld, ob|
|00005e40| 6a 2d 3e 62 6f 75 6e 64 | 73 29 3b 0a 58 09 66 6f |j->bound|s);.X.fo|
|00005e50| 72 20 28 69 20 3d 20 30 | 3b 20 69 20 3c 20 33 3b |r (i = 0|; i < 3;|
|00005e60| 20 69 2b 2b 29 20 7b 0a | 58 09 09 6c 69 73 74 2d | i++) {.|X..list-|
|00005e70| 3e 62 6f 75 6e 64 73 5b | 4c 4f 57 5d 5b 69 5d 20 |>bounds[|LOW][i] |
|00005e80| 3d 20 6f 62 6a 2d 3e 62 | 6f 75 6e 64 73 5b 4c 4f |= obj->b|ounds[LO|
|00005e90| 57 5d 5b 69 5d 3b 0a 58 | 09 09 6c 69 73 74 2d 3e |W][i];.X|..list->|
|00005ea0| 62 6f 75 6e 64 73 5b 48 | 49 47 48 5d 5b 69 5d 20 |bounds[H|IGH][i] |
|00005eb0| 3d 20 6f 62 6a 2d 3e 62 | 6f 75 6e 64 73 5b 48 49 |= obj->b|ounds[HI|
|00005ec0| 47 48 5d 5b 69 5d 3b 0a | 58 09 7d 0a 58 09 2f 2a |GH][i];.|X.}.X./*|
|00005ed0| 0a 58 09 20 2a 20 6f 62 | 6a 2d 3e 64 61 74 61 20 |.X. * ob|j->data |
|00005ee0| 6e 6f 77 20 68 6f 6c 64 | 73 20 6c 69 73 74 20 6f |now hold|s list o|
|00005ef0| 66 20 62 6f 75 6e 64 65 | 64 20 6f 62 6a 65 63 74 |f bounde|d object|
|00005f00| 73 2e 0a 58 09 20 2a 2f | 0a 58 09 6c 69 73 74 2d |s..X. */|.X.list-|
|00005f10| 3e 6c 69 73 74 20 3d 20 | 28 4f 62 6a 4c 69 73 74 |>list = |(ObjList|
|00005f20| 20 2a 29 6f 62 6a 2d 3e | 64 61 74 61 3b 0a 58 09 | *)obj->|data;.X.|
|00005f30| 6f 62 6a 2d 3e 64 61 74 | 61 20 3d 20 28 63 68 61 |obj->dat|a = (cha|
|00005f40| 72 20 2a 29 6c 69 73 74 | 3b 0a 58 7d 0a 58 0a 58 |r *)list|;.X}.X.X|
|00005f50| 2f 2a 0a 58 20 2a 20 49 | 6e 74 65 72 73 65 63 74 |/*.X * I|ntersect|
|00005f60| 20 72 61 79 20 26 20 6c | 69 73 74 20 6f 66 20 6f | ray & l|ist of o|
|00005f70| 62 6a 65 63 74 73 2e 0a | 58 20 2a 2f 0a 58 64 6f |bjects..|X */.Xdo|
|00005f80| 75 62 6c 65 0a 58 69 6e | 74 5f 6c 69 73 74 28 6c |uble.Xin|t_list(l|
|00005f90| 69 73 74 2c 20 73 6f 75 | 72 63 65 2c 20 72 61 79 |ist, sou|rce, ray|
|00005fa0| 2c 20 68 69 74 69 6e 66 | 6f 29 0a 58 4c 69 73 74 |, hitinf|o).XList|
|00005fb0| 20 2a 6c 69 73 74 3b 0a | 58 50 72 69 6d 69 74 69 | *list;.|XPrimiti|
|00005fc0| 76 65 20 2a 73 6f 75 72 | 63 65 3b 0a 58 52 61 79 |ve *sour|ce;.XRay|
|00005fd0| 20 2a 72 61 79 3b 0a 58 | 48 69 74 49 6e 66 6f 20 | *ray;.X|HitInfo |
|00005fe0| 2a 68 69 74 69 6e 66 6f | 3b 0a 58 7b 0a 58 09 72 |*hitinfo|;.X{.X.r|
|00005ff0| 65 67 69 73 74 65 72 20 | 4f 62 6a 4c 69 73 74 20 |egister |ObjList |
|00006000| 2a 6f 62 6a 6c 69 73 74 | 3b 0a 58 09 64 6f 75 62 |*objlist|;.X.doub|
|00006010| 6c 65 20 6f 66 66 73 65 | 74 3b 0a 58 09 48 69 74 |le offse|t;.X.Hit|
|00006020| 49 6e 66 6f 20 68 69 74 | 74 6d 70 3b 0a 58 09 64 |Info hit|tmp;.X.d|
|00006030| 6f 75 62 6c 65 20 64 69 | 73 74 2c 20 6d 69 6e 64 |ouble di|st, mind|
|00006040| 69 73 74 3b 0a 58 09 65 | 78 74 65 72 6e 20 64 6f |ist;.X.e|xtern do|
|00006050| 75 62 6c 65 20 69 6e 74 | 65 72 73 65 63 74 28 29 |uble int|ersect()|
|00006060| 3b 0a 58 0a 58 09 6d 69 | 6e 64 69 73 74 20 3d 20 |;.X.X.mi|ndist = |
|00006070| 46 41 52 5f 41 57 41 59 | 3b 0a 58 09 68 69 74 74 |FAR_AWAY|;.X.hitt|
|00006080| 6d 70 2e 74 6f 74 61 6c | 74 72 61 6e 73 20 3d 20 |mp.total|trans = |
|00006090| 68 69 74 69 6e 66 6f 2d | 3e 74 6f 74 61 6c 74 72 |hitinfo-|>totaltr|
|000060a0| 61 6e 73 3b 0a 58 09 2f | 2a 0a 58 09 20 2a 20 49 |ans;.X./|*.X. * I|
|000060b0| 6e 74 65 72 73 65 63 74 | 20 77 69 74 68 20 75 6e |ntersect| with un|
|000060c0| 62 6f 75 6e 64 65 64 20 | 6f 62 6a 65 63 74 73 2e |bounded |objects.|
|000060d0| 0a 58 09 20 2a 2f 0a 58 | 09 66 6f 72 20 28 6f 62 |.X. */.X|.for (ob|
|000060e0| 6a 6c 69 73 74 20 3d 20 | 6c 69 73 74 2d 3e 75 6e |jlist = |list->un|
|000060f0| 62 6f 75 6e 64 65 64 3b | 20 6f 62 6a 6c 69 73 74 |bounded;| objlist|
|00006100| 20 3b 20 6f 62 6a 6c 69 | 73 74 20 3d 20 6f 62 6a | ; objli|st = obj|
|00006110| 6c 69 73 74 2d 3e 6e 65 | 78 74 29 20 7b 0a 58 09 |list->ne|xt) {.X.|
|00006120| 09 64 69 73 74 20 3d 20 | 69 6e 74 65 72 73 65 63 |.dist = |intersec|
|00006130| 74 28 28 4f 62 6a 65 63 | 74 20 2a 29 6f 62 6a 6c |t((Objec|t *)objl|
|00006140| 69 73 74 2d 3e 64 61 74 | 61 2c 20 73 6f 75 72 63 |ist->dat|a, sourc|
|00006150| 65 2c 20 72 61 79 2c 0a | 58 09 09 09 09 09 26 68 |e, ray,.|X.....&h|
|00006160| 69 74 74 6d 70 29 3b 0a | 58 09 09 69 66 20 28 64 |ittmp);.|X..if (d|
|00006170| 69 73 74 20 3e 20 45 50 | 53 49 4c 4f 4e 20 26 26 |ist > EP|SILON &&|
|00006180| 20 64 69 73 74 20 3c 20 | 6d 69 6e 64 69 73 74 29 | dist < |mindist)|
|00006190| 20 7b 0a 58 09 09 09 6d | 69 6e 64 69 73 74 20 3d | {.X...m|indist =|
|000061a0| 20 64 69 73 74 3b 0a 58 | 09 09 09 2a 68 69 74 69 | dist;.X|...*hiti|
|000061b0| 6e 66 6f 20 3d 20 68 69 | 74 74 6d 70 3b 0a 58 09 |nfo = hi|ttmp;.X.|
|000061c0| 09 7d 0a 58 09 7d 0a 58 | 09 2f 2a 0a 58 09 20 2a |.}.X.}.X|./*.X. *|
|000061d0| 20 43 68 65 63 6b 20 66 | 6f 72 20 69 6e 74 65 72 | Check f|or inter|
|000061e0| 73 65 63 74 69 6f 6e 20 | 77 69 74 68 20 62 6f 75 |section |with bou|
|000061f0| 6e 64 69 6e 67 20 62 6f | 78 2e 0a 58 09 20 2a 2f |nding bo|x..X. */|
|00006200| 0a 58 09 69 66 20 28 4f | 75 74 4f 66 42 6f 75 6e |.X.if (O|utOfBoun|
|00006210| 64 73 28 26 72 61 79 2d | 3e 70 6f 73 2c 20 6c 69 |ds(&ray-|>pos, li|
|00006220| 73 74 2d 3e 62 6f 75 6e | 64 73 29 29 20 7b 0a 58 |st->boun|ds)) {.X|
|00006230| 09 09 6f 66 66 73 65 74 | 20 3d 20 49 6e 74 42 6f |..offset| = IntBo|
|00006240| 75 6e 64 73 28 72 61 79 | 2c 20 6c 69 73 74 2d 3e |unds(ray|, list->|
|00006250| 62 6f 75 6e 64 73 29 3b | 0a 58 09 09 69 66 20 28 |bounds);|.X..if (|
|00006260| 6f 66 66 73 65 74 20 3c | 20 45 50 53 49 4c 4f 4e |offset <| EPSILON|
|00006270| 29 0a 58 09 09 09 2f 2a | 0a 58 09 09 09 20 2a 20 |).X.../*|.X... * |
|00006280| 52 61 79 20 6e 65 76 65 | 72 20 68 69 74 20 6c 69 |Ray neve|r hit li|
|00006290| 73 74 2e 0a 58 09 09 09 | 20 2a 2f 0a 58 09 09 09 |st..X...| */.X...|
|000062a0| 72 65 74 75 72 6e 20 28 | 6d 69 6e 64 69 73 74 20 |return (|mindist |
|000062b0| 3d 3d 20 46 41 52 5f 41 | 57 41 59 20 3f 20 30 2e |== FAR_A|WAY ? 0.|
|000062c0| 20 3a 20 6d 69 6e 64 69 | 73 74 29 3b 0a 58 09 09 | : mindi|st);.X..|
|000062d0| 65 6c 73 65 20 69 66 20 | 28 6d 69 6e 64 69 73 74 |else if |(mindist|
|000062e0| 20 3c 20 6f 66 66 73 65 | 74 29 0a 58 09 09 09 2f | < offse|t).X.../|
|000062f0| 2a 0a 58 09 09 09 20 2a | 20 52 61 79 20 68 69 74 |*.X... *| Ray hit|
|00006300| 20 75 6e 62 6f 75 6e 64 | 65 64 20 6f 62 6a 65 63 | unbound|ed objec|
|00006310| 74 20 63 6c 6f 73 65 72 | 20 74 68 61 6e 20 62 6f |t closer| than bo|
|00006320| 75 6e 64 69 6e 67 20 62 | 6f 78 2e 0a 58 09 09 09 |unding b|ox..X...|
|00006330| 20 2a 2f 0a 58 09 09 09 | 72 65 74 75 72 6e 20 6d | */.X...|return m|
|00006340| 69 6e 64 69 73 74 3b 0a | 58 09 09 2f 2a 0a 58 09 |indist;.|X../*.X.|
|00006350| 09 20 2a 20 45 6c 73 65 | 20 74 68 65 20 72 61 79 |. * Else| the ray|
|00006360| 20 65 6e 74 65 72 73 20 | 6c 69 73 74 2d 73 70 61 | enters |list-spa|
|00006370| 63 65 20 62 65 66 6f 72 | 65 20 69 74 20 68 69 74 |ce befor|e it hit|
|00006380| 73 20 61 6e 0a 58 09 09 | 20 2a 20 75 6e 62 6f 75 |s an.X..| * unbou|
|00006390| 6e 64 65 64 20 6f 62 6a | 65 63 74 2e 0a 58 09 09 |nded obj|ect..X..|
|000063a0| 20 2a 2f 0a 58 09 7d 0a | 58 09 2f 2a 0a 58 09 20 | */.X.}.|X./*.X. |
|000063b0| 2a 20 49 6e 74 65 72 73 | 65 63 74 20 77 69 74 68 |* Inters|ect with|
|000063c0| 20 6f 62 6a 65 63 74 73 | 20 6f 6e 20 6c 69 73 74 | objects| on list|
|000063d0| 2e 0a 58 09 20 2a 2f 0a | 58 09 66 6f 72 20 28 6f |..X. */.|X.for (o|
|000063e0| 62 6a 6c 69 73 74 20 3d | 20 6c 69 73 74 2d 3e 6c |bjlist =| list->l|
|000063f0| 69 73 74 3b 20 6f 62 6a | 6c 69 73 74 20 3b 20 6f |ist; obj|list ; o|
+--------+-------------------------+-------------------------+--------+--------+
Only 25.0 KB of data is shown above.