mirror of
https://github.com/urbit/shrub.git
synced 2025-01-05 11:09:30 +03:00
186 lines
4.5 KiB
Plaintext
186 lines
4.5 KiB
Plaintext
/- hark=hark-store, hood, docket
|
|
/+ verb, dbug, default-agent, agentio
|
|
|%
|
|
+$ card card:agent:gall
|
|
+$ state-0 [%0 lagging=_|]
|
|
::
|
|
++ lag-interval ~m10
|
|
--
|
|
%+ verb &
|
|
%- agent:dbug
|
|
^- agent:gall
|
|
=| state-0
|
|
=* state -
|
|
=<
|
|
|_ =bowl:gall
|
|
+* this .
|
|
def ~(. (default-agent this %|) bowl)
|
|
io ~(. agentio bowl)
|
|
pass pass:io
|
|
cc ~(. +> bowl)
|
|
++ on-init
|
|
^- (quip card _this)
|
|
:_ this
|
|
[onboard watch:kiln check:lag ~]:cc
|
|
::
|
|
++ on-load
|
|
|= =vase
|
|
=+ !<(old=state-0 vase)
|
|
`this(state old)
|
|
::
|
|
++ on-save !>(state)
|
|
++ on-poke on-poke:def
|
|
++ on-peek on-peek:def
|
|
++ on-watch on-watch:def
|
|
++ on-agent
|
|
|= [=wire =sign:agent:gall]
|
|
|^
|
|
?+ wire (on-agent:def wire sign)
|
|
[%kiln %vats ~] take-kiln-vats
|
|
==
|
|
++ take-kiln-vats
|
|
?- -.sign
|
|
?(%poke-ack %watch-ack) (on-agent:def wire sign)
|
|
%kick :_(this (drop safe-watch:kiln:cc))
|
|
::
|
|
%fact
|
|
?. ?=(%kiln-vats-diff p.cage.sign) `this
|
|
=+ !<(=diff:hood q.cage.sign)
|
|
?+ -.diff `this
|
|
::
|
|
%commit
|
|
?. |(=(desk.diff %base) ~(has-docket de:cc desk.diff)) `this
|
|
=/ =action:hark ~(commit de:cc desk.diff)
|
|
:_ this
|
|
~[(poke:ha:cc action)]
|
|
::
|
|
%block
|
|
=/ =action:hark (~(blocked de:cc desk.diff) blockers.diff)
|
|
:_ this
|
|
~[(poke:ha:cc action)]
|
|
==
|
|
==
|
|
--
|
|
::
|
|
++ on-arvo
|
|
|= [=wire sign=sign-arvo]
|
|
^- (quip card _this)
|
|
?. ?=([%check-lag ~] wire) (on-arvo:def wire sign)
|
|
?> ?=([%behn %wake *] sign)
|
|
=+ .^(lag=? %$ (scry:io %$ /zen/lag))
|
|
?: =(lagging lag) :_(this ~[check:lag:cc])
|
|
:_ this(lagging lag)
|
|
:_ ~[check:lag:cc]
|
|
?:(lagging start:lag:cc stop:lag:cc)
|
|
::
|
|
++ on-fail on-fail:def
|
|
++ on-leave on-leave:def
|
|
--
|
|
|_ =bowl:gall
|
|
+* io ~(. agentio bowl)
|
|
pass pass:io
|
|
::
|
|
++ onboard
|
|
^- card
|
|
%- poke:ha
|
|
:+ %add-note [/ [q.byk.bowl /onboard]]
|
|
:: We special case this in the grid UI, but should include something
|
|
:: for third parties
|
|
[~[text+'Welcome to urbit'] ~ now.bowl / /]
|
|
::
|
|
++ lag
|
|
|%
|
|
++ check (~(wait pass /check-lag) (add now.bowl lag-interval))
|
|
++ place [q.byk.bowl /lag]
|
|
++ body `body:hark`[~[text/'Runtime lagging'] ~ now.bowl / /]
|
|
++ start (poke:ha %add-note [/ place] body)
|
|
++ stop (poke:ha %del-place place)
|
|
--
|
|
++ ha
|
|
|%
|
|
++ pass ~(. ^pass /hark)
|
|
++ poke
|
|
|=(=action:hark (poke-our:pass %hark-store hark-action+!>(action)))
|
|
--
|
|
++ kiln
|
|
|%
|
|
++ path /kiln/vats
|
|
++ pass ~(. ^pass path)
|
|
++ watch (watch-our:pass %hood path)
|
|
++ watching (~(has by wex.bowl) [path our.bowl %hood])
|
|
++ safe-watch `(unit card)`?:(watching ~ `watch)
|
|
--
|
|
::
|
|
++ de
|
|
|_ =desk
|
|
++ scry-path (scry:io desk /desk/docket)
|
|
++ has-docket .^(? %cu scry-path)
|
|
++ docket .^(docket:^docket %cx scry-path)
|
|
++ hash .^(@uv %cz (scry:io desk ~))
|
|
++ place `place:hark`[q.byk.bowl /desk/[desk]]
|
|
++ vat
|
|
.^(vat:hood %gx (scry:io %hood /kiln/vat/[desk]/noun))
|
|
++ body
|
|
|= [=path title=cord content=(unit cord)]
|
|
^- body:hark
|
|
[~[text+title] ?~(content ~ ~[text/u.content]) now.bowl ~ path]
|
|
::
|
|
::
|
|
++ title-prefix
|
|
|= =cord
|
|
?: =(desk %base)
|
|
'System software'
|
|
?: has-docket
|
|
(rap 3 'App: "' title:docket '"' cord ~)
|
|
(rap 3 'Desk: ' desk cord ~)
|
|
::
|
|
++ get-version
|
|
?: has-docket
|
|
(rap 3 'version: ' (ver version:docket) ~)
|
|
(rap 3 'hash: ' (scot %uv hash) ~)
|
|
::
|
|
++ commit
|
|
^- action:hark
|
|
?:(=(1 ud.cass:vat) created updated)
|
|
::
|
|
++ created
|
|
^- action:hark
|
|
:+ %add-note [/created place]
|
|
(body /desk/[desk] (title-prefix ' has been installed') ~)
|
|
::
|
|
++ updated
|
|
^- action:hark
|
|
:+ %add-note [/update place]
|
|
(body /desk/[desk] (title-prefix (rap 3 ' has been updated to ' get-version ~)) ~)
|
|
::
|
|
++ blocked
|
|
|= blockers=(set ^desk)
|
|
^- action:hark
|
|
:+ %add-note [/blocked place]
|
|
%^ body /blocked (title-prefix ' is blocked from upgrading')
|
|
`(rap 3 'Blocking desks: ' (join ', ' ~(tap in blockers)))
|
|
::
|
|
++ ver
|
|
|= =version:^docket
|
|
=, version
|
|
`@t`(rap 3 (num major) '.' (num minor) '.' (num patch) ~)
|
|
::
|
|
++ num
|
|
|= a=@ud
|
|
`@t`(rsh 4 (scot %ui a))
|
|
--
|
|
++ note
|
|
|%
|
|
++ merge
|
|
|= [=desk hash=@uv]
|
|
^- (list body:hark)
|
|
:_ ~
|
|
:* ~[text+'Desk Updated']
|
|
~[text+(crip "Desk {(trip desk)} has been updated to hash {(scow %uv hash)}")]
|
|
now.bowl
|
|
/update/[desk]
|
|
/
|
|
==
|
|
--
|
|
--
|