mirror of
https://github.com/urbit/shrub.git
synced 2024-12-04 14:58:10 +03:00
1948 lines
77 KiB
Plaintext
1948 lines
77 KiB
Plaintext
!: :: ames (4a), networking
|
|
::
|
|
|= pit=vase
|
|
=> =~
|
|
:: structures
|
|
|%
|
|
++ flog :: error wrapper
|
|
$% [%crud p=@tas q=(list tank)] ::
|
|
[%text p=tape] ::
|
|
== ::
|
|
++ gift :: out result <-$
|
|
$% [%hear p=lane q=@] :: receive packet
|
|
[%init p=@p] :: report install
|
|
[%send p=lane q=@] :: transmit packet
|
|
[%waft p=sock q=*] :: response message
|
|
[%wart p=sock q=@tas r=path s=*] :: network request
|
|
[%went p=ship q=cape] :: reaction message
|
|
[%woot p=ship q=coop] :: e2e reaction message
|
|
== ::
|
|
++ hasp ,[p=ship q=term] :: see %gall
|
|
++ kiss :: in request ->$
|
|
$% [%barn ~] :: new unix process
|
|
[%crud p=@tas q=(list tank)] :: error with trace
|
|
[%cash p=@p q=buck] :: civil license
|
|
[%hear p=lane q=@] :: receive packet
|
|
[%hole p=lane q=@] :: packet failed
|
|
[%junk p=@] :: entropy
|
|
[%kick p=@da] :: wake up
|
|
[%make p=(unit ,@t) q=@ud r=@ s=?] :: wild license
|
|
[%sith p=@p q=@uw r=?] :: imperial generator
|
|
[%wake ~] :: timer activate
|
|
[%want p=sock q=path r=*] :: send message
|
|
[%wont p=sock q=path r=*] :: e2e send message
|
|
== ::
|
|
++ move ,[p=duct q=(mold note gift)] :: local move
|
|
++ note :: out request $->
|
|
$? $: %d :: to %dill
|
|
$% [%flog p=flog] ::
|
|
== == ::
|
|
$: %a :: to %ames
|
|
$% [%kick p=@da] ::
|
|
== == ::
|
|
$: %g :: to %gall
|
|
$% [%rote p=sack q=path r=*] ::
|
|
[%roth p=sack q=path r=*] ::
|
|
[%mess p=[@p %ye ~] q=@p r=cage] ::
|
|
== == ::
|
|
$: @tas :: to any
|
|
$% [%init p=@p] ::
|
|
[%want p=sock q=path r=*] ::
|
|
[%wart p=sock q=@tas r=path s=*] ::
|
|
== == == ::
|
|
++ sign :: in result $<-
|
|
$? $: %a :: from %ames
|
|
$% [%went p=ship q=cape] ::
|
|
== == ::
|
|
$: %g :: from %gall
|
|
$% [%mean p=ares] ::
|
|
[%nice ~] ::
|
|
== == ::
|
|
$: @tas ::
|
|
$% [%crud p=@tas q=(list tank)] :: by any
|
|
== == == ::
|
|
--
|
|
::::::::::::::::::::::::::::::::::::::::::::::::::::::::
|
|
:: section 4aA, identity logic ::
|
|
::
|
|
|%
|
|
::
|
|
++ grip :: extend will
|
|
|= [wet=will law=will]
|
|
^- will
|
|
?~ wet law
|
|
?: =(wet law) law
|
|
?^ t.wet
|
|
?>((meld i.wet i.t.wet) [i.wet $(wet t.wet)])
|
|
?~ law
|
|
?>((pier i.wet) [i.wet ~])
|
|
?~ q.p.q.i.wet
|
|
?>((meld i.wet i.law) [i.wet law])
|
|
=+ rul=(sein r.p.q.i.wet)
|
|
|- ^- will
|
|
?: ?& =(rul r.p.q.i.law)
|
|
=(p.p.q.i.law u.q.p.q.i.wet)
|
|
==
|
|
?>((meld i.wet i.law) [i.wet law])
|
|
?>(?=(^ t.law) $(law t.law))
|
|
::
|
|
++ meld :: verify connect
|
|
|= [new=deed old=deed]
|
|
^- &
|
|
?> (melt new old)
|
|
?> =((shaf %meld (sham q.new)) (need (sure:as:(haul r.q.old) *code p.new)))
|
|
%&
|
|
::
|
|
++ melt :: proper connect
|
|
|= [new=deed old=deed]
|
|
^- ?
|
|
=+ rac=(clan r.p.q.new)
|
|
?& =(r.new r.old) :: match fake
|
|
?~ q.p.q.new
|
|
?& =(r.p.q.old r.p.q.new)
|
|
&(!=(%earl rac) =(p.p.q.old (dec p.p.q.new)))
|
|
==
|
|
?& &(!=(%pawn rac) !=(%czar rac))
|
|
|(=(0 p.p.q.new) =(%earl rac))
|
|
=(r.p.q.old (sein r.p.q.new))
|
|
=(p.p.q.old u.q.p.q.new)
|
|
==
|
|
==
|
|
::
|
|
++ pare :: shorten against
|
|
|= [fou=will law=will]
|
|
:: ~& [%pare-fou fou]
|
|
:: ~& [%pare-law law]
|
|
^- will
|
|
=+ [ouf=(flop fou) wal=(flop law)]
|
|
%- flop
|
|
|- ^- will
|
|
?~ ouf wal
|
|
?~ wal ?>(=(~ ouf) ~)
|
|
?. =(i.wal i.ouf) ouf
|
|
$(wal t.wal, ouf t.ouf)
|
|
::
|
|
++ pier !: :: initial deed
|
|
|= wed=deed
|
|
^- &
|
|
?> =+ rac=(clan r.p.q.wed)
|
|
=+ loy=(haul r.q.wed)
|
|
?: &(r.wed =(rac %czar)) %&
|
|
?> =(0 p.p.q.wed)
|
|
?> =(fig:ex:loy ?+(rac !! %czar (zeno r.p.q.wed), %pawn r.p.q.wed))
|
|
?> =((shaf %self (sham q.wed)) (need (sure:as:loy *code p.wed)))
|
|
%&
|
|
%&
|
|
::
|
|
++ real :: validate
|
|
|= [mac=mace law=will]
|
|
?> ?& |- ^- ?
|
|
?~ mac &
|
|
?> ?& ?=(^ law)
|
|
(lth p.p.q.i.law 9) :: 9-lives rule
|
|
=(p.p.q.i.law p.i.mac)
|
|
=(r.q.i.law pub:ex:(weur q.i.mac))
|
|
==
|
|
$(mac t.mac, law t.law)
|
|
==
|
|
%&
|
|
::
|
|
++ rice :: mace at life
|
|
|= [mar=life mac=mace]
|
|
^- (unit mace)
|
|
?~ mac ~
|
|
?: =(mar p.i.mac) [~ mac]
|
|
?: (gth mar p.i.mac) ~
|
|
$(mac t.mac)
|
|
::
|
|
++ rick :: will at life
|
|
|= [mar=life lag=ship law=will]
|
|
^- (unit will)
|
|
?~ law ~
|
|
?: =(mar p.p.q.i.law) [~ law]
|
|
?: (gth mar p.p.q.i.law) ~
|
|
?: |(?=(~ q.p.q.i.law) !=(lag r.p.q.i.law)) ~
|
|
$(law t.law)
|
|
::
|
|
++ zeno :: imperial keyprint
|
|
|= zar=@pD
|
|
^- @uvH ^- @
|
|
%+ snag zar
|
|
^- (list ,@uw)
|
|
:~ 0wN.Kdp5k.p5ncD.4Wsih.bFQFu :: 0, ~zod, Tlon (gleba)
|
|
0w0 :: 1, ~nec, Curtis Yarvin (sator)
|
|
0w0 :: 2, ~bud, Charles Songhurst (angelus)
|
|
0w0 :: 3, ~wes, Tamares Group (angelus)
|
|
0w0 :: 4, ~sev, Tamares Group (angelus)
|
|
0wt.cKYxs.Yb5VZ.boSwm.l0yYc :: 5, ~per, Jonathan Perlow (angelus)
|
|
0w0 :: 6, ~sut, A16Z(a) (angelus)
|
|
0w0 :: 7, ~let, A16Z(b) (angelus)
|
|
0w0 :: 8, ~ful, A16Z (angelus)
|
|
0w0 :: 9, ~pen, A16Z (angelus)
|
|
0w0 :: 10, ~syt, A16Z (angelus)
|
|
0w0 :: 11, ~dur, A16Z (angelus)
|
|
0w0 :: 12, ~wep, ~rislus-dopsym (fidelis)
|
|
0w0 :: 13, ~ser, Alex Morcos (angelus)
|
|
0w3j.H0sty.jHa3F.JlD26.4LPwV :: 14, ~wyl, Zimran Ahmed (donum)
|
|
0w3F.QdvV-.toAsR.hvUNk.fHjW6 :: 15, ~sun, Colin Smith (fortuna)
|
|
0w0 :: 16, ~ryp, FF Angel (angelus)
|
|
0w0 :: 17, ~syx, FF Angel (angelus)
|
|
0w0 :: 18, ~dyr, FF Angel (angelus)
|
|
0w0 :: 19, ~nup, FF Angel (angelus)
|
|
0w0 :: 20, ~heb, FF Angel (angelus)
|
|
0w0 :: 21, ~peg, FF Angel (angelus)
|
|
0w0 :: 22, ~lup, FF Angel (angelus)
|
|
0w0 :: 23, ~dep, FF Angel (angelus)
|
|
0w0 :: 24, ~dys, Mike Gogulski (mercor)
|
|
0w0 :: 25, ~put, Suhas Daftuar (angelus)
|
|
0w0 :: 26, ~lug, Garth Partners (angelus)
|
|
0w0 :: 27, ~hec, Garth Partners (angelus)
|
|
0w0 :: 28, ~ryt, Garth Partners (angelus)
|
|
0w0 :: 29, ~tyv, Garth Partners (angelus)
|
|
0w0 :: 30, ~syd, Curtis Yarvin (sator)
|
|
0wp.BgRGJ.kslnv.PLAqb.TRKbr :: 31, ~nex, Prakhar Goel (fortuna)
|
|
0w0 :: 32, ~lun, Tim Draper (angelus)
|
|
0w0 :: 33, ~mep, Tim Draper (angelus)
|
|
0w0 :: 34, ~lut, Tim Draper (angelus)
|
|
0w0 :: 35, ~sep, Tim Draper (angelus)
|
|
0w0 :: 36, ~pes, Curtis Yarvin (sator)
|
|
0w2J.WSHlR.t5VHN.X8GKE.DB-yz :: 37, ~del, ~novrud-hanweb (fidelis)
|
|
0w1w.KF-J1.5I63F.khFyv.h0n4J :: 38, ~sul, John Burnham (donum)
|
|
0w0 :: 39, ~ped, Curtis Yarvin (sator)
|
|
0w2.Mr2Id.SX8xI.MAs-j.5Y-1W :: 40, ~tem, Bruce Schwartz (angelus)
|
|
0w0 :: 41, ~led, ~lontec-botrum (fidelis)
|
|
0w0 :: 42, ~tul, Curtis Yarvin (sator)
|
|
0w0 :: 43, ~met, Curtis Yarvin (sator)
|
|
0w0 :: 44, ~wen, Curtis Yarvin (sator)
|
|
0w0 :: 45, ~byn, Curtis Yarvin (sator)
|
|
0w0 :: 46, ~hex, ~bishus-namsum (fidelis)
|
|
0w0 :: 47, ~feb, Curtis Yarvin (sator)
|
|
0wK.GoKEY.rMjfn.ZcvFQ.n4BmX :: 48, ~pyl, Michael Hartl (donum)
|
|
0w0 :: 49, ~dul, Curtis Yarvin (sator)
|
|
0w0 :: 50, ~het, Curtis Yarvin (sator)
|
|
0w0 :: 51, ~mev, Curtis Yarvin (sator)
|
|
0w0 :: 52, ~rut, Curtis Yarvin (sator)
|
|
0w2L.M6-o5.DDTFL.R4sFL.7Zuay :: 53, ~tyl, Jaan Tallinn (angelus)
|
|
0w0 :: 54, ~wyd, Curtis Yarvin (sator)
|
|
0w0 :: 55, ~tep, Curtis Yarvin (sator)
|
|
0w0 :: 56, ~bes, Curtis Yarvin (sator)
|
|
0w0 :: 57, ~dex, Jared Hance (aestas)
|
|
0w0 :: 58, ~sef, Curtis Yarvin (sator)
|
|
0w0 :: 59, ~wyc, Curtis Yarvin (sator)
|
|
0w0 :: 60, ~bur, Curtis Yarvin (sator)
|
|
0w0 :: 61, ~der, Curtis Yarvin (sator)
|
|
0w0 :: 62, ~nep, Curtis Yarvin (sator)
|
|
0w0 :: 63, ~pur, Curtis Yarvin (sator)
|
|
0w0 :: 64, ~rys, Curtis Yarvin (sator)
|
|
0w0 :: 65, ~reb, Curtis Yarvin (sator)
|
|
0wp.LslIa.IFSM9.mIp-z.KBIBh :: 66, ~den Michael Hartl (donum)
|
|
0w0 :: 67, ~nut, Curtis Yarvin (sator)
|
|
0w0 :: 68, ~sub, Curtis Yarvin (sator)
|
|
0w0 :: 69, ~pet, Curtis Yarvin (sator)
|
|
0w0 :: 70, ~rul, Curtis Yarvin (sator)
|
|
0w0 :: 71, ~syn, Curtis Yarvin (sator)
|
|
0w0 :: 72, ~reg, Henry Ault (aestas)
|
|
0w0 :: 73, ~tyd, Curtis Yarvin (sator)
|
|
0w0 :: 74, ~sup, Curtis Yarvin (sator)
|
|
0w0 :: 75, ~sem, ~boswed-nibnyd (fidelis)
|
|
0w0 :: 76, ~wyn, Curtis Yarvin (sator)
|
|
0w0 :: 77, ~rec, Curtis Yarvin (sator)
|
|
0w0 :: 78, ~meg, Curtis Yarvin (sator)
|
|
0w2L.tavpW.Lk4R-.elm7E.4KEqZ :: 79, ~net, ~hatteb-mitlyd (fidelis)
|
|
0w0 :: 80, ~sec, Curtis Yarvin (sator)
|
|
0w0 :: 81, ~mul, Curtis Yarvin (sator)
|
|
0w0 :: 82, ~nym, Curtis Yarvin (sator)
|
|
0w0 :: 83, ~tev, Curtis Yarvin (sator)
|
|
0w2x.~ldho.Oo7kE.QqNSx.XteFh :: 84, ~web, Ar Vicco (donum)
|
|
0w0 :: 85, ~sum, Curtis Yarvin (sator)
|
|
0w0 :: 86, ~mut, Curtis Yarvin (sator)
|
|
0w0 :: 87, ~nyx, Curtis Yarvin (sator)
|
|
0w30.UUr19.iBPlD.wfyJD.2CWPv :: 88, ~rex, Ben Davenport (angelus)
|
|
0w0 :: 89, ~teb, Curtis Yarvin (sator)
|
|
0w0 :: 90, ~fus, urbit.org (civitas)
|
|
0w0 :: 91, ~hep, urbit.org (civitas)
|
|
0w0 :: 92, ~ben, urbit.org (civitas)
|
|
0w0 :: 93, ~mus, urbit.org (civitas)
|
|
0w0 :: 94, ~wyx, urbit.org (civitas)
|
|
0w0 :: 95, ~sym, urbit.org (civitas)
|
|
0w0 :: 96, ~sel, urbit.org (civitas)
|
|
0w0 :: 97, ~ruc, urbit.org (civitas)
|
|
0w0 :: 98, ~dec, urbit.org (civitas)
|
|
0w1L.NQ-5f.ABF9R.kVwVJ.zRfn2 :: 99, ~wex, Pax Dickinson (donum)
|
|
0w0 :: 100, ~syr, urbit.org (civitas)
|
|
0w0 :: 101, ~wet, urbit.org (civitas)
|
|
0w0 :: 102, ~dyl, urbit.org (civitas)
|
|
0w0 :: 103, ~myn, urbit.org (civitas)
|
|
0w0 :: 104, ~mes, urbit.org (civitas)
|
|
0w0 :: 105, ~det, urbit.org (civitas)
|
|
0w0 :: 106, ~bet, urbit.org (civitas)
|
|
0w0 :: 107, ~bel, urbit.org (civitas)
|
|
0w0 :: 108, ~tux, Chen Zheng (angelus)
|
|
0w1D.JV9n0.9z~YK.yAWyi.c9~Lu :: 109, ~tug, Philip Monk (aestas)
|
|
0w0 :: 110, ~myr, urbit.org (civitas)
|
|
0w0 :: 111, ~pel, urbit.org (civitas)
|
|
0w0 :: 112, ~syp, urbit.org (civitas)
|
|
0w0 :: 113, ~ter, urbit.org (civitas)
|
|
0w0 :: 114, ~meb, urbit.org (civitas)
|
|
0w0 :: 115, ~set, urbit.org (civitas)
|
|
0w0 :: 116, ~dut, urbit.org (civitas)
|
|
0w0 :: 117, ~deg, urbit.org (civitas)
|
|
0w0 :: 118, ~tex, urbit.org (civitas)
|
|
0w0 :: 119, ~sur, urbit.org (civitas)
|
|
0w0 :: 120, ~fel, urbit.org (civitas)
|
|
0w0 :: 121, ~tud, urbit.org (civitas)
|
|
0w0 :: 122, ~nux, urbit.org (civitas)
|
|
0w0 :: 123, ~rux, urbit.org (civitas)
|
|
0w0 :: 124, ~ren, urbit.org (civitas)
|
|
0w0 :: 125, ~wyt, urbit.org (civitas)
|
|
0w0 :: 126, ~nub, urbit.org (civitas)
|
|
0w0 :: 127, ~med, urbit.org (civitas)
|
|
0w20.GGLXx.aqxaQ.w4Iob.wdmmr :: 128, ~lyt, Arthur Breitman (mercor)
|
|
0w0 :: 129, ~dus, urbit.org (civitas)
|
|
0w0 :: 130, ~neb, urbit.org (civitas)
|
|
0w0 :: 131, ~rum, urbit.org (civitas)
|
|
0w0 :: 132, ~tyn, urbit.org (civitas)
|
|
0w0 :: 133, ~seg, urbit.org (civitas)
|
|
0w0 :: 134, ~lyx, urbit.org (civitas)
|
|
0w0 :: 135, ~pun, urbit.org (civitas)
|
|
0w0 :: 136, ~res, urbit.org (civitas)
|
|
0w0 :: 137, ~red, urbit.org (civitas)
|
|
0w3J.15iJA.0pbNk.mZXyh.A~uKb :: 138, ~fun, Aaron Beckerman (fortuna)
|
|
0w0 :: 139, ~rev, urbit.org (civitas)
|
|
0w3m.Cqumo.ZC7-e.794A4.Bqhh8 :: 140, ~ref, Matt Brubeck (fortuna)
|
|
0w0 :: 141, ~mec, urbit.org (civitas)
|
|
0w0 :: 142, ~ted, urbit.org (civitas)
|
|
0w2d.GLlYg.-MwtO.ZCPBE.OqGB9 :: 143, ~rus, Stephen Burnham (donum)
|
|
0w0 :: 144, ~bex, urbit.org (civitas)
|
|
0w0 :: 145, ~leb, ~nosryl-tarpem (fidelis)
|
|
0w0 :: 146, ~dux, urbit.org (civitas)
|
|
0w0 :: 147, ~ryn, urbit.org (civitas)
|
|
0w0 :: 148, ~num, Tlon (gleba)
|
|
0w0 :: 149, ~pyx, ~racbes-solmun (fidelis)
|
|
0w2g.gLmg4.MtrHQ.A5VmH.WPk6G :: 150, ~ryg, Dan Haffey (fortuna)
|
|
0w0 :: 151, ~ryx, Tlon (gleba)
|
|
0w0 :: 152, ~fep, Tlon (gleba)
|
|
0w2j.T1u2s.BfXjV.ldOGR.aiZrQ :: 153, ~tyr, ~hobmed-hinrym (fidelis)
|
|
0w0 :: 154, ~tus, Tlon (gleba)
|
|
0w0 :: 155, ~tyc, Tlon (gleba)
|
|
0w0 :: 156, ~leg, Tlon (gleba)
|
|
0w0 :: 157, ~nem, Tlon (gleba)
|
|
0w0 :: 158, ~fer, Tlon (gleba)
|
|
0w0 :: 159, ~mer, Tlon (gleba)
|
|
0w0 :: 160, ~ten, Tlon (gleba)
|
|
0w0 :: 161, ~lus, Tlon (gleba)
|
|
0w0 :: 162, ~nus, Tlon (gleba)
|
|
0w0 :: 163, ~syl, Tlon (gleba)
|
|
0w0 :: 164, ~tec, Tlon (gleba)
|
|
0w0 :: 165, ~mex, Tlon (gleba)
|
|
0w0 :: 166, ~pub, Tlon (gleba)
|
|
0w0 :: 167, ~rym, Tlon (gleba)
|
|
0w0 :: 168, ~tuc, Tlon (gleba)
|
|
0w0 :: 169, ~fyl, Tlon (gleba)
|
|
0w0 :: 170, ~lep, Tlon (gleba)
|
|
0w0 :: 171, ~deb, Tlon (gleba)
|
|
0w0 :: 172, ~ber, Tlon (gleba)
|
|
0w0 :: 173, ~mug, Tlon (gleba)
|
|
0w0 :: 174, ~hut, Tlon (gleba)
|
|
0w0 :: 175, ~tun, Tlon (gleba)
|
|
0w0 :: 176, ~byl, Tlon (gleba)
|
|
0w0 :: 177, ~sud, Tlon (gleba)
|
|
0w0 :: 178, ~pem, Tlon (gleba)
|
|
0w0 :: 179, ~dev, Tlon (gleba)
|
|
0w0 :: 180, ~lur, Tlon (gleba)
|
|
0w0 :: 181, ~def, Tlon (gleba)
|
|
0w0 :: 182, ~bus, Tlon (gleba)
|
|
0w0 :: 183, ~bep, Tlon (gleba)
|
|
0w0 :: 184, ~run, Tlon (gleba)
|
|
0w0 :: 185, ~mel, Tlon (gleba)
|
|
0w0 :: 186, ~pex, Tlon (gleba)
|
|
0w0 :: 187, ~dyt, Tlon (gleba)
|
|
0w0 :: 188, ~byt, Tlon (gleba)
|
|
0w0 :: 189, ~typ, Tlon (gleba)
|
|
0w0 :: 190, ~lev, Tlon (gleba)
|
|
0w0 :: 191, ~myl, Tlon (gleba)
|
|
0w0 :: 192, ~wed, Tlon (gleba)
|
|
0w0 :: 193, ~duc, Tlon (gleba)
|
|
0w0 :: 194, ~fur, Tlon (gleba)
|
|
0w0 :: 195, ~fex, Tlon (gleba)
|
|
0w0 :: 196, ~nul, Tlon (gleba)
|
|
0w0 :: 197, ~luc, Tlon (gleba)
|
|
0w0 :: 198, ~len, Tlon (gleba)
|
|
0w0 :: 199, ~ner, Tlon (gleba)
|
|
0wv.aixe9.7gG2w.7cJiy.i3Mg8 :: 200, ~lex, Michael Hartl (donum)
|
|
0w0 :: 201, ~rup, Tlon (gleba)
|
|
0w0 :: 202, ~ned, Tlon (gleba)
|
|
0w0 :: 203, ~lec, Tlon (gleba)
|
|
0w0 :: 204, ~ryd, Tlon (gleba)
|
|
0w1U.n361n.FC3jj.9cX26.V1Wif :: 205, ~lyd, Adam Bliss (fortuna)
|
|
0w0 :: 206, ~fen, Tlon (gleba)
|
|
0w0 :: 207, ~wel, Tlon (gleba)
|
|
0w0 :: 208, ~nyd, Tlon (gleba)
|
|
0w0 :: 209, ~hus, Tlon (gleba)
|
|
0w0 :: 210, ~rel, Tlon (gleba)
|
|
0w0 :: 211, ~rud, Tlon (gleba)
|
|
0w0 :: 212, ~nes, Tlon (gleba)
|
|
0w16.~8NZV.VyMmf.4toMO.pui1R :: 213, ~hes, Alex Moskalyuk (angelus)
|
|
0w0 :: 214, ~fet, Tlon (gleba)
|
|
0w0 :: 215, ~des, Tlon (gleba)
|
|
0w0 :: 216, ~ret, Tlon (gleba)
|
|
0w0 :: 217, ~dun, Tlon (gleba)
|
|
0w0 :: 218, ~ler, Tlon (gleba)
|
|
0w10.w0AUz.QVdks.HCNvf.ja~TO :: 219, ~nyr, Ivan Matosevic (fortuna)
|
|
0w0 :: 220, ~seb, Tlon (gleba)
|
|
0w0 :: 221, ~hul, Tlon (gleba)
|
|
0w0 :: 222, ~ryl, Tlon (gleba)
|
|
0w0 :: 223, ~lud, Tlon (gleba)
|
|
0w0 :: 224, ~rem, Tlon (gleba)
|
|
0w0 :: 225, ~lys, Tlon (gleba)
|
|
0w3C.YXlEl.pFbYV.9pYWI.d7cla :: 226, ~fyn, Stephen Burnham (donum)
|
|
0w0 :: 227, ~wer, Tlon (gleba)
|
|
0w0 :: 228, ~ryc, Tlon (gleba)
|
|
0w0 :: 229, ~sug, Tlon (gleba)
|
|
0w0 :: 230, ~nys, Tlon (gleba)
|
|
0w0 :: 231, ~nyl, Tlon (gleba)
|
|
0w0 :: 232, ~lyn, Tlon (gleba)
|
|
0w0 :: 233, ~dyn, Tlon (gleba)
|
|
0w0 :: 234, ~dem, Tlon (gleba)
|
|
0w0 :: 235, ~lux, Mark Zavislak (angelus)
|
|
0w0 :: 236, ~fed, Tlon (gleba)
|
|
0w0 :: 237, ~sed, Tlon (gleba)
|
|
0w0 :: 238, ~bec, Tlon (gleba)
|
|
0w0 :: 239, ~mun, Tlon (gleba)
|
|
0w0 :: 240, ~lyr, Tlon (gleba)
|
|
0w0 :: 241, ~tes, Tlon (gleba)
|
|
0w0 :: 242, ~mud, ~difryt-dapdeg (fidelis)
|
|
0w4.yybWD.F1BgE.ynzlF.47neH :: 243, ~nyt, Byrne Hobart (mercor)
|
|
0w0 :: 244, ~byr, Tlon (gleba)
|
|
0w0 :: 245, ~sen, Tlon (gleba)
|
|
0w0 :: 246, ~weg, Tlon (gleba)
|
|
0w28.bRVMq.Oi3tM.zOCNV.j00Yq :: 247, ~fyr, Anton Dyudin (aestas)
|
|
0w0 :: 248, ~mur, Tlon (gleba)
|
|
0w0 :: 249, ~tel, Tlon (gleba)
|
|
0w0 :: 250, ~rep, Tlon (gleba)
|
|
0w0 :: 251, ~teg, Tlon (gleba)
|
|
0w0 :: 252, ~pec, Tlon (gleba)
|
|
0w0 :: 253, ~nel, Tlon (gleba)
|
|
0w0 :: 254, ~nev, Tlon (gleba)
|
|
0wY.a0HAU.7Lbkf.6V514.OsJBv :: 255, ~fes, John Burnham (donum)
|
|
==
|
|
--
|
|
::::::::::::::::::::::::::::::::::::::::::::::::::::::::
|
|
:: section 4aB, packet format ::
|
|
::
|
|
|%
|
|
++ bite :: packet to cake
|
|
|= pac=rock ^- cake
|
|
=+ [mag=(end 5 1 pac) bod=(rsh 5 1 pac)]
|
|
=+ :* vez=(end 0 3 mag) :: protocol version
|
|
chk=(cut 0 [3 20] mag) :: checksum
|
|
wix=(bex +((cut 0 [23 2] mag))) :: width of receiver
|
|
vix=(bex +((cut 0 [25 2] mag))) :: width of sender
|
|
tay=(cut 0 [27 5] mag) :: message type
|
|
==
|
|
?> =(1 vez)
|
|
?> =(chk (end 0 20 (mug bod)))
|
|
:+ [(end 3 wix bod) (cut 3 [wix vix] bod)]
|
|
(kins tay)
|
|
(rsh 3 (add wix vix) bod)
|
|
::
|
|
++ kins |=(tay=@ (snag tay `(list skin)`[%none %open %fast %full ~]))
|
|
++ ksin |=(sin=skin `@`?-(sin %none 0, %open 1, %fast 2, %full 3))
|
|
++ spit :: cake to packet
|
|
|= kec=cake ^- @
|
|
=+ wim=(met 3 p.p.kec)
|
|
=+ dum=(met 3 q.p.kec)
|
|
=+ yax=?:((lte wim 2) 0 ?:((lte wim 4) 1 ?:((lte wim 8) 2 3)))
|
|
=+ qax=?:((lte dum 2) 0 ?:((lte dum 4) 1 ?:((lte dum 8) 2 3)))
|
|
=+ wix=(bex +(yax))
|
|
=+ vix=(bex +(qax))
|
|
=+ bod=:(mix p.p.kec (lsh 3 wix q.p.kec) (lsh 3 (add wix vix) r.kec))
|
|
=+ tay=(ksin q.kec)
|
|
%+ mix
|
|
%+ can 0
|
|
:~ [3 1]
|
|
[20 (mug bod)]
|
|
[2 yax]
|
|
[2 qax]
|
|
[5 tay]
|
|
==
|
|
(lsh 5 1 bod)
|
|
--
|
|
::::::::::::::::::::::::::::::::::::::::::::::::::::::::
|
|
:: section 4aC, PKI engine ::
|
|
::
|
|
|%
|
|
++ go :: go
|
|
|_ ton=town :: ames state
|
|
++ as :: as:go
|
|
|_ [our=ship saf=sufi] :: per server
|
|
++ born :: born:as:go
|
|
|= [now=@da her=@p tic=@pG ges=gens pub=pass] :: register user
|
|
^- [(unit will) _+>]
|
|
?. =(our (sein her)) [~ +>.$]
|
|
=+ nes=sen
|
|
?. =(tic (end 6 1 (shaf %tick (mix her (shax sec:ex:q.nes)))))
|
|
[~ +>.$]
|
|
=+ rad=(~(get by hoc.saf) her)
|
|
?^ rad
|
|
?. ?=(^ lew.wod.u.rad)
|
|
$(hoc.saf (~(del by hoc.saf) her)) :: XX how can this be?
|
|
?. =(pub r.q.i.lew.wod.u.rad) [~ +>.$]
|
|
[[~ lew.wod.u.rad] +>.$]
|
|
=+ syp=[[0 [~ p.nes] her now] ges pub]
|
|
=+ ded=[(sign:as:q.nes *code (shaf %meld (sham syp))) syp fak.ton]
|
|
=+ wil=[ded law.saf]
|
|
?> =(wil (grip wil ~))
|
|
:- [~ wil]
|
|
+>.$(hoc.saf (~(put by hoc.saf) her [[~31337.1.1 ~ wil] ~ *clot]))
|
|
::
|
|
++ lax :: lax:as:go
|
|
|_ [her=ship dur=dore] :: per client
|
|
++ cluy :: cluy:lax:as:go
|
|
^- [p=life q=gens r=acru] :: client crypto
|
|
?~ lew.wod.dur !!
|
|
?. =(fak.ton r.i.lew.wod.dur) ~|([%client-wrong-fake her] !!)
|
|
:+ p.p.q.i.lew.wod.dur
|
|
q.q.i.lew.wod.dur
|
|
(haul r.q.i.lew.wod.dur)
|
|
::
|
|
++ clon
|
|
^- life
|
|
?~(lew.wod.dur 0 p.p.q.i.lew.wod.dur)
|
|
::
|
|
++ deng
|
|
|= law=will
|
|
%_(+> lew.wod.dur (grip law lew.wod.dur))
|
|
::
|
|
++ griz :: griz:lax:as:go
|
|
|= now=@da :: generate key for
|
|
^- [p=code q=_+>]
|
|
=+ key=(shas %enty (mix now any.ton))
|
|
:- key
|
|
%= +>.$
|
|
any.ton (shax (mix now any.ton))
|
|
heg.caq.dur (~(put by heg.caq.dur) (shaf %hand key) key)
|
|
==
|
|
::
|
|
++ pode :: pode:lax:as:go
|
|
|= now=@da :: timeout route
|
|
^+ +>
|
|
?: (lth her 256) +>
|
|
+>(lun.wod.dur ~)
|
|
::
|
|
++ kuch :: kuch:lax:as:go
|
|
|= had=hand :: hear key tag
|
|
^- (unit ,[code _+>])
|
|
=+ wey=(~(get by heg.caq.dur) had)
|
|
?^ wey
|
|
=+ key=u.wey
|
|
:+ ~ key
|
|
%= ..kuch
|
|
yed.caq.dur [~ had u.wey]
|
|
heg.caq.dur (~(del by heg.caq.dur) had)
|
|
qim.caq.dur (~(put by qim.caq.dur) had key)
|
|
==
|
|
=+ dyv=(~(get by qim.caq.dur) had)
|
|
?~ dyv ~
|
|
[~ u.dyv ..kuch]
|
|
::
|
|
++ wasc :: wasc:lax:as:go
|
|
|= key=code :: hear foreign code
|
|
^+ +>
|
|
=+ had=(shaf %hand key)
|
|
%_ ..wasc
|
|
yed.caq.dur [~ had key]
|
|
qim.caq.dur (~(put by qim.caq.dur) had key)
|
|
==
|
|
::
|
|
++ wast :: wast:lax:as:go
|
|
|= ryn=lane :: set route
|
|
^+ +>
|
|
%= +>
|
|
lun.wod.dur
|
|
?: ?=([%ix *] ryn)
|
|
?: ?| ?=(~ lun.wod.dur)
|
|
?=([%ix *] u.lun.wod.dur)
|
|
?& ?=([%if *] u.lun.wod.dur)
|
|
(gth p.ryn (add ~s10 p.u.lun.wod.dur))
|
|
==
|
|
==
|
|
[~ ryn]
|
|
lun.wod.dur
|
|
[~ ryn]
|
|
==
|
|
::
|
|
++ wist :: wist:lax:as:go
|
|
|= $: now=@da :: route via
|
|
waz=(list ,@p)
|
|
ryn=(unit lane)
|
|
pac=rock
|
|
==
|
|
^- (list boon)
|
|
?: =(our her) [[%ouzo *lane pac] ~]
|
|
?~ waz ~
|
|
=+ dyr=?:(=(her i.waz) dur (gur i.waz))
|
|
?. ?& !=(our i.waz)
|
|
?=(^ lun.wod.dyr)
|
|
==
|
|
$(waz t.waz)
|
|
:_ ?: ?=(%ix -.u.lun.wod.dyr)
|
|
$(waz t.waz)
|
|
~
|
|
:+ %ouzo u.lun.wod.dyr
|
|
?: &(=(i.waz her) =(~ ryn)) pac
|
|
=+ mal=(jam `meal`[%fore her ryn pac])
|
|
%- spit
|
|
^- cake
|
|
:* [our i.waz]
|
|
?~ yed.caq.dyr [%none mal]
|
|
:- %fast
|
|
%^ cat 7
|
|
p.u.yed.caq.dyr
|
|
(en:crua q.u.yed.caq.dyr mal)
|
|
==
|
|
::
|
|
++ xeno :: xeno:lax:as:go
|
|
^- (list ship) :: foreign canon
|
|
(saxo her)
|
|
::
|
|
++ xong :: xong:lax:as:go
|
|
^- (list ship) :: route unto
|
|
=+ [fro=xen too=xeno]
|
|
=+ ^= oot ^- (list ship)
|
|
=| oot=(list ship)
|
|
|- ^+ oot
|
|
?~ too ~
|
|
?: (lien fro |=(a=ship =(a i.too))) ~
|
|
[i.too $(too t.too)]
|
|
:: ~& [%xong-to [our her] (weld oot ?>(?=(^ fro) t.fro))]
|
|
(weld oot ?>(?=(^ fro) t.fro))
|
|
::
|
|
++ zuul :: zuul:lax:as:go
|
|
|= [now=@da ham=meal] :: encode message
|
|
^- [p=(list rock) q=_+>]
|
|
=< weft
|
|
|%
|
|
++ wasp :: null security
|
|
^-([p=skin q=@] [%none (jam ham)])
|
|
::
|
|
++ weft :: fragment message
|
|
^- [p=(list rock) q=_+>.$]
|
|
=^ gim ..weft wisp
|
|
:_ +>.$
|
|
^- (list rock)
|
|
=+ wit=(met 13 q.gim)
|
|
?< =(0 wit)
|
|
?: =(1 wit)
|
|
=+ yup=(spit [our her] p.gim q.gim)
|
|
[yup ~]
|
|
=+ ruv=(rip 13 q.gim)
|
|
=+ gom=(shaf %thug q.gim)
|
|
=+ inx=0
|
|
|- ^- (list rock)
|
|
?~ ruv ~
|
|
=+ ^= vie
|
|
%+ spit
|
|
[our her]
|
|
wasp(ham [%carp (ksin p.gim) inx wit gom i.ruv])
|
|
:- vie
|
|
$(ruv t.ruv, inx +(inx))
|
|
::
|
|
++ wisp :: generate message
|
|
^- [[p=skin q=@] q=_..wisp]
|
|
?: =(%carp -.ham)
|
|
[wasp ..wisp]
|
|
?: !=(~ yed.caq.dur)
|
|
?> ?=(^ yed.caq.dur)
|
|
:_ ..wisp
|
|
:- %fast
|
|
%^ cat 7
|
|
p.u.yed.caq.dur
|
|
(en:r:cluy q.u.yed.caq.dur (jam ham))
|
|
?: &(=(~ lew.wod.dur) |(=(%back -.ham) =(%buck -.ham)))
|
|
[wasp ..wisp]
|
|
=^ tuy +>.$
|
|
?:(=(~ lew.wod.dur) [*code +>.$] (griz now))
|
|
:_ ..wisp
|
|
=+ yig=sen
|
|
:: =+ bil=`will`(pare wyl.dur law.saf) :: XX not set
|
|
=+ bil=law.saf :: XX send whole will
|
|
=+ hom=(jam ham)
|
|
?: =(~ lew.wod.dur)
|
|
:- %open
|
|
%^ jam
|
|
[~ `life`p.yig]
|
|
bil
|
|
(sign:as:q.yig tuy hom)
|
|
:- %full
|
|
=+ cay=cluy
|
|
%^ jam
|
|
[`life`p.cay `life`p.yig]
|
|
bil
|
|
(seal:as:q.yig pub:ex:r.cay tuy hom)
|
|
-- :: --zuul:lax:as:go
|
|
-- :: --lax:as:go
|
|
::
|
|
++ gur :: default dore
|
|
|= her=ship
|
|
^- dore
|
|
=+ def=?.((lth her 256) ~ [~ %if ~2000.1.1 0 (mix her .0.0.1.0)])
|
|
[[~2100.1.1 def ~] ~ *clot]
|
|
::
|
|
++ myx :: dore by ship
|
|
|= her=ship
|
|
^+ lax
|
|
=+ fod=(~(get by hoc.saf) her)
|
|
~(. lax [her ?~(fod (gur her) u.fod)])
|
|
::
|
|
++ nux :: install dore
|
|
|= new=_lax
|
|
^+ +>
|
|
+>(hoc.saf (~(put by hoc.saf) her.new dur.new))
|
|
::
|
|
++ sen :: current crypto
|
|
^- [p=life q=acru]
|
|
?~(val.saf !! [p.i.val.saf r.i.val.saf])
|
|
::
|
|
++ sev :: crypto by life
|
|
|= mar=life
|
|
^- [p=? q=acru]
|
|
?~ val.saf !!
|
|
?: =(mar p.i.val.saf)
|
|
[& r.i.val.saf]
|
|
?> (lth mar p.i.val.saf)
|
|
:- |
|
|
|- ^- acru
|
|
?> ?=(^ t.val.saf)
|
|
?: =(mar p.i.t.val.saf)
|
|
r.i.t.val.saf
|
|
$(t.val.saf t.t.val.saf)
|
|
::
|
|
++ sex :: export secrets
|
|
|- ^- mace
|
|
?~ val.saf ~
|
|
:- [p.i.val.saf sec:ex:r.i.val.saf]
|
|
$(val.saf t.val.saf)
|
|
::
|
|
++ xen :: canon
|
|
|- ^- (list ship)
|
|
(saxo our)
|
|
::
|
|
++ yew :: best will for
|
|
|= her=ship
|
|
^- will
|
|
=+ gel=(~(get by hoc.saf) her)
|
|
?^ gel
|
|
lew.wod.u.gel
|
|
?:((lth her 256) ~ $(her (sein her)))
|
|
-- :: --as:go
|
|
::
|
|
++ ha !: :: adopt new license
|
|
|= [our=ship mac=mace wil=will]
|
|
^- town
|
|
?> !=(~ mac)
|
|
?> ?=(^ wil)
|
|
:: ?> =(our r.p.q.i.wil)
|
|
?> =(wil (grip wil ~))
|
|
?> (real mac wil)
|
|
%_ ton
|
|
fak r.i.wil
|
|
urb
|
|
%+ ~(put by urb.ton)
|
|
our
|
|
:* %- flop
|
|
|- ^- (list ship)
|
|
?:((lth our 256) ~ =+(seg=(sein our) [seg $(our seg)]))
|
|
::
|
|
(turn mac |=([p=life q=ring] [p q (weur q)]))
|
|
wil
|
|
~
|
|
~
|
|
==
|
|
==
|
|
::
|
|
++ su :: install safe
|
|
|= new=_as
|
|
^- town
|
|
ton(urb (~(put by urb.ton) our.new saf.new))
|
|
::
|
|
++ ti :: expire by time
|
|
|= [now=@da]
|
|
^- town
|
|
!!
|
|
::
|
|
++ us :: produce safe
|
|
|= our=ship
|
|
^- (unit ,_as)
|
|
=+ goh=(~(get by urb.ton) our)
|
|
?~ goh ~
|
|
[~ ~(. as [our u.goh])]
|
|
-- :: --go
|
|
--
|
|
::::::::::::::::::::::::::::::::::::::::::::::::::::::::
|
|
:: section 4aF, packet pump ::
|
|
|%
|
|
++ pu :: packet pump
|
|
|_ shed
|
|
++ abet +<
|
|
++ ahoy :: ahoy:pu
|
|
^+ . :: initialize
|
|
%_ .
|
|
rtt ~s1
|
|
rto ~s4
|
|
rtn ~
|
|
rue ~
|
|
nus 0
|
|
nif 0
|
|
nep 0
|
|
caw 2
|
|
cag 64
|
|
diq ~
|
|
pyz ~
|
|
puq ~
|
|
==
|
|
::
|
|
++ bick :: bick:pu
|
|
|= [now=@da fap=flap] :: ack by hash
|
|
^- [[p=(unit soup) q=(list rock)] _+>]
|
|
=+ sun=(~(get by diq) fap)
|
|
?~ sun
|
|
:: ~& [%bick-none `@p`(mug fap)] :: not a real error
|
|
[[~ ~] +>.$]
|
|
:: ~& [%bick-good `@p`(mug fap) u.sun]
|
|
=. diq (~(del by diq) fap)
|
|
=^ gub +>.$ (bock now u.sun)
|
|
=^ yop +>.$ (harv now)
|
|
[[gub yop] +>.$]
|
|
::
|
|
++ bilk :: bilk:pu
|
|
|= now=@da :: inbound packet
|
|
^+ +>
|
|
=+ trt=(mul 2 rtt)
|
|
%= +>.$
|
|
rue [~ now]
|
|
rto trt
|
|
rtn ?~(puq ~ [~ (add now trt)])
|
|
==
|
|
::
|
|
++ boom :: boom:pu
|
|
|= now=@da ^- ? :: address timeout
|
|
|(?=(~ rue) (gte (sub now u.rue) ~m1))
|
|
::
|
|
++ bust :: bust:pu
|
|
^- ? :: not responding
|
|
&(?=(^ rtn) (gte rto ~s16))
|
|
::
|
|
++ bike :: bike:pu
|
|
^+ . :: check stats
|
|
?> .= nif
|
|
|- ^- @
|
|
?~ puq 0
|
|
:(add !liv.q.n.puq $(puq l.puq) $(puq r.puq))
|
|
.
|
|
::
|
|
++ beet :: beet:pu
|
|
^+ . :: advance unacked
|
|
=- +(nep ?~(foh nus u.foh))
|
|
^= foh
|
|
|- ^- (unit ,@ud)
|
|
?~ puq ~
|
|
?: (lte p.n.puq nep) $(puq l.puq)
|
|
=+ rig=$(puq r.puq)
|
|
?^(rig rig [~ p.n.puq])
|
|
::
|
|
++ bine :: bine:pu
|
|
|= [now=@da num=@ud] :: apply ack
|
|
^- [(unit soup) _+>]
|
|
?~ puq !!
|
|
?. =(num p.n.puq)
|
|
?: (gth num p.n.puq)
|
|
=+ lef=$(puq l.puq)
|
|
[-.lef +.lef(puq [n.puq puq.lef r.puq])]
|
|
=+ rig=$(puq r.puq)
|
|
[-.rig +.rig(puq [n.puq l.puq puq.rig])]
|
|
=: rtt ?. &(liv.q.n.puq =(1 nux.q.n.puq)) rtt
|
|
=+ gap=(sub now lys.q.n.puq)
|
|
:: ~& [%bock-trip num (div gap (div ~s1 1.000))]
|
|
(div (add (mul 2 rtt) gap) 3)
|
|
nif (sub nif !liv.q.n.puq)
|
|
==
|
|
=+ lez=(dec (need (~(get by pyz) gom.q.n.puq)))
|
|
=^ gub pyz
|
|
?: =(0 lez)
|
|
[[~ gom.q.n.puq] (~(del by pyz) gom.q.n.puq)]
|
|
[~ (~(put by pyz) gom.q.n.puq lez)]
|
|
:- gub
|
|
+>.$(puq ~(nap to puq))
|
|
::
|
|
++ bock :: bock:pu
|
|
|= [now=@da num=@ud] :: ack by sequence
|
|
^- [(unit soup) _+>]
|
|
=^ gym +> (bine now num)
|
|
:- gym
|
|
?: (gth num nep)
|
|
=+ cam=(max 2 (div caw 2))
|
|
:: ~& [%bock-hole num nep cam]
|
|
beet:(wept(nep num, cag cam, caw cam) nep num)
|
|
=. caw ?: (lth caw cag) +(caw)
|
|
(add caw !=(0 (mod (mug now) caw)))
|
|
?: =(num nep)
|
|
:: ~& [%bock-fine num nif caw cag]
|
|
beet
|
|
:: ~& [%bock-fill num nif caw cag]
|
|
+>.$
|
|
::
|
|
++ harv :: harv:pu
|
|
|= now=@da :: harvest queue
|
|
^- [(list rock) _+>]
|
|
?: =(~ puq) [~ +>(rtn ~)]
|
|
?. (gth caw nif) [~ +>]
|
|
=+ wid=(sub caw nif)
|
|
=| rub=(list rock)
|
|
=< abet =< apse
|
|
|%
|
|
++ abet
|
|
?~ rub [~ +>.$]
|
|
[(flop rub) +>.$(rtn [~ (add rto now)])]
|
|
::
|
|
++ apse
|
|
^+ .
|
|
?~ puq .
|
|
?: =(0 wid) .
|
|
=> rigt =< left
|
|
?> ?=(^ puq)
|
|
?: =(0 wid) .
|
|
?. =(| liv.q.n.puq) .
|
|
:: ~& [%harv nux.q.n.puq p.n.puq]
|
|
%_ .
|
|
wid (dec wid)
|
|
rub [pac.q.n.puq rub]
|
|
nif +(nif)
|
|
liv.q.n.puq &
|
|
nux.q.n.puq +(nux.q.n.puq)
|
|
lys.q.n.puq now
|
|
==
|
|
::
|
|
++ left
|
|
?> ?=(^ puq)
|
|
^+(. =+(lef=apse(puq l.puq) lef(puq [n.puq puq.lef r.puq])))
|
|
++ rigt
|
|
?> ?=(^ puq)
|
|
^+(. =+(rig=apse(puq r.puq) rig(puq [n.puq l.puq puq.rig])))
|
|
--
|
|
::
|
|
++ wack :: wack:pu
|
|
|= now=@da :: wakeup (timeout)
|
|
^- [(list rock) _+>]
|
|
?. &(!=(~ rtn) ?>(?=(^ rtn) (gte now u.rtn))) [~ +>]
|
|
:: ~& [%slow (div rto (div ~s1 1.000))]
|
|
=. +> (wept 0 nus)
|
|
?> =(0 nif)
|
|
=+ oub=(gte rto ~s16)
|
|
=: caw 2
|
|
rto ;: min
|
|
(mul 2 rto)
|
|
~m2
|
|
(mul ~s16 ?~(rue 1 +((div (sub now u.rue) ~d1))))
|
|
==
|
|
==
|
|
(harv now)
|
|
::
|
|
++ wept :: wept:pu
|
|
|= [fip=@ud lap=@ud] :: fip thru lap-1
|
|
=< abet =< apse
|
|
|%
|
|
++ abet +>.$
|
|
++ apse
|
|
^+ .
|
|
?~ puq .
|
|
?: (lth p.n.puq fip) ?~(l.puq . left)
|
|
?: (gte p.n.puq lap) ?~(r.puq . rigt)
|
|
=> rigt =< left
|
|
?> ?=(^ puq)
|
|
?.(liv.q.n.puq . .(nif (dec nif), liv.q.n.puq |))
|
|
::
|
|
++ left
|
|
?> ?=(^ puq)
|
|
^+(. =+(lef=apse(puq l.puq) lef(puq [n.puq puq.lef r.puq])))
|
|
++ rigt
|
|
?> ?=(^ puq)
|
|
^+(. =+(rig=apse(puq r.puq) rig(puq [n.puq l.puq puq.rig])))
|
|
--
|
|
::
|
|
++ whap :: whap:pu
|
|
|= [now=@da gom=soup wyv=(list rock)] :: send a message
|
|
^- [(list rock) _+>]
|
|
=. pyz (~(put by pyz) gom (lent wyv))
|
|
=. +>
|
|
|- ^+ +>.^$
|
|
?~ wyv +>.^$
|
|
%= $
|
|
wyv t.wyv
|
|
nus +(nus)
|
|
diq (~(put by diq) (shaf %flap i.wyv) nus)
|
|
puq (~(put to puq) [nus `soul`[gom 0 | ~2000.1.1 i.wyv]])
|
|
==
|
|
(harv now)
|
|
--
|
|
--
|
|
::::::::::::::::::::::::::::::::::::::::::::::::::::::::
|
|
:: section 4aG, protocol engine ::
|
|
::
|
|
|%
|
|
++ am :: am
|
|
|_ [now=@da fox=fort] :: protocol engine
|
|
++ boot :: boot:am
|
|
^- fort :: restore from noun
|
|
%= fox
|
|
urb.ton
|
|
%- ~(gas by *(map ship sufi))
|
|
%+ turn
|
|
(~(tap by urb.ton.fox) ~)
|
|
|= [p=ship q=sufi] ^- [p=ship q=sufi]
|
|
:- p
|
|
%= q
|
|
val
|
|
(turn val.q |=([p=life q=ring r=acru] [p q (weur q)]))
|
|
==
|
|
==
|
|
++ come :: come:am
|
|
|= [ges=(unit ,@t) wid=@ bur=@ fak=?] :: instantiate pawn
|
|
^- [p=[p=ship q=@uvG] q=fort]
|
|
=+ loy=(bruw wid bur)
|
|
=+ rig=sec:ex:loy
|
|
=+ our=`@p`fig:ex:loy
|
|
=+ syp=[[0 ~ our now] [%en %pawn ges] pub:ex:loy]
|
|
:- [our pac:ex:loy]
|
|
%_ fox
|
|
ton
|
|
%^ ~(ha go ton.fox)
|
|
our
|
|
`mace`[[0 rig] ~]
|
|
`will`[[(sign:as:loy *@ (shaf %self (sham syp))) syp fak] ~]
|
|
fak.ton
|
|
fak
|
|
==
|
|
::
|
|
++ czar !: :: czar:am
|
|
|= [our=ship ger=@uw fak=?] :: instantiate emperor
|
|
^- [p=(list boon) q=fort]
|
|
=+ loy=?:(fak (bruw 2.048 our) (bruw 2.048 ger)) :: fake uses carrier #
|
|
=+ fim==(fig:ex:loy (zeno our))
|
|
?: &(!fak !fim) !! :: not fake & bad fig
|
|
=+ mac=`mace`[[0 sec:ex:loy] ~]
|
|
=+ syp=`step`[`bray`[0 ~ our now] [%en %czar ~] pub:ex:loy]
|
|
=+ ded=`deed`[(sign:as:loy *@ (shaf %self (sham syp))) syp fak]
|
|
=+ buq=`buck`[mac [ded ~]]
|
|
=: ton.fox (~(ha go ton.fox) our buq)
|
|
zac.fox (~(put by zac.fox) our *corn)
|
|
fak.ton.fox fak
|
|
==
|
|
[[[%beer our pac:ex:loy] ~] fox]
|
|
::
|
|
++ gnaw :: gnaw:am
|
|
|= [kay=cape ryn=lane pac=rock] :: process packet
|
|
^- [p=(list boon) q=fort]
|
|
?. =(1 (end 0 3 pac)) [~ fox]
|
|
=+ kec=(bite pac)
|
|
?: (goop p.p.kec) [~ fox]
|
|
?. (~(has by urb.ton.fox) q.p.kec)
|
|
[~ fox]
|
|
=< zork
|
|
=< zank
|
|
:: ~& [%hear p.p.kec ryn `@p`(mug (shaf %flap pac))]
|
|
%- ~(chew la:(ho:(um q.p.kec) p.p.kec) kay ryn %none (shaf %flap pac))
|
|
[q.kec r.kec]
|
|
::
|
|
++ goop
|
|
|= him=ship
|
|
|
|
|
::
|
|
++ hall :: hall:am
|
|
^- (list sock) :: all sockets
|
|
=| sox=(list sock) :: XX hideous
|
|
|- ^+ sox
|
|
?~ zac.fox sox
|
|
=. sox $(zac.fox l.zac.fox)
|
|
=. sox $(zac.fox r.zac.fox)
|
|
|- ^+ sox
|
|
?~ wab.q.n.zac.fox sox
|
|
=. sox $(wab.q.n.zac.fox l.wab.q.n.zac.fox)
|
|
=. sox $(wab.q.n.zac.fox r.wab.q.n.zac.fox)
|
|
[[p.n.zac.fox p.n.wab.q.n.zac.fox] sox]
|
|
::
|
|
++ have :: have:am
|
|
|= [our=ship buq=buck] :: acquire license
|
|
^- [p=(list boon) q=fort]
|
|
=: ton.fox (~(ha go ton.fox) our buq)
|
|
zac.fox (~(put by zac.fox) our *corn)
|
|
==
|
|
[[[%beer our pac:ex:q:sen:(need (~(us go ton.fox) our))] ~] fox]
|
|
::
|
|
++ kick :: kick:am
|
|
|= hen=duct :: refresh net
|
|
=+ aks=(turn (~(tap by urb.ton.fox) ~) |=([p=ship q=sufi] p))
|
|
|- ^- [p=(list boon) q=fort]
|
|
?~ aks [~ fox]
|
|
=^ buz fox zork:(kick:(um i.aks) hen)
|
|
=^ biz fox $(aks t.aks)
|
|
[(weld p.buz p.biz) fox]
|
|
::
|
|
++ rack :: rack:am
|
|
|= [soq=sock cha=path cop=coop] :: e2e ack
|
|
=+ oh=(ho:(um p.soq) q.soq)
|
|
=^ gud oh (cook:oh cop cha ~)
|
|
?. gud oh
|
|
(cans:oh cha)
|
|
::
|
|
++ wake :: wake:am
|
|
|= hen=duct :: harvest packets
|
|
^- [p=(list boon) q=fort]
|
|
=+ sox=hall
|
|
=| bin=(list boon)
|
|
|- ^- [p=(list boon) q=fort]
|
|
?~ sox
|
|
=^ ban fox (kick hen)
|
|
[(weld bin p.ban) fox]
|
|
=^ bun fox zork:zank:thaw:(ho:(um p.i.sox) q.i.sox)
|
|
$(sox t.sox, bin (weld p.bun bin))
|
|
::
|
|
++ wise :: wise:am
|
|
|= [soq=sock hen=duct cha=path val=* ete=?] :: send a statement
|
|
^- [p=(list boon) q=fort]
|
|
zork:zank:(wool:(ho:(um p.soq) q.soq) hen cha val ete)
|
|
::
|
|
++ um :: per server
|
|
|= our=ship
|
|
=+ gus=(need (~(us go ton.fox) our))
|
|
=+ ^= weg ^- corn
|
|
=+ weg=(~(get by zac.fox) our)
|
|
?^(weg u.weg *corn)
|
|
=| bin=(list boon)
|
|
|%
|
|
++ ho :: ho:um:am
|
|
|= her=ship :: per friend
|
|
=+ diz=(myx:gus her)
|
|
=+ bah=(~(get by wab.weg) her)
|
|
=+ puz=?~(bah ahoy:pu %*(. pu +< sop.u.bah))
|
|
=> .(bah `bath`?~(bah [abet:puz ~ ~] u.bah))
|
|
|%
|
|
++ busk :: busk:ho:um:am
|
|
|= [waz=(list ship) pax=(list rock)] :: send packets
|
|
%_ +>
|
|
bin
|
|
|- ^+ bin
|
|
?~ pax bin
|
|
$(pax t.pax, bin (weld (flop (wist:diz now waz ~ i.pax)) bin))
|
|
==
|
|
::
|
|
++ cans :: cans:ho:um:am
|
|
|= cha=path
|
|
=+ rum=(need (~(get by raz.bah) cha))
|
|
=. rum
|
|
%= rum
|
|
did +(did.rum)
|
|
mis (~(del by mis.rum) did.rum)
|
|
==
|
|
(coat cha rum)
|
|
::
|
|
++ coat :: coat:ho:um:am
|
|
|= [cha=path rum=race] :: update input race
|
|
^+ +>
|
|
=+ cun=(~(get by mis.rum) did.rum)
|
|
?~ cun
|
|
+>.$(raz.bah (~(put by raz.bah) cha rum))
|
|
?. =(%good p.u.cun) +>.$
|
|
?> ?=(^ s.u.cun)
|
|
%= +>.$
|
|
raz.bah (~(put by raz.bah) cha rum(dod |))
|
|
bin
|
|
:_ bin
|
|
:^ %mulk
|
|
[our her]
|
|
`soap`[[p:sen:gus clon:diz] cha did.rum]
|
|
u.s.u.cun
|
|
==
|
|
::
|
|
++ cook :: cook:ho:um:am
|
|
|= [cop=coop cha=path ram=(unit ,[ryn=lane dam=flap])]
|
|
^- [gud=? con=_+>] :: acknowledgment
|
|
:: ~& [%cook cop num cha ram]
|
|
=+ rum=(need (~(get by raz.bah) cha))
|
|
=+ lat=(~(get by mis.rum) did.rum)
|
|
?: &(?=(~ lat) ?=(~ ram))
|
|
~& %ack-late-or-redundant
|
|
[%| +>.$]
|
|
:- %&
|
|
=+ ^- [ryn=lane dam=flap]
|
|
?^ ram [ryn.u.ram dam.u.ram]
|
|
?< ?=(~ lat)
|
|
[q r]:u.lat
|
|
=. raz.bah
|
|
?^ ram raz.bah
|
|
%+ ~(put by raz.bah) cha
|
|
rum(dod &, bum ?~(cop bum.rum (~(put by bum.rum) did.rum u.cop)))
|
|
=^ roc diz (zuul:diz now [%buck cop dam ~s0])
|
|
(busk(diz (wast:diz ryn)) xong:diz roc)
|
|
::
|
|
++ done :: done:ho:um:am
|
|
|= [cha=path num=@ud] :: complete outgoing
|
|
^- [(unit duct) _+>]
|
|
=+ rol=(need (~(get by ryl.bah) cha))
|
|
=+ rix=(~(get by san.rol) num)
|
|
?~ rix [~ +>.$]
|
|
:- rix
|
|
%_ +>.$
|
|
ryl.bah
|
|
(~(put by ryl.bah) cha rol(san (~(del by san.rol) num)))
|
|
==
|
|
::
|
|
++ la :: la:ho:um:am
|
|
|_ [kay=cape ryn=lane aut=skin dam=flap] :: per packet
|
|
::
|
|
++ chew :: chew:la:ho:um:am
|
|
|= [sin=skin msg=@] :: receive
|
|
^+ +>
|
|
=< apse
|
|
|%
|
|
++ apse
|
|
^+ +>.$
|
|
=+ oub=bust:puz
|
|
=+ neg==(~ yed.caq.dur.diz)
|
|
=. +>.$ east
|
|
=+ eng==(~ yed.caq.dur.diz)
|
|
=+ bou=bust:puz
|
|
=. bin
|
|
?. &(oub !bou) bin
|
|
:_(bin [%wine [our her] " is ok"])
|
|
=. bin
|
|
?. &(neg !eng) bin
|
|
:_(bin [%wine [our her] " is your neighbor"])
|
|
+>.$
|
|
::
|
|
++ east
|
|
^+ +>.$
|
|
?- sin
|
|
%none
|
|
:: ~& %chew-none
|
|
=. puz (bilk:puz now)
|
|
(chow ((hard meal) (cue msg)))
|
|
::
|
|
%fast
|
|
:: ~& %chew-fast
|
|
=+ [mag=`hand`(end 7 1 msg) bod=(rsh 7 1 msg)]
|
|
=+ dey=(kuch:diz mag)
|
|
?~ dey
|
|
:: ~& [%bad-key her mag]
|
|
+>.$ :: ignore unknown key
|
|
=. puz (bilk:puz now)
|
|
=^ key diz u.dey
|
|
(chow(aut sin) ((hard meal) (cue (dy:q:sen:gus key bod))))
|
|
::
|
|
%full
|
|
:: ~& %chew-full
|
|
=+ mex=((hard ,[p=[p=life q=life] q=will r=@]) (cue msg))
|
|
=. diz (deng:diz q.mex)
|
|
=+ wug=cluy:diz
|
|
?> =(q.p.mex p.wug)
|
|
=+ gey=(sev:gus p.p.mex)
|
|
=+ mes=(need (tear:as:q.gey pub:ex:r.wug r.mex))
|
|
=. diz (wasc:diz p.mes)
|
|
=. puz (bilk:puz now)
|
|
(west(msg q.mes))
|
|
::
|
|
%open
|
|
:: ~& %chew-open
|
|
=+ mex=((hard ,[p=[~ q=life] q=will r=@]) (cue msg))
|
|
=. diz (deng:diz q.mex)
|
|
=+ wug=cluy:diz
|
|
?> =(q.p.mex p.wug)
|
|
=+ mes=(need (sure:as:r.wug *code r.mex))
|
|
=. puz (bilk:puz now)
|
|
(west(msg mes))
|
|
==
|
|
++ west
|
|
|= ~
|
|
=+ vib=(cue msg)
|
|
=+ mal=(meal vib)
|
|
?. =(mal vib)
|
|
~& [%bad-meal her]
|
|
+>.^$
|
|
(chow(aut sin) mal)
|
|
--
|
|
::
|
|
++ chow :: chow:la:ho:um:am
|
|
|= fud=meal :: interpret meal
|
|
^+ +>
|
|
=. diz ?:(=(%none aut) diz (wast:diz ryn))
|
|
(dine fud)
|
|
::
|
|
++ cock :: cock:la:ho:um:am
|
|
^+ . :: acknowledgment
|
|
:: ~& [%back kay dam]
|
|
=^ pax diz (zuul:diz now [%back kay dam ~s0])
|
|
+(+> (busk(diz (wast:diz ryn)) xong:diz pax))
|
|
::
|
|
++ coot :: coot:la:ho:um:am
|
|
|= [cha=path rum=race] :: update input race
|
|
^+ +>
|
|
=+ cun=(~(get by mis.rum) did.rum)
|
|
?~ cun
|
|
+>.$(raz.bah (~(put by raz.bah) cha rum))
|
|
=. +>.$ cock(kay p.u.cun, dam r.u.cun)
|
|
=. +>.$ ?. =(%good p.u.cun) +>.$
|
|
?> ?=(^ s.u.cun)
|
|
%- emit
|
|
^- boon
|
|
:^ %milk
|
|
[our her]
|
|
`soap`[[p:sen:gus clon:diz] cha did.rum]
|
|
u.s.u.cun
|
|
%= $
|
|
mis.rum (~(del by mis.rum) did.rum)
|
|
did.rum +(did.rum)
|
|
==
|
|
::
|
|
++ dear :: dear:la:ho:um:am
|
|
|= [cha=path num=@ud dut=(unit)] :: interpret message
|
|
^+ +>
|
|
=+ ^= rum ^- race
|
|
=+ rum=(~(get by raz.bah) cha)
|
|
?~(rum *race u.rum)
|
|
?. (gte num did.rum)
|
|
cock :: always ack a dup
|
|
(coot cha rum(mis (~(put by mis.rum) num [kay ryn dam dut])))
|
|
::
|
|
++ deer :: deer:la:ho:um:am
|
|
|= [cha=path num=@ud dut=(unit)] :: interpret message
|
|
^+ +>
|
|
=+ rum=(fall (~(get by raz.bah) cha) *race)
|
|
%= +>.$
|
|
+>
|
|
?. (gte num did.rum) :: always ack a dup
|
|
:: ~& [%deer-1 num]
|
|
con:(cook (~(get by bum.rum) num) cha ~ ryn dam)
|
|
?: dod.rum
|
|
:: ~& [%deer-2 num]
|
|
(coat cha rum(mis (~(put by mis.rum) num [kay ryn dam dut])))
|
|
:: ~& [%deer-3 num]
|
|
%= +>.+>.$
|
|
raz.bah
|
|
%+ ~(put by raz.bah) cha
|
|
rum(mis (~(put by mis.rum) num [kay ryn dam dut]))
|
|
==
|
|
==
|
|
::
|
|
++ dine :: dine:la:ho:um:am
|
|
|= fud=meal :: interpret meal
|
|
^+ +>
|
|
?- -.fud
|
|
%back
|
|
=. +> ?.(=(%full aut) +> cock) :: finish key exch
|
|
+>(..la (tuck p.fud q.fud r.fud))
|
|
::
|
|
%buck
|
|
=. +> ?.(=(%full aut) +> cock) :: finish key exch
|
|
+>(..la (tock p.fud q.fud r.fud))
|
|
::
|
|
%bond
|
|
:: ~& [%bond q.fud r.fud]
|
|
?> =(p:sen:gus p.fud)
|
|
(dear q.fud r.fud ?-(kay %dead ~, %good [~ s.fud]))
|
|
::
|
|
%bund
|
|
:: ~& [%bund q.fud r.fud]
|
|
?> =(p:sen:gus p.fud)
|
|
(deer q.fud r.fud ?-(kay %dead ~, %good [~ s.fud]))
|
|
::
|
|
%carp
|
|
=+ zol=(~(get by olz.weg) s.fud)
|
|
?^ zol cock(kay u.zol)
|
|
=^ neb nys.weg
|
|
=+ neb=(~(get by nys.weg) s.fud)
|
|
?^ neb [u.neb nys.weg]
|
|
=+ neb=`bait`[(kins p.fud) 0 r.fud ~]
|
|
[neb (~(put by nys.weg) s.fud neb)]
|
|
?> (lth q.fud p.r.neb)
|
|
?> =((kins p.fud) p.neb)
|
|
?> =(r.fud p.r.neb)
|
|
=+ doy=`(unit ,@)`(~(get by q.r.neb) q.fud)
|
|
?^ doy cock
|
|
=> ^+ . %= .
|
|
q.r.neb (~(put by q.r.neb) q.fud t.fud)
|
|
q.neb +(q.neb)
|
|
==
|
|
:: ~& [%carp q.fud s.fud q.neb p.r.neb]
|
|
?: =(q.neb p.r.neb)
|
|
=: nys.weg (~(del by nys.weg) s.fud)
|
|
olz.weg (~(put by olz.weg) s.fud kay)
|
|
==
|
|
(golf p.neb r.neb)
|
|
=. +>.$ cock
|
|
+>.$(nys.weg (~(put by nys.weg) s.fud neb))
|
|
::
|
|
%fore
|
|
=+ ^= lyn ^- lane
|
|
?~ q.fud ryn
|
|
?. ?=(%if -.u.q.fud) u.q.fud
|
|
[%ix +.u.q.fud]
|
|
:: u.q.fud
|
|
?: =(our p.fud)
|
|
(emit %mead lyn r.fud)
|
|
=+ zid=(myx:gus p.fud)
|
|
(emir (wist:zid now xong:zid [~ lyn] r.fud))
|
|
==
|
|
::
|
|
++ emir :: emir:la:ho:um:am
|
|
|= ben=(list boon) :: emit boons
|
|
^+ +>
|
|
?~(ben +> $(ben t.ben, bin [i.ben bin]))
|
|
::
|
|
++ emit :: emit:la:ho:um:am
|
|
|= bun=boon :: emit a boon
|
|
+>(bin [bun bin])
|
|
::
|
|
++ golf :: golf:la:ho:um:am
|
|
|= [sin=skin duv=dove] :: assemble fragments
|
|
^+ +>
|
|
%+ chew sin
|
|
=+ [nix=0 rax=*(list ,@)]
|
|
|- ^- @
|
|
?: =(p.duv nix)
|
|
(can 13 (turn (flop rax) |=(a=@ [1 a])))
|
|
$(nix +(nix), rax [(need (~(get by q.duv) nix)) rax])
|
|
-- :: --la:ho:um:am
|
|
::
|
|
++ pong :: pong:ho:um:am
|
|
|= hen=duct :: test connection
|
|
^+ +>
|
|
?. ?& =(~ puq.puz)
|
|
?| bust:puz
|
|
?=(~ rue.puz)
|
|
(gth now (add ~s32 u.rue.puz))
|
|
(lth u.rue.puz hop.fox)
|
|
==
|
|
==
|
|
+>.$
|
|
(wool [/a hen] /q/pi ~ |)
|
|
::
|
|
++ thaw :: thaw:ho:um:am
|
|
^+ . :: wakeup bomb
|
|
=+ oub=bust:puz
|
|
=^ yem puz (wack:puz now)
|
|
=+ bou=bust:puz
|
|
=. bin
|
|
?. &(bou !oub) bin
|
|
:_(bin [%wine [our her] " not responding still trying"])
|
|
=. diz ?:((boom:puz now) (pode:diz now) diz)
|
|
(busk xong:diz yem)
|
|
::
|
|
++ tock :: tock:ho:um:am
|
|
|= [cop=coop fap=flap cot=@dr] :: e2e ack by hash
|
|
^+ +>
|
|
=^ yoh puz (bick:puz now fap)
|
|
=. +>.$
|
|
?~ p.yoh +>.$
|
|
=^ hud +>.$
|
|
(done p.u.p.yoh q.u.p.yoh)
|
|
?~ hud +>.$
|
|
%= +>.$
|
|
bin
|
|
:_ bin
|
|
`boon`[%cake [our her] [[p:sen:gus clon:diz] u.p.yoh] cop u.hud]
|
|
==
|
|
(busk xong:diz q.yoh)
|
|
::
|
|
++ tuck :: tuck:ho:um:am
|
|
|= [kay=cape fap=flap cot=@dr] :: ack by hash
|
|
^+ +>
|
|
=^ yoh puz (bick:puz now fap)
|
|
=. +>.$
|
|
?~ p.yoh +>.$
|
|
=^ hud +>.$
|
|
(done p.u.p.yoh q.u.p.yoh)
|
|
?~ hud +>.$
|
|
%= +>.$
|
|
bin
|
|
:_ bin
|
|
`boon`[%coke [our her] [[p:sen:gus clon:diz] u.p.yoh] kay u.hud]
|
|
==
|
|
(busk xong:diz q.yoh)
|
|
::
|
|
++ wind :: wind:ho:um:am
|
|
|= [gom=soup ham=meal]
|
|
:: ~& [%wind her gom]
|
|
^+ +>
|
|
=^ wyv diz (zuul:diz now ham)
|
|
=^ feh puz (whap:puz now gom wyv)
|
|
(busk xong:diz feh)
|
|
::
|
|
++ wool :: wool:ho:um:am
|
|
|= [hen=duct cha=path val=* ete=?] :: send a statement
|
|
^+ +>
|
|
=+ ^= rol ^- rill
|
|
=+ rol=(~(get by ryl.bah) cha)
|
|
?~(rol *rill u.rol)
|
|
=+ sex=sed.rol
|
|
:: ~& [%tx [our her] cha sex]
|
|
=. ryl.bah
|
|
%+ ~(put by ryl.bah) cha
|
|
rol(sed +(sed.rol), san (~(put by san.rol) sex hen))
|
|
=+ cov=[p=p:sen:gus q=clon:diz]
|
|
%+ wind [cha sex]
|
|
?: ete
|
|
[%bund q.cov cha sex val]
|
|
[%bond q.cov cha sex val]
|
|
::
|
|
++ zest :: zest:ho:um:am
|
|
:~ :~ :* [%rtt rtt.sop.bah]
|
|
[%rto rto.sop.bah]
|
|
[%rtn rtn.sop.bah]
|
|
[%rue rue.sop.bah]
|
|
==
|
|
:* [%nus nus.sop.bah]
|
|
[%nif nif.sop.bah]
|
|
[%nep nep.sop.bah]
|
|
[%caw caw.sop.bah]
|
|
[%cag cag.sop.bah]
|
|
==
|
|
=+ qup=(~(tap to puq.sop.bah) ~)
|
|
:- %qup
|
|
%+ turn qup
|
|
|= [a=@ud b=soul]
|
|
:* a
|
|
nux.b
|
|
liv.b
|
|
lys.b
|
|
`@p`(mug (shaf %flap pac.b))
|
|
gom.b
|
|
==
|
|
==
|
|
::
|
|
:- %raz
|
|
=+ zar=(~(tap by raz.bah) ~)
|
|
%+ turn zar
|
|
|= [a=path b=race]
|
|
:+ a
|
|
did.b
|
|
=+ ciy=(~(tap by mis.b) ~)
|
|
%+ turn ciy
|
|
|= [c=@ud d=[p=cape q=lane r=flap s=(unit)]]
|
|
[c p.d r.d]
|
|
::
|
|
[%ryl (~(tap to ryl.bah) ~)]
|
|
[%lun lun.wod.dur.diz]
|
|
[%caq caq.dur.diz]
|
|
[%lew lew.wod.dur.diz]
|
|
==
|
|
::
|
|
++ zank :: zank:ho:um:am
|
|
%= +>.$ :: resolve
|
|
gus (nux:gus diz)
|
|
wab.weg (~(put by wab.weg) her bah(sop abet:puz))
|
|
==
|
|
-- :: --ho:um:am
|
|
::
|
|
++ kick :: kick:um:am
|
|
|= hen=duct :: test connection
|
|
^+ +>
|
|
=+ hoy=hoy.saf.gus
|
|
|- ^+ +>.^$
|
|
?~ hoy
|
|
+>.^$
|
|
$(hoy t.hoy, +>.^$ (pong i.hoy hen))
|
|
::
|
|
++ pals :: pals:um:am
|
|
^- (list ,@p) :: active neighbors
|
|
%+ turn
|
|
%+ skim (~(tap by wab.weg) ~)
|
|
|= [a=ship b=bath]
|
|
!(~(boom pu sop.b) now)
|
|
|=([a=ship b=bath] a)
|
|
::
|
|
++ pong :: pong:um:am
|
|
|= [her=ship hen=duct] :: test neighbor
|
|
^+ +>
|
|
zank:(pong:(ho her) hen)
|
|
::
|
|
++ zork :: zork:um:am
|
|
^- [p=(list boon) q=fort] :: resolve
|
|
:- (flop bin)
|
|
%_ fox
|
|
ton (~(su go ton.fox) gus)
|
|
zac (~(put by zac.fox) our.gus weg)
|
|
==
|
|
-- :: --um:am
|
|
-- :: --am
|
|
--
|
|
. ==
|
|
::::::::::::::::::::::::::::::::::::::::::::::::::::::::
|
|
:: section 4aH, protocol vane ::
|
|
::
|
|
=| $: fox=fort :: kernel state
|
|
== ::
|
|
|= [now=@da eny=@ ski=sled] :: current invocation
|
|
^? :: opaque core
|
|
=<
|
|
|% :: vane interface
|
|
++ call :: handle request
|
|
|= $: hen=duct
|
|
hic=(hypo (hobo kiss))
|
|
==
|
|
=> %= . :: XX temporary
|
|
q.hic
|
|
^- kiss
|
|
?: ?=(%soft -.q.hic)
|
|
((hard kiss) p.q.hic)
|
|
?: (~(nest ut -:!>(*kiss)) | p.hic) q.hic
|
|
~& [%ames-call-flub (,@tas `*`-.q.hic)]
|
|
((hard kiss) q.hic)
|
|
==
|
|
^- [p=(list move) q=_..^$]
|
|
=^ duy ..knob
|
|
(knob hen q.hic)
|
|
[duy ..^$]
|
|
::
|
|
++ doze
|
|
|= [now=@da hen=duct]
|
|
=+ doz=`(unit ,@da)`[~ (add now ~s32)]
|
|
|- ^+ doz
|
|
?~ zac.fox doz
|
|
=. doz $(zac.fox l.zac.fox)
|
|
=. doz $(zac.fox r.zac.fox)
|
|
=+ yem=q.n.zac.fox
|
|
|- ^+ doz
|
|
?~ wab.yem doz
|
|
=. doz $(wab.yem l.wab.yem)
|
|
=. doz $(wab.yem r.wab.yem)
|
|
=+ bah=q.n.wab.yem
|
|
(hunt doz rtn.sop.bah)
|
|
::
|
|
++ load
|
|
|= old=fort
|
|
^+ ..^$
|
|
..^$(fox old)
|
|
::
|
|
++ scry
|
|
|= [fur=(unit (set monk)) ren=@tas who=ship syd=desk lot=coin tyl=path]
|
|
^- (unit (unit (pair mark ,*)))
|
|
?~ tyl [~ ~]
|
|
=+ hun=(slaw %p i.tyl)
|
|
?~ hun [~ ~]
|
|
=- ?~ old ~
|
|
[~ ~ u.old]
|
|
^= old
|
|
?. =(0 ren) ~
|
|
?+ lot ~
|
|
[%$ %ud @]
|
|
%+ bind
|
|
(perm who u.hun q.p.lot [syd t.tyl])
|
|
|=(a=* [%noun a])
|
|
::
|
|
[%$ %da @]
|
|
?. =(now q.p.lot) ~
|
|
%+ bind
|
|
(temp who u.hun [syd t.tyl])
|
|
|=(a=* [%noun a])
|
|
==
|
|
::
|
|
++ stay fox
|
|
++ take :: accept response
|
|
|= [tea=wire hen=duct hin=(hypo sign)]
|
|
^- [p=(list move) q=_..^$]
|
|
=^ duy ..knap
|
|
(knap tea hen q.hin)
|
|
[duy ..^$]
|
|
--
|
|
|%
|
|
++ claw |=(our=ship ^-(duct hen:(need (~(get by zac.fox) our))))
|
|
++ clop
|
|
|= [now=@da hen=duct bon=boon]
|
|
^- [(list move) fort]
|
|
?- -.bon
|
|
%beer
|
|
:_ fox(zac (~(put by zac.fox) p.bon `corn`[hen ~ ~ ~]))
|
|
:: ~& [%ames-clop p.bon hen]
|
|
:* [hen [%slip %c %init p.bon]]
|
|
[hen [%give %init p.bon]]
|
|
[hen [%slip %a %kick now]]
|
|
[hen [%slip %e %init p.bon]]
|
|
[hen [%slip %g %init p.bon]]
|
|
[hen [%slip %d %init p.bon]] :: must be after gall
|
|
~
|
|
==
|
|
::
|
|
%cake
|
|
:: ~& [%cake p.bon q.bon r.bon]
|
|
:_ fox
|
|
:~ [s.bon %give %woot q.p.bon r.bon]
|
|
==
|
|
::
|
|
%coke
|
|
:: ~& [%tz p.bon q.bon r.bon]
|
|
:_ fox
|
|
:~ [s.bon %give %went q.p.bon r.bon]
|
|
==
|
|
::
|
|
%mead :_(fox [[hen [%give %hear p.bon q.bon]] ~])
|
|
%milk
|
|
:: ~& [%rx p.bon q.bon]
|
|
?> ?=([@ *] q.q.bon)
|
|
?: ?=(%r i.q.q.bon)
|
|
?: ?=([%ta *] t.q.q.bon)
|
|
=+ wil=((hard (unit will)) r.bon)
|
|
:_ fox
|
|
=+ ^= pax
|
|
:+ (scot %p p.p.bon)
|
|
(scot %p q.p.bon)
|
|
q.q.bon
|
|
[hen %pass pax %g %rote p.bon /began 0 %m %will wil]~
|
|
?> ?=([@ @ *] t.q.q.bon)
|
|
:_ fox
|
|
=+ [cak=i.t.q.q.bon ven=i.t.t.q.q.bon]
|
|
:_ ~
|
|
=+ neh=(claw p.p.bon)
|
|
?> ?=(^ neh)
|
|
?: ?=(%e ven)
|
|
?+ cak !! :: XX fix eyre
|
|
%pr :_ [%sick %waft p.bon r.bon]
|
|
[[`path`t.t.t.q.q.bon] hen]
|
|
%pc :_ [%sick %wart p.bon cak `path`t.t.t.q.q.bon r.bon]
|
|
[[%e `path`t.t.t.q.q.bon] hen]
|
|
==
|
|
=+ ton=[%waft p.bon r.bon]
|
|
:: ~& [%milk-waft [[ven `path`t.t.t.q.q.bon] t.neh]]
|
|
:_ [%sick ton]
|
|
?: =(%c ven)
|
|
?> =(%re cak)
|
|
[[%c `path`t.t.t.q.q.bon] hen]
|
|
[[ven `path`t.t.t.q.q.bon] t.neh]
|
|
?> ?=(%q i.q.q.bon)
|
|
?> ?=([@ *] t.q.q.bon)
|
|
?+ i.t.q.q.bon
|
|
:_ fox
|
|
:~ :- (claw p.p.bon)
|
|
[%sick %wart p.bon i.t.q.q.bon t.t.q.q.bon r.bon]
|
|
==
|
|
::
|
|
%pi :: ping
|
|
[~ fox]
|
|
:: $(bon [%wine p.bon " sent a ping at {(scow %da now)}"])
|
|
::
|
|
?(%pr %pc) :: %pr, %pc
|
|
:_ fox
|
|
:~ [hen [%slip %e %wart p.bon i.t.q.q.bon t.t.q.q.bon r.bon]]
|
|
==
|
|
::
|
|
%ta
|
|
=+ gox=((hard ,[p=@p q=@pG r=gens s=pass]) r.bon)
|
|
=+ gus=(need (~(us go ton.fox) p.p.bon))
|
|
=^ wyl gus (born:gus now gox)
|
|
=. ton.fox (~(su go ton.fox) gus)
|
|
:_ fox
|
|
:~ :- hen
|
|
[%pass ~ %a %want p.bon [%r %ta t.t.q.q.bon] `(unit will)`wyl]
|
|
==
|
|
%re :: %re
|
|
:_ fox
|
|
:~ [hen [%slip %c %wart p.bon i.t.q.q.bon t.t.q.q.bon r.bon]]
|
|
==
|
|
::
|
|
%ye :: %ye
|
|
:: ~& [%ye bon]
|
|
?> =(p.p.bon (sein q.p.bon))
|
|
=+ ^= paz ^- (list ,@p)
|
|
%+ skim pals:(~(um am [now fox]) p.p.bon)
|
|
|=(a=@p =(p.p.bon (sein a)))
|
|
:_ fox
|
|
%+ turn paz
|
|
|= him=ship
|
|
:- hen
|
|
[%pass /ye %g %mess [him ye/~] p.p.bon [%txt !>(((hard ,@t) r.bon))]]
|
|
==
|
|
::
|
|
%mulk
|
|
:: ~& [%mulk p.bon q.bon]
|
|
?> ?=([@ @ *] q.q.bon)
|
|
?> ?=(%q i.q.q.bon)
|
|
?+ i.t.q.q.bon
|
|
~& %mulk-bad
|
|
:_ fox
|
|
:~ :- (claw p.p.bon)
|
|
[%sick %wart p.bon i.t.q.q.bon t.t.q.q.bon r.bon]
|
|
==
|
|
::
|
|
%ge :: %gall request
|
|
=* imp t.t.q.q.bon
|
|
?> (levy imp (sane %ta))
|
|
=+ ^= pax
|
|
:+ (scot %p p.p.bon)
|
|
(scot %p q.p.bon)
|
|
q.q.bon
|
|
:_ fox [hen %pass pax %g %rote p.bon imp r.bon]~
|
|
::
|
|
%gh :: %gall response
|
|
=* imp t.t.q.q.bon
|
|
?> (levy imp (sane %ta))
|
|
=+ ^= pax
|
|
:+ (scot %p p.p.bon)
|
|
(scot %p q.p.bon)
|
|
q.q.bon
|
|
:_ fox [hen %pass pax %g %roth p.bon imp r.bon]~
|
|
==
|
|
::
|
|
%ouzo
|
|
:: ~& [%send now p.bon `@p`(mug (shaf %flap q.bon))]
|
|
:_ fox
|
|
[[gad.fox [%give %send p.bon q.bon]] ~]
|
|
::
|
|
%wine
|
|
:_ fox
|
|
=+ nym=(temp p.p.bon q.p.bon /name)
|
|
=+ fom=~(rend co %$ %p q.p.bon)
|
|
:~ :- hen
|
|
:+ %slip %d
|
|
:+ %flog %text
|
|
;: weld
|
|
"; "
|
|
?: |(?=(~ nym) =(%$ u.nym)) fom
|
|
:(weld fom " " (trip ((hard ,@) u.nym)))
|
|
q.bon
|
|
==
|
|
==
|
|
==
|
|
::
|
|
++ knap
|
|
|= [tea=wire hen=duct sih=sign]
|
|
^- [(list move) _+>]
|
|
?- +<.sih
|
|
%crud [[[hen [%slip %d %flog +.sih]] ~] +>]
|
|
%went [~ +>]
|
|
?(%mean %nice)
|
|
?: ?=([%ye ~] tea)
|
|
[~ +>.$]
|
|
?> ?=([@ @ @ *] tea)
|
|
=+ soq=[(slav %p i.tea) (slav %p i.t.tea)]
|
|
=+ pax=t.t.tea
|
|
:: ~& [%knap soq num pax]
|
|
=+ ^= fuy
|
|
=< zork =< zank
|
|
%^ ~(rack am [now fox]) soq pax
|
|
?-(+<.sih %mean `p.+.sih, %nice ~)
|
|
=> %_(. fox q.fuy)
|
|
=| out=(list move)
|
|
|- ^- [p=(list move) q=_+>.^$]
|
|
?~ p.fuy
|
|
[(flop out) +>.^$]
|
|
=^ toe fox (clop now hen i.p.fuy)
|
|
$(p.fuy t.p.fuy, out (weld (flop toe) out))
|
|
==
|
|
::
|
|
++ knob
|
|
|= [hen=duct kyz=kiss]
|
|
^- [(list move) _+>]
|
|
?: ?=([%crud *] kyz)
|
|
[[[hen [%slip %d %flog kyz]] ~] +>]
|
|
=+ ^= fuy
|
|
^- [p=(list boon) q=fort]
|
|
?- -.kyz
|
|
%barn
|
|
[~ fox(gad hen)]
|
|
%cash
|
|
(~(have am [now fox]) p.kyz q.kyz)
|
|
::
|
|
%hear
|
|
(~(gnaw am [now fox]) %good p.kyz q.kyz)
|
|
::
|
|
%hole
|
|
(~(gnaw am [now fox]) %dead p.kyz q.kyz)
|
|
::
|
|
%junk
|
|
[~ fox(any.ton (shax (mix any.ton.fox p.kyz)))]
|
|
::
|
|
%kick
|
|
(~(kick am [now fox(hop p.kyz)]) hen)
|
|
::
|
|
%make
|
|
=+ vun=(~(come am [now fox]) p.kyz (bex q.kyz) r.kyz s.kyz)
|
|
[[[%beer p.vun] ~] q.vun]
|
|
::
|
|
%sith
|
|
(~(czar am [now fox]) p.kyz q.kyz r.kyz)
|
|
::
|
|
%wake
|
|
(~(wake am [now fox]) hen)
|
|
::
|
|
%want
|
|
(~(wise am [now fox]) p.kyz hen q.kyz r.kyz |)
|
|
::
|
|
%wont
|
|
(~(wise am [now fox]) p.kyz hen q.kyz r.kyz &)
|
|
==
|
|
=> %_(. fox q.fuy)
|
|
=| out=(list move)
|
|
|- ^- [p=(list move) q=_+>.^$]
|
|
?~ p.fuy
|
|
[(flop out) +>.^$]
|
|
=^ toe fox (clop now hen i.p.fuy)
|
|
$(p.fuy t.p.fuy, out (weld (flop toe) out))
|
|
::
|
|
++ perm
|
|
|= [our=ship his=ship mar=@ud tyl=path]
|
|
^- (unit)
|
|
?~ tyl ~
|
|
?: ?=([%name ~] tyl)
|
|
=+ wul=$(tyl [%will ~])
|
|
[~ ?~(wul (scot %p his) (gnow his q.q.q:((hard deed) -.u.wul)))]
|
|
?: ?=([%gcos ~] tyl)
|
|
=+ wul=$(tyl [%will ~])
|
|
[~ ?~(wul ~ [~ `gcos`q.q.q:((hard deed) -.u.wul)])]
|
|
=+ gys=(~(us go ton.fox) our)
|
|
?~ gys ~
|
|
?. =(our his)
|
|
?: ?=([%will ~] tyl)
|
|
=+ fod=(~(get by hoc.saf.u.gys) his)
|
|
?~ fod ~
|
|
(rick mar his lew.wod.u.fod)
|
|
?: ?=([%tick ~] tyl)
|
|
?. =(our (sein his)) ~
|
|
[~ (end 6 1 (shaf %tick (mix his (shax sec:ex:q:sen:u.gys))))]
|
|
~
|
|
?: ?=([%buck ~] tyl)
|
|
=+ muc=(rice mar sex:u.gys)
|
|
=+ luw=(rick mar our law.saf.u.gys)
|
|
?. &(?=(^ muc) ?=(^ luw)) ~
|
|
[~ `buck`[u.muc u.luw]]
|
|
?: ?=([%code ~] tyl)
|
|
[~ (end 6 1 (shaf %code (shax sec:ex:q:sen:u.gys)))]
|
|
?: ?=([%will ~] tyl)
|
|
(rick mar our law.saf.u.gys)
|
|
~
|
|
::
|
|
++ temp
|
|
|= [our=ship his=ship tyl=path]
|
|
^- (unit)
|
|
?: ?=([?(%show %tell) *] tyl)
|
|
?^ t.tyl ~
|
|
=+ gys=(~(us go ton.fox) our)
|
|
?~ gys ~
|
|
=+ zet=zest:(ho:(~(um am [now fox]) our) his)
|
|
[~ ?:(=(%show i.tyl) >zet< zet)]
|
|
?: ?=([%pals ~] tyl)
|
|
?. =(our his)
|
|
~
|
|
[~ pals:(~(um am [now fox]) our)]
|
|
?. ?=([%life ~] tyl)
|
|
=+ muc=$(tyl [%life ~])
|
|
(perm our his ?~(muc 0 (,@ud u.muc)) tyl)
|
|
=+ gys=(~(us go ton.fox) our)
|
|
?~ gys ~
|
|
?. =(our his)
|
|
=+ fod=(~(get by hoc.saf.u.gys) his)
|
|
?~ fod ~
|
|
?~ lew.wod.u.fod ~
|
|
[~ `@ud`p.p.q.i.lew.wod.u.fod]
|
|
?~ val.saf.u.gys ~
|
|
[~ `@ud`p.i.val.saf.u.gys]
|
|
--
|