Hex Artifact Content
Not logged in

Artifact 4a5df34002c0725f7d1e1739799d95b5f6870125:


0000: 5c 20 6e 65 74 32 6f 20 74 65 6d 70 6c 61 74 65  \ net2o template
0010: 20 66 6f 72 20 6e 65 77 20 66 69 6c 65 73 0a 0a   for new files..
0020: 5c 20 43 6f 70 79 72 69 67 68 74 20 28 43 29 20  \ Copyright (C) 
0030: 32 30 31 35 20 20 20 42 65 72 6e 64 20 50 61 79  2015   Bernd Pay
0040: 73 61 6e 0a 0a 5c 20 54 68 69 73 20 70 72 6f 67  san..\ This prog
0050: 72 61 6d 20 69 73 20 66 72 65 65 20 73 6f 66 74  ram is free soft
0060: 77 61 72 65 3a 20 79 6f 75 20 63 61 6e 20 72 65  ware: you can re
0070: 64 69 73 74 72 69 62 75 74 65 20 69 74 20 61 6e  distribute it an
0080: 64 2f 6f 72 20 6d 6f 64 69 66 79 0a 5c 20 69 74  d/or modify.\ it
0090: 20 75 6e 64 65 72 20 74 68 65 20 74 65 72 6d 73   under the terms
00a0: 20 6f 66 20 74 68 65 20 47 4e 55 20 41 66 66 65   of the GNU Affe
00b0: 72 6f 20 47 65 6e 65 72 61 6c 20 50 75 62 6c 69  ro General Publi
00c0: 63 20 4c 69 63 65 6e 73 65 20 61 73 20 70 75 62  c License as pub
00d0: 6c 69 73 68 65 64 20 62 79 0a 5c 20 74 68 65 20  lished by.\ the 
00e0: 46 72 65 65 20 53 6f 66 74 77 61 72 65 20 46 6f  Free Software Fo
00f0: 75 6e 64 61 74 69 6f 6e 2c 20 65 69 74 68 65 72  undation, either
0100: 20 76 65 72 73 69 6f 6e 20 33 20 6f 66 20 74 68   version 3 of th
0110: 65 20 4c 69 63 65 6e 73 65 2c 20 6f 72 0a 5c 20  e License, or.\ 
0120: 28 61 74 20 79 6f 75 72 20 6f 70 74 69 6f 6e 29  (at your option)
0130: 20 61 6e 79 20 6c 61 74 65 72 20 76 65 72 73 69   any later versi
0140: 6f 6e 2e 0a 0a 5c 20 54 68 69 73 20 70 72 6f 67  on...\ This prog
0150: 72 61 6d 20 69 73 20 64 69 73 74 72 69 62 75 74  ram is distribut
0160: 65 64 20 69 6e 20 74 68 65 20 68 6f 70 65 20 74  ed in the hope t
0170: 68 61 74 20 69 74 20 77 69 6c 6c 20 62 65 20 75  hat it will be u
0180: 73 65 66 75 6c 2c 0a 5c 20 62 75 74 20 57 49 54  seful,.\ but WIT
0190: 48 4f 55 54 20 41 4e 59 20 57 41 52 52 41 4e 54  HOUT ANY WARRANT
01a0: 59 3b 20 77 69 74 68 6f 75 74 20 65 76 65 6e 20  Y; without even 
01b0: 74 68 65 20 69 6d 70 6c 69 65 64 20 77 61 72 72  the implied warr
01c0: 61 6e 74 79 20 6f 66 0a 5c 20 4d 45 52 43 48 41  anty of.\ MERCHA
01d0: 4e 54 41 42 49 4c 49 54 59 20 6f 72 20 46 49 54  NTABILITY or FIT
01e0: 4e 45 53 53 20 46 4f 52 20 41 20 50 41 52 54 49  NESS FOR A PARTI
01f0: 43 55 4c 41 52 20 50 55 52 50 4f 53 45 2e 20 20  CULAR PURPOSE.  
0200: 53 65 65 20 74 68 65 0a 5c 20 47 4e 55 20 41 66  See the.\ GNU Af
0210: 66 65 72 6f 20 47 65 6e 65 72 61 6c 20 50 75 62  fero General Pub
0220: 6c 69 63 20 4c 69 63 65 6e 73 65 20 66 6f 72 20  lic License for 
0230: 6d 6f 72 65 20 64 65 74 61 69 6c 73 2e 0a 0a 5c  more details...\
0240: 20 59 6f 75 20 73 68 6f 75 6c 64 20 68 61 76 65   You should have
0250: 20 72 65 63 65 69 76 65 64 20 61 20 63 6f 70 79   received a copy
0260: 20 6f 66 20 74 68 65 20 47 4e 55 20 41 66 66 65   of the GNU Affe
0270: 72 6f 20 47 65 6e 65 72 61 6c 20 50 75 62 6c 69  ro General Publi
0280: 63 20 4c 69 63 65 6e 73 65 0a 5c 20 61 6c 6f 6e  c License.\ alon
0290: 67 20 77 69 74 68 20 74 68 69 73 20 70 72 6f 67  g with this prog
02a0: 72 61 6d 2e 20 20 49 66 20 6e 6f 74 2c 20 73 65  ram.  If not, se
02b0: 65 20 3c 68 74 74 70 3a 2f 2f 77 77 77 2e 67 6e  e <http://www.gn
02c0: 75 2e 6f 72 67 2f 6c 69 63 65 6e 73 65 73 2f 3e  u.org/licenses/>
02d0: 2e 0a 0a 5c 20 67 65 6e 65 72 69 63 20 68 6f 6f  ...\ generic hoo
02e0: 6b 73 20 61 6e 64 20 75 73 65 72 20 76 61 72 69  ks and user vari
02f0: 61 62 6c 65 73 0a 0a 56 61 72 69 61 62 6c 65 20  ables..Variable 
0300: 70 61 63 6b 65 74 72 0a 56 61 72 69 61 62 6c 65  packetr.Variable
0310: 20 70 61 63 6b 65 74 73 0a 56 61 72 69 61 62 6c   packets.Variabl
0320: 65 20 70 61 63 6b 65 74 72 32 20 5c 20 64 6f 75  e packetr2 \ dou
0330: 62 6c 65 20 72 65 63 65 69 76 65 64 0a 56 61 72  ble received.Var
0340: 69 61 62 6c 65 20 70 61 63 6b 65 74 73 32 20 5c  iable packets2 \
0350: 20 64 6f 75 62 6c 65 20 73 65 6e 64 0a 0a 3a 20   double send..: 
0360: 2e 70 61 63 6b 65 74 73 20 28 20 2d 2d 20 29 0a  .packets ( -- ).
0370: 20 20 20 20 2e 22 20 49 50 20 70 61 63 6b 65 74      ." IP packet
0380: 73 20 73 65 6e 64 2f 72 65 63 65 69 76 65 64 3a  s send/received:
0390: 20 22 20 70 61 63 6b 65 74 73 20 3f 20 2e 22 20   " packets ? ." 
03a0: 28 22 20 70 61 63 6b 65 74 73 32 20 3f 20 2e 22  (" packets2 ? ."
03b0: 20 64 75 70 65 73 29 2f 22 0a 20 20 20 20 70 61   dupes)/".    pa
03c0: 63 6b 65 74 72 20 3f 20 2e 22 20 28 22 20 70 61  cketr ? ." (" pa
03d0: 63 6b 65 74 72 32 20 3f 20 2e 22 20 64 75 70 65  cketr2 ? ." dupe
03e0: 73 29 20 22 20 63 72 0a 20 20 20 20 70 61 63 6b  s) " cr.    pack
03f0: 65 74 73 20 6f 66 66 20 70 61 63 6b 65 74 72 20  ets off packetr 
0400: 6f 66 66 20 70 61 63 6b 65 74 73 32 20 6f 66 66  off packets2 off
0410: 20 70 61 63 6b 65 74 72 32 20 6f 66 66 20 3b 0a   packetr2 off ;.
0420: 0a 55 56 61 6c 75 65 20 70 6f 6c 6c 66 64 23 20  .UValue pollfd# 
0430: 20 30 20 74 6f 20 70 6f 6c 6c 66 64 23 0a 0a 3a   0 to pollfd#..:
0440: 20 70 72 65 70 2d 73 6f 63 6b 73 20 28 20 2d 2d   prep-socks ( --
0450: 20 29 0a 20 20 20 20 65 70 69 70 65 72 20 40 20   ).    epiper @ 
0460: 66 69 6c 65 6e 6f 20 50 4f 4c 4c 49 4e 20 20 70  fileno POLLIN  p
0470: 6f 6c 6c 66 64 73 20 66 64 73 21 2b 20 3e 72 0a  ollfds fds!+ >r.
0480: 20 20 20 20 6e 65 74 32 6f 2d 73 6f 63 6b 20 5b      net2o-sock [
0490: 49 46 44 45 46 5d 20 6e 6f 2d 68 79 62 72 69 64  IFDEF] no-hybrid
04a0: 20 73 77 61 70 20 5b 54 48 45 4e 5d 20 50 4f 4c   swap [THEN] POL
04b0: 4c 49 4e 20 20 72 3e 20 66 64 73 21 2b 0a 20 20  LIN  r> fds!+.  
04c0: 20 20 5b 49 46 44 45 46 5d 20 6e 6f 2d 68 79 62    [IFDEF] no-hyb
04d0: 72 69 64 20 50 4f 4c 4c 49 4e 20 73 77 61 70 20  rid POLLIN swap 
04e0: 66 64 73 21 2b 20 5b 54 48 45 4e 5d 0a 20 20 20  fds!+ [THEN].   
04f0: 20 70 6f 6c 6c 66 64 73 20 2d 20 70 6f 6c 6c 66   pollfds - pollf
0500: 64 20 2f 20 74 6f 20 70 6f 6c 6c 66 64 23 20 3b  d / to pollfd# ;
0510: 0a 0a 55 73 65 72 20 70 74 69 6d 65 6f 75 74 20  ..User ptimeout 
0520: 20 63 65 6c 6c 20 75 61 6c 6c 6f 74 20 64 72 6f   cell uallot dro
0530: 70 0a 23 39 39 39 39 39 39 39 39 39 20 56 61 6c  p.#999999999 Val
0540: 75 65 20 70 6f 6c 6c 2d 74 69 6d 65 6f 75 74 23  ue poll-timeout#
0550: 20 5c 20 31 73 2c 20 64 6f 6e 27 74 20 73 6c 65   \ 1s, don't sle
0560: 65 70 20 74 6f 6f 20 6c 6f 6e 67 0a 70 6f 6c 6c  ep too long.poll
0570: 2d 74 69 6d 65 6f 75 74 23 20 30 20 70 74 69 6d  -timeout# 0 ptim
0580: 65 6f 75 74 20 32 21 0a 0a 55 73 65 72 20 73 6f  eout 2!..User so
0590: 63 6b 74 69 6d 65 6f 75 74 20 63 65 6c 6c 20 75  cktimeout cell u
05a0: 61 6c 6c 6f 74 20 64 72 6f 70 0a 0a 3a 20 73 6f  allot drop..: so
05b0: 63 6b 2d 74 69 6d 65 6f 75 74 21 20 28 20 73 6f  ck-timeout! ( so
05c0: 63 6b 65 74 20 2d 2d 20 29 20 20 66 69 6c 65 6e  cket -- )  filen
05d0: 6f 0a 20 20 20 20 73 6f 63 6b 74 69 6d 65 6f 75  o.    socktimeou
05e0: 74 20 32 40 0a 20 20 20 20 70 74 69 6d 65 6f 75  t 2@.    ptimeou
05f0: 74 20 32 40 20 3e 72 20 23 31 30 30 30 20 2f 20  t 2@ >r #1000 / 
0600: 72 3e 20 32 64 75 70 20 73 6f 63 6b 74 69 6d 65  r> 2dup socktime
0610: 6f 75 74 20 32 21 20 64 3c 3e 20 49 46 0a 09 53  out 2! d<> IF..S
0620: 4f 4c 5f 53 4f 43 4b 45 54 20 53 4f 5f 52 43 56  OL_SOCKET SO_RCV
0630: 54 49 4d 45 4f 20 73 6f 63 6b 74 69 6d 65 6f 75  TIMEO socktimeou
0640: 74 20 32 20 63 65 6c 6c 73 20 73 65 74 73 6f 63  t 2 cells setsoc
0650: 6b 6f 70 74 20 54 48 45 4e 0a 20 20 20 20 64 72  kopt THEN.    dr
0660: 6f 70 20 3b 0a 0a 30 20 20 20 20 20 20 20 20 20  op ;..0         
0670: 20 20 20 20 43 6f 6e 73 74 61 6e 74 20 64 6f 2d      Constant do-
0680: 62 6c 6f 63 6b 0a 4d 53 47 5f 44 4f 4e 54 57 41  block.MSG_DONTWA
0690: 49 54 20 20 43 6f 6e 73 74 61 6e 74 20 64 6f 6e  IT  Constant don
06a0: 27 74 2d 62 6c 6f 63 6b 0a 0a 24 30 30 30 30 30  't-block..$00000
06b0: 30 30 30 20 56 61 6c 75 65 20 72 65 63 2d 64 72  000 Value rec-dr
06c0: 6f 70 72 61 74 65 23 0a 0a 3a 20 3f 64 72 6f 70  oprate#..: ?drop
06d0: 2d 69 6e 63 20 28 20 61 64 64 72 20 75 20 2d 2d  -inc ( addr u --
06e0: 20 61 64 64 72 20 75 20 2f 20 30 20 30 20 29 0a   addr u / 0 0 ).
06f0: 20 20 20 20 72 65 63 2d 64 72 6f 70 72 61 74 65      rec-droprate
0700: 23 20 49 46 20 20 72 6e 67 33 32 20 72 65 63 2d  # IF  rng32 rec-
0710: 64 72 6f 70 72 61 74 65 23 20 75 3c 20 49 46 0a  droprate# u< IF.
0720: 09 20 20 20 20 72 65 73 65 6e 64 28 20 2e 22 20  .    resend( ." 
0730: 64 72 6f 70 70 69 6e 67 20 69 6e 63 6f 6d 69 6e  dropping incomin
0740: 67 20 70 61 63 6b 65 74 22 20 63 72 20 29 0a 09  g packet" cr )..
0750: 20 20 20 20 32 64 72 6f 70 20 23 30 2e 20 20 54      2drop #0.  T
0760: 48 45 4e 20 20 54 48 45 4e 20 3b 0a 0a 3a 20 72  HEN  THEN ;..: r
0770: 65 61 64 2d 61 2d 70 61 63 6b 65 74 20 28 20 62  ead-a-packet ( b
0780: 6c 6f 63 6b 61 67 65 20 2d 2d 20 61 64 64 72 20  lockage -- addr 
0790: 75 20 2f 20 30 20 30 20 29 0a 20 20 20 20 3e 72  u / 0 0 ).    >r
07a0: 20 73 6f 63 6b 61 64 64 72 5f 69 6e 20 61 6c 65   sockaddr_in ale
07b0: 6e 20 21 0a 20 20 20 20 6e 65 74 32 6f 2d 73 6f  n !.    net2o-so
07c0: 63 6b 20 5b 49 46 44 45 46 5d 20 6e 6f 2d 68 79  ck [IFDEF] no-hy
07d0: 62 72 69 64 20 64 72 6f 70 20 5b 54 48 45 4e 5d  brid drop [THEN]
07e0: 0a 20 20 20 20 69 6e 62 75 66 20 6d 61 78 70 61  .    inbuf maxpa
07f0: 63 6b 65 74 20 72 3e 20 73 6f 63 6b 61 64 64 72  cket r> sockaddr
0800: 3c 20 61 6c 65 6e 20 72 65 63 76 66 72 6f 6d 0a  < alen recvfrom.
0810: 20 20 20 20 64 75 70 20 30 3c 20 49 46 0a 09 65      dup 0< IF..e
0820: 72 72 6e 6f 20 64 75 70 20 45 41 47 41 49 4e 20  rrno dup EAGAIN 
0830: 3d 20 20 49 46 20 20 32 64 72 6f 70 20 23 30 2e  =  IF  2drop #0.
0840: 20 45 58 49 54 20 20 54 48 45 4e 0a 09 23 35 31   EXIT  THEN..#51
0850: 32 20 2b 20 6e 65 67 61 74 65 20 74 68 72 6f 77  2 + negate throw
0860: 20 20 54 48 45 4e 0a 20 20 20 20 69 6e 62 75 66    THEN.    inbuf
0870: 20 73 77 61 70 20 20 31 20 70 61 63 6b 65 74 72   swap  1 packetr
0880: 20 2b 21 20 20 3f 64 72 6f 70 2d 69 6e 63 0a 20   +!  ?drop-inc. 
0890: 20 20 20 72 65 63 76 66 72 6f 6d 28 20 2e 22 20     recvfrom( ." 
08a0: 72 65 63 65 69 76 65 64 20 66 72 6f 6d 3a 20 22  received from: "
08b0: 20 73 6f 63 6b 61 64 64 72 3c 20 61 6c 65 6e 20   sockaddr< alen 
08c0: 40 20 2e 61 64 64 72 65 73 73 20 73 70 61 63 65  @ .address space
08d0: 20 64 75 70 20 2e 20 63 72 20 29 0a 3b 0a 0a 5b   dup . cr ).;..[
08e0: 49 46 44 45 46 5d 20 6e 6f 2d 68 79 62 72 69 64  IFDEF] no-hybrid
08f0: 0a 20 20 20 20 3a 20 72 65 61 64 2d 61 2d 70 61  .    : read-a-pa
0900: 63 6b 65 74 34 20 28 20 62 6c 6f 63 6b 61 67 65  cket4 ( blockage
0910: 20 2d 2d 20 61 64 64 72 20 75 20 2f 20 30 20 30   -- addr u / 0 0
0920: 20 29 0a 09 3e 72 20 73 6f 63 6b 61 64 64 72 5f   )..>r sockaddr_
0930: 69 6e 20 61 6c 65 6e 20 21 0a 09 6e 65 74 32 6f  in alen !..net2o
0940: 2d 73 6f 63 6b 20 6e 69 70 0a 09 69 6e 62 75 66  -sock nip..inbuf
0950: 20 6d 61 78 70 61 63 6b 65 74 20 72 3e 20 73 6f   maxpacket r> so
0960: 63 6b 61 64 64 72 3c 20 61 6c 65 6e 20 72 65 63  ckaddr< alen rec
0970: 76 66 72 6f 6d 0a 09 64 75 70 20 30 3c 20 49 46  vfrom..dup 0< IF
0980: 0a 09 20 20 20 20 65 72 72 6e 6f 20 64 75 70 20  ..    errno dup 
0990: 45 41 47 41 49 4e 20 3d 20 20 49 46 20 20 32 64  EAGAIN =  IF  2d
09a0: 72 6f 70 20 23 30 2e 20 45 58 49 54 20 20 54 48  rop #0. EXIT  TH
09b0: 45 4e 0a 09 54 48 45 4e 0a 09 69 6e 62 75 66 20  EN..THEN..inbuf 
09c0: 73 77 61 70 20 20 31 20 70 61 63 6b 65 74 72 20  swap  1 packetr 
09d0: 2b 21 20 20 3f 64 72 6f 70 2d 69 6e 63 0a 09 72  +!  ?drop-inc..r
09e0: 65 63 76 66 72 6f 6d 28 20 2e 22 20 72 65 63 65  ecvfrom( ." rece
09f0: 69 76 65 64 20 66 72 6f 6d 3a 20 22 20 73 6f 63  ived from: " soc
0a00: 6b 61 64 64 72 3c 20 61 6c 65 6e 20 40 20 2e 61  kaddr< alen @ .a
0a10: 64 64 72 65 73 73 20 73 70 61 63 65 20 64 75 70  ddress space dup
0a20: 20 2e 20 63 72 20 29 0a 20 20 20 20 3b 0a 5b 54   . cr ).    ;.[T
0a30: 48 45 4e 5d 0a 0a 24 30 30 30 30 30 30 30 30 20  HEN]..$00000000 
0a40: 56 61 6c 75 65 20 64 72 6f 70 72 61 74 65 23 0a  Value droprate#.
0a50: 0a 3a 20 25 64 72 6f 70 72 61 74 65 20 28 20 2d  .: %droprate ( -
0a60: 2d 20 29 0a 20 20 20 20 3f 70 65 65 6b 61 72 67  - ).    ?peekarg
0a70: 20 30 3d 20 49 46 20 20 45 58 49 54 20 20 54 48   0= IF  EXIT  TH
0a80: 45 4e 0a 20 20 20 20 2b 20 31 2d 20 63 40 20 27  EN.    + 1- c@ '
0a90: 25 27 20 3c 3e 20 3f 45 58 49 54 0a 20 20 20 20  %' <> ?EXIT.    
0aa0: 3f 6e 65 78 74 61 72 67 20 64 72 6f 70 20 70 72  ?nextarg drop pr
0ab0: 65 66 69 78 2d 6e 75 6d 62 65 72 20 49 46 0a 09  efix-number IF..
0ac0: 34 20 73 65 74 2d 70 72 65 63 69 73 69 6f 6e 0a  4 set-precision.
0ad0: 09 31 65 20 66 6d 69 6e 20 2d 31 65 20 66 6d 61  .1e fmin -1e fma
0ae0: 78 20 24 46 46 46 46 46 46 46 46 20 66 6d 2a 20  x $FFFFFFFF fm* 
0af0: 66 3e 64 0a 09 30 3c 20 49 46 20 20 6e 65 67 61  f>d..0< IF  nega
0b00: 74 65 20 74 6f 20 72 65 63 2d 64 72 6f 70 72 61  te to rec-dropra
0b10: 74 65 23 0a 09 20 20 20 20 5b 3a 20 2e 22 20 53  te#..    [: ." S
0b20: 65 74 20 72 65 63 20 64 72 6f 70 20 72 61 74 65  et rec drop rate
0b30: 20 74 6f 20 22 0a 09 20 20 20 20 20 20 72 65 63   to "..      rec
0b40: 2d 64 72 6f 70 72 61 74 65 23 20 73 3e 66 20 34  -droprate# s>f 4
0b50: 32 39 34 39 36 37 32 2e 39 36 65 20 66 2f 20 66  2949672.96e f/ f
0b60: 2e 20 2e 22 20 25 22 20 63 72 20 3b 5d 20 64 6f  . ." %" cr ;] do
0b70: 2d 64 65 62 75 67 0a 09 45 4c 53 45 0a 09 20 20  -debug..ELSE..  
0b80: 20 20 74 6f 20 64 72 6f 70 72 61 74 65 23 0a 09    to droprate#..
0b90: 20 20 20 20 5b 3a 20 2e 22 20 53 65 74 20 64 72      [: ." Set dr
0ba0: 6f 70 20 72 61 74 65 20 74 6f 20 22 0a 09 20 20  op rate to "..  
0bb0: 20 20 20 20 64 72 6f 70 72 61 74 65 23 20 73 3e      droprate# s>
0bc0: 66 20 34 32 39 34 39 36 37 32 2e 39 36 65 20 66  f 42949672.96e f
0bd0: 2f 20 66 2e 20 2e 22 20 25 22 20 63 72 20 3b 5d  / f. ." %" cr ;]
0be0: 20 64 6f 2d 64 65 62 75 67 0a 09 54 48 45 4e 0a   do-debug..THEN.
0bf0: 20 20 20 20 54 48 45 4e 20 3b 0a 0a 3a 20 73 65      THEN ;..: se
0c00: 6e 64 2d 61 2d 70 61 63 6b 65 74 20 28 20 61 64  nd-a-packet ( ad
0c10: 64 72 20 75 20 2d 2d 20 6e 20 29 20 2b 63 61 6c  dr u -- n ) +cal
0c20: 63 0a 20 20 20 20 64 72 6f 70 72 61 74 65 23 20  c.    droprate# 
0c30: 49 46 20 20 72 6e 67 33 32 20 64 72 6f 70 72 61  IF  rng32 dropra
0c40: 74 65 23 20 75 3c 20 49 46 0a 09 20 20 20 20 72  te# u< IF..    r
0c50: 65 73 65 6e 64 28 20 2e 22 20 64 72 6f 70 70 69  esend( ." droppi
0c60: 6e 67 20 70 61 63 6b 65 74 22 20 63 72 20 29 0a  ng packet" cr ).
0c70: 09 20 20 20 20 31 20 70 61 63 6b 65 74 73 20 2b  .    1 packets +
0c80: 21 20 32 64 72 6f 70 20 30 20 20 45 58 49 54 20  ! 2drop 0  EXIT 
0c90: 20 54 48 45 4e 20 20 54 48 45 4e 0a 20 20 20 20   THEN  THEN.    
0ca0: 32 3e 72 20 6e 65 74 32 6f 2d 73 6f 63 6b 20 32  2>r net2o-sock 2
0cb0: 72 3e 20 30 20 73 6f 63 6b 61 64 64 72 3e 20 61  r> 0 sockaddr> a
0cc0: 6c 65 6e 20 40 20 73 65 6e 64 74 6f 20 2b 73 65  len @ sendto +se
0cd0: 6e 64 20 31 20 70 61 63 6b 65 74 73 20 2b 21 0a  nd 1 packets +!.
0ce0: 20 20 20 20 73 65 6e 64 74 6f 28 20 2e 22 20 73      sendto( ." s
0cf0: 65 6e 64 20 74 6f 3a 20 22 20 73 6f 63 6b 61 64  end to: " sockad
0d00: 64 72 3e 20 61 6c 65 6e 20 40 20 2e 61 64 64 72  dr> alen @ .addr
0d10: 65 73 73 20 73 70 61 63 65 20 64 75 70 20 2e 20  ess space dup . 
0d20: 63 72 20 29 20 3b 0a 0a 5c 20 63 6c 69 65 6e 74  cr ) ;..\ client
0d30: 73 20 72 6f 75 74 69 6e 67 20 74 61 62 6c 65 0a  s routing table.
0d40: 0a 3a 20 69 6e 69 74 2d 72 6f 75 74 65 20 28 20  .: init-route ( 
0d50: 2d 2d 20 29 20 20 73 22 20 22 20 72 6f 75 74 65  -- )  s" " route
0d60: 73 23 20 68 61 73 68 40 20 24 21 20 3b 20 5c 20  s# hash@ $! ; \ 
0d70: 66 69 65 6c 64 20 30 20 69 73 20 6d 65 2c 20 6d  field 0 is me, m
0d80: 79 73 65 6c 66 0a 0a 3a 20 69 70 76 34 3e 69 70  yself..: ipv4>ip
0d90: 76 36 20 28 20 61 64 64 72 20 75 20 64 65 73 74  v6 ( addr u dest
0da0: 20 2d 2d 20 61 64 64 72 27 20 75 27 20 29 0a 20   -- addr' u' ). 
0db0: 20 20 20 3e 72 20 64 72 6f 70 0a 20 20 20 20 64     >r drop.    d
0dc0: 75 70 20 70 6f 72 74 20 62 65 2d 75 77 40 20 73  up port be-uw@ s
0dd0: 77 61 70 20 73 69 6e 5f 61 64 64 72 20 62 65 2d  wap sin_addr be-
0de0: 75 6c 40 0a 20 20 20 20 72 40 20 69 70 76 34 21  ul@.    r@ ipv4!
0df0: 20 72 40 20 70 6f 72 74 20 62 65 2d 77 21 20 72   r@ port be-w! r
0e00: 3e 20 73 6f 63 6b 2d 72 65 73 74 20 3b 0a 3a 20  > sock-rest ;.: 
0e10: 3f 3e 69 70 76 36 20 28 20 61 64 64 72 20 75 20  ?>ipv6 ( addr u 
0e20: 2d 2d 20 61 64 64 72 27 20 75 27 20 29 0a 20 20  -- addr' u' ).  
0e30: 20 20 6f 76 65 72 20 66 61 6d 69 6c 79 20 77 40    over family w@
0e40: 20 41 46 5f 49 4e 45 54 20 3d 20 49 46 20 20 73   AF_INET = IF  s
0e50: 6f 63 6b 61 64 64 72 3e 20 69 70 76 34 3e 69 70  ockaddr> ipv4>ip
0e60: 76 36 20 20 54 48 45 4e 20 3b 0a 3a 20 3f 3c 69  v6  THEN ;.: ?<i
0e70: 70 76 36 20 28 20 61 64 64 72 20 75 20 2d 2d 20  pv6 ( addr u -- 
0e80: 61 64 64 72 27 20 75 27 20 29 0a 20 20 20 20 6f  addr' u' ).    o
0e90: 76 65 72 20 66 61 6d 69 6c 79 20 77 40 20 41 46  ver family w@ AF
0ea0: 5f 49 4e 45 54 20 3d 20 49 46 20 20 73 6f 63 6b  _INET = IF  sock
0eb0: 61 64 64 72 3c 20 69 70 76 34 3e 69 70 76 36 20  addr< ipv4>ipv6 
0ec0: 20 54 48 45 4e 20 3b 0a 3a 20 69 6e 66 6f 40 20   THEN ;.: info@ 
0ed0: 28 20 69 6e 66 6f 20 2d 2d 20 61 64 64 72 20 75  ( info -- addr u
0ee0: 20 29 0a 20 20 20 20 64 75 70 20 61 69 5f 61 64   ).    dup ai_ad
0ef0: 64 72 20 40 20 73 77 61 70 20 61 69 5f 61 64 64  dr @ swap ai_add
0f00: 72 6c 65 6e 20 6c 40 20 3b 0a 3a 20 69 6e 66 6f  rlen l@ ;.: info
0f10: 3e 73 74 72 69 6e 67 20 28 20 69 6e 66 6f 20 2d  >string ( info -
0f20: 2d 20 61 64 64 72 20 75 20 29 0a 20 20 20 20 69  - addr u ).    i
0f30: 6e 66 6f 40 20 3f 3e 69 70 76 36 20 3b 0a 0a 3a  nfo@ ?>ipv6 ;..:
0f40: 20 2d 24 73 70 6c 69 74 20 28 20 61 64 64 72 20   -$split ( addr 
0f50: 75 20 63 68 61 72 20 2d 2d 20 61 64 64 72 31 20  u char -- addr1 
0f60: 75 31 20 61 64 64 72 32 20 75 32 20 29 20 5c 20  u1 addr2 u2 ) \ 
0f70: 67 66 6f 72 74 68 2d 73 74 72 69 6e 67 20 73 74  gforth-string st
0f80: 72 69 6e 67 2d 73 70 6c 69 74 0a 20 20 20 20 5c  ring-split.    \
0f90: 47 20 64 69 76 69 64 65 73 20 61 20 73 74 72 69  G divides a stri
0fa0: 6e 67 20 69 6e 74 6f 20 74 77 6f 2c 20 77 69 74  ng into two, wit
0fb0: 68 20 6f 6e 65 20 63 68 61 72 20 61 73 20 73 65  h one char as se
0fc0: 70 61 72 61 74 6f 72 20 28 65 2e 67 2e 20 27 3f  parator (e.g. '?
0fd0: 27 0a 20 20 20 20 5c 47 20 66 6f 72 20 61 72 67  '.    \G for arg
0fe0: 75 6d 65 6e 74 73 20 69 6e 20 61 6e 20 48 54 4d  uments in an HTM
0ff0: 4c 20 71 75 65 72 79 29 0a 20 20 20 20 3e 72 20  L query).    >r 
1000: 32 64 75 70 20 72 3e 20 2d 73 63 61 6e 20 64 75  2dup r> -scan du
1010: 70 20 3e 72 20 64 75 70 20 49 46 20 20 31 2d 20  p >r dup IF  1- 
1020: 20 54 48 45 4e 0a 20 20 20 20 32 73 77 61 70 20   THEN.    2swap 
1030: 72 3e 20 2f 73 74 72 69 6e 67 20 3b 0a 3a 20 70  r> /string ;.: p
1040: 69 6e 67 20 28 20 22 61 64 64 72 3a 70 6f 72 74  ing ( "addr:port
1050: 22 20 2d 2d 20 29 0a 20 20 20 20 6e 65 74 32 6f  " -- ).    net2o
1060: 2d 73 6f 63 6b 20 22 3e 22 20 30 0a 20 20 20 20  -sock ">" 0.    
1070: 70 61 72 73 65 2d 6e 61 6d 65 20 27 3a 27 20 2d  parse-name ':' -
1080: 24 73 70 6c 69 74 20 73 3e 75 6e 75 6d 62 65 72  $split s>unumber
1090: 3f 20 32 64 72 6f 70 20 3e 72 0a 20 20 20 20 6f  ? 2drop >r.    o
10a0: 76 65 72 20 63 40 20 27 5b 27 20 3d 20 6e 65 67  ver c@ '[' = neg
10b0: 61 74 65 20 2f 73 74 72 69 6e 67 20 32 64 75 70  ate /string 2dup
10c0: 20 2b 20 31 2d 20 63 40 20 27 5d 27 20 3d 20 2b   + 1- c@ ']' = +
10d0: 0a 20 20 20 20 72 3e 20 53 4f 43 4b 5f 44 47 52  .    r> SOCK_DGR
10e0: 41 4d 20 3e 68 69 6e 74 73 20 30 20 68 69 6e 74  AM >hints 0 hint
10f0: 73 20 61 69 5f 66 61 6d 69 6c 79 20 6c 21 0a 20  s ai_family l!. 
1100: 20 20 20 67 65 74 2d 69 6e 66 6f 20 64 75 70 20     get-info dup 
1110: 3e 72 20 69 6e 66 6f 40 20 73 65 6e 64 74 6f 0a  >r info@ sendto.
1120: 20 20 20 20 72 3e 20 66 72 65 65 61 64 64 72 69      r> freeaddri
1130: 6e 66 6f 20 3f 69 6f 72 20 3b 0a 0a 55 56 61 6c  nfo ?ior ;..UVal
1140: 75 65 20 6c 61 73 74 61 64 64 72 23 0a 55 73 65  ue lastaddr#.Use
1150: 72 20 6c 61 73 74 6e 32 6f 61 64 64 72 0a 0a 3a  r lastn2oaddr..:
1160: 20 69 6e 73 65 72 74 2d 61 64 64 72 65 73 73 20   insert-address 
1170: 28 20 61 64 64 72 20 75 20 2d 2d 20 6e 65 74 32  ( addr u -- net2
1180: 6f 2d 61 64 64 72 20 29 20 3f 3c 69 70 76 36 0a  o-addr ) ?<ipv6.
1190: 20 20 20 20 61 64 64 72 65 73 73 28 20 2e 22 20      address( ." 
11a0: 49 6e 73 65 72 74 20 61 64 64 72 65 73 73 20 22  Insert address "
11b0: 20 32 64 75 70 20 2e 61 64 64 72 65 73 73 20 63   2dup .address c
11c0: 72 20 29 0a 20 20 20 20 6c 61 73 74 61 64 64 72  r ).    lastaddr
11d0: 23 20 49 46 20 20 32 64 75 70 20 6c 61 73 74 61  # IF  2dup lasta
11e0: 64 64 72 23 20 24 40 20 73 74 72 3d 0a 09 49 46  ddr# $@ str=..IF
11f0: 20 20 32 64 72 6f 70 20 6c 61 73 74 6e 32 6f 61    2drop lastn2oa
1200: 64 64 72 20 40 20 45 58 49 54 20 20 54 48 45 4e  ddr @ EXIT  THEN
1210: 0a 20 20 20 20 54 48 45 4e 0a 20 20 20 20 32 64  .    THEN.    2d
1220: 75 70 20 72 6f 75 74 65 73 23 20 23 6b 65 79 20  up routes# #key 
1230: 64 75 70 20 2d 31 20 3d 20 49 46 0a 09 64 72 6f  dup -1 = IF..dro
1240: 70 20 73 22 20 22 20 32 6f 76 65 72 20 72 6f 75  p s" " 2over rou
1250: 74 65 73 23 20 23 21 0a 09 72 6f 75 74 65 73 23  tes# #!..routes#
1260: 20 23 6b 65 79 0a 20 20 20 20 45 4c 53 45 0a 09   #key.    ELSE..
1270: 6e 69 70 20 6e 69 70 0a 20 20 20 20 54 48 45 4e  nip nip.    THEN
1280: 0a 20 20 20 20 64 75 70 20 6c 61 73 74 6e 32 6f  .    dup lastn2o
1290: 61 64 64 72 20 21 0a 20 20 20 20 6c 61 73 74 23  addr !.    last#
12a0: 20 74 6f 20 6c 61 73 74 61 64 64 72 23 20 3b 0a   to lastaddr# ;.
12b0: 0a 3a 20 64 6e 73 3e 73 74 72 69 6e 67 20 28 20  .: dns>string ( 
12c0: 61 64 64 72 20 75 20 70 6f 72 74 20 68 69 6e 74  addr u port hint
12d0: 20 2d 2d 20 69 6e 66 6f 20 6e 65 74 32 6f 2d 61   -- info net2o-a
12e0: 64 64 72 20 75 20 29 0a 20 20 20 20 3e 72 20 53  ddr u ).    >r S
12f0: 4f 43 4b 5f 44 47 52 41 4d 20 3e 68 69 6e 74 73  OCK_DGRAM >hints
1300: 20 72 3e 20 68 69 6e 74 73 20 61 69 5f 66 61 6d   r> hints ai_fam
1310: 69 6c 79 20 6c 21 0a 20 20 20 20 67 65 74 2d 69  ily l!.    get-i
1320: 6e 66 6f 20 64 75 70 20 69 6e 66 6f 3e 73 74 72  nfo dup info>str
1330: 69 6e 67 20 3b 0a 0a 3a 20 69 6e 73 65 72 74 2d  ing ;..: insert-
1340: 69 70 2a 20 28 20 61 64 64 72 20 75 20 70 6f 72  ip* ( addr u por
1350: 74 20 68 69 6e 74 20 2d 2d 20 6e 65 74 32 6f 2d  t hint -- net2o-
1360: 61 64 64 72 20 29 0a 20 20 20 20 64 6e 73 3e 73  addr ).    dns>s
1370: 74 72 69 6e 67 20 72 6f 74 20 3e 72 20 69 6e 73  tring rot >r ins
1380: 65 72 74 2d 61 64 64 72 65 73 73 20 72 3e 20 66  ert-address r> f
1390: 72 65 65 61 64 64 72 69 6e 66 6f 20 3b 0a 0a 3a  reeaddrinfo ;..:
13a0: 20 69 6e 73 65 72 74 2d 69 70 20 28 20 61 64 64   insert-ip ( add
13b0: 72 20 75 20 70 6f 72 74 20 2d 2d 20 6e 65 74 32  r u port -- net2
13c0: 6f 2d 61 64 64 72 20 29 20 20 30 20 20 20 20 20  o-addr )  0     
13d0: 20 20 20 20 69 6e 73 65 72 74 2d 69 70 2a 20 3b      insert-ip* ;
13e0: 0a 3a 20 69 6e 73 65 72 74 2d 69 70 34 20 28 20  .: insert-ip4 ( 
13f0: 61 64 64 72 20 75 20 70 6f 72 74 20 2d 2d 20 6e  addr u port -- n
1400: 65 74 32 6f 2d 61 64 64 72 20 29 20 50 46 5f 49  et2o-addr ) PF_I
1410: 4e 45 54 20 20 20 69 6e 73 65 72 74 2d 69 70 2a  NET   insert-ip*
1420: 20 3b 0a 3a 20 69 6e 73 65 72 74 2d 69 70 36 20   ;.: insert-ip6 
1430: 28 20 61 64 64 72 20 75 20 70 6f 72 74 20 2d 2d  ( addr u port --
1440: 20 6e 65 74 32 6f 2d 61 64 64 72 20 29 20 50 46   net2o-addr ) PF
1450: 5f 49 4e 45 54 36 20 20 69 6e 73 65 72 74 2d 69  _INET6  insert-i
1460: 70 2a 20 3b 0a 0a 3a 20 72 6f 75 74 65 3e 61 64  p* ;..: route>ad
1470: 64 72 65 73 73 20 28 20 6e 20 2d 2d 20 66 6c 61  dress ( n -- fla
1480: 67 20 29 0a 20 20 20 20 72 6f 75 74 65 73 23 20  g ).    routes# 
1490: 23 2e 6b 65 79 20 64 75 70 20 30 3d 20 3f 45 58  #.key dup 0= ?EX
14a0: 49 54 0a 20 20 20 20 24 40 20 73 6f 63 6b 61 64  IT.    $@ sockad
14b0: 64 72 3e 20 6f 76 65 72 20 61 6c 65 6e 20 21 20  dr> over alen ! 
14c0: 73 6f 63 6b 61 64 64 72 5f 69 6e 20 73 6d 6f 76  sockaddr_in smov
14d0: 65 20 74 72 75 65 20 3b 0a 0a 5c 20 71 75 65 72  e true ;..\ quer
14e0: 79 20 69 66 20 77 65 20 68 61 76 65 20 61 20 44  y if we have a D
14f0: 4e 53 36 34 20 65 6e 76 69 72 6f 6e 6d 65 6e 74  NS64 environment
1500: 0a 0a 56 61 72 69 61 62 6c 65 20 6e 65 74 32 6f  ..Variable net2o
1510: 2d 69 70 76 34 20 22 69 70 76 34 2e 6e 65 74 32  -ipv4 "ipv4.net2
1520: 6f 2e 64 65 22 20 6e 65 74 32 6f 2d 69 70 76 34  o.de" net2o-ipv4
1530: 20 24 21 0a 0a 3a 20 64 6e 73 36 34 3f 20 28 20   $!..: dns64? ( 
1540: 2d 2d 20 66 6c 61 67 20 29 0a 20 20 20 20 6e 65  -- flag ).    ne
1550: 74 32 6f 2d 69 70 76 34 20 24 40 20 6e 65 74 32  t2o-ipv4 $@ net2
1560: 6f 2d 70 6f 72 74 20 67 65 74 2d 69 6e 66 6f 20  o-port get-info 
1570: 69 6e 66 6f 40 0a 20 20 20 20 73 6f 63 6b 61 64  info@.    sockad
1580: 64 72 5f 69 6e 36 20 3d 20 6f 76 65 72 20 66 61  dr_in6 = over fa
1590: 6d 69 6c 79 20 77 40 20 41 46 5f 49 4e 45 54 36  mily w@ AF_INET6
15a0: 20 3d 20 49 46 0a 09 73 69 6e 36 5f 61 64 64 72   = IF..sin6_addr
15b0: 20 24 43 20 6e 61 74 36 34 2d 69 70 34 20 6f 76   $C nat64-ip4 ov
15c0: 65 72 20 73 74 72 3d 0a 20 20 20 20 45 4c 53 45  er str=.    ELSE
15d0: 20 20 64 72 6f 70 20 66 61 6c 73 65 20 20 54 48    drop false  TH
15e0: 45 4e 20 3b 0a 0a 5c 20 72 6f 75 74 65 20 61 6e  EN ;..\ route an
15f0: 20 69 6e 63 6f 6d 69 6e 67 20 70 61 63 6b 65 74   incoming packet
1600: 0a 0a 3a 20 3e 72 70 61 74 68 2d 6c 65 6e 20 28  ..: >rpath-len (
1610: 20 72 70 61 74 68 20 2d 2d 20 72 70 61 74 68 20   rpath -- rpath 
1620: 6c 65 6e 20 29 0a 20 20 20 20 64 75 70 20 30 3d  len ).    dup 0=
1630: 20 49 46 20 20 30 20 20 45 58 49 54 20 20 54 48   IF  0  EXIT  TH
1640: 45 4e 0a 20 20 20 20 5b 49 46 44 45 46 5d 20 36  EN.    [IFDEF] 6
1650: 34 62 69 74 0a 09 64 75 70 20 24 31 30 30 30 30  4bit..dup $10000
1660: 30 30 30 30 20 75 3c 20 49 46 0a 09 20 20 20 20  0000 u< IF..    
1670: 64 75 70 20 24 31 30 30 30 30 20 75 3c 20 49 46  dup $10000 u< IF
1680: 0a 09 09 64 75 70 20 24 31 30 30 20 75 3c 20 32  ...dup $100 u< 2
1690: 20 2b 20 20 45 58 49 54 0a 09 20 20 20 20 45 4c   +  EXIT..    EL
16a0: 53 45 0a 09 09 64 75 70 20 24 31 30 30 30 30 30  SE...dup $100000
16b0: 30 20 75 3c 20 34 20 2b 20 45 58 49 54 0a 09 20  0 u< 4 + EXIT.. 
16c0: 20 20 20 54 48 45 4e 0a 09 45 4c 53 45 0a 09 20     THEN..ELSE.. 
16d0: 20 20 20 64 75 70 20 24 31 30 30 30 30 30 30 30     dup $10000000
16e0: 30 30 30 30 30 20 75 3c 20 49 46 0a 09 09 64 75  00000 u< IF...du
16f0: 70 20 24 31 30 30 30 30 30 30 30 30 30 30 20 75  p $10000000000 u
1700: 3c 20 36 20 2b 20 20 45 58 49 54 0a 09 20 20 20  < 6 +  EXIT..   
1710: 20 45 4c 53 45 0a 09 09 64 75 70 20 24 31 30 30   ELSE...dup $100
1720: 30 30 30 30 30 30 30 30 30 30 30 30 20 75 3c 20  000000000000 u< 
1730: 38 20 2b 20 20 45 58 49 54 0a 09 20 20 20 20 54  8 +  EXIT..    T
1740: 48 45 4e 0a 09 54 48 45 4e 0a 20 20 20 20 5b 45  HEN..THEN.    [E
1750: 4c 53 45 5d 0a 09 64 75 70 20 24 31 30 30 30 30  LSE]..dup $10000
1760: 20 75 3c 20 49 46 0a 09 20 20 20 20 64 75 70 20   u< IF..    dup 
1770: 24 31 30 30 20 75 3c 20 32 20 2b 20 20 45 58 49  $100 u< 2 +  EXI
1780: 54 0a 09 45 4c 53 45 0a 09 20 20 20 20 64 75 70  T..ELSE..    dup
1790: 20 24 31 30 30 30 30 30 30 20 75 3c 20 34 20 2b   $1000000 u< 4 +
17a0: 20 45 58 49 54 0a 09 54 48 45 4e 0a 20 20 20 20   EXIT..THEN.    
17b0: 5b 54 48 45 4e 5d 20 3b 0a 3a 20 3e 70 61 74 68  [THEN] ;.: >path
17c0: 2d 6c 65 6e 20 28 20 70 61 74 68 20 2d 2d 20 70  -len ( path -- p
17d0: 61 74 68 20 6c 65 6e 20 29 0a 20 20 20 20 64 75  ath len ).    du
17e0: 70 20 30 3d 20 49 46 20 20 30 20 20 45 58 49 54  p 0= IF  0  EXIT
17f0: 20 20 54 48 45 4e 0a 20 20 20 20 5b 49 46 44 45    THEN.    [IFDE
1800: 46 5d 20 36 34 62 69 74 0a 09 64 75 70 20 20 20  F] 64bit..dup   
1810: 20 20 24 30 30 30 30 30 30 30 30 46 46 46 46 46    $00000000FFFFF
1820: 46 46 46 20 61 6e 64 20 49 46 0a 09 20 20 20 20  FFF and IF..    
1830: 64 75 70 20 24 30 30 30 30 30 30 30 30 30 30 30  dup $00000000000
1840: 30 46 46 46 46 20 61 6e 64 20 49 46 0a 09 09 64  0FFFF and IF...d
1850: 75 70 20 24 30 30 30 30 30 30 30 30 30 30 30 30  up $000000000000
1860: 30 30 46 46 20 61 6e 64 20 30 3d 20 38 20 2b 20  00FF and 0= 8 + 
1870: 20 45 58 49 54 0a 09 20 20 20 20 45 4c 53 45 0a   EXIT..    ELSE.
1880: 09 09 64 75 70 20 24 30 30 30 30 30 30 30 30 30  ..dup $000000000
1890: 30 46 46 46 46 46 46 20 61 6e 64 20 30 3d 20 36  0FFFFFF and 0= 6
18a0: 20 2b 20 20 45 58 49 54 0a 09 20 20 20 20 54 48   +  EXIT..    TH
18b0: 45 4e 0a 09 45 4c 53 45 0a 09 20 20 20 20 64 75  EN..ELSE..    du
18c0: 70 20 24 30 30 30 30 46 46 46 46 46 46 46 46 46  p $0000FFFFFFFFF
18d0: 46 46 46 20 61 6e 64 20 49 46 0a 09 09 64 75 70  FFF and IF...dup
18e0: 20 24 30 30 30 30 30 30 46 46 46 46 46 46 46 46   $000000FFFFFFFF
18f0: 46 46 20 61 6e 64 20 30 3d 20 34 20 2b 20 20 45  FF and 0= 4 +  E
1900: 58 49 54 0a 09 20 20 20 20 45 4c 53 45 0a 09 09  XIT..    ELSE...
1910: 64 75 70 20 24 30 30 46 46 46 46 46 46 46 46 46  dup $00FFFFFFFFF
1920: 46 46 46 46 46 20 61 6e 64 20 30 3d 20 32 20 2b  FFFFF and 0= 2 +
1930: 20 20 45 58 49 54 0a 09 20 20 20 20 54 48 45 4e    EXIT..    THEN
1940: 0a 09 54 48 45 4e 0a 20 20 20 20 5b 45 4c 53 45  ..THEN.    [ELSE
1950: 5d 0a 09 64 75 70 20 20 20 20 20 24 30 30 30 30  ]..dup     $0000
1960: 46 46 46 46 20 61 6e 64 20 49 46 0a 09 20 20 20  FFFF and IF..   
1970: 20 64 75 70 20 24 30 30 30 30 30 30 46 46 20 61   dup $000000FF a
1980: 6e 64 20 30 3d 20 34 20 2b 20 20 45 58 49 54 0a  nd 0= 4 +  EXIT.
1990: 09 45 4c 53 45 0a 09 20 20 20 20 64 75 70 20 24  .ELSE..    dup $
19a0: 30 30 46 46 46 46 46 46 20 61 6e 64 20 30 3d 20  00FFFFFF and 0= 
19b0: 32 20 2b 20 20 45 58 49 54 0a 09 54 48 45 4e 0a  2 +  EXIT..THEN.
19c0: 20 20 20 20 5b 54 48 45 4e 5d 20 3b 0a 0a 3a 20      [THEN] ;..: 
19d0: 3c 30 73 74 72 69 6e 67 20 28 20 65 6e 64 61 64  <0string ( endad
19e0: 64 72 20 2d 2d 20 61 64 64 72 20 75 20 29 0a 20  dr -- addr u ). 
19f0: 20 20 20 24 31 31 20 31 20 44 4f 20 20 31 2d 20     $11 1 DO  1- 
1a00: 64 75 70 20 63 40 20 57 48 49 4c 45 20 20 4c 4f  dup c@ WHILE  LO
1a10: 4f 50 20 20 24 31 30 20 20 45 4c 53 45 20 20 49  OP  $10  ELSE  I
1a20: 20 20 55 4e 4c 4f 4f 50 20 20 54 48 45 4e 20 3b    UNLOOP  THEN ;
1a30: 0a 0a 3a 20 69 6e 73 2d 73 6f 75 72 63 65 20 28  ..: ins-source (
1a40: 20 61 64 64 72 20 70 61 63 6b 65 74 20 2d 2d 20   addr packet -- 
1a50: 29 0a 20 20 20 20 64 65 73 74 69 6e 61 74 69 6f  ).    destinatio
1a60: 6e 20 3e 72 20 72 65 76 65 72 73 65 0a 20 20 20  n >r reverse.   
1a70: 20 64 75 70 20 3e 72 70 61 74 68 2d 6c 65 6e 20   dup >rpath-len 
1a80: 7b 20 77 5e 20 72 70 61 74 68 20 72 70 6c 65 6e  { w^ rpath rplen
1a90: 20 7d 20 72 70 61 74 68 20 62 65 21 0a 20 20 20   } rpath be!.   
1aa0: 20 72 40 20 24 31 30 20 2b 20 3c 30 73 74 72 69   r@ $10 + <0stri
1ab0: 6e 67 0a 20 20 20 20 6f 76 65 72 20 72 70 6c 65  ng.    over rple
1ac0: 6e 20 2d 20 73 77 61 70 20 6d 6f 76 65 0a 20 20  n - swap move.  
1ad0: 20 20 72 70 61 74 68 20 63 65 6c 6c 2b 20 72 70    rpath cell+ rp
1ae0: 6c 65 6e 20 2d 20 72 3e 20 24 31 30 20 2b 20 72  len - r> $10 + r
1af0: 70 6c 65 6e 20 2d 20 72 70 6c 65 6e 20 6d 6f 76  plen - rplen mov
1b00: 65 20 3b 0a 3a 20 69 6e 73 2d 64 65 73 74 20 28  e ;.: ins-dest (
1b10: 20 6e 32 6f 61 64 64 72 20 64 65 73 74 61 64 64   n2oaddr destadd
1b20: 72 20 2d 2d 20 29 0a 20 20 20 20 3e 72 20 64 75  r -- ).    >r du
1b30: 70 20 3e 70 61 74 68 2d 6c 65 6e 20 7b 20 77 5e  p >path-len { w^
1b40: 20 70 61 74 68 20 70 6c 65 6e 20 7d 20 70 61 74   path plen } pat
1b50: 68 20 62 65 21 0a 20 20 20 20 72 40 20 63 73 74  h be!.    r@ cst
1b60: 72 69 6e 67 3e 73 73 74 72 69 6e 67 20 6f 76 65  ring>sstring ove
1b70: 72 20 70 6c 65 6e 20 2b 20 73 77 61 70 20 6d 6f  r plen + swap mo
1b80: 76 65 0a 20 20 20 20 70 61 74 68 20 72 3e 20 70  ve.    path r> p
1b90: 6c 65 6e 20 6d 6f 76 65 20 3b 0a 3a 20 73 6b 69  len move ;.: ski
1ba0: 70 2d 64 65 73 74 20 28 20 61 64 64 72 20 2d 2d  p-dest ( addr --
1bb0: 20 29 0a 20 20 20 20 24 31 30 20 32 64 75 70 20   ).    $10 2dup 
1bc0: 30 20 73 63 61 6e 20 6e 69 70 20 2d 0a 20 20 20  0 scan nip -.   
1bd0: 20 32 64 75 70 20 70 61 74 68 63 2b 20 7b 20 61   2dup pathc+ { a
1be0: 64 64 72 31 20 75 31 20 61 64 64 72 32 20 75 32  ddr1 u1 addr2 u2
1bf0: 20 7d 20 5c 20 62 65 74 74 65 72 20 75 73 65 20   } \ better use 
1c00: 6c 6f 63 61 6c 73 20 68 65 72 65 0a 20 20 20 20  locals here.    
1c10: 61 64 64 72 32 20 61 64 64 72 31 20 75 32 20 6d  addr2 addr1 u2 m
1c20: 6f 76 65 0a 20 20 20 20 61 64 64 72 31 20 75 31  ove.    addr1 u1
1c30: 20 75 32 20 2f 73 74 72 69 6e 67 20 65 72 61 73   u2 /string eras
1c40: 65 20 3b 0a 0a 3a 20 67 65 74 2d 64 65 73 74 20  e ;..: get-dest 
1c50: 28 20 70 61 63 6b 65 74 20 2d 2d 20 61 64 64 72  ( packet -- addr
1c60: 20 29 20 20 64 65 73 74 69 6e 61 74 69 6f 6e 20   )  destination 
1c70: 64 75 70 20 62 65 40 20 73 77 61 70 20 73 6b 69  dup be@ swap ski
1c80: 70 2d 64 65 73 74 20 3b 0a 3a 20 72 6f 75 74 65  p-dest ;.: route
1c90: 3f 20 28 20 70 61 63 6b 65 74 20 2d 2d 20 66 6c  ? ( packet -- fl
1ca0: 61 67 20 29 20 20 64 65 73 74 69 6e 61 74 69 6f  ag )  destinatio
1cb0: 6e 20 63 40 20 20 3b 0a 0a 3a 20 70 61 63 6b 65  n c@  ;..: packe
1cc0: 74 2d 72 6f 75 74 65 20 28 20 6f 72 69 67 2d 61  t-route ( orig-a
1cd0: 64 64 72 20 61 64 64 72 20 2d 2d 20 66 6c 61 67  ddr addr -- flag
1ce0: 20 29 0a 20 20 20 20 64 75 70 20 72 6f 75 74 65   ).    dup route
1cf0: 3f 20 20 49 46 0a 09 3e 72 20 72 40 20 67 65 74  ?  IF..>r r@ get
1d00: 2d 64 65 73 74 20 20 72 6f 75 74 65 3e 61 64 64  -dest  route>add
1d10: 72 65 73 73 20 20 49 46 20 20 72 40 20 69 6e 73  ress  IF  r@ ins
1d20: 2d 73 6f 75 72 63 65 20 20 45 4c 53 45 20 20 64  -source  ELSE  d
1d30: 72 6f 70 20 20 54 48 45 4e 0a 09 72 64 72 6f 70  rop  THEN..rdrop
1d40: 20 66 61 6c 73 65 20 20 45 58 49 54 20 20 54 48   false  EXIT  TH
1d50: 45 4e 0a 20 20 20 20 32 64 72 6f 70 20 74 72 75  EN.    2drop tru
1d60: 65 20 3b 20 5c 20 6c 6f 63 61 6c 20 70 61 63 6b  e ; \ local pack
1d70: 65 74 0a 0a 3a 20 6f 75 74 2d 72 6f 75 74 65 20  et..: out-route 
1d80: 28 20 2d 2d 20 29 20 20 30 20 6f 75 74 62 75 66  ( -- )  0 outbuf
1d90: 20 70 61 63 6b 65 74 2d 72 6f 75 74 65 20 64 72   packet-route dr
1da0: 6f 70 20 3b 0a 0a 5c 5c 5c 0a 4c 6f 63 61 6c 20  op ;..\\\.Local 
1db0: 56 61 72 69 61 62 6c 65 73 3a 0a 66 6f 72 74 68  Variables:.forth
1dc0: 2d 6c 6f 63 61 6c 2d 77 6f 72 64 73 3a 0a 20 20  -local-words:.  
1dd0: 20 20 28 0a 20 20 20 20 20 28 28 22 6e 65 74 32    (.     (("net2
1de0: 6f 3a 22 20 22 2b 6e 65 74 32 6f 3a 22 29 20 64  o:" "+net2o:") d
1df0: 65 66 69 6e 69 74 69 6f 6e 2d 73 74 61 72 74 65  efinition-starte
1e00: 72 20 28 66 6f 6e 74 2d 6c 6f 63 6b 2d 6b 65 79  r (font-lock-key
1e10: 77 6f 72 64 2d 66 61 63 65 20 2e 20 31 29 0a 20  word-face . 1). 
1e20: 20 20 20 20 20 22 5b 20 5c 74 5c 6e 5d 22 20 74       "[ \t\n]" t
1e30: 20 6e 61 6d 65 20 28 66 6f 6e 74 2d 6c 6f 63 6b   name (font-lock
1e40: 2d 66 75 6e 63 74 69 6f 6e 2d 6e 61 6d 65 2d 66  -function-name-f
1e50: 61 63 65 20 2e 20 33 29 29 0a 20 20 20 20 20 28  ace . 3)).     (
1e60: 22 5b 61 2d 7a 30 2d 39 5d 2b 28 22 20 69 6d 6d  "[a-z0-9]+(" imm
1e70: 65 64 69 61 74 65 20 28 66 6f 6e 74 2d 6c 6f 63  ediate (font-loc
1e80: 6b 2d 63 6f 6d 6d 65 6e 74 2d 66 61 63 65 20 2e  k-comment-face .
1e90: 20 31 29 0a 20 20 20 20 20 20 22 29 22 20 6e 69   1).      ")" ni
1ea0: 6c 20 63 6f 6d 6d 65 6e 74 20 28 66 6f 6e 74 2d  l comment (font-
1eb0: 6c 6f 63 6b 2d 63 6f 6d 6d 65 6e 74 2d 66 61 63  lock-comment-fac
1ec0: 65 20 2e 20 31 29 29 0a 20 20 20 20 29 0a 66 6f  e . 1)).    ).fo
1ed0: 72 74 68 2d 6c 6f 63 61 6c 2d 69 6e 64 65 6e 74  rth-local-indent
1ee0: 2d 77 6f 72 64 73 3a 0a 20 20 20 20 28 0a 20 20  -words:.    (.  
1ef0: 20 20 20 28 28 22 6e 65 74 32 6f 3a 22 20 22 2b     (("net2o:" "+
1f00: 6e 65 74 32 6f 3a 22 29 20 28 30 20 2e 20 32 29  net2o:") (0 . 2)
1f10: 20 28 30 20 2e 20 32 29 20 6e 6f 6e 2d 69 6d 6d   (0 . 2) non-imm
1f20: 65 64 69 61 74 65 29 0a 20 20 20 20 29 0a 45 6e  ediate).    ).En
1f30: 64 3a 0a 5b 54 48 45 4e 5d 0a                    d:.[THEN].