mirror of
https://github.com/ilyakooo0/urbit.git
synced 2024-12-01 11:33:41 +03:00
Moved some report-related parts of ++sh to be lowdown-oriented.
This commit is contained in:
parent
163c31d425
commit
718d88f3b7
@ -129,46 +129,6 @@
|
|||||||
::x produce moves or sole-effects and moves.
|
::x produce moves or sole-effects and moves.
|
||||||
[[id.cli %diff %sole-effect u.foc] moz]
|
[[id.cli %diff %sole-effect u.foc] moz]
|
||||||
::
|
::
|
||||||
++ ra-abet :: complete core
|
|
||||||
::x applies talk reports, then produces moves and updated state.
|
|
||||||
::
|
|
||||||
ra-abed:ra-axel
|
|
||||||
::
|
|
||||||
++ ra-axel :: rebound reports
|
|
||||||
::x extracts and applies the talk-reports in moves meant for our shells.
|
|
||||||
::
|
|
||||||
^+ .
|
|
||||||
::x separate talk-reports meant for our shells from other moves.
|
|
||||||
=+ ^= rey
|
|
||||||
|- ^- (pair (list move) (list (pair bone report)))
|
|
||||||
?~ moves
|
|
||||||
[~ ~]
|
|
||||||
=+ mor=$(moves t.moves)
|
|
||||||
::x if we know the target shell is ours, and it's a talk report,
|
|
||||||
::x add it to the list of reports to be locally applied.
|
|
||||||
?. ?& =(id.cli `bone`p.i.moves)
|
|
||||||
?=({$diff $talk-report *} q.i.moves)
|
|
||||||
==
|
|
||||||
[[i.moves p.mor] q.mor]
|
|
||||||
[p.mor [[p.i.moves +>.q.i.moves] q.mor]]
|
|
||||||
::x update moves to exclude our talk-reports.
|
|
||||||
=. moves p.rey
|
|
||||||
=. q.rey (flop q.rey)
|
|
||||||
?: =(q.rey ~) +
|
|
||||||
|- ^+ +>
|
|
||||||
?~ q.rey ra-axel
|
|
||||||
::x apply reports to our shells.
|
|
||||||
::TODO will this ever happen? yes: implement ra-back. no: delete sh-repo-*
|
|
||||||
=+ bak=(ra-back(ost.hid p.i.q.rey) q.i.q.rey)
|
|
||||||
$(q.rey t.q.rey, +> bak(ost.hid ost.hid))
|
|
||||||
::
|
|
||||||
++ ra-back
|
|
||||||
::x applies report.
|
|
||||||
::
|
|
||||||
|= rad/report
|
|
||||||
^+ +>
|
|
||||||
sh-abet:(~(sh-repo sh ~ cli) rad)
|
|
||||||
::
|
|
||||||
++ ra-diff-talk-lowdown
|
++ ra-diff-talk-lowdown
|
||||||
::x process a talk lowdown
|
::x process a talk lowdown
|
||||||
::
|
::
|
||||||
@ -236,16 +196,17 @@
|
|||||||
^+ +>
|
^+ +>
|
||||||
=+ tal=(~(get by tales) man)
|
=+ tal=(~(get by tales) man)
|
||||||
?~ tal ~&([%know-no-tale man] +>.$)
|
?~ tal ~&([%know-no-tale man] +>.$)
|
||||||
=. +>.$ sh-abet:(~(sh-repo-group-here sh ~ cli(p.owners locals.u.tal)) pes)
|
=. +>.$ sh-abet:(~(sh-low-precs sh ~ cli) locals.u.tal pes)
|
||||||
+>.$(tales (~(put by tales) man u.tal(locals pes)))
|
+>.$(tales (~(put by tales) man u.tal(locals pes)))
|
||||||
::
|
::
|
||||||
++ ra-diff-talk-lowdown-grams
|
++ ra-diff-talk-lowdown-grams
|
||||||
::x apply new grams
|
::x apply new grams
|
||||||
::
|
::
|
||||||
|= {man/knot num/@ud gams/(list telegram)}
|
|= {man/knot num/@ud gams/(list telegram)}
|
||||||
|
^+ +>
|
||||||
=+ tal=(~(get by tales) man)
|
=+ tal=(~(get by tales) man)
|
||||||
?~ tal ~&([%know-no-tale man] +>.$)
|
?~ tal ~&([%know-no-tale man] +>.$)
|
||||||
=. +>.$ sh-abet:(~(sh-repo-grams sh ~ cli) num gams)
|
=. +>.$ sh-abet:(~(sh-low-grams sh ~ cli) num gams)
|
||||||
pa-abet:(~(pa-lesson pa man u.tal) gams)
|
pa-abet:(~(pa-lesson pa man u.tal) gams)
|
||||||
::
|
::
|
||||||
++ ra-emil :: ra-emit move list
|
++ ra-emil :: ra-emit move list
|
||||||
@ -1027,6 +988,14 @@
|
|||||||
(weld pre "set {(scow %p p.i.cha.cul)} {(sh-spaz q.i.cha.cul)}")
|
(weld pre "set {(scow %p p.i.cha.cul)} {(sh-spaz q.i.cha.cul)}")
|
||||||
+>.$
|
+>.$
|
||||||
::
|
::
|
||||||
|
++ sh-low-precs
|
||||||
|
::x print presence changes
|
||||||
|
::
|
||||||
|
|= {old/atlas new/atlas}
|
||||||
|
^+ +>
|
||||||
|
=+ dif=(sh-repo-atlas-diff old new)
|
||||||
|
(sh-repo-group-diff-here "" dif)
|
||||||
|
::
|
||||||
++ sh-repo-group-here :: update local
|
++ sh-repo-group-here :: update local
|
||||||
::x updates local presence store and prints changes.
|
::x updates local presence store and prints changes.
|
||||||
::
|
::
|
||||||
@ -1077,7 +1046,7 @@
|
|||||||
=. +> (sh-repo-group-there q.ges)
|
=. +> (sh-repo-group-there q.ges)
|
||||||
+>
|
+>
|
||||||
::
|
::
|
||||||
++ sh-repo-gram
|
++ sh-low-gram
|
||||||
::x renders telegram: increase gram count and print the gram.
|
::x renders telegram: increase gram count and print the gram.
|
||||||
::x every fifth gram, prints the number.
|
::x every fifth gram, prints the number.
|
||||||
::
|
::
|
||||||
@ -1091,25 +1060,13 @@
|
|||||||
(sh-rend(count.she +(num)) gam)
|
(sh-rend(count.she +(num)) gam)
|
||||||
+>
|
+>
|
||||||
::
|
::
|
||||||
++ sh-repo-grams :: apply telegrams
|
++ sh-low-grams :: apply telegrams
|
||||||
::x renders telegrams.
|
::x renders telegrams.
|
||||||
::
|
::
|
||||||
|= {num/@ud gaz/(list telegram)}
|
|= {num/@ud gaz/(list telegram)}
|
||||||
^+ +>
|
^+ +>
|
||||||
?~ gaz +>
|
?~ gaz +>
|
||||||
$(gaz t.gaz, num +(num), +> (sh-repo-gram num i.gaz))
|
$(gaz t.gaz, num +(num), +> (sh-low-gram num i.gaz))
|
||||||
::
|
|
||||||
++ sh-repo :: apply report
|
|
||||||
::x applies the different kinds of reports using their handler arms above
|
|
||||||
::
|
|
||||||
|= rad/report
|
|
||||||
^+ +>
|
|
||||||
:: ~& [%sh-repo rad]
|
|
||||||
?- -.rad
|
|
||||||
$cabal (sh-repo-cabal +.rad)
|
|
||||||
$grams (sh-repo-grams +.rad)
|
|
||||||
$group (sh-repo-group +.rad)
|
|
||||||
==
|
|
||||||
::
|
::
|
||||||
++ sh-sane-chat :: sanitize chatter
|
++ sh-sane-chat :: sanitize chatter
|
||||||
::x (for chat messages) sanitizes the input buffer and splits it into
|
::x (for chat messages) sanitizes the input buffer and splits it into
|
||||||
|
Loading…
Reference in New Issue
Block a user