home *** CD-ROM | disk | FTP | other *** search
/ Usenet 1994 January / usenetsourcesnewsgroupsinfomagicjanuary1994.iso / sources / unix / volume3 / pathalias2 / part1 < prev    next >
SHell self-extracting ARchive  |  1986-11-30  |  24.4 KB

open in: MacOS 8.1     |     Win98     |     DOS

browse contents    |     view JSON data     |     view as text


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

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



hex view
+--------+-------------------------+-------------------------+--------+--------+
|00000000| 53 75 62 6a 65 63 74 3a | 20 4e 65 77 20 70 61 74 |Subject:| New pat|
|00000010| 68 61 6c 69 61 73 2c 20 | 70 61 72 74 20 31 20 6f |halias, |part 1 o|
|00000020| 66 20 32 0a 4e 65 77 73 | 67 72 6f 75 70 73 3a 20 |f 2.News|groups: |
|00000030| 6d 6f 64 2e 73 6f 75 72 | 63 65 73 0a 41 70 70 72 |mod.sour|ces.Appr|
|00000040| 6f 76 65 64 3a 20 6a 70 | 6e 40 70 61 6e 64 61 2e |oved: jp|n@panda.|
|00000050| 55 55 43 50 0a 0a 4d 6f | 64 2e 73 6f 75 72 63 65 |UUCP..Mo|d.source|
|00000060| 73 3a 20 20 56 6f 6c 75 | 6d 65 20 33 2c 20 49 73 |s: Volu|me 3, Is|
|00000070| 73 75 65 20 39 32 0a 53 | 75 62 6d 69 74 74 65 64 |sue 92.S|ubmitted|
|00000080| 20 62 79 3a 20 70 72 69 | 6e 63 65 74 6f 6e 21 64 | by: pri|nceton!d|
|00000090| 6f 77 6e 21 68 6f 6e 65 | 79 20 28 50 65 74 65 72 |own!hone|y (Peter|
|000000a0| 20 48 6f 6e 65 79 6d 61 | 6e 29 0a 0a 23 21 20 2f | Honeyma|n)..#! /|
|000000b0| 62 69 6e 2f 73 68 0a 23 | 20 54 68 69 73 20 69 73 |bin/sh.#| This is|
|000000c0| 20 61 20 73 68 65 6c 6c | 20 61 72 63 68 69 76 65 | a shell| archive|
|000000d0| 2c 20 6d 65 61 6e 69 6e | 67 3a 0a 23 20 31 2e 20 |, meanin|g:.# 1. |
|000000e0| 52 65 6d 6f 76 65 20 65 | 76 65 72 79 74 68 69 6e |Remove e|verythin|
|000000f0| 67 20 61 62 6f 76 65 20 | 74 68 65 20 23 21 20 2f |g above |the #! /|
|00000100| 62 69 6e 2f 73 68 20 6c | 69 6e 65 2e 0a 23 20 32 |bin/sh l|ine..# 2|
|00000110| 2e 20 53 61 76 65 20 74 | 68 65 20 72 65 73 75 6c |. Save t|he resul|
|00000120| 74 69 6e 67 20 74 65 78 | 74 20 69 6e 20 61 20 66 |ting tex|t in a f|
|00000130| 69 6c 65 2e 0a 23 20 33 | 2e 20 45 78 65 63 75 74 |ile..# 3|. Execut|
|00000140| 65 20 74 68 65 20 66 69 | 6c 65 20 77 69 74 68 20 |e the fi|le with |
|00000150| 2f 62 69 6e 2f 73 68 20 | 28 6e 6f 74 20 63 73 68 |/bin/sh |(not csh|
|00000160| 29 20 74 6f 20 63 72 65 | 61 74 65 20 74 68 65 20 |) to cre|ate the |
|00000170| 66 69 6c 65 73 3a 0a 23 | 09 52 45 41 44 4d 45 0a |files:.#|.README.|
|00000180| 23 09 43 48 41 4e 47 45 | 53 0a 23 09 4d 61 6b 65 |#.CHANGE|S.#.Make|
|00000190| 66 69 6c 65 0a 23 09 63 | 6f 6e 66 69 67 2e 68 0a |file.#.c|onfig.h.|
|000001a0| 23 09 64 65 66 2e 68 0a | 23 09 6d 61 6b 65 2e 76 |#.def.h.|#.make.v|
|000001b0| 38 0a 23 09 70 61 74 68 | 61 6c 69 61 73 2e 31 0a |8.#.path|alias.1.|
|000001c0| 23 20 54 68 69 73 20 61 | 72 63 68 69 76 65 20 63 |# This a|rchive c|
|000001d0| 72 65 61 74 65 64 3a 20 | 57 65 64 20 4a 61 6e 20 |reated: |Wed Jan |
|000001e0| 32 32 20 31 39 3a 32 31 | 3a 35 35 20 31 39 38 36 |22 19:21|:55 1986|
|000001f0| 0a 65 78 70 6f 72 74 20 | 50 41 54 48 3b 20 50 41 |.export |PATH; PA|
|00000200| 54 48 3d 2f 62 69 6e 3a | 24 50 41 54 48 0a 65 63 |TH=/bin:|$PATH.ec|
|00000210| 68 6f 20 73 68 61 72 3a | 20 65 78 74 72 61 63 74 |ho shar:| extract|
|00000220| 69 6e 67 20 22 27 52 45 | 41 44 4d 45 27 22 20 27 |ing "'RE|ADME'" '|
|00000230| 28 38 39 39 20 63 68 61 | 72 61 63 74 65 72 73 29 |(899 cha|racters)|
|00000240| 27 0a 69 66 20 74 65 73 | 74 20 2d 66 20 27 52 45 |'.if tes|t -f 'RE|
|00000250| 41 44 4d 45 27 0a 74 68 | 65 6e 0a 09 65 63 68 6f |ADME'.th|en..echo|
|00000260| 20 73 68 61 72 3a 20 77 | 69 6c 6c 20 6e 6f 74 20 | shar: w|ill not |
|00000270| 6f 76 65 72 2d 77 72 69 | 74 65 20 65 78 69 73 74 |over-wri|te exist|
|00000280| 69 6e 67 20 66 69 6c 65 | 20 22 27 52 45 41 44 4d |ing file| "'READM|
|00000290| 45 27 22 0a 65 6c 73 65 | 0a 73 65 64 20 27 73 2f |E'".else|.sed 's/|
|000002a0| 5e 58 2f 2f 27 20 3c 3c | 20 5c 53 48 41 52 5f 45 |^X//' <<| \SHAR_E|
|000002b0| 4f 46 20 3e 20 27 52 45 | 41 44 4d 45 27 0a 58 46 |OF > 'RE|ADME'.XF|
|000002c0| 72 6f 6d 20 70 72 69 6e | 63 65 74 6f 6e 21 68 6f |rom prin|ceton!ho|
|000002d0| 6e 65 79 20 53 75 6e 20 | 4a 61 6e 20 31 39 20 31 |ney Sun |Jan 19 1|
|000002e0| 38 3a 33 35 3a 35 38 20 | 45 53 54 20 31 39 38 36 |8:35:58 |EST 1986|
|000002f0| 0a 54 6f 3a 20 77 68 6f | 6d 20 69 74 20 6d 61 79 |.To: who|m it may|
|00000300| 20 63 6f 6e 63 65 72 6e | 0a 53 75 62 6a 65 63 74 | concern|.Subject|
|00000310| 3a 20 70 61 74 68 61 6c | 69 61 73 20 69 6e 73 74 |: pathal|ias inst|
|00000320| 72 75 63 74 69 6f 6e 73 | 0a 0a 65 64 69 74 20 63 |ructions|..edit c|
|00000330| 6f 6e 66 69 67 2e 68 0a | 6d 61 6b 65 0a 0a 69 66 |onfig.h.|make..if|
|00000340| 20 67 65 74 6f 70 74 20 | 69 73 20 75 6e 64 65 66 | getopt |is undef|
|00000350| 69 6e 65 64 2c 20 6f 62 | 74 61 69 6e 20 61 20 63 |ined, ob|tain a c|
|00000360| 6f 70 79 20 66 72 6f 6d | 20 6d 6f 64 2e 73 6f 75 |opy from| mod.sou|
|00000370| 72 63 65 73 2e 20 20 70 | 61 74 68 61 6c 69 61 73 |rces. p|athalias|
|00000380| 20 69 6e 70 75 74 0a 69 | 73 20 72 65 67 75 6c 61 | input.i|s regula|
|00000390| 72 6c 79 20 70 75 62 6c | 69 73 68 65 64 20 69 6e |rly publ|ished in|
|000003a0| 20 6d 6f 64 2e 6d 61 70 | 2e 0a 0a 09 70 65 74 65 | mod.map|....pete|
|000003b0| 72 0a 0a 70 73 3a 0a 0a | 70 61 74 68 61 6c 69 61 |r..ps:..|pathalia|
|000003c0| 73 2c 20 77 72 69 74 74 | 65 6e 20 62 79 20 73 74 |s, writt|en by st|
|000003d0| 65 76 65 20 62 65 6c 6c | 6f 76 69 6e 20 61 6e 64 |eve bell|ovin and|
|000003e0| 20 70 65 74 65 72 20 68 | 6f 6e 65 79 6d 61 6e 2c | peter h|oneyman,|
|000003f0| 20 69 73 20 69 6e 20 74 | 68 65 20 70 75 62 6c 69 | is in t|he publi|
|00000400| 63 0a 64 6f 6d 61 69 6e | 2c 20 61 6e 64 20 6d 61 |c.domain|, and ma|
|00000410| 79 20 62 65 20 75 73 65 | 64 20 62 79 20 61 6e 79 |y be use|d by any|
|00000420| 20 70 65 72 73 6f 6e 20 | 6f 72 20 6f 72 67 61 6e | person |or organ|
|00000430| 69 7a 61 74 69 6f 6e 2c | 20 69 6e 20 61 6e 79 20 |ization,| in any |
|00000440| 77 61 79 20 61 6e 64 20 | 66 6f 72 0a 61 6e 79 20 |way and |for.any |
|00000450| 70 75 72 70 6f 73 65 2e | 0a 0a 70 70 73 3a 0a 0a |purpose.|..pps:..|
|00000460| 54 68 65 72 65 20 69 73 | 20 6e 6f 20 77 61 72 72 |There is| no warr|
|00000470| 61 6e 74 79 20 6f 66 20 | 6d 65 72 63 68 61 6e 74 |anty of |merchant|
|00000480| 61 62 69 6c 69 74 79 20 | 6e 6f 72 20 61 6e 79 20 |ability |nor any |
|00000490| 77 61 72 72 61 6e 74 79 | 20 6f 66 20 66 69 74 6e |warranty| of fitn|
|000004a0| 65 73 73 20 66 6f 72 0a | 61 20 70 61 72 74 69 63 |ess for.|a partic|
|000004b0| 75 6c 61 72 20 70 75 72 | 70 6f 73 65 20 6e 6f 72 |ular pur|pose nor|
|000004c0| 20 61 6e 79 20 6f 74 68 | 65 72 20 77 61 72 72 61 | any oth|er warra|
|000004d0| 6e 74 79 2c 20 65 69 74 | 68 65 72 20 65 78 70 72 |nty, eit|her expr|
|000004e0| 65 73 73 20 6f 72 20 69 | 6d 70 6c 69 65 64 2c 0a |ess or i|mplied,.|
|000004f0| 61 73 20 74 6f 20 74 68 | 65 20 61 63 63 75 72 61 |as to th|e accura|
|00000500| 63 79 20 6f 66 20 74 68 | 65 20 65 6e 63 6c 6f 73 |cy of th|e enclos|
|00000510| 65 64 20 6d 61 74 65 72 | 69 61 6c 73 20 6f 72 20 |ed mater|ials or |
|00000520| 61 73 20 74 6f 20 74 68 | 65 69 72 20 73 75 69 74 |as to th|eir suit|
|00000530| 61 62 69 6c 69 74 79 0a | 66 6f 72 20 61 6e 79 20 |ability.|for any |
|00000540| 70 61 72 74 69 63 75 6c | 61 72 20 70 75 72 70 6f |particul|ar purpo|
|00000550| 73 65 2e 20 20 41 63 63 | 6f 72 64 69 6e 67 6c 79 |se. Acc|ordingly|
|00000560| 2c 20 74 68 65 20 61 75 | 74 68 6f 72 73 20 61 73 |, the au|thors as|
|00000570| 73 75 6d 65 20 6e 6f 20 | 72 65 73 70 6f 6e 2d 0a |sume no |respon-.|
|00000580| 73 69 62 69 6c 69 74 79 | 20 66 6f 72 20 74 68 65 |sibility| for the|
|00000590| 69 72 20 75 73 65 20 62 | 79 20 74 68 65 20 72 65 |ir use b|y the re|
|000005a0| 63 69 70 69 65 6e 74 2e | 20 20 20 46 75 72 74 68 |cipient.| Furth|
|000005b0| 65 72 2c 20 74 68 65 20 | 61 75 74 68 6f 72 73 20 |er, the |authors |
|000005c0| 61 73 73 75 6d 65 0a 6e | 6f 20 6f 62 6c 69 67 61 |assume.n|o obliga|
|000005d0| 74 69 6f 6e 20 74 6f 20 | 66 75 72 6e 69 73 68 20 |tion to |furnish |
|000005e0| 61 6e 79 20 61 73 73 69 | 73 74 61 6e 63 65 20 6f |any assi|stance o|
|000005f0| 66 20 61 6e 79 20 6b 69 | 6e 64 20 77 68 61 74 73 |f any ki|nd whats|
|00000600| 6f 65 76 65 72 2c 20 6f | 72 20 74 6f 0a 66 75 72 |oever, o|r to.fur|
|00000610| 6e 69 73 68 20 61 6e 79 | 20 61 64 64 69 74 69 6f |nish any| additio|
|00000620| 6e 61 6c 20 69 6e 66 6f | 72 6d 61 74 69 6f 6e 20 |nal info|rmation |
|00000630| 6f 72 20 64 6f 63 75 6d | 65 6e 74 61 74 69 6f 6e |or docum|entation|
|00000640| 2e 0a 53 48 41 52 5f 45 | 4f 46 0a 69 66 20 74 65 |..SHAR_E|OF.if te|
|00000650| 73 74 20 38 39 39 20 2d | 6e 65 20 22 60 77 63 20 |st 899 -|ne "`wc |
|00000660| 2d 63 20 3c 20 27 52 45 | 41 44 4d 45 27 60 22 0a |-c < 'RE|ADME'`".|
|00000670| 74 68 65 6e 0a 09 65 63 | 68 6f 20 73 68 61 72 3a |then..ec|ho shar:|
|00000680| 20 65 72 72 6f 72 20 74 | 72 61 6e 73 6d 69 74 74 | error t|ransmitt|
|00000690| 69 6e 67 20 22 27 52 45 | 41 44 4d 45 27 22 20 27 |ing "'RE|ADME'" '|
|000006a0| 28 73 68 6f 75 6c 64 20 | 68 61 76 65 20 62 65 65 |(should |have bee|
|000006b0| 6e 20 38 39 39 20 63 68 | 61 72 61 63 74 65 72 73 |n 899 ch|aracters|
|000006c0| 29 27 0a 66 69 0a 66 69 | 0a 65 63 68 6f 20 73 68 |)'.fi.fi|.echo sh|
|000006d0| 61 72 3a 20 65 78 74 72 | 61 63 74 69 6e 67 20 22 |ar: extr|acting "|
|000006e0| 27 43 48 41 4e 47 45 53 | 27 22 20 27 28 36 39 31 |'CHANGES|'" '(691|
|000006f0| 20 63 68 61 72 61 63 74 | 65 72 73 29 27 0a 69 66 | charact|ers)'.if|
|00000700| 20 74 65 73 74 20 2d 66 | 20 27 43 48 41 4e 47 45 | test -f| 'CHANGE|
|00000710| 53 27 0a 74 68 65 6e 0a | 09 65 63 68 6f 20 73 68 |S'.then.|.echo sh|
|00000720| 61 72 3a 20 77 69 6c 6c | 20 6e 6f 74 20 6f 76 65 |ar: will| not ove|
|00000730| 72 2d 77 72 69 74 65 20 | 65 78 69 73 74 69 6e 67 |r-write |existing|
|00000740| 20 66 69 6c 65 20 22 27 | 43 48 41 4e 47 45 53 27 | file "'|CHANGES'|
|00000750| 22 0a 65 6c 73 65 0a 63 | 61 74 20 3c 3c 20 5c 53 |".else.c|at << \S|
|00000760| 48 41 52 5f 45 4f 46 20 | 3e 20 27 43 48 41 4e 47 |HAR_EOF |> 'CHANG|
|00000770| 45 53 27 0a 2d 2d 20 6d | 6f 64 2e 73 6f 75 72 63 |ES'.-- m|od.sourc|
|00000780| 65 73 2c 20 34 2e 33 62 | 73 64 2c 20 31 2f 38 36 |es, 4.3b|sd, 1/86|
|00000790| 0a 49 6d 70 72 6f 76 65 | 64 20 61 6c 69 61 73 20 |.Improve|d alias |
|000007a0| 74 72 65 61 74 6d 65 6e | 74 2e 0a 52 6f 75 74 65 |treatmen|t..Route|
|000007b0| 73 20 74 6f 20 64 6f 6d | 61 69 6e 20 67 61 74 65 |s to dom|ain gate|
|000007c0| 77 61 79 73 2e 0a 4e 65 | 77 20 64 6f 6d 61 69 6e |ways..Ne|w domain|
|000007d0| 20 74 72 65 61 74 6d 65 | 6e 74 20 2d 2d 20 6c 65 | treatme|nt -- le|
|000007e0| 61 64 69 6e 67 20 64 6f | 74 20 69 6e 20 6e 61 6d |ading do|t in nam|
|000007f0| 65 20 69 6d 70 6c 69 65 | 73 20 64 6f 6d 61 69 6e |e implie|s domain|
|00000800| 2e 0a 50 72 69 6e 74 20 | 66 75 6c 6c 79 20 71 75 |..Print |fully qu|
|00000810| 61 6c 69 66 69 65 64 20 | 64 6f 6d 61 69 6e 20 6e |alified |domain n|
|00000820| 61 6d 65 20 66 6f 72 20 | 70 72 69 76 61 74 65 20 |ame for |private |
|00000830| 68 6f 73 74 73 2e 0a 4c | 69 6e 6b 2f 68 6f 73 74 |hosts..L|ink/host|
|00000840| 20 74 72 61 63 69 6e 67 | 20 28 2d 74 20 6f 70 74 | tracing| (-t opt|
|00000850| 69 6f 6e 29 2e 0a 55 73 | 65 20 67 65 74 6f 70 74 |ion)..Us|e getopt|
|00000860| 28 29 2e 0a 0a 2d 2d 20 | 6d 6f 64 2e 73 6f 75 72 |()...-- |mod.sour|
|00000870| 63 65 73 2c 20 38 2f 38 | 35 0a 50 72 69 76 61 74 |ces, 8/8|5.Privat|
|00000880| 65 20 68 6f 73 74 73 20 | 64 6f 63 75 6d 65 6e 74 |e hosts |document|
|00000890| 65 64 2e 0a 48 6f 6d 65 | 67 72 6f 77 6e 20 73 63 |ed..Home|grown sc|
|000008a0| 61 6e 6e 65 72 20 2d 2d | 20 69 74 27 73 20 74 72 |anner --| it's tr|
|000008b0| 75 65 20 77 68 61 74 20 | 74 68 65 79 20 73 61 79 |ue what |they say|
|000008c0| 20 61 62 6f 75 74 20 6c | 65 78 2e 0a 4d 61 6b 65 | about l|ex..Make|
|000008d0| 64 62 2e 0a 44 6f 6d 61 | 69 6e 73 20 61 6e 64 20 |db..Doma|ins and |
|000008e0| 67 61 74 65 77 61 79 73 | 2e 0a 44 45 41 44 20 62 |gateways|..DEAD b|
|000008f0| 61 63 6b 20 6c 69 6e 6b | 2e 0a 0a 2d 2d 20 6e 65 |ack link|...-- ne|
|00000900| 74 2e 73 6f 75 72 63 65 | 73 2c 20 31 2f 38 35 0a |t.source|s, 1/85.|
|00000910| 4e 6f 20 21 20 69 6e 20 | 64 62 6d 20 6b 65 79 2e |No ! in |dbm key.|
|00000920| 0a 4e 65 74 77 6f 72 6b | 20 63 68 61 72 61 63 74 |.Network| charact|
|00000930| 65 72 20 6d 75 73 74 20 | 62 65 20 6f 6e 65 20 6f |er must |be one o|
|00000940| 66 20 21 40 25 3a 20 2d | 2d 20 64 6f 74 20 69 73 |f !@%: -|- dot is|
|00000950| 20 64 65 61 64 2e 0a 50 | 72 69 76 61 74 65 20 68 | dead..P|rivate h|
|00000960| 6f 73 74 73 2e 0a 44 69 | 73 63 6f 75 72 61 67 65 |osts..Di|scourage|
|00000970| 20 68 79 62 72 69 64 20 | 61 64 64 72 65 73 73 65 | hybrid |addresse|
|00000980| 73 2e 20 20 0a 4d 61 67 | 69 63 20 40 20 3c 2d 3e |s. .Mag|ic @ <->|
|00000990| 20 25 20 72 75 6c 65 2e | 0a 0a 2d 2d 20 31 39 38 | % rule.|..-- 198|
|000009a0| 33 2d 31 39 38 34 0a 52 | 65 76 65 72 73 65 20 73 |3-1984.R|everse s|
|000009b0| 65 6e 73 65 20 6f 66 20 | 74 68 65 20 2d 63 20 28 |ense of |the -c (|
|000009c0| 63 6f 73 74 29 20 66 6c | 61 67 2e 0a 55 73 65 20 |cost) fl|ag..Use |
|000009d0| 63 68 65 61 70 65 73 74 | 20 61 6d 6f 6e 67 20 64 |cheapest| among d|
|000009e0| 75 70 6c 69 63 61 74 65 | 20 6c 69 6e 6b 73 2e 0a |uplicate| links..|
|000009f0| 45 6c 69 64 65 20 6e 65 | 74 77 6f 72 6b 20 6e 61 |Elide ne|twork na|
|00000a00| 6d 65 73 20 69 6e 20 6f | 75 74 70 75 74 2e 0a 0a |mes in o|utput...|
|00000a10| 2d 2d 20 65 70 6f 63 68 | 20 28 73 6d 62 20 76 65 |-- epoch| (smb ve|
|00000a20| 72 73 69 6f 6e 29 0a 53 | 48 41 52 5f 45 4f 46 0a |rsion).S|HAR_EOF.|
|00000a30| 69 66 20 74 65 73 74 20 | 36 39 31 20 2d 6e 65 20 |if test |691 -ne |
|00000a40| 22 60 77 63 20 2d 63 20 | 3c 20 27 43 48 41 4e 47 |"`wc -c |< 'CHANG|
|00000a50| 45 53 27 60 22 0a 74 68 | 65 6e 0a 09 65 63 68 6f |ES'`".th|en..echo|
|00000a60| 20 73 68 61 72 3a 20 65 | 72 72 6f 72 20 74 72 61 | shar: e|rror tra|
|00000a70| 6e 73 6d 69 74 74 69 6e | 67 20 22 27 43 48 41 4e |nsmittin|g "'CHAN|
|00000a80| 47 45 53 27 22 20 27 28 | 73 68 6f 75 6c 64 20 68 |GES'" '(|should h|
|00000a90| 61 76 65 20 62 65 65 6e | 20 36 39 31 20 63 68 61 |ave been| 691 cha|
|00000aa0| 72 61 63 74 65 72 73 29 | 27 0a 66 69 0a 66 69 0a |racters)|'.fi.fi.|
|00000ab0| 65 63 68 6f 20 73 68 61 | 72 3a 20 65 78 74 72 61 |echo sha|r: extra|
|00000ac0| 63 74 69 6e 67 20 22 27 | 4d 61 6b 65 66 69 6c 65 |cting "'|Makefile|
|00000ad0| 27 22 20 27 28 31 30 37 | 38 20 63 68 61 72 61 63 |'" '(107|8 charac|
|00000ae0| 74 65 72 73 29 27 0a 69 | 66 20 74 65 73 74 20 2d |ters)'.i|f test -|
|00000af0| 66 20 27 4d 61 6b 65 66 | 69 6c 65 27 0a 74 68 65 |f 'Makef|ile'.the|
|00000b00| 6e 0a 09 65 63 68 6f 20 | 73 68 61 72 3a 20 77 69 |n..echo |shar: wi|
|00000b10| 6c 6c 20 6e 6f 74 20 6f | 76 65 72 2d 77 72 69 74 |ll not o|ver-writ|
|00000b20| 65 20 65 78 69 73 74 69 | 6e 67 20 66 69 6c 65 20 |e existi|ng file |
|00000b30| 22 27 4d 61 6b 65 66 69 | 6c 65 27 22 0a 65 6c 73 |"'Makefi|le'".els|
|00000b40| 65 0a 63 61 74 20 3c 3c | 20 5c 53 48 41 52 5f 45 |e.cat <<| \SHAR_E|
|00000b50| 4f 46 20 3e 20 27 4d 61 | 6b 65 66 69 6c 65 27 0a |OF > 'Ma|kefile'.|
|00000b60| 23 21 2f 62 69 6e 2f 6d | 61 6b 65 20 2d 66 0a 23 |#!/bin/m|ake -f.#|
|00000b70| 20 70 61 74 68 61 6c 69 | 61 73 20 2d 2d 20 62 79 | pathali|as -- by|
|00000b80| 20 73 74 65 76 65 20 62 | 65 6c 6c 6f 76 69 6e 2c | steve b|ellovin,|
|00000b90| 20 61 73 20 74 6f 6c 64 | 20 74 6f 20 70 65 74 65 | as told| to pete|
|00000ba0| 72 20 68 6f 6e 65 79 6d | 61 6e 0a 0a 23 20 69 66 |r honeym|an..# if|
|00000bb0| 20 79 6f 75 20 63 61 6e | 27 74 20 6f 72 20 64 6f | you can|'t or do|
|00000bc0| 6e 27 74 20 69 6e 74 65 | 6e 64 20 74 6f 20 75 73 |n't inte|nd to us|
|00000bd0| 65 20 64 62 6d 20 66 69 | 6c 65 73 2c 20 64 6f 6e |e dbm fi|les, don|
|00000be0| 27 74 20 62 6f 74 68 65 | 72 20 77 69 74 68 20 6d |'t bothe|r with m|
|00000bf0| 61 6b 65 64 62 0a 44 42 | 4d 20 3d 20 2d 6c 64 62 |akedb.DB|M = -ldb|
|00000c00| 6d 0a 23 20 6f 72 20 69 | 66 20 79 6f 75 20 72 6f |m.# or i|f you ro|
|00000c10| 6c 6c 20 79 6f 75 72 20 | 6f 77 6e 20 2e 2e 2e 0a |ll your |own ....|
|00000c20| 23 20 44 42 4d 20 3d 20 | 64 62 6d 2e 6f 0a 0a 43 |# DBM = |dbm.o..C|
|00000c30| 43 20 3d 20 63 63 0a 43 | 46 4c 41 47 53 20 3d 20 |C = cc.C|FLAGS = |
|00000c40| 2d 4f 0a 4c 44 46 4c 41 | 47 53 20 3d 20 2d 73 0a |-O.LDFLA|GS = -s.|
|00000c50| 59 46 4c 41 47 53 20 3d | 20 2d 64 0a 0a 4f 42 4a |YFLAGS =| -d..OBJ|
|00000c60| 20 3d 20 61 64 64 6c 69 | 6e 6b 2e 6f 20 61 64 64 | = addli|nk.o add|
|00000c70| 6e 6f 64 65 2e 6f 20 65 | 78 74 65 72 6e 2e 6f 20 |node.o e|xtern.o |
|00000c80| 6c 6f 63 61 6c 2e 6f 20 | 6d 61 69 6e 2e 6f 20 6d |local.o |main.o m|
|00000c90| 61 70 69 74 2e 6f 20 6d | 61 70 61 75 78 2e 6f 20 |apit.o m|apaux.o |
|00000ca0| 6d 65 6d 2e 6f 20 70 61 | 72 73 65 2e 6f 20 70 72 |mem.o pa|rse.o pr|
|00000cb0| 69 6e 74 69 74 2e 6f 0a | 48 44 52 53 20 3d 20 64 |intit.o.|HDRS = d|
|00000cc0| 65 66 2e 68 20 63 6f 6e | 66 69 67 2e 68 0a 43 53 |ef.h con|fig.h.CS|
|00000cd0| 52 43 20 3d 20 61 64 64 | 6c 69 6e 6b 2e 63 20 61 |RC = add|link.c a|
|00000ce0| 64 64 6e 6f 64 65 2e 63 | 20 65 78 74 65 72 6e 2e |ddnode.c| extern.|
|00000cf0| 63 20 6c 6f 63 61 6c 2e | 63 20 6d 61 69 6e 2e 63 |c local.|c main.c|
|00000d00| 20 6d 61 70 69 74 2e 63 | 20 6d 61 70 61 75 78 2e | mapit.c| mapaux.|
|00000d10| 63 20 6d 65 6d 2e 63 20 | 70 72 69 6e 74 69 74 2e |c mem.c |printit.|
|00000d20| 63 0a 53 52 43 20 3d 20 | 24 28 43 53 52 43 29 20 |c.SRC = |$(CSRC) |
|00000d30| 70 61 72 73 65 2e 79 0a | 4c 53 52 43 20 3d 20 24 |parse.y.|LSRC = $|
|00000d40| 28 43 53 52 43 29 20 70 | 61 72 73 65 2e 63 0a 0a |(CSRC) p|arse.c..|
|00000d50| 70 61 74 68 61 6c 69 61 | 73 3a 20 24 28 4f 42 4a |pathalia|s: $(OBJ|
|00000d60| 29 0a 09 24 28 43 43 29 | 20 24 28 4c 44 46 4c 41 |)..$(CC)| $(LDFLA|
|00000d70| 47 53 29 20 24 28 4f 42 | 4a 29 20 2d 6f 20 70 61 |GS) $(OB|J) -o pa|
|00000d80| 74 68 61 6c 69 61 73 0a | 0a 61 6c 6c 3a 20 70 61 |thalias.|.all: pa|
|00000d90| 74 68 61 6c 69 61 73 20 | 6d 61 6b 65 64 62 0a 0a |thalias |makedb..|
|00000da0| 24 28 4f 42 4a 29 3a 09 | 24 28 48 44 52 53 29 0a |$(OBJ):.|$(HDRS).|
|00000db0| 0a 70 61 72 73 65 2e 63 | 3a 20 70 61 72 73 65 2e |.parse.c|: parse.|
|00000dc0| 79 20 24 28 48 44 52 53 | 29 0a 09 24 28 59 41 43 |y $(HDRS|)..$(YAC|
|00000dd0| 43 29 20 24 28 59 46 4c | 41 47 53 29 20 70 61 72 |C) $(YFL|AGS) par|
|00000de0| 73 65 2e 79 0a 09 6d 76 | 20 79 2e 74 61 62 2e 63 |se.y..mv| y.tab.c|
|00000df0| 20 70 61 72 73 65 2e 63 | 0a 0a 6d 61 6b 65 64 62 | parse.c|..makedb|
|00000e00| 3a 20 6d 61 6b 65 64 62 | 2e 6f 0a 09 24 28 43 43 |: makedb|.o..$(CC|
|00000e10| 29 20 24 28 4c 44 46 4c | 41 47 53 29 20 6d 61 6b |) $(LDFL|AGS) mak|
|00000e20| 65 64 62 2e 6f 20 24 28 | 44 42 4d 29 20 2d 6f 20 |edb.o $(|DBM) -o |
|00000e30| 6d 61 6b 65 64 62 0a 0a | 6d 61 6b 65 64 62 2e 6f |makedb..|makedb.o|
|00000e40| 3a 20 63 6f 6e 66 69 67 | 2e 68 0a 0a 63 6c 65 61 |: config|.h..clea|
|00000e50| 6e 3a 0a 09 72 6d 20 2d | 66 20 2a 2e 6f 20 79 2e |n:..rm -|f *.o y.|
|00000e60| 74 61 62 2e 3f 20 70 61 | 72 73 65 2e 63 0a 0a 63 |tab.? pa|rse.c..c|
|00000e70| 6c 6f 62 62 65 72 3a 20 | 63 6c 65 61 6e 0a 09 72 |lobber: |clean..r|
|00000e80| 6d 20 2d 66 20 70 61 74 | 68 61 6c 69 61 73 20 6d |m -f pat|halias m|
|00000e90| 61 6b 65 64 62 0a 0a 74 | 61 67 73 3a 20 24 28 53 |akedb..t|ags: $(S|
|00000ea0| 52 43 29 20 24 28 48 44 | 52 53 29 20 6d 61 6b 65 |RC) $(HD|RS) make|
|00000eb0| 64 62 2e 63 0a 09 63 74 | 61 67 73 20 2d 77 20 24 |db.c..ct|ags -w $|
|00000ec0| 28 48 44 52 53 29 20 24 | 28 53 52 43 29 0a 0a 62 |(HDRS) $|(SRC)..b|
|00000ed0| 75 6e 64 6c 65 3a 0a 09 | 40 62 75 6e 64 6c 65 20 |undle:..|@bundle |
|00000ee0| 52 45 41 44 4d 45 20 43 | 48 41 4e 47 45 53 20 70 |README C|HANGES p|
|00000ef0| 61 74 68 61 6c 69 61 73 | 2e 31 20 4d 61 6b 65 66 |athalias|.1 Makef|
|00000f00| 69 6c 65 20 24 7b 48 44 | 52 53 7d 20 24 7b 53 52 |ile ${HD|RS} ${SR|
|00000f10| 43 7d 20 6d 61 6b 65 64 | 62 2e 63 0a 0a 6c 69 6e |C} maked|b.c..lin|
|00000f20| 74 3a 09 24 28 4c 53 52 | 43 29 0a 09 6c 69 6e 74 |t:.$(LSR|C)..lint|
|00000f30| 20 24 28 43 46 4c 41 47 | 53 29 20 24 28 4c 53 52 | $(CFLAG|S) $(LSR|
|00000f40| 43 29 0a 09 6c 69 6e 74 | 20 6d 61 6b 65 64 62 2e |C)..lint| makedb.|
|00000f50| 63 0a 0a 69 6e 73 74 61 | 6c 6c 3a 0a 09 40 65 63 |c..insta|ll:..@ec|
|00000f60| 68 6f 20 22 69 6e 73 74 | 61 6c 6c 20 70 61 74 68 |ho "inst|all path|
|00000f70| 61 6c 69 61 73 20 61 63 | 63 6f 72 64 69 6e 67 20 |alias ac|cording |
|00000f80| 74 6f 20 6c 6f 63 61 6c | 20 63 6f 6e 76 65 6e 74 |to local| convent|
|00000f90| 69 6f 6e 73 22 0a 53 48 | 41 52 5f 45 4f 46 0a 69 |ions".SH|AR_EOF.i|
|00000fa0| 66 20 74 65 73 74 20 31 | 30 37 38 20 2d 6e 65 20 |f test 1|078 -ne |
|00000fb0| 22 60 77 63 20 2d 63 20 | 3c 20 27 4d 61 6b 65 66 |"`wc -c |< 'Makef|
|00000fc0| 69 6c 65 27 60 22 0a 74 | 68 65 6e 0a 09 65 63 68 |ile'`".t|hen..ech|
|00000fd0| 6f 20 73 68 61 72 3a 20 | 65 72 72 6f 72 20 74 72 |o shar: |error tr|
|00000fe0| 61 6e 73 6d 69 74 74 69 | 6e 67 20 22 27 4d 61 6b |ansmitti|ng "'Mak|
|00000ff0| 65 66 69 6c 65 27 22 20 | 27 28 73 68 6f 75 6c 64 |efile'" |'(should|
|00001000| 20 68 61 76 65 20 62 65 | 65 6e 20 31 30 37 38 20 | have be|en 1078 |
|00001010| 63 68 61 72 61 63 74 65 | 72 73 29 27 0a 66 69 0a |characte|rs)'.fi.|
|00001020| 66 69 0a 65 63 68 6f 20 | 73 68 61 72 3a 20 65 78 |fi.echo |shar: ex|
|00001030| 74 72 61 63 74 69 6e 67 | 20 22 27 63 6f 6e 66 69 |tracting| "'confi|
|00001040| 67 2e 68 27 22 20 27 28 | 32 30 31 30 20 63 68 61 |g.h'" '(|2010 cha|
|00001050| 72 61 63 74 65 72 73 29 | 27 0a 69 66 20 74 65 73 |racters)|'.if tes|
|00001060| 74 20 2d 66 20 27 63 6f | 6e 66 69 67 2e 68 27 0a |t -f 'co|nfig.h'.|
|00001070| 74 68 65 6e 0a 09 65 63 | 68 6f 20 73 68 61 72 3a |then..ec|ho shar:|
|00001080| 20 77 69 6c 6c 20 6e 6f | 74 20 6f 76 65 72 2d 77 | will no|t over-w|
|00001090| 72 69 74 65 20 65 78 69 | 73 74 69 6e 67 20 66 69 |rite exi|sting fi|
|000010a0| 6c 65 20 22 27 63 6f 6e | 66 69 67 2e 68 27 22 0a |le "'con|fig.h'".|
|000010b0| 65 6c 73 65 0a 63 61 74 | 20 3c 3c 20 5c 53 48 41 |else.cat| << \SHA|
|000010c0| 52 5f 45 4f 46 20 3e 20 | 27 63 6f 6e 66 69 67 2e |R_EOF > |'config.|
|000010d0| 68 27 0a 2f 2a 20 70 61 | 74 68 61 6c 69 61 73 20 |h'./* pa|thalias |
|000010e0| 2d 2d 20 62 79 20 73 74 | 65 76 65 20 62 65 6c 6c |-- by st|eve bell|
|000010f0| 6f 76 69 6e 2c 20 61 73 | 20 74 6f 6c 64 20 74 6f |ovin, as| told to|
|00001100| 20 70 65 74 65 72 20 68 | 6f 6e 65 79 6d 61 6e 20 | peter h|oneyman |
|00001110| 2a 2f 0a 0a 23 64 65 66 | 69 6e 65 20 53 54 52 43 |*/..#def|ine STRC|
|00001120| 48 52 09 09 2f 2a 20 68 | 61 76 65 20 73 74 72 63 |HR../* h|ave strc|
|00001130| 68 72 2c 20 6e 6f 74 20 | 69 6e 64 65 78 20 2d 2d |hr, not |index --|
|00001140| 20 70 72 6f 62 61 62 6c | 79 20 73 79 73 74 65 6d | probabl|y system|
|00001150| 20 76 20 2a 2f 0a 23 64 | 65 66 69 6e 65 20 55 4e | v */.#d|efine UN|
|00001160| 41 4d 45 09 09 2f 2a 20 | 68 61 76 65 20 75 6e 61 |AME../* |have una|
|00001170| 6d 65 28 29 20 2d 2d 20 | 70 72 6f 62 61 62 6c 79 |me() -- |probably|
|00001180| 20 73 79 73 74 65 6d 20 | 76 20 6f 72 20 38 74 68 | system |v or 8th|
|00001190| 20 65 64 2e 20 2a 2f 0a | 23 64 65 66 69 6e 65 20 | ed. */.|#define |
|000011a0| 4d 45 4d 53 45 54 09 09 | 2f 2a 20 68 61 76 65 20 |MEMSET..|/* have |
|000011b0| 6d 65 6d 73 65 74 28 29 | 20 2d 2d 20 70 72 6f 62 |memset()| -- prob|
|000011c0| 61 62 6c 79 20 73 79 73 | 74 65 6d 20 76 20 6f 72 |ably sys|tem v or|
|000011d0| 20 38 74 68 20 65 64 2e | 20 2a 2f 0a 0a 2f 2a 20 | 8th ed.| */../* |
|000011e0| 23 64 65 66 69 6e 65 20 | 47 45 54 48 4f 53 54 4e |#define |GETHOSTN|
|000011f0| 41 4d 45 09 2f 2a 20 68 | 61 76 65 20 67 65 74 68 |AME./* h|ave geth|
|00001200| 6f 73 74 6e 61 6d 65 28 | 29 20 2d 2d 20 70 72 6f |ostname(|) -- pro|
|00001210| 62 61 62 6c 79 20 34 2e | 32 62 73 64 20 2a 2f 0a |bably 4.|2bsd */.|
|00001220| 2f 2a 20 23 64 65 66 69 | 6e 65 20 42 5a 45 52 4f |/* #defi|ne BZERO|
|00001230| 09 2f 2a 20 68 61 76 65 | 20 62 7a 65 72 6f 28 29 |./* have| bzero()|
|00001240| 20 2d 2d 20 70 72 6f 62 | 61 62 6c 79 20 34 2e 32 | -- prob|ably 4.2|
|00001250| 62 73 64 20 2a 2f 0a 0a | 2f 2a 20 64 65 66 61 75 |bsd */..|/* defau|
|00001260| 6c 74 20 70 6c 61 63 65 | 20 66 6f 72 20 64 62 6d |lt place| for dbm|
|00001270| 20 6f 75 74 70 75 74 20 | 6f 66 20 6d 61 6b 65 64 | output |of maked|
|00001280| 62 20 28 6f 72 20 75 73 | 65 20 2d 6f 20 66 69 6c |b (or us|e -o fil|
|00001290| 65 20 61 74 20 72 75 6e | 2d 74 69 6d 65 29 20 2a |e at run|-time) *|
|000012a0| 2f 0a 23 64 65 66 69 6e | 65 09 41 4c 49 41 53 44 |/.#defin|e.ALIASD|
|000012b0| 42 09 22 2f 75 73 72 2f | 6c 6f 63 61 6c 2f 6c 69 |B."/usr/|local/li|
|000012c0| 62 2f 70 61 6c 69 61 73 | 22 0a 0a 0a 0a 2f 2a 2a |b/palias|"..../**|
|000012d0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000012e0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000012f0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00001300| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00001310| 2a 2a 2a 2a 2a 2a 2a 2a | 0a 20 2a 09 09 09 09 09 |********|. *.....|
|00001320| 09 09 09 09 20 20 2a 0a | 20 2a 20 2b 2d 2d 2d 2d |.... *.| * +----|
|00001330| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001340| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001350| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001360| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001370| 2b 20 2a 0a 20 2a 20 7c | 09 09 09 09 09 09 09 09 |+ *. * ||........|
|00001380| 09 7c 20 2a 0a 20 2a 20 | 7c 09 09 09 45 4e 44 20 |.| *. * ||...END |
|00001390| 4f 46 20 43 4f 4e 46 49 | 47 55 52 41 54 49 4f 4e |OF CONFI|GURATION|
|000013a0| 20 53 45 43 54 49 4f 4e | 09 09 09 7c 20 2a 0a 20 | SECTION|...| *. |
|000013b0| 2a 20 7c 09 09 09 09 09 | 09 09 09 09 7c 20 2a 0a |* |.....|....| *.|
|000013c0| 20 2a 20 7c 09 09 09 09 | 45 44 49 54 20 4e 4f 20 | * |....|EDIT NO |
|000013d0| 4d 4f 52 45 09 09 09 09 | 7c 20 2a 0a 20 2a 20 7c |MORE....|| *. * ||
|000013e0| 09 09 09 09 09 09 09 09 | 09 7c 20 2a 0a 20 2a 20 |........|.| *. * |
|000013f0| 2b 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |+-------|--------|
|00001400| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001410| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001420| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001430| 2d 2d 2d 2d 2d 2b 20 2a | 0a 20 2a 09 09 09 09 09 |-----+ *|. *.....|
|00001440| 09 09 09 09 20 20 2a 0a | 20 2a 2a 2a 2a 2a 2a 2a |.... *.| *******|
|00001450| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00001460| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00001470| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00001480| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00001490| 2a 2a 2a 2f 0a 0a 23 69 | 66 64 65 66 20 4d 41 49 |***/..#i|fdef MAI|
|000014a0| 4e 0a 23 69 66 6e 64 65 | 66 20 6c 69 6e 74 0a 73 |N.#ifnde|f lint.s|
|000014b0| 74 61 74 69 63 20 63 68 | 61 72 09 2a 63 5f 73 63 |tatic ch|ar.*c_sc|
|000014c0| 63 73 69 64 20 3d 20 22 | 40 28 23 29 63 6f 6e 66 |csid = "|@(#)conf|
|000014d0| 69 67 2e 68 09 38 2e 31 | 20 28 64 6f 77 6e 21 68 |ig.h.8.1| (down!h|
|000014e0| 6f 6e 65 79 29 20 38 36 | 2f 30 31 2f 31 39 22 3b |oney) 86|/01/19";|
|000014f0| 0a 23 65 6e 64 69 66 20 | 2f 2a 6c 69 6e 74 2a 2f |.#endif |/*lint*/|
|00001500| 0a 23 65 6e 64 69 66 20 | 2f 2a 4d 41 49 4e 2a 2f |.#endif |/*MAIN*/|
|00001510| 0a 0a 2f 2a 0a 20 2a 20 | 6d 61 6c 6c 6f 63 2f 66 |../*. * |malloc/f|
|00001520| 72 65 65 20 66 69 6e 65 | 20 74 75 6e 65 64 20 66 |ree fine| tuned f|
|00001530| 6f 72 20 70 61 74 68 61 | 6c 69 61 73 2e 0a 20 2a |or patha|lias.. *|
|00001540| 0a 20 2a 20 4d 59 4d 41 | 4c 4c 4f 43 20 73 68 6f |. * MYMA|LLOC sho|
|00001550| 75 6c 64 20 77 6f 72 6b | 20 65 76 65 72 77 68 65 |uld work| everwhe|
|00001560| 72 65 2c 20 73 6f 20 69 | 74 27 73 20 6e 6f 74 20 |re, so i|t's not |
|00001570| 61 20 63 6f 6e 66 69 67 | 75 72 61 74 69 6f 6e 0a |a config|uration.|
|00001580| 20 2a 20 6f 70 74 69 6f | 6e 20 28 61 6e 79 6d 6f | * optio|n (anymo|
|00001590| 72 65 29 2e 20 20 6e 6f | 6e 65 74 68 65 6c 65 73 |re). no|netheles|
|000015a0| 73 2c 20 69 66 20 79 6f | 75 27 72 65 20 67 65 74 |s, if yo|u're get|
|000015b0| 74 69 6e 67 20 73 74 72 | 61 6e 67 65 0a 20 2a 20 |ting str|ange. * |
|000015c0| 63 6f 72 65 20 64 75 6d | 70 73 20 28 6f 72 20 70 |core dum|ps (or p|
|000015d0| 61 6e 69 63 73 21 29 2c | 20 63 6f 6d 6d 65 6e 74 |anics!),| comment|
|000015e0| 20 6f 75 74 20 74 68 65 | 20 66 6f 6c 6c 6f 77 69 | out the| followi|
|000015f0| 6e 67 20 6d 61 6e 69 66 | 65 73 74 2c 0a 20 2a 20 |ng manif|est,. * |
|00001600| 61 6e 64 20 75 73 65 20 | 74 68 65 20 69 6e 66 65 |and use |the infe|
|00001610| 72 69 6f 72 20 43 20 6c | 69 62 72 61 72 79 20 6d |rior C l|ibrary m|
|00001620| 61 6c 6c 6f 63 2f 66 72 | 65 65 2e 0a 20 2a 0a 20 |alloc/fr|ee.. *. |
|00001630| 2a 20 72 65 70 6f 72 74 | 20 70 72 6f 62 6c 65 6d |* report| problem|
|00001640| 73 20 74 6f 20 70 72 69 | 6e 63 65 74 6f 6e 21 68 |s to pri|nceton!h|
|00001650| 6f 6e 65 79 2e 0a 20 2a | 2f 0a 23 64 65 66 69 6e |oney.. *|/.#defin|
|00001660| 65 20 4d 59 4d 41 4c 4c | 4f 43 09 2f 2a 2a 2f 0a |e MYMALL|OC./**/.|
|00001670| 0a 23 69 66 64 65 66 20 | 4d 59 4d 41 4c 4c 4f 43 |.#ifdef |MYMALLOC|
|00001680| 0a 23 64 65 66 69 6e 65 | 20 6d 61 6c 6c 6f 63 20 |.#define| malloc |
|00001690| 6d 79 6d 61 6c 6c 6f 63 | 0a 23 64 65 66 69 6e 65 |mymalloc|.#define|
|000016a0| 20 63 61 6c 6c 6f 63 28 | 6e 2c 20 73 29 20 6d 61 | calloc(|n, s) ma|
|000016b0| 6c 6c 6f 63 20 28 28 6e | 29 2a 28 73 29 29 0a 23 |lloc ((n|)*(s)).#|
|000016c0| 64 65 66 69 6e 65 20 66 | 72 65 65 28 73 29 0a 23 |define f|ree(s).#|
|000016d0| 64 65 66 69 6e 65 20 63 | 66 72 65 65 28 73 29 0a |define c|free(s).|
|000016e0| 65 78 74 65 72 6e 20 63 | 68 61 72 20 2a 6d 65 6d |extern c|har *mem|
|000016f0| 67 65 74 28 29 3b 0a 23 | 65 6e 64 69 66 0a 0a 23 |get();.#|endif..#|
|00001700| 69 66 64 65 66 20 53 54 | 52 43 48 52 0a 23 64 65 |ifdef ST|RCHR.#de|
|00001710| 66 69 6e 65 20 69 6e 64 | 65 78 20 73 74 72 63 68 |fine ind|ex strch|
|00001720| 72 0a 23 64 65 66 69 6e | 65 20 72 69 6e 64 65 78 |r.#defin|e rindex|
|00001730| 20 73 74 72 72 63 68 72 | 0a 23 65 6c 73 65 0a 23 | strrchr|.#else.#|
|00001740| 64 65 66 69 6e 65 20 73 | 74 72 63 68 72 20 69 6e |define s|trchr in|
|00001750| 64 65 78 0a 23 64 65 66 | 69 6e 65 20 73 74 72 72 |dex.#def|ine strr|
|00001760| 63 68 72 20 72 69 6e 64 | 65 78 0a 23 65 6e 64 69 |chr rind|ex.#endi|
|00001770| 66 0a 0a 23 69 66 64 65 | 66 20 42 5a 45 52 4f 0a |f..#ifde|f BZERO.|
|00001780| 23 64 65 66 69 6e 65 20 | 73 74 72 63 6c 65 61 72 |#define |strclear|
|00001790| 28 73 2c 20 6e 29 09 28 | 28 76 6f 69 64 29 20 62 |(s, n).(|(void) b|
|000017a0| 7a 65 72 6f 28 28 73 29 | 2c 20 28 6e 29 29 29 0a |zero((s)|, (n))).|
|000017b0| 23 65 6c 73 65 20 2f 2a | 21 42 5a 45 52 4f 2a 2f |#else /*|!BZERO*/|
|000017c0| 0a 0a 23 69 66 64 65 66 | 20 4d 45 4d 53 45 54 0a |..#ifdef| MEMSET.|
|000017d0| 65 78 74 65 72 6e 20 63 | 68 61 72 09 2a 6d 65 6d |extern c|har.*mem|
|000017e0| 73 65 74 28 29 3b 0a 23 | 64 65 66 69 6e 65 20 73 |set();.#|define s|
|000017f0| 74 72 63 6c 65 61 72 28 | 73 2c 20 6e 29 09 28 28 |trclear(|s, n).((|
|00001800| 76 6f 69 64 29 20 6d 65 | 6d 73 65 74 28 28 73 29 |void) me|mset((s)|
|00001810| 2c 20 30 2c 20 28 6e 29 | 29 29 0a 23 65 6c 73 65 |, 0, (n)|)).#else|
|00001820| 20 2f 2a 21 4d 45 4d 53 | 45 54 2a 2f 0a 65 78 74 | /*!MEMS|ET*/.ext|
|00001830| 65 72 6e 20 76 6f 69 64 | 09 73 74 72 63 6c 65 61 |ern void|.strclea|
|00001840| 72 28 29 3b 0a 23 65 6e | 64 69 66 20 2f 2a 4d 45 |r();.#en|dif /*ME|
|00001850| 4d 53 45 54 2a 2f 0a 0a | 23 65 6e 64 69 66 20 2f |MSET*/..|#endif /|
|00001860| 2a 42 5a 45 52 4f 2a 2f | 0a 0a 65 78 74 65 72 6e |*BZERO*/|..extern|
|00001870| 20 63 68 61 72 09 2a 6d | 61 6c 6c 6f 63 28 29 3b | char.*m|alloc();|
|00001880| 0a 65 78 74 65 72 6e 20 | 63 68 61 72 09 2a 73 74 |.extern |char.*st|
|00001890| 72 63 70 79 28 29 2c 20 | 2a 69 6e 64 65 78 28 29 |rcpy(), |*index()|
|000018a0| 2c 20 2a 72 69 6e 64 65 | 78 28 29 3b 0a 53 48 41 |, *rinde|x();.SHA|
|000018b0| 52 5f 45 4f 46 0a 69 66 | 20 74 65 73 74 20 32 30 |R_EOF.if| test 20|
|000018c0| 31 30 20 2d 6e 65 20 22 | 60 77 63 20 2d 63 20 3c |10 -ne "|`wc -c <|
|000018d0| 20 27 63 6f 6e 66 69 67 | 2e 68 27 60 22 0a 74 68 | 'config|.h'`".th|
|000018e0| 65 6e 0a 09 65 63 68 6f | 20 73 68 61 72 3a 20 65 |en..echo| shar: e|
|000018f0| 72 72 6f 72 20 74 72 61 | 6e 73 6d 69 74 74 69 6e |rror tra|nsmittin|
|00001900| 67 20 22 27 63 6f 6e 66 | 69 67 2e 68 27 22 20 27 |g "'conf|ig.h'" '|
|00001910| 28 73 68 6f 75 6c 64 20 | 68 61 76 65 20 62 65 65 |(should |have bee|
|00001920| 6e 20 32 30 31 30 20 63 | 68 61 72 61 63 74 65 72 |n 2010 c|haracter|
|00001930| 73 29 27 0a 66 69 0a 66 | 69 0a 65 63 68 6f 20 73 |s)'.fi.f|i.echo s|
|00001940| 68 61 72 3a 20 65 78 74 | 72 61 63 74 69 6e 67 20 |har: ext|racting |
|00001950| 22 27 64 65 66 2e 68 27 | 22 20 27 28 34 36 38 33 |"'def.h'|" '(4683|
|00001960| 20 63 68 61 72 61 63 74 | 65 72 73 29 27 0a 69 66 | charact|ers)'.if|
|00001970| 20 74 65 73 74 20 2d 66 | 20 27 64 65 66 2e 68 27 | test -f| 'def.h'|
|00001980| 0a 74 68 65 6e 0a 09 65 | 63 68 6f 20 73 68 61 72 |.then..e|cho shar|
|00001990| 3a 20 77 69 6c 6c 20 6e | 6f 74 20 6f 76 65 72 2d |: will n|ot over-|
|000019a0| 77 72 69 74 65 20 65 78 | 69 73 74 69 6e 67 20 66 |write ex|isting f|
|000019b0| 69 6c 65 20 22 27 64 65 | 66 2e 68 27 22 0a 65 6c |ile "'de|f.h'".el|
|000019c0| 73 65 0a 63 61 74 20 3c | 3c 20 5c 53 48 41 52 5f |se.cat <|< \SHAR_|
|000019d0| 45 4f 46 20 3e 20 27 64 | 65 66 2e 68 27 0a 2f 2a |EOF > 'd|ef.h'./*|
|000019e0| 20 70 61 74 68 61 6c 69 | 61 73 20 2d 2d 20 62 79 | pathali|as -- by|
|000019f0| 20 73 74 65 76 65 20 62 | 65 6c 6c 6f 76 69 6e 2c | steve b|ellovin,|
|00001a00| 20 61 73 20 74 6f 6c 64 | 20 74 6f 20 70 65 74 65 | as told| to pete|
|00001a10| 72 20 68 6f 6e 65 79 6d | 61 6e 20 2a 2f 0a 23 69 |r honeym|an */.#i|
|00001a20| 66 6e 64 65 66 20 6c 69 | 6e 74 0a 23 69 66 64 65 |fndef li|nt.#ifde|
|00001a30| 66 20 4d 41 49 4e 0a 73 | 74 61 74 69 63 20 63 68 |f MAIN.s|tatic ch|
|00001a40| 61 72 09 2a 68 5f 73 63 | 63 73 69 64 20 3d 20 22 |ar.*h_sc|csid = "|
|00001a50| 40 28 23 29 64 65 66 2e | 68 09 38 2e 31 20 28 64 |@(#)def.|h.8.1 (d|
|00001a60| 6f 77 6e 21 68 6f 6e 65 | 79 29 20 38 36 2f 30 31 |own!hone|y) 86/01|
|00001a70| 2f 31 39 22 3b 0a 23 65 | 6e 64 69 66 20 2f 2a 4d |/19";.#e|ndif /*M|
|00001a80| 41 49 4e 2a 2f 0a 23 65 | 6e 64 69 66 20 2f 2a 6c |AIN*/.#e|ndif /*l|
|00001a90| 69 6e 74 2a 2f 0a 0a 23 | 69 6e 63 6c 75 64 65 20 |int*/..#|include |
|00001aa0| 3c 73 74 64 69 6f 2e 68 | 3e 0a 23 69 6e 63 6c 75 |<stdio.h|>.#inclu|
|00001ab0| 64 65 20 3c 63 74 79 70 | 65 2e 68 3e 0a 23 69 6e |de <ctyp|e.h>.#in|
|00001ac0| 63 6c 75 64 65 20 22 63 | 6f 6e 66 69 67 2e 68 22 |clude "c|onfig.h"|
|00001ad0| 0a 0a 74 79 70 65 64 65 | 66 09 6c 6f 6e 67 20 43 |..typede|f.long C|
|00001ae0| 6f 73 74 3b 0a 74 79 70 | 65 64 65 66 20 73 74 72 |ost;.typ|edef str|
|00001af0| 75 63 74 20 6e 6f 64 65 | 20 6e 6f 64 65 3b 0a 74 |uct node| node;.t|
|00001b00| 79 70 65 64 65 66 20 73 | 74 72 75 63 74 20 6c 69 |ypedef s|truct li|
|00001b10| 6e 6b 20 6c 69 6e 6b 3b | 0a 0a 23 69 66 64 65 66 |nk link;|..#ifdef|
|00001b20| 20 6c 69 6e 74 0a 23 64 | 65 66 69 6e 65 20 76 70 | lint.#d|efine vp|
|00001b30| 72 69 6e 74 66 20 66 70 | 72 69 6e 74 66 0a 23 65 |rintf fp|rintf.#e|
|00001b40| 6c 73 65 20 2f 2a 21 6c | 69 6e 74 20 2d 2d 20 74 |lse /*!l|int -- t|
|00001b50| 68 69 73 20 67 69 76 65 | 73 20 6e 75 6c 6c 20 65 |his give|s null e|
|00001b60| 66 66 65 63 74 20 77 61 | 72 6e 69 6e 67 2a 2f 0a |ffect wa|rning*/.|
|00001b70| 2f 2a 20 62 65 63 61 75 | 73 65 20 69 74 27 73 20 |/* becau|se it's |
|00001b80| 74 68 65 72 65 20 2e 2e | 2e 20 2a 2f 0a 23 64 65 |there ..|. */.#de|
|00001b90| 66 69 6e 65 20 76 70 72 | 69 6e 74 66 09 09 21 56 |fine vpr|intf..!V|
|00001ba0| 66 6c 61 67 20 3f 20 30 | 20 3a 20 66 70 72 69 6e |flag ? 0| : fprin|
|00001bb0| 74 66 0a 23 65 6e 64 69 | 66 20 2f 2a 6c 69 6e 74 |tf.#endi|f /*lint|
|00001bc0| 2a 2f 0a 0a 23 64 65 66 | 69 6e 65 20 4e 54 52 41 |*/..#def|ine NTRA|
|00001bd0| 43 45 09 31 36 09 2f 2a | 20 63 61 6e 20 74 72 61 |CE.16./*| can tra|
|00001be0| 63 65 20 75 70 20 74 6f | 20 4e 54 52 41 43 45 20 |ce up to| NTRACE |
|00001bf0| 68 6f 73 74 73 2f 6c 69 | 6e 6b 73 20 2a 2f 0a 0a |hosts/li|nks */..|
|00001c00| 2f 2a 20 73 63 61 6e 6e | 65 72 20 73 74 61 74 65 |/* scann|er state|
|00001c10| 73 20 28 79 79 6c 65 78 | 2c 20 70 61 72 73 65 29 |s (yylex|, parse)|
|00001c20| 20 2a 2f 0a 23 64 65 66 | 69 6e 65 20 4f 54 48 45 | */.#def|ine OTHE|
|00001c30| 52 20 30 0a 23 64 65 66 | 69 6e 65 20 43 4f 53 54 |R 0.#def|ine COST|
|00001c40| 49 4e 47 20 31 0a 23 64 | 65 66 69 6e 65 20 4e 45 |ING 1.#d|efine NE|
|00001c50| 57 4c 49 4e 45 20 32 0a | 0a 23 64 65 66 69 6e 65 |WLINE 2.|.#define|
|00001c60| 09 69 73 6e 65 74 63 28 | 63 29 09 28 28 63 29 3d |.isnetc(|c).((c)=|
|00001c70| 3d 27 21 27 20 7c 7c 20 | 28 63 29 3d 3d 27 3a 27 |='!' || |(c)==':'|
|00001c80| 20 7c 7c 20 28 63 29 3d | 3d 27 40 27 20 7c 7c 20 | || (c)=|='@' || |
|00001c90| 28 63 29 3d 3d 27 25 27 | 29 0a 0a 23 64 65 66 69 |(c)=='%'|)..#defi|
|00001ca0| 6e 65 20 64 69 72 62 69 | 74 73 28 63 29 09 28 63 |ne dirbi|ts(c).(c|
|00001cb0| 29 0a 0a 2f 2a 20 66 6c | 61 67 73 20 66 6f 72 20 |)../* fl|ags for |
|00001cc0| 6e 5f 66 6c 61 67 20 2a | 2f 0a 23 64 65 66 69 6e |n_flag *|/.#defin|
|00001cd0| 65 20 49 53 50 52 49 56 | 41 54 45 20 20 30 78 30 |e ISPRIV|ATE 0x0|
|00001ce0| 30 30 31 20 2f 2a 20 74 | 68 69 73 20 6e 6f 64 65 |001 /* t|his node|
|00001cf0| 20 69 6e 76 69 73 69 62 | 6c 65 20 6f 75 74 73 69 | invisib|le outsi|
|00001d00| 64 65 20 69 74 73 20 64 | 65 66 69 6e 69 74 69 6f |de its d|efinitio|
|00001d10| 6e 20 66 69 6c 65 20 2a | 2f 0a 23 64 65 66 69 6e |n file *|/.#defin|
|00001d20| 65 20 43 4f 4c 4c 49 53 | 49 4f 4e 20 20 30 78 30 |e COLLIS|ION 0x0|
|00001d30| 30 30 32 20 2f 2a 20 63 | 6f 6c 6c 69 64 65 73 20 |002 /* c|ollides |
|00001d40| 77 69 74 68 20 61 20 70 | 72 69 76 61 74 65 20 68 |with a p|rivate h|
|00001d50| 6f 73 74 20 6e 61 6d 65 | 20 2a 2f 0a 23 64 65 66 |ost name| */.#def|
|00001d60| 69 6e 65 20 41 54 53 49 | 47 4e 09 20 20 20 30 78 |ine ATSI|GN. 0x|
|00001d70| 30 30 30 34 20 2f 2a 20 | 73 65 65 6e 20 61 6e 20 |0004 /* |seen an |
|00001d80| 61 74 20 73 69 67 6e 3f | 20 20 75 73 65 64 20 66 |at sign?| used f|
|00001d90| 6f 72 20 6d 61 67 69 63 | 20 40 2f 25 20 72 75 6c |or magic| @/% rul|
|00001da0| 65 73 20 2a 2f 0a 23 64 | 65 66 69 6e 65 20 4d 41 |es */.#d|efine MA|
|00001db0| 50 50 45 44 09 20 20 20 | 30 78 30 30 30 38 20 2f |PPED. |0x0008 /|
|00001dc0| 2a 20 64 6f 6e 65 20 6d | 61 70 70 69 6e 67 20 74 |* done m|apping t|
|00001dd0| 68 69 73 20 6e 6f 64 65 | 20 2a 2f 0a 23 64 65 66 |his node| */.#def|
|00001de0| 69 6e 65 09 4e 44 45 41 | 44 09 20 20 20 30 78 30 |ine.NDEA|D. 0x0|
|00001df0| 30 31 30 20 2f 2a 20 6e | 6f 64 65 20 69 73 20 64 |010 /* n|ode is d|
|00001e00| 65 61 64 20 2a 2f 0a 23 | 64 65 66 69 6e 65 20 48 |ead */.#|define H|
|00001e10| 41 53 4c 45 46 54 09 20 | 20 20 30 78 30 30 32 30 |ASLEFT. | 0x0020|
|00001e20| 20 2f 2a 20 72 6f 75 74 | 65 20 68 61 73 20 61 20 | /* rout|e has a |
|00001e30| 6c 65 66 74 20 73 69 64 | 65 20 6e 65 74 20 63 68 |left sid|e net ch|
|00001e40| 61 72 61 63 74 65 72 20 | 2a 2f 0a 23 64 65 66 69 |aracter |*/.#defi|
|00001e50| 6e 65 20 48 41 53 52 49 | 47 48 54 20 20 20 30 78 |ne HASRI|GHT 0x|
|00001e60| 30 30 34 30 20 2f 2a 20 | 72 6f 75 74 65 20 68 61 |0040 /* |route ha|
|00001e70| 73 20 61 20 72 69 67 68 | 74 20 73 69 64 65 20 6e |s a righ|t side n|
|00001e80| 65 74 20 63 68 61 72 61 | 63 74 65 72 20 2a 2f 0a |et chara|cter */.|
|00001e90| 23 64 65 66 69 6e 65 09 | 4e 4e 45 54 09 20 20 20 |#define.|NNET. |
|00001ea0| 30 78 30 30 38 30 20 2f | 2a 20 6e 6f 64 65 20 69 |0x0080 /|* node i|
|00001eb0| 73 20 61 20 6e 65 74 77 | 6f 72 6b 20 6e 61 6d 65 |s a netw|ork name|
|00001ec0| 20 2a 2f 0a 23 64 65 66 | 69 6e 65 20 49 4e 44 46 | */.#def|ine INDF|
|00001ed0| 53 09 20 20 20 30 78 30 | 31 30 30 20 2f 2a 20 75 |S. 0x0|100 /* u|
|00001ee0| 73 65 64 20 77 68 65 6e | 20 72 65 6d 6f 76 69 6e |sed when| removin|
|00001ef0| 67 20 6e 65 74 20 63 79 | 63 6c 65 73 20 2a 2f 0a |g net cy|cles */.|
|00001f00| 23 64 65 66 69 6e 65 20 | 44 55 4d 50 09 20 20 20 |#define |DUMP. |
|00001f10| 30 78 30 32 30 30 20 2f | 2a 20 77 65 20 68 61 76 |0x0200 /|* we hav|
|00001f20| 65 20 64 75 6d 70 65 64 | 20 74 68 69 73 20 6e 65 |e dumped| this ne|
|00001f30| 74 27 73 20 65 64 67 65 | 73 20 2a 2f 0a 23 64 65 |t's edge|s */.#de|
|00001f40| 66 69 6e 65 20 47 41 54 | 45 57 41 59 49 4e 20 20 |fine GAT|EWAYIN |
|00001f50| 30 78 30 34 30 30 20 2f | 2a 20 68 65 61 70 65 64 |0x0400 /|* heaped|
|00001f60| 20 76 69 61 20 67 61 74 | 65 77 61 79 65 64 20 6e | via gat|ewayed n|
|00001f70| 65 74 20 2a 2f 0a 0a 23 | 64 65 66 69 6e 65 20 49 |et */..#|define I|
|00001f80| 53 41 44 4f 4d 41 49 4e | 28 6e 29 20 28 28 6e 29 |SADOMAIN|(n) ((n)|
|00001f90| 2d 3e 6e 5f 6e 61 6d 65 | 5b 30 5d 20 3d 3d 20 27 |->n_name|[0] == '|
|00001fa0| 2e 27 29 0a 23 64 65 66 | 69 6e 65 20 49 53 41 4e |.').#def|ine ISAN|
|00001fb0| 45 54 28 6e 29 20 28 28 | 28 6e 29 2d 3e 6e 5f 66 |ET(n) ((|(n)->n_f|
|00001fc0| 6c 61 67 20 26 20 4e 4e | 45 54 29 20 7c 7c 20 49 |lag & NN|ET) || I|
|00001fd0| 53 41 44 4f 4d 41 49 4e | 28 6e 29 29 0a 23 64 65 |SADOMAIN|(n)).#de|
|00001fe0| 66 69 6e 65 20 44 45 41 | 44 48 4f 53 54 28 6e 29 |fine DEA|DHOST(n)|
|00001ff0| 20 28 28 28 6e 29 2d 3e | 6e 5f 66 6c 61 67 20 26 | (((n)->|n_flag &|
|00002000| 20 28 4e 4e 45 54 20 7c | 20 4e 44 45 41 44 29 29 | (NNET || NDEAD))|
|00002010| 20 3d 3d 20 4e 44 45 41 | 44 29 0a 23 64 65 66 69 | == NDEA|D).#defi|
|00002020| 6e 65 20 47 41 54 45 57 | 41 59 45 44 28 6e 29 20 |ne GATEW|AYED(n) |
|00002030| 28 28 28 6e 29 2d 3e 6e | 5f 66 6c 61 67 20 26 20 |(((n)->n|_flag & |
|00002040| 28 4e 4e 45 54 20 7c 20 | 4e 44 45 41 44 29 29 20 |(NNET | |NDEAD)) |
|00002050| 3d 3d 20 28 4e 4e 45 54 | 20 7c 20 4e 44 45 41 44 |== (NNET| | NDEAD|
|00002060| 29 20 7c 7c 20 49 53 41 | 44 4f 4d 41 49 4e 28 6e |) || ISA|DOMAIN(n|
|00002070| 29 29 0a 0a 0a 2f 2a 0a | 20 2a 20 73 61 76 65 20 |)).../*.| * save |
|00002080| 73 6f 6d 65 20 73 70 61 | 63 65 20 69 6e 20 6e 6f |some spa|ce in no|
|00002090| 64 65 73 20 2d 2d 20 74 | 68 65 72 65 20 61 72 65 |des -- t|here are|
|000020a0| 20 3e 20 31 30 2c 30 30 | 30 20 61 6c 6c 6f 63 61 | > 10,00|0 alloca|
|000020b0| 74 65 64 21 0a 20 2a 0a | 20 2a 09 6e 6f 64 65 09 |ted!. *.| *.node.|
|000020c0| 2a 6e 5f 6e 65 74 09 09 | 6f 74 68 65 72 73 20 69 |*n_net..|others i|
|000020d0| 6e 20 74 68 69 73 20 6e | 65 74 77 6f 72 6b 20 28 |n this n|etwork (|
|000020e0| 70 61 72 73 69 6e 67 29 | 0a 20 2a 20 09 6e 6f 64 |parsing)|. * .nod|
|000020f0| 65 09 2a 6e 5f 72 6f 6f | 74 09 09 72 6f 6f 74 20 |e.*n_roo|t..root |
|00002100| 6f 66 20 6e 65 74 20 63 | 79 63 6c 65 20 28 6d 61 |of net c|ycle (ma|
|00002110| 70 70 69 6e 67 29 0a 20 | 2a 0a 20 2a 09 6e 6f 64 |pping). |*. *.nod|
|00002120| 65 09 2a 6e 5f 70 72 69 | 76 61 74 65 09 6f 74 68 |e.*n_pri|vate.oth|
|00002130| 65 72 20 70 72 69 76 61 | 74 65 73 20 69 6e 20 74 |er priva|tes in t|
|00002140| 68 69 73 20 66 69 6c 65 | 20 28 70 61 72 73 69 6e |his file| (parsin|
|00002150| 67 29 0a 20 2a 09 63 68 | 61 72 09 2a 6e 5f 70 61 |g). *.ch|ar.*n_pa|
|00002160| 72 65 6e 74 09 70 61 72 | 65 6e 74 20 69 6e 20 73 |rent.par|ent in s|
|00002170| 68 6f 72 74 65 73 74 20 | 70 61 74 68 20 74 72 65 |hortest |path tre|
|00002180| 65 20 28 6d 61 70 70 69 | 6e 67 29 0a 20 2a 09 09 |e (mappi|ng). *..|
|00002190| 0a 20 2a 2f 0a 0a 23 64 | 65 66 69 6e 65 20 6e 5f |. */..#d|efine n_|
|000021a0| 72 6f 6f 74 20 6e 5f 6e | 65 74 5f 72 6f 6f 74 0a |root n_n|et_root.|
|000021b0| 23 64 65 66 69 6e 65 20 | 6e 5f 6e 65 74 20 6e 5f |#define |n_net n_|
|000021c0| 6e 65 74 5f 72 6f 6f 74 | 0a 0a 23 64 65 66 69 6e |net_root|..#defin|
|000021d0| 65 20 6e 5f 70 72 69 76 | 61 74 65 20 6e 5f 70 72 |e n_priv|ate n_pr|
|000021e0| 69 76 61 74 65 5f 70 61 | 72 65 6e 74 0a 23 64 65 |ivate_pa|rent.#de|
|000021f0| 66 69 6e 65 20 6e 5f 70 | 61 72 65 6e 74 20 20 6e |fine n_p|arent n|
|00002200| 5f 70 72 69 76 61 74 65 | 5f 70 61 72 65 6e 74 0a |_private|_parent.|
|00002210| 0a 2f 2a 20 57 41 52 4e | 49 4e 47 3a 20 69 66 20 |./* WARN|ING: if |
|00002220| 3e 20 32 5e 31 36 20 6e | 6f 64 65 73 2c 20 74 79 |> 2^16 n|odes, ty|
|00002230| 70 65 20 6f 66 20 6e 5f | 74 6c 6f 63 20 6d 75 73 |pe of n_|tloc mus|
|00002240| 74 20 63 68 61 6e 67 65 | 20 2a 2f 0a 73 74 72 75 |t change| */.stru|
|00002250| 63 74 20 6e 6f 64 65 20 | 7b 0a 09 63 68 61 72 09 |ct node |{..char.|
|00002260| 2a 6e 5f 6e 61 6d 65 3b | 09 2f 2a 20 68 6f 73 74 |*n_name;|./* host|
|00002270| 20 6e 61 6d 65 20 2a 2f | 0a 09 6c 69 6e 6b 09 2a | name */|..link.*|
|00002280| 6e 5f 6c 69 6e 6b 3b 09 | 2f 2a 20 68 65 61 64 20 |n_link;.|/* head |
|00002290| 6f 66 20 61 64 6a 61 63 | 65 6e 63 79 20 6c 69 73 |of adjac|ency lis|
|000022a0| 74 20 2a 2f 0a 09 6e 6f | 64 65 20 09 2a 6e 5f 6e |t */..no|de .*n_n|
|000022b0| 65 74 5f 72 6f 6f 74 3b | 0a 09 6e 6f 64 65 09 2a |et_root;|..node.*|
|000022c0| 6e 5f 70 72 69 76 61 74 | 65 5f 70 61 72 65 6e 74 |n_privat|e_parent|
|000022d0| 3b 0a 09 43 6f 73 74 09 | 6e 5f 63 6f 73 74 3b 09 |;..Cost.|n_cost;.|
|000022e0| 09 2f 2a 20 63 6f 73 74 | 20 74 6f 20 74 68 69 73 |./* cost| to this|
|000022f0| 20 68 6f 73 74 20 2a 2f | 0a 09 75 6e 73 69 67 6e | host */|..unsign|
|00002300| 65 64 20 73 68 6f 72 74 | 09 6e 5f 74 6c 6f 63 3b |ed short|.n_tloc;|
|00002310| 09 2f 2a 20 62 61 63 6b | 20 70 74 72 20 74 6f 20 |./* back| ptr to |
|00002320| 68 65 61 70 2f 68 61 73 | 68 20 74 61 62 6c 65 20 |heap/has|h table |
|00002330| 2a 2f 0a 09 73 68 6f 72 | 74 09 6e 5f 66 6c 61 67 |*/..shor|t.n_flag|
|00002340| 3b 09 09 2f 2a 20 73 65 | 65 20 6d 61 6e 69 66 65 |;../* se|e manife|
|00002350| 73 74 73 20 61 62 6f 76 | 65 20 2a 2f 0a 7d 3b 0a |sts abov|e */.};.|
|00002360| 0a 23 64 65 66 69 6e 65 | 09 44 45 46 4e 45 54 09 |.#define|.DEFNET.|
|00002370| 27 21 27 09 09 09 2f 2a | 20 64 65 66 61 75 6c 74 |'!'.../*| default|
|00002380| 20 6e 65 74 77 6f 72 6b | 20 6f 70 65 72 61 74 6f | network| operato|
|00002390| 72 20 2a 2f 0a 23 64 65 | 66 69 6e 65 09 44 45 46 |r */.#de|fine.DEF|
|000023a0| 44 49 52 09 4c 4c 45 46 | 54 09 09 09 2f 2a 20 68 |DIR.LLEF|T.../* h|
|000023b0| 6f 73 74 20 6f 6e 20 6c | 65 66 74 20 69 73 20 64 |ost on l|eft is d|
|000023c0| 65 66 61 75 6c 74 20 2a | 2f 0a 23 64 65 66 69 6e |efault *|/.#defin|
|000023d0| 65 09 44 45 46 43 4f 53 | 54 09 28 28 43 6f 73 74 |e.DEFCOS|T.((Cost|
|000023e0| 29 20 34 30 30 30 29 09 | 09 2f 2a 20 64 65 66 61 |) 4000).|./* defa|
|000023f0| 75 6c 74 20 63 6f 73 74 | 20 6f 66 20 61 20 6c 69 |ult cost| of a li|
|00002400| 6e 6b 20 2a 2f 0a 23 64 | 65 66 69 6e 65 09 49 4e |nk */.#d|efine.IN|
|00002410| 46 09 28 28 43 6f 73 74 | 29 20 33 30 30 30 30 30 |F.((Cost|) 300000|
|00002420| 30 30 29 09 2f 2a 20 69 | 6e 66 69 6e 69 74 65 6c |00)./* i|nfinitel|
|00002430| 79 20 65 78 70 65 6e 73 | 69 76 65 20 6c 69 6e 6b |y expens|ive link|
|00002440| 20 2a 2f 0a 0a 2f 2a 20 | 64 61 74 61 20 73 74 72 | */../* |data str|
|00002450| 75 63 74 75 72 65 20 66 | 6f 72 20 61 64 6a 61 63 |ucture f|or adjac|
|00002460| 65 6e 63 79 20 6c 69 73 | 74 20 72 65 70 72 65 73 |ency lis|t repres|
|00002470| 65 6e 74 61 74 69 6f 6e | 20 2a 2f 0a 0a 2f 2a 20 |entation| */../* |
|00002480| 66 6c 61 67 73 20 66 6f | 72 20 6c 5f 64 69 72 20 |flags fo|r l_dir |
|00002490| 2a 2f 0a 0a 2f 2a 0a 20 | 2a 20 74 68 65 72 65 27 |*/../*. |* there'|
|000024a0| 73 20 61 6e 20 75 67 6c | 79 20 64 65 70 65 6e 64 |s an ugl|y depend|
|000024b0| 65 6e 63 79 20 62 65 74 | 77 65 65 6e 20 74 68 65 |ency bet|ween the|
|000024c0| 20 66 6f 6c 6c 6f 77 69 | 6e 67 20 6d 61 6e 69 66 | followi|ng manif|
|000024d0| 65 73 74 73 20 61 6e 64 | 20 74 68 65 0a 20 2a 20 |ests and| the. * |
|000024e0| 76 61 72 69 61 62 6c 65 | 20 4e 65 74 63 68 61 72 |variable| Netchar|
|000024f0| 73 20 3d 20 22 21 3a 5e | 40 25 22 2c 20 64 65 66 |s = "!:^|@%", def|
|00002500| 69 6e 65 64 20 69 6e 20 | 65 78 74 65 72 6e 2e 63 |ined in |extern.c|
|00002510| 2e 20 20 74 68 69 73 20 | 73 61 76 65 73 20 32 0a |. this |saves 2.|
|00002520| 20 2a 20 62 79 74 65 73 | 20 70 65 72 20 6c 69 6e | * bytes| per lin|
|00002530| 6b 20 28 6f 66 20 77 68 | 69 63 68 20 74 68 65 72 |k (of wh|ich ther|
|00002540| 65 20 61 72 65 20 77 65 | 6c 6c 20 6f 76 65 72 20 |e are we|ll over |
|00002550| 32 30 6b 29 2e 20 20 74 | 68 69 73 20 64 6f 65 73 |20k). t|his does|
|00002560| 20 6e 6f 74 0a 20 2a 20 | 6d 65 61 6e 20 69 27 6d | not. * |mean i'm|
|00002570| 20 73 61 74 73 69 66 69 | 65 64 20 77 69 74 68 20 | satsifi|ed with |
|00002580| 62 61 64 20 64 65 73 69 | 67 6e 2e 0a 20 2a 2f 0a |bad desi|gn.. */.|
|00002590| 23 64 65 66 69 6e 65 20 | 4e 45 54 44 49 52 28 6c |#define |NETDIR(l|
|000025a0| 29 09 28 28 6c 29 2d 3e | 6c 5f 66 6c 61 67 20 26 |).((l)->|l_flag &|
|000025b0| 20 4c 44 49 52 29 0a 23 | 64 65 66 69 6e 65 20 4e | LDIR).#|define N|
|000025c0| 45 54 43 48 41 52 28 6c | 29 09 28 4e 65 74 63 68 |ETCHAR(l|).(Netch|
|000025d0| 61 72 73 5b 28 6c 29 2d | 3e 6c 5f 66 6c 61 67 20 |ars[(l)-|>l_flag |
|000025e0| 26 20 4c 4e 45 54 43 48 | 41 52 53 5d 29 0a 0a 23 |& LNETCH|ARS])..#|
|000025f0| 64 65 66 69 6e 65 20 4c | 4e 45 54 43 48 41 52 53 |define L|NETCHARS|
|00002600| 09 30 78 33 0a 23 64 65 | 66 69 6e 65 20 4c 42 41 |.0x3.#de|fine LBA|
|00002610| 4e 47 09 09 30 78 30 0a | 23 64 65 66 69 6e 65 20 |NG..0x0.|#define |
|00002620| 4c 43 4f 4c 4f 4e 09 09 | 30 78 31 0a 23 64 65 66 |LCOLON..|0x1.#def|
|00002630| 69 6e 65 20 4c 41 54 09 | 09 30 78 32 0a 23 64 65 |ine LAT.|.0x2.#de|
|00002640| 66 69 6e 65 20 4c 50 45 | 52 43 45 4e 54 09 30 78 |fine LPE|RCENT.0x|
|00002650| 33 0a 0a 23 64 65 66 69 | 6e 65 20 4c 44 49 52 09 |3..#defi|ne LDIR.|
|00002660| 30 78 38 09 2f 2a 20 30 | 20 66 6f 72 20 6c 65 66 |0x8./* 0| for lef|
|00002670| 74 2c 20 31 20 66 6f 72 | 20 72 69 67 68 74 20 2a |t, 1 for| right *|
|00002680| 2f 0a 23 64 65 66 69 6e | 65 20 4c 52 49 47 48 54 |/.#defin|e LRIGHT|
|00002690| 09 30 78 30 09 2f 2a 20 | 75 73 65 72 40 68 6f 73 |.0x0./* |user@hos|
|000026a0| 74 20 73 74 79 6c 65 20 | 2a 2f 0a 23 64 65 66 69 |t style |*/.#defi|
|000026b0| 6e 65 20 4c 4c 45 46 54 | 09 30 78 38 09 2f 2a 20 |ne LLEFT|.0x8./* |
|000026c0| 68 6f 73 74 21 75 73 65 | 72 20 73 74 79 6c 65 20 |host!use|r style |
|000026d0| 2a 2f 0a 0a 23 64 65 66 | 69 6e 65 20 4c 44 45 41 |*/..#def|ine LDEA|
|000026e0| 44 09 20 30 78 31 30 09 | 2f 2a 20 74 68 69 73 20 |D. 0x10.|/* this |
|000026f0| 6c 69 6e 6b 20 69 73 20 | 64 65 61 64 20 2a 2f 0a |link is |dead */.|
|00002700| 23 64 65 66 69 6e 65 20 | 4c 54 52 45 45 09 20 30 |#define |LTREE. 0|
|00002710| 78 32 30 09 2f 2a 20 6d | 65 6d 62 65 72 20 6f 66 |x20./* m|ember of|
|00002720| 20 73 68 6f 72 74 65 73 | 74 20 70 61 74 68 20 74 | shortes|t path t|
|00002730| 72 65 65 20 2a 2f 0a 23 | 64 65 66 69 6e 65 20 4c |ree */.#|define L|
|00002740| 41 4c 49 41 53 09 20 30 | 78 34 30 09 2f 2a 20 61 |ALIAS. 0|x40./* a|
|00002750| 6c 69 61 73 20 2a 2f 0a | 23 64 65 66 69 6e 65 20 |lias */.|#define |
|00002760| 4c 47 41 54 45 57 41 59 | 20 30 78 38 30 09 2f 2a |LGATEWAY| 0x80./*|
|00002770| 20 74 68 69 73 20 6c 69 | 6e 6b 20 69 73 20 61 20 | this li|nk is a |
|00002780| 67 61 74 65 77 61 79 20 | 2a 2f 0a 0a 2f 2a 0a 20 |gateway |*/../*. |
|00002790| 2a 20 62 6f 72 72 6f 77 | 20 61 20 66 69 65 6c 64 |* borrow| a field|
|000027a0| 20 66 6f 72 20 6c 69 6e | 6b 2f 6e 6f 64 65 20 74 | for lin|k/node t|
|000027b0| 72 61 63 69 6e 67 0a 20 | 2a 0a 20 2a 09 6c 69 6e |racing. |*. *.lin|
|000027c0| 6b 09 2a 6c 5f 6e 65 78 | 74 3b 09 72 65 73 74 20 |k.*l_nex|t;.rest |
|000027d0| 6f 66 20 61 64 6a 61 63 | 65 6e 63 79 20 6c 69 73 |of adjac|ency lis|
|000027e0| 74 20 28 6e 6f 74 20 74 | 72 61 63 69 6e 67 29 0a |t (not t|racing).|
|000027f0| 20 2a 09 6c 69 6e 6b 09 | 2a 6c 5f 66 72 6f 6d 3b | *.link.|*l_from;|
|00002800| 09 73 6f 75 72 63 65 20 | 6e 6f 64 65 20 28 74 72 |.source |node (tr|
|00002810| 61 63 69 6e 67 29 20 2d | 2d 20 72 65 71 75 69 72 |acing) -|- requir|
|00002820| 65 73 20 61 20 63 61 73 | 74 0a 20 2a 09 09 0a 20 |es a cas|t. *... |
|00002830| 2a 2f 0a 0a 23 64 65 66 | 69 6e 65 20 6c 5f 6e 65 |*/..#def|ine l_ne|
|00002840| 78 74 09 6c 5f 6e 65 78 | 74 5f 66 72 6f 6d 0a 23 |xt.l_nex|t_from.#|
|00002850| 64 65 66 69 6e 65 20 6c | 5f 66 72 6f 6d 09 6c 5f |define l|_from.l_|
|00002860| 6e 65 78 74 5f 66 72 6f | 6d 0a 0a 73 74 72 75 63 |next_fro|m..struc|
|00002870| 74 20 6c 69 6e 6b 20 7b | 0a 09 6c 69 6e 6b 09 2a |t link {|..link.*|
|00002880| 6c 5f 6e 65 78 74 5f 66 | 72 6f 6d 3b 0a 09 6e 6f |l_next_f|rom;..no|
|00002890| 64 65 09 2a 6c 5f 74 6f | 3b 09 09 2f 2a 20 61 64 |de.*l_to|;../* ad|
|000028a0| 6a 61 63 65 6e 74 20 6e | 6f 64 65 20 2a 2f 0a 09 |jacent n|ode */..|
|000028b0| 43 6f 73 74 09 6c 5f 63 | 6f 73 74 3b 09 09 2f 2a |Cost.l_c|ost;../*|
|000028c0| 20 65 64 67 65 20 63 6f | 73 74 20 2a 2f 0a 09 63 | edge co|st */..c|
|000028d0| 68 61 72 09 6c 5f 66 6c | 61 67 3b 09 09 2f 2a 20 |har.l_fl|ag;../* |
|000028e0| 72 69 67 68 74 2f 6c 65 | 66 74 20 73 79 6e 74 61 |right/le|ft synta|
|000028f0| 78 20 2a 2f 0a 7d 3b 0a | 0a 2f 2a 0a 20 2a 20 73 |x */.};.|./*. * s|
|00002900| 74 61 74 69 63 20 66 75 | 6e 63 74 69 6f 6e 73 20 |tatic fu|nctions |
|00002910| 64 6f 6e 27 74 20 73 68 | 6f 77 20 75 70 20 69 6e |don't sh|ow up in|
|00002920| 20 70 72 6f 66 28 31 29 | 2c 20 73 6f 20 2e 2e 2e | prof(1)|, so ...|
|00002930| 0a 20 2a 20 73 6f 6d 65 | 64 61 79 20 69 27 6c 6c |. * some|day i'll|
|00002940| 20 62 65 20 64 6f 6e 65 | 20 70 72 6f 66 69 6c 69 | be done| profili|
|00002950| 6e 67 2e 0a 20 2a 20 79 | 65 61 68 2c 20 73 75 72 |ng.. * y|eah, sur|
|00002960| 65 2c 20 6c 69 6b 65 20 | 77 68 65 6e 20 68 65 6c |e, like |when hel|
|00002970| 6c 20 66 72 65 65 7a 65 | 73 20 6f 76 65 72 2e 0a |l freeze|s over..|
|00002980| 20 2a 2f 0a 23 64 65 66 | 69 6e 65 20 53 54 41 54 | */.#def|ine STAT|
|00002990| 49 43 20 2f 2a 73 74 61 | 74 69 63 2a 2f 0a 0a 2f |IC /*sta|tic*/../|
|000029a0| 2a 20 65 78 74 65 72 6e | 61 6c 20 66 75 6e 63 74 |* extern|al funct|
|000029b0| 69 6f 6e 73 20 2a 2f 0a | 65 78 74 65 72 6e 20 6e |ions */.|extern n|
|000029c0| 6f 64 65 09 2a 61 64 64 | 6e 6f 64 65 28 29 2c 20 |ode.*add|node(), |
|000029d0| 2a 6e 65 77 6e 6f 64 65 | 28 29 2c 20 2a 2a 6e 65 |*newnode|(), **ne|
|000029e0| 77 74 61 62 6c 65 28 29 | 2c 20 2a 61 64 64 70 72 |wtable()|, *addpr|
|000029f0| 69 76 61 74 65 28 29 3b | 0a 65 78 74 65 72 6e 20 |ivate();|.extern |
|00002a00| 6c 69 6e 6b 09 2a 61 64 | 64 6c 69 6e 6b 28 29 2c |link.*ad|dlink(),|
|00002a10| 20 2a 61 64 64 67 61 74 | 65 77 61 79 28 29 2c 20 | *addgat|eway(), |
|00002a20| 2a 6e 65 77 6c 69 6e 6b | 28 29 3b 0a 65 78 74 65 |*newlink|();.exte|
|00002a30| 72 6e 20 63 68 61 72 09 | 2a 73 74 72 73 61 76 65 |rn char.|*strsave|
|00002a40| 28 29 2c 20 2a 6c 6f 63 | 61 6c 28 29 3b 0a 65 78 |(), *loc|al();.ex|
|00002a50| 74 65 72 6e 20 76 6f 69 | 64 09 70 61 63 6b 28 29 |tern voi|d.pack()|
|00002a60| 3b 0a 0a 2f 2a 20 65 78 | 74 65 72 6e 61 6c 20 76 |;../* ex|ternal v|
|00002a70| 61 72 69 61 62 6c 65 73 | 20 2a 2f 0a 65 78 74 65 |ariables| */.exte|
|00002a80| 72 6e 20 63 68 61 72 09 | 2a 6f 70 74 61 72 67 3b |rn char.|*optarg;|
|00002a90| 0a 65 78 74 65 72 6e 20 | 69 6e 74 09 6f 70 74 69 |.extern |int.opti|
|00002aa0| 6e 64 3b 0a 65 78 74 65 | 72 6e 20 6e 6f 64 65 09 |nd;.exte|rn node.|
|00002ab0| 2a 48 6f 6d 65 3b 0a 65 | 78 74 65 72 6e 20 63 68 |*Home;.e|xtern ch|
|00002ac0| 61 72 09 2a 43 66 69 6c | 65 3b 0a 65 78 74 65 72 |ar.*Cfil|e;.exter|
|00002ad0| 6e 20 63 68 61 72 09 2a | 2a 49 66 69 6c 65 73 3b |n char.*|*Ifiles;|
|00002ae0| 0a 65 78 74 65 72 6e 20 | 63 68 61 72 09 2a 50 72 |.extern |char.*Pr|
|00002af0| 6f 67 4e 61 6d 65 3b 0a | 65 78 74 65 72 6e 20 69 |ogName;.|extern i|
|00002b00| 6e 74 09 4c 69 6e 65 6e | 6f 3b 0a 65 78 74 65 72 |nt.Linen|o;.exter|
|00002b10| 6e 20 6e 6f 64 65 09 2a | 2a 54 61 62 6c 65 3b 0a |n node.*|*Table;.|
|00002b20| 65 78 74 65 72 6e 20 6c | 6f 6e 67 09 54 61 62 73 |extern l|ong.Tabs|
|00002b30| 69 7a 65 3b 0a 65 78 74 | 65 72 6e 20 63 68 61 72 |ize;.ext|ern char|
|00002b40| 09 2a 4e 65 74 63 68 61 | 72 73 3b 0a 65 78 74 65 |.*Netcha|rs;.exte|
|00002b50| 72 6e 20 69 6e 74 09 56 | 66 6c 61 67 3b 0a 65 78 |rn int.V|flag;.ex|
|00002b60| 74 65 72 6e 20 69 6e 74 | 09 43 66 6c 61 67 3b 0a |tern int|.Cflag;.|
|00002b70| 65 78 74 65 72 6e 20 69 | 6e 74 09 49 66 6c 61 67 |extern i|nt.Iflag|
|00002b80| 3b 0a 65 78 74 65 72 6e | 20 69 6e 74 09 54 66 6c |;.extern| int.Tfl|
|00002b90| 61 67 3b 0a 65 78 74 65 | 72 6e 20 69 6e 74 09 4e |ag;.exte|rn int.N|
|00002ba0| 63 6f 75 6e 74 3b 0a 65 | 78 74 65 72 6e 20 69 6e |count;.e|xtern in|
|00002bb0| 74 09 4c 63 6f 75 6e 74 | 3b 0a 65 78 74 65 72 6e |t.Lcount|;.extern|
|00002bc0| 20 63 68 61 72 09 2a 47 | 72 61 70 68 6f 75 74 3b | char.*G|raphout;|
|00002bd0| 0a 65 78 74 65 72 6e 20 | 63 68 61 72 09 2a 4c 69 |.extern |char.*Li|
|00002be0| 6e 6b 6f 75 74 3b 0a 65 | 78 74 65 72 6e 20 6e 6f |nkout;.e|xtern no|
|00002bf0| 64 65 09 2a 50 72 69 76 | 61 74 65 3b 0a 65 78 74 |de.*Priv|ate;.ext|
|00002c00| 65 72 6e 20 6c 6f 6e 67 | 09 48 61 73 68 70 61 72 |ern long|.Hashpar|
|00002c10| 74 3b 0a 65 78 74 65 72 | 6e 20 69 6e 74 09 53 63 |t;.exter|n int.Sc|
|00002c20| 61 6e 73 74 61 74 65 3b | 0a 53 48 41 52 5f 45 4f |anstate;|.SHAR_EO|
|00002c30| 46 0a 69 66 20 74 65 73 | 74 20 34 36 38 33 20 2d |F.if tes|t 4683 -|
|00002c40| 6e 65 20 22 60 77 63 20 | 2d 63 20 3c 20 27 64 65 |ne "`wc |-c < 'de|
|00002c50| 66 2e 68 27 60 22 0a 74 | 68 65 6e 0a 09 65 63 68 |f.h'`".t|hen..ech|
|00002c60| 6f 20 73 68 61 72 3a 20 | 65 72 72 6f 72 20 74 72 |o shar: |error tr|
|00002c70| 61 6e 73 6d 69 74 74 69 | 6e 67 20 22 27 64 65 66 |ansmitti|ng "'def|
|00002c80| 2e 68 27 22 20 27 28 73 | 68 6f 75 6c 64 20 68 61 |.h'" '(s|hould ha|
|00002c90| 76 65 20 62 65 65 6e 20 | 34 36 38 33 20 63 68 61 |ve been |4683 cha|
|00002ca0| 72 61 63 74 65 72 73 29 | 27 0a 66 69 0a 66 69 0a |racters)|'.fi.fi.|
|00002cb0| 65 63 68 6f 20 73 68 61 | 72 3a 20 65 78 74 72 61 |echo sha|r: extra|
|00002cc0| 63 74 69 6e 67 20 22 27 | 6d 61 6b 65 2e 76 38 27 |cting "'|make.v8'|
|00002cd0| 22 20 27 28 33 35 35 35 | 20 63 68 61 72 61 63 74 |" '(3555| charact|
|00002ce0| 65 72 73 29 27 0a 69 66 | 20 74 65 73 74 20 2d 66 |ers)'.if| test -f|
|00002cf0| 20 27 6d 61 6b 65 2e 76 | 38 27 0a 74 68 65 6e 0a | 'make.v|8'.then.|
|00002d00| 09 65 63 68 6f 20 73 68 | 61 72 3a 20 77 69 6c 6c |.echo sh|ar: will|
|00002d10| 20 6e 6f 74 20 6f 76 65 | 72 2d 77 72 69 74 65 20 | not ove|r-write |
|00002d20| 65 78 69 73 74 69 6e 67 | 20 66 69 6c 65 20 22 27 |existing| file "'|
|00002d30| 6d 61 6b 65 2e 76 38 27 | 22 0a 65 6c 73 65 0a 63 |make.v8'|".else.c|
|00002d40| 61 74 20 3c 3c 20 5c 53 | 48 41 52 5f 45 4f 46 20 |at << \S|HAR_EOF |
|00002d50| 3e 20 27 6d 61 6b 65 2e | 76 38 27 0a 23 21 2f 62 |> 'make.|v8'.#!/b|
|00002d60| 69 6e 2f 6d 61 6b 65 20 | 2d 66 0a 23 20 70 61 74 |in/make |-f.# pat|
|00002d70| 68 61 6c 69 61 73 20 2d | 2d 20 62 79 20 73 74 65 |halias -|- by ste|
|00002d80| 76 65 20 62 65 6c 6c 6f | 76 69 6e 2c 20 61 73 20 |ve bello|vin, as |
|00002d90| 74 6f 6c 64 20 74 6f 20 | 70 65 74 65 72 20 68 6f |told to |peter ho|
|00002da0| 6e 65 79 6d 61 6e 0a 0a | 23 20 69 66 20 79 6f 75 |neyman..|# if you|
|00002db0| 20 63 61 6e 27 74 20 6f | 72 20 64 6f 6e 27 74 20 | can't o|r don't |
|00002dc0| 69 6e 74 65 6e 64 20 74 | 6f 20 75 73 65 20 64 62 |intend t|o use db|
|00002dd0| 6d 20 66 69 6c 65 73 2c | 20 64 6f 6e 27 74 20 62 |m files,| don't b|
|00002de0| 6f 74 68 65 72 20 77 69 | 74 68 20 6d 61 6b 65 64 |other wi|th maked|
|00002df0| 62 0a 44 42 4d 20 3d 20 | 2d 6c 64 62 6d 0a 23 20 |b.DBM = |-ldbm.# |
|00002e00| 6f 72 20 69 66 20 79 6f | 75 20 72 6f 6c 6c 20 79 |or if yo|u roll y|
|00002e10| 6f 75 72 20 6f 77 6e 20 | 2e 2e 2e 0a 23 20 44 42 |our own |....# DB|
|00002e20| 4d 20 3d 20 64 62 6d 2e | 6f 0a 0a 43 43 20 3d 20 |M = dbm.|o..CC = |
|00002e30| 63 63 20 2d 67 20 2d 70 | 0a 43 46 4c 41 47 53 20 |cc -g -p|.CFLAGS |
|00002e40| 3d 20 0a 4c 44 46 4c 41 | 47 53 20 3d 0a 59 46 4c |= .LDFLA|GS =.YFL|
|00002e50| 41 47 53 20 3d 20 2d 64 | 0a 0a 4f 42 4a 20 3d 20 |AGS = -d|..OBJ = |
|00002e60| 61 64 64 6c 69 6e 6b 2e | 6f 20 61 64 64 6e 6f 64 |addlink.|o addnod|
|00002e70| 65 2e 6f 20 65 78 74 65 | 72 6e 2e 6f 20 6c 6f 63 |e.o exte|rn.o loc|
|00002e80| 61 6c 2e 6f 20 6d 61 69 | 6e 2e 6f 20 6d 61 70 69 |al.o mai|n.o mapi|
|00002e90| 74 2e 6f 20 6d 61 70 61 | 75 78 2e 6f 20 6d 65 6d |t.o mapa|ux.o mem|
|00002ea0| 2e 6f 20 70 61 72 73 65 | 2e 6f 20 70 72 69 6e 74 |.o parse|.o print|
|00002eb0| 69 74 2e 6f 0a 48 44 52 | 53 20 3d 20 64 65 66 2e |it.o.HDR|S = def.|
|00002ec0| 68 20 63 6f 6e 66 69 67 | 2e 68 0a 43 53 52 43 20 |h config|.h.CSRC |
|00002ed0| 3d 20 61 64 64 6c 69 6e | 6b 2e 63 20 61 64 64 6e |= addlin|k.c addn|
|00002ee0| 6f 64 65 2e 63 20 65 78 | 74 65 72 6e 2e 63 20 6c |ode.c ex|tern.c l|
|00002ef0| 6f 63 61 6c 2e 63 20 6d | 61 69 6e 2e 63 20 6d 61 |ocal.c m|ain.c ma|
|00002f00| 70 69 74 2e 63 20 6d 61 | 70 61 75 78 2e 63 20 6d |pit.c ma|paux.c m|
|00002f10| 65 6d 2e 63 20 70 72 69 | 6e 74 69 74 2e 63 0a 53 |em.c pri|ntit.c.S|
|00002f20| 52 43 20 3d 20 24 28 43 | 53 52 43 29 20 70 61 72 |RC = $(C|SRC) par|
|00002f30| 73 65 2e 79 0a 4c 53 52 | 43 20 3d 20 24 28 43 53 |se.y.LSR|C = $(CS|
|00002f40| 52 43 29 20 70 61 72 73 | 65 2e 63 0a 0a 70 61 74 |RC) pars|e.c..pat|
|00002f50| 68 61 6c 69 61 73 3a 20 | 26 20 24 28 4f 42 4a 29 |halias: |& $(OBJ)|
|00002f60| 0a 09 24 28 43 43 29 20 | 24 28 4c 44 46 4c 41 47 |..$(CC) |$(LDFLAG|
|00002f70| 53 29 20 24 28 4f 42 4a | 29 20 2d 6f 20 70 61 74 |S) $(OBJ|) -o pat|
|00002f80| 68 61 6c 69 61 73 0a 0a | 61 6c 6c 3a 20 70 61 74 |halias..|all: pat|
|00002f90| 68 61 6c 69 61 73 20 6d | 61 6b 65 64 62 0a 0a 24 |halias m|akedb..$|
|00002fa0| 28 4f 42 4a 29 3a 09 64 | 65 66 2e 68 0a 0a 23 20 |(OBJ):.d|ef.h..# |
|00002fb0| 69 66 20 74 6f 75 63 68 | 20 68 61 64 20 61 20 70 |if touch| had a p|
|00002fc0| 72 6f 70 65 72 20 65 78 | 69 74 20 73 74 61 74 75 |roper ex|it statu|
|00002fd0| 73 2c 20 74 68 69 73 20 | 77 6f 75 6c 64 20 77 6f |s, this |would wo|
|00002fe0| 72 6b 2e 2e 2e 0a 64 65 | 66 2e 68 3a 20 63 6f 6e |rk....de|f.h: con|
|00002ff0| 66 69 67 2e 68 0a 09 2d | 74 6f 75 63 68 20 2d 63 |fig.h..-|touch -c|
|00003000| 20 64 65 66 2e 68 0a 09 | 67 65 74 20 2d 73 20 73 | def.h..|get -s s|
|00003010| 63 63 73 2f 73 2e 64 65 | 66 2e 68 0a 0a 70 61 72 |ccs/s.de|f.h..par|
|00003020| 73 65 2e 63 3a 20 70 61 | 72 73 65 2e 79 20 64 65 |se.c: pa|rse.y de|
|00003030| 66 2e 68 0a 09 24 28 59 | 41 43 43 29 20 24 28 59 |f.h..$(Y|ACC) $(Y|
|00003040| 46 4c 41 47 53 29 20 70 | 61 72 73 65 2e 79 0a 09 |FLAGS) p|arse.y..|
|00003050| 6d 76 20 79 2e 74 61 62 | 2e 63 20 70 61 72 73 65 |mv y.tab|.c parse|
|00003060| 2e 63 0a 0a 6d 61 6b 65 | 64 62 3a 20 6d 61 6b 65 |.c..make|db: make|
|00003070| 64 62 2e 6f 0a 09 24 28 | 43 43 29 20 6d 61 6b 65 |db.o..$(|CC) make|
|00003080| 64 62 2e 6f 20 24 28 44 | 42 4d 29 20 2d 6f 20 6d |db.o $(D|BM) -o m|
|00003090| 61 6b 65 64 62 0a 0a 6d | 61 6b 65 64 62 2e 6f 3a |akedb..m|akedb.o:|
|000030a0| 20 63 6f 6e 66 69 67 2e | 68 0a 0a 63 6c 65 61 6e | config.|h..clean|
|000030b0| 3a 0a 09 72 6d 20 2d 66 | 20 2a 2e 6f 20 79 2e 74 |:..rm -f| *.o y.t|
|000030c0| 61 62 2e 3f 20 70 61 72 | 73 65 2e 63 0a 0a 74 61 |ab.? par|se.c..ta|
|000030d0| 67 73 3a 20 24 28 53 52 | 43 29 20 24 28 48 44 52 |gs: $(SR|C) $(HDR|
|000030e0| 53 29 20 6d 61 6b 65 64 | 62 2e 63 0a 09 63 74 61 |S) maked|b.c..cta|
|000030f0| 67 73 20 2d 77 20 24 5e | 0a 0a 62 75 6e 64 6c 65 |gs -w $^|..bundle|
|00003100| 3a 20 52 45 41 44 4d 45 | 20 43 48 41 4e 47 45 53 |: README| CHANGES|
|00003110| 20 70 61 74 68 61 6c 69 | 61 73 2e 31 20 4d 61 6b | pathali|as.1 Mak|
|00003120| 65 66 69 6c 65 20 24 7b | 48 44 52 53 7d 20 24 7b |efile ${|HDRS} ${|
|00003130| 53 52 43 7d 20 6d 61 6b | 65 64 62 2e 63 20 6d 61 |SRC} mak|edb.c ma|
|00003140| 6b 65 2e 76 38 0a 09 40 | 62 75 6e 64 6c 65 20 24 |ke.v8..@|bundle $|
|00003150| 5e 0a 0a 62 75 6e 64 6c | 65 31 3a 20 52 45 41 44 |^..bundl|e1: READ|
|00003160| 4d 45 20 43 48 41 4e 47 | 45 53 20 70 61 74 68 61 |ME CHANG|ES patha|
|00003170| 6c 69 61 73 2e 31 20 4d | 61 6b 65 66 69 6c 65 20 |lias.1 M|akefile |
|00003180| 64 65 66 2e 68 20 63 6f | 6e 66 69 67 2e 68 20 61 |def.h co|nfig.h a|
|00003190| 64 64 6c 69 6e 6b 2e 63 | 0a 09 40 62 75 6e 64 6c |ddlink.c|..@bundl|
|000031a0| 65 20 24 5e 0a 0a 62 75 | 6e 64 6c 65 32 3a 20 61 |e $^..bu|ndle2: a|
|000031b0| 64 64 6e 6f 64 65 2e 63 | 20 65 78 74 65 72 6e 2e |ddnode.c| extern.|
|000031c0| 63 20 6c 6f 63 61 6c 2e | 63 20 6d 61 69 6e 2e 63 |c local.|c main.c|
|000031d0| 20 6d 61 70 69 74 2e 63 | 0a 09 40 62 75 6e 64 6c | mapit.c|..@bundl|
|000031e0| 65 20 24 5e 0a 0a 62 75 | 6e 64 6c 65 33 3a 20 6d |e $^..bu|ndle3: m|
|000031f0| 61 70 61 75 78 2e 63 20 | 6d 65 6d 2e 63 20 70 72 |apaux.c |mem.c pr|
|00003200| 69 6e 74 69 74 2e 63 20 | 70 61 72 73 65 2e 79 20 |intit.c |parse.y |
|00003210| 6d 61 6b 65 64 62 2e 63 | 20 6d 61 6b 65 2e 76 38 |makedb.c| make.v8|
|00003220| 0a 09 40 62 75 6e 64 6c | 65 20 24 5e 0a 0a 6d 61 |..@bundl|e $^..ma|
|00003230| 6b 65 2e 76 38 3a 20 6d | 61 6b 65 66 69 6c 65 0a |ke.v8: m|akefile.|
|00003240| 09 40 63 70 20 6d 61 6b | 65 66 69 6c 65 20 6d 61 |.@cp mak|efile ma|
|00003250| 6b 65 2e 76 38 0a 0a 6c | 69 6e 74 3a 09 24 28 4c |ke.v8..l|int:.$(L|
|00003260| 53 52 43 29 0a 09 6c 69 | 6e 74 20 24 28 43 46 4c |SRC)..li|nt $(CFL|
|00003270| 41 47 53 29 20 24 28 4c | 53 52 43 29 0a 09 6c 69 |AGS) $(L|SRC)..li|
|00003280| 6e 74 20 6d 61 6b 65 64 | 62 2e 63 0a 0a 23 20 76 |nt maked|b.c..# v|
|00003290| 38 20 6d 61 6b 65 20 72 | 75 6c 65 73 20 66 6f 72 |8 make r|ules for|
|000032a0| 20 73 63 63 73 0a 25 3a | 20 26 20 73 63 63 73 2f | sccs.%:| & sccs/|
|000032b0| 73 2e 25 0a 09 67 65 74 | 20 2d 73 20 73 63 63 73 |s.%..get| -s sccs|
|000032c0| 2f 73 2e 24 25 0a 0a 23 | 20 74 68 65 20 72 65 6d |/s.$%..#| the rem|
|000032d0| 61 69 6e 64 65 72 20 69 | 73 20 73 69 74 65 20 73 |ainder i|s site s|
|000032e0| 70 65 63 69 66 69 63 20 | 61 6e 64 20 63 61 6e 20 |pecific |and can |
|000032f0| 62 65 20 64 65 6c 65 74 | 65 64 2e 20 20 69 74 20 |be delet|ed. it |
|00003300| 64 6f 65 73 6e 27 74 20 | 68 61 76 65 0a 23 20 74 |doesn't |have.# t|
|00003310| 6f 20 62 65 20 74 68 69 | 73 20 63 6f 6d 70 6c 69 |o be thi|s compli|
|00003320| 63 61 74 65 64 2c 20 62 | 75 74 20 61 20 6d 61 6b |cated, b|ut a mak|
|00003330| 65 66 69 6c 65 20 74 65 | 6e 64 73 20 74 6f 20 73 |efile te|nds to s|
|00003340| 77 65 6c 6c 20 61 66 74 | 65 72 20 74 68 72 65 65 |well aft|er three|
|00003350| 20 6f 72 0a 23 20 66 6f | 75 72 20 79 65 61 72 73 | or.# fo|ur years|
|00003360| 2e 0a 0a 23 20 68 6f 73 | 74 73 20 72 75 6e 6e 69 |...# hos|ts runni|
|00003370| 6e 67 20 64 65 6c 69 76 | 65 72 6d 61 69 6c 0a 44 |ng deliv|ermail.D|
|00003380| 45 4c 49 56 45 52 4d 41 | 49 4c 20 3d 20 74 69 6c |ELIVERMA|IL = til|
|00003390| 74 0a 0a 23 20 68 6f 73 | 74 73 20 72 75 6e 6e 69 |t..# hos|ts runni|
|000033a0| 6e 67 20 73 65 6e 64 6d | 61 69 6c 0a 53 45 4e 44 |ng sendm|ail.SEND|
|000033b0| 4d 41 49 4c 20 3d 20 71 | 75 69 72 6b 79 20 66 6c |MAIL = q|uirky fl|
|000033c0| 61 6b 65 79 20 79 6f 79 | 6f 20 70 61 6e 69 63 0a |akey yoy|o panic.|
|000033d0| 0a 23 20 61 6c 6c 20 6e | 65 69 67 68 62 6f 72 73 |.# all n|eighbors|
|000033e0| 0a 4e 45 49 47 48 42 4f | 52 53 20 3d 20 70 72 69 |.NEIGHBO|RS = pri|
|000033f0| 6e 63 65 74 6f 6e 20 24 | 7b 44 45 4c 49 56 45 52 |nceton $|{DELIVER|
|00003400| 4d 41 49 4c 7d 20 24 7b | 53 45 4e 44 4d 41 49 4c |MAIL} ${|SENDMAIL|
|00003410| 7d 0a 0a 23 20 69 6e 63 | 6c 75 64 69 6e 67 20 6d |}..# inc|luding m|
|00003420| 65 0a 53 49 54 45 53 20 | 3d 20 64 6f 77 6e 20 24 |e.SITES |= down $|
|00003430| 7b 4e 45 49 47 48 42 4f | 52 53 7d 0a 0a 50 41 54 |{NEIGHBO|RS}..PAT|
|00003440| 48 46 49 4c 45 53 20 3d | 20 70 61 74 68 73 2f 5b |HFILES =| paths/[|
|00003450| 5e 2e 5d 2a 20 70 61 74 | 68 73 2e 62 65 6c 6c 2f |^.]* pat|hs.bell/|
|00003460| 5b 5e 2e 5d 2a 20 70 61 | 74 68 73 2e 69 6e 74 65 |[^.]* pa|ths.inte|
|00003470| 72 6e 65 74 2f 5b 5e 2e | 5d 2a 20 70 61 74 68 2e |rnet/[^.|]* path.|
|00003480| 6d 61 70 2f 5b 5e 2e 5d | 2a 0a 0a 23 20 66 72 6f |map/[^.]|*..# fro|
|00003490| 6d 20 6f 62 73 65 72 76 | 61 74 69 6f 6e 20 61 6e |m observ|ation an|
|000034a0| 64 20 72 75 6d 6f 72 2e | 20 20 61 76 6f 69 64 20 |d rumor.| avoid |
|000034b0| 6c 69 6b 65 20 74 68 65 | 20 70 6c 61 67 75 65 0a |like the| plague.|
|000034c0| 44 45 41 44 48 4f 53 54 | 53 20 3d 20 2d 64 20 74 |DEADHOST|S = -d t|
|000034d0| 75 63 63 20 2d 64 20 6e | 65 74 77 6f 72 64 20 2d |ucc -d n|etword -|
|000034e0| 64 20 68 61 72 76 61 72 | 64 20 2d 64 20 77 68 75 |d harvar|d -d whu|
|000034f0| 78 6c 62 20 2d 64 20 63 | 6f 6e 65 6a 6f 0a 0a 44 |xlb -d c|onejo..D|
|00003500| 45 41 44 4c 49 4e 4b 53 | 20 3d 20 2d 64 20 73 69 |EADLINKS| = -d si|
|00003510| 65 6d 65 6e 73 21 75 69 | 75 63 64 63 73 20 2d 64 |emens!ui|ucdcs -d|
|00003520| 20 61 6c 6c 65 67 72 61 | 21 72 63 61 6c 61 62 73 | allegra|!rcalabs|
|00003530| 20 2d 64 20 61 6d 64 63 | 61 64 21 63 68 69 20 2d | -d amdc|ad!chi -|
|00003540| 64 20 61 6c 6c 65 67 72 | 61 21 73 68 61 73 74 61 |d allegr|a!shasta|
|00003550| 20 2d 64 20 61 6c 6c 65 | 67 72 61 21 6f 6c 79 6d | -d alle|gra!olym|
|00003560| 70 75 73 20 2d 64 20 73 | 68 61 73 74 61 21 69 6d |pus -d s|hasta!im|
|00003570| 61 67 65 6e 0a 0a 44 45 | 41 44 4e 45 54 53 20 3d |agen..DE|ADNETS =|
|00003580| 20 2d 64 20 69 6e 74 65 | 72 6e 65 74 0a 0a 44 45 | -d inte|rnet..DE|
|00003590| 41 44 20 3d 20 24 7b 44 | 45 41 44 48 4f 53 54 53 |AD = ${D|EADHOSTS|
|000035a0| 7d 20 24 7b 44 45 41 44 | 4c 49 4e 4b 53 7d 20 24 |} ${DEAD|LINKS} $|
|000035b0| 7b 44 45 41 44 4e 45 54 | 53 7d 0a 0a 23 20 6d 61 |{DEADNET|S}..# ma|
|000035c0| 70 20 6f 75 74 70 75 74 | 20 28 69 6e 70 75 74 2c |p output| (input,|
|000035d0| 20 72 65 61 6c 6c 79 29 | 20 74 6f 20 6c 6f 77 65 | really)| to lowe|
|000035e0| 72 20 63 61 73 65 2e 20 | 20 64 65 61 64 20 6c 69 |r case. | dead li|
|000035f0| 6e 6b 73 2e 0a 41 52 47 | 53 20 3d 20 2d 69 0a 0a |nks..ARG|S = -i..|
|00003600| 70 61 74 68 73 3a 09 24 | 7b 53 49 54 45 53 7d 0a |paths:.$|{SITES}.|
|00003610| 0a 64 6f 77 6e 3a 09 70 | 61 74 68 73 2f 70 72 69 |.down:.p|aths/pri|
|00003620| 6e 63 65 74 6f 6e 0a 09 | 74 69 6d 65 20 2d 76 20 |nceton..|time -v |
|00003630| 70 61 74 68 61 6c 69 61 | 73 20 2d 76 20 24 7b 41 |pathalia|s -v ${A|
|00003640| 52 47 53 7d 20 24 28 44 | 45 41 44 29 20 24 28 50 |RGS} $(D|EAD) $(P|
|00003650| 41 54 48 46 49 4c 45 53 | 29 20 32 3e 45 52 52 4f |ATHFILES|) 2>ERRO|
|00003660| 52 53 20 3e 20 64 6f 77 | 6e 2e 6e 65 77 0a 09 73 |RS > dow|n.new..s|
|00003670| 6f 72 74 20 2d 6f 20 64 | 6f 77 6e 20 64 6f 77 6e |ort -o d|own down|
|00003680| 2e 6e 65 77 0a 0a 23 20 | 44 45 4c 49 56 45 52 4d |.new..# |DELIVERM|
|00003690| 41 49 4c 20 61 6e 64 20 | 53 45 4e 44 4d 41 49 4c |AIL and |SENDMAIL|
|000036a0| 20 68 61 76 65 20 65 78 | 61 63 74 6c 79 20 74 68 | have ex|actly th|
|000036b0| 65 20 73 61 6d 65 20 6c | 69 6e 6b 73 20 61 73 20 |e same l|inks as |
|000036c0| 64 6f 77 6e 2c 20 73 6f | 20 74 75 72 6e 0a 23 09 |down, so| turn.#.|
|000036d0| 64 6f 77 6e 09 25 73 0a | 23 09 75 70 09 75 70 21 |down.%s.|#.up.up!|
|000036e0| 25 73 0a 23 20 69 6e 74 | 6f 0a 23 09 75 70 09 25 |%s.# int|o.#.up.%|
|000036f0| 73 0a 23 09 64 6f 77 6e | 09 64 6f 77 6e 21 25 73 |s.#.down|.down!%s|
|00003700| 0a 0a 24 7b 44 45 4c 49 | 56 45 52 4d 41 49 4c 7d |..${DELI|VERMAIL}|
|00003710| 3a 09 64 6f 77 6e 0a 09 | 73 65 64 20 2d 65 20 27 |:.down..|sed -e '|
|00003720| 73 2f 5e 64 6f 77 6e 09 | 25 73 24 24 2f 24 40 09 |s/^down.|%s$$/$@.|
|00003730| 25 73 2f 27 20 5c 0a 09 | 20 20 20 20 2d 65 20 27 |%s/' \..| -e '|
|00003740| 73 2f 5e 24 40 09 24 40 | 21 25 73 24 24 2f 64 6f |s/^$@.$@|!%s$$/do|
|00003750| 77 6e 09 64 6f 77 6e 21 | 25 73 2f 27 5c 0a 09 20 |wn.down!|%s/'\.. |
|00003760| 20 20 20 2d 65 20 27 73 | 2f 5e 2f 30 09 2f 27 20 | -e 's|/^/0./' |
|00003770| 64 6f 77 6e 20 7c 20 73 | 6f 72 74 20 3e 20 24 40 |down | s|ort > $@|
|00003780| 0a 09 0a 23 20 72 65 6f | 72 64 65 72 20 74 68 65 |...# reo|rder the|
|00003790| 20 6f 75 74 70 75 74 20 | 61 6e 64 20 67 65 6e 65 | output |and gene|
|000037a0| 72 61 74 65 20 70 68 6f | 6e 65 79 20 63 6f 73 74 |rate pho|ney cost|
|000037b0| 73 20 66 6f 72 20 73 65 | 6e 64 6d 61 69 6c 20 6e |s for se|ndmail n|
|000037c0| 65 69 67 68 62 6f 72 73 | 0a 24 7b 53 45 4e 44 4d |eighbors|.${SENDM|
|000037d0| 41 49 4c 7d 3a 20 64 6f | 77 6e 0a 09 73 65 64 20 |AIL}: do|wn..sed |
|000037e0| 2d 65 20 27 73 2f 5e 64 | 6f 77 6e 09 25 73 24 24 |-e 's/^d|own.%s$$|
|000037f0| 2f 24 40 09 25 73 2f 27 | 20 5c 0a 09 20 20 20 20 |/$@.%s/'| \.. |
|00003800| 20 2d 65 20 27 73 2f 24 | 40 09 24 40 21 25 73 24 | -e 's/$|@.$@!%s$|
|00003810| 24 2f 64 6f 77 6e 09 64 | 6f 77 6e 21 25 73 2f 27 |$/down.d|own!%s/'|
|00003820| 5c 0a 09 20 20 20 20 20 | 2d 65 20 27 73 2f 09 2f |\.. |-e 's/./|
|00003830| 09 30 09 2f 27 20 64 6f | 77 6e 20 7c 73 6f 72 74 |.0./' do|wn |sort|
|00003840| 20 3e 20 24 40 0a 0a 23 | 20 69 6e 73 74 61 6c 6c | > $@..#| install|
|00003850| 20 65 76 65 72 79 77 68 | 65 72 65 0a 73 68 69 70 | everywh|ere.ship|
|00003860| 69 74 3a 20 24 7b 4e 45 | 49 47 48 42 4f 52 53 7d |it: ${NE|IGHBORS}|
|00003870| 0a 09 66 6f 72 20 69 20 | 69 6e 20 24 7b 53 45 4e |..for i |in ${SEN|
|00003880| 44 4d 41 49 4c 7d 20 70 | 72 69 6e 63 65 74 6f 6e |DMAIL} p|rinceton|
|00003890| 3b 20 64 6f 20 63 70 20 | 24 24 69 20 2f 6e 2f 24 |; do cp |$$i /n/$|
|000038a0| 24 69 2f 75 73 72 2f 6c | 6f 63 61 6c 2f 6c 69 62 |$i/usr/l|ocal/lib|
|000038b0| 2f 70 61 74 68 61 6c 69 | 61 73 65 73 3b 20 64 6f |/pathali|ases; do|
|000038c0| 6e 65 0a 09 66 6f 72 20 | 69 20 69 6e 20 24 7b 44 |ne..for |i in ${D|
|000038d0| 45 4c 49 56 45 52 4d 41 | 49 4c 7d 3b 20 64 6f 20 |ELIVERMA|IL}; do |
|000038e0| 63 70 20 24 24 69 20 2f | 6e 2f 24 24 69 2f 75 73 |cp $$i /|n/$$i/us|
|000038f0| 72 2f 6c 6f 63 61 6c 2f | 6c 69 62 2f 70 61 74 68 |r/local/|lib/path|
|00003900| 61 6c 69 61 73 65 73 3b | 20 24 24 69 20 6e 65 77 |aliases;| $$i new|
|00003910| 61 6c 69 61 73 65 73 20 | 64 6f 6e 65 0a 09 74 6f |aliases |done..to|
|00003920| 75 63 68 20 73 68 69 70 | 69 74 0a 0a 23 20 72 65 |uch ship|it..# re|
|00003930| 6f 72 64 65 72 20 74 68 | 65 20 6f 75 74 70 75 74 |order th|e output|
|00003940| 20 66 6f 72 20 70 72 69 | 6e 63 65 74 6f 6e 2f 73 | for pri|nceton/s|
|00003950| 65 6e 64 6d 61 69 6c 2f | 75 75 62 61 6e 67 20 61 |endmail/|uubang a|
|00003960| 6e 64 20 67 65 6e 65 72 | 61 74 65 20 70 68 6f 6e |nd gener|ate phon|
|00003970| 65 79 20 63 6f 73 74 73 | 2e 0a 70 72 69 6e 63 65 |ey costs|..prince|
|00003980| 74 6f 6e 3a 20 64 6f 77 | 6e 0a 09 70 61 74 68 61 |ton: dow|n..patha|
|00003990| 6c 69 61 73 20 24 7b 41 | 52 47 53 7d 20 24 28 44 |lias ${A|RGS} $(D|
|000039a0| 45 41 44 29 20 2d 6c 20 | 70 72 69 6e 63 65 74 6f |EAD) -l |princeto|
|000039b0| 6e 20 24 28 50 41 54 48 | 46 49 4c 45 53 29 20 32 |n $(PATH|FILES) 2|
|000039c0| 3e 45 52 52 4f 52 53 20 | 7c 20 73 6f 72 74 20 7c |>ERRORS || sort ||
|000039d0| 20 73 65 64 20 27 73 2f | 5c 28 2e 2a 5c 29 09 5c | sed 's/|\(.*\).\|
|000039e0| 28 2e 2a 5c 29 2f 5c 31 | 09 30 09 5c 32 2f 27 20 |(.*\)/\1|.0.\2/' |
|000039f0| 3e 20 70 72 69 6e 63 65 | 74 6f 6e 0a 0a 23 20 64 |> prince|ton..# d|
|00003a00| 65 73 70 65 72 61 74 69 | 6f 6e 20 64 65 62 75 67 |esperati|on debug|
|00003a10| 67 69 6e 67 20 2d 2d 20 | 65 78 61 6d 69 6e 65 20 |ging -- |examine |
|00003a20| 74 68 65 20 63 6f 73 74 | 73 2e 0a 63 6f 73 74 73 |the cost|s..costs|
|00003a30| 3a 0a 09 70 61 74 68 61 | 6c 69 61 73 20 2d 76 63 |:..patha|lias -vc|
|00003a40| 69 20 24 7b 44 45 41 44 | 7d 20 2d 6c 20 64 6f 77 |i ${DEAD|} -l dow|
|00003a50| 6e 20 24 28 50 41 54 48 | 46 49 4c 45 53 29 20 3e |n $(PATH|FILES) >|
|00003a60| 20 64 6f 77 6e 2e 63 6f | 73 74 73 20 32 3e 45 52 | down.co|sts 2>ER|
|00003a70| 52 4f 52 53 0a 0a 23 20 | 6d 61 6b 65 20 6f 6e 65 |RORS..# |make one|
|00003a80| 20 42 49 47 20 66 69 6c | 65 2e 20 20 61 20 42 49 | BIG fil|e. a BI|
|00003a90| 47 20 62 61 64 20 69 64 | 65 61 2e 0a 63 61 74 3a |G bad id|ea..cat:|
|00003aa0| 0a 09 63 61 74 20 24 28 | 50 41 54 48 46 49 4c 45 |..cat $(|PATHFILE|
|00003ab0| 53 29 20 3e 20 43 41 54 | 0a 0a 23 20 6d 61 6b 65 |S) > CAT|..# make|
|00003ac0| 20 61 20 70 61 74 68 70 | 61 72 73 65 20 64 61 74 | a pathp|arse dat|
|00003ad0| 61 62 61 73 65 2e 20 20 | 2d 67 20 66 6c 61 67 20 |abase. |-g flag |
|00003ae0| 69 73 20 75 6e 64 6f 63 | 75 6d 65 6e 74 65 64 2e |is undoc|umented.|
|00003af0| 0a 65 64 67 65 73 3a 20 | 64 6f 77 6e 0a 09 70 61 |.edges: |down..pa|
|00003b00| 74 68 61 6c 69 61 73 20 | 2d 69 20 2d 67 20 65 64 |thalias |-i -g ed|
|00003b10| 67 65 73 20 24 28 50 41 | 54 48 46 49 4c 45 53 29 |ges $(PA|THFILES)|
|00003b20| 20 3e 2f 64 65 76 2f 6e | 75 6c 6c 0a 09 6d 61 6b | >/dev/n|ull..mak|
|00003b30| 65 64 62 20 65 64 67 65 | 73 20 64 6f 77 6e 0a 53 |edb edge|s down.S|
|00003b40| 48 41 52 5f 45 4f 46 0a | 69 66 20 74 65 73 74 20 |HAR_EOF.|if test |
|00003b50| 33 35 35 35 20 2d 6e 65 | 20 22 60 77 63 20 2d 63 |3555 -ne| "`wc -c|
|00003b60| 20 3c 20 27 6d 61 6b 65 | 2e 76 38 27 60 22 0a 74 | < 'make|.v8'`".t|
|00003b70| 68 65 6e 0a 09 65 63 68 | 6f 20 73 68 61 72 3a 20 |hen..ech|o shar: |
|00003b80| 65 72 72 6f 72 20 74 72 | 61 6e 73 6d 69 74 74 69 |error tr|ansmitti|
|00003b90| 6e 67 20 22 27 6d 61 6b | 65 2e 76 38 27 22 20 27 |ng "'mak|e.v8'" '|
|00003ba0| 28 73 68 6f 75 6c 64 20 | 68 61 76 65 20 62 65 65 |(should |have bee|
|00003bb0| 6e 20 33 35 35 35 20 63 | 68 61 72 61 63 74 65 72 |n 3555 c|haracter|
|00003bc0| 73 29 27 0a 66 69 0a 66 | 69 0a 65 63 68 6f 20 73 |s)'.fi.f|i.echo s|
|00003bd0| 68 61 72 3a 20 65 78 74 | 72 61 63 74 69 6e 67 20 |har: ext|racting |
|00003be0| 22 27 70 61 74 68 61 6c | 69 61 73 2e 31 27 22 20 |"'pathal|ias.1'" |
|00003bf0| 27 28 39 32 37 37 20 63 | 68 61 72 61 63 74 65 72 |'(9277 c|haracter|
|00003c00| 73 29 27 0a 69 66 20 74 | 65 73 74 20 2d 66 20 27 |s)'.if t|est -f '|
|00003c10| 70 61 74 68 61 6c 69 61 | 73 2e 31 27 0a 74 68 65 |pathalia|s.1'.the|
|00003c20| 6e 0a 09 65 63 68 6f 20 | 73 68 61 72 3a 20 77 69 |n..echo |shar: wi|
|00003c30| 6c 6c 20 6e 6f 74 20 6f | 76 65 72 2d 77 72 69 74 |ll not o|ver-writ|
|00003c40| 65 20 65 78 69 73 74 69 | 6e 67 20 66 69 6c 65 20 |e existi|ng file |
|00003c50| 22 27 70 61 74 68 61 6c | 69 61 73 2e 31 27 22 0a |"'pathal|ias.1'".|
|00003c60| 65 6c 73 65 0a 63 61 74 | 20 3c 3c 20 5c 53 48 41 |else.cat| << \SHA|
|00003c70| 52 5f 45 4f 46 20 3e 20 | 27 70 61 74 68 61 6c 69 |R_EOF > |'pathali|
|00003c80| 61 73 2e 31 27 0a 2e 5c | 22 20 54 68 61 6e 6b 73 |as.1'..\|" Thanks|
|00003c90| 20 74 6f 20 41 6c 61 6e | 20 53 69 6c 76 65 72 73 | to Alan| Silvers|
|00003ca0| 74 65 69 6e 20 66 6f 72 | 20 68 65 6c 70 20 77 69 |tein for| help wi|
|00003cb0| 74 68 20 74 68 65 20 6d | 61 6e 75 61 6c 20 65 6e |th the m|anual en|
|00003cc0| 74 72 79 2e 0a 2e 54 48 | 20 50 41 54 48 41 4c 49 |try...TH| PATHALI|
|00003cd0| 41 53 20 31 20 0a 2e 53 | 48 20 4e 41 4d 45 0a 70 |AS 1 ..S|H NAME.p|
|00003ce0| 61 74 68 61 6c 69 61 73 | 2c 20 6d 61 6b 65 64 62 |athalias|, makedb|
|00003cf0| 20 5c 2d 20 65 6c 65 63 | 74 72 6f 6e 69 63 20 61 | \- elec|tronic a|
|00003d00| 64 64 72 65 73 73 20 72 | 6f 75 74 65 72 0a 2e 53 |ddress r|outer..S|
|00003d10| 48 20 53 59 4e 4f 50 53 | 49 53 0a 2e 42 20 70 61 |H SYNOPS|IS..B pa|
|00003d20| 74 68 61 6c 69 61 73 0a | 5b 0a 2e 42 20 5c 2d 69 |thalias.|[..B \-i|
|00003d30| 76 63 0a 5d 20 5b 0a 2e | 42 49 20 5c 2d 74 20 5c |vc.] [..|BI \-t \|
|00003d40| 30 6c 69 6e 6b 0a 5d 20 | 5b 0a 2e 42 49 20 5c 2d |0link.] |[..BI \-|
|00003d50| 6c 20 5c 30 68 6f 73 74 | 0a 5d 20 5b 0a 2e 42 49 |l \0host|.] [..BI|
|00003d60| 20 5c 2d 64 20 5c 30 6c | 69 6e 6b 0a 5d 20 5b 0a | \-d \0l|ink.] [.|
|00003d70| 2e 69 67 0a 2e 5c 22 20 | 74 68 65 20 2d 67 20 6f |.ig..\" |the -g o|
|00003d80| 70 74 69 6f 6e 20 69 73 | 20 66 6f 72 20 70 61 74 |ption is| for pat|
|00003d90| 68 70 61 72 73 65 2e 20 | 20 69 74 27 73 20 6e 6f |hparse. | it's no|
|00003da0| 74 20 72 65 61 6c 6c 79 | 20 75 73 65 64 20 62 79 |t really| used by|
|00003db0| 20 70 61 74 68 61 6c 69 | 61 73 2e 0a 2e 42 49 20 | pathali|as...BI |
|00003dc0| 5c 2d 67 20 5c 30 66 69 | 6c 65 0a 5d 20 5b 0a 2e |\-g \0fi|le.] [..|
|00003dd0| 2e 0a 2e 49 20 66 69 6c | 65 73 0a 5d 0a 2e 50 50 |...I fil|es.]..PP|
|00003de0| 0a 2e 42 20 6d 61 6b 65 | 64 62 0a 5b 0a 2e 42 20 |..B make|db.[..B |
|00003df0| 5c 2d 61 0a 5d 20 5b 0a | 2e 42 49 20 5c 2d 6f 20 |\-a.] [.|.BI \-o |
|00003e00| 5c 30 64 62 6d 66 69 6c | 65 0a 5d 20 5b 0a 2e 49 |\0dbmfil|e.] [..I|
|00003e10| 20 66 69 6c 65 73 20 2e | 2e 2e 0a 5d 0a 2e 61 64 | files .|...]..ad|
|00003e20| 20 62 0a 2e 53 48 20 44 | 45 53 43 52 49 50 54 49 | b..SH D|ESCRIPTI|
|00003e30| 4f 4e 0a 2e 49 20 70 61 | 74 68 61 6c 69 61 73 0a |ON..I pa|thalias.|
|00003e40| 63 6f 6d 70 75 74 65 73 | 20 74 68 65 20 73 68 6f |computes| the sho|
|00003e50| 72 74 65 73 74 20 70 61 | 74 68 73 20 61 6e 64 20 |rtest pa|ths and |
|00003e60| 63 6f 72 72 65 73 70 6f | 6e 64 69 6e 67 20 72 6f |correspo|nding ro|
|00003e70| 75 74 65 73 20 66 72 6f | 6d 20 6f 6e 65 20 68 6f |utes fro|m one ho|
|00003e80| 73 74 0a 28 63 6f 6d 70 | 75 74 65 72 20 73 79 73 |st.(comp|uter sys|
|00003e90| 74 65 6d 29 20 74 6f 20 | 61 6c 6c 20 6f 74 68 65 |tem) to |all othe|
|00003ea0| 72 20 6b 6e 6f 77 6e 2c | 20 72 65 61 63 68 61 62 |r known,| reachab|
|00003eb0| 6c 65 20 68 6f 73 74 73 | 2e 0a 2e 49 20 70 61 74 |le hosts|...I pat|
|00003ec0| 68 61 6c 69 61 73 0a 72 | 65 61 64 73 20 68 6f 73 |halias.r|eads hos|
|00003ed0| 74 2d 74 6f 2d 68 6f 73 | 74 20 63 6f 6e 6e 65 63 |t-to-hos|t connec|
|00003ee0| 74 69 76 69 74 79 0a 69 | 6e 66 6f 72 6d 61 74 69 |tivity.i|nformati|
|00003ef0| 6f 6e 20 6f 6e 20 73 74 | 61 6e 64 61 72 64 20 69 |on on st|andard i|
|00003f00| 6e 70 75 74 20 6f 72 20 | 69 6e 20 74 68 65 20 6e |nput or |in the n|
|00003f10| 61 6d 65 64 0a 2e 49 52 | 20 66 69 6c 65 73 20 2c |amed..IR| files ,|
|00003f20| 0a 61 6e 64 20 77 72 69 | 74 65 73 20 61 20 6c 69 |.and wri|tes a li|
|00003f30| 73 74 20 6f 66 0a 68 6f | 73 74 2d 72 6f 75 74 65 |st of.ho|st-route|
|00003f40| 20 70 61 69 72 73 20 6f | 6e 20 74 68 65 20 73 74 | pairs o|n the st|
|00003f50| 61 6e 64 61 72 64 20 6f | 75 74 70 75 74 2e 0a 2e |andard o|utput...|
|00003f60| 50 50 0a 2e 49 20 6d 61 | 6b 65 64 62 0a 74 61 6b |PP..I ma|kedb.tak|
|00003f70| 65 73 0a 2e 49 20 70 61 | 74 68 61 6c 69 61 73 0a |es..I pa|thalias.|
|00003f80| 6f 75 74 70 75 74 20 61 | 6e 64 20 63 72 65 61 74 |output a|nd creat|
|00003f90| 65 73 20 6f 72 20 61 70 | 70 65 6e 64 73 20 74 6f |es or ap|pends to|
|00003fa0| 20 61 0a 2e 49 52 20 64 | 62 6d 20 28 33 29 0a 64 | a..IR d|bm (3).d|
|00003fb0| 61 74 61 62 61 73 65 2e | 0a 2e 50 50 0a 48 65 72 |atabase.|..PP.Her|
|00003fc0| 65 20 61 72 65 20 74 68 | 65 0a 2e 49 20 70 61 74 |e are th|e..I pat|
|00003fd0| 68 61 6c 69 61 73 0a 6f | 70 74 69 6f 6e 73 3a 0a |halias.o|ptions:.|
|00003fe0| 2e 54 50 20 36 0a 2e 42 | 20 5c 2d 69 0a 49 67 6e |.TP 6..B| \-i.Ign|
|00003ff0| 6f 72 65 20 63 61 73 65 | 3a 20 20 6d 61 70 20 61 |ore case|: map a|
|00004000| 6c 6c 20 68 6f 73 74 20 | 6e 61 6d 65 73 20 74 6f |ll host |names to|
|00004010| 20 6c 6f 77 65 72 20 63 | 61 73 65 2e 0a 42 79 20 | lower c|ase..By |
|00004020| 64 65 66 61 75 6c 74 2c | 20 63 61 73 65 20 69 73 |default,| case is|
|00004030| 20 73 69 67 6e 69 66 69 | 63 61 6e 74 2e 0a 2e 54 | signifi|cant...T|
|00004040| 50 0a 2e 42 20 5c 2d 63 | 0a 50 72 69 6e 74 20 63 |P..B \-c|.Print c|
|00004050| 6f 73 74 73 3a 20 70 72 | 69 6e 74 20 74 68 65 20 |osts: pr|int the |
|00004060| 70 61 74 68 20 63 6f 73 | 74 20 28 73 65 65 20 62 |path cos|t (see b|
|00004070| 65 6c 6f 77 29 20 62 65 | 66 6f 72 65 20 65 61 63 |elow) be|fore eac|
|00004080| 68 20 68 6f 73 74 2d 72 | 6f 75 74 65 20 70 61 69 |h host-r|oute pai|
|00004090| 72 2e 0a 2e 54 50 0a 2e | 42 20 5c 2d 76 0a 56 65 |r...TP..|B \-v.Ve|
|000040a0| 72 62 6f 73 65 3a 20 72 | 65 70 6f 72 74 20 73 6f |rbose: r|eport so|
|000040b0| 6d 65 20 73 74 61 74 69 | 73 74 69 63 73 20 6f 6e |me stati|stics on|
|000040c0| 20 74 68 65 20 73 74 61 | 6e 64 61 72 64 20 65 72 | the sta|ndard er|
|000040d0| 72 6f 72 20 6f 75 74 70 | 75 74 2e 0a 2e 69 67 0a |ror outp|ut...ig.|
|000040e0| 2e 5c 22 20 74 68 65 20 | 2d 67 20 6f 70 74 69 6f |.\" the |-g optio|
|000040f0| 6e 20 69 73 20 66 6f 72 | 20 70 61 74 68 70 61 72 |n is for| pathpar|
|00004100| 73 65 20 61 6e 64 20 69 | 73 20 6e 6f 74 20 66 6f |se and i|s not fo|
|00004110| 72 20 70 75 62 6c 69 63 | 20 63 6f 6e 73 75 6d 70 |r public| consump|
|00004120| 74 69 6f 6e 20 28 79 65 | 74 21 29 2e 0a 2e 54 50 |tion (ye|t!)...TP|
|00004130| 0a 2e 42 49 20 5c 2d 67 | 20 5c 30 66 69 6c 65 0a |..BI \-g| \0file.|
|00004140| 44 75 6d 70 20 74 68 65 | 20 65 64 67 65 73 20 6f |Dump the| edges o|
|00004150| 66 20 74 68 65 20 67 72 | 61 70 68 20 69 6e 74 6f |f the gr|aph into|
|00004160| 20 74 68 65 20 6e 61 6d | 65 64 20 66 69 6c 65 2e | the nam|ed file.|
|00004170| 0a 2e 2e 0a 2e 54 50 0a | 2e 42 49 20 5c 2d 6c 20 |.....TP.|.BI \-l |
|00004180| 5c 30 68 6f 73 74 0a 53 | 65 74 20 6c 6f 63 61 6c |\0host.S|et local|
|00004190| 20 68 6f 73 74 20 6e 61 | 6d 65 20 74 6f 0a 2e 49 | host na|me to..I|
|000041a0| 52 20 68 6f 73 74 20 2e | 0a 42 79 20 64 65 66 61 |R host .|.By defa|
|000041b0| 75 6c 74 2c 0a 2e 49 20 | 70 61 74 68 61 6c 69 61 |ult,..I |pathalia|
|000041c0| 73 0a 64 69 73 63 6f 76 | 65 72 73 20 74 68 65 20 |s.discov|ers the |
|000041d0| 6c 6f 63 61 6c 20 68 6f | 73 74 20 6e 61 6d 65 20 |local ho|st name |
|000041e0| 69 6e 20 61 20 73 79 73 | 74 65 6d 2d 64 65 70 65 |in a sys|tem-depe|
|000041f0| 6e 64 65 6e 74 20 77 61 | 79 2e 0a 2e 54 50 0a 2e |ndent wa|y...TP..|
|00004200| 42 49 20 5c 2d 64 20 5c | 30 61 72 67 0a 44 65 63 |BI \-d \|0arg.Dec|
|00004210| 6c 61 72 65 20 61 20 64 | 65 61 64 20 6c 69 6e 6b |lare a d|ead link|
|00004220| 2c 20 68 6f 73 74 2c 20 | 6f 72 20 6e 65 74 77 6f |, host, |or netwo|
|00004230| 72 6b 20 28 73 65 65 20 | 62 65 6c 6f 77 29 2e 0a |rk (see |below)..|
|00004240| 49 66 0a 2e 49 20 61 72 | 67 0a 69 73 20 6f 66 20 |If..I ar|g.is of |
|00004250| 74 68 65 20 66 6f 72 6d | 20 60 60 68 6f 73 74 31 |the form| ``host1|
|00004260| 21 68 6f 73 74 32 2c 27 | 27 20 74 68 65 20 6c 69 |!host2,'|' the li|
|00004270| 6e 6b 20 66 72 6f 6d 20 | 68 6f 73 74 31 20 74 6f |nk from |host1 to|
|00004280| 20 68 6f 73 74 32 0a 69 | 73 20 74 72 65 61 74 65 | host2.i|s treate|
|00004290| 64 20 61 73 20 61 6e 20 | 65 78 74 72 65 6d 65 6c |d as an |extremel|
|000042a0| 79 20 68 69 67 68 20 63 | 6f 73 74 20 28 5c 66 49 |y high c|ost (\fI|
|000042b0| 69 2e 65 2e 5c 66 50 2c | 20 5c 73 2d 31 44 45 41 |i.e.\fP,| \s-1DEA|
|000042c0| 44 5c 73 30 29 20 6c 69 | 6e 6b 2e 0a 49 66 0a 2e |D\s0) li|nk..If..|
|000042d0| 49 20 61 72 67 0a 69 73 | 20 61 20 73 69 6e 67 6c |I arg.is| a singl|
|000042e0| 65 20 68 6f 73 74 20 6e | 61 6d 65 2c 0a 74 68 61 |e host n|ame,.tha|
|000042f0| 74 20 68 6f 73 74 20 69 | 73 20 74 72 65 61 74 65 |t host i|s treate|
|00004300| 64 20 61 73 20 64 65 61 | 64 0a 61 6e 64 20 69 73 |d as dea|d.and is|
|00004310| 20 62 65 20 75 73 65 64 | 20 61 73 20 61 6e 20 69 | be used| as an i|
|00004320| 6e 74 65 72 6d 65 64 69 | 61 74 65 20 68 6f 73 74 |ntermedi|ate host|
|00004330| 20 6f 66 20 6c 61 73 74 | 20 72 65 73 6f 72 74 20 | of last| resort |
|00004340| 6f 6e 20 61 6e 79 20 70 | 61 74 68 2e 0a 49 66 0a |on any p|ath..If.|
|00004350| 2e 49 20 61 72 67 0a 69 | 73 20 61 20 6e 65 74 77 |.I arg.i|s a netw|
|00004360| 6f 72 6b 20 6e 61 6d 65 | 2c 20 74 68 65 20 6e 65 |ork name|, the ne|
|00004370| 74 77 6f 72 6b 20 72 65 | 71 75 69 72 65 73 20 61 |twork re|quires a|
|00004380| 20 67 61 74 65 77 61 79 | 2e 0a 2e 54 50 0a 2e 42 | gateway|...TP..B|
|00004390| 52 20 20 5c 2d 74 20 5c | 30 61 72 67 0a 54 72 61 |R \-t \|0arg.Tra|
|000043a0| 63 65 20 69 6e 70 75 74 | 20 66 6f 72 20 6c 69 6e |ce input| for lin|
|000043b0| 6b 2c 20 68 6f 73 74 20 | 6f 72 20 6e 65 74 77 6f |k, host |or netwo|
|000043c0| 72 6b 20 6f 6e 20 74 68 | 65 20 73 74 61 6e 64 61 |rk on th|e standa|
|000043d0| 72 64 20 65 72 72 6f 72 | 20 6f 75 74 70 75 74 2e |rd error| output.|
|000043e0| 0a 54 68 65 20 66 6f 72 | 6d 20 6f 66 0a 2e 49 20 |.The for|m of..I |
|000043f0| 61 72 67 0a 69 73 20 61 | 73 20 61 62 6f 76 65 2e |arg.is a|s above.|
|00004400| 0a 2e 50 50 0a 48 65 72 | 65 20 61 72 65 20 74 68 |..PP.Her|e are th|
|00004410| 65 0a 2e 49 20 6d 61 6b | 65 64 62 0a 6f 70 74 69 |e..I mak|edb.opti|
|00004420| 6f 6e 73 3a 0a 2e 54 50 | 20 36 0a 2e 42 20 5c 2d |ons:..TP| 6..B \-|
|00004430| 61 0a 41 70 70 65 6e 64 | 20 74 6f 20 61 6e 20 65 |a.Append| to an e|
|00004440| 78 69 73 74 69 6e 67 20 | 64 61 74 61 62 61 73 65 |xisting |database|
|00004450| 3b 0a 62 79 20 64 65 66 | 61 75 6c 74 2c 0a 2e 49 |;.by def|ault,..I|
|00004460| 20 6d 61 6b 65 64 62 0a | 74 72 75 6e 63 61 74 65 | makedb.|truncate|
|00004470| 73 20 74 68 65 20 64 61 | 74 61 62 61 73 65 2e 0a |s the da|tabase..|
|00004480| 2e 54 50 0a 2e 42 49 20 | 5c 2d 6f 20 5c 30 64 62 |.TP..BI |\-o \0db|
|00004490| 6d 66 69 6c 65 0a 49 64 | 65 6e 74 69 66 79 20 74 |mfile.Id|entify t|
|000044a0| 68 65 20 6f 75 74 70 75 | 74 20 66 69 6c 65 20 62 |he outpu|t file b|
|000044b0| 61 73 65 20 6e 61 6d 65 | 2e 0a 2e 53 53 20 5c 66 |ase name|...SS \f|
|000044c0| 49 70 61 74 68 61 6c 69 | 61 73 5c 66 50 20 49 6e |Ipathali|as\fP In|
|000044d0| 70 75 74 20 46 6f 72 6d | 61 74 0a 41 20 6c 69 6e |put Form|at.A lin|
|000044e0| 65 20 62 65 67 69 6e 6e | 69 6e 67 20 77 69 74 68 |e beginn|ing with|
|000044f0| 20 77 68 69 74 65 20 73 | 70 61 63 65 20 63 6f 6e | white s|pace con|
|00004500| 74 69 6e 75 65 73 20 74 | 68 65 20 70 72 65 63 65 |tinues t|he prece|
|00004510| 64 69 6e 67 20 6c 69 6e | 65 2e 0a 41 6e 79 74 68 |ding lin|e..Anyth|
|00004520| 69 6e 67 20 66 6f 6c 6c | 6f 77 69 6e 67 20 60 23 |ing foll|owing `#|
|00004530| 27 20 6f 6e 20 61 6e 20 | 69 6e 70 75 74 20 6c 69 |' on an |input li|
|00004540| 6e 65 20 69 73 20 69 67 | 6e 6f 72 65 64 2e 0a 2e |ne is ig|nored...|
|00004550| 50 50 0a 41 20 6c 69 73 | 74 20 6f 66 20 68 6f 73 |PP.A lis|t of hos|
|00004560| 74 2d 74 6f 2d 68 6f 73 | 74 20 63 6f 6e 6e 65 63 |t-to-hos|t connec|
|00004570| 74 69 6f 6e 73 20 63 6f | 6e 73 69 73 74 73 20 6f |tions co|nsists o|
|00004580| 66 20 61 20 60 60 66 72 | 6f 6d 27 27 20 68 6f 73 |f a ``fr|om'' hos|
|00004590| 74 20 69 6e 20 63 6f 6c | 75 6d 6e 20 31 2c 0a 66 |t in col|umn 1,.f|
|000045a0| 6f 6c 6c 6f 77 65 64 20 | 62 79 20 77 68 69 74 65 |ollowed |by white|
|000045b0| 20 73 70 61 63 65 2c 0a | 66 6f 6c 6c 6f 77 65 64 | space,.|followed|
|000045c0| 20 62 79 20 61 20 63 6f | 6d 6d 61 2d 73 65 70 61 | by a co|mma-sepa|
|000045d0| 72 61 74 65 64 20 6c 69 | 73 74 20 6f 66 20 60 60 |rated li|st of ``|
|000045e0| 74 6f 27 20 68 6f 73 74 | 73 2c 20 63 61 6c 6c 65 |to' host|s, calle|
|000045f0| 64 0a 2e 49 52 20 6c 69 | 6e 6b 73 20 2e 0a 41 20 |d..IR li|nks ..A |
|00004600| 6c 69 6e 6b 20 6d 61 79 | 20 62 65 20 70 72 65 63 |link may| be prec|
|00004610| 65 64 65 64 20 6f 72 20 | 66 6f 6c 6c 6f 77 65 64 |eded or |followed|
|00004620| 20 62 79 20 61 20 6e 65 | 74 77 6f 72 6b 20 63 68 | by a ne|twork ch|
|00004630| 61 72 61 63 74 65 72 20 | 74 6f 20 75 73 65 0a 69 |aracter |to use.i|
|00004640| 6e 20 74 68 65 20 72 6f | 75 74 65 2e 0a 56 61 6c |n the ro|ute..Val|
|00004650| 69 64 20 6e 65 74 77 6f | 72 6b 20 63 68 61 72 61 |id netwo|rk chara|
|00004660| 63 74 65 72 73 20 61 72 | 65 20 60 21 27 20 28 64 |cters ar|e `!' (d|
|00004670| 65 66 61 75 6c 74 29 2c | 20 60 40 27 2c 20 60 3a |efault),| `@', `:|
|00004680| 27 2c 20 61 6e 64 20 60 | 25 27 2e 0a 41 20 6c 69 |', and `|%'..A li|
|00004690| 6e 6b 20 28 61 6e 64 20 | 6e 65 74 77 6f 72 6b 20 |nk (and |network |
|000046a0| 63 68 61 72 61 63 74 65 | 72 2c 20 69 66 20 70 72 |characte|r, if pr|
|000046b0| 65 73 65 6e 74 29 20 6d | 61 79 20 62 65 0a 66 6f |esent) m|ay be.fo|
|000046c0| 6c 6c 6f 77 65 64 20 62 | 79 20 61 20 60 60 63 6f |llowed b|y a ``co|
|000046d0| 73 74 27 27 20 65 6e 63 | 6c 6f 73 65 64 20 69 6e |st'' enc|losed in|
|000046e0| 20 70 61 72 65 6e 74 68 | 65 73 65 73 2e 0a 43 6f | parenth|eses..Co|
|000046f0| 73 74 73 20 6d 61 79 20 | 62 65 20 61 72 62 69 74 |sts may |be arbit|
|00004700| 72 61 72 79 0a 61 72 69 | 74 68 6d 65 74 69 63 20 |rary.ari|thmetic |
|00004710| 65 78 70 72 65 73 73 69 | 6f 6e 73 20 69 6e 76 6f |expressi|ons invo|
|00004720| 6c 76 69 6e 67 20 6e 75 | 6d 62 65 72 73 2c 20 70 |lving nu|mbers, p|
|00004730| 61 72 65 6e 74 68 65 73 | 65 73 2c 20 60 2b 27 2c |arenthes|es, `+',|
|00004740| 20 60 5c 2d 27 2c 20 60 | 2a 27 2c 0a 61 6e 64 20 | `\-', `|*',.and |
|00004750| 60 2f 27 2e 0a 54 68 65 | 20 66 6f 6c 6c 6f 77 69 |`/'..The| followi|
|00004760| 6e 67 20 73 79 6d 62 6f | 6c 69 63 20 63 6f 73 74 |ng symbo|lic cost|
|00004770| 73 20 61 72 65 0a 72 65 | 63 6f 67 6e 69 7a 65 64 |s are.re|cognized|
|00004780| 3a 0a 2e 52 53 0a 2e 6e | 66 0a 2e 74 61 20 31 30 |:..RS..n|f..ta 10|
|00004790| 6d 52 20 31 35 6d 0a 0a | 5c 73 2d 31 4c 4f 43 41 |mR 15m..|\s-1LOCA|
|000047a0| 4c 5c 73 30 09 32 35 09 | 28 6c 6f 63 61 6c 2d 61 |L\s0.25.|(local-a|
|000047b0| 72 65 61 20 6e 65 74 77 | 6f 72 6b 20 63 6f 6e 6e |rea netw|ork conn|
|000047c0| 65 63 74 69 6f 6e 29 0a | 5c 73 2d 31 44 45 44 49 |ection).|\s-1DEDI|
|000047d0| 43 41 54 45 44 5c 73 30 | 09 39 35 09 28 68 69 67 |CATED\s0|.95.(hig|
|000047e0| 68 20 73 70 65 65 64 20 | 64 65 64 69 63 61 74 65 |h speed |dedicate|
|000047f0| 64 20 6c 69 6e 6b 29 0a | 5c 73 2d 31 44 49 52 45 |d link).|\s-1DIRE|
|00004800| 43 54 5c 73 30 09 32 30 | 30 09 28 74 6f 6c 6c 2d |CT\s0.20|0.(toll-|
|00004810| 66 72 65 65 20 63 61 6c | 6c 29 0a 5c 73 2d 31 44 |free cal|l).\s-1D|
|00004820| 45 4d 41 4e 44 5c 73 30 | 09 33 30 30 09 28 6c 6f |EMAND\s0|.300.(lo|
|00004830| 6e 67 2d 64 69 73 74 61 | 6e 63 65 20 63 61 6c 6c |ng-dista|nce call|
|00004840| 29 0a 5c 73 2d 31 48 4f | 55 52 4c 59 5c 73 30 09 |).\s-1HO|URLY\s0.|
|00004850| 35 30 30 09 28 68 6f 75 | 72 6c 79 20 70 6f 6c 6c |500.(hou|rly poll|
|00004860| 29 0a 5c 73 2d 31 45 56 | 45 4e 49 4e 47 5c 73 30 |).\s-1EV|ENING\s0|
|00004870| 09 31 38 30 30 09 28 74 | 69 6d 65 20 72 65 73 74 |.1800.(t|ime rest|
|00004880| 72 69 63 74 65 64 20 63 | 61 6c 6c 29 0a 5c 73 2d |ricted c|all).\s-|
|00004890| 31 44 41 49 4c 59 5c 73 | 30 09 35 30 30 30 09 28 |1DAILY\s|0.5000.(|
|000048a0| 64 61 69 6c 79 20 70 6f | 6c 6c 2c 20 61 6c 73 6f |daily po|ll, also|
|000048b0| 20 63 61 6c 6c 65 64 20 | 5c 73 2d 31 50 4f 4c 4c | called |\s-1POLL|
|000048c0| 45 44 5c 73 30 29 0a 5c | 73 2d 31 57 45 45 4b 4c |ED\s0).\|s-1WEEKL|
|000048d0| 59 5c 73 30 09 33 30 30 | 30 30 09 28 69 72 72 65 |Y\s0.300|00.(irre|
|000048e0| 67 75 6c 61 72 20 70 6f | 6c 6c 29 0a 2e 66 69 0a |gular po|ll)..fi.|
|000048f0| 2e 52 45 0a 2e 50 50 0a | 49 6e 20 61 64 64 69 74 |.RE..PP.|In addit|
|00004900| 69 6f 6e 2c 0a 2e 53 4d | 20 44 45 41 44 0a 69 73 |ion,..SM| DEAD.is|
|00004910| 20 61 20 76 65 72 79 20 | 6c 61 72 67 65 20 6e 75 | a very |large nu|
|00004920| 6d 62 65 72 20 28 65 66 | 66 65 63 74 69 76 65 6c |mber (ef|fectivel|
|00004930| 79 20 69 6e 66 69 6e 69 | 74 65 29 2c 0a 61 6e 64 |y infini|te),.and|
|00004940| 0a 2e 53 4d 20 48 49 47 | 48 0a 61 6e 64 0a 2e 53 |..SM HIG|H.and..S|
|00004950| 4d 20 4c 4f 57 0a 61 72 | 65 20 5c 2d 35 20 61 6e |M LOW.ar|e \-5 an|
|00004960| 64 20 2b 35 20 72 65 73 | 70 65 63 74 69 76 65 6c |d +5 res|pectivel|
|00004970| 79 2c 0a 66 6f 72 20 62 | 61 75 64 2d 72 61 74 65 |y,.for b|aud-rate|
|00004980| 20 6f 72 20 71 75 61 6c | 69 74 79 20 62 6f 6e 75 | or qual|ity bonu|
|00004990| 73 65 73 2f 70 65 6e 61 | 6c 74 69 65 73 2e 0a 54 |ses/pena|lties..T|
|000049a0| 68 65 73 65 20 73 79 6d | 62 6f 6c 69 63 20 63 6f |hese sym|bolic co|
|000049b0| 73 74 73 20 72 65 70 72 | 65 73 65 6e 74 20 61 6e |sts repr|esent an|
|000049c0| 20 69 6d 70 65 72 66 65 | 63 74 20 6d 65 61 73 75 | imperfe|ct measu|
|000049d0| 72 65 20 6f 66 20 62 61 | 6e 64 77 69 64 74 68 2c |re of ba|ndwidth,|
|000049e0| 0a 6d 6f 6e 65 74 61 72 | 79 20 63 6f 73 74 2c 20 |.monetar|y cost, |
|000049f0| 61 6e 64 20 66 72 65 71 | 75 65 6e 63 79 20 6f 66 |and freq|uency of|
|00004a00| 20 63 6f 6e 6e 65 63 74 | 69 6f 6e 73 2e 0a 46 6f | connect|ions..Fo|
|00004a10| 72 20 6d 6f 73 74 20 6d | 61 69 6c 20 74 72 61 66 |r most m|ail traf|
|00004a20| 66 69 63 2c 20 69 74 20 | 69 73 20 69 6d 70 6f 72 |fic, it |is impor|
|00004a30| 74 61 6e 74 20 74 6f 20 | 6d 69 6e 69 6d 69 7a 65 |tant to |minimize|
|00004a40| 20 74 68 65 20 6e 75 6d | 62 65 72 0a 6f 66 20 69 | the num|ber.of i|
|00004a50| 6e 74 65 72 6d 65 64 69 | 61 72 69 65 73 20 69 6e |ntermedi|aries in|
|00004a60| 20 61 20 72 6f 75 74 65 | 2c 0a 74 68 75 73 2c 0a | a route|,.thus,.|
|00004a70| 2e 49 52 20 65 2e 67 2e | 20 2c 0a 2e 53 4d 20 48 |.IR e.g.| ,..SM H|
|00004a80| 4f 55 52 4c 59 0a 69 73 | 20 66 61 72 20 67 72 65 |OURLY.is| far gre|
|00004a90| 61 74 65 72 20 74 68 61 | 6e 0a 2e 53 4d 20 44 41 |ater tha|n..SM DA|
|00004aa0| 49 4c 59 0a 2f 20 32 34 | 2e 0a 49 66 20 6e 6f 20 |ILY./ 24|..If no |
|00004ab0| 63 6f 73 74 20 69 73 20 | 67 69 76 65 6e 2c 0a 61 |cost is |given,.a|
|00004ac0| 20 64 65 66 61 75 6c 74 | 20 6f 66 20 34 30 30 30 | default| of 4000|
|00004ad0| 20 69 73 20 75 73 65 64 | 2e 0a 2e 50 50 0a 46 6f | is used|...PP.Fo|
|00004ae0| 72 20 74 68 65 20 6d 6f | 73 74 20 70 61 72 74 2c |r the mo|st part,|
|00004af0| 20 61 72 69 74 68 6d 65 | 74 69 63 20 65 78 70 72 | arithme|tic expr|
|00004b00| 65 73 73 69 6f 6e 73 20 | 74 68 61 74 20 6d 69 78 |essions |that mix|
|00004b10| 20 73 79 6d 62 6f 6c 69 | 63 20 63 6f 6e 73 74 61 | symboli|c consta|
|00004b20| 6e 74 73 0a 6f 74 68 65 | 72 20 74 68 61 6e 0a 2e |nts.othe|r than..|
|00004b30| 53 4d 20 48 49 47 48 0a | 61 6e 64 0a 2e 53 4d 20 |SM HIGH.|and..SM |
|00004b40| 4c 4f 57 0a 6d 61 6b 65 | 20 6e 6f 20 73 65 6e 73 |LOW.make| no sens|
|00004b50| 65 2e 0a 2e 49 52 20 45 | 2e 67 2e 20 2c 0a 69 66 |e...IR E|.g. ,.if|
|00004b60| 20 61 20 68 6f 73 74 20 | 63 61 6c 6c 73 20 61 20 | a host |calls a |
|00004b70| 6c 6f 63 61 6c 20 6e 65 | 69 67 68 62 6f 72 20 77 |local ne|ighbor w|
|00004b80| 68 65 6e 65 76 65 72 20 | 74 68 65 72 65 20 69 73 |henever |there is|
|00004b90| 20 77 6f 72 6b 2c 0a 61 | 6e 64 20 61 64 64 69 74 | work,.a|nd addit|
|00004ba0| 69 6f 6e 61 6c 6c 79 20 | 70 6f 6c 6c 73 20 65 76 |ionally |polls ev|
|00004bb0| 65 72 79 20 65 76 65 6e | 69 6e 67 2c 0a 74 68 65 |ery even|ing,.the|
|00004bc0| 20 63 6f 73 74 20 69 73 | 0a 2e 53 4d 20 44 49 52 | cost is|..SM DIR|
|00004bd0| 45 43 54 2c 0a 2e 42 20 | 6e 6f 74 0a 2e 53 4d 20 |ECT,..B |not..SM |
|00004be0| 44 49 52 45 43 54 2b 45 | 56 45 4e 49 4e 47 2e 0a |DIRECT+E|VENING..|
|00004bf0| 2e 50 50 0a 53 6f 6d 65 | 20 65 78 61 6d 70 6c 65 |.PP.Some| example|
|00004c00| 73 3a 0a 2e 52 53 0a 2e | 6e 66 0a 2e 74 61 20 31 |s:..RS..|nf..ta 1|
|00004c10| 30 6d 20 31 35 6d 0a 0a | 64 6f 77 6e 09 70 72 69 |0m 15m..|down.pri|
|00004c20| 6e 63 65 74 6f 6e 21 28 | 5c 73 2d 31 44 45 44 49 |nceton!(|\s-1DEDI|
|00004c30| 43 41 54 45 44 5c 73 30 | 29 2c 20 74 69 6c 74 2c |CATED\s0|), tilt,|
|00004c40| 0a 09 25 74 68 72 61 73 | 68 28 5c 73 2d 31 4c 4f |..%thras|h(\s-1LO|
|00004c50| 43 41 4c 5c 73 30 29 0a | 70 72 69 6e 63 65 74 6f |CAL\s0).|princeto|
|00004c60| 6e 09 74 6f 70 61 7a 21 | 28 5c 73 2d 31 44 45 4d |n.topaz!|(\s-1DEM|
|00004c70| 41 4e 44 5c 73 30 2b 5c | 73 2d 31 4c 4f 57 5c 73 |AND\s0+\|s-1LOW\s|
|00004c80| 30 29 0a 74 6f 70 61 7a | 09 40 72 75 74 67 65 72 |0).topaz|.@rutger|
|00004c90| 73 28 5c 73 2d 31 4c 4f | 43 41 4c 5c 73 30 29 0a |s(\s-1LO|CAL\s0).|
|00004ca0| 2e 66 69 0a 2e 52 45 0a | 2e 50 50 0a 2e 66 69 0a |.fi..RE.|.PP..fi.|
|00004cb0| 2e 52 45 0a 49 66 20 61 | 20 6c 69 6e 6b 20 69 73 |.RE.If a| link is|
|00004cc0| 20 65 6e 63 6f 75 6e 74 | 65 72 65 64 20 6d 6f 72 | encount|ered mor|
|00004cd0| 65 20 74 68 61 6e 20 6f | 6e 63 65 2c 0a 74 68 65 |e than o|nce,.the|
|00004ce0| 20 6c 65 61 73 74 2d 63 | 6f 73 74 20 6f 63 63 75 | least-c|ost occu|
|00004cf0| 72 72 65 6e 63 65 20 64 | 69 63 74 61 74 65 73 20 |rrence d|ictates |
|00004d00| 74 68 65 20 63 6f 73 74 | 20 61 6e 64 20 6e 65 74 |the cost| and net|
|00004d10| 77 6f 72 6b 20 63 68 61 | 72 61 63 74 65 72 2e 0a |work cha|racter..|
|00004d20| 4c 69 6e 6b 73 20 61 72 | 65 20 74 72 65 61 74 65 |Links ar|e treate|
|00004d30| 64 20 61 73 20 62 69 64 | 69 72 65 63 74 69 6f 6e |d as bid|irection|
|00004d40| 61 6c 2c 20 74 6f 20 74 | 68 65 20 65 78 74 65 6e |al, to t|he exten|
|00004d50| 74 20 74 68 61 74 20 61 | 0a 2e 53 4d 20 44 45 41 |t that a|..SM DEA|
|00004d60| 44 0a 72 65 76 65 72 73 | 65 20 6c 69 6e 6b 20 69 |D.revers|e link i|
|00004d70| 73 20 61 73 73 75 6d 65 | 64 20 75 6e 6c 65 73 73 |s assume|d unless|
|00004d80| 20 62 65 74 74 65 72 20 | 69 6e 66 6f 72 6d 61 74 | better |informat|
|00004d90| 69 6f 6e 20 69 73 20 61 | 76 61 69 6c 61 62 6c 65 |ion is a|vailable|
|00004da0| 2e 0a 2e 50 50 0a 54 68 | 65 20 73 65 74 20 6f 66 |...PP.Th|e set of|
|00004db0| 20 6e 61 6d 65 73 20 62 | 79 20 77 68 69 63 68 20 | names b|y which |
|00004dc0| 61 20 68 6f 73 74 20 69 | 73 20 6b 6e 6f 77 6e 20 |a host i|s known |
|00004dd0| 62 79 20 69 74 73 20 6e | 65 69 67 68 62 6f 72 73 |by its n|eighbors|
|00004de0| 20 69 73 0a 63 61 6c 6c | 65 64 20 69 74 73 0a 2e | is.call|ed its..|
|00004df0| 49 52 20 61 6c 69 61 73 | 65 73 20 2e 0a 41 6c 69 |IR alias|es ..Ali|
|00004e00| 61 73 65 73 20 61 72 65 | 20 64 65 63 6c 61 72 65 |ases are| declare|
|00004e10| 64 20 61 73 20 66 6f 6c | 6c 6f 77 73 3a 0a 2e 52 |d as fol|lows:..R|
|00004e20| 53 0a 0a 6e 61 6d 65 20 | 3d 20 61 6c 69 61 73 2c |S..name |= alias,|
|00004e30| 20 61 6c 69 61 73 20 2e | 2e 2e 0a 2e 52 45 0a 2e | alias .|....RE..|
|00004e40| 50 50 0a 54 68 65 20 6e | 61 6d 65 20 75 73 65 64 |PP.The n|ame used|
|00004e50| 20 69 6e 20 74 68 65 20 | 72 6f 75 74 65 20 74 6f | in the |route to|
|00004e60| 20 6f 72 20 74 68 72 6f | 75 67 68 20 61 6c 69 61 | or thro|ugh alia|
|00004e70| 73 65 64 20 68 6f 73 74 | 73 0a 69 73 20 74 68 65 |sed host|s.is the|
|00004e80| 20 6e 61 6d 65 20 62 79 | 20 77 68 69 63 68 20 74 | name by| which t|
|00004e90| 68 65 20 68 6f 73 74 20 | 69 73 20 6b 6e 6f 77 6e |he host |is known|
|00004ea0| 0a 74 6f 20 69 74 73 20 | 70 72 65 64 65 63 65 73 |.to its |predeces|
|00004eb0| 73 6f 72 20 69 6e 20 74 | 68 65 20 72 6f 75 74 65 |sor in t|he route|
|00004ec0| 2e 0a 2e 50 50 0a 46 75 | 6c 6c 79 20 63 6f 6e 6e |...PP.Fu|lly conn|
|00004ed0| 65 63 74 65 64 20 6e 65 | 74 77 6f 72 6b 73 2c 20 |ected ne|tworks, |
|00004ee0| 73 75 63 68 20 61 73 20 | 74 68 65 0a 2e 53 4d 20 |such as |the..SM |
|00004ef0| 41 52 50 41 4e 45 54 0a | 6f 72 20 61 20 6c 6f 63 |ARPANET.|or a loc|
|00004f00| 61 6c 2d 61 72 65 61 20 | 6e 65 74 77 6f 72 6b 2c |al-area |network,|
|00004f10| 0a 61 72 65 20 64 65 63 | 6c 61 72 65 64 20 61 73 |.are dec|lared as|
|00004f20| 20 66 6f 6c 6c 6f 77 73 | 3a 0a 2e 52 53 0a 0a 6e | follows|:..RS..n|
|00004f30| 65 74 20 3d 20 7b 68 6f | 73 74 2c 20 68 6f 73 74 |et = {ho|st, host|
|00004f40| 2c 20 2e 2e 2e 7d 0a 2e | 52 45 0a 2e 50 50 0a 54 |, ...}..|RE..PP.T|
|00004f50| 68 65 20 68 6f 73 74 2d | 6c 69 73 74 20 6d 61 79 |he host-|list may|
|00004f60| 20 62 65 20 70 72 65 63 | 65 64 65 64 20 6f 72 20 | be prec|eded or |
|00004f70| 66 6f 6c 6c 6f 77 65 64 | 20 62 79 20 61 20 72 6f |followed| by a ro|
|00004f80| 75 74 69 6e 67 0a 63 68 | 61 72 61 63 74 65 72 2c |uting.ch|aracter,|
|00004f90| 20 61 6e 64 20 6d 61 79 | 20 62 65 20 66 6f 6c 6c | and may| be foll|
|00004fa0| 6f 77 65 64 20 62 79 20 | 61 20 63 6f 73 74 3a 0a |owed by |a cost:.|
|00004fb0| 2e 52 53 0a 2e 6e 66 0a | 0a 70 72 69 6e 63 65 74 |.RS..nf.|.princet|
|00004fc0| 6f 6e 2d 65 74 68 65 72 | 6e 65 74 20 3d 20 7b 64 |on-ether|net = {d|
|00004fd0| 6f 77 6e 2c 20 75 70 2c | 20 70 72 69 6e 63 65 74 |own, up,| princet|
|00004fe0| 6f 6e 7d 21 28 5c 73 2d | 31 4c 4f 43 41 4c 5c 73 |on}!(\s-|1LOCAL\s|
|00004ff0| 30 29 0a 5c 73 2d 31 41 | 52 50 41 5c 73 30 20 3d |0).\s-1A|RPA\s0 =|
|00005000| 20 40 7b 73 72 69 2d 75 | 6e 69 78 2c 20 6d 69 74 | @{sri-u|nix, mit|
|00005010| 2d 61 69 2c 20 73 75 2d | 73 63 6f 72 65 7d 28 5c |-ai, su-|score}(\|
|00005020| 73 2d 31 44 45 44 49 43 | 41 54 45 44 5c 73 30 29 |s-1DEDIC|ATED\s0)|
|00005030| 0a 2e 66 69 0a 2e 52 45 | 0a 2e 50 50 0a 53 65 65 |..fi..RE|..PP.See|
|00005040| 20 61 6c 73 6f 20 74 68 | 65 20 73 65 63 74 69 6f | also th|e sectio|
|00005050| 6e 73 20 6f 6e 0a 2e 49 | 20 67 61 74 65 77 61 79 |ns on..I| gateway|
|00005060| 73 0a 61 6e 64 0a 2e 49 | 20 64 6f 6d 61 69 6e 73 |s.and..I| domains|
|00005070| 0a 62 65 6c 6f 77 2e 0a | 2e 50 50 0a 43 6f 6e 6e |.below..|.PP.Conn|
|00005080| 65 63 74 69 6f 6e 20 64 | 61 74 61 20 6d 61 79 20 |ection d|ata may |
|00005090| 62 65 20 67 69 76 65 6e | 20 77 68 69 6c 65 20 68 |be given| while h|
|000050a0| 69 64 69 6e 67 20 68 6f | 73 74 20 6e 61 6d 65 73 |iding ho|st names|
|000050b0| 0a 62 79 20 64 65 63 6c | 61 72 69 6e 67 0a 2e 52 |.by decl|aring..R|
|000050c0| 53 0a 0a 70 72 69 76 61 | 74 65 20 7b 68 6f 73 74 |S..priva|te {host|
|000050d0| 2c 20 68 6f 73 74 2c 20 | 2e 2e 2e 7d 0a 2e 52 45 |, host, |...}..RE|
|000050e0| 0a 2e 50 50 0a 2e 49 20 | 70 61 74 68 61 6c 69 61 |..PP..I |pathalia|
|000050f0| 73 0a 77 69 6c 6c 20 6e | 6f 74 20 67 65 6e 65 72 |s.will n|ot gener|
|00005100| 61 74 65 20 72 6f 75 74 | 65 73 20 66 6f 72 20 70 |ate rout|es for p|
|00005110| 72 69 76 61 74 65 20 68 | 6f 73 74 73 20 6f 72 20 |rivate h|osts or |
|00005120| 66 6f 72 20 61 6e 79 0a | 68 6f 73 74 20 77 69 74 |for any.|host wit|
|00005130| 68 20 74 68 65 20 73 61 | 6d 65 20 6e 61 6d 65 20 |h the sa|me name |
|00005140| 61 73 20 61 20 70 72 69 | 76 61 74 65 20 68 6f 73 |as a pri|vate hos|
|00005150| 74 2c 20 62 75 74 20 6d | 61 79 20 70 72 6f 64 75 |t, but m|ay produ|
|00005160| 63 65 20 72 6f 75 74 65 | 73 0a 74 68 72 6f 75 67 |ce route|s.throug|
|00005170| 68 20 74 68 65 6d 2e 0a | 54 68 65 20 73 63 6f 70 |h them..|The scop|
|00005180| 65 20 6f 66 20 61 20 70 | 72 69 76 61 74 65 20 64 |e of a p|rivate d|
|00005190| 65 63 6c 61 72 61 74 69 | 6f 6e 20 65 78 74 65 6e |eclarati|on exten|
|000051a0| 64 73 20 66 72 6f 6d 20 | 74 68 65 20 64 65 63 6c |ds from |the decl|
|000051b0| 61 72 61 74 69 6f 6e 20 | 74 6f 20 74 68 65 20 65 |aration |to the e|
|000051c0| 6e 64 20 6f 66 0a 74 68 | 65 20 69 6e 70 75 74 20 |nd of.th|e input |
|000051d0| 66 69 6c 65 20 69 6e 20 | 77 68 69 63 68 20 69 74 |file in |which it|
|000051e0| 20 61 70 70 65 61 72 73 | 2e 0a 49 74 20 69 73 20 | appears|..It is |
|000051f0| 62 65 73 74 20 74 6f 20 | 70 75 74 20 70 72 69 76 |best to |put priv|
|00005200| 61 74 65 20 64 65 63 6c | 61 72 61 74 69 6f 6e 73 |ate decl|arations|
|00005210| 20 61 74 20 74 68 65 20 | 62 65 67 69 6e 6e 69 6e | at the |beginnin|
|00005220| 67 20 6f 66 20 74 68 65 | 20 61 70 70 72 6f 70 72 |g of the| appropr|
|00005230| 69 61 74 65 0a 69 6e 70 | 75 74 20 66 69 6c 65 2e |iate.inp|ut file.|
|00005240| 0a 2e 53 53 20 4f 75 74 | 70 75 74 20 46 6f 72 6d |..SS Out|put Form|
|00005250| 61 74 0a 41 20 6c 69 73 | 74 20 6f 66 20 68 6f 73 |at.A lis|t of hos|
|00005260| 74 2d 72 6f 75 74 65 20 | 70 61 69 72 73 20 69 73 |t-route |pairs is|
|00005270| 20 77 72 69 74 74 65 6e | 20 74 6f 20 74 68 65 20 | written| to the |
|00005280| 73 74 61 6e 64 61 72 64 | 20 6f 75 74 70 75 74 2c |standard| output,|
|00005290| 0a 77 68 65 72 65 20 72 | 6f 75 74 65 20 69 73 20 |.where r|oute is |
|000052a0| 61 20 73 74 72 69 6e 67 | 20 61 70 70 72 6f 70 72 |a string| appropr|
|000052b0| 69 61 74 65 20 66 6f 72 | 20 75 73 65 20 77 69 74 |iate for| use wit|
|000052c0| 68 0a 2e 49 52 20 70 72 | 69 6e 74 66 20 28 33 29 |h..IR pr|intf (3)|
|000052d0| 2c 0a 2e 49 52 20 65 2e | 67 2e 20 2c 0a 2e 52 53 |,..IR e.|g. ,..RS|
|000052e0| 0a 2e 6e 66 0a 2e 74 61 | 20 31 30 6d 20 32 30 6d |..nf..ta| 10m 20m|
|000052f0| 0a 0a 72 75 74 67 65 72 | 73 09 70 72 69 6e 63 65 |..rutger|s.prince|
|00005300| 74 6f 6e 21 74 6f 70 61 | 7a 21 25 73 40 72 75 74 |ton!topa|z!%s@rut|
|00005310| 67 65 72 73 0a 2e 66 69 | 0a 2e 52 45 0a 2e 50 50 |gers..fi|..RE..PP|
|00005320| 0a 54 68 65 20 60 60 25 | 73 27 27 20 69 6e 20 74 |.The ``%|s'' in t|
|00005330| 68 65 20 72 6f 75 74 65 | 20 73 74 72 69 6e 67 20 |he route| string |
|00005340| 73 68 6f 75 6c 64 20 62 | 65 20 72 65 70 6c 61 63 |should b|e replac|
|00005350| 65 64 20 62 79 20 74 68 | 65 0a 75 73 65 72 20 6e |ed by th|e.user n|
|00005360| 61 6d 65 20 61 74 20 74 | 68 65 20 64 65 73 74 69 |ame at t|he desti|
|00005370| 6e 61 74 69 6f 6e 20 68 | 6f 73 74 2e 0a 28 54 68 |nation h|ost..(Th|
|00005380| 69 73 20 74 61 73 6b 20 | 69 73 20 6e 6f 72 6d 61 |is task |is norma|
|00005390| 6c 6c 79 20 70 65 72 66 | 6f 72 6d 65 64 20 62 79 |lly perf|ormed by|
|000053a0| 20 61 20 6d 61 69 6c 65 | 72 2e 29 0a 2e 50 50 0a | a maile|r.)..PP.|
|000053b0| 45 78 63 65 70 74 20 66 | 6f 72 0a 2e 49 20 64 6f |Except f|or..I do|
|000053c0| 6d 61 69 6e 73 0a 28 73 | 65 65 20 62 65 6c 6f 77 |mains.(s|ee below|
|000053d0| 29 2c 0a 74 68 65 20 6e | 61 6d 65 20 6f 66 20 61 |),.the n|ame of a|
|000053e0| 20 6e 65 74 77 6f 72 6b | 20 69 73 20 6e 65 76 65 | network| is neve|
|000053f0| 72 20 75 73 65 64 20 69 | 6e 0a 65 78 70 61 6e 73 |r used i|n.expans|
|00005400| 69 6f 6e 73 2e 0a 54 68 | 75 73 2c 20 69 6e 20 74 |ions..Th|us, in t|
|00005410| 68 65 20 65 61 72 6c 69 | 65 72 20 65 78 61 6d 70 |he earli|er examp|
|00005420| 6c 65 2c 20 74 68 65 20 | 70 61 74 68 20 66 72 6f |le, the |path fro|
|00005430| 6d 20 64 6f 77 6e 20 74 | 6f 0a 75 70 20 77 6f 75 |m down t|o.up wou|
|00005440| 6c 64 20 62 65 20 60 60 | 75 70 21 25 73 2c 27 27 |ld be ``|up!%s,''|
|00005450| 20 6e 6f 74 20 60 60 70 | 72 69 6e 63 65 74 6f 6e | not ``p|rinceton|
|00005460| 2d 65 74 68 65 72 6e 65 | 74 21 75 70 21 25 73 2e |-etherne|t!up!%s.|
|00005470| 27 27 0a 2e 53 53 20 47 | 61 74 65 77 61 79 73 0a |''..SS G|ateways.|
|00005480| 41 20 6e 65 74 77 6f 72 | 6b 20 69 73 20 72 65 70 |A networ|k is rep|
|00005490| 72 65 73 65 6e 74 65 64 | 20 62 79 0a 61 20 70 73 |resented| by.a ps|
|000054a0| 65 75 64 6f 2d 68 6f 73 | 74 20 61 6e 64 20 61 20 |eudo-hos|t and a |
|000054b0| 73 65 74 20 6f 66 20 6e | 65 74 77 6f 72 6b 20 6d |set of n|etwork m|
|000054c0| 65 6d 62 65 72 73 2e 0a | 4c 69 6e 6b 73 20 66 72 |embers..|Links fr|
|000054d0| 6f 6d 20 74 68 65 20 6d | 65 6d 62 65 72 73 20 74 |om the m|embers t|
|000054e0| 6f 20 74 68 65 20 6e 65 | 74 77 6f 72 6b 20 68 61 |o the ne|twork ha|
|000054f0| 76 65 20 74 68 65 20 77 | 65 69 67 68 74 20 67 69 |ve the w|eight gi|
|00005500| 76 65 6e 20 69 6e 0a 74 | 68 65 20 69 6e 70 75 74 |ven in.t|he input|
|00005510| 2c 20 77 68 69 6c 65 20 | 74 68 65 20 63 6f 73 74 |, while |the cost|
|00005520| 20 66 72 6f 6d 20 74 68 | 65 20 6e 65 74 77 6f 72 | from th|e networ|
|00005530| 6b 20 74 6f 20 74 68 65 | 20 6d 65 6d 62 65 72 73 |k to the| members|
|00005540| 20 69 73 20 7a 65 72 6f | 2e 0a 49 66 20 61 20 6e | is zero|..If a n|
|00005550| 65 74 77 6f 72 6b 20 69 | 73 20 64 65 63 6c 61 72 |etwork i|s declar|
|00005560| 65 64 20 64 65 61 64 20 | 6f 6e 20 74 68 65 20 63 |ed dead |on the c|
|00005570| 6f 6d 6d 61 6e 64 20 6c | 69 6e 65 20 28 77 69 74 |ommand l|ine (wit|
|00005580| 68 20 74 68 65 0a 2e 42 | 20 5c 2d 64 0a 6f 70 74 |h the..B| \-d.opt|
|00005590| 69 6f 6e 29 2c 0a 74 68 | 65 20 6d 65 6d 62 65 72 |ion),.th|e member|
|000055a0| 2d 74 6f 2d 6e 65 74 77 | 6f 72 6b 20 6c 69 6e 6b |-to-netw|ork link|
|000055b0| 73 20 61 72 65 20 6d 61 | 72 6b 65 64 20 64 65 61 |s are ma|rked dea|
|000055c0| 64 2c 0a 77 68 69 63 68 | 20 64 69 73 63 6f 75 72 |d,.which| discour|
|000055d0| 61 67 65 73 20 70 61 74 | 68 73 20 74 6f 20 6d 65 |ages pat|hs to me|
|000055e0| 6d 62 65 72 73 20 62 79 | 20 77 61 79 20 6f 66 20 |mbers by| way of |
|000055f0| 74 68 65 20 6e 65 74 77 | 6f 72 6b 2e 0a 2e 50 50 |the netw|ork...PP|
|00005600| 0a 49 66 20 74 68 65 20 | 69 6e 70 75 74 20 61 6c |.If the |input al|
|00005610| 73 6f 20 73 68 6f 77 73 | 20 61 20 6c 69 6e 6b 20 |so shows| a link |
|00005620| 66 72 6f 6d 20 61 20 68 | 6f 73 74 20 74 6f 20 74 |from a h|ost to t|
|00005630| 68 65 20 6e 65 74 77 6f | 72 6b 2c 0a 74 68 65 6e |he netwo|rk,.then|
|00005640| 20 74 68 61 74 20 68 6f | 73 74 20 77 69 6c 6c 20 | that ho|st will |
|00005650| 62 65 20 70 72 65 66 65 | 72 72 65 64 20 61 73 20 |be prefe|rred as |
|00005660| 61 20 67 61 74 65 77 61 | 79 2e 0a 47 61 74 65 77 |a gatewa|y..Gatew|
|00005670| 61 79 73 20 6e 65 65 64 | 20 6e 6f 74 20 62 65 20 |ays need| not be |
|00005680| 6e 65 74 77 6f 72 6b 20 | 6d 65 6d 62 65 72 73 2e |network |members.|
|00005690| 0a 2e 50 50 0a 2e 49 52 | 20 45 2e 67 2e 20 2c 0a |..PP..IR| E.g. ,.|
|000056a0| 73 75 70 70 6f 73 65 0a | 2e 53 4d 20 43 53 4e 45 |suppose.|.SM CSNE|
|000056b0| 54 0a 69 73 20 64 65 63 | 6c 61 72 65 64 20 64 65 |T.is dec|lared de|
|000056c0| 61 64 20 6f 6e 20 74 68 | 65 20 63 6f 6d 6d 61 6e |ad on th|e comman|
|000056d0| 64 20 6c 69 6e 65 0a 61 | 6e 64 20 74 68 65 20 69 |d line.a|nd the i|
|000056e0| 6e 70 75 74 20 63 6f 6e | 74 61 69 6e 73 0a 2e 52 |nput con|tains..R|
|000056f0| 53 0a 2e 6e 66 0a 2e 74 | 61 20 31 30 6d 20 32 30 |S..nf..t|a 10m 20|
|00005700| 6d 0a 0a 5c 73 2d 31 43 | 53 4e 45 54 5c 73 30 20 |m..\s-1C|SNET\s0 |
|00005710| 3d 20 7b 2e 2e 2e 7d 0a | 63 73 6e 65 74 2d 72 65 |= {...}.|csnet-re|
|00005720| 6c 61 79 09 63 73 6e 65 | 74 0a 2e 66 69 0a 2e 52 |lay.csne|t..fi..R|
|00005730| 45 0a 2e 50 50 0a 54 68 | 65 6e 20 72 6f 75 74 65 |E..PP.Th|en route|
|00005740| 73 20 74 6f 0a 2e 53 4d | 20 43 53 4e 45 54 0a 68 |s to..SM| CSNET.h|
|00005750| 6f 73 74 73 20 77 69 6c | 6c 20 75 73 65 20 63 73 |osts wil|l use cs|
|00005760| 6e 65 74 2d 72 65 6c 61 | 79 20 61 73 20 61 20 67 |net-rela|y as a g|
|00005770| 61 74 65 77 61 79 2e 0a | 2e 50 50 0a 2e 49 20 70 |ateway..|.PP..I p|
|00005780| 61 74 68 61 6c 69 61 73 | 0a 64 69 73 63 6f 75 72 |athalias|.discour|
|00005790| 61 67 65 73 20 66 6f 72 | 77 61 72 64 69 6e 67 20 |ages for|warding |
|000057a0| 62 65 79 6f 6e 64 20 64 | 65 61 64 20 6e 65 74 77 |beyond d|ead netw|
|000057b0| 6f 72 6b 73 2e 0a 2e 53 | 53 20 44 6f 6d 61 69 6e |orks...S|S Domain|
|000057c0| 73 0a 41 20 68 6f 73 74 | 20 6f 72 20 6e 65 74 77 |s.A host| or netw|
|000057d0| 6f 72 6b 20 77 68 6f 73 | 65 20 6e 61 6d 65 20 62 |ork whos|e name b|
|000057e0| 65 67 69 6e 73 20 77 69 | 74 68 20 60 2e 27 20 69 |egins wi|th `.' i|
|000057f0| 73 20 63 61 6c 6c 65 64 | 0a 61 20 64 6f 6d 61 69 |s called|.a domai|
|00005800| 6e 2e 0a 44 6f 6d 61 69 | 6e 73 20 61 72 65 20 70 |n..Domai|ns are p|
|00005810| 72 65 73 75 6d 65 64 20 | 74 6f 20 72 65 71 75 69 |resumed |to requi|
|00005820| 72 65 20 67 61 74 65 77 | 61 79 73 2c 0a 2e 49 52 |re gatew|ays,..IR|
|00005830| 20 69 2e 65 2e 20 2c 0a | 74 68 65 79 20 61 72 65 | i.e. ,.|they are|
|00005840| 20 5c 73 2d 31 44 45 41 | 44 5c 73 30 2e 0a 54 68 | \s-1DEA|D\s0..Th|
|00005850| 65 20 72 6f 75 74 65 20 | 67 69 76 65 6e 20 62 79 |e route |given by|
|00005860| 20 61 20 70 61 74 68 20 | 74 68 72 6f 75 67 68 20 | a path |through |
|00005870| 61 20 64 6f 6d 61 69 6e | 20 69 73 20 73 69 6d 69 |a domain| is simi|
|00005880| 6c 61 72 20 74 6f 0a 74 | 68 61 74 20 66 6f 72 20 |lar to.t|hat for |
|00005890| 61 20 6e 65 74 77 6f 72 | 6b 2c 20 62 75 74 20 68 |a networ|k, but h|
|000058a0| 65 72 65 0a 74 68 65 20 | 64 6f 6d 61 69 6e 20 6e |ere.the |domain n|
|000058b0| 61 6d 65 20 69 73 20 74 | 61 63 6b 65 64 20 6f 6e |ame is t|acked on|
|000058c0| 74 6f 20 74 68 65 20 65 | 6e 64 20 6f 66 20 74 68 |to the e|nd of th|
|000058d0| 65 20 6e 65 78 74 20 68 | 6f 73 74 2e 0a 53 75 62 |e next h|ost..Sub|
|000058e0| 64 6f 6d 61 69 6e 73 20 | 61 72 65 20 70 65 72 6d |domains |are perm|
|000058f0| 69 74 74 65 64 2e 0a 2e | 49 52 20 45 2e 67 2e 20 |itted...|IR E.g. |
|00005900| 2c 0a 2e 52 53 0a 2e 6e | 66 0a 2e 74 61 20 31 69 |,..RS..n|f..ta 1i|
|00005910| 0a 2e 74 61 20 31 30 6d | 20 32 30 6d 0a 0a 68 61 |..ta 10m| 20m..ha|
|00005920| 72 76 61 72 64 09 2e 5c | 73 2d 31 45 44 55 5c 73 |rvard..\|s-1EDU\s|
|00005930| 30 0a 5c 26 2e 5c 73 2d | 31 45 44 55 5c 73 30 20 |0.\&.\s-|1EDU\s0 |
|00005940| 3d 20 7b 2e 5c 73 2d 31 | 42 45 52 4b 45 4c 45 59 |= {.\s-1|BERKELEY|
|00005950| 5c 73 30 7d 0a 5c 26 2e | 5c 73 2d 31 42 45 52 4b |\s0}.\&.|\s-1BERK|
|00005960| 45 4c 45 59 5c 73 30 09 | 65 72 6e 69 65 0a 0a 2e |ELEY\s0.|ernie...|
|00005970| 66 69 0a 2e 52 45 0a 79 | 69 65 6c 64 73 0a 2e 52 |fi..RE.y|ields..R|
|00005980| 53 0a 2e 6e 66 0a 2e 74 | 61 20 31 30 6d 20 32 30 |S..nf..t|a 10m 20|
|00005990| 6d 0a 0a 65 72 6e 69 65 | 09 2e 2e 2e 21 68 61 72 |m..ernie|....!har|
|000059a0| 76 61 72 64 21 65 72 6e | 69 65 2e 5c 73 2d 31 42 |vard!ern|ie.\s-1B|
|000059b0| 45 52 4b 45 4c 45 59 5c | 73 30 2e 5c 73 2d 31 45 |ERKELEY\|s0.\s-1E|
|000059c0| 44 55 5c 73 30 21 25 73 | 0a 2e 66 69 0a 2e 52 45 |DU\s0!%s|..fi..RE|
|000059d0| 0a 2e 50 50 0a 49 66 20 | 61 20 64 6f 6d 61 69 6e |..PP.If |a domain|
|000059e0| 20 6d 65 6d 62 65 72 20 | 69 73 20 64 65 63 6c 61 | member |is decla|
|000059f0| 72 65 64 20 70 72 69 76 | 61 74 65 2c 20 69 74 73 |red priv|ate, its|
|00005a00| 20 66 75 6c 6c 79 20 71 | 75 61 6c 69 66 69 65 64 | fully q|ualified|
|00005a10| 20 64 6f 6d 61 69 6e 20 | 6e 61 6d 65 0a 69 73 20 | domain |name.is |
|00005a20| 73 68 6f 77 6e 20 69 6e | 73 74 65 61 64 2e 0a 2e |shown in|stead...|
|00005a30| 49 52 20 45 2e 67 2e 20 | 2c 0a 69 66 20 65 72 6e |IR E.g. |,.if ern|
|00005a40| 69 65 20 69 73 20 64 65 | 63 6c 61 72 65 64 20 61 |ie is de|clared a|
|00005a50| 0a 70 72 69 76 61 74 65 | 20 6d 65 6d 62 65 72 20 |.private| member |
|00005a60| 6f 66 20 2e 5c 73 2d 31 | 42 45 52 4b 45 4c 45 59 |of .\s-1|BERKELEY|
|00005a70| 5c 73 30 2c 20 74 68 65 | 6e 20 74 68 65 20 6f 75 |\s0, the|n the ou|
|00005a80| 74 70 75 74 20 69 73 0a | 2e 52 53 0a 2e 6e 66 0a |tput is.|.RS..nf.|
|00005a90| 2e 74 61 20 31 30 6d 20 | 32 35 6d 0a 0a 65 72 6e |.ta 10m |25m..ern|
|00005aa0| 69 65 2e 5c 73 2d 31 42 | 45 52 4b 45 4c 45 59 5c |ie.\s-1B|ERKELEY\|
|00005ab0| 73 30 2e 5c 73 2d 31 45 | 44 55 5c 73 30 09 2e 2e |s0.\s-1E|DU\s0...|
|00005ac0| 2e 21 68 61 72 76 61 72 | 64 21 65 72 6e 69 65 2e |.!harvar|d!ernie.|
|00005ad0| 5c 73 2d 31 42 45 52 4b | 45 4c 45 59 5c 73 30 2e |\s-1BERK|ELEY\s0.|
|00005ae0| 5c 73 2d 31 45 44 55 5c | 73 30 21 25 73 0a 2e 66 |\s-1EDU\|s0!%s..f|
|00005af0| 69 0a 2e 52 45 0a 2e 50 | 50 0a 4f 75 74 70 75 74 |i..RE..P|P.Output|
|00005b00| 20 69 73 20 61 6c 73 6f | 20 67 69 76 65 6e 20 66 | is also| given f|
|00005b10| 6f 72 20 74 68 65 20 6e | 65 61 72 65 73 74 20 67 |or the n|earest g|
|00005b20| 61 74 65 77 61 79 0a 74 | 6f 20 61 20 64 6f 6d 61 |ateway.t|o a doma|
|00005b30| 69 6e 20 6f 72 20 73 75 | 62 64 6f 6d 61 69 6e 2e |in or su|bdomain.|
|00005b40| 0a 2e 49 52 20 45 2e 67 | 2e 20 2c 0a 69 6e 20 74 |..IR E.g|. ,.in t|
|00005b50| 68 65 20 65 78 61 6d 70 | 6c 65 20 61 62 6f 76 65 |he examp|le above|
|00005b60| 0a 2e 52 53 0a 2e 6e 66 | 0a 2e 74 61 20 31 30 6d |..RS..nf|..ta 10m|
|00005b70| 20 32 35 6d 0a 0a 5c 26 | 2e 5c 73 2d 31 45 44 55 | 25m..\&|.\s-1EDU|
|00005b80| 5c 73 30 09 2e 2e 2e 21 | 68 61 72 76 61 72 64 21 |\s0....!|harvard!|
|00005b90| 25 73 0a 5c 26 2e 5c 73 | 2d 31 42 45 52 4b 45 4c |%s.\&.\s|-1BERKEL|
|00005ba0| 45 59 5c 73 30 2e 5c 73 | 2d 31 45 44 55 5c 73 30 |EY\s0.\s|-1EDU\s0|
|00005bb0| 09 2e 2e 2e 21 68 61 72 | 76 61 72 64 21 25 73 0a |....!har|vard!%s.|
|00005bc0| 2e 66 69 0a 2e 52 45 0a | 2e 53 53 20 44 61 74 61 |.fi..RE.|.SS Data|
|00005bd0| 62 61 73 65 73 0a 2e 49 | 20 4d 61 6b 65 64 62 0a |bases..I| Makedb.|
|00005be0| 62 75 69 6c 64 73 20 61 | 0a 2e 49 52 20 64 62 6d |builds a|..IR dbm|
|00005bf0| 20 28 33 29 0a 64 61 74 | 61 62 61 73 65 20 66 72 | (3).dat|abase fr|
|00005c00| 6f 6d 20 74 68 65 20 73 | 74 61 6e 64 61 72 64 20 |om the s|tandard |
|00005c10| 69 6e 70 75 74 20 6f 72 | 20 66 72 6f 6d 20 74 68 |input or| from th|
|00005c20| 65 20 6e 61 6d 65 64 0a | 2e 49 52 20 66 69 6c 65 |e named.|.IR file|
|00005c30| 73 20 2e 0a 28 5c 66 49 | 4d 61 6b 65 64 62 5c 66 |s ..(\fI|Makedb\f|
|00005c40| 50 20 72 65 70 6c 61 63 | 65 73 20 74 68 65 20 6f |P replac|es the o|
|00005c50| 62 73 6f 6c 65 74 65 20 | 0a 2e 42 20 5c 2d 62 0a |bsolete |..B \-b.|
|00005c60| 6f 70 74 69 6f 6e 20 6f | 66 0a 2e 49 52 20 70 61 |option o|f..IR pa|
|00005c70| 74 68 61 6c 69 61 73 20 | 2c 0a 77 68 69 63 68 20 |thalias |,.which |
|00005c80| 69 73 20 6e 6f 20 6c 6f | 6e 67 65 72 20 72 65 63 |is no lo|nger rec|
|00005c90| 6f 67 6e 69 7a 65 64 2e | 29 0a 49 6e 70 75 74 20 |ognized.|).Input |
|00005ca0| 69 73 20 65 78 70 65 63 | 74 65 64 20 74 6f 20 62 |is expec|ted to b|
|00005cb0| 65 20 73 65 71 75 65 6e | 63 65 20 6f 66 0a 2e 53 |e sequen|ce of..S|
|00005cc0| 4d 20 41 53 43 49 49 0a | 72 65 63 6f 72 64 73 2c |M ASCII.|records,|
|00005cd0| 0a 65 61 63 68 20 63 6f | 6e 73 69 73 74 69 6e 67 |.each co|nsisting|
|00005ce0| 20 6f 66 20 61 20 6b 65 | 79 20 66 69 65 6c 64 20 | of a ke|y field |
|00005cf0| 61 6e 64 20 61 20 64 61 | 74 61 20 66 69 65 6c 64 |and a da|ta field|
|00005d00| 20 73 65 70 61 72 61 74 | 65 64 20 62 79 20 61 20 | separat|ed by a |
|00005d10| 73 69 6e 67 6c 65 20 74 | 61 62 2e 0a 49 66 20 74 |single t|ab..If t|
|00005d20| 68 65 20 74 61 62 20 69 | 73 20 6d 69 73 73 69 6e |he tab i|s missin|
|00005d30| 67 2c 20 74 68 65 20 64 | 61 74 61 20 66 69 65 6c |g, the d|ata fiel|
|00005d40| 64 20 69 73 20 61 73 73 | 75 6d 65 64 20 74 6f 20 |d is ass|umed to |
|00005d50| 62 65 20 65 6d 70 74 79 | 2e 0a 2e 53 48 20 46 49 |be empty|...SH FI|
|00005d60| 4c 45 53 20 45 54 20 41 | 4c 2e 0a 2e 74 61 20 5c |LES ET A|L...ta \|
|00005d70| 77 27 2f 75 73 72 2f 6c | 6f 63 61 6c 2f 6c 69 62 |w'/usr/l|ocal/lib|
|00005d80| 2f 70 61 6c 69 61 73 2e | 7b 64 69 72 2c 70 61 67 |/palias.|{dir,pag|
|00005d90| 7d 20 20 20 20 20 27 75 | 0a 2f 75 73 72 2f 6c 6f |} 'u|./usr/lo|
|00005da0| 63 61 6c 2f 6c 69 62 2f | 70 61 6c 69 61 73 2e 7b |cal/lib/|palias.{|
|00005db0| 64 69 72 2c 70 61 67 7d | 09 64 65 66 61 75 6c 74 |dir,pag}|.default|
|00005dc0| 20 64 62 6d 20 6f 75 74 | 70 75 74 0a 2e 62 72 0a | dbm out|put..br.|
|00005dd0| 6e 65 77 73 67 72 6f 75 | 70 20 6d 6f 64 2e 6d 61 |newsgrou|p mod.ma|
|00005de0| 70 09 6c 69 6b 65 6c 79 | 20 6c 6f 63 61 74 69 6f |p.likely| locatio|
|00005df0| 6e 20 6f 66 20 73 6f 6d | 65 20 69 6e 70 75 74 20 |n of som|e input |
|00005e00| 66 69 6c 65 73 0a 2e 62 | 72 0a 2e 49 52 20 67 65 |files..b|r..IR ge|
|00005e10| 74 6f 70 74 20 28 33 29 | 2c 0a 61 76 61 69 6c 61 |topt (3)|,.availa|
|00005e20| 62 6c 65 20 66 72 6f 6d | 20 6e 65 77 73 67 72 6f |ble from| newsgro|
|00005e30| 75 70 20 6d 6f 64 2e 73 | 6f 75 72 63 65 73 20 28 |up mod.s|ources (|
|00005e40| 69 66 20 6e 6f 74 20 69 | 6e 20 74 68 65 20 43 20 |if not i|n the C |
|00005e50| 6c 69 62 72 61 72 79 29 | 2e 0a 2e 53 48 20 42 55 |library)|...SH BU|
|00005e60| 47 53 0a 54 68 65 20 6f | 72 64 65 72 20 6f 66 20 |GS.The o|rder of |
|00005e70| 61 72 67 75 6d 65 6e 74 | 73 20 69 73 20 73 69 67 |argument|s is sig|
|00005e80| 6e 69 66 69 63 61 6e 74 | 2e 0a 49 6e 20 70 61 72 |nificant|..In par|
|00005e90| 74 69 63 75 6c 61 72 2c | 0a 2e 42 20 5c 2d 69 0a |ticular,|..B \-i.|
|00005ea0| 61 6e 64 0a 2e 42 20 5c | 2d 74 0a 73 68 6f 75 6c |and..B \|-t.shoul|
|00005eb0| 64 20 61 70 70 65 61 72 | 20 65 61 72 6c 79 2e 0a |d appear| early..|
|00005ec0| 2e 50 50 0a 2e 49 20 70 | 61 74 68 61 6c 69 61 73 |.PP..I p|athalias|
|00005ed0| 0a 63 61 6e 20 67 65 6e | 65 72 61 74 65 20 68 79 |.can gen|erate hy|
|00005ee0| 62 72 69 64 20 28 5c 66 | 49 69 2e 65 2e 5c 66 50 |brid (\f|Ii.e.\fP|
|00005ef0| 20 61 6d 62 69 67 75 6f | 75 73 29 20 72 6f 75 74 | ambiguo|us) rout|
|00005f00| 65 73 2c 20 77 68 69 63 | 68 20 61 72 65 0a 61 62 |es, whic|h are.ab|
|00005f10| 68 6f 72 72 65 6e 74 20 | 61 6e 64 20 6d 6f 73 74 |horrent |and most|
|00005f20| 20 63 65 72 74 61 69 6e | 6c 79 20 73 68 6f 75 6c | certain|ly shoul|
|00005f30| 64 20 6e 6f 74 20 62 65 | 20 67 69 76 65 6e 20 61 |d not be| given a|
|00005f40| 73 20 65 78 61 6d 70 6c | 65 73 0a 69 6e 20 74 68 |s exampl|es.in th|
|00005f50| 65 20 6d 61 6e 75 61 6c | 20 65 6e 74 72 79 2e 0a |e manual| entry..|
|00005f60| 2e 50 50 0a 4d 75 6c 74 | 69 70 6c 65 20 60 40 27 |.PP.Mult|iple `@'|
|00005f70| 73 20 69 6e 20 72 6f 75 | 74 65 73 20 61 72 65 20 |s in rou|tes are |
|00005f80| 70 72 6f 68 69 62 69 74 | 65 64 20 62 79 20 6d 61 |prohibit|ed by ma|
|00005f90| 6e 79 20 6d 61 69 6c 65 | 72 73 2c 20 73 6f 0a 2e |ny maile|rs, so..|
|00005fa0| 49 20 70 61 74 68 61 6c | 69 61 73 0a 72 65 73 6f |I pathal|ias.reso|
|00005fb0| 72 74 73 20 74 6f 20 74 | 68 65 20 60 60 6d 61 67 |rts to t|he ``mag|
|00005fc0| 69 63 20 25 27 27 20 72 | 75 6c 65 20 77 68 65 6e |ic %'' r|ule when|
|00005fd0| 20 61 70 70 72 6f 70 72 | 69 61 74 65 2e 0a 28 54 | appropr|iate..(T|
|00005fe0| 68 69 73 20 63 6f 6e 76 | 65 6e 74 69 6f 6e 20 69 |his conv|ention i|
|00005ff0| 73 20 6e 6f 74 20 64 6f | 63 75 6d 65 6e 74 65 64 |s not do|cumented|
|00006000| 20 61 6e 79 77 68 65 72 | 65 2c 20 69 6e 63 6c 75 | anywher|e, inclu|
|00006010| 64 69 6e 67 20 68 65 72 | 65 2e 29 0a 2e 50 50 0a |ding her|e.)..PP.|
|00006020| 44 6f 6d 61 69 6e 73 20 | 63 6f 6e 73 74 69 74 75 |Domains |constitu|
|00006030| 74 65 20 61 20 66 75 74 | 69 6c 65 20 61 74 74 65 |te a fut|ile atte|
|00006040| 6d 70 74 20 74 6f 20 64 | 65 66 65 61 74 20 61 6e |mpt to d|efeat an|
|00006050| 61 72 63 68 79 20 61 6e | 64 20 6f 74 68 65 72 77 |archy an|d otherw|
|00006060| 69 73 65 0a 72 65 74 61 | 72 64 20 70 72 6f 67 72 |ise.reta|rd progr|
|00006070| 65 73 73 2e 0a 2e 53 48 | 20 41 55 54 48 4f 52 53 |ess...SH| AUTHORS|
|00006080| 0a 53 74 65 76 65 20 42 | 65 6c 6c 6f 76 69 6e 20 |.Steve B|ellovin |
|00006090| 28 75 6c 79 73 73 65 73 | 21 73 6d 62 29 0a 2e 62 |(ulysses|!smb)..b|
|000060a0| 72 0a 50 65 74 65 72 20 | 48 6f 6e 65 79 6d 61 6e |r.Peter |Honeyman|
|000060b0| 20 28 70 72 69 6e 63 65 | 74 6f 6e 21 68 6f 6e 65 | (prince|ton!hone|
|000060c0| 79 29 0a 53 48 41 52 5f | 45 4f 46 0a 69 66 20 74 |y).SHAR_|EOF.if t|
|000060d0| 65 73 74 20 39 32 37 37 | 20 2d 6e 65 20 22 60 77 |est 9277| -ne "`w|
|000060e0| 63 20 2d 63 20 3c 20 27 | 70 61 74 68 61 6c 69 61 |c -c < '|pathalia|
|000060f0| 73 2e 31 27 60 22 0a 74 | 68 65 6e 0a 09 65 63 68 |s.1'`".t|hen..ech|
|00006100| 6f 20 73 68 61 72 3a 20 | 65 72 72 6f 72 20 74 72 |o shar: |error tr|
|00006110| 61 6e 73 6d 69 74 74 69 | 6e 67 20 22 27 70 61 74 |ansmitti|ng "'pat|
|00006120| 68 61 6c 69 61 73 2e 31 | 27 22 20 27 28 73 68 6f |halias.1|'" '(sho|
|00006130| 75 6c 64 20 68 61 76 65 | 20 62 65 65 6e 20 39 32 |uld have| been 92|
|00006140| 37 37 20 63 68 61 72 61 | 63 74 65 72 73 29 27 0a |77 chara|cters)'.|
|00006150| 66 69 0a 66 69 0a 65 78 | 69 74 20 30 0a 23 09 45 |fi.fi.ex|it 0.#.E|
|00006160| 6e 64 20 6f 66 20 73 68 | 65 6c 6c 20 61 72 63 68 |nd of sh|ell arch|
|00006170| 69 76 65 0a | |ive. | |
+--------+-------------------------+-------------------------+--------+--------+