urbit/main/app/talk/core.hook
2014-12-11 13:32:59 -08:00

398 lines
10 KiB
Plaintext

::
:::: /hook/core/talk/app
::
/? 314
/- *radio
::
::::
::
!:
[sed=!>(.) .]
=> |%
++ house
$: live=(unit span) :: looking at
parties=(map span party) :: all parties
shown=(set serial) :: messages shown
targets=(unit (set station)) :: talking to
== ::
++ party :: local party
$: count=@ud :: number shown
shape=(unit config) :: configuration
present=(map ship status) :: presence
== ::
++ work :: user action
$% [%all p=mess] :: say
[%back p=?(%da %dr %ud) q=@] :: backlog
[%def p=mess] :: default
[%how ~] :: help
[%join p=station] :: subscribe /=main to
[%host p=span] :: create /=foo
[%priv p=@p q=mess] :: private
[%who ~] :: who
== ::
++ iron :: terminal output
$% [%prompt p=cord q=prom r=cord] :: prompt
[%tang p=(list tank)] :: prettyprintable
[%txt p=cord] :: simple text
==
++ mess
$% [%do p=@t]
[%exp p=@t q=tank]
[%say p=@t]
==
++ gift
$% [%mean ares]
[%nice ~]
[%rush iron]
[%rust iron]
==
++ hapt ,[p=ship q=path]
++ move ,[p=bone q=(mold note gift)]
++ note
$? $: %g
$% [%mess p=hapt q=ship r=cage]
[%nuke p=hapt q=ship]
[%show p=hapt q=ship r=path]
== == ==
++ sign
$? $: %g
$% [%mean p=ares]
[%nice ~]
$: %rush
$= p
$% [%txt p=cord]
== ==
$: %rust
$= p
$% [%txt p=cord]
[%radio-report p=report]
== ==
== == ==
--
!:
::::
::
=| [our=@p lat=@da]
|%
++ talk
=<
%+ cook |=(a=work a)
;~ pose
(cold [%how ~] wut)
(cold [%who ~] tis)
(stag %back dat)
(stag %priv ;~(plug ;~(pfix sig fed:ag) ;~(pfix ace mess)))
(stag %all ;~(pfix pam mess))
(comd %join stati)
(comd %host urs:ab)
(stag %def mess)
==
|%
++ peach :: either ++each branch
|* a=_[rule rule]
|= tub=nail
^- (like (each ,_(wonk (-.a)) ,_(wonk (+.a))))
%. tub
;~(pose (stag %& -.a) (stag %| +.a))
::
++ comd :: ! command
|* [a=@tas b=_rule]
%- full
;~((glue (plus ace)) ;~(pfix zap (cold a (jest a))) b)
::
::
++ dat
%+ sear
|= p=coin
?. ?=([%$ ?(%da %dr %ud) @] p) ~
(some +.p)
;~(pfix bas bas (star ace) nuck:so)
::
++ expn
%- sear
:_ text
|= a=@t
^- (unit ,[p=@t q=tank])
=+ hun=(rush a wide:(vang | [&1:% &2:% (scot %da lat) |3:%]))
?~ hun ~
?~(a ~ [~ a (sell (slap sed u.hun))])
::
++ mess
^- $+(nail (like ^mess))
;~ pose
(stag %do ;~(pfix pat text))
(stag %exp ;~(pfix hax expn))
(stag %do (full (easy '')))
(stag %say text)
==
::
++ text (boss 256 (star prn))
++ stati
^- $+(nail (like station))
%+ peach
;~(plug ;~(pose (cold our tis) (ifix sig^fas fed:ag)) urs:ab)
%+ sear (soft partner)
;~((glue fas) sym (cook crip (star prn))) :: XX [a-z0-9_]{1,15}
--
--
!:
::::
::
|_ [hid=hide house]
::
++ pour-shell
|= [ost=bone txt=cord]
^- [(list move) _+>]
?: =(0 txt) [~ +>.$]
=+ rey=(rush txt talk(lat lat.hid, our our.hid))
?~ rey
[(send /out %give %rush %tang [%leaf "invalid input"] ~) +>.$]
=- :_ ->
:_ ~
^- move
:* ost %pass /command
%g %mess [our.hid /rodeo] our.hid
[%radio-command !>(cod)]
==
^- [cod=command _+>.$]
?+ -.u.rey !!
%def
?> ?=(%say -.p.u.rey)
?~ live
~& %not-live
!!
=- [[%publish - ~] +>.$]
^- thought
:* (shaf %foo eny.hid)
[[`station`[%& our.hid u.live] %pending] ~ ~]
`statement`[lat.hid p.u.rey]
==
::
%host
[[%design p.u.rey ~ `config`[~ [%| ~]]] +>.$]
::
%join
?~ live
~& %not-live
!!
=+ par=(~(got by parties) u.live)
?~ shape.par
~& %not-configured
!!
=. sources.u.shape.par (~(put in sources.u.shape.par) p.u.rey)
[[%design u.live `u.shape] +>.$]
==
::
++ pour-attach :: attach to party
|= [man=span moz=(list moves)]
^- (list moves)
~& [%pour-attach man]
:* :* ost %pass /fm
%g %show
[our.hid /rodeo] our.hid
/fm/[man]
==
(welp (send /out %give %rush %prompt prompt %text '') moz)
==
::
++ pour-detach :: detach from party
|= [man=span moz=(list moves)]
^- (list moves)
~& [%pour-detach man]
:_ moz
:* ost %pass /fm
%g %nuke
[our.hid /rodeo] our.hid
==
::
++ pour-live
|= moz=(list moves)
^+ [moz +>]
?~ live
?: (~(has by parties) %main)
=. live `%main
[(pour-attach %main moz) +>.$]
?~ parties
[moz +>]
=. live `p.n.parties
[(pour-attach p.n.parties moz) +>.$]
?: (~(has by parties) u.live)
[moz +>]
$(live ~, moz (pour-detach u.live))
::
++ pour-house
|= [ost=bone wha=(set span)]
^- [(list move) _+>]
=+ lug=`(list span)`(~(tap in +.rep) ~)
=+ yap=`(list (pair span party))`(~(tap by parties) ~)
=+ nup=(skip lug |=(a=span (~(has by parties) a)))
=+ pig=(skip yap |=([a=span *] (~(has in +.rep) a)))
=. parties
|- ^+ parties
?~ pig parties
$(pig t.pig, parties (~(del by parties) p.i.pig))
=. parties
|- ^+ parties
?~ nup parties
$(nup t.nup, parties (~(put by parties) i.nup *party))
%- pour-live
^- (list move)
%+ welp
%- zing
%+ turn nup
|= man=span
^- (list move)
~& [%new-party man]
:~ :* 0 %pass /am/[man]
%g %show
[our.hid /rodeo] our.hid
/am/[man]
:* 0 %pass /xm/[man]
%g %show
[our.hid /rodeo] our.hid
/xm/[man]
==
==
%- zing
%+ turn pig
|= [man=span *]
^- (list move)
~& [%old-party man]
:~ :* 0 %pass /am/[man]
%g %nuke
[our.hid /rodeo] our.hid
:* 0 %pass /xm/[man]
%g %nuke
[our.hid /rodeo] our.hid
==
==
::
++ pour-grams
|= [ost=bone man=span raq=(pair ,@ud (list telegram))]
^- [(list move) _+>]
:_ +>.$
%- zing ^- (list (list move))
%+ turn
`(list telegram)`q.raq
|= gam=telegram
=* sta r.q.gam
?+ -.q.sta !!
%say
(send /out %give %rush %txt p.q.sta)
==
::
++ pour-config
|= [ost=bone man=span cof=config]
^- [(list move) _+>]
=+ pur=(~(get by parties) man)
?~ pur
~& [%no-party man]
[~ +>.$]
[~ (~(put by parties) man u.pur(shape `cof))]
::
++ pour-group
|= [ost=bone man=span lup=(map ship status)]
^- [(list move) _+>]
=+ pur=(~(get by parties) man)
?~ pur
~& [%no-party man]
[~ +>.$]
[~ (~(put by parties) man u.pur(present lup))]
::
++ prompt
^- cord
?~ live
'waiting...'
(cat 3 u.live '& ')
::
++ peer
|= [ost=bone you=ship pax=path]
^- [(list move) _+>]
:_ +>.$
?~ pax !!
?+ i.pax !!
%out [ost %give %rust %prompt '& ' %text '']~
==
::
++ pour
|= [ost=bone pax=path sih=*]
^- [(list move) _+>]
=> .(sih ((hard sign) sih))
~& talk-pour/sih
?~ pax ~& talk-pour-strange-path/pax !!
?+ i.pax ~& talk-pour-strange-path/pax !!
%cmd-in
?- +<.sih
%nice [~ +>.$]
%mean [(send /out %give +.sih) +>.$]
?(%rush %rust)
?> ?=(%txt -.p.sih)
(pour-shell ost p.p.sih)
==
::
%command
?> ?=(?(%mean %nice) +<.sih)
[~ +>.$]
::
%server
?+ &2.sih !!
%nice [~ +>.$]
%mean ~&(%server-mean [~ +>.$])
%rust
?> ?=([%radio-report %house *] +>.sih)
(pour-house ost `(set span)`+>.+>.sih)
==
::
%am
?> ?=([@ *] t.pax)
?+ &2.sih !!
%nice [~ +>.$]
%mean ~&(%am-mean [~ +>.$])
%rust
?> ?=([%radio-report %group *] +>.sih)
(pour-group ost i.t.pax `(map ship status)`+>.+>.sih)
==
::
%xm
?> ?=([@ *] t.pax)
?+ &2.sih !!
%nice [~ +>.$]
%mean ~&(%xm-mean [~ +>.$])
%rust
?> ?=([%radio-report %group *] +>.sih)
(pour-config ost i.t.pax `config`+>.+>.sih)
==
::
%fm
?> ?=([@ *] t.pax)
?+ &2.sih !!
%nice [~ +>.$]
%mean ~&(%fm-mean [~ +>.$])
%rust
?> ?=([%radio-report %group *] +>.sih)
(pour-grams ost i.t.pax `(pair ,@ud (list telegram))`+>.+>.sih)
==
==
::
++ poke-talk-args
|= [ost=bone you=ship arg=~]
^- [(list move) _+>]
=. cordon.sha [%| ~]
:_ +>
:* [ost %pass /cmd-in %g %show [our.hid +.imp.hid] you /in/[-.imp.hid]]
^- move
:* ost %pass /general
%g %show
[our.hid /rodeo] our.hid
/
==
==
::
++ send
|= [pax=path msg=(mold note gift)]
^- (list move)
:: ~& [%send pus.hid]
%+ turn (~(tap in (~(get ju pus.hid) pax)))
|=(ost=bone [ost msg])
--