home *** CD-ROM | disk | FTP | other *** search
/ Usenet 1994 January / usenetsourcesnewsgroupsinfomagicjanuary1994.iso / sources / unix / volume19 / fbm / part05 < prev    next >
SHell self-extracting ARchive  |  1989-06-08  |  56.6 KB

open in: MacOS 8.1     |     Win98     |     DOS

browse contents    |     view JSON data     |     view as text


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

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



hex view
+--------+-------------------------+-------------------------+--------+--------+
|00000000| 53 75 62 6a 65 63 74 3a | 20 20 76 31 39 69 30 35 |Subject:| v19i05|
|00000010| 31 3a 20 20 46 42 4d 2c | 20 69 6d 61 67 65 20 6d |1: FBM,| image m|
|00000020| 61 6e 69 70 75 6c 61 74 | 69 6f 6e 20 6c 69 62 72 |anipulat|ion libr|
|00000030| 61 72 79 2c 20 50 61 72 | 74 30 35 2f 30 38 0a 4e |ary, Par|t05/08.N|
|00000040| 65 77 73 67 72 6f 75 70 | 73 3a 20 63 6f 6d 70 2e |ewsgroup|s: comp.|
|00000050| 73 6f 75 72 63 65 73 2e | 75 6e 69 78 0a 53 65 6e |sources.|unix.Sen|
|00000060| 64 65 72 3a 20 73 6f 75 | 72 63 65 73 0a 41 70 70 |der: sou|rces.App|
|00000070| 72 6f 76 65 64 3a 20 72 | 73 61 6c 7a 40 75 75 6e |roved: r|salz@uun|
|00000080| 65 74 2e 55 55 2e 4e 45 | 54 0a 0a 53 75 62 6d 69 |et.UU.NE|T..Submi|
|00000090| 74 74 65 64 2d 62 79 3a | 20 4d 69 63 68 61 65 6c |tted-by:| Michael|
|000000a0| 2e 4d 61 75 6c 64 69 6e | 40 4e 4c 2e 43 53 2e 43 |.Mauldin|@NL.CS.C|
|000000b0| 4d 55 2e 45 44 55 0a 50 | 6f 73 74 69 6e 67 2d 6e |MU.EDU.P|osting-n|
|000000c0| 75 6d 62 65 72 3a 20 56 | 6f 6c 75 6d 65 20 31 39 |umber: V|olume 19|
|000000d0| 2c 20 49 73 73 75 65 20 | 35 31 0a 41 72 63 68 69 |, Issue |51.Archi|
|000000e0| 76 65 2d 6e 61 6d 65 3a | 20 66 62 6d 2f 70 61 72 |ve-name:| fbm/par|
|000000f0| 74 30 35 0a 0a 23 21 20 | 2f 62 69 6e 2f 73 68 0a |t05..#! |/bin/sh.|
|00000100| 23 20 54 68 69 73 20 69 | 73 20 61 20 73 68 65 6c |# This i|s a shel|
|00000110| 6c 20 61 72 63 68 69 76 | 65 2e 20 20 52 65 6d 6f |l archiv|e. Remo|
|00000120| 76 65 20 61 6e 79 74 68 | 69 6e 67 20 62 65 66 6f |ve anyth|ing befo|
|00000130| 72 65 20 74 68 69 73 20 | 6c 69 6e 65 2c 20 74 68 |re this |line, th|
|00000140| 65 6e 20 75 6e 70 61 63 | 6b 0a 23 20 69 74 20 62 |en unpac|k.# it b|
|00000150| 79 20 73 61 76 69 6e 67 | 20 69 74 20 69 6e 74 6f |y saving| it into|
|00000160| 20 61 20 66 69 6c 65 20 | 61 6e 64 20 74 79 70 69 | a file |and typi|
|00000170| 6e 67 20 22 73 68 20 66 | 69 6c 65 22 2e 20 20 54 |ng "sh f|ile". T|
|00000180| 6f 20 6f 76 65 72 77 72 | 69 74 65 20 65 78 69 73 |o overwr|ite exis|
|00000190| 74 69 6e 67 0a 23 20 66 | 69 6c 65 73 2c 20 74 79 |ting.# f|iles, ty|
|000001a0| 70 65 20 22 73 68 20 66 | 69 6c 65 20 2d 63 22 2e |pe "sh f|ile -c".|
|000001b0| 20 20 59 6f 75 20 63 61 | 6e 20 61 6c 73 6f 20 66 | You ca|n also f|
|000001c0| 65 65 64 20 74 68 69 73 | 20 61 73 20 73 74 61 6e |eed this| as stan|
|000001d0| 64 61 72 64 20 69 6e 70 | 75 74 20 76 69 61 0a 23 |dard inp|ut via.#|
|000001e0| 20 75 6e 73 68 61 72 2c | 20 6f 72 20 62 79 20 74 | unshar,| or by t|
|000001f0| 79 70 69 6e 67 20 22 73 | 68 20 3c 66 69 6c 65 22 |yping "s|h <file"|
|00000200| 2c 20 65 2e 67 2e 2e 20 | 20 49 66 20 74 68 69 73 |, e.g.. | If this|
|00000210| 20 61 72 63 68 69 76 65 | 20 69 73 20 63 6f 6d 70 | archive| is comp|
|00000220| 6c 65 74 65 2c 20 79 6f | 75 0a 23 20 77 69 6c 6c |lete, yo|u.# will|
|00000230| 20 73 65 65 20 74 68 65 | 20 66 6f 6c 6c 6f 77 69 | see the| followi|
|00000240| 6e 67 20 6d 65 73 73 61 | 67 65 20 61 74 20 74 68 |ng messa|ge at th|
|00000250| 65 20 65 6e 64 3a 0a 23 | 09 09 22 45 6e 64 20 6f |e end:.#|.."End o|
|00000260| 66 20 61 72 63 68 69 76 | 65 20 35 20 28 6f 66 20 |f archiv|e 5 (of |
|00000270| 38 29 2e 22 0a 23 20 43 | 6f 6e 74 65 6e 74 73 3a |8).".# C|ontents:|
|00000280| 20 20 66 62 65 78 74 2e | 63 20 66 62 70 73 2e 63 | fbext.|c fbps.c|
|00000290| 20 66 6c 63 6c 72 2e 63 | 20 66 6c 65 64 67 65 2e | flclr.c| fledge.|
|000002a0| 63 20 66 6c 6b 6c 6e 72 | 2e 63 20 66 6c 73 75 6e |c flklnr|.c flsun|
|000002b0| 2e 63 20 70 62 6d 32 70 | 73 2e 63 0a 23 20 57 72 |.c pbm2p|s.c.# Wr|
|000002c0| 61 70 70 65 64 20 62 79 | 20 72 73 61 6c 7a 40 66 |apped by| rsalz@f|
|000002d0| 69 67 2e 62 62 6e 2e 63 | 6f 6d 20 6f 6e 20 46 72 |ig.bbn.c|om on Fr|
|000002e0| 69 20 4a 75 6e 20 20 39 | 20 30 38 3a 33 38 3a 32 |i Jun 9| 08:38:2|
|000002f0| 36 20 31 39 38 39 0a 50 | 41 54 48 3d 2f 62 69 6e |6 1989.P|ATH=/bin|
|00000300| 3a 2f 75 73 72 2f 62 69 | 6e 3a 2f 75 73 72 2f 75 |:/usr/bi|n:/usr/u|
|00000310| 63 62 20 3b 20 65 78 70 | 6f 72 74 20 50 41 54 48 |cb ; exp|ort PATH|
|00000320| 0a 69 66 20 74 65 73 74 | 20 2d 66 20 27 66 62 65 |.if test| -f 'fbe|
|00000330| 78 74 2e 63 27 20 2d 61 | 20 22 24 7b 31 7d 22 20 |xt.c' -a| "${1}" |
|00000340| 21 3d 20 22 2d 63 22 20 | 3b 20 74 68 65 6e 20 0a |!= "-c" |; then .|
|00000350| 20 20 65 63 68 6f 20 73 | 68 61 72 3a 20 57 69 6c | echo s|har: Wil|
|00000360| 6c 20 6e 6f 74 20 63 6c | 6f 62 62 65 72 20 65 78 |l not cl|obber ex|
|00000370| 69 73 74 69 6e 67 20 66 | 69 6c 65 20 5c 22 27 66 |isting f|ile \"'f|
|00000380| 62 65 78 74 2e 63 27 5c | 22 0a 65 6c 73 65 0a 65 |bext.c'\|".else.e|
|00000390| 63 68 6f 20 73 68 61 72 | 3a 20 45 78 74 72 61 63 |cho shar|: Extrac|
|000003a0| 74 69 6e 67 20 5c 22 27 | 66 62 65 78 74 2e 63 27 |ting \"'|fbext.c'|
|000003b0| 5c 22 20 5c 28 36 33 33 | 37 20 63 68 61 72 61 63 |\" \(633|7 charac|
|000003c0| 74 65 72 73 5c 29 0a 73 | 65 64 20 22 73 2f 5e 58 |ters\).s|ed "s/^X|
|000003d0| 2f 2f 22 20 3e 27 66 62 | 65 78 74 2e 63 27 20 3c |//" >'fb|ext.c' <|
|000003e0| 3c 27 45 4e 44 5f 4f 46 | 5f 46 49 4c 45 27 0a 58 |<'END_OF|_FILE'.X|
|000003f0| 2f 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |/*******|********|
|00000400| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000410| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000420| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000430| 2a 2a 0a 58 20 2a 20 66 | 62 65 78 74 2e 63 3a 20 |**.X * f|bext.c: |
|00000440| 46 42 4d 20 4c 69 62 72 | 61 72 79 20 30 2e 39 34 |FBM Libr|ary 0.94|
|00000450| 20 28 42 65 74 61 20 74 | 65 73 74 29 20 32 30 2d | (Beta t|est) 20-|
|00000460| 4d 61 79 2d 38 39 20 20 | 4d 69 63 68 61 65 6c 20 |May-89 |Michael |
|00000470| 4d 61 75 6c 64 69 6e 0a | 58 20 2a 0a 58 20 2a 20 |Mauldin.|X *.X * |
|00000480| 43 6f 70 79 72 69 67 68 | 74 20 28 43 29 20 31 39 |Copyrigh|t (C) 19|
|00000490| 38 39 20 62 79 20 4d 69 | 63 68 61 65 6c 20 4d 61 |89 by Mi|chael Ma|
|000004a0| 75 6c 64 69 6e 2e 20 20 | 50 65 72 6d 69 73 73 69 |uldin. |Permissi|
|000004b0| 6f 6e 20 69 73 20 67 72 | 61 6e 74 65 64 20 74 6f |on is gr|anted to|
|000004c0| 0a 58 20 2a 20 75 73 65 | 20 74 68 69 73 20 66 69 |.X * use| this fi|
|000004d0| 6c 65 20 69 6e 20 77 68 | 6f 6c 65 20 6f 72 20 69 |le in wh|ole or i|
|000004e0| 6e 20 70 61 72 74 20 70 | 72 6f 76 69 64 65 64 20 |n part p|rovided |
|000004f0| 74 68 61 74 20 79 6f 75 | 20 64 6f 20 6e 6f 74 20 |that you| do not |
|00000500| 73 65 6c 6c 20 69 74 0a | 58 20 2a 20 66 6f 72 20 |sell it.|X * for |
|00000510| 70 72 6f 66 69 74 20 61 | 6e 64 20 74 68 61 74 20 |profit a|nd that |
|00000520| 74 68 69 73 20 63 6f 70 | 79 72 69 67 68 74 20 6e |this cop|yright n|
|00000530| 6f 74 69 63 65 20 69 73 | 20 72 65 74 61 69 6e 65 |otice is| retaine|
|00000540| 64 20 75 6e 63 68 61 6e | 67 65 64 2e 0a 58 20 2a |d unchan|ged..X *|
|00000550| 0a 58 20 2a 20 66 62 65 | 78 74 2e 63 3a 20 0a 58 |.X * fbe|xt.c: .X|
|00000560| 20 2a 0a 58 20 2a 20 55 | 53 41 47 45 0a 58 20 2a | *.X * U|SAGE.X *|
|00000570| 09 25 20 66 62 65 78 74 | 20 5b 20 2d 77 3c 77 69 |.% fbext| [ -w<wi|
|00000580| 64 74 68 3e 20 2d 68 3c | 68 65 69 67 68 74 3e 20 |dth> -h<|height> |
|00000590| 2d 57 3c 6d 61 78 77 69 | 64 74 68 3e 20 2d 48 3c |-W<maxwi|dth> -H<|
|000005a0| 6d 61 78 68 65 69 67 68 | 74 3e 0a 58 20 2a 09 09 |maxheigh|t>.X *..|
|000005b0| 20 2d 61 3c 61 73 70 65 | 63 74 3e 20 2d 74 27 74 | -a<aspe|ct> -t't|
|000005c0| 69 74 6c 65 27 20 2d 63 | 27 63 72 65 64 69 74 73 |itle' -c|'credits|
|000005d0| 27 20 5d 0a 58 20 2a 09 | 20 20 20 20 20 20 20 5b |' ].X *.| [|
|000005e0| 20 78 20 79 20 77 69 64 | 74 68 20 68 65 69 67 68 | x y wid|th heigh|
|000005f0| 74 20 5d 20 3c 20 66 6f | 6f 2e 66 62 6d 20 3e 20 |t ] < fo|o.fbm > |
|00000600| 62 61 72 2e 66 62 6d 0a | 58 20 2a 0a 58 20 2a 20 |bar.fbm.|X *.X * |
|00000610| 45 44 49 54 4c 4f 47 0a | 58 20 2a 09 4c 61 73 74 |EDITLOG.|X *.Last|
|00000620| 45 64 69 74 44 61 74 65 | 20 3d 20 53 61 74 20 4d |EditDate| = Sat M|
|00000630| 61 79 20 32 30 20 31 39 | 3a 30 33 3a 35 35 20 31 |ay 20 19|:03:55 1|
|00000640| 39 38 39 20 2d 20 4d 69 | 63 68 61 65 6c 20 4d 61 |989 - Mi|chael Ma|
|00000650| 75 6c 64 69 6e 0a 58 20 | 2a 09 4c 61 73 74 46 69 |uldin.X |*.LastFi|
|00000660| 6c 65 4e 61 6d 65 20 3d | 20 2f 75 73 72 32 2f 6d |leName =| /usr2/m|
|00000670| 6c 6d 2f 73 72 63 2f 6d | 69 73 63 2f 66 62 6d 2f |lm/src/m|isc/fbm/|
|00000680| 66 62 65 78 74 2e 63 0a | 58 20 2a 0a 58 20 2a 20 |fbext.c.|X *.X * |
|00000690| 48 49 53 54 4f 52 59 0a | 58 20 2a 20 32 30 2d 4d |HISTORY.|X * 20-M|
|000006a0| 61 79 2d 38 39 20 20 4d | 69 63 68 61 65 6c 20 4d |ay-89 M|ichael M|
|000006b0| 61 75 6c 64 69 6e 20 28 | 6d 6c 6d 29 20 61 74 20 |auldin (|mlm) at |
|000006c0| 43 61 72 6e 65 67 69 65 | 20 4d 65 6c 6c 6f 6e 20 |Carnegie| Mellon |
|000006d0| 55 6e 69 76 65 72 73 69 | 74 79 0a 58 20 2a 09 42 |Universi|ty.X *.B|
|000006e0| 75 67 20 66 69 78 20 66 | 72 6f 6d 20 44 61 76 65 |ug fix f|rom Dave|
|000006f0| 20 43 6f 68 72 73 20 3c | 64 61 76 65 40 63 73 2e | Cohrs <|dave@cs.|
|00000700| 77 69 73 63 2e 65 64 75 | 3e 0a 58 20 2a 0a 58 20 |wisc.edu|>.X *.X |
|00000710| 2a 20 32 30 2d 41 70 72 | 2d 38 39 20 20 4d 69 63 |* 20-Apr|-89 Mic|
|00000720| 68 61 65 6c 20 4d 61 75 | 6c 64 69 6e 20 28 6d 6c |hael Mau|ldin (ml|
|00000730| 6d 29 20 61 74 20 43 61 | 72 6e 65 67 69 65 20 4d |m) at Ca|rnegie M|
|00000740| 65 6c 6c 6f 6e 20 55 6e | 69 76 65 72 73 69 74 79 |ellon Un|iversity|
|00000750| 0a 58 20 2a 09 42 65 74 | 61 20 72 65 6c 65 61 73 |.X *.Bet|a releas|
|00000760| 65 20 28 76 65 72 73 69 | 6f 6e 20 30 2e 39 31 29 |e (versi|on 0.91)|
|00000770| 20 6d 6c 6d 40 63 73 2e | 63 6d 75 2e 65 64 75 0a | mlm@cs.|cmu.edu.|
|00000780| 58 20 2a 0a 58 20 2a 20 | 32 32 2d 41 75 67 2d 38 |X *.X * |22-Aug-8|
|00000790| 38 20 20 4d 69 63 68 61 | 65 6c 20 4d 61 75 6c 64 |8 Micha|el Mauld|
|000007a0| 69 6e 20 28 6d 6c 6d 29 | 20 61 74 20 43 61 72 6e |in (mlm)| at Carn|
|000007b0| 65 67 69 65 2d 4d 65 6c | 6c 6f 6e 20 55 6e 69 76 |egie-Mel|lon Univ|
|000007c0| 65 72 73 69 74 79 0a 58 | 20 2a 09 43 72 65 61 74 |ersity.X| *.Creat|
|000007d0| 65 64 2e 0a 58 20 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |ed..X **|********|
|000007e0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000007f0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000800| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000810| 2a 2a 2a 2a 2a 2a 2a 2f | 0a 58 0a 58 23 20 69 6e |*******/|.X.X# in|
|00000820| 63 6c 75 64 65 20 3c 73 | 74 64 69 6f 2e 68 3e 0a |clude <s|tdio.h>.|
|00000830| 58 23 20 69 6e 63 6c 75 | 64 65 20 3c 6d 61 74 68 |X# inclu|de <math|
|00000840| 2e 68 3e 0a 58 23 20 69 | 6e 63 6c 75 64 65 20 22 |.h>.X# i|nclude "|
|00000850| 66 62 6d 2e 68 22 0a 58 | 0a 58 69 6e 74 20 61 6c |fbm.h".X|.Xint al|
|00000860| 6c 6f 77 72 6f 74 20 3d | 20 30 3b 0a 58 0a 58 23 |lowrot =| 0;.X.X#|
|00000870| 20 64 65 66 69 6e 65 20 | 55 53 41 47 45 20 5c 0a | define |USAGE \.|
|00000880| 58 22 55 73 61 67 65 3a | 09 66 62 65 78 74 20 5b |X"Usage:|.fbext [|
|00000890| 20 2d 77 3c 77 69 64 74 | 68 3e 20 2d 68 3c 68 65 | -w<widt|h> -h<he|
|000008a0| 69 67 68 74 3e 20 5d 20 | 5b 20 2d 52 20 5d 5c 6e |ight> ] |[ -R ]\n|
|000008b0| 5c 0a 58 09 20 20 20 20 | 20 20 5b 20 2d 57 3c 6d |\.X. | [ -W<m|
|000008c0| 61 78 77 64 69 74 68 3e | 20 2d 48 3c 6d 61 78 68 |axwdith>| -H<maxh|
|000008d0| 65 69 67 68 74 3e 20 2d | 73 3c 73 69 7a 65 3e 20 |eight> -|s<size> |
|000008e0| 5d 5c 6e 5c 0a 58 09 20 | 20 20 20 20 20 5b 20 2d |]\n\.X. | [ -|
|000008f0| 61 3c 61 73 70 65 63 74 | 3e 20 2d 74 27 74 69 74 |a<aspect|> -t'tit|
|00000900| 6c 65 27 20 2d 63 27 63 | 72 65 64 69 74 73 27 20 |le' -c'c|redits' |
|00000910| 5d 20 5b 20 2d 3c 74 79 | 70 65 3e 20 5d 5c 6e 5c |] [ -<ty|pe> ]\n\|
|00000920| 0a 58 09 20 20 20 20 20 | 20 5b 20 78 20 79 20 5b |.X. | [ x y [|
|00000930| 20 77 69 64 74 68 20 68 | 65 69 67 68 74 20 5d 20 | width h|eight ] |
|00000940| 5d 09 3c 20 69 6d 61 67 | 65 20 3e 20 69 6d 61 67 |].< imag|e > imag|
|00000950| 65 22 0a 58 0a 58 23 69 | 66 6e 64 65 66 20 6c 69 |e".X.X#i|fndef li|
|00000960| 6e 74 0a 58 73 74 61 74 | 69 63 20 63 68 61 72 20 |nt.Xstat|ic char |
|00000970| 2a 66 62 6d 69 64 20 3d | 0a 58 09 22 24 46 42 4d |*fbmid =|.X."$FBM|
|00000980| 20 66 62 65 78 74 2e 63 | 20 3c 30 2e 39 34 3e 20 | fbext.c| <0.94> |
|00000990| 32 30 2d 4d 61 79 2d 38 | 39 20 20 28 43 29 20 31 |20-May-8|9 (C) 1|
|000009a0| 39 38 39 20 62 79 20 4d | 69 63 68 61 65 6c 20 4d |989 by M|ichael M|
|000009b0| 61 75 6c 64 69 6e 24 22 | 3b 0a 58 23 65 6e 64 69 |auldin$"|;.X#endi|
|000009c0| 66 0a 58 0a 58 6d 61 69 | 6e 20 28 61 72 67 63 2c |f.X.Xmai|n (argc,|
|000009d0| 20 61 72 67 76 29 0a 58 | 63 68 61 72 20 2a 61 72 | argv).X|char *ar|
|000009e0| 67 76 5b 5d 3b 0a 58 7b | 20 69 6e 74 20 78 6f 20 |gv[];.X{| int xo |
|000009f0| 3d 20 2d 31 2c 20 79 6f | 20 3d 20 2d 31 2c 20 77 |= -1, yo| = -1, w|
|00000a00| 20 3d 20 2d 31 2c 20 68 | 20 3d 20 2d 31 2c 20 6f | = -1, h| = -1, o|
|00000a10| 77 20 3d 20 2d 31 2c 20 | 6f 68 20 3d 20 2d 31 2c |w = -1, |oh = -1,|
|00000a20| 20 73 69 7a 65 20 3d 20 | 2d 31 3b 0a 58 20 20 69 | size = |-1;.X i|
|00000a30| 6e 74 20 6d 68 20 3d 20 | 2d 31 2c 20 6d 77 20 3d |nt mh = |-1, mw =|
|00000a40| 20 2d 31 3b 0a 58 20 20 | 64 6f 75 62 6c 65 20 61 | -1;.X |double a|
|00000a50| 73 70 65 63 74 20 3d 20 | 2d 31 2e 30 3b 0a 58 20 |spect = |-1.0;.X |
|00000a60| 20 63 68 61 72 20 74 69 | 74 6c 65 5b 46 42 4d 5f | char ti|tle[FBM_|
|00000a70| 4d 41 58 5f 54 49 54 4c | 45 5d 2c 20 63 72 65 64 |MAX_TITL|E], cred|
|00000a80| 69 74 73 5b 46 42 4d 5f | 4d 41 58 5f 54 49 54 4c |its[FBM_|MAX_TITL|
|00000a90| 45 5d 3b 0a 58 20 20 46 | 42 4d 20 69 6e 70 75 74 |E];.X F|BM input|
|00000aa0| 2c 20 72 6f 74 61 74 65 | 64 2c 20 6f 75 74 70 75 |, rotate|d, outpu|
|00000ab0| 74 2c 20 2a 69 6d 61 67 | 65 20 3d 20 26 69 6e 70 |t, *imag|e = &inp|
|00000ac0| 75 74 3b 0a 58 20 20 69 | 6e 74 20 6f 75 74 74 79 |ut;.X i|nt outty|
|00000ad0| 70 65 20 3d 20 46 4d 54 | 5f 46 42 4d 3b 0a 58 0a |pe = FMT|_FBM;.X.|
|00000ae0| 58 20 20 2f 2a 20 43 6c | 65 61 72 20 74 68 65 20 |X /* Cl|ear the |
|00000af0| 6d 65 6d 6f 72 79 20 70 | 6f 69 6e 74 65 72 73 20 |memory p|ointers |
|00000b00| 73 6f 20 61 6c 6c 6f 63 | 5f 66 62 6d 20 77 6f 6e |so alloc|_fbm won|
|00000b10| 27 74 20 62 65 20 63 6f | 6e 66 75 73 65 64 20 2a |'t be co|nfused *|
|00000b20| 2f 0a 58 20 20 69 6e 70 | 75 74 2e 63 6d 20 20 3d |/.X inp|ut.cm =|
|00000b30| 20 69 6e 70 75 74 2e 62 | 6d 20 20 3d 20 28 75 6e | input.b|m = (un|
|00000b40| 73 69 67 6e 65 64 20 63 | 68 61 72 20 2a 29 20 4e |signed c|har *) N|
|00000b50| 55 4c 4c 3b 0a 58 20 20 | 72 6f 74 61 74 65 64 2e |ULL;.X |rotated.|
|00000b60| 63 6d 20 3d 20 72 6f 74 | 61 74 65 64 2e 62 6d 20 |cm = rot|ated.bm |
|00000b70| 3d 20 28 75 6e 73 69 67 | 6e 65 64 20 63 68 61 72 |= (unsig|ned char|
|00000b80| 20 2a 29 20 4e 55 4c 4c | 3b 0a 58 20 20 6f 75 74 | *) NULL|;.X out|
|00000b90| 70 75 74 2e 63 6d 20 3d | 20 6f 75 74 70 75 74 2e |put.cm =| output.|
|00000ba0| 62 6d 20 3d 20 28 75 6e | 73 69 67 6e 65 64 20 63 |bm = (un|signed c|
|00000bb0| 68 61 72 20 2a 29 20 4e | 55 4c 4c 3b 0a 58 0a 58 |har *) N|ULL;.X.X|
|00000bc0| 20 20 74 69 74 6c 65 5b | 30 5d 20 3d 20 27 5c 30 | title[|0] = '\0|
|00000bd0| 27 3b 0a 58 20 20 63 72 | 65 64 69 74 73 5b 30 5d |';.X cr|edits[0]|
|00000be0| 20 3d 20 27 5c 30 27 3b | 0a 58 0a 58 20 20 2f 2a | = '\0';|.X.X /*|
|00000bf0| 20 47 65 74 20 74 68 65 | 20 6f 70 74 69 6f 6e 73 | Get the| options|
|00000c00| 20 2a 2f 0a 58 20 20 77 | 68 69 6c 65 20 28 2d 2d | */.X w|hile (--|
|00000c10| 61 72 67 63 20 3e 20 30 | 20 26 26 20 28 2a 2b 2b |argc > 0| && (*++|
|00000c20| 61 72 67 76 29 5b 30 5d | 20 3d 3d 20 27 2d 27 29 |argv)[0]| == '-')|
|00000c30| 0a 58 20 20 7b 20 77 68 | 69 6c 65 20 28 2a 2b 2b |.X { wh|ile (*++|
|00000c40| 28 2a 61 72 67 76 29 29 | 0a 58 20 20 20 20 7b 20 |(*argv))|.X { |
|00000c50| 73 77 69 74 63 68 20 28 | 2a 2a 61 72 67 76 29 0a |switch (|**argv).|
|00000c60| 58 20 20 20 20 20 20 7b | 20 63 61 73 65 20 27 74 |X {| case 't|
|00000c70| 27 3a 09 73 74 72 63 70 | 79 20 28 74 69 74 6c 65 |':.strcp|y (title|
|00000c80| 2c 20 2a 61 72 67 76 2b | 31 29 3b 20 43 4c 52 41 |, *argv+|1); CLRA|
|00000c90| 52 47 3b 20 62 72 65 61 | 6b 3b 0a 58 09 63 61 73 |RG; brea|k;.X.cas|
|00000ca0| 65 20 27 63 27 3a 09 73 | 74 72 63 70 79 20 28 63 |e 'c':.s|trcpy (c|
|00000cb0| 72 65 64 69 74 73 2c 20 | 2a 61 72 67 76 2b 31 29 |redits, |*argv+1)|
|00000cc0| 3b 20 43 4c 52 41 52 47 | 3b 20 62 72 65 61 6b 3b |; CLRARG|; break;|
|00000cd0| 0a 58 09 63 61 73 65 20 | 27 61 27 3a 09 61 73 70 |.X.case |'a':.asp|
|00000ce0| 65 63 74 20 3d 20 61 74 | 6f 66 20 28 2a 61 72 67 |ect = at|of (*arg|
|00000cf0| 76 2b 31 29 3b 20 53 4b | 49 50 41 52 47 3b 20 62 |v+1); SK|IPARG; b|
|00000d00| 72 65 61 6b 3b 0a 58 09 | 63 61 73 65 20 27 77 27 |reak;.X.|case 'w'|
|00000d10| 3a 09 6f 77 20 3d 20 61 | 74 6f 69 20 28 2a 61 72 |:.ow = a|toi (*ar|
|00000d20| 67 76 2b 31 29 3b 20 53 | 4b 49 50 41 52 47 3b 20 |gv+1); S|KIPARG; |
|00000d30| 62 72 65 61 6b 3b 0a 58 | 09 63 61 73 65 20 27 68 |break;.X|.case 'h|
|00000d40| 27 3a 09 6f 68 20 3d 20 | 61 74 6f 69 20 28 2a 61 |':.oh = |atoi (*a|
|00000d50| 72 67 76 2b 31 29 3b 20 | 53 4b 49 50 41 52 47 3b |rgv+1); |SKIPARG;|
|00000d60| 20 62 72 65 61 6b 3b 0a | 58 09 63 61 73 65 20 27 | break;.|X.case '|
|00000d70| 57 27 3a 09 6d 77 20 3d | 20 61 74 6f 69 20 28 2a |W':.mw =| atoi (*|
|00000d80| 61 72 67 76 2b 31 29 3b | 20 53 4b 49 50 41 52 47 |argv+1);| SKIPARG|
|00000d90| 3b 20 62 72 65 61 6b 3b | 0a 58 09 63 61 73 65 20 |; break;|.X.case |
|00000da0| 27 48 27 3a 09 6d 68 20 | 3d 20 61 74 6f 69 20 28 |'H':.mh |= atoi (|
|00000db0| 2a 61 72 67 76 2b 31 29 | 3b 20 53 4b 49 50 41 52 |*argv+1)|; SKIPAR|
|00000dc0| 47 3b 20 62 72 65 61 6b | 3b 0a 58 09 63 61 73 65 |G; break|;.X.case|
|00000dd0| 20 27 52 27 3a 09 61 6c | 6c 6f 77 72 6f 74 2b 2b | 'R':.al|lowrot++|
|00000de0| 3b 20 62 72 65 61 6b 3b | 0a 58 09 63 61 73 65 20 |; break;|.X.case |
|00000df0| 27 73 27 3a 09 73 69 7a | 65 20 3d 20 61 74 6f 69 |'s':.siz|e = atoi|
|00000e00| 20 28 2a 61 72 67 76 2b | 31 29 3b 20 53 4b 49 50 | (*argv+|1); SKIP|
|00000e10| 41 52 47 3b 20 62 72 65 | 61 6b 3b 0a 58 09 63 61 |ARG; bre|ak;.X.ca|
|00000e20| 73 65 20 27 41 27 3a 09 | 6f 75 74 74 79 70 65 20 |se 'A':.|outtype |
|00000e30| 3d 20 46 4d 54 5f 41 54 | 4b 3b 20 62 72 65 61 6b |= FMT_AT|K; break|
|00000e40| 3b 0a 58 09 63 61 73 65 | 20 27 42 27 3a 09 6f 75 |;.X.case| 'B':.ou|
|00000e50| 74 74 79 70 65 20 3d 20 | 46 4d 54 5f 46 41 43 45 |ttype = |FMT_FACE|
|00000e60| 3b 20 62 72 65 61 6b 3b | 0a 58 09 63 61 73 65 20 |; break;|.X.case |
|00000e70| 27 46 27 3a 09 6f 75 74 | 74 79 70 65 20 3d 20 46 |'F':.out|type = F|
|00000e80| 4d 54 5f 46 42 4d 3b 20 | 62 72 65 61 6b 3b 0a 58 |MT_FBM; |break;.X|
|00000e90| 09 63 61 73 65 20 27 47 | 27 3a 09 6f 75 74 74 79 |.case 'G|':.outty|
|00000ea0| 70 65 20 3d 20 46 4d 54 | 5f 47 49 46 3b 20 62 72 |pe = FMT|_GIF; br|
|00000eb0| 65 61 6b 3b 0a 58 09 63 | 61 73 65 20 27 49 27 3a |eak;.X.c|ase 'I':|
|00000ec0| 09 6f 75 74 74 79 70 65 | 20 3d 20 46 4d 54 5f 49 |.outtype| = FMT_I|
|00000ed0| 46 46 3b 20 62 72 65 61 | 6b 3b 0a 58 09 63 61 73 |FF; brea|k;.X.cas|
|00000ee0| 65 20 27 4c 27 3a 09 6f | 75 74 74 79 70 65 20 3d |e 'L':.o|uttype =|
|00000ef0| 20 46 4d 54 5f 4c 45 41 | 46 3b 20 62 72 65 61 6b | FMT_LEA|F; break|
|00000f00| 3b 0a 58 09 63 61 73 65 | 20 27 4d 27 3a 09 6f 75 |;.X.case| 'M':.ou|
|00000f10| 74 74 79 70 65 20 3d 20 | 46 4d 54 5f 4d 43 50 3b |ttype = |FMT_MCP;|
|00000f20| 20 62 72 65 61 6b 3b 0a | 58 09 63 61 73 65 20 27 | break;.|X.case '|
|00000f30| 50 27 3a 09 6f 75 74 74 | 79 70 65 20 3d 20 46 4d |P':.outt|ype = FM|
|00000f40| 54 5f 50 42 4d 3b 20 62 | 72 65 61 6b 3b 0a 58 09 |T_PBM; b|reak;.X.|
|00000f50| 63 61 73 65 20 27 53 27 | 3a 09 6f 75 74 74 79 70 |case 'S'|:.outtyp|
|00000f60| 65 20 3d 20 46 4d 54 5f | 53 55 4e 3b 20 62 72 65 |e = FMT_|SUN; bre|
|00000f70| 61 6b 3b 0a 58 09 63 61 | 73 65 20 27 54 27 3a 09 |ak;.X.ca|se 'T':.|
|00000f80| 6f 75 74 74 79 70 65 20 | 3d 20 46 4d 54 5f 54 49 |outtype |= FMT_TI|
|00000f90| 46 46 3b 20 62 72 65 61 | 6b 3b 0a 58 09 63 61 73 |FF; brea|k;.X.cas|
|00000fa0| 65 20 27 58 27 3a 09 6f | 75 74 74 79 70 65 20 3d |e 'X':.o|uttype =|
|00000fb0| 20 46 4d 54 5f 58 31 31 | 3b 20 62 72 65 61 6b 3b | FMT_X11|; break;|
|00000fc0| 0a 58 09 63 61 73 65 20 | 27 5a 27 3a 09 6f 75 74 |.X.case |'Z':.out|
|00000fd0| 74 79 70 65 20 3d 20 46 | 4d 54 5f 50 43 58 3b 20 |type = F|MT_PCX; |
|00000fe0| 62 72 65 61 6b 3b 0a 58 | 09 64 65 66 61 75 6c 74 |break;.X|.default|
|00000ff0| 3a 09 66 70 72 69 6e 74 | 66 20 28 73 74 64 65 72 |:.fprint|f (stder|
|00001000| 72 2c 20 22 25 73 5c 6e | 22 2c 20 55 53 41 47 45 |r, "%s\n|", USAGE|
|00001010| 29 3b 0a 58 09 09 09 65 | 78 69 74 20 28 31 29 3b |);.X...e|xit (1);|
|00001020| 0a 58 20 20 20 20 20 20 | 7d 0a 58 20 20 20 20 7d |.X |}.X }|
|00001030| 0a 58 20 20 7d 0a 58 0a | 58 0a 58 20 20 69 66 20 |.X }.X.|X.X if |
|00001040| 28 72 65 61 64 5f 62 69 | 74 6d 61 70 20 28 26 69 |(read_bi|tmap (&i|
|00001050| 6e 70 75 74 2c 20 28 63 | 68 61 72 20 2a 29 20 4e |nput, (c|har *) N|
|00001060| 55 4c 4c 29 29 0a 58 20 | 20 7b 0a 58 20 20 20 20 |ULL)).X | {.X |
|00001070| 69 66 20 28 69 6d 61 67 | 65 2d 3e 68 64 72 2e 70 |if (imag|e->hdr.p|
|00001080| 68 79 73 62 69 74 73 20 | 21 3d 20 38 29 0a 58 20 |hysbits |!= 8).X |
|00001090| 20 20 20 7b 20 66 70 72 | 69 6e 74 66 20 28 73 74 | { fpr|intf (st|
|000010a0| 64 65 72 72 2c 0a 58 09 | 20 20 20 20 20 20 20 22 |derr,.X.| "|
|000010b0| 43 61 6e 27 74 20 68 61 | 6e 64 6c 65 20 69 6d 61 |Can't ha|ndle ima|
|000010c0| 67 65 73 20 77 69 74 68 | 20 25 64 20 62 69 74 73 |ges with| %d bits|
|000010d0| 20 61 6e 64 20 25 64 20 | 70 68 79 73 62 69 74 73 | and %d |physbits|
|000010e0| 20 70 65 72 20 70 69 78 | 65 6c 5c 6e 22 2c 0a 58 | per pix|el\n",.X|
|000010f0| 09 20 20 20 20 20 20 20 | 69 6d 61 67 65 2d 3e 68 |. |image->h|
|00001100| 64 72 2e 62 69 74 73 2c | 20 69 6d 61 67 65 2d 3e |dr.bits,| image->|
|00001110| 68 64 72 2e 70 68 79 73 | 62 69 74 73 29 3b 0a 58 |hdr.phys|bits);.X|
|00001120| 20 20 20 20 20 20 65 78 | 69 74 20 28 31 29 3b 0a | ex|it (1);.|
|00001130| 58 20 20 20 20 7d 0a 58 | 0a 58 20 20 20 20 2f 2a |X }.X|.X /*|
|00001140| 20 47 65 74 20 61 72 67 | 75 6d 65 6e 74 73 20 2a | Get arg|uments *|
|00001150| 2f 0a 58 20 20 20 20 69 | 66 20 28 61 72 67 63 20 |/.X i|f (argc |
|00001160| 3e 20 30 29 09 78 6f 09 | 3d 20 61 74 6f 69 20 28 |> 0).xo.|= atoi (|
|00001170| 61 72 67 76 5b 30 5d 29 | 3b 0a 58 20 20 20 20 69 |argv[0])|;.X i|
|00001180| 66 20 28 78 6f 20 3c 20 | 30 29 09 09 78 6f 09 3d |f (xo < |0)..xo.=|
|00001190| 20 30 3b 0a 58 0a 58 20 | 20 20 20 69 66 20 28 61 | 0;.X.X | if (a|
|000011a0| 72 67 63 20 3e 20 31 29 | 09 79 6f 09 3d 20 61 74 |rgc > 1)|.yo.= at|
|000011b0| 6f 69 20 28 61 72 67 76 | 5b 31 5d 29 3b 0a 58 20 |oi (argv|[1]);.X |
|000011c0| 20 20 20 69 66 20 28 79 | 6f 20 3c 20 30 29 09 09 | if (y|o < 0)..|
|000011d0| 79 6f 09 3d 20 30 3b 0a | 58 0a 58 20 20 20 20 69 |yo.= 0;.|X.X i|
|000011e0| 66 20 28 61 72 67 63 20 | 3e 20 32 29 09 77 09 3d |f (argc |> 2).w.=|
|000011f0| 20 61 74 6f 69 20 28 61 | 72 67 76 5b 32 5d 29 3b | atoi (a|rgv[2]);|
|00001200| 0a 58 20 20 20 20 69 66 | 20 28 77 20 3c 20 30 29 |.X if| (w < 0)|
|00001210| 09 09 77 09 3d 20 69 6d | 61 67 65 2d 3e 68 64 72 |..w.= im|age->hdr|
|00001220| 2e 63 6f 6c 73 20 2d 20 | 78 6f 3b 0a 58 0a 58 20 |.cols - |xo;.X.X |
|00001230| 20 20 20 69 66 20 28 61 | 72 67 63 20 3e 20 33 29 | if (a|rgc > 3)|
|00001240| 09 68 09 3d 20 61 74 6f | 69 20 28 61 72 67 76 5b |.h.= ato|i (argv[|
|00001250| 33 5d 29 3b 0a 58 20 20 | 20 20 69 66 20 28 68 20 |3]);.X | if (h |
|00001260| 3c 20 30 29 09 09 68 09 | 3d 20 69 6d 61 67 65 2d |< 0)..h.|= image-|
|00001270| 3e 68 64 72 2e 72 6f 77 | 73 20 2d 20 79 6f 3b 0a |>hdr.row|s - yo;.|
|00001280| 58 0a 58 20 20 20 20 69 | 66 20 28 61 72 67 63 20 |X.X i|f (argc |
|00001290| 3e 20 34 29 09 6f 77 09 | 3d 20 61 74 6f 69 20 28 |> 4).ow.|= atoi (|
|000012a0| 61 72 67 76 5b 34 5d 29 | 3b 0a 58 0a 58 20 20 20 |argv[4])|;.X.X |
|000012b0| 20 69 66 20 28 61 72 67 | 63 20 3e 20 35 29 09 61 | if (arg|c > 5).a|
|000012c0| 73 70 65 63 74 20 3d 20 | 61 74 6f 66 20 28 61 72 |spect = |atof (ar|
|000012d0| 67 76 5b 35 5d 29 3b 0a | 58 20 20 20 20 0a 58 20 |gv[5]);.|X .X |
|000012e0| 20 20 20 2f 2a 20 49 66 | 20 27 61 6c 6c 6f 77 72 | /* If| 'allowr|
|000012f0| 6f 74 27 20 69 73 20 6f | 6e 2c 20 72 6f 74 61 74 |ot' is o|n, rotat|
|00001300| 65 20 69 6d 61 67 65 20 | 69 66 20 69 74 73 20 66 |e image |if its f|
|00001310| 69 74 73 20 62 65 74 74 | 65 72 20 2a 2f 0a 58 20 |its bett|er */.X |
|00001320| 20 20 20 69 66 20 28 61 | 6c 6c 6f 77 72 6f 74 20 | if (a|llowrot |
|00001330| 26 26 20 6d 68 20 3e 20 | 30 20 26 26 20 6d 77 20 |&& mh > |0 && mw |
|00001340| 3e 20 30 29 0a 58 20 20 | 20 20 7b 20 69 6e 74 20 |> 0).X | { int |
|00001350| 69 6e 68 6f 72 69 7a 3d | 30 2c 20 6f 75 74 68 6f |inhoriz=|0, outho|
|00001360| 72 69 7a 3d 30 3b 0a 58 | 20 20 20 20 0a 58 20 20 |riz=0;.X| .X |
|00001370| 20 20 20 20 69 66 20 28 | 61 73 70 65 63 74 20 3c | if (|aspect <|
|00001380| 20 30 2e 30 29 20 61 73 | 70 65 63 74 20 3d 20 31 | 0.0) as|pect = 1|
|00001390| 2e 30 3b 0a 58 20 20 20 | 20 0a 58 20 20 20 20 20 |.0;.X | .X |
|000013a0| 20 69 66 20 28 69 6d 61 | 67 65 2d 3e 68 64 72 2e | if (ima|ge->hdr.|
|000013b0| 63 6f 6c 73 20 3e 3d 20 | 28 69 6d 61 67 65 2d 3e |cols >= |(image->|
|000013c0| 68 64 72 2e 61 73 70 65 | 63 74 20 2a 20 69 6d 61 |hdr.aspe|ct * ima|
|000013d0| 67 65 2d 3e 68 64 72 2e | 72 6f 77 73 29 29 20 69 |ge->hdr.|rows)) i|
|000013e0| 6e 68 6f 72 69 7a 2b 2b | 3b 0a 58 20 20 20 20 20 |nhoriz++|;.X |
|000013f0| 20 69 66 20 28 6d 77 20 | 3e 3d 20 28 61 73 70 65 | if (mw |>= (aspe|
|00001400| 63 74 20 2a 20 6d 68 29 | 29 09 09 09 09 09 20 6f |ct * mh)|)..... o|
|00001410| 75 74 68 6f 72 69 7a 2b | 2b 3b 0a 58 20 20 20 20 |uthoriz+|+;.X |
|00001420| 20 20 0a 58 20 20 20 20 | 20 20 69 66 20 28 69 6e | .X | if (in|
|00001430| 68 6f 72 69 7a 20 21 3d | 20 6f 75 74 68 6f 72 69 |horiz !=| outhori|
|00001440| 7a 29 0a 58 20 20 20 20 | 20 20 7b 20 69 66 20 28 |z).X | { if (|
|00001450| 72 6f 74 61 74 65 5f 66 | 62 6d 20 28 69 6d 61 67 |rotate_f|bm (imag|
|00001460| 65 2c 20 26 72 6f 74 61 | 74 65 64 2c 20 39 30 29 |e, &rota|ted, 90)|
|00001470| 29 0a 58 20 20 20 20 20 | 20 20 20 7b 20 66 72 65 |).X | { fre|
|00001480| 65 20 28 69 6d 61 67 65 | 29 3b 0a 58 09 20 20 69 |e (image|);.X. i|
|00001490| 6d 61 67 65 20 3d 20 26 | 72 6f 74 61 74 65 64 3b |mage = &|rotated;|
|000014a0| 0a 58 09 20 20 0a 58 09 | 20 20 66 70 72 69 6e 74 |.X. .X.| fprint|
|000014b0| 66 20 28 73 74 64 65 72 | 72 2c 20 22 52 6f 74 61 |f (stder|r, "Rota|
|000014c0| 74 69 6e 67 20 5b 25 64 | 78 25 64 5d 20 69 6d 61 |ting [%d|x%d] ima|
|000014d0| 67 65 20 66 6f 72 20 62 | 65 74 74 65 72 20 66 69 |ge for b|etter fi|
|000014e0| 74 20 5b 25 64 78 25 64 | 5d 5c 6e 22 2c 0a 58 09 |t [%dx%d|]\n",.X.|
|000014f0| 09 20 20 20 69 6d 61 67 | 65 2d 3e 68 64 72 2e 72 |. imag|e->hdr.r|
|00001500| 6f 77 73 2c 20 69 6d 61 | 67 65 2d 3e 68 64 72 2e |ows, ima|ge->hdr.|
|00001510| 63 6f 6c 73 2c 20 6d 77 | 2c 20 6d 68 29 3b 0a 58 |cols, mw|, mh);.X|
|00001520| 09 7d 0a 58 20 20 20 20 | 20 20 7d 0a 58 20 20 20 |.}.X | }.X |
|00001530| 20 20 20 65 6c 73 65 0a | 58 20 20 20 20 20 20 7b | else.|X {|
|00001540| 20 65 78 69 74 20 28 31 | 29 3b 20 7d 0a 58 20 20 | exit (1|); }.X |
|00001550| 20 20 7d 0a 58 0a 58 20 | 20 20 20 2f 2a 20 49 66 | }.X.X | /* If|
|00001560| 20 6d 61 78 20 6e 75 6d | 62 65 72 20 6f 66 20 70 | max num|ber of p|
|00001570| 69 78 65 6c 73 20 73 70 | 65 63 69 66 69 65 64 2c |ixels sp|ecified,|
|00001580| 20 63 61 6c 63 75 6c 61 | 74 65 20 77 69 64 74 68 | calcula|te width|
|00001590| 20 61 6e 64 20 68 65 69 | 67 68 74 20 2a 2f 0a 58 | and hei|ght */.X|
|000015a0| 20 20 20 20 69 66 20 28 | 73 69 7a 65 20 3e 20 30 | if (|size > 0|
|000015b0| 29 0a 58 20 20 20 20 7b | 20 69 66 20 28 6f 77 20 |).X {| if (ow |
|000015c0| 3e 20 30 20 7c 7c 20 6f | 68 20 3e 20 30 29 0a 58 |> 0 || o|h > 0).X|
|000015d0| 20 20 20 20 20 20 7b 20 | 66 70 72 69 6e 74 66 20 | { |fprintf |
|000015e0| 28 73 74 64 65 72 72 2c | 0a 58 09 20 20 22 66 62 |(stderr,|.X. "fb|
|000015f0| 65 78 74 3a 20 65 72 72 | 6f 72 2c 20 63 61 6e 20 |ext: err|or, can |
|00001600| 6f 6e 6c 79 20 73 70 65 | 63 69 66 79 20 6f 6e 65 |only spe|cify one|
|00001610| 20 6f 66 20 73 69 7a 65 | 20 61 6e 64 20 77 69 64 | of size| and wid|
|00001620| 74 68 2c 68 65 69 67 68 | 74 5c 6e 22 29 3b 0a 58 |th,heigh|t\n");.X|
|00001630| 09 65 78 69 74 20 28 31 | 29 3b 0a 58 20 20 20 20 |.exit (1|);.X |
|00001640| 20 20 7d 0a 58 20 20 20 | 20 20 20 0a 58 20 20 20 | }.X | .X |
|00001650| 20 20 20 61 73 70 65 63 | 74 20 3d 20 31 2e 30 3b | aspec|t = 1.0;|
|00001660| 0a 58 0a 58 20 20 20 20 | 20 20 6f 77 20 3d 20 73 |.X.X | ow = s|
|00001670| 71 72 74 20 28 28 64 6f | 75 62 6c 65 29 20 73 69 |qrt ((do|uble) si|
|00001680| 7a 65 20 2a 20 77 20 2f | 20 28 68 20 2a 20 69 6d |ze * w /| (h * im|
|00001690| 61 67 65 2d 3e 68 64 72 | 2e 61 73 70 65 63 74 29 |age->hdr|.aspect)|
|000016a0| 29 3b 0a 58 20 20 20 20 | 20 20 6f 77 20 26 3d 20 |);.X | ow &= |
|000016b0| 7e 37 3b 09 09 09 2f 2a | 20 4d 61 6b 65 20 77 69 |~7;.../*| Make wi|
|000016c0| 64 74 68 20 6d 75 6c 74 | 69 70 6c 65 20 6f 66 20 |dth mult|iple of |
|000016d0| 38 20 2a 2f 0a 58 20 20 | 20 20 20 20 6f 68 20 3d |8 */.X | oh =|
|000016e0| 20 6f 77 20 2a 20 69 6d | 61 67 65 2d 3e 68 64 72 | ow * im|age->hdr|
|000016f0| 2e 61 73 70 65 63 74 20 | 2a 20 68 20 2f 20 77 3b |.aspect |* h / w;|
|00001700| 0a 58 20 20 20 20 7d 0a | 58 0a 58 20 20 20 20 2f |.X }.|X.X /|
|00001710| 2a 20 49 66 20 67 69 76 | 65 6e 20 77 69 64 74 68 |* If giv|en width|
|00001720| 20 61 6e 64 20 68 65 69 | 67 68 74 2c 20 6d 75 73 | and hei|ght, mus|
|00001730| 74 20 64 65 74 65 72 6d | 69 6e 65 20 6f 75 74 70 |t determ|ine outp|
|00001740| 75 74 20 61 73 70 65 63 | 74 20 2a 2f 0a 58 20 20 |ut aspec|t */.X |
|00001750| 20 20 69 66 20 28 61 73 | 70 65 63 74 20 3c 3d 20 | if (as|pect <= |
|00001760| 30 2e 30 29 0a 58 20 20 | 20 20 7b 20 69 66 20 28 |0.0).X | { if (|
|00001770| 6f 77 20 3e 20 30 20 26 | 26 20 6f 68 20 3e 20 30 |ow > 0 &|& oh > 0|
|00001780| 29 0a 58 20 20 20 20 20 | 20 7b 20 61 73 70 65 63 |).X | { aspec|
|00001790| 74 20 3d 20 69 6d 61 67 | 65 2d 3e 68 64 72 2e 61 |t = imag|e->hdr.a|
|000017a0| 73 70 65 63 74 20 2a 20 | 6f 77 20 2a 20 68 20 2f |spect * |ow * h /|
|000017b0| 20 28 6f 68 20 2a 20 77 | 29 3b 20 7d 0a 58 20 20 | (oh * w|); }.X |
|000017c0| 20 20 20 20 65 6c 73 65 | 0a 58 20 20 20 20 20 20 | else|.X |
|000017d0| 7b 20 61 73 70 65 63 74 | 20 3d 20 69 6d 61 67 65 |{ aspect| = image|
|000017e0| 2d 3e 68 64 72 2e 61 73 | 70 65 63 74 3b 20 7d 0a |->hdr.as|pect; }.|
|000017f0| 58 20 20 20 20 7d 0a 58 | 0a 58 20 20 20 20 2f 2a |X }.X|.X /*|
|00001800| 20 49 66 20 67 69 76 65 | 6e 20 6f 6e 6c 79 20 6d | If give|n only m|
|00001810| 61 78 69 6d 75 6d 20 73 | 69 7a 65 73 2c 20 61 73 |aximum s|izes, as|
|00001820| 73 75 6d 65 20 6c 61 72 | 67 65 73 74 20 77 69 64 |sume lar|gest wid|
|00001830| 74 68 20 2a 2f 0a 58 20 | 20 20 20 69 66 20 28 6f |th */.X | if (o|
|00001840| 77 20 3c 3d 20 30 20 26 | 26 20 6f 68 20 3c 3d 20 |w <= 0 &|& oh <= |
|00001850| 30 29 0a 58 20 20 20 20 | 7b 20 69 66 20 28 6d 77 |0).X |{ if (mw|
|00001860| 20 3e 20 30 29 09 6f 77 | 20 3d 20 6d 77 3b 0a 58 | > 0).ow| = mw;.X|
|00001870| 20 20 20 20 20 20 65 6c | 73 65 20 69 66 20 28 6d | el|se if (m|
|00001880| 68 20 3e 20 30 29 09 6f | 68 20 3d 20 6d 68 3b 0a |h > 0).o|h = mh;.|
|00001890| 58 20 20 20 20 7d 0a 58 | 0a 58 20 20 20 20 2f 2a |X }.X|.X /*|
|000018a0| 0a 58 20 20 20 20 20 2a | 20 49 66 20 67 69 76 65 |.X *| If give|
|000018b0| 6e 20 6f 6e 65 20 6f 66 | 20 77 69 64 74 68 20 6f |n one of| width o|
|000018c0| 72 20 68 65 69 67 68 74 | 2c 20 63 61 6c 63 75 6c |r height|, calcul|
|000018d0| 61 74 65 20 74 68 65 20 | 6f 74 68 65 72 2e 0a 58 |ate the |other..X|
|000018e0| 20 20 20 20 20 2a 20 49 | 66 20 67 69 76 65 6e 20 | * I|f given |
|000018f0| 6f 6e 6c 79 20 61 73 70 | 65 63 74 20 72 61 74 69 |only asp|ect rati|
|00001900| 6f 2c 20 69 6e 66 6c 61 | 74 65 20 74 68 65 20 73 |o, infla|te the s|
|00001910| 6d 61 6c 6c 65 72 20 64 | 69 6d 65 6e 73 69 6f 6e |maller d|imension|
|00001920| 0a 58 20 20 20 20 20 2a | 2f 0a 58 0a 58 20 20 20 |.X *|/.X.X |
|00001930| 20 69 66 20 28 6f 77 20 | 3e 20 30 20 26 26 20 6f | if (ow |> 0 && o|
|00001940| 68 20 3e 20 30 29 0a 58 | 20 20 20 20 7b 20 2f 2a |h > 0).X| { /*|
|00001950| 20 4e 6f 74 68 69 6e 67 | 20 74 6f 20 70 69 63 6b | Nothing| to pick|
|00001960| 20 2a 2f 20 7d 0a 58 20 | 20 20 20 65 6c 73 65 20 | */ }.X | else |
|00001970| 69 66 20 28 6f 77 20 3c | 3d 20 30 20 26 26 20 6f |if (ow <|= 0 && o|
|00001980| 68 20 3e 20 30 29 0a 58 | 20 20 20 20 7b 20 6f 77 |h > 0).X| { ow|
|00001990| 20 3d 20 28 28 64 6f 75 | 62 6c 65 29 20 6f 68 20 | = ((dou|ble) oh |
|000019a0| 2b 20 30 2e 35 29 20 2a | 20 28 61 73 70 65 63 74 |+ 0.5) *| (aspect|
|000019b0| 20 2f 20 69 6d 61 67 65 | 2d 3e 68 64 72 2e 61 73 | / image|->hdr.as|
|000019c0| 70 65 63 74 29 20 2a 20 | 77 20 2f 20 68 3b 20 7d |pect) * |w / h; }|
|000019d0| 0a 58 20 20 20 20 65 6c | 73 65 20 69 66 20 28 6f |.X el|se if (o|
|000019e0| 77 20 3e 20 30 20 26 26 | 20 6f 68 20 3c 3d 20 30 |w > 0 &&| oh <= 0|
|000019f0| 29 0a 58 20 20 20 20 7b | 20 6f 68 20 3d 20 28 28 |).X {| oh = ((|
|00001a00| 64 6f 75 62 6c 65 29 20 | 6f 77 20 2b 20 30 2e 35 |double) |ow + 0.5|
|00001a10| 29 20 2a 20 28 69 6d 61 | 67 65 2d 3e 68 64 72 2e |) * (ima|ge->hdr.|
|00001a20| 61 73 70 65 63 74 20 2f | 20 61 73 70 65 63 74 29 |aspect /| aspect)|
|00001a30| 20 2a 20 68 20 2f 20 77 | 3b 20 7d 0a 58 20 20 20 | * h / w|; }.X |
|00001a40| 20 65 6c 73 65 20 69 66 | 20 28 61 73 70 65 63 74 | else if| (aspect|
|00001a50| 20 21 3d 20 69 6d 61 67 | 65 2d 3e 68 64 72 2e 61 | != imag|e->hdr.a|
|00001a60| 73 70 65 63 74 29 0a 58 | 20 20 20 20 7b 20 69 66 |spect).X| { if|
|00001a70| 20 28 61 73 70 65 63 74 | 20 3e 20 69 6d 61 67 65 | (aspect| > image|
|00001a80| 2d 3e 68 64 72 2e 61 73 | 70 65 63 74 29 0a 58 20 |->hdr.as|pect).X |
|00001a90| 20 20 20 20 20 7b 20 6f | 68 20 3d 20 68 3b 0a 58 | { o|h = h;.X|
|00001aa0| 20 20 20 20 20 20 20 20 | 6f 77 20 3d 20 28 28 64 | |ow = ((d|
|00001ab0| 6f 75 62 6c 65 29 20 6f | 68 20 2b 20 30 2e 35 29 |ouble) o|h + 0.5)|
|00001ac0| 20 2a 20 28 61 73 70 65 | 63 74 20 2f 20 69 6d 61 | * (aspe|ct / ima|
|00001ad0| 67 65 2d 3e 68 64 72 2e | 61 73 70 65 63 74 29 20 |ge->hdr.|aspect) |
|00001ae0| 2a 20 77 20 2f 20 68 3b | 0a 58 20 20 20 20 20 20 |* w / h;|.X |
|00001af0| 7d 0a 58 20 20 20 20 20 | 20 65 6c 73 65 0a 58 20 |}.X | else.X |
|00001b00| 20 20 20 20 20 7b 20 6f | 77 20 3d 20 77 3b 0a 58 | { o|w = w;.X|
|00001b10| 20 20 20 20 20 20 20 20 | 6f 68 20 3d 20 28 28 64 | |oh = ((d|
|00001b20| 6f 75 62 6c 65 29 20 6f | 77 20 2b 20 30 2e 35 29 |ouble) o|w + 0.5)|
|00001b30| 20 2a 20 28 69 6e 70 75 | 74 2e 68 64 72 2e 61 73 | * (inpu|t.hdr.as|
|00001b40| 70 65 63 74 20 2f 20 61 | 73 70 65 63 74 29 20 2a |pect / a|spect) *|
|00001b50| 20 68 20 2f 20 77 3b 0a | 58 20 20 20 20 20 20 7d | h / w;.|X }|
|00001b60| 0a 58 20 20 20 20 7d 0a | 58 20 20 20 20 65 6c 73 |.X }.|X els|
|00001b70| 65 0a 58 20 20 20 20 7b | 20 6f 77 20 3d 20 77 3b |e.X {| ow = w;|
|00001b80| 20 6f 68 20 3d 20 68 3b | 20 7d 0a 58 20 20 20 20 | oh = h;| }.X |
|00001b90| 20 0a 58 20 20 20 20 2f | 2a 20 49 66 20 65 69 74 | .X /|* If eit|
|00001ba0| 68 65 72 20 64 69 6d 65 | 6e 73 69 6f 6e 20 65 78 |her dime|nsion ex|
|00001bb0| 63 65 65 64 73 20 67 69 | 76 65 6e 20 6d 61 78 69 |ceeds gi|ven maxi|
|00001bc0| 6d 75 6d 73 2c 20 73 68 | 72 69 6e 6b 20 74 68 65 |mums, sh|rink the|
|00001bd0| 20 69 6d 61 67 65 20 74 | 6f 20 66 69 74 20 2a 2f | image t|o fit */|
|00001be0| 0a 58 20 20 20 20 69 66 | 20 28 6d 68 20 3e 20 30 |.X if| (mh > 0|
|00001bf0| 20 26 26 20 6f 68 20 3e | 20 6d 68 29 0a 58 20 20 | && oh >| mh).X |
|00001c00| 20 20 7b 20 6f 77 20 3d | 20 6f 77 20 2a 20 6d 68 | { ow =| ow * mh|
|00001c10| 20 2f 20 6f 68 3b 20 6f | 68 20 3d 20 6d 68 3b 20 | / oh; o|h = mh; |
|00001c20| 7d 0a 58 0a 58 20 20 20 | 20 2f 2a 20 4e 6f 77 20 |}.X.X | /* Now |
|00001c30| 65 78 74 72 61 63 74 20 | 74 68 65 20 73 70 65 63 |extract |the spec|
|00001c40| 69 66 69 65 64 20 72 65 | 63 74 61 6e 67 6c 65 20 |ified re|ctangle |
|00001c50| 61 6e 64 20 77 72 69 74 | 65 20 69 74 20 6f 75 74 |and writ|e it out|
|00001c60| 20 2a 2f 0a 58 20 20 20 | 20 69 66 20 28 6d 77 20 | */.X | if (mw |
|00001c70| 3e 20 30 20 26 26 20 6f | 77 20 3e 20 6d 77 29 0a |> 0 && o|w > mw).|
|00001c80| 58 20 20 20 20 7b 20 6f | 68 20 3d 20 6f 68 20 2a |X { o|h = oh *|
|00001c90| 20 6d 77 20 2f 20 6f 77 | 3b 20 6f 77 20 3d 20 6d | mw / ow|; ow = m|
|00001ca0| 77 3b 20 7d 0a 58 0a 58 | 20 20 20 20 69 66 20 28 |w; }.X.X| if (|
|00001cb0| 65 78 74 72 61 63 74 5f | 66 62 6d 20 28 26 69 6e |extract_|fbm (&in|
|00001cc0| 70 75 74 2c 20 26 6f 75 | 74 70 75 74 2c 20 78 6f |put, &ou|tput, xo|
|00001cd0| 2c 20 79 6f 2c 20 77 2c | 20 68 2c 20 6f 77 2c 20 |, yo, w,| h, ow, |
|00001ce0| 6f 68 2c 0a 58 09 09 20 | 20 20 20 20 74 69 74 6c |oh,.X.. | titl|
|00001cf0| 65 5b 30 5d 20 3f 20 74 | 69 74 6c 65 20 3a 20 4e |e[0] ? t|itle : N|
|00001d00| 55 4c 4c 2c 0a 58 09 09 | 20 20 20 20 20 63 72 65 |ULL,.X..| cre|
|00001d10| 64 69 74 73 5b 30 5d 20 | 3f 20 63 72 65 64 69 74 |dits[0] |? credit|
|00001d20| 73 20 3a 20 4e 55 4c 4c | 29 29 0a 58 20 20 20 20 |s : NULL|)).X |
|00001d30| 7b 20 69 66 20 28 77 72 | 69 74 65 5f 62 69 74 6d |{ if (wr|ite_bitm|
|00001d40| 61 70 20 28 26 6f 75 74 | 70 75 74 2c 20 73 74 64 |ap (&out|put, std|
|00001d50| 6f 75 74 2c 20 6f 75 74 | 74 79 70 65 29 29 20 65 |out, out|type)) e|
|00001d60| 78 69 74 20 28 30 29 3b | 20 7d 0a 58 20 20 7d 0a |xit (0);| }.X }.|
|00001d70| 58 20 20 0a 58 20 20 65 | 78 69 74 20 28 31 29 3b |X .X e|xit (1);|
|00001d80| 0a 58 7d 0a 45 4e 44 5f | 4f 46 5f 46 49 4c 45 0a |.X}.END_|OF_FILE.|
|00001d90| 69 66 20 74 65 73 74 20 | 36 33 33 37 20 2d 6e 65 |if test |6337 -ne|
|00001da0| 20 60 77 63 20 2d 63 20 | 3c 27 66 62 65 78 74 2e | `wc -c |<'fbext.|
|00001db0| 63 27 60 3b 20 74 68 65 | 6e 0a 20 20 20 20 65 63 |c'`; the|n. ec|
|00001dc0| 68 6f 20 73 68 61 72 3a | 20 5c 22 27 66 62 65 78 |ho shar:| \"'fbex|
|00001dd0| 74 2e 63 27 5c 22 20 75 | 6e 70 61 63 6b 65 64 20 |t.c'\" u|npacked |
|00001de0| 77 69 74 68 20 77 72 6f | 6e 67 20 73 69 7a 65 21 |with wro|ng size!|
|00001df0| 0a 66 69 0a 23 20 65 6e | 64 20 6f 66 20 27 66 62 |.fi.# en|d of 'fb|
|00001e00| 65 78 74 2e 63 27 0a 66 | 69 0a 69 66 20 74 65 73 |ext.c'.f|i.if tes|
|00001e10| 74 20 2d 66 20 27 66 62 | 70 73 2e 63 27 20 2d 61 |t -f 'fb|ps.c' -a|
|00001e20| 20 22 24 7b 31 7d 22 20 | 21 3d 20 22 2d 63 22 20 | "${1}" |!= "-c" |
|00001e30| 3b 20 74 68 65 6e 20 0a | 20 20 65 63 68 6f 20 73 |; then .| echo s|
|00001e40| 68 61 72 3a 20 57 69 6c | 6c 20 6e 6f 74 20 63 6c |har: Wil|l not cl|
|00001e50| 6f 62 62 65 72 20 65 78 | 69 73 74 69 6e 67 20 66 |obber ex|isting f|
|00001e60| 69 6c 65 20 5c 22 27 66 | 62 70 73 2e 63 27 5c 22 |ile \"'f|bps.c'\"|
|00001e70| 0a 65 6c 73 65 0a 65 63 | 68 6f 20 73 68 61 72 3a |.else.ec|ho shar:|
|00001e80| 20 45 78 74 72 61 63 74 | 69 6e 67 20 5c 22 27 66 | Extract|ing \"'f|
|00001e90| 62 70 73 2e 63 27 5c 22 | 20 5c 28 37 33 39 39 20 |bps.c'\"| \(7399 |
|00001ea0| 63 68 61 72 61 63 74 65 | 72 73 5c 29 0a 73 65 64 |characte|rs\).sed|
|00001eb0| 20 22 73 2f 5e 58 2f 2f | 22 20 3e 27 66 62 70 73 | "s/^X//|" >'fbps|
|00001ec0| 2e 63 27 20 3c 3c 27 45 | 4e 44 5f 4f 46 5f 46 49 |.c' <<'E|ND_OF_FI|
|00001ed0| 4c 45 27 0a 58 2f 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |LE'.X/**|********|
|00001ee0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00001ef0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00001f00| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00001f10| 2a 2a 2a 2a 2a 2a 0a 58 | 20 2a 20 66 62 70 73 2e |******.X| * fbps.|
|00001f20| 63 3a 20 46 42 4d 20 4c | 69 62 72 61 72 79 20 30 |c: FBM L|ibrary 0|
|00001f30| 2e 39 32 20 28 42 65 74 | 61 20 74 65 73 74 29 20 |.92 (Bet|a test) |
|00001f40| 32 37 2d 41 70 72 2d 38 | 39 20 20 4d 69 63 68 61 |27-Apr-8|9 Micha|
|00001f50| 65 6c 20 4d 61 75 6c 64 | 69 6e 0a 58 20 2a 0a 58 |el Mauld|in.X *.X|
|00001f60| 20 2a 20 43 6f 70 79 72 | 69 67 68 74 20 28 43 29 | * Copyr|ight (C)|
|00001f70| 20 31 39 38 39 20 62 79 | 20 4d 69 63 68 61 65 6c | 1989 by| Michael|
|00001f80| 20 4d 61 75 6c 64 69 6e | 2e 20 20 50 65 72 6d 69 | Mauldin|. Permi|
|00001f90| 73 73 69 6f 6e 20 69 73 | 20 67 72 61 6e 74 65 64 |ssion is| granted|
|00001fa0| 20 74 6f 0a 58 20 2a 20 | 75 73 65 20 74 68 69 73 | to.X * |use this|
|00001fb0| 20 66 69 6c 65 20 69 6e | 20 77 68 6f 6c 65 20 6f | file in| whole o|
|00001fc0| 72 20 69 6e 20 70 61 72 | 74 20 70 72 6f 76 69 64 |r in par|t provid|
|00001fd0| 65 64 20 74 68 61 74 20 | 79 6f 75 20 64 6f 20 6e |ed that |you do n|
|00001fe0| 6f 74 20 73 65 6c 6c 20 | 69 74 0a 58 20 2a 20 66 |ot sell |it.X * f|
|00001ff0| 6f 72 20 70 72 6f 66 69 | 74 20 61 6e 64 20 74 68 |or profi|t and th|
|00002000| 61 74 20 74 68 69 73 20 | 63 6f 70 79 72 69 67 68 |at this |copyrigh|
|00002010| 74 20 6e 6f 74 69 63 65 | 20 69 73 20 72 65 74 61 |t notice| is reta|
|00002020| 69 6e 65 64 20 75 6e 63 | 68 61 6e 67 65 64 2e 0a |ined unc|hanged..|
|00002030| 58 20 2a 0a 58 20 2a 20 | 66 62 70 73 3a 20 43 6f |X *.X * |fbps: Co|
|00002040| 6e 76 65 72 74 20 61 20 | 67 72 61 79 73 63 61 6c |nvert a |grayscal|
|00002050| 65 20 69 6d 61 67 65 20 | 74 6f 20 61 20 50 6f 73 |e image |to a Pos|
|00002060| 74 53 63 72 69 70 74 20 | 66 69 6c 65 0a 58 20 2a |tScript |file.X *|
|00002070| 0a 58 20 2a 20 55 53 41 | 47 45 0a 58 20 2a 09 25 |.X * USA|GE.X *.%|
|00002080| 20 66 62 70 73 20 3c 20 | 69 6d 61 67 65 20 3e 20 | fbps < |image > |
|00002090| 70 6f 73 74 73 63 72 69 | 70 74 0a 58 20 2a 0a 58 |postscri|pt.X *.X|
|000020a0| 20 2a 20 45 44 49 54 4c | 4f 47 0a 58 20 2a 09 4c | * EDITL|OG.X *.L|
|000020b0| 61 73 74 45 64 69 74 44 | 61 74 65 20 3d 20 54 68 |astEditD|ate = Th|
|000020c0| 75 20 41 70 72 20 32 37 | 20 31 30 3a 30 36 3a 31 |u Apr 27| 10:06:1|
|000020d0| 35 20 31 39 38 39 20 2d | 20 4d 69 63 68 61 65 6c |5 1989 -| Michael|
|000020e0| 20 4d 61 75 6c 64 69 6e | 0a 58 20 2a 09 4c 61 73 | Mauldin|.X *.Las|
|000020f0| 74 46 69 6c 65 4e 61 6d | 65 20 3d 20 2f 75 73 72 |tFileNam|e = /usr|
|00002100| 32 2f 6d 6c 6d 2f 73 72 | 63 2f 6d 69 73 63 2f 66 |2/mlm/sr|c/misc/f|
|00002110| 62 6d 2f 66 62 70 73 2e | 63 0a 58 20 2a 0a 58 20 |bm/fbps.|c.X *.X |
|00002120| 2a 20 48 49 53 54 4f 52 | 59 0a 58 20 2a 20 32 37 |* HISTOR|Y.X * 27|
|00002130| 2d 41 70 72 2d 38 39 20 | 20 4d 69 63 68 61 65 6c |-Apr-89 | Michael|
|00002140| 20 4d 61 75 6c 64 69 6e | 20 28 6d 6c 6d 29 20 61 | Mauldin| (mlm) a|
|00002150| 74 20 43 61 72 6e 65 67 | 69 65 20 4d 65 6c 6c 6f |t Carneg|ie Mello|
|00002160| 6e 20 55 6e 69 76 65 72 | 73 69 74 79 0a 58 20 2a |n Univer|sity.X *|
|00002170| 09 42 65 74 61 20 72 65 | 6c 65 61 73 65 20 28 76 |.Beta re|lease (v|
|00002180| 65 72 73 69 6f 6e 20 30 | 2e 39 32 29 20 6d 6c 6d |ersion 0|.92) mlm|
|00002190| 40 63 73 2e 63 6d 75 2e | 65 64 75 0a 58 20 2a 0a |@cs.cmu.|edu.X *.|
|000021a0| 58 20 2a 20 32 35 2d 41 | 70 72 2d 38 39 20 20 50 |X * 25-A|pr-89 P|
|000021b0| 61 75 6c 20 4d 69 6c 61 | 7a 7a 6f 20 28 6d 69 6c |aul Mila|zzo (mil|
|000021c0| 61 7a 7a 6f 29 20 61 74 | 20 42 42 4e 0a 58 20 2a |azzo) at| BBN.X *|
|000021d0| 09 41 64 64 65 64 20 63 | 6f 6c 6f 72 20 70 6f 73 |.Added c|olor pos|
|000021e0| 74 73 63 72 69 70 74 20 | 73 75 70 70 6f 72 74 0a |tscript |support.|
|000021f0| 58 20 2a 0a 58 20 2a 20 | 32 37 2d 41 75 67 2d 38 |X *.X * |27-Aug-8|
|00002200| 38 20 20 4d 69 63 68 61 | 65 6c 20 4d 61 75 6c 64 |8 Micha|el Mauld|
|00002210| 69 6e 20 28 6d 6c 6d 29 | 20 61 74 20 43 61 72 6e |in (mlm)| at Carn|
|00002220| 65 67 69 65 2d 4d 65 6c | 6c 6f 6e 20 55 6e 69 76 |egie-Mel|lon Univ|
|00002230| 65 72 73 69 74 79 0a 58 | 20 2a 09 43 72 65 61 74 |ersity.X| *.Creat|
|00002240| 65 64 2e 0a 58 20 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |ed..X **|********|
|00002250| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00002260| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00002270| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00002280| 2a 2a 2a 2a 2a 2a 2a 2f | 0a 58 0a 58 23 20 69 6e |*******/|.X.X# in|
|00002290| 63 6c 75 64 65 20 3c 73 | 74 64 69 6f 2e 68 3e 0a |clude <s|tdio.h>.|
|000022a0| 58 23 20 69 6e 63 6c 75 | 64 65 20 3c 6d 61 74 68 |X# inclu|de <math|
|000022b0| 2e 68 3e 0a 58 23 20 69 | 6e 63 6c 75 64 65 20 22 |.h>.X# i|nclude "|
|000022c0| 66 62 6d 2e 68 22 0a 58 | 0a 58 23 20 64 65 66 69 |fbm.h".X|.X# defi|
|000022d0| 6e 65 20 4d 41 58 57 49 | 44 54 48 20 37 2e 30 20 |ne MAXWI|DTH 7.0 |
|000022e0| 2f 2a 20 69 6e 63 68 65 | 73 20 2a 2f 0a 58 23 20 |/* inche|s */.X# |
|000022f0| 64 65 66 69 6e 65 20 4d | 41 58 48 45 49 47 48 54 |define M|AXHEIGHT|
|00002300| 20 39 2e 35 20 2f 2a 20 | 69 6e 63 68 65 73 20 2a | 9.5 /* |inches *|
|00002310| 2f 0a 58 0a 58 63 68 61 | 72 20 2a 70 73 5f 63 68 |/.X.Xcha|r *ps_ch|
|00002320| 61 72 73 28 29 3b 0a 58 | 0a 58 23 20 64 65 66 69 |ars();.X|.X# defi|
|00002330| 6e 65 20 55 53 41 47 45 | 20 5c 0a 58 22 55 73 61 |ne USAGE| \.X"Usa|
|00002340| 67 65 3a 20 66 62 70 73 | 20 5b 2d 74 54 5d 20 5b |ge: fbps| [-tT] [|
|00002350| 2d 70 50 5d 20 5b 20 2d | 73 20 5d 20 5b 20 2d 77 |-pP] [ -|s ] [ -w|
|00002360| 3c 77 69 64 74 68 3e 20 | 5d 20 3c 20 66 6f 6f 2e |<width> |] < foo.|
|00002370| 66 62 6d 20 3e 20 66 6f | 6f 2e 50 53 22 0a 58 0a |fbm > fo|o.PS".X.|
|00002380| 58 23 69 66 6e 64 65 66 | 20 6c 69 6e 74 0a 58 73 |X#ifndef| lint.Xs|
|00002390| 74 61 74 69 63 20 63 68 | 61 72 20 2a 66 62 6d 69 |tatic ch|ar *fbmi|
|000023a0| 64 20 3d 0a 58 09 22 24 | 46 42 4d 20 66 62 70 73 |d =.X."$|FBM fbps|
|000023b0| 2e 63 20 3c 30 2e 39 32 | 3e 20 32 37 2d 41 70 72 |.c <0.92|> 27-Apr|
|000023c0| 2d 38 39 20 20 28 43 29 | 20 31 39 38 39 20 62 79 |-89 (C)| 1989 by|
|000023d0| 20 4d 69 63 68 61 65 6c | 20 4d 61 75 6c 64 69 6e | Michael| Mauldin|
|000023e0| 24 22 3b 0a 58 23 65 6e | 64 69 66 0a 58 0a 58 6d |$";.X#en|dif.X.Xm|
|000023f0| 61 69 6e 20 28 61 72 67 | 63 2c 20 61 72 67 76 29 |ain (arg|c, argv)|
|00002400| 0a 58 63 68 61 72 20 2a | 61 72 67 76 5b 5d 3b 0a |.Xchar *|argv[];.|
|00002410| 58 7b 20 72 65 67 69 73 | 74 65 72 20 69 6e 74 20 |X{ regis|ter int |
|00002420| 69 2c 20 6a 3b 0a 58 20 | 20 69 6e 74 20 72 6f 77 |i, j;.X | int row|
|00002430| 73 2c 20 63 6f 6c 73 2c | 20 72 6f 77 6c 65 6e 3b |s, cols,| rowlen;|
|00002440| 0a 58 20 20 64 6f 75 62 | 6c 65 20 77 69 64 74 68 |.X doub|le width|
|00002450| 20 3d 20 2d 31 2c 20 68 | 65 69 67 68 74 2c 20 6c | = -1, h|eight, l|
|00002460| 6c 78 2c 20 6c 6c 79 3b | 0a 58 20 20 69 6e 74 20 |lx, lly;|.X int |
|00002470| 62 79 74 63 6e 74 3d 30 | 3b 0a 58 20 20 69 6e 74 |bytcnt=0|;.X int|
|00002480| 20 64 6f 74 69 74 6c 65 | 3d 31 2c 20 64 6f 73 69 | dotitle|=1, dosi|
|00002490| 7a 65 3d 31 2c 20 73 63 | 72 69 62 65 3d 30 3b 0a |ze=1, sc|ribe=0;.|
|000024a0| 58 20 20 63 68 61 72 20 | 62 75 66 5b 42 55 46 53 |X char |buf[BUFS|
|000024b0| 49 5a 5d 2c 20 2a 74 69 | 74 6c 65 3d 4e 55 4c 4c |IZ], *ti|tle=NULL|
|000024c0| 2c 20 2a 63 72 65 61 74 | 6f 72 3d 4e 55 4c 4c 3b |, *creat|or=NULL;|
|000024d0| 0a 58 20 20 6c 6f 6e 67 | 20 63 6c 6f 63 6b 20 3d |.X long| clock =|
|000024e0| 20 74 69 6d 65 20 28 28 | 6c 6f 6e 67 20 2a 29 20 | time ((|long *) |
|000024f0| 4e 55 4c 4c 29 3b 0a 58 | 20 20 63 68 61 72 20 2a |NULL);.X| char *|
|00002500| 63 74 69 6d 65 20 28 29 | 3b 0a 58 20 20 46 42 4d |ctime ()|;.X FBM|
|00002510| 20 69 6d 61 67 65 3b 0a | 58 0a 58 20 20 2f 2a 20 | image;.|X.X /* |
|00002520| 43 6c 65 61 72 20 74 68 | 65 20 6d 65 6d 6f 72 79 |Clear th|e memory|
|00002530| 20 70 6f 69 6e 74 65 72 | 20 73 6f 20 61 6c 6c 6f | pointer| so allo|
|00002540| 63 5f 66 62 6d 20 77 6f | 6e 27 74 20 62 65 20 63 |c_fbm wo|n't be c|
|00002550| 6f 6e 66 75 73 65 64 20 | 2a 2f 0a 58 20 20 69 6d |onfused |*/.X im|
|00002560| 61 67 65 2e 63 6d 20 20 | 3d 20 69 6d 61 67 65 2e |age.cm |= image.|
|00002570| 62 6d 20 20 3d 20 28 75 | 6e 73 69 67 6e 65 64 20 |bm = (u|nsigned |
|00002580| 63 68 61 72 20 2a 29 20 | 4e 55 4c 4c 3b 0a 58 0a |char *) |NULL;.X.|
|00002590| 58 20 20 2f 2a 20 47 65 | 74 20 74 68 65 20 6f 70 |X /* Ge|t the op|
|000025a0| 74 69 6f 6e 73 20 2a 2f | 0a 58 20 20 77 68 69 6c |tions */|.X whil|
|000025b0| 65 20 28 2d 2d 61 72 67 | 63 20 3e 20 30 20 26 26 |e (--arg|c > 0 &&|
|000025c0| 20 28 2a 2b 2b 61 72 67 | 76 29 5b 30 5d 20 3d 3d | (*++arg|v)[0] ==|
|000025d0| 20 27 2d 27 29 0a 58 20 | 20 7b 20 77 68 69 6c 65 | '-').X | { while|
|000025e0| 20 28 2a 2b 2b 28 2a 61 | 72 67 76 29 29 0a 58 20 | (*++(*a|rgv)).X |
|000025f0| 20 20 20 7b 20 73 77 69 | 74 63 68 20 28 2a 2a 61 | { swi|tch (**a|
|00002600| 72 67 76 29 0a 58 20 20 | 20 20 20 20 7b 20 63 61 |rgv).X | { ca|
|00002610| 73 65 20 27 74 27 3a 09 | 64 6f 74 69 74 6c 65 20 |se 't':.|dotitle |
|00002620| 3d 20 31 3b 20 62 72 65 | 61 6b 3b 0a 58 09 63 61 |= 1; bre|ak;.X.ca|
|00002630| 73 65 20 27 54 27 3a 09 | 64 6f 74 69 74 6c 65 20 |se 'T':.|dotitle |
|00002640| 3d 20 30 3b 20 62 72 65 | 61 6b 3b 0a 58 09 63 61 |= 0; bre|ak;.X.ca|
|00002650| 73 65 20 27 70 27 3a 09 | 64 6f 73 69 7a 65 20 3d |se 'p':.|dosize =|
|00002660| 20 31 3b 20 62 72 65 61 | 6b 3b 0a 58 09 63 61 73 | 1; brea|k;.X.cas|
|00002670| 65 20 27 50 27 3a 09 64 | 6f 73 69 7a 65 20 3d 20 |e 'P':.d|osize = |
|00002680| 30 3b 20 62 72 65 61 6b | 3b 0a 58 09 63 61 73 65 |0; break|;.X.case|
|00002690| 20 27 73 27 3a 09 73 63 | 72 69 62 65 2b 2b 3b 20 | 's':.sc|ribe++; |
|000026a0| 62 72 65 61 6b 3b 0a 58 | 09 63 61 73 65 20 27 77 |break;.X|.case 'w|
|000026b0| 27 3a 09 77 69 64 74 68 | 20 3d 20 61 74 6f 66 20 |':.width| = atof |
|000026c0| 28 2a 61 72 67 76 2b 31 | 29 3b 20 53 4b 49 50 41 |(*argv+1|); SKIPA|
|000026d0| 52 47 3b 20 62 72 65 61 | 6b 3b 0a 58 09 64 65 66 |RG; brea|k;.X.def|
|000026e0| 61 75 6c 74 3a 09 66 70 | 72 69 6e 74 66 20 28 73 |ault:.fp|rintf (s|
|000026f0| 74 64 65 72 72 2c 20 22 | 25 73 5c 6e 22 2c 20 55 |tderr, "|%s\n", U|
|00002700| 53 41 47 45 29 3b 0a 58 | 09 09 09 65 78 69 74 20 |SAGE);.X|...exit |
|00002710| 28 31 29 3b 0a 58 20 20 | 20 20 20 20 7d 0a 58 20 |(1);.X | }.X |
|00002720| 20 20 20 7d 0a 58 20 20 | 7d 0a 58 0a 58 20 20 69 | }.X |}.X.X i|
|00002730| 66 20 28 21 72 65 61 64 | 5f 62 69 74 6d 61 70 20 |f (!read|_bitmap |
|00002740| 28 26 69 6d 61 67 65 2c | 20 28 63 68 61 72 20 2a |(&image,| (char *|
|00002750| 29 20 4e 55 4c 4c 29 29 | 0a 58 20 20 7b 20 65 78 |) NULL))|.X { ex|
|00002760| 69 74 20 28 31 29 3b 20 | 7d 0a 58 0a 58 20 20 69 |it (1); |}.X.X i|
|00002770| 66 20 28 28 69 6d 61 67 | 65 2e 68 64 72 2e 70 6c |f ((imag|e.hdr.pl|
|00002780| 61 6e 65 73 20 21 3d 20 | 31 20 26 26 20 69 6d 61 |anes != |1 && ima|
|00002790| 67 65 2e 68 64 72 2e 70 | 6c 61 6e 65 73 20 21 3d |ge.hdr.p|lanes !=|
|000027a0| 20 33 29 20 7c 7c 20 69 | 6d 61 67 65 2e 68 64 72 | 3) || i|mage.hdr|
|000027b0| 2e 63 6c 72 6c 65 6e 20 | 3e 20 30 29 0a 58 20 20 |.clrlen |> 0).X |
|000027c0| 7b 20 66 70 72 69 6e 74 | 66 20 28 73 74 64 65 72 |{ fprint|f (stder|
|000027d0| 72 2c 0a 58 09 20 20 20 | 20 20 22 45 72 72 6f 72 |r,.X. | "Error|
|000027e0| 3a 5c 74 66 62 70 73 20 | 6f 6e 6c 79 20 68 61 6e |:\tfbps |only han|
|000027f0| 64 6c 65 73 20 67 72 61 | 79 73 63 61 6c 65 20 6f |dles gra|yscale o|
|00002800| 72 20 75 6e 6d 61 70 70 | 65 64 20 63 6f 6c 6f 72 |r unmapp|ed color|
|00002810| 20 66 69 6c 65 73 5c 6e | 22 29 3b 0a 58 20 20 20 | files\n|");.X |
|00002820| 20 66 70 72 69 6e 74 66 | 20 28 73 74 64 65 72 72 | fprintf| (stderr|
|00002830| 2c 20 22 5c 74 55 73 65 | 20 74 68 65 20 63 6c 72 |, "\tUse| the clr|
|00002840| 32 67 72 61 79 20 66 69 | 6c 74 65 72 20 74 6f 20 |2gray fi|lter to |
|00002850| 63 72 65 61 74 65 20 67 | 72 61 79 73 63 61 6c 65 |create g|rayscale|
|00002860| 20 66 69 72 73 74 5c 6e | 22 29 3b 0a 58 20 20 20 | first\n|");.X |
|00002870| 20 65 78 69 74 20 28 31 | 29 3b 0a 58 20 20 7d 0a | exit (1|);.X }.|
|00002880| 58 0a 58 20 20 69 66 20 | 28 69 6d 61 67 65 2e 68 |X.X if |(image.h|
|00002890| 64 72 2e 62 69 74 73 20 | 3d 3d 20 31 29 0a 58 20 |dr.bits |== 1).X |
|000028a0| 20 7b 20 66 70 72 69 6e | 74 66 20 28 73 74 64 65 | { fprin|tf (stde|
|000028b0| 72 72 2c 20 22 45 72 72 | 6f 72 3a 5c 74 66 62 70 |rr, "Err|or:\tfbp|
|000028c0| 73 20 63 61 6e 6e 6f 74 | 20 68 61 6e 64 6c 65 20 |s cannot| handle |
|000028d0| 31 20 62 69 74 20 64 65 | 65 70 20 62 69 74 6d 61 |1 bit de|ep bitma|
|000028e0| 70 73 5c 6e 22 29 3b 0a | 58 20 20 20 20 66 70 72 |ps\n");.|X fpr|
|000028f0| 69 6e 74 66 20 28 73 74 | 64 65 72 72 2c 20 22 5c |intf (st|derr, "\|
|00002900| 74 55 73 65 20 27 66 62 | 63 61 74 20 2d 50 20 7c |tUse 'fb|cat -P ||
|00002910| 20 70 62 6d 32 70 73 27 | 20 74 6f 20 63 6f 6e 76 | pbm2ps'| to conv|
|00002920| 65 72 74 20 25 73 5c 6e | 22 2c 0a 58 09 20 20 20 |ert %s\n|",.X. |
|00002930| 20 20 22 31 62 69 74 20 | 66 69 6c 65 73 20 74 6f | "1bit |files to|
|00002940| 20 50 6f 73 74 73 63 72 | 69 70 74 22 29 3b 0a 58 | Postscr|ipt");.X|
|00002950| 20 20 20 20 65 78 69 74 | 20 28 31 29 3b 0a 58 20 | exit| (1);.X |
|00002960| 20 7d 0a 58 0a 58 20 20 | 2f 2a 20 47 65 74 20 74 | }.X.X |/* Get t|
|00002970| 69 74 6c 65 20 2a 2f 0a | 58 20 20 69 66 20 28 69 |itle */.|X if (i|
|00002980| 6d 61 67 65 2e 68 64 72 | 2e 74 69 74 6c 65 20 26 |mage.hdr|.title &|
|00002990| 26 20 69 6d 61 67 65 2e | 68 64 72 2e 74 69 74 6c |& image.|hdr.titl|
|000029a0| 65 5b 30 5d 29 0a 58 20 | 20 7b 20 74 69 74 6c 65 |e[0]).X | { title|
|000029b0| 20 3d 20 69 6d 61 67 65 | 2e 68 64 72 2e 74 69 74 | = image|.hdr.tit|
|000029c0| 6c 65 3b 20 7d 0a 58 0a | 58 20 20 2f 2a 20 47 65 |le; }.X.|X /* Ge|
|000029d0| 74 20 77 69 64 74 68 20 | 61 6e 64 20 68 65 69 67 |t width |and heig|
|000029e0| 68 74 20 2a 2f 0a 58 20 | 20 72 6f 77 73 20 3d 20 |ht */.X | rows = |
|000029f0| 69 6d 61 67 65 2e 68 64 | 72 2e 72 6f 77 73 3b 0a |image.hd|r.rows;.|
|00002a00| 58 20 20 63 6f 6c 73 20 | 3d 20 69 6d 61 67 65 2e |X cols |= image.|
|00002a10| 68 64 72 2e 63 6f 6c 73 | 3b 0a 58 20 20 72 6f 77 |hdr.cols|;.X row|
|00002a20| 6c 65 6e 20 3d 20 69 6d | 61 67 65 2e 68 64 72 2e |len = im|age.hdr.|
|00002a30| 72 6f 77 6c 65 6e 3b 0a | 58 0a 58 20 20 2f 2a 20 |rowlen;.|X.X /* |
|00002a40| 50 69 63 6b 20 6f 75 74 | 70 75 74 20 73 69 7a 65 |Pick out|put size|
|00002a50| 20 2a 2f 0a 58 20 20 69 | 66 20 28 77 69 64 74 68 | */.X i|f (width|
|00002a60| 20 3c 20 30 2e 30 20 7c | 7c 20 77 69 64 74 68 20 | < 0.0 ||| width |
|00002a70| 3e 20 4d 41 58 57 49 44 | 54 48 29 0a 58 20 20 7b |> MAXWID|TH).X {|
|00002a80| 20 77 69 64 74 68 20 3d | 20 4d 41 58 57 49 44 54 | width =| MAXWIDT|
|00002a90| 48 3b 20 7d 0a 58 20 20 | 0a 58 20 20 68 65 69 67 |H; }.X |.X heig|
|00002aa0| 68 74 20 3d 20 77 69 64 | 74 68 20 2a 20 69 6d 61 |ht = wid|th * ima|
|00002ab0| 67 65 2e 68 64 72 2e 61 | 73 70 65 63 74 20 2a 20 |ge.hdr.a|spect * |
|00002ac0| 28 64 6f 75 62 6c 65 29 | 20 72 6f 77 73 20 2f 20 |(double)| rows / |
|00002ad0| 63 6f 6c 73 3b 0a 58 20 | 20 20 20 0a 58 20 20 69 |cols;.X | .X i|
|00002ae0| 66 20 28 68 65 69 67 68 | 74 20 3e 20 4d 41 58 48 |f (heigh|t > MAXH|
|00002af0| 45 49 47 48 54 29 0a 58 | 20 20 7b 20 77 69 64 74 |EIGHT).X| { widt|
|00002b00| 68 20 3d 20 77 69 64 74 | 68 20 2a 20 4d 41 58 48 |h = widt|h * MAXH|
|00002b10| 45 49 47 48 54 20 2f 20 | 68 65 69 67 68 74 3b 20 |EIGHT / |height; |
|00002b20| 68 65 69 67 68 74 20 3d | 20 4d 41 58 48 45 49 47 |height =| MAXHEIG|
|00002b30| 48 54 3b 20 7d 0a 58 20 | 20 0a 58 20 20 2f 2a 20 |HT; }.X | .X /* |
|00002b40| 50 69 63 6b 20 6c 6f 77 | 65 72 20 6c 65 66 74 20 |Pick low|er left |
|00002b50| 63 6f 72 6e 65 72 20 2a | 2f 0a 58 20 20 69 66 20 |corner *|/.X if |
|00002b60| 28 73 63 72 69 62 65 29 | 0a 58 20 20 7b 20 6c 6c |(scribe)|.X { ll|
|00002b70| 78 20 3d 20 6c 6c 79 20 | 3d 20 30 2e 30 3b 20 20 |x = lly |= 0.0; |
|00002b80| 7d 0a 58 20 20 65 6c 73 | 65 0a 58 20 20 7b 20 6c |}.X els|e.X { l|
|00002b90| 6c 78 20 3d 20 28 38 2e | 30 20 2d 20 77 69 64 74 |lx = (8.|0 - widt|
|00002ba0| 68 29 20 2f 20 32 2e 30 | 20 2b 20 30 2e 35 3b 0a |h) / 2.0| + 0.5;.|
|00002bb0| 58 20 20 20 20 6c 6c 79 | 20 3d 20 28 31 31 2e 30 |X lly| = (11.0|
|00002bc0| 20 2d 20 68 65 69 67 68 | 74 29 20 2f 20 32 2e 30 | - heigh|t) / 2.0|
|00002bd0| 3b 0a 58 20 20 7d 0a 58 | 0a 58 20 20 66 70 72 69 |;.X }.X|.X fpri|
|00002be0| 6e 74 66 20 28 73 74 64 | 65 72 72 2c 0a 58 09 20 |ntf (std|err,.X. |
|00002bf0| 20 20 22 46 42 4d 20 74 | 6f 20 50 53 20 5c 22 25 | "FBM t|o PS \"%|
|00002c00| 73 5c 22 20 77 69 64 74 | 68 20 25 31 2e 33 6c 66 |s\" widt|h %1.3lf|
|00002c10| 20 69 6e 63 68 65 73 2c | 20 68 65 69 67 68 74 20 | inches,| height |
|00002c20| 25 31 2e 33 6c 66 20 69 | 6e 63 68 65 73 5c 6e 22 |%1.3lf i|nches\n"|
|00002c30| 2c 0a 58 09 20 20 20 74 | 69 74 6c 65 20 3f 20 74 |,.X. t|itle ? t|
|00002c40| 69 74 6c 65 20 3a 20 22 | 28 75 6e 74 69 74 6c 65 |itle : "|(untitle|
|00002c50| 64 29 22 2c 20 77 69 64 | 74 68 2c 20 68 65 69 67 |d)", wid|th, heig|
|00002c60| 68 74 29 3b 0a 58 0a 58 | 20 20 2f 2a 20 57 72 69 |ht);.X.X| /* Wri|
|00002c70| 74 65 20 6f 75 74 20 50 | 6f 73 74 53 63 72 69 70 |te out P|ostScrip|
|00002c80| 74 20 48 65 61 64 65 72 | 20 2a 2f 0a 58 20 20 69 |t Header| */.X i|
|00002c90| 66 20 28 73 63 72 69 62 | 65 29 0a 58 20 20 7b 20 |f (scrib|e).X { |
|00002ca0| 70 72 69 6e 74 66 20 28 | 22 25 25 21 20 53 63 72 |printf (|"%%! Scr|
|00002cb0| 69 62 65 20 40 67 72 61 | 70 68 69 63 20 73 74 79 |ibe @gra|phic sty|
|00002cc0| 6c 65 20 50 6f 73 74 53 | 63 72 69 70 74 5c 6e 22 |le PostS|cript\n"|
|00002cd0| 29 3b 0a 58 20 20 20 20 | 69 66 20 28 74 69 74 6c |);.X |if (titl|
|00002ce0| 65 29 20 7b 20 70 72 69 | 6e 74 66 20 28 22 25 25 |e) { pri|ntf ("%%|
|00002cf0| 25 25 54 69 74 6c 65 3a | 20 25 73 5c 6e 22 2c 20 |%%Title:| %s\n", |
|00002d00| 70 73 5f 63 68 61 72 73 | 20 28 74 69 74 6c 65 29 |ps_chars| (title)|
|00002d10| 29 3b 20 7d 0a 58 20 20 | 20 20 69 66 20 28 63 72 |); }.X | if (cr|
|00002d20| 65 61 74 6f 72 29 20 7b | 20 70 72 69 6e 74 66 20 |eator) {| printf |
|00002d30| 28 22 25 25 25 25 43 72 | 65 61 74 6f 72 3a 20 20 |("%%%%Cr|eator: |
|00002d40| 25 73 5c 6e 22 2c 20 70 | 73 5f 63 68 61 72 73 20 |%s\n", p|s_chars |
|00002d50| 28 63 72 65 61 74 6f 72 | 29 29 3b 20 7d 0a 58 20 |(creator|)); }.X |
|00002d60| 20 20 20 70 72 69 6e 74 | 66 20 28 22 25 25 25 25 | print|f ("%%%%|
|00002d70| 43 72 65 61 74 69 6f 6e | 44 61 74 65 3a 20 25 73 |Creation|Date: %s|
|00002d80| 22 2c 20 63 74 69 6d 65 | 20 28 26 63 6c 6f 63 6b |", ctime| (&clock|
|00002d90| 29 29 3b 0a 58 0a 58 20 | 20 20 20 70 72 69 6e 74 |));.X.X | print|
|00002da0| 66 20 28 22 2f 69 6e 63 | 68 20 7b 20 37 32 20 6d |f ("/inc|h { 72 m|
|00002db0| 75 6c 20 7d 20 64 65 66 | 5c 6e 22 29 3b 0a 58 20 |ul } def|\n");.X |
|00002dc0| 20 20 20 70 72 69 6e 74 | 66 20 28 22 2f 70 69 63 | print|f ("/pic|
|00002dd0| 73 74 72 20 25 64 20 73 | 74 72 69 6e 67 20 64 65 |str %d s|tring de|
|00002de0| 66 5c 6e 5c 6e 22 2c 20 | 42 59 54 45 53 50 45 52 |f\n\n", |BYTESPER|
|00002df0| 4c 49 4e 45 29 3b 0a 58 | 20 20 7d 0a 58 20 20 65 |LINE);.X| }.X e|
|00002e00| 6c 73 65 0a 58 20 20 7b | 20 70 72 69 6e 74 66 20 |lse.X {| printf |
|00002e10| 28 22 25 25 21 5c 6e 22 | 29 3b 0a 58 20 20 20 20 |("%%!\n"|);.X |
|00002e20| 69 66 20 28 74 69 74 6c | 65 29 20 7b 20 70 72 69 |if (titl|e) { pri|
|00002e30| 6e 74 66 20 28 22 25 25 | 25 25 54 69 74 6c 65 3a |ntf ("%%|%%Title:|
|00002e40| 20 25 73 5c 6e 22 2c 20 | 70 73 5f 63 68 61 72 73 | %s\n", |ps_chars|
|00002e50| 20 28 74 69 74 6c 65 29 | 29 3b 20 7d 0a 58 20 20 | (title)|); }.X |
|00002e60| 20 20 69 66 20 28 63 72 | 65 61 74 6f 72 29 20 7b | if (cr|eator) {|
|00002e70| 20 70 72 69 6e 74 66 20 | 28 22 25 25 25 25 43 72 | printf |("%%%%Cr|
|00002e80| 65 61 74 6f 72 3a 20 20 | 25 73 5c 6e 22 2c 20 70 |eator: |%s\n", p|
|00002e90| 73 5f 63 68 61 72 73 20 | 28 63 72 65 61 74 6f 72 |s_chars |(creator|
|00002ea0| 29 29 3b 20 7d 0a 58 20 | 20 20 20 70 72 69 6e 74 |)); }.X | print|
|00002eb0| 66 20 28 22 25 25 25 25 | 43 72 65 61 74 69 6f 6e |f ("%%%%|Creation|
|00002ec0| 44 61 74 65 3a 20 25 73 | 22 2c 20 63 74 69 6d 65 |Date: %s|", ctime|
|00002ed0| 20 28 26 63 6c 6f 63 6b | 29 29 3b 0a 58 20 20 20 | (&clock|));.X |
|00002ee0| 20 70 72 69 6e 74 66 20 | 28 22 25 25 25 25 50 61 | printf |("%%%%Pa|
|00002ef0| 67 65 73 3a 20 31 5c 6e | 22 29 3b 0a 58 20 20 20 |ges: 1\n|");.X |
|00002f00| 20 70 72 69 6e 74 66 20 | 28 22 25 25 25 25 44 6f | printf |("%%%%Do|
|00002f10| 63 75 6d 65 6e 74 46 6f | 6e 74 73 3a 25 73 25 73 |cumentFo|nts:%s%s|
|00002f20| 5c 6e 22 2c 0a 58 09 20 | 20 20 20 64 6f 74 69 74 |\n",.X. | dotit|
|00002f30| 6c 65 20 3f 20 22 20 54 | 69 6d 65 73 2d 42 6f 6c |le ? " T|imes-Bol|
|00002f40| 64 22 20 3a 20 22 22 2c | 0a 58 09 20 20 20 20 64 |d" : "",|.X. d|
|00002f50| 6f 73 69 7a 65 20 3f 20 | 20 22 20 54 69 6d 65 73 |osize ? | " Times|
|00002f60| 2d 52 6f 6d 61 6e 22 20 | 3a 20 22 22 29 3b 0a 58 |-Roman" |: "");.X|
|00002f70| 20 20 20 20 70 72 69 6e | 74 66 20 28 22 25 25 25 | prin|tf ("%%%|
|00002f80| 25 45 6e 64 43 6f 6d 6d | 65 6e 74 73 5c 6e 22 29 |%EndComm|ents\n")|
|00002f90| 3b 0a 58 20 20 20 20 70 | 72 69 6e 74 66 20 28 22 |;.X p|rintf ("|
|00002fa0| 25 25 25 25 45 6e 64 50 | 72 6f 6c 6f 67 5c 6e 22 |%%%%EndP|rolog\n"|
|00002fb0| 29 3b 0a 58 20 20 20 20 | 70 72 69 6e 74 66 20 28 |);.X |printf (|
|00002fc0| 22 25 25 25 25 50 61 67 | 65 3a 20 31 20 31 5c 6e |"%%%%Pag|e: 1 1\n|
|00002fd0| 5c 6e 22 29 3b 0a 58 0a | 58 20 20 20 20 70 72 69 |\n");.X.|X pri|
|00002fe0| 6e 74 66 20 28 22 2f 69 | 6e 63 68 20 7b 20 37 32 |ntf ("/i|nch { 72|
|00002ff0| 20 6d 75 6c 20 7d 20 64 | 65 66 5c 6e 22 29 3b 0a | mul } d|ef\n");.|
|00003000| 58 20 20 20 20 70 72 69 | 6e 74 66 20 28 22 2f 70 |X pri|ntf ("/p|
|00003010| 69 63 73 74 72 20 25 64 | 20 73 74 72 69 6e 67 20 |icstr %d| string |
|00003020| 64 65 66 5c 6e 5c 6e 22 | 2c 20 42 59 54 45 53 50 |def\n\n"|, BYTESP|
|00003030| 45 52 4c 49 4e 45 29 3b | 0a 58 0a 58 20 20 20 20 |ERLINE);|.X.X |
|00003040| 69 66 20 28 64 6f 74 69 | 74 6c 65 20 26 26 20 74 |if (doti|tle && t|
|00003050| 69 74 6c 65 29 0a 58 20 | 20 20 20 7b 20 70 72 69 |itle).X | { pri|
|00003060| 6e 74 66 20 28 22 2f 54 | 69 6d 65 73 2d 42 6f 6c |ntf ("/T|imes-Bol|
|00003070| 64 20 66 69 6e 64 66 6f | 6e 74 20 31 34 20 73 63 |d findfo|nt 14 sc|
|00003080| 61 6c 65 66 6f 6e 74 20 | 73 65 74 66 6f 6e 74 5c |alefont |setfont\|
|00003090| 6e 22 29 3b 0a 58 20 20 | 20 20 20 20 70 72 69 6e |n");.X | prin|
|000030a0| 74 66 20 28 22 25 6c 67 | 20 69 6e 63 68 20 25 6c |tf ("%lg| inch %l|
|000030b0| 67 20 69 6e 63 68 20 6d | 6f 76 65 74 6f 5c 6e 22 |g inch m|oveto\n"|
|000030c0| 2c 20 0a 58 09 09 6c 6c | 78 20 2b 20 77 69 64 74 |, .X..ll|x + widt|
|000030d0| 68 2f 32 2e 30 2c 20 6c | 6c 79 20 2b 20 30 2e 31 |h/2.0, l|ly + 0.1|
|000030e0| 32 35 20 2b 20 68 65 69 | 67 68 74 29 3b 0a 58 20 |25 + hei|ght);.X |
|000030f0| 20 20 20 20 20 70 72 69 | 6e 74 66 20 28 22 28 25 | pri|ntf ("(%|
|00003100| 73 29 5c 6e 22 2c 20 70 | 73 5f 63 68 61 72 73 20 |s)\n", p|s_chars |
|00003110| 28 74 69 74 6c 65 29 29 | 3b 0a 58 20 20 20 20 20 |(title))|;.X |
|00003120| 20 70 72 69 6e 74 66 20 | 28 22 64 75 70 20 73 74 | printf |("dup st|
|00003130| 72 69 6e 67 77 69 64 74 | 68 20 70 6f 70 20 32 20 |ringwidt|h pop 2 |
|00003140| 64 69 76 20 30 20 65 78 | 63 68 20 73 75 62 20 30 |div 0 ex|ch sub 0|
|00003150| 20 72 6d 6f 76 65 74 6f | 20 73 68 6f 77 5c 6e 5c | rmoveto| show\n\|
|00003160| 6e 22 29 3b 0a 58 20 20 | 20 20 7d 0a 58 20 20 0a |n");.X | }.X .|
|00003170| 58 20 20 20 20 69 66 20 | 28 64 6f 73 69 7a 65 29 |X if |(dosize)|
|00003180| 0a 58 20 20 20 20 7b 20 | 70 72 69 6e 74 66 20 28 |.X { |printf (|
|00003190| 22 2f 54 69 6d 65 73 2d | 52 6f 6d 61 6e 20 66 69 |"/Times-|Roman fi|
|000031a0| 6e 64 66 6f 6e 74 20 38 | 20 73 63 61 6c 65 66 6f |ndfont 8| scalefo|
|000031b0| 6e 74 20 73 65 74 66 6f | 6e 74 5c 6e 22 29 3b 0a |nt setfo|nt\n");.|
|000031c0| 58 20 20 20 20 20 20 20 | 20 20 20 20 20 70 72 69 |X | pri|
|000031d0| 6e 74 66 20 28 22 25 6c | 67 20 69 6e 63 68 20 25 |ntf ("%l|g inch %|
|000031e0| 6c 67 20 69 6e 63 68 20 | 6d 6f 76 65 74 6f 5c 6e |lg inch |moveto\n|
|000031f0| 22 2c 20 6c 6c 78 20 2b | 20 77 69 64 74 68 2c 20 |", llx +| width, |
|00003200| 6c 6c 79 20 2d 20 30 2e | 32 35 29 3b 0a 58 20 20 |lly - 0.|25);.X |
|00003210| 20 20 20 20 73 70 72 69 | 6e 74 66 20 28 62 75 66 | spri|ntf (buf|
|00003220| 2c 20 22 5b 20 25 64 20 | 62 79 20 25 64 20 70 69 |, "[ %d |by %d pi|
|00003230| 78 65 6c 73 2c 20 25 31 | 2e 33 6c 66 20 25 73 2c |xels, %1|.3lf %s,|
|00003240| 20 25 31 2e 32 6c 66 20 | 62 79 20 25 31 2e 32 6c | %1.2lf |by %1.2l|
|00003250| 66 20 69 6e 63 68 65 73 | 20 5d 22 2c 0a 58 09 20 |f inches| ]",.X. |
|00003260| 20 20 20 20 20 20 69 6d | 61 67 65 2e 68 64 72 2e | im|age.hdr.|
|00003270| 63 6f 6c 73 2c 20 69 6d | 61 67 65 2e 68 64 72 2e |cols, im|age.hdr.|
|00003280| 72 6f 77 73 2c 20 69 6d | 61 67 65 2e 68 64 72 2e |rows, im|age.hdr.|
|00003290| 61 73 70 65 63 74 2c 0a | 58 09 20 20 20 20 20 20 |aspect,.|X. |
|000032a0| 20 22 61 73 70 65 63 74 | 20 72 61 74 69 6f 22 2c | "aspect| ratio",|
|000032b0| 20 77 69 64 74 68 2c 20 | 68 65 69 67 68 74 29 3b | width, |height);|
|000032c0| 0a 58 20 20 20 20 20 20 | 70 72 69 6e 74 66 20 28 |.X |printf (|
|000032d0| 22 28 25 73 29 5c 6e 22 | 2c 20 70 73 5f 63 68 61 |"(%s)\n"|, ps_cha|
|000032e0| 72 73 20 28 62 75 66 29 | 29 3b 0a 58 20 20 20 20 |rs (buf)|);.X |
|000032f0| 20 20 70 72 69 6e 74 66 | 20 28 22 64 75 70 20 73 | printf| ("dup s|
|00003300| 74 72 69 6e 67 77 69 64 | 74 68 20 70 6f 70 20 30 |tringwid|th pop 0|
|00003310| 20 65 78 63 68 20 73 75 | 62 20 30 20 72 6d 6f 76 | exch su|b 0 rmov|
|00003320| 65 74 6f 20 73 68 6f 77 | 5c 6e 5c 6e 22 29 3b 0a |eto show|\n\n");.|
|00003330| 58 20 20 20 20 7d 0a 58 | 0a 58 20 20 7d 0a 58 0a |X }.X|.X }.X.|
|00003340| 58 20 20 70 72 69 6e 74 | 66 20 28 22 67 73 61 76 |X print|f ("gsav|
|00003350| 65 5c 6e 22 29 3b 0a 58 | 0a 58 20 20 69 66 20 28 |e\n");.X|.X if (|
|00003360| 6c 6c 78 20 21 3d 20 30 | 2e 30 20 7c 7c 20 6c 6c |llx != 0|.0 || ll|
|00003370| 79 20 21 3d 20 30 2e 30 | 29 0a 58 20 20 7b 20 70 |y != 0.0|).X { p|
|00003380| 72 69 6e 74 66 20 28 22 | 25 6c 67 20 69 6e 63 68 |rintf ("|%lg inch|
|00003390| 20 25 6c 67 20 69 6e 63 | 68 20 74 72 61 6e 73 6c | %lg inc|h transl|
|000033a0| 61 74 65 20 22 2c 20 6c | 6c 78 2c 20 6c 6c 79 29 |ate ", l|lx, lly)|
|000033b0| 3b 20 7d 0a 58 20 20 0a | 58 20 20 70 72 69 6e 74 |; }.X .|X print|
|000033c0| 66 20 28 22 25 6c 67 20 | 69 6e 63 68 20 25 6c 67 |f ("%lg |inch %lg|
|000033d0| 20 69 6e 63 68 20 73 63 | 61 6c 65 5c 6e 22 2c 20 | inch sc|ale\n", |
|000033e0| 77 69 64 74 68 2c 20 68 | 65 69 67 68 74 29 3b 0a |width, h|eight);.|
|000033f0| 58 0a 58 20 20 69 66 20 | 28 69 6d 61 67 65 2e 68 |X.X if |(image.h|
|00003400| 64 72 2e 70 6c 61 6e 65 | 73 20 3d 3d 20 33 29 20 |dr.plane|s == 3) |
|00003410| 7b 0a 58 09 69 6e 74 20 | 70 6c 61 6e 65 3b 0a 58 |{.X.int |plane;.X|
|00003420| 09 69 6e 74 20 70 6c 6e | 6c 65 6e 20 3d 20 69 6d |.int pln|len = im|
|00003430| 61 67 65 2e 68 64 72 2e | 70 6c 6e 6c 65 6e 3b 0a |age.hdr.|plnlen;.|
|00003440| 58 09 69 6e 74 20 62 69 | 74 73 20 3d 20 69 6d 61 |X.int bi|ts = ima|
|00003450| 67 65 2e 68 64 72 2e 62 | 69 74 73 3b 0a 58 0a 58 |ge.hdr.b|its;.X.X|
|00003460| 09 2f 2a 20 75 73 65 20 | 51 4d 53 20 63 6f 6c 6f |./* use |QMS colo|
|00003470| 72 69 6d 61 67 65 20 6f | 70 65 72 61 74 6f 72 20 |rimage o|perator |
|00003480| 2a 2f 0a 58 0a 58 09 70 | 72 69 6e 74 66 20 28 22 |*/.X.X.p|rintf ("|
|00003490| 2f 72 65 64 53 63 61 6e | 4c 69 6e 65 20 25 64 20 |/redScan|Line %d |
|000034a0| 73 74 72 69 6e 67 20 64 | 65 66 5c 6e 22 2c 20 63 |string d|ef\n", c|
|000034b0| 6f 6c 73 20 2a 20 38 20 | 2f 20 62 69 74 73 29 3b |ols * 8 |/ bits);|
|000034c0| 0a 58 09 70 72 69 6e 74 | 66 20 28 22 2f 67 72 65 |.X.print|f ("/gre|
|000034d0| 65 6e 53 63 61 6e 4c 69 | 6e 65 20 25 64 20 73 74 |enScanLi|ne %d st|
|000034e0| 72 69 6e 67 20 64 65 66 | 5c 6e 22 2c 20 63 6f 6c |ring def|\n", col|
|000034f0| 73 20 2a 20 38 20 2f 20 | 62 69 74 73 29 3b 0a 58 |s * 8 / |bits);.X|
|00003500| 09 70 72 69 6e 74 66 20 | 28 22 2f 62 6c 75 65 53 |.printf |("/blueS|
|00003510| 63 61 6e 4c 69 6e 65 20 | 25 64 20 73 74 72 69 6e |canLine |%d strin|
|00003520| 67 20 64 65 66 5c 6e 22 | 2c 20 63 6f 6c 73 20 2a |g def\n"|, cols *|
|00003530| 20 38 20 2f 20 62 69 74 | 73 29 3b 0a 58 0a 58 09 | 8 / bit|s);.X.X.|
|00003540| 70 72 69 6e 74 66 20 28 | 22 25 64 20 25 64 20 25 |printf (|"%d %d %|
|00003550| 64 20 5b 25 64 20 30 20 | 30 20 25 64 20 30 20 25 |d [%d 0 |0 %d 0 %|
|00003560| 64 5d 5c 6e 22 2c 0a 58 | 09 09 63 6f 6c 73 2c 20 |d]\n",.X|..cols, |
|00003570| 72 6f 77 73 2c 20 62 69 | 74 73 2c 20 63 6f 6c 73 |rows, bi|ts, cols|
|00003580| 2c 20 2d 72 6f 77 73 2c | 20 72 6f 77 73 29 3b 0a |, -rows,| rows);.|
|00003590| 58 09 70 75 74 73 20 28 | 22 7b 63 75 72 72 65 6e |X.puts (|"{curren|
|000035a0| 74 66 69 6c 65 20 72 65 | 64 53 63 61 6e 4c 69 6e |tfile re|dScanLin|
|000035b0| 65 20 72 65 61 64 68 65 | 78 73 74 72 69 6e 67 20 |e readhe|xstring |
|000035c0| 70 6f 70 7d 22 29 3b 0a | 58 09 70 75 74 73 20 28 |pop}");.|X.puts (|
|000035d0| 22 7b 63 75 72 72 65 6e | 74 66 69 6c 65 20 67 72 |"{curren|tfile gr|
|000035e0| 65 65 6e 53 63 61 6e 4c | 69 6e 65 20 72 65 61 64 |eenScanL|ine read|
|000035f0| 68 65 78 73 74 72 69 6e | 67 20 70 6f 70 7d 22 29 |hexstrin|g pop}")|
|00003600| 3b 0a 58 09 70 75 74 73 | 20 28 22 7b 63 75 72 72 |;.X.puts| ("{curr|
|00003610| 65 6e 74 66 69 6c 65 20 | 62 6c 75 65 53 63 61 6e |entfile |blueScan|
|00003620| 4c 69 6e 65 20 72 65 61 | 64 68 65 78 73 74 72 69 |Line rea|dhexstri|
|00003630| 6e 67 20 70 6f 70 7d 22 | 29 3b 0a 58 09 70 75 74 |ng pop}"|);.X.put|
|00003640| 73 20 28 22 74 72 75 65 | 20 33 20 63 6f 6c 6f 72 |s ("true| 3 color|
|00003650| 69 6d 61 67 65 22 29 3b | 0a 58 0a 58 09 66 6f 72 |image");|.X.X.for|
|00003660| 20 28 6a 20 3d 20 30 3b | 20 6a 20 3c 20 72 6f 77 | (j = 0;| j < row|
|00003670| 73 3b 20 6a 2b 2b 29 20 | 7b 0a 58 09 20 20 20 20 |s; j++) |{.X. |
|00003680| 66 6f 72 20 28 70 6c 61 | 6e 65 20 3d 20 30 3b 20 |for (pla|ne = 0; |
|00003690| 70 6c 61 6e 65 20 3c 20 | 33 3b 20 70 6c 61 6e 65 |plane < |3; plane|
|000036a0| 2b 2b 29 20 7b 0a 58 09 | 09 66 6f 72 20 28 69 20 |++) {.X.|.for (i |
|000036b0| 3d 20 30 3b 20 69 20 3c | 20 63 6f 6c 73 3b 20 69 |= 0; i <| cols; i|
|000036c0| 2b 2b 29 20 7b 0a 58 09 | 09 20 20 20 20 70 72 69 |++) {.X.|. pri|
|000036d0| 6e 74 66 20 28 22 25 30 | 32 78 22 2c 20 69 6d 61 |ntf ("%0|2x", ima|
|000036e0| 67 65 2e 62 6d 5b 70 6c | 61 6e 65 20 2a 20 70 6c |ge.bm[pl|ane * pl|
|000036f0| 6e 6c 65 6e 20 2b 20 6a | 20 2a 20 72 6f 77 6c 65 |nlen + j| * rowle|
|00003700| 6e 20 2b 20 69 5d 29 3b | 0a 58 09 09 20 20 20 20 |n + i]);|.X.. |
|00003710| 69 66 20 28 2b 2b 62 79 | 74 63 6e 74 20 25 20 42 |if (++by|tcnt % B|
|00003720| 59 54 45 53 50 45 52 4c | 49 4e 45 20 3d 3d 20 30 |YTESPERL|INE == 0|
|00003730| 29 0a 58 09 09 09 70 75 | 74 63 68 61 72 20 28 27 |).X...pu|tchar ('|
|00003740| 5c 6e 27 29 3b 0a 58 09 | 09 7d 0a 58 09 09 62 79 |\n');.X.|.}.X..by|
|00003750| 74 63 6e 74 20 3d 20 30 | 3b 0a 58 09 09 70 75 74 |tcnt = 0|;.X..put|
|00003760| 63 68 61 72 20 28 27 5c | 6e 27 29 3b 0a 58 09 20 |char ('\|n');.X. |
|00003770| 20 20 20 7d 0a 58 09 7d | 0a 58 20 20 7d 0a 58 20 | }.X.}|.X }.X |
|00003780| 20 65 6c 73 65 20 7b 0a | 58 20 20 20 20 70 72 69 | else {.|X pri|
|00003790| 6e 74 66 20 28 22 25 64 | 20 25 64 20 38 20 5b 25 |ntf ("%d| %d 8 [%|
|000037a0| 64 20 30 20 30 20 2d 25 | 64 20 30 20 25 64 5d 20 |d 0 0 -%|d 0 %d] |
|000037b0| 22 2c 20 63 6f 6c 73 2c | 20 72 6f 77 73 2c 20 63 |", cols,| rows, c|
|000037c0| 6f 6c 73 2c 20 72 6f 77 | 73 2c 20 72 6f 77 73 29 |ols, row|s, rows)|
|000037d0| 3b 0a 58 20 20 20 20 70 | 72 69 6e 74 66 20 28 22 |;.X p|rintf ("|
|000037e0| 7b 20 63 75 72 72 65 6e | 74 66 69 6c 65 20 70 69 |{ curren|tfile pi|
|000037f0| 63 73 74 72 20 72 65 61 | 64 68 65 78 73 74 72 69 |cstr rea|dhexstri|
|00003800| 6e 67 20 70 6f 70 20 7d | 5c 6e 22 29 3b 0a 58 20 |ng pop }|\n");.X |
|00003810| 20 20 20 70 72 69 6e 74 | 66 20 28 22 69 6d 61 67 | print|f ("imag|
|00003820| 65 5c 6e 22 29 3b 0a 58 | 20 20 0a 58 20 20 20 20 |e\n");.X| .X |
|00003830| 2f 2a 20 57 72 69 74 65 | 20 6f 75 74 20 62 69 74 |/* Write| out bit|
|00003840| 6d 61 70 20 2a 2f 0a 58 | 20 20 20 20 66 6f 72 20 |map */.X| for |
|00003850| 28 6a 3d 30 3b 20 6a 20 | 3c 20 72 6f 77 73 3b 20 |(j=0; j |< rows; |
|00003860| 6a 2b 2b 29 20 20 0a 58 | 20 20 20 20 7b 20 66 6f |j++) .X| { fo|
|00003870| 72 20 28 69 3d 30 3b 20 | 69 20 3c 20 63 6f 6c 73 |r (i=0; |i < cols|
|00003880| 3b 20 69 2b 2b 29 0a 58 | 20 20 20 20 20 20 7b 20 |; i++).X| { |
|00003890| 70 72 69 6e 74 66 20 28 | 22 25 30 32 78 22 2c 20 |printf (|"%02x", |
|000038a0| 69 6d 61 67 65 2e 62 6d | 5b 6a 20 2a 20 72 6f 77 |image.bm|[j * row|
|000038b0| 6c 65 6e 20 2b 20 69 5d | 29 3b 0a 58 0a 58 20 20 |len + i]|);.X.X |
|000038c0| 20 20 20 20 20 20 69 66 | 20 28 2b 2b 62 79 74 63 | if| (++bytc|
|000038d0| 6e 74 20 25 20 42 59 54 | 45 53 50 45 52 4c 49 4e |nt % BYT|ESPERLIN|
|000038e0| 45 20 3d 3d 20 30 29 20 | 70 75 74 63 68 61 72 20 |E == 0) |putchar |
|000038f0| 28 27 5c 6e 27 29 3b 0a | 58 20 20 20 20 20 20 7d |('\n');.|X }|
|00003900| 0a 58 20 20 7d 0a 58 0a | 58 20 20 7d 0a 58 0a 58 |.X }.X.|X }.X.X|
|00003910| 20 20 2f 2a 20 50 61 64 | 20 73 6f 20 74 68 65 72 | /* Pad| so ther|
|00003920| 65 20 61 72 65 20 65 78 | 61 63 74 6c 79 20 42 59 |e are ex|actly BY|
|00003930| 54 45 53 50 45 52 4c 49 | 4e 45 20 62 79 74 65 73 |TESPERLI|NE bytes|
|00003940| 20 69 6e 20 65 61 63 68 | 20 6c 69 6e 65 20 2a 2f | in each| line */|
|00003950| 0a 58 20 20 69 66 20 28 | 62 79 74 63 6e 74 20 25 |.X if (|bytcnt %|
|00003960| 20 42 59 54 45 53 50 45 | 52 4c 49 4e 45 29 0a 58 | BYTESPE|RLINE).X|
|00003970| 20 20 7b 20 77 68 69 6c | 65 20 28 62 79 74 63 6e | { whil|e (bytcn|
|00003980| 74 2b 2b 20 25 20 42 59 | 54 45 53 50 45 52 4c 49 |t++ % BY|TESPERLI|
|00003990| 4e 45 29 20 70 72 69 6e | 74 66 20 28 22 30 30 22 |NE) prin|tf ("00"|
|000039a0| 29 3b 0a 58 20 20 20 20 | 70 72 69 6e 74 66 20 28 |);.X |printf (|
|000039b0| 22 5c 6e 22 29 3b 0a 58 | 20 20 7d 0a 58 20 20 0a |"\n");.X| }.X .|
|000039c0| 58 20 20 70 72 69 6e 74 | 66 20 28 22 67 72 65 73 |X print|f ("gres|
|000039d0| 74 6f 72 65 5c 6e 22 29 | 3b 0a 58 0a 58 20 20 69 |tore\n")|;.X.X i|
|000039e0| 66 20 28 21 73 63 72 69 | 62 65 29 0a 58 20 20 7b |f (!scri|be).X {|
|000039f0| 20 70 72 69 6e 74 66 20 | 28 22 5c 6e 73 68 6f 77 | printf |("\nshow|
|00003a00| 70 61 67 65 5c 6e 5c 6e | 22 29 3b 0a 58 20 20 20 |page\n\n|");.X |
|00003a10| 20 70 72 69 6e 74 66 20 | 28 22 25 25 25 25 54 72 | printf |("%%%%Tr|
|00003a20| 61 69 6c 65 72 5c 6e 22 | 29 3b 0a 58 20 20 7d 0a |ailer\n"|);.X }.|
|00003a30| 58 0a 58 20 20 65 78 69 | 74 20 28 30 29 3b 0a 58 |X.X exi|t (0);.X|
|00003a40| 7d 0a 58 0a 58 2f 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |}.X.X/**|********|
|00003a50| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00003a60| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00003a70| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00003a80| 2a 2a 2a 2a 2a 2a 0a 58 | 20 2a 20 70 73 5f 63 68 |******.X| * ps_ch|
|00003a90| 61 72 73 3a 20 50 75 74 | 20 69 6e 20 70 72 6f 70 |ars: Put| in prop|
|00003aa0| 65 72 20 65 73 63 61 70 | 65 73 20 73 6f 20 61 6e |er escap|es so an|
|00003ab0| 20 61 72 62 69 74 72 61 | 72 79 20 73 74 72 69 6e | arbitra|ry strin|
|00003ac0| 67 20 77 6f 72 6b 73 0a | 58 20 2a 09 20 20 20 20 |g works.|X *. |
|00003ad0| 20 61 63 63 6f 72 64 69 | 6e 67 20 74 6f 20 74 68 | accordi|ng to th|
|00003ae0| 65 20 50 6f 73 74 53 63 | 72 69 70 74 20 64 65 66 |e PostSc|ript def|
|00003af0| 69 6e 69 74 69 6f 6e 20 | 6f 66 20 61 20 6c 69 74 |inition |of a lit|
|00003b00| 65 72 61 6c 0a 58 20 2a | 2a 2a 2a 2a 2a 2a 2a 2a |eral.X *|********|
|00003b10| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00003b20| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00003b30| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00003b40| 2a 2a 2a 2a 2a 2a 2a 2f | 0a 58 0a 58 63 68 61 72 |*******/|.X.Xchar|
|00003b50| 20 2a 70 73 5f 63 68 61 | 72 73 20 28 74 78 74 29 | *ps_cha|rs (txt)|
|00003b60| 0a 58 63 68 61 72 20 2a | 74 78 74 3b 0a 58 7b 20 |.Xchar *|txt;.X{ |
|00003b70| 73 74 61 74 69 63 20 63 | 68 61 72 20 62 75 66 5b |static c|har buf[|
|00003b80| 35 31 32 5d 3b 0a 58 20 | 20 72 65 67 69 73 74 65 |512];.X | registe|
|00003b90| 72 20 63 68 61 72 20 2a | 73 20 3d 20 62 75 66 3b |r char *|s = buf;|
|00003ba0| 0a 58 20 20 63 68 61 72 | 20 2a 69 6e 64 65 78 20 |.X char| *index |
|00003bb0| 28 29 3b 0a 58 20 20 0a | 58 20 20 66 6f 72 20 28 |();.X .|X for (|
|00003bc0| 3b 20 2a 74 78 74 3b 20 | 74 78 74 2b 2b 29 0a 58 |; *txt; |txt++).X|
|00003bd0| 20 20 7b 20 69 66 20 28 | 69 6e 64 65 78 20 28 22 | { if (|index ("|
|00003be0| 28 29 5c 5c 22 2c 20 2a | 74 78 74 29 29 0a 58 20 |()\\", *|txt)).X |
|00003bf0| 20 20 20 7b 20 2a 73 2b | 2b 20 3d 20 27 5c 5c 27 | { *s+|+ = '\\'|
|00003c00| 3b 20 2a 73 2b 2b 20 3d | 20 2a 74 78 74 3b 20 7d |; *s++ =| *txt; }|
|00003c10| 0a 58 20 20 20 20 65 6c | 73 65 20 69 66 20 28 2a |.X el|se if (*|
|00003c20| 74 78 74 20 3c 20 27 20 | 27 20 7c 7c 20 2a 74 78 |txt < ' |' || *tx|
|00003c30| 74 20 3e 20 27 7e 27 29 | 0a 58 20 20 20 20 7b 20 |t > '~')|.X { |
|00003c40| 73 70 72 69 6e 74 66 20 | 28 73 2c 20 22 5c 5c 25 |sprintf |(s, "\\%|
|00003c50| 30 33 6f 22 2c 20 2a 74 | 78 74 20 26 20 30 33 37 |03o", *t|xt & 037|
|00003c60| 37 29 3b 20 73 20 2b 3d | 20 34 3b 20 7d 0a 58 20 |7); s +=| 4; }.X |
|00003c70| 20 20 20 65 6c 73 65 0a | 58 20 20 20 20 7b 20 2a | else.|X { *|
|00003c80| 73 2b 2b 20 3d 20 2a 74 | 78 74 3b 20 7d 0a 58 20 |s++ = *t|xt; }.X |
|00003c90| 20 7d 0a 58 20 20 2a 73 | 20 3d 20 27 5c 30 27 3b | }.X *s| = '\0';|
|00003ca0| 0a 58 20 20 73 20 3d 20 | 62 75 66 3b 0a 58 20 20 |.X s = |buf;.X |
|00003cb0| 72 65 74 75 72 6e 20 28 | 73 29 3b 0a 58 7d 0a 45 |return (|s);.X}.E|
|00003cc0| 4e 44 5f 4f 46 5f 46 49 | 4c 45 0a 69 66 20 74 65 |ND_OF_FI|LE.if te|
|00003cd0| 73 74 20 37 33 39 39 20 | 2d 6e 65 20 60 77 63 20 |st 7399 |-ne `wc |
|00003ce0| 2d 63 20 3c 27 66 62 70 | 73 2e 63 27 60 3b 20 74 |-c <'fbp|s.c'`; t|
|00003cf0| 68 65 6e 0a 20 20 20 20 | 65 63 68 6f 20 73 68 61 |hen. |echo sha|
|00003d00| 72 3a 20 5c 22 27 66 62 | 70 73 2e 63 27 5c 22 20 |r: \"'fb|ps.c'\" |
|00003d10| 75 6e 70 61 63 6b 65 64 | 20 77 69 74 68 20 77 72 |unpacked| with wr|
|00003d20| 6f 6e 67 20 73 69 7a 65 | 21 0a 66 69 0a 23 20 65 |ong size|!.fi.# e|
|00003d30| 6e 64 20 6f 66 20 27 66 | 62 70 73 2e 63 27 0a 66 |nd of 'f|bps.c'.f|
|00003d40| 69 0a 69 66 20 74 65 73 | 74 20 2d 66 20 27 66 6c |i.if tes|t -f 'fl|
|00003d50| 63 6c 72 2e 63 27 20 2d | 61 20 22 24 7b 31 7d 22 |clr.c' -|a "${1}"|
|00003d60| 20 21 3d 20 22 2d 63 22 | 20 3b 20 74 68 65 6e 20 | != "-c"| ; then |
|00003d70| 0a 20 20 65 63 68 6f 20 | 73 68 61 72 3a 20 57 69 |. echo |shar: Wi|
|00003d80| 6c 6c 20 6e 6f 74 20 63 | 6c 6f 62 62 65 72 20 65 |ll not c|lobber e|
|00003d90| 78 69 73 74 69 6e 67 20 | 66 69 6c 65 20 5c 22 27 |xisting |file \"'|
|00003da0| 66 6c 63 6c 72 2e 63 27 | 5c 22 0a 65 6c 73 65 0a |flclr.c'|\".else.|
|00003db0| 65 63 68 6f 20 73 68 61 | 72 3a 20 45 78 74 72 61 |echo sha|r: Extra|
|00003dc0| 63 74 69 6e 67 20 5c 22 | 27 66 6c 63 6c 72 2e 63 |cting \"|'flclr.c|
|00003dd0| 27 5c 22 20 5c 28 37 35 | 37 30 20 63 68 61 72 61 |'\" \(75|70 chara|
|00003de0| 63 74 65 72 73 5c 29 0a | 73 65 64 20 22 73 2f 5e |cters\).|sed "s/^|
|00003df0| 58 2f 2f 22 20 3e 27 66 | 6c 63 6c 72 2e 63 27 20 |X//" >'f|lclr.c' |
|00003e00| 3c 3c 27 45 4e 44 5f 4f | 46 5f 46 49 4c 45 27 0a |<<'END_O|F_FILE'.|
|00003e10| 58 2f 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |X/******|********|
|00003e20| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00003e30| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00003e40| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00003e50| 2a 2a 2a 0a 58 20 2a 20 | 66 6c 63 6c 72 2e 63 3a |***.X * |flclr.c:|
|00003e60| 20 46 42 4d 20 4c 69 62 | 72 61 72 79 20 30 2e 39 | FBM Lib|rary 0.9|
|00003e70| 20 28 42 65 74 61 20 74 | 65 73 74 29 20 30 37 2d | (Beta t|est) 07-|
|00003e80| 4d 61 72 2d 38 39 20 20 | 4d 69 63 68 61 65 6c 20 |Mar-89 |Michael |
|00003e90| 4d 61 75 6c 64 69 6e 0a | 58 20 2a 0a 58 20 2a 20 |Mauldin.|X *.X * |
|00003ea0| 43 6f 70 79 72 69 67 68 | 74 20 28 43 29 20 31 39 |Copyrigh|t (C) 19|
|00003eb0| 38 39 20 62 79 20 4d 69 | 63 68 61 65 6c 20 4d 61 |89 by Mi|chael Ma|
|00003ec0| 75 6c 64 69 6e 2e 20 20 | 50 65 72 6d 69 73 73 69 |uldin. |Permissi|
|00003ed0| 6f 6e 20 69 73 20 67 72 | 61 6e 74 65 64 20 74 6f |on is gr|anted to|
|00003ee0| 0a 58 20 2a 20 75 73 65 | 20 74 68 69 73 20 66 69 |.X * use| this fi|
|00003ef0| 6c 65 20 69 6e 20 77 68 | 6f 6c 65 20 6f 72 20 69 |le in wh|ole or i|
|00003f00| 6e 20 70 61 72 74 20 70 | 72 6f 76 69 64 65 64 20 |n part p|rovided |
|00003f10| 74 68 61 74 20 79 6f 75 | 20 64 6f 20 6e 6f 74 20 |that you| do not |
|00003f20| 73 65 6c 6c 20 69 74 0a | 58 20 2a 20 66 6f 72 20 |sell it.|X * for |
|00003f30| 70 72 6f 66 69 74 20 61 | 6e 64 20 74 68 61 74 20 |profit a|nd that |
|00003f40| 74 68 69 73 20 63 6f 70 | 79 72 69 67 68 74 20 6e |this cop|yright n|
|00003f50| 6f 74 69 63 65 20 69 73 | 20 72 65 74 61 69 6e 65 |otice is| retaine|
|00003f60| 64 20 75 6e 63 68 61 6e | 67 65 64 2e 0a 58 20 2a |d unchan|ged..X *|
|00003f70| 0a 58 20 2a 20 66 6c 63 | 6c 72 2e 63 3a 20 43 6f |.X * flc|lr.c: Co|
|00003f80| 6c 6f 72 20 3c 2d 2d 3e | 20 42 57 2c 20 28 4d 61 |lor <-->| BW, (Ma|
|00003f90| 70 70 65 64 20 43 6f 6c | 6f 72 20 7c 20 42 57 29 |pped Col|or | BW)|
|00003fa0| 20 2d 2d 3e 20 75 6e 6d | 61 70 70 65 64 20 63 6f | --> unm|apped co|
|00003fb0| 6c 6f 72 0a 58 20 2a 0a | 58 20 2a 20 43 4f 4e 54 |lor.X *.|X * CONT|
|00003fc0| 45 4e 54 53 0a 58 20 2a | 09 63 6c 72 32 67 72 61 |ENTS.X *|.clr2gra|
|00003fd0| 79 20 28 69 6e 70 75 74 | 2c 20 6f 75 74 70 75 74 |y (input|, output|
|00003fe0| 2c 20 72 77 2c 20 67 77 | 2c 20 62 77 29 0a 58 20 |, rw, gw|, bw).X |
|00003ff0| 2a 09 67 72 61 79 32 63 | 6c 72 20 28 69 6e 70 75 |*.gray2c|lr (inpu|
|00004000| 74 2c 20 6f 75 74 70 75 | 74 2c 20 73 75 6e 29 0a |t, outpu|t, sun).|
|00004010| 58 20 2a 0a 58 20 2a 20 | 45 44 49 54 4c 4f 47 0a |X *.X * |EDITLOG.|
|00004020| 58 20 2a 09 4c 61 73 74 | 45 64 69 74 44 61 74 65 |X *.Last|EditDate|
|00004030| 20 3d 20 54 68 75 20 41 | 70 72 20 32 30 20 31 36 | = Thu A|pr 20 16|
|00004040| 3a 35 35 3a 32 33 20 31 | 39 38 39 20 2d 20 4d 69 |:55:23 1|989 - Mi|
|00004050| 63 68 61 65 6c 20 4d 61 | 75 6c 64 69 6e 0a 58 20 |chael Ma|uldin.X |
|00004060| 2a 09 4c 61 73 74 46 69 | 6c 65 4e 61 6d 65 20 3d |*.LastFi|leName =|
|00004070| 20 2f 75 73 72 32 2f 6d | 6c 6d 2f 73 72 63 2f 6d | /usr2/m|lm/src/m|
|00004080| 69 73 63 2f 66 62 6d 2f | 66 6c 63 6c 72 2e 63 0a |isc/fbm/|flclr.c.|
|00004090| 58 20 2a 0a 58 20 2a 20 | 48 49 53 54 4f 52 59 0a |X *.X * |HISTORY.|
|000040a0| 58 20 2a 20 30 37 2d 4d | 61 72 2d 38 39 20 20 4d |X * 07-M|ar-89 M|
|000040b0| 69 63 68 61 65 6c 20 4d | 61 75 6c 64 69 6e 20 28 |ichael M|auldin (|
|000040c0| 6d 6c 6d 29 20 61 74 20 | 43 61 72 6e 65 67 69 65 |mlm) at |Carnegie|
|000040d0| 20 4d 65 6c 6c 6f 6e 20 | 55 6e 69 76 65 72 73 69 | Mellon |Universi|
|000040e0| 74 79 0a 58 20 2a 09 42 | 65 74 61 20 72 65 6c 65 |ty.X *.B|eta rele|
|000040f0| 61 73 65 20 28 76 65 72 | 73 69 6f 6e 20 30 2e 39 |ase (ver|sion 0.9|
|00004100| 29 20 6d 6c 6d 40 63 73 | 2e 63 6d 75 2e 65 64 75 |) mlm@cs|.cmu.edu|
|00004110| 0a 58 20 2a 0a 58 20 2a | 20 32 38 2d 4e 6f 76 2d |.X *.X *| 28-Nov-|
|00004120| 38 38 20 20 4d 69 63 68 | 61 65 6c 20 4d 61 75 6c |88 Mich|ael Maul|
|00004130| 64 69 6e 20 28 6d 6c 6d | 29 20 61 74 20 43 61 72 |din (mlm|) at Car|
|00004140| 6e 65 67 69 65 2d 4d 65 | 6c 6c 6f 6e 20 55 6e 69 |negie-Me|llon Uni|
|00004150| 76 65 72 73 69 74 79 0a | 58 20 2a 09 43 72 65 61 |versity.|X *.Crea|
|00004160| 74 65 64 2e 0a 58 20 2a | 2a 2a 2a 2a 2a 2a 2a 2a |ted..X *|********|
|00004170| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00004180| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00004190| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000041a0| 2a 2a 2a 2a 2a 2a 2a 2a | 2f 0a 58 0a 58 23 20 69 |********|/.X.X# i|
|000041b0| 6e 63 6c 75 64 65 20 3c | 73 74 64 69 6f 2e 68 3e |nclude <|stdio.h>|
|000041c0| 0a 58 23 20 69 6e 63 6c | 75 64 65 20 22 66 62 6d |.X# incl|ude "fbm|
|000041d0| 2e 68 22 0a 58 0a 58 2f | 2a 2a 2a 2a 2a 2a 2a 2a |.h".X.X/|********|
|000041e0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000041f0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00004200| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00004210| 2a 2a 2a 2a 2a 2a 2a 2a | 0a 58 20 2a 20 63 6c 72 |********|.X * clr|
|00004220| 32 67 72 61 79 3a 20 41 | 70 70 6c 79 20 61 20 74 |2gray: A|pply a t|
|00004230| 72 69 70 6c 65 74 20 6f | 66 20 77 65 69 67 68 74 |riplet o|f weight|
|00004240| 73 20 74 6f 20 65 61 63 | 68 20 63 6f 6c 6f 72 20 |s to eac|h color |
|00004250| 69 6e 20 61 6e 64 20 52 | 47 42 0a 58 20 2a 09 20 |in and R|GB.X *. |
|00004260| 20 20 20 20 6f 72 20 6d | 61 70 70 65 64 20 69 6d | or m|apped im|
|00004270| 61 67 65 20 61 6e 64 20 | 70 72 6f 64 75 63 65 20 |age and |produce |
|00004280| 61 6e 20 38 62 69 74 20 | 67 72 61 79 73 63 61 6c |an 8bit |grayscal|
|00004290| 65 20 69 6d 61 67 65 0a | 58 20 2a 2a 2a 2a 2a 2a |e image.|X ******|
|000042a0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000042b0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000042c0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000042d0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2f 0a 58 0a 58 23 |********|**/.X.X#|
|000042e0| 69 66 6e 64 65 66 20 6c | 69 6e 74 0a 58 73 74 61 |ifndef l|int.Xsta|
|000042f0| 74 69 63 20 63 68 61 72 | 20 2a 66 62 6d 69 64 20 |tic char| *fbmid |
|00004300| 3d 0a 58 09 22 24 46 42 | 4d 20 66 6c 63 6c 72 2e |=.X."$FB|M flclr.|
|00004310| 63 20 3c 30 2e 39 3e 20 | 30 37 2d 4d 61 72 2d 38 |c <0.9> |07-Mar-8|
|00004320| 39 20 20 28 43 29 20 31 | 39 38 39 20 62 79 20 4d |9 (C) 1|989 by M|
|00004330| 69 63 68 61 65 6c 20 4d | 61 75 6c 64 69 6e 24 22 |ichael M|auldin$"|
|00004340| 3b 0a 58 23 65 6e 64 69 | 66 0a 58 0a 58 63 6c 72 |;.X#endi|f.X.Xclr|
|00004350| 32 67 72 61 79 20 28 69 | 6e 70 75 74 2c 20 6f 75 |2gray (i|nput, ou|
|00004360| 74 70 75 74 2c 20 72 77 | 2c 20 67 77 2c 20 62 77 |tput, rw|, gw, bw|
|00004370| 29 0a 58 46 42 4d 20 2a | 69 6e 70 75 74 2c 20 2a |).XFBM *|input, *|
|00004380| 6f 75 74 70 75 74 3b 0a | 58 69 6e 74 20 72 77 2c |output;.|Xint rw,|
|00004390| 20 67 77 2c 20 62 77 3b | 0a 58 7b 20 69 6e 74 20 | gw, bw;|.X{ int |
|000043a0| 72 77 31 2c 20 67 77 31 | 2c 20 62 77 31 2c 20 77 |rw1, gw1|, bw1, w|
|000043b0| 69 64 74 68 2c 20 68 65 | 69 67 68 74 2c 20 63 6c |idth, he|ight, cl|
|000043c0| 72 6c 65 6e 2c 20 72 6f | 77 6c 65 6e 2c 20 63 6f |rlen, ro|wlen, co|
|000043d0| 6c 6f 72 73 3b 0a 58 20 | 20 72 65 67 69 73 74 65 |lors;.X | registe|
|000043e0| 72 20 69 6e 74 20 69 2c | 20 6a 3b 0a 58 20 20 72 |r int i,| j;.X r|
|000043f0| 65 67 69 73 74 65 72 20 | 75 6e 73 69 67 6e 65 64 |egister |unsigned|
|00004400| 20 63 68 61 72 20 2a 62 | 6d 70 2c 20 2a 6f 62 6d | char *b|mp, *obm|
|00004410| 3b 0a 58 0a 58 20 20 2f | 2a 20 41 6c 72 65 61 64 |;.X.X /|* Alread|
|00004420| 79 20 6d 6f 6e 6f 63 68 | 72 6f 6d 65 3f 20 2a 2f |y monoch|rome? */|
|00004430| 0a 58 20 20 69 66 20 28 | 69 6e 70 75 74 2d 3e 68 |.X if (|input->h|
|00004440| 64 72 2e 70 6c 61 6e 65 | 73 20 3d 3d 20 31 20 26 |dr.plane|s == 1 &|
|00004450| 26 20 69 6e 70 75 74 2d | 3e 68 64 72 2e 63 6c 72 |& input-|>hdr.clr|
|00004460| 6c 65 6e 20 3d 3d 20 30 | 29 0a 58 20 20 7b 20 2a |len == 0|).X { *|
|00004470| 6f 75 74 70 75 74 20 3d | 20 2a 69 6e 70 75 74 3b |output =| *input;|
|00004480| 20 72 65 74 75 72 6e 20 | 28 31 29 3b 20 7d 0a 58 | return |(1); }.X|
|00004490| 20 20 0a 58 20 20 2f 2a | 20 49 6e 76 61 6c 69 64 | .X /*| Invalid|
|000044a0| 20 72 61 73 74 65 72 20 | 74 79 70 65 20 2a 2f 0a | raster |type */.|
|000044b0| 58 20 20 69 66 20 28 69 | 6e 70 75 74 2d 3e 68 64 |X if (i|nput->hd|
|000044c0| 72 2e 70 6c 61 6e 65 73 | 20 21 3d 20 33 20 26 26 |r.planes| != 3 &&|
|000044d0| 20 69 6e 70 75 74 2d 3e | 68 64 72 2e 63 6c 72 6c | input->|hdr.clrl|
|000044e0| 65 6e 20 3d 3d 20 30 29 | 0a 58 20 20 7b 20 66 70 |en == 0)|.X { fp|
|000044f0| 72 69 6e 74 66 20 28 73 | 74 64 65 72 72 2c 0a 58 |rintf (s|tderr,.X|
|00004500| 09 20 22 63 6c 72 32 67 | 72 61 79 20 77 61 73 20 |. "clr2g|ray was |
|00004510| 70 61 73 73 65 64 20 69 | 6e 76 61 6c 69 64 20 72 |passed i|nvalid r|
|00004520| 61 73 74 65 72 20 74 79 | 70 65 2c 20 63 6c 72 6c |aster ty|pe, clrl|
|00004530| 65 6e 20 25 64 2c 20 70 | 6c 61 6e 65 73 20 25 64 |en %d, p|lanes %d|
|00004540| 5c 6e 22 2c 0a 58 09 20 | 69 6e 70 75 74 2d 3e 68 |\n",.X. |input->h|
|00004550| 64 72 2e 63 6c 72 6c 65 | 6e 2c 20 69 6e 70 75 74 |dr.clrle|n, input|
|00004560| 2d 3e 68 64 72 2e 70 6c | 61 6e 65 73 29 3b 0a 58 |->hdr.pl|anes);.X|
|00004570| 20 20 20 20 72 65 74 75 | 72 6e 20 28 30 29 3b 0a | retu|rn (0);.|
|00004580| 58 20 20 7d 0a 58 20 20 | 0a 58 20 20 2f 2a 20 41 |X }.X |.X /* A|
|00004590| 64 6a 75 73 74 20 77 65 | 69 67 68 74 73 20 66 6f |djust we|ights fo|
|000045a0| 72 20 66 61 73 74 20 64 | 69 76 69 73 69 6f 6e 20 |r fast d|ivision |
|000045b0| 76 69 61 20 73 68 69 66 | 74 20 2a 2f 0a 58 20 20 |via shif|t */.X |
|000045c0| 72 77 31 20 3d 20 72 77 | 20 2a 20 32 35 36 20 2f |rw1 = rw| * 256 /|
|000045d0| 20 28 72 77 20 2b 20 67 | 77 20 2b 20 62 77 29 3b | (rw + g|w + bw);|
|000045e0| 0a 58 20 20 67 77 31 20 | 3d 20 67 77 20 2a 20 32 |.X gw1 |= gw * 2|
|000045f0| 35 36 20 2f 20 28 72 77 | 20 2b 20 67 77 20 2b 20 |56 / (rw| + gw + |
|00004600| 62 77 29 3b 0a 58 20 20 | 62 77 31 20 3d 20 32 35 |bw);.X |bw1 = 25|
|00004610| 36 20 2d 20 28 72 77 31 | 2b 67 77 31 29 3b 0a 58 |6 - (rw1|+gw1);.X|
|00004620| 20 20 0a 58 20 20 66 70 | 72 69 6e 74 66 20 28 73 | .X fp|rintf (s|
|00004630| 74 64 65 72 72 2c 20 22 | 55 73 69 6e 67 20 77 65 |tderr, "|Using we|
|00004640| 69 67 68 74 73 20 5b 25 | 32 64 20 25 32 64 20 25 |ights [%|2d %2d %|
|00004650| 32 64 5d 20 3d 3d 3e 20 | 3c 25 33 64 2c 20 25 33 |2d] ==> |<%3d, %3|
|00004660| 64 2c 20 25 33 64 3e 5c | 6e 22 2c 0a 58 09 20 20 |d, %3d>\|n",.X. |
|00004670| 20 72 77 2c 20 67 77 2c | 20 62 77 2c 20 72 77 31 | rw, gw,| bw, rw1|
|00004680| 2c 20 67 77 31 2c 20 62 | 77 31 29 3b 0a 58 0a 58 |, gw1, b|w1);.X.X|
|00004690| 20 20 2f 2a 20 41 6c 6c | 6f 63 61 74 65 20 6f 75 | /* All|ocate ou|
|000046a0| 74 70 75 74 20 62 69 74 | 6d 61 70 20 2a 2f 0a 58 |tput bit|map */.X|
|000046b0| 20 20 6f 75 74 70 75 74 | 2d 3e 68 64 72 20 3d 20 | output|->hdr = |
|000046c0| 69 6e 70 75 74 2d 3e 68 | 64 72 3b 0a 58 20 20 6f |input->h|dr;.X o|
|000046d0| 75 74 70 75 74 2d 3e 68 | 64 72 2e 63 6c 72 6c 65 |utput->h|dr.clrle|
|000046e0| 6e 20 3d 20 30 3b 0a 58 | 20 20 6f 75 74 70 75 74 |n = 0;.X| output|
|000046f0| 2d 3e 68 64 72 2e 70 6c | 61 6e 65 73 20 3d 20 31 |->hdr.pl|anes = 1|
|00004700| 3b 0a 58 20 20 6f 75 74 | 70 75 74 2d 3e 68 64 72 |;.X out|put->hdr|
|00004710| 2e 62 69 74 73 20 3d 20 | 6f 75 74 70 75 74 2d 3e |.bits = |output->|
|00004720| 68 64 72 2e 70 68 79 73 | 62 69 74 73 20 3d 20 38 |hdr.phys|bits = 8|
|00004730| 3b 0a 58 20 20 61 6c 6c | 6f 63 5f 66 62 6d 20 28 |;.X all|oc_fbm (|
|00004740| 6f 75 74 70 75 74 29 3b | 0a 58 20 20 0a 58 20 20 |output);|.X .X |
|00004750| 2f 2a 20 53 65 74 20 63 | 6f 6d 6d 6f 6e 6c 79 20 |/* Set c|ommonly |
|00004760| 75 73 65 64 20 76 61 72 | 73 20 2a 2f 0a 58 20 20 |used var|s */.X |
|00004770| 77 69 64 74 68 20 3d 20 | 69 6e 70 75 74 2d 3e 68 |width = |input->h|
|00004780| 64 72 2e 63 6f 6c 73 3b | 0a 58 20 20 68 65 69 67 |dr.cols;|.X heig|
|00004790| 68 74 20 3d 20 69 6e 70 | 75 74 2d 3e 68 64 72 2e |ht = inp|ut->hdr.|
|000047a0| 72 6f 77 73 3b 0a 58 20 | 20 72 6f 77 6c 65 6e 20 |rows;.X | rowlen |
|000047b0| 3d 20 69 6e 70 75 74 2d | 3e 68 64 72 2e 72 6f 77 |= input-|>hdr.row|
|000047c0| 6c 65 6e 3b 0a 58 20 20 | 63 6c 72 6c 65 6e 20 3d |len;.X |clrlen =|
|000047d0| 20 69 6e 70 75 74 2d 3e | 68 64 72 2e 63 6c 72 6c | input->|hdr.clrl|
|000047e0| 65 6e 3b 0a 58 20 20 63 | 6f 6c 6f 72 73 20 3d 20 |en;.X c|olors = |
|000047f0| 63 6c 72 6c 65 6e 20 2f | 20 33 3b 0a 58 0a 58 20 |clrlen /| 3;.X.X |
|00004800| 20 2f 2a 20 4d 61 70 70 | 65 64 20 63 6f 6c 6f 72 | /* Mapp|ed color|
|00004810| 20 74 6f 20 67 72 61 79 | 20 73 63 61 6c 65 20 2a | to gray| scale *|
|00004820| 2f 0a 58 20 20 69 66 20 | 28 69 6e 70 75 74 2d 3e |/.X if |(input->|
|00004830| 68 64 72 2e 63 6c 72 6c | 65 6e 20 3e 20 30 29 0a |hdr.clrl|en > 0).|
|00004840| 58 20 20 7b 20 72 65 67 | 69 73 74 65 72 20 69 6e |X { reg|ister in|
|00004850| 74 20 2a 67 72 61 79 3b | 0a 58 20 20 0a 58 20 20 |t *gray;|.X .X |
|00004860| 20 20 67 72 61 79 20 3d | 20 28 69 6e 74 20 2a 29 | gray =| (int *)|
|00004870| 20 6d 61 6c 6c 6f 63 20 | 28 28 75 6e 73 69 67 6e | malloc |((unsign|
|00004880| 65 64 29 20 69 6e 70 75 | 74 2d 3e 68 64 72 2e 63 |ed) inpu|t->hdr.c|
|00004890| 6c 72 6c 65 6e 20 2a 20 | 73 69 7a 65 6f 66 20 28 |lrlen * |sizeof (|
|000048a0| 69 6e 74 29 29 3b 0a 58 | 20 20 20 20 0a 58 20 20 |int));.X| .X |
|000048b0| 20 20 66 6f 72 20 28 69 | 3d 30 3b 20 69 3c 63 6f | for (i|=0; i<co|
|000048c0| 6c 6f 72 73 3b 20 69 2b | 2b 29 0a 58 20 20 20 20 |lors; i+|+).X |
|000048d0| 7b 20 67 72 61 79 5b 69 | 5d 20 3d 20 28 72 77 31 |{ gray[i|] = (rw1|
|000048e0| 20 2a 20 69 6e 70 75 74 | 2d 3e 63 6d 5b 69 5d 20 | * input|->cm[i] |
|000048f0| 2b 20 0a 58 09 09 20 67 | 77 31 20 2a 20 69 6e 70 |+ .X.. g|w1 * inp|
|00004900| 75 74 2d 3e 63 6d 5b 69 | 2b 63 6f 6c 6f 72 73 5d |ut->cm[i|+colors]|
|00004910| 20 2b 20 0a 58 09 09 20 | 62 77 31 20 2a 20 69 6e | + .X.. |bw1 * in|
|00004920| 70 75 74 2d 3e 63 6d 5b | 69 2b 28 63 6f 6c 6f 72 |put->cm[|i+(color|
|00004930| 73 3c 3c 31 29 5d 29 20 | 3e 3e 20 38 3b 0a 58 0a |s<<1)]) |>> 8;.X.|
|00004940| 58 23 20 69 66 64 65 66 | 20 44 45 42 55 47 0a 58 |X# ifdef| DEBUG.X|
|00004950| 20 20 20 20 20 20 66 70 | 72 69 6e 74 66 20 28 73 | fp|rintf (s|
|00004960| 74 64 65 72 72 2c 20 22 | 63 6f 6c 6f 72 20 25 33 |tderr, "|color %3|
|00004970| 64 3a 20 20 5b 25 33 64 | 20 25 33 64 20 25 33 64 |d: [%3d| %3d %3d|
|00004980| 5d 20 3d 3e 20 25 33 64 | 5c 6e 22 2c 0a 58 09 09 |] => %3d|\n",.X..|
|00004990| 69 2c 0a 58 09 09 69 6e | 70 75 74 2d 3e 63 6d 5b |i,.X..in|put->cm[|
|000049a0| 69 5d 2c 0a 58 09 09 69 | 6e 70 75 74 2d 3e 63 6d |i],.X..i|nput->cm|
|000049b0| 5b 69 2b 63 6f 6c 6f 72 | 73 5d 2c 0a 58 09 09 69 |[i+color|s],.X..i|
|000049c0| 6e 70 75 74 2d 3e 63 6d | 5b 69 2b 63 6f 6c 6f 72 |nput->cm|[i+color|
|000049d0| 73 2a 32 5d 2c 0a 58 09 | 09 67 72 61 79 5b 69 5d |s*2],.X.|.gray[i]|
|000049e0| 29 3b 0a 58 23 20 65 6e | 64 69 66 0a 58 0a 58 20 |);.X# en|dif.X.X |
|000049f0| 20 20 20 7d 0a 58 20 20 | 20 20 0a 58 20 20 20 20 | }.X | .X |
|00004a00| 66 6f 72 20 28 6a 3d 30 | 3b 20 6a 3c 68 65 69 67 |for (j=0|; j<heig|
|00004a10| 68 74 3b 20 6a 2b 2b 29 | 0a 58 20 20 20 20 7b 20 |ht; j++)|.X { |
|00004a20| 62 6d 70 20 3d 20 26 28 | 69 6e 70 75 74 2d 3e 62 |bmp = &(|input->b|
|00004a30| 6d 5b 6a 2a 72 6f 77 6c | 65 6e 5d 29 3b 0a 58 20 |m[j*rowl|en]);.X |
|00004a40| 20 20 20 20 20 6f 62 6d | 20 3d 20 26 28 6f 75 74 | obm| = &(out|
|00004a50| 70 75 74 2d 3e 62 6d 5b | 6a 2a 72 6f 77 6c 65 6e |put->bm[|j*rowlen|
|00004a60| 5d 29 3b 0a 58 20 20 20 | 20 20 20 0a 58 20 20 20 |]);.X | .X |
|00004a70| 20 20 20 66 6f 72 20 28 | 69 3d 30 3b 20 69 3c 77 | for (|i=0; i<w|
|00004a80| 69 64 74 68 3b 20 69 2b | 2b 29 0a 58 20 20 20 20 |idth; i+|+).X |
|00004a90| 20 20 7b 20 2a 6f 62 6d | 2b 2b 20 3d 20 67 72 61 | { *obm|++ = gra|
|00004aa0| 79 5b 2a 62 6d 70 2b 2b | 5d 3b 20 7d 0a 58 20 20 |y[*bmp++|]; }.X |
|00004ab0| 20 20 7d 0a 58 20 20 7d | 0a 58 09 09 20 0a 58 0a | }.X }|.X.. .X.|
|00004ac0| 58 20 20 2f 2a 20 52 47 | 42 20 63 6f 6c 6f 72 20 |X /* RG|B color |
|00004ad0| 74 6f 20 67 72 61 79 20 | 73 63 61 6c 65 20 2a 2f |to gray |scale */|
|00004ae0| 0a 58 20 20 65 6c 73 65 | 20 69 66 20 28 69 6e 70 |.X else| if (inp|
|00004af0| 75 74 2d 3e 68 64 72 2e | 70 6c 61 6e 65 73 20 3d |ut->hdr.|planes =|
|00004b00| 3d 20 33 20 26 26 20 69 | 6e 70 75 74 2d 3e 68 64 |= 3 && i|nput->hd|
|00004b10| 72 2e 70 68 79 73 62 69 | 74 73 20 3d 3d 20 38 29 |r.physbi|ts == 8)|
|00004b20| 0a 58 20 20 7b 20 72 65 | 67 69 73 74 65 72 20 75 |.X { re|gister u|
|00004b30| 6e 73 69 67 6e 65 64 20 | 63 68 61 72 20 2a 72 70 |nsigned |char *rp|
|00004b40| 2c 20 2a 67 70 2c 20 2a | 62 70 3b 0a 58 0a 58 20 |, *gp, *|bp;.X.X |
|00004b50| 20 20 20 66 6f 72 20 28 | 6a 3d 30 3b 20 6a 3c 68 | for (|j=0; j<h|
|00004b60| 65 69 67 68 74 3b 20 6a | 2b 2b 29 0a 58 20 20 20 |eight; j|++).X |
|00004b70| 20 7b 20 72 70 20 3d 20 | 26 28 69 6e 70 75 74 2d | { rp = |&(input-|
|00004b80| 3e 62 6d 5b 6a 2a 72 6f | 77 6c 65 6e 5d 29 3b 0a |>bm[j*ro|wlen]);.|
|00004b90| 58 20 20 20 20 20 20 67 | 70 20 3d 20 72 70 20 2b |X g|p = rp +|
|00004ba0| 20 69 6e 70 75 74 2d 3e | 68 64 72 2e 70 6c 6e 6c | input->|hdr.plnl|
|00004bb0| 65 6e 3b 0a 58 20 20 20 | 20 20 20 62 70 20 3d 20 |en;.X | bp = |
|00004bc0| 67 70 20 2b 20 69 6e 70 | 75 74 2d 3e 68 64 72 2e |gp + inp|ut->hdr.|
|00004bd0| 70 6c 6e 6c 65 6e 3b 0a | 58 20 20 20 20 20 20 6f |plnlen;.|X o|
|00004be0| 62 6d 20 3d 20 28 26 6f | 75 74 70 75 74 2d 3e 62 |bm = (&o|utput->b|
|00004bf0| 6d 5b 6a 2a 72 6f 77 6c | 65 6e 5d 29 3b 0a 58 0a |m[j*rowl|en]);.X.|
|00004c00| 58 20 20 20 20 20 20 66 | 6f 72 20 28 69 3d 30 3b |X f|or (i=0;|
|00004c10| 20 69 3c 77 69 64 74 68 | 3b 20 69 2b 2b 29 0a 58 | i<width|; i++).X|
|00004c20| 20 20 20 20 20 20 7b 20 | 2a 6f 62 6d 2b 2b 20 3d | { |*obm++ =|
|00004c30| 20 28 72 77 31 20 2a 20 | 2a 72 70 2b 2b 20 2b 20 | (rw1 * |*rp++ + |
|00004c40| 0a 58 09 09 20 20 67 77 | 31 20 2a 20 2a 67 70 2b |.X.. gw|1 * *gp+|
|00004c50| 2b 20 2b 20 0a 58 09 09 | 20 20 62 77 31 20 2a 20 |+ + .X..| bw1 * |
|00004c60| 2a 62 70 2b 2b 29 20 3e | 3e 20 38 3b 0a 58 20 20 |*bp++) >|> 8;.X |
|00004c70| 20 20 20 20 7d 0a 58 20 | 20 20 20 7d 0a 58 20 20 | }.X | }.X |
|00004c80| 7d 0a 58 20 20 0a 58 20 | 20 72 65 74 75 72 6e 20 |}.X .X | return |
|00004c90| 28 31 29 3b 0a 58 7d 0a | 58 0a 58 2f 2a 2a 2a 2a |(1);.X}.|X.X/****|
|00004ca0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00004cb0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00004cc0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00004cd0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 0a 58 20 2a |********|****.X *|
|00004ce0| 20 67 72 61 79 32 63 6c | 72 3a 20 41 64 64 20 61 | gray2cl|r: Add a|
|00004cf0| 20 63 6f 6c 6f 72 6d 61 | 70 20 28 73 68 61 64 65 | colorma|p (shade|
|00004d00| 73 20 6f 66 20 67 72 61 | 79 29 20 74 6f 20 61 20 |s of gra|y) to a |
|00004d10| 67 72 61 79 73 63 61 6c | 65 20 66 69 6c 65 0a 58 |grayscal|e file.X|
|00004d20| 20 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a | *******|********|
|00004d30| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00004d40| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00004d50| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00004d60| 2a 2f 0a 58 0a 58 67 72 | 61 79 32 63 6c 72 20 28 |*/.X.Xgr|ay2clr (|
|00004d70| 69 6e 70 75 74 2c 20 6f | 75 74 70 75 74 2c 20 73 |input, o|utput, s|
|00004d80| 75 6e 5f 6d 61 70 29 0a | 58 46 42 4d 20 2a 69 6e |un_map).|XFBM *in|
|00004d90| 70 75 74 2c 20 2a 6f 75 | 74 70 75 74 3b 0a 58 69 |put, *ou|tput;.Xi|
|00004da0| 6e 74 20 73 75 6e 5f 6d | 61 70 3b 0a 58 7b 20 72 |nt sun_m|ap;.X{ r|
|00004db0| 65 67 69 73 74 65 72 20 | 75 6e 73 69 67 6e 65 64 |egister |unsigned|
|00004dc0| 20 63 68 61 72 20 2a 72 | 6d 61 70 2c 20 2a 67 6d | char *r|map, *gm|
|00004dd0| 61 70 2c 20 2a 62 6d 61 | 70 2c 20 2a 62 6d 70 2c |ap, *bma|p, *bmp,|
|00004de0| 20 2a 6f 62 6d 3b 0a 58 | 20 20 72 65 67 69 73 74 | *obm;.X| regist|
|00004df0| 65 72 20 69 6e 74 20 69 | 2c 20 6d 61 70 6c 65 6e |er int i|, maplen|
|00004e00| 2c 20 70 6c 6e 6c 65 6e | 3b 0a 58 0a 58 20 20 2f |, plnlen|;.X.X /|
|00004e10| 2a 20 49 6e 76 61 6c 69 | 64 20 72 61 73 74 65 72 |* Invali|d raster|
|00004e20| 20 74 79 70 65 20 2a 2f | 0a 58 20 20 69 66 20 28 | type */|.X if (|
|00004e30| 69 6e 70 75 74 2d 3e 68 | 64 72 2e 70 6c 61 6e 65 |input->h|dr.plane|
|00004e40| 73 20 3d 3d 20 33 29 0a | 58 20 20 7b 20 66 70 72 |s == 3).|X { fpr|
|00004e50| 69 6e 74 66 20 28 73 74 | 64 65 72 72 2c 20 22 49 |intf (st|derr, "I|
|00004e60| 6e 70 75 74 20 61 6c 72 | 65 61 64 79 20 69 73 20 |nput alr|eady is |
|00004e70| 69 6e 20 52 47 42 20 66 | 6f 72 6d 61 74 5c 6e 22 |in RGB f|ormat\n"|
|00004e80| 29 3b 0a 58 20 20 20 20 | 2a 6f 75 74 70 75 74 20 |);.X |*output |
|00004e90| 3d 20 2a 69 6e 70 75 74 | 3b 20 72 65 74 75 72 6e |= *input|; return|
|00004ea0| 20 28 31 29 3b 0a 58 20 | 20 7d 0a 58 20 20 20 20 | (1);.X | }.X |
|00004eb0| 0a 58 20 20 2f 2a 20 49 | 6e 76 61 6c 69 64 20 72 |.X /* I|nvalid r|
|00004ec0| 61 73 74 65 72 20 74 79 | 70 65 20 2a 2f 0a 58 20 |aster ty|pe */.X |
|00004ed0| 20 69 66 20 28 69 6e 70 | 75 74 2d 3e 68 64 72 2e | if (inp|ut->hdr.|
|00004ee0| 63 6c 72 6c 65 6e 20 3e | 20 30 20 29 0a 58 20 20 |clrlen >| 0 ).X |
|00004ef0| 7b 20 66 70 72 69 6e 74 | 66 20 28 73 74 64 65 72 |{ fprint|f (stder|
|00004f00| 72 2c 20 22 49 6e 70 75 | 74 20 61 6c 72 65 61 64 |r, "Inpu|t alread|
|00004f10| 79 20 68 61 73 20 63 6f | 6c 6f 72 20 6d 61 70 20 |y has co|lor map |
|00004f20| 77 69 74 68 20 25 64 20 | 63 6f 6c 6f 72 73 5c 6e |with %d |colors\n|
|00004f30| 22 2c 0a 58 09 20 20 20 | 20 20 69 6e 70 75 74 2d |",.X. | input-|
|00004f40| 3e 68 64 72 2e 63 6c 72 | 6c 65 6e 20 2f 20 33 29 |>hdr.clr|len / 3)|
|00004f50| 3b 0a 58 20 20 20 20 2a | 6f 75 74 70 75 74 20 3d |;.X *|output =|
|00004f60| 20 2a 69 6e 70 75 74 3b | 20 72 65 74 75 72 6e 20 | *input;| return |
|00004f70| 28 31 29 3b 0a 58 20 20 | 7d 0a 58 0a 58 20 20 2f |(1);.X |}.X.X /|
|00004f80| 2a 20 49 6e 76 61 6c 69 | 64 20 72 61 73 74 65 72 |* Invali|d raster|
|00004f90| 20 74 79 70 65 20 2a 2f | 0a 58 20 20 69 66 20 28 | type */|.X if (|
|00004fa0| 69 6e 70 75 74 2d 3e 68 | 64 72 2e 70 6c 61 6e 65 |input->h|dr.plane|
|00004fb0| 73 20 21 3d 20 31 20 7c | 7c 20 69 6e 70 75 74 2d |s != 1 ||| input-|
|00004fc0| 3e 68 64 72 2e 63 6c 72 | 6c 65 6e 20 21 3d 20 30 |>hdr.clr|len != 0|
|00004fd0| 29 0a 58 20 20 7b 20 66 | 70 72 69 6e 74 66 20 28 |).X { f|printf (|
|00004fe0| 73 74 64 65 72 72 2c 0a | 58 09 20 22 67 72 61 79 |stderr,.|X. "gray|
|00004ff0| 32 63 6c 72 20 77 61 73 | 20 70 61 73 73 65 64 20 |2clr was| passed |
|00005000| 69 6e 76 61 6c 69 64 20 | 72 61 73 74 65 72 20 74 |invalid |raster t|
|00005010| 79 70 65 2c 20 63 6c 72 | 6c 65 6e 20 25 64 2c 20 |ype, clr|len %d, |
|00005020| 70 6c 61 6e 65 73 20 25 | 64 5c 6e 22 2c 0a 58 09 |planes %|d\n",.X.|
|00005030| 20 69 6e 70 75 74 2d 3e | 68 64 72 2e 63 6c 72 6c | input->|hdr.clrl|
|00005040| 65 6e 2c 20 69 6e 70 75 | 74 2d 3e 68 64 72 2e 70 |en, inpu|t->hdr.p|
|00005050| 6c 61 6e 65 73 29 3b 0a | 58 20 20 20 20 72 65 74 |lanes);.|X ret|
|00005060| 75 72 6e 20 28 30 29 3b | 0a 58 20 20 7d 0a 58 20 |urn (0);|.X }.X |
|00005070| 20 0a 58 20 20 70 6c 6e | 6c 65 6e 20 3d 20 69 6e | .X pln|len = in|
|00005080| 70 75 74 2d 3e 68 64 72 | 2e 70 6c 6e 6c 65 6e 3b |put->hdr|.plnlen;|
|00005090| 0a 58 20 20 0a 58 20 20 | 2f 2a 20 4d 61 6b 65 20 |.X .X |/* Make |
|000050a0| 63 6f 6c 6f 72 6d 61 70 | 20 6c 65 6e 67 74 68 20 |colormap| length |
|000050b0| 70 6f 77 65 72 20 6f 66 | 20 74 77 6f 20 2a 2f 0a |power of| two */.|
|000050c0| 58 20 20 6d 61 70 6c 65 | 6e 20 3d 20 31 20 3c 3c |X maple|n = 1 <<|
|000050d0| 20 69 6e 70 75 74 2d 3e | 68 64 72 2e 62 69 74 73 | input->|hdr.bits|
|000050e0| 3b 0a 58 0a 58 20 20 2f | 2a 20 41 6c 6c 6f 63 61 |;.X.X /|* Alloca|
|000050f0| 74 65 20 6f 75 74 70 75 | 74 20 62 69 74 6d 61 70 |te outpu|t bitmap|
|00005100| 20 2a 2f 0a 58 20 20 6f | 75 74 70 75 74 2d 3e 68 | */.X o|utput->h|
|00005110| 64 72 20 3d 20 69 6e 70 | 75 74 2d 3e 68 64 72 3b |dr = inp|ut->hdr;|
|00005120| 0a 58 20 20 6f 75 74 70 | 75 74 2d 3e 68 64 72 2e |.X outp|ut->hdr.|
|00005130| 63 6c 72 6c 65 6e 20 3d | 20 6d 61 70 6c 65 6e 20 |clrlen =| maplen |
|00005140| 2a 20 33 3b 0a 58 20 20 | 61 6c 6c 6f 63 5f 66 62 |* 3;.X |alloc_fb|
|00005150| 6d 20 28 6f 75 74 70 75 | 74 29 3b 0a 58 20 20 0a |m (outpu|t);.X .|
|00005160| 58 20 20 72 6d 61 70 20 | 3d 20 26 28 6f 75 74 70 |X rmap |= &(outp|
|00005170| 75 74 2d 3e 63 6d 5b 30 | 5d 29 3b 0a 58 20 20 67 |ut->cm[0|]);.X g|
|00005180| 6d 61 70 20 3d 20 26 28 | 6f 75 74 70 75 74 2d 3e |map = &(|output->|
|00005190| 63 6d 5b 6d 61 70 6c 65 | 6e 5d 29 3b 0a 58 20 20 |cm[maple|n]);.X |
|000051a0| 62 6d 61 70 20 3d 20 26 | 28 6f 75 74 70 75 74 2d |bmap = &|(output-|
|000051b0| 3e 63 6d 5b 32 2a 6d 61 | 70 6c 65 6e 5d 29 3b 0a |>cm[2*ma|plen]);.|
|000051c0| 58 0a 58 20 20 66 6f 72 | 20 28 69 3d 30 3b 20 69 |X.X for| (i=0; i|
|000051d0| 3c 6d 61 70 6c 65 6e 3b | 20 69 2b 2b 29 0a 58 20 |<maplen;| i++).X |
|000051e0| 20 7b 20 2a 72 6d 61 70 | 2b 2b 20 3d 20 2a 67 6d | { *rmap|++ = *gm|
|000051f0| 61 70 2b 2b 20 3d 20 2a | 62 6d 61 70 2b 2b 20 3d |ap++ = *|bmap++ =|
|00005200| 20 69 3b 20 7d 0a 58 0a | 58 20 20 2f 2a 20 46 6f | i; }.X.|X /* Fo|
|00005210| 72 20 73 75 6e 5f 6d 61 | 70 2c 20 73 77 61 70 20 |r sun_ma|p, swap |
|00005220| 63 6f 6c 6f 72 73 20 30 | 20 61 6e 64 20 32 35 35 |colors 0| and 255|
|00005230| 20 2a 2f 0a 58 20 20 69 | 66 20 28 73 75 6e 5f 6d | */.X i|f (sun_m|
|00005240| 61 70 20 26 26 20 28 6d | 61 70 6c 65 6e 20 3d 3d |ap && (m|aplen ==|
|00005250| 20 32 35 36 29 29 0a 58 | 20 20 7b 20 72 6d 61 70 | 256)).X| { rmap|
|00005260| 20 3d 20 26 28 6f 75 74 | 70 75 74 2d 3e 63 6d 5b | = &(out|put->cm[|
|00005270| 30 5d 29 3b 0a 58 20 20 | 20 20 67 6d 61 70 20 3d |0]);.X | gmap =|
|00005280| 20 26 28 6f 75 74 70 75 | 74 2d 3e 63 6d 5b 6d 61 | &(outpu|t->cm[ma|
|00005290| 70 6c 65 6e 5d 29 3b 0a | 58 20 20 20 20 62 6d 61 |plen]);.|X bma|
|000052a0| 70 20 3d 20 26 28 6f 75 | 74 70 75 74 2d 3e 63 6d |p = &(ou|tput->cm|
|000052b0| 5b 32 2a 6d 61 70 6c 65 | 6e 5d 29 3b 0a 58 0a 58 |[2*maple|n]);.X.X|
|000052c0| 20 20 20 20 72 6d 61 70 | 5b 30 5d 20 3d 20 67 6d | rmap|[0] = gm|
|000052d0| 61 70 5b 30 5d 20 3d 20 | 62 6d 61 70 5b 30 5d 20 |ap[0] = |bmap[0] |
|000052e0| 3d 20 32 35 35 3b 0a 58 | 20 20 20 20 72 6d 61 70 |= 255;.X| rmap|
|000052f0| 5b 32 35 35 5d 20 3d 20 | 67 6d 61 70 5b 32 35 35 |[255] = |gmap[255|
|00005300| 5d 20 3d 20 62 6d 61 70 | 5b 32 35 35 5d 20 3d 20 |] = bmap|[255] = |
|00005310| 30 3b 0a 58 0a 58 20 20 | 20 20 2f 2a 20 43 6f 70 |0;.X.X | /* Cop|
|00005320| 79 20 62 69 74 73 20 2a | 2f 0a 58 20 20 20 20 66 |y bits *|/.X f|
|00005330| 6f 72 20 28 62 6d 70 20 | 3d 20 69 6e 70 75 74 2d |or (bmp |= input-|
|00005340| 3e 62 6d 2c 20 6f 62 6d | 20 3d 20 6f 75 74 70 75 |>bm, obm| = outpu|
|00005350| 74 2d 3e 20 62 6d 2c 20 | 69 3d 30 3b 20 69 3c 70 |t-> bm, |i=0; i<p|
|00005360| 6c 6e 6c 65 6e 3b 20 69 | 2b 2b 2c 20 62 6d 70 2b |lnlen; i|++, bmp+|
|00005370| 2b 29 0a 58 20 20 20 20 | 7b 20 69 66 20 28 2a 62 |+).X |{ if (*b|
|00005380| 6d 70 20 3d 3d 20 30 29 | 09 09 2a 6f 62 6d 2b 2b |mp == 0)|..*obm++|
|00005390| 20 3d 20 32 35 35 3b 0a | 58 20 20 20 20 20 20 65 | = 255;.|X e|
|000053a0| 6c 73 65 20 69 66 20 28 | 2a 62 6d 70 20 3d 3d 20 |lse if (|*bmp == |
|000053b0| 32 35 35 29 09 2a 6f 62 | 6d 2b 2b 20 3d 20 30 3b |255).*ob|m++ = 0;|
|000053c0| 0a 58 20 20 20 20 20 20 | 65 6c 73 65 09 09 09 2a |.X |else...*|
|000053d0| 6f 62 6d 2b 2b 20 3d 20 | 2a 62 6d 70 3b 0a 58 20 |obm++ = |*bmp;.X |
|000053e0| 20 20 20 7d 0a 58 20 20 | 7d 0a 58 0a 58 20 20 65 | }.X |}.X.X e|
|000053f0| 6c 73 65 20 20 0a 58 20 | 20 7b 0a 58 20 20 20 20 |lse .X | {.X |
|00005400| 2f 2a 20 43 6f 70 79 20 | 62 69 74 73 20 2a 2f 0a |/* Copy |bits */.|
|00005410| 58 20 20 20 20 66 6f 72 | 20 28 62 6d 70 20 3d 20 |X for| (bmp = |
|00005420| 69 6e 70 75 74 2d 3e 62 | 6d 2c 20 6f 62 6d 20 3d |input->b|m, obm =|
|00005430| 20 6f 75 74 70 75 74 2d | 3e 20 62 6d 2c 20 69 3d | output-|> bm, i=|
|00005440| 30 3b 20 69 3c 70 6c 6e | 6c 65 6e 3b 20 69 2b 2b |0; i<pln|len; i++|
|00005450| 29 0a 58 20 20 20 20 7b | 20 2a 6f 62 6d 2b 2b 20 |).X {| *obm++ |
|00005460| 3d 20 2a 62 6d 70 2b 2b | 3b 20 7d 0a 58 20 20 7d |= *bmp++|; }.X }|
|00005470| 0a 58 0a 58 20 20 72 65 | 74 75 72 6e 20 28 31 29 |.X.X re|turn (1)|
|00005480| 3b 0a 58 7d 0a 58 0a 58 | 2f 2a 2a 2a 2a 2a 2a 2a |;.X}.X.X|/*******|
|00005490| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000054a0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000054b0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000054c0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 0a 58 20 2a 20 63 6c |********|*.X * cl|
|000054d0| 72 5f 75 6e 6d 61 70 3a | 20 43 6f 6e 76 65 72 74 |r_unmap:| Convert|
|000054e0| 20 61 20 6d 61 70 70 65 | 64 20 63 6f 6c 6f 72 20 | a mappe|d color |
|000054f0| 69 6d 61 67 65 20 69 6e | 74 6f 20 52 47 42 0a 58 |image in|to RGB.X|
|00005500| 20 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a | *******|********|
|00005510| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00005520| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00005530| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00005540| 2a 2f 0a 58 0a 58 63 6c | 72 5f 75 6e 6d 61 70 20 |*/.X.Xcl|r_unmap |
|00005550| 28 69 6e 70 75 74 2c 20 | 6f 75 74 70 75 74 29 0a |(input, |output).|
|00005560| 58 46 42 4d 20 2a 69 6e | 70 75 74 2c 20 2a 6f 75 |XFBM *in|put, *ou|
|00005570| 74 70 75 74 3b 0a 58 7b | 20 72 65 67 69 73 74 65 |tput;.X{| registe|
|00005580| 72 20 75 6e 73 69 67 6e | 65 64 20 63 68 61 72 20 |r unsign|ed char |
|00005590| 2a 72 65 64 2c 20 2a 67 | 72 6e 2c 20 2a 62 6c 75 |*red, *g|rn, *blu|
|000055a0| 2c 20 2a 62 6d 70 2c 20 | 2a 6f 62 6d 2c 20 2a 74 |, *bmp, |*obm, *t|
|000055b0| 61 69 6c 3b 0a 58 20 20 | 72 65 67 69 73 74 65 72 |ail;.X |register|
|000055c0| 20 69 6e 74 20 70 6c 6e | 6c 65 6e 2c 20 6b 3b 0a | int pln|len, k;.|
|000055d0| 58 0a 58 20 20 69 66 20 | 28 69 6e 70 75 74 2d 3e |X.X if |(input->|
|000055e0| 68 64 72 2e 70 6c 61 6e | 65 73 20 3d 3d 20 33 29 |hdr.plan|es == 3)|
|000055f0| 0a 58 20 20 7b 20 2a 6f | 75 74 70 75 74 20 3d 20 |.X { *o|utput = |
|00005600| 2a 69 6e 70 75 74 3b 20 | 72 65 74 75 72 6e 20 28 |*input; |return (|
|00005610| 31 29 3b 20 7d 0a 58 0a | 58 20 20 69 66 20 28 69 |1); }.X.|X if (i|
|00005620| 6e 70 75 74 2d 3e 68 64 | 72 2e 70 6c 61 6e 65 73 |nput->hd|r.planes|
|00005630| 20 21 3d 20 31 29 0a 58 | 20 20 7b 20 66 70 72 69 | != 1).X| { fpri|
|00005640| 6e 74 66 20 28 73 74 64 | 65 72 72 2c 20 22 63 6c |ntf (std|err, "cl|
|00005650| 72 5f 75 6e 6d 61 70 20 | 63 61 6e 6e 6f 74 20 68 |r_unmap |cannot h|
|00005660| 61 6e 64 6c 65 20 69 6d | 61 67 65 73 20 77 69 74 |andle im|ages wit|
|00005670| 68 20 25 64 20 70 6c 61 | 6e 65 73 5c 6e 22 2c 20 |h %d pla|nes\n", |
|00005680| 0a 58 09 20 20 20 20 20 | 69 6e 70 75 74 2d 3e 68 |.X. |input->h|
|00005690| 64 72 2e 70 6c 61 6e 65 | 73 29 3b 0a 58 20 20 20 |dr.plane|s);.X |
|000056a0| 20 72 65 74 75 72 6e 20 | 28 30 29 3b 0a 58 20 20 | return |(0);.X |
|000056b0| 7d 0a 58 0a 58 20 20 69 | 66 20 28 69 6e 70 75 74 |}.X.X i|f (input|
|000056c0| 2d 3e 68 64 72 2e 70 68 | 79 73 62 69 74 73 20 21 |->hdr.ph|ysbits !|
|000056d0| 3d 20 38 29 0a 58 20 20 | 7b 20 66 70 72 69 6e 74 |= 8).X |{ fprint|
|000056e0| 66 20 28 73 74 64 65 72 | 72 2c 20 22 63 6c 72 5f |f (stder|r, "clr_|
|000056f0| 75 6e 6d 61 70 20 63 61 | 6e 6e 6f 74 20 68 61 6e |unmap ca|nnot han|
|00005700| 64 6c 65 20 69 6d 61 67 | 65 73 20 77 69 74 68 20 |dle imag|es with |
|00005710| 25 64 20 70 68 79 73 62 | 69 74 73 5c 6e 22 2c 20 |%d physb|its\n", |
|00005720| 0a 58 09 20 20 20 20 20 | 69 6e 70 75 74 2d 3e 68 |.X. |input->h|
|00005730| 64 72 2e 70 68 79 73 62 | 69 74 73 29 3b 0a 58 20 |dr.physb|its);.X |
|00005740| 20 20 20 72 65 74 75 72 | 6e 20 28 30 29 3b 0a 58 | retur|n (0);.X|
|00005750| 20 20 7d 0a 58 0a 58 20 | 20 6f 75 74 70 75 74 2d | }.X.X | output-|
|00005760| 3e 68 64 72 20 3d 20 69 | 6e 70 75 74 2d 3e 68 64 |>hdr = i|nput->hd|
|00005770| 72 3b 0a 58 20 20 6f 75 | 74 70 75 74 2d 3e 68 64 |r;.X ou|tput->hd|
|00005780| 72 2e 70 6c 61 6e 65 73 | 20 3d 20 33 3b 0a 58 20 |r.planes| = 3;.X |
|00005790| 20 6f 75 74 70 75 74 2d | 3e 68 64 72 2e 63 6c 72 | output-|>hdr.clr|
|000057a0| 6c 65 6e 20 3d 20 30 3b | 0a 58 20 20 6f 75 74 70 |len = 0;|.X outp|
|000057b0| 75 74 2d 3e 68 64 72 2e | 62 69 74 73 20 3d 20 6f |ut->hdr.|bits = o|
|000057c0| 75 74 70 75 74 2d 3e 68 | 64 72 2e 70 68 79 73 62 |utput->h|dr.physb|
|000057d0| 69 74 73 3b 0a 58 20 20 | 0a 58 20 20 61 6c 6c 6f |its;.X |.X allo|
|000057e0| 63 5f 66 62 6d 20 28 6f | 75 74 70 75 74 29 3b 0a |c_fbm (o|utput);.|
|000057f0| 58 0a 58 20 20 2f 2a 20 | 52 65 61 6c 20 6d 61 70 |X.X /* |Real map|
|00005800| 70 65 64 20 63 6f 6c 6f | 72 20 69 6d 61 67 65 20 |ped colo|r image |
|00005810| 2a 2f 0a 58 20 20 69 66 | 20 28 69 6e 70 75 74 2d |*/.X if| (input-|
|00005820| 3e 68 64 72 2e 63 6c 72 | 6c 65 6e 20 3e 20 30 29 |>hdr.clr|len > 0)|
|00005830| 0a 58 20 20 7b 20 72 65 | 64 20 3d 20 26 28 69 6e |.X { re|d = &(in|
|00005840| 70 75 74 2d 3e 63 6d 5b | 30 5d 29 3b 0a 58 20 20 |put->cm[|0]);.X |
|00005850| 20 20 67 72 6e 20 3d 20 | 72 65 64 20 2b 20 69 6e | grn = |red + in|
|00005860| 70 75 74 2d 3e 68 64 72 | 2e 63 6c 72 6c 65 6e 20 |put->hdr|.clrlen |
|00005870| 2f 20 33 3b 0a 58 20 20 | 20 20 62 6c 75 20 3d 20 |/ 3;.X | blu = |
|00005880| 67 72 6e 20 2b 20 69 6e | 70 75 74 2d 3e 68 64 72 |grn + in|put->hdr|
|00005890| 2e 63 6c 72 6c 65 6e 20 | 2f 20 33 3b 0a 58 20 20 |.clrlen |/ 3;.X |
|000058a0| 20 20 70 6c 6e 6c 65 6e | 20 3d 20 69 6e 70 75 74 | plnlen| = input|
|000058b0| 2d 3e 68 64 72 2e 70 6c | 6e 6c 65 6e 3b 0a 58 20 |->hdr.pl|nlen;.X |
|000058c0| 20 20 20 0a 58 20 20 20 | 20 62 6d 70 20 3d 20 69 | .X | bmp = i|
|000058d0| 6e 70 75 74 2d 3e 62 6d | 3b 0a 58 20 20 20 20 6f |nput->bm|;.X o|
|000058e0| 62 6d 20 3d 20 6f 75 74 | 70 75 74 2d 3e 62 6d 3b |bm = out|put->bm;|
|000058f0| 0a 58 20 20 20 20 74 61 | 69 6c 20 3d 20 62 6d 70 |.X ta|il = bmp|
|00005900| 20 2b 20 70 6c 6e 6c 65 | 6e 3b 0a 58 20 20 20 20 | + plnle|n;.X |
|00005910| 0a 58 20 20 20 20 77 68 | 69 6c 65 20 28 62 6d 70 |.X wh|ile (bmp|
|00005920| 20 3c 20 74 61 69 6c 29 | 0a 58 20 20 20 20 7b 20 | < tail)|.X { |
|00005930| 6b 20 3d 20 2a 62 6d 70 | 2b 2b 3b 0a 58 20 20 20 |k = *bmp|++;.X |
|00005940| 20 0a 58 20 20 20 20 20 | 20 6f 62 6d 5b 30 5d 09 | .X | obm[0].|
|00005950| 09 09 3d 20 72 65 64 5b | 6b 5d 3b 0a 58 20 20 20 |..= red[|k];.X |
|00005960| 20 20 20 6f 62 6d 5b 70 | 6c 6e 6c 65 6e 5d 09 09 | obm[p|lnlen]..|
|00005970| 3d 20 67 72 6e 5b 6b 5d | 3b 0a 58 20 20 20 20 20 |= grn[k]|;.X |
|00005980| 20 6f 62 6d 5b 70 6c 6e | 6c 65 6e 2b 70 6c 6e 6c | obm[pln|len+plnl|
|00005990| 65 6e 5d 09 3d 20 62 6c | 75 5b 6b 5d 3b 0a 58 20 |en].= bl|u[k];.X |
|000059a0| 20 20 20 20 20 6f 62 6d | 2b 2b 3b 0a 58 20 20 20 | obm|++;.X |
|000059b0| 20 7d 0a 58 20 20 20 20 | 0a 58 20 20 7d 0a 58 20 | }.X |.X }.X |
|000059c0| 20 0a 58 20 20 2f 2a 20 | 47 72 61 79 73 63 61 6c | .X /* |Grayscal|
|000059d0| 65 20 69 6d 61 67 65 20 | 28 6a 75 73 74 20 64 75 |e image |(just du|
|000059e0| 70 6c 69 63 61 74 65 20 | 70 6c 61 6e 65 73 29 20 |plicate |planes) |
|000059f0| 2a 2f 0a 58 20 20 65 6c | 73 65 0a 58 20 20 7b 20 |*/.X el|se.X { |
|00005a00| 70 6c 6e 6c 65 6e 20 3d | 20 69 6e 70 75 74 2d 3e |plnlen =| input->|
|00005a10| 68 64 72 2e 70 6c 6e 6c | 65 6e 3b 0a 58 20 20 0a |hdr.plnl|en;.X .|
|00005a20| 58 20 20 20 20 62 6d 70 | 20 3d 20 69 6e 70 75 74 |X bmp| = input|
|00005a30| 2d 3e 62 6d 3b 0a 58 20 | 20 20 20 74 61 69 6c 20 |->bm;.X | tail |
|00005a40| 3d 20 62 6d 70 20 2b 20 | 70 6c 6e 6c 65 6e 3b 0a |= bmp + |plnlen;.|
|00005a50| 58 20 20 20 20 0a 58 20 | 20 20 20 72 65 64 20 3d |X .X | red =|
|00005a60| 20 6f 75 74 70 75 74 2d | 3e 62 6d 3b 0a 58 20 20 | output-|>bm;.X |
|00005a70| 20 20 67 72 6e 20 3d 20 | 72 65 64 20 2b 20 70 6c | grn = |red + pl|
|00005a80| 6e 6c 65 6e 3b 0a 58 20 | 20 20 20 62 6c 75 20 3d |nlen;.X | blu =|
|00005a90| 20 67 72 6e 20 2b 20 70 | 6c 6e 6c 65 6e 3b 0a 58 | grn + p|lnlen;.X|
|00005aa0| 20 20 20 20 0a 58 20 20 | 20 20 77 68 69 6c 65 20 | .X | while |
|00005ab0| 28 62 6d 70 20 3c 20 74 | 61 69 6c 29 0a 58 20 20 |(bmp < t|ail).X |
|00005ac0| 20 20 7b 20 2a 72 65 64 | 2b 2b 20 3d 20 2a 67 72 | { *red|++ = *gr|
|00005ad0| 6e 2b 2b 20 3d 20 2a 62 | 6c 75 2b 2b 20 3d 20 2a |n++ = *b|lu++ = *|
|00005ae0| 62 6d 70 2b 2b 3b 20 7d | 0a 58 20 20 7d 0a 58 20 |bmp++; }|.X }.X |
|00005af0| 20 0a 58 20 20 72 65 74 | 75 72 6e 20 28 31 29 3b | .X ret|urn (1);|
|00005b00| 0a 58 7d 0a 58 0a 58 2f | 2a 2a 2a 2a 2a 2a 2a 2a |.X}.X.X/|********|
|00005b10| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00005b20| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00005b30| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00005b40| 2a 2a 2a 2a 2a 2a 2a 2a | 0a 58 20 2a 20 63 6f 70 |********|.X * cop|
|00005b50| 79 5f 63 6c 72 3a 20 43 | 6f 70 79 20 63 6f 6c 6f |y_clr: C|opy colo|
|00005b60| 72 6d 61 70 20 66 72 6f | 6d 20 69 6e 70 75 74 20 |rmap fro|m input |
|00005b70| 74 6f 20 6f 75 74 70 75 | 74 0a 58 20 2a 2a 2a 2a |to outpu|t.X ****|
|00005b80| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00005b90| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00005ba0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00005bb0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2f 0a 58 0a |********|****/.X.|
|00005bc0| 58 63 6f 70 79 5f 63 6c | 72 20 28 69 6e 70 75 74 |Xcopy_cl|r (input|
|00005bd0| 2c 20 6f 75 74 70 75 74 | 29 0a 58 46 42 4d 20 2a |, output|).XFBM *|
|00005be0| 69 6e 70 75 74 2c 20 2a | 6f 75 74 70 75 74 3b 0a |input, *|output;.|
|00005bf0| 58 7b 20 72 65 67 69 73 | 74 65 72 20 69 6e 74 20 |X{ regis|ter int |
|00005c00| 69 2c 20 63 6c 72 6c 65 | 6e 3b 0a 58 20 20 72 65 |i, clrle|n;.X re|
|00005c10| 67 69 73 74 65 72 20 75 | 6e 73 69 67 6e 65 64 20 |gister u|nsigned |
|00005c20| 63 68 61 72 20 2a 69 63 | 2c 20 2a 6f 63 3b 0a 58 |char *ic|, *oc;.X|
|00005c30| 0a 58 20 20 6f 75 74 70 | 75 74 2d 3e 68 64 72 2e |.X outp|ut->hdr.|
|00005c40| 63 6c 72 6c 65 6e 20 3d | 20 63 6c 72 6c 65 6e 20 |clrlen =| clrlen |
|00005c50| 3d 20 69 6e 70 75 74 2d | 3e 68 64 72 2e 63 6c 72 |= input-|>hdr.clr|
|00005c60| 6c 65 6e 3b 0a 58 0a 58 | 20 20 69 63 20 3d 20 69 |len;.X.X| ic = i|
|00005c70| 6e 70 75 74 2d 3e 63 6d | 3b 0a 58 20 20 6f 63 20 |nput->cm|;.X oc |
|00005c80| 3d 20 6f 75 74 70 75 74 | 2d 3e 63 6d 3b 0a 58 20 |= output|->cm;.X |
|00005c90| 20 0a 58 20 20 66 6f 72 | 20 28 69 3d 30 3b 20 69 | .X for| (i=0; i|
|00005ca0| 20 3c 20 63 6c 72 6c 65 | 6e 3b 20 69 2b 2b 29 0a | < clrle|n; i++).|
|00005cb0| 58 20 20 7b 20 2a 6f 63 | 2b 2b 20 3d 20 2a 69 63 |X { *oc|++ = *ic|
|00005cc0| 2b 2b 3b 20 7d 0a 58 7d | 0a 45 4e 44 5f 4f 46 5f |++; }.X}|.END_OF_|
|00005cd0| 46 49 4c 45 0a 69 66 20 | 74 65 73 74 20 37 35 37 |FILE.if |test 757|
|00005ce0| 30 20 2d 6e 65 20 60 77 | 63 20 2d 63 20 3c 27 66 |0 -ne `w|c -c <'f|
|00005cf0| 6c 63 6c 72 2e 63 27 60 | 3b 20 74 68 65 6e 0a 20 |lclr.c'`|; then. |
|00005d00| 20 20 20 65 63 68 6f 20 | 73 68 61 72 3a 20 5c 22 | echo |shar: \"|
|00005d10| 27 66 6c 63 6c 72 2e 63 | 27 5c 22 20 75 6e 70 61 |'flclr.c|'\" unpa|
|00005d20| 63 6b 65 64 20 77 69 74 | 68 20 77 72 6f 6e 67 20 |cked wit|h wrong |
|00005d30| 73 69 7a 65 21 0a 66 69 | 0a 23 20 65 6e 64 20 6f |size!.fi|.# end o|
|00005d40| 66 20 27 66 6c 63 6c 72 | 2e 63 27 0a 66 69 0a 69 |f 'flclr|.c'.fi.i|
|00005d50| 66 20 74 65 73 74 20 2d | 66 20 27 66 6c 65 64 67 |f test -|f 'fledg|
|00005d60| 65 2e 63 27 20 2d 61 20 | 22 24 7b 31 7d 22 20 21 |e.c' -a |"${1}" !|
|00005d70| 3d 20 22 2d 63 22 20 3b | 20 74 68 65 6e 20 0a 20 |= "-c" ;| then . |
|00005d80| 20 65 63 68 6f 20 73 68 | 61 72 3a 20 57 69 6c 6c | echo sh|ar: Will|
|00005d90| 20 6e 6f 74 20 63 6c 6f | 62 62 65 72 20 65 78 69 | not clo|bber exi|
|00005da0| 73 74 69 6e 67 20 66 69 | 6c 65 20 5c 22 27 66 6c |sting fi|le \"'fl|
|00005db0| 65 64 67 65 2e 63 27 5c | 22 0a 65 6c 73 65 0a 65 |edge.c'\|".else.e|
|00005dc0| 63 68 6f 20 73 68 61 72 | 3a 20 45 78 74 72 61 63 |cho shar|: Extrac|
|00005dd0| 74 69 6e 67 20 5c 22 27 | 66 6c 65 64 67 65 2e 63 |ting \"'|fledge.c|
|00005de0| 27 5c 22 20 5c 28 38 33 | 35 39 20 63 68 61 72 61 |'\" \(83|59 chara|
|00005df0| 63 74 65 72 73 5c 29 0a | 73 65 64 20 22 73 2f 5e |cters\).|sed "s/^|
|00005e00| 58 2f 2f 22 20 3e 27 66 | 6c 65 64 67 65 2e 63 27 |X//" >'f|ledge.c'|
|00005e10| 20 3c 3c 27 45 4e 44 5f | 4f 46 5f 46 49 4c 45 27 | <<'END_|OF_FILE'|
|00005e20| 0a 58 2f 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |.X/*****|********|
|00005e30| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00005e40| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00005e50| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00005e60| 2a 2a 2a 2a 0a 58 20 2a | 20 66 6c 65 64 67 65 2e |****.X *| fledge.|
|00005e70| 63 3a 20 46 42 4d 20 4c | 69 62 72 61 72 79 20 30 |c: FBM L|ibrary 0|
|00005e80| 2e 39 20 28 42 65 74 61 | 20 74 65 73 74 29 20 30 |.9 (Beta| test) 0|
|00005e90| 37 2d 4d 61 72 2d 38 39 | 20 20 4d 69 63 68 61 65 |7-Mar-89| Michae|
|00005ea0| 6c 20 4d 61 75 6c 64 69 | 6e 0a 58 20 2a 0a 58 20 |l Mauldi|n.X *.X |
|00005eb0| 2a 20 43 6f 70 79 72 69 | 67 68 74 20 28 43 29 20 |* Copyri|ght (C) |
|00005ec0| 31 39 38 39 20 62 79 20 | 47 61 72 79 20 53 68 65 |1989 by |Gary She|
|00005ed0| 72 77 69 6e 20 26 20 4d | 69 63 68 61 65 6c 20 4d |rwin & M|ichael M|
|00005ee0| 61 75 6c 64 69 6e 2e 0a | 58 20 2a 20 50 65 72 6d |auldin..|X * Perm|
|00005ef0| 69 73 73 69 6f 6e 20 69 | 73 20 67 72 61 6e 74 65 |ission i|s grante|
|00005f00| 64 20 74 6f 20 75 73 65 | 20 74 68 69 73 20 66 69 |d to use| this fi|
|00005f10| 6c 65 20 69 6e 20 77 68 | 6f 6c 65 20 6f 72 20 69 |le in wh|ole or i|
|00005f20| 6e 20 70 61 72 74 20 70 | 72 6f 76 69 64 65 64 0a |n part p|rovided.|
|00005f30| 58 20 2a 20 74 68 61 74 | 20 79 6f 75 20 64 6f 20 |X * that| you do |
|00005f40| 6e 6f 74 20 73 65 6c 6c | 20 69 74 20 66 6f 72 20 |not sell| it for |
|00005f50| 70 72 6f 66 69 74 20 61 | 6e 64 20 74 68 61 74 20 |profit a|nd that |
|00005f60| 74 68 69 73 20 63 6f 70 | 79 72 69 67 68 74 20 6e |this cop|yright n|
|00005f70| 6f 74 69 63 65 0a 58 20 | 2a 20 69 73 20 72 65 74 |otice.X |* is ret|
|00005f80| 61 69 6e 65 64 20 75 6e | 63 68 61 6e 67 65 64 2e |ained un|changed.|
|00005f90| 0a 58 20 2a 0a 58 20 2a | 20 66 6c 65 64 67 65 2e |.X *.X *| fledge.|
|00005fa0| 63 3a 0a 58 20 2a 0a 58 | 20 2a 20 43 4f 4e 54 45 |c:.X *.X| * CONTE|
|00005fb0| 4e 54 53 0a 58 20 2a 09 | 66 69 6e 64 65 64 67 65 |NTS.X *.|findedge|
|00005fc0| 5f 66 62 6d 20 28 26 69 | 6d 61 67 65 2c 20 62 65 |_fbm (&i|mage, be|
|00005fd0| 74 61 29 0a 58 20 2a 0a | 58 20 2a 20 45 44 49 54 |ta).X *.|X * EDIT|
|00005fe0| 4c 4f 47 0a 58 20 2a 09 | 4c 61 73 74 45 64 69 74 |LOG.X *.|LastEdit|
|00005ff0| 44 61 74 65 20 3d 20 54 | 75 65 20 4d 61 72 20 20 |Date = T|ue Mar |
|00006000| 37 20 31 39 3a 35 36 3a | 35 34 20 31 39 38 39 20 |7 19:56:|54 1989 |
|00006010| 2d 20 4d 69 63 68 61 65 | 6c 20 4d 61 75 6c 64 69 |- Michae|l Mauldi|
|00006020| 6e 0a 58 20 2a 09 4c 61 | 73 74 46 69 6c 65 4e 61 |n.X *.La|stFileNa|
|00006030| 6d 65 20 3d 20 2f 75 73 | 72 32 2f 6d 6c 6d 2f 73 |me = /us|r2/mlm/s|
|00006040| 72 63 2f 6d 69 73 63 2f | 66 62 6d 2f 66 6c 65 64 |rc/misc/|fbm/fled|
|00006050| 67 65 2e 63 0a 58 20 2a | 0a 58 20 2a 20 48 49 53 |ge.c.X *|.X * HIS|
|00006060| 54 4f 52 59 0a 58 20 2a | 20 30 37 2d 4d 61 72 2d |TORY.X *| 07-Mar-|
|00006070| 38 39 20 20 4d 69 63 68 | 61 65 6c 20 4d 61 75 6c |89 Mich|ael Maul|
|00006080| 64 69 6e 20 28 6d 6c 6d | 29 20 61 74 20 43 61 72 |din (mlm|) at Car|
|00006090| 6e 65 67 69 65 20 4d 65 | 6c 6c 6f 6e 20 55 6e 69 |negie Me|llon Uni|
|000060a0| 76 65 72 73 69 74 79 0a | 58 20 2a 09 42 65 74 61 |versity.|X *.Beta|
|000060b0| 20 72 65 6c 65 61 73 65 | 20 28 76 65 72 73 69 6f | release| (versio|
|000060c0| 6e 20 30 2e 39 29 20 6d | 6c 6d 40 63 73 2e 63 6d |n 0.9) m|lm@cs.cm|
|000060d0| 75 2e 65 64 75 0a 58 20 | 2a 0a 58 20 2a 20 32 31 |u.edu.X |*.X * 21|
|000060e0| 2d 41 75 67 2d 38 38 20 | 20 4d 69 63 68 61 65 6c |-Aug-88 | Michael|
|000060f0| 20 4d 61 75 6c 64 69 6e | 20 28 6d 6c 6d 29 20 61 | Mauldin| (mlm) a|
|00006100| 74 20 43 61 72 6e 65 67 | 69 65 2d 4d 65 6c 6c 6f |t Carneg|ie-Mello|
|00006110| 6e 20 55 6e 69 76 65 72 | 73 69 74 79 0a 58 20 2a |n Univer|sity.X *|
|00006120| 09 43 72 65 61 74 65 64 | 2e 0a 58 20 2a 2a 2a 2a |.Created|..X ****|
|00006130| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00006140| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00006150| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00006160| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2f 0a 58 |********|*****/.X|
|00006170| 0a 58 23 20 69 6e 63 6c | 75 64 65 20 3c 73 74 64 |.X# incl|ude <std|
|00006180| 69 6f 2e 68 3e 0a 58 23 | 20 69 6e 63 6c 75 64 65 |io.h>.X#| include|
|00006190| 20 3c 6d 61 74 68 2e 68 | 3e 0a 58 23 20 69 6e 63 | <math.h|>.X# inc|
|000061a0| 6c 75 64 65 20 3c 63 74 | 79 70 65 2e 68 3e 0a 58 |lude <ct|ype.h>.X|
|000061b0| 23 20 69 6e 63 6c 75 64 | 65 20 22 66 62 6d 2e 68 |# includ|e "fbm.h|
|000061c0| 22 0a 58 0a 58 2f 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |".X.X/**|********|
|000061d0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000061e0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000061f0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00006200| 2a 2a 2a 2a 2a 2a 0a 58 | 20 2a 20 66 69 6e 64 65 |******.X| * finde|
|00006210| 64 67 65 5f 66 62 6d 3a | 20 64 65 74 65 72 6d 69 |dge_fbm:| determi|
|00006220| 6e 65 20 77 68 65 74 68 | 65 72 20 69 6d 61 67 65 |ne wheth|er image|
|00006230| 20 69 73 20 69 6e 20 63 | 6f 6c 6f 72 2c 20 61 6e | is in c|olor, an|
|00006240| 64 20 63 61 6c 6c 20 74 | 68 65 0a 58 20 2a 09 20 |d call t|he.X *. |
|00006250| 20 20 20 20 20 20 20 61 | 70 70 72 6f 70 72 69 61 | a|ppropria|
|00006260| 74 65 20 65 64 67 65 20 | 64 65 74 65 63 74 69 6f |te edge |detectio|
|00006270| 6e 20 72 6f 75 74 69 6e | 65 2e 0a 58 20 2a 2a 2a |n routin|e..X ***|
|00006280| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00006290| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000062a0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000062b0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2f 0a 58 |********|*****/.X|
|000062c0| 0a 58 23 69 66 6e 64 65 | 66 20 6c 69 6e 74 0a 58 |.X#ifnde|f lint.X|
|000062d0| 73 74 61 74 69 63 20 63 | 68 61 72 20 2a 66 62 6d |static c|har *fbm|
|000062e0| 69 64 20 3d 0a 58 09 22 | 24 46 42 4d 20 66 6c 65 |id =.X."|$FBM fle|
|000062f0| 64 67 65 2e 63 20 3c 30 | 2e 39 3e 20 30 37 2d 4d |dge.c <0|.9> 07-M|
|00006300| 61 72 2d 38 39 20 20 28 | 43 29 20 31 39 38 39 20 |ar-89 (|C) 1989 |
|00006310| 62 79 20 4d 69 63 68 61 | 65 6c 20 4d 61 75 6c 64 |by Micha|el Mauld|
|00006320| 69 6e 24 22 3b 0a 58 23 | 65 6e 64 69 66 0a 58 0a |in$";.X#|endif.X.|
|00006330| 58 66 69 6e 64 65 64 67 | 65 5f 66 62 6d 20 28 69 |Xfindedg|e_fbm (i|
|00006340| 6e 70 75 74 2c 20 6f 75 | 74 70 75 74 2c 20 62 65 |nput, ou|tput, be|
|00006350| 74 61 29 0a 58 46 42 4d | 20 2a 69 6e 70 75 74 2c |ta).XFBM| *input,|
|00006360| 20 2a 6f 75 74 70 75 74 | 3b 0a 58 69 6e 74 20 62 | *output|;.Xint b|
|00006370| 65 74 61 3b 0a 58 7b 0a | 58 20 20 69 66 20 28 69 |eta;.X{.|X if (i|
|00006380| 6e 70 75 74 2d 3e 68 64 | 72 2e 70 6c 61 6e 65 73 |nput->hd|r.planes|
|00006390| 20 3d 3d 20 31 29 0a 58 | 20 20 7b 20 72 65 74 75 | == 1).X| { retu|
|000063a0| 72 6e 20 28 66 69 6e 64 | 65 64 67 65 5f 62 77 20 |rn (find|edge_bw |
|000063b0| 28 69 6e 70 75 74 2c 20 | 6f 75 74 70 75 74 2c 20 |(input, |output, |
|000063c0| 62 65 74 61 29 29 3b 20 | 7d 0a 58 20 20 65 6c 73 |beta)); |}.X els|
|000063d0| 65 0a 58 20 20 7b 20 72 | 65 74 75 72 6e 20 28 66 |e.X { r|eturn (f|
|000063e0| 69 6e 64 65 64 67 65 5f | 62 77 20 28 69 6e 70 75 |indedge_|bw (inpu|
|000063f0| 74 2c 20 6f 75 74 70 75 | 74 2c 20 62 65 74 61 29 |t, outpu|t, beta)|
+--------+-------------------------+-------------------------+--------+--------+
Only 25.0 KB of data is shown above.