Artifact
4a5df34002c0725f7d1e1739799d95b5f6870125:
- File
socks.fs
— part of check-in
[856357a817]
at
2019-07-08 18:32:39
on branch trunk
— Fix problem with insert-address
(user:
bernd
size: 7994)
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].