mirror of
https://github.com/urbit/shrub.git
synced 2024-12-12 10:29:01 +03:00
738 lines
28 KiB
Plaintext
738 lines
28 KiB
Plaintext
!:
|
|
:: dill (4d), terminal handling
|
|
::
|
|
|= pit=vase
|
|
=> |% :: interface tiles
|
|
++ gift :: out result <-$
|
|
$% [%bbye ~] :: reset prompt
|
|
[%blit p=(list blit)] :: terminal output
|
|
[%init p=@p] :: report install
|
|
[%logo @] :: logout
|
|
[%veer p=@ta q=path r=@t] :: install vane
|
|
[%vega p=path] :: reboot by path
|
|
[%verb ~] ::
|
|
== ::
|
|
++ kiss :: in request ->$
|
|
$% [%belt p=belt] :: terminal input
|
|
[%blew p=blew] :: terminal config
|
|
[%boot p=*] :: weird %dill boot
|
|
[%crud p=@tas q=(list tank)] :: error with trace
|
|
[%flog p=flog] :: wrapped error
|
|
[%hail ~] :: terminal refresh
|
|
[%hook ~] :: this term hung up
|
|
[%harm ~] :: all terms hung up
|
|
[%init p=ship] :: after gall ready
|
|
[%noop ~] :: no operation
|
|
[%talk p=tank] ::
|
|
[%text p=tape] ::
|
|
== ::
|
|
++ flog :: sent to %dill
|
|
$% [%crud p=@tas q=(list tank)] ::
|
|
[%text p=tape] ::
|
|
== ::
|
|
++ mess :: message to terminal
|
|
$% [%term-ctrl p=(hypo ,%hail)] ::
|
|
[%term-in p=(hypo term-in)] ::
|
|
== ::
|
|
++ move ,[p=duct q=(mold note gift)] :: local move
|
|
++ note :: out request $->
|
|
$% $: %a ::
|
|
$% [%make p=(unit ,@t) q=@ud r=@ s=?] ::
|
|
[%sith p=@p q=@uw r=?] ::
|
|
== == ::
|
|
$: %c ::
|
|
$% [%warp p=sock q=riff] ::
|
|
== == ::
|
|
::S $% $: %b :: to %batz
|
|
::S $% [%hail ~] ::
|
|
::S [%harm ~] ::
|
|
::S [%hook ~] ::
|
|
::S [%kill p=~] ::
|
|
::S [%line p=@t] ::
|
|
::S [%ling ~] ::
|
|
::S [%make p=(unit ,@t) q=@ud r=@ s=?] ::
|
|
::S [%sith p=@p q=@uw r=?] ::
|
|
::S == == ::
|
|
$: %d ::
|
|
$% [%crud p=@tas q=(list tank)] ::
|
|
[%text p=tape] ::
|
|
== == ::
|
|
$: %g ::
|
|
$% [%mess p=[p=ship q=path] q=ship r=mess] ::
|
|
[%show p=[p=ship q=path] q=ship r=path] ::
|
|
== == ::
|
|
$: %t ::
|
|
$% [%wait p=@da] ::
|
|
== == == ::
|
|
++ riff ,[p=desk q=(unit rave)] :: see %clay
|
|
++ sign :: in result $<-
|
|
$?
|
|
::S $: %b :: by %batz
|
|
::S $% [%hail ~] ::
|
|
::S [%helo p=path q=prod] ::
|
|
::S [%logo p=@] ::
|
|
::S [%save p=path q=@] ::
|
|
::S [%sage p=path q=*] ::
|
|
::S [%talk p=tank] ::
|
|
::S [%tell p=(list ,@t)] ::
|
|
::S [%text p=tape] ::
|
|
::S [%verb ~] ::
|
|
::S [%veer p=@ta q=path r=@t] ::
|
|
::S [%vega p=path] ::
|
|
::S [%warn p=tape] ::
|
|
::S == == ::
|
|
$: %c ::
|
|
$% [%writ p=riot] ::
|
|
== == ::
|
|
$: %g ::
|
|
$% [%logo p=@] ::
|
|
[%mean p=ares] ::
|
|
[%nice ~] ::
|
|
$: %rush :: XX
|
|
$% [%term-line q=term-line] ::
|
|
[%hymn q=manx] ::
|
|
[%json q=json] ::
|
|
== == ::
|
|
$: %rust ::
|
|
$% [%term-line q=term-line] ::
|
|
[%hymn q=manx] ::
|
|
[%json q=json] ::
|
|
== == ::
|
|
[%verb ~] ::
|
|
[%sage p=path q=*] ::
|
|
[%veer p=@ta q=path r=@t] ::
|
|
[%vega p=path] ::
|
|
== == ::
|
|
$: @tas :: by any
|
|
$% [%crud p=@tas q=(list tank)] ::
|
|
[%init p=@p] ::
|
|
[%note p=@tD q=tank] ::
|
|
== == == ::
|
|
++ term-in ::
|
|
$: pax=path ::
|
|
$= jof ::
|
|
$% [%line p=span] ::
|
|
[%res p=span] ::
|
|
[%cmd p=char] ::
|
|
== == ::
|
|
++ term-line ,[p=[p=cord q=prom r=cord] q=(list cord) r=(list tark)]
|
|
++ tark ?(tank [%stem p=tank q=tank]) ::
|
|
:::::::: :: dill tiles
|
|
++ bein :: terminal control
|
|
$: $: bul=@ud :: buffer length
|
|
bus=@ud :: cursor in buffer
|
|
but=(list ,@c) :: buffer text
|
|
buy=prom :: input style
|
|
== ::
|
|
$: hiz=@ud :: history depth
|
|
hux=path :: history path
|
|
hym=(map ,@ud (list ,@c)) :: history overlay
|
|
hyt=hist :: history object
|
|
hyr=(unit (list ,@c)) :: history search
|
|
== ::
|
|
$: pol=@ud :: length of prompt
|
|
pot=tape :: prompt text
|
|
== ::
|
|
== ::
|
|
++ blew ,[p=@ud q=@ud] :: columns rows
|
|
++ belt :: raw console input
|
|
$% [%aro p=?(%d %l %r %u)] :: arrow key
|
|
[%bac ~] :: true backspace
|
|
[%ctl p=@ud] :: control-key
|
|
[%del ~] :: true delete
|
|
[%met p=@ud] :: meta-key
|
|
[%ret ~] :: return
|
|
[%txt p=(list ,@c)] :: utf32 text
|
|
== ::
|
|
++ blit :: raw console output
|
|
$% [%bel ~] :: make a noise
|
|
[%clr ~] :: clear the screen
|
|
[%hop p=@ud] :: set cursor position
|
|
[%lin p=(list ,@c)] :: set current line
|
|
[%mor ~] :: newline
|
|
[%sag p=path q=*] :: save to jamfile
|
|
[%sav p=path q=@] :: save to file
|
|
== ::
|
|
++ blot :: kill ring
|
|
$: p=@ud :: length
|
|
q=@ud :: depth
|
|
r=(list (list ,@c)) :: kills
|
|
== ::
|
|
++ blur ,[p=@ud q=(unit bein) r=blot] :: columns, prompt
|
|
++ kyev ::
|
|
$: p=(set ?(%ctrl %shift %alt %meta)) ::
|
|
q=$|(cord [%act speck]) ::
|
|
== ::
|
|
++ speck ::
|
|
$? %ctrl %shift %alt %meta %entr %esc ::
|
|
%caps %uncap %pgup %pgdn %home %end ::
|
|
%baxp %del %ins %up %down %left ::
|
|
%right ::
|
|
== ::
|
|
++ yard :: terminal state
|
|
$: p=? :: verbose
|
|
q=blur :: display state
|
|
r=(map path hist) :: history
|
|
== ::
|
|
-- =>
|
|
|%
|
|
++ dy
|
|
|= [hen=duct our=ship def=(unit duct) dug=(map duct yard)]
|
|
=+ ^= yar ^- yard
|
|
=+ yur=(~(get by dug) hen)
|
|
?^ yur u.yur
|
|
?^ def (~(got by dug) u.def)
|
|
[& [80 ~ *blot] ~]
|
|
=| mos=(list move)
|
|
|%
|
|
++ beep (curb [[%bel ~] ~]) :: send beep
|
|
++ curb :: send blits
|
|
|= wab=(list blit)
|
|
^+ +>
|
|
?~ wab +>
|
|
+>(mos [[hen [%give %blit (flop wab)]] mos])
|
|
::
|
|
++ wod :: word forward
|
|
|= bed=bein
|
|
^- @ud
|
|
?: =(bul.bed bus.bed)
|
|
bus.bed
|
|
?: =(' ' (snag bus.bed but.bed))
|
|
$(bus.bed +(bus.bed))
|
|
|-
|
|
^- @ud
|
|
?: =(bul.bed bus.bed)
|
|
bus.bed
|
|
?: =(' ' (snag bus.bed but.bed))
|
|
bus.bed
|
|
$(bus.bed +(bus.bed))
|
|
::
|
|
++ wob :: word backward
|
|
|= bed=bein
|
|
^- @ud
|
|
?: =(0 bus.bed)
|
|
bus.bed
|
|
?: =(' ' (snag (dec bus.bed) but.bed))
|
|
$(bus.bed (dec bus.bed))
|
|
|-
|
|
^- @ud
|
|
?: =(0 bus.bed)
|
|
bus.bed
|
|
?: =(' ' (snag (dec bus.bed) but.bed))
|
|
bus.bed
|
|
$(bus.bed (dec bus.bed))
|
|
::
|
|
++ edit :: change the bed
|
|
|= bed=bein
|
|
^+ +>
|
|
=. q.q.yar [~ bed]
|
|
?> ?=(^ q.q.yar)
|
|
%- curb
|
|
|- ^- (list blit)
|
|
?^ hyr.u.q.q.yar
|
|
=+ ris=:(weld "(reverse-i-search)'" (tufa u.hyr.u.q.q.yar) "': ")
|
|
%= $
|
|
pot.bed ris
|
|
pol.bed (lent ris)
|
|
hyr.u.q.q.yar ~
|
|
==
|
|
:~ [%hop (add pol.bed bus.bed)]
|
|
:- %lin
|
|
%+ weld pot.bed
|
|
?- buy.bed
|
|
%none but.bed
|
|
%text but.bed
|
|
%pass `(list ,@)`(runt [(lent but.bed) '*'] ~)
|
|
==
|
|
==
|
|
::
|
|
++ fume :: print tank, prefix
|
|
|= [pef=@tD tac=tank]
|
|
^+ +>
|
|
=+ wol=(~(win re tac) 2 p.q.yar)
|
|
%- furl
|
|
%+ turn wol
|
|
|= a=tape ^- tape
|
|
?> ?=([@ @ *] a)
|
|
[pef ' ' t.t.a]
|
|
::
|
|
++ furl :: print wall
|
|
|= wol=(list tape)
|
|
^+ +>
|
|
=. +>
|
|
%- curb
|
|
%- flop
|
|
|- ^- (list blit)
|
|
?~ wol ~
|
|
[[%lin (tuba i.wol)] [%mor ~] $(wol t.wol)]
|
|
?~ q.q.yar +>
|
|
(edit(q.q.yar ~) u.q.q.yar)
|
|
::
|
|
++ gore :: move in history
|
|
|= hup=@ud
|
|
^+ +>
|
|
=+ but=(goth hup)
|
|
=+ bul=(lent but)
|
|
%- edit
|
|
?> ?=(^ q.q.yar)
|
|
%= u.q.q.yar
|
|
hiz hup
|
|
hym %+ ~(put by hym.u.q.q.yar)
|
|
hiz.u.q.q.yar
|
|
but.u.q.q.yar
|
|
bus bul
|
|
bul bul
|
|
but but
|
|
==
|
|
::
|
|
++ goth :: extract history
|
|
|= hup=@ud
|
|
?> ?=(^ q.q.yar)
|
|
=+ byt=(~(get by hym.u.q.q.yar) hup)
|
|
?^ byt u.byt
|
|
(tuba (rip 3 (snag hup q.hyt.u.q.q.yar)))
|
|
::
|
|
++ kill :: add to kill ring
|
|
|= txt=(list ,@c)
|
|
^+ +>
|
|
=> ?. =(16 p.r.q.yar) .
|
|
.(p.r.q.yar 15, r.r.q.yar (scag 15 r.r.q.yar))
|
|
%= +>
|
|
p.r.q.yar +(p.r.q.yar)
|
|
q.r.q.yar 0
|
|
r.r.q.yar [txt r.r.q.yar]
|
|
==
|
|
::
|
|
++ look :: search in history
|
|
|= [hup=@ud txt=(list ,@c)]
|
|
^+ +>
|
|
=+ ^= beg
|
|
|= [a=(list ,@c) b=(list ,@c)] ^- ?
|
|
?~(a & ?~(b | &(=(i.a i.b) $(a t.a, b t.b))))
|
|
=+ ^= mid
|
|
|= [a=(list ,@c) b=(list ,@c)] ^- ?
|
|
?~(a & ?~(b | |((beg a b) $(b t.b))))
|
|
?> ?=(^ q.q.yar)
|
|
?: =(hup p.hyt.u.q.q.yar)
|
|
beep
|
|
=+ but=(goth hup)
|
|
?: (mid txt but)
|
|
(gore(hyr.u.q.q.yar [~ txt]) hup)
|
|
$(hup +(hup))
|
|
::
|
|
++ leap :: accept response
|
|
|= [tea=wire sih=sign]
|
|
^+ +>
|
|
?- -.+.sih
|
|
%crud :: error trace
|
|
=. q.+.sih [[%leaf (trip p.+.sih)] q.+.sih]
|
|
|- ^+ +>.^$
|
|
?~ q.+.sih +>.^$
|
|
(fume:$(q.+.sih t.q.+.sih) '!' `tank`i.q.+.sih)
|
|
::
|
|
::S %helo :: trigger prompt
|
|
::S %- edit
|
|
::S =| bed=bein
|
|
::S =+ ^= hyt ^- hist
|
|
::S =+ hyt=(~(get by r.yar) p.+.sih)
|
|
::S ?~(hyt *hist u.hyt)
|
|
::S ?: &(?=(^ q.q.yar) =(p.+.sih hux.u.q.q.yar))
|
|
::S %= u.q.q.yar
|
|
::S hyt [+(p.hyt) [%$ q.hyt]]
|
|
::S pot q.q.+.sih
|
|
::S pol (lent q.q.+.sih)
|
|
::S buy p.q.+.sih
|
|
::S ==
|
|
::S =+ zon=(tuba r.q.+.sih)
|
|
::S =+ zow=(lent zon)
|
|
::S %= bed
|
|
::S bul zow
|
|
::S bus zow
|
|
::S but zon
|
|
::S buy p.q.+.sih
|
|
::S hux p.+.sih
|
|
::S hiz 0
|
|
::S hyt [+(p.hyt) [%$ q.hyt]]
|
|
::S pot q.q.+.sih
|
|
::S pol (lent q.q.+.sih)
|
|
::S ==
|
|
::S ::
|
|
::S ?(%hail %make %sith)
|
|
::S +>.$(mos :_(mos [hen %pass ~ %b +.sih]))
|
|
::S ::
|
|
%mean ~& %dill-mean +>.$
|
|
%nice +>.$
|
|
%note ?.(p.yar +>.$ (fume p.+.sih q.+.sih)) :: debug message
|
|
?(%rush %rust) :: XX reset prompt
|
|
?> ?=(%term-line +>-.sih)
|
|
=. +>.$
|
|
=- (furl (zing (turn (flop r.q.sih) -)))
|
|
|= a=tark
|
|
^- wall
|
|
?+ -.a (~(win re a) 0 p.q.yar)
|
|
%stem ~[~(ram re p.a) ~(ram re p.a)]
|
|
==
|
|
%- edit
|
|
=| bed=bein
|
|
=+ ^= hyt ^- hist
|
|
=+ hyt=(~(get by r.yar) /)
|
|
?~(hyt *hist u.hyt)
|
|
?: &(?=(^ q.q.yar) =(/ hux.u.q.q.yar))
|
|
%= u.q.q.yar
|
|
bul ?~ but.u.q.q.yar (met 3 r.p.q.sih) bul.u.q.q.yar
|
|
bus ?~ but.u.q.q.yar (met 3 r.p.q.sih) bus.u.q.q.yar
|
|
but ?~ but.u.q.q.yar (rip 3 r.p.q.sih) but.u.q.q.yar
|
|
hyt [+(p.hyt) [%$ q.hyt]]
|
|
pot (trip p.p.q.sih)
|
|
pol (met 3 p.p.q.sih)
|
|
buy q.p.q.sih
|
|
==
|
|
%_ bed
|
|
bul (met 3 r.p.q.sih)
|
|
bus (met 3 r.p.q.sih)
|
|
but (rip 3 r.p.q.sih)
|
|
buy q.p.q.sih
|
|
hux /
|
|
hiz 0
|
|
hyt [+(p.hyt) [%$ q.hyt]]
|
|
pot (trip p.p.q.sih)
|
|
pol (met 3 p.p.q.sih)
|
|
==
|
|
::
|
|
%sage :: write a jamfile
|
|
%= +>.$
|
|
mos :_(mos [hen [%give %blit [%sag p.+.sih q.+.sih] ~]])
|
|
==
|
|
?(%init %logo %veer %vega %verb) :: drop-throughs
|
|
+>(mos :_(mos [hen %give +.sih]))
|
|
%writ :: file exists
|
|
%= +>.$
|
|
mos
|
|
:_ mos
|
|
[hen %pass / %g %show [our /terminal] our /lines]
|
|
==
|
|
==
|
|
::
|
|
++ lear :: handle request
|
|
|= kyz=kiss
|
|
^+ +>
|
|
?- -.kyz
|
|
%flog !!
|
|
%noop +>
|
|
%belt :: terminal input
|
|
?~ q.q.yar
|
|
%^ furl
|
|
"Downloading files from ticketing ship, please wait until"
|
|
"a prompt shows up. This could take several minutes."
|
|
~
|
|
?^ hyr.u.q.q.yar :: live search
|
|
?+ p.kyz $(hiz.u.q.q.yar 0, hyr.u.q.q.yar ~)
|
|
[%bac *]
|
|
?: =(~ u.hyr.u.q.q.yar)
|
|
(curb [[%bel ~] ~])
|
|
%- edit
|
|
%= u.q.q.yar
|
|
hyr [~ (scag (dec (lent u.hyr.u.q.q.yar)) u.hyr.u.q.q.yar)]
|
|
==
|
|
::
|
|
[%txt *] (look hiz.u.q.q.yar (weld u.hyr.u.q.q.yar p.p.kyz))
|
|
[%ctl %g] (edit u.q.q.yar(bul 0, bus 0, but ~, hiz 0, hyr ~))
|
|
[%ctl %r]
|
|
?: =(p.hyt.u.q.q.yar hiz.u.q.q.yar)
|
|
beep
|
|
(look +(hiz.u.q.q.yar) u.hyr.u.q.q.yar)
|
|
==
|
|
?- -.p.kyz
|
|
%aro :: arrow
|
|
?- p.p.kyz
|
|
%d :: down
|
|
?: =(0 hiz.u.q.q.yar)
|
|
beep
|
|
(gore (dec hiz.u.q.q.yar))
|
|
::
|
|
%l :: left
|
|
?: =(0 bus.u.q.q.yar)
|
|
beep
|
|
(edit u.q.q.yar(bus (dec bus.u.q.q.yar)))
|
|
::
|
|
%r :: right
|
|
?: =(bul.u.q.q.yar bus.u.q.q.yar)
|
|
beep
|
|
(edit u.q.q.yar(bus +(bus.u.q.q.yar)))
|
|
::
|
|
%u
|
|
=+ hup=+(hiz.u.q.q.yar)
|
|
?: =(hup p.hyt.u.q.q.yar)
|
|
beep
|
|
(gore hup)
|
|
==
|
|
::
|
|
%bac :: backspace
|
|
^+ +>.$
|
|
?: =(0 bus.u.q.q.yar)
|
|
(curb `(list blit)`[[%bel ~] ~])
|
|
%- edit
|
|
%= u.q.q.yar
|
|
bus (dec bus.u.q.q.yar)
|
|
bul (dec bul.u.q.q.yar)
|
|
but
|
|
%+ weld
|
|
(scag (dec bus.u.q.q.yar) but.u.q.q.yar)
|
|
(slag bus.u.q.q.yar but.u.q.q.yar)
|
|
==
|
|
::
|
|
%ctl :: control
|
|
?+ p.p.kyz
|
|
beep
|
|
%a (edit u.q.q.yar(bus 0))
|
|
%b $(kyz [%belt %aro %l])
|
|
%d ?: ?& =(0 bul.u.q.q.yar)
|
|
=(0 bus.u.q.q.yar)
|
|
==
|
|
+>.$(mos :_(mos (poke %term-in -:!>(*term-in) / %cmd %d)))
|
|
$(kyz [%belt %del ~])
|
|
%e (edit u.q.q.yar(bus bul.u.q.q.yar))
|
|
%f $(kyz [%belt %aro %r])
|
|
%k ?: =(bul.u.q.q.yar bus.u.q.q.yar)
|
|
beep
|
|
=> .(+>.$ (kill (slag bus.u.q.q.yar but.u.q.q.yar)))
|
|
%- edit
|
|
?> ?=(^ q.q.yar)
|
|
%= u.q.q.yar
|
|
bul bus.u.q.q.yar
|
|
but (scag bus.u.q.q.yar but.u.q.q.yar)
|
|
==
|
|
%t ?: (lth bul.u.q.q.yar 2)
|
|
beep
|
|
=+ ^= pos
|
|
?: =(bul.u.q.q.yar bus.u.q.q.yar)
|
|
(sub bus.u.q.q.yar 2)
|
|
?: =(0 bus.u.q.q.yar)
|
|
bus.u.q.q.yar
|
|
(dec bus.u.q.q.yar)
|
|
%- edit
|
|
%= u.q.q.yar
|
|
bus (add 2 pos)
|
|
but %+ weld
|
|
%+ weld
|
|
(scag pos but.u.q.q.yar)
|
|
^- (list ,@c) :+
|
|
(snag +(pos) but.u.q.q.yar)
|
|
(snag pos but.u.q.q.yar)
|
|
~
|
|
(slag (add 2 pos) but.u.q.q.yar)
|
|
==
|
|
%l +>.$(mos :_(mos [hen %give %blit [[%clr ~] ~]]))
|
|
%n $(kyz [%belt %aro %d])
|
|
%p $(kyz [%belt %aro %u])
|
|
%u ?: =(0 bus.u.q.q.yar)
|
|
beep
|
|
=> .(+>.$ (kill (scag bus.u.q.q.yar but.u.q.q.yar)))
|
|
%- edit
|
|
?> ?=(^ q.q.yar)
|
|
%= u.q.q.yar
|
|
bus 0
|
|
bul (sub bul.u.q.q.yar bus.u.q.q.yar)
|
|
but (slag bus.u.q.q.yar but.u.q.q.yar)
|
|
==
|
|
%r (edit u.q.q.yar(hyr [~ ~]))
|
|
%x +>.$(mos :_(mos (poke %term-in -:!>(*term-in) / %cmd %x)))
|
|
%y ?: =(0 p.r.q.yar)
|
|
beep
|
|
$(kyz [%belt %txt (snag q.r.q.yar r.r.q.yar)])
|
|
==
|
|
::
|
|
%del :: delete
|
|
?: =(bul.u.q.q.yar bus.u.q.q.yar)
|
|
beep
|
|
%- edit
|
|
%= u.q.q.yar
|
|
bul (dec bul.u.q.q.yar)
|
|
but
|
|
%+ weld
|
|
(scag bus.u.q.q.yar but.u.q.q.yar)
|
|
(slag +(bus.u.q.q.yar) but.u.q.q.yar)
|
|
==
|
|
::
|
|
%met :: meta
|
|
?+ p.p.kyz
|
|
beep
|
|
%f
|
|
?: =(bul.u.q.q.yar bus.u.q.q.yar)
|
|
beep
|
|
(edit u.q.q.yar(bus (wod u.q.q.yar)))
|
|
::
|
|
%b
|
|
?: =(0 bus.u.q.q.yar)
|
|
beep
|
|
(edit u.q.q.yar(bus (wob u.q.q.yar)))
|
|
::
|
|
%y
|
|
?: =(0 p.r.q.yar)
|
|
beep
|
|
=+ dol=(snag q.r.q.yar r.r.q.yar)
|
|
=+ leo=(lent dol)
|
|
?. (gte bus.u.q.q.yar leo)
|
|
beep
|
|
=+ pey=(sub bus.u.q.q.yar leo)
|
|
?. =(dol (swag [pey leo] but.u.q.q.yar))
|
|
beep
|
|
=. q.r.q.yar ?:(=(p.r.q.yar +(q.r.q.yar)) 0 +(q.r.q.yar))
|
|
=+ ney=(snag q.r.q.yar r.r.q.yar)
|
|
=+ lye=(lent ney)
|
|
%- edit
|
|
%= u.q.q.yar
|
|
bus (sub (add bus.u.q.q.yar lye) leo)
|
|
bul (sub (add bul.u.q.q.yar lye) leo)
|
|
but %+ weld
|
|
(scag pey but.u.q.q.yar)
|
|
%+ weld
|
|
`(list ,@c)`ney :: XX weird fuse-loop
|
|
(slag bus.u.q.q.yar but.u.q.q.yar)
|
|
==
|
|
==
|
|
::
|
|
%ret :: return
|
|
?: =(%none buy.u.q.q.yar) beep
|
|
=+ jab=(rap 3 (tufa but.u.q.q.yar))
|
|
%= +>.$
|
|
q.q.yar ~
|
|
r.yar
|
|
?: |(=(%$ jab) =(%pass buy.u.q.q.yar))
|
|
r.yar
|
|
%+ ~(put by r.yar)
|
|
hux.u.q.q.yar
|
|
[p.hyt.u.q.q.yar [jab ?~(q.hyt.u.q.q.yar ~ +.q.hyt.u.q.q.yar)]]
|
|
::
|
|
mos
|
|
:* (poke %term-ctrl -:!>(%hail) %hail)
|
|
[hen %give [%bbye ~]]
|
|
(poke %term-in -:!>(*term-in) / %line jab)
|
|
[hen %give [%blit [[%mor ~] ~]]]
|
|
mos
|
|
==
|
|
==
|
|
::
|
|
%txt :: text keys
|
|
?: =(%none buy.u.q.q.yar) beep
|
|
=+ let=(lent p.p.kyz)
|
|
%- edit
|
|
%= u.q.q.yar
|
|
bus (add let bus.u.q.q.yar)
|
|
bul (add let bul.u.q.q.yar)
|
|
but
|
|
;: weld
|
|
(scag bus.u.q.q.yar but.u.q.q.yar)
|
|
p.p.kyz
|
|
(slag bus.u.q.q.yar but.u.q.q.yar)
|
|
==
|
|
==
|
|
==
|
|
::
|
|
%blew +>.$(p.q.yar p.p.kyz) :: window size
|
|
%boot
|
|
%= +>.$
|
|
mos
|
|
:_(mos [hen %pass ~ (note %a p.kyz)])
|
|
==
|
|
::
|
|
%crud :: error trace
|
|
=. q.kyz [[%leaf (trip p.kyz)] q.kyz]
|
|
|- ^+ +>.^$
|
|
?~ q.kyz +>.^$
|
|
(fume:$(q.kyz t.q.kyz) '!' `tank`i.q.kyz)
|
|
::
|
|
%hail :: refresh
|
|
+>.$
|
|
::
|
|
%harm :: all terms hung up
|
|
=+ nug=((map duct yard) [[hen (~(get by dug) hen)] ~ ~])
|
|
^+ +>.$
|
|
%= +>.$
|
|
dug nug
|
|
::S mos :_(mos [hen %pass ~ %b kyz])
|
|
==
|
|
::
|
|
%hook :: this term hung up
|
|
~& %dill-hook-not-implemented
|
|
+>.$
|
|
::S +>.$(dug (~(del by dug) hen), mos :_(mos [hen %pass ~ %b kyz]))
|
|
::
|
|
%init
|
|
=. def `(fall def +.hen)
|
|
%= +>.$
|
|
our p.kyz
|
|
mos
|
|
:_ mos
|
|
[(need def) %pass / %c %warp [p.kyz p.kyz] %main `[%& %y [%ud 1] /]]
|
|
==
|
|
::
|
|
%talk (furl (~(win re p.kyz) 0 p.q.yar)) :: program output
|
|
%text $(kyz [%talk %leaf p.kyz]) :: simple message
|
|
==
|
|
::
|
|
++ poke
|
|
|= msg=mess
|
|
^- move
|
|
:^ hen %pass /
|
|
:^ %g %mess [our /terminal]
|
|
:- our msg
|
|
::
|
|
++ yerk :: complete core
|
|
^- [p=(list move) q=ship r=(unit duct) s=(map duct yard)]
|
|
:^ (flop mos) our def
|
|
(~(put by dug) hen yar)
|
|
--
|
|
--
|
|
=| $: %0 ::
|
|
our=ship ::
|
|
def=(unit duct) ::
|
|
dug=(map duct yard) ::
|
|
== ::
|
|
|= [now=@da eny=@ ski=sled] :: current invocation
|
|
|% :: poke/peek pattern
|
|
++ call :: handle request
|
|
|= $: hen=duct
|
|
hic=(hypo (hobo kiss))
|
|
==
|
|
^- [p=(list move) q=_..^$]
|
|
=> %= . :: XX temporary
|
|
q.hic
|
|
^- kiss
|
|
?: ?=(%soft -.q.hic)
|
|
:: ~& [%dill-call-soft (,@tas `*`-.p.q.hic)]
|
|
((hard kiss) p.q.hic)
|
|
?: (~(nest ut -:!>(*kiss)) | p.hic) q.hic
|
|
~& [%dill-call-flub (,@tas `*`-.q.hic)]
|
|
((hard kiss) q.hic)
|
|
==
|
|
?: ?=(%flog -.q.hic)
|
|
:_ ..^$
|
|
%+ turn (~(tap by dug) *(list ,[p=duct q=yard]))
|
|
|=([a=duct b=yard] [a %slip %d p.q.hic])
|
|
=+ res=yerk:(lear:(dy hen our def dug) q.hic)
|
|
[-.res ..^$(our +<.res, dug +>+.res, def +>-.res)]
|
|
::
|
|
++ doze
|
|
|= [now=@da hen=duct]
|
|
^- (unit ,@da)
|
|
~
|
|
::
|
|
++ load
|
|
|= old=[%0 our=ship def=(unit duct) dug=(map duct yard)]
|
|
^+ ..^$
|
|
..^$(our our.old, def def.old, dug dug.old)
|
|
::
|
|
++ scry
|
|
|= [fur=(unit (set monk)) ren=@tas his=ship syd=desk lot=coin tyl=path]
|
|
^- (unit (unit (pair mark ,*)))
|
|
[~ ~ [%tank >dug<]]
|
|
::
|
|
++ stay [%0 our def dug]
|
|
++ take :: process move
|
|
|= [tea=wire hen=duct hin=(hypo sign)]
|
|
^- [p=(list move) q=_..^$]
|
|
=+ res=yerk:(leap:(dy hen our def dug) tea q.hin)
|
|
[-.res ..^$(our +<.res, dug +>+.res, def +>-.res)]
|
|
--
|