Artifact
1540bb6b2a771e882fac64a2d2e265e7a4f59d53 :
File
socks.fs
— part of check-in
[531f5bc61f]
at
2019-01-16 17:45:30
on branch trunk
— Replace 0 [IF] for emacs editings with \\\
(user:
bernd
size: 7993)
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 30 20 56 61 nfo ?ior ;..0 Va
1140: 6c 75 65 20 6c 61 73 74 61 64 64 72 23 0a 56 61 lue lastaddr#.Va
1150: 72 69 61 62 6c 65 20 6c 61 73 74 6e 32 6f 61 64 riable lastn2oad
1160: 64 72 0a 0a 3a 20 69 6e 73 65 72 74 2d 61 64 64 dr..: insert-add
1170: 72 65 73 73 20 28 20 61 64 64 72 20 75 20 2d 2d ress ( addr u --
1180: 20 6e 65 74 32 6f 2d 61 64 64 72 20 29 20 3f 3c net2o-addr ) ?<
1190: 69 70 76 36 0a 20 20 20 20 61 64 64 72 65 73 73 ipv6. address
11a0: 28 20 2e 22 20 49 6e 73 65 72 74 20 61 64 64 72 ( ." Insert addr
11b0: 65 73 73 20 22 20 32 64 75 70 20 2e 61 64 64 72 ess " 2dup .addr
11c0: 65 73 73 20 63 72 20 29 0a 20 20 20 20 6c 61 73 ess cr ). las
11d0: 74 61 64 64 72 23 20 49 46 20 20 32 64 75 70 20 taddr# IF 2dup
11e0: 6c 61 73 74 61 64 64 72 23 20 24 40 20 73 74 72 lastaddr# $@ str
11f0: 3d 0a 09 49 46 20 20 32 64 72 6f 70 20 6c 61 73 =..IF 2drop las
1200: 74 6e 32 6f 61 64 64 72 20 40 20 45 58 49 54 20 tn2oaddr @ EXIT
1210: 20 54 48 45 4e 0a 20 20 20 20 54 48 45 4e 0a 20 THEN. THEN.
1220: 20 20 20 32 64 75 70 20 72 6f 75 74 65 73 23 20 2dup routes#
1230: 23 6b 65 79 20 64 75 70 20 2d 31 20 3d 20 49 46 #key dup -1 = IF
1240: 0a 09 64 72 6f 70 20 73 22 20 22 20 32 6f 76 65 ..drop s" " 2ove
1250: 72 20 72 6f 75 74 65 73 23 20 23 21 0a 09 6c 61 r routes# #!..la
1260: 73 74 23 20 74 6f 20 6c 61 73 74 61 64 64 72 23 st# to lastaddr#
1270: 0a 09 72 6f 75 74 65 73 23 20 23 6b 65 79 20 20 ..routes# #key
1280: 64 75 70 20 6c 61 73 74 6e 32 6f 61 64 64 72 20 dup lastn2oaddr
1290: 21 0a 20 20 20 20 45 4c 53 45 0a 09 6e 69 70 20 !. ELSE..nip
12a0: 6e 69 70 0a 20 20 20 20 54 48 45 4e 20 3b 0a 0a nip. THEN ;..
12b0: 3a 20 64 6e 73 3e 73 74 72 69 6e 67 20 28 20 61 : dns>string ( a
12c0: 64 64 72 20 75 20 70 6f 72 74 20 68 69 6e 74 20 ddr u port hint
12d0: 2d 2d 20 69 6e 66 6f 20 6e 65 74 32 6f 2d 61 64 -- info net2o-ad
12e0: 64 72 20 75 20 29 0a 20 20 20 20 3e 72 20 53 4f dr u ). >r SO
12f0: 43 4b 5f 44 47 52 41 4d 20 3e 68 69 6e 74 73 20 CK_DGRAM >hints
1300: 72 3e 20 68 69 6e 74 73 20 61 69 5f 66 61 6d 69 r> hints ai_fami
1310: 6c 79 20 6c 21 0a 20 20 20 20 67 65 74 2d 69 6e ly l!. get-in
1320: 66 6f 20 64 75 70 20 69 6e 66 6f 3e 73 74 72 69 fo dup info>stri
1330: 6e 67 20 3b 0a 0a 3a 20 69 6e 73 65 72 74 2d 69 ng ;..: insert-i
1340: 70 2a 20 28 20 61 64 64 72 20 75 20 70 6f 72 74 p* ( addr u port
1350: 20 68 69 6e 74 20 2d 2d 20 6e 65 74 32 6f 2d 61 hint -- net2o-a
1360: 64 64 72 20 29 0a 20 20 20 20 64 6e 73 3e 73 74 ddr ). dns>st
1370: 72 69 6e 67 20 72 6f 74 20 3e 72 20 69 6e 73 65 ring rot >r inse
1380: 72 74 2d 61 64 64 72 65 73 73 20 72 3e 20 66 72 rt-address r> fr
1390: 65 65 61 64 64 72 69 6e 66 6f 20 3b 0a 0a 3a 20 eeaddrinfo ;..:
13a0: 69 6e 73 65 72 74 2d 69 70 20 28 20 61 64 64 72 insert-ip ( addr
13b0: 20 75 20 70 6f 72 74 20 2d 2d 20 6e 65 74 32 6f u port -- net2o
13c0: 2d 61 64 64 72 20 29 20 20 30 20 20 20 20 20 20 -addr ) 0
13d0: 20 20 20 69 6e 73 65 72 74 2d 69 70 2a 20 3b 0a insert-ip* ;.
13e0: 3a 20 69 6e 73 65 72 74 2d 69 70 34 20 28 20 61 : insert-ip4 ( a
13f0: 64 64 72 20 75 20 70 6f 72 74 20 2d 2d 20 6e 65 ddr u port -- ne
1400: 74 32 6f 2d 61 64 64 72 20 29 20 50 46 5f 49 4e t2o-addr ) PF_IN
1410: 45 54 20 20 20 69 6e 73 65 72 74 2d 69 70 2a 20 ET insert-ip*
1420: 3b 0a 3a 20 69 6e 73 65 72 74 2d 69 70 36 20 28 ;.: insert-ip6 (
1430: 20 61 64 64 72 20 75 20 70 6f 72 74 20 2d 2d 20 addr u port --
1440: 6e 65 74 32 6f 2d 61 64 64 72 20 29 20 50 46 5f net2o-addr ) PF_
1450: 49 4e 45 54 36 20 20 69 6e 73 65 72 74 2d 69 70 INET6 insert-ip
1460: 2a 20 3b 0a 0a 3a 20 72 6f 75 74 65 3e 61 64 64 * ;..: route>add
1470: 72 65 73 73 20 28 20 6e 20 2d 2d 20 66 6c 61 67 ress ( n -- flag
1480: 20 29 0a 20 20 20 20 72 6f 75 74 65 73 23 20 23 ). routes# #
1490: 2e 6b 65 79 20 64 75 70 20 30 3d 20 3f 45 58 49 .key dup 0= ?EXI
14a0: 54 0a 20 20 20 20 24 40 20 73 6f 63 6b 61 64 64 T. $@ sockadd
14b0: 72 3e 20 6f 76 65 72 20 61 6c 65 6e 20 21 20 73 r> over alen ! s
14c0: 6f 63 6b 61 64 64 72 5f 69 6e 20 73 6d 6f 76 65 ockaddr_in smove
14d0: 20 74 72 75 65 20 3b 0a 0a 5c 20 71 75 65 72 79 true ;..\ query
14e0: 20 69 66 20 77 65 20 68 61 76 65 20 61 20 44 4e if we have a DN
14f0: 53 36 34 20 65 6e 76 69 72 6f 6e 6d 65 6e 74 0a S64 environment.
1500: 0a 56 61 72 69 61 62 6c 65 20 6e 65 74 32 6f 2d .Variable net2o-
1510: 69 70 76 34 20 22 69 70 76 34 2e 6e 65 74 32 6f ipv4 "ipv4.net2o
1520: 2e 64 65 22 20 6e 65 74 32 6f 2d 69 70 76 34 20 .de" net2o-ipv4
1530: 24 21 0a 0a 3a 20 64 6e 73 36 34 3f 20 28 20 2d $!..: dns64? ( -
1540: 2d 20 66 6c 61 67 20 29 0a 20 20 20 20 6e 65 74 - flag ). net
1550: 32 6f 2d 69 70 76 34 20 24 40 20 6e 65 74 32 6f 2o-ipv4 $@ net2o
1560: 2d 70 6f 72 74 20 67 65 74 2d 69 6e 66 6f 20 69 -port get-info i
1570: 6e 66 6f 40 0a 20 20 20 20 73 6f 63 6b 61 64 64 nfo@. sockadd
1580: 72 5f 69 6e 36 20 3d 20 6f 76 65 72 20 66 61 6d r_in6 = over fam
1590: 69 6c 79 20 77 40 20 41 46 5f 49 4e 45 54 36 20 ily w@ AF_INET6
15a0: 3d 20 49 46 0a 09 73 69 6e 36 5f 61 64 64 72 20 = IF..sin6_addr
15b0: 24 43 20 6e 61 74 36 34 2d 69 70 34 20 6f 76 65 $C nat64-ip4 ove
15c0: 72 20 73 74 72 3d 0a 20 20 20 20 45 4c 53 45 20 r str=. ELSE
15d0: 20 64 72 6f 70 20 66 61 6c 73 65 20 20 54 48 45 drop false THE
15e0: 4e 20 3b 0a 0a 5c 20 72 6f 75 74 65 20 61 6e 20 N ;..\ route an
15f0: 69 6e 63 6f 6d 69 6e 67 20 70 61 63 6b 65 74 0a incoming packet.
1600: 0a 3a 20 3e 72 70 61 74 68 2d 6c 65 6e 20 28 20 .: >rpath-len (
1610: 72 70 61 74 68 20 2d 2d 20 72 70 61 74 68 20 6c rpath -- rpath l
1620: 65 6e 20 29 0a 20 20 20 20 64 75 70 20 30 3d 20 en ). dup 0=
1630: 49 46 20 20 30 20 20 45 58 49 54 20 20 54 48 45 IF 0 EXIT THE
1640: 4e 0a 20 20 20 20 5b 49 46 44 45 46 5d 20 36 34 N. [IFDEF] 64
1650: 62 69 74 0a 09 64 75 70 20 24 31 30 30 30 30 30 bit..dup $100000
1660: 30 30 30 20 75 3c 20 49 46 0a 09 20 20 20 20 64 000 u< IF.. d
1670: 75 70 20 24 31 30 30 30 30 20 75 3c 20 49 46 0a up $10000 u< IF.
1680: 09 09 64 75 70 20 24 31 30 30 20 75 3c 20 32 20 ..dup $100 u< 2
1690: 2b 20 20 45 58 49 54 0a 09 20 20 20 20 45 4c 53 + EXIT.. ELS
16a0: 45 0a 09 09 64 75 70 20 24 31 30 30 30 30 30 30 E...dup $1000000
16b0: 20 75 3c 20 34 20 2b 20 45 58 49 54 0a 09 20 20 u< 4 + EXIT..
16c0: 20 20 54 48 45 4e 0a 09 45 4c 53 45 0a 09 20 20 THEN..ELSE..
16d0: 20 20 64 75 70 20 24 31 30 30 30 30 30 30 30 30 dup $100000000
16e0: 30 30 30 30 20 75 3c 20 49 46 0a 09 09 64 75 70 0000 u< IF...dup
16f0: 20 24 31 30 30 30 30 30 30 30 30 30 30 20 75 3c $10000000000 u<
1700: 20 36 20 2b 20 20 45 58 49 54 0a 09 20 20 20 20 6 + EXIT..
1710: 45 4c 53 45 0a 09 09 64 75 70 20 24 31 30 30 30 ELSE...dup $1000
1720: 30 30 30 30 30 30 30 30 30 30 30 20 75 3c 20 38 00000000000 u< 8
1730: 20 2b 20 20 45 58 49 54 0a 09 20 20 20 20 54 48 + EXIT.. TH
1740: 45 4e 0a 09 54 48 45 4e 0a 20 20 20 20 5b 45 4c EN..THEN. [EL
1750: 53 45 5d 0a 09 64 75 70 20 24 31 30 30 30 30 20 SE]..dup $10000
1760: 75 3c 20 49 46 0a 09 20 20 20 20 64 75 70 20 24 u< IF.. dup $
1770: 31 30 30 20 75 3c 20 32 20 2b 20 20 45 58 49 54 100 u< 2 + EXIT
1780: 0a 09 45 4c 53 45 0a 09 20 20 20 20 64 75 70 20 ..ELSE.. dup
1790: 24 31 30 30 30 30 30 30 20 75 3c 20 34 20 2b 20 $1000000 u< 4 +
17a0: 45 58 49 54 0a 09 54 48 45 4e 0a 20 20 20 20 5b EXIT..THEN. [
17b0: 54 48 45 4e 5d 20 3b 0a 3a 20 3e 70 61 74 68 2d THEN] ;.: >path-
17c0: 6c 65 6e 20 28 20 70 61 74 68 20 2d 2d 20 70 61 len ( path -- pa
17d0: 74 68 20 6c 65 6e 20 29 0a 20 20 20 20 64 75 70 th len ). dup
17e0: 20 30 3d 20 49 46 20 20 30 20 20 45 58 49 54 20 0= IF 0 EXIT
17f0: 20 54 48 45 4e 0a 20 20 20 20 5b 49 46 44 45 46 THEN. [IFDEF
1800: 5d 20 36 34 62 69 74 0a 09 64 75 70 20 20 20 20 ] 64bit..dup
1810: 20 24 30 30 30 30 30 30 30 30 46 46 46 46 46 46 $00000000FFFFFF
1820: 46 46 20 61 6e 64 20 49 46 0a 09 20 20 20 20 64 FF and IF.. d
1830: 75 70 20 24 30 30 30 30 30 30 30 30 30 30 30 30 up $000000000000
1840: 46 46 46 46 20 61 6e 64 20 49 46 0a 09 09 64 75 FFFF and IF...du
1850: 70 20 24 30 30 30 30 30 30 30 30 30 30 30 30 30 p $0000000000000
1860: 30 46 46 20 61 6e 64 20 30 3d 20 38 20 2b 20 20 0FF and 0= 8 +
1870: 45 58 49 54 0a 09 20 20 20 20 45 4c 53 45 0a 09 EXIT.. ELSE..
1880: 09 64 75 70 20 24 30 30 30 30 30 30 30 30 30 30 .dup $0000000000
1890: 46 46 46 46 46 46 20 61 6e 64 20 30 3d 20 36 20 FFFFFF and 0= 6
18a0: 2b 20 20 45 58 49 54 0a 09 20 20 20 20 54 48 45 + EXIT.. THE
18b0: 4e 0a 09 45 4c 53 45 0a 09 20 20 20 20 64 75 70 N..ELSE.. dup
18c0: 20 24 30 30 30 30 46 46 46 46 46 46 46 46 46 46 $0000FFFFFFFFFF
18d0: 46 46 20 61 6e 64 20 49 46 0a 09 09 64 75 70 20 FF and IF...dup
18e0: 24 30 30 30 30 30 30 46 46 46 46 46 46 46 46 46 $000000FFFFFFFFF
18f0: 46 20 61 6e 64 20 30 3d 20 34 20 2b 20 20 45 58 F and 0= 4 + EX
1900: 49 54 0a 09 20 20 20 20 45 4c 53 45 0a 09 09 64 IT.. ELSE...d
1910: 75 70 20 24 30 30 46 46 46 46 46 46 46 46 46 46 up $00FFFFFFFFFF
1920: 46 46 46 46 20 61 6e 64 20 30 3d 20 32 20 2b 20 FFFF and 0= 2 +
1930: 20 45 58 49 54 0a 09 20 20 20 20 54 48 45 4e 0a EXIT.. THEN.
1940: 09 54 48 45 4e 0a 20 20 20 20 5b 45 4c 53 45 5d .THEN. [ELSE]
1950: 0a 09 64 75 70 20 20 20 20 20 24 30 30 30 30 46 ..dup $0000F
1960: 46 46 46 20 61 6e 64 20 49 46 0a 09 20 20 20 20 FFF and IF..
1970: 64 75 70 20 24 30 30 30 30 30 30 46 46 20 61 6e dup $000000FF an
1980: 64 20 30 3d 20 34 20 2b 20 20 45 58 49 54 0a 09 d 0= 4 + EXIT..
1990: 45 4c 53 45 0a 09 20 20 20 20 64 75 70 20 24 30 ELSE.. dup $0
19a0: 30 46 46 46 46 46 46 20 61 6e 64 20 30 3d 20 32 0FFFFFF and 0= 2
19b0: 20 2b 20 20 45 58 49 54 0a 09 54 48 45 4e 0a 20 + EXIT..THEN.
19c0: 20 20 20 5b 54 48 45 4e 5d 20 3b 0a 0a 3a 20 3c [THEN] ;..: <
19d0: 30 73 74 72 69 6e 67 20 28 20 65 6e 64 61 64 64 0string ( endadd
19e0: 72 20 2d 2d 20 61 64 64 72 20 75 20 29 0a 20 20 r -- addr u ).
19f0: 20 20 24 31 31 20 31 20 44 4f 20 20 31 2d 20 64 $11 1 DO 1- d
1a00: 75 70 20 63 40 20 57 48 49 4c 45 20 20 4c 4f 4f up c@ WHILE LOO
1a10: 50 20 20 24 31 30 20 20 45 4c 53 45 20 20 49 20 P $10 ELSE I
1a20: 20 55 4e 4c 4f 4f 50 20 20 54 48 45 4e 20 3b 0a UNLOOP THEN ;.
1a30: 0a 3a 20 69 6e 73 2d 73 6f 75 72 63 65 20 28 20 .: ins-source (
1a40: 61 64 64 72 20 70 61 63 6b 65 74 20 2d 2d 20 29 addr packet -- )
1a50: 0a 20 20 20 20 64 65 73 74 69 6e 61 74 69 6f 6e . destination
1a60: 20 3e 72 20 72 65 76 65 72 73 65 0a 20 20 20 20 >r reverse.
1a70: 64 75 70 20 3e 72 70 61 74 68 2d 6c 65 6e 20 7b dup >rpath-len {
1a80: 20 77 5e 20 72 70 61 74 68 20 72 70 6c 65 6e 20 w^ rpath rplen
1a90: 7d 20 72 70 61 74 68 20 62 65 21 0a 20 20 20 20 } rpath be!.
1aa0: 72 40 20 24 31 30 20 2b 20 3c 30 73 74 72 69 6e r@ $10 + <0strin
1ab0: 67 0a 20 20 20 20 6f 76 65 72 20 72 70 6c 65 6e g. over rplen
1ac0: 20 2d 20 73 77 61 70 20 6d 6f 76 65 0a 20 20 20 - swap move.
1ad0: 20 72 70 61 74 68 20 63 65 6c 6c 2b 20 72 70 6c rpath cell+ rpl
1ae0: 65 6e 20 2d 20 72 3e 20 24 31 30 20 2b 20 72 70 en - r> $10 + rp
1af0: 6c 65 6e 20 2d 20 72 70 6c 65 6e 20 6d 6f 76 65 len - rplen move
1b00: 20 3b 0a 3a 20 69 6e 73 2d 64 65 73 74 20 28 20 ;.: ins-dest (
1b10: 6e 32 6f 61 64 64 72 20 64 65 73 74 61 64 64 72 n2oaddr destaddr
1b20: 20 2d 2d 20 29 0a 20 20 20 20 3e 72 20 64 75 70 -- ). >r dup
1b30: 20 3e 70 61 74 68 2d 6c 65 6e 20 7b 20 77 5e 20 >path-len { w^
1b40: 70 61 74 68 20 70 6c 65 6e 20 7d 20 70 61 74 68 path plen } path
1b50: 20 62 65 21 0a 20 20 20 20 72 40 20 63 73 74 72 be!. r@ cstr
1b60: 69 6e 67 3e 73 73 74 72 69 6e 67 20 6f 76 65 72 ing>sstring over
1b70: 20 70 6c 65 6e 20 2b 20 73 77 61 70 20 6d 6f 76 plen + swap mov
1b80: 65 0a 20 20 20 20 70 61 74 68 20 72 3e 20 70 6c e. path r> pl
1b90: 65 6e 20 6d 6f 76 65 20 3b 0a 3a 20 73 6b 69 70 en move ;.: skip
1ba0: 2d 64 65 73 74 20 28 20 61 64 64 72 20 2d 2d 20 -dest ( addr --
1bb0: 29 0a 20 20 20 20 24 31 30 20 32 64 75 70 20 30 ). $10 2dup 0
1bc0: 20 73 63 61 6e 20 6e 69 70 20 2d 0a 20 20 20 20 scan nip -.
1bd0: 32 64 75 70 20 70 61 74 68 63 2b 20 7b 20 61 64 2dup pathc+ { ad
1be0: 64 72 31 20 75 31 20 61 64 64 72 32 20 75 32 20 dr1 u1 addr2 u2
1bf0: 7d 20 5c 20 62 65 74 74 65 72 20 75 73 65 20 6c } \ better use l
1c00: 6f 63 61 6c 73 20 68 65 72 65 0a 20 20 20 20 61 ocals here. a
1c10: 64 64 72 32 20 61 64 64 72 31 20 75 32 20 6d 6f ddr2 addr1 u2 mo
1c20: 76 65 0a 20 20 20 20 61 64 64 72 31 20 75 31 20 ve. addr1 u1
1c30: 75 32 20 2f 73 74 72 69 6e 67 20 65 72 61 73 65 u2 /string erase
1c40: 20 3b 0a 0a 3a 20 67 65 74 2d 64 65 73 74 20 28 ;..: get-dest (
1c50: 20 70 61 63 6b 65 74 20 2d 2d 20 61 64 64 72 20 packet -- addr
1c60: 29 20 20 64 65 73 74 69 6e 61 74 69 6f 6e 20 64 ) destination d
1c70: 75 70 20 62 65 40 20 73 77 61 70 20 73 6b 69 70 up be@ swap skip
1c80: 2d 64 65 73 74 20 3b 0a 3a 20 72 6f 75 74 65 3f -dest ;.: route?
1c90: 20 28 20 70 61 63 6b 65 74 20 2d 2d 20 66 6c 61 ( packet -- fla
1ca0: 67 20 29 20 20 64 65 73 74 69 6e 61 74 69 6f 6e g ) destination
1cb0: 20 63 40 20 20 3b 0a 0a 3a 20 70 61 63 6b 65 74 c@ ;..: packet
1cc0: 2d 72 6f 75 74 65 20 28 20 6f 72 69 67 2d 61 64 -route ( orig-ad
1cd0: 64 72 20 61 64 64 72 20 2d 2d 20 66 6c 61 67 20 dr addr -- flag
1ce0: 29 0a 20 20 20 20 64 75 70 20 72 6f 75 74 65 3f ). dup route?
1cf0: 20 20 49 46 0a 09 3e 72 20 72 40 20 67 65 74 2d IF..>r r@ get-
1d00: 64 65 73 74 20 20 72 6f 75 74 65 3e 61 64 64 72 dest route>addr
1d10: 65 73 73 20 20 49 46 20 20 72 40 20 69 6e 73 2d ess IF r@ ins-
1d20: 73 6f 75 72 63 65 20 20 45 4c 53 45 20 20 64 72 source ELSE dr
1d30: 6f 70 20 20 54 48 45 4e 0a 09 72 64 72 6f 70 20 op THEN..rdrop
1d40: 66 61 6c 73 65 20 20 45 58 49 54 20 20 54 48 45 false EXIT THE
1d50: 4e 0a 20 20 20 20 32 64 72 6f 70 20 74 72 75 65 N. 2drop true
1d60: 20 3b 20 5c 20 6c 6f 63 61 6c 20 70 61 63 6b 65 ; \ local packe
1d70: 74 0a 0a 3a 20 6f 75 74 2d 72 6f 75 74 65 20 28 t..: out-route (
1d80: 20 2d 2d 20 29 20 20 30 20 6f 75 74 62 75 66 20 -- ) 0 outbuf
1d90: 70 61 63 6b 65 74 2d 72 6f 75 74 65 20 64 72 6f packet-route dro
1da0: 70 20 3b 0a 0a 5c 5c 5c 0a 4c 6f 63 61 6c 20 56 p ;..\\\.Local V
1db0: 61 72 69 61 62 6c 65 73 3a 0a 66 6f 72 74 68 2d ariables:.forth-
1dc0: 6c 6f 63 61 6c 2d 77 6f 72 64 73 3a 0a 20 20 20 local-words:.
1dd0: 20 28 0a 20 20 20 20 20 28 28 22 6e 65 74 32 6f (. (("net2o
1de0: 3a 22 20 22 2b 6e 65 74 32 6f 3a 22 29 20 64 65 :" "+net2o:") de
1df0: 66 69 6e 69 74 69 6f 6e 2d 73 74 61 72 74 65 72 finition-starter
1e00: 20 28 66 6f 6e 74 2d 6c 6f 63 6b 2d 6b 65 79 77 (font-lock-keyw
1e10: 6f 72 64 2d 66 61 63 65 20 2e 20 31 29 0a 20 20 ord-face . 1).
1e20: 20 20 20 20 22 5b 20 5c 74 5c 6e 5d 22 20 74 20 "[ \t\n]" t
1e30: 6e 61 6d 65 20 28 66 6f 6e 74 2d 6c 6f 63 6b 2d name (font-lock-
1e40: 66 75 6e 63 74 69 6f 6e 2d 6e 61 6d 65 2d 66 61 function-name-fa
1e50: 63 65 20 2e 20 33 29 29 0a 20 20 20 20 20 28 22 ce . 3)). ("
1e60: 5b 61 2d 7a 30 2d 39 5d 2b 28 22 20 69 6d 6d 65 [a-z0-9]+(" imme
1e70: 64 69 61 74 65 20 28 66 6f 6e 74 2d 6c 6f 63 6b diate (font-lock
1e80: 2d 63 6f 6d 6d 65 6e 74 2d 66 61 63 65 20 2e 20 -comment-face .
1e90: 31 29 0a 20 20 20 20 20 20 22 29 22 20 6e 69 6c 1). ")" nil
1ea0: 20 63 6f 6d 6d 65 6e 74 20 28 66 6f 6e 74 2d 6c comment (font-l
1eb0: 6f 63 6b 2d 63 6f 6d 6d 65 6e 74 2d 66 61 63 65 ock-comment-face
1ec0: 20 2e 20 31 29 29 0a 20 20 20 20 29 0a 66 6f 72 . 1)). ).for
1ed0: 74 68 2d 6c 6f 63 61 6c 2d 69 6e 64 65 6e 74 2d th-local-indent-
1ee0: 77 6f 72 64 73 3a 0a 20 20 20 20 28 0a 20 20 20 words:. (.
1ef0: 20 20 28 28 22 6e 65 74 32 6f 3a 22 20 22 2b 6e (("net2o:" "+n
1f00: 65 74 32 6f 3a 22 29 20 28 30 20 2e 20 32 29 20 et2o:") (0 . 2)
1f10: 28 30 20 2e 20 32 29 20 6e 6f 6e 2d 69 6d 6d 65 (0 . 2) non-imme
1f20: 64 69 61 74 65 29 0a 20 20 20 20 29 0a 45 6e 64 diate). ).End
1f30: 3a 0a 5b 54 48 45 4e 5d 0a :.[THEN].