home *** CD-ROM | disk | FTP | other *** search
/ Source Code 1992 March / Source_Code_CD-ROM_Walnut_Creek_March_1992.iso / usenet / compsrcs / unix / volume15 / hash8 < prev    next >
SHell self-extracting ARchive  |  1989-01-13  |  32.6 KB

open in: MacOS 8.1     |     Win98     |     DOS

view JSON data     |     view as text

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

You can browse this item here: hash8

ConfidenceProgramDetectionMatch TypeSupport
100% dexvert SHell self-extracting ARchive (archive/shar) magic Supported
1% dexvert Text File (text/txt) fallback Supported
100% file 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 35 69 30 33 |Subject:| v15i03|
|00000010| 36 3a 20 20 48 61 73 68 | 20 6c 6f 6e 67 20 69 64 |6: Hash| long id|
|00000020| 65 6e 74 69 66 69 65 72 | 73 20 69 6e 74 6f 20 75 |entifier|s into u|
|00000030| 6e 69 71 75 65 20 73 68 | 6f 72 74 20 6f 6e 65 73 |nique sh|ort ones|
|00000040| 0a 4e 65 77 73 67 72 6f | 75 70 73 3a 20 63 6f 6d |.Newsgro|ups: com|
|00000050| 70 2e 73 6f 75 72 63 65 | 73 2e 75 6e 69 78 0a 53 |p.source|s.unix.S|
|00000060| 65 6e 64 65 72 3a 20 73 | 6f 75 72 63 65 73 0a 41 |ender: s|ources.A|
|00000070| 70 70 72 6f 76 65 64 3a | 20 72 73 61 6c 7a 40 75 |pproved:| rsalz@u|
|00000080| 75 6e 65 74 2e 55 55 2e | 4e 45 54 0a 0a 53 75 62 |unet.UU.|NET..Sub|
|00000090| 6d 69 74 74 65 64 2d 62 | 79 3a 20 64 65 73 69 6e |mitted-b|y: desin|
|000000a0| 74 21 67 65 6f 66 66 20 | 28 47 65 6f 66 66 20 4b |t!geoff |(Geoff K|
|000000b0| 75 65 6e 6e 69 6e 67 29 | 0a 50 6f 73 74 69 6e 67 |uenning)|.Posting|
|000000c0| 2d 6e 75 6d 62 65 72 3a | 20 56 6f 6c 75 6d 65 20 |-number:| Volume |
|000000d0| 31 35 2c 20 49 73 73 75 | 65 20 33 36 0a 41 72 63 |15, Issu|e 36.Arc|
|000000e0| 68 69 76 65 2d 6e 61 6d | 65 3a 20 68 61 73 68 38 |hive-nam|e: hash8|
|000000f0| 0a 0a 5b 20 20 49 20 68 | 61 76 65 6e 27 74 20 75 |..[ I h|aven't u|
|00000100| 73 65 64 20 74 68 69 73 | 3b 20 64 6f 63 75 6d 65 |sed this|; docume|
|00000110| 6e 74 61 74 69 6f 6e 20 | 69 73 20 69 6e 20 74 68 |ntation |is in th|
|00000120| 65 20 52 45 41 44 4d 45 | 20 66 69 6c 65 73 20 61 |e README| files a|
|00000130| 73 20 75 73 65 0a 20 20 | 20 69 73 20 6c 69 6b 65 |s use. | is like|
|00000140| 6c 79 20 74 6f 20 62 65 | 20 76 65 72 79 20 73 79 |ly to be| very sy|
|00000150| 73 74 65 6d 2d 64 65 70 | 65 6e 64 65 6e 74 2e 20 |stem-dep|endent. |
|00000160| 2d 2d 72 24 20 20 5d 0a | 0a 54 68 69 73 20 69 73 |--r$ ].|.This is|
|00000170| 20 41 72 63 68 20 52 6f | 62 69 73 6f 6e 27 73 20 | Arch Ro|bison's |
|00000180| 22 68 61 73 68 38 22 20 | 70 72 6f 67 72 61 6d 2c |"hash8" |program,|
|00000190| 20 77 68 69 63 68 20 61 | 6c 6c 6f 77 73 20 6f 6c | which a|llows ol|
|000001a0| 64 20 43 20 63 6f 6d 70 | 69 6c 65 72 73 0a 74 6f |d C comp|ilers.to|
|000001b0| 20 63 6f 6d 70 69 6c 65 | 20 6c 6f 6e 67 2d 69 64 | compile| long-id|
|000001c0| 65 6e 74 69 66 69 65 72 | 20 70 72 6f 67 72 61 6d |entifier| program|
|000001d0| 73 20 63 6f 72 72 65 63 | 74 6c 79 2e 20 20 49 20 |s correc|tly. I |
|000001e0| 68 61 76 65 20 61 64 64 | 65 64 20 61 6e 20 22 6c |have add|ed an "l|
|000001f0| 63 63 22 0a 28 22 6c 6f | 6e 67 6e 61 6d 65 2d 63 |cc".("lo|ngname-c|
|00000200| 63 22 29 20 73 68 65 6c | 6c 20 73 63 72 69 70 74 |c") shel|l script|
|00000210| 20 74 6f 20 6d 61 6b 65 | 20 74 68 69 73 20 65 76 | to make| this ev|
|00000220| 65 6e 20 65 61 73 69 65 | 72 2e 20 20 55 73 65 66 |en easie|r. Usef|
|00000230| 75 6c 20 77 69 74 68 0a | 69 73 70 65 6c 6c 20 61 |ul with.|ispell a|
|00000240| 6e 64 20 6e 65 74 68 61 | 63 6b 2e 0a 0a 09 47 65 |nd netha|ck....Ge|
|00000250| 6f 66 66 20 4b 75 65 6e | 6e 69 6e 67 20 20 20 67 |off Kuen|ning g|
|00000260| 65 6f 66 66 40 49 54 63 | 6f 72 70 2e 63 6f 6d 20 |eoff@ITc|orp.com |
|00000270| 20 20 7b 75 75 6e 65 74 | 2c 74 72 77 72 62 7d 21 | {uunet|,trwrb}!|
|00000280| 64 65 73 69 6e 74 21 67 | 65 6f 66 66 0a 0a 23 21 |desint!g|eoff..#!|
|00000290| 20 2f 62 69 6e 2f 73 68 | 0a 23 20 54 68 69 73 20 | /bin/sh|.# This |
|000002a0| 69 73 20 61 20 73 68 65 | 6c 6c 20 61 72 63 68 69 |is a she|ll archi|
|000002b0| 76 65 2c 20 6d 65 61 6e | 69 6e 67 3a 0a 23 20 31 |ve, mean|ing:.# 1|
|000002c0| 2e 20 52 65 6d 6f 76 65 | 20 65 76 65 72 79 74 68 |. Remove| everyth|
|000002d0| 69 6e 67 20 61 62 6f 76 | 65 20 74 68 65 20 23 21 |ing abov|e the #!|
|000002e0| 20 2f 62 69 6e 2f 73 68 | 20 6c 69 6e 65 2e 0a 23 | /bin/sh| line..#|
|000002f0| 20 32 2e 20 53 61 76 65 | 20 74 68 65 20 72 65 73 | 2. Save| the res|
|00000300| 75 6c 74 69 6e 67 20 74 | 65 78 74 20 69 6e 20 61 |ulting t|ext in a|
|00000310| 20 66 69 6c 65 2e 0a 23 | 20 33 2e 20 45 78 65 63 | file..#| 3. Exec|
|00000320| 75 74 65 20 74 68 65 20 | 66 69 6c 65 20 77 69 74 |ute the |file wit|
|00000330| 68 20 2f 62 69 6e 2f 73 | 68 20 28 6e 6f 74 20 63 |h /bin/s|h (not c|
|00000340| 73 68 29 20 74 6f 20 63 | 72 65 61 74 65 20 74 68 |sh) to c|reate th|
|00000350| 65 20 66 69 6c 65 73 3a | 0a 23 09 52 45 41 44 4d |e files:|.#.READM|
|00000360| 45 0a 23 09 52 45 41 44 | 4d 45 2e 4f 4c 44 0a 23 |E.#.READ|ME.OLD.#|
|00000370| 09 44 4f 43 0a 23 09 4d | 61 6b 65 66 69 6c 65 0a |.DOC.#.M|akefile.|
|00000380| 23 09 68 61 73 68 38 2e | 63 0a 23 09 6c 63 63 2e |#.hash8.|c.#.lcc.|
|00000390| 73 68 2c 76 0a 23 09 6c | 74 65 73 74 2e 63 0a 23 |sh,v.#.l|test.c.#|
|000003a0| 09 6c 74 65 73 74 32 2e | 63 0a 23 09 6c 74 65 73 |.ltest2.|c.#.ltes|
|000003b0| 74 33 2e 63 0a 23 09 6e | 63 63 0a 65 78 70 6f 72 |t3.c.#.n|cc.expor|
|000003c0| 74 20 50 41 54 48 3b 20 | 50 41 54 48 3d 2f 62 69 |t PATH; |PATH=/bi|
|000003d0| 6e 3a 24 50 41 54 48 0a | 65 63 68 6f 20 73 68 61 |n:$PATH.|echo sha|
|000003e0| 72 3a 20 65 78 74 72 61 | 63 74 69 6e 67 20 22 27 |r: extra|cting "'|
|000003f0| 52 45 41 44 4d 45 27 22 | 20 27 28 38 37 33 20 63 |README'"| '(873 c|
|00000400| 68 61 72 61 63 74 65 72 | 73 29 27 0a 69 66 20 74 |haracter|s)'.if t|
|00000410| 65 73 74 20 2d 66 20 27 | 52 45 41 44 4d 45 27 0a |est -f '|README'.|
|00000420| 74 68 65 6e 0a 09 65 63 | 68 6f 20 73 68 61 72 3a |then..ec|ho shar:|
|00000430| 20 77 69 6c 6c 20 6e 6f | 74 20 6f 76 65 72 2d 77 | will no|t over-w|
|00000440| 72 69 74 65 20 65 78 69 | 73 74 69 6e 67 20 66 69 |rite exi|sting fi|
|00000450| 6c 65 20 22 27 52 45 41 | 44 4d 45 27 22 0a 65 6c |le "'REA|DME'".el|
|00000460| 73 65 0a 63 61 74 20 3c | 3c 20 5c 53 48 41 52 5f |se.cat <|< \SHAR_|
|00000470| 45 4f 46 20 3e 20 27 52 | 45 41 44 4d 45 27 0a 0a |EOF > 'R|EADME'..|
|00000480| 09 41 6e 20 49 6d 70 72 | 6f 76 65 64 20 56 65 72 |.An Impr|oved Ver|
|00000490| 73 69 6f 6e 20 6f 66 20 | 41 72 63 68 20 52 6f 62 |sion of |Arch Rob|
|000004a0| 69 73 6f 6e 27 73 20 22 | 68 61 73 68 38 22 0a 0a |ison's "|hash8"..|
|000004b0| 53 6f 6d 65 20 74 69 6d | 65 20 61 67 6f 2c 20 41 |Some tim|e ago, A|
|000004c0| 72 63 68 20 52 6f 62 69 | 73 6f 6e 20 6b 69 6e 64 |rch Robi|son kind|
|000004d0| 6c 79 20 70 72 6f 76 69 | 64 65 64 20 6d 65 20 77 |ly provi|ded me w|
|000004e0| 69 74 68 20 61 20 63 6f | 70 79 20 6f 66 20 68 69 |ith a co|py of hi|
|000004f0| 73 0a 22 68 61 73 68 38 | 22 20 70 72 6f 67 72 61 |s."hash8|" progra|
|00000500| 6d 2c 20 77 68 69 63 68 | 20 67 69 76 65 73 20 6c |m, which| gives l|
|00000510| 6f 6e 67 2d 69 64 20 63 | 61 70 61 62 69 6c 69 74 |ong-id c|apabilit|
|00000520| 69 65 73 20 74 6f 20 61 | 6c 6c 20 43 20 63 6f 6d |ies to a|ll C com|
|00000530| 70 69 6c 65 72 73 2e 0a | 42 72 69 65 66 6c 79 2c |pilers..|Briefly,|
|00000540| 20 68 61 73 68 38 20 72 | 65 70 6c 61 63 65 73 20 | hash8 r|eplaces |
|00000550| 61 6c 6c 20 6c 6f 6e 67 | 20 69 64 65 6e 74 69 66 |all long| identif|
|00000560| 69 65 72 73 20 69 6e 20 | 61 20 70 72 6f 67 72 61 |iers in |a progra|
|00000570| 6d 20 77 69 74 68 20 61 | 0a 6e 75 6d 65 72 69 63 |m with a|.numeric|
|00000580| 61 6c 6c 79 2d 62 61 73 | 65 64 20 69 64 65 6e 74 |ally-bas|ed ident|
|00000590| 69 66 69 65 72 20 6f 66 | 20 36 20 63 68 61 72 61 |ifier of| 6 chara|
|000005a0| 63 74 65 72 73 2e 20 20 | 4f 70 74 69 6f 6e 73 20 |cters. |Options |
|000005b0| 61 6c 6c 6f 77 20 74 68 | 69 6e 67 73 0a 6c 69 6b |allow th|ings.lik|
|000005c0| 65 20 75 73 69 6e 67 20 | 64 65 62 75 67 67 65 72 |e using |debugger|
|000005d0| 73 20 77 69 74 68 20 74 | 68 65 20 6f 72 69 67 69 |s with t|he origi|
|000005e0| 6e 61 6c 20 6c 6f 6e 67 | 20 6e 61 6d 65 73 2e 0a |nal long| names..|
|000005f0| 0a 49 20 68 61 76 65 20 | 65 78 74 65 6e 64 65 64 |.I have |extended|
|00000600| 20 41 72 63 68 27 73 20 | 70 72 6f 67 72 61 6d 20 | Arch's |program |
|00000610| 77 69 74 68 20 61 20 73 | 68 65 6c 6c 20 73 63 72 |with a s|hell scr|
|00000620| 69 70 74 2c 20 22 6c 63 | 63 2e 73 68 22 2c 20 77 |ipt, "lc|c.sh", w|
|00000630| 68 69 63 68 0a 64 6f 65 | 73 20 65 78 61 63 74 6c |hich.doe|s exactl|
|00000640| 79 20 77 68 61 74 20 22 | 63 63 22 20 64 6f 65 73 |y what "|cc" does|
|00000650| 2c 20 62 75 74 20 63 6f | 6d 70 69 6c 65 73 20 6c |, but co|mpiles l|
|00000660| 6f 6e 67 2d 6e 61 6d 65 | 20 70 72 6f 67 72 61 6d |ong-name| program|
|00000670| 73 2e 20 20 55 6e 66 6f | 72 74 75 6e 61 74 65 6c |s. Unfo|rtunatel|
|00000680| 79 2c 0a 74 68 65 20 73 | 63 72 69 70 74 20 69 73 |y,.the s|cript is|
|00000690| 20 71 75 69 74 65 20 73 | 79 73 74 65 6d 2d 73 70 | quite s|ystem-sp|
|000006a0| 65 63 69 66 69 63 2c 20 | 61 6e 64 20 49 20 68 61 |ecific, |and I ha|
|000006b0| 76 65 20 61 6e 20 6f 64 | 64 20 63 6f 6e 66 69 67 |ve an od|d config|
|000006c0| 75 72 61 74 69 6f 6e 0a | 28 36 38 30 30 30 20 72 |uration.|(68000 r|
|000006d0| 75 6e 6e 69 6e 67 20 55 | 6e 69 53 6f 66 74 20 53 |unning U|niSoft S|
|000006e0| 79 73 74 65 6d 20 56 2e | 30 20 77 69 74 68 20 56 |ystem V.|0 with V|
|000006f0| 37 20 63 6f 6d 70 69 6c | 65 72 73 29 2c 20 73 6f |7 compil|ers), so|
|00000700| 20 79 6f 75 20 77 69 6c | 6c 0a 61 6c 6d 6f 73 74 | you wil|l.almost|
|00000710| 20 63 65 72 74 61 69 6e | 6c 79 20 68 61 76 65 20 | certain|ly have |
|00000720| 74 6f 20 65 64 69 74 20 | 69 74 20 62 65 66 6f 72 |to edit |it befor|
|00000730| 65 20 69 74 20 69 73 20 | 63 6f 6d 70 6c 65 74 65 |e it is |complete|
|00000740| 6c 79 20 63 6f 6d 70 61 | 74 69 62 6c 65 0a 77 69 |ly compa|tible.wi|
|00000750| 74 68 20 79 6f 75 72 20 | 6f 77 6e 20 22 63 63 22 |th your |own "cc"|
|00000760| 2e 20 20 4e 65 76 65 72 | 74 68 65 6c 65 73 73 2c |. Never|theless,|
|00000770| 20 66 6f 72 20 74 68 6f | 73 65 20 77 69 74 68 20 | for tho|se with |
|00000780| 6f 6c 64 65 72 20 63 6f | 6d 70 69 6c 65 72 73 2c |older co|mpilers,|
|00000790| 0a 74 68 69 73 20 69 73 | 20 61 20 6c 69 66 65 2d |.this is| a life-|
|000007a0| 73 61 76 65 72 2e 0a 0a | 09 47 65 6f 66 66 20 4b |saver...|.Geoff K|
|000007b0| 75 65 6e 6e 69 6e 67 20 | 20 20 67 65 6f 66 66 40 |uenning | geoff@|
|000007c0| 49 54 63 6f 72 70 2e 63 | 6f 6d 20 20 20 7b 75 75 |ITcorp.c|om {uu|
|000007d0| 6e 65 74 2c 74 72 77 72 | 62 7d 21 64 65 73 69 6e |net,trwr|b}!desin|
|000007e0| 74 21 67 65 6f 66 66 0a | 53 48 41 52 5f 45 4f 46 |t!geoff.|SHAR_EOF|
|000007f0| 0a 66 69 20 23 20 65 6e | 64 20 6f 66 20 6f 76 65 |.fi # en|d of ove|
|00000800| 72 77 72 69 74 69 6e 67 | 20 63 68 65 63 6b 0a 65 |rwriting| check.e|
|00000810| 63 68 6f 20 73 68 61 72 | 3a 20 65 78 74 72 61 63 |cho shar|: extrac|
|00000820| 74 69 6e 67 20 22 27 52 | 45 41 44 4d 45 2e 4f 4c |ting "'R|EADME.OL|
|00000830| 44 27 22 20 27 28 31 33 | 30 33 20 63 68 61 72 61 |D'" '(13|03 chara|
|00000840| 63 74 65 72 73 29 27 0a | 69 66 20 74 65 73 74 20 |cters)'.|if test |
|00000850| 2d 66 20 27 52 45 41 44 | 4d 45 2e 4f 4c 44 27 0a |-f 'READ|ME.OLD'.|
|00000860| 74 68 65 6e 0a 09 65 63 | 68 6f 20 73 68 61 72 3a |then..ec|ho shar:|
|00000870| 20 77 69 6c 6c 20 6e 6f | 74 20 6f 76 65 72 2d 77 | will no|t over-w|
|00000880| 72 69 74 65 20 65 78 69 | 73 74 69 6e 67 20 66 69 |rite exi|sting fi|
|00000890| 6c 65 20 22 27 52 45 41 | 44 4d 45 2e 4f 4c 44 27 |le "'REA|DME.OLD'|
|000008a0| 22 0a 65 6c 73 65 0a 63 | 61 74 20 3c 3c 20 5c 53 |".else.c|at << \S|
|000008b0| 48 41 52 5f 45 4f 46 20 | 3e 20 27 52 45 41 44 4d |HAR_EOF |> 'READM|
|000008c0| 45 2e 4f 4c 44 27 0a 3e | 46 72 6f 6d 20 75 75 63 |E.OLD'.>|From uuc|
|000008d0| 70 20 53 61 74 20 4f 63 | 74 20 32 35 20 30 32 3a |p Sat Oc|t 25 02:|
|000008e0| 34 35 20 50 44 54 20 31 | 39 38 36 0a 3e 46 72 6f |45 PDT 1|986.>Fro|
|000008f0| 6d 20 69 68 6e 70 34 21 | 75 69 75 63 64 63 73 21 |m ihnp4!|uiucdcs!|
|00000900| 62 2e 63 73 2e 75 69 75 | 63 2e 65 64 75 21 72 6f |b.cs.uiu|c.edu!ro|
|00000910| 62 69 73 6f 6e 20 20 53 | 61 74 20 4f 63 74 20 32 |bison S|at Oct 2|
|00000920| 35 20 30 32 3a 34 35 3a | 34 36 20 31 39 38 36 20 |5 02:45:|46 1986 |
|00000930| 72 65 6d 6f 74 65 20 66 | 72 6f 6d 20 74 72 77 72 |remote f|rom trwr|
|00000940| 62 0a 52 65 63 65 69 76 | 65 64 3a 20 62 79 20 69 |b.Receiv|ed: by i|
|00000950| 68 6e 70 34 2e 41 54 54 | 2e 43 4f 4d 20 69 64 20 |hnp4.ATT|.COM id |
|00000960| 41 41 31 34 30 34 34 3b | 20 32 32 20 4f 63 74 20 |AA14044;| 22 Oct |
|00000970| 38 36 20 31 35 3a 33 34 | 3a 35 36 20 43 44 54 20 |86 15:34|:56 CDT |
|00000980| 28 57 65 64 29 0a 52 65 | 63 65 69 76 65 64 3a 20 |(Wed).Re|ceived: |
|00000990| 66 72 6f 6d 20 62 2e 63 | 73 2e 75 69 75 63 2e 65 |from b.c|s.uiuc.e|
|000009a0| 64 75 20 62 79 20 61 2e | 63 73 2e 75 69 75 63 2e |du by a.|cs.uiuc.|
|000009b0| 65 64 75 20 77 69 74 68 | 20 53 4d 54 50 20 28 55 |edu with| SMTP (U|
|000009c0| 49 55 43 2d 35 2e 34 34 | 2f 39 2e 37 29 2c 0a 09 |IUC-5.44|/9.7),..|
|000009d0| 69 64 20 41 41 32 36 38 | 33 38 3b 20 57 65 64 2c |id AA268|38; Wed,|
|000009e0| 20 32 32 20 4f 63 74 20 | 38 36 20 31 31 3a 32 39 | 22 Oct |86 11:29|
|000009f0| 3a 31 39 20 43 44 54 0a | 52 65 63 65 69 76 65 64 |:19 CDT.|Received|
|00000a00| 3a 20 62 79 20 62 2e 63 | 73 2e 75 69 75 63 2e 65 |: by b.c|s.uiuc.e|
|00000a10| 64 75 20 28 55 49 55 43 | 2d 35 2e 34 34 2f 39 2e |du (UIUC|-5.44/9.|
|00000a20| 37 29 2c 0a 09 69 64 20 | 41 41 30 34 32 38 30 3b |7),..id |AA04280;|
|00000a30| 20 57 65 64 2c 20 32 32 | 20 4f 63 74 20 38 36 20 | Wed, 22| Oct 86 |
|00000a40| 31 31 3a 32 35 3a 35 30 | 20 43 44 54 0a 44 61 74 |11:25:50| CDT.Dat|
|00000a50| 65 3a 20 57 65 64 2c 20 | 32 32 20 4f 63 74 20 38 |e: Wed, |22 Oct 8|
|00000a60| 36 20 31 31 3a 32 35 3a | 35 30 20 43 44 54 0a 46 |6 11:25:|50 CDT.F|
|00000a70| 72 6f 6d 3a 20 74 72 77 | 72 62 21 69 68 6e 70 34 |rom: trw|rb!ihnp4|
|00000a80| 21 75 69 75 63 64 63 73 | 21 62 2e 63 73 2e 75 69 |!uiucdcs|!b.cs.ui|
|00000a90| 75 63 2e 65 64 75 21 72 | 6f 62 69 73 6f 6e 20 28 |uc.edu!r|obison (|
|00000aa0| 41 72 63 68 20 52 6f 62 | 69 73 6f 6e 29 0a 4d 65 |Arch Rob|ison).Me|
|00000ab0| 73 73 61 67 65 2d 49 64 | 3a 20 3c 38 36 31 30 32 |ssage-Id|: <86102|
|00000ac0| 32 31 36 32 35 2e 41 41 | 30 34 32 38 30 40 62 2e |21625.AA|04280@b.|
|00000ad0| 63 73 2e 75 69 75 63 2e | 65 64 75 3e 0a 54 6f 3a |cs.uiuc.|edu>.To:|
|00000ae0| 20 64 65 73 69 6e 74 21 | 67 65 6f 66 66 0a 53 75 | desint!|geoff.Su|
|00000af0| 62 6a 65 63 74 3a 20 6c | 6f 6e 67 2d 74 6f 2d 73 |bject: l|ong-to-s|
|00000b00| 68 6f 72 74 20 63 6f 6e | 76 65 72 74 65 72 0a 0a |hort con|verter..|
|00000b10| 0a 48 65 72 65 20 69 73 | 20 74 68 65 20 6c 6f 6e |.Here is| the lon|
|00000b20| 67 2d 69 64 65 6e 74 69 | 66 69 65 72 20 63 6f 6e |g-identi|fier con|
|00000b30| 76 65 72 74 65 72 2e 20 | 20 54 68 65 20 63 6f 6e |verter. | The con|
|00000b40| 76 65 72 74 65 72 20 68 | 61 73 20 62 65 65 6e 20 |verter h|as been |
|00000b50| 75 73 65 64 0a 74 6f 20 | 63 72 65 61 74 65 20 61 |used.to |create a|
|00000b60| 20 6c 6f 6e 67 2d 69 64 | 65 6e 74 69 66 69 65 72 | long-id|entifier|
|00000b70| 20 6c 69 6e 74 20 61 6e | 64 20 77 69 74 68 20 63 | lint an|d with c|
|00000b80| 63 2e 20 20 50 6c 65 61 | 73 65 20 73 65 6e 64 20 |c. Plea|se send |
|00000b90| 6d 65 20 61 6e 79 20 62 | 75 67 0a 72 65 70 6f 72 |me any b|ug.repor|
|00000ba0| 74 73 20 6f 72 20 63 6f | 6d 6d 65 6e 74 73 20 6f |ts or co|mments o|
|00000bb0| 6e 20 68 6f 77 20 74 6f | 20 69 6d 70 72 6f 76 65 |n how to| improve|
|00000bc0| 20 69 74 2e 20 20 4d 79 | 20 76 65 72 73 69 6f 6e | it. My| version|
|00000bd0| 20 6f 66 20 6c 69 6e 74 | 20 74 68 61 74 20 75 73 | of lint| that us|
|00000be0| 65 73 20 0a 69 74 20 68 | 61 73 20 62 65 65 6e 20 |es .it h|as been |
|00000bf0| 72 75 6e 6e 69 6e 67 20 | 66 6f 72 20 6e 65 61 72 |running |for near|
|00000c00| 6c 79 20 61 20 79 65 61 | 72 20 6e 6f 77 20 77 69 |ly a yea|r now wi|
|00000c10| 74 68 6f 75 74 20 70 72 | 6f 62 6c 65 6d 73 2e 20 |thout pr|oblems. |
|00000c20| 20 53 69 6e 63 65 20 6c | 69 6e 74 0a 69 73 20 61 | Since l|int.is a|
|00000c30| 20 6c 69 63 65 6e 73 65 | 64 20 70 72 6f 67 72 61 | license|d progra|
|00000c40| 6d 2c 20 49 20 63 61 6e | 27 74 20 73 65 6e 64 20 |m, I can|'t send |
|00000c50| 79 6f 75 20 61 20 63 6f | 70 79 2c 20 74 68 6f 75 |you a co|py, thou|
|00000c60| 67 68 20 69 74 20 73 68 | 6f 75 6c 64 6e 27 74 20 |gh it sh|ouldn't |
|00000c70| 62 65 20 0a 68 61 72 64 | 20 74 6f 20 66 69 67 75 |be .hard| to figu|
|00000c80| 72 65 20 6f 75 74 20 68 | 6f 77 20 74 6f 20 6d 6f |re out h|ow to mo|
|00000c90| 64 69 66 79 20 69 74 2e | 20 20 28 4c 69 6e 74 20 |dify it.| (Lint |
|00000ca0| 69 73 20 61 20 73 68 65 | 6c 6c 20 73 63 72 69 70 |is a she|ll scrip|
|00000cb0| 74 2e 29 0a 0a 54 6f 20 | 75 73 65 20 68 61 73 68 |t.)..To |use hash|
|00000cc0| 38 20 77 69 74 68 20 64 | 65 62 75 67 67 65 72 73 |8 with d|ebuggers|
|00000cd0| 2c 20 79 6f 75 20 77 69 | 6c 6c 20 77 61 6e 74 20 |, you wi|ll want |
|00000ce0| 74 6f 20 6d 6f 64 69 66 | 79 20 69 74 20 74 6f 20 |to modif|y it to |
|00000cf0| 74 75 72 6e 20 6f 66 66 | 20 0a 73 74 64 69 6e 2f |turn off| .stdin/|
|00000d00| 73 74 64 6f 75 74 20 62 | 75 66 66 65 72 69 6e 67 |stdout b|uffering|
|00000d10| 2e 0a 0a 54 6f 20 63 6f | 6d 70 69 6c 65 20 74 68 |...To co|mpile th|
|00000d20| 65 20 70 72 6f 67 72 61 | 6d 2c 20 6d 61 6b 65 20 |e progra|m, make |
|00000d30| 61 20 64 69 72 65 63 74 | 6f 72 79 20 61 6e 64 20 |a direct|ory and |
|00000d40| 72 75 6e 20 74 68 65 20 | 73 68 65 6c 6c 20 73 63 |run the |shell sc|
|00000d50| 72 69 70 74 20 62 65 6c | 6f 77 2e 0a 54 68 65 6e |ript bel|ow..Then|
|00000d60| 20 22 6d 61 6b 65 20 68 | 61 73 68 38 22 2e 0a 0a | "make h|ash8"...|
|00000d70| 2d 20 41 72 63 68 20 44 | 2e 20 52 6f 62 69 73 6f |- Arch D|. Robiso|
|00000d80| 6e 0a 20 20 44 65 70 74 | 2e 20 6f 66 20 43 6f 6d |n. Dept|. of Com|
|00000d90| 70 75 74 65 72 20 53 63 | 69 65 6e 63 65 0a 20 20 |puter Sc|ience. |
|00000da0| 55 6e 69 76 65 72 73 69 | 74 79 20 6f 66 20 49 6c |Universi|ty of Il|
|00000db0| 6c 69 6e 6f 69 73 20 61 | 74 20 55 72 62 61 6e 61 |linois a|t Urbana|
|00000dc0| 2d 43 68 61 6d 70 61 69 | 67 6e 0a 0a 20 20 72 6f |-Champai|gn.. ro|
|00000dd0| 62 69 73 6f 6e 40 75 69 | 75 63 64 63 73 0a 0a 53 |bison@ui|ucdcs..S|
|00000de0| 48 41 52 5f 45 4f 46 0a | 66 69 20 23 20 65 6e 64 |HAR_EOF.|fi # end|
|00000df0| 20 6f 66 20 6f 76 65 72 | 77 72 69 74 69 6e 67 20 | of over|writing |
|00000e00| 63 68 65 63 6b 0a 65 63 | 68 6f 20 73 68 61 72 3a |check.ec|ho shar:|
|00000e10| 20 65 78 74 72 61 63 74 | 69 6e 67 20 22 27 44 4f | extract|ing "'DO|
|00000e20| 43 27 22 20 27 28 31 33 | 32 34 20 63 68 61 72 61 |C'" '(13|24 chara|
|00000e30| 63 74 65 72 73 29 27 0a | 69 66 20 74 65 73 74 20 |cters)'.|if test |
|00000e40| 2d 66 20 27 44 4f 43 27 | 0a 74 68 65 6e 0a 09 65 |-f 'DOC'|.then..e|
|00000e50| 63 68 6f 20 73 68 61 72 | 3a 20 77 69 6c 6c 20 6e |cho shar|: will n|
|00000e60| 6f 74 20 6f 76 65 72 2d | 77 72 69 74 65 20 65 78 |ot over-|write ex|
|00000e70| 69 73 74 69 6e 67 20 66 | 69 6c 65 20 22 27 44 4f |isting f|ile "'DO|
|00000e80| 43 27 22 0a 65 6c 73 65 | 0a 63 61 74 20 3c 3c 20 |C'".else|.cat << |
|00000e90| 5c 53 48 41 52 5f 45 4f | 46 20 3e 20 27 44 4f 43 |\SHAR_EO|F > 'DOC|
|00000ea0| 27 0a 48 61 73 68 38 20 | 64 6f 63 75 6d 65 6e 74 |'.Hash8 |document|
|00000eb0| 61 74 69 6f 6e 09 09 09 | 09 41 72 63 68 20 44 2e |ation...|.Arch D.|
|00000ec0| 20 52 6f 62 69 73 6f 6e | 0a 09 09 09 09 09 09 55 | Robison|.......U|
|00000ed0| 6e 69 76 65 72 73 69 74 | 79 20 6f 66 20 49 6c 6c |niversit|y of Ill|
|00000ee0| 69 6e 6f 69 73 0a 09 09 | 09 09 09 09 55 72 62 61 |inois...|....Urba|
|00000ef0| 6e 61 20 43 68 61 6d 70 | 61 69 67 6e 0a 0a 09 09 |na Champ|aign....|
|00000f00| 09 09 09 09 72 6f 62 69 | 73 6f 6e 40 75 69 75 63 |....robi|son@uiuc|
|00000f10| 64 63 73 0a 0a 09 09 09 | 48 61 73 68 38 20 0a 0a |dcs.....|Hash8 ..|
|00000f20| 54 68 65 72 65 20 74 68 | 72 65 65 20 66 69 6c 65 |There th|ree file|
|00000f30| 73 20 28 6f 74 68 65 72 | 20 74 68 61 6e 20 44 4f |s (other| than DO|
|00000f40| 43 29 20 70 72 6f 76 69 | 64 65 64 3a 0a 0a 09 68 |C) provi|ded:...h|
|00000f50| 61 73 68 38 2e 63 20 20 | 20 20 20 73 6f 75 72 63 |ash8.c | sourc|
|00000f60| 65 20 63 6f 64 65 20 66 | 6f 72 20 6c 6f 6e 67 20 |e code f|or long |
|00000f70| 69 64 65 6e 74 69 66 69 | 65 72 20 63 6f 6e 76 65 |identifi|er conve|
|00000f80| 72 74 65 72 0a 09 4d 61 | 6b 65 66 69 6c 65 20 20 |rter..Ma|kefile |
|00000f90| 20 20 65 78 61 6d 70 6c | 65 20 6d 61 6b 65 66 69 | exampl|e makefi|
|00000fa0| 6c 65 0a 09 6e 63 63 09 | 20 20 20 20 73 68 65 6c |le..ncc.| shel|
|00000fb0| 6c 20 73 63 72 69 70 74 | 20 66 6f 72 20 63 6f 6d |l script| for com|
|00000fc0| 70 69 6c 69 6e 67 0a 0a | 54 68 65 20 68 61 73 68 |piling..|The hash|
|00000fd0| 38 20 70 72 6f 67 72 61 | 6d 20 61 6c 6c 6f 77 73 |8 progra|m allows|
|00000fe0| 20 73 68 6f 72 74 2d 69 | 64 65 6e 74 69 66 69 65 | short-i|dentifie|
|00000ff0| 72 20 43 20 63 6f 6d 70 | 69 6c 65 72 73 20 74 6f |r C comp|ilers to|
|00001000| 20 63 6f 6d 70 69 6c 65 | 0a 6c 6f 6e 67 2d 69 64 | compile|.long-id|
|00001010| 65 6e 74 69 66 69 65 72 | 20 70 72 6f 67 72 61 6d |entifier| program|
|00001020| 73 2e 20 20 49 74 20 69 | 73 20 6e 6f 74 20 69 6e |s. It i|s not in|
|00001030| 74 65 6e 65 64 20 66 6f | 72 20 70 72 6f 64 75 63 |tened fo|r produc|
|00001040| 74 69 6f 6e 20 75 73 65 | 2c 0a 62 75 74 20 66 6f |tion use|,.but fo|
|00001050| 72 20 71 75 69 63 6b 6c | 79 20 70 6f 72 74 69 6e |r quickl|y portin|
|00001060| 67 20 6c 6f 6e 67 2d 69 | 64 65 6e 74 69 66 69 65 |g long-i|dentifie|
|00001070| 72 20 70 72 6f 67 72 61 | 6d 73 2e 0a 0a 53 65 65 |r progra|ms...See|
|00001080| 20 74 68 65 20 64 6f 63 | 75 6d 65 6e 74 61 74 69 | the doc|umentati|
|00001090| 6f 6e 20 69 6e 20 68 61 | 73 68 38 2e 63 20 61 6e |on in ha|sh8.c an|
|000010a0| 64 20 74 68 65 20 4d 61 | 6b 65 66 69 6c 65 20 66 |d the Ma|kefile f|
|000010b0| 6f 72 20 68 6f 77 20 74 | 6f 20 75 73 65 20 69 74 |or how t|o use it|
|000010c0| 20 77 69 74 68 20 63 63 | 2e 0a 0a 2d 2d 2d 2d 2d | with cc|...-----|
|000010d0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000010e0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000010f0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001100| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001110| 2d 0a 0a 09 09 09 48 61 | 73 68 38 20 77 69 74 68 |-.....Ha|sh8 with|
|00001120| 20 6c 69 6e 74 0a 0a 49 | 27 76 65 20 62 65 65 6e | lint..I|'ve been|
|00001130| 20 61 62 6c 65 20 74 6f | 20 68 61 63 6b 20 61 20 | able to| hack a |
|00001140| 73 68 6f 72 74 20 69 64 | 65 6e 74 69 66 69 65 72 |short id|entifier|
|00001150| 20 6c 69 6e 74 20 77 69 | 74 68 20 22 68 61 73 68 | lint wi|th "hash|
|00001160| 38 22 20 73 6f 20 69 74 | 20 77 6f 75 6c 64 20 77 |8" so it| would w|
|00001170| 6f 72 6b 0a 77 69 74 68 | 20 6c 6f 6e 67 20 69 64 |ork.with| long id|
|00001180| 65 6e 74 69 66 69 65 72 | 20 70 72 6f 67 72 61 6d |entifier| program|
|00001190| 73 2e 20 20 54 68 69 73 | 20 77 61 73 20 61 6e 20 |s. This| was an |
|000011a0| 65 61 73 79 20 6d 6f 64 | 69 66 69 63 61 74 69 6f |easy mod|ificatio|
|000011b0| 6e 20 73 69 6e 63 65 20 | 6c 69 6e 74 20 69 73 0a |n since |lint is.|
|000011c0| 61 20 73 68 65 6c 6c 20 | 73 63 72 69 70 74 2e 20 |a shell |script. |
|000011d0| 20 54 68 65 20 22 68 61 | 73 68 38 20 65 6e 63 6f | The "ha|sh8 enco|
|000011e0| 64 65 22 20 66 69 6c 74 | 65 72 20 77 61 73 20 70 |de" filt|er was p|
|000011f0| 75 74 20 69 6e 20 62 65 | 74 77 65 65 6e 20 2f 6c |ut in be|tween /l|
|00001200| 69 62 2f 63 70 70 20 61 | 6e 64 20 0a 2f 75 73 72 |ib/cpp a|nd ./usr|
|00001210| 2f 6c 69 62 2f 6c 69 6e | 74 2f 6c 69 6e 74 20 61 |/lib/lin|t/lint a|
|00001220| 6e 64 20 61 6c 6c 20 65 | 72 72 6f 72 20 6d 65 73 |nd all e|rror mes|
|00001230| 73 61 67 65 20 77 72 69 | 74 74 65 6e 20 74 6f 20 |sage wri|tten to |
|00001240| 61 20 74 65 6d 70 6f 72 | 61 72 79 20 66 69 6c 65 |a tempor|ary file|
|00001250| 2e 0a 54 68 65 6e 20 22 | 68 61 73 68 38 20 64 65 |..Then "|hash8 de|
|00001260| 63 6f 64 65 22 20 77 61 | 73 20 75 73 65 64 20 74 |code" wa|s used t|
|00001270| 6f 20 64 65 63 6f 64 65 | 20 74 68 65 20 65 72 72 |o decode| the err|
|00001280| 6f 72 20 6d 65 73 73 61 | 67 65 73 2e 0a 0a 4e 6f |or messa|ges...No|
|00001290| 74 65 20 74 68 61 74 20 | 68 61 73 68 38 27 73 20 |te that |hash8's |
|000012a0| 63 61 6e 20 6e 6f 74 20 | 72 75 6e 20 69 6e 20 70 |can not |run in p|
|000012b0| 61 72 61 6c 6c 65 6c 2c | 20 73 69 6e 63 65 20 74 |arallel,| since t|
|000012c0| 68 65 20 69 64 65 6e 74 | 69 66 69 65 72 20 6d 61 |he ident|ifier ma|
|000012d0| 70 20 69 73 20 72 65 61 | 64 20 61 6c 6c 0a 61 74 |p is rea|d all.at|
|000012e0| 20 6f 6e 63 65 20 61 6e | 64 20 77 72 69 74 74 65 | once an|d writte|
|000012f0| 6e 20 61 6c 6c 20 61 74 | 20 6f 6e 63 65 2e 0a 0a |n all at| once...|
|00001300| 54 68 75 73 20 79 6f 75 | 20 63 61 6e 27 74 20 28 |Thus you| can't (|
|00001310| 72 65 67 72 65 74 74 61 | 62 6c 79 29 20 64 6f 3a |regretta|bly) do:|
|00001320| 20 0a 0a 20 20 20 20 20 | 68 61 73 68 38 20 65 6e | .. |hash8 en|
|00001330| 63 6f 64 65 20 54 41 42 | 4c 45 20 7c 20 2f 6c 69 |code TAB|LE | /li|
|00001340| 62 2f 63 70 70 20 7c 20 | 68 61 73 68 38 20 64 65 |b/cpp | |hash8 de|
|00001350| 63 6f 64 65 20 54 41 42 | 4c 45 0a 0a 54 68 65 20 |code TAB|LE..The |
|00001360| 61 62 6f 76 65 20 77 6f | 75 6c 64 20 68 61 76 65 |above wo|uld have|
|00001370| 20 74 6f 20 62 65 20 77 | 72 69 74 74 65 6e 3a 0a | to be w|ritten:.|
|00001380| 0a 20 20 20 20 20 68 61 | 73 68 38 20 65 6e 63 6f |. ha|sh8 enco|
|00001390| 64 65 20 54 41 42 4c 45 | 20 3e 54 45 4d 50 0a 20 |de TABLE| >TEMP. |
|000013a0| 20 20 20 20 63 61 74 20 | 54 45 4d 50 20 7c 20 2f | cat |TEMP | /|
|000013b0| 6c 69 62 2f 63 70 70 20 | 7c 20 68 61 73 68 38 20 |lib/cpp || hash8 |
|000013c0| 64 65 63 6f 64 65 20 54 | 41 42 4c 45 0a 0a 53 48 |decode T|ABLE..SH|
|000013d0| 41 52 5f 45 4f 46 0a 66 | 69 20 23 20 65 6e 64 20 |AR_EOF.f|i # end |
|000013e0| 6f 66 20 6f 76 65 72 77 | 72 69 74 69 6e 67 20 63 |of overw|riting c|
|000013f0| 68 65 63 6b 0a 65 63 68 | 6f 20 73 68 61 72 3a 20 |heck.ech|o shar: |
|00001400| 65 78 74 72 61 63 74 69 | 6e 67 20 22 27 4d 61 6b |extracti|ng "'Mak|
|00001410| 65 66 69 6c 65 27 22 20 | 27 28 31 38 32 39 20 63 |efile'" |'(1829 c|
|00001420| 68 61 72 61 63 74 65 72 | 73 29 27 0a 69 66 20 74 |haracter|s)'.if t|
|00001430| 65 73 74 20 2d 66 20 27 | 4d 61 6b 65 66 69 6c 65 |est -f '|Makefile|
|00001440| 27 0a 74 68 65 6e 0a 09 | 65 63 68 6f 20 73 68 61 |'.then..|echo sha|
|00001450| 72 3a 20 77 69 6c 6c 20 | 6e 6f 74 20 6f 76 65 72 |r: will |not over|
|00001460| 2d 77 72 69 74 65 20 65 | 78 69 73 74 69 6e 67 20 |-write e|xisting |
|00001470| 66 69 6c 65 20 22 27 4d | 61 6b 65 66 69 6c 65 27 |file "'M|akefile'|
|00001480| 22 0a 65 6c 73 65 0a 63 | 61 74 20 3c 3c 20 5c 53 |".else.c|at << \S|
|00001490| 48 41 52 5f 45 4f 46 20 | 3e 20 27 4d 61 6b 65 66 |HAR_EOF |> 'Makef|
|000014a0| 69 6c 65 27 0a 23 20 48 | 65 72 65 20 69 73 20 74 |ile'.# H|ere is t|
|000014b0| 68 65 20 6f 72 69 67 69 | 6e 61 6c 20 6d 61 6b 65 |he origi|nal make|
|000014c0| 66 69 6c 65 20 66 6f 72 | 20 61 20 73 61 6d 70 6c |file for| a sampl|
|000014d0| 65 20 70 72 6f 67 72 61 | 6d 20 77 69 74 68 20 6c |e progra|m with l|
|000014e0| 6f 6e 67 20 69 64 65 6e | 74 69 66 69 65 72 73 2e |ong iden|tifiers.|
|000014f0| 0a 23 0a 23 73 6e 61 6b | 65 6f 6d 61 74 69 63 3a |.#.#snak|eomatic:|
|00001500| 09 6d 61 69 6e 2e 6f 20 | 6d 6f 76 65 2e 6f 20 73 |.main.o |move.o s|
|00001510| 63 72 65 65 6e 2e 6f 0a | 23 09 09 63 63 20 6d 61 |creen.o.|#..cc ma|
|00001520| 69 6e 2e 6f 20 6d 6f 76 | 65 2e 6f 20 73 63 72 65 |in.o mov|e.o scre|
|00001530| 65 6e 2e 6f 20 2d 6c 6d | 0a 23 0a 23 6d 61 69 6e |en.o -lm|.#.#main|
|00001540| 2e 6f 3a 09 73 6e 61 6b | 65 6f 6d 61 74 69 63 2e |.o:.snak|eomatic.|
|00001550| 68 20 6d 61 69 6e 2e 63 | 0a 23 09 09 63 63 20 2d |h main.c|.#..cc -|
|00001560| 63 20 6d 61 69 6e 2e 63 | 0a 23 0a 23 6d 6f 76 65 |c main.c|.#.#move|
|00001570| 2e 6f 3a 09 09 73 6e 61 | 6b 65 6f 6d 61 74 69 63 |.o:..sna|keomatic|
|00001580| 2e 68 20 6d 6f 76 65 2e | 63 0a 23 09 09 63 63 20 |.h move.|c.#..cc |
|00001590| 2d 63 20 6d 6f 76 65 2e | 63 0a 23 0a 23 73 63 72 |-c move.|c.#.#scr|
|000015a0| 65 65 6e 2e 6f 3a 09 73 | 6e 61 6b 65 6f 6d 61 74 |een.o:.s|nakeomat|
|000015b0| 69 63 2e 68 20 73 63 72 | 65 65 6e 2e 63 0a 23 09 |ic.h scr|een.c.#.|
|000015c0| 09 63 63 20 2d 63 20 73 | 63 72 65 65 6e 2e 63 0a |.cc -c s|creen.c.|
|000015d0| 0a 23 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |.#------|--------|
|000015e0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000015f0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001600| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001610| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 0a 23 0a |--------|-----.#.|
|00001620| 23 20 4d 61 6b 65 66 69 | 6c 65 20 6d 6f 64 69 66 |# Makefi|le modif|
|00001630| 69 65 64 20 66 6f 72 20 | 68 61 73 68 38 2e 20 20 |ied for |hash8. |
|00001640| 45 61 63 68 20 73 6f 75 | 72 63 65 20 66 69 6c 65 |Each sou|rce file|
|00001650| 20 78 78 78 20 68 61 73 | 20 62 65 65 6e 20 72 65 | xxx has| been re|
|00001660| 6e 61 6d 65 64 20 4c 5f | 78 78 78 2e 0a 23 20 54 |named L_|xxx..# T|
|00001670| 68 65 20 22 6e 63 63 22 | 20 73 68 65 6c 6c 20 73 |he "ncc"| shell s|
|00001680| 63 72 69 70 74 20 66 69 | 6c 74 65 72 73 20 65 61 |cript fi|lters ea|
|00001690| 63 68 20 4c 5f 78 78 78 | 20 66 69 6c 65 20 77 69 |ch L_xxx| file wi|
|000016a0| 74 68 20 68 61 73 68 38 | 20 61 6e 64 20 70 75 74 |th hash8| and put|
|000016b0| 73 0a 23 20 74 68 65 20 | 72 65 73 75 6c 74 20 69 |s.# the |result i|
|000016c0| 6e 20 66 69 6c 65 20 78 | 78 78 2c 20 77 68 69 63 |n file x|xx, whic|
|000016d0| 68 20 69 73 20 74 68 65 | 6e 20 63 6f 6d 70 69 6c |h is the|n compil|
|000016e0| 65 64 2e 0a 23 0a 23 20 | 41 6c 73 6f 20 6e 6f 74 |ed..#.# |Also not|
|000016f0| 65 20 74 68 61 74 20 61 | 6e 79 20 2e 68 20 66 69 |e that a|ny .h fi|
|00001700| 6c 65 20 6d 75 73 74 20 | 61 6c 73 6f 20 62 65 20 |le must |also be |
|00001710| 66 69 6c 74 65 72 65 64 | 20 62 79 20 68 61 73 68 |filtered| by hash|
|00001720| 38 2e 0a 23 0a 23 20 54 | 68 65 20 66 69 6c 65 20 |8..#.# T|he file |
|00001730| 54 41 42 4c 45 20 69 73 | 20 74 68 65 20 69 64 65 |TABLE is| the ide|
|00001740| 6e 74 69 66 69 65 72 20 | 6d 61 70 70 69 6e 67 20 |ntifier |mapping |
|00001750| 74 61 62 6c 65 2e 20 20 | 59 6f 75 20 73 68 6f 75 |table. |You shou|
|00001760| 6c 64 20 22 6d 61 6b 65 | 20 54 41 42 4c 45 22 0a |ld "make| TABLE".|
|00001770| 23 20 62 65 66 6f 72 65 | 20 79 6f 75 72 20 66 69 |# before| your fi|
|00001780| 72 73 74 20 63 6f 6d 70 | 69 6c 61 74 69 6f 6e 20 |rst comp|ilation |
|00001790| 74 6f 20 69 6e 69 74 69 | 6c 69 7a 65 20 74 68 65 |to initi|lize the|
|000017a0| 20 6d 61 70 70 69 6e 67 | 20 74 61 62 6c 65 2e 0a | mapping| table..|
|000017b0| 23 20 41 66 74 65 72 20 | 74 68 61 74 2c 20 79 6f |# After |that, yo|
|000017c0| 75 20 73 68 6f 75 6c 64 | 20 6e 6f 74 20 68 61 76 |u should| not hav|
|000017d0| 65 20 74 6f 20 72 65 6d | 61 6b 65 20 74 68 65 20 |e to rem|ake the |
|000017e0| 74 61 62 6c 65 2c 20 65 | 76 65 6e 20 69 66 20 79 |table, e|ven if y|
|000017f0| 6f 75 0a 23 20 6d 61 6b | 65 20 63 6f 72 72 65 63 |ou.# mak|e correc|
|00001800| 74 69 6f 6e 73 20 69 6e | 20 74 68 65 20 63 6f 64 |tions in| the cod|
|00001810| 65 2e 20 20 48 61 73 68 | 38 20 77 69 6c 6c 20 61 |e. Hash|8 will a|
|00001820| 75 74 6f 6d 61 74 69 63 | 61 6c 6c 79 20 75 70 64 |utomatic|ally upd|
|00001830| 61 74 65 0a 23 20 74 68 | 65 20 74 61 62 6c 65 20 |ate.# th|e table |
|00001840| 77 68 65 6e 20 6e 65 63 | 65 73 73 61 72 79 2e 0a |when nec|essary..|
|00001850| 23 0a 53 59 53 54 45 4d | 20 3d 20 2f 75 73 72 2f |#.SYSTEM| = /usr/|
|00001860| 69 6e 63 6c 75 64 65 2f | 73 74 64 69 6f 20 2f 75 |include/|stdio /u|
|00001870| 73 72 2f 69 6e 63 6c 75 | 64 65 2f 73 69 67 6e 61 |sr/inclu|de/signa|
|00001880| 6c 2e 68 20 2f 75 73 72 | 2f 69 6e 63 6c 75 64 65 |l.h /usr|/include|
|00001890| 2f 73 67 74 74 79 2e 68 | 20 0a 0a 73 6e 61 6b 65 |/sgtty.h| ..snake|
|000018a0| 6f 6d 61 74 69 63 3a 09 | 6d 61 69 6e 2e 6f 20 6d |omatic:.|main.o m|
|000018b0| 6f 76 65 2e 6f 20 73 63 | 72 65 65 6e 2e 6f 0a 09 |ove.o sc|reen.o..|
|000018c0| 09 63 63 20 6d 61 69 6e | 2e 6f 20 6d 6f 76 65 2e |.cc main|.o move.|
|000018d0| 6f 20 73 63 72 65 65 6e | 2e 6f 20 2d 6c 6d 20 32 |o screen|.o -lm 2|
|000018e0| 3e 26 31 20 7c 20 68 61 | 73 68 38 20 5f 64 65 63 |>&1 | ha|sh8 _dec|
|000018f0| 6f 64 65 20 54 41 42 4c | 45 0a 0a 6d 61 69 6e 2e |ode TABL|E..main.|
|00001900| 6f 3a 09 09 73 6e 61 6b | 65 6f 6d 61 74 69 63 2e |o:..snak|eomatic.|
|00001910| 68 20 4c 5f 6d 61 69 6e | 2e 63 0a 09 09 6e 63 63 |h L_main|.c...ncc|
|00001920| 20 6d 61 69 6e 2e 63 0a | 0a 6d 6f 76 65 2e 6f 3a | main.c.|.move.o:|
|00001930| 09 09 73 6e 61 6b 65 6f | 6d 61 74 69 63 2e 68 20 |..snakeo|matic.h |
|00001940| 4c 5f 6d 6f 76 65 2e 63 | 0a 09 09 6e 63 63 20 6d |L_move.c|...ncc m|
|00001950| 6f 76 65 2e 63 0a 0a 73 | 63 72 65 65 6e 2e 6f 3a |ove.c..s|creen.o:|
|00001960| 09 73 6e 61 6b 65 6f 6d | 61 74 69 63 2e 68 20 4c |.snakeom|atic.h L|
|00001970| 5f 73 63 72 65 65 6e 2e | 63 0a 09 09 6e 63 63 20 |_screen.|c...ncc |
|00001980| 73 63 72 65 65 6e 2e 63 | 0a 0a 73 6e 61 6b 65 6f |screen.c|..snakeo|
|00001990| 6d 61 74 69 63 2e 68 3a | 20 20 4c 5f 73 6e 61 6b |matic.h:| L_snak|
|000019a0| 65 6f 6d 61 74 69 63 2e | 68 0a 09 09 63 61 74 20 |eomatic.|h...cat |
|000019b0| 4c 5f 73 6e 61 6b 65 6f | 6d 61 74 69 63 2e 68 20 |L_snakeo|matic.h |
|000019c0| 7c 20 68 61 73 68 38 20 | 65 6e 63 6f 64 65 20 54 || hash8 |encode T|
|000019d0| 41 42 4c 45 20 3e 73 6e | 61 6b 65 6f 6d 61 74 69 |ABLE >sn|akeomati|
|000019e0| 63 2e 68 0a 0a 23 0a 23 | 20 57 68 65 6e 20 74 68 |c.h..#.#| When th|
|000019f0| 65 20 69 64 65 6e 74 69 | 66 69 65 72 20 6d 61 70 |e identi|fier map|
|00001a00| 20 69 73 20 66 69 72 73 | 74 20 63 72 65 61 74 65 | is firs|t create|
|00001a10| 64 2c 20 61 6c 6c 20 74 | 68 65 20 73 79 73 74 65 |d, all t|he syste|
|00001a20| 6d 20 23 69 6e 63 6c 75 | 64 65 20 66 69 6c 65 73 |m #inclu|de files|
|00001a30| 0a 23 20 73 68 6f 75 6c | 64 20 62 65 20 72 75 6e |.# shoul|d be run|
|00001a40| 20 74 68 72 6f 75 67 68 | 20 68 61 73 68 38 2e 20 | through| hash8. |
|00001a50| 20 54 68 69 73 20 75 73 | 75 61 6c 6c 79 20 6e 6f | This us|ually no|
|00001a60| 74 20 6e 65 63 65 73 73 | 61 72 79 2c 20 62 75 74 |t necess|ary, but|
|00001a70| 20 69 74 0a 23 20 69 73 | 20 70 6f 73 73 69 62 6c | it.# is| possibl|
|00001a80| 65 20 74 68 61 74 20 79 | 6f 75 72 20 70 72 6f 67 |e that y|our prog|
|00001a90| 72 61 6d 27 73 20 69 64 | 65 6e 74 69 66 69 65 72 |ram's id|entifier|
|00001aa0| 73 20 63 6f 75 6c 64 20 | 68 61 76 65 20 61 20 63 |s could |have a c|
|00001ab0| 6f 6d 6d 6f 6e 20 70 72 | 65 66 69 78 0a 23 20 77 |ommon pr|efix.# w|
|00001ac0| 69 74 68 20 61 20 73 79 | 73 74 65 6d 20 69 64 65 |ith a sy|stem ide|
|00001ad0| 6e 74 69 66 69 65 72 2e | 20 20 42 79 20 70 72 6f |ntifier.| By pro|
|00001ae0| 63 65 73 73 69 6e 67 20 | 74 68 65 20 73 79 73 74 |cessing |the syst|
|00001af0| 65 6d 20 23 69 6e 63 6c | 75 64 65 20 66 69 6c 65 |em #incl|ude file|
|00001b00| 73 20 66 69 72 73 74 2c | 0a 23 20 77 65 20 65 6e |s first,|.# we en|
|00001b10| 73 75 72 65 20 74 68 61 | 74 20 74 68 6f 73 65 20 |sure tha|t those |
|00001b20| 69 64 65 6e 74 69 66 69 | 65 72 73 20 77 69 6c 6c |identifi|ers will|
|00001b30| 20 6e 6f 74 20 62 65 20 | 63 68 61 6e 67 65 64 2e | not be |changed.|
|00001b40| 0a 23 0a 54 41 42 4c 45 | 3a 09 09 68 61 73 68 38 |.#.TABLE|:..hash8|
|00001b50| 20 24 28 53 59 53 54 45 | 4d 29 0a 09 09 72 6d 20 | $(SYSTE|M)...rm |
|00001b60| 2d 66 20 54 41 42 4c 45 | 0a 09 09 63 61 74 20 24 |-f TABLE|...cat $|
|00001b70| 28 53 59 53 54 45 4d 29 | 20 7c 20 68 61 73 68 38 |(SYSTEM)| | hash8|
|00001b80| 20 65 6e 63 6f 64 65 20 | 54 41 42 4c 45 20 3e 2f | encode |TABLE >/|
|00001b90| 64 65 76 2f 6e 75 6c 6c | 0a 0a 68 61 73 68 38 3a |dev/null|..hash8:|
|00001ba0| 09 09 68 61 73 68 38 2e | 63 0a 09 09 63 63 20 24 |..hash8.|c...cc $|
|00001bb0| 28 43 46 4c 41 47 53 29 | 20 68 61 73 68 38 2e 63 |(CFLAGS)| hash8.c|
|00001bc0| 20 2d 6f 20 68 61 73 68 | 38 0a 53 48 41 52 5f 45 | -o hash|8.SHAR_E|
|00001bd0| 4f 46 0a 66 69 20 23 20 | 65 6e 64 20 6f 66 20 6f |OF.fi # |end of o|
|00001be0| 76 65 72 77 72 69 74 69 | 6e 67 20 63 68 65 63 6b |verwriti|ng check|
|00001bf0| 0a 65 63 68 6f 20 73 68 | 61 72 3a 20 65 78 74 72 |.echo sh|ar: extr|
|00001c00| 61 63 74 69 6e 67 20 22 | 27 68 61 73 68 38 2e 63 |acting "|'hash8.c|
|00001c10| 27 22 20 27 28 31 31 32 | 30 30 20 63 68 61 72 61 |'" '(112|00 chara|
|00001c20| 63 74 65 72 73 29 27 0a | 69 66 20 74 65 73 74 20 |cters)'.|if test |
|00001c30| 2d 66 20 27 68 61 73 68 | 38 2e 63 27 0a 74 68 65 |-f 'hash|8.c'.the|
|00001c40| 6e 0a 09 65 63 68 6f 20 | 73 68 61 72 3a 20 77 69 |n..echo |shar: wi|
|00001c50| 6c 6c 20 6e 6f 74 20 6f | 76 65 72 2d 77 72 69 74 |ll not o|ver-writ|
|00001c60| 65 20 65 78 69 73 74 69 | 6e 67 20 66 69 6c 65 20 |e existi|ng file |
|00001c70| 22 27 68 61 73 68 38 2e | 63 27 22 0a 65 6c 73 65 |"'hash8.|c'".else|
|00001c80| 0a 63 61 74 20 3c 3c 20 | 5c 53 48 41 52 5f 45 4f |.cat << |\SHAR_EO|
|00001c90| 46 20 3e 20 27 68 61 73 | 68 38 2e 63 27 0a 2f 2a |F > 'has|h8.c'./*|
|00001ca0| 0a 20 2a 20 44 61 74 65 | 3a 20 4d 61 72 63 68 20 |. * Date|: March |
|00001cb0| 31 37 20 31 39 38 35 09 | 09 09 41 75 74 68 6f 72 |17 1985.|..Author|
|00001cc0| 3a 20 41 72 63 68 20 44 | 2e 20 52 6f 62 69 73 6f |: Arch D|. Robiso|
|00001cd0| 6e 0a 20 2a 09 09 09 09 | 09 09 44 65 70 74 2e 20 |n. *....|..Dept. |
|00001ce0| 6f 66 20 43 6f 6d 70 75 | 74 65 72 20 53 63 69 65 |of Compu|ter Scie|
|00001cf0| 6e 63 65 0a 20 2a 09 09 | 09 09 09 09 55 6e 69 76 |nce. *..|....Univ|
|00001d00| 65 72 73 69 74 79 20 6f | 66 20 49 6c 6c 69 6e 6f |ersity o|f Illino|
|00001d10| 69 73 0a 20 2a 09 09 09 | 09 09 09 55 72 62 61 6e |is. *...|...Urban|
|00001d20| 61 2d 43 68 61 6d 70 61 | 69 67 6e 0a 20 2a 0a 20 |a-Champa|ign. *. |
|00001d30| 2a 09 09 09 09 09 55 53 | 45 4e 45 54 3a 09 72 6f |*.....US|ENET:.ro|
|00001d40| 62 69 73 6f 6e 40 75 69 | 75 63 64 63 73 0a 20 2a |bison@ui|ucdcs. *|
|00001d50| 0a 20 2a 20 48 61 73 68 | 38 20 63 6f 70 69 65 73 |. * Hash|8 copies|
|00001d60| 20 73 74 64 69 6e 20 74 | 6f 20 73 74 64 6f 75 74 | stdin t|o stdout|
|00001d70| 2c 20 77 68 69 6c 65 20 | 72 65 70 6c 61 63 69 6e |, while |replacin|
|00001d80| 67 20 63 65 72 74 61 69 | 6e 20 69 64 65 6e 74 69 |g certai|n identi|
|00001d90| 66 69 65 72 73 2e 0a 20 | 2a 20 6c 69 6e 74 20 63 |fiers.. |* lint c|
|00001da0| 61 6e 20 62 65 20 63 6f | 6e 76 65 72 74 65 64 20 |an be co|nverted |
|00001db0| 74 6f 20 61 63 63 65 70 | 74 20 6c 6f 6e 67 20 69 |to accep|t long i|
|00001dc0| 64 65 6e 74 69 66 69 65 | 72 73 20 62 79 20 68 61 |dentifie|rs by ha|
|00001dd0| 63 6b 69 6e 67 20 69 6e | 20 68 61 73 68 38 0a 20 |cking in| hash8. |
|00001de0| 2a 20 62 65 74 77 65 65 | 6e 20 2f 6c 69 62 2f 63 |* betwee|n /lib/c|
|00001df0| 70 70 20 61 6e 64 20 2f | 75 73 72 2f 6c 69 62 2f |pp and /|usr/lib/|
|00001e00| 6c 69 6e 74 2f 6c 69 6e | 74 20 61 70 70 72 6f 70 |lint/lin|t approp|
|00001e10| 72 69 61 74 65 6c 79 2e | 0a 20 2a 0a 20 2a 20 54 |riately.|. *. * T|
|00001e20| 68 65 72 65 20 61 72 65 | 20 74 68 72 65 65 20 77 |here are| three w|
|00001e30| 61 79 73 20 74 6f 20 63 | 61 6c 6c 20 68 61 73 68 |ays to c|all hash|
|00001e40| 38 3a 0a 20 2a 0a 20 2a | 20 20 20 20 20 68 61 73 |8:. *. *| has|
|00001e50| 68 38 20 65 6e 63 6f 64 | 65 20 74 61 62 6c 65 0a |h8 encod|e table.|
|00001e60| 20 2a 20 20 20 20 20 20 | 20 20 20 4d 61 70 20 6c | * | Map l|
|00001e70| 6f 6e 67 20 69 64 65 6e | 74 69 66 69 65 72 73 20 |ong iden|tifiers |
|00001e80| 61 6e 64 20 74 68 6f 73 | 65 20 62 65 67 69 6e 6e |and thos|e beginn|
|00001e90| 69 6e 67 20 77 69 74 68 | 20 51 20 0a 20 2a 09 20 |ing with| Q . *. |
|00001ea0| 20 20 69 6e 74 6f 20 73 | 68 6f 72 74 20 69 64 65 | into s|hort ide|
|00001eb0| 6e 74 69 66 69 65 72 73 | 20 51 25 64 0a 20 2a 0a |ntifiers| Q%d. *.|
|00001ec0| 20 2a 20 20 20 20 20 68 | 61 73 68 38 20 64 65 63 | * h|ash8 dec|
|00001ed0| 6f 64 65 20 74 61 62 6c | 65 0a 20 2a 20 20 20 20 |ode tabl|e. * |
|00001ee0| 20 20 20 20 20 4d 61 70 | 20 73 68 6f 72 74 20 69 | Map| short i|
|00001ef0| 64 65 6e 74 69 66 69 65 | 72 73 20 51 25 64 20 69 |dentifie|rs Q%d i|
|00001f00| 6e 74 6f 20 74 68 65 69 | 72 20 6c 6f 6e 67 20 65 |nto thei|r long e|
|00001f10| 71 75 69 76 61 6c 65 6e | 74 73 0a 20 2a 0a 20 2a |quivalen|ts. *. *|
|00001f20| 20 20 20 20 20 68 61 73 | 68 38 20 5f 64 65 63 6f | has|h8 _deco|
|00001f30| 64 65 20 74 61 62 6c 65 | 0a 20 2a 20 20 20 20 20 |de table|. * |
|00001f40| 20 20 20 20 4d 61 70 20 | 73 68 6f 72 74 20 69 64 | Map |short id|
|00001f50| 65 6e 74 69 66 69 65 72 | 73 20 5f 51 25 64 20 69 |entifier|s _Q%d i|
|00001f60| 6e 74 6f 20 74 68 65 69 | 72 20 6c 6f 6e 67 20 65 |nto thei|r long e|
|00001f70| 71 75 69 76 61 6c 65 6e | 74 73 0a 20 2a 20 09 20 |quivalen|ts. * . |
|00001f80| 20 20 54 68 69 73 20 69 | 73 20 75 73 65 64 20 74 | This i|s used t|
|00001f90| 6f 20 64 65 63 6f 64 65 | 20 74 68 65 20 6c 69 6e |o decode| the lin|
|00001fa0| 6b 65 72 27 73 20 65 72 | 72 6f 72 20 6d 65 73 73 |ker's er|ror mess|
|00001fb0| 61 67 65 73 0a 20 2a 0a | 20 2a 20 54 68 65 20 27 |ages. *.| * The '|
|00001fc0| 74 61 62 6c 65 27 20 61 | 72 67 75 6d 65 6e 74 20 |table' a|rgument |
|00001fd0| 69 73 20 74 68 65 20 66 | 69 6c 65 20 6e 61 6d 65 |is the f|ile name|
|00001fe0| 20 66 6f 72 20 74 68 65 | 20 69 64 65 6e 74 69 66 | for the| identif|
|00001ff0| 69 65 72 20 6d 61 70 2e | 0a 20 2a 20 54 68 65 20 |ier map.|. * The |
|00002000| 27 65 6e 63 6f 64 65 27 | 20 63 61 6c 6c 73 20 77 |'encode'| calls w|
|00002010| 69 6c 6c 20 65 69 74 68 | 65 72 20 63 72 65 61 74 |ill eith|er creat|
|00002020| 65 20 6f 72 20 65 78 70 | 61 6e 64 20 74 68 65 20 |e or exp|and the |
|00002030| 74 61 62 6c 65 2e 0a 20 | 2a 0a 20 2a 20 54 79 70 |table.. |*. * Typ|
|00002040| 69 63 61 6c 6c 79 2c 20 | 74 68 65 20 65 6e 63 6f |ically, |the enco|
|00002050| 64 65 20 6f 70 74 69 6f | 6e 20 69 73 20 75 73 65 |de optio|n is use|
|00002060| 64 20 74 6f 20 70 72 65 | 70 72 6f 63 65 73 73 20 |d to pre|process |
|00002070| 69 6e 70 75 74 20 74 6f | 20 74 68 65 20 63 6f 6d |input to| the com|
|00002080| 70 69 6c 65 72 0a 20 2a | 20 6f 72 20 6c 69 6e 74 |piler. *| or lint|
|00002090| 2c 20 61 6e 64 20 74 68 | 65 20 64 65 63 6f 64 65 |, and th|e decode|
|000020a0| 20 6f 70 74 69 6f 6e 20 | 69 73 20 75 73 65 64 20 | option |is used |
|000020b0| 74 6f 20 64 65 63 6f 64 | 65 20 65 72 72 6f 72 20 |to decod|e error |
|000020c0| 6d 65 73 73 61 67 65 73 | 20 66 72 6f 6d 0a 20 2a |messages| from. *|
|000020d0| 20 74 68 65 20 63 6f 6d | 70 69 6c 65 72 2e 0a 20 | the com|piler.. |
|000020e0| 2a 0a 20 2a 20 54 68 65 | 20 63 6f 6e 73 74 61 6e |*. * The| constan|
|000020f0| 74 20 48 41 53 48 42 49 | 54 53 20 6d 61 79 20 6e |t HASHBI|TS may n|
|00002100| 65 65 64 20 74 6f 20 62 | 65 20 63 68 61 6e 67 65 |eed to b|e change|
|00002110| 64 2e 20 20 49 74 20 69 | 73 20 74 68 65 20 62 61 |d. It i|s the ba|
|00002120| 73 65 20 74 77 6f 0a 20 | 2a 20 6c 6f 67 20 6f 66 |se two. |* log of|
|00002130| 20 74 68 65 20 6e 75 6d | 62 65 72 20 6f 66 20 64 | the num|ber of d|
|00002140| 69 73 74 69 6e 63 74 20 | 6c 6f 6e 67 20 69 64 65 |istinct |long ide|
|00002150| 6e 74 69 66 69 65 72 73 | 20 77 68 69 63 68 20 6d |ntifiers| which m|
|00002160| 61 79 20 62 65 20 66 6f | 75 6e 64 2e 0a 20 2a 20 |ay be fo|und.. * |
|00002170| 45 2e 67 2e 20 74 68 65 | 20 76 61 6c 75 65 20 6f |E.g. the| value o|
|00002180| 66 20 31 32 20 61 6c 6c | 6f 77 73 20 66 6f 72 20 |f 12 all|ows for |
|00002190| 34 30 39 36 20 6c 6f 6e | 67 20 69 64 65 6e 74 69 |4096 lon|g identi|
|000021a0| 66 69 65 72 73 2e 0a 20 | 2a 0a 20 2a 20 48 61 73 |fiers.. |*. * Has|
|000021b0| 68 38 20 68 61 73 20 6e | 6f 74 20 62 65 65 6e 20 |h8 has n|ot been |
|000021c0| 74 68 6f 72 6f 75 67 68 | 6c 79 20 74 65 73 74 65 |thorough|ly teste|
|000021d0| 64 2c 20 74 68 6f 75 67 | 68 20 69 74 20 63 61 6e |d, thoug|h it can|
|000021e0| 20 74 72 61 6e 73 6c 61 | 74 65 20 69 74 73 65 6c | transla|te itsel|
|000021f0| 66 0a 20 2a 20 63 6f 72 | 72 65 63 74 6c 79 2e 20 |f. * cor|rectly. |
|00002200| 20 4e 6f 74 65 20 74 68 | 61 74 20 69 74 73 65 6c | Note th|at itsel|
|00002210| 66 20 63 6f 6e 74 61 69 | 6e 73 20 61 6c 6c 20 73 |f contai|ns all s|
|00002220| 6f 72 74 73 20 6f 66 20 | 71 75 6f 74 65 73 20 77 |orts of |quotes w|
|00002230| 69 74 68 69 6e 20 71 75 | 6f 74 65 73 2e 0a 20 2a |ithin qu|otes.. *|
|00002240| 2f 0a 23 69 6e 63 6c 75 | 64 65 20 3c 73 74 64 69 |/.#inclu|de <stdi|
|00002250| 6f 2e 68 3e 0a 23 69 6e | 63 6c 75 64 65 20 3c 63 |o.h>.#in|clude <c|
|00002260| 74 79 70 65 2e 68 3e 0a | 0a 2f 2a 0a 20 2a 20 52 |type.h>.|./*. * R|
|00002270| 65 73 65 72 76 65 64 20 | 69 73 20 61 6e 20 61 72 |eserved |is an ar|
|00002280| 72 61 79 20 6f 66 20 77 | 6f 72 64 73 20 77 68 69 |ray of w|ords whi|
|00002290| 63 68 20 77 65 20 64 6f | 6e 27 74 20 77 61 6e 74 |ch we do|n't want|
|000022a0| 20 6d 6f 64 69 66 69 65 | 64 2c 20 73 75 63 68 0a | modifie|d, such.|
|000022b0| 20 2a 20 61 73 20 74 68 | 65 20 6b 65 79 20 77 6f | * as th|e key wo|
|000022c0| 72 64 20 22 72 65 67 69 | 73 74 65 72 22 2c 20 6f |rd "regi|ster", o|
|000022d0| 72 20 73 79 73 74 65 6d | 20 66 75 6e 63 74 69 6f |r system| functio|
|000022e0| 6e 73 20 6c 6f 6e 67 65 | 72 20 74 68 61 6e 20 37 |ns longe|r than 7|
|000022f0| 20 63 68 61 72 61 63 74 | 65 72 73 2e 0a 20 2a 20 | charact|ers.. * |
|00002300| 46 65 65 6c 20 66 72 65 | 65 20 74 6f 20 61 64 64 |Feel fre|e to add|
|00002310| 20 61 6e 79 20 6f 74 68 | 65 72 73 2c 20 74 68 6f | any oth|ers, tho|
|00002320| 75 67 68 20 72 65 6d 65 | 6d 62 65 72 20 74 6f 20 |ugh reme|mber to |
|00002330| 63 6c 65 61 72 20 79 6f | 75 72 20 68 61 73 68 20 |clear yo|ur hash |
|00002340| 74 61 62 6c 65 0a 20 2a | 20 66 69 6c 65 73 20 61 |table. *| files a|
|00002350| 66 74 65 72 20 72 65 63 | 6f 6d 70 69 6c 69 6e 67 |fter rec|ompiling|
|00002360| 2e 0a 20 2a 2f 0a 63 68 | 61 72 20 2a 2a 52 65 73 |.. */.ch|ar **Res|
|00002370| 65 72 76 65 64 20 3d 20 | 4e 55 4c 4c 3b 0a 69 6e |erved = |NULL;.in|
|00002380| 74 20 52 65 73 5f 6d 61 | 78 20 3d 20 30 3b 0a 69 |t Res_ma|x = 0;.i|
|00002390| 6e 74 20 52 65 73 5f 63 | 6f 75 6e 74 20 3d 20 30 |nt Res_c|ount = 0|
|000023a0| 3b 0a 63 68 61 72 20 2a | 44 65 66 5f 72 65 73 65 |;.char *|Def_rese|
|000023b0| 72 76 65 64 5b 5d 20 3d | 20 7b 0a 20 20 20 22 63 |rved[] =| {. "c|
|000023c0| 6f 6e 74 69 6e 75 65 22 | 2c 0a 20 20 20 22 72 65 |ontinue"|,. "re|
|000023d0| 67 69 73 74 65 72 22 2c | 0a 20 20 20 22 75 6e 73 |gister",|. "uns|
|000023e0| 69 67 6e 65 64 22 0a 7d | 3b 0a 0a 65 78 74 65 72 |igned".}|;..exter|
|000023f0| 6e 20 63 68 61 72 20 2a | 6d 61 6c 6c 6f 63 20 28 |n char *|malloc (|
|00002400| 29 2c 20 2a 73 74 72 63 | 70 79 20 28 29 3b 0a 0a |), *strc|py ();..|
|00002410| 23 64 65 66 69 6e 65 20 | 53 49 47 43 48 41 52 53 |#define |SIGCHARS|
|00002420| 20 37 09 09 2f 2a 20 73 | 69 67 6e 69 66 69 63 61 | 7../* s|ignifica|
|00002430| 6e 74 20 63 68 61 72 61 | 63 74 65 72 73 20 69 6e |nt chara|cters in|
|00002440| 20 69 64 65 6e 74 69 66 | 69 65 72 20 2a 2f 0a 23 | identif|ier */.#|
|00002450| 64 65 66 69 6e 65 20 48 | 41 53 48 42 49 54 53 20 |define H|ASHBITS |
|00002460| 31 32 09 09 2f 2a 20 68 | 61 73 68 20 74 61 62 6c |12../* h|ash tabl|
|00002470| 65 20 61 64 64 72 65 73 | 73 20 73 69 7a 65 20 2a |e addres|s size *|
|00002480| 2f 0a 23 64 65 66 69 6e | 65 20 48 41 53 48 4c 49 |/.#defin|e HASHLI|
|00002490| 4d 49 54 20 28 31 3c 3c | 48 41 53 48 42 49 54 53 |MIT (1<<|HASHBITS|
|000024a0| 29 0a 23 64 65 66 69 6e | 65 20 48 41 53 48 4d 41 |).#defin|e HASHMA|
|000024b0| 53 4b 20 28 48 41 53 48 | 4c 49 4d 49 54 2d 31 29 |SK (HASH|LIMIT-1)|
|000024c0| 0a 23 64 65 66 69 6e 65 | 20 50 41 47 45 53 49 5a |.#define| PAGESIZ|
|000024d0| 45 20 34 30 39 36 09 09 | 2f 2a 20 4d 65 6d 6f 72 |E 4096..|/* Memor|
|000024e0| 79 20 61 6c 6c 6f 63 61 | 74 69 6f 6e 20 70 61 67 |y alloca|tion pag|
|000024f0| 65 73 69 7a 65 20 2a 2f | 20 0a 23 64 65 66 69 6e |esize */| .#defin|
|00002500| 65 20 4d 41 58 4c 49 4e | 45 20 31 30 32 34 09 09 |e MAXLIN|E 1024..|
|00002510| 2f 2a 20 4d 61 78 69 6d | 75 6d 20 6c 65 6e 67 74 |/* Maxim|um lengt|
|00002520| 68 20 6f 66 20 61 20 73 | 6f 75 72 63 65 20 6c 69 |h of a s|ource li|
|00002530| 6e 65 20 61 6c 6c 6f 77 | 65 64 20 2a 2f 0a 0a 23 |ne allow|ed */..#|
|00002540| 64 65 66 69 6e 65 20 57 | 5f 53 48 4f 52 54 45 4e |define W|_SHORTEN|
|00002550| 20 20 30 09 09 2f 2a 20 | 49 64 65 6e 74 69 66 69 | 0../* |Identifi|
|00002560| 65 72 20 63 6c 61 73 73 | 65 73 20 2a 2f 0a 23 64 |er class|es */.#d|
|00002570| 65 66 69 6e 65 20 57 5f | 4e 4f 52 4d 41 4c 20 20 |efine W_|NORMAL |
|00002580| 20 31 0a 23 64 65 66 69 | 6e 65 20 57 5f 52 45 53 | 1.#defi|ne W_RES|
|00002590| 45 52 56 45 44 20 32 0a | 23 64 65 66 69 6e 65 20 |ERVED 2.|#define |
|000025a0| 57 5f 56 61 6c 69 64 28 | 4e 29 20 28 28 4e 29 20 |W_Valid(|N) ((N) |
|000025b0| 3e 3d 20 30 20 26 26 20 | 28 4e 29 20 3c 3d 20 32 |>= 0 && |(N) <= 2|
|000025c0| 29 0a 0a 2f 2a 0a 20 2a | 20 48 61 73 68 54 61 62 |)../*. *| HashTab|
|000025d0| 0a 20 2a 0a 20 2a 20 54 | 68 65 20 69 64 65 6e 74 |. *. * T|he ident|
|000025e0| 69 66 69 65 72 20 6d 61 | 70 20 69 73 20 61 20 68 |ifier ma|p is a h|
|000025f0| 61 73 68 20 74 61 62 6c | 65 2e 20 20 54 68 65 20 |ash tabl|e. The |
|00002600| 74 61 62 6c 65 20 75 73 | 65 73 20 6f 70 65 6e 20 |table us|es open |
|00002610| 61 64 64 72 65 73 73 69 | 6e 67 0a 20 2a 20 77 69 |addressi|ng. * wi|
|00002620| 74 68 20 6c 69 6e 65 61 | 72 20 70 72 6f 62 69 6e |th linea|r probin|
|00002630| 67 20 66 6f 72 20 63 6f | 6c 6c 69 73 69 6f 6e 20 |g for co|llision |
|00002640| 72 65 73 6f 6c 75 74 69 | 6f 6e 2e 20 20 49 64 65 |resoluti|on. Ide|
|00002650| 6e 74 69 66 69 65 72 73 | 20 69 6e 20 74 68 65 0a |ntifiers| in the.|
|00002660| 20 2a 20 74 61 62 6c 65 | 20 61 72 65 20 6d 61 70 | * table| are map|
|00002670| 70 65 64 20 69 6e 74 6f | 20 51 78 78 78 2c 20 77 |ped into| Qxxx, w|
|00002680| 68 65 72 65 20 78 78 78 | 20 69 73 20 74 68 65 20 |here xxx| is the |
|00002690| 74 61 62 6c 65 20 61 64 | 64 72 65 73 73 20 69 6e |table ad|dress in|
|000026a0| 20 68 65 78 2e 0a 20 2a | 0a 20 2a 20 54 68 65 20 | hex.. *|. * The |
|000026b0| 68 61 73 68 20 74 61 62 | 6c 65 20 69 73 20 65 66 |hash tab|le is ef|
|000026c0| 66 65 63 74 69 76 65 6c | 79 20 64 65 63 6c 61 72 |fectivel|y declar|
|000026d0| 65 64 3a 0a 20 2a 0a 20 | 2a 20 20 20 20 20 20 63 |ed:. *. |* c|
|000026e0| 68 61 72 20 2a 48 61 73 | 68 54 61 62 5b 48 41 53 |har *Has|hTab[HAS|
|000026f0| 48 4c 49 4d 49 54 5d 3b | 0a 20 2a 0a 20 2a 20 74 |HLIMIT];|. *. * t|
|00002700| 68 6f 75 67 68 20 74 68 | 65 20 6d 65 6d 6f 72 79 |hough th|e memory|
|00002710| 20 61 6c 6c 6f 63 61 74 | 69 6f 6e 20 69 73 20 64 | allocat|ion is d|
|00002720| 6f 6e 65 20 77 69 74 68 | 20 6d 61 6c 6c 6f 63 2e |one with| malloc.|
|00002730| 20 20 45 61 63 68 20 65 | 6d 70 74 79 20 68 61 73 | Each e|mpty has|
|00002740| 68 20 74 61 62 6c 65 0a | 20 2a 20 69 74 65 6d 20 |h table.| * item |
|00002750| 69 73 20 4e 55 4c 4c 2e | 20 20 46 75 6c 6c 20 65 |is NULL.| Full e|
|00002760| 6e 74 72 69 65 73 20 70 | 6f 69 6e 74 20 74 6f 20 |ntries p|oint to |
|00002770| 61 6e 20 69 64 65 6e 74 | 69 66 69 65 72 2e 20 20 |an ident|ifier. |
|00002780| 54 68 65 20 66 69 72 73 | 74 20 62 79 74 65 20 6f |The firs|t byte o|
|00002790| 66 0a 20 2a 20 74 68 65 | 20 69 64 65 6e 74 69 66 |f. * the| identif|
|000027a0| 69 65 72 20 63 6c 61 73 | 73 69 66 69 65 73 20 74 |ier clas|sifies t|
|000027b0| 68 65 20 69 64 65 6e 74 | 69 66 69 65 72 3a 0a 20 |he ident|ifier:. |
|000027c0| 2a 0a 20 2a 20 20 20 20 | 20 20 57 5f 4e 4f 52 4d |*. * | W_NORM|
|000027d0| 41 4c 20 2d 20 64 6f 6e | 27 74 20 6d 6f 64 69 66 |AL - don|'t modif|
|000027e0| 79 20 74 68 69 73 20 69 | 64 65 6e 74 69 66 69 65 |y this i|dentifie|
|000027f0| 72 0a 20 2a 09 57 5f 53 | 48 4f 52 54 45 4e 20 2d |r. *.W_S|HORTEN -|
|00002800| 20 73 68 6f 72 74 65 6e | 20 74 68 69 73 20 69 64 | shorten| this id|
|00002810| 65 6e 74 69 66 69 65 72 | 0a 20 2a 09 57 5f 52 45 |entifier|. *.W_RE|
|00002820| 53 45 52 56 45 20 2d 20 | 72 65 73 65 72 76 65 64 |SERVE - |reserved|
|00002830| 20 77 6f 72 64 20 0a 20 | 2a 2f 0a 63 68 61 72 20 | word . |*/.char |
|00002840| 2a 2a 48 61 73 68 54 61 | 62 3b 0a 69 6e 74 20 48 |**HashTa|b;.int H|
|00002850| 61 73 68 53 69 7a 65 20 | 3d 20 30 3b 20 20 20 20 |ashSize |= 0; |
|00002860| 2f 2a 20 4e 75 6d 62 65 | 72 20 6f 66 20 65 6c 65 |/* Numbe|r of ele|
|00002870| 6d 65 6e 74 73 20 69 6e | 20 68 61 73 68 20 74 61 |ments in| hash ta|
|00002880| 62 6c 65 20 09 09 20 20 | 20 20 2a 2f 0a 69 6e 74 |ble .. | */.int|
|00002890| 20 4e 65 77 54 61 62 3b | 20 20 20 20 20 20 20 20 | NewTab;| |
|000028a0| 20 20 2f 2a 20 46 6c 61 | 67 20 77 68 69 63 68 20 | /* Fla|g which |
|000028b0| 69 73 20 73 65 74 20 74 | 6f 20 74 72 75 65 20 69 |is set t|o true i|
|000028c0| 66 20 68 61 73 68 20 74 | 61 62 6c 65 20 69 73 20 |f hash t|able is |
|000028d0| 6d 6f 64 69 66 69 65 64 | 20 2a 2f 0a 0a 63 68 61 |modified| */..cha|
|000028e0| 72 20 2a 53 74 72 46 72 | 65 65 3b 09 20 20 20 20 |r *StrFr|ee;. |
|000028f0| 20 2f 2a 20 50 6f 69 6e | 74 65 72 20 74 6f 20 62 | /* Poin|ter to b|
|00002900| 61 73 65 20 6f 66 20 66 | 72 65 65 20 73 74 72 69 |ase of f|ree stri|
|00002910| 6e 67 20 61 72 65 61 20 | 20 20 20 20 20 20 20 20 |ng area | |
|00002920| 20 20 20 20 20 20 20 20 | 2a 2f 0a 69 6e 74 20 53 | |*/.int S|
|00002930| 74 72 4c 65 66 74 20 3d | 20 30 3b 20 20 20 20 20 |trLeft =| 0; |
|00002940| 2f 2a 20 4e 75 6d 62 65 | 72 20 6f 66 20 63 68 61 |/* Numbe|r of cha|
|00002950| 72 61 63 74 65 72 73 20 | 6c 65 66 74 20 69 6e 20 |racters |left in |
|00002960| 66 72 65 65 20 73 74 72 | 69 6e 67 20 61 72 65 61 |free str|ing area|
|00002970| 20 20 20 20 20 20 20 2a | 2f 0a 0a 2f 2a 0a 20 2a | *|/../*. *|
|00002980| 20 49 6e 73 65 72 74 0a | 20 2a 20 0a 20 2a 20 49 | Insert.| * . * I|
|00002990| 6e 73 65 72 74 20 69 64 | 65 6e 74 69 66 69 65 72 |nsert id|entifier|
|000029a0| 20 69 6e 20 68 61 73 68 | 20 74 61 62 6c 65 0a 20 | in hash| table. |
|000029b0| 2a 0a 20 2a 20 49 6e 0a | 20 2a 20 20 20 20 20 20 |*. * In.| * |
|000029c0| 6b 20 3d 20 69 6e 64 65 | 78 20 69 6e 74 6f 20 68 |k = inde|x into h|
|000029d0| 61 73 68 20 74 61 62 6c | 65 0a 20 2a 20 20 20 20 |ash tabl|e. * |
|000029e0| 20 20 53 20 3d 20 69 64 | 65 6e 74 69 66 69 65 72 | S = id|entifier|
|000029f0| 0a 20 2a 09 43 6c 61 73 | 73 20 3d 20 63 6c 61 73 |. *.Clas|s = clas|
|00002a00| 73 20 6f 66 20 69 64 65 | 6e 74 69 66 69 65 72 20 |s of ide|ntifier |
|00002a10| 28 57 5f 4e 4f 52 4d 41 | 4c 2c 57 5f 53 48 4f 52 |(W_NORMA|L,W_SHOR|
|00002a20| 54 45 4e 2c 57 5f 52 45 | 53 45 52 56 45 44 29 0a |TEN,W_RE|SERVED).|
|00002a30| 20 2a 2f 0a 76 6f 69 64 | 20 49 6e 73 65 72 74 20 | */.void| Insert |
|00002a40| 28 6b 2c 53 2c 43 6c 61 | 73 73 29 0a 20 20 20 69 |(k,S,Cla|ss). i|
|00002a50| 6e 74 20 6b 3b 0a 20 20 | 20 63 68 61 72 20 2a 53 |nt k;. | char *S|
|00002a60| 3b 0a 20 20 20 69 6e 74 | 20 43 6c 61 73 73 3b 0a |;. int| Class;.|
|00002a70| 20 20 20 7b 0a 20 20 20 | 20 20 20 72 65 67 69 73 | {. | regis|
|00002a80| 74 65 72 20 69 6e 74 20 | 4c 3b 0a 0a 20 20 20 20 |ter int |L;.. |
|00002a90| 20 20 4e 65 77 54 61 62 | 20 3d 20 31 3b 0a 20 20 | NewTab| = 1;. |
|00002aa0| 20 20 20 20 48 61 73 68 | 53 69 7a 65 2b 2b 3b 0a | Hash|Size++;.|
|00002ab0| 20 20 20 20 20 20 69 66 | 20 28 28 53 74 72 4c 65 | if| ((StrLe|
|00002ac0| 66 74 20 2d 3d 20 28 4c | 3d 32 2b 73 74 72 6c 65 |ft -= (L|=2+strle|
|00002ad0| 6e 20 28 53 29 29 29 20 | 3c 20 30 29 0a 20 20 20 |n (S))) |< 0). |
|00002ae0| 20 20 20 20 20 20 53 74 | 72 46 72 65 65 20 3d 20 | St|rFree = |
|00002af0| 6d 61 6c 6c 6f 63 20 28 | 53 74 72 4c 65 66 74 3d |malloc (|StrLeft=|
|00002b00| 50 41 47 45 53 49 5a 45 | 29 3b 0a 20 20 20 20 20 |PAGESIZE|);. |
|00002b10| 20 2a 28 48 61 73 68 54 | 61 62 5b 6b 5d 20 3d 20 | *(HashT|ab[k] = |
|00002b20| 53 74 72 46 72 65 65 29 | 20 3d 20 43 6c 61 73 73 |StrFree)| = Class|
|00002b30| 3b 0a 20 20 20 20 20 20 | 73 74 72 63 70 79 20 28 |;. |strcpy (|
|00002b40| 53 74 72 46 72 65 65 2b | 31 2c 20 53 29 3b 0a 20 |StrFree+|1, S);. |
|00002b50| 20 20 20 20 20 53 74 72 | 46 72 65 65 20 2b 3d 20 | Str|Free += |
|00002b60| 4c 3b 0a 20 20 20 20 20 | 20 53 74 72 4c 65 66 74 |L;. | StrLeft|
|00002b70| 20 2d 3d 20 4c 3b 0a 20 | 20 20 7d 09 09 09 20 20 | -= L;. | }... |
|00002b80| 20 0a 0a 2f 2a 0a 20 2a | 20 4c 6f 6f 6b 55 70 0a | ../*. *| LookUp.|
|00002b90| 20 2a 0a 20 2a 20 4c 6f | 6f 6b 20 75 70 20 61 6e | *. * Lo|ok up an|
|00002ba0| 20 69 64 65 6e 74 69 66 | 65 72 20 69 6e 20 74 68 | identif|er in th|
|00002bb0| 65 20 69 64 65 6e 74 69 | 66 69 65 72 20 68 61 73 |e identi|fier has|
|00002bc0| 68 20 74 61 62 6c 65 2e | 0a 20 2a 20 49 66 20 6e |h table.|. * If n|
|00002bd0| 6f 74 20 66 6f 75 6e 64 | 2c 20 74 68 65 6e 20 69 |ot found|, then i|
|00002be0| 6e 73 65 72 74 20 69 74 | 20 69 6e 20 74 68 65 20 |nsert it| in the |
|00002bf0| 74 61 62 6c 65 2e 0a 20 | 2a 0a 20 2a 20 54 68 65 |table.. |*. * The|
|00002c00| 20 68 61 73 68 69 6e 67 | 20 75 73 65 73 20 6f 70 | hashing| uses op|
|00002c10| 65 6e 20 61 64 64 72 65 | 73 73 69 6e 67 20 77 69 |en addre|ssing wi|
|00002c20| 74 68 20 6c 69 6e 65 61 | 72 20 70 72 6f 62 69 6e |th linea|r probin|
|00002c30| 67 2e 0a 20 2a 20 54 68 | 65 20 61 6c 67 6f 72 69 |g.. * Th|e algori|
|00002c40| 74 68 6d 20 69 73 20 61 | 20 62 6c 75 65 2d 6c 69 |thm is a| blue-li|
|00002c50| 67 68 74 20 73 70 65 63 | 69 61 6c 2c 20 61 20 62 |ght spec|ial, a b|
|00002c60| 65 74 74 65 72 20 68 61 | 73 68 20 66 75 6e 63 74 |etter ha|sh funct|
|00002c70| 69 6f 6e 0a 20 2a 20 28 | 64 6f 75 62 6c 65 20 68 |ion. * (|double h|
|00002c80| 61 73 68 69 6e 67 3f 29 | 20 73 68 6f 75 6c 64 20 |ashing?)| should |
|00002c90| 62 65 20 75 73 65 64 2e | 0a 20 2a 20 0a 20 2a 20 |be used.|. * . * |
|00002ca0| 49 6e 0a 20 2a 20 20 20 | 20 20 20 53 20 3d 20 69 |In. * | S = i|
|00002cb0| 64 65 6e 74 69 66 69 65 | 72 20 28 6d 75 73 74 20 |dentifie|r (must |
|00002cc0| 62 65 20 61 74 20 6c 65 | 61 73 74 20 73 65 76 65 |be at le|ast seve|
|00002cd0| 6e 20 63 68 61 72 61 63 | 74 65 72 73 20 69 66 20 |n charac|ters if |
|00002ce0| 44 75 70 6c 69 63 61 74 | 65 20 3d 3d 20 30 29 0a |Duplicat|e == 0).|
|00002cf0| 20 2a 20 20 20 20 20 20 | 43 6c 61 73 73 20 3d 20 | * |Class = |
|00002d00| 69 64 65 6e 74 69 66 69 | 65 72 20 63 6c 61 73 73 |identifi|er class|
|00002d10| 20 28 57 5f 4e 4f 52 4d | 41 4c 2c 57 5f 53 48 4f | (W_NORM|AL,W_SHO|
|00002d20| 52 54 45 4e 2c 57 5f 52 | 45 53 45 52 56 45 44 29 |RTEN,W_R|ESERVED)|
|00002d30| 0a 20 2a 20 4f 75 74 0a | 20 2a 20 20 20 20 20 20 |. * Out.| * |
|00002d40| 72 65 73 75 6c 74 20 3d | 20 69 6e 64 65 78 20 69 |result =| index i|
|00002d50| 6e 74 6f 20 68 61 73 68 | 20 74 61 62 6c 65 20 0a |nto hash| table .|
|00002d60| 20 2a 2f 0a 69 6e 74 20 | 4c 6f 6f 6b 55 70 20 28 | */.int |LookUp (|
|00002d70| 53 2c 43 6c 61 73 73 29 | 0a 20 20 20 63 68 61 72 |S,Class)|. char|
|00002d80| 20 2a 53 3b 0a 20 20 20 | 69 6e 74 20 43 6c 61 73 | *S;. |int Clas|
|00002d90| 73 3b 0a 20 20 20 7b 0a | 20 20 20 20 20 20 72 65 |s;. {.| re|
|00002da0| 67 69 73 74 65 72 20 69 | 6e 74 20 6b 2c 6a 3b 0a |gister i|nt k,j;.|
|00002db0| 20 20 20 20 20 20 72 65 | 67 69 73 74 65 72 20 63 | re|gister c|
|00002dc0| 68 61 72 20 2a 54 3b 0a | 0a 20 20 20 20 20 20 69 |har *T;.|. i|
|00002dd0| 66 20 28 43 6c 61 73 73 | 20 21 3d 20 57 5f 53 48 |f (Class| != W_SH|
|00002de0| 4f 52 54 45 4e 29 20 7b | 0a 0a 20 20 20 20 20 20 |ORTEN) {|.. |
|00002df0| 20 20 20 2f 2a 20 48 61 | 73 68 20 66 69 72 73 74 | /* Ha|sh first|
|00002e00| 20 73 65 76 65 6e 20 63 | 68 61 72 61 63 74 65 72 | seven c|haracter|
|00002e10| 73 20 6f 66 20 69 64 65 | 6e 74 69 66 69 65 72 20 |s of ide|ntifier |
|00002e20| 2a 2f 20 0a 20 20 20 20 | 20 20 20 20 20 66 6f 72 |*/ . | for|
|00002e30| 20 28 6a 3d 30 2c 6b 3d | 30 2c 54 3d 53 3b 20 6a | (j=0,k=|0,T=S; j|
|00002e40| 3c 53 49 47 43 48 41 52 | 53 3b 20 6a 2b 2b 2c 20 |<SIGCHAR|S; j++, |
|00002e50| 6b 2b 3d 20 2a 54 2b 2b | 29 20 6b 20 3d 20 28 6b |k+= *T++|) k = (k|
|00002e60| 3c 3c 31 29 20 2b 20 6b | 3b 0a 0a 20 20 20 20 20 |<<1) + k|;.. |
|00002e70| 20 20 20 20 2f 2a 20 37 | 2d 63 68 61 72 61 63 74 | /* 7|-charact|
|00002e80| 65 72 20 73 65 61 72 63 | 68 20 66 6f 72 20 69 64 |er searc|h for id|
|00002e90| 65 6e 74 69 66 69 65 72 | 20 69 6e 20 74 61 62 6c |entifier| in tabl|
|00002ea0| 65 20 2a 2f 0a 20 20 20 | 20 20 20 20 20 20 66 6f |e */. | fo|
|00002eb0| 72 20 28 6a 3d 6b 3b 20 | 48 61 73 68 54 61 62 5b |r (j=k; |HashTab[|
|00002ec0| 6a 26 3d 48 41 53 48 4d | 41 53 4b 5d 20 21 3d 20 |j&=HASHM|ASK] != |
|00002ed0| 4e 55 4c 4c 3b 20 6a 2b | 2b 29 20 0a 20 20 20 20 |NULL; j+|+) . |
|00002ee0| 20 20 20 20 20 20 20 20 | 69 66 20 28 21 73 74 72 | |if (!str|
|00002ef0| 6e 63 6d 70 20 28 48 61 | 73 68 54 61 62 5b 6a 5d |ncmp (Ha|shTab[j]|
|00002f00| 2b 31 2c 53 2c 53 49 47 | 43 48 41 52 53 29 29 20 |+1,S,SIG|CHARS)) |
|00002f10| 0a 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |. | |
|00002f20| 69 66 20 28 21 73 74 72 | 63 6d 70 20 28 48 61 73 |if (!str|cmp (Has|
|00002f30| 68 54 61 62 5b 6a 5d 2b | 31 2c 53 29 29 20 72 65 |hTab[j]+|1,S)) re|
|00002f40| 74 75 72 6e 20 6a 3b 0a | 09 20 20 20 20 20 20 20 |turn j;.|. |
|00002f50| 65 6c 73 65 20 7b 0a 09 | 09 20 20 43 6c 61 73 73 |else {..|. Class|
|00002f60| 20 3d 20 57 5f 53 48 4f | 52 54 45 4e 3b 0a 09 09 | = W_SHO|RTEN;...|
|00002f70| 20 20 62 72 65 61 6b 3b | 0a 09 20 20 20 20 20 20 | break;|.. |
|00002f80| 20 7d 0a 09 20 2f 2a 20 | 54 68 65 20 66 6f 6c 6c | }.. /* |The foll|
|00002f90| 6f 77 69 6e 67 20 74 65 | 73 74 20 61 6e 64 20 61 |owing te|st and a|
|00002fa0| 73 73 69 67 6e 6d 65 6e | 74 20 63 61 75 73 65 20 |ssignmen|t cause |
|00002fb0| 69 64 65 6e 74 69 66 69 | 65 72 73 20 74 6f 20 62 |identifi|ers to b|
|00002fc0| 65 0a 09 20 20 2a 20 68 | 61 73 68 65 64 20 65 76 |e.. * h|ashed ev|
|00002fd0| 65 6e 20 69 66 20 74 68 | 65 79 20 61 72 65 20 74 |en if th|ey are t|
|00002fe0| 68 65 20 66 69 72 73 74 | 20 6c 6f 6e 67 20 69 64 |he first| long id|
|00002ff0| 65 6e 74 69 66 69 65 72 | 2e 20 20 54 68 69 73 0a |entifier|. This.|
|00003000| 09 20 20 2a 20 70 72 6f | 74 65 63 74 73 20 66 72 |. * pro|tects fr|
|00003010| 6f 6d 20 74 72 75 6e 63 | 61 74 69 6f 6e 20 62 79 |om trunc|ation by|
|00003020| 20 74 68 65 20 63 6f 6d | 70 69 6c 65 72 2e 20 20 | the com|piler. |
|00003030| 4f 74 68 65 77 69 73 65 | 2c 20 77 68 65 6e 0a 09 |Othewise|, when..|
|00003040| 20 20 2a 20 79 6f 75 20 | 72 75 6e 20 61 64 62 20 | * you |run adb |
|00003050| 79 6f 75 20 68 61 76 65 | 20 74 6f 20 6b 6e 6f 77 |you have| to know|
|00003060| 20 77 68 69 63 68 20 6c | 6f 6e 67 20 69 64 20 63 | which l|ong id c|
|00003070| 61 6d 65 20 66 69 72 73 | 74 2e 0a 09 20 20 2a 20 |ame firs|t... * |
|00003080| 47 65 6f 66 66 20 4b 75 | 65 6e 6e 69 6e 67 20 31 |Geoff Ku|enning 1|
|00003090| 31 2f 38 2f 38 36 0a 09 | 20 20 2a 2f 0a 20 20 20 |1/8/86..| */. |
|000030a0| 20 20 20 20 20 20 69 66 | 20 28 43 6c 61 73 73 20 | if| (Class |
|000030b0| 3d 3d 20 57 5f 4e 4f 52 | 4d 41 4c 20 20 26 26 20 |== W_NOR|MAL && |
|000030c0| 20 73 74 72 6c 65 6e 20 | 28 53 29 20 3e 20 53 49 | strlen |(S) > SI|
|000030d0| 47 43 48 41 52 53 29 0a | 09 20 20 20 20 43 6c 61 |GCHARS).|. Cla|
|000030e0| 73 73 20 3d 20 57 5f 53 | 48 4f 52 54 45 4e 3b 0a |ss = W_S|HORTEN;.|
|000030f0| 20 20 20 20 20 20 7d 0a | 0a 20 20 20 20 20 20 69 | }.|. i|
|00003100| 66 20 28 43 6c 61 73 73 | 20 3d 3d 20 57 5f 53 48 |f (Class| == W_SH|
|00003110| 4f 52 54 45 4e 29 20 7b | 0a 09 20 2f 2a 20 0a 09 |ORTEN) {|.. /* ..|
|00003120| 20 20 2a 20 54 68 65 72 | 65 20 69 73 20 61 6e 6f | * Ther|e is ano|
|00003130| 74 68 65 72 20 69 64 65 | 6e 74 69 66 69 65 72 20 |ther ide|ntifier |
|00003140| 77 69 74 68 20 74 68 65 | 20 73 61 6d 65 20 37 2d |with the| same 7-|
|00003150| 63 68 61 72 61 63 74 65 | 72 20 70 72 65 66 69 78 |characte|r prefix|
|00003160| 2e 20 0a 09 20 20 2a 20 | 48 61 73 68 20 74 68 65 |. .. * |Hash the|
|00003170| 20 63 6f 6d 70 6c 65 74 | 65 20 69 64 65 6e 74 69 | complet|e identi|
|00003180| 66 69 65 72 20 61 6e 64 | 20 6c 6f 6f 6b 20 69 74 |fier and| look it|
|00003190| 20 75 70 20 69 6e 20 74 | 68 65 20 74 61 62 6c 65 | up in t|he table|
|000031a0| 2e 0a 09 20 20 2a 2f 0a | 20 20 20 20 20 20 20 20 |... */.| |
|000031b0| 20 66 6f 72 20 28 6a 3d | 6b 3b 20 2a 54 3b 20 6a | for (j=|k; *T; j|
|000031c0| 2b 3d 20 2a 54 2b 2b 29 | 20 6a 20 3d 20 28 6a 3c |+= *T++)| j = (j<|
|000031d0| 3c 31 29 20 2b 20 6a 3b | 0a 0a 09 20 2f 2a 20 61 |<1) + j;|... /* a|
|000031e0| 6c 6c 20 63 68 61 72 61 | 63 74 65 72 73 20 73 65 |ll chara|cters se|
|000031f0| 61 72 63 68 20 66 6f 72 | 20 69 64 65 6e 74 69 66 |arch for| identif|
|00003200| 69 65 72 20 69 6e 20 74 | 61 62 6c 65 20 2a 2f 0a |ier in t|able */.|
|00003210| 09 20 66 6f 72 20 28 3b | 20 48 61 73 68 54 61 62 |. for (;| HashTab|
|00003220| 5b 6a 26 3d 48 41 53 48 | 4d 41 53 4b 5d 20 21 3d |[j&=HASH|MASK] !=|
|00003230| 20 4e 55 4c 4c 3b 20 6a | 2b 2b 29 0a 09 20 20 20 | NULL; j|++).. |
|00003240| 20 20 20 20 69 66 20 28 | 21 73 74 72 63 6d 70 20 | if (|!strcmp |
|00003250| 28 48 61 73 68 54 61 62 | 5b 6a 5d 2b 31 2c 53 29 |(HashTab|[j]+1,S)|
|00003260| 29 20 72 65 74 75 72 6e | 20 6a 3b 0a 20 20 20 20 |) return| j;. |
|00003270| 20 20 7d 0a 0a 20 20 20 | 20 20 20 2f 2a 20 49 64 | }.. | /* Id|
|00003280| 65 6e 74 69 66 69 65 72 | 20 77 61 73 20 6e 6f 74 |entifier| was not|
|00003290| 20 66 6f 75 6e 64 20 2d | 20 69 6e 73 65 72 74 20 | found -| insert |
|000032a0| 69 74 20 69 6e 20 68 61 | 73 68 20 74 61 62 6c 65 |it in ha|sh table|
|000032b0| 20 2a 2f 0a 20 20 20 20 | 20 20 49 6e 73 65 72 74 | */. | Insert|
|000032c0| 20 28 6a 2c 53 2c 43 6c | 61 73 73 29 3b 0a 20 20 | (j,S,Cl|ass);. |
|000032d0| 20 20 20 20 69 66 20 28 | 48 61 73 68 53 69 7a 65 | if (|HashSize|
|000032e0| 20 3d 3d 20 48 41 53 48 | 4c 49 4d 49 54 29 20 0a | == HASH|LIMIT) .|
|000032f0| 09 20 66 70 72 69 6e 74 | 66 20 28 73 74 64 65 72 |. fprint|f (stder|
|00003300| 72 2c 22 68 61 73 68 38 | 3a 20 74 61 62 6c 65 20 |r,"hash8|: table |
|00003310| 6f 76 65 72 66 6c 6f 77 | 5c 6e 22 29 2c 20 65 78 |overflow|\n"), ex|
|00003320| 69 74 20 28 31 29 3b 0a | 20 20 20 20 20 20 72 65 |it (1);.| re|
|00003330| 74 75 72 6e 20 6a 3b 0a | 20 20 20 7d 0a 0a 23 64 |turn j;.| }..#d|
|00003340| 65 66 69 6e 65 20 43 5f | 43 4f 44 45 20 30 09 2f |efine C_|CODE 0./|
|00003350| 2a 20 44 65 66 69 6e 65 | 73 20 66 6f 72 20 74 72 |* Define|s for tr|
|00003360| 61 6e 73 6c 61 74 6f 72 | 20 73 74 61 74 65 73 20 |anslator| states |
|00003370| 2a 2f 0a 23 64 65 66 69 | 6e 65 20 53 5f 51 55 4f |*/.#defi|ne S_QUO|
|00003380| 54 45 20 31 0a 23 64 65 | 66 69 6e 65 20 44 5f 51 |TE 1.#de|fine D_Q|
|00003390| 55 4f 54 45 20 32 0a 23 | 64 65 66 69 6e 65 20 43 |UOTE 2.#|define C|
|000033a0| 4f 4d 4d 45 4e 54 20 33 | 0a 0a 23 64 65 66 69 6e |OMMENT 3|..#defin|
|000033b0| 65 20 45 4e 43 4f 44 45 | 20 30 09 2f 2a 20 4d 6f |e ENCODE| 0./* Mo|
|000033c0| 64 65 20 76 61 6c 75 65 | 73 20 66 6f 72 20 74 72 |de value|s for tr|
|000033d0| 61 6e 73 6c 61 74 6f 72 | 20 2a 2f 0a 23 64 65 66 |anslator| */.#def|
|000033e0| 69 6e 65 20 44 45 43 4f | 44 45 20 31 0a 23 64 65 |ine DECO|DE 1.#de|
|000033f0| 66 69 6e 65 20 5f 44 45 | 43 4f 44 45 20 32 0a 0a |fine _DE|CODE 2..|
|00003400| 2f 2a 0a 20 2a 20 54 72 | 61 6e 73 6c 61 74 65 0a |/*. * Tr|anslate.|
|00003410| 20 2a 0a 20 2a 20 54 72 | 61 6e 73 6c 61 74 65 20 | *. * Tr|anslate |
|00003420| 69 6e 70 75 74 20 73 74 | 72 65 61 6d 20 77 69 74 |input st|ream wit|
|00003430| 68 20 69 64 65 6e 74 69 | 66 69 65 72 20 6d 61 70 |h identi|fier map|
|00003440| 2e 0a 20 2a 0a 20 2a 20 | 54 68 69 73 20 73 68 6f |.. *. * |This sho|
|00003450| 75 6c 64 20 68 61 76 65 | 20 62 65 65 6e 20 77 72 |uld have| been wr|
|00003460| 69 74 74 65 6e 20 77 69 | 74 68 20 6c 65 78 2e 0a |itten wi|th lex..|
|00003470| 20 2a 2f 0a 54 72 61 6e | 73 6c 61 74 65 20 28 4d | */.Tran|slate (M|
|00003480| 6f 64 65 29 20 0a 20 20 | 20 69 6e 74 20 4d 6f 64 |ode) . | int Mod|
|00003490| 65 3b 0a 20 20 20 7b 0a | 20 20 20 20 20 20 72 65 |e;. {.| re|
|000034a0| 67 69 73 74 65 72 20 63 | 68 61 72 20 43 2c 20 2a |gister c|har C, *|
|000034b0| 50 2c 20 2a 51 3b 0a 20 | 20 20 20 20 20 63 68 61 |P, *Q;. | cha|
|000034c0| 72 20 53 5b 4d 41 58 4c | 49 4e 45 5d 3b 0a 20 20 |r S[MAXL|INE];. |
|000034d0| 20 20 20 20 69 6e 74 20 | 6b 2c 20 73 74 61 74 65 | int |k, state|
|000034e0| 3d 43 5f 43 4f 44 45 2c | 20 49 73 51 3b 0a 0a 20 |=C_CODE,| IsQ;.. |
|000034f0| 20 20 20 20 20 77 68 69 | 6c 65 20 28 4e 55 4c 4c | whi|le (NULL|
|00003500| 20 21 3d 20 66 67 65 74 | 73 20 28 53 2c 4d 41 58 | != fget|s (S,MAX|
|00003510| 4c 49 4e 45 2c 73 74 64 | 69 6e 29 29 20 0a 20 20 |LINE,std|in)) . |
|00003520| 20 20 20 20 20 20 20 66 | 6f 72 20 28 50 3d 53 3b | f|or (P=S;|
|00003530| 20 43 3d 20 2a 50 3b 20 | 29 0a 09 20 20 20 20 73 | C= *P; |).. s|
|00003540| 77 69 74 63 68 20 28 73 | 74 61 74 65 29 20 7b 0a |witch (s|tate) {.|
|00003550| 09 20 20 20 20 20 20 20 | 63 61 73 65 20 43 4f 4d |. |case COM|
|00003560| 4d 45 4e 54 3a 0a 09 20 | 20 20 20 20 20 20 20 20 |MENT:.. | |
|00003570| 20 70 75 74 63 68 61 72 | 20 28 2a 50 2b 2b 29 3b | putchar| (*P++);|
|00003580| 0a 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |. | |
|00003590| 20 20 20 69 66 20 28 43 | 20 3d 3d 20 27 2a 27 20 | if (C| == '*' |
|000035a0| 26 26 20 2a 50 20 3d 3d | 20 27 2f 27 29 20 73 74 |&& *P ==| '/') st|
|000035b0| 61 74 65 3d 43 5f 43 4f | 44 45 2c 20 70 75 74 63 |ate=C_CO|DE, putc|
|000035c0| 68 61 72 20 28 2a 50 2b | 2b 29 3b 0a 09 09 20 20 |har (*P+|+);... |
|000035d0| 62 72 65 61 6b 3b 0a 09 | 20 20 20 20 20 20 20 63 |break;..| c|
|000035e0| 61 73 65 20 53 5f 51 55 | 4f 54 45 3a 0a 09 20 20 |ase S_QU|OTE:.. |
|000035f0| 20 20 20 20 20 63 61 73 | 65 20 44 5f 51 55 4f 54 | cas|e D_QUOT|
|00003600| 45 3a 0a 09 09 20 20 70 | 75 74 63 68 61 72 20 28 |E:... p|utchar (|
|00003610| 2a 50 2b 2b 29 3b 0a 09 | 09 20 20 73 77 69 74 63 |*P++);..|. switc|
|00003620| 68 20 28 43 29 20 7b 0a | 09 09 20 20 20 20 20 63 |h (C) {.|.. c|
|00003630| 61 73 65 20 27 5c 27 27 | 3a 20 69 66 20 28 73 74 |ase '\''|: if (st|
|00003640| 61 74 65 20 3d 3d 20 53 | 5f 51 55 4f 54 45 29 20 |ate == S|_QUOTE) |
|00003650| 73 74 61 74 65 20 3d 20 | 43 5f 43 4f 44 45 3b 20 |state = |C_CODE; |
|00003660| 62 72 65 61 6b 3b 0a 09 | 09 20 20 20 20 20 63 61 |break;..|. ca|
|00003670| 73 65 20 27 22 27 20 3a | 20 69 66 20 28 73 74 61 |se '"' :| if (sta|
|00003680| 74 65 20 3d 3d 20 44 5f | 51 55 4f 54 45 29 20 73 |te == D_|QUOTE) s|
|00003690| 74 61 74 65 20 3d 20 43 | 5f 43 4f 44 45 3b 20 62 |tate = C|_CODE; b|
|000036a0| 72 65 61 6b 3b 0a 09 09 | 20 20 20 20 20 63 61 73 |reak;...| cas|
|000036b0| 65 20 27 5c 5c 27 3a 20 | 70 75 74 63 68 61 72 20 |e '\\': |putchar |
|000036c0| 28 2a 50 2b 2b 29 3b 20 | 62 72 65 61 6b 3b 0a 09 |(*P++); |break;..|
|000036d0| 09 20 20 20 20 20 64 65 | 66 61 75 6c 74 3a 20 62 |. de|fault: b|
|000036e0| 72 65 61 6b 3b 20 0a 09 | 09 20 20 7d 0a 09 20 20 |reak; ..|. }.. |
|000036f0| 20 20 20 20 20 20 20 20 | 62 72 65 61 6b 3b 0a 09 | |break;..|
|00003700| 20 20 20 20 20 20 20 0a | 20 20 20 20 20 20 20 20 | .| |
|00003710| 20 20 20 20 20 20 20 63 | 61 73 65 20 43 5f 43 4f | c|ase C_CO|
|00003720| 44 45 3a 0a 09 09 20 20 | 69 66 20 28 69 73 61 6c |DE:... |if (isal|
|00003730| 70 68 61 20 28 43 29 20 | 7c 7c 20 43 3d 3d 27 5f |pha (C) ||| C=='_|
|00003740| 27 29 20 7b 0a 09 20 20 | 20 20 20 20 20 20 20 20 |') {.. | |
|00003750| 20 20 20 2f 2a 20 42 65 | 67 69 6e 6e 69 6e 67 20 | /* Be|ginning |
|00003760| 6f 66 20 69 64 65 6e 74 | 69 66 69 65 72 20 2a 2f |of ident|ifier */|
|00003770| 0a 20 20 20 20 20 20 09 | 20 20 20 20 20 20 20 20 |. .| |
|00003780| 20 20 20 20 20 66 6f 72 | 20 28 51 3d 50 3b 20 43 | for| (Q=P; C|
|00003790| 3d 20 2a 51 2c 20 69 73 | 61 6c 6e 75 6d 28 43 29 |= *Q, is|alnum(C)|
|000037a0| 7c 7c 43 3d 3d 27 5f 27 | 3b 20 51 2b 2b 29 3b 0a |||C=='_'|; Q++);.|
|000037b0| 09 20 20 20 20 20 20 20 | 20 20 20 20 20 20 2a 51 |. | *Q|
|000037c0| 20 3d 20 27 5c 30 27 3b | 0a 20 20 20 09 20 20 20 | = '\0';|. . |
|000037d0| 20 20 20 20 20 20 20 20 | 20 20 73 77 69 74 63 68 | | switch|
|000037e0| 20 28 4d 6f 64 65 29 20 | 7b 0a 0a 09 09 09 63 61 | (Mode) |{.....ca|
|000037f0| 73 65 20 45 4e 43 4f 44 | 45 3a 20 2f 2a 20 57 65 |se ENCOD|E: /* We|
|00003800| 20 61 72 65 20 65 6e 63 | 6f 64 69 6e 67 20 43 20 | are enc|oding C |
|00003810| 73 6f 75 72 63 65 20 2a | 2f 0a 09 09 20 20 20 20 |source *|/... |
|00003820| 20 20 20 20 20 20 20 49 | 73 51 20 3d 20 2a 50 3d | I|sQ = *P=|
|00003830| 3d 27 51 27 20 26 26 20 | 69 73 64 69 67 69 74 20 |='Q' && |isdigit |
|00003840| 28 50 5b 31 5d 29 3b 0a | 20 20 20 09 20 20 20 20 |(P[1]);.| . |
|00003850| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 69 | | i|
|00003860| 66 20 28 51 2d 50 20 3c | 3d 20 53 49 47 43 48 41 |f (Q-P <|= SIGCHA|
|00003870| 52 53 20 26 26 20 21 49 | 73 51 29 20 0a 20 20 20 |RS && !I|sQ) . |
|00003880| 09 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |. | |
|00003890| 20 20 20 20 20 20 20 66 | 70 75 74 73 20 28 50 2c | f|puts (P,|
|000038a0| 73 74 64 6f 75 74 29 3b | 0a 09 09 20 20 20 20 20 |stdout);|... |
|000038b0| 20 20 20 20 20 20 65 6c | 73 65 20 7b 0a 09 09 09 | el|se {....|
|000038c0| 20 20 20 20 20 20 6b 20 | 3d 20 4c 6f 6f 6b 55 70 | k |= LookUp|
|000038d0| 20 28 50 2c 49 73 51 20 | 3f 20 57 5f 53 48 4f 52 | (P,IsQ |? W_SHOR|
|000038e0| 54 45 4e 20 3a 20 57 5f | 4e 4f 52 4d 41 4c 29 3b |TEN : W_|NORMAL);|
|000038f0| 0a 09 09 09 20 20 20 20 | 20 20 69 66 20 28 2a 48 |.... | if (*H|
|00003900| 61 73 68 54 61 62 5b 6b | 5d 20 21 3d 20 57 5f 53 |ashTab[k|] != W_S|
|00003910| 48 4f 52 54 45 4e 29 20 | 66 70 75 74 73 20 28 50 |HORTEN) |fputs (P|
|00003920| 2c 73 74 64 6f 75 74 29 | 3b 0a 09 09 20 20 20 20 |,stdout)|;... |
|00003930| 20 20 20 20 20 20 20 20 | 20 20 65 6c 73 65 20 70 | | else p|
|00003940| 72 69 6e 74 66 20 28 22 | 51 25 64 22 2c 6b 29 3b |rintf ("|Q%d",k);|
|00003950| 0a 09 09 20 20 20 20 20 | 20 20 20 20 20 20 7d 0a |... | }.|
|00003960| 09 09 09 20 20 20 62 72 | 65 61 6b 3b 0a 0a 09 09 |... br|eak;....|
|00003970| 09 63 61 73 65 20 5f 44 | 45 43 4f 44 45 3a 20 2f |.case _D|ECODE: /|
|00003980| 2a 20 57 65 20 61 72 65 | 20 64 65 63 6f 64 69 6e |* We are| decodin|
|00003990| 67 20 6c 69 6e 6b 65 72 | 20 6d 65 73 73 61 67 65 |g linker| message|
|000039a0| 73 20 2a 2f 0a 09 09 20 | 20 20 20 20 20 20 20 20 |s */... | |
|000039b0| 20 20 69 66 20 28 2a 50 | 20 21 3d 20 27 5f 27 29 | if (*P| != '_')|
|000039c0| 20 7b 0a 09 09 09 20 20 | 20 20 20 20 66 70 75 74 | {.... | fput|
|000039d0| 73 20 28 50 2c 73 74 64 | 6f 75 74 29 3b 0a 09 09 |s (P,std|out);...|
|000039e0| 09 20 20 20 20 20 20 62 | 72 65 61 6b 3b 0a 09 09 |. b|reak;...|
|000039f0| 09 20 20 20 7d 0a 09 09 | 09 20 20 20 70 75 74 63 |. }...|. putc|
|00003a00| 68 61 72 20 28 2a 50 2b | 2b 29 3b 0a 09 09 09 20 |har (*P+|+);.... |
|00003a10| 20 20 2f 2a 20 63 6f 6e | 74 69 6e 75 65 20 6f 6e | /* con|tinue on|
|00003a20| 20 64 6f 77 6e 20 74 6f | 20 63 61 73 65 20 44 45 | down to| case DE|
|00003a30| 43 4f 44 45 20 2a 2f 0a | 0a 09 09 09 63 61 73 65 |CODE */.|....case|
|00003a40| 20 44 45 43 4f 44 45 3a | 20 2f 2a 20 57 65 20 61 | DECODE:| /* We a|
|00003a50| 72 65 20 64 65 63 6f 64 | 69 6e 67 20 65 72 72 6f |re decod|ing erro|
|00003a60| 72 20 6d 65 73 73 61 67 | 65 20 2a 2f 0a 20 20 20 |r messag|e */. |
|00003a70| 09 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |. | |
|00003a80| 20 20 20 20 69 66 20 28 | 2a 50 3d 3d 27 51 27 20 | if (|*P=='Q' |
|00003a90| 26 26 20 69 73 64 69 67 | 69 74 20 28 50 5b 31 5d |&& isdig|it (P[1]|
|00003aa0| 29 29 20 7b 20 0a 09 09 | 09 20 20 20 20 20 20 6b |)) { ...|. k|
|00003ab0| 3d 61 74 6f 69 28 50 2b | 31 29 3b 0a 09 09 09 20 |=atoi(P+|1);.... |
|00003ac0| 20 20 20 20 20 69 66 20 | 28 21 28 6b 20 26 7e 48 | if |(!(k &~H|
|00003ad0| 41 53 48 4d 41 53 4b 29 | 20 26 26 20 48 61 73 68 |ASHMASK)| && Hash|
|00003ae0| 54 61 62 5b 6b 5d 21 3d | 4e 55 4c 4c 29 20 0a 09 |Tab[k]!=|NULL) ..|
|00003af0| 09 09 09 20 50 20 3d 20 | 48 61 73 68 54 61 62 5b |... P = |HashTab[|
|00003b00| 6b 5d 20 2b 20 31 3b 0a | 09 09 09 20 20 20 7d 0a |k] + 1;.|... }.|
|00003b10| 09 09 20 20 20 20 20 20 | 20 20 20 20 20 66 70 75 |.. | fpu|
|00003b20| 74 73 20 28 50 2c 73 74 | 64 6f 75 74 29 3b 0a 09 |ts (P,st|dout);..|
|00003b30| 09 09 20 20 20 62 72 65 | 61 6b 3b 0a 09 09 20 20 |.. bre|ak;... |
|00003b40| 20 20 20 7d 0a 20 20 20 | 09 20 20 20 20 20 20 20 | }. |. |
|00003b50| 20 20 20 20 20 20 2a 28 | 50 3d 51 29 20 3d 20 43 | *(|P=Q) = C|
|00003b60| 3b 0a 20 20 20 09 20 20 | 20 20 20 20 20 20 20 20 |;. . | |
|00003b70| 7d 20 65 6c 73 65 20 69 | 66 20 28 69 73 64 69 67 |} else i|f (isdig|
|00003b80| 69 74 20 28 43 29 29 20 | 7b 0a 09 20 20 20 20 20 |it (C)) |{.. |
|00003b90| 20 20 20 20 20 20 20 20 | 2f 2a 20 53 6b 69 70 20 | |/* Skip |
|00003ba0| 6e 75 6d 62 65 72 20 74 | 6f 20 61 76 6f 69 64 20 |number t|o avoid |
|00003bb0| 63 68 61 6e 67 69 6e 67 | 20 6c 6f 6e 67 20 6e 75 |changing| long nu|
|00003bc0| 6d 62 65 72 73 20 2a 2f | 0a 09 20 20 20 20 20 20 |mbers */|.. |
|00003bd0| 20 20 20 20 20 20 20 77 | 68 69 6c 65 20 28 69 73 | w|hile (is|
|00003be0| 61 6c 6e 75 6d 28 2a 50 | 29 29 20 70 75 74 63 68 |alnum(*P|)) putch|
|00003bf0| 61 72 20 28 2a 50 2b 2b | 29 3b 0a 09 20 20 20 20 |ar (*P++|);.. |
|00003c00| 20 20 20 20 20 20 7d 20 | 65 6c 73 65 20 7b 0a 09 | } |else {..|
|00003c10| 09 20 20 20 20 20 70 75 | 74 63 68 61 72 20 28 2a |. pu|tchar (*|
|00003c20| 50 2b 2b 29 3b 0a 09 09 | 20 20 20 20 20 73 77 69 |P++);...| swi|
|00003c30| 74 63 68 20 28 43 29 20 | 7b 0a 09 09 20 20 20 20 |tch (C) |{... |
|00003c40| 20 20 20 20 64 65 66 61 | 75 6c 74 3a 20 62 72 65 | defa|ult: bre|
|00003c50| 61 6b 3b 0a 09 09 09 63 | 61 73 65 20 27 5c 27 27 |ak;....c|ase '\''|
|00003c60| 3a 20 73 74 61 74 65 20 | 3d 20 53 5f 51 55 4f 54 |: state |= S_QUOT|
|00003c70| 45 3b 20 62 72 65 61 6b | 3b 0a 20 20 20 20 20 20 |E; break|;. |
|00003c80| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00003c90| 20 20 63 61 73 65 20 27 | 22 27 20 3a 20 73 74 61 | case '|"' : sta|
|00003ca0| 74 65 20 3d 20 44 5f 51 | 55 4f 54 45 3b 20 62 72 |te = D_Q|UOTE; br|
|00003cb0| 65 61 6b 3b 0a 20 20 20 | 20 20 20 20 20 20 20 20 |eak;. | |
|00003cc0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 63 61 73 | | cas|
|00003cd0| 65 20 27 2f 27 20 3a 20 | 69 66 20 28 2a 50 20 21 |e '/' : |if (*P !|
|00003ce0| 3d 20 27 2a 27 29 20 63 | 6f 6e 74 69 6e 75 65 3b |= '*') c|ontinue;|
|00003cf0| 0a 09 09 09 20 20 20 20 | 20 20 20 20 20 20 20 73 |.... | s|
|00003d00| 74 61 74 65 3d 43 4f 4d | 4d 45 4e 54 3b 0a 09 09 |tate=COM|MENT;...|
|00003d10| 20 20 20 20 20 20 20 20 | 63 61 73 65 20 27 5c 5c | |case '\\|
|00003d20| 27 3a 20 70 75 74 63 68 | 61 72 20 28 2a 50 2b 2b |': putch|ar (*P++|
|00003d30| 29 3b 20 62 72 65 61 6b | 3b 0a 09 09 20 20 20 20 |); break|;... |
|00003d40| 20 7d 0a 09 20 20 20 20 | 20 20 20 20 20 20 7d 0a | }.. | }.|
|00003d50| 09 20 20 20 20 20 20 20 | 7d 0a 20 20 20 7d 0a 0a |. |}. }..|
|00003d60| 2f 2a 0a 20 2a 20 52 65 | 61 64 54 61 62 0a 20 2a |/*. * Re|adTab. *|
|00003d70| 0a 20 2a 20 52 65 61 64 | 20 74 68 65 20 68 61 73 |. * Read| the has|
|00003d80| 68 20 74 61 62 6c 65 2e | 0a 20 2a 0a 20 2a 20 49 |h table.|. *. * I|
|00003d90| 6e 0a 20 2a 20 20 20 20 | 20 20 4e 61 6d 65 20 3d |n. * | Name =|
|00003da0| 20 6e 61 6d 65 20 6f 66 | 20 68 61 73 68 20 74 61 | name of| hash ta|
|00003db0| 62 6c 65 20 66 69 6c 65 | 0a 20 2a 2f 0a 52 65 61 |ble file|. */.Rea|
|00003dc0| 64 54 61 62 20 28 4e 61 | 6d 65 29 0a 20 20 20 63 |dTab (Na|me). c|
|00003dd0| 68 61 72 20 2a 4e 61 6d | 65 3b 0a 20 20 20 7b 0a |har *Nam|e;. {.|
|00003de0| 20 20 20 20 20 20 46 49 | 4c 45 20 2a 54 61 62 6c | FI|LE *Tabl|
|00003df0| 65 3b 0a 20 20 20 20 20 | 20 63 68 61 72 20 53 5b |e;. | char S[|
|00003e00| 4d 41 58 4c 49 4e 45 5d | 3b 0a 20 20 20 20 20 20 |MAXLINE]|;. |
|00003e10| 69 6e 74 20 6b 2c 4c 2c | 43 6c 61 73 73 3b 0a 0a |int k,L,|Class;..|
|00003e20| 20 20 20 20 20 20 2f 2a | 20 46 69 72 73 74 20 72 | /*| First r|
|00003e30| 65 63 6f 72 64 20 61 6c | 6c 20 77 6f 72 64 73 20 |ecord al|l words |
|00003e40| 77 65 20 64 6f 6e 27 74 | 20 77 61 6e 74 20 6d 61 |we don't| want ma|
|00003e50| 6e 67 6c 65 64 20 69 6e | 20 68 61 73 68 20 74 61 |ngled in| hash ta|
|00003e60| 62 6c 65 20 2a 2f 20 20 | 20 20 20 20 0a 20 20 20 |ble */ | . |
|00003e70| 20 20 20 66 6f 72 20 28 | 6b 20 3d 20 30 3b 20 20 | for (|k = 0; |
|00003e80| 6b 20 3c 20 73 69 7a 65 | 6f 66 20 28 44 65 66 5f |k < size|of (Def_|
|00003e90| 72 65 73 65 72 76 65 64 | 29 20 2f 20 73 69 7a 65 |reserved|) / size|
|00003ea0| 6f 66 20 28 63 68 61 72 | 20 2a 29 3b 20 20 6b 2b |of (char| *); k+|
|00003eb0| 2b 29 0a 20 20 20 20 20 | 20 20 20 20 4c 6f 6f 6b |+). | Look|
|00003ec0| 55 70 20 28 44 65 66 5f | 72 65 73 65 72 76 65 64 |Up (Def_|reserved|
|00003ed0| 5b 6b 5d 2c 20 57 5f 52 | 45 53 45 52 56 45 44 29 |[k], W_R|ESERVED)|
|00003ee0| 3b 0a 20 20 20 20 20 20 | 66 6f 72 20 28 6b 20 3d |;. |for (k =|
|00003ef0| 20 30 3b 20 20 6b 20 3c | 20 52 65 73 5f 63 6f 75 | 0; k <| Res_cou|
|00003f00| 6e 74 3b 20 20 6b 2b 2b | 29 20 0a 20 20 20 20 20 |nt; k++|) . |
|00003f10| 20 20 20 20 4c 6f 6f 6b | 55 70 20 28 52 65 73 65 | Look|Up (Rese|
|00003f20| 72 76 65 64 5b 6b 5d 2c | 57 5f 52 45 53 45 52 56 |rved[k],|W_RESERV|
|00003f30| 45 44 29 3b 0a 0a 20 20 | 20 20 20 20 69 66 20 28 |ED);.. | if (|
|00003f40| 4e 55 4c 4c 20 3d 3d 20 | 28 54 61 62 6c 65 20 3d |NULL == |(Table =|
|00003f50| 20 66 6f 70 65 6e 20 28 | 4e 61 6d 65 2c 22 72 22 | fopen (|Name,"r"|
|00003f60| 29 29 29 20 72 65 74 75 | 72 6e 3b 0a 20 20 20 20 |))) retu|rn;. |
|00003f70| 20 20 77 68 69 6c 65 20 | 28 45 4f 46 20 21 3d 20 | while |(EOF != |
|00003f80| 28 4c 20 3d 20 66 73 63 | 61 6e 66 20 28 54 61 62 |(L = fsc|anf (Tab|
|00003f90| 6c 65 2c 22 25 64 20 25 | 64 20 25 73 22 2c 26 6b |le,"%d %|d %s",&k|
|00003fa0| 2c 26 43 6c 61 73 73 2c | 53 29 29 29 20 0a 09 20 |,&Class,|S))) .. |
|00003fb0| 69 66 20 28 4c 20 21 3d | 20 33 20 7c 7c 20 6b 20 |if (L !=| 3 || k |
|00003fc0| 26 7e 48 41 53 48 4d 41 | 53 4b 20 7c 7c 20 21 57 |&~HASHMA|SK || !W|
|00003fd0| 5f 56 61 6c 69 64 20 28 | 43 6c 61 73 73 29 29 0a |_Valid (|Class)).|
|00003fe0| 09 20 20 20 20 66 70 72 | 69 6e 74 66 20 28 73 74 |. fpr|intf (st|
|00003ff0| 64 65 72 72 2c 22 68 61 | 73 68 38 20 74 61 62 6c |derr,"ha|sh8 tabl|
|00004000| 65 20 65 72 72 6f 72 5c | 6e 22 29 2c 0a 09 20 20 |e error\|n"),.. |
|00004010| 20 20 65 78 69 74 20 28 | 31 29 3b 0a 20 20 20 20 | exit (|1);. |
|00004020| 20 20 20 20 20 65 6c 73 | 65 20 49 6e 73 65 72 74 | els|e Insert|
|00004030| 20 28 6b 2c 53 2c 43 6c | 61 73 73 29 3b 0a 20 20 | (k,S,Cl|ass);. |
|00004040| 20 20 20 20 66 63 6c 6f | 73 65 20 28 54 61 62 6c | fclo|se (Tabl|
|00004050| 65 29 3b 20 0a 20 20 20 | 20 20 20 4e 65 77 54 61 |e); . | NewTa|
|00004060| 62 20 3d 20 30 3b 0a 20 | 20 20 7d 0a 0a 2f 2a 0a |b = 0;. | }../*.|
|00004070| 20 2a 20 57 72 69 74 65 | 54 61 62 0a 20 2a 0a 20 | * Write|Tab. *. |
|00004080| 2a 20 57 72 69 74 65 20 | 6f 75 74 20 74 68 65 20 |* Write |out the |
|00004090| 68 61 73 68 20 74 61 62 | 6c 65 0a 20 2a 0a 20 2a |hash tab|le. *. *|
|000040a0| 20 49 6e 0a 20 2a 20 20 | 20 20 20 20 4e 61 6d 65 | In. * | Name|
|000040b0| 20 3d 20 6e 61 6d 65 20 | 6f 66 20 68 61 73 68 20 | = name |of hash |
|000040c0| 74 61 62 6c 65 20 66 69 | 6c 65 0a 20 2a 2f 0a 57 |table fi|le. */.W|
|000040d0| 72 69 74 65 54 61 62 20 | 28 4e 61 6d 65 29 0a 20 |riteTab |(Name). |
|000040e0| 20 20 63 68 61 72 20 2a | 4e 61 6d 65 3b 20 0a 20 | char *|Name; . |
|000040f0| 20 20 7b 20 0a 20 20 20 | 20 20 20 46 49 4c 45 20 | { . | FILE |
|00004100| 2a 54 61 62 6c 65 3b 0a | 20 20 20 20 20 20 69 6e |*Table;.| in|
|00004110| 74 20 69 3b 0a 0a 20 20 | 20 20 20 20 69 66 20 28 |t i;.. | if (|
|00004120| 4e 55 4c 4c 20 3d 3d 20 | 28 54 61 62 6c 65 20 3d |NULL == |(Table =|
|00004130| 20 66 6f 70 65 6e 20 28 | 4e 61 6d 65 2c 22 77 22 | fopen (|Name,"w"|
|00004140| 29 29 29 20 0a 09 20 66 | 70 72 69 6e 74 66 20 28 |))) .. f|printf (|
|00004150| 73 74 64 65 72 72 2c 22 | 68 61 73 68 38 3a 20 63 |stderr,"|hash8: c|
|00004160| 61 6e 27 74 20 6f 70 65 | 6e 20 68 61 73 68 20 74 |an't ope|n hash t|
|00004170| 61 62 6c 65 20 66 69 6c | 65 20 27 25 73 27 5c 6e |able fil|e '%s'\n|
|00004180| 22 2c 4e 61 6d 65 29 2c | 0a 09 20 65 78 69 74 20 |",Name),|.. exit |
|00004190| 28 31 29 3b 0a 20 20 20 | 20 20 20 66 6f 72 20 28 |(1);. | for (|
|000041a0| 69 3d 30 3b 20 69 3c 48 | 41 53 48 4c 49 4d 49 54 |i=0; i<H|ASHLIMIT|
|000041b0| 3b 20 69 2b 2b 29 0a 20 | 20 20 20 20 20 20 20 20 |; i++). | |
|000041c0| 69 66 20 28 48 61 73 68 | 54 61 62 5b 69 5d 20 21 |if (Hash|Tab[i] !|
|000041d0| 3d 20 4e 55 4c 4c 20 26 | 26 20 2a 48 61 73 68 54 |= NULL &|& *HashT|
|000041e0| 61 62 5b 69 5d 20 21 3d | 20 57 5f 52 45 53 45 52 |ab[i] !=| W_RESER|
|000041f0| 56 45 44 29 20 0a 20 20 | 20 20 20 20 20 20 20 20 |VED) . | |
|00004200| 20 20 66 70 72 69 6e 74 | 66 20 28 54 61 62 6c 65 | fprint|f (Table|
|00004210| 2c 22 25 64 09 25 64 09 | 25 73 5c 6e 22 2c 69 2c |,"%d.%d.|%s\n",i,|
|00004220| 2a 48 61 73 68 54 61 62 | 5b 69 5d 2c 48 61 73 68 |*HashTab|[i],Hash|
|00004230| 54 61 62 5b 69 5d 2b 31 | 29 3b 0a 20 20 20 20 20 |Tab[i]+1|);. |
|00004240| 20 66 63 6c 6f 73 65 20 | 28 54 61 62 6c 65 29 3b | fclose |(Table);|
|00004250| 20 0a 20 20 20 7d 0a 0a | 6d 61 69 6e 20 28 61 72 | . }..|main (ar|
|00004260| 67 63 2c 61 72 67 76 29 | 0a 20 20 20 69 6e 74 20 |gc,argv)|. int |
|00004270| 61 72 67 63 3b 20 63 68 | 61 72 20 2a 61 72 67 76 |argc; ch|ar *argv|
|00004280| 5b 5d 3b 0a 20 20 20 7b | 0a 20 20 20 20 20 20 72 |[];. {|. r|
|00004290| 65 67 69 73 74 65 72 20 | 63 68 61 72 20 2a 2a 68 |egister |char **h|
|000042a0| 3b 0a 20 20 20 20 20 20 | 69 6e 74 20 4d 6f 64 65 |;. |int Mode|
|000042b0| 3b 0a 0a 20 20 20 20 20 | 20 2f 2a 0a 20 20 20 20 |;.. | /*. |
|000042c0| 20 20 20 2a 20 53 65 74 | 20 75 70 20 74 68 65 20 | * Set| up the |
|000042d0| 72 65 73 65 72 76 65 64 | 2d 77 6f 72 64 20 6c 69 |reserved|-word li|
|000042e0| 73 74 2e 0a 20 20 20 20 | 20 20 20 2a 2f 0a 20 20 |st.. | */. |
|000042f0| 20 20 20 20 77 68 69 6c | 65 20 28 61 72 67 63 20 | whil|e (argc |
|00004300| 3e 20 33 20 20 26 26 20 | 20 61 72 67 76 5b 31 5d |> 3 && | argv[1]|
|00004310| 5b 30 5d 20 3d 3d 20 27 | 2d 27 20 20 26 26 20 20 |[0] == '|-' && |
|00004320| 61 72 67 76 5b 31 5d 5b | 31 5d 20 3d 3d 20 27 72 |argv[1][|1] == 'r|
|00004330| 27 29 20 7b 0a 09 20 61 | 72 67 76 5b 31 5d 20 2b |') {.. a|rgv[1] +|
|00004340| 3d 20 32 3b 0a 09 20 69 | 66 20 28 61 72 67 76 5b |= 2;.. i|f (argv[|
|00004350| 31 5d 5b 30 5d 20 3d 3d | 20 27 5c 30 27 29 20 7b |1][0] ==| '\0') {|
|00004360| 0a 09 20 20 20 20 61 72 | 67 63 2d 2d 3b 0a 09 20 |.. ar|gc--;.. |
|00004370| 20 20 20 61 72 67 76 2b | 2b 3b 0a 09 20 7d 0a 09 | argv+|+;.. }..|
|00004380| 20 69 66 20 28 52 65 73 | 5f 63 6f 75 6e 74 20 3d | if (Res|_count =|
|00004390| 3d 20 52 65 73 5f 6d 61 | 78 29 20 7b 0a 09 20 20 |= Res_ma|x) {.. |
|000043a0| 20 20 52 65 73 5f 6d 61 | 78 20 2b 3d 20 35 3b 0a | Res_ma|x += 5;.|
|000043b0| 09 20 20 20 20 69 66 20 | 28 52 65 73 65 72 76 65 |. if |(Reserve|
|000043c0| 64 20 3d 3d 20 4e 55 4c | 4c 29 0a 09 20 20 20 20 |d == NUL|L).. |
|000043d0| 20 20 20 52 65 73 65 72 | 76 65 64 20 3d 20 28 63 | Reser|ved = (c|
|000043e0| 68 61 72 20 2a 2a 29 20 | 6d 61 6c 6c 6f 63 20 28 |har **) |malloc (|
|000043f0| 35 20 2a 20 73 69 7a 65 | 6f 66 20 28 63 68 61 72 |5 * size|of (char|
|00004400| 20 2a 29 29 3b 0a 09 20 | 20 20 20 65 6c 73 65 0a | *));.. | else.|
|00004410| 09 20 20 20 20 20 20 20 | 52 65 73 65 72 76 65 64 |. |Reserved|
|00004420| 20 3d 20 28 63 68 61 72 | 20 2a 2a 29 0a 09 20 20 | = (char| **).. |
|00004430| 20 20 20 20 20 20 72 65 | 61 6c 6c 6f 63 20 28 28 | re|alloc ((|
|00004440| 63 68 61 72 20 2a 29 20 | 52 65 73 65 72 76 65 64 |char *) |Reserved|
|00004450| 2c 20 52 65 73 5f 6d 61 | 78 20 2a 20 73 69 7a 65 |, Res_ma|x * size|
|00004460| 6f 66 20 28 63 68 61 72 | 20 2a 29 29 3b 0a 09 20 |of (char| *));.. |
|00004470| 7d 0a 09 20 52 65 73 65 | 72 76 65 64 5b 52 65 73 |}.. Rese|rved[Res|
|00004480| 5f 63 6f 75 6e 74 5d 20 | 3d 20 61 72 67 76 5b 31 |_count] |= argv[1|
|00004490| 5d 3b 0a 09 20 52 65 73 | 5f 63 6f 75 6e 74 2b 2b |];.. Res|_count++|
|000044a0| 3b 0a 09 20 61 72 67 63 | 2d 2d 3b 0a 09 20 61 72 |;.. argc|--;.. ar|
|000044b0| 67 76 2b 2b 3b 0a 20 20 | 20 20 20 20 7d 0a 20 20 |gv++;. | }. |
|000044c0| 20 20 20 20 69 66 20 28 | 61 72 67 63 20 21 3d 20 | if (|argc != |
|000044d0| 33 29 20 7b 0a 20 20 20 | 20 20 20 20 20 20 66 70 |3) {. | fp|
|000044e0| 72 69 6e 74 66 20 28 73 | 74 64 65 72 72 2c 0a 20 |rintf (s|tderr,. |
|000044f0| 20 20 20 20 20 20 20 20 | 20 20 22 75 73 61 67 65 | | "usage|
|00004500| 3a 20 68 61 73 68 38 20 | 5b 2d 72 20 72 65 73 65 |: hash8 |[-r rese|
|00004510| 72 76 65 64 5d 20 2e 2e | 2e 20 28 65 6e 63 6f 64 |rved] ..|. (encod|
|00004520| 65 7c 5b 5f 5d 64 65 63 | 6f 64 65 29 20 74 61 62 |e|[_]dec|ode) tab|
|00004530| 6c 65 5c 6e 22 29 3b 0a | 20 20 20 20 20 20 20 20 |le\n");.| |
|00004540| 20 65 78 69 74 20 28 31 | 29 3b 0a 20 20 20 20 20 | exit (1|);. |
|00004550| 20 7d 0a 0a 20 20 20 20 | 20 20 2f 2a 0a 20 20 20 | }.. | /*. |
|00004560| 20 20 20 20 2a 20 49 66 | 20 65 69 74 68 65 72 20 | * If| either |
|00004570| 73 74 64 69 6e 20 6f 72 | 20 73 74 64 6f 75 74 20 |stdin or| stdout |
|00004580| 69 73 20 61 20 74 74 79 | 2c 20 73 65 74 20 62 6f |is a tty|, set bo|
|00004590| 74 68 20 75 6e 62 75 66 | 66 65 72 65 64 2c 20 66 |th unbuf|fered, f|
|000045a0| 6f 72 20 75 73 65 0a 20 | 20 20 20 20 20 20 2a 20 |or use. | * |
|000045b0| 69 6e 20 70 69 70 65 73 | 2e 0a 20 20 20 20 20 20 |in pipes|.. |
|000045c0| 20 2a 20 47 65 6f 66 66 | 20 4b 75 65 6e 6e 69 6e | * Geoff| Kuennin|
|000045d0| 67 2c 20 31 31 2f 38 2f | 38 36 0a 20 20 20 20 20 |g, 11/8/|86. |
|000045e0| 20 20 2a 2f 0a 20 20 20 | 20 20 20 69 66 20 28 69 | */. | if (i|
|000045f0| 73 61 74 74 79 20 28 66 | 69 6c 65 6e 6f 20 28 73 |satty (f|ileno (s|
|00004600| 74 64 69 6e 29 29 20 20 | 7c 7c 20 20 69 73 61 74 |tdin)) ||| isat|
|00004610| 74 79 20 28 66 69 6c 65 | 6e 6f 20 28 73 74 64 6f |ty (file|no (stdo|
|00004620| 75 74 29 29 29 20 7b 0a | 09 20 73 65 74 62 75 66 |ut))) {.|. setbuf|
|00004630| 20 28 73 74 64 69 6e 2c | 20 4e 55 4c 4c 29 3b 0a | (stdin,| NULL);.|
|00004640| 09 20 73 65 74 62 75 66 | 20 28 73 74 64 6f 75 74 |. setbuf| (stdout|
|00004650| 2c 20 4e 55 4c 4c 29 3b | 0a 20 20 20 20 20 20 7d |, NULL);|. }|
|00004660| 0a 20 20 20 20 20 20 48 | 61 73 68 54 61 62 20 3d |. H|ashTab =|
|00004670| 20 28 63 68 61 72 20 2a | 2a 29 20 6d 61 6c 6c 6f | (char *|*) mallo|
|00004680| 63 20 28 28 73 69 7a 65 | 6f 66 20 28 63 68 61 72 |c ((size|of (char|
|00004690| 2a 29 29 20 2a 20 28 48 | 41 53 48 4c 49 4d 49 54 |*)) * (H|ASHLIMIT|
|000046a0| 29 29 3b 0a 20 20 20 20 | 20 20 66 6f 72 20 28 68 |));. | for (h|
|000046b0| 20 3d 20 48 61 73 68 54 | 61 62 2b 48 41 53 48 4c | = HashT|ab+HASHL|
|000046c0| 49 4d 49 54 3b 20 2d 2d | 68 20 3e 20 48 61 73 68 |IMIT; --|h > Hash|
|000046d0| 54 61 62 3b 20 29 20 2a | 68 20 3d 20 4e 55 4c 4c |Tab; ) *|h = NULL|
|000046e0| 3b 0a 20 20 20 20 20 0a | 20 20 20 20 20 20 52 65 |;. .| Re|
|000046f0| 61 64 54 61 62 28 61 72 | 67 76 5b 32 5d 29 3b 20 |adTab(ar|gv[2]); |
|00004700| 0a 20 20 20 20 20 20 0a | 20 20 20 20 20 20 69 66 |. .| if|
|00004710| 20 28 21 73 74 72 63 6d | 70 20 28 61 72 67 76 5b | (!strcm|p (argv[|
|00004720| 31 5d 2c 22 65 6e 63 6f | 64 65 22 29 29 20 4d 6f |1],"enco|de")) Mo|
|00004730| 64 65 20 3d 20 45 4e 43 | 4f 44 45 3b 0a 20 20 20 |de = ENC|ODE;. |
|00004740| 20 20 20 65 6c 73 65 20 | 69 66 20 28 21 73 74 72 | else |if (!str|
|00004750| 63 6d 70 20 28 61 72 67 | 76 5b 31 5d 2c 22 64 65 |cmp (arg|v[1],"de|
|00004760| 63 6f 64 65 22 29 29 20 | 4d 6f 64 65 20 3d 20 44 |code")) |Mode = D|
|00004770| 45 43 4f 44 45 3b 20 0a | 20 20 20 20 20 20 65 6c |ECODE; .| el|
|00004780| 73 65 20 69 66 20 28 21 | 73 74 72 63 6d 70 20 28 |se if (!|strcmp (|
|00004790| 61 72 67 76 5b 31 5d 2c | 22 5f 64 65 63 6f 64 65 |argv[1],|"_decode|
|000047a0| 22 29 29 20 4d 6f 64 65 | 20 3d 20 5f 44 45 43 4f |")) Mode| = _DECO|
|000047b0| 44 45 3b 20 0a 20 20 20 | 20 20 20 65 6c 73 65 0a |DE; . | else.|
|000047c0| 20 20 20 20 20 20 20 20 | 20 66 70 72 69 6e 74 66 | | fprintf|
|000047d0| 20 28 73 74 64 65 72 72 | 2c 22 68 61 73 68 38 3a | (stderr|,"hash8:|
|000047e0| 20 73 65 63 6f 6e 64 20 | 61 72 67 20 6d 75 73 74 | second |arg must|
|000047f0| 20 62 65 20 27 65 6e 63 | 6f 64 65 27 20 6f 72 20 | be 'enc|ode' or |
|00004800| 27 64 65 63 6f 64 65 27 | 5c 6e 22 29 2c 0a 09 20 |'decode'|\n"),.. |
|00004810| 65 78 69 74 20 28 31 29 | 3b 0a 0a 20 20 20 20 20 |exit (1)|;.. |
|00004820| 20 54 72 61 6e 73 6c 61 | 74 65 20 28 4d 6f 64 65 | Transla|te (Mode|
|00004830| 29 3b 0a 20 20 20 20 20 | 20 69 66 20 28 4e 65 77 |);. | if (New|
|00004840| 54 61 62 29 20 57 72 69 | 74 65 54 61 62 28 61 72 |Tab) Wri|teTab(ar|
|00004850| 67 76 5b 32 5d 29 3b 0a | 20 20 20 7d 0a 0a 53 48 |gv[2]);.| }..SH|
|00004860| 41 52 5f 45 4f 46 0a 66 | 69 20 23 20 65 6e 64 20 |AR_EOF.f|i # end |
|00004870| 6f 66 20 6f 76 65 72 77 | 72 69 74 69 6e 67 20 63 |of overw|riting c|
|00004880| 68 65 63 6b 0a 65 63 68 | 6f 20 73 68 61 72 3a 20 |heck.ech|o shar: |
|00004890| 65 78 74 72 61 63 74 69 | 6e 67 20 22 27 6c 63 63 |extracti|ng "'lcc|
|000048a0| 2e 73 68 2c 76 27 22 20 | 27 28 31 31 39 35 36 20 |.sh,v'" |'(11956 |
|000048b0| 63 68 61 72 61 63 74 65 | 72 73 29 27 0a 69 66 20 |characte|rs)'.if |
|000048c0| 74 65 73 74 20 2d 66 20 | 27 6c 63 63 2e 73 68 2c |test -f |'lcc.sh,|
|000048d0| 76 27 0a 74 68 65 6e 0a | 09 65 63 68 6f 20 73 68 |v'.then.|.echo sh|
|000048e0| 61 72 3a 20 77 69 6c 6c | 20 6e 6f 74 20 6f 76 65 |ar: will| not ove|
|000048f0| 72 2d 77 72 69 74 65 20 | 65 78 69 73 74 69 6e 67 |r-write |existing|
|00004900| 20 66 69 6c 65 20 22 27 | 6c 63 63 2e 73 68 2c 76 | file "'|lcc.sh,v|
|00004910| 27 22 0a 65 6c 73 65 0a | 63 61 74 20 3c 3c 20 5c |'".else.|cat << \|
|00004920| 53 48 41 52 5f 45 4f 46 | 20 3e 20 27 6c 63 63 2e |SHAR_EOF| > 'lcc.|
|00004930| 73 68 2c 76 27 0a 68 65 | 61 64 20 20 20 20 20 31 |sh,v'.he|ad 1|
|00004940| 2e 35 3b 0a 61 63 63 65 | 73 73 20 20 20 3b 0a 73 |.5;.acce|ss ;.s|
|00004950| 79 6d 62 6f 6c 73 20 20 | 3b 0a 6c 6f 63 6b 73 20 |ymbols |;.locks |
|00004960| 20 20 20 3b 20 73 74 72 | 69 63 74 3b 0a 63 6f 6d | ; str|ict;.com|
|00004970| 6d 65 6e 74 20 20 40 23 | 20 40 3b 0a 0a 0a 31 2e |ment @#| @;...1.|
|00004980| 35 0a 64 61 74 65 20 20 | 20 20 20 38 37 2e 30 33 |5.date | 87.03|
|00004990| 2e 30 36 2e 32 30 2e 33 | 34 2e 32 39 3b 20 20 61 |.06.20.3|4.29; a|
|000049a0| 75 74 68 6f 72 20 67 65 | 6f 66 66 3b 20 20 73 74 |uthor ge|off; st|
|000049b0| 61 74 65 20 45 78 70 3b | 0a 62 72 61 6e 63 68 65 |ate Exp;|.branche|
|000049c0| 73 20 3b 0a 6e 65 78 74 | 20 20 20 20 20 31 2e 34 |s ;.next| 1.4|
|000049d0| 3b 0a 0a 31 2e 34 0a 64 | 61 74 65 20 20 20 20 20 |;..1.4.d|ate |
|000049e0| 38 37 2e 30 32 2e 32 38 | 2e 30 30 2e 35 36 2e 35 |87.02.28|.00.56.5|
|000049f0| 30 3b 20 20 61 75 74 68 | 6f 72 20 67 65 6f 66 66 |0; auth|or geoff|
|00004a00| 3b 20 20 73 74 61 74 65 | 20 45 78 70 3b 0a 62 72 |; state| Exp;.br|
|00004a10| 61 6e 63 68 65 73 20 3b | 0a 6e 65 78 74 20 20 20 |anches ;|.next |
|00004a20| 20 20 31 2e 33 3b 0a 0a | 31 2e 33 0a 64 61 74 65 | 1.3;..|1.3.date|
|00004a30| 20 20 20 20 20 38 36 2e | 31 31 2e 30 38 2e 32 33 | 86.|11.08.23|
|00004a40| 2e 30 37 2e 35 36 3b 20 | 20 61 75 74 68 6f 72 20 |.07.56; | author |
|00004a50| 67 65 6f 66 66 3b 20 20 | 73 74 61 74 65 20 45 78 |geoff; |state Ex|
|00004a60| 70 3b 0a 62 72 61 6e 63 | 68 65 73 20 3b 0a 6e 65 |p;.branc|hes ;.ne|
|00004a70| 78 74 20 20 20 20 20 31 | 2e 32 3b 0a 0a 31 2e 32 |xt 1|.2;..1.2|
|00004a80| 0a 64 61 74 65 20 20 20 | 20 20 38 36 2e 31 31 2e |.date | 86.11.|
|00004a90| 30 38 2e 32 32 2e 31 35 | 2e 32 34 3b 20 20 61 75 |08.22.15|.24; au|
|00004aa0| 74 68 6f 72 20 67 65 6f | 66 66 3b 20 20 73 74 61 |thor geo|ff; sta|
|00004ab0| 74 65 20 45 78 70 3b 0a | 62 72 61 6e 63 68 65 73 |te Exp;.|branches|
|00004ac0| 20 3b 0a 6e 65 78 74 20 | 20 20 20 20 31 2e 31 3b | ;.next | 1.1;|
|00004ad0| 0a 0a 31 2e 31 0a 64 61 | 74 65 20 20 20 20 20 38 |..1.1.da|te 8|
|00004ae0| 36 2e 31 31 2e 30 38 2e | 32 31 2e 35 38 2e 31 34 |6.11.08.|21.58.14|
|00004af0| 3b 20 20 61 75 74 68 6f | 72 20 67 65 6f 66 66 3b |; autho|r geoff;|
|00004b00| 20 20 73 74 61 74 65 20 | 45 78 70 3b 0a 62 72 61 | state |Exp;.bra|
|00004b10| 6e 63 68 65 73 20 3b 0a | 6e 65 78 74 20 20 20 20 |nches ;.|next |
|00004b20| 20 3b 0a 0a 0a 64 65 73 | 63 0a 40 53 68 65 6c 6c | ;...des|c.@Shell|
|00004b30| 20 73 63 72 69 70 74 20 | 74 6f 20 63 6f 6d 70 69 | script |to compi|
|00004b40| 6c 65 20 6c 6f 6e 67 2d | 6e 61 6d 65 20 43 20 70 |le long-|name C p|
|00004b50| 72 6f 67 72 61 6d 73 2e | 0a 40 0a 0a 0a 31 2e 35 |rograms.|.@...1.5|
|00004b60| 0a 6c 6f 67 0a 40 4d 61 | 6b 65 20 2d 70 20 77 6f |.log.@Ma|ke -p wo|
|00004b70| 72 6b 20 63 6f 72 72 65 | 63 74 6c 79 0a 40 0a 74 |rk corre|ctly.@.t|
|00004b80| 65 78 74 0a 40 3a 20 55 | 73 65 20 62 69 6e 2f 73 |ext.@: U|se bin/s|
|00004b90| 68 0a 23 0a 23 20 24 48 | 65 61 64 65 72 3a 20 6c |h.#.# $H|eader: l|
|00004ba0| 63 63 2e 73 68 2c 76 20 | 31 2e 34 20 38 37 2f 30 |cc.sh,v |1.4 87/0|
|00004bb0| 32 2f 32 38 20 30 30 3a | 35 36 3a 35 30 20 67 65 |2/28 00:|56:50 ge|
|00004bc0| 6f 66 66 20 45 78 70 20 | 24 0a 23 0a 23 20 24 4c |off Exp |$.#.# $L|
|00004bd0| 6f 67 3a 09 6c 63 63 2e | 73 68 2c 76 20 24 0a 23 |og:.lcc.|sh,v $.#|
|00004be0| 20 52 65 76 69 73 69 6f | 6e 20 31 2e 34 20 20 38 | Revisio|n 1.4 8|
|00004bf0| 37 2f 30 32 2f 32 38 20 | 20 30 30 3a 35 36 3a 35 |7/02/28 | 00:56:5|
|00004c00| 30 20 20 67 65 6f 66 66 | 0a 23 20 4d 61 6a 6f 72 |0 geoff|.# Major|
|00004c10| 20 63 68 61 6e 67 65 73 | 20 74 6f 20 68 61 6e 64 | changes| to hand|
|00004c20| 6c 65 20 74 68 69 6e 67 | 73 20 6d 75 63 68 20 62 |le thing|s much b|
|00004c30| 65 74 74 65 72 20 62 79 | 20 72 75 6e 6e 69 6e 67 |etter by| running|
|00004c40| 20 65 61 63 68 20 63 6f | 6d 70 69 6c 65 72 0a 23 | each co|mpiler.#|
|00004c50| 20 70 61 73 73 20 73 65 | 70 61 72 61 74 65 6c 79 | pass se|parately|
|00004c60| 2e 20 20 41 6c 73 6f 20 | 61 64 64 20 74 68 65 20 |. Also |add the |
|00004c70| 2d 52 20 73 77 69 74 63 | 68 2c 20 61 6e 64 20 73 |-R switc|h, and s|
|00004c80| 75 70 70 6f 72 74 20 66 | 6f 72 20 2d 44 20 61 6e |upport f|or -D an|
|00004c90| 64 0a 23 20 6c 69 62 72 | 61 72 79 20 66 69 6c 65 |d.# libr|ary file|
|00004ca0| 73 2e 0a 23 20 0a 23 20 | 52 65 76 69 73 69 6f 6e |s..# .# |Revision|
|00004cb0| 20 31 2e 33 20 20 38 36 | 2f 31 31 2f 30 38 20 20 | 1.3 86|/11/08 |
|00004cc0| 32 33 3a 30 37 3a 35 36 | 20 20 67 65 6f 66 66 0a |23:07:56| geoff.|
|00004cd0| 23 20 41 64 64 20 65 72 | 72 6f 72 20 70 72 6f 63 |# Add er|ror proc|
|00004ce0| 65 73 73 69 6e 67 2c 20 | 6e 6f 74 20 71 75 69 74 |essing, |not quit|
|00004cf0| 65 20 6c 69 6b 65 20 63 | 63 27 73 0a 23 20 0a 23 |e like c|c's.# .#|
|00004d00| 20 52 65 76 69 73 69 6f | 6e 20 31 2e 32 20 20 38 | Revisio|n 1.2 8|
|00004d10| 36 2f 31 31 2f 30 38 20 | 20 32 32 3a 31 35 3a 32 |6/11/08 | 22:15:2|
|00004d20| 34 20 20 67 65 6f 66 66 | 0a 23 20 52 65 6d 6f 76 |4 geoff|.# Remov|
|00004d30| 65 20 2d 48 50 2c 20 6d | 69 6e 6f 72 20 63 6c 65 |e -HP, m|inor cle|
|00004d40| 61 6e 75 70 20 6f 66 20 | 6f 75 74 70 75 74 2e 20 |anup of |output. |
|00004d50| 20 57 6f 72 6b 69 6e 67 | 2c 20 65 78 63 65 70 74 | Working|, except|
|00004d60| 20 69 67 6e 6f 72 65 73 | 20 65 72 72 6f 72 73 0a | ignores| errors.|
|00004d70| 23 20 0a 23 20 52 65 76 | 69 73 69 6f 6e 20 31 2e |# .# Rev|ision 1.|
|00004d80| 31 20 20 38 36 2f 31 31 | 2f 30 38 20 20 32 31 3a |1 86/11|/08 21:|
|00004d90| 35 38 3a 31 34 20 20 67 | 65 6f 66 66 0a 23 20 57 |58:14 g|eoff.# W|
|00004da0| 6f 72 6b 73 20 6f 6e 6c | 79 20 69 66 20 2d 48 50 |orks onl|y if -HP|
|00004db0| 20 73 70 65 63 69 66 69 | 65 64 0a 23 20 0a 23 0a | specifi|ed.# .#.|
|00004dc0| 23 09 52 65 70 6c 61 63 | 65 6d 65 6e 74 20 66 6f |#.Replac|ement fo|
|00004dd0| 72 20 74 68 65 20 27 63 | 63 27 20 63 6f 6d 6d 61 |r the 'c|c' comma|
|00004de0| 6e 64 2c 20 77 69 74 68 | 20 73 75 70 70 6f 72 74 |nd, with| support|
|00004df0| 20 66 6f 72 20 6c 6f 6e | 67 0a 23 09 69 64 65 6e | for lon|g.#.iden|
|00004e00| 74 69 66 69 65 72 73 2e | 0a 23 0a 23 09 55 73 61 |tifiers.|.#.#.Usa|
|00004e10| 67 65 3a 0a 23 0a 23 09 | 6c 63 63 20 5b 6f 70 74 |ge:.#.#.|lcc [opt|
|00004e20| 69 6f 6e 73 5d 20 66 69 | 6c 65 73 0a 23 0a 23 09 |ions] fi|les.#.#.|
|00004e30| 41 73 20 77 69 74 68 20 | 27 63 63 27 2c 20 74 68 |As with |'cc', th|
|00004e40| 65 20 66 69 6c 65 73 20 | 6d 65 6e 74 69 6f 6e 65 |e files |mentione|
|00004e50| 64 20 63 61 6e 20 62 65 | 20 2e 63 2c 20 2e 73 2c |d can be| .c, .s,|
|00004e60| 20 6f 72 20 2e 6f 20 66 | 69 6c 65 73 2e 0a 23 0a | or .o f|iles..#.|
|00004e70| 23 09 41 6c 6c 20 27 63 | 63 27 20 6f 70 74 69 6f |#.All 'c|c' optio|
|00004e80| 6e 73 20 61 72 65 20 73 | 75 70 70 6f 72 74 20 28 |ns are s|upport (|
|00004e90| 6f 72 20 73 68 6f 75 6c | 64 20 62 65 20 2d 2d 20 |or shoul|d be -- |
|00004ea0| 72 65 70 6f 72 74 20 62 | 75 67 73 21 29 2e 0a 23 |report b|ugs!)..#|
|00004eb0| 0a 23 09 54 68 65 72 65 | 20 61 72 65 20 73 6f 6d |.#.There| are som|
|00004ec0| 65 20 65 78 74 72 61 20 | 6f 70 74 69 6f 6e 73 2e |e extra |options.|
|00004ed0| 20 20 41 6c 6c 20 62 65 | 67 69 6e 20 77 69 74 68 | All be|gin with|
|00004ee0| 20 48 3a 0a 23 0a 23 09 | 2d 48 44 09 44 6f 6e 27 | H:.#.#.|-HD.Don'|
|00004ef0| 74 20 70 72 65 73 65 72 | 76 65 20 74 68 65 20 65 |t preser|ve the e|
|00004f00| 6e 63 6f 64 65 2f 64 65 | 63 6f 64 65 20 74 61 62 |ncode/de|code tab|
|00004f10| 6c 65 2e 20 20 28 4e 6f | 72 6d 61 6c 6c 79 2c 20 |le. (No|rmally, |
|00004f20| 69 74 20 69 73 0a 23 09 | 09 6c 65 66 74 20 69 6e |it is.#.|.left in|
|00004f30| 20 78 78 78 78 2e 74 2c | 20 77 68 65 72 65 20 78 | xxxx.t,| where x|
|00004f40| 78 78 78 20 69 73 20 74 | 68 65 20 66 69 72 73 74 |xxx is t|he first|
|00004f50| 20 66 69 6c 65 20 6e 61 | 6d 65 20 65 6e 63 6f 75 | file na|me encou|
|00004f60| 6e 74 65 72 65 64 2c 0a | 23 09 09 6f 72 20 74 68 |ntered,.|#..or th|
|00004f70| 65 20 2d 6f 20 66 69 6c | 65 20 6e 61 6d 65 20 69 |e -o fil|e name i|
|00004f80| 66 20 2d 6f 20 69 73 20 | 73 70 65 63 69 66 69 65 |f -o is |specifie|
|00004f90| 64 2e 29 0a 23 09 2d 48 | 41 20 6e 61 6d 65 20 54 |d.).#.-H|A name T|
|00004fa0| 68 65 20 65 6e 63 6f 64 | 65 2f 64 65 63 6f 64 65 |he encod|e/decode|
|00004fb0| 20 74 61 62 6c 65 20 69 | 73 20 70 75 74 20 69 6e | table i|s put in|
|00004fc0| 20 3c 6e 61 6d 65 3e 2e | 20 20 49 66 20 69 74 20 | <name>.| If it |
|00004fd0| 65 78 69 73 74 73 2c 0a | 23 09 09 74 68 65 20 70 |exists,.|#..the p|
|00004fe0| 72 6f 67 72 61 6d 20 77 | 69 6c 6c 20 61 70 70 65 |rogram w|ill appe|
|00004ff0| 6e 64 20 74 6f 20 69 74 | 2e 0a 23 09 2d 48 4c 09 |nd to it|..#.-HL.|
|00005000| 4f 6e 6c 79 20 74 68 65 | 20 43 20 63 6f 6d 70 69 |Only the| C compi|
|00005010| 6c 65 72 20 69 74 73 65 | 6c 66 20 69 73 20 64 65 |ler itse|lf is de|
|00005020| 66 69 63 69 65 6e 74 3b | 20 20 74 68 65 20 61 73 |ficient;| the as|
|00005030| 73 65 6d 62 6c 65 72 0a | 23 09 09 61 6e 64 20 6c |sembler.|#..and l|
|00005040| 69 6e 6b 65 72 20 63 61 | 6e 20 68 61 6e 64 6c 65 |inker ca|n handle|
|00005050| 20 6c 6f 6e 67 20 6e 61 | 6d 65 73 2e 20 20 55 73 | long na|mes. Us|
|00005060| 65 20 74 68 69 73 20 66 | 61 63 69 6c 69 74 79 20 |e this f|acility |
|00005070| 74 6f 0a 23 09 09 67 65 | 6e 65 72 61 74 65 20 6c |to.#..ge|nerate l|
|00005080| 6f 6e 67 2d 6e 61 6d 65 | 20 6f 62 6a 65 63 74 20 |ong-name| object |
|00005090| 66 69 6c 65 73 2e 20 20 | 54 68 69 73 20 69 73 20 |files. |This is |
|000050a0| 69 6e 63 6f 6d 70 61 74 | 69 62 6c 65 0a 23 09 09 |incompat|ible.#..|
|000050b0| 77 69 74 68 20 2d 50 20 | 61 6e 64 20 2d 53 2c 20 |with -P |and -S, |
|000050c0| 62 75 74 20 63 6f 6e 66 | 6c 69 63 74 20 69 73 20 |but conf|lict is |
|000050d0| 6e 6f 74 20 63 68 65 63 | 6b 65 64 2e 0a 23 09 2d |not chec|ked..#.-|
|000050e0| 52 20 6e 61 6d 65 09 41 | 64 64 20 3c 6e 61 6d 65 |R name.A|dd <name|
|000050f0| 3e 20 74 6f 20 74 68 65 | 20 72 65 73 65 72 76 65 |> to the| reserve|
|00005100| 64 2d 77 6f 72 64 20 6c | 69 73 74 2e 20 20 55 73 |d-word l|ist. Us|
|00005110| 65 66 75 6c 20 66 6f 72 | 0a 23 09 09 6c 69 62 72 |eful for|.#..libr|
|00005120| 61 72 79 20 72 6f 75 74 | 69 6e 65 73 20 74 68 61 |ary rout|ines tha|
|00005130| 74 20 68 61 76 65 20 6c | 6f 6e 67 20 6e 61 6d 65 |t have l|ong name|
|00005140| 73 2e 0a 23 0a 23 09 4f | 70 74 69 6f 6e 73 20 73 |s..#.#.O|ptions s|
|00005150| 75 70 70 6f 72 74 65 64 | 3a 0a 23 0a 23 09 2d 49 |upported|:.#.#.-I|
|00005160| 3c 64 69 72 3e 09 53 65 | 74 20 69 6e 63 6c 75 64 |<dir>.Se|t includ|
|00005170| 65 20 70 61 74 68 20 66 | 6f 72 20 63 70 70 0a 23 |e path f|or cpp.#|
|00005180| 09 2d 53 09 47 65 6e 65 | 72 61 74 65 20 2e 73 20 |.-S.Gene|rate .s |
|00005190| 66 69 6c 65 73 0a 23 09 | 2d 63 09 47 65 6e 65 72 |files.#.|-c.Gener|
|000051a0| 61 74 65 20 2e 6f 20 66 | 69 6c 65 73 3b 20 20 64 |ate .o f|iles; d|
|000051b0| 6f 6e 27 74 20 6c 6f 61 | 64 0a 23 09 2d 6e 09 47 |on't loa|d.#.-n.G|
|000051c0| 65 6e 65 72 61 74 65 20 | 73 68 61 72 65 64 20 74 |enerate |shared t|
|000051d0| 65 78 74 20 28 6c 64 29 | 0a 23 09 2d 70 09 47 65 |ext (ld)|.#.-p.Ge|
|000051e0| 6e 65 72 61 74 65 20 70 | 72 6f 66 69 6c 65 64 20 |nerate p|rofiled |
|000051f0| 6f 75 74 70 75 74 0a 23 | 09 2d 66 2a 09 50 61 73 |output.#|.-f*.Pas|
|00005200| 73 65 64 20 6f 6e 20 74 | 6f 20 63 63 0a 23 0a 54 |sed on t|o cc.#.T|
|00005210| 44 49 52 3d 24 7b 54 4d | 50 44 49 52 3a 2d 2f 74 |DIR=${TM|PDIR:-/t|
|00005220| 6d 70 7d 09 09 23 20 57 | 68 65 72 65 20 74 6f 20 |mp}..# W|here to |
|00005230| 70 75 74 20 74 65 6d 70 | 20 66 69 6c 65 73 0a 54 |put temp| files.T|
|00005240| 46 49 4c 45 3d 6c 63 63 | 24 24 09 09 09 23 20 42 |FILE=lcc|$$...# B|
|00005250| 61 73 65 20 6e 61 6d 65 | 20 66 6f 72 20 65 6e 63 |ase name| for enc|
|00005260| 6f 64 65 64 20 73 6f 75 | 72 63 65 20 66 69 6c 65 |oded sou|rce file|
|00005270| 73 0a 54 4d 50 3d 24 54 | 44 49 52 2f 24 54 46 49 |s.TMP=$T|DIR/$TFI|
|00005280| 4c 45 09 09 23 20 42 61 | 73 65 20 6e 61 6d 65 20 |LE..# Ba|se name |
|00005290| 6f 66 20 63 63 27 73 20 | 65 6e 63 6f 64 65 64 20 |of cc's |encoded |
|000052a0| 69 6e 70 75 74 20 66 69 | 6c 65 73 0a 54 41 42 4c |input fi|les.TABL|
|000052b0| 45 3d 24 7b 54 46 49 4c | 45 7d 74 09 09 09 23 20 |E=${TFIL|E}t...# |
|000052c0| 57 68 65 72 65 20 74 68 | 65 20 64 65 63 6f 64 65 |Where th|e decode|
|000052d0| 20 66 69 6c 65 20 67 6f | 65 73 0a 63 31 73 77 3d | file go|es.c1sw=|
|000052e0| 09 09 09 09 23 20 53 77 | 69 74 63 68 65 73 20 66 |....# Sw|itches f|
|000052f0| 6f 72 20 63 6f 6d 70 69 | 6c 65 72 20 70 61 73 73 |or compi|ler pass|
|00005300| 20 31 0a 63 63 73 77 3d | 09 09 09 09 23 20 53 77 | 1.ccsw=|....# Sw|
|00005310| 69 74 63 68 65 73 20 66 | 6f 72 20 63 63 0a 6c 64 |itches f|or cc.ld|
|00005320| 73 77 3d 09 09 09 09 23 | 20 53 77 69 74 63 68 65 |sw=....#| Switche|
|00005330| 73 20 66 6f 72 20 6c 64 | 0a 73 75 66 66 69 78 3d |s for ld|.suffix=|
|00005340| 6f 09 09 09 23 20 53 75 | 66 66 69 78 20 6f 66 20 |o...# Su|ffix of |
|00005350| 6f 75 74 70 75 74 20 22 | 6f 62 6a 65 63 74 22 20 |output "|object" |
|00005360| 66 69 6c 65 73 3a 20 20 | 6f 2c 20 73 2c 20 6f 72 |files: |o, s, or|
|00005370| 20 69 0a 66 6f 72 63 65 | 6f 62 6a 3d 2d 63 09 09 | i.force|obj=-c..|
|00005380| 09 23 20 48 6f 77 20 74 | 6f 20 66 6f 72 63 65 20 |.# How t|o force |
|00005390| 22 6f 62 6a 65 63 74 73 | 22 3a 20 20 2d 63 2c 20 |"objects|": -c, |
|000053a0| 2d 50 2c 20 6f 72 20 2d | 53 0a 6c 6f 61 64 3d 79 |-P, or -|S.load=y|
|000053b0| 65 73 09 09 09 23 20 59 | 65 73 20 74 6f 20 69 6e |es...# Y|es to in|
|000053c0| 76 6f 6b 65 20 6c 6f 61 | 64 65 72 0a 6e 75 6d 73 |voke loa|der.nums|
|000053d0| 72 63 66 69 6c 65 73 3d | 09 09 09 23 20 49 66 20 |rcfiles=|...# If |
|000053e0| 74 68 69 73 20 69 73 20 | 65 78 61 63 74 6c 79 20 |this is |exactly |
|000053f0| 6f 6e 65 20 78 2c 20 77 | 65 20 6b 69 6c 6c 20 6f |one x, w|e kill o|
|00005400| 62 6a 65 63 74 73 0a 6f | 66 69 6c 65 73 3d 09 09 |bjects.o|files=..|
|00005410| 09 09 23 20 46 69 6c 65 | 73 20 74 6f 20 62 65 20 |..# File|s to be |
|00005420| 6c 69 6e 6b 65 64 0a 6f | 70 74 69 6d 69 7a 65 3d |linked.o|ptimize=|
|00005430| 6e 6f 09 09 09 23 20 2d | 4f 20 73 77 69 74 63 68 |no...# -|O switch|
|00005440| 20 73 70 65 63 69 66 69 | 65 64 0a 6f 70 74 73 77 | specifi|ed.optsw|
|00005450| 3d 09 09 09 09 23 20 53 | 77 69 74 63 68 65 73 20 |=....# S|witches |
|00005460| 66 6f 72 20 6f 70 74 69 | 6d 69 7a 65 72 0a 70 72 |for opti|mizer.pr|
|00005470| 65 70 72 6f 63 65 73 73 | 3d 09 09 09 23 20 50 72 |eprocess|=...# Pr|
|00005480| 65 70 72 6f 63 65 73 73 | 20 6f 70 74 69 6f 6e 3a |eprocess| option:|
|00005490| 20 20 6e 75 6c 6c 2c 20 | 2d 50 2c 20 6f 72 20 2d | null, |-P, or -|
|000054a0| 45 0a 72 65 73 65 72 76 | 65 64 3d 09 09 09 23 20 |E.reserv|ed=...# |
|000054b0| 52 65 73 65 72 76 65 64 | 2d 77 6f 72 64 20 6c 69 |Reserved|-word li|
|000054c0| 73 74 0a 72 6d 66 69 6c | 65 73 3d 09 09 09 23 20 |st.rmfil|es=...# |
|000054d0| 4c 69 73 74 20 6f 66 20 | 6f 62 6a 65 63 74 20 66 |List of |object f|
|000054e0| 69 6c 65 73 20 74 6f 20 | 72 65 6d 6f 76 65 20 28 |iles to |remove (|
|000054f0| 6f 6e 6c 79 20 6f 6e 65 | 29 0a 76 65 72 62 6f 73 |only one|).verbos|
|00005500| 65 3d 09 09 09 23 20 56 | 65 72 62 6f 73 65 20 6f |e=...# V|erbose o|
|00005510| 70 74 69 6f 6e 3a 20 20 | 2d 76 20 6f 72 20 6e 75 |ption: |-v or nu|
|00005520| 6c 6c 0a 6b 69 6c 6c 74 | 61 62 6c 65 3d 6e 6f 09 |ll.killt|able=no.|
|00005530| 09 09 23 20 59 65 73 20 | 69 66 20 24 54 41 42 4c |..# Yes |if $TABL|
|00005540| 45 20 69 73 20 74 6f 20 | 62 65 20 64 65 6c 65 74 |E is to |be delet|
|00005550| 65 64 0a 74 61 62 6c 65 | 6e 61 6d 65 3d 09 09 09 |ed.table|name=...|
|00005560| 23 20 4e 61 6d 65 20 6f | 66 20 74 68 65 20 6f 75 |# Name o|f the ou|
|00005570| 74 70 75 74 20 74 61 62 | 6c 65 0a 6d 61 64 65 74 |tput tab|le.madet|
|00005580| 61 62 6c 65 3d 6e 6f 09 | 09 09 23 20 59 65 73 20 |able=no.|..# Yes |
|00005590| 69 66 20 77 65 20 61 64 | 64 65 64 20 74 6f 20 74 |if we ad|ded to t|
|000055a0| 68 65 20 74 61 62 6c 65 | 0a 64 75 6d 62 63 63 3d |he table|.dumbcc=|
|000055b0| 6e 6f 09 09 09 23 20 59 | 65 73 20 69 66 20 6f 6e |no...# Y|es if on|
|000055c0| 6c 79 20 63 63 20 69 73 | 20 64 75 6d 62 20 61 62 |ly cc is| dumb ab|
|000055d0| 6f 75 74 20 6c 6f 6e 67 | 20 6e 61 6d 65 73 0a 0a |out long| names..|
|000055e0| 69 66 20 5b 20 2d 78 20 | 2f 6c 69 62 2f 63 20 5d |if [ -x |/lib/c ]|
|000055f0| 0a 74 68 65 6e 0a 20 20 | 20 20 43 4f 4d 50 49 4c |.then. | COMPIL|
|00005600| 45 52 3d 2f 6c 69 62 2f | 63 0a 65 6c 69 66 20 5b |ER=/lib/|c.elif [|
|00005610| 20 2d 78 20 2f 75 73 72 | 2f 6c 69 62 2f 63 20 5d | -x /usr|/lib/c ]|
|00005620| 0a 74 68 65 6e 0a 20 20 | 20 20 43 4f 4d 50 49 4c |.then. | COMPIL|
|00005630| 45 52 3d 2f 75 73 72 2f | 6c 69 62 2f 63 0a 65 6c |ER=/usr/|lib/c.el|
|00005640| 73 65 0a 20 20 20 20 43 | 4f 4d 50 49 4c 45 52 3d |se. C|OMPILER=|
|00005650| 63 0a 66 69 0a 69 66 20 | 5b 20 2d 78 20 2f 6c 69 |c.fi.if |[ -x /li|
|00005660| 62 2f 63 32 20 5d 0a 74 | 68 65 6e 0a 20 20 20 20 |b/c2 ].t|hen. |
|00005670| 4f 50 54 49 4d 49 5a 45 | 52 3d 2f 6c 69 62 2f 63 |OPTIMIZE|R=/lib/c|
|00005680| 32 0a 65 6c 69 66 20 5b | 20 2d 78 20 2f 75 73 72 |2.elif [| -x /usr|
|00005690| 2f 6c 69 62 2f 63 32 20 | 5d 0a 74 68 65 6e 0a 20 |/lib/c2 |].then. |
|000056a0| 20 20 20 4f 50 54 49 4d | 49 5a 45 52 3d 2f 75 73 | OPTIM|IZER=/us|
|000056b0| 72 2f 6c 69 62 2f 63 32 | 0a 65 6c 73 65 0a 20 20 |r/lib/c2|.else. |
|000056c0| 20 20 4f 50 54 49 4d 49 | 5a 45 52 3d 63 32 0a 66 | OPTIMI|ZER=c2.f|
|000056d0| 69 0a 74 72 61 70 20 27 | 2f 62 69 6e 2f 72 6d 20 |i.trap '|/bin/rm |
|000056e0| 2d 66 20 24 7b 54 46 49 | 4c 45 7d 2e 3f 20 24 7b |-f ${TFI|LE}.? ${|
|000056f0| 54 4d 50 7d 2a 20 24 54 | 41 42 4c 45 3b 20 65 78 |TMP}* $T|ABLE; ex|
|00005700| 69 74 20 31 27 20 31 20 | 32 20 31 35 0a 23 20 37 |it 1' 1 |2 15.# 7|
|00005710| 20 69 73 20 53 49 47 45 | 4d 54 2c 20 61 20 66 61 | is SIGE|MT, a fa|
|00005720| 69 72 6c 79 20 6f 62 73 | 63 75 72 65 20 6f 6e 65 |irly obs|cure one|
|00005730| 0a 66 61 69 6c 75 72 65 | 3d 6e 6f 0a 74 72 61 70 |.failure|=no.trap|
|00005740| 20 22 66 61 69 6c 75 72 | 65 3d 79 65 73 22 20 37 | "failur|e=yes" 7|
|00005750| 0a 77 68 69 6c 65 20 5b | 20 24 23 20 2d 67 74 20 |.while [| $# -gt |
|00005760| 30 20 5d 0a 64 6f 0a 20 | 20 20 20 63 61 73 65 20 |0 ].do. | case |
|00005770| 22 24 31 22 20 69 6e 0a | 09 2d 48 44 29 0a 09 20 |"$1" in.|.-HD).. |
|00005780| 20 20 20 54 41 42 4c 45 | 3d 24 7b 54 4d 50 7d 74 | TABLE|=${TMP}t|
|00005790| 09 23 20 50 75 74 20 6f | 75 74 70 75 74 20 74 61 |.# Put o|utput ta|
|000057a0| 62 6c 65 20 69 6e 20 24 | 54 4d 50 44 49 52 0a 09 |ble in $|TMPDIR..|
|000057b0| 20 20 20 20 6b 69 6c 6c | 74 61 62 6c 65 3d 79 65 | kill|table=ye|
|000057c0| 73 0a 09 20 20 20 20 3b | 3b 0a 09 2d 48 41 29 0a |s.. ;|;..-HA).|
|000057d0| 09 20 20 20 20 74 61 62 | 6c 65 6e 61 6d 65 3d 24 |. tab|lename=$|
|000057e0| 32 0a 09 20 20 20 20 54 | 41 42 4c 45 3d 24 32 0a |2.. T|ABLE=$2.|
|000057f0| 09 20 20 20 20 73 68 69 | 66 74 0a 09 20 20 20 20 |. shi|ft.. |
|00005800| 3b 3b 0a 09 2d 48 4c 29 | 0a 09 20 20 20 20 64 75 |;;..-HL)|.. du|
|00005810| 6d 62 63 63 3d 79 65 73 | 0a 09 20 20 20 20 3b 3b |mbcc=yes|.. ;;|
|00005820| 0a 09 2d 52 29 0a 09 20 | 20 20 20 72 65 73 65 72 |..-R).. | reser|
|00005830| 76 65 64 3d 22 24 72 65 | 73 65 72 76 65 64 20 2d |ved="$re|served -|
|00005840| 72 20 24 32 22 0a 09 20 | 20 20 20 73 68 69 66 74 |r $2".. | shift|
|00005850| 0a 09 20 20 20 20 3b 3b | 0a 09 2d 6e 29 0a 09 20 |.. ;;|..-n).. |
|00005860| 20 20 20 6c 64 73 77 3d | 22 24 6c 64 73 77 20 24 | ldsw=|"$ldsw $|
|00005870| 31 22 0a 09 20 20 20 20 | 3b 3b 0a 09 2d 76 29 0a |1".. |;;..-v).|
|00005880| 09 20 20 20 20 76 65 72 | 62 6f 73 65 3d 2d 76 0a |. ver|bose=-v.|
|00005890| 09 20 20 20 20 3b 3b 0a | 09 2d 70 29 0a 09 20 20 |. ;;.|.-p).. |
|000058a0| 20 20 6c 64 73 77 3d 22 | 24 6c 64 73 77 20 24 31 | ldsw="|$ldsw $1|
|000058b0| 22 0a 09 20 20 20 20 63 | 31 73 77 3d 22 24 63 31 |".. c|1sw="$c1|
|000058c0| 73 77 20 2d 58 70 22 0a | 09 20 20 20 20 3b 3b 0a |sw -Xp".|. ;;.|
|000058d0| 09 2d 66 2a 29 0a 09 20 | 20 20 20 6c 64 73 77 3d |.-f*).. | ldsw=|
|000058e0| 22 24 6c 64 73 77 20 24 | 31 22 0a 09 20 20 20 20 |"$ldsw $|1".. |
|000058f0| 63 31 73 77 3d 22 24 63 | 31 73 77 20 24 31 22 0a |c1sw="$c|1sw $1".|
|00005900| 09 20 20 20 20 3b 3b 0a | 09 2d 6f 29 0a 09 20 20 |. ;;.|.-o).. |
|00005910| 20 20 6c 64 73 77 3d 22 | 24 6c 64 73 77 20 24 31 | ldsw="|$ldsw $1|
|00005920| 20 24 32 22 0a 09 20 20 | 20 20 74 61 62 6c 65 6e | $2".. | tablen|
|00005930| 61 6d 65 3d 24 32 2e 74 | 0a 09 20 20 20 20 73 68 |ame=$2.t|.. sh|
|00005940| 69 66 74 0a 09 20 20 20 | 20 3b 3b 0a 09 2d 52 29 |ift.. | ;;..-R)|
|00005950| 0a 09 20 20 20 20 6c 64 | 73 77 3d 22 24 6c 64 73 |.. ld|sw="$lds|
|00005960| 77 20 24 31 20 24 32 22 | 0a 09 20 20 20 20 73 68 |w $1 $2"|.. sh|
|00005970| 69 66 74 0a 09 20 20 20 | 20 3b 3b 0a 09 2d 45 7c |ift.. | ;;..-E||
|00005980| 2d 50 29 0a 09 20 20 20 | 20 70 72 65 70 72 6f 63 |-P).. | preproc|
|00005990| 65 73 73 3d 24 31 0a 09 | 20 20 20 20 66 6f 72 63 |ess=$1..| forc|
|000059a0| 65 6f 62 6a 3d 24 31 0a | 09 20 20 20 20 73 75 66 |eobj=$1.|. suf|
|000059b0| 66 69 78 3d 69 0a 09 20 | 20 20 20 6c 6f 61 64 3d |fix=i.. | load=|
|000059c0| 6e 6f 0a 09 20 20 20 20 | 3b 3b 0a 09 2d 4f 2a 29 |no.. |;;..-O*)|
|000059d0| 0a 09 20 20 20 20 6f 70 | 74 69 6d 69 7a 65 3d 79 |.. op|timize=y|
|000059e0| 65 73 0a 09 20 20 20 20 | 6f 70 74 73 77 3d 60 65 |es.. |optsw=`e|
|000059f0| 63 68 6f 20 24 31 20 7c | 20 74 72 20 2d 64 20 4f |cho $1 || tr -d O|
|00005a00| 60 0a 09 20 20 20 20 69 | 66 20 5b 20 22 58 24 6f |`.. i|f [ "X$o|
|00005a10| 70 74 73 77 22 20 3d 20 | 22 58 2d 22 20 5d 0a 09 |ptsw" = |"X-" ]..|
|00005a20| 20 20 20 20 74 68 65 6e | 0a 09 09 6f 70 74 73 77 | then|...optsw|
|00005a30| 3d 0a 09 20 20 20 20 66 | 69 0a 09 20 20 20 20 3b |=.. f|i.. ;|
|00005a40| 3b 0a 09 2d 43 7c 2d 44 | 2a 7c 2d 55 2a 7c 2d 49 |;..-C|-D|*|-U*|-I|
|00005a50| 2a 29 0a 09 20 20 20 20 | 63 63 73 77 3d 22 24 63 |*).. |ccsw="$c|
|00005a60| 63 73 77 20 24 31 22 0a | 09 20 20 20 20 3b 3b 0a |csw $1".|. ;;.|
|00005a70| 09 2d 53 29 0a 09 20 20 | 20 20 66 6f 72 63 65 6f |.-S).. | forceo|
|00005a80| 62 6a 3d 2d 53 0a 09 20 | 20 20 20 73 75 66 66 69 |bj=-S.. | suffi|
|00005a90| 78 3d 73 0a 09 20 20 20 | 20 6c 6f 61 64 3d 6e 6f |x=s.. | load=no|
|00005aa0| 0a 09 20 20 20 20 6e 75 | 6d 73 72 63 66 69 6c 65 |.. nu|msrcfile|
|00005ab0| 73 3d 78 78 0a 09 20 20 | 20 20 3b 3b 0a 09 2d 63 |s=xx.. | ;;..-c|
|00005ac0| 29 0a 09 20 20 20 20 6c | 6f 61 64 3d 6e 6f 0a 09 |).. l|oad=no..|
|00005ad0| 20 20 20 20 6e 75 6d 73 | 72 63 66 69 6c 65 73 3d | nums|rcfiles=|
|00005ae0| 78 78 0a 09 20 20 20 20 | 3b 3b 0a 09 2d 6c 2a 29 |xx.. |;;..-l*)|
|00005af0| 0a 09 20 20 20 20 6f 66 | 69 6c 65 73 3d 22 24 6f |.. of|iles="$o|
|00005b00| 66 69 6c 65 73 20 24 31 | 22 0a 09 20 20 20 20 3b |files $1|".. ;|
|00005b10| 3b 0a 09 2a 2e 6f 29 0a | 09 20 20 20 20 6e 75 6d |;..*.o).|. num|
|00005b20| 73 72 63 66 69 6c 65 73 | 3d 78 78 0a 09 20 20 20 |srcfiles|=xx.. |
|00005b30| 20 6f 66 69 6c 65 73 3d | 22 24 6f 66 69 6c 65 73 | ofiles=|"$ofiles|
|00005b40| 20 24 31 22 0a 09 20 20 | 20 20 69 66 20 5b 20 22 | $1".. | if [ "|
|00005b50| 24 74 61 62 6c 65 6e 61 | 6d 65 22 20 3d 20 22 22 |$tablena|me" = ""|
|00005b60| 20 5d 0a 09 20 20 20 20 | 74 68 65 6e 0a 09 09 74 | ].. |then...t|
|00005b70| 61 62 6c 65 6e 61 6d 65 | 3d 60 62 61 73 65 6e 61 |ablename|=`basena|
|00005b80| 6d 65 20 24 31 20 2e 6f | 60 2e 74 0a 09 20 20 20 |me $1 .o|`.t.. |
|00005b90| 20 66 69 0a 09 20 20 20 | 20 3b 3b 0a 09 2a 2e 73 | fi.. | ;;..*.s|
|00005ba0| 29 0a 09 20 20 20 20 69 | 66 20 20 5b 20 22 24 64 |).. i|f [ "$d|
|00005bb0| 75 6d 62 63 63 22 20 3d | 20 22 79 65 73 22 20 2d |umbcc" =| "yes" -|
|00005bc0| 61 20 22 58 24 70 72 65 | 70 72 6f 63 65 73 73 22 |a "X$pre|process"|
|00005bd0| 20 3d 20 22 58 22 20 5d | 0a 09 20 20 20 20 74 68 | = "X" ]|.. th|
|00005be0| 65 6e 0a 09 09 69 66 20 | 63 63 20 24 63 63 73 77 |en...if |cc $ccsw|
|00005bf0| 20 24 76 65 72 62 6f 73 | 65 20 24 66 6f 72 63 65 | $verbos|e $force|
|00005c00| 6f 62 6a 20 24 31 0a 09 | 09 74 68 65 6e 0a 09 09 |obj $1..|.then...|
|00005c10| 20 20 20 20 3a 0a 09 09 | 65 6c 73 65 0a 09 09 20 | :...|else... |
|00005c20| 20 20 20 66 61 69 6c 75 | 72 65 3d 79 65 73 0a 09 | failu|re=yes..|
|00005c30| 09 20 20 20 20 62 72 65 | 61 6b 0a 09 09 66 69 0a |. bre|ak...fi.|
|00005c40| 09 20 20 20 20 65 6c 69 | 66 20 5b 20 22 24 73 75 |. eli|f [ "$su|
|00005c50| 66 66 69 78 22 20 21 3d | 20 22 73 22 20 2d 61 20 |ffix" !=| "s" -a |
|00005c60| 22 58 24 70 72 65 70 72 | 6f 63 65 73 73 22 20 3d |"X$prepr|ocess" =|
|00005c70| 20 22 58 22 20 5d 0a 09 | 20 20 20 20 74 68 65 6e | "X" ]..| then|
|00005c80| 0a 09 09 68 61 73 68 38 | 20 24 72 65 73 65 72 76 |...hash8| $reserv|
|00005c90| 65 64 20 65 6e 63 6f 64 | 65 20 24 54 41 42 4c 45 |ed encod|e $TABLE|
|00005ca0| 20 3c 20 24 31 20 3e 20 | 24 7b 54 4d 50 7d 2e 73 | < $1 > |${TMP}.s|
|00005cb0| 0a 09 09 6d 61 64 65 74 | 61 62 6c 65 3d 79 65 73 |...madet|able=yes|
|00005cc0| 0a 09 09 28 63 63 20 24 | 63 63 73 77 20 24 66 6f |...(cc $|ccsw $fo|
|00005cd0| 72 63 65 6f 62 6a 20 24 | 76 65 72 62 6f 73 65 20 |rceobj $|verbose |
|00005ce0| 24 7b 54 4d 50 7d 2e 73 | 20 32 3e 20 24 7b 54 4d |${TMP}.s| 2> ${TM|
|00005cf0| 50 7d 2e 65 20 5c 0a 09 | 09 20 20 20 20 7c 7c 20 |P}.e \..|. || |
|00005d00| 20 6b 69 6c 6c 20 2d 37 | 20 24 24 29 20 5c 0a 09 | kill -7| $$) \..|
|00005d10| 09 20 20 7c 20 73 65 64 | 20 22 73 3b 24 7b 54 4d |. | sed| "s;${TM|
|00005d20| 50 7d 2e 73 3b 24 31 3b | 22 20 7c 20 68 61 73 68 |P}.s;$1;|" | hash|
|00005d30| 38 20 64 65 63 6f 64 65 | 20 24 54 41 42 4c 45 0a |8 decode| $TABLE.|
|00005d40| 09 09 73 65 64 20 22 73 | 3b 24 7b 54 4d 50 7d 2e |..sed "s|;${TMP}.|
|00005d50| 73 3b 24 31 3b 22 20 24 | 7b 54 4d 50 7d 2e 65 20 |s;$1;" $|{TMP}.e |
|00005d60| 7c 20 68 61 73 68 38 20 | 64 65 63 6f 64 65 20 24 || hash8 |decode $|
|00005d70| 54 41 42 4c 45 20 31 3e | 26 32 0a 09 09 69 66 20 |TABLE 1>|&2...if |
|00005d80| 5b 20 22 24 66 61 69 6c | 75 72 65 22 20 3d 20 22 |[ "$fail|ure" = "|
|00005d90| 79 65 73 22 20 5d 0a 09 | 09 74 68 65 6e 0a 09 09 |yes" ]..|.then...|
|00005da0| 20 20 20 20 62 72 65 61 | 6b 0a 09 09 66 69 0a 09 | brea|k...fi..|
|00005db0| 09 6f 62 6a 3d 60 62 61 | 73 65 6e 61 6d 65 20 22 |.obj=`ba|sename "|
|00005dc0| 24 31 22 20 27 2e 73 27 | 60 2e 24 73 75 66 66 69 |$1" '.s'|`.$suffi|
|00005dd0| 78 0a 09 09 6f 66 69 6c | 65 73 3d 22 24 6f 66 69 |x...ofil|es="$ofi|
|00005de0| 6c 65 73 20 24 6f 62 6a | 22 0a 09 09 72 6d 66 69 |les $obj|"...rmfi|
|00005df0| 6c 65 73 3d 22 24 72 6d | 66 69 6c 65 73 20 24 6f |les="$rm|files $o|
|00005e00| 62 6a 22 0a 09 09 6d 76 | 20 24 7b 54 46 49 4c 45 |bj"...mv| ${TFILE|
|00005e10| 7d 2e 24 73 75 66 66 69 | 78 20 24 6f 62 6a 0a 09 |}.$suffi|x $obj..|
|00005e20| 09 6e 75 6d 73 72 63 66 | 69 6c 65 73 3d 22 78 24 |.numsrcf|iles="x$|
|00005e30| 6e 75 6d 73 72 63 66 69 | 6c 65 73 22 0a 09 20 20 |numsrcfi|les".. |
|00005e40| 20 20 66 69 0a 09 20 20 | 20 20 69 66 20 5b 20 22 | fi.. | if [ "|
|00005e50| 24 74 61 62 6c 65 6e 61 | 6d 65 22 20 3d 20 22 22 |$tablena|me" = ""|
|00005e60| 20 5d 0a 09 20 20 20 20 | 74 68 65 6e 0a 09 09 74 | ].. |then...t|
|00005e70| 61 62 6c 65 6e 61 6d 65 | 3d 60 62 61 73 65 6e 61 |ablename|=`basena|
|00005e80| 6d 65 20 24 31 20 2e 73 | 60 2e 74 0a 09 20 20 20 |me $1 .s|`.t.. |
|00005e90| 20 66 69 0a 09 20 20 20 | 20 3b 3b 0a 09 2a 2e 63 | fi.. | ;;..*.c|
|00005ea0| 29 0a 09 20 20 20 20 6f | 62 6a 3d 60 62 61 73 65 |).. o|bj=`base|
|00005eb0| 6e 61 6d 65 20 22 24 31 | 22 20 27 2e 63 27 60 2e |name "$1|" '.c'`.|
|00005ec0| 24 73 75 66 66 69 78 0a | 09 20 20 20 20 70 70 66 |$suffix.|. ppf|
|00005ed0| 69 6c 65 3d 24 7b 54 4d | 50 7d 2e 69 0a 09 20 20 |ile=${TM|P}.i.. |
|00005ee0| 20 20 69 66 20 5b 20 22 | 58 24 76 65 72 62 6f 73 | if [ "|X$verbos|
|00005ef0| 65 22 20 3d 20 22 58 2d | 76 22 20 5d 0a 09 20 20 |e" = "X-|v" ].. |
|00005f00| 20 20 74 68 65 6e 0a 09 | 09 65 63 68 6f 20 22 24 | then..|.echo "$|
|00005f10| 7b 31 7d 3a 22 0a 09 09 | 65 63 68 6f 20 22 20 20 |{1}:"...|echo " |
|00005f20| 50 72 65 70 72 6f 63 65 | 73 73 69 6e 67 22 20 31 |Preproce|ssing" 1|
|00005f30| 3e 26 32 0a 09 20 20 20 | 20 66 69 0a 09 20 20 20 |>&2.. | fi.. |
|00005f40| 20 69 66 20 5b 20 22 58 | 24 70 72 65 70 72 6f 63 | if [ "X|$preproc|
|00005f50| 65 73 73 22 20 3d 20 22 | 58 2d 45 22 20 5d 0a 09 |ess" = "|X-E" ]..|
|00005f60| 20 20 20 20 74 68 65 6e | 0a 09 09 69 66 20 63 63 | then|...if cc|
|00005f70| 20 24 63 63 73 77 20 24 | 70 72 65 70 72 6f 63 65 | $ccsw $|preproce|
|00005f80| 73 73 20 24 31 0a 09 09 | 74 68 65 6e 0a 09 09 20 |ss $1...|then... |
|00005f90| 20 20 20 3a 0a 09 09 65 | 6c 73 65 0a 09 09 20 20 | :...e|lse... |
|00005fa0| 20 20 66 61 69 6c 75 72 | 65 3d 79 65 73 0a 09 09 | failur|e=yes...|
|00005fb0| 66 69 0a 09 20 20 20 20 | 65 6c 69 66 20 5b 20 22 |fi.. |elif [ "|
|00005fc0| 58 24 70 72 65 70 72 6f | 63 65 73 73 22 20 3d 20 |X$prepro|cess" = |
|00005fd0| 22 58 2d 50 22 20 5d 0a | 09 20 20 20 20 74 68 65 |"X-P" ].|. the|
|00005fe0| 6e 0a 09 09 70 70 66 69 | 6c 65 3d 24 6f 62 6a 0a |n...ppfi|le=$obj.|
|00005ff0| 09 20 20 20 20 66 69 0a | 09 20 20 20 20 69 66 20 |. fi.|. if |
|00006000| 63 63 20 24 63 63 73 77 | 20 2d 45 20 24 31 20 3e |cc $ccsw| -E $1 >|
|00006010| 20 24 70 70 66 69 6c 65 | 0a 09 20 20 20 20 74 68 | $ppfile|.. th|
|00006020| 65 6e 0a 09 09 3a 0a 09 | 20 20 20 20 65 6c 73 65 |en...:..| else|
|00006030| 0a 09 09 66 61 69 6c 75 | 72 65 3d 79 65 73 0a 09 |...failu|re=yes..|
|00006040| 09 2f 62 69 6e 2f 72 6d | 20 2d 66 20 24 70 70 66 |./bin/rm| -f $ppf|
|00006050| 69 6c 65 0a 09 09 62 72 | 65 61 6b 0a 09 20 20 20 |ile...br|eak.. |
|00006060| 20 66 69 0a 09 20 20 20 | 20 69 66 20 5b 20 22 58 | fi.. | if [ "X|
|00006070| 24 70 72 65 70 72 6f 63 | 65 73 73 22 20 3d 20 22 |$preproc|ess" = "|
|00006080| 58 2d 50 22 20 5d 0a 09 | 20 20 20 20 74 68 65 6e |X-P" ]..| then|
|00006090| 0a 09 09 62 72 65 61 6b | 0a 09 20 20 20 20 66 69 |...break|.. fi|
|000060a0| 0a 09 20 20 20 20 68 61 | 73 68 38 20 24 72 65 73 |.. ha|sh8 $res|
|000060b0| 65 72 76 65 64 20 65 6e | 63 6f 64 65 20 24 54 41 |erved en|code $TA|
|000060c0| 42 4c 45 20 3c 20 24 70 | 70 66 69 6c 65 20 3e 20 |BLE < $p|pfile > |
|000060d0| 24 7b 54 4d 50 7d 2e 63 | 0a 09 20 20 20 20 6d 61 |${TMP}.c|.. ma|
|000060e0| 64 65 74 61 62 6c 65 3d | 79 65 73 0a 09 20 20 20 |detable=|yes.. |
|000060f0| 20 2f 62 69 6e 2f 72 6d | 20 2d 66 20 24 70 70 66 | /bin/rm| -f $ppf|
|00006100| 69 6c 65 0a 09 20 20 20 | 20 69 66 20 5b 20 22 24 |ile.. | if [ "$|
|00006110| 6f 70 74 69 6d 69 7a 65 | 22 20 3d 20 79 65 73 20 |optimize|" = yes |
|00006120| 5d 0a 09 20 20 20 20 74 | 68 65 6e 0a 09 09 75 6e |].. t|hen...un|
|00006130| 6f 70 74 66 69 6c 65 3d | 24 7b 54 4d 50 7d 2e 73 |optfile=|${TMP}.s|
|00006140| 31 0a 09 20 20 20 20 65 | 6c 73 65 0a 09 09 75 6e |1.. e|lse...un|
|00006150| 6f 70 74 66 69 6c 65 3d | 24 7b 54 4d 50 7d 2e 73 |optfile=|${TMP}.s|
|00006160| 0a 09 20 20 20 20 66 69 | 0a 09 20 20 20 20 69 66 |.. fi|.. if|
|00006170| 20 5b 20 22 58 24 76 65 | 72 62 6f 73 65 22 20 3d | [ "X$ve|rbose" =|
|00006180| 20 22 58 2d 76 22 20 5d | 0a 09 20 20 20 20 74 68 | "X-v" ]|.. th|
|00006190| 65 6e 0a 09 09 65 63 68 | 6f 20 22 20 20 43 6f 6d |en...ech|o " Com|
|000061a0| 70 69 6c 69 6e 67 22 20 | 31 3e 26 32 0a 09 20 20 |piling" |1>&2.. |
|000061b0| 20 20 66 69 0a 09 20 20 | 20 20 69 66 20 24 43 4f | fi.. | if $CO|
|000061c0| 4d 50 49 4c 45 52 20 24 | 63 31 73 77 20 3c 20 24 |MPILER $|c1sw < $|
|000061d0| 7b 54 4d 50 7d 2e 63 20 | 3e 20 24 75 6e 6f 70 74 |{TMP}.c |> $unopt|
|000061e0| 66 69 6c 65 20 32 3e 20 | 24 7b 54 4d 50 7d 2e 65 |file 2> |${TMP}.e|
|000061f0| 0a 09 20 20 20 20 74 68 | 65 6e 0a 09 09 2f 62 69 |.. th|en.../bi|
|00006200| 6e 2f 72 6d 20 2d 66 20 | 24 7b 54 4d 50 7d 2e 63 |n/rm -f |${TMP}.c|
|00006210| 0a 09 20 20 20 20 65 6c | 73 65 0a 09 09 68 61 73 |.. el|se...has|
|00006220| 68 38 20 64 65 63 6f 64 | 65 20 24 54 41 42 4c 45 |h8 decod|e $TABLE|
|00006230| 20 3c 20 24 7b 54 4d 50 | 7d 2e 65 20 31 3e 26 32 | < ${TMP|}.e 1>&2|
|00006240| 0a 09 09 2f 62 69 6e 2f | 72 6d 20 24 75 6e 6f 70 |.../bin/|rm $unop|
|00006250| 74 66 69 6c 65 20 24 7b | 54 4d 50 7d 2e 63 20 24 |tfile ${|TMP}.c $|
|00006260| 7b 54 4d 50 7d 2e 65 0a | 09 09 66 61 69 6c 75 72 |{TMP}.e.|..failur|
|00006270| 65 3d 79 65 73 0a 09 09 | 62 72 65 61 6b 0a 09 20 |e=yes...|break.. |
|00006280| 20 20 20 66 69 0a 09 20 | 20 20 20 69 66 20 5b 20 | fi.. | if [ |
|00006290| 24 6f 70 74 69 6d 69 7a | 65 20 3d 20 79 65 73 20 |$optimiz|e = yes |
|000062a0| 5d 0a 09 20 20 20 20 74 | 68 65 6e 0a 09 09 69 66 |].. t|hen...if|
|000062b0| 20 5b 20 22 58 24 76 65 | 72 62 6f 73 65 22 20 3d | [ "X$ve|rbose" =|
|000062c0| 20 22 58 2d 76 22 20 5d | 0a 09 09 74 68 65 6e 0a | "X-v" ]|...then.|
|000062d0| 09 09 20 20 20 20 65 63 | 68 6f 20 22 20 20 4f 70 |.. ec|ho " Op|
|000062e0| 74 69 6d 69 7a 69 6e 67 | 22 20 31 3e 26 32 0a 09 |timizing|" 1>&2..|
|000062f0| 09 66 69 0a 09 09 69 66 | 20 24 4f 50 54 49 4d 49 |.fi...if| $OPTIMI|
|00006300| 5a 45 52 20 24 6f 70 74 | 73 77 20 3c 20 24 75 6e |ZER $opt|sw < $un|
|00006310| 6f 70 74 66 69 6c 65 20 | 3e 20 24 7b 54 4d 50 7d |optfile |> ${TMP}|
|00006320| 2e 73 20 32 3e 20 24 7b | 54 4d 50 7d 2e 65 0a 09 |.s 2> ${|TMP}.e..|
|00006330| 09 74 68 65 6e 0a 09 09 | 20 20 20 20 2f 62 69 6e |.then...| /bin|
|00006340| 2f 72 6d 20 2d 66 20 24 | 75 6e 6f 70 74 66 69 6c |/rm -f $|unoptfil|
|00006350| 65 0a 09 09 20 20 20 20 | 75 6e 6f 70 74 66 69 6c |e... |unoptfil|
|00006360| 65 3d 24 7b 54 4d 50 7d | 2e 73 0a 09 09 65 6c 73 |e=${TMP}|.s...els|
|00006370| 65 0a 09 09 20 20 20 20 | 68 61 73 68 38 20 64 65 |e... |hash8 de|
|00006380| 63 6f 64 65 20 24 54 41 | 42 4c 45 20 3c 20 24 7b |code $TA|BLE < ${|
|00006390| 54 4d 50 7d 2e 65 20 31 | 3e 26 32 0a 09 09 20 20 |TMP}.e 1|>&2... |
|000063a0| 20 20 2f 62 69 6e 2f 72 | 6d 20 2d 66 20 24 75 6e | /bin/r|m -f $un|
|000063b0| 6f 70 74 66 69 6c 65 20 | 24 7b 54 4d 50 7d 2e 73 |optfile |${TMP}.s|
|000063c0| 20 24 7b 54 4d 50 7d 2e | 65 0a 09 09 20 20 20 20 | ${TMP}.|e... |
|000063d0| 66 61 69 6c 75 72 65 3d | 79 65 73 0a 09 09 20 20 |failure=|yes... |
|000063e0| 20 20 62 72 65 61 6b 0a | 09 09 66 69 0a 09 20 20 | break.|..fi.. |
|000063f0| 20 20 66 69 0a 09 20 20 | 20 20 63 61 73 65 20 22 | fi.. | case "|
+--------+-------------------------+-------------------------+--------+--------+
Only 25.0 KB of data is shown above.