:: :::: /hook/core/talk/app :: /? 314 /- *radio /+ radio :: :::: :: !: => |% :: structures ++ town :: all client state $: live=(unit span) :: present story console=terminal :: controlling terminal stories=(map span story) :: all stories == :: ++ grip :: subscription state |* nub=$+(* *) :: wrapped state $| $? %warm :: activated %cool :: activating %dead :: inoperative %cold :: inactive == [%live p=nub] :: operating ++ terminal :: terminal state $: present=presence :: presence state == :: ++ story :: persona $: link=(grip bridge) :: connection count=@ud :: message counter mike=(pair ,? (set station)) :: active/voice quiet=? :: !verbose past=(list station) :: past received auds == :: ++ bridge :: remote state $: xm=config :: configuration am=register :: presence == :: ++ work :: general action $% [%ask (unit work)] :: help (about) [%exp twig] :: compute [%mor (list work)] :: sequence [%rub work-adjust] :: configure story [%say speech] :: publish in voice [%who (unit station)] :: show presence [%wry work-construct] :: configure system == :: ++ work-adjust :: adjust story $% [%dark p=(set ship)] :: toggle blacklist [%lite p=(set ship)] :: toggle whitelist [%love p=(set station)] :: toggle stations [%whom p=? q=(set station)] :: active/voice [%wind p=@dr] :: rewind by date == :: ++ work-construct :: configure system $% [%make p=span] :: create story [%raze p=span] :: destroy story [%tune p=span] :: switch to story == :: ++ iron :: terminal output $% [%prompt p=cord q=prom r=cord] :: prompt [%tang p=(list tank)] :: prettyprintable [%txt p=cord] :: simple text == ++ 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] == == $: %t $% [%wait p=@da] == == == ++ gall-sign :: subscription result $% [%mean p=ares] [%nice ~] $: %rush $= p $% [%txt p=cord] :: input text [%type p=?] :: typing notify == == $: %rust $= p $% [%txt p=cord] [%radio-report p=report] == == == ++ sign $? [%g gall-sign] :: from %gall $: %t :: from %time $% [%wake ~] :: timer wakeup == == == -- !: :::: :: => |% ++ swatch :: print station set |= [our=ship tou=(set station)] =+ tuo=(~(tap in tou)) |- ^- tape ?~ tuo ~ =+ ted=$(tuo t.tuo) =+ ^= ind ^- tape ?- -.i.tuo %& =+ sip=(scow %p p.p.i.tuo) ?: =((main our) q.p.i.tuo) sip (welp sip (trip q.p.i.tuo)) %| ['^' '@' (trip p.p.i.tuo)] == ?~ ted ind (welp ind `tape`[',' ' ' ted]) :: ++ parse :: command parser |= our=ship =+ vag=(vang | [&1:% &2:% '0' |3:%]) |% ++ come :: keyword command |* [a=@tas b=_rule] ;~((glue (plus ace)) (cold a (jest a)) b) :: ++ gone :: parse unit |* a=_rule ;~(pose (stag ~ a) (easy ~)) :: ++ posh :: parse each |* [a=_rule b=_rule] ;~(pose (stag %& a) (stag %| b)) :: ++ ship ;~(pfix sig fed:ag) :: ship ++ shiz :: ship set %+ cook |=(a=(list ^ship) (~(gas in *(set ^ship)) a)) (most ;~(plug com (star ace)) ship) :: ++ stat :: station %+ posh ;~ plug ship ;~(pose ;~(pfix fas urs:ab) (easy (main our))) == ;~ pfix ket ;~ pose ;~(pfix pat (stag %twitter urs:ab)) == == :: ++ staz :: station set %+ cook |=(a=(list station) (~(gas in *(set station)) a)) (most ;~(plug com (star ace)) stat) :: ++ step :: rollback interval %+ sear |= a=coin ?. ?=([%$ %dr @] a) ~ (some `@dr`+>.a) nuck:so :: ++ text (boss 256 (star prn)) :: utf8 text ++ tome %+ stag %lin ;~ pose (stag %| ;~(pfix pat text)) (stag %& text) == :: ++ work :: all commands %+ knee *^work |. ~+ ;~ pose ;~ pfix zap %+ stag %wry ;~ pose (come %make urs:ab) (come %raze urs:ab) (come %tune urs:ab) == == :: ;~ pfix cen %+ stag %rub ;~ pose (come %dark shiz) (come %lite shiz) (come %whom (stag %& staz)) (come %wind step) == == :: ;~(pfix wut (stag %ask (gone work))) ;~(pfix tis (stag %who (gone stat))) ;~(pfix cen (stag %exp wide:vag)) :: %+ cook |= [a=(set station) b=(unit ,[%lin p=? q=@t])] ^- ^work =. b ?~(b ~ ?:(=(0 q.u.b) ~ b)) =+ c=[%rub %whom %& a] ?~(b c [%mor c [%say u.b] ~]) ;~ plug staz (gone ;~(pfix (star ace) tome)) == :: (stag %say tome) == -- ++ stog :: toggle set |* [tog=(set) tag=(set)] =+ got=(~(tap in tog)) |- ^+ tag ?~ got tag %= $ got t.got tag ?: (~(has in tag) i.got) (~(del in tag) i.got) (~(put in tag) i.got) == -- !: :::: :: |_ [hid=hide town] ++ transmit :: radio command |= [cod=command moz=(list move)] ^- (list move) :_ moz :* 0 %pass /command %g %mess [our.hid /radio] our.hid [%radio-command !>(cod)] == :: ++ subscribe :: radio show |= [way=path hoc=path moz=(list move)] ^- (list move) :_(moz [0 %pass way %g %show [our.hid /radio] our.hid hoc]) :: ++ unsubscribe :: radio nuke |= [way=path moz=(list move)] ^- (list move) :_(moz [0 %pass way %g %nuke [our.hid /radio] our.hid]) :: ++ render :: send to console |= [rod=iron moz=(list move)] =+ oss=(~(tap in (~(get ju pus.hid) /out))) |- ^- (list move) ?~ oss moz [`move`[i.oss %give %rush rod] $(oss t.oss)] :: ++ display :: print to console |= [tay=(list tank) moz=(list move)] (render [%tang tay] moz) :: ++ show :: simple show |= [tep=tape moz=(list move)] (display [%leaf tep]~ moz) :: ++ accept :: set prompt |= [asq=cord moz=(list move)] (render [%prompt asq %text ''] moz) :: ++ sy |_ $: $: man=span :: u.live moz=(list move) :: pending moves == :: story :: current story == :: ++ sy-abet :: resolve core ^- [(list move) _+>] [(flop moz) +>(stories (~(put by stories) man +<+))] :: ++ sy-subscribe :: story subscribe ~& [%subscribe-link link] ?> =(%cold -.link) %_ . link %cool moz ^- (list move) :: %^ subscribe /xm/[man] /xm/[man] :: %^ subscribe /am/[man] /am/[man] %^ subscribe /fm/[man] :~ %fm man ?: =(0 count) ~& [%story-init man `@da`(sub lat.hid ~d1)] (scot %da (sub lat.hid ~d1)) (scot %ud count) == ~ == :: ++ sy-unsubscribe :: story unsubscribe ?: =(& ?=(?(%cold %dead) -.link)) . %_ . link %cold moz :: %+ unsubscribe /xm/[man] :: %+ unsubscribe /am/[man] (unsubscribe /fm/[man] ~) == :: ++ sy-serial :: make serial no ^- [serial _.] [(shaf %serial eny.hid) .(eny.hid (shax eny.hid))] :: ++ sy-audience :: speech audience %- ~(gas by *audience) %+ turn `(list station)`[[%& our.hid man] (~(tap in q.mike))] |=(a=station [a %pending]) :: ++ sy-message :: print message |= msg=tape %_(+> moz (display [%leaf "{(trip man)}: {msg}"]~ moz)) :: ++ sy-voice :: set targets |= [act=? tou=(set station)] ?: &(p.mike !act) +> %_(+> mike [act tou], moz (accept (crip (swatch our.hid tou)) moz)) :: ++ sy-rollback |= lon=@dr !! :: ++ sy-work :: run user command |= job=work ^+ +> ?- -.job %ask ~&(%sy-work-ask-stub !!) %exp ~&(%sy-work-exp-stub !!) %mor |- ^+ +>.^$ ?~ +.job +>.^$ $(+.job t.+.job, +>.^$ ^$(job i.+.job)) :: %rub ?: ?=(%whom +<.job) (sy-voice +>.job) ?: ?=(%wind +<.job) ~& %rub-wind-stub !! =+ suz=sy-live ?~ suz (sy-message "not connected") ?- +<.job %lite sz-abet:(sz-cordon:u.suz [%| +>.job]) %dark sz-abet:(sz-cordon:u.suz [%& +>.job]) %love sz-abet:(sz-sources:u.suz +>.job) == :: %say =^ sir +>.$ sy-serial +>.$(moz (transmit [%publish [[sir sy-audience [lat.hid +.job]] ~]] moz)) :: %wry ~&(%sy-work-wry !!) %who ~&(%sy-work-who-stub !!) == :: ++ sy-gram :: apply telegram |= gam=telegram ^+ +> %= +> moz %- render :_ moz ^- iron =* sta r.q.gam ?+ -.q.sta ~&([%strange-gram -.q.sta] !!) :: %say [%txt (rap 3 (scot %p p.gam) ': ' p.q.sta ~)] %own [%txt (rap 3 (scot %p p.gam) ' ' p.q.sta ~)] %lin [%txt (rap 3 (scot %p p.gam) ?:(p.q.sta ' ' ': ') q.q.sta ~)] %inv !! %exp :- %tang :_ ~ :~ %rose [" " "" ""] [%leaf "{