From 0c8f77d187884d91e16a4b13e7089803632bd865 Mon Sep 17 00:00:00 2001 From: Joseph Bryan Date: Wed, 19 Oct 2016 12:28:11 -0400 Subject: [PATCH] adds support for styled prompt ... $pro in ++dill-blit, ++sole-prompt, drum/hood state transition --- app/hood.hoon | 4 +- arvo/dill.hoon | 3 ++ arvo/zuse.hoon | 1 + lib/drum.hoon | 110 ++++++++++++++++++++++++++++++------------------- sur/sole.hoon | 2 +- 5 files changed, 74 insertions(+), 46 deletions(-) diff --git a/app/hood.hoon b/app/hood.hoon index 6279b89b34..a2d0b475fd 100644 --- a/app/hood.hoon +++ b/app/hood.hoon @@ -32,7 +32,7 @@ $womb *part:womb :: $write *part:write :: == :: - ++ hood-part-old ?(hood-part) :: drum-part-old :: + ++ hood-part-old ?(hood-part drum-part-old) :: ++ hood-port :: |= paw/hood-part-old ^- hood-part :: ?+ -.paw paw :: @@ -40,7 +40,7 @@ == :: :: :: ++ hood-part :: - $% {$drum $1 drum-pith-1} :: + $% {$drum $2 drum-pith-2} :: {$helm $0 helm-pith} :: {$kiln $0 kiln-pith} :: {$womb $1 pith:womb} :: diff --git a/arvo/dill.hoon b/arvo/dill.hoon index eeeea1a717..1fd68a8a1d 100644 --- a/arvo/dill.hoon +++ b/arvo/dill.hoon @@ -189,6 +189,9 @@ == ?: ?=($pro -.bit) (done(see p.bit) %blit [[%lin p.bit] [%hop pos] ~]) + ?: ?=($pom -.bit) + =. see (cvrt:ansi p.bit) + (done %blit [[%lin see] [%hop pos] ~]) ?: ?=($hop -.bit) (done(pos p.bit) %blit [bit ~]) ?: ?=($qit -.bit) diff --git a/arvo/zuse.hoon b/arvo/zuse.hoon index c80e065d70..e6d30a89dc 100644 --- a/arvo/zuse.hoon +++ b/arvo/zuse.hoon @@ -2761,6 +2761,7 @@ {$hop p/@ud} :: set cursor position {$mor p/(list dill-blit)} :: multiple blits {$pro p/(list @c)} :: show as cursor+line + {$pom p/stub} :: styled prompt {$qit $~} :: close console {$out p/(list @c)} :: send output line {$sag p/path q/*} :: save to jamfile diff --git a/lib/drum.hoon b/lib/drum.hoon index ef84bc72a1..13dfa8ec4e 100644 --- a/lib/drum.hoon +++ b/lib/drum.hoon @@ -9,10 +9,18 @@ :::: :: :: :: :: :: |% :: :: -++ drum-part {$drum $1 drum-pith-1} :: -++ drum-part-old {$drum $0 drum-pith-0} :: -++ drum-pith-0 _!! :: forgotten -++ drum-pith-1 :: +++ drum-part {$drum $2 drum-pith-2} :: +++ drum-part-old {$drum $1 drum-pith-1} :: +:: :: +++ drum-pith-1 :: pre-style + %+ cork drum-pith-2 :: + |=(drum-pith-2 +<(bin *(map bone source-1))) :: +:: :: +++ source-1 :: + %+ cork source :: + |=(source +<(mir *(pair @ud (list @c)))) :: style-less mir +:: :: +++ drum-pith-2 :: $: sys/(unit bone) :: local console eel/(set gill) :: connect to ray/(set well) :: @@ -38,7 +46,7 @@ kil/kill :: kill buffer inx/@ud :: ring index fug/(map gill (unit target)) :: connections - mir/(pair @ud (list @c)) :: mirrored terminal + mir/(pair @ud stub) :: mirrored terminal == :: ++ history :: past input $: pos/@ud :: input position @@ -85,7 +93,7 @@ |= our/ship ^- drum-part :* %drum - %1 + %2 ~ :: sys (deft-fish our) :: eel (deft-apes our) :: ray @@ -96,8 +104,13 @@ ++ drum-port |= old/?(drum-part drum-part-old) ^- drum-part ?- &2.old - $1 old - $0 !! :: XX unreachable, see issue #242 + $2 old + $1 %= old + &2 %2 + bin %- ~(run by bin.old) + |= source-1 ^- source + +<(mir [(add 20 p.mir) [[*stye q.mir] ~]]) + == == :: ++ drum-path :: encode path @@ -384,18 +397,20 @@ (se-emit [u.sys %diff %dill-blit bil]) :: ++ se-show :: show buffer, raw - |= lin/(pair @ud (list @c)) + |= lin/(pair @ud stub) ^+ +> ?: =(mir lin) +> - =. +> ?:(=(q.mir q.lin) +> (se-blit %pro q.lin)) + =. +> ?:(=(q.mir q.lin) +> (se-blit %pom q.lin)) =. +> ?:(=(p.mir p.lin) +> (se-blit %hop p.lin)) +>(mir lin) :: ++ se-just :: adjusted buffer - |= lin/(pair @ud (list @c)) + |= lin/(pair @ud stub) ^+ +> =. off ?:((lth p.lin edg) 0 (sub p.lin edg)) - (se-show (sub p.lin off) (scag edg (slag off q.lin))) + :: XX: wrap q.lin?? + :: (se-show (sub p.lin off) (scag edg (slag off q.lin))) + (se-show (sub p.lin off) q.lin) :: ++ se-view :: flush buffer ^+ . @@ -576,36 +591,34 @@ |= pos/@ud (ta-erl (~(transpose sole say.inp) pos)) :: + ++ flatten-styx + |= a/styx + =| b/styd + %+ reel + |- ^- stub + %- zing + %+ turn a + |= a/$@(@t (pair styl styx)) + ?@ a + [b (tuba (trip a))]~ + %= ^$ + a q.a + b :+ ?~ p.p.a p.b + ?~(u.p.p.a ~ (~(put in p.b) u.p.p.a)) + ?~(p.q.p.a p.q.b u.p.q.p.a) + ?~(q.q.p.a q.q.b u.q.q.p.a) + == + :: + |= {a/(pair styd (list @c)) b/stub} + ?~ b + [a]~ + ?. =(p.a p.i.b) + [a b] + [[p.a (weld q.a q.i.b)] t.b] + :: ++ ta-klr :: render styled text |= a/styx - =< =. +>+>.$ (se-klr (flatten a)) - +>.$ - |% - ++ flatten - |= a/styx - =| b/styd - %+ reel - |- ^- stub - %- zing - %+ turn a - |= a/_?>(?=(^ a) i.a) - ?@ a - [b (tuba (trip a))]~ - %= ^$ - a q.a - b :+ ?~ p.p.a p.b - ?~(u.p.p.a ~ (~(put in p.b) u.p.p.a)) - ?~(p.q.p.a p.q.b u.p.q.p.a) - ?~(q.q.p.a q.q.b u.q.q.p.a) - == - :: - |= {a/(pair styd (list @c)) b/stub} - ?~ b - [a]~ - ?. =(p.a p.i.b) - [a b] - [[p.a (weld q.a q.i.b)] t.b] - -- + +>(..ta (se-klr (flatten-styx a))) :: ++ ta-fec :: apply effect |= fec/sole-effect @@ -842,9 +855,20 @@ (ta-hom (cat:edit pos.inp txt)) :: ++ ta-vew :: computed prompt - |- ^- (pair @ud (list @c)) - =; vew/(pair (list @c) tape) - [(add pos.inp (lent q.vew)) (weld (tuba q.vew) p.vew)] + ^- (pair @ud stub) + =; vew/(pair (list @c) styx) + =/ lin/stub + (flatten-styx q.vew) + =/ len + %- (curr roll add) + %+ turn + lin + |= a/(pair styd (list @c)) + %+ add + (lent (tail a)) + =+ d=~(wyt in p.p.a) + (mul 4 ?:(=(0 d) 0 +(d))) + [(add pos.inp len) (welp lin [*styd p.vew]~)] ?: vis.pom :- buf.say.inp :: default prompt ?~ ris diff --git a/sur/sole.hoon b/sur/sole.hoon index b00baa7f90..793ff256b0 100644 --- a/sur/sole.hoon +++ b/sur/sole.hoon @@ -46,7 +46,7 @@ ++ sole-prompt :: prompt definition $: vis/? :: command visible tag/term :: history mode - cad/tape :: caption + cad/styx :: caption == :: ++ sole-share :: symmetric state $: ven/sole-clock :: our vector clock