!: :: dill (4d), terminal handling :: |= pit=vase => |% :: interface tiles ++ gill (pair ship term) :: general contact -- :: => |% :: console protocol ++ all-axle ?(old-axle axle) :: ++ old-axle :: all dill state $: %2 :: ore=(unit ship) :: identity once set hey=(unit duct) :: default duct dug=(map duct axon) :: conversations == :: ++ axle :: $: %3 :: ore=(unit ship) :: identity once set hey=(unit duct) :: default duct dug=(map duct axon) :: conversations $= hef :: other weights $: a=(unit mass) :: c=(unit mass) :: e=(unit mass) :: f=(unit mass) :: g=(unit mass) :: t=(unit mass) :: == :: == :: ++ axon :: dill per duct $: ram=term :: console program tem=(unit (list dill-belt)) :: pending, reverse wid=_80 :: terminal width pos=@ud :: cursor position see=(list ,@c) :: current line == :: -- => :: |% :: protocol below ++ gift gift-dill :: out result <-$ ++ kiss kiss-dill :: in request ->$ -- => :: |% :: protocol outward ++ mess :: $% [%dill-belt p=(hypo dill-belt)] :: == :: ++ cuft :: internal gift $% [%coup p=(unit tang)] :: poke result [%quit ~] :: close subscription [%reap p=(unit tang)] :: peer result [%diff p=cage] :: subscription output == :: ++ suss (trel term ,@tas ,@da) :: config report ++ move ,[p=duct q=(mold note gift)] :: local move ++ note-ames :: weird ames move $% [%make p=(unit ,@t) q=@ud r=@ s=?] :: [%sith p=@p q=@uw r=?] :: == :: ++ note-clay :: $% [%font p=@p q=@tas r=@p s=@tas] :: [%warp p=sock q=riff] :: wait for clay, hack == :: ++ note-dill :: note to self, odd $% [%crud p=@tas q=(list tank)] :: [%heft ~] :: [%init p=ship] :: [%text p=tape] :: [%veer p=@ta q=path r=@t] :: install vane [%vega p=path] :: reboot by path [%verb ~] :: verbose mode == :: ++ note-gall :: $% [%conf dock %load ship desk] :: [%deal p=sock q=cush] :: == :: ++ note :: out request $-> $? [?(%a %c %e %f %g %t) %wegh ~] :: $% [%a note-ames] :: [%c note-clay] :: [%d note-dill] :: [%g note-gall] :: == == :: ++ riff ,[p=desk q=(unit rave)] :: see %clay ++ sign-ames :: $% [%nice ~] :: [%init p=ship] :: == :: ++ sign-gall :: see %gall $% [%onto p=(unit tang)] :: == :: ++ sign-clay :: $% [%mere p=(each (set path) (pair term tang))] :: [%note p=@tD q=tank] :: [%writ p=riot] :: == :: ++ sign-dill :: $% [%blit p=(list blit)] :: == :: ++ sign-gall :: $% [%onto p=(each suss tang)] :: [%unto p=cuft] :: == :: ++ sign-time :: $% [%wake ~] :: == :: ++ sign :: in result $<- $? [?(%a %c %e %f %g %t) %mass p=mass] :: $% [%a sign-ames] :: [%c sign-clay] :: [%d sign-dill] :: [%g sign-gall] :: [%t sign-time] :: == == :: :::::::: :: dill tiles -- =| all=axle |= [now=@da eny=@ ski=sled] :: current invocation => |% ++ as :: per cause |_ $: [moz=(list move) hen=duct our=ship] axon == ++ abet :: resolve ^- [(list move) axle] [(flop moz) all(dug (~(put by dug.all) hen +<+))] :: ++ call :: receive input |= kyz=kiss ^+ +> ?+ -.kyz ~& [%strange-kiss -.kyz] +> %flow +> %harm +> %hail +> %belt (send `dill-belt`p.kyz) %text (from %out (tuba p.kyz)) %crud :: (send `dill-belt`[%cru p.kyz q.kyz]) (crud p.kyz q.kyz) %blew (send %rez p.p.kyz q.p.kyz) %heft heft %tick =+ ^= ges ^- gens ^- gens :- %en =+ can=(clan p.kyz) ?- can %czar [%czar ~] %duke [%duke %anon ~] %earl [%earl (scot %p p.kyz)] %king :- %king ?: =(~doznec p.kyz) :: so old tickets work 'Urban Republic' (scot %p p.kyz) %pawn [%pawn ~] == =+ yen=(scot %p (shax :(mix %ticket eny now))) =+ ^= beg ^- [his=@p tic=@p yen=@t ges=gens] [p.kyz q.kyz yen ges] =+ cag=`cage`[%hood-begin !>(beg)] %= +>.$ moz :_(moz [hen %pass ~ %g %deal [our our] %hood %poke cag]) == %veer (dump kyz) %vega (dump kyz) %verb (dump kyz) == :: ++ crud |= [err=@tas tac=(list tank)] =+ ^= wol ^- wall :- (trip err) (zing (turn tac |=(a=tank (~(win re a) [0 wid])))) |- ^+ +>.^$ ?~ wol +>.^$ $(wol t.wol, +>.^$ (from %out (tuba i.wol))) :: ++ dump :: pass down to hey |= git=gift ?> ?=(^ hey.all) +>(moz [[u.hey.all %give git] moz]) :: ++ done :: return gift |= git=gift +>(moz :_(moz [hen %give git])) :: ++ from :: receive belt |= bit=dill-blit ^+ +> ?: ?=(%mor -.bit) |- ^+ +>.^$ ?~ p.bit +>.^$ $(p.bit t.p.bit, +>.^$ ^$(bit i.p.bit)) ?: ?=(%out -.bit) %+ done %blit :~ [%lin p.bit] [%mor ~] [%lin see] [%hop pos] == ?: ?=(%pro -.bit) (done(see p.bit) %blit [[%lin p.bit] [%hop pos] ~]) ?: ?=(%hop -.bit) (done(pos p.bit) %blit [bit ~]) ?: ?=(%qit -.bit) (dump %logo ~) (done %blit [bit ~]) :: ++ heft %_ . moz :* [hen %pass /heft/ames %a %wegh ~] [hen %pass /heft/clay %c %wegh ~] [hen %pass /heft/eyre %e %wegh ~] [hen %pass /heft/ford %f %wegh ~] [hen %pass /heft/gall %g %wegh ~] [hen %pass /heft/time %t %wegh ~] moz == == :: ++ init :: initialize ~& [%dill-init our ram] =+ myt=(flop (need tem)) =+ can=(clan our) =. tem ~ =. moz :_(moz [hen %pass / %c %font our %home our %base]) =. moz ?. ?=(?(%king %czar) can) moz :_(moz [hen %pass / %c %font our %kids our %base]) =. moz :_(moz [hen %pass ~ %g %conf [[our ram] %load our %home]]) =. moz :_(moz [hen %pass ~ %g %deal [our our] ram %peer /drum]) |- ^+ +>+ ?~ myt +>+ $(myt t.myt, +>+ (send i.myt)) :: ++ into :: preinitialize |= gyl=(list gill) %_ +> tem `(turn gyl |=(a=gill [%yow a])) moz :_ moz :* hen %pass / %c [%warp [our our] %base `[%sing %y [%ud 1] /]] == == :: ++ send :: send action |= bet=dill-belt ?^ tem +>(tem `[bet u.tem]) %_ +> moz :_ moz [hen %pass ~ %g %deal [our our] ram %poke [%dill-belt -:!>(bet) bet]] == :: ++ pump :: send diff ack %_ . moz :_(moz [hen %pass ~ %g %deal [our our] ram %pump ~]) == :: ++ take :: receive |= sih=sign ^+ +> ?- sih [?(%a %c %e %f %g %t) %mass *] (wegt -.sih p.sih) :: [%a %nice *] :: ~& [%take-nice-ames sih] +> :: [%a %init *] +>(moz :_(moz [hen %give +.sih])) :: [%c %mere *] ?: ?=(%& -.p.sih) +>.$ ~| %dill-mere-fail ~| p.p.p.sih |- ?~ q.p.p.sih !! ~> %mean.|.(i.q.p.p.sih) :: pull ford fail into stack trace $(q.p.p.sih t.q.p.p.sih) :: [%g %onto *] :: ~& [%take-gall-onto +>.sih] ?- -.+>.sih %| (crud %onto p.p.+>.sih) %& (done %blit [%lin (tuba "{