mirror of
https://github.com/ilyakooo0/urbit.git
synced 2025-01-02 03:52:13 +03:00
1876 lines
61 KiB
Plaintext
1876 lines
61 KiB
Plaintext
::
|
|
:::: /hook/core/talk/app
|
|
::
|
|
/? 314
|
|
/- *talk, *twitter, *sole
|
|
/+ talk, sole
|
|
::
|
|
::::
|
|
::
|
|
!:
|
|
=> |% :: data structures
|
|
++ house ,[%1 house-1] :: full state
|
|
++ house-any :: app history
|
|
$% [%1 house-1] :: 1: talk
|
|
[%0 house-0] :: 0: initial version
|
|
== ::
|
|
++ house-1 ::
|
|
$: stories=(map span story) :: conversations
|
|
general=(set bone) :: meta-subscribe
|
|
outbox=(pair ,@ud (map ,@ud thought)) :: urbit outbox
|
|
folks=(map ship human) :: human identities
|
|
shells=(map bone shell) :: interaction state
|
|
== ::
|
|
++ house-0 :: legacy state
|
|
%+ map path ::
|
|
,[p=(list zong) q=(map ship ,?)] ::
|
|
:: ::
|
|
++ zong :: legacy messages
|
|
$% $: %mess p=@da q=ship ::
|
|
$= r ::
|
|
$% [%do p=@t] ::
|
|
[%exp p=@t q=tank] ::
|
|
[%say p=@t] ::
|
|
== == == ::
|
|
++ story :: wire content
|
|
$: count=@ud :: (lent grams)
|
|
grams=(list telegram) :: all history
|
|
locals=(map ship (pair ,@da status)) :: local presence
|
|
remotes=(map partner atlas) :: remote presence
|
|
mirrors=(map station config) :: remote config
|
|
sequence=(map partner ,@ud) :: partners heard
|
|
shape=config :: configuration
|
|
known=(map serial ,@ud) :: messages heard
|
|
guests=(map bone river) :: message followers
|
|
viewers=(set bone) :: presence followers
|
|
owners=(set bone) :: config followers
|
|
== ::
|
|
++ shell :: console session
|
|
$: her=ship :: client identity
|
|
man=span :: mailbox
|
|
count=@ud :: messages shown
|
|
say=sole-share :: console state
|
|
active=(unit (set partner)) :: active targets
|
|
passive=(set partner) :: passive targets
|
|
guests=register :: presence mirror
|
|
harbor=(map span (pair posture cord)) :: stations mirror
|
|
system=cabal :: config mirror
|
|
== ::
|
|
++ river (pair point point) :: stream definition
|
|
++ point :: stream endpoint
|
|
$% [%ud p=@ud] :: by number
|
|
[%da p=@da] :: by date
|
|
== ::
|
|
++ gift :: result
|
|
$% [%rush salt] :: refresh
|
|
[%mean ares] :: cancel
|
|
[%nice ~] :: accept
|
|
== ::
|
|
++ sign :: response
|
|
$% $: %e :: from %eyre
|
|
$% [%thou p=httr] :: HTTP response
|
|
== == ::
|
|
$: %g :: application
|
|
$% [%mean p=ares] :: cancel
|
|
[%nice ~] :: acknowledge
|
|
[%rush p=silt] :: subs data
|
|
== == ::
|
|
$: %t ::
|
|
$% [%wake ~] :: timer wakeup
|
|
== == == ::
|
|
++ salt :: output rush
|
|
$% [%talk-report p=report] ::
|
|
[%sole-effect p=sole-effect] ::
|
|
== ::
|
|
++ silt :: input rush
|
|
$% [%talk-report p=report] :: refresh
|
|
[%twit-stat p=twit-stat] :: tweet receipt
|
|
[%twit-feed p=(list twit-stat)] :: tweet receipt
|
|
== ::
|
|
++ move ,[p=bone q=(mold note gift)] :: all actions
|
|
++ hapt ,[p=ship q=path] :: app instance
|
|
++ note :: requests
|
|
$% $: %c ::
|
|
$% [%info p=@p q=@tas r=nori] ::
|
|
== == ::
|
|
$: %g :: network
|
|
$% [%mess p=hapt q=ship r=cage] :: message
|
|
[%nuke p=hapt q=ship] :: cancel
|
|
[%show p=hapt q=ship r=path] :: subscribe
|
|
[%took p=hapt q=ship] :: acknowledge
|
|
== == ::
|
|
$: %t ::
|
|
$% [%wait p=@da] ::
|
|
== == == ::
|
|
:: ::
|
|
++ work :: interface action
|
|
$% [%number p=? q=@ud] :: activate by number
|
|
[%join p=(set partner)] ::
|
|
[%say p=speech] ::
|
|
[%invite p=span q=(list partner)] ::
|
|
[%banish p=span q=(list partner)] ::
|
|
[%target p=(set partner)] :: set active targets
|
|
:: [%destroy p=span] ::
|
|
[%create p=posture q=span r=cord] ::
|
|
[%probe p=station] ::
|
|
== ::
|
|
:: ::
|
|
++ sigh :: assemble label
|
|
|= [len=@ud pre=tape yiz=cord]
|
|
^- tape
|
|
=+ nez=(trip yiz)
|
|
=+ lez=(lent nez)
|
|
?> (gth len (lent pre))
|
|
=. len (sub len (lent pre))
|
|
?. (gth lez len)
|
|
=. nez (welp pre nez)
|
|
?. (lth lez len) nez
|
|
(runt [(sub len lez) '-'] nez)
|
|
:(welp pre (scag (dec len) nez) "+")
|
|
--
|
|
|_ [hid=hide house]
|
|
++ ra :: transaction core
|
|
|_ [ost=bone moves=(list move)]
|
|
++ sh :: console interface
|
|
|_ $: coz=(list command) :: talk actions
|
|
she=shell
|
|
==
|
|
++ sh-scad :: command parser
|
|
=+ vag=(vang | [&1:% &2:% '0' |3:%])
|
|
=< work
|
|
|%
|
|
++ dare :: @dr
|
|
%+ sear
|
|
|= a=coin
|
|
?. ?=([%$ %dr @] a) ~
|
|
(some `@dr`+>.a)
|
|
nuck:so
|
|
::
|
|
++ ship ;~(pfix sig fed:ag) :: ship
|
|
++ shiz :: ship set
|
|
%+ cook
|
|
|=(a=(list ^ship) (~(gas in *(set ^ship)) a))
|
|
(most ;~(plug com (star ace)) ship)
|
|
::
|
|
++ pasp :: passport
|
|
;~ pfix pat
|
|
;~ pose
|
|
(stag %twitter ;~(pfix ;~(plug (jest 't') col) urs:ab))
|
|
==
|
|
==
|
|
::
|
|
++ stan :: station
|
|
;~ pose
|
|
(cold [our.hid man.she] tis)
|
|
;~(pfix cen (cook |=(a=term [our.hid a]) sym))
|
|
;~(pfix fas (cook |=(a=term [(sein our.hid) a]) sym))
|
|
::
|
|
%+ cook
|
|
|= [a=@p b=(unit term)]
|
|
[a ?^(b u.b (main a))]
|
|
;~ plug
|
|
ship
|
|
;~(pose (stag ~ ;~(pfix fas urs:ab)) (easy ~))
|
|
==
|
|
==
|
|
::
|
|
++ parn :: partner
|
|
;~ pose
|
|
(stag %& stan)
|
|
(stag %| pasp)
|
|
==
|
|
++ parq :: non-empty partners
|
|
%+ cook
|
|
|=(a=(list partner) (~(gas in *(set partner)) a))
|
|
(most ;~(plug com (star ace)) parn)
|
|
::
|
|
++ parz :: partner set
|
|
%+ cook
|
|
|=(a=(list partner) (~(gas in *(set partner)) a))
|
|
(more ;~(plug com (star ace)) parn)
|
|
::
|
|
++ nump :: number reference
|
|
;~ pose
|
|
(stag %& dem:ag)
|
|
(stag %| ;~(pfix (just '0') dem:ag))
|
|
==
|
|
::
|
|
++ pore :: posture
|
|
;~ pose
|
|
(cold %black (jest %channel))
|
|
(cold %white (jest %village))
|
|
(cold %green (jest %journal))
|
|
(cold %brown (jest %mailbox))
|
|
==
|
|
::
|
|
++ work
|
|
%+ knee *^work |. ~+
|
|
;~ pose
|
|
%+ stag %create
|
|
;~ pfix (jest %create)
|
|
;~ plug
|
|
;~(pfix ace pore)
|
|
;~(pfix ;~(plug ace cen) sym)
|
|
;~(pfix ace qut)
|
|
==
|
|
==
|
|
::
|
|
%+ stag %join
|
|
;~(pfix (jest %join) ;~(pfix ace parq))
|
|
::
|
|
(stag %number nump)
|
|
(stag %target parz)
|
|
==
|
|
--
|
|
++ sh-abet
|
|
^+ +>
|
|
=+ zoc=(flop coz)
|
|
|- ^+ +>+>
|
|
?~ zoc +>+>.$(shells (~(put by shells) ost she))
|
|
$(zoc t.zoc, +>.$ (sh-deal i.zoc))
|
|
::
|
|
++ sh-deal :: apply from shell
|
|
|= cod=command
|
|
^+ +>
|
|
?- -.cod
|
|
%design
|
|
?~ q.cod
|
|
=. +>+>.$ (ra-config p.cod *config)
|
|
+>.$(stories (~(del by stories) p.cod))
|
|
+>(+> (ra-config p.cod u.q.cod))
|
|
::
|
|
%review +>(+> (ra-think | her.she +.cod))
|
|
%publish +>(+> (ra-think & her.she +.cod))
|
|
==
|
|
::
|
|
++ sh-fact :: send console effect
|
|
|= fec=sole-effect
|
|
^+ +>
|
|
+>(moves :_(moves [ost %give %rush %sole-effect fec]))
|
|
::
|
|
++ sh-peep :: peer to path
|
|
|= pax=path
|
|
^+ +>
|
|
+>(+> (~(ra-subscribe ra ost ~) her.she pax))
|
|
::
|
|
++ sh-peer :: subscribe shell
|
|
=< sh-prod
|
|
%_ .
|
|
+>
|
|
%- ra-subscribe:(~(ra-subscribe ra ost ~) her.she ~)
|
|
[her.she [%afx man.she ~]]
|
|
==
|
|
::
|
|
++ sh-prod :: show prompt
|
|
^+ .
|
|
%+ sh-fact %pro
|
|
:+ & %talk-line
|
|
^- tape
|
|
=+ ^= rew ^- (pair (pair ,@t ,@t) (set partner))
|
|
?~ active.she
|
|
[['(' ')'] passive.she]
|
|
[['[' ']'] u.active.she]
|
|
=+ por=~(te-prom te man.she q.rew)
|
|
(weld `tape`[p.p.rew por] `tape`[q.p.rew ' ' ~])
|
|
::
|
|
++ sh-pact :: update active aud
|
|
|= lix=(set partner)
|
|
^+ +>
|
|
=+ act=?~(lix ~ `(sh-pare lix))
|
|
?: =(active.she act) +>.$
|
|
sh-prod(active.she act)
|
|
::
|
|
++ sh-pare :: adjust target list
|
|
|= paz=(set partner)
|
|
?: (sh-pear paz) paz
|
|
(~(put in paz) [%& our.hid man.she])
|
|
::
|
|
++ sh-pear :: hearback
|
|
|= paz=(set partner)
|
|
?~ paz |
|
|
?| $(paz l.paz)
|
|
$(paz r.paz)
|
|
(~(has in sources.shape:(~(got by stories) man.she)) `partner`n.paz)
|
|
==
|
|
::
|
|
++ sh-pass :: passive from aud
|
|
|= aud=audience
|
|
%- sh-poss
|
|
%- ~(gas in *(set partner))
|
|
(turn (~(tap by aud)) |=([a=partner *] a))
|
|
::
|
|
::
|
|
++ sh-poss :: passive update
|
|
|= lix=(set partner)
|
|
=+ sap=(sh-pare lix)
|
|
?: =(sap passive.she)
|
|
+>.$
|
|
sh-prod(passive.she sap)
|
|
::
|
|
++ sh-pest :: report listen
|
|
|= tay=partner
|
|
^+ +>
|
|
?. ?=(%& -.tay) +>
|
|
=+ sib=(~(get by ham.system.she) `station`p.tay)
|
|
?. |(?=(~ sib) !?=(%white p.cordon.u.sib))
|
|
+>.$
|
|
(sh-poss [tay ~ ~])
|
|
::
|
|
++ sh-rend :: print on one line
|
|
|= gam=telegram
|
|
(sh-pass:(sh-fact %txt ~(tr-line tr man.she gam)) q.q.gam)
|
|
::
|
|
++ sh-numb :: print msg number
|
|
|= num=@ud
|
|
^+ +>
|
|
=+ bun=(scow %ud num)
|
|
=+ pad=(sub 36 (lent bun))
|
|
=+ now=`@da`(dis lat.hid 0xffff.ffff.ffff.ffff.0000.0000.0000.0000)
|
|
%+ sh-fact %txt
|
|
"----------------| [{bun}] {(runt [pad ' '] (scow %da now))}"
|
|
::
|
|
++ sh-repo-house-diff
|
|
|= [one=shelf two=shelf]
|
|
=| $= ret
|
|
$: old=(list (pair span (pair posture cord)))
|
|
new=(list (pair span (pair posture cord)))
|
|
cha=(list (pair span (pair posture cord)))
|
|
==
|
|
^+ ret
|
|
=. ret
|
|
=+ eno=(~(tap by one))
|
|
|- ^+ ret
|
|
?~ eno ret
|
|
=. ret $(eno t.eno)
|
|
=+ unt=(~(get by two) p.i.eno)
|
|
?~ unt
|
|
ret(old [i.eno old.ret])
|
|
?: =(q.i.eno u.unt) ret
|
|
ret(cha [[p.i.eno u.unt] cha.ret])
|
|
=. ret
|
|
=+ owt=(~(tap by two))
|
|
|- ^+ ret
|
|
?~ owt ret
|
|
=. ret $(owt t.owt)
|
|
?: (~(has by one) p.i.owt)
|
|
ret
|
|
ret(new [i.owt new.ret])
|
|
ret
|
|
::
|
|
++ sh-repo-atlas-diff
|
|
|= [one=atlas two=atlas]
|
|
=| $= ret
|
|
$: old=(list (pair ship status))
|
|
new=(list (pair ship status))
|
|
cha=(list (pair ship status))
|
|
==
|
|
^+ ret
|
|
=. ret
|
|
=+ eno=(~(tap by one))
|
|
|- ^+ ret
|
|
?~ eno ret
|
|
=. ret $(eno t.eno)
|
|
=+ unt=(~(get by two) p.i.eno)
|
|
?~ unt
|
|
ret(old [i.eno old.ret])
|
|
?: =(q.i.eno u.unt) ret
|
|
ret(cha [[p.i.eno u.unt] cha.ret])
|
|
=. ret
|
|
=+ owt=(~(tap by two))
|
|
|- ^+ ret
|
|
?~ owt ret
|
|
=. ret $(owt t.owt)
|
|
?: (~(has by one) p.i.owt)
|
|
ret
|
|
ret(new [i.owt new.ret])
|
|
ret
|
|
::
|
|
++ sh-repo-cabal-diff
|
|
|= [one=(map station config) two=(map station config)]
|
|
=| $= ret
|
|
$: old=(list (pair station config))
|
|
new=(list (pair station config))
|
|
cha=(list (pair station config))
|
|
==
|
|
^+ ret
|
|
=. ret
|
|
=+ eno=(~(tap by one))
|
|
|- ^+ ret
|
|
?~ eno ret
|
|
=. ret $(eno t.eno)
|
|
=+ unt=(~(get by two) p.i.eno)
|
|
?~ unt
|
|
ret(old [i.eno old.ret])
|
|
?: =(q.i.eno u.unt) ret
|
|
ret(cha [[p.i.eno u.unt] cha.ret])
|
|
=. ret
|
|
=+ owt=(~(tap by two))
|
|
|- ^+ ret
|
|
?~ owt ret
|
|
=. ret $(owt t.owt)
|
|
?: (~(has by one) p.i.owt)
|
|
ret
|
|
ret(new [i.owt new.ret])
|
|
ret
|
|
::
|
|
++ sh-repo-rogue-diff
|
|
|= [one=(map partner atlas) two=(map partner atlas)]
|
|
=| $= ret
|
|
$: old=(list (pair partner atlas))
|
|
new=(list (pair partner atlas))
|
|
cha=(list (pair partner atlas))
|
|
==
|
|
^+ ret
|
|
=. ret
|
|
=+ eno=(~(tap by one))
|
|
|- ^+ ret
|
|
?~ eno ret
|
|
=. ret $(eno t.eno)
|
|
=+ unt=(~(get by two) p.i.eno)
|
|
?~ unt
|
|
ret(old [i.eno old.ret])
|
|
?: =(q.i.eno u.unt) ret
|
|
ret(cha [[p.i.eno u.unt] cha.ret])
|
|
=. ret
|
|
=+ owt=(~(tap by two))
|
|
|- ^+ ret
|
|
?~ owt ret
|
|
=. ret $(owt t.owt)
|
|
?: (~(has by one) p.i.owt)
|
|
ret
|
|
ret(new [i.owt new.ret])
|
|
ret
|
|
::
|
|
++ sh-repo-whom-diff
|
|
|= [one=(set partner) two=(set partner)]
|
|
=| $= ret
|
|
$: old=(list partner)
|
|
new=(list partner)
|
|
==
|
|
^+ ret
|
|
=. ret
|
|
=+ eno=(~(tap by one))
|
|
|- ^+ ret
|
|
?~ eno ret
|
|
=. ret $(eno t.eno)
|
|
?: (~(has in two) i.eno)
|
|
ret
|
|
ret(old [i.eno old.ret])
|
|
=. ret
|
|
=+ owt=(~(tap by two))
|
|
|- ^+ ret
|
|
?~ owt ret
|
|
=. ret $(owt t.owt)
|
|
?: (~(has in one) i.owt)
|
|
ret
|
|
ret(new [i.owt new.ret])
|
|
ret
|
|
::
|
|
++ sh-repo-ship-diff
|
|
|= [one=(set ship) two=(set ship)]
|
|
=| $= ret
|
|
$: old=(list ship)
|
|
new=(list ship)
|
|
==
|
|
^+ ret
|
|
=. ret
|
|
=+ eno=(~(tap by one))
|
|
|- ^+ ret
|
|
?~ eno ret
|
|
=. ret $(eno t.eno)
|
|
?: (~(has in two) i.eno)
|
|
ret
|
|
ret(old [i.eno old.ret])
|
|
=. ret
|
|
=+ owt=(~(tap by two))
|
|
|- ^+ ret
|
|
?~ owt ret
|
|
=. ret $(owt t.owt)
|
|
?: (~(has in one) i.owt)
|
|
ret
|
|
ret(new [i.owt new.ret])
|
|
ret
|
|
::
|
|
++ sh-puss
|
|
|= a=posture ^- tape
|
|
?- a
|
|
%black "channel"
|
|
%brown "mailbox"
|
|
%white "village"
|
|
%green "journal"
|
|
==
|
|
::
|
|
++ sh-repo-config-exceptions
|
|
|= [pre=tape por=posture old=(list ship) new=(list ship)]
|
|
=+ out=?:(?=(?(%black %brown) por) "try " "cut ")
|
|
=+ inn=?:(?=(?(%black %brown) por) "ban " "add ")
|
|
=. +>.$
|
|
|- ^+ +>.^$
|
|
?~ old +>.^$
|
|
=. +>.^$ $(old t.old)
|
|
(sh-note :(weld pre out " " (scow %p i.old)))
|
|
=. +>.$
|
|
|- ^+ +>.^$
|
|
?~ new +>.^$
|
|
=. +>.^$ $(new t.new)
|
|
(sh-note :(weld pre out " " (scow %p i.new)))
|
|
+>.$
|
|
::
|
|
++ sh-repo-config-sources
|
|
|= [pre=tape old=(list partner) new=(list partner)]
|
|
^+ +>
|
|
=. +>.$
|
|
|- ^+ +>.^$
|
|
?~ old +>.^$
|
|
=. +>.^$ $(old t.old)
|
|
(sh-note (weld pre "off {~(ta-full ta man.she i.old)}"))
|
|
=. +>.$
|
|
|- ^+ +>.^$
|
|
?~ new +>.^$
|
|
=. +>.^$ $(new t.new)
|
|
(sh-note (weld pre "hey {~(ta-full ta man.she i.new)}"))
|
|
+>.$
|
|
::
|
|
++ sh-repo-config-show
|
|
|= [pre=tape laz=config loc=config]
|
|
^+ +>
|
|
=. +>.$
|
|
?: =(caption.loc caption.laz) +>.$
|
|
(sh-note :(weld pre "cap " (trip caption.loc)))
|
|
=. +>.$
|
|
%+ sh-repo-config-sources
|
|
(weld (trip man.she) ": ")
|
|
(sh-repo-whom-diff sources.laz sources.loc)
|
|
?: !=(p.cordon.loc p.cordon.laz)
|
|
=. +>.$ (sh-note :(weld pre "but " (sh-puss p.cordon.loc)))
|
|
%^ sh-repo-config-exceptions
|
|
(weld (trip man.she) ": ")
|
|
p.cordon.loc
|
|
[~ (~(tap in q.cordon.loc))]
|
|
%^ sh-repo-config-exceptions
|
|
(weld (trip man.she) ": ")
|
|
p.cordon.loc
|
|
(sh-repo-ship-diff q.cordon.laz q.cordon.loc)
|
|
::
|
|
++ sh-repo-cabal-changes
|
|
|= $: laz=(map station config)
|
|
old=(list (pair station config))
|
|
new=(list (pair station config))
|
|
cha=(list (pair station config))
|
|
==
|
|
=. +>.$
|
|
|- ^+ +>.^$
|
|
?~ new +>.^$
|
|
=. +>.^$ $(new t.new)
|
|
=. +>.^$ (sh-pest [%& p.i.new])
|
|
%+ sh-repo-config-show
|
|
(weld ~(sn-phat sn man.she p.i.new) ": ")
|
|
[*config q.i.new]
|
|
=. +>.$
|
|
|- ^+ +>.^$
|
|
?~ cha +>.^$
|
|
=. +>.^$ $(cha t.cha)
|
|
%+ sh-repo-config-show
|
|
(weld ~(sn-phat sn man.she p.i.cha) ": ")
|
|
[(~(got by laz) `station`p.i.cha) q.i.cha]
|
|
+>.$
|
|
::
|
|
++ sh-repo-cabal
|
|
|= bal=cabal
|
|
^+ +>
|
|
=+ laz=system.she
|
|
=. system.she bal
|
|
=. +>.$
|
|
%+ sh-repo-cabal-changes ham.laz
|
|
(sh-repo-cabal-diff ham.laz ham.bal)
|
|
(sh-repo-config-show "" loc.laz loc.bal)
|
|
::
|
|
++ sh-repo-house
|
|
|= awl=(map span (pair posture cord))
|
|
^+ +>
|
|
=+ dif=(sh-repo-house-diff harbor.she awl)
|
|
=. harbor.she awl
|
|
=. +>.$
|
|
|- ^+ +>.^$
|
|
?~ old.dif +>.^$
|
|
=. +>.^$ $(old.dif t.old.dif)
|
|
(sh-note "cut {(sh-puss p.q.i.old.dif)} %{(trip p.i.old.dif)}")
|
|
=. +>.$
|
|
|- ^+ +>.^$
|
|
?~ new.dif +>.^$
|
|
=. +>.^$ $(new.dif t.new.dif)
|
|
=+ :* nam=(trip p.i.new.dif)
|
|
por=(sh-puss p.q.i.new.dif)
|
|
des=(trip q.q.i.new.dif)
|
|
==
|
|
(sh-note "new {por} %{nam}: {des}")
|
|
=. +>.$
|
|
|- ^+ +>.^$
|
|
?~ cha.dif +>.^$
|
|
=. +>.^$ $(cha.dif t.cha.dif)
|
|
=+ :* nam=(trip p.i.cha.dif)
|
|
por=(sh-puss p.q.i.cha.dif)
|
|
des=(trip q.q.i.cha.dif)
|
|
==
|
|
(sh-note "mod %{nam}: {por}, {des}")
|
|
+>.$
|
|
::
|
|
++ sh-note :: shell message
|
|
|= txt=tape
|
|
^+ +>
|
|
(sh-fact %txt (runt [16 '-'] `tape`['|' ' ' (scag 62 txt)]))
|
|
::
|
|
++ sh-spaz :: print status
|
|
|= saz=status
|
|
^- tape
|
|
['%' (trip p.saz)]
|
|
::
|
|
++ sh-repo-group-diff-here :: print atlas diff
|
|
|= $: pre=tape
|
|
$= cul
|
|
$: old=(list (pair ship status))
|
|
new=(list (pair ship status))
|
|
cha=(list (pair ship status))
|
|
==
|
|
==
|
|
=. +>.$
|
|
|- ^+ +>.^$
|
|
?~ old.cul +>.^$
|
|
=. +>.^$ $(old.cul t.old.cul)
|
|
(sh-note (weld pre "bye {(scow %p p.i.old.cul)}"))
|
|
=. +>.$
|
|
|- ^+ +>.^$
|
|
?~ new.cul +>.^$
|
|
=. +>.^$ $(new.cul t.new.cul)
|
|
%- sh-note
|
|
(weld pre "met {(scow %p p.i.new.cul)} {(sh-spaz q.i.new.cul)}")
|
|
=. +>.$
|
|
|- ^+ +>.^$
|
|
?~ cha.cul +>.^$
|
|
%- sh-note
|
|
(weld pre "set {(scow %p p.i.cha.cul)} {(sh-spaz q.i.cha.cul)}")
|
|
+>.$
|
|
::
|
|
++ sh-repo-group-here :: update local
|
|
|= loc=atlas
|
|
^+ +>
|
|
=+ cul=(sh-repo-atlas-diff p.guests.she loc)
|
|
=. p.guests.she loc
|
|
(sh-repo-group-diff-here "" cul)
|
|
::
|
|
++ sh-repo-group-there :: update foreign
|
|
|= yid=(map partner atlas)
|
|
=+ day=(sh-repo-rogue-diff q.guests.she yid)
|
|
=+ dun=q.guests.she
|
|
=. q.guests.she yid
|
|
=. +>.$
|
|
|- ^+ +>.^$
|
|
?~ old.day +>.^$
|
|
=. +>.^$ $(old.day t.old.day)
|
|
(sh-note (weld "not " (~(ta-show ta man.she p.i.old.day) ~)))
|
|
=. +>.$
|
|
|- ^+ +>.^$
|
|
?~ new.day +>.^$
|
|
=. +>.^$ $(new.day t.new.day)
|
|
=. +>.^$
|
|
(sh-note (weld "new " (~(ta-show ta man.she p.i.new.day) ~)))
|
|
(sh-repo-group-diff-here "--" ~ (~(tap by q.i.new.day)) ~)
|
|
=. +>.$
|
|
|- ^+ +>.^$
|
|
?~ cha.day +>.^$
|
|
=. +>.^$ $(cha.day t.cha.day)
|
|
=. +>.^$
|
|
(sh-note (weld "for " (~(ta-show ta man.she p.i.cha.day) ~)))
|
|
=+ yez=(~(got by dun) p.i.cha.day)
|
|
%+ sh-repo-group-diff-here "--"
|
|
(sh-repo-atlas-diff yez q.i.cha.day)
|
|
+>.$
|
|
::
|
|
++ sh-repo-group
|
|
|= ges=register
|
|
^+ +>
|
|
=. +> (sh-repo-group-here p.ges)
|
|
=. +> (sh-repo-group-there q.ges)
|
|
+>
|
|
::
|
|
++ sh-repo-gram
|
|
|= [num=@ud gam=telegram]
|
|
^+ +>
|
|
?: =(num count.she)
|
|
=. +> ?:(=(0 (mod num 5)) (sh-numb num) +>)
|
|
(sh-rend(count.she +(num)) gam)
|
|
?: (gth num count.she)
|
|
=. +> (sh-numb num)
|
|
(sh-rend(count.she +(num)) gam)
|
|
+>
|
|
::
|
|
++ sh-repo-grams :: apply telegrams
|
|
|= [num=@ud gaz=(list telegram)]
|
|
^+ +>
|
|
?~ gaz +>
|
|
$(gaz t.gaz, num +(num), +> (sh-repo-gram num i.gaz))
|
|
::
|
|
++ sh-repo :: apply report
|
|
|= rad=report
|
|
^+ +>
|
|
:: ~& [%sh-repo rad]
|
|
?- -.rad
|
|
%cabal (sh-repo-cabal +.rad)
|
|
%grams (sh-repo-grams +.rad)
|
|
%group (sh-repo-group +.rad)
|
|
%house (sh-repo-house +.rad)
|
|
==
|
|
::
|
|
++ sh-sane-chat :: sanitize chatter
|
|
|= buf=(list ,@c)
|
|
^- (list sole-edit)
|
|
=+ :- inx=0
|
|
^= fix
|
|
|= [inx=@ud cha=@t lit=(list sole-edit)]
|
|
^+ lit
|
|
[[%mor [%del inx] [%ins inx `@c`cha] ~] lit]
|
|
|- ^- (list sole-edit)
|
|
?: =(62 inx)
|
|
|- ^- (list sole-edit)
|
|
?~(buf ~ [[%del 62] $(buf t.buf)])
|
|
?~ buf ~
|
|
=+ lit=$(inx +(inx), buf t.buf)
|
|
?: |((lth i.buf 32) (gth i.buf 126))
|
|
(fix inx '?' lit)
|
|
?: &((gte i.buf 'A') (lte i.buf 'Z'))
|
|
(fix inx (add 32 i.buf) lit)
|
|
:: ?: &(=('/' i.buf) ?=([47 *] t.buf))
|
|
:: (fix inx '\\' lit)
|
|
lit
|
|
::
|
|
++ sh-sane-rule :: sanitize by rule
|
|
|* sef=_rule
|
|
|= [inv=sole-edit txt=tape]
|
|
^- (list sole-edit)
|
|
=+ ryv=(rose txt sef)
|
|
?:(-.ryv ~ [inv ~])
|
|
::
|
|
++ sh-sane :: sanitize input
|
|
|= [inv=sole-edit buf=(list ,@c)]
|
|
^- (list sole-edit)
|
|
?~ buf ~
|
|
?: =(';' i.buf)
|
|
((sh-sane-rule sh-scad) inv (tufa t.buf))
|
|
?: =('@' i.buf)
|
|
(sh-sane-chat +.buf)
|
|
(sh-sane-chat buf)
|
|
::
|
|
++ sh-slug :: edit to sanity
|
|
|= lit=(list sole-edit)
|
|
^+ +>
|
|
?~ lit +>
|
|
=^ lic say.she
|
|
(~(transmit cs say.she) `sole-edit`?~(t.lit i.lit [%mor lit]))
|
|
(sh-fact [%mor [%det lic] ~])
|
|
::
|
|
++ sh-stir :: apply edit
|
|
|= cal=sole-change
|
|
^+ +>
|
|
=^ inv say.she (~(transceive cs say.she) cal)
|
|
=+ lit=(sh-sane inv buf.say.she)
|
|
?~ lit
|
|
+>.$
|
|
(sh-slug lit)
|
|
::
|
|
++ sh-pork :: parse work
|
|
^- (unit work)
|
|
?~ buf.say.she ~
|
|
?: =(';' -.buf.say.she)
|
|
(rust (tufa +.buf.say.she) sh-scad)
|
|
?: =('@' -.buf.say.she)
|
|
`[%say %lin | (crip (tufa +.buf.say.she))]
|
|
`[%say %lin & (crip (tufa buf.say.she))]
|
|
::
|
|
++ sh-lame :: send error
|
|
|= txt=tape
|
|
(sh-fact [%txt txt])
|
|
::
|
|
++ sh-whom :: current audience
|
|
^- audience
|
|
%- ~(gas by *audience)
|
|
%+ turn (~(tap in ?~(active.she passive.she u.active.she)))
|
|
|=(a=partner [a *envelope %pending])
|
|
::
|
|
++ sh-tell :: add command
|
|
|= cod=command
|
|
%_(+> coz [cod coz])
|
|
::
|
|
++ sh-work :: do work
|
|
|= job=work
|
|
^+ +>
|
|
=+ roy=(~(got by stories) man.she)
|
|
=< work
|
|
|%
|
|
++ work
|
|
?- -.job
|
|
%number (number +.job)
|
|
%join (join +.job)
|
|
%invite (invite +.job)
|
|
%banish (banish +.job)
|
|
%create (create +.job)
|
|
%target (target +.job)
|
|
%probe (probe +.job)
|
|
%say (say +.job)
|
|
==
|
|
::
|
|
++ activate :: from %number
|
|
|= gam=telegram
|
|
^+ +>+>+>
|
|
~& [%activate gam]
|
|
sh-prod(active.she `~(tr-pals tr man.she gam))
|
|
::
|
|
++ join :: %join
|
|
|= lix=(set partner)
|
|
^+ +>+>+>
|
|
=+ loc=loc.system.she
|
|
%^ sh-tell %design man.she
|
|
:- ~
|
|
=+ tal=(~(tap in lix))
|
|
%_ loc
|
|
sources
|
|
|- ^- (set partner)
|
|
?~ tal sources.loc
|
|
?: (~(has in sources.loc) i.tal)
|
|
$(tal t.tal, sources.loc (~(del in sources.loc) i.tal))
|
|
$(tal t.tal, sources.loc (~(put in sources.loc) i.tal))
|
|
==
|
|
::
|
|
++ invite :: %invite
|
|
|= [nom=span tal=(list partner)]
|
|
^+ +>+>+>
|
|
!!
|
|
::
|
|
++ banish :: %banish
|
|
|= [nom=span tal=(list partner)]
|
|
^+ +>+>+>
|
|
!!
|
|
::
|
|
++ create :: %create
|
|
|= [por=posture nom=span txt=cord]
|
|
^+ +>+>+>
|
|
?: (~(has in stories) nom)
|
|
(sh-lame "{(trip nom)}: already exists")
|
|
=. +>+>+>
|
|
%^ sh-tell %design nom
|
|
:- ~
|
|
:+ *(set partner)
|
|
(end 3 62 txt)
|
|
[por ~]
|
|
(join [[%& our.hid nom] ~ ~])
|
|
::
|
|
++ target :: %target
|
|
|= lix=(set partner)
|
|
(sh-pact lix)
|
|
::
|
|
++ number :: %number
|
|
|= [rel=? num=@ud]
|
|
^+ +>+>+>
|
|
=+ roy=(~(got by stories) man.she)
|
|
=. num
|
|
?. rel num
|
|
=+ dog=|-(?:(=(0 num) 1 (mul 10 $(num (div num 10)))))
|
|
(add num (mul dog (div count.roy dog)))
|
|
?: (gte num count.roy)
|
|
(sh-lame "{(scow %ud num)}: no such telegram")
|
|
(activate (snag (sub count.roy +(num)) grams.roy))
|
|
::
|
|
++ probe :: inquire
|
|
|= cuz=station
|
|
^+ +>+>+>
|
|
~& [%probe cuz]
|
|
+>+>+>
|
|
::
|
|
++ say :: publish
|
|
|= sep=speech
|
|
^+ +>+>+>
|
|
=^ sir +>+>+> sh-uniq
|
|
%= +>+>+>.$
|
|
coz :_ coz
|
|
[%publish [[sir sh-whom [lat.hid ~ sep]] ~]]
|
|
==
|
|
--
|
|
::
|
|
++ sh-done :: apply result
|
|
=+ lit=(sh-sane [%nop ~] buf.say.she)
|
|
?^ lit
|
|
(sh-slug lit)
|
|
=+ jub=sh-pork
|
|
?~ jub (sh-fact %bel ~)
|
|
=. +> (sh-work u.jub)
|
|
=+ buf=buf.say.she
|
|
=^ cal say.she (~(transmit cs say.she) [%set ~])
|
|
%- sh-fact
|
|
:* %mor
|
|
[%nex ~]
|
|
[%det cal]
|
|
?. ?=([%';' *] buf) ~
|
|
:_ ~
|
|
[%txt (weld "----------------| " (tufa buf))]
|
|
==
|
|
::
|
|
++ sh-sole :: apply edit
|
|
|= act=sole-action
|
|
^+ +>
|
|
?- -.act
|
|
%det (sh-stir +.act)
|
|
%ret sh-done
|
|
==
|
|
::
|
|
++ sh-uniq
|
|
^- [serial _.]
|
|
[(shaf %serial eny.hid) .(eny.hid (shax eny.hid))]
|
|
--
|
|
++ ra-abed :: resolve core
|
|
^- [(list move) _+>]
|
|
:_ +>
|
|
=+ ^= yop
|
|
|- ^- (pair (list move) (list sole-effect))
|
|
?~ moves [~ ~]
|
|
=+ mor=$(moves t.moves)
|
|
?: ?& =(ost p.i.moves)
|
|
?=([%give %rush %sole-effect *] q.i.moves)
|
|
==
|
|
[p.mor [+>+.q.i.moves q.mor]]
|
|
[[i.moves p.mor] q.mor]
|
|
=+ :* moz=(flop p.yop)
|
|
^= foc ^- (unit sole-effect)
|
|
?~ q.yop ~
|
|
?~(t.q.yop `i.q.yop `[%mor (flop `(list sole-effect)`q.yop)])
|
|
==
|
|
?~(foc moz [[ost %give %rush %sole-effect u.foc] moz])
|
|
::
|
|
++ ra-abet :: complete core
|
|
ra-abed:ra-axel
|
|
::
|
|
++ ra-axel :: rebound reports
|
|
^+ .
|
|
=+ ^= rey
|
|
|- ^- (pair (list move) (list (pair bone report)))
|
|
?~ moves
|
|
[~ ~]
|
|
=+ mor=$(moves t.moves)
|
|
?. ?& (~(has by shells) `bone`p.i.moves)
|
|
?=([%give %rush %talk-report *] q.i.moves)
|
|
==
|
|
[[i.moves p.mor] q.mor]
|
|
[p.mor [[p.i.moves +>+.q.i.moves] q.mor]]
|
|
=. moves p.rey
|
|
?: =(q.rey ~) +
|
|
=. q.rey (flop q.rey)
|
|
|- ^+ +>
|
|
?~ q.rey ra-axel
|
|
$(q.rey t.q.rey, +> (ra-back(ost p.i.q.rey) q.i.q.rey))
|
|
::
|
|
++ ra-back
|
|
|= rad=report
|
|
^+ +>
|
|
sh-abet:(~(sh-repo sh ~ (~(got by shells) ost)) rad)
|
|
::
|
|
++ ra-sole
|
|
|= act=sole-action
|
|
^+ +>
|
|
=+ shu=(~(get by shells) ost)
|
|
?~ shu
|
|
~& [%ra-console-broken ost]
|
|
+>.$
|
|
sh-abet:(~(sh-sole sh ~ (~(got by shells) ost)) act)
|
|
::
|
|
++ ra-emil :: ra-emit move list
|
|
|= mol=(list move)
|
|
%_(+> moves (welp (flop mol) moves))
|
|
::
|
|
++ ra-emit :: emit a move
|
|
|= mov=move
|
|
%_(+> moves [mov moves])
|
|
::
|
|
++ ra-ever :: emit success
|
|
(ra-emit ost %give %nice ~)
|
|
::
|
|
++ ra-evil :: emit error
|
|
|= msg=cord
|
|
~& [%ra-evil msg]
|
|
(ra-emit ost %give %mean ~ msg ~)
|
|
:: (ra-emit ost %give %nice ~)
|
|
::
|
|
++ ra-house :: emit partners
|
|
|= ost=bone
|
|
%+ ra-emit ost
|
|
:^ %give %rush %talk-report
|
|
:- %house
|
|
%- ~(gas in *(map span (pair posture cord)))
|
|
%+ turn (~(tap by stories))
|
|
|=([a=span b=story] [a p.cordon.shape.b caption.shape.b])
|
|
::
|
|
++ ra-homes :: update partners
|
|
=+ gel=general
|
|
|- ^+ +>
|
|
?~ gel +>
|
|
=. +> $(gel l.gel)
|
|
=. +> $(gel r.gel)
|
|
(ra-house n.gel)
|
|
::
|
|
++ ra-init :: initialize talk
|
|
%+ ra-apply our.hid
|
|
:+ %design (main our.hid)
|
|
:- ~ :- ~
|
|
:- 'default home'
|
|
[%brown ~]
|
|
::
|
|
++ ra-apply :: apply command
|
|
|= [her=ship cod=command]
|
|
^+ +>
|
|
?- -.cod
|
|
%design
|
|
?. =(her our.hid)
|
|
(ra-evil %talk-no-owner)
|
|
?~ q.cod
|
|
?. (~(has by stories) p.cod)
|
|
(ra-evil %talk-no-story)
|
|
=. +>.$ (ra-config p.cod *config)
|
|
ra-ever(stories (~(del by stories) p.cod))
|
|
=. +>.$ (ra-config p.cod u.q.cod)
|
|
ra-ever
|
|
::
|
|
%review ra-ever:(ra-think | her +.cod)
|
|
%publish ra-ever:(ra-think & her +.cod)
|
|
==
|
|
::
|
|
++ ra-config :: configure story
|
|
|= [man=span con=config]
|
|
^+ +>
|
|
=+ :- neu=(~(has by stories) man)
|
|
pur=(fall (~(get by stories) man) *story)
|
|
=. +>.$ pa-abet:(~(pa-reform pa man pur) con)
|
|
?:(neu +>.$ ra-homes)
|
|
::
|
|
++ ra-friend :: %friend response
|
|
|= [man=span tay=partner sih=sign]
|
|
^+ +>
|
|
=+ pur=(~(get by stories) man)
|
|
?~ pur ~& [%ra-friend-none man] +>.$
|
|
pa-abet:(~(pa-friend pa man u.pur) tay sih)
|
|
::
|
|
++ ra-twitter :: %twitter response
|
|
|= [[num=@ud man=span] sih=sign]
|
|
^+ +>
|
|
?+ sih ~|([%talk-bad-twitter sih] !!)
|
|
[%g ?(%nice %mean) ~]
|
|
+>
|
|
[%g %mean ^]
|
|
(ra-repeat num [%| %twitter man] sih)
|
|
[%g %rush %twit-stat *]
|
|
(ra-repeat num [%| %twitter man] [%g %nice ~])
|
|
==
|
|
::
|
|
++ ra-repeat :: %repeat response
|
|
|= [num=@ud pan=partner sih=sign]
|
|
=+ oot=(~(get by q.outbox) num)
|
|
?~ oot ~& [%ra-repeat-none num] +>.$
|
|
=. q.outbox (~(del by q.outbox) num)
|
|
=. q.u.oot
|
|
=+ olg=(~(got by q.u.oot) pan)
|
|
%+ ~(put by q.u.oot) pan
|
|
:- -.olg
|
|
?+ sih !!
|
|
[%g %mean *] ~&([%talk-repeat-rejected num pan sih] %rejected)
|
|
[%g %nice ~] %received
|
|
==
|
|
(ra-think | our.hid u.oot ~)
|
|
::
|
|
++ ra-cancel :: drop a bone
|
|
^+ .
|
|
=+ hep=(~(get by sup.hid) ost)
|
|
?~ hep +
|
|
?. ?=([@ @ *] q.u.hep)
|
|
+(general (~(del in general) ost))
|
|
=* man i.t.q.u.hep
|
|
=+ pur=(~(get by stories) man)
|
|
?~ pur +>
|
|
pa-abet:(pa-notify:~(pa-cancel pa man u.pur) p.u.hep %gone *human)
|
|
::
|
|
++ ra-human :: look up person
|
|
|= her=ship
|
|
^- [human _+>]
|
|
=^ who folks
|
|
=+ who=(~(get by folks) her)
|
|
?^ who [u.who folks]
|
|
=+ who=`human`[~ `(scot %p her)] :: XX do right
|
|
[who (~(put by folks) her who)]
|
|
[who +>.$]
|
|
::
|
|
++ ra-console :: console subscribe
|
|
|= [her=ship pax=path]
|
|
^+ +>
|
|
=+ man=`span`?~(pax (main her) ?>(?=(~ t.pax) i.pax))
|
|
=+ ^= she ^- shell
|
|
[her man 0 *sole-share ~ [[%& our.hid man] ~ ~] [~ ~] ~ *cabal]
|
|
sh-abet:~(sh-peer sh ~ she)
|
|
::
|
|
++ ra-subscribe :: listen to
|
|
|= [her=ship pax=path]
|
|
^+ +>
|
|
:: ~& [%ra-subscribe ost her pax]
|
|
?: ?=(~ pax)
|
|
(ra-house(general (~(put in general) ost)) ost)
|
|
?. ?=([@ @ *] pax)
|
|
(ra-evil %talk-bad-path)
|
|
=+ ^= vab ^- (set ,@tas)
|
|
=| vab=(set ,@tas)
|
|
|- ^+ vab
|
|
?: =(0 i.pax) vab
|
|
$(i.pax (rsh 3 1 i.pax), vab (~(put in vab) (end 3 1 i.pax)))
|
|
=+ pur=(~(get by stories) i.t.pax)
|
|
?~ pur
|
|
~& [%bad-subscribe-story-c i.t.pax]
|
|
(ra-evil %talk-no-story)
|
|
=+ soy=~(. pa i.t.pax u.pur)
|
|
=. soy ?.((~(has in vab) %a) soy (pa-watch:soy her))
|
|
=. soy ?.((~(has in vab) %x) soy (pa-master:soy her))
|
|
=. soy ?.((~(has in vab) %f) soy (pa-listen:soy her t.t.pax))
|
|
=^ who +>.$ (ra-human her)
|
|
pa-abet:(pa-notify:soy her %hear who)
|
|
::
|
|
++ ra-think :: publish/review
|
|
|= [pub=? her=ship tiz=(list thought)]
|
|
^+ +>
|
|
?~ tiz +>
|
|
$(tiz t.tiz, +> (ra-consume pub her i.tiz))
|
|
::
|
|
++ ra-normal :: normalize
|
|
|= tip=thought
|
|
^- thought
|
|
?. ?=([%lin *] r.r.tip) tip
|
|
%_ tip
|
|
q.r.r
|
|
%- crip
|
|
%+ scag 62
|
|
%- tufa
|
|
%+ turn (tuba (trip q.r.r.tip))
|
|
|= a=@c
|
|
?: &((gte a 'A') (lte a 'Z'))
|
|
(add a 32)
|
|
?: |((lth a 32) (gth a 126))
|
|
`@`'?'
|
|
a
|
|
==
|
|
::
|
|
++ ra-consume :: consume thought
|
|
|= [pub=? her=ship tip=thought]
|
|
=. tip (ra-normal tip)
|
|
=+ aud=(~(tap by q.tip) ~)
|
|
|- ^+ +>.^$
|
|
?~ aud +>.^$
|
|
$(aud t.aud, +>.^$ (ra-conduct pub her p.i.aud tip))
|
|
::
|
|
++ ra-conduct :: thought to partner
|
|
|= [pub=? her=ship tay=partner tip=thought]
|
|
^+ +>
|
|
:: ~& [%ra-conduct pub her tay]
|
|
?- -.tay
|
|
%& ?: pub
|
|
=. her our.hid :: XX security!
|
|
?: =(her p.p.tay)
|
|
(ra-record q.p.tay p.p.tay tip)
|
|
(ra-transmit p.tay tip)
|
|
?. =(our.hid p.p.tay)
|
|
+>
|
|
(ra-record q.p.tay her tip)
|
|
%| ?. pub +>
|
|
?- -.p.tay
|
|
%twitter
|
|
(ra-tweet p.p.tay tip)
|
|
== ==
|
|
::
|
|
++ ra-record :: add to story
|
|
|= [man=span gam=telegram]
|
|
^+ +>
|
|
=+ pur=(~(get by stories) man)
|
|
?~ pur
|
|
~& [%no-story man]
|
|
+>.$
|
|
pa-abet:(~(pa-learn pa man u.pur) gam)
|
|
::
|
|
++ ra-transmit :: send to neighbor
|
|
|= [cuz=station tip=thought]
|
|
^+ +>
|
|
=. +>
|
|
%+ ra-emit ost
|
|
:* %pass
|
|
/repeat/(scot %ud p.outbox)/(scot %p p.cuz)/[q.cuz]
|
|
%g
|
|
%mess
|
|
[p.cuz /talk]
|
|
our.hid
|
|
[%talk-command !>(`command`[%review tip ~])]
|
|
==
|
|
+>(p.outbox +(p.outbox), q.outbox (~(put by q.outbox) p.outbox tip))
|
|
::
|
|
++ ra-tweet :: send to /twit
|
|
|= [man=span tip=thought]
|
|
=* sta r.tip
|
|
?> ?=(%lin -.r.sta)
|
|
=. q.outbox (~(put by q.outbox) p.outbox tip)
|
|
%^ ra-emil(p.outbox +(p.outbox))
|
|
:* ost
|
|
%pass /twitter/stat/(scot %ud p.outbox)/[man]
|
|
%g %mess
|
|
[our.hid /twit] our.hid
|
|
[%twit-do !>(`twit-do`[man %post p.tip q.r.sta])]
|
|
==
|
|
:* ost
|
|
%pass /twitter/stat/(scot %ud p.outbox)/[man]
|
|
[%g %show [our.hid /twit] our.hid /post/(scot %uv p.tip)]
|
|
==
|
|
~
|
|
++ pa :: story core
|
|
|_ $: man=span
|
|
story
|
|
==
|
|
++ pa-abet
|
|
^+ +>
|
|
+>(stories (~(put by stories) man `story`+<+))
|
|
::
|
|
++ pa-admire :: accept from
|
|
|= her=ship
|
|
^- ?
|
|
::?- -.cordon.shape
|
|
:: %& (~(has in p.cordon.shape) her)
|
|
:: %| !(~(has in p.cordon.shape) her)
|
|
::==
|
|
&
|
|
::
|
|
++ pa-watch :: watch presence
|
|
|= her=ship
|
|
?. (pa-admire her)
|
|
(pa-sauce ost [[%mean ~ %talk-watch-unauthorized ~] ~])
|
|
=. viewers (~(put in viewers) ost)
|
|
(pa-display ost ~ ~)
|
|
::
|
|
++ pa-master :: hear config
|
|
|= her=ship
|
|
?. (pa-admire her)
|
|
(pa-sauce ost [[%mean ~ %talk-master-unauthorized ~] ~])
|
|
=. owners (~(put in owners) ost)
|
|
:: ~& [%pa-master her man shape]
|
|
(pa-sauce ost [[%rush %talk-report %cabal shape mirrors] ~])
|
|
::
|
|
++ pa-display :: update presence
|
|
|= vew=(set bone)
|
|
=+ ^= reg
|
|
:_ remotes
|
|
|- ^- atlas
|
|
?~ locals ~
|
|
[[p.n.locals q.q.n.locals] $(locals l.locals) $(locals r.locals)]
|
|
:: ~& [%pa-display man reg]
|
|
|- ^+ +>.^$
|
|
?~ vew +>.^$
|
|
=. +>.^$ $(vew l.vew)
|
|
=. +>.^$ $(vew r.vew)
|
|
(pa-sauce n.vew [[%rush %talk-report %group reg] ~])
|
|
::
|
|
++ pa-monitor :: update config
|
|
=+ owe=owners
|
|
|- ^+ +>
|
|
?~ owe +>
|
|
=. +> $(owe l.owe)
|
|
=. +> $(owe r.owe)
|
|
:: ~& [%pa-monitor man shape]
|
|
(pa-sauce n.owe [[%rush %talk-report %cabal shape mirrors] ~])
|
|
::
|
|
++ pa-cabal
|
|
|= [cuz=station con=config ham=(map station config)]
|
|
^+ +>
|
|
=+ old=mirrors
|
|
=. mirrors (~(put by mirrors) cuz con)
|
|
?: =(mirrors old)
|
|
+>.$
|
|
pa-monitor
|
|
::
|
|
++ pa-friend :: subscribed update
|
|
|= [tay=partner sih=sign]
|
|
^+ +>
|
|
?+ sih ~|([%talk-bad-friend sih] !!)
|
|
[%g %nice ~]
|
|
+>.$
|
|
::
|
|
[%g %mean *]
|
|
?~ +>.sih
|
|
?. (~(has in sources.shape) tay) +>.$ :: XX hack for odd mean
|
|
(pa-acquire [tay ~])
|
|
pa-monitor(sources.shape (~(del in sources.shape) tay))
|
|
::
|
|
[%g %rush %twit-feed *]
|
|
%- pa-lesson
|
|
%+ turn p.p.sih |= twit-stat
|
|
^- telegram
|
|
:^ our.hid :: XX inaccurate
|
|
(shas %twit id)
|
|
`audience`[[tay [& ~ tay] %received] `~] :: current party?
|
|
^- statement
|
|
:+ now
|
|
~ :: XX hashtags
|
|
[%lin & txt]
|
|
::
|
|
[%g %rush %talk-report *]
|
|
:: ~& [%pa-friend-report +>+.sih]
|
|
?> ?=(%& -.tay)
|
|
=. +> %+ pa-scrub ost
|
|
:_ ~
|
|
:- /friend/show/[man]/(scot %p p.p.tay)/[q.p.tay]
|
|
[%g %took [p.p.tay /talk] our.hid]
|
|
?+ -.p.p.sih ~|([%talk-odd-friend sih] !!)
|
|
%cabal (pa-cabal `station`p.tay `cabal`+.p.p.sih)
|
|
%group (pa-remind tay +.p.p.sih)
|
|
%grams (pa-lesson q.+.p.p.sih)
|
|
==
|
|
==
|
|
::
|
|
++ pa-scrub :: pass forward
|
|
|= [ost=bone bub=(list (pair path note))]
|
|
%_ +>.$
|
|
moves
|
|
(welp (flop (turn bub |=(a=(pair path note) [ost %pass a]))) moves)
|
|
==
|
|
::
|
|
++ pa-sauce :: send backward
|
|
|= [ost=bone gub=(list gift)]
|
|
%_ +>.$
|
|
moves
|
|
(welp (flop (turn gub |=(a=gift [ost %give a]))) moves)
|
|
==
|
|
::
|
|
++ pa-abjure :: unsubscribe move
|
|
|= tal=(list partner)
|
|
%+ pa-scrub 0
|
|
%- zing
|
|
%+ turn tal
|
|
|= tay=partner
|
|
?- -.tay
|
|
%| ~& tweet-abjure/p.p.tay
|
|
!!
|
|
:: :~ :- /friend/nuke/[man]/twitter/[p.p.tay]
|
|
:: [%g %nuke [our.hid /twit] our.hid]
|
|
:: ==
|
|
::
|
|
%& ~& [%pa-abjure [our.hid man] [p.p.tay q.p.tay]]
|
|
:~ :- /friend/show/[man]/(scot %p p.p.tay)/[q.p.tay]
|
|
[%g %nuke [p.p.tay /talk] our.hid]
|
|
==
|
|
==
|
|
::
|
|
++ pa-acquire :: subscribe to
|
|
|= tal=(list partner)
|
|
%+ pa-scrub 0
|
|
%- zing
|
|
%+ turn tal
|
|
|= tay=partner
|
|
^- (list (pair path note))
|
|
=+ num=(fall (~(get by sequence) tay) 0)
|
|
?- -.tay
|
|
%| ~& tweet-acquire/p.p.tay
|
|
:~ :- /friend/show/[man]/twitter/[p.p.tay]
|
|
[%g %show [our.hid /twit] our.hid /user/[p.p.tay]]
|
|
==
|
|
::
|
|
%& :: ~& [%pa-acquire [our.hid man] [p.p.tay q.p.tay]]
|
|
:~ :- /friend/show/[man]/(scot %p p.p.tay)/[q.p.tay]
|
|
[%g %show [p.p.tay /talk] our.hid /afx/[q.p.tay]/(scot %ud num)]
|
|
==
|
|
==
|
|
::
|
|
++ pa-reform :: reconfigure, ugly
|
|
|= cof=config
|
|
=+ ^= dif ^- (pair (list partner) (list partner))
|
|
=+ old=`(list partner)`(~(tap in sources.shape) ~)
|
|
=+ new=`(list partner)`(~(tap in sources.cof) ~)
|
|
:- (skip new |=(a=partner (~(has in sources.shape) a)))
|
|
(skip old |=(a=partner (~(has in sources.cof) a)))
|
|
=. +>.$ (pa-acquire p.dif)
|
|
=. +>.$ (pa-abjure q.dif)
|
|
=. shape cof
|
|
pa-monitor
|
|
::
|
|
++ pa-cancel :: unsubscribe from
|
|
:: ~& [%pa-cancel ost]
|
|
%_ .
|
|
guests (~(del by guests) ost)
|
|
viewers (~(del in viewers) ost)
|
|
owners (~(del in owners) ost)
|
|
==
|
|
::
|
|
++ pa-notify :: local presence
|
|
|= [her=ship saz=status]
|
|
^+ +>
|
|
=+ ^= nol
|
|
?: =(%gone p.saz)
|
|
(~(del by locals) her)
|
|
(~(put by locals) her lat.hid saz)
|
|
?: =(nol locals) +>.$
|
|
(pa-display(locals nol) viewers)
|
|
::
|
|
++ pa-remind :: remote presence
|
|
|= [tay=partner loc=atlas rem=(map partner atlas)]
|
|
=+ ^= buk
|
|
=+ mer=(turn (~(tap by rem) ~) |=([* a=atlas] a))
|
|
|- ^- atlas
|
|
?~ mer loc
|
|
=. loc $(mer t.mer)
|
|
=+ dur=`(list (pair ship status))`(~(tap by i.mer) ~)
|
|
|- ^- atlas
|
|
?~ dur loc
|
|
=. loc $(dur t.dur)
|
|
=+ fuy=(~(get by loc) p.i.dur)
|
|
?~ fuy (~(put by loc) p.i.dur q.i.dur)
|
|
?: =(`presence`p.q.i.dur `presence`p.u.fuy)
|
|
loc
|
|
?- p.u.fuy
|
|
%gone (~(del by loc) p.i.dur q.i.dur)
|
|
%talk loc
|
|
%hear (~(put by loc) p.i.dur q.i.dur)
|
|
==
|
|
=+ gub=(~(get by remotes) tay)
|
|
:: ~& [%pa-remind tay gub buk]
|
|
?. |(?=(~ gub) !=(buk u.gub))
|
|
+>.$
|
|
=. remotes (~(put by remotes) tay buk)
|
|
(pa-display viewers)
|
|
::
|
|
++ pa-start :: start stream
|
|
|= riv=river
|
|
^+ +>
|
|
=- :: ~& [%pa-start riv lab]
|
|
=. +>.$ (pa-sauce ost [[%rush %talk-report %grams q.lab r.lab] ~])
|
|
?: p.lab
|
|
(pa-sauce ost [[%mean ~] ~])
|
|
+>.$(guests (~(put by guests) ost riv))
|
|
^= lab
|
|
=+ [end=count gaz=grams dun=| zeg=*(list telegram)]
|
|
|- ^- (trel ,? ,@ud (list telegram))
|
|
?~ gaz [dun end zeg]
|
|
?: ?- -.q.riv :: after the end
|
|
%ud (lte p.q.riv end)
|
|
%da (lte p.q.riv p.r.q.i.gaz)
|
|
==
|
|
$(end (dec end), gaz t.gaz)
|
|
?: ?- -.p.riv :: before the start
|
|
%ud (lth end p.p.riv)
|
|
%da (lth p.r.q.i.gaz p.p.riv)
|
|
==
|
|
[dun end zeg]
|
|
$(end (dec end), gaz t.gaz, zeg [i.gaz zeg])
|
|
::
|
|
++ pa-listen :: subscribe
|
|
|= [her=ship pax=path]
|
|
^+ +>
|
|
?. (pa-admire her)
|
|
(pa-sauce ost [[%mean ~ %talk-listen-unauthorized ~] ~])
|
|
=+ ^= ruv ^- (unit river)
|
|
?: ?=(~ pax)
|
|
`[[%ud count] [%da (dec (bex 128))]]
|
|
?: ?=([@ ~] pax)
|
|
=+ say=(slay i.pax)
|
|
?. ?=([~ %$ ?(%ud %da) @] say) ~
|
|
`[(point +>.say) [%da (dec (bex 128))]]
|
|
?. ?=([@ @ ~] pax) ~
|
|
=+ [say=(slay i.pax) den=(slay i.t.pax)]
|
|
?. ?=([~ %$ ?(%ud %da) @] say) ~
|
|
?. ?=([~ %$ ?(%ud %da) @] den) ~
|
|
`[(point +>.say) (point +>.den)]
|
|
:: ~& [%pa-listen her pax ruv]
|
|
?~ ruv
|
|
(pa-sauce ost [[%mean ~ %talk-malformed ~] ~])
|
|
(pa-start u.ruv)
|
|
::
|
|
++ pa-refresh :: update to guests
|
|
|= [num=@ud gam=telegram]
|
|
^+ +>
|
|
=+ ^= moy
|
|
|- ^- (pair (list bone) (list move))
|
|
?~ guests [~ ~]
|
|
:: ~& [%pa-refresh num n.guests]
|
|
=+ lef=$(guests l.guests)
|
|
=+ rit=$(guests r.guests)
|
|
=+ old=[p=(welp p.lef p.rit) q=(welp q.lef q.rit)]
|
|
?: ?- -.q.q.n.guests :: after the end
|
|
%ud (lte p.q.q.n.guests num)
|
|
%da (lte p.q.q.n.guests p.r.q.gam)
|
|
==
|
|
[[p.n.guests p.old] [[p.n.guests %give %mean ~] q.old]]
|
|
?: ?- -.p.q.n.guests :: before the start
|
|
%ud (gth p.p.q.n.guests num)
|
|
%da (gth p.p.q.n.guests p.r.q.gam)
|
|
==
|
|
old
|
|
:- p.old
|
|
[[p.n.guests %give %rush %talk-report %grams num gam ~] q.old]
|
|
=. moves (welp q.moy moves)
|
|
|- ^+ +>.^$
|
|
?~ p.moy +>.^$
|
|
$(p.moy t.p.moy, guests (~(del by guests) i.p.moy))
|
|
::
|
|
++ pa-lesson :: learn multiple
|
|
|= gaz=(list telegram)
|
|
^+ +>
|
|
?~ gaz +>
|
|
$(gaz t.gaz, +> (pa-learn i.gaz))
|
|
::
|
|
++ pa-learn :: learn message
|
|
|= gam=telegram
|
|
^+ +>
|
|
?. (pa-admire p.gam)
|
|
~& %pa-admire-rejected
|
|
+>.$
|
|
=. q.q.gam
|
|
=+ ole=(~(get by q.q.gam) [%& our.hid man])
|
|
?~ ole q.q.gam
|
|
(~(put by q.q.gam) [%& our.hid man] -.u.ole %received)
|
|
=+ old=(~(get by known) p.q.gam)
|
|
?~ old
|
|
(pa-append gam)
|
|
(pa-revise u.old gam)
|
|
::
|
|
++ pa-append :: append new
|
|
|= gam=telegram
|
|
^+ +>
|
|
%+ %= pa-refresh
|
|
grams [gam grams]
|
|
count +(count)
|
|
known (~(put by known) p.q.gam count)
|
|
==
|
|
count
|
|
gam
|
|
::
|
|
++ pa-revise :: revise existing
|
|
|= [num=@ud gam=telegram]
|
|
=+ way=(sub count num)
|
|
=. grams (welp (scag (dec way) grams) [gam (slag way grams)])
|
|
(pa-refresh num gam)
|
|
--
|
|
--
|
|
::
|
|
++ sn :: station render core
|
|
|_ [man=span one=station]
|
|
++ sn-best :: best to show
|
|
|= two=station
|
|
^- ?
|
|
?: =(our.hid p.one)
|
|
?: =(our.hid p.two)
|
|
?< =(q.one q.two)
|
|
?: =((main p.one) q.one) %&
|
|
?: =((main p.two) q.two) %|
|
|
(lth q.one q.two)
|
|
%&
|
|
?: =(our.hid p.two)
|
|
%|
|
|
?: =(p.one p.two)
|
|
(lth q.one q.two)
|
|
(lth p.one q.one)
|
|
::
|
|
++ sn-curt :: render name in 14
|
|
|= mup=?
|
|
^- tape
|
|
=+ ^= syl
|
|
|= [len=@ud sez=(list cord)]
|
|
?> !=(0 len)
|
|
|- ^- tape
|
|
?~ sez ~
|
|
=+ nez=(trip i.sez)
|
|
=+ nel=(lent nez)
|
|
?: (gte nel len)
|
|
(welp (scag (dec len) nez) ">")
|
|
(welp nez $(sez t.sez))
|
|
::
|
|
?: =(p.one our.hid)
|
|
?: =(q.one man)
|
|
(sigh 14 ?:(mup "*=" "=") %$)
|
|
(sigh 14 ?:(mup "*%" "%") q.one)
|
|
?: =(p.one (sein our.hid))
|
|
(sigh 14 ?:(mup "*/" "/") q.one)
|
|
=+ rac=(clan p.one)
|
|
=+ raw=(scow %p p.one)
|
|
=. raw ?.(mup raw ['*' (slag 2 raw)])
|
|
?- rac
|
|
%czar (weld " " raw)
|
|
%king (weld " " raw)
|
|
%duke raw
|
|
%earl :(welp (scag 7 raw) "^" (scag 6 (slag 22 raw)))
|
|
%pawn :(welp (scag 7 raw) "_" (scag 6 (slag 51 raw)))
|
|
==
|
|
::
|
|
++ sn-phat :: render accurately
|
|
^- tape
|
|
?: =(p.one our.hid)
|
|
?: =(q.one man)
|
|
"="
|
|
['%' (trip q.one)]
|
|
?: =(p.one (sein our.hid))
|
|
['/' (trip q.one)]
|
|
=+ wun=(scow %p p.one)
|
|
?: =(q.one (main p.one))
|
|
wun
|
|
:(welp wun "/" (trip q.one))
|
|
--
|
|
::
|
|
++ ta :: partner core
|
|
|_ [man=span one=partner]
|
|
++ ta-beat :: more relevant
|
|
|= two=partner ^- ?
|
|
?- -.one
|
|
%&
|
|
?- -.two
|
|
%| %&
|
|
%& (~(sn-best sn man p.one) p.two)
|
|
==
|
|
::
|
|
%|
|
|
?- -.two
|
|
%& %|
|
|
%| ?: =(-.p.two -.p.one)
|
|
(lth (mug +.p.one) (mug +.p.two))
|
|
(lth -.p.two -.p.one)
|
|
==
|
|
==
|
|
++ ta-best :: most relevant
|
|
|=(two=partner ?:((ta-beat two) one two))
|
|
::
|
|
++ ta-full (ta-show ~) :: render full width
|
|
++ ta-show :: render partner
|
|
|= moy=(unit ,?)
|
|
^- tape
|
|
?- -.one
|
|
%&
|
|
?~ moy
|
|
~(sn-phat sn man p.one)
|
|
(~(sn-curt sn man p.one) u.moy)
|
|
::
|
|
%|
|
|
=+ ^= pre ^- tape
|
|
?- -.p.one
|
|
%twitter "@t:"
|
|
==
|
|
?~ moy
|
|
(weld pre (trip p.p.one))
|
|
=. pre ?.(=(& u.moy) pre ['*' pre])
|
|
(sigh 14 pre p.p.one)
|
|
==
|
|
--
|
|
::
|
|
++ te :: audience renderer
|
|
|_ [man=span lix=(set partner)]
|
|
++ te-best ^- (unit partner)
|
|
?~ lix ~
|
|
:- ~
|
|
|- ^- partner
|
|
=+ lef=`(unit partner)`te-best(lix l.lix)
|
|
=+ rit=`(unit partner)`te-best(lix r.lix)
|
|
=. n.lix ?~(lef n.lix (~(ta-best ta man n.lix) u.lef))
|
|
=. n.lix ?~(rit n.lix (~(ta-best ta man n.lix) u.rit))
|
|
n.lix
|
|
::
|
|
++ te-deaf ^+ . :: except for self
|
|
.(lix (~(del in lix) `partner`[%& our.hid man]))
|
|
::
|
|
++ te-maud ^- ? :: multiple audience
|
|
=. . te-deaf
|
|
?~ lix %|
|
|
|(!=(~ l.lix) !=(~ r.lix))
|
|
::
|
|
++ te-prom ^- tape :: render targets
|
|
=. . te-deaf
|
|
=+ ^= all
|
|
%+ sort `(list partner)`(~(tap in lix))
|
|
|= [a=partner b=partner]
|
|
(~(ta-beat ta man a) b)
|
|
=+ fir=&
|
|
|- ^- tape
|
|
?~ all ~
|
|
;: welp
|
|
?:(fir "" " ")
|
|
(~(ta-show ta man i.all) ~)
|
|
$(all t.all, fir |)
|
|
==
|
|
::
|
|
++ te-whom :: render sender
|
|
(~(ta-show ta man (need te-best)) ~ te-maud)
|
|
--
|
|
::
|
|
++ tr :: telegram renderer
|
|
|_ $: man=span
|
|
who=ship
|
|
sen=serial
|
|
aud=audience
|
|
wen=@da
|
|
bou=(set flavor)
|
|
sep=speech
|
|
==
|
|
++ tr-line ^- tape :: one-line print
|
|
=+ oug==(who our.hid)
|
|
=+ txt=(tr-text oug)
|
|
?: =(~ txt) ""
|
|
=+ eck=?:((~(has by aud) [%& our.hid man]) '*' '-')
|
|
=+ heb=?:(oug '>' '<')
|
|
=+ ^= baw
|
|
?: oug
|
|
~(te-whom te man tr-pals)
|
|
(~(sn-curt sn man [who (main who)]) |)
|
|
[heb eck (weld baw txt)]
|
|
::
|
|
++ tr-pals
|
|
^- (set partner)
|
|
%- ~(gas in *(set partner))
|
|
(turn (~(tap by aud)) |=([a=partner *] a))
|
|
::
|
|
++ tr-text
|
|
|= oug=?
|
|
^- tape
|
|
?+ -.sep ""
|
|
%lin
|
|
=+ txt=(trip q.sep)
|
|
?: p.sep
|
|
(weld ": " txt)
|
|
?: oug
|
|
(weld "@ " txt)
|
|
(weld " " txt)
|
|
==
|
|
--
|
|
::
|
|
++ peer
|
|
|= [ost=bone her=ship pax=path]
|
|
^- [(list move) _+>]
|
|
?: ?=([%sole *] pax)
|
|
?> =(our.hid her)
|
|
?< (~(has by shells) ost)
|
|
ra-abet:(~(ra-console ra ost ~) her t.pax)
|
|
:: ~& [%talk-peer-data ost her pax]
|
|
ra-abet:(~(ra-subscribe ra ost ~) her pax)
|
|
::
|
|
++ poke-talk-command
|
|
|= [ost=bone her=ship cod=command]
|
|
^- [(list move) _+>]
|
|
:: ~& [%talk-poke-command her cod]
|
|
ra-abet:(~(ra-apply ra ost ~) her cod)
|
|
::
|
|
++ poke-sole-action
|
|
|= [ost=bone her=ship act=sole-action]
|
|
ra-abet:(~(ra-sole ra ost [ost %give %nice ~]~) act)
|
|
::
|
|
++ pour
|
|
|= [ost=bone pax=path sih=*]
|
|
^- [(list move) _+>]
|
|
:: ~& sih=sih
|
|
=+ sih=((hard sign) sih)
|
|
:: ~& [%talk-pour ost pax sih]
|
|
?+ pax ~& [%talk-strange-path pax] !!
|
|
::
|
|
[%twitter *]
|
|
=- ra-abet:(~(ra-twitter ra ost ~) met sih)
|
|
^= met
|
|
?+ t.pax ~| [%talk-twitter-strange-path pax] !!
|
|
:: [%mine @ @ ~]
|
|
:: [i.t.pax i.t.t.t.pax]
|
|
[%stat @ @ ~]
|
|
[(slav %ud i.t.t.pax) i.t.t.t.pax]
|
|
==
|
|
::
|
|
[%friend *]
|
|
?> ?=([@ @ @ @ ~] t.pax)
|
|
?. =(%show i.t.pax)
|
|
:: ~& [%pour-friend-nuke-nuke pax]
|
|
[~ +>.$]
|
|
=+ man=i.t.t.pax
|
|
=+ ?: ?=(%twitter i.t.t.t.pax)
|
|
tay=[%| i.t.t.t.pax i.t.t.t.t.pax]
|
|
tay=[%& (slav %p i.t.t.t.pax) i.t.t.t.t.pax]
|
|
ra-abet:(~(ra-friend ra ost ~) man tay sih)
|
|
::
|
|
[%repeat *]
|
|
?> ?=([@ @ @ ~] t.pax)
|
|
=+ [num her man]=[(slav %ud i.t.pax) (slav %p i.t.t.pax) i.t.t.t.pax]
|
|
ra-abet:(~(ra-repeat ra ost ~) num [%& her man] sih)
|
|
==
|
|
::
|
|
++ pull
|
|
|= ost=bone
|
|
^- [(list move) _+>]
|
|
:: ~& [%talk-pull `*`ost]
|
|
=^ moz +>.$ ra-abet:ra-ever:~(ra-cancel ra ost ~)
|
|
[moz +>.$(shells (~(del by shells) ost))]
|
|
::
|
|
++ poke-bit
|
|
|= [ost=bone you=ship ~]
|
|
^- [(list move) _+>]
|
|
:_ +>.$
|
|
=+ paf=/(scot %p our.hid)/try/(scot %da lat.hid)/talk/backlog/jam
|
|
[ost %pass /jamfile %c %info our.hid (foal paf (jam +<+.+>.$))]~
|
|
::
|
|
++ prep
|
|
|= old=(unit (unit house-any))
|
|
^- [(list move) _+>]
|
|
?> ?=(^ old)
|
|
=| moz=(list move)
|
|
|-
|
|
?~ u.old
|
|
=+ paf=/(scot %p our.hid)/try/(scot %da lat.hid)/talk/backlog/jam
|
|
?. ?=([%0 %0 %0] [.^(%cy paf)])
|
|
~& %talk-prep-restore
|
|
$(u.old (some ((hard house-any) (cue ((hard ,@) .^(%cx paf))))))
|
|
ra-abet:~(ra-init ra 0 moz)
|
|
:- moz
|
|
|-
|
|
?- -.u.u.old
|
|
%1 %_(+>.^^$ +<+ u.u.old)
|
|
%0 $(u.u.old [%1 (house-0-to-house-1 +.u.u.old)])
|
|
==
|
|
::
|
|
++ house-0-to-house-1
|
|
|= vat=house-0
|
|
^- house-1
|
|
=- :* stories=-
|
|
general=~
|
|
outbox=[0 ~]
|
|
folks=~
|
|
shells=~
|
|
==
|
|
^- (map span story)
|
|
=- %- ~(run by -)
|
|
|= grams=(list telegram)
|
|
^- story
|
|
:* count=(lent grams)
|
|
grams=grams
|
|
locals=~
|
|
remotes=~
|
|
mirrors=~
|
|
sequence=~
|
|
shape=[.(cordon [%black ~])]:*config
|
|
^= known %- mo ^- (list ,[serial @]) =< +
|
|
(roll grams |=([telegram a=@ b=(list ,[serial @])] [+(a) [a p.q] b]))
|
|
guests=~
|
|
viewers=~
|
|
owners=~
|
|
==
|
|
^- (map span (list telegram))
|
|
%- mo %+ turn (~(tap by vat))
|
|
|= [a=path b=(list zong) c=(map ship ,?)]
|
|
=+ ^= par
|
|
?: =(/ a) 'hub'
|
|
=+ (turn a |=(d=span leaf/(trip d)))
|
|
(crip ~(ram re %rose ["_" ~ ~] -))
|
|
:- par
|
|
=+ aud=`audience`[[[%& our.hid par] *envelope %received] `~]
|
|
=+ ^= spe
|
|
|= r=_r:*zong ^- speech
|
|
?- -.r
|
|
%say [%lin %& p.r]
|
|
%do [%lin %| p.r]
|
|
%exp [%fat [%tank q.r ~] [%exp p.r]]
|
|
==
|
|
%+ turn b
|
|
|= d=zong ^- telegram
|
|
[q.d (sham eny.hid d) aud p.d ~ (spe r.d)]
|
|
--
|