home *** CD-ROM | disk | FTP | other *** search
/ Usenet 1994 January / usenetsourcesnewsgroupsinfomagicjanuary1994.iso / sources / unix / volume12 / pathalias9 / part02 < prev    next >
SHell self-extracting ARchive  |  1987-10-08  |  59.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, ASCII text default
100% checkBytes Printable ASCII default
100% perlTextCheck Likely Text (Perl) default
100% siegfried fmt/329 Shell Archive Format default
100% detectItEasy Format: plain text[LF] default (weak)
100% xdgMime message/rfc822 default



hex view
+--------+-------------------------+-------------------------+--------+--------+
|00000000| 53 75 62 6a 65 63 74 3a | 20 20 76 31 32 69 30 30 |Subject:| v12i00|
|00000010| 32 3a 20 20 50 61 74 68 | 61 6c 69 61 73 2c 20 76 |2: Path|alias, v|
|00000020| 65 72 73 69 6f 6e 20 39 | 2c 20 50 61 72 74 30 32 |ersion 9|, Part02|
|00000030| 2f 30 32 0a 4e 65 77 73 | 67 72 6f 75 70 73 3a 20 |/02.News|groups: |
|00000040| 63 6f 6d 70 2e 73 6f 75 | 72 63 65 73 2e 75 6e 69 |comp.sou|rces.uni|
|00000050| 78 0a 53 65 6e 64 65 72 | 3a 20 73 6f 75 72 63 65 |x.Sender|: source|
|00000060| 73 0a 41 70 70 72 6f 76 | 65 64 3a 20 72 73 40 75 |s.Approv|ed: rs@u|
|00000070| 75 6e 65 74 2e 55 55 2e | 4e 45 54 0a 0a 53 75 62 |unet.UU.|NET..Sub|
|00000080| 6d 69 74 74 65 64 2d 62 | 79 3a 20 68 6f 6e 65 79 |mitted-b|y: honey|
|00000090| 40 43 49 54 49 2e 55 4d | 49 43 48 2e 45 44 55 20 |@CITI.UM|ICH.EDU |
|000000a0| 28 50 65 74 65 72 20 48 | 6f 6e 65 79 6d 61 6e 29 |(Peter H|oneyman)|
|000000b0| 0a 50 6f 73 74 69 6e 67 | 2d 6e 75 6d 62 65 72 3a |.Posting|-number:|
|000000c0| 20 56 6f 6c 75 6d 65 20 | 31 32 2c 20 49 73 73 75 | Volume |12, Issu|
|000000d0| 65 20 32 0a 41 72 63 68 | 69 76 65 2d 6e 61 6d 65 |e 2.Arch|ive-name|
|000000e0| 3a 20 70 61 74 68 61 6c | 69 61 73 39 2f 70 61 72 |: pathal|ias9/par|
|000000f0| 74 30 32 0a 0a 5b 20 20 | 54 68 69 73 20 69 73 20 |t02..[ |This is |
|00000100| 74 68 65 20 6c 61 74 65 | 73 74 20 61 6e 64 20 67 |the late|st and g|
|00000110| 72 65 61 74 65 73 74 20 | 70 61 74 68 61 6c 69 61 |reatest |pathalia|
|00000120| 73 2c 20 61 6e 64 20 6f | 74 68 65 72 20 74 6f 6f |s, and o|ther too|
|00000130| 6c 73 2e 20 20 49 74 20 | 6d 61 79 0a 20 20 20 77 |ls. It |may. w|
|00000140| 65 6c 6c 20 62 65 20 74 | 68 65 20 6c 61 73 74 20 |ell be t|he last |
|00000150| 6f 6e 65 20 70 65 74 65 | 72 20 65 76 65 72 20 77 |one pete|r ever w|
|00000160| 6f 72 6b 73 20 6f 6e 2c | 20 6a 75 64 67 69 6e 67 |orks on,| judging|
|00000170| 20 66 72 6f 6d 20 68 69 | 73 20 6f 66 66 2d 6c 69 | from hi|s off-li|
|00000180| 6e 65 0a 20 20 20 72 65 | 6d 61 72 6b 73 2e 2e 2e |ne. re|marks...|
|00000190| 20 3a 2d 29 20 20 54 68 | 69 73 20 76 65 72 73 69 | :-) Th|is versi|
|000001a0| 6f 6e 20 68 61 73 20 68 | 61 64 20 73 65 76 65 72 |on has h|ad sever|
|000001b0| 61 6c 20 62 75 67 73 20 | 66 69 78 65 64 2c 20 61 |al bugs |fixed, a|
|000001c0| 6e 64 20 68 61 73 0a 20 | 20 20 62 65 65 6e 20 74 |nd has. | been t|
|000001d0| 65 73 74 65 64 20 6f 6e | 20 42 53 44 2c 20 53 75 |ested on| BSD, Su|
|000001e0| 6e 2c 20 33 42 2c 20 53 | 79 73 56 2c 20 4d 61 63 |n, 3B, S|ysV, Mac|
|000001f0| 2c 20 65 74 63 2e 20 20 | 4d 4f 53 54 20 49 4d 50 |, etc. |MOST IMP|
|00000200| 4f 52 54 41 4e 54 4c 59 | 3a 0a 20 20 20 69 74 20 |ORTANTLY|:. it |
|00000210| 68 61 73 20 73 65 76 65 | 72 61 6c 20 6e 65 77 20 |has seve|ral new |
|00000220| 66 65 61 74 75 72 65 73 | 2c 20 61 6e 64 20 61 64 |features|, and ad|
|00000230| 64 69 74 69 6f 6e 73 20 | 74 6f 20 74 68 65 20 69 |ditions |to the i|
|00000240| 6e 70 75 74 20 73 79 6e | 74 61 78 2c 20 74 68 61 |nput syn|tax, tha|
|00000250| 74 0a 20 20 20 79 6f 75 | 20 77 69 6c 6c 20 6e 65 |t. you| will ne|
|00000260| 65 64 20 66 6f 72 20 61 | 6c 6c 20 66 75 74 75 72 |ed for a|ll futur|
|00000270| 65 20 55 55 43 50 20 6d | 61 70 73 2e 20 20 46 69 |e UUCP m|aps. Fi|
|00000280| 6e 61 6c 6c 79 2c 20 68 | 61 64 20 49 20 61 6e 0a |nally, h|ad I an.|
|00000290| 20 20 20 69 72 72 65 6c | 65 76 61 6e 74 20 61 78 | irrel|evant ax|
|000002a0| 65 20 74 6f 20 67 72 69 | 6e 64 2c 20 49 27 64 20 |e to gri|nd, I'd |
|000002b0| 70 6f 69 6e 74 20 6f 75 | 74 20 74 68 61 74 20 74 |point ou|t that t|
|000002c0| 68 69 73 20 63 6f 64 65 | 20 68 61 73 20 6e 6f 0a |his code| has no.|
|000002d0| 20 20 20 63 6f 70 79 72 | 69 67 68 74 20 61 6e 64 | copyr|ight and|
|000002e0| 20 69 73 20 69 6e 20 74 | 68 65 20 70 75 62 6c 69 | is in t|he publi|
|000002f0| 63 20 64 6f 6d 61 69 6e | 2e 20 20 2d 2d 72 24 20 |c domain|. --r$ |
|00000300| 20 5d 0a 0a 23 21 20 2f | 62 69 6e 2f 73 68 0a 23 | ]..#! /|bin/sh.#|
|00000310| 20 54 68 69 73 20 69 73 | 20 61 20 73 68 65 6c 6c | This is| a shell|
|00000320| 20 61 72 63 68 69 76 65 | 2e 20 20 52 65 6d 6f 76 | archive|. Remov|
|00000330| 65 20 61 6e 79 74 68 69 | 6e 67 20 62 65 66 6f 72 |e anythi|ng befor|
|00000340| 65 20 74 68 69 73 20 6c | 69 6e 65 2c 20 74 68 65 |e this l|ine, the|
|00000350| 6e 20 75 6e 70 61 63 6b | 0a 23 20 69 74 20 62 79 |n unpack|.# it by|
|00000360| 20 73 61 76 69 6e 67 20 | 69 74 20 69 6e 74 6f 20 | saving |it into |
|00000370| 61 20 66 69 6c 65 20 61 | 6e 64 20 74 79 70 69 6e |a file a|nd typin|
|00000380| 67 20 22 73 68 20 66 69 | 6c 65 22 2e 20 20 54 6f |g "sh fi|le". To|
|00000390| 20 6f 76 65 72 77 72 69 | 74 65 20 65 78 69 73 74 | overwri|te exist|
|000003a0| 69 6e 67 0a 23 20 66 69 | 6c 65 73 2c 20 74 79 70 |ing.# fi|les, typ|
|000003b0| 65 20 22 73 68 20 66 69 | 6c 65 20 2d 63 22 2e 20 |e "sh fi|le -c". |
|000003c0| 20 59 6f 75 20 63 61 6e | 20 61 6c 73 6f 20 66 65 | You can| also fe|
|000003d0| 65 64 20 74 68 69 73 20 | 61 73 20 73 74 61 6e 64 |ed this |as stand|
|000003e0| 61 72 64 20 69 6e 70 75 | 74 20 76 69 61 0a 23 20 |ard inpu|t via.# |
|000003f0| 75 6e 73 68 61 72 2c 20 | 6f 72 20 62 79 20 74 79 |unshar, |or by ty|
|00000400| 70 69 6e 67 20 22 73 68 | 20 3c 66 69 6c 65 22 2c |ping "sh| <file",|
|00000410| 20 65 2e 67 2e 2e 20 20 | 49 66 20 74 68 69 73 20 | e.g.. |If this |
|00000420| 61 72 63 68 69 76 65 20 | 69 73 20 63 6f 6d 70 6c |archive |is compl|
|00000430| 65 74 65 2c 20 79 6f 75 | 0a 23 20 77 69 6c 6c 20 |ete, you|.# will |
|00000440| 73 65 65 20 74 68 65 20 | 66 6f 6c 6c 6f 77 69 6e |see the |followin|
|00000450| 67 20 6d 65 73 73 61 67 | 65 20 61 74 20 74 68 65 |g messag|e at the|
|00000460| 20 65 6e 64 3a 0a 23 09 | 09 22 45 6e 64 20 6f 66 | end:.#.|."End of|
|00000470| 20 61 72 63 68 69 76 65 | 20 32 20 28 6f 66 20 32 | archive| 2 (of 2|
|00000480| 29 2e 22 0a 23 20 43 6f | 6e 74 65 6e 74 73 3a 20 |).".# Co|ntents: |
|00000490| 20 61 64 64 6e 6f 64 65 | 2e 63 20 61 72 70 61 74 | addnode|.c arpat|
|000004a0| 78 74 2e 63 20 6d 61 70 | 69 74 2e 63 20 70 61 72 |xt.c map|it.c par|
|000004b0| 73 65 2e 79 20 70 61 74 | 68 61 6c 69 61 73 2e 31 |se.y pat|halias.1|
|000004c0| 0a 23 20 57 72 61 70 70 | 65 64 20 62 79 20 72 73 |.# Wrapp|ed by rs|
|000004d0| 61 6c 7a 40 75 75 6e 65 | 74 20 6f 6e 20 4d 6f 6e |alz@uune|t on Mon|
|000004e0| 20 4f 63 74 20 20 35 20 | 32 32 3a 34 35 3a 31 32 | Oct 5 |22:45:12|
|000004f0| 20 31 39 38 37 0a 50 41 | 54 48 3d 2f 62 69 6e 3a | 1987.PA|TH=/bin:|
|00000500| 2f 75 73 72 2f 62 69 6e | 3a 2f 75 73 72 2f 75 63 |/usr/bin|:/usr/uc|
|00000510| 62 20 3b 20 65 78 70 6f | 72 74 20 50 41 54 48 0a |b ; expo|rt PATH.|
|00000520| 69 66 20 74 65 73 74 20 | 2d 66 20 61 64 64 6e 6f |if test |-f addno|
|00000530| 64 65 2e 63 20 2d 61 20 | 22 24 7b 31 7d 22 20 21 |de.c -a |"${1}" !|
|00000540| 3d 20 22 2d 63 22 20 3b | 20 74 68 65 6e 20 0a 20 |= "-c" ;| then . |
|00000550| 20 65 63 68 6f 20 73 68 | 61 72 3a 20 57 69 6c 6c | echo sh|ar: Will|
|00000560| 20 6e 6f 74 20 6f 76 65 | 72 2d 77 72 69 74 65 20 | not ove|r-write |
|00000570| 65 78 69 73 74 69 6e 67 | 20 66 69 6c 65 20 5c 22 |existing| file \"|
|00000580| 61 64 64 6e 6f 64 65 2e | 63 5c 22 0a 65 6c 73 65 |addnode.|c\".else|
|00000590| 0a 65 63 68 6f 20 73 68 | 61 72 3a 20 45 78 74 72 |.echo sh|ar: Extr|
|000005a0| 61 63 74 69 6e 67 20 5c | 22 61 64 64 6e 6f 64 65 |acting \|"addnode|
|000005b0| 2e 63 5c 22 20 5c 28 38 | 35 31 34 20 63 68 61 72 |.c\" \(8|514 char|
|000005c0| 61 63 74 65 72 73 5c 29 | 0a 73 65 64 20 22 73 2f |acters\)|.sed "s/|
|000005d0| 5e 58 2f 2f 22 20 3e 61 | 64 64 6e 6f 64 65 2e 63 |^X//" >a|ddnode.c|
|000005e0| 20 3c 3c 27 45 4e 44 5f | 4f 46 5f 61 64 64 6e 6f | <<'END_|OF_addno|
|000005f0| 64 65 2e 63 27 0a 58 2f | 2a 20 70 61 74 68 61 6c |de.c'.X/|* pathal|
|00000600| 69 61 73 20 2d 2d 20 62 | 79 20 73 74 65 76 65 20 |ias -- b|y steve |
|00000610| 62 65 6c 6c 6f 76 69 6e | 2c 20 61 73 20 74 6f 6c |bellovin|, as tol|
|00000620| 64 20 74 6f 20 70 65 74 | 65 72 20 68 6f 6e 65 79 |d to pet|er honey|
|00000630| 6d 61 6e 20 2a 2f 0a 58 | 23 69 66 6e 64 65 66 20 |man */.X|#ifndef |
|00000640| 6c 69 6e 74 0a 58 73 74 | 61 74 69 63 20 63 68 61 |lint.Xst|atic cha|
|00000650| 72 09 2a 73 63 63 73 69 | 64 20 3d 20 22 40 28 23 |r.*sccsi|d = "@(#|
|00000660| 29 61 64 64 6e 6f 64 65 | 2e 63 09 39 2e 31 20 38 |)addnode|.c.9.1 8|
|00000670| 37 2f 31 30 2f 30 34 22 | 3b 0a 58 23 65 6e 64 69 |7/10/04"|;.X#endi|
|00000680| 66 0a 58 0a 58 23 69 6e | 63 6c 75 64 65 20 22 64 |f.X.X#in|clude "d|
|00000690| 65 66 2e 68 22 0a 58 0a | 58 2f 2a 20 65 78 70 6f |ef.h".X.|X/* expo|
|000006a0| 72 74 73 20 2a 2f 0a 58 | 6e 6f 64 65 20 2a 61 64 |rts */.X|node *ad|
|000006b0| 64 6e 6f 64 65 28 29 2c | 20 2a 61 64 64 70 72 69 |dnode(),| *addpri|
|000006c0| 76 61 74 65 28 29 3b 0a | 58 76 6f 69 64 20 61 6c |vate();.|Xvoid al|
|000006d0| 69 61 73 28 29 2c 20 68 | 61 73 68 61 6e 61 6c 79 |ias(), h|ashanaly|
|000006e0| 7a 65 28 29 2c 20 66 69 | 78 70 72 69 76 61 74 65 |ze(), fi|xprivate|
|000006f0| 28 29 2c 20 70 65 6e 61 | 6c 69 7a 65 28 29 3b 0a |(), pena|lize();.|
|00000700| 58 6e 6f 64 65 20 2a 2a | 54 61 62 6c 65 3b 09 09 |Xnode **|Table;..|
|00000710| 09 09 2f 2a 20 68 61 73 | 68 20 74 61 62 6c 65 20 |../* has|h table |
|00000720| 5e 20 70 72 69 6f 72 69 | 74 79 20 71 75 65 75 65 |^ priori|ty queue|
|00000730| 20 2a 2f 0a 58 6c 6f 6e | 67 20 54 61 62 73 69 7a | */.Xlon|g Tabsiz|
|00000740| 65 3b 09 09 09 09 2f 2a | 20 73 69 7a 65 20 6f 66 |e;..../*| size of|
|00000750| 20 54 61 62 6c 65 20 2a | 2f 09 0a 58 0a 58 2f 2a | Table *|/..X.X/*|
|00000760| 20 69 6d 70 6f 72 74 73 | 20 2a 2f 0a 58 65 78 74 | imports| */.Xext|
|00000770| 65 72 6e 20 6c 69 6e 6b | 20 2a 61 64 64 6c 69 6e |ern link| *addlin|
|00000780| 6b 28 29 3b 0a 58 65 78 | 74 65 72 6e 20 6e 6f 64 |k();.Xex|tern nod|
|00000790| 65 20 2a 6e 65 77 6e 6f | 64 65 28 29 2c 20 2a 2a |e *newno|de(), **|
|000007a0| 6e 65 77 74 61 62 6c 65 | 28 29 3b 0a 58 65 78 74 |newtable|();.Xext|
|000007b0| 65 72 6e 20 63 68 61 72 | 20 2a 73 74 72 73 61 76 |ern char| *strsav|
|000007c0| 65 28 29 3b 0a 58 65 78 | 74 65 72 6e 20 69 6e 74 |e();.Xex|tern int|
|000007d0| 20 49 66 6c 61 67 2c 20 | 54 66 6c 61 67 2c 20 56 | Iflag, |Tflag, V|
|000007e0| 66 6c 61 67 3b 0a 58 65 | 78 74 65 72 6e 20 6e 6f |flag;.Xe|xtern no|
|000007f0| 64 65 20 2a 2a 54 61 62 | 6c 65 3b 0a 58 65 78 74 |de **Tab|le;.Xext|
|00000800| 65 72 6e 20 6c 6f 6e 67 | 20 4e 63 6f 75 6e 74 2c |ern long| Ncount,|
|00000810| 20 54 61 62 73 69 7a 65 | 3b 0a 58 65 78 74 65 72 | Tabsize|;.Xexter|
|00000820| 6e 20 63 68 61 72 20 2a | 2a 41 72 67 76 3b 0a 58 |n char *|*Argv;.X|
|00000830| 65 78 74 65 72 6e 20 76 | 6f 69 64 20 61 74 72 61 |extern v|oid atra|
|00000840| 63 65 28 29 2c 20 64 69 | 65 28 29 3b 0a 58 0a 58 |ce(), di|e();.X.X|
|00000850| 2f 2a 20 70 72 69 76 61 | 74 65 73 20 2a 2f 0a 58 |/* priva|tes */.X|
|00000860| 53 54 41 54 49 43 20 76 | 6f 69 64 20 63 72 63 69 |STATIC v|oid crci|
|00000870| 6e 69 74 28 29 2c 20 72 | 65 68 61 73 68 28 29 2c |nit(), r|ehash(),|
|00000880| 20 6c 6f 77 65 72 63 61 | 73 65 28 29 3b 0a 58 53 | lowerca|se();.XS|
|00000890| 54 41 54 49 43 20 6c 6f | 6e 67 20 66 6f 6c 64 28 |TATIC lo|ng fold(|
|000008a0| 29 3b 0a 58 53 54 41 54 | 49 43 20 6c 6f 6e 67 20 |);.XSTAT|IC long |
|000008b0| 68 61 73 68 28 29 3b 0a | 58 53 54 41 54 49 43 20 |hash();.|XSTATIC |
|000008c0| 6e 6f 64 65 20 2a 69 73 | 70 72 69 76 61 74 65 28 |node *is|private(|
|000008d0| 29 3b 0a 58 73 74 61 74 | 69 63 20 6e 6f 64 65 20 |);.Xstat|ic node |
|000008e0| 2a 50 72 69 76 61 74 65 | 3b 09 2f 2a 20 6c 69 73 |*Private|;./* lis|
|000008f0| 74 20 6f 66 20 70 72 69 | 76 61 74 65 20 6e 6f 64 |t of pri|vate nod|
|00000900| 65 73 20 69 6e 20 63 75 | 72 72 65 6e 74 20 69 6e |es in cu|rrent in|
|00000910| 70 75 74 20 66 69 6c 65 | 20 2a 2f 0a 58 2f 2a 0a |put file| */.X/*.|
|00000920| 58 20 2a 20 74 68 65 73 | 65 20 6e 75 6d 62 65 72 |X * thes|e number|
|00000930| 73 20 61 72 65 20 63 68 | 6f 73 65 6e 20 62 65 63 |s are ch|osen bec|
|00000940| 61 75 73 65 3a 0a 58 20 | 2a 09 2d 3e 20 74 68 65 |ause:.X |*.-> the|
|00000950| 79 20 61 72 65 20 70 72 | 69 6d 65 2c 0a 58 20 2a |y are pr|ime,.X *|
|00000960| 09 2d 3e 20 74 68 65 79 | 20 61 72 65 20 6d 6f 6e |.-> they| are mon|
|00000970| 6f 74 6f 6e 69 63 20 69 | 6e 63 72 65 61 73 69 6e |otonic i|ncreasin|
|00000980| 67 2c 0a 58 20 2a 09 2d | 3e 20 65 61 63 68 20 69 |g,.X *.-|> each i|
|00000990| 73 20 61 20 74 61 64 20 | 73 6d 61 6c 6c 65 72 20 |s a tad |smaller |
|000009a0| 74 68 61 6e 20 61 20 6d | 75 6c 74 69 70 6c 65 20 |than a m|ultiple |
|000009b0| 6f 66 20 31 30 32 34 2c | 0a 58 20 2a 09 2d 3e 20 |of 1024,|.X *.-> |
|000009c0| 74 68 65 79 20 66 6f 72 | 6d 20 61 20 66 69 62 6f |they for|m a fibo|
|000009d0| 6e 61 63 63 69 20 73 65 | 71 75 65 6e 63 65 20 28 |nacci se|quence (|
|000009e0| 61 6c 6d 6f 73 74 29 2e | 0a 58 20 2a 20 74 68 65 |almost).|.X * the|
|000009f0| 20 66 69 72 73 74 20 70 | 6f 69 6e 74 20 79 69 65 | first p|oint yie|
|00000a00| 6c 64 73 20 67 6f 6f 64 | 20 68 61 73 68 20 66 75 |lds good| hash fu|
|00000a10| 6e 63 74 69 6f 6e 73 2c | 20 74 68 65 20 73 65 63 |nctions,| the sec|
|00000a20| 6f 6e 64 20 69 73 20 75 | 73 65 64 20 66 6f 72 20 |ond is u|sed for |
|00000a30| 74 68 65 0a 58 20 2a 20 | 73 74 61 6e 64 61 72 64 |the.X * |standard|
|00000a40| 20 72 65 2d 68 61 73 68 | 69 6e 67 20 69 6d 70 6c | re-hash|ing impl|
|00000a50| 65 6d 65 6e 74 61 74 69 | 6f 6e 20 6f 66 20 6f 70 |ementati|on of op|
|00000a60| 65 6e 20 61 64 64 72 65 | 73 73 69 6e 67 2c 20 74 |en addre|ssing, t|
|00000a70| 68 65 20 74 68 69 72 64 | 0a 58 20 2a 20 6f 70 74 |he third|.X * opt|
|00000a80| 69 6d 69 7a 65 73 20 66 | 6f 72 20 71 75 69 72 6b |imizes f|or quirk|
|00000a90| 73 20 69 6e 20 73 6f 6d | 65 20 6d 61 6c 6c 6f 63 |s in som|e malloc|
|00000aa0| 73 20 69 20 68 61 76 65 | 20 73 65 65 6e 2c 20 61 |s i have| seen, a|
|00000ab0| 6e 64 20 74 68 65 20 66 | 6f 75 72 74 68 20 73 69 |nd the f|ourth si|
|00000ac0| 6d 70 6c 79 0a 58 20 2a | 20 61 70 70 65 61 6c 73 |mply.X *| appeals|
|00000ad0| 20 74 6f 20 6d 65 2e 0a | 58 20 2a 2f 0a 58 73 74 | to me..|X */.Xst|
|00000ae0| 61 74 69 63 20 6c 6f 6e | 67 20 50 72 69 6d 65 73 |atic lon|g Primes|
|00000af0| 5b 5d 20 3d 20 7b 0a 58 | 09 31 30 32 31 2c 20 32 |[] = {.X|.1021, 2|
|00000b00| 30 33 39 2c 20 33 30 36 | 37 2c 20 35 31 31 33 2c |039, 306|7, 5113,|
|00000b10| 20 38 31 37 39 2c 20 31 | 33 33 30 39 2c 20 32 31 | 8179, 1|3309, 21|
|00000b20| 34 39 39 2c 20 33 34 38 | 30 37 2c 20 35 36 33 31 |499, 348|07, 5631|
|00000b30| 31 2c 20 30 0a 58 7d 3b | 0a 58 0a 58 73 74 61 74 |1, 0.X};|.X.Xstat|
|00000b40| 69 63 20 69 6e 74 09 54 | 61 62 69 6e 64 65 78 3b |ic int.T|abindex;|
|00000b50| 0a 58 73 74 61 74 69 63 | 20 6c 6f 6e 67 09 54 61 |.Xstatic| long.Ta|
|00000b60| 62 31 32 38 3b 09 09 2f | 2a 20 54 61 62 73 69 7a |b128;../|* Tabsiz|
|00000b70| 65 20 2a 20 31 32 38 20 | 2a 2f 0a 58 0a 58 6e 6f |e * 128 |*/.X.Xno|
|00000b80| 64 65 09 2a 0a 58 61 64 | 64 6e 6f 64 65 28 6e 61 |de.*.Xad|dnode(na|
|00000b90| 6d 65 29 0a 58 09 72 65 | 67 69 73 74 65 72 20 63 |me).X.re|gister c|
|00000ba0| 68 61 72 20 2a 6e 61 6d | 65 3b 0a 58 7b 09 72 65 |har *nam|e;.X{.re|
|00000bb0| 67 69 73 74 65 72 20 6c | 6f 6e 67 20 69 3b 0a 58 |gister l|ong i;.X|
|00000bc0| 09 72 65 67 69 73 74 65 | 72 20 6e 6f 64 65 20 2a |.registe|r node *|
|00000bd0| 6e 3b 0a 58 0a 58 09 69 | 66 20 28 49 66 6c 61 67 |n;.X.X.i|f (Iflag|
|00000be0| 29 0a 58 09 09 6c 6f 77 | 65 72 63 61 73 65 28 6e |).X..low|ercase(n|
|00000bf0| 61 6d 65 29 3b 0a 58 0a | 58 09 2f 2a 20 69 73 20 |ame);.X.|X./* is |
|00000c00| 69 74 20 61 20 70 72 69 | 76 61 74 65 20 68 6f 73 |it a pri|vate hos|
|00000c10| 74 3f 20 2a 2f 0a 58 09 | 6e 20 3d 20 69 73 70 72 |t? */.X.|n = ispr|
|00000c20| 69 76 61 74 65 28 6e 61 | 6d 65 29 3b 0a 58 09 69 |ivate(na|me);.X.i|
|00000c30| 66 20 28 6e 29 0a 58 09 | 09 72 65 74 75 72 6e 20 |f (n).X.|.return |
|00000c40| 6e 3b 0a 58 0a 58 09 69 | 20 3d 20 68 61 73 68 28 |n;.X.X.i| = hash(|
|00000c50| 6e 61 6d 65 2c 20 30 29 | 3b 0a 58 09 69 66 20 28 |name, 0)|;.X.if (|
|00000c60| 54 61 62 6c 65 5b 69 5d | 29 20 0a 58 09 09 72 65 |Table[i]|) .X..re|
|00000c70| 74 75 72 6e 20 54 61 62 | 6c 65 5b 69 5d 3b 0a 58 |turn Tab|le[i];.X|
|00000c80| 0a 58 09 6e 20 3d 20 6e | 65 77 6e 6f 64 65 28 29 |.X.n = n|ewnode()|
|00000c90| 3b 0a 58 09 6e 2d 3e 6e | 5f 6e 61 6d 65 20 3d 20 |;.X.n->n|_name = |
|00000ca0| 73 74 72 73 61 76 65 28 | 6e 61 6d 65 29 3b 0a 58 |strsave(|name);.X|
|00000cb0| 09 54 61 62 6c 65 5b 69 | 5d 20 3d 20 6e 3b 0a 58 |.Table[i|] = n;.X|
|00000cc0| 09 6e 2d 3e 6e 5f 74 6c | 6f 63 20 3d 20 69 3b 09 |.n->n_tl|oc = i;.|
|00000cd0| 2f 2a 20 65 73 73 65 6e | 74 69 61 6c 6c 79 20 61 |/* essen|tially a|
|00000ce0| 20 62 61 63 6b 20 6c 69 | 6e 6b 20 74 6f 20 74 68 | back li|nk to th|
|00000cf0| 65 20 74 61 62 6c 65 20 | 2a 2f 0a 58 0a 58 09 72 |e table |*/.X.X.r|
|00000d00| 65 74 75 72 6e 20 6e 3b | 0a 58 7d 0a 58 0a 58 76 |eturn n;|.X}.X.Xv|
|00000d10| 6f 69 64 0a 58 61 6c 69 | 61 73 28 6e 31 2c 20 6e |oid.Xali|as(n1, n|
|00000d20| 32 29 0a 58 09 6e 6f 64 | 65 20 2a 6e 31 2c 20 2a |2).X.nod|e *n1, *|
|00000d30| 6e 32 3b 0a 58 7b 0a 58 | 09 6c 69 6e 6b 09 2a 6c |n2;.X{.X|.link.*l|
|00000d40| 3b 0a 58 0a 58 09 69 66 | 20 28 49 53 41 44 4f 4d |;.X.X.if| (ISADOM|
|00000d50| 41 49 4e 28 6e 31 29 20 | 26 26 20 49 53 41 44 4f |AIN(n1) |&& ISADO|
|00000d60| 4d 41 49 4e 28 6e 32 29 | 29 20 7b 0a 58 09 09 66 |MAIN(n2)|) {.X..f|
|00000d70| 70 72 69 6e 74 66 28 73 | 74 64 65 72 72 2c 20 22 |printf(s|tderr, "|
|00000d80| 25 73 3a 20 64 6f 6d 61 | 69 6e 20 61 6c 69 61 73 |%s: doma|in alias|
|00000d90| 20 25 73 20 3d 20 25 73 | 20 69 73 20 69 6c 6c 65 | %s = %s| is ille|
|00000da0| 67 61 6c 5c 6e 22 2c 20 | 41 72 67 76 5b 30 5d 2c |gal\n", |Argv[0],|
|00000db0| 20 6e 31 2d 3e 6e 5f 6e | 61 6d 65 2c 20 6e 32 2d | n1->n_n|ame, n2-|
|00000dc0| 3e 6e 5f 6e 61 6d 65 29 | 3b 0a 58 09 09 72 65 74 |>n_name)|;.X..ret|
|00000dd0| 75 72 6e 3b 0a 58 09 7d | 0a 58 09 6c 20 3d 20 61 |urn;.X.}|.X.l = a|
|00000de0| 64 64 6c 69 6e 6b 28 6e | 31 2c 20 6e 32 2c 20 28 |ddlink(n|1, n2, (|
|00000df0| 43 6f 73 74 29 20 30 2c | 20 44 45 46 4e 45 54 2c |Cost) 0,| DEFNET,|
|00000e00| 20 44 45 46 44 49 52 29 | 3b 0a 58 09 6c 2d 3e 6c | DEFDIR)|;.X.l->l|
|00000e10| 5f 66 6c 61 67 20 7c 3d | 20 4c 41 4c 49 41 53 3b |_flag |=| LALIAS;|
|00000e20| 0a 58 09 6c 20 3d 20 61 | 64 64 6c 69 6e 6b 28 6e |.X.l = a|ddlink(n|
|00000e30| 32 2c 20 6e 31 2c 20 28 | 43 6f 73 74 29 20 30 2c |2, n1, (|Cost) 0,|
|00000e40| 20 44 45 46 4e 45 54 2c | 20 44 45 46 44 49 52 29 | DEFNET,| DEFDIR)|
|00000e50| 3b 0a 58 09 6c 2d 3e 6c | 5f 66 6c 61 67 20 7c 3d |;.X.l->l|_flag |=|
|00000e60| 20 4c 41 4c 49 41 53 3b | 0a 58 09 69 66 20 28 54 | LALIAS;|.X.if (T|
|00000e70| 66 6c 61 67 29 0a 58 09 | 09 61 74 72 61 63 65 28 |flag).X.|.atrace(|
|00000e80| 6e 31 2c 20 6e 32 29 3b | 0a 58 7d 0a 58 0a 58 2f |n1, n2);|.X}.X.X/|
|00000e90| 2a 0a 58 20 2a 20 66 6f | 6c 64 20 61 20 73 74 72 |*.X * fo|ld a str|
|00000ea0| 69 6e 67 20 69 6e 74 6f | 20 61 20 6c 6f 6e 67 20 |ing into| a long |
|00000eb0| 69 6e 74 2e 20 20 33 31 | 20 62 69 74 20 63 72 63 |int. 31| bit crc|
|00000ec0| 20 28 66 72 6f 6d 20 61 | 6e 64 72 65 77 20 61 70 | (from a|ndrew ap|
|00000ed0| 70 65 6c 29 2e 0a 58 20 | 2a 20 74 68 65 20 63 72 |pel)..X |* the cr|
|00000ee0| 63 20 74 61 62 6c 65 20 | 69 73 20 63 6f 6d 70 75 |c table |is compu|
|00000ef0| 74 65 64 20 61 74 20 72 | 75 6e 20 74 69 6d 65 20 |ted at r|un time |
|00000f00| 62 79 20 63 72 63 69 6e | 69 74 28 29 20 2d 2d 20 |by crcin|it() -- |
|00000f10| 77 65 20 63 6f 75 6c 64 | 0a 58 20 2a 20 70 72 65 |we could|.X * pre|
|00000f20| 63 6f 6d 70 75 74 65 2c | 20 62 75 74 20 69 74 20 |compute,| but it |
|00000f30| 74 61 6b 65 73 20 31 20 | 63 6c 6f 63 6b 20 74 69 |takes 1 |clock ti|
|00000f40| 63 6b 20 6f 6e 20 61 20 | 37 35 30 2e 0a 58 20 2a |ck on a |750..X *|
|00000f50| 0a 58 20 2a 20 54 68 69 | 73 20 66 61 73 74 20 74 |.X * Thi|s fast t|
|00000f60| 61 62 6c 65 20 63 61 6c | 63 75 6c 61 74 69 6f 6e |able cal|culation|
|00000f70| 20 77 6f 72 6b 73 20 6f | 6e 6c 79 20 69 66 20 50 | works o|nly if P|
|00000f80| 4f 4c 59 20 69 73 20 61 | 20 70 72 69 6d 65 20 70 |OLY is a| prime p|
|00000f90| 6f 6c 79 6e 6f 6d 69 61 | 6c 0a 58 20 2a 20 69 6e |olynomia|l.X * in|
|00000fa0| 20 74 68 65 20 66 69 65 | 6c 64 20 6f 66 20 69 6e | the fie|ld of in|
|00000fb0| 74 65 67 65 72 73 20 6d | 6f 64 75 6c 6f 20 32 2e |tegers m|odulo 2.|
|00000fc0| 20 20 53 69 6e 63 65 20 | 74 68 65 20 63 6f 65 66 | Since |the coef|
|00000fd0| 66 69 63 69 65 6e 74 73 | 20 6f 66 20 61 0a 58 20 |ficients| of a.X |
|00000fe0| 2a 20 33 32 2d 62 69 74 | 20 70 6f 6c 79 6e 6f 6d |* 32-bit| polynom|
|00000ff0| 61 69 6c 20 77 6f 6e 27 | 74 20 66 69 74 20 69 6e |ail won'|t fit in|
|00001000| 20 61 20 33 32 2d 62 69 | 74 20 77 6f 72 64 2c 20 | a 32-bi|t word, |
|00001010| 74 68 65 20 68 69 67 68 | 2d 6f 72 64 65 72 20 62 |the high|-order b|
|00001020| 69 74 20 69 73 0a 58 20 | 2a 20 69 6d 70 6c 69 63 |it is.X |* implic|
|00001030| 69 74 2e 20 20 49 54 20 | 4d 55 53 54 20 41 4c 53 |it. IT |MUST ALS|
|00001040| 4f 20 42 45 20 54 48 45 | 20 43 41 53 45 20 74 68 |O BE THE| CASE th|
|00001050| 61 74 20 74 68 65 20 63 | 6f 65 66 66 69 63 69 65 |at the c|oefficie|
|00001060| 6e 74 73 20 6f 66 20 6f | 72 64 65 72 73 0a 58 20 |nts of o|rders.X |
|00001070| 2a 20 33 31 20 64 6f 77 | 6e 20 74 6f 20 32 35 20 |* 31 dow|n to 25 |
|00001080| 61 72 65 20 7a 65 72 6f | 2e 20 20 48 61 70 70 69 |are zero|. Happi|
|00001090| 6c 79 2c 20 77 65 20 68 | 61 76 65 20 63 61 6e 64 |ly, we h|ave cand|
|000010a0| 69 64 61 74 65 73 2c 20 | 66 72 6f 6d 0a 58 20 2a |idates, |from.X *|
|000010b0| 20 45 2e 20 4a 2e 20 20 | 57 61 74 73 6f 6e 2c 20 | E. J. |Watson, |
|000010c0| 22 50 72 69 6d 69 74 69 | 76 65 20 50 6f 6c 79 6e |"Primiti|ve Polyn|
|000010d0| 6f 6d 69 61 6c 73 20 28 | 4d 6f 64 20 32 29 22 2c |omials (|Mod 2)",|
|000010e0| 20 4d 61 74 68 2e 20 43 | 6f 6d 70 2e 20 31 36 20 | Math. C|omp. 16 |
|000010f0| 28 31 39 36 32 29 3a 0a | 58 20 2a 09 78 5e 33 32 |(1962):.|X *.x^32|
|00001100| 20 2b 20 78 5e 37 20 2b | 20 78 5e 35 20 2b 20 78 | + x^7 +| x^5 + x|
|00001110| 5e 33 20 2b 20 78 5e 32 | 20 2b 20 78 5e 31 20 2b |^3 + x^2| + x^1 +|
|00001120| 20 78 5e 30 0a 58 20 2a | 09 78 5e 33 31 20 2b 20 | x^0.X *|.x^31 + |
|00001130| 78 5e 33 20 2b 20 78 5e | 30 0a 58 20 2a 0a 58 20 |x^3 + x^|0.X *.X |
|00001140| 2a 20 57 65 20 72 65 76 | 65 72 73 65 20 74 68 65 |* We rev|erse the|
|00001150| 20 62 69 74 73 20 74 6f | 20 67 65 74 3a 0a 58 20 | bits to| get:.X |
|00001160| 2a 09 31 31 31 31 30 31 | 30 31 30 30 30 30 30 30 |*.111101|01000000|
|00001170| 30 30 30 30 30 30 30 30 | 30 30 30 30 30 30 30 30 |00000000|00000000|
|00001180| 30 30 31 20 62 75 74 20 | 64 72 6f 70 20 74 68 65 |001 but |drop the|
|00001190| 20 6c 61 73 74 20 31 0a | 58 20 2a 20 20 20 20 20 | last 1.|X * |
|000011a0| 20 20 20 20 66 20 20 20 | 35 20 20 20 30 20 20 20 | f |5 0 |
|000011b0| 30 20 20 20 30 20 20 20 | 30 20 20 20 30 20 20 20 |0 0 |0 0 |
|000011c0| 30 0a 58 20 2a 09 30 31 | 30 30 31 30 30 30 30 30 |0.X *.01|00100000|
|000011d0| 30 30 30 30 30 30 30 30 | 30 30 30 30 30 30 30 30 |00000000|00000000|
|000011e0| 30 30 30 30 30 30 31 20 | 64 69 74 74 6f 2c 20 66 |0000001 |ditto, f|
|000011f0| 6f 72 20 33 31 2d 62 69 | 74 20 63 72 63 0a 58 20 |or 31-bi|t crc.X |
|00001200| 2a 09 20 20 20 34 20 20 | 20 38 20 20 20 30 20 20 |*. 4 | 8 0 |
|00001210| 20 30 20 20 20 30 20 20 | 20 30 20 20 20 30 20 20 | 0 0 | 0 0 |
|00001220| 20 30 0a 58 20 2a 2f 0a | 58 0a 58 23 64 65 66 69 | 0.X */.|X.X#defi|
|00001230| 6e 65 20 50 4f 4c 59 33 | 32 20 30 78 66 35 30 30 |ne POLY3|2 0xf500|
|00001240| 30 30 30 30 09 2f 2a 20 | 33 32 2d 62 69 74 20 70 |0000./* |32-bit p|
|00001250| 6f 6c 79 6e 6f 6d 69 61 | 6c 20 2a 2f 0a 58 23 64 |olynomia|l */.X#d|
|00001260| 65 66 69 6e 65 20 50 4f | 4c 59 33 31 20 30 78 34 |efine PO|LY31 0x4|
|00001270| 38 30 30 30 30 30 30 09 | 2f 2a 20 33 31 2d 62 69 |8000000.|/* 31-bi|
|00001280| 74 20 70 6f 6c 79 6e 6f | 6d 69 61 6c 20 2a 2f 0a |t polyno|mial */.|
|00001290| 58 23 64 65 66 69 6e 65 | 20 50 4f 4c 59 20 50 4f |X#define| POLY PO|
|000012a0| 4c 59 33 31 09 2f 2a 20 | 75 73 65 20 33 31 2d 62 |LY31./* |use 31-b|
|000012b0| 69 74 20 74 6f 20 61 76 | 6f 69 64 20 73 69 67 6e |it to av|oid sign|
|000012c0| 20 70 72 6f 62 6c 65 6d | 73 20 2a 2f 0a 58 0a 58 | problem|s */.X.X|
|000012d0| 73 74 61 74 69 63 20 6c | 6f 6e 67 20 43 72 63 54 |static l|ong CrcT|
|000012e0| 61 62 6c 65 5b 31 32 38 | 5d 3b 0a 58 0a 58 53 54 |able[128|];.X.XST|
|000012f0| 41 54 49 43 20 76 6f 69 | 64 0a 58 63 72 63 69 6e |ATIC voi|d.Xcrcin|
|00001300| 69 74 28 29 0a 58 7b 09 | 72 65 67 69 73 74 65 72 |it().X{.|register|
|00001310| 20 69 6e 74 20 69 2c 6a | 3b 0a 58 09 72 65 67 69 | int i,j|;.X.regi|
|00001320| 73 74 65 72 20 6c 6f 6e | 67 20 73 75 6d 3b 0a 58 |ster lon|g sum;.X|
|00001330| 0a 58 09 66 6f 72 20 28 | 69 20 3d 20 30 3b 20 69 |.X.for (|i = 0; i|
|00001340| 20 3c 20 31 32 38 3b 20 | 69 2b 2b 29 20 7b 0a 58 | < 128; |i++) {.X|
|00001350| 09 09 73 75 6d 20 3d 20 | 30 3b 0a 58 09 09 66 6f |..sum = |0;.X..fo|
|00001360| 72 20 28 6a 20 3d 20 37 | 2d 31 3b 20 6a 20 3e 3d |r (j = 7|-1; j >=|
|00001370| 20 30 3b 20 2d 2d 6a 29 | 0a 58 09 09 09 69 66 20 | 0; --j)|.X...if |
|00001380| 28 69 20 26 20 28 31 20 | 3c 3c 20 6a 29 29 0a 58 |(i & (1 |<< j)).X|
|00001390| 09 09 09 09 73 75 6d 20 | 5e 3d 20 50 4f 4c 59 20 |....sum |^= POLY |
|000013a0| 3e 3e 20 6a 3b 0a 58 09 | 09 43 72 63 54 61 62 6c |>> j;.X.|.CrcTabl|
|000013b0| 65 5b 69 5d 20 3d 20 73 | 75 6d 3b 0a 58 09 7d 0a |e[i] = s|um;.X.}.|
|000013c0| 58 7d 0a 58 0a 58 53 54 | 41 54 49 43 20 6c 6f 6e |X}.X.XST|ATIC lon|
|000013d0| 67 0a 58 66 6f 6c 64 28 | 73 29 0a 58 09 72 65 67 |g.Xfold(|s).X.reg|
|000013e0| 69 73 74 65 72 20 63 68 | 61 72 20 2a 73 3b 0a 58 |ister ch|ar *s;.X|
|000013f0| 7b 09 72 65 67 69 73 74 | 65 72 20 6c 6f 6e 67 20 |{.regist|er long |
|00001400| 73 75 6d 20 3d 20 30 3b | 0a 58 09 72 65 67 69 73 |sum = 0;|.X.regis|
|00001410| 74 65 72 20 69 6e 74 20 | 63 3b 0a 58 0a 58 09 77 |ter int |c;.X.X.w|
|00001420| 68 69 6c 65 20 28 63 20 | 3d 20 2a 73 2b 2b 29 0a |hile (c |= *s++).|
|00001430| 58 09 09 73 75 6d 20 3d | 20 28 73 75 6d 20 3e 3e |X..sum =| (sum >>|
|00001440| 20 37 29 20 5e 20 43 72 | 63 54 61 62 6c 65 5b 28 | 7) ^ Cr|cTable[(|
|00001450| 73 75 6d 20 5e 20 63 29 | 20 26 20 30 78 37 66 5d |sum ^ c)| & 0x7f]|
|00001460| 3b 0a 58 09 72 65 74 75 | 72 6e 20 73 75 6d 3b 0a |;.X.retu|rn sum;.|
|00001470| 58 7d 0a 58 0a 58 0a 58 | 23 64 65 66 69 6e 65 20 |X}.X.X.X|#define |
|00001480| 48 41 53 48 31 28 6e 29 | 20 28 28 6e 29 20 25 20 |HASH1(n)| ((n) % |
|00001490| 54 61 62 73 69 7a 65 29 | 3b 0a 58 23 64 65 66 69 |Tabsize)|;.X#defi|
|000014a0| 6e 65 20 48 41 53 48 32 | 28 6e 29 20 28 54 61 62 |ne HASH2|(n) (Tab|
|000014b0| 73 69 7a 65 20 2d 20 32 | 20 2d 20 28 28 6e 29 20 |size - 2| - ((n) |
|000014c0| 25 20 28 54 61 62 73 69 | 7a 65 2d 32 29 29 29 09 |% (Tabsi|ze-2))).|
|000014d0| 2f 2a 20 73 65 64 67 65 | 77 69 63 6b 20 2a 2f 0a |/* sedge|wick */.|
|000014e0| 58 0a 58 2f 2a 0a 58 20 | 2a 20 77 68 65 6e 20 61 |X.X/*.X |* when a|
|000014f0| 6c 70 68 61 20 69 73 20 | 30 2e 37 39 2c 20 74 68 |lpha is |0.79, th|
|00001500| 65 72 65 20 73 68 6f 75 | 6c 64 20 62 65 20 32 20 |ere shou|ld be 2 |
|00001510| 70 72 6f 62 65 73 20 70 | 65 72 20 61 63 63 65 73 |probes p|er acces|
|00001520| 73 20 28 67 6f 6e 6e 65 | 74 29 2e 0a 58 20 2a 20 |s (gonne|t)..X * |
|00001530| 75 73 65 20 6c 6f 6e 67 | 20 63 6f 6e 73 74 61 6e |use long| constan|
|00001540| 74 20 74 6f 20 66 6f 72 | 63 65 20 70 72 6f 6d 6f |t to for|ce promo|
|00001550| 74 69 6f 6e 2e 20 20 54 | 61 62 31 32 38 20 62 69 |tion. T|ab128 bi|
|00001560| 61 73 65 73 20 48 49 47 | 48 57 41 54 45 52 20 62 |ases HIG|HWATER b|
|00001570| 79 0a 58 20 2a 20 31 32 | 38 2f 31 30 30 20 66 6f |y.X * 12|8/100 fo|
|00001580| 72 20 72 65 64 75 63 74 | 69 6f 6e 20 69 6e 20 73 |r reduct|ion in s|
|00001590| 74 72 65 6e 67 74 68 20 | 69 6e 20 69 73 66 75 6c |trength |in isful|
|000015a0| 6c 28 29 2e 0a 58 20 2a | 2f 0a 58 23 64 65 66 69 |l()..X *|/.X#defi|
|000015b0| 6e 65 20 48 49 47 48 57 | 41 54 45 52 09 37 39 4c |ne HIGHW|ATER.79L|
|000015c0| 0a 58 23 64 65 66 69 6e | 65 20 69 73 66 75 6c 6c |.X#defin|e isfull|
|000015d0| 28 6e 29 09 28 28 6e 29 | 20 2a 20 31 32 38 20 3e |(n).((n)| * 128 >|
|000015e0| 3d 20 54 61 62 31 32 38 | 29 0a 58 09 0a 58 53 54 |= Tab128|).X..XST|
|000015f0| 41 54 49 43 20 6c 6f 6e | 67 0a 58 68 61 73 68 28 |ATIC lon|g.Xhash(|
|00001600| 6e 61 6d 65 2c 20 75 6e | 69 71 75 65 29 0a 58 09 |name, un|ique).X.|
|00001610| 63 68 61 72 20 2a 6e 61 | 6d 65 3b 0a 58 7b 09 72 |char *na|me;.X{.r|
|00001620| 65 67 69 73 74 65 72 20 | 6c 6f 6e 67 20 70 72 6f |egister |long pro|
|00001630| 62 65 3b 0a 58 09 72 65 | 67 69 73 74 65 72 20 6c |be;.X.re|gister l|
|00001640| 6f 6e 67 20 68 61 73 68 | 32 3b 0a 58 09 72 65 67 |ong hash|2;.X.reg|
|00001650| 69 73 74 65 72 20 6e 6f | 64 65 20 2a 6e 3b 0a 58 |ister no|de *n;.X|
|00001660| 0a 58 09 69 66 20 28 69 | 73 66 75 6c 6c 28 4e 63 |.X.if (i|sfull(Nc|
|00001670| 6f 75 6e 74 29 29 20 7b | 0a 58 09 09 69 66 20 28 |ount)) {|.X..if (|
|00001680| 54 61 62 73 69 7a 65 20 | 3d 3d 20 30 29 20 7b 09 |Tabsize |== 0) {.|
|00001690| 09 2f 2a 20 66 69 72 73 | 74 20 74 69 6d 65 20 2a |./* firs|t time *|
|000016a0| 2f 0a 58 09 09 09 63 72 | 63 69 6e 69 74 28 29 3b |/.X...cr|cinit();|
|000016b0| 0a 58 09 09 09 54 61 62 | 69 6e 64 65 78 20 3d 20 |.X...Tab|index = |
|000016c0| 30 3b 0a 58 09 09 09 54 | 61 62 73 69 7a 65 20 3d |0;.X...T|absize =|
|000016d0| 20 50 72 69 6d 65 73 5b | 30 5d 3b 0a 58 09 09 09 | Primes[|0];.X...|
|000016e0| 54 61 62 6c 65 20 3d 20 | 6e 65 77 74 61 62 6c 65 |Table = |newtable|
|000016f0| 28 54 61 62 73 69 7a 65 | 29 3b 0a 58 09 09 09 54 |(Tabsize|);.X...T|
|00001700| 61 62 31 32 38 20 3d 20 | 28 48 49 47 48 57 41 54 |ab128 = |(HIGHWAT|
|00001710| 45 52 20 2a 20 54 61 62 | 73 69 7a 65 20 2a 20 31 |ER * Tab|size * 1|
|00001720| 32 38 4c 29 2f 31 30 30 | 4c 3b 0a 58 09 09 7d 20 |28L)/100|L;.X..} |
|00001730| 65 6c 73 65 0a 58 09 09 | 09 72 65 68 61 73 68 28 |else.X..|.rehash(|
|00001740| 29 3b 09 09 2f 2a 20 6d | 6f 72 65 2c 20 6d 6f 72 |);../* m|ore, mor|
|00001750| 65 21 20 2a 2f 0a 58 09 | 7d 0a 58 0a 58 09 70 72 |e! */.X.|}.X.X.pr|
|00001760| 6f 62 65 20 3d 20 66 6f | 6c 64 28 6e 61 6d 65 29 |obe = fo|ld(name)|
|00001770| 3b 0a 58 09 68 61 73 68 | 32 20 3d 20 48 41 53 48 |;.X.hash|2 = HASH|
|00001780| 32 28 70 72 6f 62 65 29 | 3b 0a 58 09 70 72 6f 62 |2(probe)|;.X.prob|
|00001790| 65 20 3d 20 48 41 53 48 | 31 28 70 72 6f 62 65 29 |e = HASH|1(probe)|
|000017a0| 3b 0a 58 0a 58 09 2f 2a | 0a 58 09 20 2a 20 70 72 |;.X.X./*|.X. * pr|
|000017b0| 6f 62 65 20 74 68 65 20 | 68 61 73 68 20 74 61 62 |obe the |hash tab|
|000017c0| 6c 65 2e 0a 58 09 20 2a | 20 69 66 20 75 6e 69 71 |le..X. *| if uniq|
|000017d0| 75 65 20 69 73 20 73 65 | 74 2c 20 77 65 20 72 65 |ue is se|t, we re|
|000017e0| 71 75 69 72 65 20 61 20 | 66 72 65 73 68 20 73 6c |quire a |fresh sl|
|000017f0| 6f 74 2e 0a 58 09 20 2a | 20 6f 74 68 65 72 77 69 |ot..X. *| otherwi|
|00001800| 73 65 2c 20 75 73 65 20 | 64 6f 75 62 6c 65 20 68 |se, use |double h|
|00001810| 61 73 68 69 6e 67 20 74 | 6f 20 66 69 6e 64 20 65 |ashing t|o find e|
|00001820| 69 74 68 65 72 0a 58 09 | 20 2a 20 20 28 31 29 20 |ither.X.| * (1) |
|00001830| 61 6e 20 65 6d 70 74 79 | 20 73 6c 6f 74 2c 20 6f |an empty| slot, o|
|00001840| 72 0a 58 09 20 2a 20 20 | 28 32 29 20 61 20 6e 6f |r.X. * |(2) a no|
|00001850| 6e 2d 70 72 69 76 61 74 | 65 20 63 6f 70 79 20 6f |n-privat|e copy o|
|00001860| 66 20 74 68 69 73 20 68 | 6f 73 74 20 6e 61 6d 65 |f this h|ost name|
|00001870| 0a 58 09 20 2a 2f 0a 58 | 09 77 68 69 6c 65 20 28 |.X. */.X|.while (|
|00001880| 28 6e 20 3d 20 54 61 62 | 6c 65 5b 70 72 6f 62 65 |(n = Tab|le[probe|
|00001890| 5d 29 20 21 3d 20 30 29 | 20 7b 0a 58 09 09 69 66 |]) != 0)| {.X..if|
|000018a0| 20 28 75 6e 69 71 75 65 | 29 0a 58 09 09 09 67 6f | (unique|).X...go|
|000018b0| 74 6f 20 73 6b 69 70 3b | 0a 58 09 09 69 66 20 28 |to skip;|.X..if (|
|000018c0| 6e 2d 3e 6e 5f 66 6c 61 | 67 20 26 20 49 53 50 52 |n->n_fla|g & ISPR|
|000018d0| 49 56 41 54 45 29 0a 58 | 09 09 09 67 6f 74 6f 20 |IVATE).X|...goto |
|000018e0| 73 6b 69 70 3b 0a 58 09 | 09 69 66 20 28 73 74 72 |skip;.X.|.if (str|
|000018f0| 63 6d 70 28 6e 2d 3e 6e | 5f 6e 61 6d 65 2c 20 6e |cmp(n->n|_name, n|
|00001900| 61 6d 65 29 20 3d 3d 20 | 30 29 0a 58 09 09 09 62 |ame) == |0).X...b|
|00001910| 72 65 61 6b 3b 09 09 09 | 2f 2a 20 74 68 69 73 20 |reak;...|/* this |
|00001920| 69 73 20 69 74 21 20 2a | 2f 0a 58 73 6b 69 70 3a |is it! *|/.Xskip:|
|00001930| 0a 58 09 09 70 72 6f 62 | 65 20 2d 3d 20 68 61 73 |.X..prob|e -= has|
|00001940| 68 32 3b 0a 58 09 09 69 | 66 20 28 70 72 6f 62 65 |h2;.X..i|f (probe|
|00001950| 20 3c 20 30 29 0a 58 09 | 09 09 70 72 6f 62 65 20 | < 0).X.|..probe |
|00001960| 2b 3d 20 54 61 62 73 69 | 7a 65 3b 0a 58 09 7d 0a |+= Tabsi|ze;.X.}.|
|00001970| 58 09 72 65 74 75 72 6e | 20 70 72 6f 62 65 3b 0a |X.return| probe;.|
|00001980| 58 7d 0a 58 0a 58 53 54 | 41 54 49 43 20 76 6f 69 |X}.X.XST|ATIC voi|
|00001990| 64 0a 58 72 65 68 61 73 | 68 28 29 0a 58 7b 09 72 |d.Xrehas|h().X{.r|
|000019a0| 65 67 69 73 74 65 72 20 | 6e 6f 64 65 20 2a 2a 6f |egister |node **o|
|000019b0| 74 61 62 6c 65 2c 20 2a | 2a 6f 70 74 72 3b 0a 58 |table, *|*optr;.X|
|000019c0| 09 72 65 67 69 73 74 65 | 72 20 6c 6f 6e 67 20 70 |.registe|r long p|
|000019d0| 72 6f 62 65 3b 0a 58 09 | 6c 6f 6e 67 20 6f 73 69 |robe;.X.|long osi|
|000019e0| 7a 65 3b 0a 58 0a 58 23 | 69 66 64 65 66 20 44 45 |ze;.X.X#|ifdef DE|
|000019f0| 42 55 47 0a 58 09 68 61 | 73 68 61 6e 61 6c 79 7a |BUG.X.ha|shanalyz|
|00001a00| 65 28 29 3b 0a 58 23 65 | 6e 64 69 66 0a 58 09 6f |e();.X#e|ndif.X.o|
|00001a10| 70 74 72 20 3d 20 54 61 | 62 6c 65 20 2b 20 54 61 |ptr = Ta|ble + Ta|
|00001a20| 62 73 69 7a 65 20 2d 20 | 31 3b 09 2f 2a 20 70 74 |bsize - |1;./* pt|
|00001a30| 72 20 74 6f 20 6c 61 73 | 74 20 2a 2f 0a 58 09 6f |r to las|t */.X.o|
|00001a40| 74 61 62 6c 65 20 3d 20 | 54 61 62 6c 65 3b 0a 58 |table = |Table;.X|
|00001a50| 09 6f 73 69 7a 65 20 3d | 20 54 61 62 73 69 7a 65 |.osize =| Tabsize|
|00001a60| 3b 0a 58 09 54 61 62 73 | 69 7a 65 20 3d 20 50 72 |;.X.Tabs|ize = Pr|
|00001a70| 69 6d 65 73 5b 2b 2b 54 | 61 62 69 6e 64 65 78 5d |imes[++T|abindex]|
|00001a80| 3b 0a 58 09 69 66 20 28 | 54 61 62 73 69 7a 65 20 |;.X.if (|Tabsize |
|00001a90| 3d 3d 20 30 29 0a 58 09 | 09 64 69 65 28 22 74 6f |== 0).X.|.die("to|
|00001aa0| 6f 20 6d 61 6e 79 20 68 | 6f 73 74 73 22 29 3b 09 |o many h|osts");.|
|00001ab0| 2f 2a 20 6e 65 65 64 20 | 6d 6f 72 65 20 70 72 69 |/* need |more pri|
|00001ac0| 6d 65 20 6e 75 6d 62 65 | 72 73 20 2a 2f 0a 58 09 |me numbe|rs */.X.|
|00001ad0| 76 70 72 69 6e 74 66 28 | 73 74 64 65 72 72 2c 20 |vprintf(|stderr, |
|00001ae0| 22 72 65 68 61 73 68 20 | 69 6e 74 6f 20 25 64 5c |"rehash |into %d\|
|00001af0| 6e 22 2c 20 54 61 62 73 | 69 7a 65 29 3b 0a 58 09 |n", Tabs|ize);.X.|
|00001b00| 54 61 62 6c 65 20 3d 20 | 6e 65 77 74 61 62 6c 65 |Table = |newtable|
|00001b10| 28 54 61 62 73 69 7a 65 | 29 3b 0a 58 09 54 61 62 |(Tabsize|);.X.Tab|
|00001b20| 31 32 38 20 3d 20 28 48 | 49 47 48 57 41 54 45 52 |128 = (H|IGHWATER|
|00001b30| 20 2a 20 54 61 62 73 69 | 7a 65 20 2a 20 31 32 38 | * Tabsi|ze * 128|
|00001b40| 4c 29 2f 31 30 30 4c 3b | 0a 58 0a 58 09 64 6f 20 |L)/100L;|.X.X.do |
|00001b50| 7b 0a 58 09 09 69 66 20 | 28 2a 6f 70 74 72 20 3d |{.X..if |(*optr =|
|00001b60| 3d 20 30 29 0a 58 09 09 | 09 63 6f 6e 74 69 6e 75 |= 0).X..|.continu|
|00001b70| 65 3b 09 2f 2a 20 65 6d | 70 74 79 20 73 6c 6f 74 |e;./* em|pty slot|
|00001b80| 20 69 6e 20 6f 6c 64 20 | 74 61 62 6c 65 20 2a 2f | in old |table */|
|00001b90| 0a 58 09 09 70 72 6f 62 | 65 20 3d 20 68 61 73 68 |.X..prob|e = hash|
|00001ba0| 28 28 2a 6f 70 74 72 29 | 2d 3e 6e 5f 6e 61 6d 65 |((*optr)|->n_name|
|00001bb0| 2c 20 28 69 6e 74 29 20 | 28 28 2a 6f 70 74 72 29 |, (int) |((*optr)|
|00001bc0| 2d 3e 6e 5f 66 6c 61 67 | 20 26 20 49 53 50 52 49 |->n_flag| & ISPRI|
|00001bd0| 56 41 54 45 29 29 3b 0a | 58 09 09 69 66 20 28 54 |VATE));.|X..if (T|
|00001be0| 61 62 6c 65 5b 70 72 6f | 62 65 5d 20 21 3d 20 30 |able[pro|be] != 0|
|00001bf0| 29 0a 58 09 09 09 64 69 | 65 28 22 72 65 68 61 73 |).X...di|e("rehas|
|00001c00| 68 20 65 72 72 6f 72 22 | 29 3b 0a 58 09 09 54 61 |h error"|);.X..Ta|
|00001c10| 62 6c 65 5b 70 72 6f 62 | 65 5d 20 3d 20 2a 6f 70 |ble[prob|e] = *op|
|00001c20| 74 72 3b 0a 58 09 09 28 | 2a 6f 70 74 72 29 2d 3e |tr;.X..(|*optr)->|
|00001c30| 6e 5f 74 6c 6f 63 20 3d | 20 70 72 6f 62 65 3b 0a |n_tloc =| probe;.|
|00001c40| 58 09 7d 20 77 68 69 6c | 65 20 28 6f 70 74 72 2d |X.} whil|e (optr-|
|00001c50| 2d 20 3e 20 6f 74 61 62 | 6c 65 29 3b 0a 58 09 66 |- > otab|le);.X.f|
|00001c60| 72 65 65 74 61 62 6c 65 | 28 6f 74 61 62 6c 65 2c |reetable|(otable,|
|00001c70| 20 6f 73 69 7a 65 29 3b | 0a 58 7d 0a 58 0a 58 76 | osize);|.X}.X.Xv|
|00001c80| 6f 69 64 0a 58 68 61 73 | 68 61 6e 61 6c 79 7a 65 |oid.Xhas|hanalyze|
|00001c90| 28 29 0a 58 7b 20 09 6c | 6f 6e 67 09 70 72 6f 62 |().X{ .l|ong.prob|
|00001ca0| 65 2c 20 68 61 73 68 32 | 3b 0a 58 09 69 6e 74 09 |e, hash2|;.X.int.|
|00001cb0| 63 6f 75 6e 74 2c 20 69 | 2c 20 63 6f 6c 6c 69 73 |count, i|, collis|
|00001cc0| 69 6f 6e 5b 38 5d 3b 0a | 58 09 69 6e 74 09 6c 6f |ion[8];.|X.int.lo|
|00001cd0| 6e 67 65 73 74 20 3d 20 | 30 2c 20 74 6f 74 61 6c |ngest = |0, total|
|00001ce0| 20 3d 20 30 2c 20 73 6c | 6f 74 73 20 3d 20 30 2c | = 0, sl|ots = 0,|
|00001cf0| 20 6c 6f 6e 67 70 72 6f | 62 65 20 3d 20 30 3b 0a | longpro|be = 0;.|
|00001d00| 58 09 69 6e 74 09 6e 73 | 6c 6f 74 73 20 3d 20 73 |X.int.ns|lots = s|
|00001d10| 69 7a 65 6f 66 28 63 6f | 6c 6c 69 73 69 6f 6e 29 |izeof(co|llision)|
|00001d20| 2f 73 69 7a 65 6f 66 28 | 63 6f 6c 6c 69 73 69 6f |/sizeof(|collisio|
|00001d30| 6e 5b 30 5d 29 3b 0a 58 | 0a 58 09 69 66 20 28 21 |n[0]);.X|.X.if (!|
|00001d40| 56 66 6c 61 67 29 0a 58 | 09 09 72 65 74 75 72 6e |Vflag).X|..return|
|00001d50| 3b 0a 58 0a 58 09 73 74 | 72 63 6c 65 61 72 28 28 |;.X.X.st|rclear((|
|00001d60| 63 68 61 72 20 2a 29 20 | 63 6f 6c 6c 69 73 69 6f |char *) |collisio|
|00001d70| 6e 2c 20 73 69 7a 65 6f | 66 28 63 6f 6c 6c 69 73 |n, sizeo|f(collis|
|00001d80| 69 6f 6e 29 29 3b 0a 58 | 09 66 6f 72 20 28 69 20 |ion));.X|.for (i |
|00001d90| 3d 20 30 3b 20 69 20 3c | 20 54 61 62 73 69 7a 65 |= 0; i <| Tabsize|
|00001da0| 3b 20 69 2b 2b 29 20 7b | 0a 58 09 09 69 66 20 28 |; i++) {|.X..if (|
|00001db0| 54 61 62 6c 65 5b 69 5d | 20 3d 3d 20 30 29 0a 58 |Table[i]| == 0).X|
|00001dc0| 09 09 09 63 6f 6e 74 69 | 6e 75 65 3b 0a 58 09 09 |...conti|nue;.X..|
|00001dd0| 2f 2a 20 70 72 69 76 61 | 74 65 20 68 6f 73 74 73 |/* priva|te hosts|
|00001de0| 20 74 6f 6f 20 68 61 72 | 64 20 74 6f 20 61 63 63 | too har|d to acc|
|00001df0| 6f 75 6e 74 20 66 6f 72 | 20 2e 2e 2e 20 2a 2f 0a |ount for| ... */.|
|00001e00| 58 09 09 69 66 20 28 54 | 61 62 6c 65 5b 69 5d 2d |X..if (T|able[i]-|
|00001e10| 3e 6e 5f 66 6c 61 67 20 | 26 20 49 53 50 52 49 56 |>n_flag |& ISPRIV|
|00001e20| 41 54 45 29 0a 58 09 09 | 09 63 6f 6e 74 69 6e 75 |ATE).X..|.continu|
|00001e30| 65 3b 0a 58 09 09 63 6f | 75 6e 74 20 3d 20 31 3b |e;.X..co|unt = 1;|
|00001e40| 0a 58 09 09 70 72 6f 62 | 65 20 3d 20 66 6f 6c 64 |.X..prob|e = fold|
|00001e50| 28 54 61 62 6c 65 5b 69 | 5d 2d 3e 6e 5f 6e 61 6d |(Table[i|]->n_nam|
|00001e60| 65 29 3b 0a 58 09 09 2f | 2a 20 64 6f 6e 27 74 20 |e);.X../|* don't |
|00001e70| 63 68 61 6e 67 65 20 74 | 68 65 20 6f 72 64 65 72 |change t|he order|
|00001e80| 20 6f 66 20 74 68 65 20 | 6e 65 78 74 20 74 77 6f | of the |next two|
|00001e90| 20 6c 69 6e 65 73 20 2a | 2f 0a 58 09 09 68 61 73 | lines *|/.X..has|
|00001ea0| 68 32 20 3d 20 48 41 53 | 48 32 28 70 72 6f 62 65 |h2 = HAS|H2(probe|
|00001eb0| 29 3b 0a 58 09 09 70 72 | 6f 62 65 20 3d 20 48 41 |);.X..pr|obe = HA|
|00001ec0| 53 48 31 28 70 72 6f 62 | 65 29 3b 0a 58 09 09 2f |SH1(prob|e);.X../|
|00001ed0| 2a 20 74 68 61 6e 6b 20 | 79 6f 75 21 20 2a 2f 0a |* thank |you! */.|
|00001ee0| 58 09 09 77 68 69 6c 65 | 20 28 54 61 62 6c 65 5b |X..while| (Table[|
|00001ef0| 70 72 6f 62 65 5d 20 21 | 3d 20 30 0a 58 09 09 20 |probe] !|= 0.X.. |
|00001f00| 20 20 20 26 26 20 73 74 | 72 63 6d 70 28 54 61 62 | && st|rcmp(Tab|
|00001f10| 6c 65 5b 70 72 6f 62 65 | 5d 2d 3e 6e 5f 6e 61 6d |le[probe|]->n_nam|
|00001f20| 65 2c 20 54 61 62 6c 65 | 5b 69 5d 2d 3e 6e 5f 6e |e, Table|[i]->n_n|
|00001f30| 61 6d 65 29 20 21 3d 20 | 30 29 20 7b 0a 58 09 09 |ame) != |0) {.X..|
|00001f40| 09 63 6f 75 6e 74 2b 2b | 3b 0a 58 09 09 09 70 72 |.count++|;.X...pr|
|00001f50| 6f 62 65 20 2d 3d 20 68 | 61 73 68 32 3b 0a 58 09 |obe -= h|ash2;.X.|
|00001f60| 09 09 69 66 20 28 70 72 | 6f 62 65 20 3c 20 30 29 |..if (pr|obe < 0)|
|00001f70| 0a 58 09 09 09 09 70 72 | 6f 62 65 20 2b 3d 20 54 |.X....pr|obe += T|
|00001f80| 61 62 73 69 7a 65 3b 0a | 58 09 09 7d 0a 58 09 09 |absize;.|X..}.X..|
|00001f90| 69 66 20 28 54 61 62 6c | 65 5b 70 72 6f 62 65 5d |if (Tabl|e[probe]|
|00001fa0| 20 3d 3d 20 30 29 0a 58 | 09 09 09 64 69 65 28 22 | == 0).X|...die("|
|00001fb0| 69 6d 70 6f 73 73 69 62 | 6c 65 20 68 61 73 68 20 |impossib|le hash |
|00001fc0| 65 72 72 6f 72 22 29 3b | 0a 58 09 09 0a 58 09 09 |error");|.X...X..|
|00001fd0| 74 6f 74 61 6c 20 2b 3d | 20 63 6f 75 6e 74 3b 0a |total +=| count;.|
|00001fe0| 58 09 09 73 6c 6f 74 73 | 2b 2b 3b 0a 58 09 09 69 |X..slots|++;.X..i|
|00001ff0| 66 20 28 63 6f 75 6e 74 | 20 3e 20 6c 6f 6e 67 65 |f (count| > longe|
|00002000| 73 74 29 20 7b 0a 58 09 | 09 09 6c 6f 6e 67 65 73 |st) {.X.|..longes|
|00002010| 74 20 3d 20 63 6f 75 6e | 74 3b 0a 58 09 09 09 6c |t = coun|t;.X...l|
|00002020| 6f 6e 67 70 72 6f 62 65 | 20 3d 20 69 3b 0a 58 09 |ongprobe| = i;.X.|
|00002030| 09 7d 0a 58 09 09 69 66 | 20 28 63 6f 75 6e 74 20 |.}.X..if| (count |
|00002040| 3e 3d 20 6e 73 6c 6f 74 | 73 29 0a 58 09 09 09 63 |>= nslot|s).X...c|
|00002050| 6f 75 6e 74 20 3d 20 30 | 3b 0a 58 09 09 63 6f 6c |ount = 0|;.X..col|
|00002060| 6c 69 73 69 6f 6e 5b 63 | 6f 75 6e 74 5d 2b 2b 3b |lision[c|ount]++;|
|00002070| 0a 58 09 7d 0a 58 09 66 | 6f 72 20 28 69 20 3d 20 |.X.}.X.f|or (i = |
|00002080| 31 3b 20 69 20 3c 20 6e | 73 6c 6f 74 73 3b 20 69 |1; i < n|slots; i|
|00002090| 2b 2b 29 0a 58 09 09 69 | 66 20 28 63 6f 6c 6c 69 |++).X..i|f (colli|
|000020a0| 73 69 6f 6e 5b 69 5d 29 | 0a 58 09 09 09 66 70 72 |sion[i])|.X...fpr|
|000020b0| 69 6e 74 66 28 73 74 64 | 65 72 72 2c 20 22 25 64 |intf(std|err, "%d|
|000020c0| 20 63 68 61 69 6e 73 3a | 20 25 64 20 28 25 6c 64 | chains:| %d (%ld|
|000020d0| 25 25 29 5c 6e 22 2c 0a | 58 09 09 09 09 69 2c 20 |%%)\n",.|X....i, |
|000020e0| 63 6f 6c 6c 69 73 69 6f | 6e 5b 69 5d 2c 20 28 63 |collisio|n[i], (c|
|000020f0| 6f 6c 6c 69 73 69 6f 6e | 5b 69 5d 20 2a 20 31 30 |ollision|[i] * 10|
|00002100| 30 4c 29 2f 20 73 6c 6f | 74 73 29 3b 0a 58 09 09 |0L)/ slo|ts);.X..|
|00002110| 69 66 20 28 63 6f 6c 6c | 69 73 69 6f 6e 5b 30 5d |if (coll|ision[0]|
|00002120| 29 0a 58 09 09 09 66 70 | 72 69 6e 74 66 28 73 74 |).X...fp|rintf(st|
|00002130| 64 65 72 72 2c 20 22 3e | 20 25 64 20 63 68 61 69 |derr, ">| %d chai|
|00002140| 6e 73 3a 20 25 64 20 28 | 25 6c 64 25 25 29 5c 6e |ns: %d (|%ld%%)\n|
|00002150| 22 2c 0a 58 09 09 09 09 | 6e 73 6c 6f 74 73 20 2d |",.X....|nslots -|
|00002160| 20 31 2c 20 63 6f 6c 6c | 69 73 69 6f 6e 5b 30 5d | 1, coll|ision[0]|
|00002170| 2c 0a 58 09 09 09 09 28 | 63 6f 6c 6c 69 73 69 6f |,.X....(|collisio|
|00002180| 6e 5b 30 5d 20 2a 20 31 | 30 30 4c 29 2f 20 73 6c |n[0] * 1|00L)/ sl|
|00002190| 6f 74 73 29 3b 0a 58 09 | 66 70 72 69 6e 74 66 28 |ots);.X.|fprintf(|
|000021a0| 73 74 64 65 72 72 2c 20 | 22 25 32 2e 32 66 20 70 |stderr, |"%2.2f p|
|000021b0| 72 6f 62 65 73 20 70 65 | 72 20 61 63 63 65 73 73 |robes pe|r access|
|000021c0| 2c 20 6c 6f 6e 67 65 73 | 74 20 63 68 61 69 6e 3a |, longes|t chain:|
|000021d0| 20 25 64 2c 20 25 73 5c | 6e 22 2c 0a 58 09 09 28 | %d, %s\|n",.X..(|
|000021e0| 64 6f 75 62 6c 65 29 20 | 74 6f 74 61 6c 20 2f 20 |double) |total / |
|000021f0| 73 6c 6f 74 73 2c 20 6c | 6f 6e 67 65 73 74 2c 20 |slots, l|ongest, |
|00002200| 54 61 62 6c 65 5b 6c 6f | 6e 67 70 72 6f 62 65 5d |Table[lo|ngprobe]|
|00002210| 2d 3e 6e 5f 6e 61 6d 65 | 29 3b 0a 58 09 69 66 20 |->n_name|);.X.if |
|00002220| 28 56 66 6c 61 67 20 3c | 20 32 29 0a 58 09 09 72 |(Vflag <| 2).X..r|
|00002230| 65 74 75 72 6e 3b 0a 58 | 09 70 72 6f 62 65 20 3d |eturn;.X|.probe =|
|00002240| 20 66 6f 6c 64 28 54 61 | 62 6c 65 5b 6c 6f 6e 67 | fold(Ta|ble[long|
|00002250| 70 72 6f 62 65 5d 2d 3e | 6e 5f 6e 61 6d 65 29 3b |probe]->|n_name);|
|00002260| 0a 58 09 68 61 73 68 32 | 20 3d 20 48 41 53 48 32 |.X.hash2| = HASH2|
|00002270| 28 70 72 6f 62 65 29 3b | 0a 58 09 70 72 6f 62 65 |(probe);|.X.probe|
|00002280| 20 3d 20 48 41 53 48 31 | 28 70 72 6f 62 65 29 3b | = HASH1|(probe);|
|00002290| 0a 58 09 77 68 69 6c 65 | 20 28 54 61 62 6c 65 5b |.X.while| (Table[|
|000022a0| 70 72 6f 62 65 5d 20 21 | 3d 20 30 0a 58 09 20 20 |probe] !|= 0.X. |
|000022b0| 20 20 26 26 20 73 74 72 | 63 6d 70 28 54 61 62 6c | && str|cmp(Tabl|
|000022c0| 65 5b 70 72 6f 62 65 5d | 2d 3e 6e 5f 6e 61 6d 65 |e[probe]|->n_name|
|000022d0| 2c 20 54 61 62 6c 65 5b | 6c 6f 6e 67 70 72 6f 62 |, Table[|longprob|
|000022e0| 65 5d 2d 3e 6e 5f 6e 61 | 6d 65 29 20 21 3d 20 30 |e]->n_na|me) != 0|
|000022f0| 29 20 7b 0a 58 09 09 66 | 70 72 69 6e 74 66 28 73 |) {.X..f|printf(s|
|00002300| 74 64 65 72 72 2c 20 22 | 25 35 64 20 25 73 5c 6e |tderr, "|%5d %s\n|
|00002310| 22 2c 20 70 72 6f 62 65 | 2c 20 54 61 62 6c 65 5b |", probe|, Table[|
|00002320| 70 72 6f 62 65 5d 2d 3e | 6e 5f 6e 61 6d 65 29 3b |probe]->|n_name);|
|00002330| 0a 58 09 09 70 72 6f 62 | 65 20 2d 3d 20 68 61 73 |.X..prob|e -= has|
|00002340| 68 32 3b 0a 58 09 09 69 | 66 20 28 70 72 6f 62 65 |h2;.X..i|f (probe|
|00002350| 20 3c 20 30 29 0a 58 09 | 09 09 70 72 6f 62 65 20 | < 0).X.|..probe |
|00002360| 2b 3d 20 54 61 62 73 69 | 7a 65 3b 0a 58 09 7d 0a |+= Tabsi|ze;.X.}.|
|00002370| 58 09 66 70 72 69 6e 74 | 66 28 73 74 64 65 72 72 |X.fprint|f(stderr|
|00002380| 2c 20 22 25 35 64 20 25 | 73 5c 6e 22 2c 20 70 72 |, "%5d %|s\n", pr|
|00002390| 6f 62 65 2c 20 54 61 62 | 6c 65 5b 70 72 6f 62 65 |obe, Tab|le[probe|
|000023a0| 5d 2d 3e 6e 5f 6e 61 6d | 65 29 3b 0a 58 09 0a 58 |]->n_nam|e);.X..X|
|000023b0| 7d 0a 58 0a 58 2f 2a 20 | 63 6f 6e 76 65 72 74 20 |}.X.X/* |convert |
|000023c0| 74 6f 20 6c 6f 77 65 72 | 20 63 61 73 65 20 69 6e |to lower| case in|
|000023d0| 20 70 6c 61 63 65 20 2a | 2f 0a 58 53 54 41 54 49 | place *|/.XSTATI|
|000023e0| 43 20 76 6f 69 64 0a 58 | 6c 6f 77 65 72 63 61 73 |C void.X|lowercas|
|000023f0| 65 28 73 29 0a 58 09 72 | 65 67 69 73 74 65 72 20 |e(s).X.r|egister |
|00002400| 63 68 61 72 20 2a 73 3b | 0a 58 7b 0a 58 09 64 6f |char *s;|.X{.X.do|
|00002410| 20 7b 0a 58 09 09 69 66 | 20 28 69 73 75 70 70 65 | {.X..if| (isuppe|
|00002420| 72 28 2a 73 29 29 0a 58 | 09 09 09 2a 73 20 2d 3d |r(*s)).X|...*s -=|
|00002430| 20 27 41 27 20 2d 20 27 | 61 27 3b 09 2f 2a 20 41 | 'A' - '|a';./* A|
|00002440| 53 43 49 49 20 2a 2f 0a | 58 09 7d 20 77 68 69 6c |SCII */.|X.} whil|
|00002450| 65 20 28 2a 73 2b 2b 29 | 3b 0a 58 7d 0a 58 0a 58 |e (*s++)|;.X}.X.X|
|00002460| 2f 2a 0a 58 20 2a 20 74 | 68 69 73 20 6d 69 67 68 |/*.X * t|his migh|
|00002470| 74 20 6e 65 65 64 20 63 | 68 61 6e 67 65 20 69 66 |t need c|hange if|
|00002480| 20 70 72 69 76 61 74 65 | 73 20 63 61 74 63 68 20 | private|s catch |
|00002490| 6f 6e 0a 58 20 2a 2f 0a | 58 53 54 41 54 49 43 20 |on.X */.|XSTATIC |
|000024a0| 6e 6f 64 65 20 2a 0a 58 | 69 73 70 72 69 76 61 74 |node *.X|isprivat|
|000024b0| 65 28 6e 61 6d 65 29 0a | 58 09 72 65 67 69 73 74 |e(name).|X.regist|
|000024c0| 65 72 20 63 68 61 72 20 | 2a 6e 61 6d 65 3b 0a 58 |er char |*name;.X|
|000024d0| 7b 09 72 65 67 69 73 74 | 65 72 20 6e 6f 64 65 20 |{.regist|er node |
|000024e0| 2a 6e 3b 0a 58 0a 58 09 | 66 6f 72 20 28 6e 20 3d |*n;.X.X.|for (n =|
|000024f0| 20 50 72 69 76 61 74 65 | 3b 20 6e 20 21 3d 20 30 | Private|; n != 0|
|00002500| 3b 20 6e 20 3d 20 6e 2d | 3e 6e 5f 70 72 69 76 61 |; n = n-|>n_priva|
|00002510| 74 65 29 0a 58 09 09 69 | 66 20 28 73 74 72 63 6d |te).X..i|f (strcm|
|00002520| 70 28 6e 61 6d 65 2c 20 | 6e 2d 3e 6e 5f 6e 61 6d |p(name, |n->n_nam|
|00002530| 65 29 20 3d 3d 20 30 29 | 0a 58 09 09 09 72 65 74 |e) == 0)|.X...ret|
|00002540| 75 72 6e 20 6e 3b 0a 58 | 09 72 65 74 75 72 6e 20 |urn n;.X|.return |
|00002550| 30 3b 0a 58 7d 0a 58 0a | 58 76 6f 69 64 0a 58 66 |0;.X}.X.|Xvoid.Xf|
|00002560| 69 78 70 72 69 76 61 74 | 65 28 29 0a 58 7b 09 72 |ixprivat|e().X{.r|
|00002570| 65 67 69 73 74 65 72 20 | 6e 6f 64 65 20 2a 6e 2c |egister |node *n,|
|00002580| 20 2a 6e 65 78 74 3b 0a | 58 09 72 65 67 69 73 74 | *next;.|X.regist|
|00002590| 65 72 20 6c 6f 6e 67 20 | 69 3b 0a 58 0a 58 09 66 |er long |i;.X.X.f|
|000025a0| 6f 72 20 28 6e 20 3d 20 | 50 72 69 76 61 74 65 3b |or (n = |Private;|
|000025b0| 20 6e 20 21 3d 20 30 3b | 20 6e 20 3d 20 6e 65 78 | n != 0;| n = nex|
|000025c0| 74 29 20 7b 0a 58 09 09 | 6e 2d 3e 6e 5f 66 6c 61 |t) {.X..|n->n_fla|
|000025d0| 67 20 7c 3d 20 49 53 50 | 52 49 56 41 54 45 3b 09 |g |= ISP|RIVATE;.|
|000025e0| 09 2f 2a 20 6f 76 65 72 | 6b 69 6c 6c 2c 20 62 75 |./* over|kill, bu|
|000025f0| 74 20 73 61 66 65 20 2a | 2f 0a 58 09 09 69 20 3d |t safe *|/.X..i =|
|00002600| 20 68 61 73 68 28 6e 2d | 3e 6e 5f 6e 61 6d 65 2c | hash(n-|>n_name,|
|00002610| 20 31 29 3b 0a 58 09 09 | 69 66 20 28 54 61 62 6c | 1);.X..|if (Tabl|
|00002620| 65 5b 69 5d 20 21 3d 20 | 30 29 0a 58 09 09 09 64 |e[i] != |0).X...d|
|00002630| 69 65 28 22 69 6d 70 6f | 73 73 69 62 6c 65 20 70 |ie("impo|ssible p|
|00002640| 72 69 76 61 74 65 20 6e | 6f 64 65 20 65 72 72 6f |rivate n|ode erro|
|00002650| 72 22 29 3b 0a 58 09 0a | 58 09 09 54 61 62 6c 65 |r");.X..|X..Table|
|00002660| 5b 69 5d 20 3d 20 6e 3b | 0a 58 09 09 6e 2d 3e 6e |[i] = n;|.X..n->n|
|00002670| 5f 74 6c 6f 63 20 3d 20 | 69 3b 09 2f 2a 20 65 73 |_tloc = |i;./* es|
|00002680| 73 65 6e 74 69 61 6c 6c | 79 20 61 20 62 61 63 6b |sentiall|y a back|
|00002690| 20 6c 69 6e 6b 20 74 6f | 20 74 68 65 20 74 61 62 | link to| the tab|
|000026a0| 6c 65 20 2a 2f 0a 58 09 | 09 6e 65 78 74 20 3d 20 |le */.X.|.next = |
|000026b0| 6e 2d 3e 6e 5f 70 72 69 | 76 61 74 65 3b 0a 58 09 |n->n_pri|vate;.X.|
|000026c0| 09 6e 2d 3e 6e 5f 70 72 | 69 76 61 74 65 20 3d 20 |.n->n_pr|ivate = |
|000026d0| 30 3b 09 2f 2a 20 63 6c | 65 61 72 20 66 6f 72 20 |0;./* cl|ear for |
|000026e0| 6c 61 74 65 72 20 75 73 | 65 20 2a 2f 0a 58 09 7d |later us|e */.X.}|
|000026f0| 0a 58 09 50 72 69 76 61 | 74 65 20 3d 20 30 3b 0a |.X.Priva|te = 0;.|
|00002700| 58 7d 0a 58 0a 58 6e 6f | 64 65 20 2a 0a 58 61 64 |X}.X.Xno|de *.Xad|
|00002710| 64 70 72 69 76 61 74 65 | 28 6e 61 6d 65 29 0a 58 |dprivate|(name).X|
|00002720| 09 72 65 67 69 73 74 65 | 72 20 63 68 61 72 20 2a |.registe|r char *|
|00002730| 6e 61 6d 65 3b 0a 58 7b | 09 72 65 67 69 73 74 65 |name;.X{|.registe|
|00002740| 72 20 6e 6f 64 65 20 2a | 6e 3b 0a 58 0a 58 09 69 |r node *|n;.X.X.i|
|00002750| 66 20 28 49 66 6c 61 67 | 29 0a 58 09 09 6c 6f 77 |f (Iflag|).X..low|
|00002760| 65 72 63 61 73 65 28 6e | 61 6d 65 29 3b 0a 58 09 |ercase(n|ame);.X.|
|00002770| 69 66 20 28 28 6e 20 3d | 20 69 73 70 72 69 76 61 |if ((n =| ispriva|
|00002780| 74 65 28 6e 61 6d 65 29 | 29 20 21 3d 20 30 29 0a |te(name)|) != 0).|
|00002790| 58 09 09 72 65 74 75 72 | 6e 20 6e 3b 0a 58 0a 58 |X..retur|n n;.X.X|
|000027a0| 09 6e 20 3d 20 6e 65 77 | 6e 6f 64 65 28 29 3b 0a |.n = new|node();.|
|000027b0| 58 09 6e 2d 3e 6e 5f 6e | 61 6d 65 20 3d 20 73 74 |X.n->n_n|ame = st|
|000027c0| 72 73 61 76 65 28 6e 61 | 6d 65 29 3b 0a 58 09 6e |rsave(na|me);.X.n|
|000027d0| 2d 3e 6e 5f 70 72 69 76 | 61 74 65 20 3d 20 50 72 |->n_priv|ate = Pr|
|000027e0| 69 76 61 74 65 3b 0a 58 | 09 50 72 69 76 61 74 65 |ivate;.X|.Private|
|000027f0| 20 3d 20 6e 3b 0a 58 09 | 72 65 74 75 72 6e 20 6e | = n;.X.|return n|
|00002800| 3b 0a 58 7d 0a 58 0a 58 | 76 6f 69 64 0a 58 70 65 |;.X}.X.X|void.Xpe|
|00002810| 6e 61 6c 69 7a 65 28 6e | 61 6d 65 2c 20 63 6f 73 |nalize(n|ame, cos|
|00002820| 74 29 0a 58 09 63 68 61 | 72 20 2a 6e 61 6d 65 3b |t).X.cha|r *name;|
|00002830| 0a 58 09 43 6f 73 74 20 | 63 6f 73 74 3b 0a 58 7b |.X.Cost |cost;.X{|
|00002840| 09 6e 6f 64 65 20 2a 6e | 3b 0a 58 0a 58 09 69 66 |.node *n|;.X.X.if|
|00002850| 20 28 49 66 6c 61 67 29 | 0a 58 09 09 6c 6f 77 65 | (Iflag)|.X..lowe|
|00002860| 72 63 61 73 65 28 6e 61 | 6d 65 29 3b 0a 58 09 6e |rcase(na|me);.X.n|
|00002870| 20 3d 20 61 64 64 6e 6f | 64 65 28 6e 61 6d 65 29 | = addno|de(name)|
|00002880| 3b 0a 58 09 6e 2d 3e 6e | 5f 63 6f 73 74 20 2b 3d |;.X.n->n|_cost +=|
|00002890| 20 63 6f 73 74 3b 09 2f | 2a 20 63 75 6d 75 6c 61 | cost;./|* cumula|
|000028a0| 74 69 76 65 20 2a 2f 0a | 58 7d 0a 45 4e 44 5f 4f |tive */.|X}.END_O|
|000028b0| 46 5f 61 64 64 6e 6f 64 | 65 2e 63 0a 69 66 20 74 |F_addnod|e.c.if t|
|000028c0| 65 73 74 20 38 35 31 34 | 20 2d 6e 65 20 60 77 63 |est 8514| -ne `wc|
|000028d0| 20 2d 63 20 3c 61 64 64 | 6e 6f 64 65 2e 63 60 3b | -c <add|node.c`;|
|000028e0| 20 74 68 65 6e 0a 20 20 | 20 20 65 63 68 6f 20 73 | then. | echo s|
|000028f0| 68 61 72 3a 20 5c 22 61 | 64 64 6e 6f 64 65 2e 63 |har: \"a|ddnode.c|
|00002900| 5c 22 20 75 6e 70 61 63 | 6b 65 64 20 77 69 74 68 |\" unpac|ked with|
|00002910| 20 77 72 6f 6e 67 20 73 | 69 7a 65 21 0a 66 69 0a | wrong s|ize!.fi.|
|00002920| 23 20 65 6e 64 20 6f 66 | 20 6f 76 65 72 77 72 69 |# end of| overwri|
|00002930| 74 69 6e 67 20 63 68 65 | 63 6b 0a 66 69 0a 69 66 |ting che|ck.fi.if|
|00002940| 20 74 65 73 74 20 2d 66 | 20 61 72 70 61 74 78 74 | test -f| arpatxt|
|00002950| 2e 63 20 2d 61 20 22 24 | 7b 31 7d 22 20 21 3d 20 |.c -a "$|{1}" != |
|00002960| 22 2d 63 22 20 3b 20 74 | 68 65 6e 20 0a 20 20 65 |"-c" ; t|hen . e|
|00002970| 63 68 6f 20 73 68 61 72 | 3a 20 57 69 6c 6c 20 6e |cho shar|: Will n|
|00002980| 6f 74 20 6f 76 65 72 2d | 77 72 69 74 65 20 65 78 |ot over-|write ex|
|00002990| 69 73 74 69 6e 67 20 66 | 69 6c 65 20 5c 22 61 72 |isting f|ile \"ar|
|000029a0| 70 61 74 78 74 2e 63 5c | 22 0a 65 6c 73 65 0a 65 |patxt.c\|".else.e|
|000029b0| 63 68 6f 20 73 68 61 72 | 3a 20 45 78 74 72 61 63 |cho shar|: Extrac|
|000029c0| 74 69 6e 67 20 5c 22 61 | 72 70 61 74 78 74 2e 63 |ting \"a|rpatxt.c|
|000029d0| 5c 22 20 5c 28 31 32 33 | 31 37 20 63 68 61 72 61 |\" \(123|17 chara|
|000029e0| 63 74 65 72 73 5c 29 0a | 73 65 64 20 22 73 2f 5e |cters\).|sed "s/^|
|000029f0| 58 2f 2f 22 20 3e 61 72 | 70 61 74 78 74 2e 63 20 |X//" >ar|patxt.c |
|00002a00| 3c 3c 27 45 4e 44 5f 4f | 46 5f 61 72 70 61 74 78 |<<'END_O|F_arpatx|
|00002a10| 74 2e 63 27 0a 58 23 69 | 66 6e 64 65 66 20 6c 69 |t.c'.X#i|fndef li|
|00002a20| 6e 74 0a 58 73 74 61 74 | 69 63 20 63 68 61 72 20 |nt.Xstat|ic char |
|00002a30| 2a 73 63 63 73 69 64 20 | 3d 20 22 40 28 23 29 61 |*sccsid |= "@(#)a|
|00002a40| 72 70 61 74 78 74 2e 63 | 09 39 2e 31 20 38 37 2f |rpatxt.c|.9.1 87/|
|00002a50| 31 30 2f 30 34 22 3b 0a | 58 23 65 6e 64 69 66 0a |10/04";.|X#endif.|
|00002a60| 58 0a 58 2f 2a 0a 58 20 | 2a 20 63 6f 6e 76 65 72 |X.X/*.X |* conver|
|00002a70| 74 20 68 6f 73 74 73 2e | 74 78 74 20 69 6e 74 6f |t hosts.|txt into|
|00002a80| 20 70 61 74 68 61 6c 69 | 61 73 20 66 6f 72 6d 61 | pathali|as forma|
|00002a90| 74 2e 0a 58 20 2a 0a 58 | 20 2a 20 61 6c 69 61 73 |t..X *.X| * alias|
|00002aa0| 20 72 75 6c 65 3a 20 22 | 68 6f 73 74 2e 64 6f 6d | rule: "|host.dom|
|00002ab0| 2e 61 69 6e 2c 6e 69 63 | 6b 6e 61 6d 65 2e 61 72 |.ain,nic|kname.ar|
|00002ac0| 70 61 2c 2e 2e 2e 22 20 | 2d 3e 20 68 6f 73 74 20 |pa,..." |-> host |
|00002ad0| 3d 20 6e 69 63 6b 6e 61 | 6d 65 2c 20 2e 2e 2e 0a |= nickna|me, ....|
|00002ae0| 58 20 2a 2f 0a 58 0a 58 | 2f 2a 20 72 65 6d 6f 76 |X */.X.X|/* remov|
|00002af0| 65 20 74 68 65 20 6e 65 | 78 74 20 6c 69 6e 65 20 |e the ne|xt line |
|00002b00| 66 6f 72 20 73 74 61 6e | 64 61 72 64 20 6f 72 20 |for stan|dard or |
|00002b10| 72 65 73 65 61 72 63 68 | 20 75 6e 69 78 20 2a 2f |research| unix */|
|00002b20| 0a 58 23 64 65 66 69 6e | 65 20 42 53 44 0a 58 0a |.X#defin|e BSD.X.|
|00002b30| 58 23 69 66 64 65 66 20 | 42 53 44 0a 58 23 64 65 |X#ifdef |BSD.X#de|
|00002b40| 66 69 6e 65 20 73 74 72 | 63 68 72 20 69 6e 64 65 |fine str|chr inde|
|00002b50| 78 0a 58 23 65 6e 64 69 | 66 20 2f 2a 20 42 53 44 |x.X#endi|f /* BSD|
|00002b60| 20 2a 2f 0a 58 0a 58 23 | 69 6e 63 6c 75 64 65 20 | */.X.X#|include |
|00002b70| 3c 73 74 64 69 6f 2e 68 | 3e 0a 58 23 69 6e 63 6c |<stdio.h|>.X#incl|
|00002b80| 75 64 65 20 3c 63 74 79 | 70 65 2e 68 3e 0a 58 0a |ude <cty|pe.h>.X.|
|00002b90| 58 74 79 70 65 64 65 66 | 20 73 74 72 75 63 74 20 |Xtypedef| struct |
|00002ba0| 6e 6f 64 65 20 6e 6f 64 | 65 3b 0a 58 0a 58 73 74 |node nod|e;.X.Xst|
|00002bb0| 72 75 63 74 20 6e 6f 64 | 65 20 7b 0a 58 09 6e 6f |ruct nod|e {.X.no|
|00002bc0| 64 65 20 2a 63 68 69 6c | 64 3b 09 2f 2a 20 73 75 |de *chil|d;./* su|
|00002bd0| 62 64 6f 6d 61 69 6e 20 | 6f 72 20 6d 65 6d 62 65 |bdomain |or membe|
|00002be0| 72 20 68 6f 73 74 20 2a | 2f 0a 58 09 6e 6f 64 65 |r host *|/.X.node|
|00002bf0| 20 2a 70 61 72 65 6e 74 | 3b 09 2f 2a 20 70 61 72 | *parent|;./* par|
|00002c00| 65 6e 74 20 64 6f 6d 61 | 69 6e 20 2a 2f 0a 58 09 |ent doma|in */.X.|
|00002c10| 6e 6f 64 65 20 2a 6e 65 | 78 74 3b 09 2f 2a 20 73 |node *ne|xt;./* s|
|00002c20| 69 62 6c 69 6e 67 20 69 | 6e 20 64 6f 6d 61 69 6e |ibling i|n domain|
|00002c30| 20 74 72 65 65 20 6f 72 | 20 68 6f 73 74 20 6c 69 | tree or| host li|
|00002c40| 73 74 20 2a 2f 0a 58 09 | 63 68 61 72 20 2a 6e 61 |st */.X.|char *na|
|00002c50| 6d 65 3b 0a 58 09 6e 6f | 64 65 20 2a 61 6c 69 61 |me;.X.no|de *alia|
|00002c60| 73 3b 0a 58 09 6e 6f 64 | 65 20 2a 62 75 63 6b 65 |s;.X.nod|e *bucke|
|00002c70| 74 3b 0a 58 09 6e 6f 64 | 65 20 2a 67 61 74 65 77 |t;.X.nod|e *gatew|
|00002c80| 61 79 3b 0a 58 09 69 6e | 74 20 20 66 6c 61 67 3b |ay;.X.in|t flag;|
|00002c90| 0a 58 7d 3b 0a 58 0a 58 | 6e 6f 64 65 20 2a 54 6f |.X};.X.X|node *To|
|00002ca0| 70 3b 0a 58 69 6e 74 20 | 41 74 66 6c 61 67 3b 0a |p;.Xint |Atflag;.|
|00002cb0| 58 69 6e 74 20 46 66 6c | 61 67 2c 20 49 66 6c 61 |Xint Ffl|ag, Ifla|
|00002cc0| 67 3b 0a 58 63 68 61 72 | 20 2a 44 6f 74 41 72 70 |g;.Xchar| *DotArp|
|00002cd0| 61 20 3d 20 22 2e 41 52 | 50 41 22 3b 0a 58 63 68 |a = ".AR|PA";.Xch|
|00002ce0| 61 72 20 46 6e 61 6d 65 | 5b 32 35 36 5d 2c 20 2a |ar Fname|[256], *|
|00002cf0| 46 73 74 61 72 74 3b 0a | 58 0a 58 6e 6f 64 65 20 |Fstart;.|X.Xnode |
|00002d00| 2a 6e 65 77 6e 6f 64 65 | 28 29 2c 20 2a 66 69 6e |*newnode|(), *fin|
|00002d10| 64 28 29 3b 0a 58 63 68 | 61 72 20 2a 73 74 72 73 |d();.Xch|ar *strs|
|00002d20| 61 76 65 28 29 2c 20 2a | 6c 6f 77 65 72 63 61 73 |ave(), *|lowercas|
|00002d30| 65 28 29 3b 0a 58 76 6f | 69 64 20 63 72 63 69 6e |e();.Xvo|id crcin|
|00002d40| 69 74 28 29 3b 0a 58 6c | 6f 6e 67 20 66 6f 6c 64 |it();.Xl|ong fold|
|00002d50| 28 29 3b 0a 58 46 49 4c | 45 20 2a 6d 6b 66 69 6c |();.XFIL|E *mkfil|
|00002d60| 65 28 29 3b 0a 58 0a 58 | 65 78 74 65 72 6e 20 63 |e();.X.X|extern c|
|00002d70| 68 61 72 20 2a 6d 61 6c | 6c 6f 63 28 29 2c 20 2a |har *mal|loc(), *|
|00002d80| 73 74 72 63 68 72 28 29 | 2c 20 2a 63 61 6c 6c 6f |strchr()|, *callo|
|00002d90| 63 28 29 2c 20 2a 67 65 | 74 73 28 29 2c 20 2a 73 |c(), *ge|ts(), *s|
|00002da0| 74 72 63 70 79 28 29 2c | 20 2a 66 67 65 74 73 28 |trcpy(),| *fgets(|
|00002db0| 29 3b 0a 58 65 78 74 65 | 72 6e 20 46 49 4c 45 20 |);.Xexte|rn FILE |
|00002dc0| 2a 66 6f 70 65 6e 28 29 | 3b 0a 58 0a 58 23 64 65 |*fopen()|;.X.X#de|
|00002dd0| 66 69 6e 65 20 49 53 41 | 44 4f 4d 41 49 4e 28 6e |fine ISA|DOMAIN(n|
|00002de0| 29 20 28 28 6e 29 20 26 | 26 20 2a 28 28 6e 29 2d |) ((n) &|& *((n)-|
|00002df0| 3e 6e 61 6d 65 29 20 3d | 3d 20 27 2e 27 29 0a 58 |>name) =|= '.').X|
|00002e00| 0a 58 2f 2a 20 66 6f 72 | 20 6e 6f 64 65 2e 66 6c |.X/* for| node.fl|
|00002e10| 61 67 20 2a 2f 0a 58 23 | 64 65 66 69 6e 65 20 43 |ag */.X#|define C|
|00002e20| 4f 4c 4c 49 53 49 4f 4e | 20 31 0a 58 0a 58 2f 2a |OLLISION| 1.X.X/*|
|00002e30| 20 66 6f 72 20 66 6f 72 | 6d 61 74 70 72 69 6e 74 | for for|matprint|
|00002e40| 28 29 20 2a 2f 0a 58 23 | 64 65 66 69 6e 65 20 50 |() */.X#|define P|
|00002e50| 52 49 56 41 54 45 09 09 | 30 0a 58 23 64 65 66 69 |RIVATE..|0.X#defi|
|00002e60| 6e 65 20 48 4f 53 54 53 | 09 09 31 0a 58 23 64 65 |ne HOSTS|..1.X#de|
|00002e70| 66 69 6e 65 20 53 55 42 | 44 4f 4d 41 49 4e 53 09 |fine SUB|DOMAINS.|
|00002e80| 32 0a 58 0a 58 2f 2a 20 | 66 6f 72 20 75 73 61 67 |2.X.X/* |for usag|
|00002e90| 65 28 29 20 2a 2f 0a 58 | 23 64 65 66 69 6e 65 20 |e() */.X|#define |
|00002ea0| 55 53 41 47 45 20 22 75 | 73 61 67 65 3a 20 25 73 |USAGE "u|sage: %s|
|00002eb0| 20 5b 2d 69 40 5d 20 5b | 2d 67 20 67 61 74 65 77 | [-i@] [|-g gatew|
|00002ec0| 61 79 5d 20 5b 2d 70 20 | 70 72 69 76 61 74 65 66 |ay] [-p |privatef|
|00002ed0| 69 6c 65 5d 20 5b 2d 66 | 20 7c 20 2d 64 20 64 69 |ile] [-f| | -d di|
|00002ee0| 72 65 63 74 6f 72 79 5d | 20 5b 66 69 6c 65 20 2e |rectory]| [file .|
|00002ef0| 2e 2e 5d 5c 6e 22 0a 58 | 0a 58 6d 61 69 6e 28 61 |..]\n".X|.Xmain(a|
|00002f00| 72 67 63 2c 20 61 72 67 | 76 29 0a 58 09 63 68 61 |rgc, arg|v).X.cha|
|00002f10| 72 20 2a 2a 61 72 67 76 | 3b 0a 58 7b 09 69 6e 74 |r **argv|;.X{.int|
|00002f20| 20 63 3b 0a 58 09 63 68 | 61 72 20 2a 70 72 6f 67 | c;.X.ch|ar *prog|
|00002f30| 6e 61 6d 65 3b 0a 58 09 | 65 78 74 65 72 6e 20 63 |name;.X.|extern c|
|00002f40| 68 61 72 20 2a 6f 70 74 | 61 72 67 3b 0a 58 09 65 |har *opt|arg;.X.e|
|00002f50| 78 74 65 72 6e 20 69 6e | 74 20 6f 70 74 69 6e 64 |xtern in|t optind|
|00002f60| 3b 0a 58 0a 58 09 69 66 | 20 28 28 70 72 6f 67 6e |;.X.X.if| ((progn|
|00002f70| 61 6d 65 20 3d 20 73 74 | 72 63 68 72 28 61 72 67 |ame = st|rchr(arg|
|00002f80| 76 5b 30 5d 2c 20 27 2f | 27 29 29 20 21 3d 20 30 |v[0], '/|')) != 0|
|00002f90| 29 0a 58 09 09 70 72 6f | 67 6e 61 6d 65 2b 2b 3b |).X..pro|gname++;|
|00002fa0| 0a 58 09 65 6c 73 65 0a | 58 09 09 70 72 6f 67 6e |.X.else.|X..progn|
|00002fb0| 61 6d 65 20 3d 20 61 72 | 67 76 5b 30 5d 3b 0a 58 |ame = ar|gv[0];.X|
|00002fc0| 09 63 72 63 69 6e 69 74 | 28 29 3b 0a 58 0a 58 09 |.crcinit|();.X.X.|
|00002fd0| 54 6f 70 20 3d 20 6e 65 | 77 6e 6f 64 65 28 29 3b |Top = ne|wnode();|
|00002fe0| 09 2f 2a 20 6e 65 65 64 | 65 64 20 66 6f 72 20 61 |./* need|ed for a|
|00002ff0| 64 64 69 6e 67 20 67 61 | 74 65 77 61 79 73 20 2a |dding ga|teways *|
|00003000| 2f 0a 58 09 77 68 69 6c | 65 20 28 28 63 20 3d 20 |/.X.whil|e ((c = |
|00003010| 67 65 74 6f 70 74 28 61 | 72 67 63 2c 20 61 72 67 |getopt(a|rgc, arg|
|00003020| 76 2c 20 22 64 3a 66 67 | 3a 69 70 3a 40 22 29 29 |v, "d:fg|:ip:@"))|
|00003030| 20 21 3d 20 45 4f 46 29 | 0a 58 09 09 73 77 69 74 | != EOF)|.X..swit|
|00003040| 63 68 28 63 29 20 7b 0a | 58 09 09 63 61 73 65 20 |ch(c) {.|X..case |
|00003050| 27 64 27 3a 0a 58 09 09 | 09 73 74 72 63 70 79 28 |'d':.X..|.strcpy(|
|00003060| 46 6e 61 6d 65 2c 20 6f | 70 74 61 72 67 29 3b 0a |Fname, o|ptarg);.|
|00003070| 58 09 09 09 62 72 65 61 | 6b 3b 0a 58 09 09 63 61 |X...brea|k;.X..ca|
|00003080| 73 65 20 27 66 27 3a 09 | 2f 2a 20 66 69 6c 74 65 |se 'f':.|/* filte|
|00003090| 72 20 6d 6f 64 65 20 2d | 2d 20 77 72 69 74 65 20 |r mode -|- write |
|000030a0| 6f 6e 20 73 74 64 6f 75 | 74 20 2a 2f 0a 58 09 09 |on stdou|t */.X..|
|000030b0| 09 46 66 6c 61 67 2b 2b | 3b 0a 58 09 09 09 62 72 |.Fflag++|;.X...br|
|000030c0| 65 61 6b 3b 0a 58 09 09 | 63 61 73 65 20 27 67 27 |eak;.X..|case 'g'|
|000030d0| 3a 0a 58 09 09 09 67 61 | 74 65 77 61 79 28 6f 70 |:.X...ga|teway(op|
|000030e0| 74 61 72 67 29 3b 0a 58 | 09 09 09 62 72 65 61 6b |targ);.X|...break|
|000030f0| 3b 0a 58 09 09 63 61 73 | 65 20 27 69 27 3a 0a 58 |;.X..cas|e 'i':.X|
|00003100| 09 09 09 49 66 6c 61 67 | 2b 2b 3b 0a 58 09 09 09 |...Iflag|++;.X...|
|00003110| 62 72 65 61 6b 3b 0a 58 | 09 09 63 61 73 65 20 27 |break;.X|..case '|
|00003120| 70 27 3a 0a 58 09 09 09 | 72 65 61 64 70 72 69 76 |p':.X...|readpriv|
|00003130| 61 74 65 73 28 6f 70 74 | 61 72 67 29 3b 0a 58 09 |ates(opt|arg);.X.|
|00003140| 09 09 62 72 65 61 6b 3b | 0a 58 09 09 63 61 73 65 |..break;|.X..case|
|00003150| 20 27 40 27 3a 0a 58 09 | 09 09 41 74 66 6c 61 67 | '@':.X.|..Atflag|
|00003160| 2b 2b 3b 0a 58 09 09 09 | 62 72 65 61 6b 3b 0a 58 |++;.X...|break;.X|
|00003170| 09 09 64 65 66 61 75 6c | 74 3a 0a 58 09 09 09 75 |..defaul|t:.X...u|
|00003180| 73 61 67 65 28 70 72 6f | 67 6e 61 6d 65 29 3b 0a |sage(pro|gname);.|
|00003190| 58 09 09 7d 0a 58 0a 58 | 09 69 66 20 28 46 66 6c |X..}.X.X|.if (Ffl|
|000031a0| 61 67 20 26 26 20 2a 46 | 6e 61 6d 65 29 0a 58 09 |ag && *F|name).X.|
|000031b0| 09 75 73 61 67 65 28 70 | 72 6f 67 6e 61 6d 65 29 |.usage(p|rogname)|
|000031c0| 3b 0a 58 09 69 66 20 28 | 49 66 6c 61 67 29 0a 58 |;.X.if (|Iflag).X|
|000031d0| 09 09 28 76 6f 69 64 29 | 20 6c 6f 77 65 72 63 61 |..(void)| lowerca|
|000031e0| 73 65 28 44 6f 74 41 72 | 70 61 29 3b 0a 58 09 69 |se(DotAr|pa);.X.i|
|000031f0| 66 20 28 54 6f 70 2d 3e | 67 61 74 65 77 61 79 20 |f (Top->|gateway |
|00003200| 3d 3d 20 30 29 0a 58 09 | 09 66 70 72 69 6e 74 66 |== 0).X.|.fprintf|
|00003210| 28 73 74 64 65 72 72 2c | 20 22 25 73 3a 20 77 61 |(stderr,| "%s: wa|
|00003220| 72 6e 69 6e 67 3a 20 6e | 6f 20 67 61 74 65 77 61 |rning: n|o gatewa|
|00003230| 79 20 74 6f 20 74 6f 70 | 20 6c 65 76 65 6c 20 64 |y to top| level d|
|00003240| 6f 6d 61 69 6e 73 5c 6e | 22 2c 20 70 72 6f 67 6e |omains\n|", progn|
|00003250| 61 6d 65 29 3b 0a 58 0a | 58 09 46 73 74 61 72 74 |ame);.X.|X.Fstart|
|00003260| 20 3d 20 46 6e 61 6d 65 | 20 2b 20 73 74 72 6c 65 | = Fname| + strle|
|00003270| 6e 28 46 6e 61 6d 65 29 | 3b 0a 58 09 69 66 20 28 |n(Fname)|;.X.if (|
|00003280| 46 73 74 61 72 74 20 21 | 3d 20 46 6e 61 6d 65 29 |Fstart !|= Fname)|
|00003290| 20 7b 0a 58 09 09 2a 46 | 73 74 61 72 74 2b 2b 20 | {.X..*F|start++ |
|000032a0| 3d 20 27 2f 27 3b 0a 58 | 09 09 2a 46 73 74 61 72 |= '/';.X|..*Fstar|
|000032b0| 74 20 3d 20 30 3b 0a 58 | 09 7d 0a 58 09 2f 2a 20 |t = 0;.X|.}.X./* |
|000032c0| 73 68 6f 75 6c 64 20 64 | 6f 20 74 68 65 20 6d 6b |should d|o the mk|
|000032d0| 64 69 72 20 68 65 72 65 | 20 69 6e 73 74 65 61 64 |dir here| instead|
|000032e0| 20 6f 66 20 74 68 65 20 | 73 68 65 6c 6c 20 73 63 | of the |shell sc|
|000032f0| 72 69 70 74 20 2e 2e 2e | 2a 2f 0a 58 09 09 0a 58 |ript ...|*/.X...X|
|00003300| 09 54 6f 70 2d 3e 6e 61 | 6d 65 20 3d 20 22 69 6e |.Top->na|me = "in|
|00003310| 74 65 72 6e 65 74 22 3b | 0a 58 09 69 66 20 28 6f |ternet";|.X.if (o|
|00003320| 70 74 69 6e 64 20 3d 3d | 20 61 72 67 63 29 0a 58 |ptind ==| argc).X|
|00003330| 09 09 73 63 61 6e 28 29 | 3b 0a 58 09 65 6c 73 65 |..scan()|;.X.else|
|00003340| 20 66 6f 72 20 28 20 3b | 20 6f 70 74 69 6e 64 20 | for ( ;| optind |
|00003350| 3c 20 61 72 67 63 3b 20 | 6f 70 74 69 6e 64 2b 2b |< argc; |optind++|
|00003360| 29 20 7b 0a 58 09 09 69 | 66 20 28 66 72 65 6f 70 |) {.X..i|f (freop|
|00003370| 65 6e 28 61 72 67 76 5b | 6f 70 74 69 6e 64 5d 2c |en(argv[|optind],|
|00003380| 20 22 72 22 2c 20 73 74 | 64 69 6e 29 20 3d 3d 20 | "r", st|din) == |
|00003390| 30 29 20 7b 0a 58 09 09 | 09 70 65 72 72 6f 72 28 |0) {.X..|.perror(|
|000033a0| 61 72 67 76 5b 6f 70 74 | 69 6e 64 5d 29 3b 0a 58 |argv[opt|ind]);.X|
|000033b0| 09 09 09 63 6f 6e 74 69 | 6e 75 65 3b 0a 58 09 09 |...conti|nue;.X..|
|000033c0| 7d 0a 58 09 09 73 63 61 | 6e 28 29 3b 0a 58 09 7d |}.X..sca|n();.X.}|
|000033d0| 0a 58 09 6d 65 72 67 65 | 28 29 3b 0a 58 09 64 75 |.X.merge|();.X.du|
|000033e0| 6d 70 28 54 6f 70 29 3b | 0a 58 09 72 65 74 75 72 |mp(Top);|.X.retur|
|000033f0| 6e 20 30 3b 0a 58 7d 0a | 58 0a 58 73 63 61 6e 28 |n 0;.X}.|X.Xscan(|
|00003400| 29 0a 58 7b 09 73 74 61 | 74 69 63 20 66 69 72 73 |).X{.sta|tic firs|
|00003410| 74 3b 0a 58 09 63 68 61 | 72 20 62 75 66 30 5b 42 |t;.X.cha|r buf0[B|
|00003420| 55 46 53 49 5a 5d 2c 20 | 62 75 66 31 5b 42 55 46 |UFSIZ], |buf1[BUF|
|00003430| 53 49 5a 5d 2c 20 62 75 | 66 32 5b 42 55 46 53 49 |SIZ], bu|f2[BUFSI|
|00003440| 5a 5d 3b 0a 58 0a 58 09 | 69 66 20 28 66 69 72 73 |Z];.X.X.|if (firs|
|00003450| 74 2b 2b 20 3d 3d 20 30 | 29 0a 58 09 09 28 76 6f |t++ == 0|).X..(vo|
|00003460| 69 64 29 20 72 65 5f 63 | 6f 6d 70 28 22 5e 48 4f |id) re_c|omp("^HO|
|00003470| 53 54 2e 2a 53 4d 54 50 | 22 29 3b 0a 58 09 77 68 |ST.*SMTP|");.X.wh|
|00003480| 69 6c 65 20 28 67 65 74 | 73 28 62 75 66 30 29 20 |ile (get|s(buf0) |
|00003490| 21 3d 20 30 29 20 7b 0a | 58 09 09 69 66 20 28 72 |!= 0) {.|X..if (r|
|000034a0| 65 5f 65 78 65 63 28 62 | 75 66 30 29 20 3d 3d 20 |e_exec(b|uf0) == |
|000034b0| 30 29 0a 58 09 09 09 63 | 6f 6e 74 69 6e 75 65 3b |0).X...c|ontinue;|
|000034c0| 0a 58 09 09 69 66 20 28 | 73 73 63 61 6e 66 28 62 |.X..if (|sscanf(b|
|000034d0| 75 66 30 2c 20 22 48 4f | 53 54 20 3a 20 25 5b 5e |uf0, "HO|ST : %[^|
|000034e0| 3a 5d 20 3a 20 25 5b 5e | 3a 20 5d 22 2c 20 62 75 |:] : %[^|: ]", bu|
|000034f0| 66 31 2c 20 62 75 66 32 | 29 20 21 3d 20 32 29 0a |f1, buf2|) != 2).|
|00003500| 58 09 09 09 63 6f 6e 74 | 69 6e 75 65 3b 0a 58 09 |X...cont|inue;.X.|
|00003510| 09 69 66 20 28 49 66 6c | 61 67 29 0a 58 09 09 09 |.if (Ifl|ag).X...|
|00003520| 28 76 6f 69 64 29 20 6c | 6f 77 65 72 63 61 73 65 |(void) l|owercase|
|00003530| 28 62 75 66 32 29 3b 0a | 58 09 09 69 6e 73 65 72 |(buf2);.|X..inser|
|00003540| 74 28 62 75 66 32 29 3b | 0a 58 09 7d 0a 58 7d 0a |t(buf2);|.X.}.X}.|
|00003550| 58 2f 2a 0a 58 20 2a 20 | 66 6f 72 6d 61 74 20 6f |X/*.X * |format o|
|00003560| 66 20 70 72 69 76 61 74 | 65 20 66 69 6c 65 3a 0a |f privat|e file:.|
|00003570| 58 20 2a 09 6f 6e 65 20 | 70 65 72 20 6c 69 6e 65 |X *.one |per line|
|00003580| 2c 20 6f 70 74 69 6f 6e | 61 6c 6c 79 20 66 6f 6c |, option|ally fol|
|00003590| 6c 6f 77 65 64 20 62 79 | 20 77 68 69 74 65 20 73 |lowed by| white s|
|000035a0| 70 61 63 65 20 61 6e 64 | 20 63 6f 6d 6d 65 6e 74 |pace and| comment|
|000035b0| 73 0a 58 20 2a 09 6c 69 | 6e 65 20 73 74 61 72 74 |s.X *.li|ne start|
|000035c0| 69 6e 67 20 77 69 74 68 | 20 23 20 69 73 20 63 6f |ing with| # is co|
|000035d0| 6d 6d 65 6e 74 0a 58 20 | 2a 2f 0a 58 72 65 61 64 |mment.X |*/.Xread|
|000035e0| 70 72 69 76 61 74 65 73 | 28 70 66 69 6c 65 29 0a |privates|(pfile).|
|000035f0| 58 09 63 68 61 72 20 2a | 70 66 69 6c 65 3b 0a 58 |X.char *|pfile;.X|
|00003600| 7b 09 46 49 4c 45 20 2a | 66 3b 0a 58 09 6e 6f 64 |{.FILE *|f;.X.nod|
|00003610| 65 20 2a 6e 3b 0a 58 09 | 63 68 61 72 20 62 75 66 |e *n;.X.|char buf|
|00003620| 5b 42 55 46 53 49 5a 5d | 2c 20 2a 62 70 74 72 3b |[BUFSIZ]|, *bptr;|
|00003630| 0a 58 0a 58 09 69 66 20 | 28 28 66 20 3d 20 66 6f |.X.X.if |((f = fo|
|00003640| 70 65 6e 28 70 66 69 6c | 65 2c 20 22 72 22 29 29 |pen(pfil|e, "r"))|
|00003650| 20 3d 3d 20 30 29 20 7b | 0a 58 09 09 70 65 72 72 | == 0) {|.X..perr|
|00003660| 6f 72 28 70 66 69 6c 65 | 29 3b 0a 58 09 09 72 65 |or(pfile|);.X..re|
|00003670| 74 75 72 6e 3b 0a 58 09 | 7d 0a 58 09 77 68 69 6c |turn;.X.|}.X.whil|
|00003680| 65 20 28 66 67 65 74 73 | 28 62 75 66 2c 20 42 55 |e (fgets|(buf, BU|
|00003690| 46 53 49 5a 2c 20 66 29 | 20 21 3d 20 30 29 20 7b |FSIZ, f)| != 0) {|
|000036a0| 0a 58 09 09 69 66 20 28 | 2a 62 75 66 20 3d 3d 20 |.X..if (|*buf == |
|000036b0| 27 23 27 29 0a 58 09 09 | 09 63 6f 6e 74 69 6e 75 |'#').X..|.continu|
|000036c0| 65 3b 0a 58 09 09 69 66 | 20 28 28 62 70 74 72 20 |e;.X..if| ((bptr |
|000036d0| 3d 20 73 74 72 63 68 72 | 28 62 75 66 2c 20 27 20 |= strchr|(buf, ' |
|000036e0| 27 29 29 20 21 3d 20 30 | 29 0a 58 09 09 09 2a 62 |')) != 0|).X...*b|
|000036f0| 70 74 72 20 3d 20 30 3b | 0a 58 09 09 69 66 20 28 |ptr = 0;|.X..if (|
|00003700| 28 62 70 74 72 20 3d 20 | 73 74 72 63 68 72 28 62 |(bptr = |strchr(b|
|00003710| 75 66 2c 20 27 5c 74 27 | 29 29 20 21 3d 20 30 29 |uf, '\t'|)) != 0)|
|00003720| 0a 58 09 09 09 2a 62 70 | 74 72 20 3d 20 30 3b 0a |.X...*bp|tr = 0;.|
|00003730| 58 09 09 69 66 20 28 2a | 62 75 66 20 3d 3d 20 30 |X..if (*|buf == 0|
|00003740| 29 0a 58 09 09 09 63 6f | 6e 74 69 6e 75 65 3b 0a |).X...co|ntinue;.|
|00003750| 58 09 09 6e 20 3d 20 6e | 65 77 6e 6f 64 65 28 29 |X..n = n|ewnode()|
|00003760| 3b 0a 58 09 09 6e 2d 3e | 6e 61 6d 65 20 3d 20 73 |;.X..n->|name = s|
|00003770| 74 72 73 61 76 65 28 62 | 75 66 29 3b 0a 58 09 09 |trsave(b|uf);.X..|
|00003780| 68 61 73 68 28 6e 29 3b | 0a 58 09 7d 0a 58 09 28 |hash(n);|.X.}.X.(|
|00003790| 76 6f 69 64 29 20 66 63 | 6c 6f 73 65 28 66 29 3b |void) fc|lose(f);|
|000037a0| 0a 58 7d 0a 58 75 73 61 | 67 65 28 70 72 6f 67 6e |.X}.Xusa|ge(progn|
|000037b0| 61 6d 65 29 0a 58 09 63 | 68 61 72 20 2a 70 72 6f |ame).X.c|har *pro|
|000037c0| 67 6e 61 6d 65 3b 0a 58 | 7b 0a 58 09 66 70 72 69 |gname;.X|{.X.fpri|
|000037d0| 6e 74 66 28 73 74 64 65 | 72 72 2c 20 55 53 41 47 |ntf(stde|rr, USAG|
|000037e0| 45 2c 20 70 72 6f 67 6e | 61 6d 65 29 3b 0a 58 09 |E, progn|ame);.X.|
|000037f0| 65 78 69 74 28 31 29 3b | 0a 58 7d 0a 58 64 75 6d |exit(1);|.X}.Xdum|
|00003800| 70 67 61 74 65 77 61 79 | 73 28 6e 64 6f 6d 2c 20 |pgateway|s(ndom, |
|00003810| 66 29 0a 58 09 6e 6f 64 | 65 20 2a 6e 64 6f 6d 3b |f).X.nod|e *ndom;|
|00003820| 0a 58 09 46 49 4c 45 20 | 2a 66 3b 0a 58 7b 09 6e |.X.FILE |*f;.X{.n|
|00003830| 6f 64 65 20 2a 6e 3b 0a | 58 0a 58 09 66 6f 72 20 |ode *n;.|X.X.for |
|00003840| 28 6e 20 3d 20 6e 64 6f | 6d 2d 3e 67 61 74 65 77 |(n = ndo|m->gatew|
|00003850| 61 79 3b 20 6e 3b 20 6e | 20 3d 20 6e 2d 3e 6e 65 |ay; n; n| = n->ne|
|00003860| 78 74 29 20 7b 0a 58 09 | 09 66 70 72 69 6e 74 66 |xt) {.X.|.fprintf|
|00003870| 28 66 2c 20 22 25 73 20 | 22 2c 20 6e 2d 3e 6e 61 |(f, "%s |", n->na|
|00003880| 6d 65 29 3b 0a 58 09 09 | 69 66 20 28 41 74 66 6c |me);.X..|if (Atfl|
|00003890| 61 67 29 0a 58 09 09 09 | 70 75 74 63 28 27 40 27 |ag).X...|putc('@'|
|000038a0| 2c 20 66 29 3b 0a 58 09 | 09 66 70 72 69 6e 74 66 |, f);.X.|.fprintf|
|000038b0| 28 66 2c 20 22 25 73 28 | 25 73 29 5c 74 23 20 67 |(f, "%s(|%s)\t# g|
|000038c0| 61 74 65 77 61 79 5c 6e | 22 2c 20 6e 64 6f 6d 2d |ateway\n|", ndom-|
|000038d0| 3e 6e 61 6d 65 2c 0a 58 | 09 09 09 09 6e 64 6f 6d |>name,.X|....ndom|
|000038e0| 20 3d 3d 20 54 6f 70 20 | 3f 20 22 44 45 44 49 43 | == Top |? "DEDIC|
|000038f0| 41 54 45 44 22 20 3a 20 | 22 4c 4f 43 41 4c 22 29 |ATED" : |"LOCAL")|
|00003900| 3b 0a 58 09 7d 0a 58 7d | 0a 58 0a 58 67 61 74 65 |;.X.}.X}|.X.Xgate|
|00003910| 77 61 79 28 62 75 66 29 | 0a 58 09 63 68 61 72 20 |way(buf)|.X.char |
|00003920| 2a 62 75 66 3b 0a 58 7b | 09 6e 6f 64 65 20 2a 6e |*buf;.X{|.node *n|
|00003930| 2c 20 2a 64 6f 6d 3b 0a | 58 09 63 68 61 72 20 2a |, *dom;.|X.char *|
|00003940| 64 6f 74 3b 0a 58 0a 58 | 09 64 6f 74 20 3d 20 73 |dot;.X.X|.dot = s|
|00003950| 74 72 63 68 72 28 62 75 | 66 2c 20 27 2e 27 29 3b |trchr(bu|f, '.');|
|00003960| 0a 58 09 69 66 20 28 64 | 6f 74 29 20 7b 0a 58 09 |.X.if (d|ot) {.X.|
|00003970| 09 64 6f 6d 20 3d 20 66 | 69 6e 64 28 64 6f 74 29 |.dom = f|ind(dot)|
|00003980| 3b 0a 58 09 09 2a 64 6f | 74 20 3d 20 30 3b 0a 58 |;.X..*do|t = 0;.X|
|00003990| 09 7d 20 65 6c 73 65 0a | 58 09 09 64 6f 6d 20 3d |.} else.|X..dom =|
|000039a0| 20 54 6f 70 3b 0a 58 0a | 58 09 6e 20 3d 20 6e 65 | Top;.X.|X.n = ne|
|000039b0| 77 6e 6f 64 65 28 29 3b | 0a 58 09 6e 2d 3e 6e 61 |wnode();|.X.n->na|
|000039c0| 6d 65 20 3d 20 73 74 72 | 73 61 76 65 28 62 75 66 |me = str|save(buf|
|000039d0| 29 3b 0a 58 09 6e 2d 3e | 6e 65 78 74 20 3d 20 64 |);.X.n->|next = d|
|000039e0| 6f 6d 2d 3e 67 61 74 65 | 77 61 79 3b 0a 58 09 64 |om->gate|way;.X.d|
|000039f0| 6f 6d 2d 3e 67 61 74 65 | 77 61 79 20 3d 20 6e 3b |om->gate|way = n;|
|00003a00| 0a 58 7d 0a 58 09 0a 58 | 69 6e 73 65 72 74 28 62 |.X}.X..X|insert(b|
|00003a10| 75 66 29 0a 58 09 63 68 | 61 72 20 2a 62 75 66 3b |uf).X.ch|ar *buf;|
|00003a20| 0a 58 7b 09 63 68 61 72 | 20 68 6f 73 74 5b 42 55 |.X{.char| host[BU|
|00003a30| 46 53 49 5a 5d 2c 20 2a | 68 70 74 72 2c 20 2a 64 |FSIZ], *|hptr, *d|
|00003a40| 6f 74 3b 0a 58 09 6e 6f | 64 65 20 2a 6e 3b 0a 58 |ot;.X.no|de *n;.X|
|00003a50| 0a 58 09 66 6f 72 20 28 | 68 70 74 72 20 3d 20 68 |.X.for (|hptr = h|
|00003a60| 6f 73 74 3b 20 2a 68 70 | 74 72 20 3d 20 2a 62 75 |ost; *hp|tr = *bu|
|00003a70| 66 2b 2b 3b 20 68 70 74 | 72 2b 2b 29 0a 58 09 09 |f++; hpt|r++).X..|
|00003a80| 69 66 20 28 2a 68 70 74 | 72 20 3d 3d 20 27 2c 27 |if (*hpt|r == ','|
|00003a90| 29 0a 58 09 09 09 62 72 | 65 61 6b 3b 0a 58 0a 58 |).X...br|eak;.X.X|
|00003aa0| 09 69 66 20 28 2a 68 70 | 74 72 20 3d 3d 20 27 2c |.if (*hp|tr == ',|
|00003ab0| 27 29 0a 58 09 09 2a 68 | 70 74 72 20 3d 20 30 3b |').X..*h|ptr = 0;|
|00003ac0| 0a 58 09 65 6c 73 65 0a | 58 09 09 62 75 66 20 3d |.X.else.|X..buf =|
|00003ad0| 20 30 3b 09 2f 2a 20 6e | 6f 20 61 6c 69 61 73 65 | 0;./* n|o aliase|
|00003ae0| 73 20 2a 2f 0a 58 0a 58 | 09 69 66 20 28 28 64 6f |s */.X.X|.if ((do|
|00003af0| 74 20 3d 20 73 74 72 63 | 68 72 28 68 6f 73 74 2c |t = strc|hr(host,|
|00003b00| 20 27 2e 27 29 29 20 3d | 3d 20 30 29 0a 58 09 09 | '.')) =|= 0).X..|
|00003b10| 61 62 6f 72 74 28 29 3b | 09 2f 2a 20 63 61 6e 27 |abort();|./* can'|
|00003b20| 74 20 68 61 70 70 65 6e | 20 2a 2f 0a 58 09 0a 58 |t happen| */.X..X|
|00003b30| 09 69 66 20 28 73 74 72 | 63 6d 70 28 64 6f 74 2c |.if (str|cmp(dot,|
|00003b40| 20 44 6f 74 41 72 70 61 | 29 20 3d 3d 20 30 29 0a | DotArpa|) == 0).|
|00003b50| 58 09 09 62 75 66 20 3d | 20 30 3b 09 09 2f 2a 20 |X..buf =| 0;../* |
|00003b60| 6e 6f 20 61 6c 69 61 73 | 65 73 20 2a 2f 0a 58 0a |no alias|es */.X.|
|00003b70| 58 09 6e 20 3d 20 66 69 | 6e 64 28 64 6f 74 29 3b |X.n = fi|nd(dot);|
|00003b80| 0a 58 09 2a 64 6f 74 20 | 3d 20 30 3b 0a 58 0a 58 |.X.*dot |= 0;.X.X|
|00003b90| 09 61 64 64 63 68 69 6c | 64 28 6e 2c 20 68 6f 73 |.addchil|d(n, hos|
|00003ba0| 74 2c 20 62 75 66 29 3b | 0a 58 7d 0a 58 0a 58 6e |t, buf);|.X}.X.Xn|
|00003bb0| 6f 64 65 20 2a 0a 58 66 | 69 6e 64 28 64 6f 6d 61 |ode *.Xf|ind(doma|
|00003bc0| 69 6e 29 0a 58 09 63 68 | 61 72 20 2a 64 6f 6d 61 |in).X.ch|ar *doma|
|00003bd0| 69 6e 3b 0a 58 7b 09 63 | 68 61 72 20 2a 64 6f 74 |in;.X{.c|har *dot|
|00003be0| 3b 0a 58 09 6e 6f 64 65 | 20 2a 70 61 72 65 6e 74 |;.X.node| *parent|
|00003bf0| 2c 20 2a 63 68 69 6c 64 | 3b 0a 58 0a 58 09 69 66 |, *child|;.X.X.if|
|00003c00| 20 28 64 6f 6d 61 69 6e | 20 3d 3d 20 30 29 0a 58 | (domain| == 0).X|
|00003c10| 09 09 72 65 74 75 72 6e | 20 54 6f 70 3b 0a 58 09 |..return| Top;.X.|
|00003c20| 69 66 20 28 28 64 6f 74 | 20 3d 20 73 74 72 63 68 |if ((dot| = strch|
|00003c30| 72 28 64 6f 6d 61 69 6e | 2b 31 2c 20 27 2e 27 29 |r(domain|+1, '.')|
|00003c40| 29 20 21 3d 20 30 29 20 | 7b 0a 58 09 09 70 61 72 |) != 0) |{.X..par|
|00003c50| 65 6e 74 20 3d 20 66 69 | 6e 64 28 64 6f 74 29 3b |ent = fi|nd(dot);|
|00003c60| 0a 58 09 09 2a 64 6f 74 | 20 3d 20 30 3b 0a 58 09 |.X..*dot| = 0;.X.|
|00003c70| 7d 20 65 6c 73 65 0a 58 | 09 09 70 61 72 65 6e 74 |} else.X|..parent|
|00003c80| 20 3d 20 54 6f 70 3b 0a | 58 0a 58 09 66 6f 72 20 | = Top;.|X.X.for |
|00003c90| 28 63 68 69 6c 64 20 3d | 20 70 61 72 65 6e 74 2d |(child =| parent-|
|00003ca0| 3e 63 68 69 6c 64 3b 20 | 63 68 69 6c 64 3b 20 63 |>child; |child; c|
|00003cb0| 68 69 6c 64 20 3d 20 63 | 68 69 6c 64 2d 3e 6e 65 |hild = c|hild->ne|
|00003cc0| 78 74 29 0a 58 09 09 69 | 66 20 28 73 74 72 63 6d |xt).X..i|f (strcm|
|00003cd0| 70 28 64 6f 6d 61 69 6e | 2c 20 63 68 69 6c 64 2d |p(domain|, child-|
|00003ce0| 3e 6e 61 6d 65 29 20 3d | 3d 20 30 29 0a 58 09 09 |>name) =|= 0).X..|
|00003cf0| 09 62 72 65 61 6b 3b 0a | 58 09 69 66 20 28 63 68 |.break;.|X.if (ch|
|00003d00| 69 6c 64 20 3d 3d 20 30 | 29 20 7b 0a 58 09 09 63 |ild == 0|) {.X..c|
|00003d10| 68 69 6c 64 20 3d 20 6e | 65 77 6e 6f 64 65 28 29 |hild = n|ewnode()|
|00003d20| 3b 0a 58 09 09 63 68 69 | 6c 64 2d 3e 6e 65 78 74 |;.X..chi|ld->next|
|00003d30| 20 3d 20 70 61 72 65 6e | 74 2d 3e 63 68 69 6c 64 | = paren|t->child|
|00003d40| 3b 0a 58 09 09 70 61 72 | 65 6e 74 2d 3e 63 68 69 |;.X..par|ent->chi|
|00003d50| 6c 64 20 3d 20 63 68 69 | 6c 64 3b 0a 58 09 09 63 |ld = chi|ld;.X..c|
|00003d60| 68 69 6c 64 2d 3e 70 61 | 72 65 6e 74 20 3d 20 70 |hild->pa|rent = p|
|00003d70| 61 72 65 6e 74 3b 0a 58 | 09 09 63 68 69 6c 64 2d |arent;.X|..child-|
|00003d80| 3e 6e 61 6d 65 20 3d 20 | 73 74 72 73 61 76 65 28 |>name = |strsave(|
|00003d90| 64 6f 6d 61 69 6e 29 3b | 0a 58 09 7d 0a 58 09 72 |domain);|.X.}.X.r|
|00003da0| 65 74 75 72 6e 20 63 68 | 69 6c 64 3b 0a 58 7d 0a |eturn ch|ild;.X}.|
|00003db0| 58 0a 58 6e 6f 64 65 20 | 2a 0a 58 6e 65 77 6e 6f |X.Xnode |*.Xnewno|
|00003dc0| 64 65 28 29 0a 58 7b 0a | 58 09 6e 6f 64 65 20 2a |de().X{.|X.node *|
|00003dd0| 6e 3b 0a 58 0a 58 09 69 | 66 20 28 28 6e 20 3d 20 |n;.X.X.i|f ((n = |
|00003de0| 28 6e 6f 64 65 20 2a 29 | 20 63 61 6c 6c 6f 63 28 |(node *)| calloc(|
|00003df0| 31 2c 20 73 69 7a 65 6f | 66 28 6e 6f 64 65 29 29 |1, sizeo|f(node))|
|00003e00| 29 20 3d 3d 20 30 29 0a | 58 09 09 61 62 6f 72 74 |) == 0).|X..abort|
|00003e10| 28 29 3b 0a 58 09 72 65 | 74 75 72 6e 20 6e 3b 0a |();.X.re|turn n;.|
|00003e20| 58 7d 0a 58 0a 58 63 68 | 61 72 20 2a 0a 58 73 74 |X}.X.Xch|ar *.Xst|
|00003e30| 72 73 61 76 65 28 62 75 | 66 29 0a 58 09 63 68 61 |rsave(bu|f).X.cha|
|00003e40| 72 20 2a 62 75 66 3b 0a | 58 7b 09 63 68 61 72 20 |r *buf;.|X{.char |
|00003e50| 2a 6d 73 74 72 3b 0a 58 | 0a 58 09 69 66 20 28 28 |*mstr;.X|.X.if ((|
|00003e60| 6d 73 74 72 20 3d 20 6d | 61 6c 6c 6f 63 28 73 74 |mstr = m|alloc(st|
|00003e70| 72 6c 65 6e 28 62 75 66 | 29 2b 31 29 29 20 3d 3d |rlen(buf|)+1)) ==|
|00003e80| 20 30 29 0a 58 09 09 61 | 62 6f 72 74 28 29 3b 0a | 0).X..a|bort();.|
|00003e90| 58 09 73 74 72 63 70 79 | 28 6d 73 74 72 2c 20 62 |X.strcpy|(mstr, b|
|00003ea0| 75 66 29 3b 0a 58 09 72 | 65 74 75 72 6e 20 6d 73 |uf);.X.r|eturn ms|
|00003eb0| 74 72 3b 0a 58 7d 0a 58 | 0a 58 61 64 64 63 68 69 |tr;.X}.X|.Xaddchi|
|00003ec0| 6c 64 28 6e 2c 20 68 6f | 73 74 2c 20 61 6c 69 61 |ld(n, ho|st, alia|
|00003ed0| 73 65 73 29 0a 58 09 6e | 6f 64 65 20 2a 6e 3b 0a |ses).X.n|ode *n;.|
|00003ee0| 58 09 63 68 61 72 20 2a | 68 6f 73 74 2c 20 2a 61 |X.char *|host, *a|
|00003ef0| 6c 69 61 73 65 73 3b 0a | 58 7b 09 6e 6f 64 65 20 |liases;.|X{.node |
|00003f00| 2a 63 68 69 6c 64 3b 0a | 58 0a 58 09 2f 2a 20 63 |*child;.|X.X./* c|
|00003f10| 68 65 63 6b 20 66 6f 72 | 20 64 75 70 73 3f 20 20 |heck for| dups? |
|00003f20| 6e 61 68 21 20 2a 2f 0a | 58 09 63 68 69 6c 64 20 |nah! */.|X.child |
|00003f30| 3d 20 6e 65 77 6e 6f 64 | 65 28 29 3b 0a 58 09 63 |= newnod|e();.X.c|
|00003f40| 68 69 6c 64 2d 3e 6e 61 | 6d 65 20 3d 20 73 74 72 |hild->na|me = str|
|00003f50| 73 61 76 65 28 68 6f 73 | 74 29 3b 0a 58 09 63 68 |save(hos|t);.X.ch|
|00003f60| 69 6c 64 2d 3e 70 61 72 | 65 6e 74 20 3d 20 6e 3b |ild->par|ent = n;|
|00003f70| 0a 58 09 63 68 69 6c 64 | 2d 3e 6e 65 78 74 20 3d |.X.child|->next =|
|00003f80| 20 6e 2d 3e 63 68 69 6c | 64 3b 0a 58 09 6d 61 6b | n->chil|d;.X.mak|
|00003f90| 65 61 6c 69 61 73 65 73 | 28 63 68 69 6c 64 2c 20 |ealiases|(child, |
|00003fa0| 61 6c 69 61 73 65 73 29 | 3b 0a 58 09 6e 2d 3e 63 |aliases)|;.X.n->c|
|00003fb0| 68 69 6c 64 20 3d 20 63 | 68 69 6c 64 3b 0a 58 7d |hild = c|hild;.X}|
|00003fc0| 0a 58 0a 58 2f 2a 20 79 | 65 72 20 62 61 73 69 63 |.X.X/* y|er basic|
|00003fd0| 20 74 72 65 65 20 77 61 | 6c 6b 20 2a 2f 0a 58 64 | tree wa|lk */.Xd|
|00003fe0| 75 6d 70 28 6e 29 0a 58 | 09 6e 6f 64 65 20 2a 6e |ump(n).X|.node *n|
|00003ff0| 3b 0a 58 7b 09 6e 6f 64 | 65 20 2a 63 68 69 6c 64 |;.X{.nod|e *child|
|00004000| 3b 0a 58 09 46 49 4c 45 | 20 2a 66 3b 0a 58 09 69 |;.X.FILE| *f;.X.i|
|00004010| 6e 74 20 68 61 64 70 72 | 69 76 61 74 65 73 20 3d |nt hadpr|ivates =|
|00004020| 20 30 3b 0a 58 0a 58 09 | 69 66 20 28 6e 2d 3e 63 | 0;.X.X.|if (n->c|
|00004030| 68 69 6c 64 20 3d 3d 20 | 30 29 0a 58 09 09 72 65 |hild == |0).X..re|
|00004040| 74 75 72 6e 3b 0a 58 0a | 58 09 66 20 3d 20 6d 6b |turn;.X.|X.f = mk|
|00004050| 66 69 6c 65 28 6e 29 3b | 0a 58 0a 58 09 69 66 20 |file(n);|.X.X.if |
|00004060| 28 6e 20 21 3d 20 54 6f | 70 20 26 26 20 21 20 49 |(n != To|p && ! I|
|00004070| 53 41 44 4f 4d 41 49 4e | 28 6e 29 29 0a 58 09 09 |SADOMAIN|(n)).X..|
|00004080| 61 62 6f 72 74 28 29 3b | 0a 58 0a 58 09 68 61 64 |abort();|.X.X.had|
|00004090| 70 72 69 76 61 74 65 73 | 20 3d 20 64 6f 6d 70 72 |privates| = dompr|
|000040a0| 69 6e 74 28 6e 2c 20 66 | 29 3b 0a 58 09 64 75 6d |int(n, f|);.X.dum|
|000040b0| 70 67 61 74 65 77 61 79 | 73 28 6e 2c 20 66 29 3b |pgateway|s(n, f);|
|000040c0| 0a 58 09 69 66 20 28 68 | 61 64 70 72 69 76 61 74 |.X.if (h|adprivat|
|000040d0| 65 73 20 7c 7c 20 6e 20 | 3d 3d 20 54 6f 70 29 0a |es || n |== Top).|
|000040e0| 58 09 09 66 70 75 74 73 | 28 22 70 72 69 76 61 74 |X..fputs|("privat|
|000040f0| 65 20 7b 7d 5c 6e 22 2c | 20 66 29 3b 09 2f 2a 20 |e {}\n",| f);./* |
|00004100| 65 6e 64 20 73 63 6f 70 | 65 20 6f 66 20 70 72 69 |end scop|e of pri|
|00004110| 76 61 74 65 73 20 2a 2f | 0a 58 09 69 66 20 28 21 |vates */|.X.if (!|
|00004120| 46 66 6c 61 67 29 0a 58 | 09 09 28 76 6f 69 64 29 |Fflag).X|..(void)|
|00004130| 20 66 63 6c 6f 73 65 28 | 66 29 3b 0a 58 09 65 6c | fclose(|f);.X.el|
|00004140| 73 65 0a 58 09 09 70 75 | 74 63 28 27 5c 6e 27 2c |se.X..pu|tc('\n',|
|00004150| 20 66 29 3b 0a 58 09 66 | 6f 72 20 28 63 68 69 6c | f);.X.f|or (chil|
|00004160| 64 20 3d 20 6e 2d 3e 63 | 68 69 6c 64 3b 20 63 68 |d = n->c|hild; ch|
|00004170| 69 6c 64 3b 20 63 68 69 | 6c 64 20 3d 20 63 68 69 |ild; chi|ld = chi|
|00004180| 6c 64 2d 3e 6e 65 78 74 | 29 0a 58 09 09 64 75 6d |ld->next|).X..dum|
|00004190| 70 28 63 68 69 6c 64 29 | 3b 0a 58 7d 0a 58 0a 58 |p(child)|;.X}.X.X|
|000041a0| 71 63 6d 70 28 61 2c 20 | 62 29 0a 58 09 6e 6f 64 |qcmp(a, |b).X.nod|
|000041b0| 65 20 2a 2a 61 2c 20 2a | 2a 62 3b 0a 58 7b 0a 58 |e **a, *|*b;.X{.X|
|000041c0| 09 72 65 74 75 72 6e 20 | 73 74 72 63 6d 70 28 28 |.return |strcmp((|
|000041d0| 2a 61 29 2d 3e 6e 61 6d | 65 2c 20 28 2a 62 29 2d |*a)->nam|e, (*b)-|
|000041e0| 3e 6e 61 6d 65 29 3b 0a | 58 7d 0a 58 0a 58 64 6f |>name);.|X}.X.Xdo|
|000041f0| 6d 70 72 69 6e 74 28 6e | 2c 20 66 29 0a 58 09 6e |mprint(n|, f).X.n|
|00004200| 6f 64 65 20 2a 6e 3b 0a | 58 09 46 49 4c 45 20 2a |ode *n;.|X.FILE *|
|00004210| 66 3b 0a 58 7b 09 6e 6f | 64 65 20 2a 74 61 62 6c |f;.X{.no|de *tabl|
|00004220| 65 5b 31 30 32 34 30 5d | 2c 20 2a 63 68 69 6c 64 |e[10240]|, *child|
|00004230| 2c 20 2a 61 6c 69 61 73 | 3b 0a 58 09 63 68 61 72 |, *alias|;.X.char|
|00004240| 20 2a 63 6f 73 74 20 3d | 20 30 3b 0a 58 09 69 6e | *cost =| 0;.X.in|
|00004250| 74 20 6e 65 6c 65 6d 2c | 20 69 2c 20 72 76 61 6c |t nelem,| i, rval|
|00004260| 20 3d 20 30 3b 0a 58 0a | 58 09 2f 2a 20 64 75 6d | = 0;.X.|X./* dum|
|00004270| 70 20 70 72 69 76 61 74 | 65 20 64 65 66 69 6e 69 |p privat|e defini|
|00004280| 74 69 6f 6e 73 20 2a 2f | 0a 58 09 2f 2a 20 73 6f |tions */|.X./* so|
|00004290| 72 74 20 68 6f 73 74 73 | 20 61 6e 64 20 61 6c 69 |rt hosts| and ali|
|000042a0| 61 73 65 73 20 69 6e 20 | 74 61 62 6c 65 20 2a 2f |ases in |table */|
|000042b0| 0a 58 09 69 20 3d 20 30 | 3b 0a 58 09 66 6f 72 20 |.X.i = 0|;.X.for |
|000042c0| 28 63 68 69 6c 64 20 3d | 20 6e 2d 3e 63 68 69 6c |(child =| n->chil|
|000042d0| 64 3b 20 63 68 69 6c 64 | 3b 20 63 68 69 6c 64 20 |d; child|; child |
|000042e0| 3d 20 63 68 69 6c 64 2d | 3e 6e 65 78 74 29 20 7b |= child-|>next) {|
|000042f0| 0a 58 09 09 74 61 62 6c | 65 5b 69 2b 2b 5d 20 3d |.X..tabl|e[i++] =|
|00004300| 20 63 68 69 6c 64 3b 0a | 58 09 09 66 6f 72 20 28 | child;.|X..for (|
|00004310| 61 6c 69 61 73 20 3d 20 | 63 68 69 6c 64 2d 3e 61 |alias = |child->a|
|00004320| 6c 69 61 73 3b 20 61 6c | 69 61 73 3b 20 61 6c 69 |lias; al|ias; ali|
|00004330| 61 73 20 3d 20 61 6c 69 | 61 73 2d 3e 6e 65 78 74 |as = ali|as->next|
|00004340| 29 0a 58 09 09 09 74 61 | 62 6c 65 5b 69 2b 2b 5d |).X...ta|ble[i++]|
|00004350| 20 3d 20 61 6c 69 61 73 | 3b 0a 58 09 7d 0a 58 0a | = alias|;.X.}.X.|
|00004360| 58 09 71 73 6f 72 74 28 | 28 63 68 61 72 20 2a 29 |X.qsort(|(char *)|
|00004370| 20 74 61 62 6c 65 2c 20 | 69 2c 20 73 69 7a 65 6f | table, |i, sizeo|
|00004380| 66 28 74 61 62 6c 65 5b | 30 5d 29 2c 20 71 63 6d |f(table[|0]), qcm|
|00004390| 70 29 3b 0a 58 09 66 6f | 72 6d 61 74 70 72 69 6e |p);.X.fo|rmatprin|
|000043a0| 74 28 66 2c 20 74 61 62 | 6c 65 2c 20 69 2c 20 50 |t(f, tab|le, i, P|
|000043b0| 52 49 56 41 54 45 2c 20 | 22 70 72 69 76 61 74 65 |RIVATE, |"private|
|000043c0| 22 2c 20 63 6f 73 74 29 | 3b 0a 58 0a 58 09 2f 2a |", cost)|;.X.X./*|
|000043d0| 20 72 76 61 6c 20 3d 3d | 20 30 20 49 46 46 20 6e | rval ==| 0 IFF n|
|000043e0| 6f 20 70 72 69 76 61 74 | 65 73 20 2a 2f 0a 58 09 |o privat|es */.X.|
|000043f0| 77 68 69 6c 65 20 28 69 | 2d 2d 20 3e 20 30 29 0a |while (i|-- > 0).|
|00004400| 58 09 09 69 66 20 28 74 | 61 62 6c 65 5b 69 5d 2d |X..if (t|able[i]-|
|00004410| 3e 66 6c 61 67 20 26 20 | 43 4f 4c 4c 49 53 49 4f |>flag & |COLLISIO|
|00004420| 4e 29 20 7b 0a 58 09 09 | 09 72 76 61 6c 20 3d 20 |N) {.X..|.rval = |
|00004430| 31 3b 0a 58 09 09 09 62 | 72 65 61 6b 3b 0a 58 09 |1;.X...b|reak;.X.|
|00004440| 09 7d 0a 58 0a 58 09 2f | 2a 20 64 75 6d 70 20 64 |.}.X.X./|* dump d|
|00004450| 6f 6d 61 69 6e 73 20 61 | 6e 64 20 61 6c 69 61 73 |omains a|nd alias|
|00004460| 65 73 20 2a 2f 0a 58 09 | 2f 2a 20 73 6f 72 74 20 |es */.X.|/* sort |
|00004470| 68 6f 73 74 73 20 28 6f | 6e 6c 79 29 20 69 6e 20 |hosts (o|nly) in |
|00004480| 74 61 62 6c 65 20 2a 2f | 0a 58 09 69 20 3d 20 30 |table */|.X.i = 0|
|00004490| 3b 0a 58 09 66 6f 72 20 | 28 63 68 69 6c 64 20 3d |;.X.for |(child =|
|000044a0| 20 6e 2d 3e 63 68 69 6c | 64 3b 20 63 68 69 6c 64 | n->chil|d; child|
|000044b0| 3b 20 63 68 69 6c 64 20 | 3d 20 63 68 69 6c 64 2d |; child |= child-|
|000044c0| 3e 6e 65 78 74 29 0a 58 | 09 09 74 61 62 6c 65 5b |>next).X|..table[|
|000044d0| 69 2b 2b 5d 20 3d 20 63 | 68 69 6c 64 3b 0a 58 09 |i++] = c|hild;.X.|
|000044e0| 71 73 6f 72 74 28 28 63 | 68 61 72 20 2a 29 20 74 |qsort((c|har *) t|
|000044f0| 61 62 6c 65 2c 20 69 2c | 20 73 69 7a 65 6f 66 28 |able, i,| sizeof(|
|00004500| 74 61 62 6c 65 5b 30 5d | 29 2c 20 71 63 6d 70 29 |table[0]|), qcmp)|
|00004510| 3b 0a 58 0a 58 09 2f 2a | 20 63 6f 73 74 20 69 73 |;.X.X./*| cost is|
|00004520| 20 44 45 44 49 43 41 54 | 45 44 20 66 6f 72 20 68 | DEDICAT|ED for h|
|00004530| 6f 73 74 73 20 69 6e 20 | 74 6f 70 2d 6c 65 76 65 |osts in |top-leve|
|00004540| 6c 20 64 6f 6d 61 69 6e | 73 2c 20 4c 4f 43 41 4c |l domain|s, LOCAL|
|00004550| 20 6f 2e 77 2e 20 2a 2f | 0a 58 09 69 66 20 28 6e | o.w. */|.X.if (n|
|00004560| 2d 3e 70 61 72 65 6e 74 | 20 3d 3d 20 54 6f 70 20 |->parent| == Top |
|00004570| 26 26 20 73 74 72 63 68 | 72 28 6e 2d 3e 6e 61 6d |&& strch|r(n->nam|
|00004580| 65 20 2b 20 31 2c 20 27 | 2e 27 29 20 3d 3d 20 30 |e + 1, '|.') == 0|
|00004590| 29 0a 58 09 09 63 6f 73 | 74 20 3d 20 22 44 45 44 |).X..cos|t = "DED|
|000045a0| 49 43 41 54 45 44 22 3b | 0a 58 09 65 6c 73 65 0a |ICATED";|.X.else.|
|000045b0| 58 09 09 63 6f 73 74 20 | 3d 20 22 4c 4f 43 41 4c |X..cost |= "LOCAL|
|000045c0| 22 3b 0a 58 09 66 6f 72 | 6d 61 74 70 72 69 6e 74 |";.X.for|matprint|
|000045d0| 28 66 2c 20 74 61 62 6c | 65 2c 20 69 2c 20 48 4f |(f, tabl|e, i, HO|
|000045e0| 53 54 53 2c 20 6e 2d 3e | 6e 61 6d 65 2c 20 63 6f |STS, n->|name, co|
|000045f0| 73 74 29 3b 0a 58 0a 58 | 09 66 6f 72 6d 61 74 70 |st);.X.X|.formatp|
|00004600| 72 69 6e 74 28 66 2c 20 | 74 61 62 6c 65 2c 20 69 |rint(f, |table, i|
|00004610| 2c 20 53 55 42 44 4f 4d | 41 49 4e 53 2c 20 6e 2d |, SUBDOM|AINS, n-|
|00004620| 3e 6e 61 6d 65 2c 20 22 | 30 22 29 3b 0a 58 0a 58 |>name, "|0");.X.X|
|00004630| 09 2f 2a 20 64 75 6d 70 | 20 61 6c 69 61 73 65 73 |./* dump| aliases|
|00004640| 20 2a 2f 0a 58 09 6e 65 | 6c 65 6d 20 3d 20 69 3b | */.X.ne|lem = i;|
|00004650| 0a 58 09 66 6f 72 20 28 | 69 20 3d 20 30 3b 20 69 |.X.for (|i = 0; i|
|00004660| 20 3c 20 6e 65 6c 65 6d | 3b 20 69 2b 2b 29 20 7b | < nelem|; i++) {|
|00004670| 0a 58 09 09 69 66 20 28 | 28 61 6c 69 61 73 20 3d |.X..if (|(alias =|
|00004680| 20 74 61 62 6c 65 5b 69 | 5d 2d 3e 61 6c 69 61 73 | table[i|]->alias|
|00004690| 29 20 3d 3d 20 30 29 0a | 58 09 09 09 63 6f 6e 74 |) == 0).|X...cont|
|000046a0| 69 6e 75 65 3b 0a 58 09 | 09 66 70 72 69 6e 74 66 |inue;.X.|.fprintf|
|000046b0| 28 66 2c 20 22 25 73 20 | 3d 20 25 73 22 2c 20 74 |(f, "%s |= %s", t|
|000046c0| 61 62 6c 65 5b 69 5d 2d | 3e 6e 61 6d 65 2c 20 61 |able[i]-|>name, a|
|000046d0| 6c 69 61 73 2d 3e 6e 61 | 6d 65 29 3b 0a 58 09 09 |lias->na|me);.X..|
|000046e0| 66 6f 72 20 28 61 6c 69 | 61 73 20 3d 20 61 6c 69 |for (ali|as = ali|
|000046f0| 61 73 2d 3e 6e 65 78 74 | 3b 20 61 6c 69 61 73 3b |as->next|; alias;|
|00004700| 20 61 6c 69 61 73 20 3d | 20 61 6c 69 61 73 2d 3e | alias =| alias->|
|00004710| 6e 65 78 74 29 0a 58 09 | 09 09 66 70 72 69 6e 74 |next).X.|..fprint|
|00004720| 66 28 66 2c 20 22 2c 20 | 25 73 22 2c 20 61 6c 69 |f(f, ", |%s", ali|
|00004730| 61 73 2d 3e 6e 61 6d 65 | 29 3b 0a 58 09 09 70 75 |as->name|);.X..pu|
|00004740| 74 63 28 27 5c 6e 27 2c | 20 66 29 3b 0a 58 09 7d |tc('\n',| f);.X.}|
|00004750| 0a 58 0a 58 09 72 65 74 | 75 72 6e 20 72 76 61 6c |.X.X.ret|urn rval|
|00004760| 3b 0a 58 7d 0a 58 0a 58 | 2f 2a 20 66 6f 72 20 64 |;.X}.X.X|/* for d|
|00004770| 65 62 75 67 67 69 6e 67 | 20 2a 2f 0a 58 64 74 61 |ebugging| */.Xdta|
|00004780| 62 6c 65 28 63 6f 6d 6d | 65 6e 74 2c 20 74 61 62 |ble(comm|ent, tab|
|00004790| 6c 65 2c 20 6e 65 6c 65 | 6d 29 0a 58 09 63 68 61 |le, nele|m).X.cha|
|000047a0| 72 20 2a 63 6f 6d 6d 65 | 6e 74 3b 0a 58 09 6e 6f |r *comme|nt;.X.no|
|000047b0| 64 65 20 2a 2a 74 61 62 | 6c 65 3b 0a 58 7b 09 69 |de **tab|le;.X{.i|
|000047c0| 6e 74 09 69 3b 0a 58 0a | 58 09 66 70 72 69 6e 74 |nt.i;.X.|X.fprint|
|000047d0| 66 28 73 74 64 65 72 72 | 2c 20 22 5c 6e 25 73 5c |f(stderr|, "\n%s\|
|000047e0| 6e 22 2c 20 63 6f 6d 6d | 65 6e 74 29 3b 0a 58 09 |n", comm|ent);.X.|
|000047f0| 66 6f 72 20 28 69 20 3d | 20 30 3b 20 69 20 3c 20 |for (i =| 0; i < |
|00004800| 6e 65 6c 65 6d 3b 20 69 | 2b 2b 29 0a 58 09 09 66 |nelem; i|++).X..f|
|00004810| 70 72 69 6e 74 66 28 73 | 74 64 65 72 72 2c 20 22 |printf(s|tderr, "|
|00004820| 25 33 64 5c 74 25 73 5c | 6e 22 2c 20 69 2c 20 74 |%3d\t%s\|n", i, t|
|00004830| 61 62 6c 65 5b 69 5d 2d | 3e 6e 61 6d 65 29 3b 0a |able[i]-|>name);.|
|00004840| 58 7d 0a 58 0a 58 66 6f | 72 6d 61 74 70 72 69 6e |X}.X.Xfo|rmatprin|
|00004850| 74 28 66 2c 20 74 61 62 | 6c 65 2c 20 6e 65 6c 65 |t(f, tab|le, nele|
|00004860| 6d 2c 20 74 79 70 65 2c | 20 6c 68 73 2c 20 63 6f |m, type,| lhs, co|
|00004870| 73 74 29 0a 58 09 46 49 | 4c 45 20 2a 66 3b 0a 58 |st).X.FI|LE *f;.X|
|00004880| 09 6e 6f 64 65 20 2a 2a | 74 61 62 6c 65 3b 0a 58 |.node **|table;.X|
|00004890| 09 63 68 61 72 20 2a 6c | 68 73 2c 20 2a 63 6f 73 |.char *l|hs, *cos|
|000048a0| 74 3b 0a 58 7b 09 69 6e | 74 20 69 2c 20 64 69 64 |t;.X{.in|t i, did|
|000048b0| 70 72 69 6e 74 3b 0a 58 | 09 63 68 61 72 20 62 75 |print;.X|.char bu|
|000048c0| 66 5b 31 32 38 5d 2c 20 | 2a 62 70 74 72 3b 0a 58 |f[128], |*bptr;.X|
|000048d0| 0a 58 09 73 70 72 69 6e | 74 66 28 62 75 66 2c 20 |.X.sprin|tf(buf, |
|000048e0| 22 25 73 25 73 7b 22 20 | 2f 2a 7d 2a 2f 2c 20 6c |"%s%s{" |/*}*/, l|
|000048f0| 68 73 2c 20 74 79 70 65 | 20 3d 3d 20 50 52 49 56 |hs, type| == PRIV|
|00004900| 41 54 45 20 3f 20 22 20 | 22 20 3a 20 22 20 3d 20 |ATE ? " |" : " = |
|00004910| 22 29 3b 0a 58 09 62 70 | 74 72 20 3d 20 62 75 66 |");.X.bp|tr = buf|
|00004920| 20 2b 20 73 74 72 6c 65 | 6e 28 62 75 66 29 3b 0a | + strle|n(buf);.|
|00004930| 58 0a 58 09 64 69 64 70 | 72 69 6e 74 20 3d 20 30 |X.X.didp|rint = 0|
|00004940| 3b 0a 58 09 66 6f 72 20 | 28 69 20 3d 20 30 3b 20 |;.X.for |(i = 0; |
|00004950| 69 20 3c 20 6e 65 6c 65 | 6d 3b 20 69 2b 2b 29 20 |i < nele|m; i++) |
|00004960| 7b 0a 58 09 09 69 66 20 | 28 74 79 70 65 20 3d 3d |{.X..if |(type ==|
|00004970| 20 50 52 49 56 41 54 45 | 20 26 26 20 21 20 28 74 | PRIVATE| && ! (t|
|00004980| 61 62 6c 65 5b 69 5d 2d | 3e 66 6c 61 67 20 26 20 |able[i]-|>flag & |
|00004990| 43 4f 4c 4c 49 53 49 4f | 4e 29 29 0a 58 09 09 09 |COLLISIO|N)).X...|
|000049a0| 63 6f 6e 74 69 6e 75 65 | 3b 0a 58 09 09 65 6c 73 |continue|;.X..els|
|000049b0| 65 20 69 66 20 28 74 79 | 70 65 20 3d 3d 20 48 4f |e if (ty|pe == HO|
|000049c0| 53 54 53 20 26 26 20 49 | 53 41 44 4f 4d 41 49 4e |STS && I|SADOMAIN|
|000049d0| 28 74 61 62 6c 65 5b 69 | 5d 29 20 29 0a 58 09 09 |(table[i|]) ).X..|
|000049e0| 09 63 6f 6e 74 69 6e 75 | 65 3b 0a 58 09 09 65 6c |.continu|e;.X..el|
|000049f0| 73 65 20 69 66 20 28 74 | 79 70 65 20 3d 3d 20 53 |se if (t|ype == S|
|00004a00| 55 42 44 4f 4d 41 49 4e | 53 20 26 26 20 21 20 49 |UBDOMAIN|S && ! I|
|00004a10| 53 41 44 4f 4d 41 49 4e | 28 74 61 62 6c 65 5b 69 |SADOMAIN|(table[i|
|00004a20| 5d 29 20 29 0a 58 09 09 | 09 63 6f 6e 74 69 6e 75 |]) ).X..|.continu|
|00004a30| 65 3b 0a 58 0a 58 09 09 | 69 66 20 28 28 62 70 74 |e;.X.X..|if ((bpt|
|00004a40| 72 20 2d 20 62 75 66 29 | 20 2b 20 73 74 72 6c 65 |r - buf)| + strle|
|00004a50| 6e 28 74 61 62 6c 65 5b | 69 5d 2d 3e 6e 61 6d 65 |n(table[|i]->name|
|00004a60| 29 20 3e 20 36 39 29 20 | 7b 0a 58 09 09 09 2a 62 |) > 69) |{.X...*b|
|00004a70| 70 74 72 20 3d 20 30 3b | 0a 58 09 09 09 66 70 72 |ptr = 0;|.X...fpr|
|00004a80| 69 6e 74 66 28 66 2c 20 | 22 25 73 5c 6e 20 22 2c |intf(f, |"%s\n ",|
|00004a90| 20 62 75 66 29 3b 09 2f | 2a 20 63 6f 6e 74 69 6e | buf);./|* contin|
|00004aa0| 75 61 74 69 6f 6e 20 2a | 2f 0a 58 09 09 09 62 70 |uation *|/.X...bp|
|00004ab0| 74 72 20 3d 20 62 75 66 | 3b 0a 58 09 09 7d 0a 58 |tr = buf|;.X..}.X|
|00004ac0| 09 09 73 70 72 69 6e 74 | 66 28 62 70 74 72 2c 20 |..sprint|f(bptr, |
|00004ad0| 22 25 73 2c 20 22 2c 20 | 74 61 62 6c 65 5b 69 5d |"%s, ", |table[i]|
|00004ae0| 2d 3e 6e 61 6d 65 29 3b | 0a 58 09 09 62 70 74 72 |->name);|.X..bptr|
|00004af0| 20 2b 3d 20 73 74 72 6c | 65 6e 28 62 70 74 72 29 | += strl|en(bptr)|
|00004b00| 3b 0a 58 09 09 64 69 64 | 70 72 69 6e 74 2b 2b 3b |;.X..did|print++;|
|00004b10| 0a 58 09 7d 0a 58 09 2a | 62 70 74 72 20 3d 20 30 |.X.}.X.*|bptr = 0|
|00004b20| 3b 0a 58 0a 58 09 69 66 | 20 28 20 21 20 64 69 64 |;.X.X.if| ( ! did|
|00004b30| 70 72 69 6e 74 20 29 0a | 58 09 09 72 65 74 75 72 |print ).|X..retur|
|00004b40| 6e 3b 0a 58 0a 58 09 66 | 70 72 69 6e 74 66 28 66 |n;.X.X.f|printf(f|
|00004b50| 2c 20 2f 2a 7b 2a 2f 20 | 22 25 73 7d 22 2c 20 62 |, /*{*/ |"%s}", b|
|00004b60| 75 66 29 3b 0a 58 09 69 | 66 20 28 74 79 70 65 20 |uf);.X.i|f (type |
|00004b70| 21 3d 20 50 52 49 56 41 | 54 45 29 0a 58 09 09 66 |!= PRIVA|TE).X..f|
|00004b80| 70 72 69 6e 74 66 28 66 | 2c 20 22 28 25 73 29 22 |printf(f|, "(%s)"|
|00004b90| 2c 20 63 6f 73 74 29 3b | 0a 58 09 70 75 74 63 28 |, cost);|.X.putc(|
|00004ba0| 27 5c 6e 27 2c 20 66 29 | 3b 0a 58 7d 0a 58 0a 58 |'\n', f)|;.X}.X.X|
|00004bb0| 46 49 4c 45 20 2a 09 09 | 09 09 0a 58 6d 6b 66 69 |FILE *..|...Xmkfi|
|00004bc0| 6c 65 28 6e 29 0a 58 09 | 6e 6f 64 65 20 2a 6e 3b |le(n).X.|node *n;|
|00004bd0| 0a 58 7b 09 6e 6f 64 65 | 20 2a 70 61 72 65 6e 74 |.X{.node| *parent|
|00004be0| 3b 0a 58 09 63 68 61 72 | 20 2a 62 70 74 72 3b 0a |;.X.char| *bptr;.|
|00004bf0| 58 09 46 49 4c 45 20 2a | 66 3b 0a 58 0a 58 09 2f |X.FILE *|f;.X.X./|
|00004c00| 2a 20 62 75 69 6c 64 20 | 75 70 20 74 68 65 20 64 |* build |up the d|
|00004c10| 6f 6d 61 69 6e 20 6e 61 | 6d 65 20 69 6e 20 46 6e |omain na|me in Fn|
|00004c20| 61 6d 65 5b 5d 20 2a 2f | 0a 58 09 62 70 74 72 20 |ame[] */|.X.bptr |
|00004c30| 3d 20 46 73 74 61 72 74 | 3b 0a 58 09 69 66 20 28 |= Fstart|;.X.if (|
|00004c40| 6e 20 3d 3d 20 54 6f 70 | 29 0a 58 09 09 73 74 72 |n == Top|).X..str|
|00004c50| 63 70 79 28 62 70 74 72 | 2c 20 6e 2d 3e 6e 61 6d |cpy(bptr|, n->nam|
|00004c60| 65 29 3b 0a 58 09 65 6c | 73 65 20 7b 0a 58 09 09 |e);.X.el|se {.X..|
|00004c70| 73 74 72 63 70 79 28 62 | 70 74 72 2c 20 6e 2d 3e |strcpy(b|ptr, n->|
|00004c80| 6e 61 6d 65 20 2b 20 31 | 29 3b 09 2f 2a 20 73 6b |name + 1|);./* sk|
|00004c90| 69 70 20 6c 65 61 64 69 | 6e 67 20 64 6f 74 20 2a |ip leadi|ng dot *|
|00004ca0| 2f 0a 58 09 09 62 70 74 | 72 20 3d 20 62 70 74 72 |/.X..bpt|r = bptr|
|00004cb0| 20 2b 20 73 74 72 6c 65 | 6e 28 62 70 74 72 29 3b | + strle|n(bptr);|
|00004cc0| 0a 58 09 09 70 61 72 65 | 6e 74 20 3d 20 6e 2d 3e |.X..pare|nt = n->|
|00004cd0| 70 61 72 65 6e 74 3b 0a | 58 09 09 77 68 69 6c 65 |parent;.|X..while|
|00004ce0| 20 28 49 53 41 44 4f 4d | 41 49 4e 28 70 61 72 65 | (ISADOM|AIN(pare|
|00004cf0| 6e 74 29 29 20 7b 0a 58 | 09 09 09 73 74 72 63 70 |nt)) {.X|...strcp|
|00004d00| 79 28 62 70 74 72 2c 20 | 70 61 72 65 6e 74 2d 3e |y(bptr, |parent->|
|00004d10| 6e 61 6d 65 29 3b 0a 58 | 09 09 09 62 70 74 72 20 |name);.X|...bptr |
|00004d20| 2b 3d 20 73 74 72 6c 65 | 6e 28 62 70 74 72 29 3b |+= strle|n(bptr);|
|00004d30| 0a 58 09 09 09 70 61 72 | 65 6e 74 20 3d 20 70 61 |.X...par|ent = pa|
|00004d40| 72 65 6e 74 2d 3e 70 61 | 72 65 6e 74 3b 0a 58 09 |rent->pa|rent;.X.|
|00004d50| 09 7d 0a 58 09 09 2a 62 | 70 74 72 20 3d 20 30 3b |.}.X..*b|ptr = 0;|
|00004d60| 0a 58 09 7d 0a 58 0a 58 | 09 2f 2a 20 67 65 74 20 |.X.}.X.X|./* get |
|00004d70| 61 20 73 74 72 65 61 6d | 20 64 65 73 63 72 69 70 |a stream| descrip|
|00004d80| 74 6f 72 20 2a 2f 0a 58 | 09 69 66 20 28 46 66 6c |tor */.X|.if (Ffl|
|00004d90| 61 67 29 20 7b 0a 58 09 | 09 70 72 69 6e 74 66 28 |ag) {.X.|.printf(|
|00004da0| 22 23 20 25 73 5c 6e 22 | 2c 20 46 73 74 61 72 74 |"# %s\n"|, Fstart|
|00004db0| 29 3b 0a 58 09 09 66 20 | 3d 20 73 74 64 6f 75 74 |);.X..f |= stdout|
|00004dc0| 3b 0a 58 09 7d 20 65 6c | 73 65 20 7b 0a 58 23 69 |;.X.} el|se {.X#i|
|00004dd0| 66 6e 64 65 66 20 42 53 | 44 0a 58 09 09 46 73 74 |fndef BS|D.X..Fst|
|00004de0| 61 72 74 5b 31 34 5d 20 | 3d 20 30 3b 0a 58 23 65 |art[14] |= 0;.X#e|
|00004df0| 6e 64 69 66 0a 58 09 09 | 69 66 20 28 28 66 20 3d |ndif.X..|if ((f =|
|00004e00| 20 66 6f 70 65 6e 28 46 | 6e 61 6d 65 2c 20 22 77 | fopen(F|name, "w|
|00004e10| 22 29 29 20 3d 3d 20 30 | 29 20 7b 0a 58 09 09 09 |")) == 0|) {.X...|
|00004e20| 70 65 72 72 6f 72 28 46 | 6e 61 6d 65 29 3b 0a 58 |perror(F|name);.X|
|00004e30| 09 09 09 65 78 69 74 28 | 31 29 3b 0a 58 09 09 7d |...exit(|1);.X..}|
|00004e40| 0a 58 09 7d 0a 58 09 69 | 66 20 28 6e 20 3d 3d 20 |.X.}.X.i|f (n == |
|00004e50| 54 6f 70 29 0a 58 09 09 | 66 70 72 69 6e 74 66 28 |Top).X..|fprintf(|
|00004e60| 66 2c 20 22 70 72 69 76 | 61 74 65 20 7b 25 73 7d |f, "priv|ate {%s}|
|00004e70| 5c 6e 64 65 61 64 20 7b | 25 73 7d 5c 6e 22 2c 20 |\ndead {|%s}\n", |
|00004e80| 54 6f 70 2d 3e 6e 61 6d | 65 2c 20 54 6f 70 2d 3e |Top->nam|e, Top->|
|00004e90| 6e 61 6d 65 29 3b 0a 58 | 09 72 65 74 75 72 6e 20 |name);.X|.return |
|00004ea0| 66 3b 0a 58 7d 0a 58 0a | 58 2f 2a 20 6d 61 70 20 |f;.X}.X.|X/* map |
|00004eb0| 74 6f 20 6c 6f 77 65 72 | 20 63 61 73 65 20 69 6e |to lower| case in|
|00004ec0| 20 70 6c 61 63 65 2e 20 | 20 72 65 74 75 72 6e 20 | place. | return |
|00004ed0| 70 61 72 61 6d 65 74 65 | 72 20 66 6f 72 20 63 6f |paramete|r for co|
|00004ee0| 6e 76 65 6e 69 65 6e 63 | 65 20 2a 2f 0a 58 63 68 |nvenienc|e */.Xch|
|00004ef0| 61 72 20 2a 0a 58 6c 6f | 77 65 72 63 61 73 65 28 |ar *.Xlo|wercase(|
|00004f00| 62 75 66 29 0a 58 09 63 | 68 61 72 20 2a 62 75 66 |buf).X.c|har *buf|
|00004f10| 3b 0a 58 7b 09 63 68 61 | 72 20 2a 73 74 72 3b 0a |;.X{.cha|r *str;.|
|00004f20| 58 0a 58 09 66 6f 72 20 | 28 73 74 72 20 3d 20 62 |X.X.for |(str = b|
|00004f30| 75 66 20 3b 20 2a 73 74 | 72 3b 20 73 74 72 2b 2b |uf ; *st|r; str++|
|00004f40| 29 0a 58 09 09 69 66 20 | 28 69 73 75 70 70 65 72 |).X..if |(isupper|
|00004f50| 28 2a 73 74 72 29 29 0a | 58 09 09 09 2a 73 74 72 |(*str)).|X...*str|
|00004f60| 20 2d 3d 20 27 41 27 20 | 2d 20 27 61 27 3b 0a 58 | -= 'A' |- 'a';.X|
|00004f70| 09 72 65 74 75 72 6e 20 | 62 75 66 3b 0a 58 7d 0a |.return |buf;.X}.|
|00004f80| 58 0a 58 2f 2a 20 67 65 | 74 20 74 68 65 20 69 6e |X.X/* ge|t the in|
|00004f90| 74 65 72 65 73 74 69 6e | 67 20 61 6c 69 61 73 65 |terestin|g aliase|
|00004fa0| 73 2c 20 61 74 74 61 63 | 68 20 74 6f 20 6e 2d 3e |s, attac|h to n->|
|00004fb0| 61 6c 69 61 73 20 2a 2f | 0a 58 6d 61 6b 65 61 6c |alias */|.Xmakeal|
|00004fc0| 69 61 73 65 73 28 6e 2c | 20 6c 69 6e 65 29 0a 58 |iases(n,| line).X|
|00004fd0| 09 6e 6f 64 65 20 2a 6e | 3b 0a 58 09 63 68 61 72 |.node *n|;.X.char|
|00004fe0| 20 2a 6c 69 6e 65 3b 0a | 58 7b 09 63 68 61 72 20 | *line;.|X{.char |
|00004ff0| 2a 6e 65 78 74 2c 20 2a | 64 6f 74 3b 0a 58 09 6e |*next, *|dot;.X.n|
|00005000| 6f 64 65 20 2a 61 3b 0a | 58 0a 58 09 69 66 20 28 |ode *a;.|X.X.if (|
|00005010| 6c 69 6e 65 20 3d 3d 20 | 30 20 7c 7c 20 2a 6c 69 |line == |0 || *li|
|00005020| 6e 65 20 3d 3d 20 30 29 | 0a 58 09 09 72 65 74 75 |ne == 0)|.X..retu|
|00005030| 72 6e 3b 0a 58 0a 58 09 | 66 6f 72 20 28 20 3b 20 |rn;.X.X.|for ( ; |
|00005040| 6c 69 6e 65 3b 20 6c 69 | 6e 65 20 3d 20 6e 65 78 |line; li|ne = nex|
|00005050| 74 29 20 7b 0a 58 09 09 | 6e 65 78 74 20 3d 20 73 |t) {.X..|next = s|
|00005060| 74 72 63 68 72 28 6c 69 | 6e 65 2c 20 27 2c 27 29 |trchr(li|ne, ',')|
|00005070| 3b 0a 58 09 09 69 66 20 | 28 6e 65 78 74 29 0a 58 |;.X..if |(next).X|
|00005080| 09 09 09 2a 6e 65 78 74 | 2b 2b 20 3d 20 30 3b 0a |...*next|++ = 0;.|
|00005090| 58 09 09 69 66 20 28 28 | 64 6f 74 20 3d 20 73 74 |X..if ((|dot = st|
|000050a0| 72 63 68 72 28 6c 69 6e | 65 2c 20 27 2e 27 29 29 |rchr(lin|e, '.'))|
|000050b0| 20 3d 3d 20 30 29 0a 58 | 09 09 09 63 6f 6e 74 69 | == 0).X|...conti|
|000050c0| 6e 75 65 3b 0a 58 09 09 | 69 66 20 28 73 74 72 63 |nue;.X..|if (strc|
|000050d0| 6d 70 28 64 6f 74 2c 20 | 44 6f 74 41 72 70 61 29 |mp(dot, |DotArpa)|
|000050e0| 20 21 3d 20 30 29 0a 58 | 09 09 09 63 6f 6e 74 69 | != 0).X|...conti|
|000050f0| 6e 75 65 3b 0a 58 09 09 | 2a 64 6f 74 20 3d 20 30 |nue;.X..|*dot = 0|
|00005100| 3b 0a 58 0a 58 09 09 69 | 66 20 28 73 74 72 63 6d |;.X.X..i|f (strcm|
|00005110| 70 28 6e 2d 3e 6e 61 6d | 65 2c 20 6c 69 6e 65 29 |p(n->nam|e, line)|
|00005120| 20 3d 3d 20 30 29 0a 58 | 09 09 09 63 6f 6e 74 69 | == 0).X|...conti|
|00005130| 6e 75 65 3b 0a 58 0a 58 | 09 09 61 20 3d 20 6e 65 |nue;.X.X|..a = ne|
|00005140| 77 6e 6f 64 65 28 29 3b | 0a 58 09 09 61 2d 3e 6e |wnode();|.X..a->n|
|00005150| 61 6d 65 20 3d 20 73 74 | 72 73 61 76 65 28 6c 69 |ame = st|rsave(li|
|00005160| 6e 65 29 3b 0a 58 09 09 | 61 2d 3e 6e 65 78 74 20 |ne);.X..|a->next |
|00005170| 3d 20 6e 2d 3e 61 6c 69 | 61 73 3b 0a 58 09 09 6e |= n->ali|as;.X..n|
|00005180| 2d 3e 61 6c 69 61 73 20 | 3d 20 61 3b 0a 58 09 7d |->alias |= a;.X.}|
|00005190| 0a 58 7d 0a 58 0a 58 23 | 64 65 66 69 6e 65 20 4e |.X}.X.X#|define N|
|000051a0| 48 41 53 48 20 31 33 33 | 30 39 0a 58 6e 6f 64 65 |HASH 133|09.Xnode|
|000051b0| 20 2a 68 74 61 62 6c 65 | 5b 4e 48 41 53 48 5d 3b | *htable|[NHASH];|
|000051c0| 0a 58 0a 58 6d 65 72 67 | 65 28 29 0a 58 7b 09 6e |.X.Xmerg|e().X{.n|
|000051d0| 6f 64 65 20 2a 6e 3b 0a | 58 0a 58 09 73 65 74 75 |ode *n;.|X.X.setu|
|000051e0| 6e 69 71 66 6c 61 67 28 | 54 6f 70 29 3b 0a 58 09 |niqflag(|Top);.X.|
|000051f0| 66 6f 72 20 28 6e 20 3d | 20 54 6f 70 2d 3e 63 68 |for (n =| Top->ch|
|00005200| 69 6c 64 3b 20 6e 3b 20 | 6e 20 3d 20 6e 2d 3e 6e |ild; n; |n = n->n|
|00005210| 65 78 74 29 20 7b 0a 58 | 09 09 69 66 20 28 6e 2d |ext) {.X|..if (n-|
|00005220| 3e 66 6c 61 67 20 26 20 | 43 4f 4c 4c 49 53 49 4f |>flag & |COLLISIO|
|00005230| 4e 29 20 7b 0a 58 09 09 | 09 66 70 72 69 6e 74 66 |N) {.X..|.fprintf|
|00005240| 28 73 74 64 65 72 72 2c | 20 22 69 6c 6c 65 67 61 |(stderr,| "illega|
|00005250| 6c 20 73 75 62 64 6f 6d | 61 69 6e 3a 20 25 73 5c |l subdom|ain: %s\|
|00005260| 6e 22 2c 20 6e 2d 3e 6e | 61 6d 65 29 3b 0a 58 09 |n", n->n|ame);.X.|
|00005270| 09 09 61 62 6f 72 74 28 | 29 3b 0a 58 09 09 7d 0a |..abort(|);.X..}.|
|00005280| 58 09 09 70 72 6f 6d 6f | 74 65 28 6e 29 3b 0a 58 |X..promo|te(n);.X|
|00005290| 09 7d 0a 58 7d 0a 58 0a | 58 2f 2a 0a 58 20 2a 20 |.}.X}.X.|X/*.X * |
|000052a0| 66 6f 72 20 64 6f 6d 61 | 69 6e 73 20 6c 69 6b 65 |for doma|ins like|
|000052b0| 20 63 63 2e 75 6d 69 63 | 68 2e 65 64 75 20 61 6e | cc.umic|h.edu an|
|000052c0| 64 20 63 63 2e 62 65 72 | 6b 65 6c 65 79 2e 65 64 |d cc.ber|keley.ed|
|000052d0| 75 2c 20 69 74 27 73 20 | 69 6e 61 63 63 75 72 61 |u, it's |inaccura|
|000052e0| 74 65 0a 58 20 2a 20 74 | 6f 20 64 65 73 63 72 69 |te.X * t|o descri|
|000052f0| 62 65 20 63 63 20 61 73 | 20 61 20 6d 65 6d 62 65 |be cc as| a membe|
|00005300| 72 20 6f 66 20 75 6d 69 | 63 68 2e 65 64 75 20 6f |r of umi|ch.edu o|
|00005310| 72 20 62 65 72 6b 65 6c | 65 79 2e 65 64 75 2e 20 |r berkel|ey.edu. |
|00005320| 20 28 69 2e 65 2e 2c 20 | 74 68 65 0a 58 20 2a 20 | (i.e., |the.X * |
|00005330| 6c 6f 75 73 79 20 73 63 | 6f 70 69 6e 67 20 72 75 |lousy sc|oping ru|
|00005340| 6c 65 73 20 66 6f 72 20 | 70 72 69 76 61 74 65 73 |les for |privates|
|00005350| 20 64 6f 6e 27 74 20 70 | 65 72 6d 69 74 20 61 20 | don't p|ermit a |
|00005360| 63 6c 65 61 6e 20 73 79 | 6e 74 61 78 2e 29 20 20 |clean sy|ntax.) |
|00005370| 73 6f 2e 0a 58 20 2a 0a | 58 20 2a 20 74 6f 20 70 |so..X *.|X * to p|
|00005380| 72 65 76 65 6e 74 20 63 | 6f 6e 66 75 73 69 6f 6e |revent c|onfusion|
|00005390| 2c 20 74 61 63 6b 20 6f | 6e 20 74 6f 20 61 6e 79 |, tack o|n to any|
|000053a0| 20 73 75 63 68 20 64 6f | 6d 61 69 6e 20 6e 61 6d | such do|main nam|
|000053b0| 65 20 69 74 73 20 70 61 | 72 65 6e 74 20 64 6f 6d |e its pa|rent dom|
|000053c0| 61 69 6e 0a 58 20 2a 20 | 61 6e 64 20 70 72 6f 6d |ain.X * |and prom|
|000053d0| 6f 74 65 20 69 74 20 69 | 6e 20 74 68 65 20 74 72 |ote it i|n the tr|
|000053e0| 65 65 2e 20 20 65 2e 67 | 2e 2c 20 6d 61 6b 65 20 |ee. e.g|., make |
|000053f0| 63 63 2e 75 6d 69 63 68 | 20 61 6e 64 20 63 63 2e |cc.umich| and cc.|
|00005400| 62 65 72 6b 65 6c 65 79 | 0a 58 20 2a 20 73 75 62 |berkeley|.X * sub|
|00005410| 64 6f 6d 61 69 6e 73 20 | 6f 66 20 65 64 75 2e 0a |domains |of edu..|
|00005420| 58 20 2a 2f 0a 58 0a 58 | 70 72 6f 6d 6f 74 65 28 |X */.X.X|promote(|
|00005430| 70 61 72 65 6e 74 29 0a | 58 09 6e 6f 64 65 20 2a |parent).|X.node *|
|00005440| 70 61 72 65 6e 74 3b 0a | 58 7b 09 6e 6f 64 65 20 |parent;.|X{.node |
|00005450| 2a 70 72 65 76 2c 20 2a | 63 68 69 6c 64 2c 20 2a |*prev, *|child, *|
|00005460| 6e 65 78 74 3b 0a 58 09 | 63 68 61 72 20 62 75 66 |next;.X.|char buf|
|00005470| 5b 42 55 46 53 49 5a 5d | 3b 0a 58 0a 58 09 70 72 |[BUFSIZ]|;.X.X.pr|
|00005480| 65 76 20 3d 20 30 3b 0a | 58 09 66 6f 72 20 28 63 |ev = 0;.|X.for (c|
|00005490| 68 69 6c 64 20 3d 20 70 | 61 72 65 6e 74 2d 3e 63 |hild = p|arent->c|
|000054a0| 68 69 6c 64 3b 20 63 68 | 69 6c 64 3b 20 63 68 69 |hild; ch|ild; chi|
|000054b0| 6c 64 20 3d 20 6e 65 78 | 74 29 20 7b 0a 58 09 09 |ld = nex|t) {.X..|
|000054c0| 6e 65 78 74 20 3d 20 63 | 68 69 6c 64 2d 3e 6e 65 |next = c|hild->ne|
|000054d0| 78 74 3b 0a 58 09 09 69 | 66 20 28 21 49 53 41 44 |xt;.X..i|f (!ISAD|
|000054e0| 4f 4d 41 49 4e 28 63 68 | 69 6c 64 29 29 20 7b 0a |OMAIN(ch|ild)) {.|
|000054f0| 58 09 09 09 70 72 65 76 | 20 3d 20 63 68 69 6c 64 |X...prev| = child|
|00005500| 3b 0a 58 09 09 09 63 6f | 6e 74 69 6e 75 65 3b 0a |;.X...co|ntinue;.|
|00005510| 58 09 09 7d 0a 58 09 09 | 69 66 20 28 28 63 68 69 |X..}.X..|if ((chi|
|00005520| 6c 64 2d 3e 66 6c 61 67 | 20 26 20 43 4f 4c 4c 49 |ld->flag| & COLLI|
|00005530| 53 49 4f 4e 29 20 7c 7c | 20 63 68 69 6c 64 2d 3e |SION) ||| child->|
|00005540| 67 61 74 65 77 61 79 29 | 20 7b 0a 58 09 09 09 2f |gateway)| {.X.../|
|00005550| 2a 0a 58 09 09 09 20 2a | 20 64 75 70 20 64 6f 6d |*.X... *| dup dom|
|00005560| 61 69 6e 20 6e 61 6d 65 | 20 6f 72 20 67 61 74 65 |ain name| or gate|
|00005570| 77 61 79 20 66 6f 75 6e | 64 2e 20 20 64 6f 6e 27 |way foun|d. don'|
|00005580| 74 20 62 75 6d 70 0a 58 | 09 09 09 20 2a 20 70 72 |t bump.X|... * pr|
|00005590| 65 76 3a 20 74 68 69 73 | 20 6e 6f 64 65 20 69 73 |ev: this| node is|
|000055a0| 20 6d 6f 76 69 6e 67 20 | 75 70 20 74 68 65 20 74 | moving |up the t|
|000055b0| 72 65 65 2e 0a 58 09 09 | 09 20 2a 2f 0a 58 0a 58 |ree..X..|. */.X.X|
|000055c0| 09 09 09 2f 2a 20 71 75 | 61 6c 69 66 79 20 63 68 |.../* qu|alify ch|
|000055d0| 69 6c 64 20 64 6f 6d 61 | 69 6e 20 6e 61 6d 65 20 |ild doma|in name |
|000055e0| 2a 2f 0a 58 09 09 09 73 | 70 72 69 6e 74 66 28 62 |*/.X...s|printf(b|
|000055f0| 75 66 2c 20 22 25 73 25 | 73 22 2c 20 63 68 69 6c |uf, "%s%|s", chil|
|00005600| 64 2d 3e 6e 61 6d 65 2c | 20 70 61 72 65 6e 74 2d |d->name,| parent-|
|00005610| 3e 6e 61 6d 65 29 3b 0a | 58 09 09 09 63 66 72 65 |>name);.|X...cfre|
|00005620| 65 28 63 68 69 6c 64 2d | 3e 6e 61 6d 65 29 3b 0a |e(child-|>name);.|
|00005630| 58 09 09 09 63 68 69 6c | 64 2d 3e 6e 61 6d 65 20 |X...chil|d->name |
|00005640| 3d 20 73 74 72 73 61 76 | 65 28 62 75 66 29 3b 0a |= strsav|e(buf);.|
|00005650| 58 0a 58 09 09 09 2f 2a | 20 75 6e 6c 69 6e 6b 20 |X.X.../*| unlink |
|00005660| 63 68 69 6c 64 20 6f 75 | 74 20 6f 66 20 73 69 62 |child ou|t of sib|
|00005670| 6c 69 6e 67 20 63 68 61 | 69 6e 20 2a 2f 0a 58 09 |ling cha|in */.X.|
|00005680| 09 09 69 66 20 28 70 72 | 65 76 29 0a 58 09 09 09 |..if (pr|ev).X...|
|00005690| 09 70 72 65 76 2d 3e 6e | 65 78 74 20 3d 20 63 68 |.prev->n|ext = ch|
|000056a0| 69 6c 64 2d 3e 6e 65 78 | 74 3b 0a 58 09 09 09 65 |ild->nex|t;.X...e|
|000056b0| 6c 73 65 0a 58 09 09 09 | 09 70 61 72 65 6e 74 2d |lse.X...|.parent-|
|000056c0| 3e 63 68 69 6c 64 20 3d | 20 63 68 69 6c 64 2d 3e |>child =| child->|
|000056d0| 6e 65 78 74 3b 0a 58 0a | 58 09 09 09 2f 2a 20 6c |next;.X.|X.../* l|
|000056e0| 69 6e 6b 20 63 68 69 6c | 64 20 69 6e 20 61 73 20 |ink chil|d in as |
|000056f0| 70 65 65 72 20 6f 66 20 | 70 61 72 65 6e 74 20 2a |peer of |parent *|
|00005700| 2f 0a 58 09 09 09 63 68 | 69 6c 64 2d 3e 6e 65 78 |/.X...ch|ild->nex|
|00005710| 74 20 3d 20 70 61 72 65 | 6e 74 2d 3e 6e 65 78 74 |t = pare|nt->next|
|00005720| 3b 0a 58 09 09 09 70 61 | 72 65 6e 74 2d 3e 6e 65 |;.X...pa|rent->ne|
|00005730| 78 74 20 3d 20 63 68 69 | 6c 64 3b 0a 58 09 09 09 |xt = chi|ld;.X...|
|00005740| 63 68 69 6c 64 2d 3e 70 | 61 72 65 6e 74 20 3d 20 |child->p|arent = |
|00005750| 70 61 72 65 6e 74 2d 3e | 70 61 72 65 6e 74 3b 0a |parent->|parent;.|
|00005760| 58 0a 58 09 09 09 2f 2a | 0a 58 09 09 09 20 2a 20 |X.X.../*|.X... * |
|00005770| 72 65 73 65 74 20 63 6f | 6c 6c 69 73 69 6f 6e 20 |reset co|llision |
|00005780| 66 6c 61 67 3b 20 6d 61 | 79 20 70 72 6f 6d 6f 74 |flag; ma|y promot|
|00005790| 65 20 61 67 61 69 6e 20 | 6f 6e 0a 58 09 09 09 20 |e again |on.X... |
|000057a0| 2a 20 72 65 74 75 72 6e | 20 74 6f 20 63 61 6c 6c |* return| to call|
|000057b0| 65 72 2e 0a 58 09 09 09 | 20 2a 2f 0a 58 09 09 09 |er..X...| */.X...|
|000057c0| 63 68 69 6c 64 2d 3e 66 | 6c 61 67 20 26 3d 20 7e |child->f|lag &= ~|
|000057d0| 43 4f 4c 4c 49 53 49 4f | 4e 3b 0a 58 09 09 09 68 |COLLISIO|N;.X...h|
|000057e0| 61 73 68 28 63 68 69 6c | 64 29 3b 0a 58 09 09 7d |ash(chil|d);.X..}|
|000057f0| 20 65 6c 73 65 20 7b 0a | 58 09 09 09 2f 2a 20 74 | else {.|X.../* t|
|00005800| 68 69 73 20 64 6f 6d 61 | 69 6e 20 69 73 20 75 6e |his doma|in is un|
|00005810| 69 6e 74 65 72 65 73 74 | 69 6e 67 20 28 73 6f 20 |interest|ing (so |
|00005820| 62 75 6d 70 20 70 72 65 | 76 29 20 2a 2f 0a 58 09 |bump pre|v) */.X.|
|00005830| 09 09 70 72 6f 6d 6f 74 | 65 28 63 68 69 6c 64 29 |..promot|e(child)|
|00005840| 3b 0a 58 09 09 09 70 72 | 65 76 20 3d 20 63 68 69 |;.X...pr|ev = chi|
|00005850| 6c 64 3b 0a 58 09 09 7d | 0a 58 09 7d 0a 58 09 0a |ld;.X..}|.X.}.X..|
|00005860| 58 7d 0a 58 0a 58 73 65 | 74 75 6e 69 71 66 6c 61 |X}.X.Xse|tuniqfla|
|00005870| 67 28 6e 29 0a 58 09 6e | 6f 64 65 20 2a 6e 3b 0a |g(n).X.n|ode *n;.|
|00005880| 58 7b 09 6e 6f 64 65 20 | 2a 63 68 69 6c 64 2c 20 |X{.node |*child, |
|00005890| 2a 61 6c 69 61 73 3b 0a | 58 0a 58 09 2f 2a 20 6d |*alias;.|X.X./* m|
|000058a0| 61 72 6b 20 74 68 69 73 | 20 6e 6f 64 65 20 69 6e |ark this| node in|
|000058b0| 20 74 68 65 20 68 61 73 | 68 20 74 61 62 6c 65 20 | the has|h table |
|000058c0| 2a 2f 0a 58 09 68 61 73 | 68 28 6e 29 3b 0a 58 09 |*/.X.has|h(n);.X.|
|000058d0| 2f 2a 20 6d 61 72 6b 20 | 74 68 65 20 61 6c 69 61 |/* mark |the alia|
|000058e0| 73 65 73 20 6f 66 20 74 | 68 69 73 20 6e 6f 64 65 |ses of t|his node|
|000058f0| 20 2a 2f 0a 58 09 66 6f | 72 20 28 61 6c 69 61 73 | */.X.fo|r (alias|
|00005900| 20 3d 20 6e 2d 3e 61 6c | 69 61 73 3b 20 61 6c 69 | = n->al|ias; ali|
|00005910| 61 73 3b 20 61 6c 69 61 | 73 20 3d 20 61 6c 69 61 |as; alia|s = alia|
|00005920| 73 2d 3e 6e 65 78 74 29 | 0a 58 09 09 68 61 73 68 |s->next)|.X..hash|
|00005930| 28 61 6c 69 61 73 29 3b | 0a 58 09 2f 2a 20 72 65 |(alias);|.X./* re|
|00005940| 63 75 72 73 69 76 65 6c | 79 20 6d 61 72 6b 20 74 |cursivel|y mark t|
|00005950| 68 69 73 20 6e 6f 64 65 | 27 73 20 63 68 69 6c 64 |his node|'s child|
|00005960| 72 65 6e 20 2a 2f 0a 58 | 09 66 6f 72 20 28 63 68 |ren */.X|.for (ch|
|00005970| 69 6c 64 20 3d 20 6e 2d | 3e 63 68 69 6c 64 3b 20 |ild = n-|>child; |
|00005980| 63 68 69 6c 64 3b 20 63 | 68 69 6c 64 20 3d 20 63 |child; c|hild = c|
|00005990| 68 69 6c 64 2d 3e 6e 65 | 78 74 29 0a 58 09 09 73 |hild->ne|xt).X..s|
|000059a0| 65 74 75 6e 69 71 66 6c | 61 67 28 63 68 69 6c 64 |etuniqfl|ag(child|
|000059b0| 29 3b 0a 58 7d 0a 58 0a | 58 68 61 73 68 28 6e 29 |);.X}.X.|Xhash(n)|
|000059c0| 0a 58 09 6e 6f 64 65 20 | 2a 6e 3b 0a 58 7b 09 6e |.X.node |*n;.X{.n|
|000059d0| 6f 64 65 20 2a 2a 62 75 | 63 6b 65 74 2c 20 2a 62 |ode **bu|cket, *b|
|000059e0| 3b 0a 58 0a 58 09 62 75 | 63 6b 65 74 20 3d 20 26 |;.X.X.bu|cket = &|
|000059f0| 68 74 61 62 6c 65 5b 66 | 6f 6c 64 28 6e 2d 3e 6e |htable[f|old(n->n|
|00005a00| 61 6d 65 29 20 25 20 4e | 48 41 53 48 5d 3b 0a 58 |ame) % N|HASH];.X|
|00005a10| 09 66 6f 72 20 28 62 20 | 3d 20 2a 62 75 63 6b 65 |.for (b |= *bucke|
|00005a20| 74 3b 20 62 3b 20 62 20 | 3d 20 62 2d 3e 62 75 63 |t; b; b |= b->buc|
|00005a30| 6b 65 74 29 20 7b 0a 58 | 09 09 69 66 20 28 73 74 |ket) {.X|..if (st|
|00005a40| 72 63 6d 70 28 6e 2d 3e | 6e 61 6d 65 2c 20 62 2d |rcmp(n->|name, b-|
|00005a50| 3e 6e 61 6d 65 29 20 3d | 3d 20 30 29 20 7b 0a 58 |>name) =|= 0) {.X|
|00005a60| 09 09 09 62 2d 3e 66 6c | 61 67 20 7c 3d 20 43 4f |...b->fl|ag |= CO|
|00005a70| 4c 4c 49 53 49 4f 4e 3b | 0a 58 09 09 09 6e 2d 3e |LLISION;|.X...n->|
|00005a80| 66 6c 61 67 20 7c 3d 20 | 43 4f 4c 4c 49 53 49 4f |flag |= |COLLISIO|
|00005a90| 4e 3b 0a 58 09 09 09 72 | 65 74 75 72 6e 3b 0a 58 |N;.X...r|eturn;.X|
|00005aa0| 09 09 7d 0a 58 09 7d 0a | 58 09 6e 2d 3e 62 75 63 |..}.X.}.|X.n->buc|
|00005ab0| 6b 65 74 20 3d 20 2a 62 | 75 63 6b 65 74 3b 0a 58 |ket = *b|ucket;.X|
|00005ac0| 09 2a 62 75 63 6b 65 74 | 20 3d 20 6e 3b 0a 58 7d |.*bucket| = n;.X}|
|00005ad0| 0a 58 0a 58 2f 2a 20 73 | 74 6f 6c 65 6e 20 66 72 |.X.X/* s|tolen fr|
|00005ae0| 6f 6d 20 70 61 74 68 61 | 6c 69 61 73 3a 61 64 64 |om patha|lias:add|
|00005af0| 6e 6f 64 65 2e 63 2c 20 | 71 2e 76 2e 20 2a 2f 0a |node.c, |q.v. */.|
|00005b00| 58 23 64 65 66 69 6e 65 | 20 50 4f 4c 59 09 30 78 |X#define| POLY.0x|
|00005b10| 34 38 30 30 30 30 30 30 | 09 09 2f 2a 20 33 31 2d |48000000|../* 31-|
|00005b20| 62 69 74 20 70 6f 6c 79 | 6e 6f 6d 69 61 6c 20 2a |bit poly|nomial *|
|00005b30| 2f 0a 58 6c 6f 6e 67 20 | 43 72 63 54 61 62 6c 65 |/.Xlong |CrcTable|
|00005b40| 5b 31 32 38 5d 3b 0a 58 | 0a 58 76 6f 69 64 0a 58 |[128];.X|.Xvoid.X|
|00005b50| 63 72 63 69 6e 69 74 28 | 29 0a 58 7b 09 72 65 67 |crcinit(|).X{.reg|
|00005b60| 69 73 74 65 72 20 69 6e | 74 20 69 2c 6a 3b 0a 58 |ister in|t i,j;.X|
|00005b70| 09 72 65 67 69 73 74 65 | 72 20 6c 6f 6e 67 20 73 |.registe|r long s|
|00005b80| 75 6d 3b 0a 58 0a 58 09 | 66 6f 72 20 28 69 20 3d |um;.X.X.|for (i =|
|00005b90| 20 30 3b 20 69 20 3c 20 | 31 32 38 3b 20 69 2b 2b | 0; i < |128; i++|
|00005ba0| 29 20 7b 0a 58 09 09 73 | 75 6d 20 3d 20 30 3b 0a |) {.X..s|um = 0;.|
|00005bb0| 58 09 09 66 6f 72 20 28 | 6a 20 3d 20 37 2d 31 3b |X..for (|j = 7-1;|
|00005bc0| 20 6a 20 3e 3d 20 30 3b | 20 2d 2d 6a 29 0a 58 09 | j >= 0;| --j).X.|
|00005bd0| 09 09 69 66 20 28 69 20 | 26 20 28 31 20 3c 3c 20 |..if (i |& (1 << |
|00005be0| 6a 29 29 0a 58 09 09 09 | 09 73 75 6d 20 5e 3d 20 |j)).X...|.sum ^= |
|00005bf0| 50 4f 4c 59 20 3e 3e 20 | 6a 3b 0a 58 09 09 43 72 |POLY >> |j;.X..Cr|
|00005c00| 63 54 61 62 6c 65 5b 69 | 5d 20 3d 20 73 75 6d 3b |cTable[i|] = sum;|
|00005c10| 0a 58 09 7d 0a 58 7d 0a | 58 0a 58 6c 6f 6e 67 0a |.X.}.X}.|X.Xlong.|
|00005c20| 58 66 6f 6c 64 28 73 29 | 0a 58 09 72 65 67 69 73 |Xfold(s)|.X.regis|
|00005c30| 74 65 72 20 63 68 61 72 | 20 2a 73 3b 0a 58 7b 09 |ter char| *s;.X{.|
|00005c40| 72 65 67 69 73 74 65 72 | 20 6c 6f 6e 67 20 73 75 |register| long su|
|00005c50| 6d 20 3d 20 30 3b 0a 58 | 09 72 65 67 69 73 74 65 |m = 0;.X|.registe|
|00005c60| 72 20 69 6e 74 20 63 3b | 0a 58 0a 58 09 77 68 69 |r int c;|.X.X.whi|
|00005c70| 6c 65 20 28 63 20 3d 20 | 2a 73 2b 2b 29 0a 58 09 |le (c = |*s++).X.|
|00005c80| 09 73 75 6d 20 3d 20 28 | 73 75 6d 20 3e 3e 20 37 |.sum = (|sum >> 7|
|00005c90| 29 20 5e 20 43 72 63 54 | 61 62 6c 65 5b 28 73 75 |) ^ CrcT|able[(su|
|00005ca0| 6d 20 5e 20 63 29 20 26 | 20 30 78 37 66 5d 3b 0a |m ^ c) &| 0x7f];.|
|00005cb0| 58 09 72 65 74 75 72 6e | 20 73 75 6d 3b 0a 58 7d |X.return| sum;.X}|
|00005cc0| 0a 45 4e 44 5f 4f 46 5f | 61 72 70 61 74 78 74 2e |.END_OF_|arpatxt.|
|00005cd0| 63 0a 69 66 20 74 65 73 | 74 20 31 32 33 31 37 20 |c.if tes|t 12317 |
|00005ce0| 2d 6e 65 20 60 77 63 20 | 2d 63 20 3c 61 72 70 61 |-ne `wc |-c <arpa|
|00005cf0| 74 78 74 2e 63 60 3b 20 | 74 68 65 6e 0a 20 20 20 |txt.c`; |then. |
|00005d00| 20 65 63 68 6f 20 73 68 | 61 72 3a 20 5c 22 61 72 | echo sh|ar: \"ar|
|00005d10| 70 61 74 78 74 2e 63 5c | 22 20 75 6e 70 61 63 6b |patxt.c\|" unpack|
|00005d20| 65 64 20 77 69 74 68 20 | 77 72 6f 6e 67 20 73 69 |ed with |wrong si|
|00005d30| 7a 65 21 0a 66 69 0a 23 | 20 65 6e 64 20 6f 66 20 |ze!.fi.#| end of |
|00005d40| 6f 76 65 72 77 72 69 74 | 69 6e 67 20 63 68 65 63 |overwrit|ing chec|
|00005d50| 6b 0a 66 69 0a 69 66 20 | 74 65 73 74 20 2d 66 20 |k.fi.if |test -f |
|00005d60| 6d 61 70 69 74 2e 63 20 | 2d 61 20 22 24 7b 31 7d |mapit.c |-a "${1}|
|00005d70| 22 20 21 3d 20 22 2d 63 | 22 20 3b 20 74 68 65 6e |" != "-c|" ; then|
|00005d80| 20 0a 20 20 65 63 68 6f | 20 73 68 61 72 3a 20 57 | . echo| shar: W|
|00005d90| 69 6c 6c 20 6e 6f 74 20 | 6f 76 65 72 2d 77 72 69 |ill not |over-wri|
|00005da0| 74 65 20 65 78 69 73 74 | 69 6e 67 20 66 69 6c 65 |te exist|ing file|
|00005db0| 20 5c 22 6d 61 70 69 74 | 2e 63 5c 22 0a 65 6c 73 | \"mapit|.c\".els|
|00005dc0| 65 0a 65 63 68 6f 20 73 | 68 61 72 3a 20 45 78 74 |e.echo s|har: Ext|
|00005dd0| 72 61 63 74 69 6e 67 20 | 5c 22 6d 61 70 69 74 2e |racting |\"mapit.|
|00005de0| 63 5c 22 20 5c 28 31 33 | 38 36 31 20 63 68 61 72 |c\" \(13|861 char|
|00005df0| 61 63 74 65 72 73 5c 29 | 0a 73 65 64 20 22 73 2f |acters\)|.sed "s/|
|00005e00| 5e 58 2f 2f 22 20 3e 6d | 61 70 69 74 2e 63 20 3c |^X//" >m|apit.c <|
|00005e10| 3c 27 45 4e 44 5f 4f 46 | 5f 6d 61 70 69 74 2e 63 |<'END_OF|_mapit.c|
|00005e20| 27 0a 58 2f 2a 20 70 61 | 74 68 61 6c 69 61 73 20 |'.X/* pa|thalias |
|00005e30| 2d 2d 20 62 79 20 73 74 | 65 76 65 20 62 65 6c 6c |-- by st|eve bell|
|00005e40| 6f 76 69 6e 2c 20 61 73 | 20 74 6f 6c 64 20 74 6f |ovin, as| told to|
|00005e50| 20 70 65 74 65 72 20 68 | 6f 6e 65 79 6d 61 6e 20 | peter h|oneyman |
|00005e60| 2a 2f 0a 58 23 69 66 6e | 64 65 66 20 6c 69 6e 74 |*/.X#ifn|def lint|
|00005e70| 0a 58 73 74 61 74 69 63 | 20 63 68 61 72 09 2a 73 |.Xstatic| char.*s|
|00005e80| 63 63 73 69 64 20 3d 20 | 22 40 28 23 29 6d 61 70 |ccsid = |"@(#)map|
|00005e90| 69 74 2e 63 09 39 2e 31 | 20 38 37 2f 31 30 2f 30 |it.c.9.1| 87/10/0|
|00005ea0| 34 22 3b 0a 58 23 65 6e | 64 69 66 0a 58 0a 58 23 |4";.X#en|dif.X.X#|
|00005eb0| 69 6e 63 6c 75 64 65 20 | 22 64 65 66 2e 68 22 0a |include |"def.h".|
|00005ec0| 58 0a 58 23 64 65 66 69 | 6e 65 20 63 68 6b 68 65 |X.X#defi|ne chkhe|
|00005ed0| 61 70 28 69 29 09 2f 2a | 20 76 6f 69 64 20 2a 2f |ap(i)./*| void */|
|00005ee0| 0a 58 0a 58 2f 2a 20 65 | 78 70 6f 72 74 73 20 2a |.X.X/* e|xports *|
|00005ef0| 2f 0a 58 2f 2a 20 69 6e | 76 61 72 69 61 6e 74 20 |/.X/* in|variant |
|00005f00| 77 68 69 6c 65 20 6d 61 | 70 70 69 6e 67 3a 20 4e |while ma|pping: N|
|00005f10| 68 65 61 70 20 3c 20 48 | 61 73 68 70 61 72 74 20 |heap < H|ashpart |
|00005f20| 2a 2f 0a 58 6c 6f 6e 67 | 20 48 61 73 68 70 61 72 |*/.Xlong| Hashpar|
|00005f30| 74 3b 09 09 2f 2a 20 73 | 74 61 72 74 20 6f 66 20 |t;../* s|tart of |
|00005f40| 75 6e 72 65 61 63 68 65 | 64 20 6e 6f 64 65 73 20 |unreache|d nodes |
|00005f50| 2a 2f 0a 58 6c 6f 6e 67 | 20 4e 68 65 61 70 3b 09 |*/.Xlong| Nheap;.|
|00005f60| 09 2f 2a 20 65 6e 64 20 | 6f 66 20 68 65 61 70 20 |./* end |of heap |
|00005f70| 2a 2f 0a 58 0a 58 76 6f | 69 64 20 6d 61 70 69 74 |*/.X.Xvo|id mapit|
|00005f80| 28 29 3b 0a 58 0a 58 2f | 2a 20 69 6d 70 6f 72 74 |();.X.X/|* import|
|00005f90| 73 20 2a 2f 0a 58 65 78 | 74 65 72 6e 20 6c 6f 6e |s */.Xex|tern lon|
|00005fa0| 67 20 4e 68 65 61 70 2c | 20 48 61 73 68 70 61 72 |g Nheap,| Hashpar|
|00005fb0| 74 2c 20 54 61 62 73 69 | 7a 65 3b 0a 58 65 78 74 |t, Tabsi|ze;.Xext|
|00005fc0| 65 72 6e 20 69 6e 74 20 | 54 66 6c 61 67 2c 20 56 |ern int |Tflag, V|
|00005fd0| 66 6c 61 67 3b 0a 58 65 | 78 74 65 72 6e 20 6e 6f |flag;.Xe|xtern no|
|00005fe0| 64 65 20 2a 2a 54 61 62 | 6c 65 2c 20 2a 48 6f 6d |de **Tab|le, *Hom|
|00005ff0| 65 3b 0a 58 65 78 74 65 | 72 6e 20 63 68 61 72 20 |e;.Xexte|rn char |
|00006000| 2a 4c 69 6e 6b 6f 75 74 | 2c 20 2a 47 72 61 70 68 |*Linkout|, *Graph|
|00006010| 6f 75 74 3b 0a 58 0a 58 | 65 78 74 65 72 6e 20 76 |out;.X.X|extern v|
|00006020| 6f 69 64 20 66 72 65 65 | 6c 69 6e 6b 28 29 2c 20 |oid free|link(), |
|00006030| 72 65 73 65 74 6e 6f 64 | 65 73 28 29 2c 20 70 72 |resetnod|es(), pr|
|00006040| 69 6e 74 69 74 28 29 2c | 20 64 75 6d 70 67 72 61 |intit(),| dumpgra|
|00006050| 70 68 28 29 3b 0a 58 65 | 78 74 65 72 6e 20 76 6f |ph();.Xe|xtern vo|
|00006060| 69 64 20 73 68 6f 77 6c | 69 6e 6b 73 28 29 2c 20 |id showl|inks(), |
|00006070| 64 69 65 28 29 3b 0a 58 | 65 78 74 65 72 6e 20 6c |die();.X|extern l|
|00006080| 6f 6e 67 20 70 61 63 6b | 28 29 2c 20 61 6c 6c 6f |ong pack|(), allo|
|00006090| 63 61 74 69 6f 6e 28 29 | 3b 0a 58 65 78 74 65 72 |cation()|;.Xexter|
|000060a0| 6e 20 6c 69 6e 6b 20 2a | 6e 65 77 6c 69 6e 6b 28 |n link *|newlink(|
|000060b0| 29 2c 20 2a 61 64 64 6c | 69 6e 6b 28 29 3b 0a 58 |), *addl|ink();.X|
|000060c0| 65 78 74 65 72 6e 20 69 | 6e 74 20 6d 61 70 74 72 |extern i|nt maptr|
|000060d0| 61 63 65 28 29 3b 0a 58 | 65 78 74 65 72 6e 20 6e |ace();.X|extern n|
|000060e0| 6f 64 65 20 2a 6e 63 6f | 70 79 28 29 3b 0a 58 0a |ode *nco|py();.X.|
|000060f0| 58 0a 58 2f 2a 20 70 72 | 69 76 61 74 65 73 20 2a |X.X/* pr|ivates *|
|00006100| 2f 0a 58 73 74 61 74 69 | 63 20 6c 6f 6e 67 09 48 |/.Xstati|c long.H|
|00006110| 65 61 70 68 69 67 68 77 | 61 74 65 72 3b 0a 58 73 |eaphighw|ater;.Xs|
|00006120| 74 61 74 69 63 20 6c 69 | 6e 6b 09 2a 2a 48 65 61 |tatic li|nk.**Hea|
|00006130| 70 3b 0a 58 0a 58 53 54 | 41 54 49 43 20 76 6f 69 |p;.X.XST|ATIC voi|
|00006140| 64 20 69 6e 73 65 72 74 | 28 29 2c 20 68 65 61 70 |d insert|(), heap|
|00006150| 75 70 28 29 2c 20 68 65 | 61 70 64 6f 77 6e 28 29 |up(), he|apdown()|
|00006160| 2c 20 68 65 61 70 73 77 | 61 70 28 29 2c 20 62 61 |, heapsw|ap(), ba|
|00006170| 63 6b 6c 69 6e 6b 73 28 | 29 3b 0a 58 53 54 41 54 |cklinks(|);.XSTAT|
|00006180| 49 43 20 76 6f 69 64 20 | 73 65 74 68 65 61 70 62 |IC void |setheapb|
|00006190| 69 74 73 28 29 2c 20 6d | 74 72 61 63 65 72 65 70 |its(), m|tracerep|
|000061a0| 6f 72 74 28 29 2c 20 68 | 65 61 70 63 68 69 6c 64 |ort(), h|eapchild|
|000061b0| 72 65 6e 28 29 3b 0a 58 | 53 54 41 54 49 43 20 6c |ren();.X|STATIC l|
|000061c0| 69 6e 6b 20 2a 6d 69 6e | 5f 6e 6f 64 65 28 29 3b |ink *min|_node();|
|000061d0| 0a 58 53 54 41 54 49 43 | 20 69 6e 74 20 64 65 68 |.XSTATIC| int deh|
|000061e0| 61 73 68 28 29 2c 20 73 | 6b 69 70 6c 69 6e 6b 28 |ash(), s|kiplink(|
|000061f0| 29 2c 20 73 6b 69 70 74 | 65 72 6d 69 6e 61 6c 61 |), skipt|erminala|
|00006200| 6c 69 61 73 28 29 3b 0a | 58 53 54 41 54 49 43 20 |lias();.|XSTATIC |
|00006210| 43 6f 73 74 20 63 6f 73 | 74 6f 66 28 29 3b 0a 58 |Cost cos|tof();.X|
|00006220| 0a 58 2f 2a 20 74 72 61 | 6e 73 66 6f 72 6d 20 74 |.X/* tra|nsform t|
|00006230| 68 65 20 67 72 61 70 68 | 20 74 6f 20 61 20 73 68 |he graph| to a sh|
|00006240| 6f 72 74 65 73 74 2d 70 | 61 74 68 20 74 72 65 65 |ortest-p|ath tree|
|00006250| 20 62 79 20 6d 61 72 6b | 69 6e 67 20 74 72 65 65 | by mark|ing tree|
|00006260| 20 65 64 67 65 73 20 2a | 2f 0a 58 76 6f 69 64 0a | edges *|/.Xvoid.|
|00006270| 58 6d 61 70 69 74 28 29 | 0a 58 7b 09 72 65 67 69 |Xmapit()|.X{.regi|
|00006280| 73 74 65 72 20 6e 6f 64 | 65 20 2a 6e 3b 0a 58 09 |ster nod|e *n;.X.|
|00006290| 72 65 67 69 73 74 65 72 | 20 6c 69 6e 6b 20 2a 6c |register| link *l|
|000062a0| 3b 0a 58 09 6c 69 6e 6b | 20 2a 6c 70 61 72 65 6e |;.X.link| *lparen|
|000062b0| 74 3b 0a 58 09 73 74 61 | 74 69 63 20 69 6e 74 20 |t;.X.sta|tic int |
|000062c0| 66 69 72 73 74 74 69 6d | 65 20 3d 20 30 3b 0a 58 |firsttim|e = 0;.X|
|000062d0| 0a 58 09 76 70 72 69 6e | 74 66 28 73 74 64 65 72 |.X.vprin|tf(stder|
|000062e0| 72 2c 20 22 2a 2a 2a 20 | 6d 61 70 70 69 6e 67 5c |r, "*** |mapping\|
|000062f0| 6e 22 29 3b 0a 58 09 54 | 66 6c 61 67 20 3d 20 54 |n");.X.T|flag = T|
|00006300| 66 6c 61 67 20 26 26 20 | 56 66 6c 61 67 3b 09 09 |flag && |Vflag;..|
|00006310| 2f 2a 20 74 72 61 63 69 | 6e 67 20 68 65 72 65 20 |/* traci|ng here |
|00006320| 6f 6e 6c 79 20 69 66 20 | 76 65 72 62 6f 73 65 20 |only if |verbose |
|00006330| 2a 2f 0a 58 09 2f 2a 20 | 72 65 2d 75 73 65 20 74 |*/.X./* |re-use t|
|00006340| 68 65 20 68 61 73 68 20 | 74 61 62 6c 65 20 73 70 |he hash |table sp|
|00006350| 61 63 65 20 66 6f 72 20 | 74 68 65 20 68 65 61 70 |ace for |the heap|
|00006360| 20 2a 2f 0a 58 09 48 65 | 61 70 20 3d 20 28 6c 69 | */.X.He|ap = (li|
|00006370| 6e 6b 20 2a 2a 29 20 54 | 61 62 6c 65 3b 0a 58 09 |nk **) T|able;.X.|
|00006380| 48 61 73 68 70 61 72 74 | 20 3d 20 70 61 63 6b 28 |Hashpart| = pack(|
|00006390| 30 4c 2c 20 54 61 62 73 | 69 7a 65 20 2d 20 31 29 |0L, Tabs|ize - 1)|
|000063a0| 3b 0a 58 0a 58 09 2f 2a | 20 65 78 70 75 6e 67 65 |;.X.X./*| expunge|
|000063b0| 20 70 65 6e 61 6c 74 69 | 65 73 20 66 72 6f 6d 20 | penalti|es from |
|000063c0| 2d 61 20 6f 70 74 69 6f | 6e 20 61 6e 64 20 6d 61 |-a optio|n and ma|
|000063d0| 6b 65 20 63 69 72 63 75 | 6c 61 72 20 63 6f 70 79 |ke circu|lar copy|
|000063e0| 20 6c 69 73 74 73 20 2a | 2f 0a 58 09 72 65 73 65 | lists *|/.X.rese|
|000063f0| 74 6e 6f 64 65 73 28 29 | 3b 0a 58 0a 58 09 69 66 |tnodes()|;.X.X.if|
+--------+-------------------------+-------------------------+--------+--------+
Only 25.0 KB of data is shown above.