home *** CD-ROM | disk | FTP | other *** search
open in:
MacOS 8.1
|
Win98
|
DOS
view JSON data
|
view as text
This file was processed as: SHell self-extracting ARchive
(archive/shar).
You can browse this item here: 2215
Confidence | Program | Detection | Match Type | Support
|
---|
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%
| TrID
| E-Mail message (Var. 2)
| 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| 46 72 6f 6d 3a 20 6b 6f | 72 79 40 61 76 61 74 61 |From: ko|ry@avata|
|00000010| 72 2e 61 76 61 74 61 72 | 2e 63 6f 6d 20 28 4b 6f |r.avatar|.com (Ko|
|00000020| 72 79 20 48 61 6d 7a 65 | 68 29 0a 4e 65 77 73 67 |ry Hamze|h).Newsg|
|00000030| 72 6f 75 70 73 3a 20 61 | 6c 74 2e 73 6f 75 72 63 |roups: a|lt.sourc|
|00000040| 65 73 0a 53 75 62 6a 65 | 63 74 3a 20 70 72 74 3a |es.Subje|ct: prt:|
|00000050| 20 61 20 70 61 72 61 6c | 6c 65 6c 20 72 61 79 74 | a paral|lel rayt|
|00000060| 72 61 63 65 72 2e 20 50 | 61 72 74 20 33 20 6f 66 |racer. P|art 3 of|
|00000070| 20 33 2e 0a 4d 65 73 73 | 61 67 65 2d 49 44 3a 20 | 3..Mess|age-ID: |
|00000080| 3c 31 31 31 40 61 76 61 | 74 61 72 2e 61 76 61 74 |<111@ava|tar.avat|
|00000090| 61 72 2e 63 6f 6d 3e 0a | 44 61 74 65 3a 20 36 20 |ar.com>.|Date: 6 |
|000000a0| 44 65 63 20 39 30 20 30 | 33 3a 34 30 3a 32 33 20 |Dec 90 0|3:40:23 |
|000000b0| 47 4d 54 0a 0a 41 72 63 | 68 69 76 65 2d 6e 61 6d |GMT..Arc|hive-nam|
|000000c0| 65 3a 20 70 72 74 2f 50 | 61 72 74 30 33 0a 0a 0a |e: prt/P|art03...|
|000000d0| 23 21 20 2f 62 69 6e 2f | 73 68 0a 23 20 54 68 69 |#! /bin/|sh.# Thi|
|000000e0| 73 20 69 73 20 61 20 73 | 68 65 6c 6c 20 61 72 63 |s is a s|hell arc|
|000000f0| 68 69 76 65 2e 20 20 52 | 65 6d 6f 76 65 20 61 6e |hive. R|emove an|
|00000100| 79 74 68 69 6e 67 20 62 | 65 66 6f 72 65 20 74 68 |ything b|efore th|
|00000110| 69 73 20 6c 69 6e 65 2c | 20 74 68 65 6e 20 75 6e |is line,| then un|
|00000120| 70 61 63 6b 0a 23 20 69 | 74 20 62 79 20 73 61 76 |pack.# i|t by sav|
|00000130| 69 6e 67 20 69 74 20 69 | 6e 74 6f 20 61 20 66 69 |ing it i|nto a fi|
|00000140| 6c 65 20 61 6e 64 20 74 | 79 70 69 6e 67 20 22 73 |le and t|yping "s|
|00000150| 68 20 66 69 6c 65 22 2e | 20 20 54 6f 20 6f 76 65 |h file".| To ove|
|00000160| 72 77 72 69 74 65 20 65 | 78 69 73 74 69 6e 67 0a |rwrite e|xisting.|
|00000170| 23 20 66 69 6c 65 73 2c | 20 74 79 70 65 20 22 73 |# files,| type "s|
|00000180| 68 20 66 69 6c 65 20 2d | 63 22 2e 20 20 59 6f 75 |h file -|c". You|
|00000190| 20 63 61 6e 20 61 6c 73 | 6f 20 66 65 65 64 20 74 | can als|o feed t|
|000001a0| 68 69 73 20 61 73 20 73 | 74 61 6e 64 61 72 64 20 |his as s|tandard |
|000001b0| 69 6e 70 75 74 20 76 69 | 61 0a 23 20 75 6e 73 68 |input vi|a.# unsh|
|000001c0| 61 72 2c 20 6f 72 20 62 | 79 20 74 79 70 69 6e 67 |ar, or b|y typing|
|000001d0| 20 22 73 68 20 3c 66 69 | 6c 65 22 2c 20 65 2e 67 | "sh <fi|le", e.g|
|000001e0| 2e 2e 20 20 49 66 20 74 | 68 69 73 20 61 72 63 68 |.. If t|his arch|
|000001f0| 69 76 65 20 69 73 20 63 | 6f 6d 70 6c 65 74 65 2c |ive is c|omplete,|
|00000200| 20 79 6f 75 0a 23 20 77 | 69 6c 6c 20 73 65 65 20 | you.# w|ill see |
|00000210| 74 68 65 20 66 6f 6c 6c | 6f 77 69 6e 67 20 6d 65 |the foll|owing me|
|00000220| 73 73 61 67 65 20 61 74 | 20 74 68 65 20 65 6e 64 |ssage at| the end|
|00000230| 3a 0a 23 09 09 22 45 6e | 64 20 6f 66 20 61 72 63 |:.#.."En|d of arc|
|00000240| 68 69 76 65 20 33 20 28 | 6f 66 20 33 29 2e 22 0a |hive 3 (|of 3).".|
|00000250| 23 20 43 6f 6e 74 65 6e | 74 73 3a 20 20 69 6e 70 |# Conten|ts: inp|
|00000260| 75 74 2e 63 0a 23 20 57 | 72 61 70 70 65 64 20 62 |ut.c.# W|rapped b|
|00000270| 79 20 6b 6f 72 79 40 61 | 76 61 74 61 72 20 6f 6e |y kory@a|vatar on|
|00000280| 20 57 65 64 20 44 65 63 | 20 20 35 20 31 38 3a 32 | Wed Dec| 5 18:2|
|00000290| 33 3a 32 33 20 31 39 39 | 30 0a 50 41 54 48 3d 2f |3:23 199|0.PATH=/|
|000002a0| 62 69 6e 3a 2f 75 73 72 | 2f 62 69 6e 3a 2f 75 73 |bin:/usr|/bin:/us|
|000002b0| 72 2f 75 63 62 20 3b 20 | 65 78 70 6f 72 74 20 50 |r/ucb ; |export P|
|000002c0| 41 54 48 0a 69 66 20 74 | 65 73 74 20 2d 66 20 27 |ATH.if t|est -f '|
|000002d0| 69 6e 70 75 74 2e 63 27 | 20 2d 61 20 22 24 7b 31 |input.c'| -a "${1|
|000002e0| 7d 22 20 21 3d 20 22 2d | 63 22 20 3b 20 74 68 65 |}" != "-|c" ; the|
|000002f0| 6e 20 0a 20 20 65 63 68 | 6f 20 73 68 61 72 3a 20 |n . ech|o shar: |
|00000300| 57 69 6c 6c 20 6e 6f 74 | 20 63 6c 6f 62 62 65 72 |Will not| clobber|
|00000310| 20 65 78 69 73 74 69 6e | 67 20 66 69 6c 65 20 5c | existin|g file \|
|00000320| 22 27 69 6e 70 75 74 2e | 63 27 5c 22 0a 65 6c 73 |"'input.|c'\".els|
|00000330| 65 0a 65 63 68 6f 20 73 | 68 61 72 3a 20 45 78 74 |e.echo s|har: Ext|
|00000340| 72 61 63 74 69 6e 67 20 | 5c 22 27 69 6e 70 75 74 |racting |\"'input|
|00000350| 2e 63 27 5c 22 20 5c 28 | 31 34 37 37 32 20 63 68 |.c'\" \(|14772 ch|
|00000360| 61 72 61 63 74 65 72 73 | 5c 29 0a 73 65 64 20 22 |aracters|\).sed "|
|00000370| 73 2f 5e 58 2f 2f 22 20 | 3e 27 69 6e 70 75 74 2e |s/^X//" |>'input.|
|00000380| 63 27 20 3c 3c 27 45 4e | 44 5f 4f 46 5f 46 49 4c |c' <<'EN|D_OF_FIL|
|00000390| 45 27 0a 58 0a 58 2f 2a | 0a 58 20 2a 20 69 6e 70 |E'.X.X/*|.X * inp|
|000003a0| 75 74 2e 63 20 2d 20 54 | 68 69 73 20 66 69 6c 65 |ut.c - T|his file|
|000003b0| 73 20 72 65 61 64 73 20 | 69 6e 20 61 6e 64 20 69 |s reads |in and i|
|000003c0| 6e 74 65 72 70 65 72 74 | 73 20 74 68 65 20 69 6e |nterpert|s the in|
|000003d0| 70 75 74 20 66 69 6c 65 | 20 66 6f 72 20 72 74 2e |put file| for rt.|
|000003e0| 0a 58 20 2a 20 0a 58 20 | 2a 20 43 6f 70 79 72 69 |.X * .X |* Copyri|
|000003f0| 67 68 74 20 28 43 29 20 | 31 39 39 30 2c 20 4b 6f |ght (C) |1990, Ko|
|00000400| 72 79 20 48 61 6d 7a 65 | 68 0a 58 20 2a 2f 0a 58 |ry Hamze|h.X */.X|
|00000410| 0a 58 23 69 6e 63 6c 75 | 64 65 20 3c 73 74 64 69 |.X#inclu|de <stdi|
|00000420| 6f 2e 68 3e 0a 58 23 69 | 6e 63 6c 75 64 65 20 3c |o.h>.X#i|nclude <|
|00000430| 6d 61 6c 6c 6f 63 2e 68 | 3e 0a 58 23 69 6e 63 6c |malloc.h|>.X#incl|
|00000440| 75 64 65 20 3c 63 74 79 | 70 65 2e 68 3e 0a 58 23 |ude <cty|pe.h>.X#|
|00000450| 69 6e 63 6c 75 64 65 20 | 22 72 74 2e 68 22 0a 58 |include |"rt.h".X|
|00000460| 23 69 6e 63 6c 75 64 65 | 20 22 65 78 74 65 72 6e |#include| "extern|
|00000470| 73 2e 68 22 0a 58 0a 58 | 69 6e 74 20 20 20 20 20 |s.h".X.X|int |
|00000480| 20 20 20 20 20 20 20 20 | 50 61 72 73 65 5f 66 72 | |Parse_fr|
|00000490| 6f 6d 28 29 2c 20 50 61 | 72 73 65 5f 61 74 28 29 |om(), Pa|rse_at()|
|000004a0| 2c 20 50 61 72 73 65 5f | 75 70 28 29 2c 20 50 61 |, Parse_|up(), Pa|
|000004b0| 72 73 65 5f 61 6e 67 6c | 65 28 29 2c 20 50 61 72 |rse_angl|e(), Par|
|000004c0| 73 65 5f 72 65 73 28 29 | 3b 0a 58 69 6e 74 20 20 |se_res()|;.Xint |
|000004d0| 20 20 20 20 20 20 20 20 | 20 20 20 50 61 72 73 65 | | Parse|
|000004e0| 5f 6c 69 67 68 74 28 29 | 2c 20 50 61 72 73 65 5f |_light()|, Parse_|
|000004f0| 62 6b 67 6e 64 28 29 2c | 20 50 61 72 73 65 5f 73 |bkgnd(),| Parse_s|
|00000500| 75 72 66 61 63 65 28 29 | 2c 20 50 61 72 73 65 5f |urface()|, Parse_|
|00000510| 63 6f 6e 65 28 29 3b 0a | 58 69 6e 74 20 20 20 20 |cone();.|Xint |
|00000520| 20 20 20 20 20 20 20 20 | 20 50 61 72 73 65 5f 73 | | Parse_s|
|00000530| 70 68 65 72 65 28 29 2c | 20 50 61 72 73 65 5f 68 |phere(),| Parse_h|
|00000540| 61 6c 6c 6f 77 5f 73 70 | 68 65 72 65 28 29 2c 20 |allow_sp|here(), |
|00000550| 50 61 72 73 65 5f 70 6f | 6c 79 28 29 2c 20 50 61 |Parse_po|ly(), Pa|
|00000560| 72 73 65 5f 72 69 6e 67 | 28 29 3b 0a 58 69 6e 74 |rse_ring|();.Xint|
|00000570| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 50 61 72 | | Par|
|00000580| 73 65 5f 71 75 61 64 72 | 69 63 28 29 2c 20 50 61 |se_quadr|ic(), Pa|
|00000590| 72 73 65 5f 69 6e 73 74 | 61 6e 63 65 28 29 2c 20 |rse_inst|ance(), |
|000005a0| 50 61 72 73 65 5f 65 6e | 64 5f 69 6e 73 74 61 6e |Parse_en|d_instan|
|000005b0| 63 65 28 29 3b 0a 58 69 | 6e 74 20 20 20 20 20 20 |ce();.Xi|nt |
|000005c0| 20 20 20 20 20 20 20 50 | 61 72 73 65 5f 69 6e 73 | P|arse_ins|
|000005d0| 74 61 6e 63 65 6f 66 28 | 29 3b 0a 58 0a 58 63 68 |tanceof(|);.X.Xch|
|000005e0| 61 72 20 20 20 20 20 20 | 20 20 20 20 20 2a 47 65 |ar | *Ge|
|000005f0| 74 5f 74 6f 6b 65 6e 28 | 29 2c 20 2a 73 74 72 63 |t_token(|), *strc|
|00000600| 68 72 28 29 3b 0a 58 69 | 6e 74 20 20 20 20 20 20 |hr();.Xi|nt |
|00000610| 20 20 20 20 20 20 20 69 | 66 6c 61 67 20 3d 20 30 | i|flag = 0|
|00000620| 3b 0a 58 0a 58 0a 58 73 | 74 72 75 63 74 20 70 61 |;.X.X.Xs|truct pa|
|00000630| 72 73 65 5f 70 72 6f 63 | 73 0a 58 7b 0a 58 09 69 |rse_proc|s.X{.X.i|
|00000640| 6e 74 20 20 20 20 20 20 | 20 20 20 20 20 20 20 28 |nt | (|
|00000650| 2a 70 61 72 73 65 29 20 | 28 29 3b 0a 58 09 63 68 |*parse) |();.X.ch|
|00000660| 61 72 20 20 20 20 20 20 | 20 20 20 20 20 2a 74 6f |ar | *to|
|00000670| 6b 65 6e 3b 0a 58 7d 3b | 0a 58 0a 58 0a 58 46 49 |ken;.X};|.X.X.XFI|
|00000680| 4c 45 20 20 20 20 20 20 | 20 20 20 20 20 2a 69 6e |LE | *in|
|00000690| 5f 66 70 3b 0a 58 69 6e | 74 20 20 20 20 20 20 20 |_fp;.Xin|t |
|000006a0| 20 20 20 20 20 20 6c 69 | 6e 65 3b 0a 58 63 68 61 | li|ne;.Xcha|
|000006b0| 72 20 20 20 20 20 20 20 | 20 20 20 20 20 6c 69 6e |r | lin|
|000006c0| 65 5f 62 75 66 5b 32 35 | 35 5d 2c 20 74 6f 6b 65 |e_buf[25|5], toke|
|000006d0| 6e 5b 33 32 5d 2c 20 2a | 69 6e 66 6f 5f 70 74 72 |n[32], *|info_ptr|
|000006e0| 3b 0a 58 63 68 61 72 20 | 20 20 20 20 20 20 20 20 |;.Xchar | |
|000006f0| 20 20 2a 73 70 20 3d 20 | 22 25 6c 67 20 25 6c 67 | *sp = |"%lg %lg|
|00000700| 20 25 6c 67 20 25 6c 67 | 20 25 6c 67 20 25 6c 67 | %lg %lg| %lg %lg|
|00000710| 20 25 6c 67 20 25 6c 67 | 20 25 6c 67 20 25 6c 67 | %lg %lg| %lg %lg|
|00000720| 20 25 6c 67 20 25 6c 67 | 20 25 6c 67 20 25 6c 67 | %lg %lg| %lg %lg|
|00000730| 20 25 6c 67 20 25 6c 67 | 20 25 6c 67 20 25 6c 67 | %lg %lg| %lg %lg|
|00000740| 20 25 6c 67 22 3b 0a 58 | 0a 58 73 74 72 75 63 74 | %lg";.X|.Xstruct|
|00000750| 20 70 61 72 73 65 5f 70 | 72 6f 63 73 20 74 6f 6b | parse_p|rocs tok|
|00000760| 65 6e 73 5b 4d 41 58 5f | 54 4f 4b 45 4e 53 5d 20 |ens[MAX_|TOKENS] |
|00000770| 3d 0a 58 7b 0a 58 09 7b | 50 61 72 73 65 5f 66 72 |=.X{.X.{|Parse_fr|
|00000780| 6f 6d 2c 20 22 66 72 6f | 6d 22 7d 2c 0a 58 09 7b |om, "fro|m"},.X.{|
|00000790| 50 61 72 73 65 5f 61 74 | 2c 20 22 61 74 22 7d 2c |Parse_at|, "at"},|
|000007a0| 0a 58 09 7b 50 61 72 73 | 65 5f 75 70 2c 20 22 75 |.X.{Pars|e_up, "u|
|000007b0| 70 22 7d 2c 0a 58 09 7b | 50 61 72 73 65 5f 61 6e |p"},.X.{|Parse_an|
|000007c0| 67 6c 65 2c 20 22 61 6e | 67 6c 65 22 7d 2c 0a 58 |gle, "an|gle"},.X|
|000007d0| 09 7b 50 61 72 73 65 5f | 72 65 73 2c 20 22 72 65 |.{Parse_|res, "re|
|000007e0| 73 6f 6c 75 74 69 6f 6e | 22 7d 2c 0a 58 09 7b 50 |solution|"},.X.{P|
|000007f0| 61 72 73 65 5f 6c 69 67 | 68 74 2c 20 22 6c 69 67 |arse_lig|ht, "lig|
|00000800| 68 74 22 7d 2c 0a 58 09 | 7b 50 61 72 73 65 5f 62 |ht"},.X.|{Parse_b|
|00000810| 6b 67 6e 64 2c 20 22 62 | 61 63 6b 67 72 6f 75 6e |kgnd, "b|ackgroun|
|00000820| 64 22 7d 2c 0a 58 09 7b | 50 61 72 73 65 5f 73 75 |d"},.X.{|Parse_su|
|00000830| 72 66 61 63 65 2c 20 22 | 73 75 72 66 61 63 65 22 |rface, "|surface"|
|00000840| 7d 2c 0a 58 09 7b 50 61 | 72 73 65 5f 63 6f 6e 65 |},.X.{Pa|rse_cone|
|00000850| 2c 20 22 63 6f 6e 65 22 | 7d 2c 0a 58 09 7b 50 61 |, "cone"|},.X.{Pa|
|00000860| 72 73 65 5f 73 70 68 65 | 72 65 2c 20 22 73 70 68 |rse_sphe|re, "sph|
|00000870| 65 72 65 22 7d 2c 0a 58 | 09 7b 50 61 72 73 65 5f |ere"},.X|.{Parse_|
|00000880| 68 61 6c 6c 6f 77 5f 73 | 70 68 65 72 65 2c 20 22 |hallow_s|phere, "|
|00000890| 68 73 70 68 65 72 65 22 | 7d 2c 0a 58 09 7b 50 61 |hsphere"|},.X.{Pa|
|000008a0| 72 73 65 5f 70 6f 6c 79 | 2c 20 22 70 6f 6c 79 67 |rse_poly|, "polyg|
|000008b0| 6f 6e 22 7d 2c 0a 58 09 | 7b 50 61 72 73 65 5f 72 |on"},.X.|{Parse_r|
|000008c0| 69 6e 67 2c 20 22 72 69 | 6e 67 22 7d 2c 0a 58 09 |ing, "ri|ng"},.X.|
|000008d0| 7b 50 61 72 73 65 5f 71 | 75 61 64 72 69 63 2c 20 |{Parse_q|uadric, |
|000008e0| 22 71 75 61 64 72 69 63 | 22 7d 2c 0a 58 09 7b 50 |"quadric|"},.X.{P|
|000008f0| 61 72 73 65 5f 69 6e 73 | 74 61 6e 63 65 2c 20 22 |arse_ins|tance, "|
|00000900| 69 6e 73 74 61 6e 63 65 | 22 7d 2c 0a 58 09 7b 50 |instance|"},.X.{P|
|00000910| 61 72 73 65 5f 65 6e 64 | 5f 69 6e 73 74 61 6e 63 |arse_end|_instanc|
|00000920| 65 2c 20 22 65 6e 64 5f | 69 6e 73 74 61 6e 63 65 |e, "end_|instance|
|00000930| 22 7d 2c 0a 58 09 7b 50 | 61 72 73 65 5f 69 6e 73 |"},.X.{P|arse_ins|
|00000940| 74 61 6e 63 65 6f 66 2c | 20 22 69 6e 73 74 61 6e |tanceof,| "instan|
|00000950| 63 65 5f 6f 66 22 7d 0a | 58 7d 3b 0a 58 0a 58 2f |ce_of"}.|X};.X.X/|
|00000960| 2a 0a 58 20 2a 20 52 65 | 61 64 5f 69 6e 70 75 74 |*.X * Re|ad_input|
|00000970| 5f 66 69 6c 65 28 29 0a | 58 20 2a 20 0a 58 20 2a |_file().|X * .X *|
|00000980| 20 52 65 61 64 20 74 68 | 65 20 69 6e 70 75 74 20 | Read th|e input |
|00000990| 66 69 6c 65 20 67 69 76 | 65 6e 20 62 79 20 74 68 |file giv|en by th|
|000009a0| 65 20 75 73 65 72 2e 20 | 49 6e 74 65 72 70 65 72 |e user. |Interper|
|000009b0| 74 20 61 6e 64 20 62 75 | 69 6c 64 20 61 6c 6c 20 |t and bu|ild all |
|000009c0| 6f 66 20 74 68 65 0a 58 | 20 2a 20 72 65 71 75 69 |of the.X| * requi|
|000009d0| 72 65 64 20 73 74 72 75 | 63 74 75 72 65 73 2e 0a |red stru|ctures..|
|000009e0| 58 20 2a 2f 0a 58 0a 58 | 52 65 61 64 5f 69 6e 70 |X */.X.X|Read_inp|
|000009f0| 75 74 5f 66 69 6c 65 28 | 66 69 6c 65 6e 61 6d 65 |ut_file(|filename|
|00000a00| 29 0a 58 63 68 61 72 20 | 20 20 20 20 20 20 20 20 |).Xchar | |
|00000a10| 20 20 2a 66 69 6c 65 6e | 61 6d 65 3b 0a 58 7b 0a | *filen|ame;.X{.|
|00000a20| 58 09 69 6e 74 20 20 20 | 20 20 20 20 20 20 20 20 |X.int | |
|00000a30| 20 20 69 2c 20 72 63 3b | 0a 58 09 63 68 61 72 20 | i, rc;|.X.char |
|00000a40| 20 20 20 20 20 20 20 20 | 20 20 2a 70 3b 0a 58 0a | | *p;.X.|
|00000a50| 58 09 69 66 20 28 66 69 | 6c 65 6e 61 6d 65 29 0a |X.if (fi|lename).|
|00000a60| 58 09 7b 0a 58 09 09 69 | 66 20 28 28 69 6e 5f 66 |X.{.X..i|f ((in_f|
|00000a70| 70 20 3d 20 66 6f 70 65 | 6e 28 69 6e 70 75 74 5f |p = fope|n(input_|
|00000a80| 66 69 6c 65 2c 20 22 72 | 22 29 29 20 3d 3d 20 4e |file, "r|")) == N|
|00000a90| 55 4c 4c 29 0a 58 09 09 | 7b 0a 58 09 09 09 66 70 |ULL).X..|{.X...fp|
|00000aa0| 72 69 6e 74 66 28 73 74 | 64 65 72 72 2c 20 22 25 |rintf(st|derr, "%|
|00000ab0| 73 3a 20 63 61 6e 27 74 | 20 6f 70 65 6e 20 69 6e |s: can't| open in|
|00000ac0| 70 75 74 20 66 69 6c 65 | 20 27 25 73 27 5c 6e 22 |put file| '%s'\n"|
|00000ad0| 2c 0a 58 09 09 09 09 6d | 79 5f 6e 61 6d 65 2c 20 |,.X....m|y_name, |
|00000ae0| 69 6e 70 75 74 5f 66 69 | 6c 65 29 3b 0a 58 09 09 |input_fi|le);.X..|
|00000af0| 09 65 78 69 74 28 31 29 | 3b 0a 58 09 09 7d 0a 58 |.exit(1)|;.X..}.X|
|00000b00| 09 7d 0a 58 09 65 6c 73 | 65 0a 58 09 7b 0a 58 09 |.}.X.els|e.X.{.X.|
|00000b10| 09 69 6e 5f 66 70 20 3d | 20 73 74 64 69 6e 3b 0a |.in_fp =| stdin;.|
|00000b20| 58 09 7d 0a 58 0a 58 09 | 6c 69 6e 65 20 3d 20 31 |X.}.X.X.|line = 1|
|00000b30| 3b 0a 58 0a 58 09 77 68 | 69 6c 65 20 28 66 67 65 |;.X.X.wh|ile (fge|
|00000b40| 74 73 28 6c 69 6e 65 5f | 62 75 66 2c 20 73 69 7a |ts(line_|buf, siz|
|00000b50| 65 6f 66 28 6c 69 6e 65 | 5f 62 75 66 29 2c 20 69 |eof(line|_buf), i|
|00000b60| 6e 5f 66 70 29 29 0a 58 | 09 7b 0a 58 0a 58 09 09 |n_fp)).X|.{.X.X..|
|00000b70| 69 66 20 28 76 65 72 62 | 6f 73 65 29 0a 58 09 09 |if (verb|ose).X..|
|00000b80| 09 66 70 72 69 6e 74 66 | 28 73 74 64 65 72 72 2c |.fprintf|(stderr,|
|00000b90| 20 22 25 73 3a 20 70 61 | 72 73 69 6e 67 20 6c 69 | "%s: pa|rsing li|
|00000ba0| 6e 65 20 25 64 5c 72 22 | 2c 20 6d 79 5f 6e 61 6d |ne %d\r"|, my_nam|
|00000bb0| 65 2c 20 6c 69 6e 65 29 | 3b 0a 58 0a 58 09 09 69 |e, line)|;.X.X..i|
|00000bc0| 66 20 28 6c 69 6e 65 5f | 62 75 66 5b 30 5d 20 3d |f (line_|buf[0] =|
|00000bd0| 3d 20 27 23 27 20 7c 7c | 20 6c 69 6e 65 5f 62 75 |= '#' ||| line_bu|
|00000be0| 66 5b 30 5d 20 3d 3d 20 | 27 5c 6e 27 29 0a 58 09 |f[0] == |'\n').X.|
|00000bf0| 09 7b 0a 58 09 09 09 2b | 2b 6c 69 6e 65 3b 0a 58 |.{.X...+|+line;.X|
|00000c00| 09 09 09 63 6f 6e 74 69 | 6e 75 65 3b 0a 58 09 09 |...conti|nue;.X..|
|00000c10| 7d 0a 58 0a 58 09 09 69 | 66 20 28 28 70 20 3d 20 |}.X.X..i|f ((p = |
|00000c20| 73 74 72 63 68 72 28 6c | 69 6e 65 5f 62 75 66 2c |strchr(l|ine_buf,|
|00000c30| 20 27 5c 6e 27 29 29 20 | 21 3d 20 4e 55 4c 4c 29 | '\n')) |!= NULL)|
|00000c40| 0a 58 09 09 09 2a 70 20 | 3d 20 30 3b 0a 58 0a 58 |.X...*p |= 0;.X.X|
|00000c50| 09 09 69 6e 66 6f 5f 70 | 74 72 20 3d 20 47 65 74 |..info_p|tr = Get|
|00000c60| 5f 74 6f 6b 65 6e 28 6c | 69 6e 65 5f 62 75 66 2c |_token(l|ine_buf,|
|00000c70| 20 74 6f 6b 65 6e 29 3b | 0a 58 0a 58 09 09 66 6f | token);|.X.X..fo|
|00000c80| 72 20 28 69 20 3d 20 30 | 3b 20 69 20 3c 20 4d 41 |r (i = 0|; i < MA|
|00000c90| 58 5f 54 4f 4b 45 4e 53 | 3b 20 69 2b 2b 29 0a 58 |X_TOKENS|; i++).X|
|00000ca0| 09 09 7b 0a 58 09 09 09 | 69 66 20 28 21 73 74 72 |..{.X...|if (!str|
|00000cb0| 63 6d 70 28 74 6f 6b 65 | 6e 73 5b 69 5d 2e 74 6f |cmp(toke|ns[i].to|
|00000cc0| 6b 65 6e 2c 20 74 6f 6b | 65 6e 29 29 0a 58 09 09 |ken, tok|en)).X..|
|00000cd0| 09 09 62 72 65 61 6b 3b | 0a 58 09 09 7d 0a 58 0a |..break;|.X..}.X.|
|00000ce0| 58 0a 58 09 09 69 66 20 | 28 69 20 3d 3d 20 4d 41 |X.X..if |(i == MA|
|00000cf0| 58 5f 54 4f 4b 45 4e 53 | 29 0a 58 09 09 7b 0a 58 |X_TOKENS|).X..{.X|
|00000d00| 09 09 09 66 70 72 69 6e | 74 66 28 73 74 64 65 72 |...fprin|tf(stder|
|00000d10| 72 2c 20 22 25 73 3a 20 | 69 6e 76 61 6c 69 64 20 |r, "%s: |invalid |
|00000d20| 74 6f 6b 65 6e 20 69 6e | 20 6c 69 6e 65 20 25 64 |token in| line %d|
|00000d30| 5c 6e 22 2c 20 6d 79 5f | 6e 61 6d 65 2c 0a 58 09 |\n", my_|name,.X.|
|00000d40| 09 09 09 6c 69 6e 65 29 | 3b 0a 58 09 09 7d 0a 58 |...line)|;.X..}.X|
|00000d50| 09 09 65 6c 73 65 20 69 | 66 20 28 28 2a 74 6f 6b |..else i|f ((*tok|
|00000d60| 65 6e 73 5b 69 5d 2e 70 | 61 72 73 65 29 20 28 29 |ens[i].p|arse) ()|
|00000d70| 20 21 3d 20 30 29 0a 58 | 09 09 7b 0a 58 09 09 09 | != 0).X|..{.X...|
|00000d80| 53 79 6e 74 61 78 5f 65 | 72 72 6f 72 28 29 3b 0a |Syntax_e|rror();.|
|00000d90| 58 09 09 09 65 78 69 74 | 28 31 29 3b 0a 58 09 09 |X...exit|(1);.X..|
|00000da0| 7d 0a 58 09 09 2b 2b 6c | 69 6e 65 3b 0a 58 09 7d |}.X..++l|ine;.X.}|
|00000db0| 0a 58 0a 58 09 69 66 20 | 28 66 69 6c 65 6e 61 6d |.X.X.if |(filenam|
|00000dc0| 65 29 0a 58 09 09 66 63 | 6c 6f 73 65 28 69 6e 5f |e).X..fc|lose(in_|
|00000dd0| 66 70 29 3b 0a 58 0a 58 | 7d 0a 58 0a 58 0a 58 2f |fp);.X.X|}.X.X.X/|
|00000de0| 2a 0a 58 20 2a 20 53 79 | 6e 74 61 78 5f 65 72 72 |*.X * Sy|ntax_err|
|00000df0| 6f 72 28 29 0a 58 20 2a | 20 0a 58 20 2a 20 50 72 |or().X *| .X * Pr|
|00000e00| 65 74 74 79 20 73 65 6c | 66 20 65 78 70 6c 61 6e |etty sel|f explan|
|00000e10| 61 74 6f 72 79 2e 0a 58 | 20 2a 2f 0a 58 0a 58 53 |atory..X| */.X.XS|
|00000e20| 79 6e 74 61 78 5f 65 72 | 72 6f 72 28 29 0a 58 7b |yntax_er|ror().X{|
|00000e30| 0a 58 0a 58 09 66 70 72 | 69 6e 74 66 28 73 74 64 |.X.X.fpr|intf(std|
|00000e40| 65 72 72 2c 20 22 25 73 | 3a 20 73 79 6e 74 61 78 |err, "%s|: syntax|
|00000e50| 20 65 72 72 6f 72 20 6f | 6e 20 6c 69 6e 65 20 25 | error o|n line %|
|00000e60| 64 20 69 6e 20 69 6e 70 | 75 74 20 66 69 6c 65 5c |d in inp|ut file\|
|00000e70| 6e 22 2c 0a 58 09 09 6d | 79 5f 6e 61 6d 65 2c 20 |n",.X..m|y_name, |
|00000e80| 6c 69 6e 65 29 3b 0a 58 | 09 66 63 6c 6f 73 65 28 |line);.X|.fclose(|
|00000e90| 69 6e 5f 66 70 29 3b 0a | 58 09 65 78 69 74 28 31 |in_fp);.|X.exit(1|
|00000ea0| 29 3b 0a 58 7d 0a 58 0a | 58 0a 58 2f 2a 0a 58 20 |);.X}.X.|X.X/*.X |
|00000eb0| 2a 20 47 65 74 5f 74 6f | 6b 65 6e 28 29 0a 58 20 |* Get_to|ken().X |
|00000ec0| 2a 20 0a 58 20 2a 20 47 | 72 61 62 20 74 68 65 20 |* .X * G|rab the |
|00000ed0| 74 6f 6b 65 6e 20 66 72 | 6f 6d 20 74 68 65 20 67 |token fr|om the g|
|00000ee0| 69 76 65 6e 20 6c 69 6e | 65 2e 20 52 65 74 75 72 |iven lin|e. Retur|
|00000ef0| 6e 20 61 20 70 6f 69 6e | 74 65 72 20 74 6f 20 74 |n a poin|ter to t|
|00000f00| 68 65 20 6e 65 78 74 20 | 74 6f 6b 65 6e 20 69 6e |he next |token in|
|00000f10| 20 74 68 65 0a 58 20 2a | 20 6c 69 6e 65 20 62 75 | the.X *| line bu|
|00000f20| 66 66 65 72 2e 0a 58 20 | 2a 2f 0a 58 0a 58 63 68 |ffer..X |*/.X.Xch|
|00000f30| 61 72 20 20 20 20 20 20 | 20 20 20 20 20 2a 0a 58 |ar | *.X|
|00000f40| 47 65 74 5f 74 6f 6b 65 | 6e 28 6c 6e 2c 20 74 6b |Get_toke|n(ln, tk|
|00000f50| 29 0a 58 63 68 61 72 20 | 20 20 20 20 20 20 20 20 |).Xchar | |
|00000f60| 20 20 2a 6c 6e 2c 20 2a | 74 6b 3b 0a 58 7b 0a 58 | *ln, *|tk;.X{.X|
|00000f70| 09 63 68 61 72 20 20 20 | 20 20 20 20 20 20 20 20 |.char | |
|00000f80| 20 63 3b 0a 58 0a 58 09 | 2f 2a 20 73 6b 69 70 20 | c;.X.X.|/* skip |
|00000f90| 6c 65 61 64 69 6e 67 20 | 77 68 69 74 65 20 73 70 |leading |white sp|
|00000fa0| 61 63 65 73 20 2a 2f 0a | 58 0a 58 09 77 68 69 6c |aces */.|X.X.whil|
|00000fb0| 65 20 28 2a 6c 6e 20 26 | 26 20 69 73 73 70 61 63 |e (*ln &|& isspac|
|00000fc0| 65 28 2a 6c 6e 29 29 0a | 58 09 09 2b 2b 6c 6e 3b |e(*ln)).|X..++ln;|
|00000fd0| 0a 58 0a 58 09 64 6f 0a | 58 09 7b 0a 58 09 09 63 |.X.X.do.|X.{.X..c|
|00000fe0| 20 3d 20 2a 6c 6e 2b 2b | 3b 0a 58 09 09 69 66 20 | = *ln++|;.X..if |
|00000ff0| 28 63 20 3d 3d 20 27 20 | 27 20 7c 7c 20 63 20 3d |(c == ' |' || c =|
|00001000| 3d 20 30 29 0a 58 09 09 | 09 62 72 65 61 6b 3b 0a |= 0).X..|.break;.|
|00001010| 58 0a 58 09 09 2a 74 6b | 2b 2b 20 3d 20 63 3b 0a |X.X..*tk|++ = c;.|
|00001020| 58 09 7d 20 77 68 69 6c | 65 20 28 31 29 3b 0a 58 |X.} whil|e (1);.X|
|00001030| 0a 58 09 2a 74 6b 20 3d | 20 30 3b 0a 58 09 72 65 |.X.*tk =| 0;.X.re|
|00001040| 74 75 72 6e 20 28 6c 6e | 29 3b 0a 58 7d 0a 58 0a |turn (ln|);.X}.X.|
|00001050| 58 2f 2a 0a 58 20 2a 20 | 4e 65 78 74 5f 6c 69 6e |X/*.X * |Next_lin|
|00001060| 65 28 29 0a 58 20 2a 20 | 0a 58 20 2a 20 52 65 61 |e().X * |.X * Rea|
|00001070| 64 20 74 68 65 20 6e 65 | 78 74 20 6c 69 6e 65 20 |d the ne|xt line |
|00001080| 66 72 6f 6d 20 74 68 65 | 20 69 6e 70 75 74 20 66 |from the| input f|
|00001090| 69 6c 65 20 61 6e 64 20 | 62 75 6d 70 20 74 68 65 |ile and |bump the|
|000010a0| 20 6c 69 6e 65 20 63 6f | 75 6e 74 65 72 2e 20 43 | line co|unter. C|
|000010b0| 72 6f 61 6b 20 6f 6e 0a | 58 20 2a 20 45 4f 46 2e |roak on.|X * EOF.|
|000010c0| 0a 58 20 2a 2f 0a 58 0a | 58 4e 65 78 74 5f 6c 69 |.X */.X.|XNext_li|
|000010d0| 6e 65 28 29 0a 58 7b 0a | 58 09 2b 2b 6c 69 6e 65 |ne().X{.|X.++line|
|000010e0| 3b 0a 58 09 69 66 20 28 | 21 66 67 65 74 73 28 6c |;.X.if (|!fgets(l|
|000010f0| 69 6e 65 5f 62 75 66 2c | 20 73 69 7a 65 6f 66 28 |ine_buf,| sizeof(|
|00001100| 6c 69 6e 65 5f 62 75 66 | 29 2c 20 69 6e 5f 66 70 |line_buf|), in_fp|
|00001110| 29 29 0a 58 09 7b 0a 58 | 09 09 66 70 72 69 6e 74 |)).X.{.X|..fprint|
|00001120| 66 28 73 74 64 65 72 72 | 2c 20 22 25 73 3a 20 75 |f(stderr|, "%s: u|
|00001130| 6e 65 78 70 65 63 74 65 | 64 20 65 6e 64 2d 6f 66 |nexpecte|d end-of|
|00001140| 2d 66 69 6c 65 5c 6e 22 | 2c 20 6d 79 5f 6e 61 6d |-file\n"|, my_nam|
|00001150| 65 29 3b 0a 58 09 09 65 | 78 69 74 28 31 29 3b 0a |e);.X..e|xit(1);.|
|00001160| 58 09 7d 0a 58 7d 0a 58 | 0a 58 2f 2a 0a 58 20 2a |X.}.X}.X|.X/*.X *|
|00001170| 20 42 61 64 5f 6d 61 6c | 6c 6f 63 28 29 0a 58 20 | Bad_mal|loc().X |
|00001180| 2a 20 0a 58 20 2a 20 4d | 61 6c 6c 6f 63 20 68 61 |* .X * M|alloc ha|
|00001190| 73 20 66 61 69 6c 65 64 | 2e 20 50 72 69 6e 74 20 |s failed|. Print |
|000011a0| 61 6e 20 65 72 72 6f 72 | 20 6d 65 73 73 61 67 65 |an error| message|
|000011b0| 20 6f 6e 20 73 74 64 65 | 72 72 20 61 6e 64 20 65 | on stde|rr and e|
|000011c0| 78 69 74 2e 0a 58 20 2a | 2f 0a 58 0a 58 42 61 64 |xit..X *|/.X.XBad|
|000011d0| 5f 6d 61 6c 6c 6f 63 28 | 29 0a 58 7b 0a 58 0a 58 |_malloc(|).X{.X.X|
|000011e0| 09 66 70 72 69 6e 74 66 | 28 73 74 64 65 72 72 2c |.fprintf|(stderr,|
|000011f0| 20 22 25 73 3a 20 6d 61 | 6c 6c 6f 63 20 66 61 69 | "%s: ma|lloc fai|
|00001200| 6c 65 64 2e 5c 6e 22 2c | 20 6d 79 5f 6e 61 6d 65 |led.\n",| my_name|
|00001210| 29 3b 0a 58 09 65 78 69 | 74 28 31 29 3b 0a 58 7d |);.X.exi|t(1);.X}|
|00001220| 0a 58 0a 58 0a 58 2f 2a | 0a 58 20 2a 20 50 61 72 |.X.X.X/*|.X * Par|
|00001230| 73 65 5f 66 72 6f 6d 28 | 29 0a 58 20 2a 20 0a 58 |se_from(|).X * .X|
|00001240| 20 2a 20 50 61 72 73 65 | 20 74 68 65 20 66 72 6f | * Parse| the fro|
|00001250| 6d 20 74 6f 6b 65 6e 2e | 20 54 68 65 20 66 6f 72 |m token.| The for|
|00001260| 6d 61 74 20 69 73 3a 0a | 58 20 2a 20 0a 58 20 2a |mat is:.|X * .X *|
|00001270| 20 66 72 6f 6d 20 78 20 | 79 20 7a 0a 58 20 2a 20 | from x |y z.X * |
|00001280| 0a 58 20 2a 2f 0a 58 0a | 58 50 61 72 73 65 5f 66 |.X */.X.|XParse_f|
|00001290| 72 6f 6d 28 29 0a 58 7b | 0a 58 0a 58 09 69 66 20 |rom().X{|.X.X.if |
|000012a0| 28 73 73 63 61 6e 66 28 | 69 6e 66 6f 5f 70 74 72 |(sscanf(|info_ptr|
|000012b0| 2c 20 22 25 6c 67 20 25 | 6c 67 20 25 6c 67 22 2c |, "%lg %|lg %lg",|
|000012c0| 20 26 76 69 65 77 2e 66 | 72 6f 6d 2e 78 2c 20 26 | &view.f|rom.x, &|
|000012d0| 76 69 65 77 2e 66 72 6f | 6d 2e 79 2c 0a 58 09 09 |view.fro|m.y,.X..|
|000012e0| 20 20 20 26 76 69 65 77 | 2e 66 72 6f 6d 2e 7a 29 | &view|.from.z)|
|000012f0| 20 21 3d 20 33 29 0a 58 | 09 09 72 65 74 75 72 6e | != 3).X|..return|
|00001300| 20 28 31 29 3b 0a 58 09 | 65 6c 73 65 0a 58 09 09 | (1);.X.|else.X..|
|00001310| 72 65 74 75 72 6e 20 28 | 30 29 3b 0a 58 7d 0a 58 |return (|0);.X}.X|
|00001320| 0a 58 2f 2a 0a 58 20 2a | 20 50 61 72 73 65 5f 61 |.X/*.X *| Parse_a|
|00001330| 74 28 29 0a 58 20 2a 20 | 0a 58 20 2a 20 50 61 72 |t().X * |.X * Par|
|00001340| 73 65 20 74 68 65 20 61 | 74 20 74 6f 6b 65 6e 2e |se the a|t token.|
|00001350| 20 54 68 65 20 66 6f 72 | 6d 61 74 20 69 73 3a 0a | The for|mat is:.|
|00001360| 58 20 2a 20 0a 58 20 2a | 20 61 74 20 78 20 79 20 |X * .X *| at x y |
|00001370| 7a 0a 58 20 2a 20 0a 58 | 20 2a 2f 0a 58 0a 58 50 |z.X * .X| */.X.XP|
|00001380| 61 72 73 65 5f 61 74 28 | 29 0a 58 7b 0a 58 0a 58 |arse_at(|).X{.X.X|
|00001390| 09 69 66 20 28 73 73 63 | 61 6e 66 28 69 6e 66 6f |.if (ssc|anf(info|
|000013a0| 5f 70 74 72 2c 20 22 25 | 6c 67 20 25 6c 67 20 25 |_ptr, "%|lg %lg %|
|000013b0| 6c 67 22 2c 20 26 76 69 | 65 77 2e 6c 6f 6f 6b 5f |lg", &vi|ew.look_|
|000013c0| 61 74 2e 78 2c 20 26 76 | 69 65 77 2e 6c 6f 6f 6b |at.x, &v|iew.look|
|000013d0| 5f 61 74 2e 79 2c 0a 58 | 09 09 20 20 20 26 76 69 |_at.y,.X|.. &vi|
|000013e0| 65 77 2e 6c 6f 6f 6b 5f | 61 74 2e 7a 29 20 21 3d |ew.look_|at.z) !=|
|000013f0| 20 33 29 0a 58 09 09 72 | 65 74 75 72 6e 20 28 31 | 3).X..r|eturn (1|
|00001400| 29 3b 0a 58 09 65 6c 73 | 65 0a 58 09 09 72 65 74 |);.X.els|e.X..ret|
|00001410| 75 72 6e 20 28 30 29 3b | 0a 58 7d 0a 58 0a 58 0a |urn (0);|.X}.X.X.|
|00001420| 58 2f 2a 0a 58 20 2a 20 | 50 61 72 73 65 5f 75 70 |X/*.X * |Parse_up|
|00001430| 28 29 0a 58 20 2a 20 0a | 58 20 2a 20 50 61 72 73 |().X * .|X * Pars|
|00001440| 65 20 74 68 65 20 75 70 | 20 74 6f 6b 65 6e 2e 20 |e the up| token. |
|00001450| 54 68 65 20 66 6f 72 6d | 61 74 20 69 73 3a 0a 58 |The form|at is:.X|
|00001460| 20 2a 20 0a 58 20 2a 20 | 75 70 20 78 20 79 20 7a | * .X * |up x y z|
|00001470| 0a 58 20 2a 20 0a 58 20 | 2a 2f 0a 58 0a 58 50 61 |.X * .X |*/.X.XPa|
|00001480| 72 73 65 5f 75 70 28 29 | 0a 58 7b 0a 58 0a 58 09 |rse_up()|.X{.X.X.|
|00001490| 69 66 20 28 73 73 63 61 | 6e 66 28 69 6e 66 6f 5f |if (ssca|nf(info_|
|000014a0| 70 74 72 2c 20 22 25 6c | 67 20 25 6c 67 20 25 6c |ptr, "%l|g %lg %l|
|000014b0| 67 22 2c 20 26 76 69 65 | 77 2e 75 70 2e 78 2c 20 |g", &vie|w.up.x, |
|000014c0| 26 76 69 65 77 2e 75 70 | 2e 79 2c 0a 58 09 09 20 |&view.up|.y,.X.. |
|000014d0| 20 20 26 76 69 65 77 2e | 75 70 2e 7a 29 20 21 3d | &view.|up.z) !=|
|000014e0| 20 33 29 0a 58 09 09 72 | 65 74 75 72 6e 20 28 31 | 3).X..r|eturn (1|
|000014f0| 29 3b 0a 58 09 65 6c 73 | 65 0a 58 09 09 72 65 74 |);.X.els|e.X..ret|
|00001500| 75 72 6e 20 28 30 29 3b | 0a 58 7d 0a 58 0a 58 2f |urn (0);|.X}.X.X/|
|00001510| 2a 0a 58 20 2a 20 50 61 | 72 73 65 5f 61 6e 67 6c |*.X * Pa|rse_angl|
|00001520| 65 28 29 0a 58 20 2a 20 | 0a 58 20 2a 20 50 61 72 |e().X * |.X * Par|
|00001530| 73 65 20 74 68 65 20 61 | 6e 67 6c 65 20 74 6f 6b |se the a|ngle tok|
|00001540| 65 6e 2e 20 54 68 65 20 | 66 6f 72 6d 61 74 20 69 |en. The |format i|
|00001550| 73 3a 0a 58 20 2a 20 0a | 58 20 2a 20 61 6e 67 6c |s:.X * .|X * angl|
|00001560| 65 20 66 6f 76 0a 58 20 | 2a 20 0a 58 20 2a 2f 0a |e fov.X |* .X */.|
|00001570| 58 0a 58 50 61 72 73 65 | 5f 61 6e 67 6c 65 28 29 |X.XParse|_angle()|
|00001580| 0a 58 7b 0a 58 0a 58 09 | 69 66 20 28 73 73 63 61 |.X{.X.X.|if (ssca|
|00001590| 6e 66 28 69 6e 66 6f 5f | 70 74 72 2c 20 22 25 6c |nf(info_|ptr, "%l|
|000015a0| 67 22 2c 20 26 76 69 65 | 77 2e 61 6e 67 6c 65 29 |g", &vie|w.angle)|
|000015b0| 20 21 3d 20 31 29 0a 58 | 09 09 72 65 74 75 72 6e | != 1).X|..return|
|000015c0| 20 28 31 29 3b 0a 58 09 | 65 6c 73 65 0a 58 09 09 | (1);.X.|else.X..|
|000015d0| 72 65 74 75 72 6e 20 28 | 30 29 3b 0a 58 7d 0a 58 |return (|0);.X}.X|
|000015e0| 0a 58 0a 58 2f 2a 0a 58 | 20 2a 20 50 61 72 73 65 |.X.X/*.X| * Parse|
|000015f0| 5f 72 65 73 28 29 0a 58 | 20 2a 20 0a 58 20 2a 20 |_res().X| * .X * |
|00001600| 50 61 72 73 65 20 74 68 | 65 20 72 65 73 6f 6c 75 |Parse th|e resolu|
|00001610| 74 69 6f 6e 20 74 6f 6b | 65 6e 2e 20 54 68 65 20 |tion tok|en. The |
|00001620| 66 6f 72 6d 61 74 20 69 | 73 3a 0a 58 20 2a 20 0a |format i|s:.X * .|
|00001630| 58 20 2a 20 72 65 73 6f | 6c 75 74 69 6f 6e 20 78 |X * reso|lution x|
|00001640| 5f 72 65 73 20 79 5f 72 | 65 73 0a 58 20 2a 20 0a |_res y_r|es.X * .|
|00001650| 58 20 2a 2f 0a 58 0a 58 | 50 61 72 73 65 5f 72 65 |X */.X.X|Parse_re|
|00001660| 73 28 29 0a 58 7b 0a 58 | 0a 58 09 69 66 20 28 73 |s().X{.X|.X.if (s|
|00001670| 73 63 61 6e 66 28 69 6e | 66 6f 5f 70 74 72 2c 20 |scanf(in|fo_ptr, |
|00001680| 22 25 64 20 25 64 22 2c | 20 26 76 69 65 77 2e 78 |"%d %d",| &view.x|
|00001690| 5f 72 65 73 2c 20 26 76 | 69 65 77 2e 79 5f 72 65 |_res, &v|iew.y_re|
|000016a0| 73 29 20 21 3d 20 32 29 | 0a 58 09 09 72 65 74 75 |s) != 2)|.X..retu|
|000016b0| 72 6e 20 28 31 29 3b 0a | 58 09 65 6c 73 65 0a 58 |rn (1);.|X.else.X|
|000016c0| 09 09 72 65 74 75 72 6e | 20 28 30 29 3b 0a 58 7d |..return| (0);.X}|
|000016d0| 0a 58 0a 58 0a 58 0a 58 | 0a 58 2f 2a 0a 58 20 2a |.X.X.X.X|.X/*.X *|
|000016e0| 20 50 61 72 73 65 5f 6c | 69 67 68 74 28 29 0a 58 | Parse_l|ight().X|
|000016f0| 20 2a 20 0a 58 20 2a 20 | 50 61 72 73 65 20 74 68 | * .X * |Parse th|
|00001700| 65 20 70 6f 73 69 74 69 | 6f 6e 61 6c 20 6c 69 67 |e positi|onal lig|
|00001710| 68 74 20 74 6f 6b 65 6e | 2e 20 54 68 65 20 66 6f |ht token|. The fo|
|00001720| 72 6d 61 74 20 69 73 3a | 0a 58 20 2a 20 0a 58 20 |rmat is:|.X * .X |
|00001730| 2a 20 6c 20 78 20 79 20 | 7a 0a 58 20 2a 20 0a 58 |* l x y |z.X * .X|
|00001740| 20 2a 2f 0a 58 0a 58 50 | 61 72 73 65 5f 6c 69 67 | */.X.XP|arse_lig|
|00001750| 68 74 28 29 0a 58 7b 0a | 58 09 4c 49 47 48 54 20 |ht().X{.|X.LIGHT |
|00001760| 20 20 20 20 20 20 20 20 | 20 2a 6c 3b 0a 58 0a 58 | | *l;.X.X|
|00001770| 09 69 66 20 28 6e 6c 69 | 67 68 74 73 20 3d 3d 20 |.if (nli|ghts == |
|00001780| 4d 41 58 5f 4c 49 47 48 | 54 53 29 0a 58 09 7b 0a |MAX_LIGH|TS).X.{.|
|00001790| 58 09 09 66 70 72 69 6e | 74 66 28 73 74 64 65 72 |X..fprin|tf(stder|
|000017a0| 72 2c 20 22 25 73 3a 20 | 74 6f 6f 20 6d 61 6e 79 |r, "%s: |too many|
|000017b0| 20 6c 69 67 68 74 20 73 | 6f 75 72 63 65 73 20 64 | light s|ources d|
|000017c0| 65 66 69 6e 65 64 5c 6e | 22 2c 20 6d 79 5f 6e 61 |efined\n|", my_na|
|000017d0| 6d 65 29 3b 0a 58 09 09 | 72 65 74 75 72 6e 20 28 |me);.X..|return (|
|000017e0| 31 29 3b 0a 58 09 7d 0a | 58 0a 58 09 69 66 20 28 |1);.X.}.|X.X.if (|
|000017f0| 28 6c 20 3d 20 28 4c 49 | 47 48 54 20 2a 29 20 63 |(l = (LI|GHT *) c|
|00001800| 61 6c 6c 6f 63 28 31 2c | 20 73 69 7a 65 6f 66 28 |alloc(1,| sizeof(|
|00001810| 4c 49 47 48 54 29 29 29 | 20 3d 3d 20 4e 55 4c 4c |LIGHT)))| == NULL|
|00001820| 29 0a 58 09 09 42 61 64 | 5f 6d 61 6c 6c 6f 63 28 |).X..Bad|_malloc(|
|00001830| 29 3b 0a 58 0a 58 09 69 | 66 20 28 73 73 63 61 6e |);.X.X.i|f (sscan|
|00001840| 66 28 69 6e 66 6f 5f 70 | 74 72 2c 20 22 25 6c 67 |f(info_p|tr, "%lg|
|00001850| 20 25 6c 67 20 25 6c 67 | 22 2c 20 26 6c 2d 3e 70 | %lg %lg|", &l->p|
|00001860| 6f 73 2e 78 2c 20 26 6c | 2d 3e 70 6f 73 2e 79 2c |os.x, &l|->pos.y,|
|00001870| 20 26 6c 2d 3e 70 6f 73 | 2e 7a 29 20 21 3d 20 33 | &l->pos|.z) != 3|
|00001880| 29 0a 58 09 09 72 65 74 | 75 72 6e 20 28 31 29 3b |).X..ret|urn (1);|
|00001890| 0a 58 0a 58 09 6c 69 67 | 68 74 73 5b 6e 6c 69 67 |.X.X.lig|hts[nlig|
|000018a0| 68 74 73 2b 2b 5d 20 3d | 20 6c 3b 0a 58 09 72 65 |hts++] =| l;.X.re|
|000018b0| 74 75 72 6e 20 28 30 29 | 3b 0a 58 7d 0a 58 0a 58 |turn (0)|;.X}.X.X|
|000018c0| 0a 58 2f 2a 0a 58 20 2a | 20 50 61 72 73 65 5f 62 |.X/*.X *| Parse_b|
|000018d0| 6b 67 6e 64 28 29 0a 58 | 20 2a 20 0a 58 20 2a 20 |kgnd().X| * .X * |
|000018e0| 50 61 72 73 65 20 74 68 | 65 20 62 61 63 6b 67 72 |Parse th|e backgr|
|000018f0| 6f 75 6e 64 20 74 6f 6b | 65 6e 2e 20 54 68 65 20 |ound tok|en. The |
|00001900| 66 6f 72 6d 61 74 20 69 | 73 3a 0a 58 20 2a 20 0a |format i|s:.X * .|
|00001910| 58 20 2a 20 62 20 78 20 | 79 20 7a 20 63 0a 58 20 |X * b x |y z c.X |
|00001920| 2a 20 0a 58 20 2a 2f 0a | 58 0a 58 50 61 72 73 65 |* .X */.|X.XParse|
|00001930| 5f 62 6b 67 6e 64 28 29 | 0a 58 7b 0a 58 0a 58 09 |_bkgnd()|.X{.X.X.|
|00001940| 69 66 20 28 73 73 63 61 | 6e 66 28 69 6e 66 6f 5f |if (ssca|nf(info_|
|00001950| 70 74 72 2c 20 22 25 6c | 67 20 25 6c 67 20 25 6c |ptr, "%l|g %lg %l|
|00001960| 67 20 25 63 22 2c 20 26 | 62 6b 67 6e 64 2e 63 6f |g %c", &|bkgnd.co|
|00001970| 6c 2e 72 2c 20 26 62 6b | 67 6e 64 2e 63 6f 6c 2e |l.r, &bk|gnd.col.|
|00001980| 67 2c 0a 58 09 09 20 20 | 20 26 62 6b 67 6e 64 2e |g,.X.. | &bkgnd.|
|00001990| 63 6f 6c 2e 62 2c 20 26 | 62 6b 67 6e 64 2e 63 75 |col.b, &|bkgnd.cu|
|000019a0| 65 29 20 21 3d 20 34 29 | 0a 58 09 09 72 65 74 75 |e) != 4)|.X..retu|
|000019b0| 72 6e 20 28 31 29 3b 0a | 58 0a 58 09 69 66 20 28 |rn (1);.|X.X.if (|
|000019c0| 62 6b 67 6e 64 2e 63 75 | 65 20 21 3d 20 27 6e 27 |bkgnd.cu|e != 'n'|
|000019d0| 20 26 26 20 62 6b 67 6e | 64 2e 63 75 65 20 21 3d | && bkgn|d.cue !=|
|000019e0| 20 27 78 27 20 26 26 20 | 62 6b 67 6e 64 2e 63 75 | 'x' && |bkgnd.cu|
|000019f0| 65 20 21 3d 20 27 79 27 | 20 26 26 0a 58 09 20 20 |e != 'y'| &&.X. |
|00001a00| 20 20 62 6b 67 6e 64 2e | 63 75 65 20 21 3d 20 27 | bkgnd.|cue != '|
|00001a10| 7a 27 29 0a 58 09 09 72 | 65 74 75 72 6e 20 28 31 |z').X..r|eturn (1|
|00001a20| 29 3b 0a 58 09 65 6c 73 | 65 0a 58 09 09 72 65 74 |);.X.els|e.X..ret|
|00001a30| 75 72 6e 20 28 30 29 3b | 0a 58 7d 0a 58 0a 58 0a |urn (0);|.X}.X.X.|
|00001a40| 58 2f 2a 0a 58 20 2a 20 | 50 61 72 73 65 5f 73 75 |X/*.X * |Parse_su|
|00001a50| 72 66 61 63 65 28 29 0a | 58 20 2a 20 0a 58 20 2a |rface().|X * .X *|
|00001a60| 20 54 68 69 73 20 6f 6e | 65 20 69 73 20 61 20 62 | This on|e is a b|
|00001a70| 69 67 67 79 2e 20 50 61 | 72 73 65 20 74 68 65 20 |iggy. Pa|rse the |
|00001a80| 66 6f 75 72 20 6d 69 6c | 6c 69 6f 6e 20 70 61 72 |four mil|lion par|
|00001a90| 61 6d 65 74 65 72 73 20 | 77 69 6c 6c 20 66 6f 6c |ameters |will fol|
|00001aa0| 6c 6f 77 20 74 68 65 0a | 58 20 2a 20 73 75 72 66 |low the.|X * surf|
|00001ab0| 61 63 65 20 69 6e 66 6f | 20 74 6f 6b 65 6e 2e 0a |ace info| token..|
|00001ac0| 58 20 2a 2f 0a 58 0a 58 | 50 61 72 73 65 5f 73 75 |X */.X.X|Parse_su|
|00001ad0| 72 66 61 63 65 28 29 0a | 58 7b 0a 58 09 53 55 52 |rface().|X{.X.SUR|
|00001ae0| 46 41 43 45 20 20 20 20 | 20 20 20 20 2a 73 3b 0a |FACE | *s;.|
|00001af0| 58 0a 58 09 69 66 20 28 | 28 73 20 3d 20 28 53 55 |X.X.if (|(s = (SU|
|00001b00| 52 46 41 43 45 20 2a 29 | 20 6d 61 6c 6c 6f 63 28 |RFACE *)| malloc(|
|00001b10| 73 69 7a 65 6f 66 28 53 | 55 52 46 41 43 45 29 29 |sizeof(S|URFACE))|
|00001b20| 29 20 3d 3d 20 4e 55 4c | 4c 29 0a 58 09 09 42 61 |) == NUL|L).X..Ba|
|00001b30| 64 5f 6d 61 6c 6c 6f 63 | 28 29 3b 0a 58 0a 58 09 |d_malloc|();.X.X.|
|00001b40| 69 66 20 28 73 73 63 61 | 6e 66 28 69 6e 66 6f 5f |if (ssca|nf(info_|
|00001b50| 70 74 72 2c 20 73 70 2c | 0a 58 09 20 20 20 26 73 |ptr, sp,|.X. &s|
|00001b60| 2d 3e 63 5f 72 65 66 6c | 65 63 74 2e 72 2c 20 26 |->c_refl|ect.r, &|
|00001b70| 73 2d 3e 63 5f 72 65 66 | 6c 65 63 74 2e 67 2c 20 |s->c_ref|lect.g, |
|00001b80| 26 73 2d 3e 63 5f 72 65 | 66 6c 65 63 74 2e 62 2c |&s->c_re|flect.b,|
|00001b90| 20 26 73 2d 3e 70 5f 72 | 65 66 6c 65 63 74 2c 0a | &s->p_r|eflect,.|
|00001ba0| 58 09 20 20 20 26 73 2d | 3e 63 5f 72 65 66 72 61 |X. &s-|>c_refra|
|00001bb0| 63 74 2e 72 2c 20 26 73 | 2d 3e 63 5f 72 65 66 72 |ct.r, &s|->c_refr|
|00001bc0| 61 63 74 2e 67 2c 20 26 | 73 2d 3e 63 5f 72 65 66 |act.g, &|s->c_ref|
|00001bd0| 72 61 63 74 2e 62 2c 20 | 26 73 2d 3e 70 5f 72 65 |ract.b, |&s->p_re|
|00001be0| 66 72 61 63 74 2c 0a 58 | 09 09 20 20 20 26 73 2d |fract,.X|.. &s-|
|00001bf0| 3e 63 5f 61 6d 62 69 65 | 6e 74 2e 72 2c 20 26 73 |>c_ambie|nt.r, &s|
|00001c00| 2d 3e 63 5f 61 6d 62 69 | 65 6e 74 2e 67 2c 20 26 |->c_ambi|ent.g, &|
|00001c10| 73 2d 3e 63 5f 61 6d 62 | 69 65 6e 74 2e 62 2c 0a |s->c_amb|ient.b,.|
|00001c20| 58 09 09 20 20 20 26 73 | 2d 3e 63 5f 64 69 66 66 |X.. &s|->c_diff|
|00001c30| 75 73 65 2e 72 2c 20 26 | 73 2d 3e 63 5f 64 69 66 |use.r, &|s->c_dif|
|00001c40| 66 75 73 65 2e 67 2c 20 | 26 73 2d 3e 63 5f 64 69 |fuse.g, |&s->c_di|
|00001c50| 66 66 75 73 65 2e 62 2c | 0a 58 09 09 20 20 20 26 |ffuse.b,|.X.. &|
|00001c60| 73 2d 3e 63 5f 73 70 65 | 63 75 6c 61 72 2e 72 2c |s->c_spe|cular.r,|
|00001c70| 20 26 73 2d 3e 63 5f 73 | 70 65 63 75 6c 61 72 2e | &s->c_s|pecular.|
|00001c80| 67 2c 20 26 73 2d 3e 63 | 5f 73 70 65 63 75 6c 61 |g, &s->c|_specula|
|00001c90| 72 2e 62 2c 0a 58 09 09 | 20 20 20 26 73 2d 3e 73 |r.b,.X..| &s->s|
|00001ca0| 70 65 63 5f 77 69 64 74 | 68 2c 20 26 73 2d 3e 69 |pec_widt|h, &s->i|
|00001cb0| 5f 72 65 66 72 61 63 74 | 69 6f 6e 29 20 21 3d 20 |_refract|ion) != |
|00001cc0| 31 39 29 0a 58 09 09 72 | 65 74 75 72 6e 20 28 31 |19).X..r|eturn (1|
|00001cd0| 29 3b 0a 58 0a 58 09 2f | 2a 0a 58 09 20 2a 20 49 |);.X.X./|*.X. * I|
|00001ce0| 66 20 77 65 20 61 72 65 | 20 69 6e 20 74 68 65 20 |f we are| in the |
|00001cf0| 6d 69 64 64 6c 65 20 6f | 66 20 61 6e 20 69 6e 73 |middle o|f an ins|
|00001d00| 74 61 6e 63 65 2c 20 74 | 68 65 6e 20 6a 73 75 74 |tance, t|hen jsut|
|00001d10| 20 6c 6f 67 20 69 74 2e | 0a 58 09 20 2a 2f 0a 58 | log it.|.X. */.X|
|00001d20| 0a 58 09 69 66 20 28 69 | 66 6c 61 67 29 0a 58 09 |.X.if (i|flag).X.|
|00001d30| 09 41 64 64 5f 74 6f 5f | 69 6c 69 73 74 28 73 2c |.Add_to_|ilist(s,|
|00001d40| 20 49 5f 53 55 52 46 41 | 43 45 2c 20 30 29 3b 0a | I_SURFA|CE, 0);.|
|00001d50| 58 09 65 6c 73 65 0a 58 | 09 09 63 75 72 5f 73 75 |X.else.X|..cur_su|
|00001d60| 72 66 61 63 65 20 3d 20 | 73 3b 0a 58 09 72 65 74 |rface = |s;.X.ret|
|00001d70| 75 72 6e 20 28 30 29 3b | 0a 58 7d 0a 58 0a 58 0a |urn (0);|.X}.X.X.|
|00001d80| 58 2f 2a 0a 58 20 2a 20 | 50 61 72 73 65 5f 63 6f |X/*.X * |Parse_co|
|00001d90| 6e 65 28 29 0a 58 20 2a | 20 0a 58 20 2a 20 50 61 |ne().X *| .X * Pa|
|00001da0| 72 73 65 20 74 68 65 20 | 63 6f 6e 65 20 70 72 69 |rse the |cone pri|
|00001db0| 6d 69 74 69 76 65 2e 0a | 58 20 2a 2f 0a 58 0a 58 |mitive..|X */.X.X|
|00001dc0| 50 61 72 73 65 5f 63 6f | 6e 65 28 29 0a 58 7b 0a |Parse_co|ne().X{.|
|00001dd0| 58 09 43 4f 4e 45 20 20 | 20 20 20 20 20 20 20 20 |X.CONE | |
|00001de0| 20 2a 63 64 3b 0a 58 0a | 58 09 69 66 20 28 28 63 | *cd;.X.|X.if ((c|
|00001df0| 64 20 3d 20 28 43 4f 4e | 45 20 2a 29 20 6d 61 6c |d = (CON|E *) mal|
|00001e00| 6c 6f 63 28 73 69 7a 65 | 6f 66 28 43 4f 4e 45 29 |loc(size|of(CONE)|
|00001e10| 29 29 20 3d 3d 20 4e 55 | 4c 4c 29 0a 58 09 09 42 |)) == NU|LL).X..B|
|00001e20| 61 64 5f 6d 61 6c 6c 6f | 63 28 29 3b 0a 58 0a 58 |ad_mallo|c();.X.X|
|00001e30| 09 2f 2a 20 67 65 74 20 | 74 68 65 20 63 6f 6e 65 |./* get |the cone|
|00001e40| 20 62 61 73 65 20 69 6e | 66 6f 20 2a 2f 0a 58 09 | base in|fo */.X.|
|00001e50| 4e 65 78 74 5f 6c 69 6e | 65 28 29 3b 0a 58 09 69 |Next_lin|e();.X.i|
|00001e60| 66 20 28 73 73 63 61 6e | 66 28 6c 69 6e 65 5f 62 |f (sscan|f(line_b|
|00001e70| 75 66 2c 20 22 25 6c 67 | 20 25 6c 67 20 25 6c 67 |uf, "%lg| %lg %lg|
|00001e80| 20 25 6c 67 22 2c 20 26 | 63 64 2d 3e 62 61 73 65 | %lg", &|cd->base|
|00001e90| 2e 78 2c 20 26 63 64 2d | 3e 62 61 73 65 2e 79 2c |.x, &cd-|>base.y,|
|00001ea0| 0a 58 09 09 20 20 20 26 | 63 64 2d 3e 62 61 73 65 |.X.. &|cd->base|
|00001eb0| 2e 7a 2c 20 26 63 64 2d | 3e 62 61 73 65 5f 72 61 |.z, &cd-|>base_ra|
|00001ec0| 64 69 75 73 29 20 21 3d | 20 34 29 0a 58 09 09 72 |dius) !=| 4).X..r|
|00001ed0| 65 74 75 72 6e 20 28 31 | 29 3b 0a 58 0a 58 09 2f |eturn (1|);.X.X./|
|00001ee0| 2a 20 61 6e 64 20 74 68 | 65 20 61 70 65 78 20 73 |* and th|e apex s|
|00001ef0| 74 75 66 66 20 2a 2f 0a | 58 09 4e 65 78 74 5f 6c |tuff */.|X.Next_l|
|00001f00| 69 6e 65 28 29 3b 0a 58 | 09 69 66 20 28 73 73 63 |ine();.X|.if (ssc|
|00001f10| 61 6e 66 28 6c 69 6e 65 | 5f 62 75 66 2c 20 22 25 |anf(line|_buf, "%|
|00001f20| 6c 67 20 25 6c 67 20 25 | 6c 67 20 25 6c 67 22 2c |lg %lg %|lg %lg",|
|00001f30| 20 26 63 64 2d 3e 61 70 | 65 78 2e 78 2c 20 26 63 | &cd->ap|ex.x, &c|
|00001f40| 64 2d 3e 61 70 65 78 2e | 79 2c 0a 58 09 09 20 20 |d->apex.|y,.X.. |
|00001f50| 20 26 63 64 2d 3e 61 70 | 65 78 2e 7a 2c 20 26 63 | &cd->ap|ex.z, &c|
|00001f60| 64 2d 3e 61 70 65 78 5f | 72 61 64 69 75 73 29 20 |d->apex_|radius) |
|00001f70| 21 3d 20 34 29 0a 58 09 | 09 72 65 74 75 72 6e 20 |!= 4).X.|.return |
|00001f80| 28 31 29 3b 0a 58 0a 58 | 09 69 66 20 28 69 66 6c |(1);.X.X|.if (ifl|
|00001f90| 61 67 29 0a 58 09 09 41 | 64 64 5f 74 6f 5f 69 6c |ag).X..A|dd_to_il|
|00001fa0| 69 73 74 28 63 64 2c 20 | 49 5f 4f 42 4a 45 43 54 |ist(cd, |I_OBJECT|
|00001fb0| 2c 20 54 5f 43 4f 4e 45 | 29 3b 0a 58 09 65 6c 73 |, T_CONE|);.X.els|
|00001fc0| 65 0a 58 09 09 42 75 69 | 6c 64 5f 63 6f 6e 65 28 |e.X..Bui|ld_cone(|
|00001fd0| 63 64 29 3b 0a 58 09 72 | 65 74 75 72 6e 20 28 30 |cd);.X.r|eturn (0|
|00001fe0| 29 3b 0a 58 0a 58 7d 0a | 58 0a 58 2f 2a 0a 58 20 |);.X.X}.|X.X/*.X |
|00001ff0| 2a 20 50 61 72 73 65 5f | 73 70 68 65 72 65 28 29 |* Parse_|sphere()|
|00002000| 0a 58 20 2a 20 0a 58 20 | 2a 20 50 61 72 73 65 20 |.X * .X |* Parse |
|00002010| 74 68 65 20 73 70 68 65 | 72 65 20 70 72 69 6d 69 |the sphe|re primi|
|00002020| 74 69 76 65 2e 0a 58 20 | 2a 2f 0a 58 0a 58 50 61 |tive..X |*/.X.XPa|
|00002030| 72 73 65 5f 73 70 68 65 | 72 65 28 29 0a 58 7b 0a |rse_sphe|re().X{.|
|00002040| 58 09 53 50 48 45 52 45 | 20 20 20 20 20 20 20 20 |X.SPHERE| |
|00002050| 20 2a 73 3b 0a 58 0a 58 | 09 69 66 20 28 28 73 20 | *s;.X.X|.if ((s |
|00002060| 3d 20 28 53 50 48 45 52 | 45 20 2a 29 20 6d 61 6c |= (SPHER|E *) mal|
|00002070| 6c 6f 63 28 73 69 7a 65 | 6f 66 28 53 50 48 45 52 |loc(size|of(SPHER|
|00002080| 45 29 29 29 20 3d 3d 20 | 4e 55 4c 4c 29 0a 58 09 |E))) == |NULL).X.|
|00002090| 09 42 61 64 5f 6d 61 6c | 6c 6f 63 28 29 3b 0a 58 |.Bad_mal|loc();.X|
|000020a0| 0a 58 09 69 66 20 28 73 | 73 63 61 6e 66 28 69 6e |.X.if (s|scanf(in|
|000020b0| 66 6f 5f 70 74 72 2c 20 | 22 25 6c 67 20 25 6c 67 |fo_ptr, |"%lg %lg|
|000020c0| 20 25 6c 67 20 25 6c 67 | 22 2c 20 26 73 2d 3e 63 | %lg %lg|", &s->c|
|000020d0| 65 6e 74 65 72 2e 78 2c | 20 26 73 2d 3e 63 65 6e |enter.x,| &s->cen|
|000020e0| 74 65 72 2e 79 2c 0a 58 | 09 09 20 20 20 26 73 2d |ter.y,.X|.. &s-|
|000020f0| 3e 63 65 6e 74 65 72 2e | 7a 2c 20 26 73 2d 3e 72 |>center.|z, &s->r|
|00002100| 61 64 69 75 73 29 20 21 | 3d 20 34 29 0a 58 09 09 |adius) !|= 4).X..|
|00002110| 72 65 74 75 72 6e 20 28 | 31 29 3b 0a 58 0a 58 0a |return (|1);.X.X.|
|00002120| 58 09 69 66 20 28 69 66 | 6c 61 67 29 0a 58 09 09 |X.if (if|lag).X..|
|00002130| 41 64 64 5f 74 6f 5f 69 | 6c 69 73 74 28 73 2c 20 |Add_to_i|list(s, |
|00002140| 49 5f 4f 42 4a 45 43 54 | 2c 20 54 5f 53 50 48 45 |I_OBJECT|, T_SPHE|
|00002150| 52 45 29 3b 0a 58 09 65 | 6c 73 65 0a 58 09 09 42 |RE);.X.e|lse.X..B|
|00002160| 75 69 6c 64 5f 73 70 68 | 65 72 65 28 73 29 3b 0a |uild_sph|ere(s);.|
|00002170| 58 09 72 65 74 75 72 6e | 20 28 30 29 3b 0a 58 7d |X.return| (0);.X}|
|00002180| 0a 58 0a 58 2f 2a 0a 58 | 20 2a 20 50 61 72 73 65 |.X.X/*.X| * Parse|
|00002190| 5f 68 61 6c 6c 6f 77 5f | 73 70 68 65 72 65 28 29 |_hallow_|sphere()|
|000021a0| 0a 58 20 2a 20 0a 58 20 | 2a 20 50 61 72 73 65 20 |.X * .X |* Parse |
|000021b0| 74 68 65 20 68 61 6c 6c | 6f 77 20 73 70 68 65 72 |the hall|ow spher|
|000021c0| 65 20 70 72 69 6d 69 74 | 69 76 65 2e 20 54 68 65 |e primit|ive. The|
|000021d0| 20 66 6f 72 6d 61 74 20 | 69 73 0a 58 20 2a 20 0a | format |is.X * .|
|000021e0| 58 20 2a 20 68 73 70 68 | 65 72 65 20 63 65 6e 74 |X * hsph|ere cent|
|000021f0| 65 72 2e 78 20 63 65 6e | 74 65 72 2e 79 20 63 65 |er.x cen|ter.y ce|
|00002200| 6e 74 65 72 2e 7a 20 72 | 61 64 69 75 73 20 74 69 |nter.z r|adius ti|
|00002210| 63 6b 6e 65 73 73 0a 58 | 20 2a 2f 0a 58 0a 58 50 |ckness.X| */.X.XP|
|00002220| 61 72 73 65 5f 68 61 6c | 6c 6f 77 5f 73 70 68 65 |arse_hal|low_sphe|
|00002230| 72 65 28 29 0a 58 7b 0a | 58 09 48 53 50 48 45 52 |re().X{.|X.HSPHER|
|00002240| 45 20 20 20 20 20 20 20 | 20 2a 73 3b 0a 58 09 64 |E | *s;.X.d|
|00002250| 6f 75 62 6c 65 20 20 20 | 20 20 20 20 20 20 20 74 |ouble | t|
|00002260| 68 69 63 6b 6e 65 73 73 | 3b 0a 58 0a 58 09 69 66 |hickness|;.X.X.if|
|00002270| 20 28 28 73 20 3d 20 28 | 48 53 50 48 45 52 45 20 | ((s = (|HSPHERE |
|00002280| 2a 29 20 6d 61 6c 6c 6f | 63 28 73 69 7a 65 6f 66 |*) mallo|c(sizeof|
|00002290| 28 48 53 50 48 45 52 45 | 29 29 29 20 3d 3d 20 4e |(HSPHERE|))) == N|
|000022a0| 55 4c 4c 29 0a 58 09 09 | 42 61 64 5f 6d 61 6c 6c |ULL).X..|Bad_mall|
|000022b0| 6f 63 28 29 3b 0a 58 0a | 58 09 69 66 20 28 73 73 |oc();.X.|X.if (ss|
|000022c0| 63 61 6e 66 28 69 6e 66 | 6f 5f 70 74 72 2c 20 22 |canf(inf|o_ptr, "|
|000022d0| 25 6c 67 20 25 6c 67 20 | 25 6c 67 20 25 6c 67 20 |%lg %lg |%lg %lg |
|000022e0| 25 6c 67 22 2c 20 26 73 | 2d 3e 63 65 6e 74 65 72 |%lg", &s|->center|
|000022f0| 2e 78 2c 20 26 73 2d 3e | 63 65 6e 74 65 72 2e 79 |.x, &s->|center.y|
|00002300| 2c 0a 58 09 09 20 20 20 | 26 73 2d 3e 63 65 6e 74 |,.X.. |&s->cent|
|00002310| 65 72 2e 7a 2c 20 26 73 | 2d 3e 72 61 64 69 75 73 |er.z, &s|->radius|
|00002320| 2c 20 26 74 68 69 63 6b | 6e 65 73 73 29 20 21 3d |, &thick|ness) !=|
|00002330| 20 35 29 0a 58 09 09 72 | 65 74 75 72 6e 20 28 31 | 5).X..r|eturn (1|
|00002340| 29 3b 0a 58 0a 58 09 73 | 2d 3e 69 5f 72 61 64 69 |);.X.X.s|->i_radi|
|00002350| 75 73 20 3d 20 73 2d 3e | 72 61 64 69 75 73 20 2d |us = s->|radius -|
|00002360| 20 74 68 69 63 6b 6e 65 | 73 73 3b 0a 58 0a 58 09 | thickne|ss;.X.X.|
|00002370| 69 66 20 28 69 66 6c 61 | 67 29 0a 58 09 09 41 64 |if (ifla|g).X..Ad|
|00002380| 64 5f 74 6f 5f 69 6c 69 | 73 74 28 73 2c 20 49 5f |d_to_ili|st(s, I_|
|00002390| 4f 42 4a 45 43 54 2c 20 | 54 5f 48 53 50 48 45 52 |OBJECT, |T_HSPHER|
|000023a0| 45 29 3b 0a 58 09 65 6c | 73 65 0a 58 09 09 42 75 |E);.X.el|se.X..Bu|
|000023b0| 69 6c 64 5f 68 73 70 68 | 65 72 65 28 73 29 3b 0a |ild_hsph|ere(s);.|
|000023c0| 58 09 72 65 74 75 72 6e | 20 28 30 29 3b 0a 58 7d |X.return| (0);.X}|
|000023d0| 0a 58 0a 58 0a 58 2f 2a | 0a 58 20 2a 20 50 61 72 |.X.X.X/*|.X * Par|
|000023e0| 73 65 5f 70 6f 6c 79 28 | 29 0a 58 20 2a 20 0a 58 |se_poly(|).X * .X|
|000023f0| 20 2a 20 50 61 72 73 65 | 20 74 68 65 20 70 6f 6c | * Parse| the pol|
|00002400| 79 67 6f 6e 20 76 65 72 | 74 69 63 69 65 73 20 69 |ygon ver|ticies i|
|00002410| 6e 66 6f 2e 0a 58 20 2a | 2f 0a 58 0a 58 50 61 72 |nfo..X *|/.X.XPar|
|00002420| 73 65 5f 70 6f 6c 79 28 | 29 0a 58 7b 0a 58 09 69 |se_poly(|).X{.X.i|
|00002430| 6e 74 20 20 20 20 20 20 | 20 20 20 20 20 20 20 6e |nt | n|
|00002440| 70 2c 20 69 3b 0a 58 09 | 50 4f 4c 59 47 4f 4e 20 |p, i;.X.|POLYGON |
|00002450| 20 20 20 20 20 20 20 2a | 70 3b 0a 58 0a 58 09 2f | *|p;.X.X./|
|00002460| 2a 20 67 65 74 20 74 68 | 65 20 6e 75 6d 62 65 72 |* get th|e number|
|00002470| 20 6f 66 20 70 6f 69 6e | 74 73 20 2a 2f 0a 58 09 | of poin|ts */.X.|
|00002480| 69 66 20 28 73 73 63 61 | 6e 66 28 69 6e 66 6f 5f |if (ssca|nf(info_|
|00002490| 70 74 72 2c 20 22 25 64 | 22 2c 20 26 6e 70 29 20 |ptr, "%d|", &np) |
|000024a0| 21 3d 20 31 29 0a 58 09 | 09 72 65 74 75 72 6e 20 |!= 1).X.|.return |
|000024b0| 28 31 29 3b 0a 58 0a 58 | 09 69 66 20 28 28 70 20 |(1);.X.X|.if ((p |
|000024c0| 3d 20 28 50 4f 4c 59 47 | 4f 4e 20 2a 29 20 6d 61 |= (POLYG|ON *) ma|
|000024d0| 6c 6c 6f 63 28 73 69 7a | 65 6f 66 28 50 4f 4c 59 |lloc(siz|eof(POLY|
|000024e0| 47 4f 4e 29 20 2b 20 28 | 73 69 7a 65 6f 66 28 56 |GON) + (|sizeof(V|
|000024f0| 45 43 54 4f 52 29 20 2a | 20 28 6e 70 20 2d 20 31 |ECTOR) *| (np - 1|
|00002500| 29 29 29 29 0a 58 09 20 | 20 20 20 3d 3d 20 4e 55 |)))).X. | == NU|
|00002510| 4c 4c 29 0a 58 09 09 42 | 61 64 5f 6d 61 6c 6c 6f |LL).X..B|ad_mallo|
|00002520| 63 28 29 3b 0a 58 0a 58 | 09 69 66 20 28 6e 70 20 |c();.X.X|.if (np |
|00002530| 3c 20 33 29 0a 58 09 09 | 72 65 74 75 72 6e 20 28 |< 3).X..|return (|
|00002540| 31 29 3b 0a 58 0a 58 09 | 66 6f 72 20 28 69 20 3d |1);.X.X.|for (i =|
|00002550| 20 30 3b 20 69 20 3c 20 | 6e 70 3b 20 69 2b 2b 29 | 0; i < |np; i++)|
|00002560| 0a 58 09 7b 0a 58 09 09 | 4e 65 78 74 5f 6c 69 6e |.X.{.X..|Next_lin|
|00002570| 65 28 29 3b 0a 58 09 09 | 69 66 20 28 73 73 63 61 |e();.X..|if (ssca|
|00002580| 6e 66 28 6c 69 6e 65 5f | 62 75 66 2c 20 22 25 6c |nf(line_|buf, "%l|
|00002590| 67 20 25 6c 67 20 25 6c | 67 22 2c 20 26 70 2d 3e |g %lg %l|g", &p->|
|000025a0| 70 6f 69 6e 74 73 5b 69 | 5d 2e 78 2c 20 26 70 2d |points[i|].x, &p-|
|000025b0| 3e 70 6f 69 6e 74 73 5b | 69 5d 2e 79 2c 0a 58 09 |>points[|i].y,.X.|
|000025c0| 09 09 20 20 20 26 70 2d | 3e 70 6f 69 6e 74 73 5b |.. &p-|>points[|
|000025d0| 69 5d 2e 7a 29 20 21 3d | 20 33 29 0a 58 09 09 09 |i].z) !=| 3).X...|
|000025e0| 72 65 74 75 72 6e 20 28 | 31 29 3b 0a 58 09 7d 0a |return (|1);.X.}.|
|000025f0| 58 0a 58 09 70 2d 3e 6e | 70 6f 69 6e 74 73 20 3d |X.X.p->n|points =|
|00002600| 20 6e 70 3b 0a 58 0a 58 | 09 69 66 20 28 69 66 6c | np;.X.X|.if (ifl|
|00002610| 61 67 29 0a 58 09 09 41 | 64 64 5f 74 6f 5f 69 6c |ag).X..A|dd_to_il|
|00002620| 69 73 74 28 70 2c 20 49 | 5f 4f 42 4a 45 43 54 2c |ist(p, I|_OBJECT,|
|00002630| 20 54 5f 50 4f 4c 59 47 | 4f 4e 29 3b 0a 58 09 65 | T_POLYG|ON);.X.e|
|00002640| 6c 73 65 0a 58 09 09 42 | 75 69 6c 64 5f 70 6f 6c |lse.X..B|uild_pol|
|00002650| 79 28 70 29 3b 0a 58 09 | 72 65 74 75 72 6e 20 28 |y(p);.X.|return (|
|00002660| 30 29 3b 0a 58 7d 0a 58 | 0a 58 0a 58 0a 58 2f 2a |0);.X}.X|.X.X.X/*|
|00002670| 0a 58 20 2a 20 50 61 72 | 73 65 5f 72 69 6e 67 28 |.X * Par|se_ring(|
|00002680| 29 0a 58 20 2a 20 0a 58 | 20 2a 20 50 61 72 73 65 |).X * .X| * Parse|
|00002690| 20 74 68 65 20 72 69 6e | 67 20 70 72 69 6d 69 74 | the rin|g primit|
|000026a0| 69 76 65 2e 20 54 68 65 | 20 66 6f 72 6d 61 74 20 |ive. The| format |
|000026b0| 69 73 3a 0a 58 20 2a 20 | 0a 58 20 2a 20 72 69 6e |is:.X * |.X * rin|
|000026c0| 67 20 63 65 6e 74 65 72 | 2e 78 20 63 65 6e 74 65 |g center|.x cente|
|000026d0| 72 2e 79 20 63 65 6e 74 | 65 72 2e 7a 20 70 31 2e |r.y cent|er.z p1.|
|000026e0| 78 20 70 31 2e 79 20 70 | 31 2e 7a 20 70 32 2e 78 |x p1.y p|1.z p2.x|
|000026f0| 20 70 32 2e 79 20 70 32 | 2e 7a 20 6f 72 20 69 72 | p2.y p2|.z or ir|
|00002700| 0a 58 20 2a 2f 0a 58 0a | 58 50 61 72 73 65 5f 72 |.X */.X.|XParse_r|
|00002710| 69 6e 67 28 29 0a 58 7b | 0a 58 09 52 49 4e 47 20 |ing().X{|.X.RING |
|00002720| 20 20 20 20 20 20 20 20 | 20 20 2a 72 3b 0a 58 0a | | *r;.X.|
|00002730| 58 09 69 66 20 28 28 72 | 20 3d 20 28 52 49 4e 47 |X.if ((r| = (RING|
|00002740| 20 2a 29 20 6d 61 6c 6c | 6f 63 28 73 69 7a 65 6f | *) mall|oc(sizeo|
|00002750| 66 28 52 49 4e 47 29 29 | 29 20 3d 3d 20 4e 55 4c |f(RING))|) == NUL|
|00002760| 4c 29 0a 58 09 09 42 61 | 64 5f 6d 61 6c 6c 6f 63 |L).X..Ba|d_malloc|
|00002770| 28 29 3b 0a 58 0a 58 09 | 69 66 20 28 73 73 63 61 |();.X.X.|if (ssca|
|00002780| 6e 66 28 69 6e 66 6f 5f | 70 74 72 2c 20 22 25 6c |nf(info_|ptr, "%l|
|00002790| 67 20 25 6c 67 20 25 6c | 67 20 25 6c 67 20 25 6c |g %lg %l|g %lg %l|
|000027a0| 67 20 25 6c 67 20 25 6c | 67 20 25 6c 67 20 25 6c |g %lg %l|g %lg %l|
|000027b0| 67 20 25 6c 67 20 25 6c | 67 22 2c 0a 58 09 09 20 |g %lg %l|g",.X.. |
|000027c0| 20 20 26 72 2d 3e 63 65 | 6e 74 65 72 2e 78 2c 20 | &r->ce|nter.x, |
|000027d0| 26 72 2d 3e 63 65 6e 74 | 65 72 2e 79 2c 20 26 72 |&r->cent|er.y, &r|
|000027e0| 2d 3e 63 65 6e 74 65 72 | 2e 7a 2c 0a 58 09 09 20 |->center|.z,.X.. |
|000027f0| 20 20 26 72 2d 3e 70 6f | 69 6e 74 31 2e 78 2c 20 | &r->po|int1.x, |
|00002800| 26 72 2d 3e 70 6f 69 6e | 74 31 2e 79 2c 20 26 72 |&r->poin|t1.y, &r|
|00002810| 2d 3e 70 6f 69 6e 74 31 | 2e 7a 2c 0a 58 09 09 20 |->point1|.z,.X.. |
|00002820| 20 20 26 72 2d 3e 70 6f | 69 6e 74 32 2e 78 2c 20 | &r->po|int2.x, |
|00002830| 26 72 2d 3e 70 6f 69 6e | 74 32 2e 79 2c 20 26 72 |&r->poin|t2.y, &r|
|00002840| 2d 3e 70 6f 69 6e 74 32 | 2e 7a 2c 0a 58 09 09 20 |->point2|.z,.X.. |
|00002850| 20 20 26 72 2d 3e 6f 5f | 72 61 64 69 75 73 2c 20 | &r->o_|radius, |
|00002860| 26 72 2d 3e 69 5f 72 61 | 64 69 75 73 29 20 21 3d |&r->i_ra|dius) !=|
|00002870| 20 31 31 29 0a 58 09 09 | 72 65 74 75 72 6e 20 28 | 11).X..|return (|
|00002880| 31 29 3b 0a 58 0a 58 09 | 69 66 20 28 69 66 6c 61 |1);.X.X.|if (ifla|
|00002890| 67 29 0a 58 09 09 41 64 | 64 5f 74 6f 5f 69 6c 69 |g).X..Ad|d_to_ili|
|000028a0| 73 74 28 72 2c 20 49 5f | 4f 42 4a 45 43 54 2c 20 |st(r, I_|OBJECT, |
|000028b0| 54 5f 52 49 4e 47 29 3b | 0a 58 09 65 6c 73 65 0a |T_RING);|.X.else.|
|000028c0| 58 09 09 42 75 69 6c 64 | 5f 72 69 6e 67 28 72 29 |X..Build|_ring(r)|
|000028d0| 3b 0a 58 09 72 65 74 75 | 72 6e 20 28 30 29 3b 0a |;.X.retu|rn (0);.|
|000028e0| 58 7d 0a 58 0a 58 0a 58 | 2f 2a 0a 58 20 2a 20 50 |X}.X.X.X|/*.X * P|
|000028f0| 61 72 73 65 5f 71 75 61 | 64 72 69 63 28 29 0a 58 |arse_qua|dric().X|
|00002900| 20 2a 20 0a 58 20 2a 20 | 50 61 72 73 65 20 74 68 | * .X * |Parse th|
|00002910| 65 20 71 75 61 64 72 69 | 63 20 64 61 74 61 20 74 |e quadri|c data t|
|00002920| 79 70 65 2e 20 54 68 65 | 20 66 6f 72 6d 61 74 20 |ype. The| format |
|00002930| 69 73 3a 0a 58 20 2a 20 | 0a 58 20 2a 20 71 75 61 |is:.X * |.X * qua|
|00002940| 64 72 69 63 20 6c 6f 63 | 2e 78 20 6c 6f 63 2e 79 |dric loc|.x loc.y|
|00002950| 20 6c 6f 63 2e 7a 20 61 | 20 20 62 20 20 63 20 20 | loc.z a| b c |
|00002960| 64 20 20 65 20 66 20 20 | 67 20 20 68 20 20 69 20 |d e f |g h i |
|00002970| 20 6a 0a 58 20 2a 2f 0a | 58 0a 58 50 61 72 73 65 | j.X */.|X.XParse|
|00002980| 5f 71 75 61 64 72 69 63 | 28 29 0a 58 7b 0a 58 09 |_quadric|().X{.X.|
|00002990| 51 55 41 44 52 49 43 20 | 20 20 20 20 20 20 20 2a |QUADRIC | *|
|000029a0| 71 3b 0a 58 0a 58 09 2f | 2a 0a 58 09 20 2a 20 41 |q;.X.X./|*.X. * A|
|000029b0| 6c 6c 6f 63 61 74 65 20 | 61 20 64 61 74 61 20 73 |llocate |a data s|
|000029c0| 74 72 75 63 74 75 72 65 | 2e 0a 58 09 20 2a 2f 0a |tructure|..X. */.|
|000029d0| 58 0a 58 09 69 66 20 28 | 28 71 20 3d 20 28 51 55 |X.X.if (|(q = (QU|
|000029e0| 41 44 52 49 43 20 2a 29 | 20 6d 61 6c 6c 6f 63 28 |ADRIC *)| malloc(|
|000029f0| 73 69 7a 65 6f 66 28 51 | 55 41 44 52 49 43 29 29 |sizeof(Q|UADRIC))|
|00002a00| 29 20 3d 3d 20 4e 55 4c | 4c 29 0a 58 09 09 42 61 |) == NUL|L).X..Ba|
|00002a10| 64 5f 6d 61 6c 6c 6f 63 | 28 29 3b 0a 58 0a 58 09 |d_malloc|();.X.X.|
|00002a20| 2f 2a 0a 58 09 20 2a 20 | 47 65 74 20 74 68 65 20 |/*.X. * |Get the |
|00002a30| 63 65 6e 74 65 72 20 6f | 66 20 74 68 65 20 71 75 |center o|f the qu|
|00002a40| 61 64 72 61 74 69 63 2e | 0a 58 09 20 2a 2f 0a 58 |adratic.|.X. */.X|
|00002a50| 0a 58 09 69 66 20 28 73 | 73 63 61 6e 66 28 69 6e |.X.if (s|scanf(in|
|00002a60| 66 6f 5f 70 74 72 2c 20 | 22 25 6c 67 20 25 6c 67 |fo_ptr, |"%lg %lg|
|00002a70| 20 25 6c 67 22 2c 20 26 | 71 2d 3e 6c 6f 63 2e 78 | %lg", &|q->loc.x|
|00002a80| 2c 20 26 71 2d 3e 6c 6f | 63 2e 79 2c 20 26 71 2d |, &q->lo|c.y, &q-|
|00002a90| 3e 6c 6f 63 2e 7a 29 20 | 21 3d 20 33 29 0a 58 09 |>loc.z) |!= 3).X.|
|00002aa0| 09 72 65 74 75 72 6e 20 | 28 31 29 3b 0a 58 0a 58 |.return |(1);.X.X|
|00002ab0| 09 2f 2a 0a 58 09 20 2a | 20 47 65 74 20 74 68 65 |./*.X. *| Get the|
|00002ac0| 20 6d 69 6e 20 61 6e 64 | 20 6d 61 78 20 76 61 6c | min and| max val|
|00002ad0| 75 65 73 2e 0a 58 09 20 | 2a 2f 0a 58 0a 58 09 4e |ues..X. |*/.X.X.N|
|00002ae0| 65 78 74 5f 6c 69 6e 65 | 28 29 3b 0a 58 09 69 66 |ext_line|();.X.if|
|00002af0| 20 28 73 73 63 61 6e 66 | 28 6c 69 6e 65 5f 62 75 | (sscanf|(line_bu|
|00002b00| 66 2c 20 22 25 6c 67 20 | 25 6c 67 20 25 6c 67 20 |f, "%lg |%lg %lg |
|00002b10| 25 6c 67 20 25 6c 67 20 | 25 6c 67 22 2c 0a 58 09 |%lg %lg |%lg",.X.|
|00002b20| 09 20 20 20 26 71 2d 3e | 6d 69 6e 2e 78 2c 20 26 |. &q->|min.x, &|
|00002b30| 71 2d 3e 6d 69 6e 2e 79 | 2c 20 26 71 2d 3e 6d 69 |q->min.y|, &q->mi|
|00002b40| 6e 2e 7a 2c 0a 58 09 09 | 20 20 20 26 71 2d 3e 6d |n.z,.X..| &q->m|
|00002b50| 61 78 2e 78 2c 20 26 71 | 2d 3e 6d 61 78 2e 79 2c |ax.x, &q|->max.y,|
|00002b60| 20 26 71 2d 3e 6d 61 78 | 2e 7a 29 20 21 3d 20 36 | &q->max|.z) != 6|
|00002b70| 29 0a 58 09 09 72 65 74 | 75 72 6e 20 28 31 29 3b |).X..ret|urn (1);|
|00002b80| 0a 58 0a 58 09 2f 2a 0a | 58 09 20 2a 20 47 65 74 |.X.X./*.|X. * Get|
|00002b90| 20 74 68 65 20 41 2c 20 | 42 2c 20 43 2c 20 44 2c | the A, |B, C, D,|
|00002ba0| 20 61 6e 64 20 45 20 63 | 6f 65 66 66 69 63 69 65 | and E c|oefficie|
|00002bb0| 6e 74 73 2e 0a 58 09 20 | 2a 2f 0a 58 0a 58 09 4e |nts..X. |*/.X.X.N|
|00002bc0| 65 78 74 5f 6c 69 6e 65 | 28 29 3b 0a 58 09 69 66 |ext_line|();.X.if|
|00002bd0| 20 28 73 73 63 61 6e 66 | 28 6c 69 6e 65 5f 62 75 | (sscanf|(line_bu|
|00002be0| 66 2c 20 22 25 6c 67 20 | 25 6c 67 20 25 6c 67 20 |f, "%lg |%lg %lg |
|00002bf0| 25 6c 67 20 25 6c 67 22 | 2c 20 26 71 2d 3e 61 2c |%lg %lg"|, &q->a,|
|00002c00| 20 26 71 2d 3e 62 2c 20 | 26 71 2d 3e 63 2c 20 26 | &q->b, |&q->c, &|
|00002c10| 71 2d 3e 64 2c 0a 58 09 | 09 20 20 20 26 71 2d 3e |q->d,.X.|. &q->|
|00002c20| 65 29 20 21 3d 20 35 29 | 0a 58 09 09 72 65 74 75 |e) != 5)|.X..retu|
|00002c30| 72 6e 20 28 31 29 3b 0a | 58 0a 58 09 2f 2a 0a 58 |rn (1);.|X.X./*.X|
|00002c40| 09 20 2a 20 47 65 74 20 | 74 68 65 20 46 2c 20 47 |. * Get |the F, G|
|00002c50| 2c 20 48 2c 20 49 2c 20 | 61 6e 64 20 4a 20 63 6f |, H, I, |and J co|
|00002c60| 65 66 66 69 63 69 65 6e | 74 73 2e 0a 58 09 20 2a |efficien|ts..X. *|
|00002c70| 2f 0a 58 0a 58 09 4e 65 | 78 74 5f 6c 69 6e 65 28 |/.X.X.Ne|xt_line(|
|00002c80| 29 3b 0a 58 09 69 66 20 | 28 73 73 63 61 6e 66 28 |);.X.if |(sscanf(|
|00002c90| 6c 69 6e 65 5f 62 75 66 | 2c 20 22 25 6c 67 20 25 |line_buf|, "%lg %|
|00002ca0| 6c 67 20 25 6c 67 20 25 | 6c 67 20 25 6c 67 22 2c |lg %lg %|lg %lg",|
|00002cb0| 20 26 71 2d 3e 66 2c 20 | 26 71 2d 3e 67 2c 20 26 | &q->f, |&q->g, &|
|00002cc0| 71 2d 3e 68 2c 20 26 71 | 2d 3e 69 2c 0a 58 09 09 |q->h, &q|->i,.X..|
|00002cd0| 20 20 20 26 71 2d 3e 6a | 29 20 21 3d 20 35 29 0a | &q->j|) != 5).|
|00002ce0| 58 09 09 72 65 74 75 72 | 6e 20 28 31 29 3b 0a 58 |X..retur|n (1);.X|
|00002cf0| 0a 58 09 69 66 20 28 69 | 66 6c 61 67 29 0a 58 09 |.X.if (i|flag).X.|
|00002d00| 09 41 64 64 5f 74 6f 5f | 69 6c 69 73 74 28 71 2c |.Add_to_|ilist(q,|
|00002d10| 20 49 5f 4f 42 4a 45 43 | 54 2c 20 54 5f 51 55 41 | I_OBJEC|T, T_QUA|
|00002d20| 44 52 49 43 29 3b 0a 58 | 09 65 6c 73 65 0a 58 09 |DRIC);.X|.else.X.|
|00002d30| 09 42 75 69 6c 64 5f 71 | 75 61 64 72 69 63 28 71 |.Build_q|uadric(q|
|00002d40| 29 3b 0a 58 09 72 65 74 | 75 72 6e 20 28 30 29 3b |);.X.ret|urn (0);|
|00002d50| 0a 58 7d 0a 58 0a 58 0a | 58 2f 2a 0a 58 20 2a 20 |.X}.X.X.|X/*.X * |
|00002d60| 50 61 72 73 65 5f 69 6e | 73 74 61 6e 63 65 28 29 |Parse_in|stance()|
|00002d70| 0a 58 20 2a 20 0a 58 20 | 2a 20 53 74 61 72 74 20 |.X * .X |* Start |
|00002d80| 61 20 6e 65 77 20 69 6e | 73 74 61 6e 63 65 20 64 |a new in|stance d|
|00002d90| 65 66 69 6e 69 74 69 6f | 6e 20 68 65 72 65 2e 0a |efinitio|n here..|
|00002da0| 58 20 2a 2f 0a 58 0a 58 | 50 61 72 73 65 5f 69 6e |X */.X.X|Parse_in|
|00002db0| 73 74 61 6e 63 65 28 29 | 0a 58 7b 0a 58 09 49 4e |stance()|.X{.X.IN|
|00002dc0| 53 54 41 4e 43 45 20 20 | 20 20 20 20 20 2a 69 3b |STANCE | *i;|
|00002dd0| 0a 58 09 63 68 61 72 20 | 20 20 20 20 20 20 20 20 |.X.char | |
|00002de0| 20 20 20 6e 61 6d 65 5b | 31 32 38 5d 3b 0a 58 0a | name[|128];.X.|
|00002df0| 58 09 2f 2a 0a 58 09 20 | 2a 20 49 6e 73 74 61 6e |X./*.X. |* Instan|
|00002e00| 63 65 73 20 63 61 6e 20 | 6e 6f 74 20 62 65 20 6e |ces can |not be n|
|00002e10| 65 73 74 65 64 2e 0a 58 | 09 20 2a 2f 0a 58 0a 58 |ested..X|. */.X.X|
|00002e20| 09 69 66 20 28 69 66 6c | 61 67 29 0a 58 09 7b 0a |.if (ifl|ag).X.{.|
|00002e30| 58 09 09 66 70 72 69 6e | 74 66 28 73 74 64 65 72 |X..fprin|tf(stder|
|00002e40| 72 2c 20 22 25 73 3a 20 | 69 6e 73 74 61 6e 63 65 |r, "%s: |instance|
|00002e50| 20 64 65 66 69 6e 69 74 | 69 6f 6e 73 20 63 61 6e | definit|ions can|
|00002e60| 27 74 20 62 65 20 6e 65 | 73 74 65 64 5c 6e 2e 22 |'t be ne|sted\n."|
|00002e70| 2c 0a 58 09 09 09 6d 79 | 5f 6e 61 6d 65 29 3b 0a |,.X...my|_name);.|
|00002e80| 58 09 09 72 65 74 75 72 | 6e 20 28 31 29 3b 0a 58 |X..retur|n (1);.X|
|00002e90| 09 7d 0a 58 0a 58 09 69 | 66 20 28 6e 75 6d 5f 69 |.}.X.X.i|f (num_i|
|00002ea0| 6e 73 74 61 6e 63 65 20 | 3d 3d 20 4d 41 58 5f 49 |nstance |== MAX_I|
|00002eb0| 4e 53 54 41 4e 43 45 29 | 0a 58 09 7b 0a 58 09 09 |NSTANCE)|.X.{.X..|
|00002ec0| 66 70 72 69 6e 74 66 28 | 73 74 64 65 72 72 2c 20 |fprintf(|stderr, |
|00002ed0| 22 25 73 3a 20 74 6f 6f | 20 6d 61 6e 79 20 69 6e |"%s: too| many in|
|00002ee0| 73 74 61 6e 63 65 73 20 | 64 65 66 69 6e 65 64 2e |stances |defined.|
|00002ef0| 5c 6e 22 29 3b 0a 58 09 | 09 72 65 74 75 72 6e 20 |\n");.X.|.return |
|00002f00| 28 31 29 3b 0a 58 09 7d | 0a 58 0a 58 0a 58 09 2f |(1);.X.}|.X.X.X./|
|00002f10| 2a 0a 58 09 20 2a 20 47 | 65 74 20 74 68 65 20 6e |*.X. * G|et the n|
|00002f20| 61 6d 65 20 66 6f 72 20 | 74 68 69 73 20 69 6e 73 |ame for |this ins|
|00002f30| 74 61 6e 63 65 73 2e 0a | 58 09 20 2a 2f 0a 58 0a |tances..|X. */.X.|
|00002f40| 58 09 47 65 74 5f 74 6f | 6b 65 6e 28 69 6e 66 6f |X.Get_to|ken(info|
|00002f50| 5f 70 74 72 2c 20 6e 61 | 6d 65 29 3b 0a 58 09 69 |_ptr, na|me);.X.i|
|00002f60| 66 20 28 73 74 72 6c 65 | 6e 28 6e 61 6d 65 29 20 |f (strle|n(name) |
|00002f70| 3c 20 31 29 0a 58 09 7b | 0a 58 09 09 66 70 72 69 |< 1).X.{|.X..fpri|
|00002f80| 6e 74 66 28 73 74 64 65 | 72 72 2c 20 22 25 73 3a |ntf(stde|rr, "%s:|
|00002f90| 20 6d 69 73 73 69 6e 67 | 20 6f 72 20 69 6e 76 61 | missing| or inva|
|00002fa0| 6c 69 64 20 69 6e 73 74 | 61 6e 63 65 20 6c 61 62 |lid inst|ance lab|
|00002fb0| 65 6c 2e 5c 6e 22 2c 20 | 6d 79 5f 6e 61 6d 65 29 |el.\n", |my_name)|
|00002fc0| 3b 0a 58 09 09 72 65 74 | 75 72 6e 20 28 31 29 3b |;.X..ret|urn (1);|
|00002fd0| 0a 58 09 7d 0a 58 0a 58 | 09 69 66 20 28 28 69 20 |.X.}.X.X|.if ((i |
|00002fe0| 3d 20 28 49 4e 53 54 41 | 4e 43 45 20 2a 29 20 6d |= (INSTA|NCE *) m|
|00002ff0| 61 6c 6c 6f 63 28 73 69 | 7a 65 6f 66 28 49 4e 53 |alloc(si|zeof(INS|
|00003000| 54 41 4e 43 45 29 29 29 | 20 3d 3d 20 4e 55 4c 4c |TANCE)))| == NULL|
|00003010| 29 0a 58 09 09 42 61 64 | 5f 6d 61 6c 6c 6f 63 28 |).X..Bad|_malloc(|
|00003020| 29 3b 0a 58 0a 58 09 69 | 66 20 28 28 69 2d 3e 6e |);.X.X.i|f ((i->n|
|00003030| 61 6d 65 20 3d 20 6d 61 | 6c 6c 6f 63 28 73 74 72 |ame = ma|lloc(str|
|00003040| 6c 65 6e 28 6e 61 6d 65 | 29 29 29 20 3d 3d 20 4e |len(name|))) == N|
|00003050| 55 4c 4c 29 0a 58 09 09 | 42 61 64 5f 6d 61 6c 6c |ULL).X..|Bad_mall|
|00003060| 6f 63 28 29 3b 0a 58 0a | 58 09 73 74 72 63 70 79 |oc();.X.|X.strcpy|
|00003070| 28 69 2d 3e 6e 61 6d 65 | 2c 20 6e 61 6d 65 29 3b |(i->name|, name);|
|00003080| 0a 58 09 69 2d 3e 74 79 | 70 65 20 3d 20 69 2d 3e |.X.i->ty|pe = i->|
|00003090| 73 75 62 74 79 70 65 20 | 3d 20 2d 31 3b 0a 58 09 |subtype |= -1;.X.|
|000030a0| 69 2d 3e 6e 65 78 74 20 | 3d 20 69 2d 3e 64 61 74 |i->next |= i->dat|
|000030b0| 61 20 3d 20 28 76 6f 69 | 64 20 2a 29 20 30 3b 0a |a = (voi|d *) 0;.|
|000030c0| 58 0a 58 09 69 6e 73 74 | 61 6e 63 65 73 5b 6e 75 |X.X.inst|ances[nu|
|000030d0| 6d 5f 69 6e 73 74 61 6e | 63 65 5d 20 3d 20 69 3b |m_instan|ce] = i;|
|000030e0| 0a 58 09 69 66 6c 61 67 | 20 3d 20 31 3b 0a 58 09 |.X.iflag| = 1;.X.|
|000030f0| 72 65 74 75 72 6e 20 28 | 30 29 3b 0a 58 7d 0a 58 |return (|0);.X}.X|
|00003100| 0a 58 2f 2a 0a 58 20 2a | 20 50 61 72 73 65 5f 65 |.X/*.X *| Parse_e|
|00003110| 6e 64 5f 69 6e 73 74 61 | 6e 63 65 28 29 0a 58 20 |nd_insta|nce().X |
|00003120| 2a 20 0a 58 20 2a 20 43 | 6c 65 61 6e 20 75 70 20 |* .X * C|lean up |
|00003130| 61 6e 64 20 73 61 76 65 | 20 73 74 75 66 66 2e 0a |and save| stuff..|
|00003140| 58 20 2a 2f 0a 58 0a 58 | 50 61 72 73 65 5f 65 6e |X */.X.X|Parse_en|
|00003150| 64 5f 69 6e 73 74 61 6e | 63 65 28 29 0a 58 7b 0a |d_instan|ce().X{.|
|00003160| 58 0a 58 09 2f 2a 0a 58 | 09 20 2a 20 69 66 20 77 |X.X./*.X|. * if w|
|00003170| 65 20 61 72 65 20 6e 6f | 74 20 69 6e 20 61 6e 20 |e are no|t in an |
|00003180| 69 6e 73 74 61 6e 63 65 | 2c 20 69 74 73 61 20 62 |instance|, itsa b|
|00003190| 6f 6f 62 6f 6f 2e 0a 58 | 09 20 2a 2f 0a 58 0a 58 |ooboo..X|. */.X.X|
|000031a0| 09 69 66 20 28 21 69 66 | 6c 61 67 29 0a 58 09 7b |.if (!if|lag).X.{|
|000031b0| 0a 58 09 09 66 70 72 69 | 6e 74 66 28 73 74 64 65 |.X..fpri|ntf(stde|
|000031c0| 72 72 2c 20 22 25 73 3a | 20 75 6e 65 78 70 65 63 |rr, "%s:| unexpec|
|000031d0| 74 65 64 20 27 65 6e 64 | 5f 69 6e 73 74 61 6e 63 |ted 'end|_instanc|
|000031e0| 65 27 2e 5c 6e 22 2c 20 | 6d 79 5f 6e 61 6d 65 29 |e'.\n", |my_name)|
|000031f0| 3b 0a 58 09 09 72 65 74 | 75 72 6e 20 28 31 29 3b |;.X..ret|urn (1);|
|00003200| 0a 58 09 7d 0a 58 0a 58 | 09 69 66 6c 61 67 20 3d |.X.}.X.X|.iflag =|
|00003210| 20 30 3b 0a 58 09 2b 2b | 6e 75 6d 5f 69 6e 73 74 | 0;.X.++|num_inst|
|00003220| 61 6e 63 65 3b 0a 58 09 | 72 65 74 75 72 6e 20 28 |ance;.X.|return (|
|00003230| 30 29 3b 0a 58 7d 0a 58 | 0a 58 2f 2a 0a 58 20 2a |0);.X}.X|.X/*.X *|
|00003240| 20 50 61 72 73 65 5f 69 | 6e 73 74 61 6e 63 65 6f | Parse_i|nstanceo|
|00003250| 66 28 29 0a 58 20 2a 20 | 0a 58 20 2a 20 42 75 69 |f().X * |.X * Bui|
|00003260| 6c 64 20 74 68 65 20 69 | 6e 73 74 61 6e 63 65 20 |ld the i|nstance |
|00003270| 72 65 71 75 65 73 74 65 | 64 20 75 73 69 6e 67 20 |requeste|d using |
|00003280| 74 68 65 20 67 69 76 65 | 6e 20 6f 66 66 73 65 74 |the give|n offset|
|00003290| 2e 20 46 6f 72 6d 61 74 | 20 69 73 0a 58 20 2a 20 |. Format| is.X * |
|000032a0| 0a 58 20 2a 20 69 6e 73 | 74 61 6e 63 65 5f 6f 66 |.X * ins|tance_of|
|000032b0| 20 66 75 62 61 72 20 6c | 6f 63 2e 78 20 6c 6f 63 | fubar l|oc.x loc|
|000032c0| 2e 79 20 6c 6f 63 2e 7a | 0a 58 20 2a 2f 0a 58 0a |.y loc.z|.X */.X.|
|000032d0| 58 50 61 72 73 65 5f 69 | 6e 73 74 61 6e 63 65 6f |XParse_i|nstanceo|
|000032e0| 66 28 29 0a 58 7b 0a 58 | 09 49 4e 53 54 41 4e 43 |f().X{.X|.INSTANC|
|000032f0| 45 20 20 20 20 20 20 20 | 2a 69 6e 73 74 3b 0a 58 |E |*inst;.X|
|00003300| 09 53 50 48 45 52 45 20 | 20 20 20 20 20 20 20 20 |.SPHERE | |
|00003310| 2a 73 3b 0a 58 09 48 53 | 50 48 45 52 45 20 20 20 |*s;.X.HS|PHERE |
|00003320| 20 20 20 20 20 2a 68 73 | 3b 0a 58 09 50 4f 4c 59 | *hs|;.X.POLY|
|00003330| 47 4f 4e 20 20 20 20 20 | 20 20 20 2a 70 2c 20 2a |GON | *p, *|
|00003340| 70 31 3b 0a 58 09 43 4f | 4e 45 20 20 20 20 20 20 |p1;.X.CO|NE |
|00003350| 20 20 20 20 20 2a 63 3b | 0a 58 09 52 49 4e 47 20 | *c;|.X.RING |
|00003360| 20 20 20 20 20 20 20 20 | 20 20 2a 72 3b 0a 58 09 | | *r;.X.|
|00003370| 51 55 41 44 52 49 43 20 | 20 20 20 20 20 20 20 2a |QUADRIC | *|
|00003380| 71 3b 0a 58 09 56 45 43 | 54 4f 52 20 20 20 20 20 |q;.X.VEC|TOR |
|00003390| 20 20 20 20 20 6f 66 66 | 3b 0a 58 09 63 68 61 72 | off|;.X.char|
|000033a0| 20 20 20 20 20 20 20 20 | 20 20 20 20 6e 61 6d 65 | | name|
|000033b0| 5b 33 32 5d 3b 0a 58 09 | 69 6e 74 20 20 20 20 20 |[32];.X.|int |
|000033c0| 20 20 20 20 20 20 20 20 | 69 2c 20 73 69 7a 65 3b | |i, size;|
|000033d0| 0a 58 0a 58 09 69 66 20 | 28 69 66 6c 61 67 29 0a |.X.X.if |(iflag).|
|000033e0| 58 09 7b 0a 58 09 09 66 | 70 72 69 6e 74 66 28 73 |X.{.X..f|printf(s|
|000033f0| 74 64 65 72 72 2c 20 22 | 25 73 3a 20 69 6e 73 74 |tderr, "|%s: inst|
|00003400| 61 6e 63 65 5f 6f 66 20 | 63 61 6e 27 74 20 62 65 |ance_of |can't be|
|00003410| 20 75 73 65 64 20 69 6e | 20 61 6e 20 69 6e 73 74 | used in| an inst|
|00003420| 61 6e 63 65 20 64 65 66 | 2e 5c 6e 22 2c 0a 58 09 |ance def|.\n",.X.|
|00003430| 09 09 6d 79 5f 6e 61 6d | 65 29 3b 0a 58 09 09 72 |..my_nam|e);.X..r|
|00003440| 65 74 75 72 6e 20 28 31 | 29 3b 0a 58 09 7d 0a 58 |eturn (1|);.X.}.X|
|00003450| 0a 58 09 2f 2a 20 67 65 | 74 20 74 68 65 20 69 6e |.X./* ge|t the in|
|00003460| 73 74 61 6e 63 65 20 6e | 61 6d 65 20 2a 2f 0a 58 |stance n|ame */.X|
|00003470| 09 69 6e 66 6f 5f 70 74 | 72 20 3d 20 47 65 74 5f |.info_pt|r = Get_|
|00003480| 74 6f 6b 65 6e 28 69 6e | 66 6f 5f 70 74 72 2c 20 |token(in|fo_ptr, |
|00003490| 6e 61 6d 65 29 3b 0a 58 | 0a 58 09 66 6f 72 20 28 |name);.X|.X.for (|
|000034a0| 69 20 3d 20 30 3b 20 69 | 20 3c 20 6e 75 6d 5f 69 |i = 0; i| < num_i|
|000034b0| 6e 73 74 61 6e 63 65 3b | 20 69 2b 2b 29 0a 58 09 |nstance;| i++).X.|
|000034c0| 09 69 66 20 28 21 73 74 | 72 63 6d 70 28 69 6e 73 |.if (!st|rcmp(ins|
|000034d0| 74 61 6e 63 65 73 5b 69 | 5d 2d 3e 6e 61 6d 65 2c |tances[i|]->name,|
|000034e0| 20 6e 61 6d 65 29 29 0a | 58 09 09 09 62 72 65 61 | name)).|X...brea|
|000034f0| 6b 3b 0a 58 0a 58 09 69 | 66 20 28 69 20 3d 3d 20 |k;.X.X.i|f (i == |
|00003500| 6e 75 6d 5f 69 6e 73 74 | 61 6e 63 65 29 0a 58 09 |num_inst|ance).X.|
|00003510| 7b 0a 58 09 09 66 70 72 | 69 6e 74 66 28 73 74 64 |{.X..fpr|intf(std|
|00003520| 65 72 72 2c 20 22 25 73 | 3a 20 69 6e 73 74 61 6e |err, "%s|: instan|
|00003530| 63 65 20 27 25 73 27 20 | 77 61 73 20 6e 65 76 65 |ce '%s' |was neve|
|00003540| 72 20 64 65 66 69 6e 65 | 64 2e 5c 6e 22 2c 20 6d |r define|d.\n", m|
|00003550| 79 5f 6e 61 6d 65 2c 0a | 58 09 09 09 6e 61 6d 65 |y_name,.|X...name|
|00003560| 29 3b 0a 58 09 09 72 65 | 74 75 72 6e 20 28 31 29 |);.X..re|turn (1)|
|00003570| 3b 0a 58 09 7d 0a 58 0a | 58 09 69 6e 73 74 20 3d |;.X.}.X.|X.inst =|
|00003580| 20 69 6e 73 74 61 6e 63 | 65 73 5b 69 5d 3b 0a 58 | instanc|es[i];.X|
|00003590| 0a 58 09 2f 2a 20 67 65 | 74 20 74 68 65 20 6f 66 |.X./* ge|t the of|
|000035a0| 66 73 65 74 20 66 6f 72 | 20 74 68 69 73 20 69 6e |fset for| this in|
|000035b0| 73 74 61 6e 63 65 20 2a | 2f 0a 58 09 69 66 20 28 |stance *|/.X.if (|
|000035c0| 73 73 63 61 6e 66 28 69 | 6e 66 6f 5f 70 74 72 2c |sscanf(i|nfo_ptr,|
|000035d0| 20 22 25 6c 67 20 25 6c | 67 20 25 6c 67 22 2c 20 | "%lg %l|g %lg", |
|000035e0| 26 6f 66 66 2e 78 2c 20 | 26 6f 66 66 2e 79 2c 20 |&off.x, |&off.y, |
|000035f0| 26 6f 66 66 2e 7a 29 20 | 21 3d 20 33 29 0a 58 09 |&off.z) |!= 3).X.|
|00003600| 7b 0a 58 09 09 66 70 72 | 69 6e 74 66 28 73 74 64 |{.X..fpr|intf(std|
|00003610| 65 72 72 2c 20 22 25 73 | 3a 20 6d 69 73 73 69 6e |err, "%s|: missin|
|00003620| 67 20 69 6e 73 74 61 6e | 63 65 20 6c 6f 63 61 74 |g instan|ce locat|
|00003630| 69 6f 6e 2e 5c 6e 22 2c | 20 6d 79 5f 6e 61 6d 65 |ion.\n",| my_name|
|00003640| 29 3b 0a 58 09 09 72 65 | 74 75 72 6e 20 28 31 29 |);.X..re|turn (1)|
|00003650| 3b 0a 58 09 7d 0a 58 0a | 58 09 2f 2a 20 73 6b 69 |;.X.}.X.|X./* ski|
|00003660| 70 20 74 68 65 20 66 69 | 72 73 74 20 6f 6e 65 20 |p the fi|rst one |
|00003670| 2a 2f 0a 58 09 69 6e 73 | 74 20 3d 20 69 6e 73 74 |*/.X.ins|t = inst|
|00003680| 2d 3e 6e 65 78 74 3b 0a | 58 0a 58 09 77 68 69 6c |->next;.|X.X.whil|
|00003690| 65 20 28 69 6e 73 74 29 | 0a 58 09 7b 0a 58 09 09 |e (inst)|.X.{.X..|
|000036a0| 73 77 69 74 63 68 20 28 | 69 6e 73 74 2d 3e 74 79 |switch (|inst->ty|
|000036b0| 70 65 29 0a 58 09 09 7b | 0a 58 09 09 63 61 73 65 |pe).X..{|.X..case|
|000036c0| 20 49 5f 53 55 52 46 41 | 43 45 3a 0a 58 09 09 09 | I_SURFA|CE:.X...|
|000036d0| 63 75 72 5f 73 75 72 66 | 61 63 65 20 3d 20 28 53 |cur_surf|ace = (S|
|000036e0| 55 52 46 41 43 45 20 2a | 29 20 69 6e 73 74 2d 3e |URFACE *|) inst->|
|000036f0| 64 61 74 61 3b 0a 58 09 | 09 09 62 72 65 61 6b 3b |data;.X.|..break;|
|00003700| 0a 58 0a 58 09 09 63 61 | 73 65 20 49 5f 4f 42 4a |.X.X..ca|se I_OBJ|
|00003710| 45 43 54 3a 0a 58 09 09 | 09 73 77 69 74 63 68 20 |ECT:.X..|.switch |
|00003720| 28 69 6e 73 74 2d 3e 73 | 75 62 74 79 70 65 29 0a |(inst->s|ubtype).|
|00003730| 58 09 09 09 7b 0a 58 09 | 09 09 63 61 73 65 20 54 |X...{.X.|..case T|
|00003740| 5f 50 4f 4c 59 47 4f 4e | 3a 0a 58 09 09 09 09 70 |_POLYGON|:.X....p|
|00003750| 31 20 3d 20 28 50 4f 4c | 59 47 4f 4e 20 2a 29 20 |1 = (POL|YGON *) |
|00003760| 69 6e 73 74 2d 3e 64 61 | 74 61 3b 0a 58 09 09 09 |inst->da|ta;.X...|
|00003770| 09 73 69 7a 65 20 3d 20 | 73 69 7a 65 6f 66 28 50 |.size = |sizeof(P|
|00003780| 4f 4c 59 47 4f 4e 29 20 | 2b 20 28 73 69 7a 65 6f |OLYGON) |+ (sizeo|
|00003790| 66 28 56 45 43 54 4f 52 | 29 20 2a 20 28 70 31 2d |f(VECTOR|) * (p1-|
|000037a0| 3e 6e 70 6f 69 6e 74 73 | 20 2d 20 31 29 29 3b 0a |>npoints| - 1));.|
|000037b0| 58 09 09 09 09 69 66 20 | 28 28 70 20 3d 20 28 50 |X....if |((p = (P|
|000037c0| 4f 4c 59 47 4f 4e 20 2a | 29 20 6d 61 6c 6c 6f 63 |OLYGON *|) malloc|
|000037d0| 28 73 69 7a 65 29 29 20 | 3d 3d 20 4e 55 4c 4c 29 |(size)) |== NULL)|
|000037e0| 0a 58 09 09 09 09 09 42 | 61 64 5f 6d 61 6c 6c 6f |.X.....B|ad_mallo|
|000037f0| 63 28 29 3b 0a 58 09 09 | 09 09 6d 65 6d 63 70 79 |c();.X..|..memcpy|
|00003800| 28 70 2c 20 70 31 2c 20 | 73 69 7a 65 29 3b 0a 58 |(p, p1, |size);.X|
|00003810| 0a 58 09 09 09 09 66 6f | 72 20 28 69 20 3d 20 30 |.X....fo|r (i = 0|
|00003820| 3b 20 69 20 3c 20 70 2d | 3e 6e 70 6f 69 6e 74 73 |; i < p-|>npoints|
|00003830| 3b 20 69 2b 2b 29 0a 58 | 09 09 09 09 7b 0a 58 09 |; i++).X|....{.X.|
|00003840| 09 09 09 09 56 65 63 41 | 64 64 28 6f 66 66 2c 20 |....VecA|dd(off, |
|00003850| 70 2d 3e 70 6f 69 6e 74 | 73 5b 69 5d 2c 20 70 2d |p->point|s[i], p-|
|00003860| 3e 70 6f 69 6e 74 73 5b | 69 5d 29 3b 0a 58 09 09 |>points[|i]);.X..|
|00003870| 09 09 7d 0a 58 09 09 09 | 09 42 75 69 6c 64 5f 70 |..}.X...|.Build_p|
|00003880| 6f 6c 79 28 70 29 3b 0a | 58 09 09 09 09 62 72 65 |oly(p);.|X....bre|
|00003890| 61 6b 3b 0a 58 0a 58 09 | 09 09 63 61 73 65 20 54 |ak;.X.X.|..case T|
|000038a0| 5f 53 50 48 45 52 45 3a | 0a 58 09 09 09 09 69 66 |_SPHERE:|.X....if|
|000038b0| 20 28 28 73 20 3d 20 28 | 53 50 48 45 52 45 20 2a | ((s = (|SPHERE *|
|000038c0| 29 20 6d 61 6c 6c 6f 63 | 28 73 69 7a 65 6f 66 28 |) malloc|(sizeof(|
|000038d0| 53 50 48 45 52 45 29 29 | 29 20 3d 3d 20 4e 55 4c |SPHERE))|) == NUL|
|000038e0| 4c 29 0a 58 09 09 09 09 | 09 42 61 64 5f 6d 61 6c |L).X....|.Bad_mal|
|000038f0| 6c 6f 63 28 29 3b 0a 58 | 0a 58 09 09 09 09 6d 65 |loc();.X|.X....me|
|00003900| 6d 63 70 79 28 73 2c 20 | 69 6e 73 74 2d 3e 64 61 |mcpy(s, |inst->da|
|00003910| 74 61 2c 20 73 69 7a 65 | 6f 66 28 53 50 48 45 52 |ta, size|of(SPHER|
|00003920| 45 29 29 3b 0a 58 0a 58 | 09 09 09 09 56 65 63 41 |E));.X.X|....VecA|
|00003930| 64 64 28 6f 66 66 2c 20 | 73 2d 3e 63 65 6e 74 65 |dd(off, |s->cente|
|00003940| 72 2c 20 73 2d 3e 63 65 | 6e 74 65 72 29 3b 0a 58 |r, s->ce|nter);.X|
|00003950| 09 09 09 09 42 75 69 6c | 64 5f 73 70 68 65 72 65 |....Buil|d_sphere|
|00003960| 28 73 29 3b 0a 58 09 09 | 09 09 62 72 65 61 6b 3b |(s);.X..|..break;|
|00003970| 0a 58 0a 58 09 09 09 63 | 61 73 65 20 54 5f 48 53 |.X.X...c|ase T_HS|
|00003980| 50 48 45 52 45 3a 0a 58 | 09 09 09 09 69 66 20 28 |PHERE:.X|....if (|
|00003990| 28 68 73 20 3d 20 28 48 | 53 50 48 45 52 45 20 2a |(hs = (H|SPHERE *|
|000039a0| 29 20 6d 61 6c 6c 6f 63 | 28 73 69 7a 65 6f 66 28 |) malloc|(sizeof(|
|000039b0| 48 53 50 48 45 52 45 29 | 29 29 20 3d 3d 20 4e 55 |HSPHERE)|)) == NU|
|000039c0| 4c 4c 29 0a 58 09 09 09 | 09 09 42 61 64 5f 6d 61 |LL).X...|..Bad_ma|
|000039d0| 6c 6c 6f 63 28 29 3b 0a | 58 0a 58 09 09 09 09 6d |lloc();.|X.X....m|
|000039e0| 65 6d 63 70 79 28 68 73 | 2c 20 69 6e 73 74 2d 3e |emcpy(hs|, inst->|
|000039f0| 64 61 74 61 2c 20 73 69 | 7a 65 6f 66 28 48 53 50 |data, si|zeof(HSP|
|00003a00| 48 45 52 45 29 29 3b 0a | 58 09 09 09 09 56 65 63 |HERE));.|X....Vec|
|00003a10| 41 64 64 28 6f 66 66 2c | 20 68 73 2d 3e 63 65 6e |Add(off,| hs->cen|
|00003a20| 74 65 72 2c 20 68 73 2d | 3e 63 65 6e 74 65 72 29 |ter, hs-|>center)|
|00003a30| 3b 0a 58 09 09 09 09 42 | 75 69 6c 64 5f 68 73 70 |;.X....B|uild_hsp|
|00003a40| 68 65 72 65 28 68 73 29 | 3b 0a 58 09 09 09 09 62 |here(hs)|;.X....b|
|00003a50| 72 65 61 6b 3b 0a 58 0a | 58 09 09 09 63 61 73 65 |reak;.X.|X...case|
|00003a60| 20 54 5f 43 4f 4e 45 3a | 0a 58 09 09 09 09 69 66 | T_CONE:|.X....if|
|00003a70| 20 28 28 63 20 3d 20 28 | 43 4f 4e 45 20 2a 29 20 | ((c = (|CONE *) |
|00003a80| 6d 61 6c 6c 6f 63 28 73 | 69 7a 65 6f 66 28 43 4f |malloc(s|izeof(CO|
|00003a90| 4e 45 29 29 29 20 3d 3d | 20 4e 55 4c 4c 29 0a 58 |NE))) ==| NULL).X|
|00003aa0| 09 09 09 09 09 42 61 64 | 5f 6d 61 6c 6c 6f 63 28 |.....Bad|_malloc(|
|00003ab0| 29 3b 0a 58 09 09 09 09 | 6d 65 6d 63 70 79 28 63 |);.X....|memcpy(c|
|00003ac0| 2c 20 69 6e 73 74 2d 3e | 64 61 74 61 2c 20 73 69 |, inst->|data, si|
|00003ad0| 7a 65 6f 66 28 43 4f 4e | 45 29 29 3b 0a 58 0a 58 |zeof(CON|E));.X.X|
|00003ae0| 09 09 09 09 56 65 63 41 | 64 64 28 6f 66 66 2c 20 |....VecA|dd(off, |
|00003af0| 63 2d 3e 62 61 73 65 2c | 20 63 2d 3e 62 61 73 65 |c->base,| c->base|
|00003b00| 29 3b 0a 58 09 09 09 09 | 56 65 63 41 64 64 28 6f |);.X....|VecAdd(o|
|00003b10| 66 66 2c 20 63 2d 3e 61 | 70 65 78 2c 20 63 2d 3e |ff, c->a|pex, c->|
|00003b20| 61 70 65 78 29 3b 0a 58 | 09 09 09 09 42 75 69 6c |apex);.X|....Buil|
|00003b30| 64 5f 63 6f 6e 65 28 63 | 29 3b 0a 58 09 09 09 09 |d_cone(c|);.X....|
|00003b40| 62 72 65 61 6b 3b 0a 58 | 0a 58 09 09 09 63 61 73 |break;.X|.X...cas|
|00003b50| 65 20 54 5f 52 49 4e 47 | 3a 0a 58 09 09 09 09 69 |e T_RING|:.X....i|
|00003b60| 66 20 28 28 72 20 3d 20 | 28 52 49 4e 47 20 2a 29 |f ((r = |(RING *)|
|00003b70| 20 6d 61 6c 6c 6f 63 28 | 73 69 7a 65 6f 66 28 52 | malloc(|sizeof(R|
|00003b80| 49 4e 47 29 29 29 20 3d | 3d 20 4e 55 4c 4c 29 0a |ING))) =|= NULL).|
|00003b90| 58 09 09 09 09 09 42 61 | 64 5f 6d 61 6c 6c 6f 63 |X.....Ba|d_malloc|
|00003ba0| 28 29 3b 0a 58 09 09 09 | 09 6d 65 6d 63 70 79 28 |();.X...|.memcpy(|
|00003bb0| 72 2c 20 69 6e 73 74 2d | 3e 64 61 74 61 2c 20 73 |r, inst-|>data, s|
|00003bc0| 69 7a 65 6f 66 28 52 49 | 4e 47 29 29 3b 0a 58 0a |izeof(RI|NG));.X.|
|00003bd0| 58 09 09 09 09 56 65 63 | 41 64 64 28 6f 66 66 2c |X....Vec|Add(off,|
|00003be0| 20 72 2d 3e 63 65 6e 74 | 65 72 2c 20 72 2d 3e 63 | r->cent|er, r->c|
|00003bf0| 65 6e 74 65 72 29 3b 0a | 58 09 09 09 09 56 65 63 |enter);.|X....Vec|
|00003c00| 41 64 64 28 6f 66 66 2c | 20 72 2d 3e 70 6f 69 6e |Add(off,| r->poin|
|00003c10| 74 31 2c 20 72 2d 3e 70 | 6f 69 6e 74 31 29 3b 0a |t1, r->p|oint1);.|
|00003c20| 58 09 09 09 09 56 65 63 | 41 64 64 28 6f 66 66 2c |X....Vec|Add(off,|
|00003c30| 20 72 2d 3e 70 6f 69 6e | 74 32 2c 20 72 2d 3e 70 | r->poin|t2, r->p|
|00003c40| 6f 69 6e 74 32 29 3b 0a | 58 0a 58 09 09 09 09 42 |oint2);.|X.X....B|
|00003c50| 75 69 6c 64 5f 72 69 6e | 67 28 72 29 3b 0a 58 09 |uild_rin|g(r);.X.|
|00003c60| 09 09 09 62 72 65 61 6b | 3b 0a 58 0a 58 09 09 09 |...break|;.X.X...|
|00003c70| 63 61 73 65 20 54 5f 51 | 55 41 44 52 49 43 3a 0a |case T_Q|UADRIC:.|
|00003c80| 58 09 09 09 09 69 66 20 | 28 28 71 20 3d 20 28 51 |X....if |((q = (Q|
|00003c90| 55 41 44 52 49 43 20 2a | 29 20 6d 61 6c 6c 6f 63 |UADRIC *|) malloc|
|00003ca0| 28 73 69 7a 65 6f 66 28 | 51 55 41 44 52 49 43 29 |(sizeof(|QUADRIC)|
|00003cb0| 29 29 20 3d 3d 20 4e 55 | 4c 4c 29 0a 58 09 09 09 |)) == NU|LL).X...|
|00003cc0| 09 09 42 61 64 5f 6d 61 | 6c 6c 6f 63 28 29 3b 0a |..Bad_ma|lloc();.|
|00003cd0| 58 09 09 09 09 6d 65 6d | 63 70 79 28 71 2c 20 69 |X....mem|cpy(q, i|
|00003ce0| 6e 73 74 2d 3e 64 61 74 | 61 2c 20 73 69 7a 65 6f |nst->dat|a, sizeo|
|00003cf0| 66 28 51 55 41 44 52 49 | 43 29 29 3b 0a 58 0a 58 |f(QUADRI|C));.X.X|
|00003d00| 09 09 09 09 56 65 63 41 | 64 64 28 6f 66 66 2c 20 |....VecA|dd(off, |
|00003d10| 71 2d 3e 6c 6f 63 2c 20 | 71 2d 3e 6c 6f 63 29 3b |q->loc, |q->loc);|
|00003d20| 0a 58 09 09 09 09 56 65 | 63 41 64 64 28 6f 66 66 |.X....Ve|cAdd(off|
|00003d30| 2c 20 71 2d 3e 6d 69 6e | 2c 20 71 2d 3e 6d 69 6e |, q->min|, q->min|
|00003d40| 29 3b 0a 58 09 09 09 09 | 56 65 63 41 64 64 28 6f |);.X....|VecAdd(o|
|00003d50| 66 66 2c 20 71 2d 3e 6d | 61 78 2c 20 71 2d 3e 6d |ff, q->m|ax, q->m|
|00003d60| 61 78 29 3b 0a 58 0a 58 | 09 09 09 09 42 75 69 6c |ax);.X.X|....Buil|
|00003d70| 64 5f 71 75 61 64 72 69 | 63 28 71 29 3b 0a 58 09 |d_quadri|c(q);.X.|
|00003d80| 09 09 09 62 72 65 61 6b | 3b 0a 58 0a 58 09 09 09 |...break|;.X.X...|
|00003d90| 64 65 66 61 75 6c 74 3a | 0a 58 09 09 09 09 66 70 |default:|.X....fp|
|00003da0| 72 69 6e 74 66 28 73 74 | 64 65 72 72 2c 20 22 25 |rintf(st|derr, "%|
|00003db0| 73 3a 20 69 6e 74 65 72 | 6e 61 6c 20 65 72 72 6f |s: inter|nal erro|
|00003dc0| 72 20 30 31 2e 5c 6e 22 | 2c 20 6d 79 5f 6e 61 6d |r 01.\n"|, my_nam|
|00003dd0| 65 29 3b 0a 58 09 09 09 | 09 72 65 74 75 72 6e 20 |e);.X...|.return |
|00003de0| 28 31 29 3b 0a 58 09 09 | 09 7d 0a 58 09 09 09 62 |(1);.X..|.}.X...b|
|00003df0| 72 65 61 6b 3b 0a 58 0a | 58 09 09 64 65 66 61 75 |reak;.X.|X..defau|
|00003e00| 6c 74 3a 0a 58 09 09 09 | 66 70 72 69 6e 74 66 28 |lt:.X...|fprintf(|
|00003e10| 73 74 64 65 72 72 2c 20 | 22 25 73 3a 20 69 6e 74 |stderr, |"%s: int|
|00003e20| 65 72 6e 61 6c 20 65 72 | 72 6f 72 20 30 32 2e 5c |ernal er|ror 02.\|
|00003e30| 6e 22 2c 20 6d 79 5f 6e | 61 6d 65 29 3b 0a 58 09 |n", my_n|ame);.X.|
|00003e40| 09 09 72 65 74 75 72 6e | 20 28 31 29 3b 0a 58 09 |..return| (1);.X.|
|00003e50| 09 7d 0a 58 0a 58 09 09 | 69 6e 73 74 20 3d 20 69 |.}.X.X..|inst = i|
|00003e60| 6e 73 74 2d 3e 6e 65 78 | 74 3b 0a 58 09 7d 0a 58 |nst->nex|t;.X.}.X|
|00003e70| 0a 58 09 72 65 74 75 72 | 6e 20 28 30 29 3b 0a 58 |.X.retur|n (0);.X|
|00003e80| 7d 0a 58 0a 58 0a 58 2f | 2a 0a 58 20 2a 20 41 64 |}.X.X.X/|*.X * Ad|
|00003e90| 64 5f 74 6f 5f 69 6c 69 | 73 74 28 29 0a 58 20 2a |d_to_ili|st().X *|
|00003ea0| 20 0a 58 20 2a 20 41 64 | 64 20 74 68 65 20 67 69 | .X * Ad|d the gi|
|00003eb0| 76 65 6e 20 6f 62 6a 65 | 63 74 2f 73 75 72 66 61 |ven obje|ct/surfa|
|00003ec0| 63 65 20 74 6f 20 74 68 | 65 20 65 6e 64 20 6f 66 |ce to th|e end of|
|00003ed0| 20 74 68 65 20 63 75 72 | 72 65 6e 74 20 69 6e 73 | the cur|rent ins|
|00003ee0| 74 61 6e 63 65 20 6c 69 | 6e 6b 20 6c 69 73 74 2e |tance li|nk list.|
|00003ef0| 0a 58 20 2a 2f 0a 58 0a | 58 41 64 64 5f 74 6f 5f |.X */.X.|XAdd_to_|
|00003f00| 69 6c 69 73 74 28 64 61 | 74 61 2c 20 74 79 70 65 |ilist(da|ta, type|
|00003f10| 2c 20 73 75 62 74 79 70 | 65 29 0a 58 76 6f 69 64 |, subtyp|e).Xvoid|
|00003f20| 20 20 20 20 20 20 20 20 | 20 20 20 2a 64 61 74 61 | | *data|
|00003f30| 3b 0a 58 69 6e 74 20 20 | 20 20 20 20 20 20 20 20 |;.Xint | |
|00003f40| 20 20 20 74 79 70 65 3b | 0a 58 69 6e 74 20 20 20 | type;|.Xint |
|00003f50| 20 20 20 20 20 20 20 20 | 20 20 73 75 62 74 79 70 | | subtyp|
|00003f60| 65 3b 0a 58 7b 0a 58 09 | 49 4e 53 54 41 4e 43 45 |e;.X{.X.|INSTANCE|
|00003f70| 20 20 20 20 20 20 20 2a | 69 31 2c 20 2a 69 32 3b | *|i1, *i2;|
|00003f80| 0a 58 0a 58 09 2f 2a 20 | 61 6c 6c 6f 63 61 74 65 |.X.X./* |allocate|
|00003f90| 20 61 6e 20 69 6e 73 74 | 61 6e 63 65 20 73 74 72 | an inst|ance str|
|00003fa0| 75 63 74 75 72 65 20 2a | 2f 0a 58 09 69 66 20 28 |ucture *|/.X.if (|
|00003fb0| 28 69 31 20 3d 20 28 49 | 4e 53 54 41 4e 43 45 20 |(i1 = (I|NSTANCE |
|00003fc0| 2a 29 20 6d 61 6c 6c 6f | 63 28 73 69 7a 65 6f 66 |*) mallo|c(sizeof|
|00003fd0| 28 49 4e 53 54 41 4e 43 | 45 29 29 29 20 3d 3d 20 |(INSTANC|E))) == |
|00003fe0| 4e 55 4c 4c 29 0a 58 09 | 09 42 61 64 5f 6d 61 6c |NULL).X.|.Bad_mal|
|00003ff0| 6c 6f 63 28 29 3b 0a 58 | 0a 58 09 69 32 20 3d 20 |loc();.X|.X.i2 = |
|00004000| 69 6e 73 74 61 6e 63 65 | 73 5b 6e 75 6d 5f 69 6e |instance|s[num_in|
|00004010| 73 74 61 6e 63 65 5d 3b | 0a 58 09 77 68 69 6c 65 |stance];|.X.while|
|00004020| 20 28 69 32 2d 3e 6e 65 | 78 74 29 0a 58 09 09 69 | (i2->ne|xt).X..i|
|00004030| 32 20 3d 20 69 32 2d 3e | 6e 65 78 74 3b 0a 58 0a |2 = i2->|next;.X.|
|00004040| 58 09 69 32 2d 3e 6e 65 | 78 74 20 3d 20 69 31 3b |X.i2->ne|xt = i1;|
|00004050| 0a 58 09 69 31 2d 3e 6e | 65 78 74 20 3d 20 28 76 |.X.i1->n|ext = (v|
|00004060| 6f 69 64 20 2a 29 20 30 | 3b 0a 58 09 69 31 2d 3e |oid *) 0|;.X.i1->|
|00004070| 64 61 74 61 20 3d 20 64 | 61 74 61 3b 0a 58 09 69 |data = d|ata;.X.i|
|00004080| 31 2d 3e 74 79 70 65 20 | 3d 20 74 79 70 65 3b 0a |1->type |= type;.|
|00004090| 58 09 69 31 2d 3e 73 75 | 62 74 79 70 65 20 3d 20 |X.i1->su|btype = |
|000040a0| 73 75 62 74 79 70 65 3b | 0a 58 0a 58 7d 0a 45 4e |subtype;|.X.X}.EN|
|000040b0| 44 5f 4f 46 5f 46 49 4c | 45 0a 69 66 20 74 65 73 |D_OF_FIL|E.if tes|
|000040c0| 74 20 31 34 37 37 32 20 | 2d 6e 65 20 60 77 63 20 |t 14772 |-ne `wc |
|000040d0| 2d 63 20 3c 27 69 6e 70 | 75 74 2e 63 27 60 3b 20 |-c <'inp|ut.c'`; |
|000040e0| 74 68 65 6e 0a 20 20 20 | 20 65 63 68 6f 20 73 68 |then. | echo sh|
|000040f0| 61 72 3a 20 5c 22 27 69 | 6e 70 75 74 2e 63 27 5c |ar: \"'i|nput.c'\|
|00004100| 22 20 75 6e 70 61 63 6b | 65 64 20 77 69 74 68 20 |" unpack|ed with |
|00004110| 77 72 6f 6e 67 20 73 69 | 7a 65 21 0a 66 69 0a 23 |wrong si|ze!.fi.#|
|00004120| 20 65 6e 64 20 6f 66 20 | 27 69 6e 70 75 74 2e 63 | end of |'input.c|
|00004130| 27 0a 66 69 0a 65 63 68 | 6f 20 73 68 61 72 3a 20 |'.fi.ech|o shar: |
|00004140| 45 6e 64 20 6f 66 20 61 | 72 63 68 69 76 65 20 33 |End of a|rchive 3|
|00004150| 20 5c 28 6f 66 20 33 5c | 29 2e 0a 63 70 20 2f 64 | \(of 3\|)..cp /d|
|00004160| 65 76 2f 6e 75 6c 6c 20 | 61 72 6b 33 69 73 64 6f |ev/null |ark3isdo|
|00004170| 6e 65 0a 4d 49 53 53 49 | 4e 47 3d 22 22 0a 66 6f |ne.MISSI|NG="".fo|
|00004180| 72 20 49 20 69 6e 20 31 | 20 32 20 33 20 3b 20 64 |r I in 1| 2 3 ; d|
|00004190| 6f 0a 20 20 20 20 69 66 | 20 74 65 73 74 20 21 20 |o. if| test ! |
|000041a0| 2d 66 20 61 72 6b 24 7b | 49 7d 69 73 64 6f 6e 65 |-f ark${|I}isdone|
|000041b0| 20 3b 20 74 68 65 6e 0a | 09 4d 49 53 53 49 4e 47 | ; then.|.MISSING|
|000041c0| 3d 22 24 7b 4d 49 53 53 | 49 4e 47 7d 20 24 7b 49 |="${MISS|ING} ${I|
|000041d0| 7d 22 0a 20 20 20 20 66 | 69 0a 64 6f 6e 65 0a 69 |}". f|i.done.i|
|000041e0| 66 20 74 65 73 74 20 22 | 24 7b 4d 49 53 53 49 4e |f test "|${MISSIN|
|000041f0| 47 7d 22 20 3d 20 22 22 | 20 3b 20 74 68 65 6e 0a |G}" = ""| ; then.|
|00004200| 20 20 20 20 65 63 68 6f | 20 59 6f 75 20 68 61 76 | echo| You hav|
|00004210| 65 20 75 6e 70 61 63 6b | 65 64 20 61 6c 6c 20 33 |e unpack|ed all 3|
|00004220| 20 61 72 63 68 69 76 65 | 73 2e 0a 20 20 20 20 72 | archive|s.. r|
|00004230| 6d 20 2d 66 20 61 72 6b | 5b 31 2d 39 5d 69 73 64 |m -f ark|[1-9]isd|
|00004240| 6f 6e 65 0a 65 6c 73 65 | 0a 20 20 20 20 65 63 68 |one.else|. ech|
|00004250| 6f 20 59 6f 75 20 73 74 | 69 6c 6c 20 6e 65 65 64 |o You st|ill need|
|00004260| 20 74 6f 20 75 6e 70 61 | 63 6b 20 74 68 65 20 66 | to unpa|ck the f|
|00004270| 6f 6c 6c 6f 77 69 6e 67 | 20 61 72 63 68 69 76 65 |ollowing| archive|
|00004280| 73 3a 0a 20 20 20 20 65 | 63 68 6f 20 22 20 20 20 |s:. e|cho " |
|00004290| 20 20 20 20 20 22 20 24 | 7b 4d 49 53 53 49 4e 47 | " $|{MISSING|
|000042a0| 7d 0a 66 69 0a 23 23 20 | 20 45 6e 64 20 6f 66 20 |}.fi.## | End of |
|000042b0| 73 68 65 6c 6c 20 61 72 | 63 68 69 76 65 2e 0a 65 |shell ar|chive..e|
|000042c0| 78 69 74 20 30 0a 2d 2d | 20 0a 2d 2d 2d 2d 2d 2d |xit 0.--| .------|
|000042d0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000042e0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000042f0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00004300| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00004310| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 0a 4b 6f 72 79 20 48 |--------|-.Kory H|
|00004320| 61 6d 7a 65 68 20 20 20 | 20 20 20 20 20 20 20 20 |amzeh | |
|00004330| 20 20 55 55 43 50 3a 20 | 61 76 61 74 61 72 21 6b | UUCP: |avatar!k|
|00004340| 6f 72 79 20 6f 72 20 2e | 2e 21 75 75 6e 65 74 21 |ory or .|.!uunet!|
|00004350| 61 76 61 74 61 72 21 6b | 6f 72 79 0a 20 20 20 20 |avatar!k|ory. |
|00004360| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00004370| 49 4e 54 45 52 4e 45 54 | 3a 20 6b 6f 72 79 40 61 |INTERNET|: kory@a|
|00004380| 76 61 74 61 72 2e 63 6f | 6d 20 0a |vatar.co|m . |
+--------+-------------------------+-------------------------+--------+--------+