2020-07-15 22:26:55 +03:00
|
|
|
/- glob
|
|
|
|
/+ default-agent, verb, dbug
|
|
|
|
|%
|
2020-07-31 07:28:08 +03:00
|
|
|
++ hash 0v1.lkkr3.b5rri.loft7.tctif.hlu0t
|
2020-07-15 22:26:55 +03:00
|
|
|
+$ state-0 [%0 hash=@uv glob=(unit (each glob:glob tid=@ta))]
|
|
|
|
+$ all-states
|
|
|
|
$% state-0
|
|
|
|
==
|
|
|
|
+$ card card:agent:gall
|
|
|
|
--
|
|
|
|
|%
|
2020-07-18 02:58:28 +03:00
|
|
|
++ wait-timeout
|
|
|
|
|= [=path now=@da]
|
2020-07-15 22:26:55 +03:00
|
|
|
^- card
|
2020-07-18 02:58:28 +03:00
|
|
|
[%pass [%timer path] %arvo %b %wait (add now ~m30)]
|
|
|
|
::
|
|
|
|
++ wait-start
|
|
|
|
|= now=@da
|
|
|
|
^- card
|
|
|
|
[%pass /start %arvo %b %wait now]
|
2020-07-15 22:26:55 +03:00
|
|
|
::
|
|
|
|
++ poke-file-server
|
|
|
|
|= [our=@p =cage]
|
|
|
|
^- card
|
|
|
|
[%pass /serving/(scot %uv hash) %agent [our %file-server] %poke cage]
|
|
|
|
::
|
|
|
|
++ poke-spider
|
|
|
|
|= [=path our=@p =cage]
|
|
|
|
^- card
|
|
|
|
[%pass [%running path] %agent [our %spider] %poke cage]
|
|
|
|
::
|
|
|
|
++ watch-spider
|
|
|
|
|= [=path our=@p =sub=path]
|
|
|
|
^- card
|
|
|
|
[%pass [%running path] %agent [our %spider] %watch sub-path]
|
|
|
|
::
|
|
|
|
++ leave-spider
|
|
|
|
|= [=path our=@p]
|
|
|
|
^- card
|
|
|
|
[%pass [%running path] %agent [our %spider] %leave ~]
|
|
|
|
--
|
|
|
|
=| state=state-0
|
|
|
|
=. hash.state hash
|
2020-07-18 02:58:28 +03:00
|
|
|
=/ serve-path=path /'~landscape'/js/index
|
2020-07-15 22:26:55 +03:00
|
|
|
^- agent:gall
|
|
|
|
%+ verb |
|
|
|
|
%- agent:dbug
|
|
|
|
^- agent:gall
|
|
|
|
|_ =bowl:gall
|
|
|
|
+* this .
|
|
|
|
def ~(. (default-agent this %|) bowl)
|
|
|
|
++ on-init
|
|
|
|
^- (quip card _this)
|
2020-07-18 02:58:28 +03:00
|
|
|
:: delay through timer to make sure %spider has started
|
|
|
|
[[(wait-start now.bowl) ~] this]
|
2020-07-15 22:26:55 +03:00
|
|
|
::
|
|
|
|
++ on-save !>(state)
|
|
|
|
++ on-load
|
|
|
|
|= old-state=vase
|
|
|
|
^- (quip card _this)
|
|
|
|
=+ !<(old=all-states old-state)
|
|
|
|
?> ?=(%0 -.old)
|
|
|
|
?~ glob.old
|
|
|
|
on-init
|
|
|
|
?: ?=(%& -.u.glob.old)
|
|
|
|
?: =(hash.old hash.state)
|
|
|
|
`this(state old)
|
|
|
|
on-init
|
|
|
|
=/ cancel-cards
|
|
|
|
=/ args [tid.p.u.glob.old &]
|
|
|
|
:~ (leave-spider /(scot %uv hash.old) our.bowl)
|
|
|
|
(poke-spider /(scot %uv hash.old) our.bowl %spider-stop !>(args))
|
|
|
|
==
|
|
|
|
=^ init-cards this on-init
|
|
|
|
[(weld cancel-cards init-cards) this]
|
|
|
|
::
|
|
|
|
++ on-poke
|
|
|
|
|= [=mark =vase]
|
|
|
|
^- (quip card _this)
|
2020-07-18 02:58:28 +03:00
|
|
|
?+ mark (on-poke:def mark vase)
|
|
|
|
%glob-make
|
|
|
|
:_ this
|
|
|
|
=/ home=path /(scot %p our.bowl)/home/(scot %da now.bowl)
|
|
|
|
=+ .^(=tube:clay %cc (weld home /js/mime))
|
|
|
|
=+ .^(js=@t %cx (weld home /app/landscape/js/index/js))
|
|
|
|
=+ !<(=mime (tube !>(js)))
|
|
|
|
=/ =glob:glob (~(put by *glob:glob) /js mime)
|
|
|
|
=/ =path /(cat 3 'glob-' (scot %uv (sham glob)))/glob
|
|
|
|
[%pass /make %agent [our.bowl %hood] %poke %drum-put !>([path (jam glob)])]~
|
|
|
|
::
|
|
|
|
%noun
|
|
|
|
?: =(%kick q.vase)
|
|
|
|
(on-load !>(state(hash *@uv)))
|
|
|
|
(on-poke:def mark vase)
|
|
|
|
==
|
2020-07-15 22:26:55 +03:00
|
|
|
::
|
|
|
|
++ on-watch on-watch:def
|
|
|
|
++ on-leave on-leave:def
|
|
|
|
++ on-peek on-peek:def
|
|
|
|
++ on-agent
|
|
|
|
|= [=wire =sign:agent:gall]
|
|
|
|
^- (quip card _this)
|
|
|
|
?: ?=([%serving @ ~] wire)
|
|
|
|
(on-agent:def wire sign)
|
2020-07-18 02:58:28 +03:00
|
|
|
?: ?=([%make ~] wire)
|
|
|
|
(on-agent:def wire sign)
|
2020-07-15 22:26:55 +03:00
|
|
|
?. ?=([%running @ ~] wire)
|
|
|
|
%- (slog leaf+"glob: strange on-agent! {<wire -.sign>}" ~)
|
|
|
|
(on-agent:def wire sign)
|
|
|
|
?- -.sign
|
|
|
|
%poke-ack
|
|
|
|
?~ p.sign
|
|
|
|
[~ this]
|
|
|
|
%- (slog leaf+"glob: couldn't start thread; will retry" u.p.sign)
|
|
|
|
:_ this(glob.state ~) :_ ~
|
|
|
|
(leave-spider t.wire our.bowl)
|
|
|
|
::
|
|
|
|
%watch-ack
|
|
|
|
?~ p.sign
|
|
|
|
[~ this]
|
|
|
|
%- (slog leaf+"glob: couldn't listen to thread; will retry" u.p.sign)
|
|
|
|
[~ this(glob.state ~)]
|
|
|
|
::
|
|
|
|
%kick
|
|
|
|
=? glob.state ?=([~ %| *] glob.state)
|
|
|
|
~
|
|
|
|
`this
|
|
|
|
::
|
|
|
|
%fact
|
|
|
|
=/ produced-hash (slav %uv i.t.wire)
|
|
|
|
?. =(hash.state produced-hash)
|
|
|
|
[~ this]
|
|
|
|
?+ p.cage.sign (on-agent:def wire sign)
|
|
|
|
%thread-fail
|
|
|
|
=+ !<([=term =tang] q.cage.sign)
|
|
|
|
%- (slog leaf+"glob: thread failed; will retry" leaf+<term> tang)
|
|
|
|
[~ this(glob.state ~)]
|
|
|
|
::
|
|
|
|
%thread-done
|
|
|
|
=+ !<(=glob:glob q.cage.sign)
|
|
|
|
?. =(hash.state (sham glob))
|
|
|
|
%: mean
|
|
|
|
leaf+"glob: hash doesn't match!"
|
|
|
|
>expected=hash.state<
|
|
|
|
>got=(sham glob)<
|
|
|
|
~
|
|
|
|
==
|
|
|
|
:_ this(glob.state `[%& glob]) :_ ~
|
|
|
|
%+ poke-file-server our.bowl
|
2020-07-18 02:58:28 +03:00
|
|
|
[%file-server-action !>([%serve-glob serve-path glob %&])]
|
2020-07-15 22:26:55 +03:00
|
|
|
==
|
|
|
|
==
|
|
|
|
::
|
|
|
|
++ on-arvo
|
|
|
|
|= [=wire =sign-arvo]
|
|
|
|
^- (quip card _this)
|
2020-07-18 02:58:28 +03:00
|
|
|
?: ?=([%start ~] wire)
|
|
|
|
=/ new-tid=@ta (cat 3 'glob--' (scot %uv eny.bowl))
|
|
|
|
=/ args [~ `new-tid %glob !>([hash.state ~])]
|
|
|
|
=/ action !>([%unserve-dir serve-path])
|
|
|
|
:_ this(glob.state `[%| new-tid])
|
|
|
|
:~ (poke-file-server our.bowl %file-server-action action)
|
|
|
|
(wait-timeout /[new-tid] now.bowl)
|
|
|
|
(watch-spider /(scot %uv hash.state) our.bowl /thread-result/[new-tid])
|
|
|
|
(poke-spider /(scot %uv hash.state) our.bowl %spider-start !>(args))
|
|
|
|
==
|
2020-07-15 22:26:55 +03:00
|
|
|
?. ?=([%timer @ ~] wire)
|
|
|
|
%- (slog leaf+"glob: strange on-arvo wire: {<wire [- +<]:sign-arvo>}" ~)
|
|
|
|
`this
|
|
|
|
?. ?=(%wake +<.sign-arvo)
|
|
|
|
%- (slog leaf+"glob: strange on-arvo sign: {<wire [- +<]:sign-arvo>}" ~)
|
|
|
|
`this
|
|
|
|
?: ?=([~ %& *] glob.state)
|
|
|
|
`this
|
|
|
|
?. ?| ?=(~ glob.state)
|
|
|
|
=(i.t.wire tid.p.u.glob.state)
|
|
|
|
==
|
|
|
|
`this
|
|
|
|
?^ error.sign-arvo
|
|
|
|
%- (slog leaf+"glob: timer handling failed; will retry" ~)
|
2020-07-18 02:58:28 +03:00
|
|
|
[[(wait-timeout t.wire now.bowl)]~ this]
|
2020-07-15 22:26:55 +03:00
|
|
|
%- (slog leaf+"glob: timed out; retrying" ~)
|
|
|
|
(on-load !>(state(hash *@uv)))
|
|
|
|
::
|
|
|
|
++ on-fail on-fail:def
|
|
|
|
--
|