home *** CD-ROM | disk | FTP | other *** search
open in:
MacOS 8.1
|
Win98
|
DOS
view JSON data
|
view as text
This file was processed as: SHell self-extracting ARchive
(archive/shar).
You can browse this item here: 2068
Confidence | Program | Detection | Match Type | Support
|
---|
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)
|
|
hex view+--------+-------------------------+-------------------------+--------+--------+
|00000000| 4e 65 77 73 67 72 6f 75 | 70 73 3a 20 61 6c 74 2e |Newsgrou|ps: alt.|
|00000010| 73 6f 75 72 63 65 73 0a | 46 72 6f 6d 3a 20 6e 65 |sources.|From: ne|
|00000020| 6c 73 6f 6e 40 73 75 6e | 2e 73 6f 65 2e 63 6c 61 |lson@sun|.soe.cla|
|00000030| 72 6b 73 6f 6e 2e 65 64 | 75 20 28 52 75 73 73 20 |rkson.ed|u (Russ |
|00000040| 4e 65 6c 73 6f 6e 29 0a | 53 75 62 6a 65 63 74 3a |Nelson).|Subject:|
|00000050| 20 63 6f 64 65 20 66 6f | 72 20 72 65 61 64 69 6e | code fo|r readin|
|00000060| 67 20 66 72 6f 6d 20 2e | 3f 51 3f 20 66 69 6c 65 |g from .|?Q? file|
|00000070| 73 0a 44 61 74 65 3a 20 | 31 35 20 4e 6f 76 20 39 |s.Date: |15 Nov 9|
|00000080| 30 20 31 30 3a 30 30 3a | 30 34 0a 4d 65 73 73 61 |0 10:00:|04.Messa|
|00000090| 67 65 2d 49 44 3a 20 3c | 4e 45 4c 53 4f 4e 2e 39 |ge-ID: <|NELSON.9|
|000000a0| 30 4e 6f 76 31 35 31 30 | 30 30 30 34 40 69 6d 61 |0Nov1510|0004@ima|
|000000b0| 67 65 2e 63 6c 61 72 6b | 73 6f 6e 2e 65 64 75 3e |ge.clark|son.edu>|
|000000c0| 0a 0a 49 6e 20 61 72 74 | 69 63 6c 65 20 3c 31 34 |..In art|icle <14|
|000000d0| 32 32 40 74 68 61 72 72 | 2e 55 55 43 50 3e 20 67 |22@tharr|.UUCP> g|
|000000e0| 74 6f 61 6c 40 74 68 61 | 72 72 2e 55 55 43 50 20 |toal@tha|rr.UUCP |
|000000f0| 28 47 72 61 68 61 6d 20 | 54 6f 61 6c 29 20 77 72 |(Graham |Toal) wr|
|00000100| 69 74 65 73 3a 0a 0a 20 | 20 20 54 68 69 73 20 70 |ites:.. | This p|
|00000110| 6f 73 74 69 6e 67 20 63 | 6f 6e 73 69 73 74 73 20 |osting c|onsists |
|00000120| 6f 66 20 61 20 73 65 74 | 20 6f 66 20 72 6f 75 74 |of a set| of rout|
|00000130| 69 6e 65 73 20 77 68 69 | 63 68 20 72 6f 75 67 68 |ines whi|ch rough|
|00000140| 6c 79 20 73 69 6d 75 6c | 61 74 65 0a 20 20 20 66 |ly simul|ate. f|
|00000150| 6f 70 65 6e 2c 20 66 67 | 65 74 63 2c 20 66 67 65 |open, fg|etc, fge|
|00000160| 74 73 2c 20 61 6e 64 20 | 66 63 6c 6f 73 65 2e 20 |ts, and |fclose. |
|00000170| 20 54 68 65 20 64 69 66 | 66 65 72 65 6e 63 65 20 | The dif|ference |
|00000180| 62 65 74 77 65 65 6e 20 | 74 68 65 73 65 20 61 6e |between |these an|
|00000190| 64 0a 20 20 20 74 68 65 | 20 6f 72 69 67 69 6e 61 |d. the| origina|
|000001a0| 6c 73 20 69 73 20 74 68 | 61 74 20 74 68 65 73 65 |ls is th|at these|
|000001b0| 20 77 69 6c 6c 20 72 65 | 61 64 20 64 61 74 61 20 | will re|ad data |
|000001c0| 66 72 6f 6d 20 61 20 2e | 5a 20 63 6f 6d 70 72 65 |from a .|Z compre|
|000001d0| 73 73 65 64 0a 20 20 20 | 66 69 6c 65 2c 20 64 65 |ssed. |file, de|
|000001e0| 63 6f 6d 70 72 65 73 73 | 69 6e 67 20 69 74 20 6f |compress|ing it o|
|000001f0| 6e 20 74 68 65 20 66 6c | 79 2e 20 20 49 74 20 64 |n the fl|y. It d|
|00000200| 6f 65 73 20 2a 6e 6f 74 | 2a 20 75 73 65 73 20 70 |oes *not|* uses p|
|00000210| 69 70 65 73 2c 0a 20 20 | 20 70 72 6f 63 65 73 73 |ipes,. | process|
|00000220| 65 73 2c 20 6f 72 20 69 | 6e 74 65 72 6d 65 64 69 |es, or i|ntermedi|
|00000230| 61 74 65 20 66 69 6c 65 | 73 2e 20 20 54 68 69 73 |ate file|s. This|
|00000240| 20 6d 61 6b 65 73 20 69 | 74 20 75 73 65 66 75 6c | makes i|t useful|
|00000250| 20 74 6f 20 61 64 64 20 | 74 6f 0a 20 20 20 61 6e | to add |to. an|
|00000260| 79 20 70 72 6f 67 72 61 | 6d 73 20 77 68 69 63 68 |y progra|ms which|
|00000270| 20 72 65 61 64 20 6c 61 | 72 67 65 20 74 65 78 74 | read la|rge text|
|00000280| 20 66 69 6c 65 73 20 73 | 65 71 75 65 6e 74 69 61 | files s|equentia|
|00000290| 6c 6c 79 2e 0a 0a 49 20 | 68 61 64 20 61 20 76 65 |lly...I |had a ve|
|000002a0| 72 79 20 73 69 6d 69 6c | 61 72 20 6e 65 65 64 2c |ry simil|ar need,|
|000002b0| 20 65 78 63 65 70 74 20 | 74 68 61 74 20 49 20 6e | except |that I n|
|000002c0| 65 65 64 65 64 20 74 6f | 20 53 45 45 4b 20 61 6c |eeded to| SEEK al|
|000002d0| 73 6f 2e 20 20 57 69 74 | 68 0a 63 6f 6d 70 72 65 |so. Wit|h.compre|
|000002e0| 73 73 2c 20 74 68 69 73 | 20 69 73 20 61 20 70 72 |ss, this| is a pr|
|000002f0| 6f 62 6c 65 6d 2e 20 20 | 42 75 74 20 77 69 74 68 |oblem. |But with|
|00000300| 20 48 75 66 66 6d 61 6e | 20 65 6e 63 6f 64 69 6e | Huffman| encodin|
|00000310| 67 2c 20 73 65 65 6b 69 | 6e 67 20 69 73 6e 27 74 |g, seeki|ng isn't|
|00000320| 0a 61 20 70 72 6f 62 6c | 65 6d 2c 20 73 6f 20 6c |.a probl|em, so l|
|00000330| 6f 6e 67 20 61 73 20 79 | 6f 75 20 73 65 65 6b 20 |ong as y|ou seek |
|00000340| 74 6f 20 61 20 62 69 74 | 20 62 6f 75 6e 64 61 72 |to a bit| boundar|
|00000350| 79 20 72 61 74 68 65 72 | 20 74 68 61 6e 20 61 20 |y rather| than a |
|00000360| 62 79 74 65 0a 62 6f 75 | 6e 64 61 72 79 2e 0a 0a |byte.bou|ndary...|
|00000370| 53 69 6e 63 65 20 6f 74 | 68 65 72 20 70 65 6f 70 |Since ot|her peop|
|00000380| 6c 65 20 6d 61 79 20 6e | 65 65 64 20 74 6f 20 73 |le may n|eed to s|
|00000390| 65 65 6b 20 69 6e 74 6f | 20 73 71 75 65 65 7a 65 |eek into| squeeze|
|000003a0| 64 20 66 69 6c 65 73 2c | 20 68 65 72 65 27 73 20 |d files,| here's |
|000003b0| 6d 79 0a 76 65 72 73 69 | 6f 6e 2e 20 20 49 74 20 |my.versi|on. It |
|000003c0| 72 65 61 64 73 20 66 69 | 6c 65 73 20 70 72 6f 64 |reads fi|les prod|
|000003d0| 75 63 65 64 20 69 6e 20 | 74 68 65 20 66 6f 72 6d |uced in |the form|
|000003e0| 61 74 20 6f 66 20 74 68 | 65 20 22 53 51 22 20 73 |at of th|e "SQ" s|
|000003f0| 74 61 6e 64 61 72 64 0a | 66 69 72 73 74 20 73 65 |tandard.|first se|
|00000400| 65 6e 20 6f 6e 20 43 50 | 2f 4d 2e 20 20 49 74 27 |en on CP|/M. It'|
|00000410| 73 20 64 65 72 69 76 65 | 64 20 66 72 6f 6d 0a 73 |s derive|d from.s|
|00000420| 69 6d 74 65 6c 32 30 2e | 61 72 6d 79 2e 6d 69 6c |imtel20.|army.mil|
|00000430| 3a 70 64 31 3a 3c 75 6e | 69 78 2d 63 2e 63 70 6d |:pd1:<un|ix-c.cpm|
|00000440| 3e 78 73 71 2e 74 61 72 | 2d 7a 2c 20 61 6e 64 20 |>xsq.tar|-z, and |
|00000450| 69 73 20 6b 69 6e 64 20 | 6f 66 20 75 73 65 6c 65 |is kind |of usele|
|00000460| 73 73 0a 77 69 74 68 6f | 75 74 20 69 74 2c 20 62 |ss.witho|ut it, b|
|00000470| 65 63 61 75 73 65 20 79 | 6f 75 20 6e 65 65 64 20 |ecause y|ou need |
|00000480| 74 6f 20 6d 6f 64 69 66 | 79 20 78 73 71 2e 63 20 |to modif|y xsq.c |
|00000490| 6f 72 20 78 75 73 71 2e | 63 20 74 6f 20 63 6f 6e |or xusq.|c to con|
|000004a0| 76 69 6e 63 65 20 69 74 | 20 74 6f 20 74 65 6c 6c |vince it| to tell|
|000004b0| 0a 79 6f 75 20 74 68 65 | 20 63 6f 64 65 20 6f 66 |.you the| code of|
|000004c0| 66 73 65 74 73 2e 20 20 | 49 27 76 65 20 65 6e 63 |fsets. |I've enc|
|000004d0| 6c 6f 73 65 64 20 6d 79 | 20 78 75 73 71 69 2e 63 |losed my| xusqi.c|
|000004e0| 20 70 72 6f 67 72 61 6d | 2c 20 77 68 69 63 68 20 | program|, which |
|000004f0| 6c 6f 6f 6b 73 0a 74 68 | 72 6f 75 67 68 20 61 20 |looks.th|rough a |
|00000500| 73 70 65 63 69 61 6c 6c | 79 20 66 6f 72 6d 61 74 |speciall|y format|
|00000510| 74 65 64 2d 66 69 6c 65 | 20 28 73 65 76 65 6e 2d |ted-file| (seven-|
|00000520| 6c 69 6e 65 20 72 65 63 | 6f 72 64 73 29 2c 20 61 |line rec|ords), a|
|00000530| 6e 64 20 6d 61 70 73 20 | 61 20 62 79 74 65 0a 6f |nd maps |a byte.o|
|00000540| 66 66 73 65 74 20 69 6e | 74 6f 20 74 68 65 20 6f |ffset in|to the o|
|00000550| 72 69 67 69 6e 61 6c 20 | 66 69 6c 65 20 69 6e 74 |riginal |file int|
|00000560| 6f 20 61 20 62 69 74 20 | 6f 66 66 73 65 74 20 69 |o a bit |offset i|
|00000570| 6e 74 6f 20 74 68 65 20 | 73 71 75 65 65 7a 65 64 |nto the |squeezed|
|00000580| 20 66 69 6c 65 2e 0a 0a | 54 68 69 73 20 63 6f 64 | file...|This cod|
|00000590| 65 20 68 61 73 20 62 65 | 65 6e 20 77 72 69 74 74 |e has be|en writt|
|000005a0| 65 6e 20 66 6f 72 20 4d | 53 44 4f 53 2c 20 62 75 |en for M|SDOS, bu|
|000005b0| 74 20 73 68 6f 75 6c 64 | 20 62 65 20 70 6f 72 74 |t should| be port|
|000005c0| 61 62 6c 65 20 74 6f 20 | 55 6e 69 78 2e 0a 0a 23 |able to |Unix...#|
|000005d0| 21 20 2f 62 69 6e 2f 73 | 68 0a 23 20 54 68 69 73 |! /bin/s|h.# This|
|000005e0| 20 69 73 20 61 20 73 68 | 65 6c 6c 20 61 72 63 68 | is a sh|ell arch|
|000005f0| 69 76 65 2e 20 20 52 65 | 6d 6f 76 65 20 61 6e 79 |ive. Re|move any|
|00000600| 74 68 69 6e 67 20 62 65 | 66 6f 72 65 20 74 68 69 |thing be|fore thi|
|00000610| 73 20 6c 69 6e 65 2c 20 | 74 68 65 6e 20 75 6e 70 |s line, |then unp|
|00000620| 61 63 6b 0a 23 20 69 74 | 20 62 79 20 73 61 76 69 |ack.# it| by savi|
|00000630| 6e 67 20 69 74 20 69 6e | 74 6f 20 61 20 66 69 6c |ng it in|to a fil|
|00000640| 65 20 61 6e 64 20 74 79 | 70 69 6e 67 20 22 73 68 |e and ty|ping "sh|
|00000650| 20 66 69 6c 65 22 2e 20 | 20 54 6f 20 6f 76 65 72 | file". | To over|
|00000660| 77 72 69 74 65 20 65 78 | 69 73 74 69 6e 67 0a 23 |write ex|isting.#|
|00000670| 20 66 69 6c 65 73 2c 20 | 74 79 70 65 20 22 73 68 | files, |type "sh|
|00000680| 20 66 69 6c 65 20 2d 63 | 22 2e 20 20 59 6f 75 20 | file -c|". You |
|00000690| 63 61 6e 20 61 6c 73 6f | 20 66 65 65 64 20 74 68 |can also| feed th|
|000006a0| 69 73 20 61 73 20 73 74 | 61 6e 64 61 72 64 20 69 |is as st|andard i|
|000006b0| 6e 70 75 74 20 76 69 61 | 0a 23 20 75 6e 73 68 61 |nput via|.# unsha|
|000006c0| 72 2c 20 6f 72 20 62 79 | 20 74 79 70 69 6e 67 20 |r, or by| typing |
|000006d0| 22 73 68 20 3c 66 69 6c | 65 22 2c 20 65 2e 67 2e |"sh <fil|e", e.g.|
|000006e0| 2e 20 20 49 66 20 74 68 | 69 73 20 61 72 63 68 69 |. If th|is archi|
|000006f0| 76 65 20 69 73 20 63 6f | 6d 70 6c 65 74 65 2c 20 |ve is co|mplete, |
|00000700| 79 6f 75 0a 23 20 77 69 | 6c 6c 20 73 65 65 20 74 |you.# wi|ll see t|
|00000710| 68 65 20 66 6f 6c 6c 6f | 77 69 6e 67 20 6d 65 73 |he follo|wing mes|
|00000720| 73 61 67 65 20 61 74 20 | 74 68 65 20 65 6e 64 3a |sage at |the end:|
|00000730| 0a 23 09 09 22 45 6e 64 | 20 6f 66 20 73 68 65 6c |.#.."End| of shel|
|00000740| 6c 20 61 72 63 68 69 76 | 65 2e 22 0a 23 20 43 6f |l archiv|e.".# Co|
|00000750| 6e 74 65 6e 74 73 3a 20 | 20 73 71 72 65 61 64 2e |ntents: | sqread.|
|00000760| 63 20 73 71 72 65 61 64 | 2e 68 20 78 75 73 71 69 |c sqread|.h xusqi|
|00000770| 2e 63 0a 23 20 57 72 61 | 70 70 65 64 20 62 79 20 |.c.# Wra|pped by |
|00000780| 6e 65 6c 73 6f 6e 40 69 | 6d 61 67 65 2e 73 6f 65 |nelson@i|mage.soe|
|00000790| 2e 63 6c 61 72 6b 73 6f | 6e 2e 65 64 75 20 6f 6e |.clarkso|n.edu on|
|000007a0| 20 54 68 75 20 4e 6f 76 | 20 31 35 20 30 39 3a 35 | Thu Nov| 15 09:5|
|000007b0| 39 3a 31 32 20 31 39 39 | 30 0a 50 41 54 48 3d 2f |9:12 199|0.PATH=/|
|000007c0| 62 69 6e 3a 2f 75 73 72 | 2f 62 69 6e 3a 2f 75 73 |bin:/usr|/bin:/us|
|000007d0| 72 2f 75 63 62 20 3b 20 | 65 78 70 6f 72 74 20 50 |r/ucb ; |export P|
|000007e0| 41 54 48 0a 69 66 20 74 | 65 73 74 20 2d 66 20 27 |ATH.if t|est -f '|
|000007f0| 73 71 72 65 61 64 2e 63 | 27 20 2d 61 20 22 24 7b |sqread.c|' -a "${|
|00000800| 31 7d 22 20 21 3d 20 22 | 2d 63 22 20 3b 20 74 68 |1}" != "|-c" ; th|
|00000810| 65 6e 20 0a 20 20 65 63 | 68 6f 20 73 68 61 72 3a |en . ec|ho shar:|
|00000820| 20 57 69 6c 6c 20 6e 6f | 74 20 63 6c 6f 62 62 65 | Will no|t clobbe|
|00000830| 72 20 65 78 69 73 74 69 | 6e 67 20 66 69 6c 65 20 |r existi|ng file |
|00000840| 5c 22 27 73 71 72 65 61 | 64 2e 63 27 5c 22 0a 65 |\"'sqrea|d.c'\".e|
|00000850| 6c 73 65 0a 65 63 68 6f | 20 73 68 61 72 3a 20 45 |lse.echo| shar: E|
|00000860| 78 74 72 61 63 74 69 6e | 67 20 5c 22 27 73 71 72 |xtractin|g \"'sqr|
|00000870| 65 61 64 2e 63 27 5c 22 | 20 5c 28 34 39 30 33 20 |ead.c'\"| \(4903 |
|00000880| 63 68 61 72 61 63 74 65 | 72 73 5c 29 0a 73 65 64 |characte|rs\).sed|
|00000890| 20 22 73 2f 5e 58 2f 2f | 22 20 3e 27 73 71 72 65 | "s/^X//|" >'sqre|
|000008a0| 61 64 2e 63 27 20 3c 3c | 27 45 4e 44 5f 4f 46 5f |ad.c' <<|'END_OF_|
|000008b0| 46 49 4c 45 27 0a 58 23 | 69 6e 63 6c 75 64 65 20 |FILE'.X#|include |
|000008c0| 3c 73 74 64 69 6f 2e 68 | 3e 0a 58 23 69 6e 63 6c |<stdio.h|>.X#incl|
|000008d0| 75 64 65 20 3c 73 74 64 | 6c 69 62 2e 68 3e 0a 58 |ude <std|lib.h>.X|
|000008e0| 23 69 6e 63 6c 75 64 65 | 20 3c 73 69 67 6e 61 6c |#include| <signal|
|000008f0| 2e 68 3e 0a 58 23 69 6e | 63 6c 75 64 65 20 3c 63 |.h>.X#in|clude <c|
|00000900| 74 79 70 65 2e 68 3e 0a | 58 23 69 6e 63 6c 75 64 |type.h>.|X#includ|
|00000910| 65 20 3c 6c 69 6d 69 74 | 73 2e 68 3e 0a 58 23 69 |e <limit|s.h>.X#i|
|00000920| 6e 63 6c 75 64 65 20 3c | 6d 65 6d 2e 68 3e 0a 58 |nclude <|mem.h>.X|
|00000930| 23 64 65 66 69 6e 65 20 | 49 4e 54 45 52 4e 41 4c |#define |INTERNAL|
|00000940| 0a 58 23 69 6e 63 6c 75 | 64 65 20 22 73 71 72 65 |.X#inclu|de "sqre|
|00000950| 61 64 2e 68 22 0a 58 0a | 58 23 64 65 66 69 6e 65 |ad.h".X.|X#define|
|00000960| 20 45 52 52 4f 52 20 28 | 2d 31 29 0a 58 23 64 65 | ERROR (|-1).X#de|
|00000970| 66 69 6e 65 20 50 41 54 | 48 4c 45 4e 09 33 31 32 |fine PAT|HLEN.312|
|00000980| 09 2f 2a 20 4e 75 6d 62 | 65 72 20 6f 66 20 63 68 |./* Numb|er of ch|
|00000990| 61 72 61 63 74 65 72 73 | 20 61 6c 6c 6f 77 65 64 |aracters| allowed|
|000009a0| 20 69 6e 20 70 61 74 68 | 6e 61 6d 65 20 2a 2f 0a | in path|name */.|
|000009b0| 58 23 64 65 66 69 6e 65 | 20 4f 4b 20 30 0a 58 0a |X#define| OK 0.X.|
|000009c0| 58 23 64 65 66 69 6e 65 | 20 52 45 43 4f 47 4e 49 |X#define| RECOGNI|
|000009d0| 5a 45 20 30 78 46 46 37 | 36 09 2f 2a 20 75 6e 6c |ZE 0xFF7|6./* unl|
|000009e0| 69 6b 65 6c 79 20 70 61 | 74 74 65 72 6e 20 2a 2f |ikely pa|ttern */|
|000009f0| 0a 58 23 64 65 66 69 6e | 65 20 44 4c 45 20 30 78 |.X#defin|e DLE 0x|
|00000a00| 39 30 09 09 2f 2a 20 72 | 65 70 65 61 74 20 62 79 |90../* r|epeat by|
|00000a10| 74 65 20 66 6c 61 67 20 | 2a 2f 0a 58 23 64 65 66 |te flag |*/.X#def|
|00000a20| 69 6e 65 20 53 50 45 4f | 46 20 32 35 36 09 09 2f |ine SPEO|F 256../|
|00000a30| 2a 20 73 70 65 63 69 61 | 6c 20 65 6e 64 66 69 6c |* specia|l endfil|
|00000a40| 65 20 74 6f 6b 65 6e 20 | 2a 2f 0a 58 23 64 65 66 |e token |*/.X#def|
|00000a50| 69 6e 65 20 4e 55 4d 56 | 41 4c 53 20 32 35 37 09 |ine NUMV|ALS 257.|
|00000a60| 09 2f 2a 20 32 35 36 20 | 64 61 74 61 20 76 61 6c |./* 256 |data val|
|00000a70| 75 65 73 20 70 6c 75 73 | 20 53 50 45 4f 46 2a 2f |ues plus| SPEOF*/|
|00000a80| 0a 58 0a 58 73 74 61 74 | 69 63 20 69 6e 74 20 67 |.X.Xstat|ic int g|
|00000a90| 65 74 75 68 75 66 66 28 | 53 51 46 49 4c 45 20 2a |etuhuff(|SQFILE *|
|00000aa0| 73 71 70 29 3b 0a 58 73 | 74 61 74 69 63 20 69 6e |sqp);.Xs|tatic in|
|00000ab0| 74 20 70 6f 72 74 67 65 | 74 77 28 46 49 4c 45 20 |t portge|tw(FILE |
|00000ac0| 2a 66 29 3b 0a 58 0a 58 | 2f 2a 20 42 55 47 3a 20 |*f);.X.X|/* BUG: |
|00000ad0| 79 6f 75 20 63 61 6e 6e | 6f 74 20 73 65 6c 65 63 |you cann|ot selec|
|00000ae0| 74 20 61 6e 20 61 72 62 | 69 74 72 61 72 79 20 70 |t an arb|itrary p|
|00000af0| 6f 73 69 74 69 6f 6e 20 | 69 6e 20 74 68 65 20 6f |osition |in the o|
|00000b00| 75 74 70 75 74 20 73 74 | 72 65 61 6d 0a 58 20 2a |utput st|ream.X *|
|00000b10| 20 74 6f 20 73 74 61 72 | 74 20 79 6f 75 72 20 6f | to star|t your o|
|00000b20| 75 74 70 75 74 20 28 75 | 6e 6c 65 73 73 20 79 6f |utput (u|nless yo|
|00000b30| 75 20 6d 61 6b 65 20 70 | 72 6f 76 69 73 69 6f 6e |u make p|rovision|
|00000b40| 73 20 66 6f 72 20 74 68 | 61 74 29 2e 20 20 54 68 |s for th|at). Th|
|00000b50| 69 73 20 69 73 0a 58 20 | 2a 20 62 65 63 61 75 73 |is is.X |* becaus|
|00000b60| 65 20 6f 66 20 74 68 65 | 20 72 65 70 65 61 74 20 |e of the| repeat |
|00000b70| 63 6f 6d 70 72 65 73 73 | 69 6f 6e 2e 20 20 59 6f |compress|ion. Yo|
|00000b80| 75 20 63 61 6e 20 6d 61 | 6b 65 20 70 72 6f 76 69 |u can ma|ke provi|
|00000b90| 73 69 6f 6e 20 66 6f 72 | 20 73 65 65 6b 69 6e 67 |sion for| seeking|
|00000ba0| 0a 58 20 2a 20 74 6f 20 | 74 68 65 20 6d 69 64 64 |.X * to |the midd|
|00000bb0| 6c 65 20 6f 66 20 61 20 | 72 65 70 65 61 74 20 73 |le of a |repeat s|
|00000bc0| 65 71 75 65 6e 63 65 20 | 62 79 20 74 65 72 6d 69 |equence |by termi|
|00000bd0| 6e 61 74 69 6e 67 20 74 | 68 65 20 72 65 70 65 61 |nating t|he repea|
|00000be0| 74 20 77 68 65 6e 0a 58 | 20 2a 20 63 6f 6d 70 72 |t when.X| * compr|
|00000bf0| 65 73 73 69 6e 67 20 74 | 68 65 20 66 69 6c 65 2e |essing t|he file.|
|00000c00| 0a 58 20 2a 2f 0a 58 0a | 58 53 51 46 49 4c 45 20 |.X */.X.|XSQFILE |
|00000c10| 2a 0a 58 73 71 6f 70 65 | 6e 20 20 20 20 28 63 6f |*.Xsqope|n (co|
|00000c20| 6e 73 74 20 63 68 61 72 | 20 2a 70 61 74 68 29 0a |nst char| *path).|
|00000c30| 58 7b 0a 58 09 46 49 4c | 45 20 2a 66 70 3b 0a 58 |X{.X.FIL|E *fp;.X|
|00000c40| 09 53 51 46 49 4c 45 20 | 2a 73 71 70 3b 0a 58 09 |.SQFILE |*sqp;.X.|
|00000c50| 69 6e 74 20 6e 75 6d 6e | 6f 64 65 73 3b 0a 58 09 |int numn|odes;.X.|
|00000c60| 69 6e 74 20 69 3b 0a 58 | 0a 58 09 66 70 20 3d 20 |int i;.X|.X.fp = |
|00000c70| 66 6f 70 65 6e 28 70 61 | 74 68 2c 20 22 72 62 22 |fopen(pa|th, "rb"|
|00000c80| 29 3b 0a 58 09 69 66 20 | 28 21 66 70 29 0a 58 09 |);.X.if |(!fp).X.|
|00000c90| 09 72 65 74 75 72 6e 20 | 4e 55 4c 4c 3b 0a 58 09 |.return |NULL;.X.|
|00000ca0| 73 71 70 20 3d 20 6d 61 | 6c 6c 6f 63 28 73 69 7a |sqp = ma|lloc(siz|
|00000cb0| 65 6f 66 28 53 51 46 49 | 4c 45 29 29 3b 0a 58 09 |eof(SQFI|LE));.X.|
|00000cc0| 69 66 20 28 21 73 71 70 | 29 0a 58 09 09 72 65 74 |if (!sqp|).X..ret|
|00000cd0| 75 72 6e 20 4e 55 4c 4c | 3b 0a 58 09 73 71 70 2d |urn NULL|;.X.sqp-|
|00000ce0| 3e 66 69 6c 65 20 3d 20 | 66 70 3b 0a 58 09 69 66 |>file = |fp;.X.if|
|00000cf0| 28 70 6f 72 74 67 65 74 | 77 28 66 70 29 20 21 3d |(portget|w(fp) !=|
|00000d00| 20 28 69 6e 74 29 20 52 | 45 43 4f 47 4e 49 5a 45 | (int) R|ECOGNIZE|
|00000d10| 29 20 7b 2f 2a 20 50 72 | 6f 63 65 73 73 20 68 65 |) {/* Pr|ocess he|
|00000d20| 61 64 65 72 20 2a 2f 0a | 58 09 09 72 65 77 69 6e |ader */.|X..rewin|
|00000d30| 64 28 73 71 70 2d 3e 66 | 69 6c 65 29 3b 0a 58 09 |d(sqp->f|ile);.X.|
|00000d40| 09 73 71 70 2d 3e 69 73 | 73 71 20 3d 20 30 3b 0a |.sqp->is|sq = 0;.|
|00000d50| 58 09 09 72 65 74 75 72 | 6e 20 73 71 70 3b 0a 58 |X..retur|n sqp;.X|
|00000d60| 09 7d 0a 58 09 73 71 70 | 2d 3e 69 73 73 71 20 3d |.}.X.sqp|->issq =|
|00000d70| 20 31 3b 0a 58 09 28 76 | 6f 69 64 29 20 70 6f 72 | 1;.X.(v|oid) por|
|00000d80| 74 67 65 74 77 28 66 70 | 29 3b 09 09 2f 2a 20 63 |tgetw(fp|);../* c|
|00000d90| 68 65 63 6b 73 75 6d 20 | 2a 2f 0a 58 09 77 68 69 |hecksum |*/.X.whi|
|00000da0| 6c 65 20 28 67 65 74 63 | 28 66 70 29 29 09 09 2f |le (getc|(fp))../|
|00000db0| 2a 20 52 65 61 64 20 61 | 6e 64 20 64 69 73 63 61 |* Read a|nd disca|
|00000dc0| 72 64 20 74 68 65 20 6e | 61 6d 65 20 2a 2f 0a 58 |rd the n|ame */.X|
|00000dd0| 09 09 3b 0a 58 0a 58 09 | 6e 75 6d 6e 6f 64 65 73 |..;.X.X.|numnodes|
|00000de0| 20 3d 20 70 6f 72 74 67 | 65 74 77 28 66 70 29 3b | = portg|etw(fp);|
|00000df0| 0a 58 09 69 66 28 6e 75 | 6d 6e 6f 64 65 73 20 3c |.X.if(nu|mnodes <|
|00000e00| 20 30 20 7c 7c 20 6e 75 | 6d 6e 6f 64 65 73 20 3e | 0 || nu|mnodes >|
|00000e10| 3d 20 4e 55 4d 56 41 4c | 53 29 20 7b 0a 58 09 09 |= NUMVAL|S) {.X..|
|00000e20| 2f 2a 20 69 6e 76 61 6c | 69 64 20 64 65 63 6f 64 |/* inval|id decod|
|00000e30| 65 20 74 72 65 65 20 2a | 2f 0a 58 09 09 66 63 6c |e tree *|/.X..fcl|
|00000e40| 6f 73 65 28 66 70 29 3b | 0a 58 09 09 72 65 74 75 |ose(fp);|.X..retu|
|00000e50| 72 6e 20 4e 55 4c 4c 3b | 0a 58 09 7d 0a 58 09 2f |rn NULL;|.X.}.X./|
|00000e60| 2a 20 49 6e 69 74 69 61 | 6c 69 7a 65 20 66 6f 72 |* Initia|lize for|
|00000e70| 20 70 6f 73 73 69 62 6c | 65 20 65 6d 70 74 79 20 | possibl|e empty |
|00000e80| 74 72 65 65 20 28 53 50 | 45 4f 46 20 6f 6e 6c 79 |tree (SP|EOF only|
|00000e90| 29 20 2a 2f 0a 58 09 73 | 71 70 2d 3e 73 71 6c 65 |) */.X.s|qp->sqle|
|00000ea0| 61 66 5b 30 5d 2e 63 68 | 69 6c 64 72 65 6e 5b 30 |af[0].ch|ildren[0|
|00000eb0| 5d 20 3d 20 2d 28 53 50 | 45 4f 46 20 2b 20 31 29 |] = -(SP|EOF + 1)|
|00000ec0| 3b 0a 58 09 73 71 70 2d | 3e 73 71 6c 65 61 66 5b |;.X.sqp-|>sqleaf[|
|00000ed0| 30 5d 2e 63 68 69 6c 64 | 72 65 6e 5b 31 5d 20 3d |0].child|ren[1] =|
|00000ee0| 20 2d 28 53 50 45 4f 46 | 20 2b 20 31 29 3b 0a 58 | -(SPEOF| + 1);.X|
|00000ef0| 0a 58 09 66 6f 72 28 69 | 20 3d 20 30 3b 20 69 20 |.X.for(i| = 0; i |
|00000f00| 3c 20 6e 75 6d 6e 6f 64 | 65 73 3b 20 2b 2b 69 29 |< numnod|es; ++i)|
|00000f10| 20 7b 09 2f 2a 20 47 65 | 74 20 64 65 63 6f 64 69 | {./* Ge|t decodi|
|00000f20| 6e 67 20 74 72 65 65 20 | 66 72 6f 6d 20 66 69 6c |ng tree |from fil|
|00000f30| 65 20 2a 2f 0a 58 09 09 | 73 71 70 2d 3e 73 71 6c |e */.X..|sqp->sql|
|00000f40| 65 61 66 5b 69 5d 2e 63 | 68 69 6c 64 72 65 6e 5b |eaf[i].c|hildren[|
|00000f50| 30 5d 20 3d 20 70 6f 72 | 74 67 65 74 77 28 66 70 |0] = por|tgetw(fp|
|00000f60| 29 3b 0a 58 09 09 73 71 | 70 2d 3e 73 71 6c 65 61 |);.X..sq|p->sqlea|
|00000f70| 66 5b 69 5d 2e 63 68 69 | 6c 64 72 65 6e 5b 31 5d |f[i].chi|ldren[1]|
|00000f80| 20 3d 20 70 6f 72 74 67 | 65 74 77 28 66 70 29 3b | = portg|etw(fp);|
|00000f90| 0a 58 09 7d 0a 58 09 73 | 71 70 2d 3e 72 65 77 70 |.X.}.X.s|qp->rewp|
|00000fa0| 6f 73 20 3d 20 66 74 65 | 6c 6c 28 73 71 70 2d 3e |os = fte|ll(sqp->|
|00000fb0| 66 69 6c 65 29 3b 0a 58 | 09 73 71 70 2d 3e 62 70 |file);.X|.sqp->bp|
|00000fc0| 6f 73 20 3d 20 37 3b 09 | 09 09 2f 2a 20 66 6f 72 |os = 7;.|../* for|
|00000fd0| 63 65 20 69 6e 69 74 69 | 61 6c 20 72 65 61 64 20 |ce initi|al read |
|00000fe0| 2a 2f 0a 58 09 73 71 70 | 2d 3e 72 65 70 63 74 20 |*/.X.sqp|->repct |
|00000ff0| 3d 20 30 3b 09 09 09 2f | 2a 20 73 74 61 72 74 20 |= 0;.../|* start |
|00001000| 77 69 74 68 20 6e 6f 20 | 72 65 70 65 61 74 73 20 |with no |repeats |
|00001010| 2a 2f 0a 58 09 72 65 74 | 75 72 6e 20 73 71 70 3b |*/.X.ret|urn sqp;|
|00001020| 0a 58 7d 0a 58 0a 58 76 | 6f 69 64 0a 58 73 71 72 |.X}.X.Xv|oid.Xsqr|
|00001030| 65 77 69 6e 64 28 53 51 | 46 49 4c 45 20 2a 73 71 |ewind(SQ|FILE *sq|
|00001040| 70 29 0a 58 7b 0a 58 09 | 73 71 70 2d 3e 62 70 6f |p).X{.X.|sqp->bpo|
|00001050| 73 20 3d 20 37 3b 09 09 | 09 2f 2a 20 66 6f 72 63 |s = 7;..|./* forc|
|00001060| 65 20 69 6e 69 74 69 61 | 6c 20 72 65 61 64 20 2a |e initia|l read *|
|00001070| 2f 0a 58 09 73 71 70 2d | 3e 72 65 70 63 74 20 3d |/.X.sqp-|>repct =|
|00001080| 20 30 3b 09 09 09 2f 2a | 20 73 74 61 72 74 20 77 | 0;.../*| start w|
|00001090| 69 74 68 20 6e 6f 20 72 | 65 70 65 61 74 73 20 2a |ith no r|epeats *|
|000010a0| 2f 0a 58 09 66 73 65 65 | 6b 28 73 71 70 2d 3e 66 |/.X.fsee|k(sqp->f|
|000010b0| 69 6c 65 2c 20 73 71 70 | 2d 3e 72 65 77 70 6f 73 |ile, sqp|->rewpos|
|000010c0| 2c 20 53 45 45 4b 5f 53 | 45 54 29 3b 0a 58 7d 0a |, SEEK_S|ET);.X}.|
|000010d0| 58 0a 58 0a 58 2f 2a 20 | 54 68 65 20 22 6f 66 66 |X.X.X/* |The "off|
|000010e0| 73 65 74 22 20 69 73 20 | 61 63 74 75 61 6c 6c 79 |set" is |actually|
|000010f0| 20 61 20 62 69 74 20 6f | 66 66 73 65 74 20 77 69 | a bit o|ffset wi|
|00001100| 74 68 69 6e 20 74 68 65 | 20 66 69 6c 65 2e 20 20 |thin the| file. |
|00001110| 4f 66 66 73 65 74 20 30 | 20 69 73 0a 58 20 2a 20 |Offset 0| is.X * |
|00001120| 62 69 74 20 30 2c 20 62 | 79 74 65 20 30 2e 20 20 |bit 0, b|yte 0. |
|00001130| 4f 66 66 73 65 74 20 38 | 20 69 73 20 62 69 74 20 |Offset 8| is bit |
|00001140| 30 2c 20 62 79 74 65 20 | 31 2e 20 20 45 74 63 2e |0, byte |1. Etc.|
|00001150| 2e 2e 0a 58 20 2a 2f 0a | 58 6c 6f 6e 67 0a 58 73 |...X */.|Xlong.Xs|
|00001160| 71 73 65 65 6b 28 53 51 | 46 49 4c 45 20 2a 73 71 |qseek(SQ|FILE *sq|
|00001170| 70 2c 20 6c 6f 6e 67 20 | 6f 66 66 73 65 74 29 0a |p, long |offset).|
|00001180| 58 7b 0a 58 09 69 6e 74 | 20 62 70 6f 73 3b 0a 58 |X{.X.int| bpos;.X|
|00001190| 09 6c 6f 6e 67 20 76 61 | 6c 75 65 3b 0a 58 0a 58 |.long va|lue;.X.X|
|000011a0| 09 69 66 20 28 21 73 71 | 70 2d 3e 69 73 73 71 29 |.if (!sq|p->issq)|
|000011b0| 0a 58 09 09 72 65 74 75 | 72 6e 20 66 73 65 65 6b |.X..retu|rn fseek|
|000011c0| 28 73 71 70 2d 3e 66 69 | 6c 65 2c 20 6f 66 66 73 |(sqp->fi|le, offs|
|000011d0| 65 74 2c 20 53 45 45 4b | 5f 53 45 54 29 3b 0a 58 |et, SEEK|_SET);.X|
|000011e0| 0a 58 09 62 70 6f 73 20 | 3d 20 6f 66 66 73 65 74 |.X.bpos |= offset|
|000011f0| 20 26 20 37 3b 0a 58 09 | 76 61 6c 75 65 20 3d 20 | & 7;.X.|value = |
|00001200| 66 73 65 65 6b 28 73 71 | 70 2d 3e 66 69 6c 65 2c |fseek(sq|p->file,|
|00001210| 20 6f 66 66 73 65 74 20 | 3e 3e 20 33 2c 20 53 45 | offset |>> 3, SE|
|00001220| 45 4b 5f 53 45 54 29 3b | 0a 58 09 69 66 20 28 62 |EK_SET);|.X.if (b|
|00001230| 70 6f 73 20 3d 3d 20 30 | 29 20 7b 0a 58 09 09 73 |pos == 0|) {.X..s|
|00001240| 71 70 2d 3e 62 70 6f 73 | 20 3d 20 37 3b 0a 58 09 |qp->bpos| = 7;.X.|
|00001250| 7d 20 65 6c 73 65 20 7b | 0a 58 09 09 73 71 70 2d |} else {|.X..sqp-|
|00001260| 3e 62 70 6f 73 20 3d 20 | 62 70 6f 73 20 2d 20 31 |>bpos = |bpos - 1|
|00001270| 3b 0a 58 09 09 73 71 70 | 2d 3e 63 75 72 69 6e 20 |;.X..sqp|->curin |
|00001280| 3d 20 67 65 74 63 28 73 | 71 70 2d 3e 66 69 6c 65 |= getc(s|qp->file|
|00001290| 29 20 3e 3e 20 28 62 70 | 6f 73 20 2d 20 31 29 3b |) >> (bp|os - 1);|
|000012a0| 0a 58 09 7d 0a 58 09 73 | 71 70 2d 3e 72 65 70 63 |.X.}.X.s|qp->repc|
|000012b0| 74 20 3d 20 30 3b 09 09 | 09 2f 2a 20 73 74 61 72 |t = 0;..|./* star|
|000012c0| 74 20 77 69 74 68 20 6e | 6f 20 72 65 70 65 61 74 |t with n|o repeat|
|000012d0| 73 20 2a 2f 0a 58 09 72 | 65 74 75 72 6e 20 76 61 |s */.X.r|eturn va|
|000012e0| 6c 75 65 3b 0a 58 7d 0a | 58 0a 58 0a 58 2f 2a 20 |lue;.X}.|X.X.X/* |
|000012f0| 47 65 74 20 62 79 74 65 | 73 20 77 69 74 68 20 64 |Get byte|s with d|
|00001300| 65 63 6f 64 69 6e 67 20 | 2d 20 74 68 69 73 20 64 |ecoding |- this d|
|00001310| 65 63 6f 64 65 73 20 72 | 65 70 65 74 69 74 69 6f |ecodes r|epetitio|
|00001320| 6e 2c 0a 58 20 2a 20 63 | 61 6c 6c 73 20 67 65 74 |n,.X * c|alls get|
|00001330| 75 68 75 66 66 20 74 6f | 20 64 65 63 6f 64 65 20 |uhuff to| decode |
|00001340| 66 69 6c 65 20 73 74 72 | 65 61 6d 20 69 6e 74 6f |file str|eam into|
|00001350| 20 62 79 74 65 0a 58 20 | 2a 20 6c 65 76 65 6c 20 | byte.X |* level |
|00001360| 63 6f 64 65 20 77 69 74 | 68 20 6f 6e 6c 79 20 72 |code wit|h only r|
|00001370| 65 70 65 74 69 74 69 6f | 6e 20 65 6e 63 6f 64 69 |epetitio|n encodi|
|00001380| 6e 67 2e 0a 58 20 2a 0a | 58 20 2a 20 54 68 65 20 |ng..X *.|X * The |
|00001390| 63 6f 64 65 20 69 73 20 | 73 69 6d 70 6c 65 20 70 |code is |simple p|
|000013a0| 61 73 73 69 6e 67 20 74 | 68 72 6f 75 67 68 20 6f |assing t|hrough o|
|000013b0| 66 20 62 79 74 65 73 20 | 65 78 63 65 70 74 0a 58 |f bytes |except.X|
|000013c0| 20 2a 20 74 68 61 74 20 | 44 4c 45 20 69 73 20 65 | * that |DLE is e|
|000013d0| 6e 63 6f 64 65 64 20 61 | 73 20 44 4c 45 2d 7a 65 |ncoded a|s DLE-ze|
|000013e0| 72 6f 20 61 6e 64 20 6f | 74 68 65 72 20 76 61 6c |ro and o|ther val|
|000013f0| 75 65 73 0a 58 20 2a 20 | 72 65 70 65 61 74 65 64 |ues.X * |repeated|
|00001400| 20 6d 6f 72 65 20 74 68 | 61 6e 20 74 77 69 63 65 | more th|an twice|
|00001410| 20 61 72 65 20 65 6e 63 | 6f 64 65 64 20 61 73 20 | are enc|oded as |
|00001420| 76 61 6c 75 65 2d 44 4c | 45 2d 63 6f 75 6e 74 2e |value-DL|E-count.|
|00001430| 0a 58 20 2a 2f 0a 58 0a | 58 69 6e 74 0a 58 73 71 |.X */.X.|Xint.Xsq|
|00001440| 67 65 74 63 28 53 51 46 | 49 4c 45 20 2a 73 71 70 |getc(SQF|ILE *sqp|
|00001450| 29 0a 58 7b 0a 58 09 69 | 6e 74 20 63 3b 0a 58 0a |).X{.X.i|nt c;.X.|
|00001460| 58 09 69 66 20 28 21 73 | 71 70 2d 3e 69 73 73 71 |X.if (!s|qp->issq|
|00001470| 29 0a 58 09 09 72 65 74 | 75 72 6e 20 67 65 74 63 |).X..ret|urn getc|
|00001480| 28 73 71 70 2d 3e 66 69 | 6c 65 29 3b 0a 58 0a 58 |(sqp->fi|le);.X.X|
|00001490| 09 69 66 28 73 71 70 2d | 3e 72 65 70 63 74 20 3e |.if(sqp-|>repct >|
|000014a0| 20 30 29 20 7b 0a 58 09 | 09 2f 2a 20 45 78 70 61 | 0) {.X.|./* Expa|
|000014b0| 6e 64 69 6e 67 20 61 20 | 72 65 70 65 61 74 65 64 |nding a |repeated|
|000014c0| 20 63 68 61 72 20 2a 2f | 0a 58 09 09 2d 2d 73 71 | char */|.X..--sq|
|000014d0| 70 2d 3e 72 65 70 63 74 | 3b 0a 58 09 09 72 65 74 |p->repct|;.X..ret|
|000014e0| 75 72 6e 28 73 71 70 2d | 3e 76 61 6c 75 65 29 3b |urn(sqp-|>value);|
|000014f0| 0a 58 09 7d 20 65 6c 73 | 65 20 7b 0a 58 09 09 2f |.X.} els|e {.X../|
|00001500| 2a 20 4e 6f 74 68 69 6e | 67 20 75 6e 75 73 75 61 |* Nothin|g unusua|
|00001510| 6c 20 2a 2f 0a 58 09 09 | 69 66 28 28 63 20 3d 20 |l */.X..|if((c = |
|00001520| 67 65 74 75 68 75 66 66 | 28 73 71 70 29 29 20 21 |getuhuff|(sqp)) !|
|00001530| 3d 20 44 4c 45 29 20 7b | 0a 58 09 09 09 2f 2a 20 |= DLE) {|.X.../* |
|00001540| 49 74 27 73 20 6e 6f 74 | 20 74 68 65 20 73 70 65 |It's not| the spe|
|00001550| 63 69 61 6c 20 64 65 6c | 69 6d 69 74 65 72 20 2a |cial del|imiter *|
|00001560| 2f 0a 58 09 09 09 73 71 | 70 2d 3e 76 61 6c 75 65 |/.X...sq|p->value|
|00001570| 20 3d 20 63 3b 0a 58 09 | 09 09 69 66 28 73 71 70 | = c;.X.|..if(sqp|
|00001580| 2d 3e 76 61 6c 75 65 20 | 3d 3d 20 45 4f 46 29 0a |->value |== EOF).|
|00001590| 58 09 09 09 09 73 71 70 | 2d 3e 72 65 70 63 74 20 |X....sqp|->repct |
|000015a0| 3d 20 49 4e 54 5f 4d 41 | 58 3b 0a 58 09 09 09 72 |= INT_MA|X;.X...r|
|000015b0| 65 74 75 72 6e 28 73 71 | 70 2d 3e 76 61 6c 75 65 |eturn(sq|p->value|
|000015c0| 29 3b 0a 58 09 09 7d 20 | 65 6c 73 65 20 7b 0a 58 |);.X..} |else {.X|
|000015d0| 09 09 09 2f 2a 20 53 70 | 65 63 69 61 6c 20 74 6f |.../* Sp|ecial to|
|000015e0| 6b 65 6e 20 2a 2f 0a 58 | 09 09 09 69 66 28 28 73 |ken */.X|...if((s|
|000015f0| 71 70 2d 3e 72 65 70 63 | 74 20 3d 20 67 65 74 75 |qp->repc|t = getu|
|00001600| 68 75 66 66 28 73 71 70 | 29 29 20 3d 3d 20 30 29 |huff(sqp|)) == 0)|
|00001610| 0a 58 09 09 09 09 2f 2a | 20 44 4c 45 2c 20 7a 65 |.X..../*| DLE, ze|
|00001620| 72 6f 20 72 65 70 72 65 | 73 65 6e 74 73 20 44 4c |ro repre|sents DL|
|00001630| 45 20 2a 2f 0a 58 09 09 | 09 09 72 65 74 75 72 6e |E */.X..|..return|
|00001640| 28 44 4c 45 29 3b 0a 58 | 09 09 09 65 6c 73 65 20 |(DLE);.X|...else |
|00001650| 7b 0a 58 09 09 09 09 2f | 2a 20 42 65 67 69 6e 20 |{.X..../|* Begin |
|00001660| 65 78 70 61 6e 64 69 6e | 67 20 72 65 70 65 74 69 |expandin|g repeti|
|00001670| 74 69 6f 6e 20 2a 2f 0a | 58 09 09 09 09 73 71 70 |tion */.|X....sqp|
|00001680| 2d 3e 72 65 70 63 74 20 | 2d 3d 20 32 3b 09 2f 2a |->repct |-= 2;./*|
|00001690| 20 32 6e 64 20 74 69 6d | 65 20 2a 2f 0a 58 09 09 | 2nd tim|e */.X..|
|000016a0| 09 09 72 65 74 75 72 6e | 28 73 71 70 2d 3e 76 61 |..return|(sqp->va|
|000016b0| 6c 75 65 29 3b 0a 58 09 | 09 09 7d 0a 58 09 09 7d |lue);.X.|..}.X..}|
|000016c0| 0a 58 09 7d 0a 58 7d 0a | 58 0a 58 0a 58 2f 2a 20 |.X.}.X}.|X.X.X/* |
|000016d0| 44 65 63 6f 64 65 20 66 | 69 6c 65 20 73 74 72 65 |Decode f|ile stre|
|000016e0| 61 6d 20 69 6e 74 6f 20 | 61 20 62 79 74 65 20 6c |am into |a byte l|
|000016f0| 65 76 65 6c 20 63 6f 64 | 65 20 77 69 74 68 20 6f |evel cod|e with o|
|00001700| 6e 6c 79 0a 58 20 2a 20 | 72 65 70 65 74 69 74 69 |nly.X * |repetiti|
|00001710| 6f 6e 20 65 6e 63 6f 64 | 69 6e 67 20 72 65 6d 61 |on encod|ing rema|
|00001720| 69 6e 69 6e 67 2e 0a 58 | 20 2a 2f 0a 58 73 74 61 |ining..X| */.Xsta|
|00001730| 74 69 63 20 69 6e 74 0a | 58 67 65 74 75 68 75 66 |tic int.|Xgetuhuf|
|00001740| 66 28 53 51 46 49 4c 45 | 20 2a 73 71 70 29 0a 58 |f(SQFILE| *sqp).X|
|00001750| 7b 0a 58 09 69 6e 74 20 | 69 3b 0a 58 0a 58 09 2f |{.X.int |i;.X.X./|
|00001760| 2a 20 46 6f 6c 6c 6f 77 | 20 62 69 74 20 73 74 72 |* Follow| bit str|
|00001770| 65 61 6d 20 69 6e 20 74 | 72 65 65 20 74 6f 20 61 |eam in t|ree to a|
|00001780| 20 6c 65 61 66 2a 2f 0a | 58 09 69 20 3d 20 30 3b | leaf*/.|X.i = 0;|
|00001790| 09 2f 2a 20 53 74 61 72 | 74 20 61 74 20 72 6f 6f |./* Star|t at roo|
|000017a0| 74 20 6f 66 20 74 72 65 | 65 20 2a 2f 0a 58 09 64 |t of tre|e */.X.d|
|000017b0| 6f 20 7b 0a 58 09 09 69 | 66 28 2b 2b 73 71 70 2d |o {.X..i|f(++sqp-|
|000017c0| 3e 62 70 6f 73 20 3e 20 | 37 29 20 7b 0a 58 09 09 |>bpos > |7) {.X..|
|000017d0| 09 69 66 28 28 73 71 70 | 2d 3e 63 75 72 69 6e 20 |.if((sqp|->curin |
|000017e0| 3d 20 67 65 74 63 28 73 | 71 70 2d 3e 66 69 6c 65 |= getc(s|qp->file|
|000017f0| 29 29 20 3d 3d 20 45 4f | 46 29 0a 58 09 09 09 09 |)) == EO|F).X....|
|00001800| 72 65 74 75 72 6e 28 45 | 52 52 4f 52 29 3b 0a 58 |return(E|RROR);.X|
|00001810| 09 09 09 73 71 70 2d 3e | 62 70 6f 73 20 3d 20 30 |...sqp->|bpos = 0|
|00001820| 3b 0a 58 09 09 09 2f 2a | 20 6d 6f 76 65 20 61 20 |;.X.../*| move a |
|00001830| 6c 65 76 65 6c 20 64 65 | 65 70 65 72 20 69 6e 20 |level de|eper in |
|00001840| 74 72 65 65 20 2a 2f 0a | 58 09 09 09 69 20 3d 20 |tree */.|X...i = |
|00001850| 73 71 70 2d 3e 73 71 6c | 65 61 66 5b 69 5d 2e 63 |sqp->sql|eaf[i].c|
|00001860| 68 69 6c 64 72 65 6e 5b | 31 20 26 20 73 71 70 2d |hildren[|1 & sqp-|
|00001870| 3e 63 75 72 69 6e 5d 3b | 0a 58 09 09 7d 20 65 6c |>curin];|.X..} el|
|00001880| 73 65 0a 58 09 09 09 69 | 20 3d 20 73 71 70 2d 3e |se.X...i| = sqp->|
|00001890| 73 71 6c 65 61 66 5b 69 | 5d 2e 63 68 69 6c 64 72 |sqleaf[i|].childr|
|000018a0| 65 6e 5b 31 20 26 20 28 | 73 71 70 2d 3e 63 75 72 |en[1 & (|sqp->cur|
|000018b0| 69 6e 20 3e 3e 3d 20 31 | 29 5d 3b 0a 58 09 7d 20 |in >>= 1|)];.X.} |
|000018c0| 77 68 69 6c 65 28 69 20 | 3e 3d 20 30 29 3b 0a 58 |while(i |>= 0);.X|
|000018d0| 0a 58 09 2f 2a 20 44 65 | 63 6f 64 65 20 66 61 6b |.X./* De|code fak|
|000018e0| 65 20 6e 6f 64 65 20 69 | 6e 64 65 78 20 74 6f 20 |e node i|ndex to |
|000018f0| 6f 72 69 67 69 6e 61 6c | 20 64 61 74 61 20 76 61 |original| data va|
|00001900| 6c 75 65 20 2a 2f 0a 58 | 09 69 20 3d 20 2d 28 69 |lue */.X|.i = -(i|
|00001910| 20 2b 20 31 29 3b 0a 58 | 09 2f 2a 20 44 65 63 6f | + 1);.X|./* Deco|
|00001920| 64 65 20 73 70 65 63 69 | 61 6c 20 65 6e 64 66 69 |de speci|al endfi|
|00001930| 6c 65 20 74 6f 6b 65 6e | 20 74 6f 20 6e 6f 72 6d |le token| to norm|
|00001940| 61 6c 20 45 4f 46 20 2a | 2f 0a 58 09 72 65 74 75 |al EOF *|/.X.retu|
|00001950| 72 6e 28 69 20 3d 3d 20 | 53 50 45 4f 46 29 20 3f |rn(i == |SPEOF) ?|
|00001960| 20 45 4f 46 20 3a 20 69 | 3b 0a 58 7d 0a 58 0a 58 | EOF : i|;.X}.X.X|
|00001970| 0a 58 63 68 61 72 0a 58 | 2a 73 71 67 65 74 73 20 |.Xchar.X|*sqgets |
|00001980| 20 20 20 28 63 68 61 72 | 20 2a 73 2c 20 69 6e 74 | (char| *s, int|
|00001990| 20 6e 2c 20 53 51 46 49 | 4c 45 20 2a 73 71 70 29 | n, SQFI|LE *sqp)|
|000019a0| 0a 58 7b 0a 58 09 69 6e | 74 20 63 20 3d 20 27 5c |.X{.X.in|t c = '\|
|000019b0| 30 27 3b 0a 58 0a 58 09 | 77 68 69 6c 65 20 28 63 |0';.X.X.|while (c|
|000019c0| 20 21 3d 20 27 5c 6e 27 | 20 26 26 20 6e 20 3e 20 | != '\n'| && n > |
|000019d0| 31 29 20 7b 0a 58 09 09 | 69 66 20 28 28 63 20 3d |1) {.X..|if ((c =|
|000019e0| 20 73 71 67 65 74 63 28 | 73 71 70 29 29 20 3d 3d | sqgetc(|sqp)) ==|
|000019f0| 20 45 4f 46 29 0a 58 09 | 09 09 72 65 74 75 72 6e | EOF).X.|..return|
|00001a00| 20 4e 55 4c 4c 3b 0a 58 | 09 09 69 66 20 28 63 20 | NULL;.X|..if (c |
|00001a10| 3d 3d 20 27 5c 72 27 29 | 0a 58 09 09 09 63 6f 6e |== '\r')|.X...con|
|00001a20| 74 69 6e 75 65 3b 0a 58 | 09 09 2a 73 2b 2b 20 3d |tinue;.X|..*s++ =|
|00001a30| 20 63 3b 0a 58 09 09 2d | 2d 6e 3b 0a 58 09 7d 0a | c;.X..-|-n;.X.}.|
|00001a40| 58 09 2a 73 20 3d 20 27 | 5c 30 27 3b 0a 58 09 72 |X.*s = '|\0';.X.r|
|00001a50| 65 74 75 72 6e 20 73 3b | 0a 58 7d 0a 58 0a 58 0a |eturn s;|.X}.X.X.|
|00001a60| 58 6c 6f 6e 67 0a 58 73 | 71 74 65 6c 6c 20 20 20 |Xlong.Xs|qtell |
|00001a70| 20 28 53 51 46 49 4c 45 | 20 2a 73 71 70 29 0a 58 | (SQFILE| *sqp).X|
|00001a80| 7b 0a 58 09 69 66 20 28 | 21 73 71 70 2d 3e 69 73 |{.X.if (|!sqp->is|
|00001a90| 73 71 29 0a 58 09 09 72 | 65 74 75 72 6e 20 66 74 |sq).X..r|eturn ft|
|00001aa0| 65 6c 6c 28 73 71 70 2d | 3e 66 69 6c 65 29 3b 0a |ell(sqp-|>file);.|
|00001ab0| 58 09 72 65 74 75 72 6e | 20 28 66 74 65 6c 6c 28 |X.return| (ftell(|
|00001ac0| 73 71 70 2d 3e 66 69 6c | 65 29 20 3c 3c 20 33 29 |sqp->fil|e) << 3)|
|00001ad0| 20 2b 20 73 71 70 2d 3e | 62 70 6f 73 3b 0a 58 7d | + sqp->|bpos;.X}|
|00001ae0| 0a 58 0a 58 0a 58 6c 6f | 6e 67 0a 58 73 71 73 69 |.X.X.Xlo|ng.Xsqsi|
|00001af0| 7a 65 20 20 20 20 28 53 | 51 46 49 4c 45 20 2a 73 |ze (S|QFILE *s|
|00001b00| 71 70 29 0a 58 7b 0a 58 | 09 66 73 65 65 6b 28 73 |qp).X{.X|.fseek(s|
|00001b10| 71 70 2d 3e 66 69 6c 65 | 2c 20 30 2c 20 53 45 45 |qp->file|, 0, SEE|
|00001b20| 4b 5f 45 4e 44 29 3b 0a | 58 09 69 66 20 28 21 73 |K_END);.|X.if (!s|
|00001b30| 71 70 2d 3e 69 73 73 71 | 29 0a 58 09 09 72 65 74 |qp->issq|).X..ret|
|00001b40| 75 72 6e 20 66 74 65 6c | 6c 28 73 71 70 2d 3e 66 |urn ftel|l(sqp->f|
|00001b50| 69 6c 65 29 3b 0a 58 09 | 72 65 74 75 72 6e 20 28 |ile);.X.|return (|
|00001b60| 66 74 65 6c 6c 28 73 71 | 70 2d 3e 66 69 6c 65 29 |ftell(sq|p->file)|
|00001b70| 20 3c 3c 20 33 29 20 2b | 20 37 3b 0a 58 7d 0a 58 | << 3) +| 7;.X}.X|
|00001b80| 0a 58 0a 58 69 6e 74 0a | 58 73 71 63 6c 6f 73 65 |.X.Xint.|Xsqclose|
|00001b90| 20 20 20 28 53 51 46 49 | 4c 45 20 2a 73 71 70 29 | (SQFI|LE *sqp)|
|00001ba0| 0a 58 7b 0a 58 09 69 6e | 74 20 76 61 6c 75 65 20 |.X{.X.in|t value |
|00001bb0| 3d 20 66 63 6c 6f 73 65 | 28 73 71 70 2d 3e 66 69 |= fclose|(sqp->fi|
|00001bc0| 6c 65 29 3b 0a 58 09 66 | 72 65 65 28 73 71 70 29 |le);.X.f|ree(sqp)|
|00001bd0| 3b 0a 58 09 72 65 74 75 | 72 6e 20 76 61 6c 75 65 |;.X.retu|rn value|
|00001be0| 3b 0a 58 7d 0a 58 0a 58 | 0a 58 2f 2a 0a 58 20 2a |;.X}.X.X|.X/*.X *|
|00001bf0| 20 4d 61 63 68 69 6e 65 | 20 69 6e 64 65 70 65 6e | Machine| indepen|
|00001c00| 64 65 6e 74 20 67 65 74 | 77 20 77 68 69 63 68 20 |dent get|w which |
|00001c10| 61 6c 77 61 79 73 20 67 | 65 74 73 20 62 79 74 65 |always g|ets byte|
|00001c20| 73 20 69 6e 20 74 68 65 | 20 73 61 6d 65 20 6f 72 |s in the| same or|
|00001c30| 64 65 72 0a 58 20 2a 20 | 20 61 73 20 74 68 65 20 |der.X * | as the |
|00001c40| 43 50 2f 4d 20 76 65 72 | 73 69 6f 6e 20 6f 66 20 |CP/M ver|sion of |
|00001c50| 53 51 20 77 72 6f 74 65 | 20 74 68 65 6d 0a 58 20 |SQ wrote| them.X |
|00001c60| 2a 2f 0a 58 73 74 61 74 | 69 63 20 69 6e 74 0a 58 |*/.Xstat|ic int.X|
|00001c70| 70 6f 72 74 67 65 74 77 | 28 66 29 0a 58 46 49 4c |portgetw|(f).XFIL|
|00001c80| 45 20 2a 66 3b 0a 58 7b | 0a 58 09 69 6e 74 20 63 |E *f;.X{|.X.int c|
|00001c90| 3b 0a 58 0a 58 09 63 20 | 3d 20 67 65 74 63 28 66 |;.X.X.c |= getc(f|
|00001ca0| 29 20 26 20 30 33 37 37 | 3b 0a 58 09 72 65 74 75 |) & 0377|;.X.retu|
|00001cb0| 72 6e 28 63 20 7c 20 28 | 67 65 74 63 28 66 29 20 |rn(c | (|getc(f) |
|00001cc0| 3c 3c 20 38 29 29 3b 0a | 58 7d 0a 45 4e 44 5f 4f |<< 8));.|X}.END_O|
|00001cd0| 46 5f 46 49 4c 45 0a 69 | 66 20 74 65 73 74 20 34 |F_FILE.i|f test 4|
|00001ce0| 39 30 33 20 2d 6e 65 20 | 60 77 63 20 2d 63 20 3c |903 -ne |`wc -c <|
|00001cf0| 27 73 71 72 65 61 64 2e | 63 27 60 3b 20 74 68 65 |'sqread.|c'`; the|
|00001d00| 6e 0a 20 20 20 20 65 63 | 68 6f 20 73 68 61 72 3a |n. ec|ho shar:|
|00001d10| 20 5c 22 27 73 71 72 65 | 61 64 2e 63 27 5c 22 20 | \"'sqre|ad.c'\" |
|00001d20| 75 6e 70 61 63 6b 65 64 | 20 77 69 74 68 20 77 72 |unpacked| with wr|
|00001d30| 6f 6e 67 20 73 69 7a 65 | 21 0a 66 69 0a 23 20 65 |ong size|!.fi.# e|
|00001d40| 6e 64 20 6f 66 20 27 73 | 71 72 65 61 64 2e 63 27 |nd of 's|qread.c'|
|00001d50| 0a 66 69 0a 69 66 20 74 | 65 73 74 20 2d 66 20 27 |.fi.if t|est -f '|
|00001d60| 73 71 72 65 61 64 2e 68 | 27 20 2d 61 20 22 24 7b |sqread.h|' -a "${|
|00001d70| 31 7d 22 20 21 3d 20 22 | 2d 63 22 20 3b 20 74 68 |1}" != "|-c" ; th|
|00001d80| 65 6e 20 0a 20 20 65 63 | 68 6f 20 73 68 61 72 3a |en . ec|ho shar:|
|00001d90| 20 57 69 6c 6c 20 6e 6f | 74 20 63 6c 6f 62 62 65 | Will no|t clobbe|
|00001da0| 72 20 65 78 69 73 74 69 | 6e 67 20 66 69 6c 65 20 |r existi|ng file |
|00001db0| 5c 22 27 73 71 72 65 61 | 64 2e 68 27 5c 22 0a 65 |\"'sqrea|d.h'\".e|
|00001dc0| 6c 73 65 0a 65 63 68 6f | 20 73 68 61 72 3a 20 45 |lse.echo| shar: E|
|00001dd0| 78 74 72 61 63 74 69 6e | 67 20 5c 22 27 73 71 72 |xtractin|g \"'sqr|
|00001de0| 65 61 64 2e 68 27 5c 22 | 20 5c 28 37 30 39 20 63 |ead.h'\"| \(709 c|
|00001df0| 68 61 72 61 63 74 65 72 | 73 5c 29 0a 73 65 64 20 |haracter|s\).sed |
|00001e00| 22 73 2f 5e 58 2f 2f 22 | 20 3e 27 73 71 72 65 61 |"s/^X//"| >'sqrea|
|00001e10| 64 2e 68 27 20 3c 3c 27 | 45 4e 44 5f 4f 46 5f 46 |d.h' <<'|END_OF_F|
|00001e20| 49 4c 45 27 0a 58 73 74 | 72 75 63 74 20 73 71 6c |ILE'.Xst|ruct sql|
|00001e30| 65 61 66 20 7b 09 09 2f | 2a 20 44 65 63 6f 64 69 |eaf {../|* Decodi|
|00001e40| 6e 67 20 74 72 65 65 20 | 2a 2f 0a 58 09 69 6e 74 |ng tree |*/.X.int|
|00001e50| 20 63 68 69 6c 64 72 65 | 6e 5b 32 5d 3b 09 2f 2a | childre|n[2];./*|
|00001e60| 20 6c 65 66 74 2c 20 72 | 69 67 68 74 20 2a 2f 0a | left, r|ight */.|
|00001e70| 58 7d 3b 0a 58 0a 58 74 | 79 70 65 64 65 66 20 73 |X};.X.Xt|ypedef s|
|00001e80| 74 72 75 63 74 20 7b 0a | 58 23 69 66 64 65 66 20 |truct {.|X#ifdef |
|00001e90| 49 4e 54 45 52 4e 41 4c | 0a 58 09 46 49 4c 45 20 |INTERNAL|.X.FILE |
|00001ea0| 2a 66 69 6c 65 3b 0a 58 | 09 73 74 72 75 63 74 20 |*file;.X|.struct |
|00001eb0| 73 71 6c 65 61 66 20 73 | 71 6c 65 61 66 5b 32 35 |sqleaf s|qleaf[25|
|00001ec0| 36 5d 3b 0a 58 09 69 6e | 74 20 69 73 73 71 3b 09 |6];.X.in|t issq;.|
|00001ed0| 09 2f 2a 20 6e 6f 6e 2d | 7a 65 72 6f 20 69 66 20 |./* non-|zero if |
|00001ee0| 74 68 69 73 20 66 69 6c | 65 27 73 20 73 71 75 65 |this fil|e's sque|
|00001ef0| 65 7a 65 64 20 2a 2f 0a | 58 09 69 6e 74 20 62 70 |ezed */.|X.int bp|
|00001f00| 6f 73 3b 09 09 2f 2a 20 | 6c 61 73 74 20 62 69 74 |os;../* |last bit|
|00001f10| 20 70 6f 73 69 74 69 6f | 6e 20 72 65 61 64 20 2a | positio|n read *|
|00001f20| 2f 0a 58 09 69 6e 74 20 | 63 75 72 69 6e 3b 09 09 |/.X.int |curin;..|
|00001f30| 2f 2a 20 6c 61 73 74 20 | 62 79 74 65 20 76 61 6c |/* last |byte val|
|00001f40| 75 65 20 72 65 61 64 20 | 2a 2f 0a 58 09 69 6e 74 |ue read |*/.X.int|
|00001f50| 20 72 65 70 63 74 3b 09 | 09 2f 2a 20 4e 75 6d 62 | repct;.|./* Numb|
|00001f60| 65 72 20 6f 66 20 74 69 | 6d 65 73 20 74 6f 20 72 |er of ti|mes to r|
|00001f70| 65 74 75 72 6e 20 76 61 | 6c 75 65 20 2a 2f 0a 58 |eturn va|lue */.X|
|00001f80| 09 69 6e 74 20 76 61 6c | 75 65 3b 09 09 2f 2a 20 |.int val|ue;../* |
|00001f90| 63 75 72 72 65 6e 74 20 | 62 79 74 65 20 76 61 6c |current |byte val|
|00001fa0| 75 65 20 6f 72 20 45 4f | 46 20 2a 2f 0a 58 09 6c |ue or EO|F */.X.l|
|00001fb0| 6f 6e 67 20 72 65 77 70 | 6f 73 3b 09 09 2f 2a 20 |ong rewp|os;../* |
|00001fc0| 72 65 77 69 6e 64 20 73 | 65 65 6b 20 70 6f 73 69 |rewind s|eek posi|
|00001fd0| 74 69 6f 6e 20 2a 2f 0a | 58 23 65 6e 64 69 66 0a |tion */.|X#endif.|
|00001fe0| 58 7d 20 53 51 46 49 4c | 45 3b 0a 58 0a 58 53 51 |X} SQFIL|E;.X.XSQ|
|00001ff0| 46 49 4c 45 09 2a 73 71 | 6f 70 65 6e 20 20 20 20 |FILE.*sq|open |
|00002000| 28 63 6f 6e 73 74 20 63 | 68 61 72 20 2a 70 61 74 |(const c|har *pat|
|00002010| 68 29 3b 0a 58 76 6f 69 | 64 09 20 73 71 72 65 77 |h);.Xvoi|d. sqrew|
|00002020| 69 6e 64 20 20 28 53 51 | 46 49 4c 45 20 2a 73 74 |ind (SQ|FILE *st|
|00002030| 72 65 61 6d 29 3b 0a 58 | 6c 6f 6e 67 09 20 73 71 |ream);.X|long. sq|
|00002040| 73 65 65 6b 20 20 20 20 | 28 53 51 46 49 4c 45 20 |seek |(SQFILE |
|00002050| 2a 73 74 72 65 61 6d 2c | 20 6c 6f 6e 67 20 6f 66 |*stream,| long of|
|00002060| 66 73 65 74 29 3b 0a 58 | 63 68 61 72 09 2a 73 71 |fset);.X|char.*sq|
|00002070| 67 65 74 73 20 20 20 20 | 28 63 68 61 72 20 2a 73 |gets |(char *s|
|00002080| 2c 20 69 6e 74 20 6e 2c | 20 53 51 46 49 4c 45 20 |, int n,| SQFILE |
|00002090| 2a 73 74 72 65 61 6d 29 | 3b 0a 58 6c 6f 6e 67 09 |*stream)|;.Xlong.|
|000020a0| 20 73 71 74 65 6c 6c 20 | 20 20 20 28 53 51 46 49 | sqtell | (SQFI|
|000020b0| 4c 45 20 2a 73 74 72 65 | 61 6d 29 3b 0a 58 6c 6f |LE *stre|am);.Xlo|
|000020c0| 6e 67 09 20 73 71 73 69 | 7a 65 20 20 20 20 28 53 |ng. sqsi|ze (S|
|000020d0| 51 46 49 4c 45 20 2a 73 | 74 72 65 61 6d 29 3b 0a |QFILE *s|tream);.|
|000020e0| 58 69 6e 74 09 20 73 71 | 63 6c 6f 73 65 20 20 20 |Xint. sq|close |
|000020f0| 28 53 51 46 49 4c 45 20 | 2a 73 74 72 65 61 6d 29 |(SQFILE |*stream)|
|00002100| 3b 0a 45 4e 44 5f 4f 46 | 5f 46 49 4c 45 0a 69 66 |;.END_OF|_FILE.if|
|00002110| 20 74 65 73 74 20 37 30 | 39 20 2d 6e 65 20 60 77 | test 70|9 -ne `w|
|00002120| 63 20 2d 63 20 3c 27 73 | 71 72 65 61 64 2e 68 27 |c -c <'s|qread.h'|
|00002130| 60 3b 20 74 68 65 6e 0a | 20 20 20 20 65 63 68 6f |`; then.| echo|
|00002140| 20 73 68 61 72 3a 20 5c | 22 27 73 71 72 65 61 64 | shar: \|"'sqread|
|00002150| 2e 68 27 5c 22 20 75 6e | 70 61 63 6b 65 64 20 77 |.h'\" un|packed w|
|00002160| 69 74 68 20 77 72 6f 6e | 67 20 73 69 7a 65 21 0a |ith wron|g size!.|
|00002170| 66 69 0a 23 20 65 6e 64 | 20 6f 66 20 27 73 71 72 |fi.# end| of 'sqr|
|00002180| 65 61 64 2e 68 27 0a 66 | 69 0a 69 66 20 74 65 73 |ead.h'.f|i.if tes|
|00002190| 74 20 2d 66 20 27 78 75 | 73 71 69 2e 63 27 20 2d |t -f 'xu|sqi.c' -|
|000021a0| 61 20 22 24 7b 31 7d 22 | 20 21 3d 20 22 2d 63 22 |a "${1}"| != "-c"|
|000021b0| 20 3b 20 74 68 65 6e 20 | 0a 20 20 65 63 68 6f 20 | ; then |. echo |
|000021c0| 73 68 61 72 3a 20 57 69 | 6c 6c 20 6e 6f 74 20 63 |shar: Wi|ll not c|
|000021d0| 6c 6f 62 62 65 72 20 65 | 78 69 73 74 69 6e 67 20 |lobber e|xisting |
|000021e0| 66 69 6c 65 20 5c 22 27 | 78 75 73 71 69 2e 63 27 |file \"'|xusqi.c'|
|000021f0| 5c 22 0a 65 6c 73 65 0a | 65 63 68 6f 20 73 68 61 |\".else.|echo sha|
|00002200| 72 3a 20 45 78 74 72 61 | 63 74 69 6e 67 20 5c 22 |r: Extra|cting \"|
|00002210| 27 78 75 73 71 69 2e 63 | 27 5c 22 20 5c 28 35 30 |'xusqi.c|'\" \(50|
|00002220| 39 32 20 63 68 61 72 61 | 63 74 65 72 73 5c 29 0a |92 chara|cters\).|
|00002230| 73 65 64 20 22 73 2f 5e | 58 2f 2f 22 20 3e 27 78 |sed "s/^|X//" >'x|
|00002240| 75 73 71 69 2e 63 27 20 | 3c 3c 27 45 4e 44 5f 4f |usqi.c' |<<'END_O|
|00002250| 46 5f 46 49 4c 45 27 0a | 58 73 74 61 74 69 63 20 |F_FILE'.|Xstatic |
|00002260| 63 68 61 72 20 2a 73 63 | 63 73 69 64 20 3d 20 22 |char *sc|csid = "|
|00002270| 40 28 23 29 75 73 71 2e | 63 20 20 20 20 20 20 20 |@(#)usq.|c |
|00002280| 20 31 2e 37 75 20 28 55 | 43 46 29 20 38 32 2f 31 | 1.7u (U|CF) 82/1|
|00002290| 32 2f 31 35 22 3b 0a 58 | 2f 2a 0a 58 20 2a 20 09 |2/15";.X|/*.X * .|
|000022a0| 75 73 71 2e 63 20 2d 20 | 43 50 2f 4d 20 63 6f 6d |usq.c - |CP/M com|
|000022b0| 70 61 74 69 62 6c 65 20 | 66 69 6c 65 20 75 6e 73 |patible |file uns|
|000022c0| 71 75 65 65 7a 65 72 20 | 75 74 69 6c 69 74 79 0a |queezer |utility.|
|000022d0| 58 20 2a 0a 58 20 2a 09 | 63 6f 6d 70 69 6c 65 20 |X *.X *.|compile |
|000022e0| 61 73 20 66 6f 6c 6c 6f | 77 73 3a 0a 58 20 2a 09 |as follo|ws:.X *.|
|000022f0| 63 63 20 5b 2d 44 56 41 | 58 5d 20 2d 4f 20 75 73 |cc [-DVA|X] -O us|
|00002300| 71 2e 63 20 2d 6f 20 75 | 73 71 0a 58 20 2a 09 20 |q.c -o u|sq.X *. |
|00002310| 20 20 28 64 65 66 69 6e | 65 20 56 41 58 20 6f 6e | (defin|e VAX on|
|00002320| 6c 79 20 69 66 20 72 75 | 6e 6e 69 6e 67 20 6f 6e |ly if ru|nning on|
|00002330| 20 56 41 58 29 0a 58 20 | 2a 2f 0a 58 0a 58 23 69 | VAX).X |*/.X.X#i|
|00002340| 6e 63 6c 75 64 65 20 3c | 73 74 64 69 6f 2e 68 3e |nclude <|stdio.h>|
|00002350| 0a 58 23 69 6e 63 6c 75 | 64 65 20 3c 73 74 64 6c |.X#inclu|de <stdl|
|00002360| 69 62 2e 68 3e 0a 58 23 | 69 6e 63 6c 75 64 65 20 |ib.h>.X#|include |
|00002370| 3c 6c 69 6d 69 74 73 2e | 68 3e 0a 58 23 69 6e 63 |<limits.|h>.X#inc|
|00002380| 6c 75 64 65 20 3c 73 69 | 67 6e 61 6c 2e 68 3e 0a |lude <si|gnal.h>.|
|00002390| 58 23 69 6e 63 6c 75 64 | 65 20 3c 63 74 79 70 65 |X#includ|e <ctype|
|000023a0| 2e 68 3e 0a 58 0a 58 23 | 64 65 66 69 6e 65 20 45 |.h>.X.X#|define E|
|000023b0| 52 52 4f 52 20 28 2d 31 | 29 0a 58 23 64 65 66 69 |RROR (-1|).X#defi|
|000023c0| 6e 65 20 50 41 54 48 4c | 45 4e 09 33 31 32 09 2f |ne PATHL|EN.312./|
|000023d0| 2a 20 4e 75 6d 62 65 72 | 20 6f 66 20 63 68 61 72 |* Number| of char|
|000023e0| 61 63 74 65 72 73 20 61 | 6c 6c 6f 77 65 64 20 69 |acters a|llowed i|
|000023f0| 6e 20 70 61 74 68 6e 61 | 6d 65 20 2a 2f 0a 58 23 |n pathna|me */.X#|
|00002400| 64 65 66 69 6e 65 20 4f | 4b 20 30 0a 58 0a 58 23 |define O|K 0.X.X#|
|00002410| 64 65 66 69 6e 65 20 52 | 45 43 4f 47 4e 49 5a 45 |define R|ECOGNIZE|
|00002420| 20 30 78 46 46 37 36 09 | 2f 2a 20 75 6e 6c 69 6b | 0xFF76.|/* unlik|
|00002430| 65 6c 79 20 70 61 74 74 | 65 72 6e 20 2a 2f 0a 58 |ely patt|ern */.X|
|00002440| 23 64 65 66 69 6e 65 20 | 44 4c 45 20 30 78 39 30 |#define |DLE 0x90|
|00002450| 09 09 2f 2a 20 72 65 70 | 65 61 74 20 62 79 74 65 |../* rep|eat byte|
|00002460| 20 66 6c 61 67 20 2a 2f | 0a 58 23 64 65 66 69 6e | flag */|.X#defin|
|00002470| 65 20 53 50 45 4f 46 20 | 32 35 36 09 09 2f 2a 20 |e SPEOF |256../* |
|00002480| 73 70 65 63 69 61 6c 20 | 65 6e 64 66 69 6c 65 20 |special |endfile |
|00002490| 74 6f 6b 65 6e 20 2a 2f | 0a 58 23 64 65 66 69 6e |token */|.X#defin|
|000024a0| 65 20 4e 55 4d 56 41 4c | 53 20 32 35 37 09 09 2f |e NUMVAL|S 257../|
|000024b0| 2a 20 32 35 36 20 64 61 | 74 61 20 76 61 6c 75 65 |* 256 da|ta value|
|000024c0| 73 20 70 6c 75 73 20 53 | 50 45 4f 46 2a 2f 0a 58 |s plus S|PEOF*/.X|
|000024d0| 0a 58 2f 2a 20 31 36 20 | 62 69 74 20 69 6e 74 73 |.X/* 16 |bit ints|
|000024e0| 2c 20 70 6c 65 61 73 65 | 20 2a 2f 0a 58 74 79 70 |, please| */.Xtyp|
|000024f0| 65 64 65 66 20 69 6e 74 | 20 49 4e 54 31 36 3b 0a |edef int| INT16;.|
|00002500| 58 74 79 70 65 64 65 66 | 20 75 6e 73 69 67 6e 65 |Xtypedef| unsigne|
|00002510| 64 20 55 4e 53 49 47 4e | 45 44 3b 0a 58 74 79 70 |d UNSIGN|ED;.Xtyp|
|00002520| 65 64 65 66 20 6c 6f 6e | 67 20 4c 4f 4e 47 33 32 |edef lon|g LONG32|
|00002530| 3b 0a 58 0a 58 73 74 72 | 75 63 74 20 73 71 6c 65 |;.X.Xstr|uct sqle|
|00002540| 61 66 20 7b 09 09 2f 2a | 20 44 65 63 6f 64 69 6e |af {../*| Decodin|
|00002550| 67 20 74 72 65 65 20 2a | 2f 0a 58 09 49 4e 54 31 |g tree *|/.X.INT1|
|00002560| 36 20 63 68 69 6c 64 72 | 65 6e 5b 32 5d 3b 09 2f |6 childr|en[2];./|
|00002570| 2a 20 6c 65 66 74 2c 20 | 72 69 67 68 74 20 2a 2f |* left, |right */|
|00002580| 0a 58 7d 3b 0a 58 73 74 | 72 75 63 74 20 73 71 6c |.X};.Xst|ruct sql|
|00002590| 65 61 66 20 44 6e 6f 64 | 65 5b 4e 55 4d 56 41 4c |eaf Dnod|e[NUMVAL|
|000025a0| 53 20 2d 20 31 5d 3b 0a | 58 0a 58 49 4e 54 31 36 |S - 1];.|X.XINT16|
|000025b0| 20 42 70 6f 73 3b 09 09 | 2f 2a 20 6c 61 73 74 20 | Bpos;..|/* last |
|000025c0| 62 69 74 20 70 6f 73 69 | 74 69 6f 6e 20 72 65 61 |bit posi|tion rea|
|000025d0| 64 20 2a 2f 0a 58 49 4e | 54 31 36 20 43 75 72 69 |d */.XIN|T16 Curi|
|000025e0| 6e 3b 09 09 2f 2a 20 6c | 61 73 74 20 62 79 74 65 |n;../* l|ast byte|
|000025f0| 20 76 61 6c 75 65 20 72 | 65 61 64 20 2a 2f 0a 58 | value r|ead */.X|
|00002600| 49 4e 54 31 36 20 52 65 | 70 63 74 3b 09 09 2f 2a |INT16 Re|pct;../*|
|00002610| 20 4e 75 6d 62 65 72 20 | 6f 66 20 74 69 6d 65 73 | Number |of times|
|00002620| 20 74 6f 20 72 65 74 75 | 72 6e 20 76 61 6c 75 65 | to retu|rn value|
|00002630| 20 2a 2f 0a 58 49 4e 54 | 31 36 20 56 61 6c 75 65 | */.XINT|16 Value|
|00002640| 3b 09 09 2f 2a 20 63 75 | 72 72 65 6e 74 20 62 79 |;../* cu|rrent by|
|00002650| 74 65 20 76 61 6c 75 65 | 20 6f 72 20 45 4f 46 20 |te value| or EOF |
|00002660| 2a 2f 0a 58 0a 58 49 4e | 54 31 36 20 67 65 74 63 |*/.X.XIN|T16 getc|
|00002670| 72 28 76 6f 69 64 29 3b | 0a 58 49 4e 54 31 36 20 |r(void);|.XINT16 |
|00002680| 67 65 74 75 68 75 66 66 | 28 76 6f 69 64 29 3b 0a |getuhuff|(void);.|
|00002690| 58 49 4e 54 31 36 20 70 | 6f 72 74 67 65 74 77 28 |XINT16 p|ortgetw(|
|000026a0| 46 49 4c 45 20 2a 66 29 | 3b 0a 58 4c 4f 4e 47 33 |FILE *f)|;.XLONG3|
|000026b0| 32 20 72 65 6d 61 70 28 | 4c 4f 4e 47 33 32 29 3b |2 remap(|LONG32);|
|000026c0| 0a 58 0a 58 6d 61 69 6e | 28 69 6e 74 20 61 72 67 |.X.Xmain|(int arg|
|000026d0| 63 2c 20 63 68 61 72 20 | 2a 61 72 67 76 5b 5d 29 |c, char |*argv[])|
|000026e0| 0a 58 7b 0a 58 09 73 71 | 75 65 65 7a 65 28 61 72 |.X{.X.sq|ueeze(ar|
|000026f0| 67 76 5b 31 5d 29 3b 0a | 58 7d 0a 58 0a 58 2f 2a |gv[1]);.|X}.X.X/*|
|00002700| 0a 58 09 54 68 65 20 66 | 6f 6c 6c 6f 77 69 6e 67 |.X.The f|ollowing|
|00002710| 20 63 6f 64 65 20 69 73 | 20 70 72 69 6d 61 72 69 | code is| primari|
|00002720| 6c 79 20 66 72 6f 6d 20 | 74 79 70 65 73 71 2e 63 |ly from |typesq.c|
|00002730| 20 61 6e 64 20 75 74 72 | 2e 63 2e 20 20 54 79 70 | and utr|.c. Typ|
|00002740| 65 73 71 0a 58 69 73 20 | 61 20 6d 6f 64 69 66 69 |esq.Xis |a modifi|
|00002750| 63 61 74 69 6f 6e 20 6f | 66 20 55 53 51 20 62 79 |cation o|f USQ by|
|00002760| 20 44 69 63 6b 20 47 72 | 65 65 6e 6c 61 77 2e 20 | Dick Gr|eenlaw. |
|00002770| 20 54 68 6f 73 65 20 6d | 6f 64 69 66 69 63 61 74 | Those m|odificat|
|00002780| 69 6f 6e 73 20 28 75 73 | 71 0a 58 74 6f 20 74 79 |ions (us|q.Xto ty|
|00002790| 70 65 73 71 29 20 77 65 | 72 65 20 6d 61 64 65 20 |pesq) we|re made |
|000027a0| 62 79 20 42 6f 62 20 4d | 61 74 68 69 61 73 2c 20 |by Bob M|athias, |
|000027b0| 49 20 61 6d 20 72 65 73 | 70 6f 6e 73 69 62 6c 65 |I am res|ponsible|
|000027c0| 20 66 6f 72 20 74 68 65 | 20 62 75 74 63 68 65 72 | for the| butcher|
|000027d0| 79 0a 58 64 6f 6e 65 20 | 74 6f 20 6d 61 6b 65 20 |y.Xdone |to make |
|000027e0| 69 74 20 77 6f 72 6b 20 | 77 69 74 68 20 63 61 74 |it work |with cat|
|000027f0| 2e 0a 58 0a 58 2a 2f 0a | 58 0a 58 46 49 4c 45 20 |..X.X*/.|X.XFILE |
|00002800| 2a 69 6e 3b 0a 58 73 71 | 75 65 65 7a 65 28 66 6e |*in;.Xsq|ueeze(fn|
|00002810| 61 6d 65 29 0a 58 63 68 | 61 72 20 2a 66 6e 61 6d |ame).Xch|ar *fnam|
|00002820| 65 3b 0a 58 7b 0a 58 09 | 72 65 67 69 73 74 65 72 |e;.X{.X.|register|
|00002830| 20 49 4e 54 31 36 20 69 | 2c 20 63 3b 0a 58 09 72 | INT16 i|, c;.X.r|
|00002840| 65 67 69 73 74 65 72 20 | 63 68 61 72 20 2a 70 3b |egister |char *p;|
|00002850| 0a 58 09 72 65 67 69 73 | 74 65 72 20 49 4e 54 31 |.X.regis|ter INT1|
|00002860| 36 20 6e 75 6d 6e 6f 64 | 65 73 3b 09 09 09 2f 2a |6 numnod|es;.../*|
|00002870| 20 73 69 7a 65 20 6f 66 | 20 64 65 63 6f 64 69 6e | size of| decodin|
|00002880| 67 20 74 72 65 65 20 2a | 2f 0a 58 09 72 65 67 69 |g tree *|/.X.regi|
|00002890| 73 74 65 72 20 55 4e 53 | 49 47 4e 45 44 20 63 72 |ster UNS|IGNED cr|
|000028a0| 63 3b 0a 58 09 55 4e 53 | 49 47 4e 45 44 20 66 69 |c;.X.UNS|IGNED fi|
|000028b0| 6c 65 63 72 63 3b 0a 58 | 09 63 68 61 72 20 69 6e |lecrc;.X|.char in|
|000028c0| 6c 5b 42 55 46 53 49 5a | 5d 3b 0a 58 09 49 4e 54 |l[BUFSIZ|];.X.INT|
|000028d0| 31 36 20 69 6e 6c 63 6e | 74 3b 0a 58 0a 58 09 69 |16 inlcn|t;.X.X.i|
|000028e0| 6e 69 74 5f 63 72 28 29 | 3b 20 69 6e 69 74 5f 68 |nit_cr()|; init_h|
|000028f0| 75 66 66 28 29 3b 20 63 | 72 63 3d 30 3b 0a 58 0a |uff(); c|rc=0;.X.|
|00002900| 58 09 69 66 28 28 69 6e | 3d 66 6f 70 65 6e 28 20 |X.if((in|=fopen( |
|00002910| 66 6e 61 6d 65 2c 20 22 | 72 62 22 29 29 3d 3d 4e |fname, "|rb"))==N|
|00002920| 55 4c 4c 29 20 7b 0a 58 | 09 09 66 70 72 69 6e 74 |ULL) {.X|..fprint|
|00002930| 66 28 73 74 64 65 72 72 | 2c 20 22 75 73 71 3a 20 |f(stderr|, "usq: |
|00002940| 63 61 6e 27 74 20 6f 70 | 65 6e 20 25 73 5c 6e 22 |can't op|en %s\n"|
|00002950| 2c 20 66 6e 61 6d 65 29 | 3b 0a 58 09 09 72 65 74 |, fname)|;.X..ret|
|00002960| 75 72 6e 20 45 52 52 4f | 52 3b 0a 58 09 7d 0a 58 |urn ERRO|R;.X.}.X|
|00002970| 09 69 66 28 70 6f 72 74 | 67 65 74 77 28 69 6e 29 |.if(port|getw(in)|
|00002980| 20 21 3d 20 28 49 4e 54 | 31 36 29 20 52 45 43 4f | != (INT|16) RECO|
|00002990| 47 4e 49 5a 45 29 20 7b | 2f 2a 20 50 72 6f 63 65 |GNIZE) {|/* Proce|
|000029a0| 73 73 20 68 65 61 64 65 | 72 20 2a 2f 0a 58 09 09 |ss heade|r */.X..|
|000029b0| 66 70 72 69 6e 74 66 28 | 73 74 64 65 72 72 2c 20 |fprintf(|stderr, |
|000029c0| 22 75 73 71 3a 20 25 73 | 20 69 73 20 6e 6f 74 20 |"usq: %s| is not |
|000029d0| 61 20 53 51 75 65 65 7a | 65 64 20 66 69 6c 65 5c |a SQueez|ed file\|
|000029e0| 6e 22 2c 20 66 6e 61 6d | 65 29 3b 0a 58 09 09 72 |n", fnam|e);.X..r|
|000029f0| 65 74 75 72 6e 28 45 52 | 52 4f 52 29 3b 0a 58 09 |eturn(ER|ROR);.X.|
|00002a00| 7d 0a 58 09 66 69 6c 65 | 63 72 63 20 3d 20 28 55 |}.X.file|crc = (U|
|00002a10| 4e 53 49 47 4e 45 44 29 | 20 70 6f 72 74 67 65 74 |NSIGNED)| portget|
|00002a20| 77 28 69 6e 29 3b 09 2f | 2a 20 63 68 65 63 6b 73 |w(in);./|* checks|
|00002a30| 75 6d 20 2a 2f 0a 58 09 | 77 68 69 6c 65 20 28 67 |um */.X.|while (g|
|00002a40| 65 74 63 28 69 6e 29 29 | 09 09 2f 2a 20 52 65 61 |etc(in))|../* Rea|
|00002a50| 64 20 61 6e 64 20 64 69 | 73 63 61 72 64 20 74 68 |d and di|scard th|
|00002a60| 65 20 6e 61 6d 65 20 2a | 2f 0a 58 09 09 3b 0a 58 |e name *|/.X..;.X|
|00002a70| 0a 58 09 6e 75 6d 6e 6f | 64 65 73 20 3d 20 70 6f |.X.numno|des = po|
|00002a80| 72 74 67 65 74 77 28 69 | 6e 29 3b 0a 58 09 69 66 |rtgetw(i|n);.X.if|
|00002a90| 28 6e 75 6d 6e 6f 64 65 | 73 20 3c 20 30 20 7c 7c |(numnode|s < 0 |||
|00002aa0| 20 6e 75 6d 6e 6f 64 65 | 73 20 3e 3d 20 4e 55 4d | numnode|s >= NUM|
|00002ab0| 56 41 4c 53 29 20 7b 0a | 58 09 09 66 70 72 69 6e |VALS) {.|X..fprin|
|00002ac0| 74 66 28 73 74 64 65 72 | 72 2c 20 22 75 73 71 3a |tf(stder|r, "usq:|
|00002ad0| 20 25 73 20 68 61 73 20 | 69 6e 76 61 6c 69 64 20 | %s has |invalid |
|00002ae0| 64 65 63 6f 64 65 20 74 | 72 65 65 5c 6e 22 2c 20 |decode t|ree\n", |
|00002af0| 66 6e 61 6d 65 29 3b 0a | 58 09 09 66 63 6c 6f 73 |fname);.|X..fclos|
|00002b00| 65 28 69 6e 29 3b 0a 58 | 09 09 72 65 74 75 72 6e |e(in);.X|..return|
|00002b10| 28 45 52 52 4f 52 29 3b | 0a 58 09 7d 0a 58 09 2f |(ERROR);|.X.}.X./|
|00002b20| 2a 20 49 6e 69 74 69 61 | 6c 69 7a 65 20 66 6f 72 |* Initia|lize for|
|00002b30| 20 70 6f 73 73 69 62 6c | 65 20 65 6d 70 74 79 20 | possibl|e empty |
|00002b40| 74 72 65 65 20 28 53 50 | 45 4f 46 20 6f 6e 6c 79 |tree (SP|EOF only|
|00002b50| 29 20 2a 2f 0a 58 09 44 | 6e 6f 64 65 5b 30 5d 2e |) */.X.D|node[0].|
|00002b60| 63 68 69 6c 64 72 65 6e | 5b 30 5d 20 3d 20 2d 28 |children|[0] = -(|
|00002b70| 53 50 45 4f 46 20 2b 20 | 31 29 3b 0a 58 09 44 6e |SPEOF + |1);.X.Dn|
|00002b80| 6f 64 65 5b 30 5d 2e 63 | 68 69 6c 64 72 65 6e 5b |ode[0].c|hildren[|
|00002b90| 31 5d 20 3d 20 2d 28 53 | 50 45 4f 46 20 2b 20 31 |1] = -(S|PEOF + 1|
|00002ba0| 29 3b 0a 58 0a 58 09 66 | 6f 72 28 69 20 3d 20 30 |);.X.X.f|or(i = 0|
|00002bb0| 3b 20 69 20 3c 20 6e 75 | 6d 6e 6f 64 65 73 3b 20 |; i < nu|mnodes; |
|00002bc0| 2b 2b 69 29 20 7b 09 2f | 2a 20 47 65 74 20 64 65 |++i) {./|* Get de|
|00002bd0| 63 6f 64 69 6e 67 20 74 | 72 65 65 20 66 72 6f 6d |coding t|ree from|
|00002be0| 20 66 69 6c 65 20 2a 2f | 0a 58 09 09 44 6e 6f 64 | file */|.X..Dnod|
|00002bf0| 65 5b 69 5d 2e 63 68 69 | 6c 64 72 65 6e 5b 30 5d |e[i].chi|ldren[0]|
|00002c00| 20 3d 20 70 6f 72 74 67 | 65 74 77 28 69 6e 29 3b | = portg|etw(in);|
|00002c10| 0a 58 09 09 44 6e 6f 64 | 65 5b 69 5d 2e 63 68 69 |.X..Dnod|e[i].chi|
|00002c20| 6c 64 72 65 6e 5b 31 5d | 20 3d 20 70 6f 72 74 67 |ldren[1]| = portg|
|00002c30| 65 74 77 28 69 6e 29 3b | 0a 58 09 7d 0a 58 09 69 |etw(in);|.X.}.X.i|
|00002c40| 6e 6c 63 6e 74 20 3d 20 | 30 3b 0a 58 09 77 68 69 |nlcnt = |0;.X.whi|
|00002c50| 6c 65 20 28 66 67 65 74 | 73 28 69 6e 6c 2c 20 73 |le (fget|s(inl, s|
|00002c60| 69 7a 65 6f 66 28 69 6e | 6c 29 2c 20 73 74 64 69 |izeof(in|l), stdi|
|00002c70| 6e 29 29 7b 0a 58 09 09 | 69 66 20 28 2b 2b 69 6e |n)){.X..|if (++in|
|00002c80| 6c 63 6e 74 20 3d 3d 20 | 37 29 20 7b 0a 58 09 09 |lcnt == |7) {.X..|
|00002c90| 09 73 70 72 69 6e 74 66 | 28 69 6e 6c 2c 20 22 25 |.sprintf|(inl, "%|
|00002ca0| 6c 64 5c 6e 22 2c 20 72 | 65 6d 61 70 28 61 74 6f |ld\n", r|emap(ato|
|00002cb0| 6c 28 69 6e 6c 29 29 29 | 3b 0a 58 09 09 09 69 6e |l(inl)))|;.X...in|
|00002cc0| 6c 63 6e 74 20 3d 20 30 | 3b 0a 58 09 09 7d 0a 58 |lcnt = 0|;.X..}.X|
|00002cd0| 09 09 66 70 75 74 73 28 | 69 6e 6c 2c 20 73 74 64 |..fputs(|inl, std|
|00002ce0| 6f 75 74 29 3b 0a 58 09 | 7d 0a 58 09 66 63 6c 6f |out);.X.|}.X.fclo|
|00002cf0| 73 65 28 69 6e 29 3b 0a | 58 09 72 65 74 75 72 6e |se(in);.|X.return|
|00002d00| 28 4f 4b 29 3b 0a 58 7d | 0a 58 0a 58 2f 2a 20 4d |(OK);.X}|.X.X/* M|
|00002d10| 61 70 20 74 68 65 20 6f | 72 69 67 69 6e 61 6c 20 |ap the o|riginal |
|00002d20| 73 6f 75 72 63 65 20 70 | 6f 73 69 74 69 6f 6e 20 |source p|osition |
|00002d30| 69 6e 74 6f 20 74 68 65 | 20 63 6f 6d 70 72 65 73 |into the| compres|
|00002d40| 73 65 64 20 62 69 74 20 | 70 6f 73 69 74 69 6f 6e |sed bit |position|
|00002d50| 2e 0a 58 20 2a 0a 58 20 | 2a 2f 0a 58 4c 4f 4e 47 |..X *.X |*/.XLONG|
|00002d60| 33 32 0a 58 72 65 6d 61 | 70 28 4c 4f 4e 47 33 32 |32.Xrema|p(LONG32|
|00002d70| 20 70 6f 73 29 0a 58 7b | 0a 58 09 73 74 61 74 69 | pos).X{|.X.stati|
|00002d80| 63 20 4c 4f 4e 47 33 32 | 20 69 6e 70 6f 73 20 3d |c LONG32| inpos =|
|00002d90| 20 30 4c 3b 0a 58 09 69 | 6e 74 20 63 3b 0a 58 0a | 0L;.X.i|nt c;.X.|
|00002da0| 58 09 77 68 69 6c 65 20 | 28 70 6f 73 20 21 3d 20 |X.while |(pos != |
|00002db0| 69 6e 70 6f 73 29 20 7b | 0a 58 09 09 69 66 20 28 |inpos) {|.X..if (|
|00002dc0| 28 63 20 3d 20 67 65 74 | 63 72 28 29 29 20 3d 3d |(c = get|cr()) ==|
|00002dd0| 20 45 4f 46 29 0a 58 09 | 09 09 61 62 6f 72 74 28 | EOF).X.|..abort(|
|00002de0| 29 3b 0a 58 23 69 66 64 | 65 66 20 6e 6f 74 64 65 |);.X#ifd|ef notde|
|00002df0| 66 0a 58 09 09 70 75 74 | 63 68 61 72 28 63 29 3b |f.X..put|char(c);|
|00002e00| 0a 58 23 65 6e 64 69 66 | 0a 58 09 09 69 6e 70 6f |.X#endif|.X..inpo|
|00002e10| 73 2b 2b 3b 0a 58 09 7d | 0a 58 09 66 70 72 69 6e |s++;.X.}|.X.fprin|
|00002e20| 74 66 28 73 74 64 65 72 | 72 2c 20 22 66 74 65 6c |tf(stder|r, "ftel|
|00002e30| 6c 28 29 20 3d 20 25 6c | 64 2c 20 42 70 6f 73 20 |l() = %l|d, Bpos |
|00002e40| 3d 20 25 64 5c 6e 22 2c | 20 66 74 65 6c 6c 28 69 |= %d\n",| ftell(i|
|00002e50| 6e 29 2c 20 42 70 6f 73 | 29 3b 0a 58 09 69 66 20 |n), Bpos|);.X.if |
|00002e60| 28 42 70 6f 73 20 3d 3d | 20 39 39 29 0a 58 09 09 |(Bpos ==| 99).X..|
|00002e70| 72 65 74 75 72 6e 20 28 | 66 74 65 6c 6c 28 69 6e |return (|ftell(in|
|00002e80| 29 20 3c 3c 20 33 29 20 | 2b 20 28 28 42 70 6f 73 |) << 3) |+ ((Bpos|
|00002e90| 20 3d 3d 20 39 39 29 3f | 30 3a 28 42 70 6f 73 2b | == 99)?|0:(Bpos+|
|00002ea0| 31 29 29 3b 0a 58 09 72 | 65 74 75 72 6e 20 28 28 |1));.X.r|eturn ((|
|00002eb0| 66 74 65 6c 6c 28 69 6e | 29 2d 31 29 20 3c 3c 20 |ftell(in|)-1) << |
|00002ec0| 33 29 20 2b 20 42 70 6f | 73 2b 31 3b 0a 58 7d 0a |3) + Bpo|s+1;.X}.|
|00002ed0| 58 0a 58 0a 58 2f 2a 2a | 2a 20 66 72 6f 6d 20 75 |X.X.X/**|* from u|
|00002ee0| 74 72 2e 63 20 2d 20 2a | 2f 0a 58 2f 2a 20 69 6e |tr.c - *|/.X/* in|
|00002ef0| 69 74 69 61 6c 69 7a 65 | 20 64 65 63 6f 64 69 6e |itialize| decodin|
|00002f00| 67 20 66 75 6e 63 74 69 | 6f 6e 73 20 2a 2f 0a 58 |g functi|ons */.X|
|00002f10| 0a 58 69 6e 69 74 5f 63 | 72 28 29 0a 58 7b 0a 58 |.Xinit_c|r().X{.X|
|00002f20| 09 52 65 70 63 74 20 3d | 20 30 3b 0a 58 7d 0a 58 |.Repct =| 0;.X}.X|
|00002f30| 0a 58 69 6e 69 74 5f 68 | 75 66 66 28 29 0a 58 7b |.Xinit_h|uff().X{|
|00002f40| 0a 58 09 42 70 6f 73 20 | 3d 20 39 39 3b 09 2f 2a |.X.Bpos |= 99;./*|
|00002f50| 20 66 6f 72 63 65 20 69 | 6e 69 74 69 61 6c 20 72 | force i|nitial r|
|00002f60| 65 61 64 20 2a 2f 0a 58 | 7d 0a 58 0a 58 2f 2a 20 |ead */.X|}.X.X/* |
|00002f70| 47 65 74 20 62 79 74 65 | 73 20 77 69 74 68 20 64 |Get byte|s with d|
|00002f80| 65 63 6f 64 69 6e 67 20 | 2d 20 74 68 69 73 20 64 |ecoding |- this d|
|00002f90| 65 63 6f 64 65 73 20 72 | 65 70 65 74 69 74 69 6f |ecodes r|epetitio|
|00002fa0| 6e 2c 0a 58 20 2a 20 63 | 61 6c 6c 73 20 67 65 74 |n,.X * c|alls get|
|00002fb0| 75 68 75 66 66 20 74 6f | 20 64 65 63 6f 64 65 20 |uhuff to| decode |
|00002fc0| 66 69 6c 65 20 73 74 72 | 65 61 6d 20 69 6e 74 6f |file str|eam into|
|00002fd0| 20 62 79 74 65 0a 58 20 | 2a 20 6c 65 76 65 6c 20 | byte.X |* level |
|00002fe0| 63 6f 64 65 20 77 69 74 | 68 20 6f 6e 6c 79 20 72 |code wit|h only r|
|00002ff0| 65 70 65 74 69 74 69 6f | 6e 20 65 6e 63 6f 64 69 |epetitio|n encodi|
|00003000| 6e 67 2e 0a 58 20 2a 0a | 58 20 2a 20 54 68 65 20 |ng..X *.|X * The |
|00003010| 63 6f 64 65 20 69 73 20 | 73 69 6d 70 6c 65 20 70 |code is |simple p|
|00003020| 61 73 73 69 6e 67 20 74 | 68 72 6f 75 67 68 20 6f |assing t|hrough o|
|00003030| 66 20 62 79 74 65 73 20 | 65 78 63 65 70 74 0a 58 |f bytes |except.X|
|00003040| 20 2a 20 74 68 61 74 20 | 44 4c 45 20 69 73 20 65 | * that |DLE is e|
|00003050| 6e 63 6f 64 65 64 20 61 | 73 20 44 4c 45 2d 7a 65 |ncoded a|s DLE-ze|
|00003060| 72 6f 20 61 6e 64 20 6f | 74 68 65 72 20 76 61 6c |ro and o|ther val|
|00003070| 75 65 73 0a 58 20 2a 20 | 72 65 70 65 61 74 65 64 |ues.X * |repeated|
|00003080| 20 6d 6f 72 65 20 74 68 | 61 6e 20 74 77 69 63 65 | more th|an twice|
|00003090| 20 61 72 65 20 65 6e 63 | 6f 64 65 64 20 61 73 20 | are enc|oded as |
|000030a0| 76 61 6c 75 65 2d 44 4c | 45 2d 63 6f 75 6e 74 2e |value-DL|E-count.|
|000030b0| 0a 58 20 2a 2f 0a 58 0a | 58 49 4e 54 31 36 0a 58 |.X */.X.|XINT16.X|
|000030c0| 67 65 74 63 72 28 29 0a | 58 7b 0a 58 09 72 65 67 |getcr().|X{.X.reg|
|000030d0| 69 73 74 65 72 20 49 4e | 54 31 36 20 63 3b 0a 58 |ister IN|T16 c;.X|
|000030e0| 0a 58 09 69 66 28 52 65 | 70 63 74 20 3e 20 30 29 |.X.if(Re|pct > 0)|
|000030f0| 20 7b 0a 58 09 09 2f 2a | 20 45 78 70 61 6e 64 69 | {.X../*| Expandi|
|00003100| 6e 67 20 61 20 72 65 70 | 65 61 74 65 64 20 63 68 |ng a rep|eated ch|
|00003110| 61 72 20 2a 2f 0a 58 09 | 09 2d 2d 52 65 70 63 74 |ar */.X.|.--Repct|
|00003120| 3b 0a 58 09 09 72 65 74 | 75 72 6e 28 56 61 6c 75 |;.X..ret|urn(Valu|
|00003130| 65 29 3b 0a 58 09 7d 20 | 65 6c 73 65 20 7b 0a 58 |e);.X.} |else {.X|
|00003140| 09 09 2f 2a 20 4e 6f 74 | 68 69 6e 67 20 75 6e 75 |../* Not|hing unu|
|00003150| 73 75 61 6c 20 2a 2f 0a | 58 09 09 69 66 28 28 63 |sual */.|X..if((c|
|00003160| 20 3d 20 67 65 74 75 68 | 75 66 66 28 29 29 20 21 | = getuh|uff()) !|
|00003170| 3d 20 44 4c 45 29 20 7b | 0a 58 09 09 09 2f 2a 20 |= DLE) {|.X.../* |
|00003180| 49 74 27 73 20 6e 6f 74 | 20 74 68 65 20 73 70 65 |It's not| the spe|
|00003190| 63 69 61 6c 20 64 65 6c | 69 6d 69 74 65 72 20 2a |cial del|imiter *|
|000031a0| 2f 0a 58 09 09 09 56 61 | 6c 75 65 20 3d 20 63 3b |/.X...Va|lue = c;|
|000031b0| 0a 58 09 09 09 69 66 28 | 56 61 6c 75 65 20 3d 3d |.X...if(|Value ==|
|000031c0| 20 45 4f 46 29 0a 58 09 | 09 09 09 52 65 70 63 74 | EOF).X.|...Repct|
|000031d0| 20 3d 20 49 4e 54 5f 4d | 41 58 3b 0a 58 09 09 09 | = INT_M|AX;.X...|
|000031e0| 72 65 74 75 72 6e 28 56 | 61 6c 75 65 29 3b 0a 58 |return(V|alue);.X|
|000031f0| 09 09 7d 20 65 6c 73 65 | 20 7b 0a 58 09 09 09 2f |..} else| {.X.../|
|00003200| 2a 20 53 70 65 63 69 61 | 6c 20 74 6f 6b 65 6e 20 |* Specia|l token |
|00003210| 2a 2f 0a 58 09 09 09 69 | 66 28 28 52 65 70 63 74 |*/.X...i|f((Repct|
|00003220| 20 3d 20 67 65 74 75 68 | 75 66 66 28 29 29 20 3d | = getuh|uff()) =|
|00003230| 3d 20 30 29 0a 58 09 09 | 09 09 2f 2a 20 44 4c 45 |= 0).X..|../* DLE|
|00003240| 2c 20 7a 65 72 6f 20 72 | 65 70 72 65 73 65 6e 74 |, zero r|epresent|
|00003250| 73 20 44 4c 45 20 2a 2f | 0a 58 09 09 09 09 72 65 |s DLE */|.X....re|
|00003260| 74 75 72 6e 28 44 4c 45 | 29 3b 0a 58 09 09 09 65 |turn(DLE|);.X...e|
|00003270| 6c 73 65 20 7b 0a 58 09 | 09 09 09 2f 2a 20 42 65 |lse {.X.|.../* Be|
|00003280| 67 69 6e 20 65 78 70 61 | 6e 64 69 6e 67 20 72 65 |gin expa|nding re|
|00003290| 70 65 74 69 74 69 6f 6e | 20 2a 2f 0a 58 09 09 09 |petition| */.X...|
|000032a0| 09 52 65 70 63 74 20 2d | 3d 20 32 3b 09 2f 2a 20 |.Repct -|= 2;./* |
|000032b0| 32 6e 64 20 74 69 6d 65 | 20 2a 2f 0a 58 09 09 09 |2nd time| */.X...|
|000032c0| 09 72 65 74 75 72 6e 28 | 56 61 6c 75 65 29 3b 0a |.return(|Value);.|
|000032d0| 58 09 09 09 7d 0a 58 09 | 09 7d 0a 58 09 7d 0a 58 |X...}.X.|.}.X.}.X|
|000032e0| 7d 0a 58 2f 2a 20 44 65 | 63 6f 64 65 20 66 69 6c |}.X/* De|code fil|
|000032f0| 65 20 73 74 72 65 61 6d | 20 69 6e 74 6f 20 61 20 |e stream| into a |
|00003300| 62 79 74 65 20 6c 65 76 | 65 6c 20 63 6f 64 65 20 |byte lev|el code |
|00003310| 77 69 74 68 20 6f 6e 6c | 79 0a 58 20 2a 20 72 65 |with onl|y.X * re|
|00003320| 70 65 74 69 74 69 6f 6e | 20 65 6e 63 6f 64 69 6e |petition| encodin|
|00003330| 67 20 72 65 6d 61 69 6e | 69 6e 67 2e 0a 58 20 2a |g remain|ing..X *|
|00003340| 2f 0a 58 0a 58 49 4e 54 | 31 36 0a 58 67 65 74 75 |/.X.XINT|16.Xgetu|
|00003350| 68 75 66 66 28 29 0a 58 | 7b 0a 58 09 72 65 67 69 |huff().X|{.X.regi|
|00003360| 73 74 65 72 20 49 4e 54 | 31 36 20 69 3b 0a 58 0a |ster INT|16 i;.X.|
|00003370| 58 09 2f 2a 20 46 6f 6c | 6c 6f 77 20 62 69 74 20 |X./* Fol|low bit |
|00003380| 73 74 72 65 61 6d 20 69 | 6e 20 74 72 65 65 20 74 |stream i|n tree t|
|00003390| 6f 20 61 20 6c 65 61 66 | 2a 2f 0a 58 09 69 20 3d |o a leaf|*/.X.i =|
|000033a0| 20 30 3b 09 2f 2a 20 53 | 74 61 72 74 20 61 74 20 | 0;./* S|tart at |
|000033b0| 72 6f 6f 74 20 6f 66 20 | 74 72 65 65 20 2a 2f 0a |root of |tree */.|
|000033c0| 58 09 64 6f 20 7b 0a 58 | 09 09 69 66 28 2b 2b 42 |X.do {.X|..if(++B|
|000033d0| 70 6f 73 20 3e 20 37 29 | 20 7b 0a 58 09 09 09 69 |pos > 7)| {.X...i|
|000033e0| 66 28 28 43 75 72 69 6e | 20 3d 20 67 65 74 63 28 |f((Curin| = getc(|
|000033f0| 69 6e 29 29 20 3d 3d 20 | 45 4f 46 29 0a 58 09 09 |in)) == |EOF).X..|
|00003400| 09 09 72 65 74 75 72 6e | 28 45 52 52 4f 52 29 3b |..return|(ERROR);|
|00003410| 0a 58 09 09 09 42 70 6f | 73 20 3d 20 30 3b 0a 58 |.X...Bpo|s = 0;.X|
|00003420| 09 09 09 2f 2a 20 6d 6f | 76 65 20 61 20 6c 65 76 |.../* mo|ve a lev|
|00003430| 65 6c 20 64 65 65 70 65 | 72 20 69 6e 20 74 72 65 |el deepe|r in tre|
|00003440| 65 20 2a 2f 0a 58 09 09 | 09 69 20 3d 20 44 6e 6f |e */.X..|.i = Dno|
|00003450| 64 65 5b 69 5d 2e 63 68 | 69 6c 64 72 65 6e 5b 31 |de[i].ch|ildren[1|
|00003460| 20 26 20 43 75 72 69 6e | 5d 3b 0a 58 09 09 7d 20 | & Curin|];.X..} |
|00003470| 65 6c 73 65 0a 58 09 09 | 09 69 20 3d 20 44 6e 6f |else.X..|.i = Dno|
|00003480| 64 65 5b 69 5d 2e 63 68 | 69 6c 64 72 65 6e 5b 31 |de[i].ch|ildren[1|
|00003490| 20 26 20 28 43 75 72 69 | 6e 20 3e 3e 3d 20 31 29 | & (Curi|n >>= 1)|
|000034a0| 5d 3b 0a 58 09 7d 20 77 | 68 69 6c 65 28 69 20 3e |];.X.} w|hile(i >|
|000034b0| 3d 20 30 29 3b 0a 58 0a | 58 09 2f 2a 20 44 65 63 |= 0);.X.|X./* Dec|
|000034c0| 6f 64 65 20 66 61 6b 65 | 20 6e 6f 64 65 20 69 6e |ode fake| node in|
|000034d0| 64 65 78 20 74 6f 20 6f | 72 69 67 69 6e 61 6c 20 |dex to o|riginal |
|000034e0| 64 61 74 61 20 76 61 6c | 75 65 20 2a 2f 0a 58 09 |data val|ue */.X.|
|000034f0| 69 20 3d 20 2d 28 69 20 | 2b 20 31 29 3b 0a 58 09 |i = -(i |+ 1);.X.|
|00003500| 2f 2a 20 44 65 63 6f 64 | 65 20 73 70 65 63 69 61 |/* Decod|e specia|
|00003510| 6c 20 65 6e 64 66 69 6c | 65 20 74 6f 6b 65 6e 20 |l endfil|e token |
|00003520| 74 6f 20 6e 6f 72 6d 61 | 6c 20 45 4f 46 20 2a 2f |to norma|l EOF */|
|00003530| 0a 58 09 72 65 74 75 72 | 6e 28 69 20 3d 3d 20 53 |.X.retur|n(i == S|
|00003540| 50 45 4f 46 29 20 3f 20 | 45 4f 46 20 3a 20 69 3b |PEOF) ? |EOF : i;|
|00003550| 0a 58 7d 0a 58 2f 2a 0a | 58 20 2a 20 4d 61 63 68 |.X}.X/*.|X * Mach|
|00003560| 69 6e 65 20 69 6e 64 65 | 70 65 6e 64 65 6e 74 20 |ine inde|pendent |
|00003570| 67 65 74 77 20 77 68 69 | 63 68 20 61 6c 77 61 79 |getw whi|ch alway|
|00003580| 73 20 67 65 74 73 20 62 | 79 74 65 73 20 69 6e 20 |s gets b|ytes in |
|00003590| 74 68 65 20 73 61 6d 65 | 20 6f 72 64 65 72 0a 58 |the same| order.X|
|000035a0| 20 2a 20 20 61 73 20 74 | 68 65 20 43 50 2f 4d 20 | * as t|he CP/M |
|000035b0| 76 65 72 73 69 6f 6e 20 | 6f 66 20 53 51 20 77 72 |version |of SQ wr|
|000035c0| 6f 74 65 20 74 68 65 6d | 0a 58 20 2a 2f 0a 58 49 |ote them|.X */.XI|
|000035d0| 4e 54 31 36 0a 58 70 6f | 72 74 67 65 74 77 28 66 |NT16.Xpo|rtgetw(f|
|000035e0| 29 0a 58 46 49 4c 45 20 | 2a 66 3b 0a 58 7b 0a 58 |).XFILE |*f;.X{.X|
|000035f0| 09 72 65 67 69 73 74 65 | 72 20 49 4e 54 31 36 20 |.registe|r INT16 |
|00003600| 63 3b 0a 58 0a 58 09 63 | 20 3d 20 67 65 74 63 28 |c;.X.X.c| = getc(|
|00003610| 66 29 20 26 20 30 33 37 | 37 3b 0a 58 09 72 65 74 |f) & 037|7;.X.ret|
|00003620| 75 72 6e 28 63 20 7c 20 | 28 67 65 74 63 28 66 29 |urn(c | |(getc(f)|
|00003630| 20 3c 3c 20 38 29 29 3b | 0a 58 7d 0a 45 4e 44 5f | << 8));|.X}.END_|
|00003640| 4f 46 5f 46 49 4c 45 0a | 69 66 20 74 65 73 74 20 |OF_FILE.|if test |
|00003650| 35 30 39 32 20 2d 6e 65 | 20 60 77 63 20 2d 63 20 |5092 -ne| `wc -c |
|00003660| 3c 27 78 75 73 71 69 2e | 63 27 60 3b 20 74 68 65 |<'xusqi.|c'`; the|
|00003670| 6e 0a 20 20 20 20 65 63 | 68 6f 20 73 68 61 72 3a |n. ec|ho shar:|
|00003680| 20 5c 22 27 78 75 73 71 | 69 2e 63 27 5c 22 20 75 | \"'xusq|i.c'\" u|
|00003690| 6e 70 61 63 6b 65 64 20 | 77 69 74 68 20 77 72 6f |npacked |with wro|
|000036a0| 6e 67 20 73 69 7a 65 21 | 0a 66 69 0a 23 20 65 6e |ng size!|.fi.# en|
|000036b0| 64 20 6f 66 20 27 78 75 | 73 71 69 2e 63 27 0a 66 |d of 'xu|sqi.c'.f|
|000036c0| 69 0a 65 63 68 6f 20 73 | 68 61 72 3a 20 45 6e 64 |i.echo s|har: End|
|000036d0| 20 6f 66 20 73 68 65 6c | 6c 20 61 72 63 68 69 76 | of shel|l archiv|
|000036e0| 65 2e 0a 65 78 69 74 20 | 30 0a 2d 2d 0a 2d 2d 72 |e..exit |0.--.--r|
|000036f0| 75 73 73 20 28 6e 65 6c | 73 6f 6e 40 63 6c 75 74 |uss (nel|son@clut|
|00003700| 78 20 5b 2e 62 69 74 6e | 65 74 20 7c 20 2e 63 6c |x [.bitn|et | .cl|
|00003710| 61 72 6b 73 6f 6e 2e 65 | 64 75 5d 29 20 20 46 41 |arkson.e|du]) FA|
|00003720| 58 20 33 31 35 2d 32 36 | 38 2d 37 36 30 30 0a 49 |X 315-26|8-7600.I|
|00003730| 74 27 73 20 62 65 74 74 | 65 72 20 74 6f 20 67 65 |t's bett|er to ge|
|00003740| 74 20 6d 75 67 67 65 64 | 20 74 68 61 6e 20 74 6f |t mugged| than to|
|00003750| 20 6c 69 76 65 20 61 20 | 6c 69 66 65 20 6f 66 20 | live a |life of |
|00003760| 66 65 61 72 20 2d 2d 20 | 46 72 65 65 6d 61 6e 20 |fear -- |Freeman |
|00003770| 44 79 73 6f 6e 0a 49 20 | 6a 6f 69 6e 65 64 20 74 |Dyson.I |joined t|
|00003780| 68 65 20 4c 65 61 67 75 | 65 20 66 6f 72 20 50 72 |he Leagu|e for Pr|
|00003790| 6f 67 72 61 6d 6d 69 6e | 67 20 46 72 65 65 64 6f |ogrammin|g Freedo|
|000037a0| 6d 2c 20 61 6e 64 20 49 | 20 68 6f 70 65 20 79 6f |m, and I| hope yo|
|000037b0| 75 27 6c 6c 20 6a 6f 69 | 6e 20 74 6f 6f 2e 0a |u'll joi|n too.. |
+--------+-------------------------+-------------------------+--------+--------+