home *** CD-ROM | disk | FTP | other *** search
/ Usenet 1994 January / usenetsourcesnewsgroupsinfomagicjanuary1994.iso / sources / unix / volume14 / rast < prev    next >
SHell self-extracting ARchive  |  1988-05-08  |  17.2 KB

view JSON data     |     view as text     |     open on a Mac     |     open on a PC

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

You can browse this item here: rast

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 text default
99% file C source text default
98% file makefile script text default
97% file C source, 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 31 34 69 30 38 |Subject:| v14i08|
|00000010| 36 3a 20 20 53 75 6e 20 | 72 61 73 74 65 72 66 69 |6: Sun |rasterfi|
|00000020| 6c 65 20 49 2f 4f 20 6c | 69 62 72 61 72 79 0a 4e |le I/O l|ibrary.N|
|00000030| 65 77 73 67 72 6f 75 70 | 73 3a 20 63 6f 6d 70 2e |ewsgroup|s: comp.|
|00000040| 73 6f 75 72 63 65 73 2e | 75 6e 69 78 0a 53 65 6e |sources.|unix.Sen|
|00000050| 64 65 72 3a 20 73 6f 75 | 72 63 65 73 0a 41 70 70 |der: sou|rces.App|
|00000060| 72 6f 76 65 64 3a 20 72 | 73 61 6c 7a 40 75 75 6e |roved: r|salz@uun|
|00000070| 65 74 2e 55 55 2e 4e 45 | 54 0a 0a 53 75 62 6d 69 |et.UU.NE|T..Submi|
|00000080| 74 74 65 64 2d 62 79 3a | 20 4d 61 72 63 20 4d 61 |tted-by:| Marc Ma|
|00000090| 6a 6b 61 20 3c 6d 61 6a | 6b 61 40 67 72 61 64 73 |jka <maj|ka@grads|
|000000a0| 2e 63 73 2e 75 62 63 2e | 63 64 6e 3e 0a 50 6f 73 |.cs.ubc.|cdn>.Pos|
|000000b0| 74 69 6e 67 2d 6e 75 6d | 62 65 72 3a 20 56 6f 6c |ting-num|ber: Vol|
|000000c0| 75 6d 65 20 31 34 2c 20 | 49 73 73 75 65 20 38 36 |ume 14, |Issue 86|
|000000d0| 0a 41 72 63 68 69 76 65 | 2d 6e 61 6d 65 3a 20 72 |.Archive|-name: r|
|000000e0| 61 73 74 0a 0a 48 65 72 | 65 20 69 73 20 61 20 73 |ast..Her|e is a s|
|000000f0| 65 74 20 6f 66 20 6c 69 | 62 72 61 72 79 20 73 75 |et of li|brary su|
|00000100| 62 72 6f 75 74 69 6e 65 | 73 20 77 68 69 63 68 20 |broutine|s which |
|00000110| 49 20 68 61 76 65 20 66 | 6f 75 6e 64 20 75 73 65 |I have f|ound use|
|00000120| 66 75 6c 20 66 6f 72 20 | 72 65 61 64 69 6e 67 0a |ful for |reading.|
|00000130| 61 6e 64 20 77 72 69 74 | 69 6e 67 20 53 55 4e 20 |and writ|ing SUN |
|00000140| 72 61 73 74 65 72 66 69 | 6c 65 73 2e 20 20 54 68 |rasterfi|les. Th|
|00000150| 65 20 70 61 63 6b 61 67 | 65 20 63 6f 6e 74 61 69 |e packag|e contai|
|00000160| 6e 73 20 61 6c 6c 20 74 | 68 65 20 75 73 75 61 6c |ns all t|he usual|
|00000170| 20 73 74 75 66 66 3a 0a | 52 45 41 44 4d 45 2c 20 | stuff:.|README, |
|00000180| 4d 61 6b 65 66 69 6c 65 | 2c 20 73 6f 75 72 63 65 |Makefile|, source|
|00000190| 73 2c 20 6d 61 6e 75 61 | 6c 73 2c 20 61 6e 64 20 |s, manua|ls, and |
|000001a0| 61 20 63 6f 75 70 6c 65 | 20 6f 66 20 73 61 6d 70 |a couple| of samp|
|000001b0| 6c 65 20 70 72 6f 67 72 | 61 6d 73 2e 0a 0a 49 20 |le progr|ams...I |
|000001c0| 68 61 76 65 20 74 65 73 | 74 65 64 20 61 6e 64 20 |have tes|ted and |
|000001d0| 64 65 62 75 67 67 65 64 | 20 74 68 65 20 6c 69 62 |debugged| the lib|
|000001e0| 72 61 72 79 20 74 6f 20 | 73 6f 6d 65 20 65 78 74 |rary to |some ext|
|000001f0| 65 6e 74 2c 20 62 75 74 | 20 6c 6f 63 61 6c 20 68 |ent, but| local h|
|00000200| 61 72 64 77 61 72 65 0a | 6c 69 6d 69 74 61 74 69 |ardware.|limitati|
|00000210| 6f 6e 73 20 70 72 65 63 | 6c 75 64 65 64 20 6d 79 |ons prec|luded my|
|00000220| 20 66 72 6f 6d 20 67 69 | 76 69 6e 67 20 74 68 65 | from gi|ving the|
|00000230| 6d 20 61 20 76 69 67 6f | 72 6f 75 73 20 77 6f 72 |m a vigo|rous wor|
|00000240| 6b 6f 75 74 2e 20 20 54 | 68 65 72 65 20 6d 61 79 |kout. T|here may|
|00000250| 0a 62 65 20 62 75 67 73 | 2e 20 20 49 66 20 79 6f |.be bugs|. If yo|
|00000260| 75 20 66 69 6e 64 20 6f | 72 20 66 69 78 20 61 6e |u find o|r fix an|
|00000270| 79 2c 20 70 6c 65 61 73 | 65 20 6c 65 74 20 6d 65 |y, pleas|e let me|
|00000280| 20 6b 6e 6f 77 21 0a 0a | 2d 2d 2d 0a 4d 61 72 63 | know!..|---.Marc|
|00000290| 20 4d 61 6a 6b 61 0a 0a | 23 21 20 2f 62 69 6e 2f | Majka..|#! /bin/|
|000002a0| 73 68 0a 23 20 54 68 69 | 73 20 69 73 20 61 20 73 |sh.# Thi|s is a s|
|000002b0| 68 65 6c 6c 20 61 72 63 | 68 69 76 65 2c 20 6d 65 |hell arc|hive, me|
|000002c0| 61 6e 69 6e 67 3a 0a 23 | 20 31 2e 20 52 65 6d 6f |aning:.#| 1. Remo|
|000002d0| 76 65 20 65 76 65 72 79 | 74 68 69 6e 67 20 61 62 |ve every|thing ab|
|000002e0| 6f 76 65 20 74 68 65 20 | 23 21 20 2f 62 69 6e 2f |ove the |#! /bin/|
|000002f0| 73 68 20 6c 69 6e 65 2e | 0a 23 20 32 2e 20 53 61 |sh line.|.# 2. Sa|
|00000300| 76 65 20 74 68 65 20 72 | 65 73 75 6c 74 69 6e 67 |ve the r|esulting|
|00000310| 20 74 65 78 74 20 69 6e | 20 61 20 66 69 6c 65 2e | text in| a file.|
|00000320| 0a 23 20 33 2e 20 45 78 | 65 63 75 74 65 20 74 68 |.# 3. Ex|ecute th|
|00000330| 65 20 66 69 6c 65 20 77 | 69 74 68 20 2f 62 69 6e |e file w|ith /bin|
|00000340| 2f 73 68 20 28 6e 6f 74 | 20 63 73 68 29 20 74 6f |/sh (not| csh) to|
|00000350| 20 63 72 65 61 74 65 20 | 74 68 65 20 66 69 6c 65 | create |the file|
|00000360| 73 3a 0a 23 09 52 45 41 | 44 4d 45 0a 23 09 4d 61 |s:.#.REA|DME.#.Ma|
|00000370| 6b 65 66 69 6c 65 0a 23 | 09 72 61 73 74 2e 63 0a |kefile.#|.rast.c.|
|00000380| 23 09 72 61 73 74 2e 68 | 0a 23 09 72 61 73 74 2e |#.rast.h|.#.rast.|
|00000390| 33 0a 23 09 72 64 65 6d | 6f 2e 63 0a 23 09 72 73 |3.#.rdem|o.c.#.rs|
|000003a0| 65 65 2e 63 0a 65 78 70 | 6f 72 74 20 50 41 54 48 |ee.c.exp|ort PATH|
|000003b0| 3b 20 50 41 54 48 3d 2f | 62 69 6e 3a 24 50 41 54 |; PATH=/|bin:$PAT|
|000003c0| 48 0a 69 66 20 74 65 73 | 74 20 2d 66 20 27 52 45 |H.if tes|t -f 'RE|
|000003d0| 41 44 4d 45 27 0a 74 68 | 65 6e 0a 09 65 63 68 6f |ADME'.th|en..echo|
|000003e0| 20 73 68 61 72 3a 20 77 | 69 6c 6c 20 6e 6f 74 20 | shar: w|ill not |
|000003f0| 6f 76 65 72 2d 77 72 69 | 74 65 20 65 78 69 73 74 |over-wri|te exist|
|00000400| 69 6e 67 20 66 69 6c 65 | 20 22 27 52 45 41 44 4d |ing file| "'READM|
|00000410| 45 27 22 0a 65 6c 73 65 | 0a 63 61 74 20 3c 3c 20 |E'".else|.cat << |
|00000420| 5c 53 48 41 52 5f 45 4f | 46 20 3e 20 27 52 45 41 |\SHAR_EO|F > 'REA|
|00000430| 44 4d 45 27 0a 54 68 69 | 73 20 70 61 63 6b 61 67 |DME'.Thi|s packag|
|00000440| 65 20 63 6f 6e 74 61 69 | 6e 73 20 61 20 6c 69 62 |e contai|ns a lib|
|00000450| 72 61 72 79 20 6f 66 20 | 72 6f 75 74 69 6e 65 73 |rary of |routines|
|00000460| 20 66 6f 72 20 72 65 61 | 64 69 6e 67 20 61 6e 64 | for rea|ding and|
|00000470| 20 77 72 69 74 69 6e 67 | 0a 53 55 4e 20 72 61 73 | writing|.SUN ras|
|00000480| 74 65 72 66 69 6c 65 73 | 20 69 6e 20 61 20 70 69 |terfiles| in a pi|
|00000490| 78 65 6c 2d 61 74 2d 61 | 2d 74 69 6d 65 20 6d 61 |xel-at-a|-time ma|
|000004a0| 6e 6e 65 72 2e 20 20 54 | 68 65 20 72 6f 75 74 69 |nner. T|he routi|
|000004b0| 6e 65 73 20 6d 61 69 6e | 74 61 69 6e 0a 61 20 64 |nes main|tain.a d|
|000004c0| 61 74 61 20 73 74 72 75 | 63 74 75 72 65 20 63 61 |ata stru|cture ca|
|000004d0| 6c 6c 65 64 20 61 20 52 | 41 53 54 45 52 2c 20 77 |lled a R|ASTER, w|
|000004e0| 68 69 63 68 20 63 6f 6e | 74 61 69 6e 73 20 61 6c |hich con|tains al|
|000004f0| 6c 20 74 68 65 20 75 73 | 75 61 6c 20 66 69 6c 65 |l the us|ual file|
|00000500| 0a 68 65 61 64 65 72 20 | 69 6e 66 6f 72 6d 61 74 |.header |informat|
|00000510| 69 6f 6e 20 66 72 6f 6d | 20 61 20 72 61 73 74 65 |ion from| a raste|
|00000520| 72 66 69 6c 65 2c 20 61 | 6c 6f 6e 67 20 77 69 74 |rfile, a|long wit|
|00000530| 68 20 61 20 66 69 6c 65 | 20 70 6f 69 6e 74 65 72 |h a file| pointer|
|00000540| 20 61 6e 64 0a 61 20 6d | 65 6d 6f 72 79 20 63 61 | and.a m|emory ca|
|00000550| 63 68 65 20 6f 66 20 61 | 20 73 69 6e 67 6c 65 20 |che of a| single |
|00000560| 6c 69 6e 65 20 28 72 6f | 77 29 20 6f 66 20 74 68 |line (ro|w) of th|
|00000570| 65 20 72 61 73 74 65 72 | 66 69 6c 65 2e 0a 0a 42 |e raster|file...B|
|00000580| 69 74 20 73 74 75 66 66 | 69 6e 67 20 61 6e 64 20 |it stuff|ing and |
|00000590| 75 6e 70 61 63 6b 69 6e | 67 20 69 73 20 61 63 63 |unpackin|g is acc|
|000005a0| 6f 6d 70 6c 69 73 68 65 | 64 20 77 69 74 68 20 70 |omplishe|d with p|
|000005b0| 69 78 72 65 63 74 20 6f | 70 65 72 61 74 69 6f 6e |ixrect o|peration|
|000005c0| 73 2c 0a 77 68 69 63 68 | 20 61 72 65 20 61 62 6f |s,.which| are abo|
|000005d0| 75 74 20 61 73 20 66 61 | 73 74 20 61 73 20 70 6f |ut as fa|st as po|
|000005e0| 73 73 69 62 6c 65 2e 0a | 0a 4d 61 6e 69 66 65 73 |ssible..|.Manifes|
|000005f0| 74 3a 0a 0a 72 61 73 74 | 2e 68 20 20 20 2d 20 68 |t:..rast|.h - h|
|00000600| 65 61 64 65 72 20 66 69 | 6c 65 20 74 6f 20 69 6e |eader fi|le to in|
|00000610| 63 6c 75 64 65 0a 72 61 | 73 74 2e 63 20 20 20 2d |clude.ra|st.c -|
|00000620| 20 6c 69 62 72 61 72 79 | 20 73 6f 75 72 63 65 0a | library| source.|
|00000630| 72 61 73 74 2e 33 20 20 | 20 2d 20 6d 61 6e 75 61 |rast.3 | - manua|
|00000640| 6c 20 65 6e 74 72 79 0a | 72 64 65 6d 6f 2e 63 20 |l entry.|rdemo.c |
|00000650| 20 2d 20 64 65 6d 6f 20 | 70 72 6f 67 72 61 6d 0a | - demo |program.|
|00000660| 72 73 65 65 2e 63 20 20 | 20 2d 20 70 72 6f 67 72 |rsee.c | - progr|
|00000670| 61 6d 20 74 6f 20 70 72 | 69 6e 74 20 72 61 73 74 |am to pr|int rast|
|00000680| 65 72 66 69 6c 65 20 68 | 65 61 64 65 72 73 0a 4d |erfile h|eaders.M|
|00000690| 61 6b 65 66 69 6c 65 20 | 2d 20 74 6f 20 63 6f 6d |akefile |- to com|
|000006a0| 70 69 6c 65 20 69 74 20 | 61 6c 6c 0a 0a 4e 6f 74 |pile it |all..Not|
|000006b0| 65 20 74 68 61 74 2c 20 | 73 69 6e 63 65 20 74 68 |e that, |since th|
|000006c0| 65 20 6c 69 62 72 61 72 | 79 20 70 69 78 72 65 63 |e librar|y pixrec|
|000006d0| 74 20 6f 70 65 72 61 74 | 69 6f 6e 73 2c 20 79 6f |t operat|ions, yo|
|000006e0| 75 20 6d 75 73 74 20 69 | 6e 63 6c 75 64 65 0a 2d |u must i|nclude.-|
|000006f0| 6c 70 69 78 72 65 63 74 | 20 69 6e 20 61 6e 79 20 |lpixrect| in any |
|00000700| 70 72 6f 67 72 61 6d 73 | 20 77 68 69 63 68 20 75 |programs| which u|
|00000710| 73 65 20 74 68 65 20 6c | 69 62 72 61 72 79 2e 0a |se the l|ibrary..|
|00000720| 0a 2d 2d 2d 0a 4d 61 72 | 63 20 4d 61 6a 6b 61 20 |.---.Mar|c Majka |
|00000730| 20 2d 20 20 55 42 43 20 | 4c 61 62 6f 72 61 74 6f | - UBC |Laborato|
|00000740| 72 79 20 66 6f 72 20 43 | 6f 6d 70 75 74 61 74 69 |ry for C|omputati|
|00000750| 6f 6e 61 6c 20 56 69 73 | 69 6f 6e 0a 0a 3c 6d 61 |onal Vis|ion..<ma|
|00000760| 6a 6b 61 40 76 69 73 69 | 6f 6e 2e 75 62 63 2e 63 |jka@visi|on.ubc.c|
|00000770| 64 6e 3e 0a 3c 6d 61 6a | 6b 61 40 75 62 63 2e 62 |dn>.<maj|ka@ubc.b|
|00000780| 69 74 6e 65 74 3e 0a 3c | 6d 61 6a 6b 61 40 75 62 |itnet>.<|majka@ub|
|00000790| 63 2d 76 69 73 69 6f 6e | 2e 75 75 63 70 3e 0a 0a |c-vision|.uucp>..|
|000007a0| 53 48 41 52 5f 45 4f 46 | 0a 66 69 20 23 20 65 6e |SHAR_EOF|.fi # en|
|000007b0| 64 20 6f 66 20 6f 76 65 | 72 77 72 69 74 69 6e 67 |d of ove|rwriting|
|000007c0| 20 63 68 65 63 6b 0a 69 | 66 20 74 65 73 74 20 2d | check.i|f test -|
|000007d0| 66 20 27 4d 61 6b 65 66 | 69 6c 65 27 0a 74 68 65 |f 'Makef|ile'.the|
|000007e0| 6e 0a 09 65 63 68 6f 20 | 73 68 61 72 3a 20 77 69 |n..echo |shar: wi|
|000007f0| 6c 6c 20 6e 6f 74 20 6f | 76 65 72 2d 77 72 69 74 |ll not o|ver-writ|
|00000800| 65 20 65 78 69 73 74 69 | 6e 67 20 66 69 6c 65 20 |e existi|ng file |
|00000810| 22 27 4d 61 6b 65 66 69 | 6c 65 27 22 0a 65 6c 73 |"'Makefi|le'".els|
|00000820| 65 0a 63 61 74 20 3c 3c | 20 5c 53 48 41 52 5f 45 |e.cat <<| \SHAR_E|
|00000830| 4f 46 20 3e 20 27 4d 61 | 6b 65 66 69 6c 65 27 0a |OF > 'Ma|kefile'.|
|00000840| 61 6c 6c 3a 20 72 61 73 | 74 2e 6f 20 72 64 65 6d |all: ras|t.o rdem|
|00000850| 6f 20 72 73 65 65 0a 0a | 72 61 73 74 2e 6f 3a 20 |o rsee..|rast.o: |
|00000860| 72 61 73 74 2e 63 20 72 | 61 73 74 2e 68 0a 09 63 |rast.c r|ast.h..c|
|00000870| 63 20 2d 63 20 72 61 73 | 74 2e 63 0a 0a 72 64 65 |c -c ras|t.c..rde|
|00000880| 6d 6f 3a 20 72 64 65 6d | 6f 2e 63 20 72 61 73 74 |mo: rdem|o.c rast|
|00000890| 2e 6f 0a 09 63 63 20 2d | 6f 20 72 64 65 6d 6f 20 |.o..cc -|o rdemo |
|000008a0| 72 64 65 6d 6f 2e 63 20 | 72 61 73 74 2e 6f 20 2d |rdemo.c |rast.o -|
|000008b0| 6c 70 69 78 72 65 63 74 | 0a 0a 72 73 65 65 3a 20 |lpixrect|..rsee: |
|000008c0| 72 73 65 65 2e 63 20 72 | 61 73 74 2e 6f 0a 09 63 |rsee.c r|ast.o..c|
|000008d0| 63 20 2d 6f 20 72 73 65 | 65 20 72 73 65 65 2e 63 |c -o rse|e rsee.c|
|000008e0| 20 72 61 73 74 2e 6f 20 | 2d 6c 70 69 78 72 65 63 | rast.o |-lpixrec|
|000008f0| 74 0a 53 48 41 52 5f 45 | 4f 46 0a 66 69 20 23 20 |t.SHAR_E|OF.fi # |
|00000900| 65 6e 64 20 6f 66 20 6f | 76 65 72 77 72 69 74 69 |end of o|verwriti|
|00000910| 6e 67 20 63 68 65 63 6b | 0a 69 66 20 74 65 73 74 |ng check|.if test|
|00000920| 20 2d 66 20 27 72 61 73 | 74 2e 63 27 0a 74 68 65 | -f 'ras|t.c'.the|
|00000930| 6e 0a 09 65 63 68 6f 20 | 73 68 61 72 3a 20 77 69 |n..echo |shar: wi|
|00000940| 6c 6c 20 6e 6f 74 20 6f | 76 65 72 2d 77 72 69 74 |ll not o|ver-writ|
|00000950| 65 20 65 78 69 73 74 69 | 6e 67 20 66 69 6c 65 20 |e existi|ng file |
|00000960| 22 27 72 61 73 74 2e 63 | 27 22 0a 65 6c 73 65 0a |"'rast.c|'".else.|
|00000970| 63 61 74 20 3c 3c 20 5c | 53 48 41 52 5f 45 4f 46 |cat << \|SHAR_EOF|
|00000980| 20 3e 20 27 72 61 73 74 | 2e 63 27 0a 23 69 6e 63 | > 'rast|.c'.#inc|
|00000990| 6c 75 64 65 20 22 72 61 | 73 74 2e 68 22 0a 0a 52 |lude "ra|st.h"..R|
|000009a0| 41 53 54 45 52 20 2a 52 | 6f 70 65 6e 28 66 2c 6d |ASTER *R|open(f,m|
|000009b0| 29 0a 63 68 61 72 20 2a | 66 3b 0a 69 6e 74 20 6d |).char *|f;.int m|
|000009c0| 3b 0a 7b 0a 09 52 41 53 | 54 45 52 20 2a 69 6d 2c |;.{..RAS|TER *im,|
|000009d0| 20 2a 52 6f 70 65 6e 5f | 72 65 61 64 28 29 2c 20 | *Ropen_|read(), |
|000009e0| 2a 52 6f 70 65 6e 5f 77 | 72 69 74 65 28 29 3b 0a |*Ropen_w|rite();.|
|000009f0| 0a 09 69 6d 20 3d 20 4e | 55 4c 4c 3b 0a 09 69 66 |..im = N|ULL;..if|
|00000a00| 20 28 6d 20 3d 3d 20 52 | 29 20 69 6d 20 3d 20 52 | (m == R|) im = R|
|00000a10| 6f 70 65 6e 5f 72 65 61 | 64 28 66 29 3b 0a 09 69 |open_rea|d(f);..i|
|00000a20| 66 20 28 6d 20 3d 3d 20 | 57 29 20 69 6d 20 3d 20 |f (m == |W) im = |
|00000a30| 52 6f 70 65 6e 5f 77 72 | 69 74 65 28 66 29 3b 0a |Ropen_wr|ite(f);.|
|00000a40| 09 72 65 74 75 72 6e 28 | 69 6d 29 3b 0a 7d 0a 0a |.return(|im);.}..|
|00000a50| 52 41 53 54 45 52 20 2a | 52 64 6f 70 65 6e 28 66 |RASTER *|Rdopen(f|
|00000a60| 2c 6d 29 0a 69 6e 74 20 | 66 2c 6d 3b 0a 7b 0a 09 |,m).int |f,m;.{..|
|00000a70| 52 41 53 54 45 52 20 2a | 69 6d 2c 20 2a 52 64 6f |RASTER *|im, *Rdo|
|00000a80| 70 65 6e 5f 73 74 64 69 | 6e 28 29 2c 20 2a 52 64 |pen_stdi|n(), *Rd|
|00000a90| 6f 70 65 6e 5f 73 74 64 | 6f 75 74 28 29 3b 0a 0a |open_std|out();..|
|00000aa0| 09 69 6d 20 3d 20 4e 55 | 4c 4c 3b 0a 09 69 66 20 |.im = NU|LL;..if |
|00000ab0| 28 66 20 3d 3d 20 30 20 | 26 26 20 6d 20 3d 3d 20 |(f == 0 |&& m == |
|00000ac0| 52 29 20 69 6d 20 3d 20 | 52 64 6f 70 65 6e 5f 73 |R) im = |Rdopen_s|
|00000ad0| 74 64 69 6e 28 29 3b 0a | 09 69 66 20 28 66 20 3d |tdin();.|.if (f =|
|00000ae0| 3d 20 31 20 26 26 20 6d | 20 3d 3d 20 57 29 20 69 |= 1 && m| == W) i|
|00000af0| 6d 20 3d 20 52 64 6f 70 | 65 6e 5f 73 74 64 6f 75 |m = Rdop|en_stdou|
|00000b00| 74 28 29 3b 0a 09 72 65 | 74 75 72 6e 28 69 6d 29 |t();..re|turn(im)|
|00000b10| 3b 0a 7d 0a 0a 52 41 53 | 54 45 52 20 2a 52 6f 70 |;.}..RAS|TER *Rop|
|00000b20| 65 6e 5f 72 65 61 64 28 | 66 29 0a 63 68 61 72 20 |en_read(|f).char |
|00000b30| 2a 66 3b 0a 7b 0a 09 52 | 41 53 54 45 52 20 2a 69 |*f;.{..R|ASTER *i|
|00000b40| 6d 3b 0a 09 63 68 61 72 | 20 2a 6d 61 6c 6c 6f 63 |m;..char| *malloc|
|00000b50| 28 29 3b 0a 0a 09 69 6d | 20 3d 20 28 52 41 53 54 |();...im| = (RAST|
|00000b60| 45 52 20 2a 29 6d 61 6c | 6c 6f 63 28 73 69 7a 65 |ER *)mal|loc(size|
|00000b70| 6f 66 28 52 41 53 54 45 | 52 29 29 3b 0a 09 69 6d |of(RASTE|R));..im|
|00000b80| 2d 3e 66 70 20 3d 20 66 | 6f 70 65 6e 28 66 2c 22 |->fp = f|open(f,"|
|00000b90| 72 22 29 3b 0a 09 69 6d | 2d 3e 6d 6f 64 65 20 3d |r");..im|->mode =|
|00000ba0| 20 52 3b 0a 09 69 66 20 | 28 69 6d 2d 3e 66 70 20 | R;..if |(im->fp |
|00000bb0| 3d 3d 20 4e 55 4c 4c 29 | 20 7b 0a 09 09 66 70 72 |== NULL)| {...fpr|
|00000bc0| 69 6e 74 66 28 73 74 64 | 65 72 72 2c 22 72 65 61 |intf(std|err,"rea|
|00000bd0| 64 20 6f 70 65 6e 20 66 | 61 69 6c 73 20 66 6f 72 |d open f|ails for|
|00000be0| 20 66 69 6c 65 20 5c 22 | 25 73 5c 22 21 5c 6e 22 | file \"|%s\"!\n"|
|00000bf0| 2c 66 29 3b 0a 09 09 69 | 6d 20 3d 20 4e 55 4c 4c |,f);...i|m = NULL|
|00000c00| 3b 0a 09 09 72 65 74 75 | 72 6e 28 69 6d 29 3b 0a |;...retu|rn(im);.|
|00000c10| 09 7d 0a 09 72 65 74 75 | 72 6e 28 69 6d 29 3b 0a |.}..retu|rn(im);.|
|00000c20| 7d 0a 0a 52 41 53 54 45 | 52 20 2a 52 64 6f 70 65 |}..RASTE|R *Rdope|
|00000c30| 6e 5f 73 74 64 69 6e 28 | 29 0a 7b 0a 09 52 41 53 |n_stdin(|).{..RAS|
|00000c40| 54 45 52 20 2a 69 6d 3b | 0a 09 63 68 61 72 20 2a |TER *im;|..char *|
|00000c50| 6d 61 6c 6c 6f 63 28 29 | 3b 0a 0a 09 69 6d 20 3d |malloc()|;...im =|
|00000c60| 20 28 52 41 53 54 45 52 | 20 2a 29 6d 61 6c 6c 6f | (RASTER| *)mallo|
|00000c70| 63 28 73 69 7a 65 6f 66 | 28 52 41 53 54 45 52 29 |c(sizeof|(RASTER)|
|00000c80| 29 3b 0a 09 69 6d 2d 3e | 66 70 20 3d 20 73 74 64 |);..im->|fp = std|
|00000c90| 69 6e 3b 0a 09 69 6d 2d | 3e 6d 6f 64 65 20 3d 20 |in;..im-|>mode = |
|00000ca0| 52 3b 0a 09 69 66 20 28 | 69 6d 2d 3e 66 70 20 3d |R;..if (|im->fp =|
|00000cb0| 3d 20 4e 55 4c 4c 29 20 | 7b 0a 09 09 66 70 72 69 |= NULL) |{...fpri|
|00000cc0| 6e 74 66 28 73 74 64 65 | 72 72 2c 22 72 65 61 64 |ntf(stde|rr,"read|
|00000cd0| 20 6f 70 65 6e 20 66 61 | 69 6c 73 20 66 6f 72 20 | open fa|ils for |
|00000ce0| 73 74 64 69 6e 21 5c 6e | 22 29 3b 0a 09 09 69 6d |stdin!\n|");...im|
|00000cf0| 20 3d 20 4e 55 4c 4c 3b | 0a 09 09 72 65 74 75 72 | = NULL;|...retur|
|00000d00| 6e 28 69 6d 29 3b 0a 09 | 7d 0a 09 72 65 74 75 72 |n(im);..|}..retur|
|00000d10| 6e 28 69 6d 29 3b 0a 7d | 0a 0a 52 41 53 54 45 52 |n(im);.}|..RASTER|
|00000d20| 20 2a 52 6f 70 65 6e 5f | 77 72 69 74 65 28 66 29 | *Ropen_|write(f)|
|00000d30| 0a 63 68 61 72 20 2a 66 | 3b 0a 7b 0a 09 52 41 53 |.char *f|;.{..RAS|
|00000d40| 54 45 52 20 2a 69 6d 3b | 0a 09 63 68 61 72 20 2a |TER *im;|..char *|
|00000d50| 6d 61 6c 6c 6f 63 28 29 | 3b 0a 0a 09 69 6d 20 3d |malloc()|;...im =|
|00000d60| 20 28 52 41 53 54 45 52 | 20 2a 29 6d 61 6c 6c 6f | (RASTER| *)mallo|
|00000d70| 63 28 73 69 7a 65 6f 66 | 28 52 41 53 54 45 52 29 |c(sizeof|(RASTER)|
|00000d80| 29 3b 0a 09 69 6d 2d 3e | 66 70 20 3d 20 66 6f 70 |);..im->|fp = fop|
|00000d90| 65 6e 28 66 2c 22 77 22 | 29 3b 0a 09 69 66 20 28 |en(f,"w"|);..if (|
|00000da0| 69 6d 2d 3e 66 70 20 3d | 3d 20 4e 55 4c 4c 29 20 |im->fp =|= NULL) |
|00000db0| 7b 0a 09 09 66 70 72 69 | 6e 74 66 28 73 74 64 65 |{...fpri|ntf(stde|
|00000dc0| 72 72 2c 22 77 72 69 74 | 65 20 6f 70 65 6e 20 66 |rr,"writ|e open f|
|00000dd0| 61 69 6c 73 20 66 6f 72 | 20 66 69 6c 65 20 5c 22 |ails for| file \"|
|00000de0| 25 73 5c 22 21 5c 6e 22 | 2c 66 29 3b 0a 09 09 69 |%s\"!\n"|,f);...i|
|00000df0| 6d 20 3d 20 4e 55 4c 4c | 3b 0a 09 09 72 65 74 75 |m = NULL|;...retu|
|00000e00| 72 6e 28 69 6d 29 3b 0a | 09 7d 0a 0a 09 69 6d 2d |rn(im);.|.}...im-|
|00000e10| 3e 6d 6f 64 65 20 20 20 | 20 20 20 3d 20 57 3b 0a |>mode | = W;.|
|00000e20| 09 69 6d 2d 3e 77 69 64 | 74 68 20 20 20 20 20 3d |.im->wid|th =|
|00000e30| 20 30 3b 0a 09 69 6d 2d | 3e 68 65 69 67 68 74 20 | 0;..im-|>height |
|00000e40| 20 20 20 3d 20 30 3b 0a | 09 69 6d 2d 3e 64 65 70 | = 0;.|.im->dep|
|00000e50| 74 68 20 20 20 20 20 3d | 20 30 3b 0a 09 69 6d 2d |th =| 0;..im-|
|00000e60| 3e 6d 61 70 6c 65 6e 67 | 74 68 20 3d 20 30 3b 0a |>mapleng|th = 0;.|
|00000e70| 09 69 6d 2d 3e 6d 61 70 | 74 79 70 65 20 20 20 3d |.im->map|type =|
|00000e80| 20 52 4d 54 5f 4e 4f 4e | 45 3b 0a 0a 09 69 66 20 | RMT_NON|E;...if |
|00000e90| 28 69 6d 2d 3e 66 70 20 | 3d 3d 20 4e 55 4c 4c 29 |(im->fp |== NULL)|
|00000ea0| 20 69 6d 20 3d 20 4e 55 | 4c 4c 3b 0a 09 72 65 74 | im = NU|LL;..ret|
|00000eb0| 75 72 6e 28 69 6d 29 3b | 0a 7d 0a 0a 52 41 53 54 |urn(im);|.}..RAST|
|00000ec0| 45 52 20 2a 52 64 6f 70 | 65 6e 5f 73 74 64 6f 75 |ER *Rdop|en_stdou|
|00000ed0| 74 28 29 0a 7b 0a 09 52 | 41 53 54 45 52 20 2a 69 |t().{..R|ASTER *i|
|00000ee0| 6d 3b 0a 09 63 68 61 72 | 20 2a 6d 61 6c 6c 6f 63 |m;..char| *malloc|
|00000ef0| 28 29 3b 0a 0a 09 69 6d | 20 3d 20 28 52 41 53 54 |();...im| = (RAST|
|00000f00| 45 52 20 2a 29 6d 61 6c | 6c 6f 63 28 73 69 7a 65 |ER *)mal|loc(size|
|00000f10| 6f 66 28 52 41 53 54 45 | 52 29 29 3b 0a 09 69 6d |of(RASTE|R));..im|
|00000f20| 2d 3e 66 70 20 3d 20 73 | 74 64 6f 75 74 3b 0a 09 |->fp = s|tdout;..|
|00000f30| 69 66 20 28 69 6d 2d 3e | 66 70 20 3d 3d 20 4e 55 |if (im->|fp == NU|
|00000f40| 4c 4c 29 20 7b 0a 09 09 | 66 70 72 69 6e 74 66 28 |LL) {...|fprintf(|
|00000f50| 73 74 64 65 72 72 2c 22 | 77 72 69 74 65 20 6f 70 |stderr,"|write op|
|00000f60| 65 6e 20 66 61 69 6c 73 | 20 66 6f 72 20 73 74 64 |en fails| for std|
|00000f70| 6f 75 74 21 5c 6e 22 29 | 3b 0a 09 09 69 6d 20 3d |out!\n")|;...im =|
|00000f80| 20 4e 55 4c 4c 3b 0a 09 | 09 72 65 74 75 72 6e 28 | NULL;..|.return(|
|00000f90| 69 6d 29 3b 0a 09 7d 0a | 0a 09 69 6d 2d 3e 6d 6f |im);..}.|..im->mo|
|00000fa0| 64 65 20 20 20 20 20 20 | 3d 20 57 3b 0a 09 69 6d |de |= W;..im|
|00000fb0| 2d 3e 77 69 64 74 68 20 | 20 20 20 20 3d 20 30 3b |->width | = 0;|
|00000fc0| 0a 09 69 6d 2d 3e 68 65 | 69 67 68 74 20 20 20 20 |..im->he|ight |
|00000fd0| 3d 20 30 3b 0a 09 69 6d | 2d 3e 64 65 70 74 68 20 |= 0;..im|->depth |
|00000fe0| 20 20 20 20 3d 20 30 3b | 0a 09 69 6d 2d 3e 6d 61 | = 0;|..im->ma|
|00000ff0| 70 6c 65 6e 67 74 68 20 | 3d 20 30 3b 0a 09 69 6d |plength |= 0;..im|
|00001000| 2d 3e 6d 61 70 74 79 70 | 65 20 20 20 3d 20 52 4d |->maptyp|e = RM|
|00001010| 54 5f 4e 4f 4e 45 3b 0a | 0a 09 72 65 74 75 72 6e |T_NONE;.|..return|
|00001020| 28 69 6d 29 3b 0a 7d 0a | 0a 52 67 65 74 68 65 61 |(im);.}.|.Rgethea|
|00001030| 64 65 72 28 69 6d 29 0a | 52 41 53 54 45 52 20 2a |der(im).|RASTER *|
|00001040| 69 6d 3b 0a 7b 0a 09 63 | 68 61 72 20 2a 6d 61 6c |im;.{..c|har *mal|
|00001050| 6c 6f 63 28 29 3b 0a 09 | 69 6e 74 20 69 2c 20 72 |loc();..|int i, r|
|00001060| 63 2c 20 6c 6c 2c 20 65 | 78 74 72 61 3b 0a 09 73 |c, ll, e|xtra;..s|
|00001070| 74 72 75 63 74 20 72 61 | 73 74 65 72 66 69 6c 65 |truct ra|sterfile|
|00001080| 20 72 68 65 61 64 3b 0a | 0a 09 72 63 20 3d 20 66 | rhead;.|..rc = f|
|00001090| 72 65 61 64 28 26 72 68 | 65 61 64 2c 28 73 69 7a |read(&rh|ead,(siz|
|000010a0| 65 6f 66 20 28 73 74 72 | 75 63 74 20 72 61 73 74 |eof (str|uct rast|
|000010b0| 65 72 66 69 6c 65 29 29 | 2c 31 2c 69 6d 2d 3e 66 |erfile))|,1,im->f|
|000010c0| 70 29 3b 0a 09 0a 09 69 | 66 20 28 72 63 20 3c 3d |p);....i|f (rc <=|
|000010d0| 20 30 29 20 7b 0a 09 09 | 66 70 72 69 6e 74 66 28 | 0) {...|fprintf(|
|000010e0| 73 74 64 65 72 72 2c 22 | 52 67 65 74 68 65 61 64 |stderr,"|Rgethead|
|000010f0| 65 72 20 66 61 69 6c 65 | 64 21 5c 6e 22 29 3b 0a |er faile|d!\n");.|
|00001100| 09 09 72 65 74 75 72 6e | 28 30 29 3b 0a 09 7d 0a |..return|(0);..}.|
|00001110| 09 69 66 20 28 72 68 65 | 61 64 2e 72 61 73 5f 6d |.if (rhe|ad.ras_m|
|00001120| 61 67 69 63 20 21 3d 20 | 52 41 53 5f 4d 41 47 49 |agic != |RAS_MAGI|
|00001130| 43 29 20 72 65 74 75 72 | 6e 28 30 29 3b 0a 0a 09 |C) retur|n(0);...|
|00001140| 69 6d 2d 3e 68 65 69 67 | 68 74 20 20 20 20 3d 20 |im->heig|ht = |
|00001150| 72 68 65 61 64 2e 72 61 | 73 5f 68 65 69 67 68 74 |rhead.ra|s_height|
|00001160| 3b 0a 09 69 6d 2d 3e 77 | 69 64 74 68 20 20 20 20 |;..im->w|idth |
|00001170| 20 3d 20 72 68 65 61 64 | 2e 72 61 73 5f 77 69 64 | = rhead|.ras_wid|
|00001180| 74 68 3b 0a 09 69 6d 2d | 3e 64 65 70 74 68 20 20 |th;..im-|>depth |
|00001190| 20 20 20 3d 20 72 68 65 | 61 64 2e 72 61 73 5f 64 | = rhe|ad.ras_d|
|000011a0| 65 70 74 68 3b 0a 09 69 | 6d 2d 3e 6c 65 6e 67 74 |epth;..i|m->lengt|
|000011b0| 68 20 20 20 20 3d 20 72 | 68 65 61 64 2e 72 61 73 |h = r|head.ras|
|000011c0| 5f 6c 65 6e 67 74 68 3b | 0a 09 69 6d 2d 3e 74 79 |_length;|..im->ty|
|000011d0| 70 65 20 20 20 20 20 20 | 3d 20 72 68 65 61 64 2e |pe |= rhead.|
|000011e0| 72 61 73 5f 74 79 70 65 | 3b 0a 09 69 6d 2d 3e 6d |ras_type|;..im->m|
|000011f0| 61 70 74 79 70 65 20 20 | 20 3d 20 72 68 65 61 64 |aptype | = rhead|
|00001200| 2e 72 61 73 5f 6d 61 70 | 74 79 70 65 3b 0a 09 69 |.ras_map|type;..i|
|00001210| 6d 2d 3e 6d 61 70 6c 65 | 6e 67 74 68 20 3d 20 72 |m->maple|ngth = r|
|00001220| 68 65 61 64 2e 72 61 73 | 5f 6d 61 70 6c 65 6e 67 |head.ras|_mapleng|
|00001230| 74 68 3b 0a 0a 09 65 78 | 74 72 61 20 3d 20 28 31 |th;...ex|tra = (1|
|00001240| 36 20 2d 20 28 28 69 6d | 2d 3e 77 69 64 74 68 20 |6 - ((im|->width |
|00001250| 2a 20 69 6d 2d 3e 64 65 | 70 74 68 29 20 25 20 31 |* im->de|pth) % 1|
|00001260| 36 29 29 20 25 20 31 36 | 3b 0a 09 6c 6c 20 3d 20 |6)) % 16|;..ll = |
|00001270| 28 28 69 6d 2d 3e 77 69 | 64 74 68 20 2a 20 69 6d |((im->wi|dth * im|
|00001280| 2d 3e 64 65 70 74 68 29 | 20 2b 20 65 78 74 72 61 |->depth)| + extra|
|00001290| 29 20 2f 20 38 3b 0a 0a | 09 69 6d 2d 3e 6c 69 6e |) / 8;..|.im->lin|
|000012a0| 65 6c 65 6e 20 20 20 3d | 20 6c 6c 3b 0a 09 69 6d |elen =| ll;..im|
|000012b0| 2d 3e 63 61 63 68 65 20 | 20 20 20 20 3d 20 6d 61 |->cache | = ma|
|000012c0| 6c 6c 6f 63 28 6c 6c 29 | 3b 0a 09 69 6d 2d 3e 63 |lloc(ll)|;..im->c|
|000012d0| 5f 70 69 78 65 6c 20 20 | 20 3d 20 69 6d 2d 3e 77 |_pixel | = im->w|
|000012e0| 69 64 74 68 20 2b 20 31 | 3b 0a 09 69 6d 2d 3e 63 |idth + 1|;..im->c|
|000012f0| 5f 70 72 20 20 20 20 20 | 20 3d 20 6d 65 6d 5f 70 |_pr | = mem_p|
|00001300| 6f 69 6e 74 28 69 6d 2d | 3e 77 69 64 74 68 2c 31 |oint(im-|>width,1|
|00001310| 2c 69 6d 2d 3e 64 65 70 | 74 68 2c 69 6d 2d 3e 63 |,im->dep|th,im->c|
|00001320| 61 63 68 65 29 3b 0a 09 | 69 66 20 28 69 6d 2d 3e |ache);..|if (im->|
|00001330| 6d 61 70 6c 65 6e 67 74 | 68 20 3e 20 30 29 20 7b |maplengt|h > 0) {|
|00001340| 0a 09 09 69 6d 2d 3e 6d | 61 70 20 3d 20 6d 61 6c |...im->m|ap = mal|
|00001350| 6c 6f 63 28 69 6d 2d 3e | 6d 61 70 6c 65 6e 67 74 |loc(im->|maplengt|
|00001360| 68 29 3b 0a 09 09 66 6f | 72 20 28 69 20 3d 20 30 |h);...fo|r (i = 0|
|00001370| 3b 20 69 20 3c 20 69 6d | 2d 3e 6d 61 70 6c 65 6e |; i < im|->maplen|
|00001380| 67 74 68 3b 20 69 2b 2b | 29 20 69 6d 2d 3e 6d 61 |gth; i++|) im->ma|
|00001390| 70 5b 69 5d 20 3d 20 67 | 65 74 63 28 69 6d 2d 3e |p[i] = g|etc(im->|
|000013a0| 66 70 29 3b 0a 09 7d 0a | 09 72 65 74 75 72 6e 28 |fp);..}.|.return(|
|000013b0| 31 29 3b 0a 7d 0a 0a 52 | 70 75 74 68 65 61 64 65 |1);.}..R|putheade|
|000013c0| 72 28 69 6d 29 0a 52 41 | 53 54 45 52 20 2a 69 6d |r(im).RA|STER *im|
|000013d0| 3b 0a 7b 0a 09 63 68 61 | 72 20 2a 6d 61 6c 6c 6f |;.{..cha|r *mallo|
|000013e0| 63 28 29 3b 0a 09 69 6e | 74 20 69 2c 20 72 63 2c |c();..in|t i, rc,|
|000013f0| 20 6c 6c 2c 20 65 78 74 | 72 61 3b 0a 09 73 74 72 | ll, ext|ra;..str|
|00001400| 75 63 74 20 72 61 73 74 | 65 72 66 69 6c 65 20 72 |uct rast|erfile r|
|00001410| 68 65 61 64 3b 0a 0a 09 | 65 78 74 72 61 20 3d 20 |head;...|extra = |
|00001420| 28 31 36 20 2d 20 28 28 | 69 6d 2d 3e 77 69 64 74 |(16 - ((|im->widt|
|00001430| 68 20 2a 20 69 6d 2d 3e | 64 65 70 74 68 29 20 25 |h * im->|depth) %|
|00001440| 20 31 36 29 29 20 25 20 | 31 36 3b 0a 09 6c 6c 20 | 16)) % |16;..ll |
|00001450| 3d 20 28 28 69 6d 2d 3e | 77 69 64 74 68 20 2a 20 |= ((im->|width * |
|00001460| 69 6d 2d 3e 64 65 70 74 | 68 29 20 2b 20 65 78 74 |im->dept|h) + ext|
|00001470| 72 61 29 20 2f 20 38 3b | 0a 0a 09 69 66 20 28 69 |ra) / 8;|...if (i|
|00001480| 6d 2d 3e 77 69 64 74 68 | 20 3d 3d 20 30 29 20 7b |m->width| == 0) {|
|00001490| 0a 09 09 66 70 72 69 6e | 74 66 28 73 74 64 65 72 |...fprin|tf(stder|
|000014a0| 72 2c 22 72 61 73 74 65 | 72 66 69 6c 65 20 77 69 |r,"raste|rfile wi|
|000014b0| 64 74 68 20 69 73 20 7a | 65 72 6f 21 5c 6e 22 29 |dth is z|ero!\n")|
|000014c0| 3b 0a 09 09 72 65 74 75 | 72 6e 28 30 29 3b 0a 09 |;...retu|rn(0);..|
|000014d0| 7d 0a 09 69 66 20 28 69 | 6d 2d 3e 68 65 69 67 68 |}..if (i|m->heigh|
|000014e0| 74 20 3d 3d 20 30 29 20 | 7b 0a 09 09 66 70 72 69 |t == 0) |{...fpri|
|000014f0| 6e 74 66 28 73 74 64 65 | 72 72 2c 22 72 61 73 74 |ntf(stde|rr,"rast|
|00001500| 65 72 66 69 6c 65 20 68 | 65 69 67 68 74 20 69 73 |erfile h|eight is|
|00001510| 20 7a 65 72 6f 21 5c 6e | 22 29 3b 0a 09 09 72 65 | zero!\n|");...re|
|00001520| 74 75 72 6e 28 30 29 3b | 0a 09 7d 0a 09 69 66 20 |turn(0);|..}..if |
|00001530| 28 69 6d 2d 3e 64 65 70 | 74 68 20 3d 3d 20 30 29 |(im->dep|th == 0)|
|00001540| 20 7b 0a 09 09 66 70 72 | 69 6e 74 66 28 73 74 64 | {...fpr|intf(std|
|00001550| 65 72 72 2c 22 72 61 73 | 74 65 72 66 69 6c 65 20 |err,"ras|terfile |
|00001560| 64 65 70 74 68 20 69 73 | 20 7a 65 72 6f 21 5c 6e |depth is| zero!\n|
|00001570| 22 29 3b 0a 09 09 72 65 | 74 75 72 6e 28 30 29 3b |");...re|turn(0);|
|00001580| 0a 09 7d 0a 0a 09 72 68 | 65 61 64 2e 72 61 73 5f |..}...rh|ead.ras_|
|00001590| 6d 61 67 69 63 20 20 20 | 20 20 3d 20 52 41 53 5f |magic | = RAS_|
|000015a0| 4d 41 47 49 43 3b 0a 09 | 72 68 65 61 64 2e 72 61 |MAGIC;..|rhead.ra|
|000015b0| 73 5f 77 69 64 74 68 20 | 20 20 20 20 3d 20 69 6d |s_width | = im|
|000015c0| 2d 3e 77 69 64 74 68 3b | 0a 09 72 68 65 61 64 2e |->width;|..rhead.|
|000015d0| 72 61 73 5f 68 65 69 67 | 68 74 20 20 20 20 3d 20 |ras_heig|ht = |
|000015e0| 69 6d 2d 3e 68 65 69 67 | 68 74 3b 0a 09 72 68 65 |im->heig|ht;..rhe|
|000015f0| 61 64 2e 72 61 73 5f 64 | 65 70 74 68 20 20 20 20 |ad.ras_d|epth |
|00001600| 20 3d 20 69 6d 2d 3e 64 | 65 70 74 68 3b 0a 09 72 | = im->d|epth;..r|
|00001610| 68 65 61 64 2e 72 61 73 | 5f 6c 65 6e 67 74 68 20 |head.ras|_length |
|00001620| 20 20 20 3d 20 6c 6c 20 | 2a 20 69 6d 2d 3e 68 65 | = ll |* im->he|
|00001630| 69 67 68 74 3b 0a 09 72 | 68 65 61 64 2e 72 61 73 |ight;..r|head.ras|
|00001640| 5f 74 79 70 65 20 20 20 | 20 20 20 3d 20 52 54 5f |_type | = RT_|
|00001650| 53 54 41 4e 44 41 52 44 | 3b 0a 09 72 68 65 61 64 |STANDARD|;..rhead|
|00001660| 2e 72 61 73 5f 6d 61 70 | 74 79 70 65 20 20 20 3d |.ras_map|type =|
|00001670| 20 69 6d 2d 3e 6d 61 70 | 74 79 70 65 3b 0a 09 72 | im->map|type;..r|
|00001680| 68 65 61 64 2e 72 61 73 | 5f 6d 61 70 6c 65 6e 67 |head.ras|_mapleng|
|00001690| 74 68 20 3d 20 69 6d 2d | 3e 6d 61 70 6c 65 6e 67 |th = im-|>mapleng|
|000016a0| 74 68 3b 0a 0a 09 69 6d | 2d 3e 6c 69 6e 65 6c 65 |th;...im|->linele|
|000016b0| 6e 20 20 20 3d 20 6c 6c | 3b 0a 09 69 6d 2d 3e 63 |n = ll|;..im->c|
|000016c0| 61 63 68 65 20 20 20 20 | 20 3d 20 6d 61 6c 6c 6f |ache | = mallo|
|000016d0| 63 28 6c 6c 29 3b 0a 09 | 69 6d 2d 3e 63 5f 70 69 |c(ll);..|im->c_pi|
|000016e0| 78 65 6c 20 20 20 3d 20 | 30 3b 0a 09 69 6d 2d 3e |xel = |0;..im->|
|000016f0| 63 5f 70 72 20 20 20 20 | 20 20 3d 20 6d 65 6d 5f |c_pr | = mem_|
|00001700| 70 6f 69 6e 74 28 69 6d | 2d 3e 77 69 64 74 68 2c |point(im|->width,|
|00001710| 31 2c 69 6d 2d 3e 64 65 | 70 74 68 2c 69 6d 2d 3e |1,im->de|pth,im->|
|00001720| 63 61 63 68 65 29 3b 0a | 0a 09 72 63 20 3d 20 66 |cache);.|..rc = f|
|00001730| 77 72 69 74 65 28 26 72 | 68 65 61 64 2c 28 73 69 |write(&r|head,(si|
|00001740| 7a 65 6f 66 20 28 73 74 | 72 75 63 74 20 72 61 73 |zeof (st|ruct ras|
|00001750| 74 65 72 66 69 6c 65 29 | 29 2c 31 2c 69 6d 2d 3e |terfile)|),1,im->|
|00001760| 66 70 29 3b 0a 09 0a 09 | 69 66 20 28 72 63 20 3c |fp);....|if (rc <|
|00001770| 3d 20 30 29 20 7b 0a 09 | 09 66 70 72 69 6e 74 66 |= 0) {..|.fprintf|
|00001780| 28 73 74 64 65 72 72 2c | 22 52 70 75 74 68 65 61 |(stderr,|"Rputhea|
|00001790| 64 65 72 20 66 61 69 6c | 65 64 21 5c 6e 22 29 3b |der fail|ed!\n");|
|000017a0| 0a 09 09 72 65 74 75 72 | 6e 28 30 29 3b 0a 09 7d |...retur|n(0);..}|
|000017b0| 0a 0a 09 69 66 20 28 69 | 6d 2d 3e 6d 61 70 74 79 |...if (i|m->mapty|
|000017c0| 70 65 20 21 3d 20 52 4d | 54 5f 4e 4f 4e 45 20 26 |pe != RM|T_NONE &|
|000017d0| 26 20 69 6d 2d 3e 6d 61 | 70 6c 65 6e 67 74 68 20 |& im->ma|plength |
|000017e0| 3e 20 30 29 0a 09 09 66 | 77 72 69 74 65 28 69 6d |> 0)...f|write(im|
|000017f0| 2d 3e 6d 61 70 2c 69 6d | 2d 3e 6d 61 70 6c 65 6e |->map,im|->maplen|
|00001800| 67 74 68 2c 31 2c 69 6d | 2d 3e 66 70 29 3b 0a 09 |gth,1,im|->fp);..|
|00001810| 72 65 74 75 72 6e 28 31 | 29 3b 0a 7d 0a 0a 52 67 |return(1|);.}..Rg|
|00001820| 65 74 70 69 78 28 69 6d | 29 0a 52 41 53 54 45 52 |etpix(im|).RASTER|
|00001830| 20 2a 69 6d 3b 0a 7b 0a | 09 69 6e 74 20 70 69 78 | *im;.{.|.int pix|
|00001840| 3b 0a 09 0a 09 69 66 20 | 28 69 6d 2d 3e 6d 6f 64 |;....if |(im->mod|
|00001850| 65 20 21 3d 20 52 29 20 | 7b 0a 09 09 66 70 72 69 |e != R) |{...fpri|
|00001860| 6e 74 66 28 73 74 64 65 | 72 72 2c 22 61 74 74 65 |ntf(stde|rr,"atte|
|00001870| 6d 70 74 20 74 6f 20 72 | 65 61 64 20 72 61 73 74 |mpt to r|ead rast|
|00001880| 65 72 66 69 6c 65 20 6f | 70 65 6e 65 64 20 66 6f |erfile o|pened fo|
|00001890| 72 20 77 72 69 74 65 21 | 5c 6e 22 29 3b 0a 09 09 |r write!|\n");...|
|000018a0| 72 65 74 75 72 6e 28 2d | 31 29 3b 0a 09 7d 0a 0a |return(-|1);..}..|
|000018b0| 09 69 66 20 28 69 6d 2d | 3e 63 5f 70 69 78 65 6c |.if (im-|>c_pixel|
|000018c0| 20 3e 3d 20 69 6d 2d 3e | 77 69 64 74 68 29 20 7b | >= im->|width) {|
|000018d0| 0a 09 09 66 72 65 61 64 | 28 69 6d 2d 3e 63 61 63 |...fread|(im->cac|
|000018e0| 68 65 2c 69 6d 2d 3e 6c | 69 6e 65 6c 65 6e 2c 31 |he,im->l|inelen,1|
|000018f0| 2c 69 6d 2d 3e 66 70 29 | 3b 0a 09 09 69 6d 2d 3e |,im->fp)|;...im->|
|00001900| 63 5f 70 69 78 65 6c 20 | 3d 20 30 3b 0a 09 7d 0a |c_pixel |= 0;..}.|
|00001910| 0a 09 70 69 78 20 3d 20 | 70 72 5f 67 65 74 28 69 |..pix = |pr_get(i|
|00001920| 6d 2d 3e 63 5f 70 72 2c | 69 6d 2d 3e 63 5f 70 69 |m->c_pr,|im->c_pi|
|00001930| 78 65 6c 2c 30 29 3b 0a | 09 69 6d 2d 3e 63 5f 70 |xel,0);.|.im->c_p|
|00001940| 69 78 65 6c 2b 2b 3b 0a | 09 72 65 74 75 72 6e 28 |ixel++;.|.return(|
|00001950| 70 69 78 29 3b 0a 7d 0a | 0a 52 70 75 74 70 69 78 |pix);.}.|.Rputpix|
|00001960| 28 69 6d 2c 70 69 78 29 | 0a 52 41 53 54 45 52 20 |(im,pix)|.RASTER |
|00001970| 2a 69 6d 3b 0a 69 6e 74 | 20 70 69 78 3b 0a 7b 0a |*im;.int| pix;.{.|
|00001980| 09 69 66 20 28 69 6d 2d | 3e 6d 6f 64 65 20 21 3d |.if (im-|>mode !=|
|00001990| 20 57 29 20 7b 0a 09 09 | 66 70 72 69 6e 74 66 28 | W) {...|fprintf(|
|000019a0| 73 74 64 65 72 72 2c 22 | 61 74 74 65 6d 70 74 20 |stderr,"|attempt |
|000019b0| 74 6f 20 77 72 69 74 65 | 20 72 61 73 74 65 72 66 |to write| rasterf|
|000019c0| 69 6c 65 20 6f 70 65 6e | 65 64 20 66 6f 72 20 72 |ile open|ed for r|
|000019d0| 65 61 64 21 5c 6e 22 29 | 3b 0a 09 09 72 65 74 75 |ead!\n")|;...retu|
|000019e0| 72 6e 28 2d 31 29 3b 0a | 09 7d 0a 0a 09 70 72 5f |rn(-1);.|.}...pr_|
|000019f0| 70 75 74 28 69 6d 2d 3e | 63 5f 70 72 2c 69 6d 2d |put(im->|c_pr,im-|
|00001a00| 3e 63 5f 70 69 78 65 6c | 2c 30 2c 70 69 78 29 3b |>c_pixel|,0,pix);|
|00001a10| 0a 09 69 6d 2d 3e 63 5f | 70 69 78 65 6c 2b 2b 3b |..im->c_|pixel++;|
|00001a20| 0a 09 0a 09 69 66 20 28 | 69 6d 2d 3e 63 5f 70 69 |....if (|im->c_pi|
|00001a30| 78 65 6c 20 3e 3d 20 69 | 6d 2d 3e 77 69 64 74 68 |xel >= i|m->width|
|00001a40| 29 20 7b 0a 09 09 66 77 | 72 69 74 65 28 69 6d 2d |) {...fw|rite(im-|
|00001a50| 3e 63 61 63 68 65 2c 69 | 6d 2d 3e 6c 69 6e 65 6c |>cache,i|m->linel|
|00001a60| 65 6e 2c 31 2c 69 6d 2d | 3e 66 70 29 3b 0a 09 09 |en,1,im-|>fp);...|
|00001a70| 69 6d 2d 3e 63 5f 70 69 | 78 65 6c 20 3d 20 30 3b |im->c_pi|xel = 0;|
|00001a80| 0a 09 7d 0a 7d 0a 0a 52 | 63 6c 6f 73 65 28 69 6d |..}.}..R|close(im|
|00001a90| 29 0a 52 41 53 54 45 52 | 20 2a 69 6d 3b 0a 7b 0a |).RASTER| *im;.{.|
|00001aa0| 09 69 66 20 28 69 6d 2d | 3e 6d 6f 64 65 20 3d 3d |.if (im-|>mode ==|
|00001ab0| 20 57 29 20 66 66 6c 75 | 73 68 28 69 6d 2d 3e 66 | W) fflu|sh(im->f|
|00001ac0| 70 29 3b 0a 09 66 63 6c | 6f 73 65 28 69 6d 2d 3e |p);..fcl|ose(im->|
|00001ad0| 66 70 29 3b 0a 7d 0a 0a | 52 69 6e 66 6f 28 69 6d |fp);.}..|Rinfo(im|
|00001ae0| 29 0a 52 41 53 54 45 52 | 20 2a 69 6d 3b 0a 7b 0a |).RASTER| *im;.{.|
|00001af0| 09 66 70 72 69 6e 74 66 | 28 73 74 64 65 72 72 2c |.fprintf|(stderr,|
|00001b00| 22 20 20 68 65 69 67 68 | 74 20 20 20 20 3d 20 25 |" heigh|t = %|
|00001b10| 64 5c 6e 22 2c 69 6d 2d | 3e 68 65 69 67 68 74 29 |d\n",im-|>height)|
|00001b20| 3b 0a 09 66 70 72 69 6e | 74 66 28 73 74 64 65 72 |;..fprin|tf(stder|
|00001b30| 72 2c 22 20 20 77 69 64 | 74 68 20 20 20 20 20 3d |r," wid|th =|
|00001b40| 20 25 64 5c 6e 22 2c 69 | 6d 2d 3e 77 69 64 74 68 | %d\n",i|m->width|
|00001b50| 29 3b 0a 09 66 70 72 69 | 6e 74 66 28 73 74 64 65 |);..fpri|ntf(stde|
|00001b60| 72 72 2c 22 20 20 64 65 | 70 74 68 20 20 20 20 20 |rr," de|pth |
|00001b70| 3d 20 25 64 5c 6e 22 2c | 69 6d 2d 3e 64 65 70 74 |= %d\n",|im->dept|
|00001b80| 68 29 3b 0a 09 66 70 72 | 69 6e 74 66 28 73 74 64 |h);..fpr|intf(std|
|00001b90| 65 72 72 2c 22 20 20 6c | 65 6e 67 74 68 20 20 20 |err," l|ength |
|00001ba0| 20 3d 20 25 64 5c 6e 22 | 2c 69 6d 2d 3e 6c 65 6e | = %d\n"|,im->len|
|00001bb0| 67 74 68 29 3b 0a 09 66 | 70 72 69 6e 74 66 28 73 |gth);..f|printf(s|
|00001bc0| 74 64 65 72 72 2c 22 20 | 20 74 79 70 65 20 20 20 |tderr," | type |
|00001bd0| 20 20 20 3d 20 25 64 5c | 6e 22 2c 69 6d 2d 3e 74 | = %d\|n",im->t|
|00001be0| 79 70 65 29 3b 0a 09 66 | 70 72 69 6e 74 66 28 73 |ype);..f|printf(s|
|00001bf0| 74 64 65 72 72 2c 22 20 | 20 6d 61 70 74 79 70 65 |tderr," | maptype|
|00001c00| 20 20 20 3d 20 25 64 5c | 6e 22 2c 69 6d 2d 3e 6d | = %d\|n",im->m|
|00001c10| 61 70 74 79 70 65 29 3b | 0a 09 66 70 72 69 6e 74 |aptype);|..fprint|
|00001c20| 66 28 73 74 64 65 72 72 | 2c 22 20 20 6d 61 70 6c |f(stderr|," mapl|
|00001c30| 65 6e 67 74 68 20 3d 20 | 25 64 5c 6e 22 2c 69 6d |ength = |%d\n",im|
|00001c40| 2d 3e 6d 61 70 6c 65 6e | 67 74 68 29 3b 0a 7d 0a |->maplen|gth);.}.|
|00001c50| 0a 52 69 6e 69 74 6d 61 | 70 28 69 6d 2c 74 2c 6c |.Rinitma|p(im,t,l|
|00001c60| 29 0a 52 41 53 54 45 52 | 20 2a 69 6d 3b 0a 69 6e |).RASTER| *im;.in|
|00001c70| 74 20 74 2c 6c 3b 0a 7b | 0a 09 63 68 61 72 20 2a |t t,l;.{|..char *|
|00001c80| 6d 61 6c 6c 6f 63 28 29 | 3b 0a 0a 09 69 6d 2d 3e |malloc()|;...im->|
|00001c90| 6d 61 70 74 79 70 65 20 | 20 20 3d 20 74 3b 0a 09 |maptype | = t;..|
|00001ca0| 69 6d 2d 3e 6d 61 70 6c | 65 6e 67 74 68 20 3d 20 |im->mapl|ength = |
|00001cb0| 6c 3b 0a 09 69 6d 2d 3e | 6d 61 70 20 20 20 20 20 |l;..im->|map |
|00001cc0| 20 20 3d 20 6d 61 6c 6c | 6f 63 28 6c 29 3b 0a 7d | = mall|oc(l);.}|
|00001cd0| 0a 0a 52 70 75 74 6d 61 | 70 28 69 6d 2c 69 2c 72 |..Rputma|p(im,i,r|
|00001ce0| 2c 67 2c 62 29 0a 52 41 | 53 54 45 52 20 2a 69 6d |,g,b).RA|STER *im|
|00001cf0| 3b 0a 69 6e 74 20 69 2c | 72 2c 67 2c 62 3b 0a 7b |;.int i,|r,g,b;.{|
|00001d00| 0a 09 69 6e 74 20 78 3b | 0a 09 0a 09 73 77 69 74 |..int x;|....swit|
|00001d10| 63 68 20 28 69 6d 2d 3e | 6d 61 70 74 79 70 65 29 |ch (im->|maptype)|
|00001d20| 20 7b 0a 09 09 63 61 73 | 65 20 52 4d 54 5f 4e 4f | {...cas|e RMT_NO|
|00001d30| 4e 45 3a 20 0a 09 09 09 | 66 70 72 69 6e 74 66 28 |NE: ....|fprintf(|
|00001d40| 73 74 64 65 72 72 2c 22 | 63 61 6e 27 74 20 70 75 |stderr,"|can't pu|
|00001d50| 74 20 69 6e 20 61 20 6e | 75 6c 6c 20 6d 61 70 21 |t in a n|ull map!|
|00001d60| 5c 6e 22 29 3b 0a 09 09 | 09 62 72 65 61 6b 3b 0a |\n");...|.break;.|
|00001d70| 09 09 63 61 73 65 20 52 | 4d 54 5f 52 41 57 3a 0a |..case R|MT_RAW:.|
|00001d80| 09 09 09 69 6d 2d 3e 6d | 61 70 5b 69 5d 20 3d 20 |...im->m|ap[i] = |
|00001d90| 72 3b 0a 09 09 09 62 72 | 65 61 6b 3b 0a 09 09 63 |r;....br|eak;...c|
|00001da0| 61 73 65 20 52 4d 54 5f | 45 51 55 41 4c 5f 52 47 |ase RMT_|EQUAL_RG|
|00001db0| 42 3a 0a 09 09 09 78 20 | 3d 20 69 20 2a 20 33 3b |B:....x |= i * 3;|
|00001dc0| 0a 09 09 09 69 6d 2d 3e | 6d 61 70 5b 78 2b 2b 5d |....im->|map[x++]|
|00001dd0| 20 3d 20 72 3b 0a 09 09 | 09 69 6d 2d 3e 6d 61 70 | = r;...|.im->map|
|00001de0| 5b 78 2b 2b 5d 20 3d 20 | 67 3b 0a 09 09 09 69 6d |[x++] = |g;....im|
|00001df0| 2d 3e 6d 61 70 5b 78 5d | 20 20 20 3d 20 62 3b 0a |->map[x]| = b;.|
|00001e00| 09 09 09 62 72 65 61 6b | 3b 0a 09 09 64 65 66 61 |...break|;...defa|
|00001e10| 75 6c 74 3a 0a 09 09 09 | 66 70 72 69 6e 74 66 28 |ult:....|fprintf(|
|00001e20| 73 74 64 65 72 72 2c 22 | 75 6e 6b 6e 6f 77 6e 20 |stderr,"|unknown |
|00001e30| 6d 61 70 20 74 79 70 65 | 20 69 6e 20 72 61 73 74 |map type| in rast|
|00001e40| 65 72 66 69 6c 65 21 5c | 6e 22 29 3b 0a 09 7d 0a |erfile!\|n");..}.|
|00001e50| 7d 0a 0a 52 67 65 74 6d | 61 70 28 69 6d 2c 69 2c |}..Rgetm|ap(im,i,|
|00001e60| 72 2c 67 2c 62 29 0a 52 | 41 53 54 45 52 20 2a 69 |r,g,b).R|ASTER *i|
|00001e70| 6d 3b 0a 69 6e 74 20 69 | 2c 2a 72 2c 2a 67 2c 2a |m;.int i|,*r,*g,*|
|00001e80| 62 3b 0a 7b 0a 09 69 6e | 74 20 78 3b 0a 09 0a 09 |b;.{..in|t x;....|
|00001e90| 73 77 69 74 63 68 20 28 | 69 6d 2d 3e 6d 61 70 74 |switch (|im->mapt|
|00001ea0| 79 70 65 29 20 7b 0a 09 | 09 63 61 73 65 20 52 4d |ype) {..|.case RM|
|00001eb0| 54 5f 4e 4f 4e 45 3a 20 | 0a 09 09 09 66 70 72 69 |T_NONE: |....fpri|
|00001ec0| 6e 74 66 28 73 74 64 65 | 72 72 2c 22 63 61 6e 27 |ntf(stde|rr,"can'|
|00001ed0| 74 20 67 65 74 20 66 72 | 6f 6d 20 61 20 6e 75 6c |t get fr|om a nul|
|00001ee0| 6c 20 6d 61 70 21 5c 6e | 22 29 3b 0a 09 09 09 62 |l map!\n|");....b|
|00001ef0| 72 65 61 6b 3b 0a 09 09 | 63 61 73 65 20 52 4d 54 |reak;...|case RMT|
|00001f00| 5f 52 41 57 3a 0a 09 09 | 09 2a 72 20 3d 20 69 6d |_RAW:...|.*r = im|
|00001f10| 2d 3e 6d 61 70 5b 69 5d | 3b 0a 09 09 09 62 72 65 |->map[i]|;....bre|
|00001f20| 61 6b 3b 0a 09 09 63 61 | 73 65 20 52 4d 54 5f 45 |ak;...ca|se RMT_E|
|00001f30| 51 55 41 4c 5f 52 47 42 | 3a 0a 09 09 09 78 20 3d |QUAL_RGB|:....x =|
|00001f40| 20 69 20 2a 20 33 3b 0a | 09 09 09 2a 72 20 3d 20 | i * 3;.|...*r = |
|00001f50| 69 6d 2d 3e 6d 61 70 5b | 78 2b 2b 5d 3b 0a 09 09 |im->map[|x++];...|
|00001f60| 09 2a 67 20 3d 20 69 6d | 2d 3e 6d 61 70 5b 78 2b |.*g = im|->map[x+|
|00001f70| 2b 5d 3b 0a 09 09 09 2a | 62 20 3d 20 69 6d 2d 3e |+];....*|b = im->|
|00001f80| 6d 61 70 5b 78 5d 3b 0a | 09 09 09 62 72 65 61 6b |map[x];.|...break|
|00001f90| 3b 0a 09 09 64 65 66 61 | 75 6c 74 3a 0a 09 09 09 |;...defa|ult:....|
|00001fa0| 66 70 72 69 6e 74 66 28 | 73 74 64 65 72 72 2c 22 |fprintf(|stderr,"|
|00001fb0| 75 6e 6b 6e 6f 77 6e 20 | 6d 61 70 20 74 79 70 65 |unknown |map type|
|00001fc0| 20 69 6e 20 72 61 73 74 | 65 72 66 69 6c 65 21 5c | in rast|erfile!\|
|00001fd0| 6e 22 29 3b 0a 09 7d 0a | 7d 0a 0a 52 67 65 74 6d |n");..}.|}..Rgetm|
|00001fe0| 61 70 70 65 64 70 69 78 | 28 69 6d 2c 72 2c 67 2c |appedpix|(im,r,g,|
|00001ff0| 62 29 0a 52 41 53 54 45 | 52 20 2a 69 6d 3b 0a 69 |b).RASTE|R *im;.i|
|00002000| 6e 74 20 2a 72 2c 2a 67 | 2c 2a 62 3b 0a 7b 0a 09 |nt *r,*g|,*b;.{..|
|00002010| 69 6e 74 20 70 69 78 2c | 20 78 3b 0a 0a 09 69 66 |int pix,| x;...if|
|00002020| 20 28 69 6d 2d 3e 6d 6f | 64 65 20 21 3d 20 52 29 | (im->mo|de != R)|
|00002030| 20 7b 0a 09 09 66 70 72 | 69 6e 74 66 28 73 74 64 | {...fpr|intf(std|
|00002040| 65 72 72 2c 22 61 74 74 | 65 6d 70 74 20 74 6f 20 |err,"att|empt to |
|00002050| 72 65 61 64 20 72 61 73 | 74 65 72 66 69 6c 65 20 |read ras|terfile |
|00002060| 6f 70 65 6e 65 64 20 66 | 6f 72 20 77 72 69 74 65 |opened f|or write|
|00002070| 21 5c 6e 22 29 3b 0a 09 | 09 72 65 74 75 72 6e 28 |!\n");..|.return(|
|00002080| 2d 31 29 3b 0a 09 7d 0a | 09 0a 09 69 66 20 28 69 |-1);..}.|...if (i|
|00002090| 6d 2d 3e 63 5f 70 69 78 | 65 6c 20 3e 3d 20 69 6d |m->c_pix|el >= im|
|000020a0| 2d 3e 77 69 64 74 68 29 | 20 7b 0a 09 09 66 72 65 |->width)| {...fre|
|000020b0| 61 64 28 69 6d 2d 3e 63 | 61 63 68 65 2c 69 6d 2d |ad(im->c|ache,im-|
|000020c0| 3e 6c 69 6e 65 6c 65 6e | 2c 31 2c 69 6d 2d 3e 66 |>linelen|,1,im->f|
|000020d0| 70 29 3b 0a 09 09 69 6d | 2d 3e 63 5f 70 69 78 65 |p);...im|->c_pixe|
|000020e0| 6c 20 3d 20 30 3b 0a 09 | 7d 0a 0a 09 70 69 78 20 |l = 0;..|}...pix |
|000020f0| 3d 20 70 72 5f 67 65 74 | 28 69 6d 2d 3e 63 5f 70 |= pr_get|(im->c_p|
|00002100| 72 2c 69 6d 2d 3e 63 5f | 70 69 78 65 6c 2c 30 29 |r,im->c_|pixel,0)|
|00002110| 3b 0a 09 69 6d 2d 3e 63 | 5f 70 69 78 65 6c 2b 2b |;..im->c|_pixel++|
|00002120| 3b 0a 09 0a 09 73 77 69 | 74 63 68 20 28 69 6d 2d |;....swi|tch (im-|
|00002130| 3e 6d 61 70 74 79 70 65 | 29 20 7b 0a 09 09 63 61 |>maptype|) {...ca|
|00002140| 73 65 20 52 4d 54 5f 52 | 41 57 3a 20 0a 09 09 09 |se RMT_R|AW: ....|
|00002150| 2a 72 20 3d 20 69 6d 2d | 3e 6d 61 70 5b 70 69 78 |*r = im-|>map[pix|
|00002160| 5d 3b 0a 09 09 09 62 72 | 65 61 6b 3b 0a 09 09 63 |];....br|eak;...c|
|00002170| 61 73 65 20 52 4d 54 5f | 45 51 55 41 4c 5f 52 47 |ase RMT_|EQUAL_RG|
|00002180| 42 3a 0a 09 09 09 78 20 | 3d 20 70 69 78 20 2a 20 |B:....x |= pix * |
|00002190| 33 3b 0a 09 09 09 2a 72 | 20 3d 20 69 6d 2d 3e 6d |3;....*r| = im->m|
|000021a0| 61 70 5b 78 2b 2b 5d 3b | 0a 09 09 09 2a 67 20 3d |ap[x++];|....*g =|
|000021b0| 20 69 6d 2d 3e 6d 61 70 | 5b 78 2b 2b 5d 3b 0a 09 | im->map|[x++];..|
|000021c0| 09 09 2a 62 20 3d 20 69 | 6d 2d 3e 6d 61 70 5b 78 |..*b = i|m->map[x|
|000021d0| 5d 3b 0a 09 09 09 62 72 | 65 61 6b 3b 0a 09 09 64 |];....br|eak;...d|
|000021e0| 65 66 61 75 6c 74 3a 0a | 09 09 09 2a 72 20 3d 20 |efault:.|...*r = |
|000021f0| 70 69 78 3b 0a 09 09 09 | 62 72 65 61 6b 3b 0a 09 |pix;....|break;..|
|00002200| 7d 0a 7d 0a 53 48 41 52 | 5f 45 4f 46 0a 66 69 20 |}.}.SHAR|_EOF.fi |
|00002210| 23 20 65 6e 64 20 6f 66 | 20 6f 76 65 72 77 72 69 |# end of| overwri|
|00002220| 74 69 6e 67 20 63 68 65 | 63 6b 0a 69 66 20 74 65 |ting che|ck.if te|
|00002230| 73 74 20 2d 66 20 27 72 | 61 73 74 2e 68 27 0a 74 |st -f 'r|ast.h'.t|
|00002240| 68 65 6e 0a 09 65 63 68 | 6f 20 73 68 61 72 3a 20 |hen..ech|o shar: |
|00002250| 77 69 6c 6c 20 6e 6f 74 | 20 6f 76 65 72 2d 77 72 |will not| over-wr|
|00002260| 69 74 65 20 65 78 69 73 | 74 69 6e 67 20 66 69 6c |ite exis|ting fil|
|00002270| 65 20 22 27 72 61 73 74 | 2e 68 27 22 0a 65 6c 73 |e "'rast|.h'".els|
|00002280| 65 0a 63 61 74 20 3c 3c | 20 5c 53 48 41 52 5f 45 |e.cat <<| \SHAR_E|
|00002290| 4f 46 20 3e 20 27 72 61 | 73 74 2e 68 27 0a 23 69 |OF > 'ra|st.h'.#i|
|000022a0| 6e 63 6c 75 64 65 20 3c | 73 74 64 69 6f 2e 68 3e |nclude <|stdio.h>|
|000022b0| 0a 23 69 6e 63 6c 75 64 | 65 20 3c 70 69 78 72 65 |.#includ|e <pixre|
|000022c0| 63 74 2f 70 69 78 72 65 | 63 74 5f 68 73 2e 68 3e |ct/pixre|ct_hs.h>|
|000022d0| 0a 0a 23 64 65 66 69 6e | 65 20 52 20 30 0a 23 64 |..#defin|e R 0.#d|
|000022e0| 65 66 69 6e 65 20 57 20 | 31 0a 0a 74 79 70 65 64 |efine W |1..typed|
|000022f0| 65 66 20 73 74 72 75 63 | 74 20 52 41 53 54 45 52 |ef struc|t RASTER|
|00002300| 5f 53 54 52 55 43 54 20 | 7b 0a 09 69 6e 74 20 68 |_STRUCT |{..int h|
|00002310| 65 69 67 68 74 3b 09 09 | 09 09 2f 2a 20 6e 75 6d |eight;..|../* num|
|00002320| 62 65 72 20 6f 66 20 72 | 6f 77 73 09 09 09 09 09 |ber of r|ows.....|
|00002330| 09 09 2a 2f 0a 09 69 6e | 74 20 77 69 64 74 68 3b |..*/..in|t width;|
|00002340| 09 09 09 09 2f 2a 20 6e | 75 6d 62 65 72 20 6f 66 |..../* n|umber of|
|00002350| 20 63 6f 6c 75 6d 6e 73 | 09 09 09 09 09 09 2a 2f | columns|......*/|
|00002360| 0a 09 69 6e 74 20 64 65 | 70 74 68 3b 09 09 09 09 |..int de|pth;....|
|00002370| 2f 2a 20 62 69 74 73 20 | 70 65 72 20 70 69 78 65 |/* bits |per pixe|
|00002380| 6c 09 09 09 09 09 09 09 | 2a 2f 0a 09 69 6e 74 20 |l.......|*/..int |
|00002390| 6c 65 6e 67 74 68 3b 09 | 09 09 09 2f 2a 20 62 79 |length;.|.../* by|
|000023a0| 74 65 73 20 6f 66 20 64 | 61 74 61 20 66 6f 6c 6c |tes of d|ata foll|
|000023b0| 6f 77 69 6e 67 20 68 65 | 61 64 65 72 09 09 09 2a |owing he|ader...*|
|000023c0| 2f 0a 09 69 6e 74 20 74 | 79 70 65 3b 09 09 09 09 |/..int t|ype;....|
|000023d0| 2f 2a 20 72 61 73 74 65 | 72 66 69 6c 65 20 74 79 |/* raste|rfile ty|
|000023e0| 70 65 09 09 09 09 09 09 | 09 2a 2f 0a 09 69 6e 74 |pe......|.*/..int|
|000023f0| 20 6d 61 70 74 79 70 65 | 3b 09 09 09 2f 2a 20 74 | maptype|;.../* t|
|00002400| 79 70 65 20 6f 66 20 6c | 6f 6f 6b 75 70 20 74 61 |ype of l|ookup ta|
|00002410| 62 6c 65 09 09 09 09 09 | 09 2a 2f 0a 09 69 6e 74 |ble.....|.*/..int|
|00002420| 20 6d 61 70 6c 65 6e 67 | 74 68 3b 09 09 09 2f 2a | mapleng|th;.../*|
|00002430| 20 6c 65 6e 67 74 68 20 | 6f 66 20 6c 6f 6f 6b 75 | length |of looku|
|00002440| 70 20 74 61 62 6c 65 09 | 09 09 09 09 2a 2f 0a 09 |p table.|....*/..|
|00002450| 63 68 61 72 20 2a 6d 61 | 70 3b 09 09 09 09 2f 2a |char *ma|p;..../*|
|00002460| 20 6c 6f 6f 6b 75 70 20 | 74 61 62 6c 65 09 09 09 | lookup |table...|
|00002470| 09 09 09 09 09 2a 2f 0a | 09 69 6e 74 20 6c 69 6e |.....*/.|.int lin|
|00002480| 65 6c 65 6e 3b 09 09 09 | 2f 2a 20 62 79 74 65 73 |elen;...|/* bytes|
|00002490| 20 69 6e 20 61 20 72 6f | 77 20 28 70 61 64 64 65 | in a ro|w (padde|
|000024a0| 64 20 74 6f 20 65 76 65 | 6e 20 31 36 20 62 69 74 |d to eve|n 16 bit|
|000024b0| 73 29 09 2a 2f 0a 09 46 | 49 4c 45 20 2a 66 70 3b |s).*/..F|ILE *fp;|
|000024c0| 09 09 09 09 2f 2a 20 66 | 69 6c 65 20 70 6f 69 6e |..../* f|ile poin|
|000024d0| 74 65 72 09 09 09 09 09 | 09 09 09 2a 2f 0a 09 69 |ter.....|...*/..i|
|000024e0| 6e 74 20 6d 6f 64 65 3b | 09 09 09 09 2f 2a 20 72 |nt mode;|..../* r|
|000024f0| 65 61 64 20 28 52 29 20 | 6f 72 20 77 72 69 74 65 |ead (R) |or write|
|00002500| 20 28 57 29 20 6d 6f 64 | 65 20 66 6c 61 67 09 09 | (W) mod|e flag..|
|00002510| 09 2a 2f 0a 09 63 68 61 | 72 20 2a 63 61 63 68 65 |.*/..cha|r *cache|
|00002520| 3b 09 09 09 2f 2a 20 63 | 61 63 68 65 20 6f 66 20 |;.../* c|ache of |
|00002530| 31 20 72 6f 77 09 09 09 | 09 09 09 09 2a 2f 0a 09 |1 row...|....*/..|
|00002540| 69 6e 74 20 63 5f 70 69 | 78 65 6c 3b 09 09 09 2f |int c_pi|xel;.../|
|00002550| 2a 20 63 75 72 72 65 6e | 74 20 70 69 78 65 6c 20 |* curren|t pixel |
|00002560| 69 6e 20 72 6f 77 20 63 | 61 63 68 65 09 09 09 09 |in row c|ache....|
|00002570| 2a 2f 0a 09 73 74 72 75 | 63 74 20 70 69 78 72 65 |*/..stru|ct pixre|
|00002580| 63 74 20 2a 63 5f 70 72 | 3b 09 2f 2a 20 6d 61 6b |ct *c_pr|;./* mak|
|00002590| 65 20 63 61 63 68 65 20 | 6c 6f 6f 6b 20 6c 69 6b |e cache |look lik|
|000025a0| 65 20 61 20 70 69 78 72 | 65 63 74 09 09 09 2a 2f |e a pixr|ect...*/|
|000025b0| 0a 7d 20 52 41 53 54 45 | 52 3b 0a 53 48 41 52 5f |.} RASTE|R;.SHAR_|
|000025c0| 45 4f 46 0a 66 69 20 23 | 20 65 6e 64 20 6f 66 20 |EOF.fi #| end of |
|000025d0| 6f 76 65 72 77 72 69 74 | 69 6e 67 20 63 68 65 63 |overwrit|ing chec|
|000025e0| 6b 0a 69 66 20 74 65 73 | 74 20 2d 66 20 27 72 61 |k.if tes|t -f 'ra|
|000025f0| 73 74 2e 33 27 0a 74 68 | 65 6e 0a 09 65 63 68 6f |st.3'.th|en..echo|
|00002600| 20 73 68 61 72 3a 20 77 | 69 6c 6c 20 6e 6f 74 20 | shar: w|ill not |
|00002610| 6f 76 65 72 2d 77 72 69 | 74 65 20 65 78 69 73 74 |over-wri|te exist|
|00002620| 69 6e 67 20 66 69 6c 65 | 20 22 27 72 61 73 74 2e |ing file| "'rast.|
|00002630| 33 27 22 0a 65 6c 73 65 | 0a 63 61 74 20 3c 3c 20 |3'".else|.cat << |
|00002640| 5c 53 48 41 52 5f 45 4f | 46 20 3e 20 27 72 61 73 |\SHAR_EO|F > 'ras|
|00002650| 74 2e 33 27 0a 2e 54 48 | 20 52 41 53 54 20 33 0a |t.3'..TH| RAST 3.|
|00002660| 2e 53 48 20 4e 41 4d 45 | 0a 72 61 73 74 20 2d 20 |.SH NAME|.rast - |
|00002670| 53 55 4e 20 72 61 73 74 | 65 72 66 69 6c 65 20 69 |SUN rast|erfile i|
|00002680| 6e 74 65 72 66 61 63 65 | 0a 2e 53 48 20 53 59 4e |nterface|..SH SYN|
|00002690| 4f 50 53 49 53 0a 2e 42 | 20 23 69 6e 63 6c 75 64 |OPSIS..B| #includ|
|000026a0| 65 20 5c 2a 28 6c 71 72 | 61 73 74 2e 68 5c 2a 28 |e \*(lqr|ast.h\*(|
|000026b0| 72 71 0a 2e 73 70 0a 2e | 42 20 52 41 53 54 45 52 |rq..sp..|B RASTER|
|000026c0| 20 2a 52 6f 70 65 6e 28 | 66 69 6c 65 6e 61 6d 65 | *Ropen(|filename|
|000026d0| 2c 6d 6f 64 65 29 0a 2e | 62 72 0a 2e 42 20 63 68 |,mode)..|br..B ch|
|000026e0| 61 72 20 2a 66 69 6c 65 | 6e 61 6d 65 3b 0a 2e 62 |ar *file|name;..b|
|000026f0| 72 0a 2e 42 20 69 6e 74 | 20 6d 6f 64 65 3b 0a 2e |r..B int| mode;..|
|00002700| 73 70 0a 2e 42 20 52 41 | 53 54 45 52 20 52 64 6f |sp..B RA|STER Rdo|
|00002710| 70 65 6e 28 66 69 6c 65 | 64 65 73 2c 6d 6f 64 65 |pen(file|des,mode|
|00002720| 29 0a 2e 62 72 0a 2e 42 | 20 69 6e 74 20 66 69 6c |)..br..B| int fil|
|00002730| 65 64 65 73 2c 20 6d 6f | 64 65 3b 0a 2e 73 70 0a |edes, mo|de;..sp.|
|00002740| 2e 42 20 52 67 65 74 68 | 65 61 64 65 72 28 72 61 |.B Rgeth|eader(ra|
|00002750| 73 74 65 72 29 0a 2e 62 | 72 0a 2e 42 20 52 41 53 |ster)..b|r..B RAS|
|00002760| 54 45 52 20 2a 72 61 73 | 74 65 72 3b 0a 2e 73 70 |TER *ras|ter;..sp|
|00002770| 0a 2e 42 20 52 70 75 74 | 68 65 61 64 65 72 28 72 |..B Rput|header(r|
|00002780| 61 73 74 65 72 29 0a 2e | 62 72 0a 2e 42 20 52 41 |aster)..|br..B RA|
|00002790| 53 54 45 52 20 2a 72 61 | 73 74 65 72 3b 0a 2e 73 |STER *ra|ster;..s|
|000027a0| 70 0a 2e 42 20 52 67 65 | 74 70 69 78 28 72 61 73 |p..B Rge|tpix(ras|
|000027b0| 74 65 72 29 0a 2e 62 72 | 0a 2e 42 20 52 41 53 54 |ter)..br|..B RAST|
|000027c0| 45 52 20 2a 72 61 73 74 | 65 72 3b 0a 2e 73 70 0a |ER *rast|er;..sp.|
|000027d0| 2e 42 20 52 70 75 74 70 | 69 78 28 72 61 73 74 65 |.B Rputp|ix(raste|
|000027e0| 72 2c 70 69 78 65 6c 29 | 0a 2e 62 72 0a 2e 42 20 |r,pixel)|..br..B |
|000027f0| 52 41 53 54 45 52 20 2a | 72 61 73 74 65 72 3b 0a |RASTER *|raster;.|
|00002800| 2e 62 72 0a 2e 42 20 69 | 6e 74 20 70 69 78 65 6c |.br..B i|nt pixel|
|00002810| 3b 0a 2e 73 70 0a 2e 42 | 20 52 67 65 74 6d 61 70 |;..sp..B| Rgetmap|
|00002820| 70 65 64 70 69 78 28 72 | 61 73 74 65 72 2c 76 61 |pedpix(r|aster,va|
|00002830| 6c 75 65 29 0a 2e 62 72 | 0a 2e 42 20 52 41 53 54 |lue)..br|..B RAST|
|00002840| 45 52 20 2a 72 61 73 74 | 65 72 3b 0a 2e 62 72 0a |ER *rast|er;..br.|
|00002850| 2e 42 20 69 6e 74 20 2a | 76 61 6c 75 65 3b 0a 2e |.B int *|value;..|
|00002860| 73 70 0a 2e 42 20 52 67 | 65 74 6d 61 70 70 65 64 |sp..B Rg|etmapped|
|00002870| 70 69 78 28 72 61 73 74 | 65 72 2c 72 65 64 2c 67 |pix(rast|er,red,g|
|00002880| 72 65 65 6e 2c 62 6c 75 | 65 29 0a 2e 62 72 0a 2e |reen,blu|e)..br..|
|00002890| 42 20 52 41 53 54 45 52 | 20 2a 72 61 73 74 65 72 |B RASTER| *raster|
|000028a0| 3b 0a 2e 62 72 0a 2e 42 | 20 69 6e 74 20 2a 72 65 |;..br..B| int *re|
|000028b0| 64 2c 20 2a 67 72 65 65 | 6e 2c 20 2a 62 6c 75 65 |d, *gree|n, *blue|
|000028c0| 3b 0a 2e 73 70 0a 2e 42 | 20 52 69 6e 69 74 6d 61 |;..sp..B| Rinitma|
|000028d0| 70 28 72 61 73 74 65 72 | 2c 74 79 70 65 2c 6c 65 |p(raster|,type,le|
|000028e0| 6e 67 74 68 29 0a 2e 62 | 72 0a 2e 42 20 52 41 53 |ngth)..b|r..B RAS|
|000028f0| 54 45 52 20 2a 72 61 73 | 74 65 72 3b 0a 2e 62 72 |TER *ras|ter;..br|
|00002900| 0a 2e 42 20 69 6e 74 20 | 74 79 70 65 2c 20 6c 65 |..B int |type, le|
|00002910| 6e 67 74 68 3b 0a 2e 73 | 70 0a 2e 42 20 52 70 75 |ngth;..s|p..B Rpu|
|00002920| 74 6d 61 70 28 72 61 73 | 74 65 72 2c 69 6e 64 65 |tmap(ras|ter,inde|
|00002930| 78 2c 76 61 6c 75 65 29 | 0a 2e 62 72 0a 2e 42 20 |x,value)|..br..B |
|00002940| 52 41 53 54 45 52 20 2a | 72 61 73 74 65 72 3b 0a |RASTER *|raster;.|
|00002950| 2e 62 72 0a 2e 42 20 69 | 6e 74 20 69 6e 64 65 78 |.br..B i|nt index|
|00002960| 2c 20 76 61 6c 75 65 3b | 0a 2e 73 70 0a 2e 42 20 |, value;|..sp..B |
|00002970| 52 70 75 74 6d 61 70 28 | 72 61 73 74 65 72 2c 69 |Rputmap(|raster,i|
|00002980| 6e 64 65 78 2c 72 65 64 | 2c 67 72 65 65 6e 2c 62 |ndex,red|,green,b|
|00002990| 6c 75 65 29 0a 2e 62 72 | 0a 2e 42 20 52 41 53 54 |lue)..br|..B RAST|
|000029a0| 45 52 20 2a 72 61 73 74 | 65 72 3b 0a 2e 62 72 0a |ER *rast|er;..br.|
|000029b0| 2e 42 20 69 6e 74 20 69 | 6e 64 65 78 2c 20 72 65 |.B int i|ndex, re|
|000029c0| 64 2c 20 67 72 65 65 6e | 2c 20 62 6c 75 65 3b 0a |d, green|, blue;.|
|000029d0| 2e 73 70 0a 2e 42 20 52 | 67 65 74 6d 61 70 28 72 |.sp..B R|getmap(r|
|000029e0| 61 73 74 65 72 2c 69 6e | 64 65 78 2c 76 61 6c 75 |aster,in|dex,valu|
|000029f0| 65 29 0a 2e 62 72 0a 2e | 42 20 52 41 53 54 45 52 |e)..br..|B RASTER|
|00002a00| 20 2a 72 61 73 74 65 72 | 3b 0a 2e 62 72 0a 2e 42 | *raster|;..br..B|
|00002a10| 20 69 6e 74 20 69 6e 64 | 65 78 2c 20 2a 76 61 6c | int ind|ex, *val|
|00002a20| 75 65 3b 0a 2e 73 70 0a | 2e 42 20 52 67 65 74 6d |ue;..sp.|.B Rgetm|
|00002a30| 61 70 28 72 61 73 74 65 | 72 2c 69 6e 64 65 78 2c |ap(raste|r,index,|
|00002a40| 72 65 64 2c 67 72 65 65 | 6e 2c 62 6c 75 65 29 0a |red,gree|n,blue).|
|00002a50| 2e 62 72 0a 2e 42 20 52 | 41 53 54 45 52 20 2a 72 |.br..B R|ASTER *r|
|00002a60| 61 73 74 65 72 3b 0a 2e | 62 72 0a 2e 42 20 69 6e |aster;..|br..B in|
|00002a70| 74 20 69 6e 64 65 78 2c | 20 2a 72 65 64 2c 20 2a |t index,| *red, *|
|00002a80| 67 72 65 65 6e 2c 20 2a | 62 6c 75 65 3b 0a 2e 73 |green, *|blue;..s|
|00002a90| 70 0a 2e 42 20 52 63 6c | 6f 73 65 28 72 61 73 74 |p..B Rcl|ose(rast|
|00002aa0| 65 72 29 0a 2e 62 72 0a | 2e 42 20 52 41 53 54 45 |er)..br.|.B RASTE|
|00002ab0| 52 20 2a 72 61 73 74 65 | 72 3b 0a 2e 73 70 0a 2e |R *raste|r;..sp..|
|00002ac0| 53 48 20 44 45 53 43 52 | 49 50 54 49 4f 4e 0a 54 |SH DESCR|IPTION.T|
|00002ad0| 68 69 73 20 6c 69 62 72 | 61 72 79 20 70 72 6f 76 |his libr|ary prov|
|00002ae0| 69 64 65 73 20 70 69 78 | 65 6c 20 49 2f 4f 20 66 |ides pix|el I/O f|
|00002af0| 6f 72 20 53 55 4e 20 72 | 61 73 74 65 72 66 69 6c |or SUN r|asterfil|
|00002b00| 65 73 2e 20 0a 2e 73 70 | 0a 2e 49 20 52 6f 70 65 |es. ..sp|..I Rope|
|00002b10| 6e 0a 6f 70 65 6e 73 20 | 61 20 53 55 4e 20 72 61 |n.opens |a SUN ra|
|00002b20| 73 74 65 72 66 69 6c 65 | 20 66 6f 72 20 72 65 61 |sterfile| for rea|
|00002b30| 64 69 6e 67 20 6f 72 20 | 77 72 69 74 69 6e 67 2c |ding or |writing,|
|00002b40| 20 61 6e 64 20 72 65 74 | 75 72 6e 73 20 61 20 52 | and ret|urns a R|
|00002b50| 41 53 54 45 52 0a 73 74 | 72 75 63 74 75 72 65 2e |ASTER.st|ructure.|
|00002b60| 20 20 54 68 65 20 6d 6f | 64 65 20 73 68 6f 75 6c | The mo|de shoul|
|00002b70| 64 20 62 65 20 52 20 66 | 6f 72 20 72 65 61 64 2c |d be R f|or read,|
|00002b80| 20 57 20 66 6f 72 20 77 | 72 69 74 65 2e 20 20 52 | W for w|rite. R|
|00002b90| 20 61 6e 64 20 57 20 61 | 72 65 0a 64 65 66 69 6e | and W a|re.defin|
|00002ba0| 65 64 20 69 6e 20 74 68 | 65 20 66 69 6c 65 20 72 |ed in th|e file r|
|00002bb0| 61 73 74 2e 68 2e 0a 2e | 49 20 52 64 6f 70 65 6e |ast.h...|I Rdopen|
|00002bc0| 0a 6f 70 65 6e 73 20 61 | 20 73 74 72 65 61 6d 2c |.opens a| stream,|
|00002bd0| 20 73 70 65 63 69 66 69 | 65 64 20 62 79 20 61 20 | specifi|ed by a |
|00002be0| 55 4e 49 58 20 66 69 6c | 65 20 64 65 73 63 72 69 |UNIX fil|e descri|
|00002bf0| 70 74 6f 72 2e 20 20 54 | 68 65 20 52 41 53 54 45 |ptor. T|he RASTE|
|00002c00| 52 20 73 74 72 75 63 74 | 75 72 65 0a 69 73 20 64 |R struct|ure.is d|
|00002c10| 65 66 69 6e 65 64 20 62 | 65 6c 6f 77 2e 0a 2e 73 |efined b|elow...s|
|00002c20| 70 0a 41 66 74 65 72 20 | 61 20 72 61 73 74 65 72 |p.After |a raster|
|00002c30| 66 69 6c 65 20 68 61 73 | 20 62 65 65 6e 20 6f 70 |file has| been op|
|00002c40| 65 6e 65 64 20 74 6f 20 | 72 65 61 64 2c 20 64 61 |ened to |read, da|
|00002c50| 74 61 20 66 72 6f 6d 20 | 74 68 65 20 72 61 73 74 |ta from |the rast|
|00002c60| 65 72 66 69 6c 65 0a 68 | 65 61 64 65 72 20 69 73 |erfile.h|eader is|
|00002c70| 20 66 65 74 63 68 65 64 | 20 61 6e 64 20 70 6c 61 | fetched| and pla|
|00002c80| 63 65 64 20 69 6e 20 74 | 68 65 20 52 41 53 54 45 |ced in t|he RASTE|
|00002c90| 52 20 73 74 72 75 63 74 | 75 72 65 20 77 69 74 68 |R struct|ure with|
|00002ca0| 20 61 20 63 61 6c 6c 20 | 74 6f 0a 2e 49 20 52 67 | a call |to..I Rg|
|00002cb0| 65 74 68 65 61 64 65 72 | 2e 0a 41 20 72 61 73 74 |etheader|..A rast|
|00002cc0| 65 72 66 69 6c 65 20 6f | 70 65 6e 65 64 20 66 6f |erfile o|pened fo|
|00002cd0| 72 20 6f 75 74 70 75 74 | 20 6d 75 73 74 20 68 61 |r output| must ha|
|00002ce0| 76 65 20 28 61 74 20 6c | 65 61 73 74 29 20 69 74 |ve (at l|east) it|
|00002cf0| 27 73 20 77 69 64 74 68 | 2c 20 68 65 69 67 68 74 |'s width|, height|
|00002d00| 2c 20 61 6e 64 0a 64 65 | 70 74 68 20 73 65 74 20 |, and.de|pth set |
|00002d10| 62 65 66 6f 72 65 20 74 | 68 65 20 68 65 61 64 65 |before t|he heade|
|00002d20| 72 20 6d 61 79 20 62 65 | 20 77 72 69 74 74 65 6e |r may be| written|
|00002d30| 20 77 69 74 68 0a 2e 49 | 20 52 70 75 74 68 65 61 | with..I| Rputhea|
|00002d40| 64 65 72 2e 0a 49 66 20 | 74 68 65 20 68 65 61 64 |der..If |the head|
|00002d50| 65 72 20 69 73 20 74 6f | 20 69 6e 63 6c 75 64 65 |er is to| include|
|00002d60| 20 61 20 6d 61 70 2c 20 | 74 68 65 20 6d 61 70 20 | a map, |the map |
|00002d70| 6d 75 73 74 20 62 65 20 | 69 6e 69 74 69 61 6c 69 |must be |initiali|
|00002d80| 7a 65 64 20 77 69 74 68 | 20 61 20 63 61 6c 6c 20 |zed with| a call |
|00002d90| 74 6f 20 0a 2e 49 20 52 | 69 6e 69 74 6d 61 70 2e |to ..I R|initmap.|
|00002da0| 0a 4d 61 70 20 76 61 6c | 75 65 73 20 6d 61 79 20 |.Map val|ues may |
|00002db0| 62 65 20 73 65 74 20 64 | 69 72 65 63 74 6c 79 20 |be set d|irectly |
|00002dc0| 69 6e 20 74 68 65 20 52 | 41 53 54 45 52 20 73 74 |in the R|ASTER st|
|00002dd0| 72 75 63 74 75 72 65 2c | 20 6f 72 20 74 68 65 79 |ructure,| or they|
|00002de0| 20 6d 79 20 62 65 20 73 | 65 74 0a 75 73 69 6e 67 | my be s|et.using|
|00002df0| 20 0a 2e 49 20 52 70 75 | 74 6d 61 70 2e 0a 54 68 | ..I Rpu|tmap..Th|
|00002e00| 65 20 6d 61 70 20 74 79 | 70 65 20 6d 75 73 74 20 |e map ty|pe must |
|00002e10| 62 65 20 6f 6e 65 20 64 | 65 66 69 6e 65 64 20 69 |be one d|efined i|
|00002e20| 6e 20 74 68 65 20 69 6e | 63 6c 75 64 65 20 66 69 |n the in|clude fi|
|00002e30| 6c 65 20 3c 72 61 73 74 | 65 72 66 69 6c 65 2e 68 |le <rast|erfile.h|
|00002e40| 3e 2e 0a 2e 73 70 0a 46 | 6f 72 20 63 6f 6e 76 65 |>...sp.F|or conve|
|00002e50| 6e 69 65 6e 63 65 2c 20 | 6d 61 70 20 76 61 6c 75 |nience, |map valu|
|00002e60| 65 73 20 6d 61 79 20 62 | 65 20 72 65 74 72 69 65 |es may b|e retrie|
|00002e70| 76 65 64 20 77 69 74 68 | 0a 2e 49 20 52 67 65 74 |ved with|..I Rget|
|00002e80| 6d 61 70 2e 0a 2e 73 70 | 0a 45 61 63 68 20 63 61 |map...sp|.Each ca|
|00002e90| 6c 6c 20 74 6f 0a 2e 49 | 20 52 67 65 74 70 69 78 |ll to..I| Rgetpix|
|00002ea0| 0a 77 69 6c 6c 20 72 65 | 74 75 72 6e 20 61 20 72 |.will re|turn a r|
|00002eb0| 61 77 20 70 69 78 65 6c | 20 76 61 6c 75 65 20 66 |aw pixel| value f|
|00002ec0| 72 6f 6d 20 74 68 65 20 | 72 61 73 74 65 72 66 69 |rom the |rasterfi|
|00002ed0| 6c 65 2e 20 0a 2e 49 20 | 52 67 65 74 6d 61 70 70 |le. ..I |Rgetmapp|
|00002ee0| 65 64 70 69 78 0a 72 65 | 74 75 72 6e 73 20 74 68 |edpix.re|turns th|
|00002ef0| 65 20 72 65 73 75 6c 74 | 20 6f 66 20 70 75 74 74 |e result| of putt|
|00002f00| 69 6e 67 20 74 68 65 20 | 72 61 77 20 70 69 78 65 |ing the |raw pixe|
|00002f10| 6c 20 76 61 6c 75 65 20 | 74 68 72 6f 75 67 68 20 |l value |through |
|00002f20| 74 68 65 20 72 61 73 74 | 65 72 66 69 6c 65 20 6d |the rast|erfile m|
|00002f30| 61 70 2e 0a 2e 49 20 52 | 70 75 74 70 69 78 0a 77 |ap...I R|putpix.w|
|00002f40| 72 69 74 65 73 20 70 69 | 78 65 6c 20 76 61 6c 75 |rites pi|xel valu|
|00002f50| 65 73 20 74 6f 20 74 68 | 65 20 72 61 73 74 65 72 |es to th|e raster|
|00002f60| 66 69 6c 65 2e 0a 2e 73 | 70 0a 41 20 72 61 73 74 |file...s|p.A rast|
|00002f70| 65 72 66 69 6c 65 20 69 | 73 20 63 6c 6f 73 65 64 |erfile i|s closed|
|00002f80| 20 77 69 74 68 20 0a 2e | 49 20 52 63 6c 6f 73 65 | with ..|I Rclose|
|00002f90| 2e 0a 2e 53 48 20 22 52 | 41 53 54 45 52 20 53 54 |...SH "R|ASTER ST|
|00002fa0| 52 55 43 54 55 52 45 22 | 0a 54 68 65 20 64 61 74 |RUCTURE"|.The dat|
|00002fb0| 61 20 73 74 72 75 63 74 | 75 72 65 20 6d 61 69 6e |a struct|ure main|
|00002fc0| 74 61 69 6e 65 64 20 62 | 79 20 74 68 65 73 65 20 |tained b|y these |
|00002fd0| 72 6f 75 74 69 6e 65 73 | 20 69 73 20 64 65 66 69 |routines| is defi|
|00002fe0| 6e 65 64 20 69 6e 20 74 | 68 65 20 66 69 6c 65 20 |ned in t|he file |
|00002ff0| 72 61 73 74 2e 68 2e 0a | 2e 73 70 0a 2e 6e 66 0a |rast.h..|.sp..nf.|
|00003000| 74 79 70 65 64 65 66 20 | 73 74 72 75 63 74 20 52 |typedef |struct R|
|00003010| 41 53 54 45 52 5f 53 54 | 52 55 43 54 20 7b 0a 20 |ASTER_ST|RUCT {. |
|00003020| 20 20 20 69 6e 74 20 68 | 65 69 67 68 74 3b 20 20 | int h|eight; |
|00003030| 20 20 20 20 20 20 20 20 | 20 20 20 2f 2a 20 6e 75 | | /* nu|
|00003040| 6d 62 65 72 20 6f 66 20 | 72 6f 77 73 20 20 20 20 |mber of |rows |
|00003050| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00003060| 20 20 20 20 20 20 20 2a | 2f 0a 20 20 20 20 69 6e | *|/. in|
|00003070| 74 20 77 69 64 74 68 3b | 20 20 20 20 20 20 20 20 |t width;| |
|00003080| 20 20 20 20 20 20 2f 2a | 20 6e 75 6d 62 65 72 20 | /*| number |
|00003090| 6f 66 20 63 6f 6c 75 6d | 6e 73 20 20 20 20 20 20 |of colum|ns |
|000030a0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|000030b0| 20 20 2a 2f 0a 20 20 20 | 20 69 6e 74 20 64 65 70 | */. | int dep|
|000030c0| 74 68 3b 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |th; | |
|000030d0| 20 2f 2a 20 62 69 74 73 | 20 70 65 72 20 70 69 78 | /* bits| per pix|
|000030e0| 65 6c 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |el | |
|000030f0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 2a 2f 0a | | */.|
|00003100| 20 20 20 20 69 6e 74 20 | 6c 65 6e 67 74 68 3b 20 | int |length; |
|00003110| 20 20 20 20 20 20 20 20 | 20 20 20 20 2f 2a 20 62 | | /* b|
|00003120| 79 74 65 73 20 6f 66 20 | 64 61 74 61 20 66 6f 6c |ytes of |data fol|
|00003130| 6c 6f 77 69 6e 67 20 68 | 65 61 64 65 72 20 20 20 |lowing h|eader |
|00003140| 20 20 20 20 20 20 20 20 | 2a 2f 0a 20 20 20 20 69 | |*/. i|
|00003150| 6e 74 20 74 79 70 65 3b | 20 20 20 20 20 20 20 20 |nt type;| |
|00003160| 20 20 20 20 20 20 20 2f | 2a 20 72 61 73 74 65 72 | /|* raster|
|00003170| 66 69 6c 65 20 74 79 70 | 65 20 20 20 20 20 20 20 |file typ|e |
|00003180| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00003190| 20 20 20 2a 2f 0a 20 20 | 20 20 69 6e 74 20 6d 61 | */. | int ma|
|000031a0| 70 74 79 70 65 3b 20 20 | 20 20 20 20 20 20 20 20 |ptype; | |
|000031b0| 20 20 2f 2a 20 74 79 70 | 65 20 6f 66 20 6c 6f 6f | /* typ|e of loo|
|000031c0| 6b 75 70 20 74 61 62 6c | 65 20 20 20 20 20 20 20 |kup tabl|e |
|000031d0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 2a 2f | | */|
|000031e0| 0a 20 20 20 20 69 6e 74 | 20 6d 61 70 6c 65 6e 67 |. int| mapleng|
|000031f0| 74 68 3b 20 20 20 20 20 | 20 20 20 20 20 2f 2a 20 |th; | /* |
|00003200| 6c 65 6e 67 74 68 20 6f | 66 20 6c 6f 6f 6b 75 70 |length o|f lookup|
|00003210| 20 74 61 62 6c 65 20 20 | 20 20 20 20 20 20 20 20 | table | |
|00003220| 20 20 20 20 20 20 20 20 | 20 2a 2f 0a 20 20 20 20 | | */. |
|00003230| 63 68 61 72 20 2a 6d 61 | 70 3b 20 20 20 20 20 20 |char *ma|p; |
|00003240| 20 20 20 20 20 20 20 20 | 2f 2a 20 6c 6f 6f 6b 75 | |/* looku|
|00003250| 70 20 74 61 62 6c 65 20 | 20 20 20 20 20 20 20 20 |p table | |
|00003260| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00003270| 20 20 20 20 2a 2f 0a 20 | 20 20 20 69 6e 74 20 6c | */. | int l|
|00003280| 69 6e 65 6c 65 6e 3b 20 | 20 20 20 20 20 20 20 20 |inelen; | |
|00003290| 20 20 20 2f 2a 20 62 79 | 74 65 73 20 69 6e 20 61 | /* by|tes in a|
|000032a0| 20 72 6f 77 20 28 70 61 | 64 64 65 64 20 74 6f 20 | row (pa|dded to |
|000032b0| 65 76 65 6e 20 31 36 20 | 62 69 74 73 29 20 20 2a |even 16 |bits) *|
|000032c0| 2f 0a 20 20 20 20 46 49 | 4c 45 20 2a 66 70 3b 20 |/. FI|LE *fp; |
|000032d0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 2f 2a | | /*|
|000032e0| 20 66 69 6c 65 20 70 6f | 69 6e 74 65 72 20 20 20 | file po|inter |
|000032f0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00003300| 20 20 20 20 20 20 20 20 | 20 20 2a 2f 0a 20 20 20 | | */. |
|00003310| 20 69 6e 74 20 6d 6f 64 | 65 3b 20 20 20 20 20 20 | int mod|e; |
|00003320| 20 20 20 20 20 20 20 20 | 20 2f 2a 20 72 65 61 64 | | /* read|
|00003330| 20 28 52 29 20 6f 72 20 | 77 72 69 74 65 20 28 57 | (R) or |write (W|
|00003340| 29 20 6d 6f 64 65 20 66 | 6c 61 67 20 20 20 20 20 |) mode f|lag |
|00003350| 20 20 20 20 20 2a 2f 0a | 20 20 20 20 63 68 61 72 | */.| char|
|00003360| 20 2a 63 61 63 68 65 3b | 20 20 20 20 20 20 20 20 | *cache;| |
|00003370| 20 20 20 20 2f 2a 20 63 | 61 63 68 65 20 6f 66 20 | /* c|ache of |
|00003380| 31 20 72 6f 77 20 20 20 | 20 20 20 20 20 20 20 20 |1 row | |
|00003390| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|000033a0| 2a 2f 0a 20 20 20 20 69 | 6e 74 20 63 5f 70 69 78 |*/. i|nt c_pix|
|000033b0| 65 6c 3b 20 20 20 20 20 | 20 20 20 20 20 20 20 2f |el; | /|
|000033c0| 2a 20 63 75 72 72 65 6e | 74 20 70 69 78 65 6c 20 |* curren|t pixel |
|000033d0| 69 6e 20 72 6f 77 20 63 | 61 63 68 65 20 20 20 20 |in row c|ache |
|000033e0| 20 20 20 20 20 20 20 20 | 20 20 20 2a 2f 0a 20 20 | | */. |
|000033f0| 20 20 73 74 72 75 63 74 | 20 70 69 78 72 65 63 74 | struct| pixrect|
|00003400| 20 2a 63 5f 70 72 3b 20 | 20 20 2f 2a 20 6d 61 6b | *c_pr; | /* mak|
|00003410| 65 20 63 61 63 68 65 20 | 6c 6f 6f 6b 20 6c 69 6b |e cache |look lik|
|00003420| 65 20 61 20 70 69 78 72 | 65 63 74 20 20 20 20 20 |e a pixr|ect |
|00003430| 20 20 20 20 20 20 2a 2f | 0a 7d 20 52 41 53 54 45 | */|.} RASTE|
|00003440| 52 3b 0a 2e 66 69 0a 2e | 73 70 0a 54 68 65 20 68 |R;..fi..|sp.The h|
|00003450| 65 69 67 68 74 2c 20 77 | 69 64 74 68 2c 20 64 65 |eight, w|idth, de|
|00003460| 70 74 68 2c 20 6c 65 6e | 67 74 68 2c 20 74 79 70 |pth, len|gth, typ|
|00003470| 65 2c 20 6d 61 70 74 79 | 70 65 2c 20 61 6e 64 20 |e, mapty|pe, and |
|00003480| 6d 61 70 6c 65 6e 67 74 | 68 20 66 69 65 6c 64 73 |maplengt|h fields|
|00003490| 0a 68 61 76 65 20 65 78 | 61 63 74 6c 79 20 74 68 |.have ex|actly th|
|000034a0| 65 20 73 61 6d 65 20 6d | 65 61 6e 69 6e 67 20 61 |e same m|eaning a|
|000034b0| 73 20 74 68 65 79 20 64 | 6f 20 69 6e 20 72 61 73 |s they d|o in ras|
|000034c0| 74 65 72 66 69 6c 65 73 | 2e 20 20 54 68 65 20 6d |terfiles|. The m|
|000034d0| 61 70 20 66 69 65 6c 64 | 0a 69 73 20 75 73 65 64 |ap field|.is used|
|000034e0| 20 74 6f 20 73 74 6f 72 | 65 20 74 68 65 20 72 61 | to stor|e the ra|
|000034f0| 73 74 65 72 66 69 6c 65 | 20 6d 61 70 20 64 61 74 |sterfile| map dat|
|00003500| 61 2e 0a 2e 73 70 0a 54 | 68 65 20 6c 69 6e 65 6c |a...sp.T|he linel|
|00003510| 65 6e 20 66 69 65 6c 64 | 20 67 69 76 65 73 20 74 |en field| gives t|
|00003520| 68 65 20 6e 75 6d 62 65 | 72 20 6f 66 20 62 79 74 |he numbe|r of byt|
|00003530| 65 73 20 69 6e 20 61 20 | 73 69 6e 67 6c 65 20 6c |es in a |single l|
|00003540| 69 6e 65 20 28 72 6f 77 | 29 0a 69 6e 20 74 68 65 |ine (row|).in the|
|00003550| 20 72 61 73 74 65 72 66 | 69 6c 65 2e 20 20 54 68 | rasterf|ile. Th|
|00003560| 69 73 20 69 73 20 64 69 | 66 66 65 72 65 6e 74 20 |is is di|fferent |
|00003570| 66 72 6f 6d 20 74 68 65 | 20 77 69 64 74 68 20 62 |from the| width b|
|00003580| 65 63 61 75 73 65 20 65 | 61 63 68 20 6c 69 6e 65 |ecause e|ach line|
|00003590| 0a 69 73 20 70 61 64 64 | 65 64 20 77 69 74 68 20 |.is padd|ed with |
|000035a0| 7a 65 72 6f 20 62 69 74 | 73 20 74 6f 20 6d 61 6b |zero bit|s to mak|
|000035b0| 65 20 69 74 20 61 6e 20 | 69 6e 74 65 67 65 72 20 |e it an |integer |
|000035c0| 6d 75 6c 74 69 70 6c 65 | 20 6f 66 20 31 36 20 62 |multiple| of 16 b|
|000035d0| 69 74 73 20 69 6e 20 6c | 65 6e 67 74 68 2e 0a 2e |its in l|ength...|
|000035e0| 73 70 0a 54 68 65 20 55 | 4e 49 58 20 66 69 6c 65 |sp.The U|NIX file|
|000035f0| 20 70 6f 69 6e 74 65 72 | 20 69 73 20 6b 65 70 74 | pointer| is kept|
|00003600| 20 69 6e 20 74 68 65 20 | 66 70 20 66 69 65 6c 64 | in the |fp field|
|00003610| 2c 20 61 6e 64 20 61 20 | 72 65 61 64 2f 77 72 69 |, and a |read/wri|
|00003620| 74 65 20 66 6c 61 67 20 | 69 73 20 0a 6b 65 70 74 |te flag |is .kept|
|00003630| 20 69 6e 20 74 68 65 20 | 6d 6f 64 65 20 66 69 65 | in the |mode fie|
|00003640| 6c 64 2e 0a 2e 73 70 0a | 50 69 78 65 6c 73 20 61 |ld...sp.|Pixels a|
|00003650| 72 65 20 73 74 6f 72 65 | 64 20 69 6e 20 74 68 65 |re store|d in the|
|00003660| 20 63 61 63 68 65 20 66 | 69 65 6c 64 2c 20 77 68 | cache f|ield, wh|
|00003670| 69 63 68 20 68 6f 6c 64 | 73 20 6f 6e 65 20 6c 69 |ich hold|s one li|
|00003680| 6e 65 20 28 72 6f 77 29 | 20 6f 66 20 74 68 65 0a |ne (row)| of the.|
|00003690| 72 61 73 74 65 72 2e 20 | 54 68 65 20 63 61 63 68 |raster. |The cach|
|000036a0| 65 20 69 73 20 6d 61 69 | 6e 74 61 69 6e 65 64 20 |e is mai|ntained |
|000036b0| 62 79 20 0a 2e 49 20 52 | 67 65 74 70 69 78 0a 61 |by ..I R|getpix.a|
|000036c0| 6e 64 0a 2e 49 20 52 70 | 75 74 70 69 78 2e 0a 54 |nd..I Rp|utpix..T|
|000036d0| 68 65 20 63 75 72 72 65 | 6e 74 20 70 69 78 65 6c |he curre|nt pixel|
|000036e0| 20 28 63 6f 6c 75 6d 6e | 29 20 77 69 74 68 69 6e | (column|) within|
|000036f0| 20 74 68 65 20 63 61 63 | 68 65 20 69 73 20 72 65 | the cac|he is re|
|00003700| 63 6f 72 64 65 64 20 62 | 79 20 69 6e 20 74 68 65 |corded b|y in the|
|00003710| 20 63 5f 70 69 78 65 6c | 0a 66 69 65 6c 64 2e 20 | c_pixel|.field. |
|00003720| 20 54 68 65 20 63 61 63 | 68 65 20 69 73 20 65 66 | The cac|he is ef|
|00003730| 66 69 63 69 65 6e 74 6c | 79 20 61 63 63 65 73 73 |ficientl|y access|
|00003740| 65 64 20 62 79 20 74 75 | 72 6e 69 6e 67 20 69 74 |ed by tu|rning it|
|00003750| 20 69 6e 74 6f 20 61 20 | 6d 65 6d 6f 72 79 20 70 | into a |memory p|
|00003760| 69 78 72 65 63 74 0a 61 | 6e 64 20 75 73 69 6e 67 |ixrect.a|nd using|
|00003770| 20 0a 2e 49 20 70 72 5f | 67 65 74 0a 61 6e 64 0a | ..I pr_|get.and.|
|00003780| 2e 49 20 70 72 5f 70 75 | 74 0a 74 6f 20 64 6f 20 |.I pr_pu|t.to do |
|00003790| 74 68 65 20 6e 65 63 65 | 73 73 61 72 79 20 62 69 |the nece|ssary bi|
|000037a0| 74 20 73 74 75 66 66 69 | 6e 67 2e 20 20 54 68 65 |t stuffi|ng. The|
|000037b0| 20 6d 65 6d 6f 72 79 20 | 70 69 78 72 65 63 74 20 | memory |pixrect |
|000037c0| 69 73 20 6b 65 70 74 20 | 69 6e 20 74 68 65 20 63 |is kept |in the c|
|000037d0| 5f 70 72 0a 66 69 65 6c | 64 2e 20 20 42 65 63 61 |_pr.fiel|d. Beca|
|000037e0| 75 73 65 20 6f 66 20 74 | 68 69 73 2c 20 70 72 6f |use of t|his, pro|
|000037f0| 67 72 61 6d 73 20 75 73 | 69 6e 67 20 74 68 69 73 |grams us|ing this|
|00003800| 20 6c 69 62 72 61 72 79 | 20 6d 75 73 74 20 62 65 | library| must be|
|00003810| 20 63 6f 6d 70 69 6c 65 | 64 20 77 69 74 68 0a 2d | compile|d with.-|
|00003820| 6c 70 69 78 72 65 63 74 | 2e 0a 2e 53 48 20 41 55 |lpixrect|...SH AU|
|00003830| 54 48 4f 52 0a 4d 61 72 | 63 20 4d 61 6a 6b 61 0a |THOR.Mar|c Majka.|
|00003840| 53 48 41 52 5f 45 4f 46 | 0a 66 69 20 23 20 65 6e |SHAR_EOF|.fi # en|
|00003850| 64 20 6f 66 20 6f 76 65 | 72 77 72 69 74 69 6e 67 |d of ove|rwriting|
|00003860| 20 63 68 65 63 6b 0a 69 | 66 20 74 65 73 74 20 2d | check.i|f test -|
|00003870| 66 20 27 72 64 65 6d 6f | 2e 63 27 0a 74 68 65 6e |f 'rdemo|.c'.then|
|00003880| 0a 09 65 63 68 6f 20 73 | 68 61 72 3a 20 77 69 6c |..echo s|har: wil|
|00003890| 6c 20 6e 6f 74 20 6f 76 | 65 72 2d 77 72 69 74 65 |l not ov|er-write|
|000038a0| 20 65 78 69 73 74 69 6e | 67 20 66 69 6c 65 20 22 | existin|g file "|
|000038b0| 27 72 64 65 6d 6f 2e 63 | 27 22 0a 65 6c 73 65 0a |'rdemo.c|'".else.|
|000038c0| 63 61 74 20 3c 3c 20 5c | 53 48 41 52 5f 45 4f 46 |cat << \|SHAR_EOF|
|000038d0| 20 3e 20 27 72 64 65 6d | 6f 2e 63 27 0a 2f 2a 2a | > 'rdem|o.c'./**|
|000038e0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000038f0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00003900| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00003910| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00003920| 2a 2a 2a 2a 2a 0a 0a 20 | 20 20 72 64 65 6d 6f 20 |*****.. | rdemo |
|00003930| 2d 20 72 65 61 64 73 20 | 61 20 72 61 73 74 65 72 |- reads |a raster|
|00003940| 66 69 6c 65 2c 20 63 6f | 6d 70 75 74 65 73 20 74 |file, co|mputes t|
|00003950| 68 65 20 61 76 65 72 61 | 67 65 20 6f 66 20 74 68 |he avera|ge of th|
|00003960| 65 20 63 6f 6c 6f 75 72 | 0a 20 20 20 76 61 6c 75 |e colour|. valu|
|00003970| 65 73 20 28 69 66 20 61 | 70 70 6c 69 63 61 62 6c |es (if a|pplicabl|
|00003980| 65 29 20 6f 66 20 74 68 | 65 20 70 69 78 65 6c 73 |e) of th|e pixels|
|00003990| 2c 20 61 6e 64 20 77 72 | 69 74 65 73 20 61 20 6e |, and wr|ites a n|
|000039a0| 65 77 20 72 61 73 74 65 | 72 66 69 6c 65 0a 20 20 |ew raste|rfile. |
|000039b0| 20 77 69 74 68 20 74 68 | 65 20 61 76 65 72 61 67 | with th|e averag|
|000039c0| 65 2e 20 20 41 6e 20 69 | 6e 76 65 72 74 69 6e 67 |e. An i|nverting|
|000039d0| 20 63 6f 6c 6f 75 72 20 | 6d 61 70 20 69 73 20 61 | colour |map is a|
|000039e0| 64 64 65 64 2e 0a 0a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |dded...*|********|
|000039f0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00003a00| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00003a10| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00003a20| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2f 0a |********|******/.|
|00003a30| 0a 23 69 6e 63 6c 75 64 | 65 20 3c 73 74 64 69 6f |.#includ|e <stdio|
|00003a40| 2e 68 3e 0a 23 69 6e 63 | 6c 75 64 65 20 22 72 61 |.h>.#inc|lude "ra|
|00003a50| 73 74 2e 68 22 0a 0a 6d | 61 69 6e 28 61 72 67 63 |st.h"..m|ain(argc|
|00003a60| 2c 61 72 67 76 29 0a 69 | 6e 74 20 61 72 67 63 3b |,argv).i|nt argc;|
|00003a70| 0a 63 68 61 72 20 2a 61 | 72 67 76 5b 5d 3b 0a 7b |.char *a|rgv[];.{|
|00003a80| 0a 09 69 6e 74 20 72 2c | 20 67 2c 20 62 2c 20 61 |..int r,| g, b, a|
|00003a90| 76 67 2c 20 72 6f 77 2c | 20 63 6f 6c 2c 20 69 2c |vg, row,| col, i,|
|00003aa0| 20 70 69 78 2c 20 69 66 | 69 6c 65 2c 20 6f 66 69 | pix, if|ile, ofi|
|00003ab0| 6c 65 3b 0a 09 52 41 53 | 54 45 52 20 2a 69 72 61 |le;..RAS|TER *ira|
|00003ac0| 73 74 2c 20 2a 6f 72 61 | 73 74 2c 20 2a 52 6f 70 |st, *ora|st, *Rop|
|00003ad0| 65 6e 28 29 2c 20 2a 52 | 64 6f 70 65 6e 28 29 3b |en(), *R|dopen();|
|00003ae0| 0a 0a 09 69 66 69 6c 65 | 20 3d 20 30 3b 0a 09 6f |...ifile| = 0;..o|
|00003af0| 66 69 6c 65 20 3d 20 30 | 3b 0a 0a 09 66 6f 72 20 |file = 0|;...for |
|00003b00| 28 69 20 3d 20 31 3b 20 | 69 20 3c 20 61 72 67 63 |(i = 1; |i < argc|
|00003b10| 3b 20 69 2b 2b 29 20 7b | 0a 09 09 69 66 20 28 61 |; i++) {|...if (a|
|00003b20| 72 67 76 5b 69 5d 5b 30 | 5d 20 3d 3d 20 27 2d 27 |rgv[i][0|] == '-'|
|00003b30| 29 20 7b 0a 09 09 09 73 | 77 69 74 63 68 20 28 61 |) {....s|witch (a|
|00003b40| 72 67 76 5b 69 5d 5b 31 | 5d 29 20 7b 0a 09 09 09 |rgv[i][1|]) {....|
|00003b50| 09 63 61 73 65 20 27 69 | 27 3a 20 69 66 69 6c 65 |.case 'i|': ifile|
|00003b60| 20 3d 20 2b 2b 69 3b 20 | 62 72 65 61 6b 3b 0a 09 | = ++i; |break;..|
|00003b70| 09 09 09 63 61 73 65 20 | 27 6f 27 3a 20 6f 66 69 |...case |'o': ofi|
|00003b80| 6c 65 20 3d 20 2b 2b 69 | 3b 20 62 72 65 61 6b 3b |le = ++i|; break;|
|00003b90| 0a 09 09 09 09 64 65 66 | 61 75 6c 74 3a 20 20 75 |.....def|ault: u|
|00003ba0| 73 61 67 65 28 29 3b 0a | 09 09 09 7d 0a 09 09 7d |sage();.|...}...}|
|00003bb0| 0a 09 7d 0a 0a 09 69 66 | 20 28 69 66 69 6c 65 29 |..}...if| (ifile)|
|00003bc0| 20 69 72 61 73 74 20 3d | 20 52 6f 70 65 6e 28 61 | irast =| Ropen(a|
|00003bd0| 72 67 76 5b 69 66 69 6c | 65 5d 2c 52 29 3b 0a 09 |rgv[ifil|e],R);..|
|00003be0| 65 6c 73 65 20 69 72 61 | 73 74 20 3d 20 52 64 6f |else ira|st = Rdo|
|00003bf0| 70 65 6e 28 30 2c 52 29 | 3b 0a 09 69 66 20 28 69 |pen(0,R)|;..if (i|
|00003c00| 72 61 73 74 20 3d 3d 20 | 4e 55 4c 4c 29 20 7b 0a |rast == |NULL) {.|
|00003c10| 09 09 66 70 72 69 6e 74 | 66 28 73 74 64 65 72 72 |..fprint|f(stderr|
|00003c20| 2c 22 72 64 65 6d 6f 3a | 20 69 6e 70 75 74 20 72 |,"rdemo:| input r|
|00003c30| 61 73 74 65 72 66 69 6c | 65 20 6f 70 65 6e 20 66 |asterfil|e open f|
|00003c40| 61 69 6c 65 64 21 5c 6e | 22 29 3b 0a 09 09 65 78 |ailed!\n|");...ex|
|00003c50| 69 74 28 31 29 3b 0a 09 | 7d 0a 0a 09 69 66 20 28 |it(1);..|}...if (|
|00003c60| 6f 66 69 6c 65 29 20 6f | 72 61 73 74 20 3d 20 52 |ofile) o|rast = R|
|00003c70| 6f 70 65 6e 28 61 72 67 | 76 5b 6f 66 69 6c 65 5d |open(arg|v[ofile]|
|00003c80| 2c 57 29 3b 0a 09 65 6c | 73 65 20 6f 72 61 73 74 |,W);..el|se orast|
|00003c90| 20 3d 20 52 64 6f 70 65 | 6e 28 31 2c 57 29 3b 0a | = Rdope|n(1,W);.|
|00003ca0| 09 69 66 20 28 69 72 61 | 73 74 20 3d 3d 20 4e 55 |.if (ira|st == NU|
|00003cb0| 4c 4c 29 20 7b 0a 09 09 | 66 70 72 69 6e 74 66 28 |LL) {...|fprintf(|
|00003cc0| 73 74 64 65 72 72 2c 22 | 72 64 65 6d 6f 3a 20 6f |stderr,"|rdemo: o|
|00003cd0| 75 74 70 75 74 20 72 61 | 73 74 65 72 66 69 6c 65 |utput ra|sterfile|
|00003ce0| 20 6f 70 65 6e 20 66 61 | 69 6c 65 64 21 5c 6e 22 | open fa|iled!\n"|
|00003cf0| 29 3b 0a 09 09 65 78 69 | 74 28 31 29 3b 0a 09 7d |);...exi|t(1);..}|
|00003d00| 0a 0a 09 69 66 20 28 21 | 52 67 65 74 68 65 61 64 |...if (!|Rgethead|
|00003d10| 65 72 28 69 72 61 73 74 | 29 29 20 7b 0a 09 09 66 |er(irast|)) {...f|
|00003d20| 70 72 69 6e 74 66 28 73 | 74 64 65 72 72 2c 22 69 |printf(s|tderr,"i|
|00003d30| 6e 70 75 74 20 66 69 6c | 65 20 69 73 20 6e 6f 74 |nput fil|e is not|
|00003d40| 20 61 20 72 61 73 74 65 | 72 20 66 69 6c 65 21 5c | a raste|r file!\|
|00003d50| 6e 22 29 3b 0a 09 09 65 | 78 69 74 28 31 29 3b 0a |n");...e|xit(1);.|
|00003d60| 09 7d 0a 0a 09 6f 72 61 | 73 74 2d 3e 68 65 69 67 |.}...ora|st->heig|
|00003d70| 68 74 20 3d 20 69 72 61 | 73 74 2d 3e 68 65 69 67 |ht = ira|st->heig|
|00003d80| 68 74 3b 0a 09 6f 72 61 | 73 74 2d 3e 77 69 64 74 |ht;..ora|st->widt|
|00003d90| 68 20 20 3d 20 69 72 61 | 73 74 2d 3e 77 69 64 74 |h = ira|st->widt|
|00003da0| 68 3b 0a 09 6f 72 61 73 | 74 2d 3e 64 65 70 74 68 |h;..oras|t->depth|
|00003db0| 20 20 3d 20 69 72 61 73 | 74 2d 3e 64 65 70 74 68 | = iras|t->depth|
|00003dc0| 3b 0a 0a 09 52 69 6e 69 | 74 6d 61 70 28 6f 72 61 |;...Rini|tmap(ora|
|00003dd0| 73 74 2c 52 4d 54 5f 45 | 51 55 41 4c 5f 52 47 42 |st,RMT_E|QUAL_RGB|
|00003de0| 2c 32 35 36 2a 33 29 3b | 0a 09 66 6f 72 20 28 69 |,256*3);|..for (i|
|00003df0| 20 3d 20 30 3b 20 69 20 | 3c 20 32 35 36 3b 20 69 | = 0; i |< 256; i|
|00003e00| 2b 2b 29 20 52 70 75 74 | 6d 61 70 28 6f 72 61 73 |++) Rput|map(oras|
|00003e10| 74 2c 32 35 35 2d 69 2c | 69 2c 69 2c 69 29 3b 0a |t,255-i,|i,i,i);.|
|00003e20| 09 0a 09 52 70 75 74 68 | 65 61 64 65 72 28 6f 72 |...Rputh|eader(or|
|00003e30| 61 73 74 29 3b 0a 0a 09 | 69 66 20 28 69 72 61 73 |ast);...|if (iras|
|00003e40| 74 2d 3e 6d 61 70 74 79 | 70 65 20 3d 3d 20 52 4d |t->mapty|pe == RM|
|00003e50| 54 5f 45 51 55 41 4c 5f | 52 47 42 29 20 7b 0a 09 |T_EQUAL_|RGB) {..|
|00003e60| 09 66 6f 72 20 28 72 6f | 77 20 3d 20 30 3b 20 72 |.for (ro|w = 0; r|
|00003e70| 6f 77 20 3c 20 69 72 61 | 73 74 2d 3e 68 65 69 67 |ow < ira|st->heig|
|00003e80| 68 74 3b 20 72 6f 77 2b | 2b 29 20 0a 09 09 09 66 |ht; row+|+) ....f|
|00003e90| 6f 72 20 28 63 6f 6c 20 | 3d 20 30 3b 20 63 6f 6c |or (col |= 0; col|
|00003ea0| 20 3c 20 69 72 61 73 74 | 2d 3e 77 69 64 74 68 3b | < irast|->width;|
|00003eb0| 20 63 6f 6c 2b 2b 29 20 | 7b 0a 09 09 09 09 52 67 | col++) |{.....Rg|
|00003ec0| 65 74 6d 61 70 70 65 64 | 70 69 78 28 69 72 61 73 |etmapped|pix(iras|
|00003ed0| 74 2c 26 72 2c 26 67 2c | 26 62 29 3b 0a 09 09 09 |t,&r,&g,|&b);....|
|00003ee0| 09 61 76 67 20 3d 20 28 | 72 20 2b 20 67 20 2b 20 |.avg = (|r + g + |
|00003ef0| 62 29 20 2f 20 33 3b 0a | 09 09 09 09 52 70 75 74 |b) / 3;.|....Rput|
|00003f00| 70 69 78 28 6f 72 61 73 | 74 2c 61 76 67 29 3b 0a |pix(oras|t,avg);.|
|00003f10| 09 09 09 7d 0a 09 7d 0a | 09 65 6c 73 65 20 69 66 |...}..}.|.else if|
|00003f20| 20 28 69 72 61 73 74 2d | 3e 6d 61 70 74 79 70 65 | (irast-|>maptype|
|00003f30| 20 3d 3d 20 52 4d 54 5f | 52 41 57 29 20 7b 0a 09 | == RMT_|RAW) {..|
|00003f40| 09 66 6f 72 20 28 72 6f | 77 20 3d 20 30 3b 20 72 |.for (ro|w = 0; r|
|00003f50| 6f 77 20 3c 20 69 72 61 | 73 74 2d 3e 68 65 69 67 |ow < ira|st->heig|
|00003f60| 68 74 3b 20 72 6f 77 2b | 2b 29 20 0a 09 09 09 66 |ht; row+|+) ....f|
|00003f70| 6f 72 20 28 63 6f 6c 20 | 3d 20 30 3b 20 63 6f 6c |or (col |= 0; col|
|00003f80| 20 3c 20 69 72 61 73 74 | 2d 3e 77 69 64 74 68 3b | < irast|->width;|
|00003f90| 20 63 6f 6c 2b 2b 29 20 | 7b 0a 09 09 09 09 52 67 | col++) |{.....Rg|
|00003fa0| 65 74 6d 61 70 70 65 64 | 70 69 78 28 69 72 61 73 |etmapped|pix(iras|
|00003fb0| 74 2c 26 70 69 78 29 3b | 0a 09 09 09 09 52 70 75 |t,&pix);|.....Rpu|
|00003fc0| 74 70 69 78 28 6f 72 61 | 73 74 2c 70 69 78 29 3b |tpix(ora|st,pix);|
|00003fd0| 0a 09 09 09 7d 0a 09 7d | 0a 09 65 6c 73 65 20 69 |....}..}|..else i|
|00003fe0| 66 20 28 69 72 61 73 74 | 2d 3e 6d 61 70 74 79 70 |f (irast|->maptyp|
|00003ff0| 65 20 3d 3d 20 52 4d 54 | 5f 4e 4f 4e 45 29 20 7b |e == RMT|_NONE) {|
|00004000| 0a 09 09 66 6f 72 20 28 | 72 6f 77 20 3d 20 30 3b |...for (|row = 0;|
|00004010| 20 72 6f 77 20 3c 20 69 | 72 61 73 74 2d 3e 68 65 | row < i|rast->he|
|00004020| 69 67 68 74 3b 20 72 6f | 77 2b 2b 29 20 0a 09 09 |ight; ro|w++) ...|
|00004030| 09 66 6f 72 20 28 63 6f | 6c 20 3d 20 30 3b 20 63 |.for (co|l = 0; c|
|00004040| 6f 6c 20 3c 20 69 72 61 | 73 74 2d 3e 77 69 64 74 |ol < ira|st->widt|
|00004050| 68 3b 20 63 6f 6c 2b 2b | 29 20 7b 0a 09 09 09 09 |h; col++|) {.....|
|00004060| 70 69 78 20 3d 20 52 67 | 65 74 70 69 78 28 69 72 |pix = Rg|etpix(ir|
|00004070| 61 73 74 29 3b 0a 09 09 | 09 09 52 70 75 74 70 69 |ast);...|..Rputpi|
|00004080| 78 28 6f 72 61 73 74 2c | 70 69 78 29 3b 0a 09 09 |x(orast,|pix);...|
|00004090| 09 7d 0a 09 7d 0a 09 65 | 6c 73 65 20 7b 0a 09 09 |.}..}..e|lse {...|
|000040a0| 66 70 72 69 6e 74 66 28 | 73 74 64 65 72 72 2c 22 |fprintf(|stderr,"|
|000040b0| 72 64 65 6d 6f 3a 20 75 | 6e 6b 6e 6f 77 6e 20 6d |rdemo: u|nknown m|
|000040c0| 61 70 20 74 79 70 65 20 | 69 6e 20 69 6e 70 75 74 |ap type |in input|
|000040d0| 20 72 61 73 74 65 72 66 | 69 6c 65 21 5c 6e 22 29 | rasterf|ile!\n")|
|000040e0| 3b 0a 09 09 65 78 69 74 | 28 31 29 3b 0a 09 7d 0a |;...exit|(1);..}.|
|000040f0| 09 0a 09 52 63 6c 6f 73 | 65 28 69 72 61 73 74 29 |...Rclos|e(irast)|
|00004100| 3b 0a 09 52 63 6c 6f 73 | 65 28 6f 72 61 73 74 29 |;..Rclos|e(orast)|
|00004110| 3b 0a 7d 0a 0a 75 73 61 | 67 65 28 29 0a 7b 0a 09 |;.}..usa|ge().{..|
|00004120| 66 70 72 69 6e 74 66 28 | 73 74 64 65 72 72 2c 22 |fprintf(|stderr,"|
|00004130| 75 73 61 67 65 3a 20 72 | 64 65 6d 6f 20 5b 2d 69 |usage: r|demo [-i|
|00004140| 20 66 69 6c 65 5d 20 5b | 2d 6f 20 66 69 6c 65 5d | file] [|-o file]|
|00004150| 5c 6e 22 29 3b 0a 09 66 | 70 72 69 6e 74 66 28 73 |\n");..f|printf(s|
|00004160| 74 64 65 72 72 2c 22 20 | 20 20 20 20 20 20 2d 69 |tderr," | -i|
|00004170| 20 20 69 6e 70 75 74 20 | 72 61 73 74 65 72 66 69 | input |rasterfi|
|00004180| 6c 65 20 5b 64 65 66 61 | 75 6c 74 20 69 73 20 73 |le [defa|ult is s|
|00004190| 74 64 69 6e 5d 5c 6e 22 | 29 3b 0a 09 66 70 72 69 |tdin]\n"|);..fpri|
|000041a0| 6e 74 66 28 73 74 64 65 | 72 72 2c 22 20 20 20 20 |ntf(stde|rr," |
|000041b0| 20 20 20 2d 6f 20 20 6f | 75 74 70 75 74 20 72 61 | -o o|utput ra|
|000041c0| 73 74 65 72 66 69 6c 65 | 20 5b 64 65 66 61 75 6c |sterfile| [defaul|
|000041d0| 74 20 69 73 20 73 74 64 | 6f 75 74 5d 5c 6e 22 29 |t is std|out]\n")|
|000041e0| 3b 0a 09 65 78 69 74 28 | 30 29 3b 0a 7d 0a 53 48 |;..exit(|0);.}.SH|
|000041f0| 41 52 5f 45 4f 46 0a 66 | 69 20 23 20 65 6e 64 20 |AR_EOF.f|i # end |
|00004200| 6f 66 20 6f 76 65 72 77 | 72 69 74 69 6e 67 20 63 |of overw|riting c|
|00004210| 68 65 63 6b 0a 69 66 20 | 74 65 73 74 20 2d 66 20 |heck.if |test -f |
|00004220| 27 72 73 65 65 2e 63 27 | 0a 74 68 65 6e 0a 09 65 |'rsee.c'|.then..e|
|00004230| 63 68 6f 20 73 68 61 72 | 3a 20 77 69 6c 6c 20 6e |cho shar|: will n|
|00004240| 6f 74 20 6f 76 65 72 2d | 77 72 69 74 65 20 65 78 |ot over-|write ex|
|00004250| 69 73 74 69 6e 67 20 66 | 69 6c 65 20 22 27 72 73 |isting f|ile "'rs|
|00004260| 65 65 2e 63 27 22 0a 65 | 6c 73 65 0a 63 61 74 20 |ee.c'".e|lse.cat |
|00004270| 3c 3c 20 5c 53 48 41 52 | 5f 45 4f 46 20 3e 20 27 |<< \SHAR|_EOF > '|
|00004280| 72 73 65 65 2e 63 27 0a | 23 69 6e 63 6c 75 64 65 |rsee.c'.|#include|
|00004290| 20 3c 73 74 64 69 6f 2e | 68 3e 0a 23 69 6e 63 6c | <stdio.|h>.#incl|
|000042a0| 75 64 65 20 22 72 61 73 | 74 2e 68 22 0a 0a 6d 61 |ude "ras|t.h"..ma|
|000042b0| 69 6e 28 61 72 67 63 2c | 61 72 67 76 29 0a 69 6e |in(argc,|argv).in|
|000042c0| 74 20 61 72 67 63 3b 0a | 63 68 61 72 20 2a 61 72 |t argc;.|char *ar|
|000042d0| 67 76 5b 5d 3b 0a 7b 0a | 09 52 41 53 54 45 52 20 |gv[];.{.|.RASTER |
|000042e0| 2a 69 72 61 73 74 2c 20 | 2a 52 6f 70 65 6e 28 29 |*irast, |*Ropen()|
|000042f0| 3b 0a 09 69 6e 74 20 69 | 2c 20 72 63 3b 0a 0a 09 |;..int i|, rc;...|
|00004300| 66 6f 72 20 28 69 20 3d | 20 31 3b 20 69 20 3c 20 |for (i =| 1; i < |
|00004310| 61 72 67 63 3b 20 69 2b | 2b 29 20 7b 0a 09 09 69 |argc; i+|+) {...i|
|00004320| 72 61 73 74 20 3d 20 52 | 6f 70 65 6e 28 61 72 67 |rast = R|open(arg|
|00004330| 76 5b 69 5d 2c 52 29 3b | 0a 09 09 69 66 20 28 69 |v[i],R);|...if (i|
|00004340| 72 61 73 74 20 3d 3d 20 | 4e 55 4c 4c 29 0a 09 09 |rast == |NULL)...|
|00004350| 09 66 70 72 69 6e 74 66 | 28 73 74 64 65 72 72 2c |.fprintf|(stderr,|
|00004360| 22 72 61 73 74 65 72 66 | 69 6c 65 20 6f 70 65 6e |"rasterf|ile open|
|00004370| 20 66 61 69 6c 65 64 20 | 66 6f 72 20 5c 22 25 73 | failed |for \"%s|
|00004380| 5c 22 21 5c 6e 22 2c 61 | 72 67 76 5b 69 5d 29 3b |\"!\n",a|rgv[i]);|
|00004390| 0a 09 09 65 6c 73 65 20 | 7b 0a 09 09 09 72 63 20 |...else |{....rc |
|000043a0| 3d 20 52 67 65 74 68 65 | 61 64 65 72 28 69 72 61 |= Rgethe|ader(ira|
|000043b0| 73 74 29 3b 0a 09 09 09 | 66 70 72 69 6e 74 66 28 |st);....|fprintf(|
|000043c0| 73 74 64 65 72 72 2c 22 | 25 73 3a 5c 6e 22 2c 61 |stderr,"|%s:\n",a|
|000043d0| 72 67 76 5b 69 5d 29 3b | 0a 09 09 09 69 66 20 28 |rgv[i]);|....if (|
|000043e0| 72 63 29 20 52 69 6e 66 | 6f 28 69 72 61 73 74 29 |rc) Rinf|o(irast)|
|000043f0| 3b 0a 09 09 09 65 6c 73 | 65 20 66 70 72 69 6e 74 |;....els|e fprint|
|00004400| 66 28 73 74 64 65 72 72 | 2c 22 6e 6f 74 20 61 20 |f(stderr|,"not a |
|00004410| 72 61 73 74 65 72 66 69 | 6c 65 21 5c 6e 22 29 3b |rasterfi|le!\n");|
|00004420| 0a 09 09 09 66 70 72 69 | 6e 74 66 28 73 74 64 65 |....fpri|ntf(stde|
|00004430| 72 72 2c 22 5c 6e 22 29 | 3b 0a 09 09 09 52 63 6c |rr,"\n")|;....Rcl|
|00004440| 6f 73 65 28 69 72 61 73 | 74 29 3b 0a 09 09 7d 0a |ose(iras|t);...}.|
|00004450| 09 7d 0a 09 65 78 69 74 | 28 30 29 3b 0a 7d 0a 53 |.}..exit|(0);.}.S|
|00004460| 48 41 52 5f 45 4f 46 0a | 66 69 20 23 20 65 6e 64 |HAR_EOF.|fi # end|
|00004470| 20 6f 66 20 6f 76 65 72 | 77 72 69 74 69 6e 67 20 | of over|writing |
|00004480| 63 68 65 63 6b 0a 23 09 | 45 6e 64 20 6f 66 20 73 |check.#.|End of s|
|00004490| 68 65 6c 6c 20 61 72 63 | 68 69 76 65 0a 65 78 69 |hell arc|hive.exi|
|000044a0| 74 20 30 0a 0a 0a | |t 0... | |
+--------+-------------------------+-------------------------+--------+--------+