urbit/arvo/ford.hoon

225 lines
6.8 KiB
Plaintext
Raw Normal View History

2014-04-23 21:02:36 +04:00
!: :: %ford, new execution control
!? 164
::::
|= pit=vase
^- vane
=> =~
|% :: structures
++ axle :: all %ford state
2014-04-30 21:04:07 +04:00
$: ven=%0 :: version for update
tad=[p=@ud q=(map ,@ud task)] :: tasks by number
dym=(map duct ,@ud) :: duct to number
haf=(map path cash) :: path to file hash
tiz=(map cash twig) :: file hash to twig
2014-04-23 21:02:36 +04:00
== ::
2014-04-30 21:04:07 +04:00
++ bolt :: local product
$% [%0 p=(list path) q=vase] :: depends / result
[%1 p=(list path)] :: blockage
[%2 p=(list tank)] :: error
2014-04-23 21:02:36 +04:00
== ::
2014-04-30 21:04:07 +04:00
++ task :: problem in progress
$: wor=writ :: rights and powers
nah=duct :: cause
sic=silk :: problem
kig=,[p=@ud q=(map ,@ud path)] :: blocks
2014-04-23 21:02:36 +04:00
== ::
2014-04-30 21:04:07 +04:00
|% ::
++ colt :: reduce to save
|= lex=axle
2014-04-30 21:04:07 +04:00
lex
::
++ za :: per event
=| $: $: $: wor=writ :: event authority
tea=wire :: event place
hen=duct :: event floor
fav=card :: event data
== ::
$: now=@da :: event date
eny=@ :: unique entropy
sky=$+(* (unit)) :: system namespace
== ::
mow=(list move) :: pending actions
== ::
2014-04-30 21:04:07 +04:00
axle :: all vane state
== ::
2014-04-30 21:04:07 +04:00
=* lex ->
|%
++ abet
2014-04-30 21:04:07 +04:00
^- [(list move) axle]
[(flop mow) lex]
::
++ apex
|- ^+ +
?^ tea
2014-04-30 21:04:07 +04:00
?> ?=([@ @ ~] tea)
=+ num=(need (slaw %ud i.tea))
?> ?=([%writ *] fav)
=+ tus=(~(get by q.tad) num)
?~ tus
~& [%ford-lost num]
+.$
(~(resp zo [num u.tus]) (need (slaw %ud i.t.tea)) p.fav)
::
?+ -.fav
%exec
=+ num=p.tad
?> !(~(has by dym) hen)
=: p.tad +(p.tad)
dym (~(put by dym) num hen)
2014-04-30 21:04:07 +04:00
==
abet:~(exec zo [num `task`[wor hen p.fav ~]])
::
%kill
=+ num=(need (~(get by dym) hen))
=+ tas=(need (~(get by q.tad) num))
~(kill zo [num tas])
==
::
2014-04-30 21:04:07 +04:00
++ zo
|_ [num=@ud task]
++ abet %_(..zo q.tad (~(put by q.tad) num +<+))
++ amok %_(..zo q.tad (~(del by q.tad) num))
++ camp :: request a file
|= pax=path
^+ +>
=+ kit=(need (tame pax))
=+ [him=`ship`r.kit ryf=`riff`
=+ tik=(scot %ud p.kig)
=: p.kig +(p.kig)
q.kig (~(put by q.kig) p.kig pax)
==
%= $
mow :_ mow
:+ [~ wor]
~[/c [%f (scot %ud num) (scot %ud tik) ~] hen]
[%warp `ship`r.kit [s.kit ~ %& p.kit q.kit t.kit]]
==
++ exec
^+ ..zo
?^ q.kig ..zo
|- ^+ ..zo
=^ bot +.$ (make sic)
?- -.bot
%0 amok:+.$(mow [%made %& p.bot])
%2 amok:+.$(mow [%made %| p.bot])
%1 =< abet
|- ^+ +.^$
?~ p.bot +.^$
$(p.bot t.p.bot, +.$ (camp i.p.bot))
==
2014-04-30 21:04:07 +04:00
++ find :: XX awaits nu scry
|= pax=path
^- (unit (unit ,*))
=+ dum=(sky pax)
?^ dum [~ u.dum]
?: &(?=(^ pax) =((scot %p q.wor) i.pax))
~ :: assumed nonexistent
[~ ~] :: block on it
::
++ fuss :: load code
|= lav=(list path)
^- [p=(unit bolt) q=_+>]
?~ lav [~ +>.$]
=+ daz=(find %cy (weld i.lav /hoon))
?~ daz $(lav t.lav)
?~ u.daz
2014-04-30 21:04:07 +04:00
::
++ make
|= kis=silk
^- [bolt _+>]
?- -.kis
^
=^ one +>.$ $(kis p.kis)
?. ?=(%0 -.one) [one +>.$]
=^ two +>.$ $(kis q.kis)
?. ?=(%0 -.two) [two +>.$]
[[%0 (weld p.one p.two) (slop q.one q.two)] +>.$]
::
%call
=^ one +>.$ $(kis p.kis)
?. ?=(%0 -.one) [one +>.$]
=^ two +>.$ $(kis q.kis)
?. ?=(%0 -.two) [two +>.$]
=^ tri +>.$ (maul q.one q.two)
[%0 :(weld p.one p.two p.tri) q.tri]
::
%code
2014-04-30 21:04:07 +04:00
=^ one +>.$ $(kis q.kis)
?. ?=(%0 -.one) [one +>.$]
=^ twu +>.$ (fuss p.kis)
|- ^- [(unit bolt) _+>.^$]
=+
2014-04-30 21:04:07 +04:00
::
%data !!
::
%noun !!
::
%pass !!
::
%reef [%0
2014-04-30 21:04:07 +04:00
==
::
++ maul :: slam
++ maim :: slap
2014-04-30 21:04:07 +04:00
::
++ kill
^+ ..zo
=< amok
|- ^+ k
2014-04-30 21:04:07 +04:00
++ resp
|= [tik=@ud rot=riot]
^+ ..zo
?> (~(has by q.kig) tik)
?~ rot
amok:+.$(mow [%made %| (smyt (need (~(get by q.kig)) tik))])
exec(q.kig (~(del by q.kig) tik))
--
--
--
2014-04-23 21:02:36 +04:00
. ==
=| axle
=* lex -
|= [now=@da eny=@ sky=$+(* (unit))] :: activate
^? :: opaque core
|% ::
++ beat :: process move
|= [wru=(unit writ) tea=wire hen=duct fav=curd]
^- [p=(list move) q=vane]
2014-04-30 21:04:07 +04:00
?~ wru ~|(%beat-whom !!)
=^ mos lex
abet:~(apex za [[u.wru tea hen fav] [now eny sky] ~] lex)
2014-04-23 21:02:36 +04:00
[mos ..^$]
::
++ come
|= [sam=? old=vase]
^- vane
(load old)
::
++ doze
|= [now=@da hen=duct]
^- (unit ,@da)
~
::
++ load
|= old=vase
^- vane
2014-04-30 21:04:07 +04:00
?. (~(nest ut -:!>(`axle`+>-.^$)) | p.old)
2014-04-23 21:02:36 +04:00
~& %eyre-reset
..^$
2014-04-30 21:04:07 +04:00
..^$(+>- (axle q.old))
2014-04-23 21:02:36 +04:00
::
++ raze
^- vane
2014-04-30 21:04:07 +04:00
..$(+>- *axle)
2014-04-23 21:02:36 +04:00
::
++ scry
|= [our=ship ren=@tas who=ship syd=disc lot=coin tyl=path]
^- (unit)
~
::
++ stay
2014-04-30 21:04:07 +04:00
`vase`!>((colt `axle`+>-.$))
2014-04-23 21:02:36 +04:00
++ vern [164 0]
--