diff --git a/ape/dojo.hoon b/ape/dojo.hoon index dcc30ba4a..54acf9a8e 100644 --- a/ape/dojo.hoon +++ b/ape/dojo.hoon @@ -100,7 +100,7 @@ house :: program state == :: ++ he :: per session - |_ [[ost=bone moz=(list move)] session] :: + |_ [moz=(list move) session] :: ++ dp :: dojo parser |% ++ dp-default-app %hood @@ -670,7 +670,11 @@ == :: ++ he-abet :: resolve - [(flop moz) %_(+> hoc (~(put by hoc) ost +<+))] + [(flop moz) %_(+> hoc (~(put by hoc) ost.hid +<+))] + :: + ++ he-abut :: discard + => he-stop + [(flop moz) %_(+> hoc (~(del by hoc) ost.hid))] :: ++ he-beak -:he-beam ++ he-beam :: logical beam @@ -681,7 +685,7 @@ ++ he-card :: emit gift |= cad=card ^+ +> - %_(+> moz [[ost cad] moz]) + %_(+> moz [[ost.hid cad] moz]) :: ++ he-send |= [way=wire him=ship dap=term cop=clap] @@ -844,10 +848,10 @@ == :: :: pattern: ++ foo |=(data he-abet:(~(he-foo he (~(got by hoc) ost)) data)) -++ arm (arm-session (~(got by hoc) ost.hid)) +++ arm (arm-session ~ (~(got by hoc) ost.hid)) ++ arm-session - |= ses=session - => ~(. he [ost.hid ~] ses) + |= [moz=(list move) ses=session] + => ~(. he moz ses) =- [wrap=- +] |* he-arm=_he-type |= _+<.he-arm ^- (quip move ..he) @@ -856,9 +860,12 @@ ++ peer-sole ~? !=(src.hid our.hid) [%dojo-peer-stranger ost.hid src.hid] :: ?> =(src.hid our.hid) - ~? (~(has by hoc) ost.hid) [%dojo-peer-replaced ost.hid] + =^ moz . + ?. (~(has by hoc) ost.hid) [~ .] + ~& [%dojo-peer-replaced ost.hid] + ~(he-abut he ~ (~(got by hoc) ost.hid)) =+ ses=%*(. *session -.dir [our.hid %home ud/0]) - (wrap he-peer):(arm-session ses) + (wrap he-peer):(arm-session moz ses) :: ++ poke-sole-action |= act=sole-action ~| poke/act %. act @@ -872,7 +879,6 @@ ++ pull |= [pax=path] ^- (quip move +>) - =^ moz +> - he-abet:~(he-stop he [[ost.hid ~] (~(got by hoc) ost.hid)]) + =^ moz +> ~(he-abut he ~ (~(got by hoc) ost.hid)) [moz +>.$(hoc (~(del by hoc) ost.hid))] -- diff --git a/ape/hood.hoon b/ape/hood.hoon index 89e218f94..a14cf7d4e 100644 --- a/ape/hood.hoon +++ b/ape/hood.hoon @@ -56,6 +56,11 @@ ~? ?=(^ saw) [%kiln-spam-lame u.saw] [~ +>] :: +++ coup-kiln-reload :: + |= [way=wire saw=(unit tang)] + ~? ?=(^ saw) [%kiln-reload-lame u.saw] + [~ +>] +:: ++ coup-drum-phat (wrap take-coup-phat):from-drum ++ coup-helm-hi (wrap coup-hi):from-helm ++ diff-sole-effect-drum-phat (wrap diff-sole-effect-phat):from-drum @@ -72,41 +77,45 @@ ++ from-helm (from-lib %helm [..$ ,_abet]:(helm)) ++ from-kiln (from-lib %kiln [..$ ,_abet]:(kiln)) :: -++ init-helm |=([way=wire *] [~ +>]) -++ made-kiln (wrap take-made):from-kiln -++ mere-kiln (wrap take-mere):from-kiln -++ mere-kiln-sync (wrap take-mere-sync):from-kiln -++ note-helm (wrap take-note):from-helm -++ onto-drum (wrap take-onto):from-drum -++ peer-drum (wrap peer):from-drum -++ poke-dill-belt (wrap poke-dill-belt):from-drum -++ poke-drum-link (wrap poke-link):from-drum -::++ poke-drum-exit (wrap poke-exit):from-drum -++ poke-drum-start (wrap poke-start):from-drum -++ poke-helm-hi (wrap poke-hi):from-helm -++ poke-helm-init (wrap poke-init):from-helm -++ poke-helm-invite (wrap poke-invite):from-helm -++ poke-helm-mass (wrap poke-mass):from-helm -++ poke-helm-reload (wrap poke-reload):from-helm -++ poke-helm-reload-desk (wrap poke-reload-desk):from-helm -++ poke-helm-reset (wrap poke-reset):from-helm -++ poke-helm-send-hi (wrap poke-send-hi):from-helm -++ poke-helm-verb (wrap poke-verb):from-helm -++ poke-helm-begin (wrap poke-begin):from-helm -++ poke-hood-sync (wrap poke-sync):from-kiln -++ poke-kiln-cp (wrap poke-cp):from-kiln -++ poke-kiln-label (wrap poke-label):from-kiln -++ poke-kiln-merge (wrap poke-merge):from-kiln -++ poke-kiln-mount (wrap poke-mount):from-kiln -++ poke-kiln-mv (wrap poke-mv):from-kiln -++ poke-kiln-rm (wrap poke-rm):from-kiln -++ poke-kiln-schedule (wrap poke-schedule):from-kiln -++ poke-kiln-sync (wrap poke-sync):from-kiln -++ poke-kiln-unmount (wrap poke-unmount):from-kiln -++ poke-kiln-unsync (wrap poke-unsync):from-kiln -++ poke-will (wrap poke-will):from-helm -++ quit-drum-phat (wrap quit-phat):from-drum -++ reap-drum-phat (wrap reap-phat):from-drum -++ woot-helm (wrap take-woot):from-helm -++ writ-kiln-sync (wrap take-writ):from-kiln +++ init-helm |=([way=wire *] [~ +>]) +++ made-kiln (wrap take-made):from-kiln +++ mere-kiln (wrap take-mere):from-kiln +++ mere-kiln-sync (wrap take-mere-sync):from-kiln +++ note-helm (wrap take-note):from-helm +++ onto-drum (wrap take-onto):from-drum +++ peer-drum (wrap peer):from-drum +++ poke-dill-belt (wrap poke-dill-belt):from-drum +++ poke-drum-link (wrap poke-link):from-drum +::++ poke-drum-exit (wrap poke-exit):from-drum +++ poke-drum-start (wrap poke-start):from-drum +++ poke-helm-hi (wrap poke-hi):from-helm +++ poke-helm-init (wrap poke-init):from-helm +++ poke-helm-invite (wrap poke-invite):from-helm +++ poke-helm-mass (wrap poke-mass):from-helm +++ poke-helm-reload (wrap poke-reload):from-helm +++ poke-helm-reload-desk (wrap poke-reload-desk):from-helm +++ poke-helm-reset (wrap poke-reset):from-helm +++ poke-helm-send-hi (wrap poke-send-hi):from-helm +++ poke-helm-verb (wrap poke-verb):from-helm +++ poke-helm-begin (wrap poke-begin):from-helm +++ poke-hood-sync (wrap poke-sync):from-kiln +++ poke-kiln-cp (wrap poke-cp):from-kiln +++ poke-kiln-label (wrap poke-label):from-kiln +++ poke-kiln-merge (wrap poke-merge):from-kiln +++ poke-kiln-cancel (wrap poke-cancel):from-kiln +++ poke-kiln-mount (wrap poke-mount):from-kiln +++ poke-kiln-mv (wrap poke-mv):from-kiln +++ poke-kiln-rm (wrap poke-rm):from-kiln +++ poke-kiln-schedule (wrap poke-schedule):from-kiln +++ poke-kiln-sync (wrap poke-sync):from-kiln +++ poke-kiln-start-autoload (wrap poke-start-autoload):from-kiln +++ poke-kiln-autoload (wrap poke-autoload):from-kiln +++ poke-kiln-unmount (wrap poke-unmount):from-kiln +++ poke-kiln-unsync (wrap poke-unsync):from-kiln +++ poke-will (wrap poke-will):from-helm +++ quit-drum-phat (wrap quit-phat):from-drum +++ reap-drum-phat (wrap reap-phat):from-drum +++ woot-helm (wrap take-woot):from-helm +++ writ-kiln-autoload (wrap take-writ-autoload):from-kiln +++ writ-kiln-sync (wrap take-writ-sync):from-kiln -- diff --git a/arvo/clay.hoon b/arvo/clay.hoon index f6c8f9bf3..e43c090fe 100644 --- a/arvo/clay.hoon +++ b/arvo/clay.hoon @@ -162,11 +162,7 @@ mer=mer.jod == =* red -> - =| yel=(list ,[p=duct q=gift]) - =| byn=(list ,[p=duct q=riot]) - =| reg=(list ,[p=duct q=gift]) - =| say=(list ,[p=duct q=path r=ship s=[p=@ud q=riff]]) - =| tag=(list move) + =| mow=(list move) |% ++ abet ^- [(list move) raft] @@ -176,23 +172,7 @@ ruf(hoy (~(put by hoy.ruf) her rug)) =+ dos=(~(put by dos.u.rom) syd [qyx dom dok mer]) ruf(fat (~(put by fat.ruf) her [(need hun) dos])) - ;: weld - %+ turn (flop yel) - |=([a=duct b=gift] [(need hun) %give b]) - :: - %+ turn (flop reg) - |=([a=duct b=gift] [a %give b]) - :: - %+ turn (flop byn) - |=([a=duct b=riot] [a %give [%writ b]]) - :: - %+ turn (flop say) - |= [a=duct b=path c=ship d=[p=@ud q=riff]] - :- a - [%pass b %a %wont [our c] [%c %question p.q.d (scot %ud p.d) ~] q.d] - :: - tag - == + (flop mow) :: ++ aver :: read |= mun=mood @@ -260,6 +240,14 @@ (mule |.(`~`~|([%expected-path got=p.pax] !!))) $(tay t.tay, can (~(put by can) ((hard path) q.q.pax) q.i.tay)) :: + ++ emit + |= mof=move + %_(+> mow [mof mow]) + :: + ++ emil + |= mof=(list move) + %_(+> mow (welp mof mow)) + :: ++ balk :: read and send |= [hen=duct cay=(unit (each cage lobe)) mun=mood] ^+ +> @@ -268,18 +256,18 @@ :: ++ bait |= [hen=duct tym=@da] - %_(+> tag :_(tag [hen %pass /tyme %t %wait tym])) + (emit hen %pass /tyme %t %wait tym) :: ++ best |= [hen=duct tym=@da] - %_(+> tag :_(tag [hen %pass /tyme %t %rest tym])) + (emit hen %pass /tyme %t %rest tym) :: ++ blab :: ship result |= [hen=duct mun=mood dat=(each cage lobe)] ^+ +> ?: ?=(%& -.dat) - +>.$(byn [[hen ~ [p.mun q.mun syd] r.mun p.dat] byn]) - =- +>.$(tag [- tag]) + (emit hen %give %writ ~ [p.mun q.mun syd] r.mun p.dat) + %- emit :* hen %pass [%blab p.mun (scot q.mun) syd r.mun] %f %exec our ~ [her syd q.mun] (lobe-to-silk:ze r.mun p.dat) == @@ -295,7 +283,15 @@ :: ++ blub :: ship stop |= hen=duct - %_(+> byn [[hen ~] byn]) + (emit hen %give %writ ~) + :: + ++ print-to-dill + |= [car=@tD tan=tank] + (emit (need hun) %give %note car tan) + :: + ++ send-over-ames + |= [a=duct b=path c=ship d=[p=@ud q=riff]] + (emit a %pass b %a %wont [our c] [%c %question p.q.d (scot %ud p.d) ~] q.d) :: ++ duce :: produce request |= rov=rove @@ -309,8 +305,10 @@ ?. ?=([%sing %v *] rav) rav [%many %| [%ud let.dom] `case`q.p.rav r.p.rav] =+ inx=nix.u.ref + =. +>+.$ + =< ?>(?=(^ ref) .) + (send-over-ames hen [(scot %ud inx) ~] her inx syd ~ vaw) %= +>+.$ - say [[hen [(scot %ud inx) ~] her [inx syd ~ vaw]] say] nix.u.ref +(nix.u.ref) bom.u.ref (~(put by bom.u.ref) inx [hen vaw]) fod.u.ref (~(put by fod.u.ref) hen inx) @@ -335,22 +333,19 @@ =+ mus=(skim can |=(paf=path =(pax (scag (lent pax) paf)))) ?~ mus +>.$ - %_ +>.$ - tag - :_ tag - :* hen %pass [%ergoing (scot %p her) syd ~] %f - %exec our ~ [her syd %da now] %tabl - ^- (list (pair silk silk)) - %+ turn `(list path)`mus - |= a=path - ^- (pair silk silk) - :- [%$ %path !>(a)] - :+ %cast %mime - =+ (need (need (read-x:ze let.dom a))) - ?: ?=(%& -<) - [%$ p.-] - (lobe-to-silk:ze a p.-) - == + %- emit + :* hen %pass [%ergoing (scot %p her) syd ~] %f + %exec our ~ [her syd %da now] %tabl + ^- (list (pair silk silk)) + %+ turn `(list path)`mus + |= a=path + ^- (pair silk silk) + :- [%$ %path !>(a)] + :+ %cast %mime + =+ (need (need (read-x:ze let.dom a))) + ?: ?=(%& -<) + [%$ p.-] + (lobe-to-silk:ze a p.-) == :: ++ ease :: release request @@ -364,8 +359,10 @@ |- ^+ +.$ =+ nux=(~(get by fod.u.ref) hen) ?~ nux +.$ + =. +.$ + =< ?>(?=(^ ref) .) + (send-over-ames hen [(scot %ud u.nux) ~] her u.nux syd ~) %= +.$ - say [[hen [(scot %ud u.nux) ~] her [u.nux syd ~]] say] fod.u.ref (~(del by fod.u.ref) hen) bom.u.ref (~(del by bom.u.ref) u.nux) == @@ -422,31 +419,19 @@ (duce `rove`[%many p.rav ptr q.q.rav r.q.rav ear]) == :: - ++ echa :: announce raw - |= [wen=@da mer=mizu] - ^+ +> - %= +> - reg ~& %merge-announce reg - :: yel [[hen %note '=' %leaf ~] yel] :: XX do better - == - :: ++ echo :: announce changes |= [wen=@da lem=nuri] ^+ +> - %_ +>.$ - yel - =+ pre=`path`~[(scot %p her) syd (scot %ud let.dom)] - ?- -.lem - | :_ yel - [hen %note '=' %leaf :(weld (trip p.lem) " " (spud pre))] - & |- ^+ yel - ?~ p.lem yel - :_ $(p.lem t.p.lem) - :- hen - :+ %note - ?-(-.q.i.p.lem %del '-', %ins '+', %dif ':') - [%leaf (spud (weld pre p.i.p.lem))] - == + =+ pre=`path`~[(scot %p her) syd (scot %ud let.dom)] + ?- -.lem + | (print-to-dill '=' %leaf :(weld (trip p.lem) " " (spud pre))) + & |- ^+ +>.^$ + ?~ p.lem +>.^$ + =. +>.^$ + %+ print-to-dill + ?-(-.q.i.p.lem %del '-', %ins '+', %dif ':') + [%leaf (spud (weld pre p.i.p.lem))] + $(p.lem t.p.lem) == :: ++ edit :: apply changes @@ -472,107 +457,97 @@ ?& ?=([?(%hoon %hook) *] (flop pax)) ?=(%mime p.p.mis) == - =- %_ +>.$ - tag (welp - tag) - dok - :- ~ - :* %+ turn del + =. +>.$ + %- emil + ^- (list move) + :~ :* hen %pass + [%inserting (scot %p her) syd (scot %da wen) ~] + %f %exec our ~ [her syd %da wen] %tabl + ^- (list (pair silk silk)) + %+ turn ins |= [pax=path mis=miso] - ?> ?=(%del -.mis) - pax - :: - %+ turn ink - |= [pax=path mis=miso] - ^- (pair path cage) ?> ?=(%ins -.mis) + :- [%$ %path -:!>(*path) pax] =+ =>((flop pax) ?~(. %$ i)) - [pax - [%atom %t] ((hard ,@t) +>.q.q.p.mis)] - :: - ~ - :: - %- mo + [%cast - [%$ p.mis]] + == + :* hen %pass + [%diffing (scot %p her) syd (scot %da wen) ~] + %f %exec our ~ [her syd %da wen] %tabl + ^- (list (pair silk silk)) %+ turn dif |= [pax=path mis=miso] ?> ?=(%dif -.mis) - [pax p.mis] - :: - ~ - :: - %- mo + =+ (need (need (read-x:ze let.dom pax))) + ?> ?=(%& -<) + :- [%$ %path -:!>(*path) pax] + [%pact [%$ p.-] [%$ p.mis]] + == + :* hen %pass + [%castifying (scot %p her) syd (scot %da wen) ~] + %f %exec our ~ [her syd %da wen] %tabl + ^- (list (pair silk silk)) %+ turn mut |= [pax=path mis=miso] ?> ?=(%mut -.mis) - [pax p.mis] - :: - ~ - :: - ~ - :: - %- mo ^- (list (pair path mime)) - ;: welp - ^- (list (pair path mime)) - %+ murn ins - |= [pax=path mis=miso] - ^- (unit (pair path mime)) - ?> ?=(%ins -.mis) - ?. ?=(%mime p.p.mis) - ~ - `[pax ((hard mime) q.q.p.mis)] - :: - ^- (list (pair path mime)) - %+ murn ink - |= [pax=path mis=miso] - ^- (unit (pair path mime)) - ?> ?=(%ins -.mis) - ?> ?=(%mime p.p.mis) - `[pax ((hard mime) q.q.p.mis)] - :: - ^- (list (pair path mime)) - %+ murn mut - |= [pax=path mis=miso] - ^- (unit (pair path mime)) - ?> ?=(%mut -.mis) - ?. ?=(%mime p.p.mis) - ~ - `[pax ((hard mime) q.q.p.mis)] - == + :- [%$ %path -:!>(*path) pax] + =+ (lobe-to-mark:ze (~(got by q:(aeon-to-yaki:ze let.dom)) pax)) + [%cast - [%$ p.mis]] == - == - ^- (list move) - :~ :* hen %pass - [%inserting (scot %p her) syd (scot %da wen) ~] - %f %exec our ~ [her syd %da wen] %tabl - ^- (list (pair silk silk)) - %+ turn ins + == + %_ +>.$ + dok + :- ~ + :* (turn del |=([pax=path mis=miso] ?>(?=(%del -.mis) pax))) + :: + %+ turn ink + |= [pax=path mis=miso] + ^- (pair path cage) + ?> ?=(%ins -.mis) + =+ =>((flop pax) ?~(. %$ i)) + [pax - [%atom %t] ((hard ,@t) +>.q.q.p.mis)] + :: + ~ + :: + (mo (turn dif |=([pax=path mis=miso] ?>(?=(%dif -.mis) [pax p.mis])))) + :: + ~ + :: + (mo (turn mut |=([pax=path mis=miso] ?>(?=(%mut -.mis) [pax p.mis])))) + :: + ~ + :: + ~ + :: + %- mo ^- (list (pair path mime)) + ;: welp + ^- (list (pair path mime)) + %+ murn ins |= [pax=path mis=miso] + ^- (unit (pair path mime)) ?> ?=(%ins -.mis) - :- [%$ %path -:!>(*path) pax] - =+ =>((flop pax) ?~(. %$ i)) - [%cast - [%$ p.mis]] - == - :* hen %pass - [%diffing (scot %p her) syd (scot %da wen) ~] - %f %exec our ~ [her syd %da wen] %tabl - ^- (list (pair silk silk)) - %+ turn dif + ?. ?=(%mime p.p.mis) + ~ + `[pax ((hard mime) q.q.p.mis)] + :: + ^- (list (pair path mime)) + %+ murn ink |= [pax=path mis=miso] - ?> ?=(%dif -.mis) - =+ (need (need (read-x:ze let.dom pax))) - ?> ?=(%& -<) - :- [%$ %path -:!>(*path) pax] - [%pact [%$ p.-] [%$ p.mis]] - == - :* hen %pass - [%castifying (scot %p her) syd (scot %da wen) ~] - %f %exec our ~ [her syd %da wen] %tabl - ^- (list (pair silk silk)) - %+ turn mut + ^- (unit (pair path mime)) + ?> ?=(%ins -.mis) + ?> ?=(%mime p.p.mis) + `[pax ((hard mime) q.q.p.mis)] + :: + ^- (list (pair path mime)) + %+ murn mut |= [pax=path mis=miso] + ^- (unit (pair path mime)) ?> ?=(%mut -.mis) - :- [%$ %path -:!>(*path) pax] - =+ (lobe-to-mark:ze (~(got by q:(aeon-to-yaki:ze let.dom)) pax)) - [%cast - [%$ p.mis]] - == + ?. ?=(%mime p.p.mis) + ~ + `[pax ((hard mime) q.q.p.mis)] + == + == == :: ++ silkify @@ -691,8 +666,7 @@ %+ turn cat |= [pax=path cay=cage] [pax (page-to-lobe:ze [p q.q]:cay)] - =- %_(+>.$ tag [- tag]) - ^- move + %- emit :* hen %pass [%mutating (scot %p her) syd (scot %da wen) ~] %f %exec our ~ [her syd %da wen] %tabl @@ -733,11 +707,8 @@ ^+ +> :: ~& %taking-patch ?: ?=(%| -.res) - %_ +>.$ - dok ~ - yel - [[hen %note '!' %rose [" " "" ""] leaf/"clay patch failed" p.res] yel] - == + =. dok ~ + (print-to-dill '!' %rose [" " "" ""] leaf/"clay patch failed" p.res) :: ~& %editing =+ ^- sim=(list (pair path misu)) ?~ dok @@ -795,38 +766,31 @@ =+ can=(mo sim) :: ~& %forming-ergo :: =- ~& %formed-ergo - - %_ +>.$ - dok ~ - tag - :_ tag - :* hen %pass [%ergoing (scot %p her) syd ~] %f - %exec our ~ [her syd %da now] %tabl - ^- (list (pair silk silk)) - %+ turn (~(tap in sum)) - |= a=path - ^- (pair silk silk) - :- [%$ %path !>(a)] - =+ b=(~(got by can) a) - ?: ?=(%del -.b) - [%$ %null !>(~)] - =+ (~(get by mim.u.dok) a) - ?^ - [%$ %mime !>(u.-)] - :+ %cast %mime - =+ (need (need (read-x:ze let.dom a))) - ?: ?=(%& -<) - [%$ p.-] - (lobe-to-silk:ze a p.-) - == + %- emit(dok ~) + :* hen %pass [%ergoing (scot %p her) syd ~] %f + %exec our ~ [her syd %da now] %tabl + ^- (list (pair silk silk)) + %+ turn (~(tap in sum)) + |= a=path + ^- (pair silk silk) + :- [%$ %path !>(a)] + =+ b=(~(got by can) a) + ?: ?=(%del -.b) + [%$ %null !>(~)] + =+ (~(get by mim.u.dok) a) + ?^ - [%$ %mime !>(u.-)] + :+ %cast %mime + =+ (need (need (read-x:ze let.dom a))) + ?: ?=(%& -<) + [%$ p.-] + (lobe-to-silk:ze a p.-) == :: ++ take-ergo |= res=gage ^+ +> ?: ?=(%| -.res) - %_ +>.$ - yel - [[hen %note '!' %rose [" " "" ""] leaf/"clay ergo failed" p.res] yel] - == + (print-to-dill '!' %rose [" " "" ""] leaf/"clay ergo failed" p.res) ?~ hez ~|(%no-sync-duct !!) =+ ^- can=(map path (unit mime)) %- mo ^- mode @@ -839,33 +803,27 @@ ~ `((hard mime) q.q.mim) =+ mus=(must-ergo (turn (~(tap by can)) head)) - %= +>.$ - reg - %- welp :_ reg - %+ turn (~(tap by mus)) - |= [pot=term len=@ud pak=(set path)] - :* u.hez %ergo pot - %+ turn (~(tap in pak)) - |= pax=path - [(slag len pax) (~(got by can) pax)] - == + %- emil + %+ turn (~(tap by mus)) + |= [pot=term len=@ud pak=(set path)] + :* u.hez %give %ergo pot + %+ turn (~(tap in pak)) + |= pax=path + [(slag len pax) (~(got by can) pax)] == :: ++ checkout-ankh |= hat=(map path lobe) ^+ +> - %_ +>.$ - tag - :_ tag - :* hen %pass [%patching (scot %p her) syd ~] %f - %exec our :^ ~ [her syd %da now] %tabl - ^- (list (pair silk silk)) - %+ turn (~(tap by hat)) - |= [a=path b=lobe] - ^- (pair silk silk) - :- [%$ %path-hash !>([a b])] - (lobe-to-silk:ze a b) - == + %- emit + :* hen %pass [%patching (scot %p her) syd ~] %f + %exec our :^ ~ [her syd %da now] %tabl + ^- (list (pair silk silk)) + %+ turn (~(tap by hat)) + |= [a=path b=lobe] + ^- (pair silk silk) + :- [%$ %path-hash !>([a b])] + (lobe-to-silk:ze a b) == :: ++ apply-foreign-update :: apply subscription @@ -1016,34 +974,10 @@ !! == :: - ++ rand-to-rant - |= rut=rand - ^+ +> - ~| [%x-over-network-not-implemented [p q -.r]:rut hen] !! - :: =- %_(+>.$ tag [- tag]) - :: :* hen - :: [%foreign-plops (scot %p our) (scot %p her) syd ~] - :: %f %exec our ~ %tabl - :: ^- (list (pair silk silk)) - :: %+ turn (~(tap in pop)) - :: |= a=plop - :: ?- -.a - :: %delta - :: :- [%$ %blob !>([%delta p.a q.a *cage])] - :: [%vale p.r.a q.r.a] - :: :: - :: %direct - :: :- [%$ %blob !>([%direct p.a *cage])] - :: [%vale p.q.a q.q.a] - :: :: - :: %indirect ~| %foreign-indirect-not-implemented !! - :: == - :: == - :: ++ validate-x |= [car=care cas=case pax=path peg=page] ^+ +> - =- %_(+>.$ tag [- tag]) + %- emit :* hen %pass [%foreign-x (scot %p our) (scot %p her) syd car (scot cas) pax] %f %exec our ~ [her syd cas] @@ -1065,8 +999,8 @@ ++ validate-plops |= [cas=case lem=(unit ,@da) pop=(set plop)] ^+ +> - =- %_(+>.$ tag [- tag]) =+ lum=(scot %da (fall lem *@da)) + %- emit :* hen %pass [%foreign-plops (scot %p our) (scot %p her) syd lum ~] %f %exec our ~ [her syd cas] %tabl @@ -1074,15 +1008,8 @@ %+ turn (~(tap in pop)) |= a=plop ?- -.a - %delta - :- [%$ %blob !>([%delta p.a q.a *page])] - [%vale p.r.a q.r.a] - :: - %direct - :- [%$ %blob !>([%direct p.a *page])] - [%vale p.q.a q.q.a] - :: - %indirect ~| %foreign-indirect-not-implemented !! + %delta [[%$ %blob !>([%delta p.a q.a *page])] [%vale p.r.a q.r.a]] + %direct [[%$ %blob !>([%direct p.a *page])] [%vale p.q.a q.q.a]] == == :: @@ -1101,7 +1028,6 @@ ?- -.bol %delta [-.bol p.bol q.bol p.cay q.q.cay] %direct [-.bol p.bol p.cay q.q.cay] - %indirect ~| %plop-indirect-not-implemented !! == %^ apply-foreign-update lem @@ -1219,6 +1145,15 @@ (bleb p.i.xiq +(u.nab) ?:(p.q.i.xiq ~ `[u.nab u.huy])) == == + ++ drop-me + ^+ . + ?~ mer + . + %- emit(mer ~) ^- move :* + hen.u.mer %give %mere %| %user-interrupt + >sor.u.mer< >our< >cas.u.mer< >gem.u.mer< ~ + == + :: ++ ze |% ++ aeon-to-tako ~(got by hit.dom) @@ -1231,7 +1166,6 @@ ?- - %delta p.q %direct p.q - %indirect p.q == ++ lobe-to-silk :: XX maybe move hoo{n,k} stuff here |= [pax=path lob=lobe] @@ -1249,7 +1183,6 @@ =+ bol=(~(got by lat.ran) lob) ?- -.bol %direct [%volt q.bol] - %indirect [%volt q.bol] %delta ~| delta/q.q.bol [%pact $(lob q.q.bol) [%volt r.bol]] == @@ -1482,7 +1415,6 @@ ?- -.gar %direct (~(put in far) lob) %delta (~(put in $(lob q.q.gar)) lob) - %indirect (~(put in $(lob r.gar)) lob) == :: ++ data-twixt-takos @@ -1530,6 +1462,15 @@ ~ ```[%null [%atom %n] ~] :: + ++ read-v + |= [yon=aeon pax=path] + ^- (unit (unit ,[%dome (hypo dome)])) + ?: (lth yon let.dom) + ~ + ?: (gth yon let.dom) + `~ + ``[%dome -:!>(*dome) dom] + :: ++ read-x |= [yon=aeon pax=path] ^- (unit (unit (each cage lobe))) @@ -1556,8 +1497,6 @@ =+ bol=(lobe-to-blob u.lob) ?: ?=(%direct -.bol) ((hard ,@t) q.q.bol) - ?: ?=(%indirect -.bol) - ((hard ,@t) q.q.bol) ?> ?=(%delta -.bol) =+ txt=$(u.lob q.q.bol) ?> ?=(%txt-diff p.r.bol) @@ -1611,6 +1550,8 @@ ?^(r.mun [~ ~] [~ ~ %& %aeon !>(yon)]) ?: ?=(%u p.mun) (read-u yon r.mun) + ?: ?=(%v p.mun) + (bind (read-v yon r.mun) (curr bind (cury same %&))) ?: ?=(%x p.mun) (read-x yon r.mun) ?: ?=(%y p.mun) @@ -1645,7 +1586,7 @@ :: %- ~(run by hat) :: |= a=lobe :: =+ (lobe-to-blob a) - :: ?-(-.- %direct q.-, %indirect q.-, %delta !!) + :: ?-(-.- %direct q.-, %delta !!) ::`+>.$(ank.dom (checkout-ankh -), let.dom yon) :: ++ update-lat :: update-lat:ze @@ -1716,7 +1657,17 @@ ^+ ..me ?: don ..me(mer `dat) - ..me(mer ~, reg :_(reg [hen %mere gon.dat])) + =. mer ~ + => (emit hen.dat %give %mere gon.dat) + ..me + :: + ++ emit + |= move + %_(+> ..ze (^emit +<)) + :: + ++ emil + |= (list move) + %_(+> ..ze (^emil +<)) :: ++ route |= [sat=term res=(each riot gage)] @@ -1759,7 +1710,7 @@ :: ++ fetch-ali ^+ . - =- %_(+ tag [- tag], wat.dat %ali) + %- emit(wat.dat %ali) :* hen %pass [%merge (scot %p p.bob) q.bob (scot %p p.ali) q.ali %ali ~] %c %warp [p.bob p.ali] q.ali @@ -1937,7 +1888,7 @@ ++ diff-bas |= [nam=term yak=yaki oth=(trel ship desk case) yuk=yaki] ^+ +> - =- %_(+>.$ tag [- tag]) + %- emit :* hen %pass =+ (cat 3 %diff- nam) [%merge (scot %p p.bob) q.bob (scot %p p.ali) q.ali - ~] @@ -1982,15 +1933,18 @@ |= [pax=path lob=lobe] (~(has by q.bas.dat) pax) =. cal.dal.dat - %- mo - %+ skim (~(tap by q.bas.dat)) + %- mo ^- (list (pair path lobe)) + %+ murn (~(tap by q.bas.dat)) |= [pax=path lob=lobe] + ^- (unit (pair path lobe)) =+ a=(~(get by q.ali.dat) pax) =+ b=(~(get by q.bob.dat) pax) - ?& ?=(^ a) - !=([~ lob] a) - =([~ lob] b) - == + ?. ?& ?=(^ a) + !=([~ lob] a) + =([~ lob] b) + == + ~ + `[pax +.a] =. can.dal.dat p.can =. old.dal.dat %- mo ^- (list ,[path ~]) @@ -2022,15 +1976,18 @@ |= [pax=path lob=lobe] (~(has by q.bas.dat) pax) =. cal.dob.dat - %- mo - %+ skim (~(tap by q.bas.dat)) + %- mo ^- (list (pair path lobe)) + %+ murn (~(tap by q.bas.dat)) |= [pax=path lob=lobe] + ^- (unit (pair path lobe)) =+ a=(~(get by q.ali.dat) pax) =+ b=(~(get by q.bob.dat) pax) - ?& ?=(^ b) - !=([~ lob] b) - =([~ lob] a) - == + ?. ?& ?=(^ b) + !=([~ lob] b) + =([~ lob] a) + == + ~ + `[pax +.b] =. can.dob.dat p.can =. old.dob.dat %- mo ^- (list ,[path ~]) @@ -2046,7 +2003,7 @@ |- ^+ +.$ ?+ gem.dat ~| [%merge-weird-gem gem.dat] !! ?(%mate %meld) - =- %_(+.$ tag [- tag], wat.dat %merge) + %- emit(wat.dat %merge) :* hen %pass [%merge (scot %p p.bob) q.bob (scot %p p.ali) q.ali %merge ~] %f %exec p.bob ~ [p.bob q.bob da/now] %tabl @@ -2080,7 +2037,7 @@ :: ++ build ^+ . - =- %_(+ tag [- tag], wat.dat %build) + %- emit(wat.dat %build) :* hen %pass [%merge (scot %p p.bob) q.bob (scot %p p.ali) q.ali %build ~] %f %exec p.bob ~ [p.bob q.bob da/now] %tabl @@ -2119,7 +2076,7 @@ %- ~(urn by con) |= [pax=path *] (~(got by q.bas.dat) pax) - =. con :: add/del conflict + =. con :: change/del conflict %- ~(uni by con) %- mo ^- (list ,[path *]) %+ skim (~(tap by old.dal.dat)) @@ -2128,7 +2085,7 @@ ~| %strange-add-and-del !! (~(has by can.dob.dat) pax) - =. con :: add/del conflict + =. con :: change/del conflict %- ~(uni by con) %- mo ^- (list ,[path *]) %+ skim (~(tap by old.dob.dat)) @@ -2175,6 +2132,13 @@ [(lobe-to-mark u.-) u.-] [p q.q]:cay [(~(put by hat) pax p.bol) (~(put by lat) p.bol bol)] + :: ~& old=(~(run by old) mug) + :: ~& newdal=(~(run by new.dal.dat) mug) + :: ~& newdob=(~(run by new.dob.dat) mug) + :: ~& caldal=(~(run by cal.dal.dat) mug) + :: ~& caldob=(~(run by cal.dob.dat) mug) + :: ~& hot=(~(run by hot) mug) + :: ~& cas=(~(run by cas) mug) =+ ^- hat=(map path lobe) :: all the content %- ~(uni by old) %- ~(uni by new.dal.dat) @@ -2183,6 +2147,7 @@ %- ~(uni by cal.dob.dat) %- ~(uni by hot) cas + :: ~& > hat=(~(run by hat) mug) =+ ^- del=(map path ,?) (~(run by (~(uni by old.dal.dat) old.dob.dat)) |=(~ %|)) =. gon.dat [%& (sa (turn (~(tap by con)) head))] @@ -2201,11 +2166,11 @@ :: ++ checkout ^+ . - =- %_(+ tag [- tag], wat.dat %checkout) =+ ^- val=beak ?: ?=(%init gem.dat) [p.ali q.ali cas.dat] [p.bob q.bob da/now] + %- emit(wat.dat %checkout) :* hen %pass [%merge (scot %p p.bob) q.bob (scot %p p.ali) q.ali %checkout ~] %f %exec p.bob ~ val %tabl @@ -2244,7 +2209,6 @@ :: ++ ergo ^+ . - =- %_(+ tag [- tag], wat.dat %ergo) =+ ^- sum=(set path) =+ (must-ergo (turn (~(tap by erg.dat)) head)) =+ (turn (~(tap by -)) (corl tail tail)) @@ -2256,6 +2220,7 @@ ?: ?=(%init gem.dat) [p.ali q.ali cas.dat] [p.bob q.bob da/now] + %- emit(wat.dat %ergo) :* hen %pass [%merge (scot %p p.bob) q.bob (scot %p p.ali) q.ali %ergo ~] %f %exec p.bob ~ val %tabl @@ -2292,17 +2257,15 @@ (error:he %ergo-no-hez ~) ?: ?=(%| -.gon.dat) +>.$ - %* done he - reg - =+ mus=(must-ergo (turn (~(tap by erg.dat)) head)) - %- welp :_ reg - %+ turn (~(tap by mus)) - |= [pot=term len=@ud pak=(set path)] - :* u.hez %ergo pot - %+ turn (~(tap in pak)) - |= pax=path - [(slag len pax) (~(got by can) pax)] - == + =+ mus=(must-ergo (turn (~(tap by erg.dat)) head)) + =< done:he + %- emil + %+ turn (~(tap by mus)) + |= [pot=term len=@ud pak=(set path)] + :* u.hez %give %ergo pot + %+ turn (~(tap in pak)) + |= pax=path + [(slag len pax) (~(got by can) pax)] == :: ++ he @@ -2350,7 +2313,6 @@ =+ bol=(~(got by lat.ran) lob) ?- -.bol %direct [%volt q.bol] - %indirect [%volt q.bol] %delta [%pact $(lob q.q.bol) [%volt r.bol]] == :: @@ -2408,6 +2370,20 @@ %boat :_ ..^$ [hen %give %hill (turn (~(tap by mon.ruf)) head)]~ + :: + %drop + =^ mos ruf + =+ den=((de now hen ruf) [. .]:p.q.hic q.q.hic) + abet:drop-me:den + [mos ..^$] + :: + %info + ?: =(%$ q.q.hic) + [~ ..^$] + =^ mos ruf + =+ den=((de now hen ruf) [. .]:p.q.hic q.q.hic) + abet:(exec:den now r.q.hic) + [mos ..^$] :: %init :_ %_ ..^$ @@ -2422,14 +2398,6 @@ :: ~ == - :: - %info - ?: =(%$ q.q.hic) - [~ ..^$] - =^ mos ruf - =+ den=((de now hen ruf) [. .]:p.q.hic q.q.hic) - abet:(exec:den now r.q.hic) - [mos ..^$] :: %into =. hez.ruf `hen diff --git a/arvo/dill.hoon b/arvo/dill.hoon index 42c21e764..e5ce33127 100644 --- a/arvo/dill.hoon +++ b/arvo/dill.hoon @@ -216,6 +216,7 @@ =. +> (sync %home our %base) =. +> ?. ?=(?(%king %czar) can) +> (sync %kids our %base) + =. +> autoload =. +> peer |- ^+ +>+ ?~ myt +>+ @@ -255,7 +256,18 @@ %_ +>.$ moz :_ moz - [hen %pass ~ %g %deal [our our] ram %poke %hood-sync -:!>(syn) syn] + :* hen %pass /sync %g %deal [our our] + ram %poke %hood-sync -:!>(syn) syn + == + == + :: + ++ autoload + %_ . + moz + :_ moz + :* hen %pass /autoload %g %deal [our our] + ram %poke %kiln-start-autoload [%cube ~ [%atom %n]] ~ + == == :: ++ pump :: send diff ack diff --git a/arvo/gall.hoon b/arvo/gall.hoon index 05664dd45..645ec68be 100644 --- a/arvo/gall.hoon +++ b/arvo/gall.hoon @@ -1122,6 +1122,7 @@ %deal `%g %exec `%f %flog `%d + %drop `%c %info `%c %merg `%c %mont `%c diff --git a/arvo/zuse.hoon b/arvo/zuse.hoon index f6d71674f..08b2e31ae 100644 --- a/arvo/zuse.hoon +++ b/arvo/zuse.hoon @@ -1836,7 +1836,6 @@ ++ blob :: fs blob $% [%delta p=lobe q=[p=mark q=lobe] r=page] :: delta on q [%direct p=lobe q=page] :: immediate - [%indirect p=lobe q=page r=lobe s=page] :: both == :: ++ boat (map (pair bone wire) (trel bean ship path)) :: outgoing subs ++ boon :: fort output @@ -2360,6 +2359,7 @@ == :: ++ kiss-clay :: in request ->$ $% [%boat ~] :: pier rebooted + [%drop p=@p q=@tas] :: cancel pending merge [%info p=@p q=@tas r=nori] :: internal edit [%init p=@p] :: report install [%into p=@tas q=? r=mode] :: external edit diff --git a/gen/hood/autoload.hoon b/gen/hood/autoload.hoon new file mode 100644 index 000000000..5476276a1 --- /dev/null +++ b/gen/hood/autoload.hoon @@ -0,0 +1,13 @@ +:: +:::: /hoon/autoload/hood/gen + :: +/? 314 +:: +:::: + !: +:- %say +|= $: [now=@da eny=@uvI bec=beak] + [arg=?(~ [? ~]) ~] + == +:- %kiln-autoload +`(unit ,?)`?~(arg ~ `-.arg) diff --git a/lib/kiln.hoon b/lib/kiln.hoon index 44c022ded..54d21eda7 100644 --- a/lib/kiln.hoon +++ b/lib/kiln.hoon @@ -10,6 +10,7 @@ ++ kiln-pith :: $: rem=(map desk kiln-desk) :: syn=(map kiln-sync ,[let=@ud ust=bone]) :: + autoload=? :: == :: ++ kiln-desk :: per-desk state $: auto=? :: escalate on failure @@ -54,6 +55,7 @@ => |% :: arvo structures ++ card :: $% [%exec wire @p ~ [beak silk]] :: + [%drop wire @p @tas] :: [%info wire @p @tas nori] :: [%mont wire @tas @p @tas path] :: [%ogre wire $|(@tas beam)] :: @@ -64,6 +66,8 @@ ++ pear :: poke fruit $% [%talk-command command:talk] :: [%kiln-merge kiln-merge] :: + [%helm-reload (list term)] :: + [%helm-reset ~] :: == :: ++ move (pair bone card) :: user-level move -- @@ -118,6 +122,10 @@ |= kiln-merge abet:abet:(merge:(work syd) ali sud gim) :: +++ poke-cancel + |= syd=desk + abet:(emit %drop /cancel our syd) +:: ++ do-info |= [mez=tape tor=toro] abet:(emit:(spam leaf/mez ~) %info /kiln our tor) @@ -148,6 +156,25 @@ =+ old=;;((map ,@da cord) (fall (file where) ~)) (foal where %sched !>((~(put by old) tym eve))) :: +++ poke-autoload + |= lod=(unit ,?) + ?^ lod + abet(autoload u.lod) + =< abet(autoload !autoload) + (spam leaf/"turning autoload o{?:(autoload "ff" "n")}" ~) +:: +++ poke-start-autoload + |= ~ + =< abet + %- emil + %+ turn + `(list term)`~[%ames %behn %clay %dill %eyre %ford %gall %zuse %hoon] + |= syd=term + ^- card + :* %warp /kiln/autoload/[syd] [our our] %home ~ + %next %y da/now /arvo/[syd]/hoon + == +:: ++ take |=(way=wire ?>(?=([@ ~] way) (work i.way))) :: general handler ++ take-mere :: |= [way=wire are=(each (set path) (pair term tang))] @@ -171,7 +198,7 @@ == abet:abet:(mere:(auto hos) mes) :: -++ take-writ :: +++ take-writ-sync :: |= [way=wire rot=riot] ?> ?=([@ @ @ ~] way) =+ ^- hos=kiln-sync @@ -181,6 +208,24 @@ == abet:abet:(writ:(auto hos) rot) :: +++ take-writ-autoload + |= [way=wire rot=riot] + ?> ?=([@ ~] way) + ?> ?=(^ rot) + =+ syd=(slav %tas i.way) + =. +>.$ + ?. autoload + +>.$ + ?: ?=(%hoon syd) + (emit %poke /kiln/reload/[syd] [our %hood] %helm-reset ~) + (emit %poke /kiln/reload/[syd] [our %hood] %helm-reload ~[syd]) + =. +>.$ + %- emit :* + %warp /kiln/autoload/[syd] [our our] %home ~ + %next %y da/now /arvo/[syd]/hoon + == + abet +:: ++ spam |= mes=(list tank) ((slog mes) ..spam) @@ -244,7 +289,7 @@ ?+ p.p.mes :* (render "sync failed" sud her syd) leaf/"please manually merge the desks with" - leaf/":+merge %{(trip syd)} {(scow %p her)} %{(trip sud)}" + leaf/"|merge %{(trip syd)} {(scow %p her)} %{(trip sud)}" leaf/"" leaf/"error code: {