urbit/try/bin/show.hoon
2014-08-01 11:34:42 -04:00

77 lines
2.3 KiB
Plaintext

!:
:: /=try=/bin/revert/hoon
:: Call with desk & change to revert
::
=> .(-< `who=@p`-<)
=> .(+ =>(+ ^/=/main/=/lib/pony))
|= [est=time eny=@uw]
|= $: des=span
fas=(list ,@ud)
==
=+ dom=((hard dome) .^(%cv /=/[des]/=)) :: should be instant
=+ cas=?~(fas let.dom i.fas) :: default to head
::%- (posh (add ~s1 est))
::|= tim=@da
=+ tim=est
^- bowl
:_ ~
^- (list gift)
=+ ran=((hard rang) .^(%cu /(scot %p who)/main/(scot %da tim)))
=+ hed=(~(got by hut.ran) (~(got by hit.dom) cas))
?~ p.hed !!
=+ ^= par
?~ fas (~(got by hut.ran) i.p.hed)
?~ t.fas (~(got by hut.ran) i.p.hed)
(~(got by hut.ran) (~(got by hit.dom) i.t.fas)) :: explicit
=+ ^= dif
%- %~ zerg ze
:+ est dom ran
?~ fas [par hed]
?~ t.fas [par hed]
[hed par]
=+ ^= sla
|= pat=path
%+ roll %+ turn pat |= t=@t (cat 3 '/' t)
|= [t=@t a=@t]
(cat 3 a t)
%- |= lin=(list ,@t)
:- [%la %leaf (trip (cat 3 '%show ' (scot %u cas)))]
%+ turn lin
|= lan=@t ^- gift
[%la %leaf (trip lan)]
%+ roll (~(tap by dif) ~)
|= [[pat=path mis=miso] lin=(list ,@t)]
?- -.mis
%del [(cat 3 '%del ' (sla pat)) lin]
%ins [(cat 3 '%ins ' (sla pat)) lin]
%mut ?> ?=(%c -.q.p.mis)
=+ ^= con
%- lore
%- (hard ,@)
%- %~ zaul ze
:+ est dom ran
(~(got by q.par) pat)
%+ welp lin
%+ welp [(cat 3 '%mut ' (sla pat)) ~]
^- (list ,@t)
=< q
%+ roll ((hard (urge ,@t)) p.q.p.mis)
|= [p=(unce ,@t) [q=(list ,@t) r=@ud]]
?- -.p
%& [q (add r p.p)]
%| =+ old=((hard (list ,@t)) p.p)
=+ new=((hard (list ,@t)) q.p)
=+ ^= pre
?: =(r 0) ~
(slag (dec r) con)
:_ (add r (lent p.p))
^- (list ,@t)
%+ welp q
%+ welp :_ ~ (cat 3 '%chunk ' (scot %u r))
%+ welp ?~ pre ~ :_ ~ (cat 3 '|| ' i.pre)
%+ welp %- flop %+ turn old |= t=@t (cat 3 '-< ' t)
%- flop %+ turn new |= t=@t (cat 3 '+> ' t)
==
==
::`gift`[%og des [let hit hut lat]]