mirror of
https://github.com/urbit/shrub.git
synced 2025-01-04 18:43:46 +03:00
134 lines
3.2 KiB
Plaintext
134 lines
3.2 KiB
Plaintext
/- spider
|
|
/+ strandio, store=graph-store, gra=graph, graph-view, sig=signatures
|
|
=, strand=strand:spider
|
|
=>
|
|
|%
|
|
++ scry-graph
|
|
|= rid=resource:store
|
|
=/ m (strand ,graph:store)
|
|
^- form:m
|
|
;< =update:store bind:m
|
|
%+ scry:strandio update:store
|
|
/gx/graph-store/graph/(scot %p entity.rid)/[name.rid]/noun
|
|
?> ?=(%add-graph -.q.update)
|
|
(pure:m graph.q.update)
|
|
--
|
|
::
|
|
^- thread:spider
|
|
|= arg=vase
|
|
=/ m (strand:spider ,vase)
|
|
^- form:m
|
|
=+ !<([~ =update:store] arg)
|
|
?> ?=(%add-nodes -.q.update)
|
|
=* poke-our poke-our:strandio
|
|
;< =bowl:spider bind:m get-bowl:strandio
|
|
;< =graph:store bind:m (scry-graph resource.q.update)
|
|
|^
|
|
=. nodes.q.update
|
|
%- ~(gas by *(map index:store node:store))
|
|
%+ turn
|
|
(concat-by-parent (sort-nodes nodes.q.update))
|
|
add-hash-to-node
|
|
=/ hashes (nodes-to-pending-indices nodes.q.update)
|
|
;< ~ bind:m
|
|
%^ poke-our %graph-push-hook
|
|
%graph-update-2
|
|
!> ^- update:store
|
|
update
|
|
(pure:m !>(`action:graph-view`[%pending-indices hashes]))
|
|
::
|
|
++ sort-nodes
|
|
|= nodes=(map index:store node:store)
|
|
^- (list [index:store node:store])
|
|
%+ sort ~(tap by nodes)
|
|
|= [p=[=index:store *] q=[=index:store *]]
|
|
^- ?
|
|
(lth (lent index.p) (lent index.q))
|
|
::
|
|
++ concat-by-parent
|
|
|= lis=(list [index:store node:store])
|
|
^- (list [index:store node:store])
|
|
%~ tap by
|
|
%+ roll lis
|
|
|= $: [=index:store =node:store]
|
|
nds=(map index:store node:store)
|
|
==
|
|
?: ?=(~ index) !!
|
|
?: ?=([@ ~] index)
|
|
(~(put by nds) index node)
|
|
=/ ind (snip `(list atom)`index)
|
|
=/ nod (~(get by nds) ind)
|
|
?~ nod
|
|
(~(put by nds) index node)
|
|
=. children.u.nod
|
|
:- %graph
|
|
?: ?=(%empty -.children.u.nod)
|
|
%+ gas:orm:store *graph:store
|
|
[(rear index) node]~
|
|
%^ put:orm:store p.children.u.nod
|
|
(rear index)
|
|
node
|
|
(~(put by nds) ind u.nod)
|
|
::
|
|
++ add-hash-to-node
|
|
=| parent-hash=(unit hash:store)
|
|
|= [=index:store =node:store]
|
|
^- [index:store node:store]
|
|
=* loop $
|
|
:- index
|
|
?> ?=(%& -.post.node)
|
|
=* p p.post.node
|
|
=/ =hash:store
|
|
=- `@ux`(sham -)
|
|
:^ ?^ parent-hash
|
|
parent-hash
|
|
(index-to-parent-hash index)
|
|
author.p
|
|
time-sent.p
|
|
contents.p
|
|
%_ node
|
|
hash.p.post `hash
|
|
::
|
|
signatures.p.post
|
|
%- ~(gas in *signatures:store)
|
|
[(sign:sig our.bowl now.bowl hash)]~
|
|
::
|
|
children
|
|
?: ?=(%empty -.children.node)
|
|
children.node
|
|
:- %graph
|
|
%+ gas:orm:store *graph:store
|
|
%+ turn (tap:orm:store p.children.node)
|
|
|= [=atom =node:store]
|
|
=/ [* nod=node:store]
|
|
%_ loop
|
|
parent-hash `hash
|
|
index (snoc index atom)
|
|
node node
|
|
==
|
|
[atom nod]
|
|
==
|
|
::
|
|
++ index-to-parent-hash
|
|
|= =index:store
|
|
^- (unit hash:store)
|
|
?: ?=(~ index)
|
|
!!
|
|
?: ?=([@ ~] index)
|
|
~
|
|
=/ node (got-deep:gra graph (snip `(list atom)`index))
|
|
?> ?=(%& -.post.node)
|
|
hash.p.post.node
|
|
::
|
|
++ nodes-to-pending-indices
|
|
|= nodes=(map index:store node:store)
|
|
^- (map hash:store index:store)
|
|
%- ~(gas by *(map hash:store index:store))
|
|
%+ turn ~(tap by nodes)
|
|
|= [=index:store =node:store]
|
|
^- [hash:store index:store]
|
|
?> ?=(%& -.post.node)
|
|
?> ?=(^ hash.p.post.node)
|
|
[u.hash.p.post.node index]
|
|
--
|