Merge branch 'nextbreach' of https://github.com/urbit/urbit into nextbreach

This commit is contained in:
Luke Patmore 2014-06-13 15:32:05 -07:00
commit 95fd2a7901
4 changed files with 82 additions and 38 deletions

View File

@ -1569,6 +1569,7 @@
[hen [%give %init p.bon]] [hen [%give %init p.bon]]
[hen [%slip %a %kick now]] [hen [%slip %a %kick now]]
[hen [%slip %e %init p.bon]] [hen [%slip %e %init p.bon]]
[hen [%slip %g %init p.bon]]
~ ~
== ==
:: ::

View File

@ -81,7 +81,6 @@
cug=(list ,@t) :: unacked cookies cug=(list ,@t) :: unacked cookies
lax=@da :: last used lax=@da :: last used
sok=(map ,@ud (trel term ship sink)) :: live apps by reqno sok=(map ,@ud (trel term ship sink)) :: live apps by reqno
kog=(map (pair term ship) ,@ud) :: live apps by name
rey=[p=@ud q=(map ,@ud pimp)] :: live requests rey=[p=@ud q=(map ,@ud pimp)] :: live requests
== :: == ::
++ dual ,[p=@ud q=(each ,[p=ship q=hole] ship)] :: request handle ++ dual ,[p=@ud q=(each ,[p=ship q=hole] ship)] :: request handle
@ -710,7 +709,6 @@
:: ::
now now
~ ~
~
[1 ~] [1 ~]
== ==
abet:work:(~(into ya [our p.saw] sef q.saw) pul moh) abet:work:(~(into ya [our p.saw] sef q.saw) pul moh)
@ -1864,8 +1862,7 @@
++ yokg :: main call ++ yokg :: main call
|= [num=@ud app=term you=ship pax=path] |= [num=@ud app=term you=ship pax=path]
^+ +> ^+ +>
=+ nup=(~(get by kog) [app you]) ?< (~(has by sok) num)
=. +>.$ ?~(nup +>.$ amok:(need (yolk u.nup)))
abet:(~(self yo num app you *sink) pax) abet:(~(self yo num app you *sink) pax)
:: ::
++ yokm :: message ++ yokm :: message
@ -1901,7 +1898,6 @@
== ==
++ abet :: resolve ++ abet :: resolve
%_ ..yo %_ ..yo
kog (~(put by kog) [app you] nap)
sok (~(put by sok) nap [app you siq]) sok (~(put by sok) nap [app you siq])
== ==
:: ::
@ -1911,7 +1907,6 @@
|- ^+ ..yo |- ^+ ..yo
?~ wuh ?~ wuh
%= ..yo %= ..yo
kog (~(del by kog) [app you])
sok (~(del by sok) nap) sok (~(del by sok) nap)
== ==
$(wuh t.wuh, ..amok (toss p.i.wuh `note`[%nuke our app])) $(wuh t.wuh, ..amok (toss p.i.wuh `note`[%nuke our app]))
@ -1932,6 +1927,7 @@
?. =(cnt meg.siq) ?. =(cnt meg.siq)
~& [%post-num cnt meg.siq] ~& [%post-num cnt meg.siq]
+>.$ +>.$
=. meg.siq +(meg.siq)
(toss %post `note`[%mess [our app] you [%json !>(jon)]]) (toss %post `note`[%mess [our app] you [%json !>(jon)]])
:: ::
++ self :: request main ++ self :: request main

View File

@ -22,10 +22,11 @@
== :: == ::
++ hasp ,[p=ship q=term] :: app identity ++ hasp ,[p=ship q=term] :: app identity
++ kiss :: in request ->$ ++ kiss :: in request ->$
$% [%show p=hasp q=ship r=path] :: subscribe $% [%init p=ship] :: initialize owner
[%cuff p=(unit cuff) q=kiss] :: controlled kiss [%show p=hasp q=ship r=path] :: subscribe
:: [%cuff p=(unit cuff) q=kiss] :: controlled kiss
[%mess p=hasp q=ship r=cage] :: message [%mess p=hasp q=ship r=cage] :: message
[%nuke p=hasp] :: clear all state [%nuke p=hasp] :: clear duct
== :: == ::
++ knob :: pending action ++ knob :: pending action
$% [%boot ~] :: boot/reboot $% [%boot ~] :: boot/reboot
@ -36,7 +37,8 @@
[%take p=path q=vase] :: user result [%take p=path q=vase] :: user result
== :: == ::
++ mast :: apps by ship ++ mast :: apps by ship
$: bum=(map ,@ta seat) :: apps by name $: hun=duct :: control duct
bum=(map ,@ta seat) :: apps by name
== :: == ::
++ move ,[p=duct q=(mold note gift)] :: typed move ++ move ,[p=duct q=(mold note gift)] :: typed move
++ note :: out request $-> ++ note :: out request $->
@ -58,7 +60,9 @@
++ seat :: the living app ++ seat :: the living app
$: huv=(unit vase) :: application vase $: huv=(unit vase) :: application vase
qic=(unit toil) :: current project qic=(unit toil) :: current project
oot=(map duct (set path)) :: live fords
vey=(qeu toil) :: pending projects vey=(qeu toil) :: pending projects
nuc=(set duct) :: nuked ducts
tik=@ud :: build number tik=@ud :: build number
orm=(unit ,@da) :: build date orm=(unit ,@da) :: build date
sup=(map duct (pair ship path)) :: subscribers sup=(map duct (pair ship path)) :: subscribers
@ -136,6 +140,8 @@
++ call :: handle request ++ call :: handle request
|= [hen=duct hic=(hypo (hobo kiss))] |= [hen=duct hic=(hypo (hobo kiss))]
=> .(q.hic ?.(?=(%soft -.q.hic) q.hic ((hard kiss) p.q.hic))) => .(q.hic ?.(?=(%soft -.q.hic) q.hic ((hard kiss) p.q.hic)))
?: ?=(%init -.q.hic)
[p=~ q=..^$(pol.all (~(put by pol.all) p.q.hic hen ~))]
|- ^- [p=(list move) q=_..^^$] |- ^- [p=(list move) q=_..^^$]
=+ =| law=(unit cuff) =+ =| law=(unit cuff)
|- ^- $: law=(unit cuff) |- ^- $: law=(unit cuff)
@ -143,7 +149,7 @@
kon=knob kon=knob
== ==
?- -.q.hic ?- -.q.hic
%cuff $(q.hic q.q.hic, law (limp p.q.hic law)) :: %cuff $(q.hic q.q.hic, law (limp p.q.hic law))
%mess [law p.q.hic %mess q.q.hic r.q.hic] %mess [law p.q.hic %mess q.q.hic r.q.hic]
%show [law p.q.hic %show q.q.hic r.q.hic] %show [law p.q.hic %show q.q.hic r.q.hic]
%nuke [law p.q.hic %nuke ~] %nuke [law p.q.hic %nuke ~]
@ -206,17 +212,17 @@
:: ::
++ goat :: call and go ++ goat :: call and go
|= [our=@p app=@tas] |= [our=@p app=@tas]
=+ ^= mat ^- mast =+ mat=(need (~(get by pol.all) our))
=+ mat=(~(get by pol.all) our)
?~(mat *mast u.mat)
=+ ^= sat ^- seat =+ ^= sat ^- seat
=+ sat=(~(get by bum.mat) app) =+ syt=(~(get by bum.mat) app)
?^ sat u.sat ?^ syt u.syt
*seat %* . *seat
:: %* . *seat zam
:: eny (shax (mix now eny)) ^- scar
:: lat now :+ 1
:: == [[hun.mat 0 ~] ~ ~]
[[0 hun.mat] ~ ~]
==
~(. go [our app] mat sat) ~(. go [our app] mat sat)
:: ::
++ go :: application core ++ go :: application core
@ -308,7 +314,7 @@
mow=(list move) :: actions mow=(list move) :: actions
== ==
++ abet [(flop mow) ^abet] :: resolve ++ abet [(flop mow) ^abet] :: resolve
++ apex ++ apex :: enter
^+ . ^+ .
?. &(=(~ huv.sat) =(~ qic.sat) =(~ vey.sat) =(~ ped.sat)) . ?. &(=(~ huv.sat) =(~ qic.sat) =(~ vey.sat) =(~ ped.sat)) .
%_(. vey.sat (~(put to vey.sat) hen [%boot ~])) %_(. vey.sat (~(put to vey.sat) hen [%boot ~]))
@ -331,7 +337,6 @@
|= kas=silk |= kas=silk
^- silk ^- silk
:+ %mute kas :+ %mute kas
~& [%conf-now now]
:~ [[%$ 12]~ (cave !>([[our app] 0 0 eny now]))] :~ [[%$ 12]~ (cave !>([[our app] 0 0 eny now]))]
== ==
++ core |=(vax=vase (cove %core vax)) :: core as silk ++ core |=(vax=vase (cove %core vax)) :: core as silk
@ -363,7 +368,7 @@
%+ skip (~(tap in pen) ~) %+ skip (~(tap in pen) ~)
|=(a=(pair ship desk) (~(has in ped.sat) a)) |=(a=(pair ship desk) (~(has in ped.sat) a))
|= a=(pair ship desk) |= a=(pair ship desk)
:- hen :- hun.mat
:^ %toss %c (away %s %drug (scot %p p.a) q.a ~) :^ %toss %c (away %s %drug (scot %p p.a) q.a ~)
[%warp [our p.a] q.a ~ %| [%da now] [%da (add now ~d1000)]] [%warp [our p.a] q.a ~ %| [%da now] [%da (add now ~d1000)]]
=+ ^= old ^- (list move) =+ ^= old ^- (list move)
@ -371,7 +376,7 @@
%+ skip (~(tap in ped.sat) ~) %+ skip (~(tap in ped.sat) ~)
|=(a=(pair ship desk) (~(has in pen) a)) |=(a=(pair ship desk) (~(has in pen) a))
|= a=(pair ship desk) |= a=(pair ship desk)
:- hen :- hun.mat
:^ %toss %c (away %s %drug (scot %p p.a) q.a ~) :^ %toss %c (away %s %drug (scot %p p.a) q.a ~)
[%warp [our p.a] q.a ~] [%warp [our p.a] q.a ~]
%_(+>.$ ped.sat pen, mow :(weld new old mow)) %_(+>.$ ped.sat pen, mow :(weld new old mow))
@ -391,12 +396,20 @@
:: ::
++ ford :: exec to ford ++ ford :: exec to ford
|= [pax=path kas=silk] |= [pax=path kas=silk]
%_ +>.$ (gawk %f [%s pax] [%exec our `kas])
mow ::
:_(mow [hen [%toss %f (away [%s pax]) [%exec our `kas]]]) ++ gawk :: toss a note
|= [lal=term pax=path noy=note]
^+ +>
%_ +>
mow [[hen %toss lal (away pax) noy] mow]
oot.sat =+ vut=(~(get by oot.sat) hen)
=+ vit=?^(vut u.vut *(set path))
?< (~(has in vit) pax)
(~(put by oot.sat) hen (~(put in vit) pax))
== ==
:: ::
++ give :: return card ++ give :: give a gift
|= gip=gift |= gip=gift
%_(+> mow [[hen %give gip] mow]) %_(+> mow [[hen %give gip] mow])
:: ::
@ -418,13 +431,23 @@
:: ::
++ more :: accept result ++ more :: accept result
|= $: pax=path :: internal position |= $: pax=path :: internal position
hin=(hypo sign) :: urbit event hin=(hypo sign) :: typed event
== ==
^+ +> ^+ +>
:: ~& [%more pax -.q.hin]
=. oot.sat
?: ?=([%s %drug *] pax) oot.sat
=+ vut=(~(get by oot.sat) hen)
?~ vut
~& [%more-lost-a our app hen] !!
?. (~(has in u.vut) pax)
~& [%more-lost our app hen pax] !!
?: =(~ u.vut)
(~(del by oot.sat) hen)
(~(put by oot.sat) hen (~(del in u.vut) pax))
?: ?=([%u *] pax) ?: ?=([%u *] pax)
?. ?=(%ruse -.q.hin) ?. ?=(%ruse -.q.hin)
~& [%more-card -.q.hin pax] ~& [%more-card -.q.hin pax] !!
!!
%_ +>.$ %_ +>.$
vey.sat vey.sat
%- ~(put to vey.sat) %- ~(put to vey.sat)
@ -493,7 +516,25 @@
++ quem :: queue action ++ quem :: queue action
|= kon=knob :: content |= kon=knob :: content
^+ +> ^+ +>
%_(+> vey.sat (~(put to vey.sat) hen kon)) ?. ?=(%nuke -.kon)
+>.$(vey.sat (~(put to vey.sat) hen kon))
?: (~(has in nuc.sat) hen)
~& [%quem-renuke hen]
+>.$
=+ vut=(~(get by oot.sat) hen)
=+ ^= ded ^- (list path)
?~(vut ~ (~(tap by u.vut) ~))
|- ^+ +>.^$
?~ ded
%= +>.^$
qic.sat ?.(&(?=(^ qic.sat) =(hen p.u.qic.sat)) qic.sat ~)
nuc.sat (~(put in nuc.sat) hen)
vey.sat (~(put to vey.sat) hen kon)
==
%= $
ded t.ded
mow [[hen [%toss %f (away i.ded) [%exec our ~]]] mow]
==
:: ::
++ said ++ said
|= vud=vase |= vud=vase
@ -516,6 +557,12 @@
:+ %rasp :+ %rasp
((hard lode) +<.q.vig) ((hard lode) +<.q.vig)
(slot 7 vig) (slot 7 vig)
::
[%rush *]
:^ %rush
[tik.sat now]
((hard lode) +<.q.vig)
(slot 7 vig)
:: ::
[%rust *] [%rust *]
:^ %rust :^ %rust
@ -546,9 +593,10 @@
== ==
:: ::
++ work :: eat queue ++ work :: eat queue
^+ . |- ^+ +
?: |(?=(^ qic.sat) =(~ vey.sat)) . :: nothing to do ?: |(?=(^ qic.sat) =(~ vey.sat)) +.$ :: nothing to do
=^ yev vey.sat [p q]:~(get to vey.sat) =^ yev vey.sat [p q]:~(get to vey.sat)
?: (~(has in nuc.sat) p.yev) $
work:(yawn:(bing p.yev) q.yev) work:(yawn:(bing p.yev) q.yev)
:: ::
++ yawn :: start event ++ yawn :: start event
@ -576,7 +624,7 @@
:: ::
%nuke %nuke
:: ~& %yawn-nuke :: ~& %yawn-nuke
gone gone :: send unsubscribe
:: ::
%mess %mess
?~ huv.sat ?~ huv.sat

View File

@ -18,7 +18,6 @@
:: ::
++ peer ++ peer
|= [ost=bone you=ship pax=path] |= [ost=bone you=ship pax=path]
~& [%peer-hide hid]
~& [%peer [ost you pax]] ~& [%peer [ost you pax]]
:_ +> :_ ~ :_ +> :_ ~
:+ ost %give :+ ost %give
@ -33,7 +32,7 @@
;title: Hi, everyone! ;title: Hi, everyone!
== ==
;body ;body
;p: Hello, world (instance {<bug.foo>}) ;p: Happy, world (instance {<bug.foo>})
== ==
== ==
-- --