home *** CD-ROM | disk | FTP | other *** search
/ Usenet 1994 January / usenetsourcesnewsgroupsinfomagicjanuary1994.iso / sources / unix / volume8 / sp / part02 < prev    next >
SHell self-extracting ARchive  |  1987-02-19  |  17.8 KB

open in: MacOS 8.1     |     Win98     |     DOS

browse contents    |     view JSON data     |     view as text


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

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



hex view
+--------+-------------------------+-------------------------+--------+--------+
|00000000| 53 75 62 6a 65 63 74 3a | 20 20 76 30 38 69 30 37 |Subject:| v08i07|
|00000010| 37 3a 20 20 53 6f 75 6e | 64 65 78 20 73 70 65 6c |7: Soun|dex spel|
|00000020| 6c 69 6e 67 20 63 68 65 | 63 6b 65 72 2c 20 50 61 |ling che|cker, Pa|
|00000030| 72 74 30 32 2f 30 32 0a | 4e 65 77 73 67 72 6f 75 |rt02/02.|Newsgrou|
|00000040| 70 73 3a 20 6d 6f 64 2e | 73 6f 75 72 63 65 73 0a |ps: mod.|sources.|
|00000050| 41 70 70 72 6f 76 65 64 | 3a 20 6d 69 72 72 6f 72 |Approved|: mirror|
|00000060| 21 72 73 0a 0a 53 75 62 | 6d 69 74 74 65 64 20 62 |!rs..Sub|mitted b|
|00000070| 79 3a 20 42 61 72 72 79 | 20 42 72 61 63 68 6d 61 |y: Barry| Brachma|
|00000080| 6e 20 3c 62 72 61 63 68 | 6d 61 6e 40 63 73 2e 75 |n <brach|man@cs.u|
|00000090| 62 63 2e 63 64 6e 3e 0a | 4d 6f 64 2e 73 6f 75 72 |bc.cdn>.|Mod.sour|
|000000a0| 63 65 73 3a 20 56 6f 6c | 75 6d 65 20 38 2c 20 49 |ces: Vol|ume 8, I|
|000000b0| 73 73 75 65 20 37 37 0a | 41 72 63 68 69 76 65 2d |ssue 77.|Archive-|
|000000c0| 6e 61 6d 65 3a 20 73 70 | 2f 50 61 72 74 30 32 0a |name: sp|/Part02.|
|000000d0| 0a 23 21 20 2f 62 69 6e | 2f 73 68 0a 23 20 54 68 |.#! /bin|/sh.# Th|
|000000e0| 69 73 20 69 73 20 61 20 | 73 68 65 6c 6c 20 61 72 |is is a |shell ar|
|000000f0| 63 68 69 76 65 2e 20 20 | 52 65 6d 6f 76 65 20 61 |chive. |Remove a|
|00000100| 6e 79 74 68 69 6e 67 20 | 62 65 66 6f 72 65 20 74 |nything |before t|
|00000110| 68 69 73 20 6c 69 6e 65 | 2c 0a 23 20 74 68 65 6e |his line|,.# then|
|00000120| 20 75 6e 70 61 63 6b 20 | 69 74 20 62 79 20 73 61 | unpack |it by sa|
|00000130| 76 69 6e 67 20 69 74 20 | 69 6e 20 61 20 66 69 6c |ving it |in a fil|
|00000140| 65 20 61 6e 64 20 74 79 | 70 69 6e 67 20 22 73 68 |e and ty|ping "sh|
|00000150| 20 66 69 6c 65 22 2e 0a | 23 20 49 66 20 61 6c 6c | file"..|# If all|
|00000160| 20 67 6f 65 73 20 77 65 | 6c 6c 2c 20 79 6f 75 20 | goes we|ll, you |
|00000170| 77 69 6c 6c 20 73 65 65 | 20 74 68 65 20 6d 65 73 |will see| the mes|
|00000180| 73 61 67 65 20 22 45 6e | 64 20 6f 66 20 61 72 63 |sage "En|d of arc|
|00000190| 68 69 76 65 20 32 20 28 | 6f 66 20 32 29 2e 22 0a |hive 2 (|of 2).".|
|000001a0| 23 20 43 6f 6e 74 65 6e | 74 73 3a 20 20 73 70 2e |# Conten|ts: sp.|
|000001b0| 39 20 73 70 2e 63 20 73 | 70 2e 68 20 73 70 2e 6d |9 sp.c s|p.h sp.m|
|000001c0| 6c 0a 50 41 54 48 3d 2f | 62 69 6e 3a 2f 75 73 72 |l.PATH=/|bin:/usr|
|000001d0| 2f 62 69 6e 3a 2f 75 73 | 72 2f 75 63 62 3b 20 65 |/bin:/us|r/ucb; e|
|000001e0| 78 70 6f 72 74 20 50 41 | 54 48 0a 65 63 68 6f 20 |xport PA|TH.echo |
|000001f0| 73 68 61 72 3a 20 65 78 | 74 72 61 63 74 69 6e 67 |shar: ex|tracting|
|00000200| 20 22 27 73 70 2e 39 27 | 22 20 27 28 31 31 31 32 | "'sp.9'|" '(1112|
|00000210| 20 63 68 61 72 61 63 74 | 65 72 73 29 27 0a 69 66 | charact|ers)'.if|
|00000220| 20 74 65 73 74 20 2d 66 | 20 27 73 70 2e 39 27 20 | test -f| 'sp.9' |
|00000230| 3b 20 74 68 65 6e 20 0a | 20 20 65 63 68 6f 20 73 |; then .| echo s|
|00000240| 68 61 72 3a 20 77 69 6c | 6c 20 6e 6f 74 20 6f 76 |har: wil|l not ov|
|00000250| 65 72 2d 77 72 69 74 65 | 20 65 78 69 73 74 69 6e |er-write| existin|
|00000260| 67 20 66 69 6c 65 20 22 | 27 73 70 2e 39 27 22 0a |g file "|'sp.9'".|
|00000270| 65 6c 73 65 0a 73 65 64 | 20 27 73 2f 5e 58 2f 2f |else.sed| 's/^X//|
|00000280| 27 20 3e 73 70 2e 39 20 | 3c 3c 27 40 2f 2f 45 2a |' >sp.9 |<<'@//E*|
|00000290| 4f 2a 46 20 73 70 2e 39 | 2f 2f 27 0a 58 2e 54 48 |O*F sp.9|//'.X.TH|
|000002a0| 20 53 50 20 39 2d 45 4d | 41 43 53 20 22 38 2d 41 | SP 9-EM|ACS "8-A|
|000002b0| 75 67 2d 31 39 38 35 22 | 0a 58 2e 55 43 0a 58 2e |ug-1985"|.X.UC.X.|
|000002c0| 53 48 20 4e 41 4d 45 0a | 58 73 70 2c 20 73 70 2d |SH NAME.|Xsp, sp-|
|000002d0| 66 72 6f 6d 2d 62 75 66 | 66 65 72 20 5c 2d 20 67 |from-buf|fer \- g|
|000002e0| 69 76 65 20 70 6f 73 73 | 69 62 6c 65 20 73 70 65 |ive poss|ible spe|
|000002f0| 6c 6c 69 6e 67 73 0a 58 | 2e 62 72 0a 58 67 65 74 |llings.X|.br.Xget|
|00000300| 2d 6e 65 78 74 2d 77 6f | 72 64 20 5c 2d 20 72 65 |-next-wo|rd \- re|
|00000310| 74 75 72 6e 20 77 6f 72 | 64 20 61 74 20 63 75 72 |turn wor|d at cur|
|00000320| 73 6f 72 0a 58 2e 53 48 | 20 53 59 4e 4f 50 53 49 |sor.X.SH| SYNOPSI|
|00000330| 53 0a 58 2e 42 20 28 73 | 70 29 0a 58 2e 62 72 0a |S.X.B (s|p).X.br.|
|00000340| 58 2e 42 20 28 73 70 2d | 66 72 6f 6d 2d 62 75 66 |X.B (sp-|from-buf|
|00000350| 66 65 72 29 0a 58 2e 62 | 72 0a 58 2e 42 20 28 67 |fer).X.b|r.X.B (g|
|00000360| 65 74 2d 6e 65 78 74 2d | 77 6f 72 64 29 0a 58 2e |et-next-|word).X.|
|00000370| 53 48 20 44 45 53 43 52 | 49 50 54 49 4f 4e 0a 58 |SH DESCR|IPTION.X|
|00000380| 2e 49 20 53 70 0a 58 70 | 72 6f 6d 70 74 73 20 66 |.I Sp.Xp|rompts f|
|00000390| 6f 72 20 61 20 77 6f 72 | 64 20 61 6e 64 20 74 68 |or a wor|d and th|
|000003a0| 65 6e 20 69 6e 76 6f 6b | 65 73 20 74 68 65 0a 58 |en invok|es the.X|
|000003b0| 2e 42 20 73 70 0a 58 70 | 72 6f 67 72 61 6d 20 77 |.B sp.Xp|rogram w|
|000003c0| 69 74 68 20 74 68 65 20 | 77 6f 72 64 20 61 73 20 |ith the |word as |
|000003d0| 61 6e 20 61 72 67 75 6d | 65 6e 74 2e 0a 58 54 68 |an argum|ent..XTh|
|000003e0| 65 20 6f 75 74 70 75 74 | 20 6f 66 20 74 68 65 0a |e output| of the.|
|000003f0| 58 2e 42 20 73 70 0a 58 | 70 72 6f 67 72 61 6d 2c |X.B sp.X|program,|
|00000400| 20 61 20 6c 69 73 74 20 | 6f 66 20 77 6f 72 64 73 | a list |of words|
|00000410| 2c 20 69 73 20 70 6c 61 | 63 65 64 20 69 6e 20 61 |, is pla|ced in a|
|00000420| 20 62 75 66 66 65 72 20 | 63 61 6c 6c 65 64 20 22 | buffer |called "|
|00000430| 73 70 22 2e 0a 58 49 66 | 20 74 68 65 20 77 6f 72 |sp"..XIf| the wor|
|00000440| 64 20 69 73 20 66 6f 75 | 6e 64 2c 20 74 68 65 6e |d is fou|nd, then|
|00000450| 20 74 68 65 20 63 75 72 | 73 6f 72 20 69 73 20 70 | the cur|sor is p|
|00000460| 6f 73 69 74 69 6f 6e 65 | 64 20 61 74 20 74 68 65 |ositione|d at the|
|00000470| 20 77 6f 72 64 2e 0a 58 | 49 66 20 74 68 65 20 77 | word..X|If the w|
|00000480| 6f 72 64 20 69 73 6e 27 | 74 20 66 6f 75 6e 64 2c |ord isn'|t found,|
|00000490| 20 74 68 65 20 63 75 72 | 73 6f 72 20 69 73 20 6c | the cur|sor is l|
|000004a0| 65 66 74 20 61 74 20 74 | 68 65 20 73 74 61 72 74 |eft at t|he start|
|000004b0| 20 6f 66 20 74 68 65 20 | 62 75 66 66 65 72 2e 0a | of the |buffer..|
|000004c0| 58 49 6e 20 65 69 74 68 | 65 72 20 63 61 73 65 20 |XIn eith|er case |
|000004d0| 74 68 65 20 6d 6f 64 65 | 20 6c 69 6e 65 20 6f 66 |the mode| line of|
|000004e0| 20 74 68 65 20 62 75 66 | 66 65 72 20 69 6e 64 69 | the buf|fer indi|
|000004f0| 63 61 74 65 73 20 77 68 | 65 74 68 65 72 20 74 68 |cates wh|ether th|
|00000500| 65 20 77 6f 72 64 0a 58 | 77 61 73 20 66 6f 75 6e |e word.X|was foun|
|00000510| 64 2e 0a 58 2e 73 70 20 | 32 0a 58 2e 42 20 53 70 |d..X.sp |2.X.B Sp|
|00000520| 2d 66 72 6f 6d 2d 62 75 | 66 66 65 72 0a 58 69 73 |-from-bu|ffer.Xis|
|00000530| 20 74 68 65 20 73 61 6d | 65 20 61 73 0a 58 2e 42 | the sam|e as.X.B|
|00000540| 20 73 70 0a 58 65 78 63 | 65 70 74 20 74 68 61 74 | sp.Xexc|ept that|
|00000550| 20 74 68 65 20 75 73 65 | 72 20 69 73 20 6e 6f 74 | the use|r is not|
|00000560| 20 70 72 6f 6d 70 74 65 | 64 20 66 6f 72 20 74 68 | prompte|d for th|
|00000570| 65 20 77 6f 72 64 3b 20 | 74 68 65 20 77 6f 72 64 |e word; |the word|
|00000580| 20 75 6e 64 65 72 20 6f | 72 0a 58 69 6d 6d 65 64 | under o|r.Ximmed|
|00000590| 69 61 74 65 6c 79 20 74 | 6f 20 74 68 65 20 6c 65 |iately t|o the le|
|000005a0| 66 74 20 6f 66 20 74 68 | 65 20 63 75 72 73 6f 72 |ft of th|e cursor|
|000005b0| 20 69 73 20 75 73 65 64 | 2e 0a 58 2e 73 70 20 32 | is used|..X.sp 2|
|000005c0| 0a 58 2e 42 20 47 65 74 | 2d 6e 65 78 74 2d 77 6f |.X.B Get|-next-wo|
|000005d0| 72 64 0a 58 72 65 74 75 | 72 6e 73 20 74 68 65 20 |rd.Xretu|rns the |
|000005e0| 77 6f 72 64 20 74 68 65 | 20 63 75 72 73 6f 72 20 |word the| cursor |
|000005f0| 69 73 20 70 6f 69 6e 74 | 69 6e 67 20 61 74 20 6f |is point|ing at o|
|00000600| 72 20 74 68 65 20 77 6f | 72 64 20 69 6d 6d 65 64 |r the wo|rd immed|
|00000610| 69 61 74 65 6c 79 0a 58 | 74 6f 20 74 68 65 20 6c |iately.X|to the l|
|00000620| 65 66 74 20 6f 66 20 74 | 68 65 20 63 75 72 73 6f |eft of t|he curso|
|00000630| 72 20 69 66 20 69 74 20 | 69 73 20 62 65 74 77 65 |r if it |is betwe|
|00000640| 65 6e 20 77 6f 72 64 73 | 2e 0a 58 2e 53 48 20 42 |en words|..X.SH B|
|00000650| 55 46 46 45 52 53 20 55 | 53 45 44 0a 58 73 70 20 |UFFERS U|SED.Xsp |
|00000660| 5c 2d 20 72 65 73 75 6c | 74 0a 58 2e 53 48 20 46 |\- resul|t.X.SH F|
|00000670| 49 4c 45 53 0a 58 2f 75 | 73 72 2f 6c 6f 63 61 6c |ILES.X/u|sr/local|
|00000680| 2f 6c 69 62 2f 65 6d 61 | 63 73 2f 73 70 2e 6d 6c |/lib/ema|cs/sp.ml|
|00000690| 0a 58 2e 62 72 0a 58 2f | 75 73 72 2f 6c 6f 63 61 |.X.br.X/|usr/loca|
|000006a0| 6c 2f 73 70 0a 58 2e 53 | 48 20 53 45 45 20 41 4c |l/sp.X.S|H SEE AL|
|000006b0| 53 4f 0a 58 2e 42 20 73 | 70 28 31 2d 4c 4f 43 41 |SO.X.B s|p(1-LOCA|
|000006c0| 4c 29 0a 58 2e 53 48 20 | 41 55 54 48 4f 52 0a 58 |L).X.SH |AUTHOR.X|
|000006d0| 42 61 72 72 79 20 42 72 | 61 63 68 6d 61 6e 0a 58 |Barry Br|achman.X|
|000006e0| 2e 62 72 0a 58 44 65 70 | 74 2e 20 6f 66 20 43 6f |.br.XDep|t. of Co|
|000006f0| 6d 70 75 74 65 72 20 53 | 63 69 65 6e 63 65 0a 58 |mputer S|cience.X|
|00000700| 2e 62 72 0a 58 55 6e 69 | 76 65 72 73 69 74 79 20 |.br.XUni|versity |
|00000710| 6f 66 20 42 72 69 74 69 | 73 68 20 43 6f 6c 75 6d |of Briti|sh Colum|
|00000720| 62 69 61 0a 40 2f 2f 45 | 2a 4f 2a 46 20 73 70 2e |bia.@//E|*O*F sp.|
|00000730| 39 2f 2f 0a 69 66 20 74 | 65 73 74 20 31 31 31 32 |9//.if t|est 1112|
|00000740| 20 2d 6e 65 20 22 60 77 | 63 20 2d 63 20 3c 27 73 | -ne "`w|c -c <'s|
|00000750| 70 2e 39 27 60 22 3b 20 | 74 68 65 6e 0a 20 20 20 |p.9'`"; |then. |
|00000760| 20 65 63 68 6f 20 73 68 | 61 72 3a 20 65 72 72 6f | echo sh|ar: erro|
|00000770| 72 20 74 72 61 6e 73 6d | 69 74 74 69 6e 67 20 22 |r transm|itting "|
|00000780| 27 73 70 2e 39 27 22 20 | 27 28 73 68 6f 75 6c 64 |'sp.9'" |'(should|
|00000790| 20 68 61 76 65 20 62 65 | 65 6e 20 31 31 31 32 20 | have be|en 1112 |
|000007a0| 63 68 61 72 61 63 74 65 | 72 73 29 27 0a 66 69 0a |characte|rs)'.fi.|
|000007b0| 66 69 20 23 20 65 6e 64 | 20 6f 66 20 6f 76 65 72 |fi # end| of over|
|000007c0| 77 72 69 74 69 6e 67 20 | 63 68 65 63 6b 0a 65 63 |writing |check.ec|
|000007d0| 68 6f 20 73 68 61 72 3a | 20 65 78 74 72 61 63 74 |ho shar:| extract|
|000007e0| 69 6e 67 20 22 27 73 70 | 2e 63 27 22 20 27 28 39 |ing "'sp|.c'" '(9|
|000007f0| 31 32 38 20 63 68 61 72 | 61 63 74 65 72 73 29 27 |128 char|acters)'|
|00000800| 0a 69 66 20 74 65 73 74 | 20 2d 66 20 27 73 70 2e |.if test| -f 'sp.|
|00000810| 63 27 20 3b 20 74 68 65 | 6e 20 0a 20 20 65 63 68 |c' ; the|n . ech|
|00000820| 6f 20 73 68 61 72 3a 20 | 77 69 6c 6c 20 6e 6f 74 |o shar: |will not|
|00000830| 20 6f 76 65 72 2d 77 72 | 69 74 65 20 65 78 69 73 | over-wr|ite exis|
|00000840| 74 69 6e 67 20 66 69 6c | 65 20 22 27 73 70 2e 63 |ting fil|e "'sp.c|
|00000850| 27 22 0a 65 6c 73 65 0a | 73 65 64 20 27 73 2f 5e |'".else.|sed 's/^|
|00000860| 58 2f 2f 27 20 3e 73 70 | 2e 63 20 3c 3c 27 40 2f |X//' >sp|.c <<'@/|
|00000870| 2f 45 2a 4f 2a 46 20 73 | 70 2e 63 2f 2f 27 0a 58 |/E*O*F s|p.c//'.X|
|00000880| 2f 2a 20 76 69 3a 20 73 | 65 74 20 74 61 62 73 74 |/* vi: s|et tabst|
|00000890| 6f 70 3d 34 20 3a 20 2a | 2f 0a 58 0a 58 2f 2a 0a |op=4 : *|/.X.X/*.|
|000008a0| 58 20 2a 20 56 65 72 73 | 69 6f 6e 20 31 2e 33 20 |X * Vers|ion 1.3 |
|000008b0| 44 65 63 65 6d 62 65 72 | 20 31 39 38 36 0a 58 20 |December| 1986.X |
|000008c0| 2a 0a 58 20 2a 20 73 70 | 20 2d 20 73 70 65 6c 6c |*.X * sp| - spell|
|000008d0| 20 77 6f 72 64 0a 58 20 | 2a 0a 58 20 2a 20 55 73 | word.X |*.X * Us|
|000008e0| 61 67 65 3a 09 73 70 20 | 5b 2d 66 20 64 69 63 74 |age:.sp |[-f dict|
|000008f0| 69 6f 6e 61 72 79 2d 6c | 69 73 74 5d 20 5b 2d 65 |ionary-l|ist] [-e|
|00000900| 61 76 63 5d 20 5b 77 6f | 72 64 20 2e 2e 2e 5d 0a |avc] [wo|rd ...].|
|00000910| 58 20 2a 0a 58 20 2a 20 | 43 6f 6d 70 75 74 65 20 |X *.X * |Compute |
|00000920| 74 68 65 20 53 6f 75 6e | 64 65 78 20 63 6f 64 65 |the Soun|dex code|
|00000930| 20 66 6f 72 20 65 61 63 | 68 20 77 6f 72 64 20 6f | for eac|h word o|
|00000940| 6e 20 74 68 65 20 63 6f | 6d 6d 61 6e 64 20 6c 69 |n the co|mmand li|
|00000950| 6e 65 0a 58 20 2a 20 28 | 6f 72 20 65 61 63 68 20 |ne.X * (|or each |
|00000960| 77 6f 72 64 20 6f 6e 20 | 74 68 65 20 73 74 61 6e |word on |the stan|
|00000970| 64 61 72 64 20 69 6e 70 | 75 74 29 20 61 6e 64 20 |dard inp|ut) and |
|00000980| 63 6f 6d 70 61 72 65 20 | 61 67 61 69 6e 73 74 20 |compare |against |
|00000990| 61 0a 58 20 2a 20 64 69 | 63 74 69 6f 6e 61 72 79 |a.X * di|ctionary|
|000009a0| 0a 58 20 2a 0a 58 20 2a | 20 54 68 65 20 73 6f 75 |.X *.X *| The sou|
|000009b0| 6e 64 65 78 20 64 69 63 | 74 69 6f 6e 61 72 79 20 |ndex dic|tionary |
|000009c0| 6c 69 73 74 20 6d 61 79 | 20 62 65 20 73 70 65 63 |list may| be spec|
|000009d0| 69 66 69 65 64 20 6f 6e | 20 74 68 65 20 63 6f 6d |ified on| the com|
|000009e0| 6d 61 6e 64 20 6c 69 6e | 65 0a 58 20 2a 20 54 68 |mand lin|e.X * Th|
|000009f0| 65 20 65 6e 76 69 72 6f | 6e 6d 65 6e 74 20 76 61 |e enviro|nment va|
|00000a00| 72 69 61 62 6c 65 20 53 | 50 50 41 54 48 20 6d 61 |riable S|PPATH ma|
|00000a10| 79 20 62 65 20 73 65 74 | 20 74 6f 20 61 20 6c 69 |y be set| to a li|
|00000a20| 73 74 20 6f 66 20 63 6f | 6c 6f 6e 0a 58 20 2a 20 |st of co|lon.X * |
|00000a30| 73 65 70 61 72 61 74 65 | 64 20 70 61 74 68 6e 61 |separate|d pathna|
|00000a40| 6d 65 73 20 6f 66 20 73 | 6f 75 6e 64 65 78 20 64 |mes of s|oundex d|
|00000a50| 69 63 74 69 6f 6e 61 72 | 69 65 73 2e 0a 58 20 2a |ictionar|ies..X *|
|00000a60| 20 49 66 20 61 20 63 6f | 6d 6d 61 6e 64 20 6c 69 | If a co|mmand li|
|00000a70| 6e 65 20 64 69 63 74 69 | 6f 6e 61 72 79 2d 6c 69 |ne dicti|onary-li|
|00000a80| 73 74 20 28 61 20 63 6f | 6c 6f 6e 20 73 65 70 61 |st (a co|lon sepa|
|00000a90| 72 61 74 65 64 20 6c 69 | 73 74 20 6f 66 20 70 61 |rated li|st of pa|
|00000aa0| 74 68 6e 61 6d 65 73 29 | 20 69 73 0a 58 20 2a 20 |thnames)| is.X * |
|00000ab0| 67 69 76 65 6e 20 69 6e | 20 61 64 64 69 74 69 6f |given in| additio|
|00000ac0| 6e 20 74 6f 20 74 68 65 | 20 53 50 50 41 54 48 20 |n to the| SPPATH |
|00000ad0| 76 61 72 69 61 62 6c 65 | 2c 20 61 6c 6c 20 64 69 |variable|, all di|
|00000ae0| 63 74 69 6f 6e 61 72 69 | 65 73 20 61 72 65 20 75 |ctionari|es are u|
|00000af0| 73 65 64 2e 0a 58 20 2a | 0a 58 20 2a 20 54 6f 20 |sed..X *|.X * To |
|00000b00| 72 65 64 75 63 65 20 74 | 68 65 20 73 69 7a 65 20 |reduce t|he size |
|00000b10| 6f 66 20 74 68 65 20 77 | 6f 72 64 20 6c 69 73 74 |of the w|ord list|
|00000b20| 2c 20 63 65 72 74 61 69 | 6e 20 68 65 75 72 69 73 |, certai|n heuris|
|00000b30| 74 69 63 73 20 61 72 65 | 20 75 73 65 64 3a 0a 58 |tics are| used:.X|
|00000b40| 20 2a 20 74 68 65 20 2d | 61 20 6f 70 74 69 6f 6e | * the -|a option|
|00000b50| 20 63 61 75 73 65 73 20 | 61 6c 6c 20 77 6f 72 64 | causes |all word|
|00000b60| 73 20 6d 61 74 63 68 65 | 64 20 74 6f 20 62 65 20 |s matche|d to be |
|00000b70| 70 72 69 6e 74 65 64 0a | 58 20 2a 20 54 68 65 20 |printed.|X * The |
|00000b80| 6f 75 74 70 75 74 20 69 | 73 20 61 6c 70 68 61 62 |output i|s alphab|
|00000b90| 65 74 69 63 61 6c 6c 79 | 20 73 6f 72 74 65 64 20 |etically| sorted |
|00000ba0| 61 6e 64 20 69 6e 64 69 | 63 61 74 6f 72 73 20 61 |and indi|cators a|
|00000bb0| 72 65 20 70 72 69 6e 74 | 65 64 0a 58 20 2a 20 62 |re print|ed.X * b|
|00000bc0| 65 73 69 64 65 20 65 61 | 63 68 20 77 6f 72 64 3a |eside ea|ch word:|
|00000bd0| 0a 58 20 2a 09 58 20 20 | 20 3d 3d 20 65 78 61 63 |.X *.X | == exac|
|00000be0| 74 20 6d 61 74 63 68 0a | 58 20 2a 09 21 20 20 20 |t match.|X *.! |
|00000bf0| 3d 3d 20 63 6c 6f 73 65 | 20 6d 61 74 63 68 0a 58 |== close| match.X|
|00000c00| 20 2a 09 2a 20 20 20 3d | 3d 20 6e 65 61 72 20 6d | *.* =|= near m|
|00000c10| 61 74 63 68 0a 58 20 2a | 20 27 20 27 20 20 3d 3d |atch.X *| ' ' ==|
|00000c20| 20 6d 61 74 63 68 65 64 | 0a 58 20 2a 0a 58 20 2a | matched|.X *.X *|
|00000c30| 20 4e 6f 74 65 20 74 68 | 61 74 20 74 68 65 20 6d | Note th|at the m|
|00000c40| 61 78 69 6d 75 6d 20 6e | 75 6d 62 65 72 20 6f 66 |aximum n|umber of|
|00000c50| 20 63 6f 6c 6c 69 64 69 | 6e 67 20 77 6f 72 64 73 | collidi|ng words|
|00000c60| 20 69 73 20 4d 41 58 43 | 4f 55 4e 54 20 64 75 65 | is MAXC|OUNT due|
|00000c70| 20 74 6f 20 74 68 65 0a | 58 20 2a 20 64 61 74 61 | to the.|X * data|
|00000c80| 20 73 74 72 75 63 74 75 | 72 65 20 75 73 65 64 2e | structu|re used.|
|00000c90| 0a 58 20 2a 0a 58 20 2a | 20 50 65 72 6d 69 73 73 |.X *.X *| Permiss|
|00000ca0| 69 6f 6e 20 69 73 20 67 | 69 76 65 6e 20 74 6f 20 |ion is g|iven to |
|00000cb0| 63 6f 70 79 20 6f 72 20 | 64 69 73 74 72 69 62 75 |copy or |distribu|
|00000cc0| 74 65 20 74 68 69 73 20 | 70 72 6f 67 72 61 6d 20 |te this |program |
|00000cd0| 70 72 6f 76 69 64 65 64 | 20 79 6f 75 0a 58 20 2a |provided| you.X *|
|00000ce0| 20 64 6f 20 6e 6f 74 20 | 72 65 6d 6f 76 65 20 74 | do not |remove t|
|00000cf0| 68 69 73 20 68 65 61 64 | 65 72 20 6f 72 20 6d 61 |his head|er or ma|
|00000d00| 6b 65 20 6d 6f 6e 65 79 | 20 6f 66 66 20 6f 66 20 |ke money| off of |
|00000d10| 74 68 65 20 70 72 6f 67 | 72 61 6d 2e 0a 58 20 2a |the prog|ram..X *|
|00000d20| 0a 58 20 2a 20 50 6c 65 | 61 73 65 20 73 65 6e 64 |.X * Ple|ase send|
|00000d30| 20 63 6f 6d 6d 65 6e 74 | 73 20 61 6e 64 20 73 75 | comment|s and su|
|00000d40| 67 67 65 73 74 69 6f 6e | 73 20 74 6f 3a 0a 58 20 |ggestion|s to:.X |
|00000d50| 2a 0a 58 20 2a 20 42 61 | 72 72 79 20 42 72 61 63 |*.X * Ba|rry Brac|
|00000d60| 68 6d 61 6e 0a 58 20 2a | 20 44 65 70 74 2e 20 6f |hman.X *| Dept. o|
|00000d70| 66 20 43 6f 6d 70 75 74 | 65 72 20 53 63 69 65 6e |f Comput|er Scien|
|00000d80| 63 65 0a 58 20 2a 20 55 | 6e 69 76 2e 20 6f 66 20 |ce.X * U|niv. of |
|00000d90| 42 72 69 74 69 73 68 20 | 43 6f 6c 75 6d 62 69 61 |British |Columbia|
|00000da0| 0a 58 20 2a 20 56 61 6e | 63 6f 75 76 65 72 2c 20 |.X * Van|couver, |
|00000db0| 42 2e 43 2e 20 56 36 54 | 20 31 57 35 0a 58 20 2a |B.C. V6T| 1W5.X *|
|00000dc0| 0a 58 20 2a 20 2e 2e 20 | 7b 69 68 6e 70 34 21 61 |.X * .. |{ihnp4!a|
|00000dd0| 6c 62 65 72 74 61 2c 20 | 75 77 2d 62 65 61 76 65 |lberta, |uw-beave|
|00000de0| 72 7d 21 75 62 63 2d 76 | 69 73 69 6f 6e 21 75 62 |r}!ubc-v|ision!ub|
|00000df0| 63 2d 63 73 21 62 72 61 | 63 68 6d 61 6e 0a 58 20 |c-cs!bra|chman.X |
|00000e00| 2a 20 62 72 61 63 68 6d | 61 6e 40 63 73 2e 75 62 |* brachm|an@cs.ub|
|00000e10| 63 2e 63 64 6e 0a 58 20 | 2a 20 62 72 61 63 68 6d |c.cdn.X |* brachm|
|00000e20| 61 6e 25 75 62 63 2e 63 | 73 6e 65 74 40 63 73 6e |an%ubc.c|snet@csn|
|00000e30| 65 74 2d 72 65 6c 61 79 | 2e 61 72 70 61 0a 58 20 |et-relay|.arpa.X |
|00000e40| 2a 20 62 72 61 63 68 6d | 61 6e 40 75 62 63 2e 63 |* brachm|an@ubc.c|
|00000e50| 73 6e 65 74 0a 58 20 2a | 2f 0a 58 0a 58 23 69 6e |snet.X *|/.X.X#in|
|00000e60| 63 6c 75 64 65 20 3c 73 | 79 73 2f 74 79 70 65 73 |clude <s|ys/types|
|00000e70| 2e 68 3e 0a 58 23 69 6e | 63 6c 75 64 65 20 3c 73 |.h>.X#in|clude <s|
|00000e80| 79 73 2f 66 69 6c 65 2e | 68 3e 0a 58 23 69 6e 63 |ys/file.|h>.X#inc|
|00000e90| 6c 75 64 65 20 3c 63 74 | 79 70 65 2e 68 3e 0a 58 |lude <ct|ype.h>.X|
|00000ea0| 23 69 6e 63 6c 75 64 65 | 20 3c 73 74 64 69 6f 2e |#include| <stdio.|
|00000eb0| 68 3e 0a 58 0a 58 23 69 | 66 64 65 66 20 4e 45 57 |h>.X.X#i|fdef NEW|
|00000ec0| 44 42 4d 0a 58 23 69 6e | 63 6c 75 64 65 20 3c 6e |DBM.X#in|clude <n|
|00000ed0| 64 62 6d 2e 68 3e 0a 58 | 23 65 6c 73 65 20 21 4e |dbm.h>.X|#else !N|
|00000ee0| 45 57 44 42 4d 0a 58 23 | 69 6e 63 6c 75 64 65 20 |EWDBM.X#|include |
|00000ef0| 3c 64 62 6d 2e 68 3e 0a | 58 23 65 6e 64 69 66 20 |<dbm.h>.|X#endif |
|00000f00| 4e 45 57 44 42 4d 0a 58 | 0a 58 23 69 6e 63 6c 75 |NEWDBM.X|.X#inclu|
|00000f10| 64 65 20 22 73 70 2e 68 | 22 0a 58 0a 58 23 64 65 |de "sp.h|".X.X#de|
|00000f20| 66 69 6e 65 20 73 74 72 | 65 71 28 58 2c 20 59 29 |fine str|eq(X, Y)|
|00000f30| 09 28 21 73 74 72 63 6d | 70 28 58 2c 20 59 29 29 |.(!strcm|p(X, Y))|
|00000f40| 0a 58 23 64 65 66 69 6e | 65 20 72 61 6e 67 65 28 |.X#defin|e range(|
|00000f50| 53 29 09 28 28 73 74 72 | 6c 65 6e 28 53 29 20 2b |S).((str|len(S) +|
|00000f60| 20 34 29 20 2f 20 35 29 | 0a 58 0a 58 23 64 65 66 | 4) / 5)|.X.X#def|
|00000f70| 69 6e 65 20 55 53 41 47 | 45 09 09 22 55 73 61 67 |ine USAG|E.."Usag|
|00000f80| 65 3a 20 73 70 20 5b 2d | 66 20 64 69 63 74 69 6f |e: sp [-|f dictio|
|00000f90| 6e 61 72 79 2d 6c 69 73 | 74 5d 20 5b 2d 65 61 76 |nary-lis|t] [-eav|
|00000fa0| 63 5d 20 5b 77 6f 72 64 | 20 2e 2e 2e 5d 22 0a 58 |c] [word| ...]".X|
|00000fb0| 0a 58 63 68 61 72 20 77 | 6f 72 64 5b 4d 41 58 57 |.Xchar w|ord[MAXW|
|00000fc0| 4f 52 44 4c 45 4e 20 2b | 20 32 5d 3b 0a 58 0a 58 |ORDLEN +| 2];.X.X|
|00000fd0| 64 61 74 75 6d 20 46 45 | 54 43 48 28 29 3b 0a 58 |datum FE|TCH();.X|
|00000fe0| 0a 58 63 68 61 72 20 2a | 66 69 6c 65 70 74 72 5b |.Xchar *|fileptr[|
|00000ff0| 4d 41 58 44 49 43 54 20 | 2b 20 31 5d 3b 09 2f 2a |MAXDICT |+ 1];./*|
|00001000| 20 55 70 20 74 6f 20 4d | 41 58 44 49 43 54 20 64 | Up to M|AXDICT d|
|00001010| 69 63 74 69 6f 6e 61 72 | 69 65 73 20 2b 20 73 65 |ictionar|ies + se|
|00001020| 6e 74 69 6e 65 6c 20 2a | 2f 0a 58 69 6e 74 20 64 |ntinel *|/.Xint d|
|00001030| 69 63 74 5f 70 74 72 20 | 3d 20 30 3b 0a 58 0a 58 |ict_ptr |= 0;.X.X|
|00001040| 63 68 61 72 20 2a 77 6f | 72 64 70 74 72 5b 4d 41 |char *wo|rdptr[MA|
|00001050| 58 57 4f 52 44 53 5d 2c | 20 2a 77 6f 72 64 6c 69 |XWORDS],| *wordli|
|00001060| 73 74 70 74 72 3b 0a 58 | 63 68 61 72 20 77 6f 72 |stptr;.X|char wor|
|00001070| 64 6c 69 73 74 5b 57 4f | 52 44 53 50 41 43 45 5d |dlist[WO|RDSPACE]|
|00001080| 3b 0a 58 69 6e 74 20 6e | 6d 61 74 63 68 65 64 3b |;.Xint n|matched;|
|00001090| 0a 58 0a 58 2f 2a 0a 58 | 20 2a 20 53 6f 75 6e 64 |.X.X/*.X| * Sound|
|000010a0| 65 78 20 63 6f 64 65 73 | 0a 58 20 2a 20 54 68 65 |ex codes|.X * The|
|000010b0| 20 70 72 6f 67 72 61 6d | 20 64 65 70 65 6e 64 73 | program| depends|
|000010c0| 20 75 70 6f 6e 20 74 68 | 65 20 6e 75 6d 62 65 72 | upon th|e number|
|000010d0| 73 20 7a 65 72 6f 20 74 | 68 72 6f 75 67 68 20 73 |s zero t|hrough s|
|000010e0| 69 78 20 62 65 69 6e 67 | 20 75 73 65 64 0a 58 20 |ix being| used.X |
|000010f0| 2a 20 62 75 74 20 74 68 | 69 73 20 63 61 6e 20 65 |* but th|is can e|
|00001100| 61 73 69 6c 79 20 62 65 | 20 63 68 61 6e 67 65 64 |asily be| changed|
|00001110| 0a 58 20 2a 2f 0a 58 63 | 68 61 72 20 73 6f 75 6e |.X */.Xc|har soun|
|00001120| 64 65 78 5f 63 6f 64 65 | 5f 6d 61 70 5b 32 36 5d |dex_code|_map[26]|
|00001130| 20 3d 20 7b 0a 58 2f 2a | 2a 2a 09 20 41 20 20 42 | = {.X/*|**. A B|
|00001140| 20 20 43 20 20 44 20 20 | 45 20 20 46 20 20 47 20 | C D |E F G |
|00001150| 20 48 20 20 49 20 20 4a | 20 20 4b 20 20 4c 20 20 | H I J| K L |
|00001160| 4d 20 20 4e 20 20 4f 20 | 20 50 09 2a 2a 2a 2f 20 |M N O | P.***/ |
|00001170| 0a 58 09 09 20 30 2c 20 | 31 2c 20 32 2c 20 33 2c |.X.. 0, |1, 2, 3,|
|00001180| 20 30 2c 20 31 2c 20 32 | 2c 20 30 2c 20 30 2c 20 | 0, 1, 2|, 0, 0, |
|00001190| 32 2c 20 32 2c 20 34 2c | 20 35 2c 20 35 2c 20 30 |2, 2, 4,| 5, 5, 0|
|000011a0| 2c 20 31 2c 0a 58 0a 58 | 2f 2a 2a 2a 09 20 51 20 |, 1,.X.X|/***. Q |
|000011b0| 20 52 20 20 53 20 20 54 | 20 20 55 20 20 56 20 20 | R S T| U V |
|000011c0| 57 20 20 58 20 20 59 20 | 20 5a 09 09 09 2a 2a 2a |W X Y | Z...***|
|000011d0| 2f 0a 58 09 09 20 32 2c | 20 36 2c 20 32 2c 20 33 |/.X.. 2,| 6, 2, 3|
|000011e0| 2c 20 30 2c 20 31 2c 20 | 30 2c 20 32 2c 20 30 2c |, 0, 1, |0, 2, 0,|
|000011f0| 20 32 0a 58 7d 3b 0a 58 | 0a 58 69 6e 74 20 61 66 | 2.X};.X|.Xint af|
|00001200| 6c 61 67 2c 20 63 66 6c | 61 67 2c 20 65 66 6c 61 |lag, cfl|ag, efla|
|00001210| 67 2c 20 76 66 6c 61 67 | 3b 0a 58 0a 58 6d 61 69 |g, vflag|;.X.Xmai|
|00001220| 6e 28 61 72 67 63 2c 20 | 61 72 67 76 29 0a 58 69 |n(argc, |argv).Xi|
|00001230| 6e 74 20 61 72 67 63 3b | 0a 58 63 68 61 72 20 2a |nt argc;|.Xchar *|
|00001240| 2a 61 72 67 76 3b 0a 58 | 7b 0a 58 09 72 65 67 69 |*argv;.X|{.X.regi|
|00001250| 73 74 65 72 20 69 6e 74 | 20 66 66 6c 61 67 2c 20 |ster int| fflag, |
|00001260| 69 3b 0a 58 09 72 65 67 | 69 73 74 65 72 20 63 68 |i;.X.reg|ister ch|
|00001270| 61 72 20 2a 70 3b 0a 58 | 09 63 68 61 72 20 2a 67 |ar *p;.X|.char *g|
|00001280| 65 74 65 6e 76 28 29 3b | 0a 58 0a 58 09 61 72 67 |etenv();|.X.X.arg|
|00001290| 63 2d 2d 3b 20 61 72 67 | 76 2b 2b 3b 0a 58 09 66 |c--; arg|v++;.X.f|
|000012a0| 69 6c 65 70 74 72 5b 30 | 5d 20 3d 20 28 63 68 61 |ileptr[0|] = (cha|
|000012b0| 72 20 2a 29 20 4e 55 4c | 4c 3b 0a 58 09 77 68 69 |r *) NUL|L;.X.whi|
|000012c0| 6c 65 20 28 61 72 67 63 | 20 3e 20 30 20 26 26 20 |le (argc| > 0 && |
|000012d0| 61 72 67 76 5b 30 5d 5b | 30 5d 20 3d 3d 20 27 2d |argv[0][|0] == '-|
|000012e0| 27 29 20 7b 0a 58 09 09 | 66 66 6c 61 67 20 3d 20 |') {.X..|fflag = |
|000012f0| 30 3b 09 09 2f 2a 20 74 | 6f 20 62 72 65 61 6b 20 |0;../* t|o break |
|00001300| 6f 75 74 20 6f 66 20 66 | 6f 6c 6c 6f 77 69 6e 67 |out of f|ollowing|
|00001310| 20 6c 6f 6f 70 2e 2e 2e | 20 2a 2f 0a 58 09 09 66 | loop...| */.X..f|
|00001320| 6f 72 20 28 69 20 3d 20 | 31 3b 20 61 72 67 76 5b |or (i = |1; argv[|
|00001330| 30 5d 5b 69 5d 20 21 3d | 20 27 5c 30 27 20 26 26 |0][i] !=| '\0' &&|
|00001340| 20 66 66 6c 61 67 20 3d | 3d 20 30 3b 20 69 2b 2b | fflag =|= 0; i++|
|00001350| 29 20 7b 0a 58 09 09 09 | 73 77 69 74 63 68 20 28 |) {.X...|switch (|
|00001360| 61 72 67 76 5b 30 5d 5b | 69 5d 29 20 7b 0a 58 09 |argv[0][|i]) {.X.|
|00001370| 09 09 63 61 73 65 20 27 | 61 27 3a 0a 58 09 09 09 |..case '|a':.X...|
|00001380| 09 61 66 6c 61 67 20 3d | 20 31 3b 0a 58 09 09 09 |.aflag =| 1;.X...|
|00001390| 09 62 72 65 61 6b 3b 0a | 58 09 09 09 63 61 73 65 |.break;.|X...case|
|000013a0| 20 27 63 27 3a 0a 58 09 | 09 09 09 63 66 6c 61 67 | 'c':.X.|...cflag|
|000013b0| 20 3d 20 31 3b 0a 58 09 | 09 09 09 62 72 65 61 6b | = 1;.X.|...break|
|000013c0| 3b 0a 58 09 09 09 63 61 | 73 65 20 27 65 27 3a 0a |;.X...ca|se 'e':.|
|000013d0| 58 09 09 09 09 65 66 6c | 61 67 20 3d 20 31 3b 0a |X....efl|ag = 1;.|
|000013e0| 58 09 09 09 09 62 72 65 | 61 6b 3b 0a 58 09 09 09 |X....bre|ak;.X...|
|000013f0| 63 61 73 65 20 27 66 27 | 3a 0a 58 09 09 09 09 69 |case 'f'|:.X....i|
|00001400| 66 20 28 61 72 67 63 20 | 3d 3d 20 31 29 20 7b 0a |f (argc |== 1) {.|
|00001410| 58 09 09 09 09 09 66 70 | 72 69 6e 74 66 28 73 74 |X.....fp|rintf(st|
|00001420| 64 65 72 72 2c 20 22 25 | 73 5c 6e 22 2c 20 55 53 |derr, "%|s\n", US|
|00001430| 41 47 45 29 3b 0a 58 09 | 09 09 09 09 65 78 69 74 |AGE);.X.|....exit|
|00001440| 28 31 29 3b 0a 58 09 09 | 09 09 7d 0a 58 09 09 09 |(1);.X..|..}.X...|
|00001450| 09 6d 6b 66 69 6c 65 6c | 69 73 74 28 61 72 67 76 |.mkfilel|ist(argv|
|00001460| 5b 31 5d 29 3b 0a 58 09 | 09 09 09 61 72 67 63 2d |[1]);.X.|...argc-|
|00001470| 2d 3b 0a 58 09 09 09 09 | 61 72 67 76 2b 2b 3b 0a |-;.X....|argv++;.|
|00001480| 58 09 09 09 09 66 66 6c | 61 67 20 3d 20 31 3b 09 |X....ffl|ag = 1;.|
|00001490| 09 2f 2a 20 62 72 65 61 | 6b 20 6f 75 74 20 6f 66 |./* brea|k out of|
|000014a0| 20 6c 6f 6f 70 20 2a 2f | 0a 58 09 09 09 09 62 72 | loop */|.X....br|
|000014b0| 65 61 6b 3b 0a 58 09 09 | 09 63 61 73 65 20 27 76 |eak;.X..|.case 'v|
|000014c0| 27 3a 0a 58 09 09 09 09 | 76 66 6c 61 67 20 3d 20 |':.X....|vflag = |
|000014d0| 31 3b 0a 58 09 09 09 09 | 62 72 65 61 6b 3b 0a 58 |1;.X....|break;.X|
|000014e0| 09 09 09 64 65 66 61 75 | 6c 74 3a 0a 58 09 09 09 |...defau|lt:.X...|
|000014f0| 09 66 70 72 69 6e 74 66 | 28 73 74 64 65 72 72 2c |.fprintf|(stderr,|
|00001500| 20 22 25 73 5c 6e 22 2c | 20 55 53 41 47 45 29 3b | "%s\n",| USAGE);|
|00001510| 0a 58 09 09 09 09 65 78 | 69 74 28 31 29 3b 0a 58 |.X....ex|it(1);.X|
|00001520| 09 09 09 7d 0a 58 09 09 | 7d 0a 58 09 09 61 72 67 |...}.X..|}.X..arg|
|00001530| 63 2d 2d 2c 20 61 72 67 | 76 2b 2b 3b 0a 58 09 7d |c--, arg|v++;.X.}|
|00001540| 0a 58 0a 58 09 69 66 20 | 28 28 70 20 3d 20 67 65 |.X.X.if |((p = ge|
|00001550| 74 65 6e 76 28 22 53 50 | 50 41 54 48 22 29 29 20 |tenv("SP|PATH")) |
|00001560| 21 3d 20 28 63 68 61 72 | 20 2a 29 20 4e 55 4c 4c |!= (char| *) NULL|
|00001570| 29 0a 58 09 09 6d 6b 66 | 69 6c 65 6c 69 73 74 28 |).X..mkf|ilelist(|
|00001580| 70 29 3b 0a 58 09 69 66 | 20 28 66 69 6c 65 70 74 |p);.X.if| (filept|
|00001590| 72 5b 30 5d 20 3d 3d 20 | 28 63 68 61 72 20 2a 29 |r[0] == |(char *)|
|000015a0| 20 4e 55 4c 4c 29 0a 58 | 09 09 6d 6b 66 69 6c 65 | NULL).X|..mkfile|
|000015b0| 6c 69 73 74 28 44 45 46 | 41 55 4c 54 5f 53 50 50 |list(DEF|AULT_SPP|
|000015c0| 41 54 48 29 3b 0a 58 09 | 69 66 20 28 76 66 6c 61 |ATH);.X.|if (vfla|
|000015d0| 67 29 20 7b 0a 58 09 09 | 70 72 69 6e 74 66 28 22 |g) {.X..|printf("|
|000015e0| 55 73 69 6e 67 20 64 69 | 63 74 69 6f 6e 61 72 69 |Using di|ctionari|
|000015f0| 65 73 3a 5c 6e 22 29 3b | 0a 58 09 09 66 6f 72 20 |es:\n");|.X..for |
|00001600| 28 69 20 3d 20 30 3b 20 | 66 69 6c 65 70 74 72 5b |(i = 0; |fileptr[|
|00001610| 69 5d 20 21 3d 20 28 63 | 68 61 72 20 2a 29 20 4e |i] != (c|har *) N|
|00001620| 55 4c 4c 3b 20 69 2b 2b | 29 0a 58 09 09 09 69 66 |ULL; i++|).X...if|
|00001630| 20 28 73 74 72 6c 65 6e | 28 66 69 6c 65 70 74 72 | (strlen|(fileptr|
|00001640| 5b 69 5d 29 20 3e 20 30 | 29 0a 58 09 09 09 09 70 |[i]) > 0|).X....p|
|00001650| 72 69 6e 74 66 28 22 5c | 74 25 73 5c 6e 22 2c 20 |rintf("\|t%s\n", |
|00001660| 66 69 6c 65 70 74 72 5b | 69 5d 29 3b 0a 58 09 7d |fileptr[|i]);.X.}|
|00001670| 0a 58 09 69 66 20 28 61 | 72 67 63 29 20 7b 0a 58 |.X.if (a|rgc) {.X|
|00001680| 09 09 66 6f 72 20 28 69 | 20 3d 20 30 3b 20 69 20 |..for (i| = 0; i |
|00001690| 3c 20 61 72 67 63 3b 20 | 69 2b 2b 29 20 7b 0a 58 |< argc; |i++) {.X|
|000016a0| 09 09 09 69 66 20 28 21 | 65 66 6c 61 67 29 0a 58 |...if (!|eflag).X|
|000016b0| 09 09 09 09 70 72 69 6e | 74 66 28 22 25 73 3a 5c |....prin|tf("%s:\|
|000016c0| 6e 22 2c 20 61 72 67 76 | 5b 69 5d 29 3b 0a 58 09 |n", argv|[i]);.X.|
|000016d0| 09 09 61 70 70 6c 79 28 | 61 72 67 76 5b 69 5d 29 |..apply(|argv[i])|
|000016e0| 3b 0a 58 09 09 09 69 66 | 20 28 21 65 66 6c 61 67 |;.X...if| (!eflag|
|000016f0| 29 0a 58 09 09 09 09 70 | 72 69 6e 74 66 28 22 5c |).X....p|rintf("\|
|00001700| 6e 22 29 3b 0a 58 09 09 | 7d 0a 58 09 7d 0a 58 09 |n");.X..|}.X.}.X.|
|00001710| 65 6c 73 65 20 7b 0a 58 | 09 09 69 6e 74 20 63 68 |else {.X|..int ch|
|00001720| 2c 20 6c 65 6e 3b 0a 58 | 0a 58 09 09 77 68 69 6c |, len;.X|.X..whil|
|00001730| 65 20 28 31 29 20 7b 0a | 58 09 09 09 70 72 69 6e |e (1) {.|X...prin|
|00001740| 74 66 28 22 57 6f 72 64 | 3f 20 22 29 3b 0a 58 09 |tf("Word|? ");.X.|
|00001750| 09 09 69 66 20 28 66 67 | 65 74 73 28 77 6f 72 64 |..if (fg|ets(word|
|00001760| 2c 20 73 69 7a 65 6f 66 | 28 77 6f 72 64 29 2c 20 |, sizeof|(word), |
|00001770| 73 74 64 69 6e 29 20 3d | 3d 20 28 63 68 61 72 20 |stdin) =|= (char |
|00001780| 2a 29 20 4e 55 4c 4c 29 | 20 7b 0a 58 09 09 09 09 |*) NULL)| {.X....|
|00001790| 70 72 69 6e 74 66 28 22 | 5c 6e 22 29 3b 0a 58 09 |printf("|\n");.X.|
|000017a0| 09 09 09 62 72 65 61 6b | 3b 0a 58 09 09 09 7d 0a |...break|;.X...}.|
|000017b0| 58 09 09 09 6c 65 6e 20 | 3d 20 73 74 72 6c 65 6e |X...len |= strlen|
|000017c0| 28 77 6f 72 64 29 3b 0a | 58 09 09 09 69 66 20 28 |(word);.|X...if (|
|000017d0| 77 6f 72 64 5b 6c 65 6e | 20 2d 20 31 5d 20 21 3d |word[len| - 1] !=|
|000017e0| 20 27 5c 6e 27 29 20 7b | 0a 58 09 09 09 09 66 70 | '\n') {|.X....fp|
|000017f0| 72 69 6e 74 66 28 73 74 | 64 65 72 72 2c 20 22 73 |rintf(st|derr, "s|
|00001800| 70 3a 20 57 6f 72 64 20 | 74 6f 6f 20 6c 6f 6e 67 |p: Word |too long|
|00001810| 3a 20 25 73 22 2c 20 77 | 6f 72 64 29 3b 0a 58 09 |: %s", w|ord);.X.|
|00001820| 09 09 09 77 68 69 6c 65 | 20 28 28 63 68 20 3d 20 |...while| ((ch = |
|00001830| 67 65 74 63 68 61 72 28 | 29 29 20 21 3d 20 27 5c |getchar(|)) != '\|
|00001840| 6e 27 29 09 2f 2a 20 66 | 6c 75 73 68 20 72 65 73 |n')./* f|lush res|
|00001850| 74 20 6f 66 20 6c 69 6e | 65 20 2a 2f 0a 58 09 09 |t of lin|e */.X..|
|00001860| 09 09 09 70 75 74 63 28 | 63 68 2c 20 73 74 64 65 |...putc(|ch, stde|
|00001870| 72 72 29 3b 0a 58 09 09 | 09 09 70 75 74 63 28 27 |rr);.X..|..putc('|
|00001880| 5c 6e 27 2c 20 73 74 64 | 65 72 72 29 3b 0a 58 09 |\n', std|err);.X.|
|00001890| 09 09 09 63 6f 6e 74 69 | 6e 75 65 3b 0a 58 09 09 |...conti|nue;.X..|
|000018a0| 09 7d 0a 58 09 09 09 77 | 6f 72 64 5b 2d 2d 6c 65 |.}.X...w|ord[--le|
|000018b0| 6e 5d 20 3d 20 27 5c 30 | 27 3b 0a 58 09 09 09 69 |n] = '\0|';.X...i|
|000018c0| 66 20 28 6c 65 6e 20 3e | 20 4d 41 58 57 4f 52 44 |f (len >| MAXWORD|
|000018d0| 4c 45 4e 29 20 7b 0a 58 | 09 09 09 09 66 70 72 69 |LEN) {.X|....fpri|
|000018e0| 6e 74 66 28 73 74 64 65 | 72 72 2c 20 22 73 70 3a |ntf(stde|rr, "sp:|
|000018f0| 20 57 6f 72 64 20 74 6f | 6f 20 6c 6f 6e 67 3a 20 | Word to|o long: |
|00001900| 25 73 5c 6e 22 2c 20 77 | 6f 72 64 29 3b 0a 58 09 |%s\n", w|ord);.X.|
|00001910| 09 09 09 63 6f 6e 74 69 | 6e 75 65 3b 0a 58 09 09 |...conti|nue;.X..|
|00001920| 09 7d 0a 58 0a 58 09 09 | 09 61 70 70 6c 79 28 77 |.}.X.X..|.apply(w|
|00001930| 6f 72 64 29 3b 0a 58 09 | 09 09 69 66 20 28 21 65 |ord);.X.|..if (!e|
|00001940| 66 6c 61 67 29 0a 58 09 | 09 09 09 70 72 69 6e 74 |flag).X.|...print|
|00001950| 66 28 22 5c 6e 22 29 3b | 0a 58 09 09 7d 0a 58 09 |f("\n");|.X..}.X.|
|00001960| 7d 0a 58 7d 0a 58 0a 58 | 2f 2a 0a 58 20 2a 20 41 |}.X}.X.X|/*.X * A|
|00001970| 70 70 6c 79 20 74 68 65 | 20 53 6f 75 6e 64 65 78 |pply the| Soundex|
|00001980| 20 73 65 61 72 63 68 20 | 66 6f 72 20 61 20 77 6f | search |for a wo|
|00001990| 72 64 20 74 6f 20 65 61 | 63 68 20 64 69 63 74 69 |rd to ea|ch dicti|
|000019a0| 6f 6e 61 72 79 20 69 6e | 20 74 75 72 6e 0a 58 20 |onary in| turn.X |
|000019b0| 2a 20 4e 6f 74 65 20 74 | 68 61 74 20 27 44 42 4d |* Note t|hat 'DBM|
|000019c0| 49 4e 49 54 27 20 6f 70 | 65 6e 73 20 62 6f 74 68 |INIT' op|ens both|
|000019d0| 20 74 68 65 20 27 2e 64 | 69 72 27 20 61 6e 64 20 | the '.d|ir' and |
|000019e0| 74 68 65 20 27 2e 70 61 | 67 27 20 66 69 6c 65 73 |the '.pa|g' files|
|000019f0| 0a 58 20 2a 20 61 6e 64 | 20 77 65 20 6d 75 73 74 |.X * and| we must|
|00001a00| 20 63 6c 6f 73 65 20 74 | 68 65 6d 20 74 6f 20 61 | close t|hem to a|
|00001a10| 76 6f 69 64 20 72 75 6e | 6e 69 6e 67 20 6f 75 74 |void run|ning out|
|00001a20| 20 6f 66 20 66 69 6c 65 | 20 64 65 73 63 72 69 70 | of file| descrip|
|00001a30| 74 6f 72 73 0a 58 20 2a | 0a 58 20 2a 20 54 68 69 |tors.X *|.X * Thi|
|00001a40| 73 20 72 6f 75 74 69 6e | 65 20 67 65 74 73 20 63 |s routin|e gets c|
|00001a50| 61 6c 6c 65 64 20 65 61 | 63 68 20 74 69 6d 65 20 |alled ea|ch time |
|00001a60| 61 20 77 6f 72 64 20 69 | 73 20 6c 6f 6f 6b 65 64 |a word i|s looked|
|00001a70| 20 75 70 20 61 6e 64 20 | 74 68 65 72 65 66 6f 72 | up and |therefor|
|00001a80| 65 0a 58 20 2a 20 74 68 | 65 20 64 62 6d 20 66 69 |e.X * th|e dbm fi|
|00001a90| 6c 65 73 20 6d 61 79 20 | 62 65 20 72 65 70 65 61 |les may |be repea|
|00001aa0| 74 65 64 6c 79 20 6f 70 | 65 6e 65 64 20 61 6e 64 |tedly op|ened and|
|00001ab0| 20 63 6c 6f 73 65 64 2e | 20 20 53 69 6e 63 65 20 | closed.| Since |
|00001ac0| 74 68 65 20 76 61 73 74 | 20 6d 61 6a 6f 72 69 74 |the vast| majorit|
|00001ad0| 79 0a 58 20 2a 20 6f 66 | 20 74 68 65 20 74 69 6d |y.X * of| the tim|
|00001ae0| 65 20 74 68 69 73 20 70 | 72 6f 67 72 61 6d 20 69 |e this p|rogram i|
|00001af0| 73 20 69 6e 76 6f 6b 65 | 64 20 66 6f 72 20 6a 75 |s invoke|d for ju|
|00001b00| 73 74 20 61 20 73 69 6e | 67 6c 65 20 77 6f 72 64 |st a sin|gle word|
|00001b10| 20 69 74 20 64 6f 65 73 | 6e 27 74 20 73 65 65 6d | it does|n't seem|
|00001b20| 0a 58 20 2a 20 77 6f 72 | 74 68 77 68 69 6c 65 20 |.X * wor|thwhile |
|00001b30| 74 6f 20 64 6f 20 74 68 | 65 20 72 69 67 68 74 20 |to do th|e right |
|00001b40| 74 68 69 6e 67 20 62 79 | 20 73 61 76 69 6e 67 20 |thing by| saving |
|00001b50| 66 69 6c 65 20 64 65 73 | 63 72 69 70 74 6f 72 73 |file des|criptors|
|00001b60| 2f 44 42 4d 20 70 6f 69 | 6e 74 65 72 73 2e 0a 58 |/DBM poi|nters..X|
|00001b70| 20 2a 20 54 68 65 72 65 | 20 70 72 6f 62 61 62 6c | * There| probabl|
|00001b80| 79 20 77 6f 6e 27 74 20 | 62 65 20 6d 6f 72 65 20 |y won't |be more |
|00001b90| 74 68 61 6e 20 74 77 6f | 20 64 69 63 74 69 6f 6e |than two| diction|
|00001ba0| 61 72 69 65 73 20 69 6e | 20 75 73 65 20 61 6e 79 |aries in| use any|
|00001bb0| 77 61 79 2e 0a 58 20 2a | 2f 0a 58 61 70 70 6c 79 |way..X *|/.Xapply|
|00001bc0| 28 77 6f 72 64 29 0a 58 | 63 68 61 72 20 2a 77 6f |(word).X|char *wo|
|00001bd0| 72 64 3b 0a 58 7b 0a 58 | 09 72 65 67 69 73 74 65 |rd;.X{.X|.registe|
|00001be0| 72 20 69 6e 74 20 63 6f | 64 65 2c 20 69 2c 20 6e |r int co|de, i, n|
|00001bf0| 6f 64 69 63 74 73 3b 0a | 58 0a 58 09 6e 6d 61 74 |odicts;.|X.X.nmat|
|00001c00| 63 68 65 64 20 3d 20 30 | 3b 0a 58 09 77 6f 72 64 |ched = 0|;.X.word|
|00001c10| 6c 69 73 74 70 74 72 20 | 3d 20 77 6f 72 64 6c 69 |listptr |= wordli|
|00001c20| 73 74 3b 0a 58 09 69 66 | 20 28 28 63 6f 64 65 20 |st;.X.if| ((code |
|00001c30| 3d 20 73 6f 75 6e 64 65 | 78 28 77 6f 72 64 2c 20 |= sounde|x(word, |
|00001c40| 33 29 29 20 3d 3d 20 42 | 41 44 5f 57 4f 52 44 29 |3)) == B|AD_WORD)|
|00001c50| 0a 58 09 09 72 65 74 75 | 72 6e 3b 0a 58 09 6e 6f |.X..retu|rn;.X.no|
|00001c60| 64 69 63 74 73 20 3d 20 | 31 3b 0a 58 09 66 6f 72 |dicts = |1;.X.for|
|00001c70| 20 28 69 20 3d 20 30 3b | 20 66 69 6c 65 70 74 72 | (i = 0;| fileptr|
|00001c80| 5b 69 5d 20 21 3d 20 28 | 63 68 61 72 20 2a 29 20 |[i] != (|char *) |
|00001c90| 4e 55 4c 4c 3b 20 69 2b | 2b 29 20 7b 0a 58 09 09 |NULL; i+|+) {.X..|
|00001ca0| 69 66 20 28 73 74 72 6c | 65 6e 28 66 69 6c 65 70 |if (strl|en(filep|
|00001cb0| 74 72 5b 69 5d 29 20 3d | 3d 20 30 29 0a 58 09 09 |tr[i]) =|= 0).X..|
|00001cc0| 09 63 6f 6e 74 69 6e 75 | 65 3b 0a 58 09 09 69 66 |.continu|e;.X..if|
|00001cd0| 20 28 44 42 4d 49 4e 49 | 54 28 66 69 6c 65 70 74 | (DBMINI|T(filept|
|00001ce0| 72 5b 69 5d 2c 20 4f 5f | 52 44 4f 4e 4c 59 29 20 |r[i], O_|RDONLY) |
|00001cf0| 21 3d 20 2d 31 29 20 7b | 0a 58 09 09 09 70 72 6f |!= -1) {|.X...pro|
|00001d00| 63 28 63 6f 64 65 29 3b | 0a 58 09 09 09 6e 6f 64 |c(code);|.X...nod|
|00001d10| 69 63 74 73 20 3d 20 30 | 3b 0a 58 09 09 7d 0a 58 |icts = 0|;.X..}.X|
|00001d20| 09 09 44 42 4d 43 4c 4f | 53 45 28 29 3b 0a 58 09 |..DBMCLO|SE();.X.|
|00001d30| 7d 0a 58 09 69 66 20 28 | 6e 6f 64 69 63 74 73 29 |}.X.if (|nodicts)|
|00001d40| 20 7b 0a 58 09 09 66 70 | 72 69 6e 74 66 28 73 74 | {.X..fp|rintf(st|
|00001d50| 64 65 72 72 2c 20 22 73 | 70 3a 20 43 61 6e 27 74 |derr, "s|p: Can't|
|00001d60| 20 6f 70 65 6e 20 61 6e | 79 20 64 69 63 74 69 6f | open an|y dictio|
|00001d70| 6e 61 72 69 65 73 5c 6e | 22 29 3b 0a 58 09 09 65 |naries\n|");.X..e|
|00001d80| 78 69 74 28 31 29 3b 0a | 58 09 7d 0a 58 09 69 66 |xit(1);.|X.}.X.if|
|00001d90| 20 28 76 66 6c 61 67 20 | 26 26 20 21 65 66 6c 61 | (vflag |&& !efla|
|00001da0| 67 20 26 26 20 6e 6d 61 | 74 63 68 65 64 20 3d 3d |g && nma|tched ==|
|00001db0| 20 30 29 0a 58 09 09 70 | 72 69 6e 74 66 28 22 25 | 0).X..p|rintf("%|
|00001dc0| 73 3a 20 6e 6f 20 6d 61 | 74 63 68 5c 6e 22 2c 20 |s: no ma|tch\n", |
|00001dd0| 77 6f 72 64 29 3b 0a 58 | 09 65 6c 73 65 0a 58 09 |word);.X|.else.X.|
|00001de0| 09 63 68 6f 6f 73 65 28 | 77 6f 72 64 29 3b 0a 58 |.choose(|word);.X|
|00001df0| 7d 0a 58 0a 58 2f 2a 0a | 58 20 2a 20 4c 6f 6f 6b |}.X.X/*.|X * Look|
|00001e00| 20 74 68 65 20 77 6f 72 | 64 20 75 70 20 69 6e 20 | the wor|d up in |
|00001e10| 74 68 65 20 63 75 72 72 | 65 6e 74 20 64 69 63 74 |the curr|ent dict|
|00001e20| 69 6f 6e 61 72 79 0a 58 | 20 2a 20 61 6e 64 20 73 |ionary.X| * and s|
|00001e30| 61 76 65 20 61 6c 6c 20 | 74 68 65 20 6d 61 74 63 |ave all |the matc|
|00001e40| 68 65 73 0a 58 20 2a 20 | 4e 6f 74 65 20 74 68 61 |hes.X * |Note tha|
|00001e50| 74 20 6f 6e 6c 79 20 74 | 68 72 65 65 20 64 69 67 |t only t|hree dig|
|00001e60| 69 74 73 20 61 72 65 20 | 6f 66 20 74 68 65 20 53 |its are |of the S|
|00001e70| 6f 75 6e 64 65 78 20 63 | 6f 64 65 20 61 72 65 20 |oundex c|ode are |
|00001e80| 73 74 6f 72 65 64 0a 58 | 20 2a 20 69 6e 20 61 20 |stored.X| * in a |
|00001e90| 64 69 63 74 69 6f 6e 61 | 72 79 0a 58 20 2a 2f 0a |dictiona|ry.X */.|
|00001ea0| 58 70 72 6f 63 28 73 6f | 75 6e 64 65 78 29 0a 58 |Xproc(so|undex).X|
|00001eb0| 69 6e 74 20 73 6f 75 6e | 64 65 78 3b 0a 58 7b 0a |int soun|dex;.X{.|
|00001ec0| 58 09 72 65 67 69 73 74 | 65 72 20 69 6e 74 20 63 |X.regist|er int c|
|00001ed0| 2c 20 6c 65 6e 3b 0a 58 | 09 64 61 74 75 6d 20 64 |, len;.X|.datum d|
|00001ee0| 62 6d 5f 6b 65 79 2c 20 | 64 62 6d 5f 63 6f 6e 74 |bm_key, |dbm_cont|
|00001ef0| 65 6e 74 3b 0a 58 09 6b | 65 79 5f 74 20 2a 6b 65 |ent;.X.k|ey_t *ke|
|00001f00| 79 2c 20 6b 65 79 76 65 | 63 5b 4b 45 59 53 49 5a |y, keyve|c[KEYSIZ|
|00001f10| 45 5d 3b 0a 58 09 63 68 | 61 72 20 2a 6d 6b 5f 77 |E];.X.ch|ar *mk_w|
|00001f20| 6f 72 64 28 29 2c 20 2a | 70 3b 0a 58 0a 58 09 6b |ord(), *|p;.X.X.k|
|00001f30| 65 79 20 3d 20 6b 65 79 | 76 65 63 3b 0a 58 09 64 |ey = key|vec;.X.d|
|00001f40| 62 6d 5f 6b 65 79 2e 64 | 70 74 72 20 3d 20 28 63 |bm_key.d|ptr = (c|
|00001f50| 68 61 72 20 2a 29 20 6b | 65 79 3b 0a 58 09 64 62 |har *) k|ey;.X.db|
|00001f60| 6d 5f 6b 65 79 2e 64 73 | 69 7a 65 20 3d 20 4b 45 |m_key.ds|ize = KE|
|00001f70| 59 53 49 5a 45 3b 0a 58 | 09 63 20 3d 20 30 3b 0a |YSIZE;.X|.c = 0;.|
|00001f80| 58 09 77 68 69 6c 65 20 | 28 31 29 20 7b 0a 58 09 |X.while |(1) {.X.|
|00001f90| 09 6d 6b 5f 6b 65 79 28 | 6b 65 79 2c 20 73 6f 75 |.mk_key(|key, sou|
|00001fa0| 6e 64 65 78 2c 20 63 29 | 3b 0a 58 09 09 64 62 6d |ndex, c)|;.X..dbm|
|00001fb0| 5f 63 6f 6e 74 65 6e 74 | 20 3d 20 46 45 54 43 48 |_content| = FETCH|
|00001fc0| 28 64 62 6d 5f 6b 65 79 | 29 3b 0a 58 0a 58 09 09 |(dbm_key|);.X.X..|
|00001fd0| 69 66 20 28 64 62 6d 5f | 63 6f 6e 74 65 6e 74 2e |if (dbm_|content.|
|00001fe0| 64 70 74 72 20 3d 3d 20 | 30 29 0a 58 09 09 09 62 |dptr == |0).X...b|
|00001ff0| 72 65 61 6b 3b 0a 58 0a | 58 09 09 69 66 20 28 49 |reak;.X.|X..if (I|
|00002000| 53 5f 44 45 4c 45 54 45 | 44 28 64 62 6d 5f 63 6f |S_DELETE|D(dbm_co|
|00002010| 6e 74 65 6e 74 29 29 20 | 7b 0a 58 09 09 09 69 66 |ntent)) |{.X...if|
|00002020| 20 28 2b 2b 63 20 3e 20 | 4d 41 58 43 4f 55 4e 54 | (++c > |MAXCOUNT|
|00002030| 29 20 7b 0a 58 09 09 09 | 09 66 70 72 69 6e 74 66 |) {.X...|.fprintf|
|00002040| 28 73 74 64 65 72 72 2c | 20 22 73 70 3a 20 65 6e |(stderr,| "sp: en|
|00002050| 74 72 79 20 63 6f 75 6e | 74 20 6f 76 65 72 66 6c |try coun|t overfl|
|00002060| 6f 77 5c 6e 22 29 3b 0a | 58 09 09 09 09 65 78 69 |ow\n");.|X....exi|
|00002070| 74 28 31 29 3b 0a 58 09 | 09 09 7d 0a 58 09 09 09 |t(1);.X.|..}.X...|
|00002080| 63 6f 6e 74 69 6e 75 65 | 3b 0a 58 09 09 7d 0a 58 |continue|;.X..}.X|
|00002090| 0a 58 09 09 69 66 20 28 | 6e 6d 61 74 63 68 65 64 |.X..if (|nmatched|
|000020a0| 20 3d 3d 20 4d 41 58 57 | 4f 52 44 53 29 20 7b 0a | == MAXW|ORDS) {.|
|000020b0| 58 09 09 09 66 70 72 69 | 6e 74 66 28 73 74 64 65 |X...fpri|ntf(stde|
|000020c0| 72 72 2c 20 22 73 70 3a | 20 54 6f 6f 20 6d 61 6e |rr, "sp:| Too man|
|000020d0| 79 20 6d 61 74 63 68 65 | 73 5c 6e 22 29 3b 0a 58 |y matche|s\n");.X|
|000020e0| 09 09 09 65 78 69 74 28 | 31 29 3b 0a 58 09 09 7d |...exit(|1);.X..}|
|000020f0| 0a 58 0a 58 09 09 70 20 | 3d 20 6d 6b 5f 77 6f 72 |.X.X..p |= mk_wor|
|00002100| 64 28 64 62 6d 5f 63 6f | 6e 74 65 6e 74 2e 64 70 |d(dbm_co|ntent.dp|
|00002110| 74 72 2c 20 64 62 6d 5f | 63 6f 6e 74 65 6e 74 2e |tr, dbm_|content.|
|00002120| 64 73 69 7a 65 2c 20 73 | 6f 75 6e 64 65 78 29 3b |dsize, s|oundex);|
|00002130| 0a 58 09 09 6c 65 6e 20 | 3d 20 73 74 72 6c 65 6e |.X..len |= strlen|
|00002140| 28 70 29 3b 0a 58 09 09 | 69 66 20 28 77 6f 72 64 |(p);.X..|if (word|
|00002150| 6c 69 73 74 70 74 72 20 | 2b 20 6c 65 6e 20 3e 3d |listptr |+ len >=|
|00002160| 20 26 77 6f 72 64 6c 69 | 73 74 5b 57 4f 52 44 53 | &wordli|st[WORDS|
|00002170| 50 41 43 45 5d 29 20 7b | 0a 58 09 09 09 66 70 72 |PACE]) {|.X...fpr|
|00002180| 69 6e 74 66 28 73 74 64 | 65 72 72 2c 20 22 73 70 |intf(std|err, "sp|
|00002190| 3a 20 4f 75 74 20 6f 66 | 20 73 70 61 63 65 20 66 |: Out of| space f|
|000021a0| 6f 72 20 77 6f 72 64 73 | 5c 6e 22 29 3b 0a 58 09 |or words|\n");.X.|
|000021b0| 09 09 65 78 69 74 28 31 | 29 3b 0a 58 09 09 7d 0a |..exit(1|);.X..}.|
|000021c0| 58 09 09 73 74 72 6e 63 | 70 79 28 77 6f 72 64 6c |X..strnc|py(wordl|
|000021d0| 69 73 74 70 74 72 2c 20 | 70 2c 20 6c 65 6e 29 3b |istptr, |p, len);|
|000021e0| 0a 58 09 09 77 6f 72 64 | 6c 69 73 74 70 74 72 5b |.X..word|listptr[|
|000021f0| 6c 65 6e 5d 20 3d 20 27 | 5c 30 27 3b 0a 58 09 09 |len] = '|\0';.X..|
|00002200| 77 6f 72 64 70 74 72 5b | 6e 6d 61 74 63 68 65 64 |wordptr[|nmatched|
|00002210| 2b 2b 5d 20 3d 20 77 6f | 72 64 6c 69 73 74 70 74 |++] = wo|rdlistpt|
|00002220| 72 3b 0a 58 09 09 77 6f | 72 64 6c 69 73 74 70 74 |r;.X..wo|rdlistpt|
|00002230| 72 20 2b 3d 20 6c 65 6e | 20 2b 20 31 3b 0a 58 09 |r += len| + 1;.X.|
|00002240| 09 69 66 20 28 2b 2b 63 | 20 3e 20 4d 41 58 43 4f |.if (++c| > MAXCO|
|00002250| 55 4e 54 29 20 7b 0a 58 | 09 09 09 66 70 72 69 6e |UNT) {.X|...fprin|
|00002260| 74 66 28 73 74 64 65 72 | 72 2c 20 22 73 70 3a 20 |tf(stder|r, "sp: |
|00002270| 65 6e 74 72 79 20 63 6f | 75 6e 74 20 6f 76 65 72 |entry co|unt over|
|00002280| 66 6c 6f 77 5c 6e 22 29 | 3b 0a 58 09 09 09 65 78 |flow\n")|;.X...ex|
|00002290| 69 74 28 31 29 3b 0a 58 | 09 09 7d 0a 58 09 7d 0a |it(1);.X|..}.X.}.|
|000022a0| 58 7d 0a 58 0a 58 2f 2a | 0a 58 20 2a 20 53 65 6c |X}.X.X/*|.X * Sel|
|000022b0| 65 63 74 20 61 6e 64 20 | 70 72 69 6e 74 20 74 68 |ect and |print th|
|000022c0| 6f 73 65 20 77 6f 72 64 | 73 20 77 68 69 63 68 20 |ose word|s which |
|000022d0| 77 65 20 63 6f 6e 73 69 | 64 65 72 0a 58 20 2a 20 |we consi|der.X * |
|000022e0| 74 6f 20 68 61 76 65 20 | 6d 61 74 63 68 65 64 20 |to have |matched |
|000022f0| 27 77 6f 72 64 27 0a 58 | 20 2a 2f 0a 58 63 68 6f |'word'.X| */.Xcho|
|00002300| 6f 73 65 28 77 6f 72 64 | 29 0a 58 72 65 67 69 73 |ose(word|).Xregis|
|00002310| 74 65 72 20 63 68 61 72 | 20 2a 77 6f 72 64 3b 0a |ter char| *word;.|
|00002320| 58 7b 0a 58 09 72 65 67 | 69 73 74 65 72 20 69 6e |X{.X.reg|ister in|
|00002330| 74 20 63 2c 20 63 6f 64 | 65 2c 20 69 2c 20 6c 65 |t c, cod|e, i, le|
|00002340| 6e 2c 20 6d 63 6f 75 6e | 74 2c 20 77 6f 72 64 6c |n, mcoun|t, wordl|
|00002350| 65 6e 3b 0a 58 09 72 65 | 67 69 73 74 65 72 20 63 |en;.X.re|gister c|
|00002360| 68 61 72 20 2a 70 3b 0a | 58 09 69 6e 74 20 63 6f |har *p;.|X.int co|
|00002370| 6d 70 61 72 28 29 3b 0a | 58 0a 58 09 63 6f 64 65 |mpar();.|X.X.code|
|00002380| 20 3d 20 73 6f 75 6e 64 | 65 78 28 77 6f 72 64 2c | = sound|ex(word,|
|00002390| 20 34 29 3b 0a 58 09 71 | 73 6f 72 74 28 77 6f 72 | 4);.X.q|sort(wor|
|000023a0| 64 70 74 72 2c 20 6e 6d | 61 74 63 68 65 64 2c 20 |dptr, nm|atched, |
|000023b0| 73 69 7a 65 6f 66 28 63 | 68 61 72 20 2a 29 2c 20 |sizeof(c|har *), |
|000023c0| 63 6f 6d 70 61 72 29 3b | 0a 58 09 63 20 3d 20 72 |compar);|.X.c = r|
|000023d0| 61 6e 67 65 28 77 6f 72 | 64 29 3b 0a 58 09 77 6f |ange(wor|d);.X.wo|
|000023e0| 72 64 6c 65 6e 20 3d 20 | 73 74 72 6c 65 6e 28 77 |rdlen = |strlen(w|
|000023f0| 6f 72 64 29 3b 0a 58 09 | 6d 63 6f 75 6e 74 20 3d |ord);.X.|mcount =|
|00002400| 20 30 3b 0a 58 09 66 6f | 72 20 28 69 20 3d 20 30 | 0;.X.fo|r (i = 0|
|00002410| 3b 20 69 20 3c 20 6e 6d | 61 74 63 68 65 64 3b 20 |; i < nm|atched; |
|00002420| 69 2b 2b 29 20 7b 0a 58 | 09 09 70 20 3d 20 77 6f |i++) {.X|..p = wo|
|00002430| 72 64 70 74 72 5b 69 5d | 3b 0a 58 09 09 69 66 20 |rdptr[i]|;.X..if |
|00002440| 28 73 74 72 6d 61 74 63 | 68 28 77 6f 72 64 2c 20 |(strmatc|h(word, |
|00002450| 70 29 20 3d 3d 20 30 29 | 20 7b 0a 58 09 09 09 70 |p) == 0)| {.X...p|
|00002460| 72 69 6e 74 66 28 22 58 | 22 29 3b 0a 58 09 09 09 |rintf("X|");.X...|
|00002470| 69 66 20 28 65 66 6c 61 | 67 29 20 7b 0a 58 09 09 |if (efla|g) {.X..|
|00002480| 09 09 70 72 69 6e 74 66 | 28 22 20 25 73 5c 6e 22 |..printf|(" %s\n"|
|00002490| 2c 20 77 6f 72 64 29 3b | 0a 58 09 09 09 09 72 65 |, word);|.X....re|
|000024a0| 74 75 72 6e 3b 0a 58 09 | 09 09 7d 0a 58 09 09 7d |turn;.X.|..}.X..}|
|000024b0| 0a 58 09 09 65 6c 73 65 | 20 69 66 20 28 65 66 6c |.X..else| if (efl|
|000024c0| 61 67 29 0a 58 09 09 09 | 63 6f 6e 74 69 6e 75 65 |ag).X...|continue|
|000024d0| 3b 0a 58 09 09 65 6c 73 | 65 20 69 66 20 28 73 6f |;.X..els|e if (so|
|000024e0| 75 6e 64 65 78 28 70 2c | 20 34 29 20 3d 3d 20 63 |undex(p,| 4) == c|
|000024f0| 6f 64 65 29 0a 58 09 09 | 09 70 72 69 6e 74 66 28 |ode).X..|.printf(|
|00002500| 22 21 22 29 3b 0a 58 09 | 09 65 6c 73 65 20 69 66 |"!");.X.|.else if|
|00002510| 20 28 61 66 6c 61 67 20 | 26 26 0a 58 09 09 09 28 | (aflag |&&.X...(|
|00002520| 77 6f 72 64 6c 65 6e 20 | 3c 20 28 6c 65 6e 20 3d |wordlen |< (len =|
|00002530| 20 73 74 72 6c 65 6e 28 | 70 29 29 20 2d 20 63 20 | strlen(|p)) - c |
|00002540| 7c 7c 20 6c 65 6e 20 3e | 20 77 6f 72 64 6c 65 6e ||| len >| wordlen|
|00002550| 20 2b 20 63 29 29 0a 58 | 09 09 09 70 72 69 6e 74 | + c)).X|...print|
|00002560| 66 28 22 20 22 29 3b 0a | 58 09 09 65 6c 73 65 20 |f(" ");.|X..else |
|00002570| 69 66 20 28 21 63 66 6c | 61 67 29 0a 58 09 09 09 |if (!cfl|ag).X...|
|00002580| 70 72 69 6e 74 66 28 22 | 2a 22 29 3b 0a 58 09 09 |printf("|*");.X..|
|00002590| 65 6c 73 65 0a 58 09 09 | 09 63 6f 6e 74 69 6e 75 |else.X..|.continu|
|000025a0| 65 3b 0a 58 09 09 70 72 | 69 6e 74 66 28 22 25 33 |e;.X..pr|intf("%3|
|000025b0| 64 2e 20 25 73 5c 6e 22 | 2c 20 6d 63 6f 75 6e 74 |d. %s\n"|, mcount|
|000025c0| 20 2b 20 31 2c 20 70 29 | 3b 0a 58 09 09 6d 63 6f | + 1, p)|;.X..mco|
|000025d0| 75 6e 74 2b 2b 3b 0a 58 | 09 7d 0a 58 09 69 66 20 |unt++;.X|.}.X.if |
|000025e0| 28 76 66 6c 61 67 29 0a | 58 09 09 70 72 69 6e 74 |(vflag).|X..print|
|000025f0| 66 28 22 28 25 64 20 74 | 6f 74 61 6c 20 6d 61 74 |f("(%d t|otal mat|
|00002600| 63 68 65 73 29 5c 6e 22 | 2c 20 6e 6d 61 74 63 68 |ches)\n"|, nmatch|
|00002610| 65 64 29 3b 0a 58 7d 0a | 58 0a 58 2f 2a 0a 58 20 |ed);.X}.|X.X/*.X |
|00002620| 2a 20 43 6f 6d 70 75 74 | 65 20 61 6e 20 27 6e 27 |* Comput|e an 'n'|
|00002630| 20 64 69 67 69 74 20 53 | 6f 75 6e 64 65 78 20 63 | digit S|oundex c|
|00002640| 6f 64 65 20 66 6f 72 20 | 27 77 6f 72 64 27 20 0a |ode for |'word' .|
|00002650| 58 20 2a 20 53 65 65 20 | 6d 6b 73 70 2e 63 0a 58 |X * See |mksp.c.X|
|00002660| 20 2a 2f 0a 58 73 6f 75 | 6e 64 65 78 28 77 6f 72 | */.Xsou|ndex(wor|
|00002670| 64 2c 20 6e 29 0a 58 72 | 65 67 69 73 74 65 72 20 |d, n).Xr|egister |
|00002680| 63 68 61 72 20 2a 77 6f | 72 64 3b 0a 58 69 6e 74 |char *wo|rd;.Xint|
|00002690| 20 6e 3b 0a 58 7b 0a 58 | 09 72 65 67 69 73 74 65 | n;.X{.X|.registe|
|000026a0| 72 20 69 6e 74 20 63 2c | 20 64 69 67 69 74 5f 70 |r int c,| digit_p|
|000026b0| 61 72 74 2c 20 70 72 65 | 76 69 6f 75 73 5f 63 6f |art, pre|vious_co|
|000026c0| 64 65 2c 20 73 6f 75 6e | 64 65 78 5f 6c 65 6e 67 |de, soun|dex_leng|
|000026d0| 74 68 3b 0a 58 09 72 65 | 67 69 73 74 65 72 20 63 |th;.X.re|gister c|
|000026e0| 68 61 72 20 2a 70 2c 20 | 2a 77 3b 0a 58 09 63 68 |har *p, |*w;.X.ch|
|000026f0| 61 72 20 77 63 6f 70 79 | 5b 4d 41 58 57 4f 52 44 |ar wcopy|[MAXWORD|
|00002700| 4c 45 4e 20 2b 20 32 5d | 3b 0a 58 0a 58 09 73 74 |LEN + 2]|;.X.X.st|
|00002710| 72 63 70 79 28 77 63 6f | 70 79 2c 20 77 6f 72 64 |rcpy(wco|py, word|
|00002720| 29 3b 0a 58 09 70 20 3d | 20 77 20 3d 20 77 63 6f |);.X.p =| w = wco|
|00002730| 70 79 3b 0a 58 09 77 68 | 69 6c 65 20 28 2a 70 20 |py;.X.wh|ile (*p |
|00002740| 21 3d 20 27 5c 30 27 29 | 20 7b 0a 58 09 09 69 66 |!= '\0')| {.X..if|
|00002750| 20 28 69 73 75 70 70 65 | 72 28 2a 70 29 29 0a 58 | (isuppe|r(*p)).X|
|00002760| 09 09 09 2a 70 20 3d 20 | 74 6f 6c 6f 77 65 72 28 |...*p = |tolower(|
|00002770| 2a 70 29 3b 0a 58 09 09 | 70 2b 2b 3b 0a 58 09 7d |*p);.X..|p++;.X.}|
|00002780| 0a 58 09 69 66 20 28 21 | 69 73 61 6c 70 68 61 28 |.X.if (!|isalpha(|
|00002790| 2a 77 29 29 20 7b 0a 58 | 09 09 66 70 72 69 6e 74 |*w)) {.X|..fprint|
|000027a0| 66 28 73 74 64 65 72 72 | 2c 20 22 73 70 3a 20 49 |f(stderr|, "sp: I|
|000027b0| 6d 70 72 6f 70 65 72 20 | 77 6f 72 64 3a 20 25 73 |mproper |word: %s|
|000027c0| 5c 6e 22 2c 20 77 6f 72 | 64 29 3b 0a 58 09 09 72 |\n", wor|d);.X..r|
|000027d0| 65 74 75 72 6e 28 42 41 | 44 5f 57 4f 52 44 29 3b |eturn(BA|D_WORD);|
|000027e0| 0a 58 09 7d 0a 58 09 64 | 69 67 69 74 5f 70 61 72 |.X.}.X.d|igit_par|
|000027f0| 74 20 3d 20 30 3b 0a 58 | 09 73 6f 75 6e 64 65 78 |t = 0;.X|.soundex|
|00002800| 5f 6c 65 6e 67 74 68 20 | 3d 20 30 3b 0a 58 09 70 |_length |= 0;.X.p|
|00002810| 72 65 76 69 6f 75 73 5f | 63 6f 64 65 20 3d 20 73 |revious_|code = s|
|00002820| 6f 75 6e 64 65 78 5f 63 | 6f 64 65 5f 6d 61 70 5b |oundex_c|ode_map[|
|00002830| 2a 77 20 2d 20 27 61 27 | 5d 3b 0a 58 09 66 6f 72 |*w - 'a'|];.X.for|
|00002840| 20 28 70 20 3d 20 77 20 | 2b 20 31 3b 20 2a 70 20 | (p = w |+ 1; *p |
|00002850| 21 3d 20 27 5c 30 27 20 | 26 26 20 73 6f 75 6e 64 |!= '\0' |&& sound|
|00002860| 65 78 5f 6c 65 6e 67 74 | 68 20 3c 20 6e 3b 20 70 |ex_lengt|h < n; p|
|00002870| 2b 2b 29 20 7b 0a 58 09 | 09 69 66 20 28 21 69 73 |++) {.X.|.if (!is|
|00002880| 61 6c 70 68 61 28 2a 70 | 29 29 0a 58 09 09 09 63 |alpha(*p|)).X...c|
|00002890| 6f 6e 74 69 6e 75 65 3b | 0a 58 09 09 63 20 3d 20 |ontinue;|.X..c = |
|000028a0| 73 6f 75 6e 64 65 78 5f | 63 6f 64 65 5f 6d 61 70 |soundex_|code_map|
|000028b0| 5b 2a 70 20 2d 20 27 61 | 27 5d 3b 0a 58 09 09 69 |[*p - 'a|'];.X..i|
|000028c0| 66 20 28 63 20 3d 3d 20 | 30 20 7c 7c 20 70 72 65 |f (c == |0 || pre|
|000028d0| 76 69 6f 75 73 5f 63 6f | 64 65 20 3d 3d 20 63 29 |vious_co|de == c)|
|000028e0| 20 7b 0a 58 09 09 09 70 | 72 65 76 69 6f 75 73 5f | {.X...p|revious_|
|000028f0| 63 6f 64 65 20 3d 20 63 | 3b 0a 58 09 09 09 63 6f |code = c|;.X...co|
|00002900| 6e 74 69 6e 75 65 3b 0a | 58 09 09 7d 0a 58 09 09 |ntinue;.|X..}.X..|
|00002910| 64 69 67 69 74 5f 70 61 | 72 74 20 3d 20 64 69 67 |digit_pa|rt = dig|
|00002920| 69 74 5f 70 61 72 74 20 | 2a 20 37 20 2b 20 63 3b |it_part |* 7 + c;|
|00002930| 0a 58 09 09 70 72 65 76 | 69 6f 75 73 5f 63 6f 64 |.X..prev|ious_cod|
|00002940| 65 20 3d 20 63 3b 0a 58 | 09 09 73 6f 75 6e 64 65 |e = c;.X|..sounde|
|00002950| 78 5f 6c 65 6e 67 74 68 | 2b 2b 3b 0a 58 09 7d 0a |x_length|++;.X.}.|
|00002960| 58 09 77 68 69 6c 65 20 | 28 73 6f 75 6e 64 65 78 |X.while |(soundex|
|00002970| 5f 6c 65 6e 67 74 68 2b | 2b 20 3c 20 6e 29 0a 58 |_length+|+ < n).X|
|00002980| 09 09 64 69 67 69 74 5f | 70 61 72 74 20 2a 3d 20 |..digit_|part *= |
|00002990| 37 3b 0a 58 09 72 65 74 | 75 72 6e 28 28 64 69 67 |7;.X.ret|urn((dig|
|000029a0| 69 74 5f 70 61 72 74 20 | 3c 3c 20 35 29 20 2b 20 |it_part |<< 5) + |
|000029b0| 2a 77 20 2d 20 27 61 27 | 29 3b 0a 58 7d 0a 58 0a |*w - 'a'|);.X}.X.|
|000029c0| 58 2f 2a 0a 58 20 2a 20 | 50 72 6f 63 65 73 73 20 |X/*.X * |Process |
|000029d0| 61 20 70 61 74 68 20 73 | 74 72 69 6e 67 20 28 65 |a path s|tring (e|
|000029e0| 6e 76 69 72 6f 6e 6d 65 | 6e 74 20 76 61 72 69 61 |nvironme|nt varia|
|000029f0| 62 6c 65 20 53 50 50 41 | 54 48 2c 20 44 45 46 41 |ble SPPA|TH, DEFA|
|00002a00| 55 4c 54 5f 53 50 50 41 | 54 48 2c 20 6f 72 20 61 |ULT_SPPA|TH, or a|
|00002a10| 6e 0a 58 20 2a 20 61 72 | 67 29 20 62 79 20 73 65 |n.X * ar|g) by se|
|00002a20| 70 61 72 61 74 69 6e 67 | 20 74 68 65 20 70 61 74 |parating| the pat|
|00002a30| 68 6e 61 6d 65 73 20 69 | 6e 74 6f 20 73 74 72 69 |hnames i|nto stri|
|00002a40| 6e 67 73 20 70 6f 69 6e | 74 65 64 20 74 6f 20 62 |ngs poin|ted to b|
|00002a50| 79 20 65 6c 65 6d 65 6e | 74 73 0a 58 20 2a 20 6f |y elemen|ts.X * o|
|00002a60| 66 20 27 66 69 6c 65 70 | 74 72 27 0a 58 20 2a 20 |f 'filep|tr'.X * |
|00002a70| 45 6e 64 20 6f 66 20 6c | 69 73 74 20 69 6e 64 69 |End of l|ist indi|
|00002a80| 63 61 74 65 64 20 62 79 | 20 66 69 6c 65 70 74 72 |cated by| fileptr|
|00002a90| 20 65 6e 74 72 79 20 6f | 66 20 4e 55 4c 4c 0a 58 | entry o|f NULL.X|
|00002aa0| 20 2a 0a 58 20 2a 20 4e | 6f 20 61 74 74 65 6d 70 | *.X * N|o attemp|
|00002ab0| 74 20 6d 61 64 65 20 74 | 6f 20 69 67 6e 6f 72 65 |t made t|o ignore|
|00002ac0| 20 64 75 70 6c 69 63 61 | 74 65 20 70 61 74 68 6e | duplica|te pathn|
|00002ad0| 61 6d 65 73 0a 58 20 2a | 2f 0a 58 6d 6b 66 69 6c |ames.X *|/.Xmkfil|
|00002ae0| 65 6c 69 73 74 28 70 29 | 0a 58 72 65 67 69 73 74 |elist(p)|.Xregist|
|00002af0| 65 72 20 63 68 61 72 20 | 2a 70 3b 0a 58 7b 0a 58 |er char |*p;.X{.X|
|00002b00| 09 72 65 67 69 73 74 65 | 72 20 69 6e 74 20 6c 65 |.registe|r int le|
|00002b10| 6e 3b 0a 58 09 72 65 67 | 69 73 74 65 72 20 63 68 |n;.X.reg|ister ch|
|00002b20| 61 72 20 2a 70 61 74 68 | 2c 20 2a 73 74 61 72 74 |ar *path|, *start|
|00002b30| 3b 0a 58 09 63 68 61 72 | 20 2a 6d 61 6c 6c 6f 63 |;.X.char| *malloc|
|00002b40| 28 29 3b 0a 58 0a 58 09 | 77 68 69 6c 65 20 28 2a |();.X.X.|while (*|
|00002b50| 70 20 21 3d 20 27 5c 30 | 27 20 26 26 20 64 69 63 |p != '\0|' && dic|
|00002b60| 74 5f 70 74 72 20 3c 20 | 4d 41 58 44 49 43 54 29 |t_ptr < |MAXDICT)|
|00002b70| 20 7b 0a 58 09 09 73 74 | 61 72 74 20 3d 20 70 3b | {.X..st|art = p;|
|00002b80| 0a 58 09 09 77 68 69 6c | 65 20 28 2a 70 20 21 3d |.X..whil|e (*p !=|
|00002b90| 20 27 3a 27 20 26 26 20 | 2a 70 20 21 3d 20 27 5c | ':' && |*p != '\|
|00002ba0| 30 27 29 0a 58 09 09 09 | 70 2b 2b 3b 0a 58 09 09 |0').X...|p++;.X..|
|00002bb0| 69 66 20 28 73 74 61 72 | 74 20 3d 3d 20 70 20 26 |if (star|t == p &|
|00002bc0| 26 20 2a 70 20 3d 3d 20 | 27 3a 27 29 20 7b 09 2f |& *p == |':') {./|
|00002bd0| 2a 20 63 6f 6c 6f 6e 20 | 77 69 74 68 20 6e 6f 74 |* colon |with not|
|00002be0| 68 69 6e 67 20 65 6c 73 | 65 20 2a 2f 0a 58 09 09 |hing els|e */.X..|
|00002bf0| 09 70 2b 2b 3b 0a 58 09 | 09 09 63 6f 6e 74 69 6e |.p++;.X.|..contin|
|00002c00| 75 65 3b 0a 58 09 09 7d | 0a 58 09 09 6c 65 6e 20 |ue;.X..}|.X..len |
|00002c10| 3d 20 70 20 2d 20 73 74 | 61 72 74 3b 0a 58 09 09 |= p - st|art;.X..|
|00002c20| 70 61 74 68 20 3d 20 28 | 63 68 61 72 20 2a 29 20 |path = (|char *) |
|00002c30| 6d 61 6c 6c 6f 63 28 28 | 75 6e 73 69 67 6e 65 64 |malloc((|unsigned|
|00002c40| 29 20 28 6c 65 6e 20 2b | 20 31 29 29 3b 0a 58 09 |) (len +| 1));.X.|
|00002c50| 09 69 66 20 28 70 61 74 | 68 20 3d 3d 20 28 63 68 |.if (pat|h == (ch|
|00002c60| 61 72 20 2a 29 20 4e 55 | 4c 4c 29 20 7b 0a 58 09 |ar *) NU|LL) {.X.|
|00002c70| 09 09 66 70 72 69 6e 74 | 66 28 73 74 64 65 72 72 |..fprint|f(stderr|
|00002c80| 2c 20 22 73 70 3a 20 4f | 75 74 20 6f 66 20 64 69 |, "sp: O|ut of di|
|00002c90| 63 74 69 6f 6e 61 72 79 | 20 73 70 61 63 65 5c 6e |ctionary| space\n|
|00002ca0| 22 29 3b 0a 58 09 09 09 | 65 78 69 74 28 31 29 3b |");.X...|exit(1);|
|00002cb0| 0a 58 09 09 7d 0a 58 09 | 09 73 74 72 6e 63 70 79 |.X..}.X.|.strncpy|
|00002cc0| 28 70 61 74 68 2c 20 73 | 74 61 72 74 2c 20 6c 65 |(path, s|tart, le|
|00002cd0| 6e 29 3b 0a 58 09 09 70 | 61 74 68 5b 6c 65 6e 5d |n);.X..p|ath[len]|
|00002ce0| 20 3d 20 27 5c 30 27 3b | 0a 58 09 09 66 69 6c 65 | = '\0';|.X..file|
|00002cf0| 70 74 72 5b 64 69 63 74 | 5f 70 74 72 2b 2b 5d 20 |ptr[dict|_ptr++] |
|00002d00| 3d 20 70 61 74 68 3b 0a | 58 09 7d 0a 58 09 66 69 |= path;.|X.}.X.fi|
|00002d10| 6c 65 70 74 72 5b 64 69 | 63 74 5f 70 74 72 5d 20 |leptr[di|ct_ptr] |
|00002d20| 3d 20 28 63 68 61 72 20 | 2a 29 20 4e 55 4c 4c 3b |= (char |*) NULL;|
|00002d30| 0a 58 7d 0a 58 0a 58 63 | 6f 6d 70 61 72 28 70 2c |.X}.X.Xc|ompar(p,|
|00002d40| 20 71 29 0a 58 63 68 61 | 72 20 2a 2a 70 2c 20 2a | q).Xcha|r **p, *|
|00002d50| 2a 71 3b 0a 58 7b 0a 58 | 0a 58 09 72 65 74 75 72 |*q;.X{.X|.X.retur|
|00002d60| 6e 28 73 74 72 6d 61 74 | 63 68 28 2a 70 2c 20 2a |n(strmat|ch(*p, *|
|00002d70| 71 29 29 3b 0a 58 2f 2a | 09 72 65 74 75 72 6e 28 |q));.X/*|.return(|
|00002d80| 73 74 72 63 6d 70 28 2a | 70 2c 20 2a 71 29 29 3b |strcmp(*|p, *q));|
|00002d90| 20 2a 2f 09 2f 2a 20 75 | 73 65 20 69 66 20 79 6f | */./* u|se if yo|
|00002da0| 75 20 70 72 65 66 65 72 | 20 63 61 73 65 20 73 65 |u prefer| case se|
|00002db0| 6e 73 69 74 69 76 65 20 | 2a 2f 0a 58 7d 0a 58 0a |nsitive |*/.X}.X.|
|00002dc0| 40 2f 2f 45 2a 4f 2a 46 | 20 73 70 2e 63 2f 2f 0a |@//E*O*F| sp.c//.|
|00002dd0| 69 66 20 74 65 73 74 20 | 39 31 32 38 20 2d 6e 65 |if test |9128 -ne|
|00002de0| 20 22 60 77 63 20 2d 63 | 20 3c 27 73 70 2e 63 27 | "`wc -c| <'sp.c'|
|00002df0| 60 22 3b 20 74 68 65 6e | 0a 20 20 20 20 65 63 68 |`"; then|. ech|
|00002e00| 6f 20 73 68 61 72 3a 20 | 65 72 72 6f 72 20 74 72 |o shar: |error tr|
|00002e10| 61 6e 73 6d 69 74 74 69 | 6e 67 20 22 27 73 70 2e |ansmitti|ng "'sp.|
|00002e20| 63 27 22 20 27 28 73 68 | 6f 75 6c 64 20 68 61 76 |c'" '(sh|ould hav|
|00002e30| 65 20 62 65 65 6e 20 39 | 31 32 38 20 63 68 61 72 |e been 9|128 char|
|00002e40| 61 63 74 65 72 73 29 27 | 0a 66 69 0a 66 69 20 23 |acters)'|.fi.fi #|
|00002e50| 20 65 6e 64 20 6f 66 20 | 6f 76 65 72 77 72 69 74 | end of |overwrit|
|00002e60| 69 6e 67 20 63 68 65 63 | 6b 0a 65 63 68 6f 20 73 |ing chec|k.echo s|
|00002e70| 68 61 72 3a 20 65 78 74 | 72 61 63 74 69 6e 67 20 |har: ext|racting |
|00002e80| 22 27 73 70 2e 68 27 22 | 20 27 28 33 35 35 33 20 |"'sp.h'"| '(3553 |
|00002e90| 63 68 61 72 61 63 74 65 | 72 73 29 27 0a 69 66 20 |characte|rs)'.if |
|00002ea0| 74 65 73 74 20 2d 66 20 | 27 73 70 2e 68 27 20 3b |test -f |'sp.h' ;|
|00002eb0| 20 74 68 65 6e 20 0a 20 | 20 65 63 68 6f 20 73 68 | then . | echo sh|
|00002ec0| 61 72 3a 20 77 69 6c 6c | 20 6e 6f 74 20 6f 76 65 |ar: will| not ove|
|00002ed0| 72 2d 77 72 69 74 65 20 | 65 78 69 73 74 69 6e 67 |r-write |existing|
|00002ee0| 20 66 69 6c 65 20 22 27 | 73 70 2e 68 27 22 0a 65 | file "'|sp.h'".e|
|00002ef0| 6c 73 65 0a 73 65 64 20 | 27 73 2f 5e 58 2f 2f 27 |lse.sed |'s/^X//'|
|00002f00| 20 3e 73 70 2e 68 20 3c | 3c 27 40 2f 2f 45 2a 4f | >sp.h <|<'@//E*O|
|00002f10| 2a 46 20 73 70 2e 68 2f | 2f 27 0a 58 2f 2a 20 73 |*F sp.h/|/'.X/* s|
|00002f20| 70 2e 68 20 2a 2f 0a 58 | 2f 2a 20 76 69 3a 20 73 |p.h */.X|/* vi: s|
|00002f30| 65 74 20 74 61 62 73 74 | 6f 70 3d 34 20 3a 20 2a |et tabst|op=4 : *|
|00002f40| 2f 0a 58 0a 58 2f 2a 0a | 58 20 2a 20 41 20 64 65 |/.X.X/*.|X * A de|
|00002f50| 6c 65 74 65 64 20 64 62 | 6d 20 65 6e 74 72 79 20 |leted db|m entry |
|00002f60| 69 73 20 64 65 6e 6f 74 | 65 64 20 62 79 20 61 20 |is denot|ed by a |
|00002f70| 64 73 69 7a 65 20 6f 66 | 20 7a 65 72 6f 0a 58 20 |dsize of| zero.X |
|00002f80| 2a 2f 0a 58 23 64 65 66 | 69 6e 65 20 49 53 5f 44 |*/.X#def|ine IS_D|
|00002f90| 45 4c 45 54 45 44 28 43 | 29 09 09 28 43 2e 64 73 |ELETED(C|)..(C.ds|
|00002fa0| 69 7a 65 20 3d 3d 20 30 | 29 0a 58 0a 58 2f 2a 0a |ize == 0|).X.X/*.|
|00002fb0| 58 20 2a 20 42 65 63 61 | 75 73 65 20 74 68 65 20 |X * Beca|use the |
|00002fc0| 73 6f 75 6e 64 65 78 20 | 63 6f 64 65 20 28 70 61 |soundex |code (pa|
|00002fd0| 72 74 20 6f 66 20 74 68 | 65 20 6b 65 79 29 20 69 |rt of th|e key) i|
|00002fe0| 6e 63 6c 75 64 65 73 20 | 74 68 65 20 66 69 72 73 |ncludes |the firs|
|00002ff0| 74 20 63 68 61 72 61 63 | 74 65 72 20 6f 66 0a 58 |t charac|ter of.X|
|00003000| 20 2a 20 74 68 65 20 77 | 6f 72 64 2c 20 77 65 20 | * the w|ord, we |
|00003010| 64 6f 6e 27 74 20 6e 65 | 65 64 20 74 6f 20 73 74 |don't ne|ed to st|
|00003020| 6f 72 65 20 74 68 65 20 | 66 69 72 73 74 20 63 68 |ore the |first ch|
|00003030| 61 72 61 63 74 65 72 20 | 61 67 61 69 6e 20 77 69 |aracter |again wi|
|00003040| 74 68 20 74 68 65 20 63 | 6f 6e 74 65 6e 74 2e 0a |th the c|ontent..|
|00003050| 58 20 2a 20 54 6f 20 64 | 6f 20 74 68 69 73 20 77 |X * To d|o this w|
|00003060| 65 20 74 72 65 61 74 20 | 74 68 65 20 66 69 72 73 |e treat |the firs|
|00003070| 74 20 62 79 74 65 20 6f | 66 20 74 68 65 20 63 6f |t byte o|f the co|
|00003080| 6e 74 65 6e 74 20 73 74 | 6f 72 65 64 20 69 6e 20 |ntent st|ored in |
|00003090| 74 68 65 20 64 62 6d 0a | 58 20 2a 20 73 70 65 63 |the dbm.|X * spec|
|000030a0| 69 61 6c 6c 79 3a 20 20 | 77 65 20 72 69 70 20 6f |ially: |we rip o|
|000030b0| 66 66 20 74 68 65 20 74 | 77 6f 20 68 69 67 68 20 |ff the t|wo high |
|000030c0| 6f 72 64 65 72 20 62 69 | 74 73 20 6f 66 20 74 68 |order bi|ts of th|
|000030d0| 65 20 66 69 72 73 74 20 | 62 79 74 65 20 6f 66 0a |e first |byte of.|
|000030e0| 58 20 2a 20 74 68 65 20 | 63 6f 6e 74 65 6e 74 20 |X * the |content |
|000030f0| 61 6e 64 20 74 68 65 72 | 65 66 6f 72 65 20 68 61 |and ther|efore ha|
|00003100| 76 65 20 74 6f 20 72 65 | 73 74 72 69 63 74 20 74 |ve to re|strict t|
|00003110| 68 65 20 76 61 6c 75 65 | 20 6f 66 20 74 68 65 20 |he value| of the |
|00003120| 73 65 63 6f 6e 64 0a 58 | 20 2a 20 63 68 61 72 61 |second.X| * chara|
|00003130| 63 74 65 72 20 6f 66 20 | 74 68 65 20 77 6f 72 64 |cter of |the word|
|00003140| 2e 20 20 57 65 20 75 73 | 65 20 27 61 27 20 3d 3d |. We us|e 'a' ==|
|00003150| 20 30 2c 20 27 7a 27 20 | 3d 3d 20 32 35 2c 20 27 | 0, 'z' |== 25, '|
|00003160| 41 27 20 3d 3d 20 32 36 | 2c 20 27 5a 27 20 3d 3d |A' == 26|, 'Z' ==|
|00003170| 20 35 31 2e 0a 58 20 2a | 20 53 65 65 20 73 70 63 | 51..X *| See spc|
|00003180| 68 61 72 5f 6d 61 70 5b | 5d 20 28 6d 69 73 63 2e |har_map[|] (misc.|
|00003190| 63 29 20 66 6f 72 20 74 | 68 65 20 6d 61 70 70 69 |c) for t|he mappi|
|000031a0| 6e 67 20 6f 66 20 63 6f | 64 65 73 20 35 32 20 74 |ng of co|des 52 t|
|000031b0| 68 72 6f 75 67 68 20 36 | 33 2e 0a 58 20 2a 20 54 |hrough 6|3..X * T|
|000031c0| 68 69 73 20 62 65 68 61 | 76 69 6f 75 72 20 69 73 |his beha|viour is|
|000031d0| 20 69 73 6f 6c 61 74 65 | 64 20 69 6e 20 74 6f 73 | isolate|d in tos|
|000031e0| 70 63 68 61 72 28 29 20 | 61 6e 64 20 66 72 6f 6d |pchar() |and from|
|000031f0| 73 70 63 68 61 72 28 29 | 2e 0a 58 20 2a 20 49 66 |spchar()|..X * If|
|00003200| 20 73 70 63 68 61 72 5f | 6d 61 70 20 69 73 20 63 | spchar_|map is c|
|00003210| 68 61 6e 67 65 64 20 79 | 6f 75 20 73 68 6f 75 6c |hanged y|ou shoul|
|00003220| 64 20 63 68 61 6e 67 65 | 20 74 68 65 20 6d 61 6e |d change| the man|
|00003230| 20 70 61 67 65 20 74 6f | 6f 2e 0a 58 20 2a 0a 58 | page to|o..X *.X|
|00003240| 20 2a 20 54 68 65 20 77 | 6f 72 64 20 63 61 6e 20 | * The w|ord can |
|00003250| 62 65 20 72 65 63 6f 6e | 73 74 72 75 63 74 65 64 |be recon|structed|
|00003260| 20 62 79 20 65 78 74 72 | 61 63 74 69 6e 67 20 74 | by extr|acting t|
|00003270| 68 65 20 66 69 72 73 74 | 20 63 68 61 72 61 63 74 |he first| charact|
|00003280| 65 72 20 6f 66 20 74 68 | 65 20 77 6f 72 64 0a 58 |er of th|e word.X|
|00003290| 20 2a 20 66 72 6f 6d 20 | 74 68 65 20 73 6f 75 6e | * from |the soun|
|000032a0| 64 65 78 20 63 6f 64 65 | 20 61 6e 64 20 74 68 65 |dex code| and the|
|000032b0| 6e 20 6c 6f 6f 6b 69 6e | 67 20 61 74 20 74 68 65 |n lookin|g at the|
|000032c0| 20 66 69 72 73 74 20 62 | 79 74 65 20 6f 66 20 74 | first b|yte of t|
|000032d0| 68 65 20 63 6f 6e 74 65 | 6e 74 2e 0a 58 20 2a 20 |he conte|nt..X * |
|000032e0| 49 66 20 74 68 65 20 55 | 50 50 45 52 5f 43 48 41 |If the U|PPER_CHA|
|000032f0| 52 20 62 69 74 20 69 73 | 20 6f 6e 20 69 6e 20 74 |R bit is| on in t|
|00003300| 68 65 20 66 69 72 73 74 | 20 62 79 74 65 20 6f 66 |he first| byte of|
|00003310| 20 74 68 65 20 63 6f 6e | 74 65 6e 74 20 74 68 65 | the con|tent the|
|00003320| 6e 20 74 68 65 20 66 69 | 72 73 74 0a 58 20 2a 20 |n the fi|rst.X * |
|00003330| 63 68 61 72 61 63 74 65 | 72 20 6f 66 20 74 68 65 |characte|r of the|
|00003340| 20 77 6f 72 64 20 73 68 | 6f 75 6c 64 20 62 65 20 | word sh|ould be |
|00003350| 75 70 70 65 72 20 63 61 | 73 65 2e 0a 58 20 2a 20 |upper ca|se..X * |
|00003360| 54 68 65 20 6c 65 6e 67 | 74 68 20 6f 66 20 74 68 |The leng|th of th|
|00003370| 65 20 63 6f 6e 74 65 6e | 74 20 72 65 66 6c 65 63 |e conten|t reflec|
|00003380| 74 73 20 74 68 65 20 61 | 63 74 75 61 6c 20 6e 75 |ts the a|ctual nu|
|00003390| 6d 62 65 72 20 6f 66 20 | 62 79 74 65 73 20 73 74 |mber of |bytes st|
|000033a0| 6f 72 65 64 20 69 6e 20 | 74 68 65 0a 58 20 2a 20 |ored in |the.X * |
|000033b0| 64 62 6d 2e 20 20 57 6f | 72 64 73 20 74 68 61 74 |dbm. Wo|rds that|
|000033c0| 20 68 61 76 65 20 62 65 | 65 6e 20 64 65 6c 65 74 | have be|en delet|
|000033d0| 65 64 20 66 72 6f 6d 20 | 74 68 65 20 64 62 6d 20 |ed from |the dbm |
|000033e0| 61 72 65 20 73 74 6f 72 | 65 64 20 77 69 74 68 20 |are stor|ed with |
|000033f0| 61 20 6c 65 6e 67 74 68 | 20 6f 66 0a 58 20 2a 20 |a length| of.X * |
|00003400| 7a 65 72 6f 2e 20 20 42 | 65 63 61 75 73 65 20 6f |zero. B|ecause o|
|00003410| 66 20 74 68 69 73 2c 20 | 77 6f 72 64 73 20 6f 66 |f this, |words of|
|00003420| 20 6c 65 6e 67 74 68 20 | 31 20 61 72 65 20 74 72 | length |1 are tr|
|00003430| 65 61 74 65 64 20 64 69 | 66 66 65 72 65 6e 74 6c |eated di|fferentl|
|00003440| 79 3a 20 74 68 65 79 20 | 61 72 65 0a 58 20 2a 20 |y: they |are.X * |
|00003450| 73 74 6f 72 65 64 20 77 | 69 74 68 20 61 20 6c 65 |stored w|ith a le|
|00003460| 6e 67 74 68 20 6f 66 20 | 31 20 61 6e 64 20 77 69 |ngth of |1 and wi|
|00003470| 74 68 20 74 68 65 20 53 | 49 4e 47 4c 45 5f 43 48 |th the S|INGLE_CH|
|00003480| 41 52 20 62 69 74 20 73 | 65 74 2e 20 20 57 6f 72 |AR bit s|et. Wor|
|00003490| 64 73 20 77 69 74 68 0a | 58 20 2a 20 6f 72 69 67 |ds with.|X * orig|
|000034a0| 69 6e 61 6c 20 6c 65 6e | 67 74 68 20 3e 20 31 20 |inal len|gth > 1 |
|000034b0| 77 69 6c 6c 20 68 61 76 | 65 20 28 6c 65 6e 67 74 |will hav|e (lengt|
|000034c0| 68 20 2d 20 31 29 20 62 | 79 74 65 73 20 73 74 6f |h - 1) b|ytes sto|
|000034d0| 72 65 64 20 69 6e 20 74 | 68 65 20 63 6f 6e 74 65 |red in t|he conte|
|000034e0| 6e 74 2e 0a 58 20 2a 20 | 43 6c 65 61 72 3f 0a 58 |nt..X * |Clear?.X|
|000034f0| 20 2a 2f 0a 58 23 64 65 | 66 69 6e 65 20 49 53 5f | */.X#de|fine IS_|
|00003500| 56 41 4c 49 44 28 77 29 | 09 09 28 69 73 61 6c 70 |VALID(w)|..(isalp|
|00003510| 68 61 28 2a 77 29 20 26 | 26 20 28 2a 28 77 2b 31 |ha(*w) &|& (*(w+1|
|00003520| 29 20 3d 3d 20 27 5c 30 | 27 20 7c 7c 20 69 73 61 |) == '\0|' || isa|
|00003530| 6c 70 68 61 28 2a 28 77 | 2b 31 29 29 20 5c 0a 58 |lpha(*(w|+1)) \.X|
|00003540| 09 09 09 09 09 09 09 09 | 09 09 7c 7c 20 74 6f 73 |........|..|| tos|
|00003550| 70 63 68 61 72 28 2a 28 | 77 2b 31 29 29 20 21 3d |pchar(*(|w+1)) !=|
|00003560| 20 27 5c 30 27 29 29 0a | 58 23 64 65 66 69 6e 65 | '\0')).|X#define|
|00003570| 20 55 50 50 45 52 5f 43 | 48 41 52 09 09 30 32 30 | UPPER_C|HAR..020|
|00003580| 30 09 2f 2a 20 31 73 74 | 20 63 68 61 72 20 6f 66 |0./* 1st| char of|
|00003590| 20 77 6f 72 64 20 69 73 | 20 75 70 70 65 72 20 63 | word is| upper c|
|000035a0| 61 73 65 20 2a 2f 0a 58 | 23 64 65 66 69 6e 65 20 |ase */.X|#define |
|000035b0| 53 49 4e 47 4c 45 5f 43 | 48 41 52 09 09 30 31 30 |SINGLE_C|HAR..010|
|000035c0| 30 09 2f 2a 20 73 69 6e | 67 6c 65 20 63 68 61 72 |0./* sin|gle char|
|000035d0| 20 77 6f 72 64 20 2a 2f | 0a 58 23 64 65 66 69 6e | word */|.X#defin|
|000035e0| 65 20 4d 41 53 4b 5f 43 | 48 41 52 09 09 30 30 37 |e MASK_C|HAR..007|
|000035f0| 37 09 2f 2a 20 6d 61 73 | 6b 20 6f 75 74 20 74 68 |7./* mas|k out th|
|00003600| 65 20 69 6e 64 69 63 61 | 74 6f 72 20 62 69 74 73 |e indica|tor bits|
|00003610| 20 2a 2f 0a 58 23 64 65 | 66 69 6e 65 20 51 55 4f | */.X#de|fine QUO|
|00003620| 54 45 5f 43 48 41 52 09 | 09 30 30 36 34 09 2f 2a |TE_CHAR.|.0064./*|
|00003630| 20 28 35 32 29 20 63 6f | 64 65 20 66 6f 72 20 73 | (52) co|de for s|
|00003640| 69 6e 67 6c 65 20 71 75 | 6f 74 65 20 2a 2f 0a 58 |ingle qu|ote */.X|
|00003650| 23 64 65 66 69 6e 65 20 | 41 4d 50 45 52 5f 43 48 |#define |AMPER_CH|
|00003660| 41 52 09 09 30 30 36 35 | 09 2f 2a 20 28 35 33 29 |AR..0065|./* (53)|
|00003670| 20 66 6f 72 20 61 6d 70 | 65 72 73 61 6e 64 20 2a | for amp|ersand *|
|00003680| 2f 0a 58 23 64 65 66 69 | 6e 65 20 50 45 52 49 4f |/.X#defi|ne PERIO|
|00003690| 44 5f 43 48 41 52 09 09 | 30 30 36 36 09 2f 2a 20 |D_CHAR..|0066./* |
|000036a0| 28 35 34 29 20 66 6f 72 | 20 70 65 72 69 6f 64 20 |(54) for| period |
|000036b0| 2a 2f 0a 58 23 64 65 66 | 69 6e 65 20 53 50 41 43 |*/.X#def|ine SPAC|
|000036c0| 45 5f 43 48 41 52 09 09 | 30 30 36 37 09 2f 2a 20 |E_CHAR..|0067./* |
|000036d0| 28 35 35 29 20 66 6f 72 | 20 62 6c 61 6e 6b 20 2a |(55) for| blank *|
|000036e0| 2f 0a 58 0a 58 2f 2a 0a | 58 20 2a 20 4d 61 70 20 |/.X.X/*.|X * Map |
|000036f0| 66 6f 72 20 66 69 72 73 | 74 20 62 79 74 65 20 6f |for firs|t byte o|
|00003700| 66 20 64 62 6d 20 63 6f | 6e 74 65 6e 74 20 28 73 |f dbm co|ntent (s|
|00003710| 70 65 63 69 61 6c 20 63 | 68 61 72 61 63 74 65 72 |pecial c|haracter|
|00003720| 73 29 0a 58 20 2a 20 54 | 65 72 6d 69 6e 61 74 65 |s).X * T|erminate|
|00003730| 64 20 62 79 20 61 20 6e | 75 6c 6c 20 65 6e 74 72 |d by a n|ull entr|
|00003740| 79 0a 58 20 2a 2f 0a 58 | 73 74 72 75 63 74 20 73 |y.X */.X|struct s|
|00003750| 70 63 68 61 72 5f 6d 61 | 70 20 7b 0a 58 09 63 68 |pchar_ma|p {.X.ch|
|00003760| 61 72 20 73 70 63 68 61 | 72 3b 0a 58 09 63 68 61 |ar spcha|r;.X.cha|
|00003770| 72 20 63 6f 64 65 3b 0a | 58 7d 3b 0a 58 0a 58 23 |r code;.|X};.X.X#|
|00003780| 64 65 66 69 6e 65 20 4d | 41 58 44 49 43 54 09 09 |define M|AXDICT..|
|00003790| 09 31 30 09 09 2f 2a 20 | 4d 61 78 20 6e 75 6d 62 |.10../* |Max numb|
|000037a0| 65 72 20 6f 66 20 64 69 | 63 74 69 6f 6e 61 72 69 |er of di|ctionari|
|000037b0| 65 73 20 74 6f 20 75 73 | 65 20 2a 2f 0a 58 23 64 |es to us|e */.X#d|
|000037c0| 65 66 69 6e 65 20 4d 41 | 58 57 4f 52 44 4c 45 4e |efine MA|XWORDLEN|
|000037d0| 09 09 35 30 09 09 2f 2a | 20 4d 61 78 20 77 6f 72 |..50../*| Max wor|
|000037e0| 64 20 6c 65 6e 67 74 68 | 20 2a 2f 0a 58 23 64 65 |d length| */.X#de|
|000037f0| 66 69 6e 65 20 4d 41 58 | 57 4f 52 44 53 09 09 34 |fine MAX|WORDS..4|
|00003800| 30 30 09 09 2f 2a 20 4d | 61 78 20 6e 75 6d 62 65 |00../* M|ax numbe|
|00003810| 72 20 6f 66 20 77 6f 72 | 64 73 20 69 6e 20 6f 6e |r of wor|ds in on|
|00003820| 65 20 73 70 20 71 75 65 | 72 79 20 2a 2f 0a 58 23 |e sp que|ry */.X#|
|00003830| 64 65 66 69 6e 65 20 57 | 4f 52 44 53 50 41 43 45 |define W|ORDSPACE|
|00003840| 09 09 32 30 34 38 30 09 | 2f 2a 20 4d 61 78 20 73 |..20480.|/* Max s|
|00003850| 70 61 63 65 20 75 73 65 | 64 20 77 6f 72 64 73 20 |pace use|d words |
|00003860| 66 6f 72 20 6f 6e 65 20 | 73 70 20 71 75 65 72 79 |for one |sp query|
|00003870| 20 2a 2f 0a 58 0a 58 2f | 2a 0a 58 20 2a 20 54 68 | */.X.X/|*.X * Th|
|00003880| 69 73 20 69 73 20 74 68 | 65 20 64 65 66 61 75 6c |is is th|e defaul|
|00003890| 74 20 70 61 74 68 20 75 | 73 65 64 20 62 79 20 73 |t path u|sed by s|
|000038a0| 70 20 74 6f 20 66 69 6e | 64 20 64 69 63 74 69 6f |p to fin|d dictio|
|000038b0| 6e 61 72 69 65 73 0a 58 | 20 2a 20 41 64 6a 75 73 |naries.X| * Adjus|
|000038c0| 74 20 66 6f 72 20 6c 6f | 63 61 6c 20 63 6f 6e 64 |t for lo|cal cond|
|000038d0| 69 74 69 6f 6e 73 0a 58 | 20 2a 2f 0a 58 23 64 65 |itions.X| */.X#de|
|000038e0| 66 69 6e 65 20 44 45 46 | 41 55 4c 54 5f 53 50 50 |fine DEF|AULT_SPP|
|000038f0| 41 54 48 09 22 2f 75 73 | 72 2f 6c 6f 63 61 6c 2f |ATH."/us|r/local/|
|00003900| 6c 69 62 2f 73 70 2e 64 | 69 63 74 2e 31 3a 2f 75 |lib/sp.d|ict.1:/u|
|00003910| 73 72 2f 6c 6f 63 61 6c | 2f 6c 69 62 2f 73 70 2e |sr/local|/lib/sp.|
|00003920| 64 69 63 74 2e 32 22 0a | 58 0a 58 2f 2a 0a 58 20 |dict.2".|X.X/*.X |
|00003930| 2a 20 54 68 65 20 66 6f | 6c 6c 6f 77 69 6e 67 20 |* The fo|llowing |
|00003940| 6d 75 73 74 20 62 65 20 | 74 68 65 20 6d 61 78 69 |must be |the maxi|
|00003950| 6d 75 6d 20 76 61 6c 75 | 65 20 63 6f 6e 74 61 69 |mum valu|e contai|
|00003960| 6e 61 62 6c 65 20 69 6e | 20 74 68 65 20 63 6f 75 |nable in| the cou|
|00003970| 6e 74 20 70 61 72 74 20 | 6f 66 0a 58 20 2a 20 61 |nt part |of.X * a|
|00003980| 20 6b 65 79 2e 0a 58 20 | 2a 20 49 74 20 6d 75 73 | key..X |* It mus|
|00003990| 74 20 62 65 20 61 6c 77 | 61 79 73 20 62 65 20 6c |t be alw|ays be l|
|000039a0| 65 73 73 20 74 68 61 6e | 3a 20 28 74 68 65 20 6d |ess than|: (the m|
|000039b0| 61 78 69 6d 75 6d 20 70 | 6f 73 69 74 69 76 65 20 |aximum p|ositive |
|000039c0| 76 61 6c 75 65 20 74 68 | 61 74 20 63 61 6e 20 62 |value th|at can b|
|000039d0| 65 0a 58 20 2a 20 63 6f | 6e 74 61 69 6e 65 64 20 |e.X * co|ntained |
|000039e0| 69 6e 20 61 6e 20 69 6e | 74 29 20 2d 20 31 0a 58 |in an in|t) - 1.X|
|000039f0| 20 2a 20 54 68 69 73 20 | 76 61 6c 75 65 20 69 6d | * This |value im|
|00003a00| 70 6f 73 65 73 20 61 20 | 6c 69 6d 69 74 20 6f 6e |poses a |limit on|
|00003a10| 20 74 68 65 20 6e 75 6d | 62 65 72 20 6f 66 20 77 | the num|ber of w|
|00003a20| 6f 72 64 73 20 69 6e 20 | 61 20 64 69 63 74 69 6f |ords in |a dictio|
|00003a30| 6e 61 72 79 20 68 61 76 | 69 6e 67 20 74 68 65 0a |nary hav|ing the.|
|00003a40| 58 20 2a 20 73 61 6d 65 | 20 73 6f 75 6e 64 65 78 |X * same| soundex|
|00003a50| 20 63 6f 64 65 2e 20 20 | 46 6f 72 20 2f 75 73 72 | code. |For /usr|
|00003a60| 2f 64 69 63 74 2f 77 6f | 72 64 73 20 28 7e 32 35 |/dict/wo|rds (~25|
|00003a70| 4b 20 77 6f 72 64 73 29 | 2c 20 61 20 63 6f 75 6e |K words)|, a coun|
|00003a80| 74 20 6f 66 20 32 35 35 | 20 69 73 0a 58 20 2a 20 |t of 255| is.X * |
|00003a90| 73 75 66 66 69 63 69 65 | 6e 74 2e 20 20 4c 61 72 |sufficie|nt. Lar|
|00003aa0| 67 65 72 20 64 69 63 74 | 69 6f 6e 61 72 69 65 73 |ger dict|ionaries|
|00003ab0| 20 77 69 6c 6c 20 6e 65 | 65 64 20 6d 6f 72 65 2e | will ne|ed more.|
|00003ac0| 20 20 49 6e 20 61 6e 79 | 20 63 61 73 65 20 79 6f | In any| case yo|
|00003ad0| 75 20 63 61 6e 0a 58 20 | 2a 20 61 6c 77 61 79 73 |u can.X |* always|
|00003ae0| 20 6a 75 73 74 20 6d 61 | 6b 65 20 61 6e 6f 74 68 | just ma|ke anoth|
|00003af0| 65 72 20 64 69 63 74 69 | 6f 6e 61 72 79 20 61 6e |er dicti|onary an|
|00003b00| 64 20 73 70 6c 69 74 20 | 75 70 20 79 6f 75 72 20 |d split |up your |
|00003b10| 77 6f 72 64 73 2e 0a 58 | 20 2a 20 59 6f 75 20 6d |words..X| * You m|
|00003b20| 69 67 68 74 20 77 61 6e | 74 20 74 6f 20 61 64 6a |ight wan|t to adj|
|00003b30| 75 73 74 20 4d 41 58 57 | 4f 52 44 53 20 61 6e 64 |ust MAXW|ORDS and|
|00003b40| 20 57 4f 52 44 53 50 41 | 43 45 20 28 61 62 6f 76 | WORDSPA|CE (abov|
|00003b50| 65 29 20 74 6f 20 72 65 | 66 6c 65 63 74 20 4d 41 |e) to re|flect MA|
|00003b60| 58 43 4f 55 4e 54 0a 58 | 20 2a 20 69 66 20 79 6f |XCOUNT.X| * if yo|
|00003b70| 75 27 76 65 20 67 6f 74 | 20 70 6c 65 6e 74 79 20 |u've got| plenty |
|00003b80| 6f 66 20 6d 65 6d 6f 72 | 79 2e 0a 58 20 2a 2f 0a |of memor|y..X */.|
|00003b90| 58 23 64 65 66 69 6e 65 | 20 4d 41 58 43 4f 55 4e |X#define| MAXCOUN|
|00003ba0| 54 09 31 30 32 33 09 09 | 09 09 2f 2a 20 32 5e 31 |T.1023..|../* 2^1|
|00003bb0| 30 20 2d 20 31 20 2a 2f | 0a 58 0a 58 2f 2a 0a 58 |0 - 1 */|.X.X/*.X|
|00003bc0| 20 2a 20 54 68 65 20 6b | 65 79 20 75 73 65 64 20 | * The k|ey used |
|00003bd0| 62 79 20 64 62 6d 20 6c | 6f 6f 6b 73 20 6c 69 6b |by dbm l|ooks lik|
|00003be0| 65 20 74 68 69 73 3a 0a | 58 20 2a 0a 58 20 2a 20 |e this:.|X *.X * |
|00003bf0| 09 3c 31 30 20 62 69 74 | 73 3e 09 3c 35 20 62 69 |.<10 bit|s>.<5 bi|
|00003c00| 74 73 3e 09 3c 39 20 62 | 69 74 73 3e 0a 58 20 2a |ts>.<9 b|its>.X *|
|00003c10| 09 63 6f 75 6e 74 65 72 | 09 09 66 69 72 73 74 20 |.counter|..first |
|00003c20| 63 68 61 72 09 73 6f 75 | 6e 64 65 78 0a 58 20 2a |char.sou|ndex.X *|
|00003c30| 0a 58 20 2a 20 41 20 73 | 6f 75 6e 64 65 78 20 76 |.X * A s|oundex v|
|00003c40| 61 6c 75 65 20 69 73 20 | 74 72 65 61 74 65 64 20 |alue is |treated |
|00003c50| 61 73 20 61 20 62 61 73 | 65 20 37 20 6e 75 6d 62 |as a bas|e 7 numb|
|00003c60| 65 72 20 28 6d 61 78 69 | 6d 75 6d 20 69 73 20 36 |er (maxi|mum is 6|
|00003c70| 36 36 2c 20 62 61 73 65 | 20 37 29 2e 0a 58 20 2a |66, base| 7)..X *|
|00003c80| 2f 0a 58 23 64 65 66 69 | 6e 65 20 4b 45 59 53 49 |/.X#defi|ne KEYSI|
|00003c90| 5a 45 09 09 33 09 09 09 | 09 09 2f 2a 20 69 6e 20 |ZE..3...|../* in |
|00003ca0| 62 79 74 65 73 20 2a 2f | 0a 58 74 79 70 65 64 65 |bytes */|.Xtypede|
|00003cb0| 66 20 75 6e 73 69 67 6e | 65 64 20 63 68 61 72 20 |f unsign|ed char |
|00003cc0| 6b 65 79 5f 74 3b 0a 58 | 0a 58 23 64 65 66 69 6e |key_t;.X|.X#defin|
|00003cd0| 65 20 42 41 44 5f 57 4f | 52 44 09 2d 31 09 09 09 |e BAD_WO|RD.-1...|
|00003ce0| 09 09 2f 2a 20 54 68 69 | 73 20 6d 75 73 74 20 62 |../* Thi|s must b|
|00003cf0| 65 20 61 6e 20 69 6c 6c | 65 67 61 6c 20 53 6f 75 |e an ill|egal Sou|
|00003d00| 6e 64 65 78 20 2a 2f 0a | 58 23 64 65 66 69 6e 65 |ndex */.|X#define|
|00003d10| 20 4e 4f 5f 4d 41 54 43 | 48 09 20 30 0a 58 23 64 | NO_MATC|H. 0.X#d|
|00003d20| 65 66 69 6e 65 20 4d 41 | 54 43 48 45 44 09 09 20 |efine MA|TCHED.. |
|00003d30| 31 0a 58 0a 58 65 78 74 | 65 72 6e 20 63 68 61 72 |1.X.Xext|ern char|
|00003d40| 20 73 6f 75 6e 64 65 78 | 5f 63 6f 64 65 5f 6d 61 | soundex|_code_ma|
|00003d50| 70 5b 5d 3b 0a 58 0a 40 | 2f 2f 45 2a 4f 2a 46 20 |p[];.X.@|//E*O*F |
|00003d60| 73 70 2e 68 2f 2f 0a 69 | 66 20 74 65 73 74 20 33 |sp.h//.i|f test 3|
|00003d70| 35 35 33 20 2d 6e 65 20 | 22 60 77 63 20 2d 63 20 |553 -ne |"`wc -c |
|00003d80| 3c 27 73 70 2e 68 27 60 | 22 3b 20 74 68 65 6e 0a |<'sp.h'`|"; then.|
|00003d90| 20 20 20 20 65 63 68 6f | 20 73 68 61 72 3a 20 65 | echo| shar: e|
|00003da0| 72 72 6f 72 20 74 72 61 | 6e 73 6d 69 74 74 69 6e |rror tra|nsmittin|
|00003db0| 67 20 22 27 73 70 2e 68 | 27 22 20 27 28 73 68 6f |g "'sp.h|'" '(sho|
|00003dc0| 75 6c 64 20 68 61 76 65 | 20 62 65 65 6e 20 33 35 |uld have| been 35|
|00003dd0| 35 33 20 63 68 61 72 61 | 63 74 65 72 73 29 27 0a |53 chara|cters)'.|
|00003de0| 66 69 0a 66 69 20 23 20 | 65 6e 64 20 6f 66 20 6f |fi.fi # |end of o|
|00003df0| 76 65 72 77 72 69 74 69 | 6e 67 20 63 68 65 63 6b |verwriti|ng check|
|00003e00| 0a 65 63 68 6f 20 73 68 | 61 72 3a 20 65 78 74 72 |.echo sh|ar: extr|
|00003e10| 61 63 74 69 6e 67 20 22 | 27 73 70 2e 6d 6c 27 22 |acting "|'sp.ml'"|
|00003e20| 20 27 28 31 36 31 33 20 | 63 68 61 72 61 63 74 65 | '(1613 |characte|
|00003e30| 72 73 29 27 0a 69 66 20 | 74 65 73 74 20 2d 66 20 |rs)'.if |test -f |
|00003e40| 27 73 70 2e 6d 6c 27 20 | 3b 20 74 68 65 6e 20 0a |'sp.ml' |; then .|
|00003e50| 20 20 65 63 68 6f 20 73 | 68 61 72 3a 20 77 69 6c | echo s|har: wil|
|00003e60| 6c 20 6e 6f 74 20 6f 76 | 65 72 2d 77 72 69 74 65 |l not ov|er-write|
|00003e70| 20 65 78 69 73 74 69 6e | 67 20 66 69 6c 65 20 22 | existin|g file "|
|00003e80| 27 73 70 2e 6d 6c 27 22 | 0a 65 6c 73 65 0a 73 65 |'sp.ml'"|.else.se|
|00003e90| 64 20 27 73 2f 5e 58 2f | 2f 27 20 3e 73 70 2e 6d |d 's/^X/|/' >sp.m|
|00003ea0| 6c 20 3c 3c 27 40 2f 2f | 45 2a 4f 2a 46 20 73 70 |l <<'@//|E*O*F sp|
|00003eb0| 2e 6d 6c 2f 2f 27 0a 58 | 3b 20 0a 58 3b 20 57 72 |.ml//'.X|; .X; Wr|
|00003ec0| 69 74 74 65 6e 20 62 79 | 20 44 6f 6e 61 6c 64 20 |itten by| Donald |
|00003ed0| 41 63 74 6f 6e 20 61 6e | 64 20 42 61 72 72 79 20 |Acton an|d Barry |
|00003ee0| 42 72 61 63 68 6d 61 6e | 20 77 69 74 68 20 68 65 |Brachman| with he|
|00003ef0| 6c 70 20 66 72 6f 6d 20 | 4d 61 72 63 20 4d 61 6a |lp from |Marc Maj|
|00003f00| 6b 61 0a 58 3b 20 20 4d | 61 72 63 68 20 31 31 2f |ka.X; M|arch 11/|
|00003f10| 38 35 0a 58 3b 0a 58 3b | 20 44 65 70 74 2e 20 6f |85.X;.X;| Dept. o|
|00003f20| 66 20 43 6f 6d 70 75 74 | 65 72 20 53 63 69 65 6e |f Comput|er Scien|
|00003f30| 63 65 0a 58 3b 20 55 6e | 69 76 65 72 73 69 74 79 |ce.X; Un|iversity|
|00003f40| 20 6f 66 20 42 72 69 74 | 69 73 68 20 43 6f 6c 75 | of Brit|ish Colu|
|00003f50| 6d 62 69 61 0a 58 3b 20 | 0a 58 0a 58 28 64 65 66 |mbia.X; |.X.X(def|
|00003f60| 75 6e 20 0a 58 20 20 20 | 20 28 73 70 20 73 70 77 |un .X | (sp spw|
|00003f70| 6f 72 64 0a 58 20 20 20 | 20 20 20 28 73 65 74 71 |ord.X | (setq|
|00003f80| 20 73 70 77 6f 72 64 20 | 28 67 65 74 2d 74 74 79 | spword |(get-tty|
|00003f90| 2d 73 74 72 69 6e 67 20 | 22 57 6f 72 64 3a 20 22 |-string |"Word: "|
|00003fa0| 20 29 29 0a 58 20 20 20 | 20 20 20 28 64 6f 2d 73 | )).X | (do-s|
|00003fb0| 70 20 73 70 77 6f 72 64 | 29 0a 58 20 20 20 20 29 |p spword|).X )|
|00003fc0| 0a 58 29 0a 58 0a 58 28 | 64 65 66 75 6e 09 09 09 |.X).X.X(|defun...|
|00003fd0| 09 09 09 3b 20 62 6a 62 | 0a 58 20 20 20 20 28 73 |...; bjb|.X (s|
|00003fe0| 70 2d 66 72 6f 6d 2d 62 | 75 66 66 65 72 20 73 70 |p-from-b|uffer sp|
|00003ff0| 77 6f 72 64 0a 58 09 28 | 73 65 74 71 20 73 70 77 |word.X.(|setq spw|
|00004000| 6f 72 64 20 28 67 65 74 | 2d 6e 65 78 74 2d 77 6f |ord (get|-next-wo|
|00004010| 72 64 29 29 0a 58 09 28 | 6d 65 73 73 61 67 65 20 |rd)).X.(|message |
|00004020| 28 63 6f 6e 63 61 74 20 | 22 57 6f 72 64 3a 20 22 |(concat |"Word: "|
|00004030| 20 73 70 77 6f 72 64 29 | 29 0a 58 09 28 73 69 74 | spword)|).X.(sit|
|00004040| 2d 66 6f 72 20 30 29 0a | 58 09 28 64 6f 2d 73 70 |-for 0).|X.(do-sp|
|00004050| 20 73 70 77 6f 72 64 29 | 0a 58 20 20 20 20 29 0a | spword)|.X ).|
|00004060| 58 29 0a 58 0a 58 28 64 | 65 66 75 6e 0a 58 20 20 |X).X.X(d|efun.X |
|00004070| 20 20 28 64 6f 2d 73 70 | 20 63 75 72 72 20 66 6f | (do-sp| curr fo|
|00004080| 75 6e 64 20 74 6d 70 0a | 58 20 20 20 20 20 20 28 |und tmp.|X (|
|00004090| 73 65 74 71 20 63 75 72 | 72 20 28 63 75 72 72 65 |setq cur|r (curre|
|000040a0| 6e 74 2d 62 75 66 66 65 | 72 2d 6e 61 6d 65 29 29 |nt-buffe|r-name))|
|000040b0| 0a 58 20 20 20 20 20 20 | 28 70 6f 70 2d 74 6f 2d |.X |(pop-to-|
|000040c0| 62 75 66 66 65 72 20 22 | 73 70 22 29 0a 58 20 20 |buffer "|sp").X |
|000040d0| 20 20 20 20 28 73 65 74 | 71 20 6e 65 65 64 73 2d | (set|q needs-|
|000040e0| 63 68 65 63 6b 70 6f 69 | 6e 74 69 6e 67 20 30 29 |checkpoi|nting 0)|
|000040f0| 0a 58 20 20 20 20 20 20 | 28 65 72 61 73 65 2d 62 |.X |(erase-b|
|00004100| 75 66 66 65 72 29 0a 58 | 20 20 20 20 20 20 28 73 |uffer).X| (s|
|00004110| 65 74 2d 6d 61 72 6b 29 | 0a 58 20 20 20 20 20 20 |et-mark)|.X |
|00004120| 28 66 69 6c 74 65 72 2d | 72 65 67 69 6f 6e 20 28 |(filter-|region (|
|00004130| 63 6f 6e 63 61 74 20 22 | 73 70 20 22 20 73 70 77 |concat "|sp " spw|
|00004140| 6f 72 64 29 29 0a 58 20 | 20 20 20 20 20 28 62 65 |ord)).X | (be|
|00004150| 67 69 6e 6e 69 6e 67 2d | 6f 66 2d 66 69 6c 65 29 |ginning-|of-file)|
|00004160| 0a 58 20 20 20 20 20 20 | 28 73 65 74 71 20 66 6f |.X |(setq fo|
|00004170| 75 6e 64 20 22 20 2a 6e | 6f 74 20 66 6f 75 6e 64 |und " *n|ot found|
|00004180| 2a 22 29 0a 58 20 20 20 | 20 20 20 28 73 65 74 71 |*").X | (setq|
|00004190| 20 74 6d 70 20 63 61 73 | 65 2d 66 6f 6c 64 2d 73 | tmp cas|e-fold-s|
|000041a0| 65 61 72 63 68 29 0a 58 | 20 20 20 20 20 20 28 73 |earch).X| (s|
|000041b0| 65 74 71 20 63 61 73 65 | 2d 66 6f 6c 64 2d 73 65 |etq case|-fold-se|
|000041c0| 61 72 63 68 20 31 29 0a | 58 20 20 20 20 20 20 28 |arch 1).|X (|
|000041d0| 65 72 72 6f 72 2d 6f 63 | 63 75 72 72 65 64 20 28 |error-oc|curred (|
|000041e0| 72 65 2d 73 65 61 72 63 | 68 2d 66 6f 72 77 61 72 |re-searc|h-forwar|
|000041f0| 64 20 28 63 6f 6e 63 61 | 74 20 22 5c 2e 20 22 20 |d (conca|t "\. " |
|00004200| 73 70 77 6f 72 64 20 22 | 24 22 29 29 0a 58 20 20 |spword "|$")).X |
|00004210| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00004220| 20 20 20 20 20 28 62 65 | 67 69 6e 6e 69 6e 67 2d | (be|ginning-|
|00004230| 6f 66 2d 6c 69 6e 65 29 | 0a 58 20 20 20 20 20 20 |of-line)|.X |
|00004240| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00004250| 20 28 6c 69 6e 65 2d 74 | 6f 2d 74 6f 70 2d 6f 66 | (line-t|o-top-of|
|00004260| 2d 77 69 6e 64 6f 77 29 | 0a 58 20 20 20 20 20 20 |-window)|.X |
|00004270| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00004280| 20 28 73 65 74 71 20 66 | 6f 75 6e 64 20 22 20 2a | (setq f|ound " *|
|00004290| 66 6f 75 6e 64 2a 22 29 | 29 0a 58 20 20 20 20 20 |found*")|).X |
|000042a0| 20 28 73 65 74 71 20 63 | 61 73 65 2d 66 6f 6c 64 | (setq c|ase-fold|
|000042b0| 2d 73 65 61 72 63 68 20 | 74 6d 70 29 0a 58 20 20 |-search |tmp).X |
|000042c0| 20 20 20 20 28 73 65 74 | 71 20 6d 6f 64 65 2d 6c | (set|q mode-l|
|000042d0| 69 6e 65 2d 66 6f 72 6d | 61 74 20 22 20 25 62 20 |ine-form|at " %b |
|000042e0| 2d 20 25 6d 20 20 20 20 | 20 20 25 70 22 29 0a 58 |- %m | %p").X|
|000042f0| 20 20 20 20 20 20 28 73 | 65 74 71 20 6d 6f 64 65 | (s|etq mode|
|00004300| 2d 73 74 72 69 6e 67 20 | 28 63 6f 6e 63 61 74 20 |-string |(concat |
|00004310| 73 70 77 6f 72 64 20 66 | 6f 75 6e 64 29 29 0a 58 |spword f|ound)).X|
|00004320| 20 20 20 20 20 20 28 70 | 6f 70 2d 74 6f 2d 62 75 | (p|op-to-bu|
|00004330| 66 66 65 72 20 63 75 72 | 72 29 0a 58 20 20 20 20 |ffer cur|r).X |
|00004340| 20 20 28 6e 6f 76 61 6c | 75 65 29 29 29 0a 58 0a | (noval|ue))).X.|
|00004350| 58 3b 0a 58 3b 20 52 65 | 74 75 72 6e 20 74 68 65 |X;.X; Re|turn the|
|00004360| 20 77 6f 72 64 20 74 68 | 65 20 63 75 72 73 6f 72 | word th|e cursor|
|00004370| 20 69 73 20 70 6f 69 6e | 74 69 6e 67 20 61 74 0a | is poin|ting at.|
|00004380| 58 3b 20 6f 72 20 74 68 | 65 20 77 6f 72 64 20 69 |X; or th|e word i|
|00004390| 6d 6d 65 64 69 61 74 65 | 6c 79 20 74 6f 20 74 68 |mmediate|ly to th|
|000043a0| 65 20 6c 65 66 74 20 6f | 66 20 74 68 65 0a 58 3b |e left o|f the.X;|
|000043b0| 20 63 75 72 73 6f 72 20 | 69 66 20 69 74 20 69 73 | cursor |if it is|
|000043c0| 20 62 65 74 77 65 65 6e | 20 77 6f 72 64 73 0a 58 | between| words.X|
|000043d0| 3b 0a 58 3b 20 41 70 72 | 69 6c 20 31 35 2f 38 35 |;.X; Apr|il 15/85|
|000043e0| 20 2d 20 62 6a 62 0a 58 | 3b 0a 58 28 64 65 66 75 | - bjb.X|;.X(defu|
|000043f0| 6e 0a 58 20 20 20 20 28 | 67 65 74 2d 6e 65 78 74 |n.X (|get-next|
|00004400| 2d 77 6f 72 64 20 6f 72 | 69 67 69 6e 61 6c 2d 64 |-word or|iginal-d|
|00004410| 6f 74 20 72 62 20 73 70 | 77 6f 72 64 0a 58 09 28 |ot rb sp|word.X.(|
|00004420| 73 61 76 65 2d 65 78 63 | 75 72 73 69 6f 6e 0a 58 |save-exc|ursion.X|
|00004430| 09 20 20 20 20 28 73 65 | 74 71 20 6f 72 69 67 69 |. (se|tq origi|
|00004440| 6e 61 6c 2d 64 6f 74 20 | 28 64 6f 74 29 29 0a 58 |nal-dot |(dot)).X|
|00004450| 09 20 20 20 20 28 62 61 | 63 6b 77 61 72 64 2d 77 |. (ba|ckward-w|
|00004460| 6f 72 64 29 20 28 66 6f | 72 77 61 72 64 2d 77 6f |ord) (fo|rward-wo|
|00004470| 72 64 29 20 28 73 65 74 | 71 20 72 62 20 28 64 6f |rd) (set|q rb (do|
|00004480| 74 29 29 0a 58 09 20 20 | 20 20 28 69 66 20 28 3e |t)).X. | (if (>|
|00004490| 20 6f 72 69 67 69 6e 61 | 6c 2d 64 6f 74 20 72 62 | origina|l-dot rb|
|000044a0| 29 0a 58 09 09 28 70 72 | 6f 67 6e 20 28 66 6f 72 |).X..(pr|ogn (for|
|000044b0| 77 61 72 64 2d 77 6f 72 | 64 29 20 28 62 61 63 6b |ward-wor|d) (back|
|000044c0| 77 61 72 64 2d 77 6f 72 | 64 29 29 0a 58 09 20 20 |ward-wor|d)).X. |
|000044d0| 20 20 28 62 61 63 6b 77 | 61 72 64 2d 77 6f 72 64 | (backw|ard-word|
|000044e0| 29 29 0a 58 09 20 20 20 | 20 28 73 65 74 2d 6d 61 |)).X. | (set-ma|
|000044f0| 72 6b 29 0a 58 09 20 20 | 20 20 28 66 6f 72 77 61 |rk).X. | (forwa|
|00004500| 72 64 2d 77 6f 72 64 29 | 0a 58 09 20 20 20 20 28 |rd-word)|.X. (|
|00004510| 73 65 74 71 20 73 70 77 | 6f 72 64 20 28 72 65 67 |setq spw|ord (reg|
|00004520| 69 6f 6e 2d 74 6f 2d 73 | 74 72 69 6e 67 29 29 0a |ion-to-s|tring)).|
|00004530| 58 09 29 0a 58 09 73 70 | 77 6f 72 64 0a 58 20 20 |X.).X.sp|word.X |
|00004540| 20 29 0a 58 29 20 0a 58 | 0a 40 2f 2f 45 2a 4f 2a | ).X) .X|.@//E*O*|
|00004550| 46 20 73 70 2e 6d 6c 2f | 2f 0a 69 66 20 74 65 73 |F sp.ml/|/.if tes|
|00004560| 74 20 31 36 31 33 20 2d | 6e 65 20 22 60 77 63 20 |t 1613 -|ne "`wc |
|00004570| 2d 63 20 3c 27 73 70 2e | 6d 6c 27 60 22 3b 20 74 |-c <'sp.|ml'`"; t|
|00004580| 68 65 6e 0a 20 20 20 20 | 65 63 68 6f 20 73 68 61 |hen. |echo sha|
|00004590| 72 3a 20 65 72 72 6f 72 | 20 74 72 61 6e 73 6d 69 |r: error| transmi|
|000045a0| 74 74 69 6e 67 20 22 27 | 73 70 2e 6d 6c 27 22 20 |tting "'|sp.ml'" |
|000045b0| 27 28 73 68 6f 75 6c 64 | 20 68 61 76 65 20 62 65 |'(should| have be|
|000045c0| 65 6e 20 31 36 31 33 20 | 63 68 61 72 61 63 74 65 |en 1613 |characte|
|000045d0| 72 73 29 27 0a 66 69 0a | 66 69 20 23 20 65 6e 64 |rs)'.fi.|fi # end|
|000045e0| 20 6f 66 20 6f 76 65 72 | 77 72 69 74 69 6e 67 20 | of over|writing |
|000045f0| 63 68 65 63 6b 0a 65 63 | 68 6f 20 73 68 61 72 3a |check.ec|ho shar:|
|00004600| 20 22 45 6e 64 20 6f 66 | 20 61 72 63 68 69 76 65 | "End of| archive|
|00004610| 20 32 20 28 6f 66 20 32 | 29 2e 22 0a 63 70 20 2f | 2 (of 2|).".cp /|
|00004620| 64 65 76 2f 6e 75 6c 6c | 20 61 72 6b 32 69 73 64 |dev/null| ark2isd|
|00004630| 6f 6e 65 0a 44 4f 4e 45 | 3d 74 72 75 65 0a 66 6f |one.DONE|=true.fo|
|00004640| 72 20 49 20 69 6e 20 31 | 20 32 3b 20 64 6f 0a 20 |r I in 1| 2; do. |
|00004650| 20 20 20 69 66 20 74 65 | 73 74 20 21 20 2d 66 20 | if te|st ! -f |
|00004660| 61 72 6b 24 7b 49 7d 69 | 73 64 6f 6e 65 3b 20 74 |ark${I}i|sdone; t|
|00004670| 68 65 6e 0a 20 20 20 20 | 20 20 20 20 65 63 68 6f |hen. | echo|
|00004680| 20 22 59 6f 75 20 73 74 | 69 6c 6c 20 6e 65 65 64 | "You st|ill need|
|00004690| 20 74 6f 20 72 75 6e 20 | 61 72 63 68 69 76 65 20 | to run |archive |
|000046a0| 24 7b 49 7d 2e 22 0a 20 | 20 20 20 20 20 20 20 44 |${I}.". | D|
|000046b0| 4f 4e 45 3d 66 61 6c 73 | 65 0a 20 20 20 20 66 69 |ONE=fals|e. fi|
|000046c0| 0a 64 6f 6e 65 0a 63 61 | 73 65 20 24 44 4f 4e 45 |.done.ca|se $DONE|
|000046d0| 20 69 6e 0a 20 20 20 20 | 74 72 75 65 29 0a 20 20 | in. |true). |
|000046e0| 20 20 20 20 20 20 65 63 | 68 6f 20 22 59 6f 75 20 | ec|ho "You |
|000046f0| 68 61 76 65 20 72 75 6e | 20 62 6f 74 68 20 61 72 |have run| both ar|
|00004700| 63 68 69 76 65 73 2e 22 | 0a 20 20 20 20 20 20 20 |chives."|. |
|00004710| 20 65 63 68 6f 20 27 53 | 65 65 20 74 68 65 20 52 | echo 'S|ee the R|
|00004720| 45 41 44 4d 45 27 0a 20 | 20 20 20 20 20 20 20 3b |EADME'. | ;|
|00004730| 3b 0a 65 73 61 63 0a 23 | 23 20 20 45 6e 64 20 6f |;.esac.#|# End o|
|00004740| 66 20 73 68 65 6c 6c 20 | 61 72 63 68 69 76 65 2e |f shell |archive.|
|00004750| 0a 65 78 69 74 20 30 0a | |.exit 0.| |
+--------+-------------------------+-------------------------+--------+--------+