mirror of
https://github.com/urbit/shrub.git
synced 2025-01-07 05:26:56 +03:00
Added check for missing return ducts
This commit is contained in:
parent
dcef29a318
commit
bc5128694d
@ -1,5 +1,5 @@
|
||||
::::::
|
||||
!: :: %ford, new execution control
|
||||
:: :: %ford, new execution control
|
||||
!? 164
|
||||
::::
|
||||
|= pit=vase
|
||||
@ -909,12 +909,10 @@
|
||||
++ meow :: assemble
|
||||
|= [how=beam arg=heel]
|
||||
=| $: rop=(map term (pair hoof twig)) :: structure/complex
|
||||
zog=(set term) :: structure guard
|
||||
bil=(map term (pair hoof twig)) :: libraries known
|
||||
lot=(list term) :: library stack
|
||||
zeg=(set term) :: library guard
|
||||
boy=(list twig) :: body stack
|
||||
hol=? :: horns allowed?
|
||||
==
|
||||
|%
|
||||
++ able :: assemble preamble
|
||||
@ -956,9 +954,6 @@
|
||||
++ apex :: build to body
|
||||
|= [cof=cafe hyd=hood]
|
||||
^- (bolt ,_..apex)
|
||||
?. |(hol ?=(~ fan.hyd))
|
||||
%+ flaw cof :_ ~ :- %leaf
|
||||
"horns not allowed in structures and libraries: {<[how arg]>}"
|
||||
%+ cope (body cof src.hyd)
|
||||
|= [cof=cafe sel=_..apex]
|
||||
=. ..apex sel
|
||||
@ -1096,9 +1091,6 @@
|
||||
|- ^- (bolt ,_..head)
|
||||
?~ bir
|
||||
(fine cof ..head)
|
||||
?: (~(has in zog) p.q.i.bir)
|
||||
(flaw cof [%leaf "circular structure dependency: {<i.bir>}"]~)
|
||||
=+ goz=(~(put in zog) p.q.i.bir)
|
||||
=+ byf=(~(get by rop) p.q.i.bir)
|
||||
?^ byf
|
||||
?. =(`hoof`q.i.bir `hoof`p.u.byf)
|
||||
@ -1107,17 +1099,14 @@
|
||||
=+ bem=(hone ?:(p.i.bir %gate %core) %sur q.i.bir)
|
||||
%+ cope (fade cof %hook bem)
|
||||
|= [cof=cafe hyd=hood]
|
||||
%+ cope (apex(zog goz, hol |, boy ~) cof hyd)
|
||||
%+ cope (apex(boy ~) cof hyd)
|
||||
|= [cof=cafe sel=_..head]
|
||||
?. =(bil bil.sel)
|
||||
(flaw cof [%leaf "structures cannot include libraries: {<i.bir>}"]~)
|
||||
=. ..head
|
||||
%= sel
|
||||
boy ?: p.i.bir
|
||||
boy
|
||||
(welp boy [[[%cnzy p.q.i.bir] [%$ 1]] ~])
|
||||
zog zog
|
||||
hol hol
|
||||
zeg zeg
|
||||
rop %+ ~(put by (~(uni by rop) rop.sel))
|
||||
p.q.i.bir
|
||||
[q.i.bir [%tssg (flop boy.sel)]]
|
||||
@ -1136,8 +1125,8 @@
|
||||
^- (bolt ,_..neck)
|
||||
?~ bir (fine cof ..neck)
|
||||
?: (~(has in zeg) p.i.bir)
|
||||
(flaw cof [%leaf "circular library dependency: {<i.bir>}"]~)
|
||||
=+ gez=(~(put in zeg) p.i.bir)
|
||||
(flaw cof [%leaf "circular dependency: {<i.bir>}"]~)
|
||||
=+ goz=(~(put in zeg) p.i.bir)
|
||||
=+ byf=(~(get by bil) p.i.bir)
|
||||
?^ byf
|
||||
?. =(`hoof`i.bir `hoof`p.u.byf)
|
||||
@ -1146,12 +1135,11 @@
|
||||
=+ bem=(hone %core %lib i.bir)
|
||||
%+ cope (fade cof %hook bem)
|
||||
|= [cof=cafe hyd=hood]
|
||||
%+ cope (apex(zeg gez, hol |, boy ~) cof hyd)
|
||||
%+ cope (apex(zeg goz, boy ~) cof hyd)
|
||||
|= [cof=cafe sel=_..neck]
|
||||
=. ..neck
|
||||
%= sel
|
||||
zeg zeg
|
||||
hol hol
|
||||
lot [p.i.bir lot]
|
||||
bil (~(put by bil) p.i.bir [i.bir [%tssg (flop boy.sel)]])
|
||||
==
|
||||
|
@ -266,7 +266,9 @@
|
||||
=+ lum=(lump t.pax)
|
||||
=+ mat=(~(get by pol.all) p.p.lum)
|
||||
?~ mat [~ ..^$]
|
||||
?. (~(has by bum.u.mat) q.p.lum) ~& %too-late [~ ..^$]
|
||||
=+ sat=(~(get by bum.u.mat) q.p.lum)
|
||||
?~ sat ~& %too-late [~ ..^$]
|
||||
?. (~(has by q.zam.u.sat) hen) ~& %app-lost [~ ..^$]
|
||||
=< abet =< work
|
||||
(more:(bear:(gaff p.lum) hen) q.lum hin)
|
||||
::
|
||||
@ -333,7 +335,7 @@
|
||||
^- [(list move) _..^^$]
|
||||
?> ?=(?(%mess %show %nuke) -.kon)
|
||||
=+ you=`ship`?-(-.kon %mess p.kon, %nuke p.kon, %show p.kon)
|
||||
=+ mat=(need (~(get by pol.all) you))
|
||||
=+ mat=(~(got by pol.all) you)
|
||||
=+ sad==+(sad=(~(get by sap.mat) our) ?^(sad u.sad *scad))
|
||||
=^ num sad
|
||||
=+ nym=(~(get by q.sad) hen)
|
||||
@ -439,9 +441,9 @@
|
||||
++ gawd :: %r handle response
|
||||
|= [hen=duct saq=sack imp=path num=@ud ron=roon]
|
||||
^- [p=(list move) q=_..^$]
|
||||
=+ mat=(need (~(get by pol.all) p.saq))
|
||||
=+ sad=(need (~(get by sap.mat) q.saq))
|
||||
=+ neh=(need (~(get by r.sad) num))
|
||||
=+ mat=(~(got by pol.all) p.saq)
|
||||
=+ sad=(~(got by sap.mat) q.saq)
|
||||
=+ neh=(~(got by r.sad) num)
|
||||
:_ ..^$
|
||||
:- [hen %give %nice ~] :_ ~
|
||||
^- move :- neh
|
||||
@ -524,7 +526,7 @@
|
||||
::
|
||||
++ bear :: write backward
|
||||
|= hen=duct
|
||||
=+ orf=(need (~(get by q.zam.sat) hen))
|
||||
=+ orf=(~(got by q.zam.sat) hen)
|
||||
~(apex bo:~(. au (read q.orf)) hen p.orf (rite q.orf) ~)
|
||||
::
|
||||
++ beef :: read in
|
||||
@ -599,7 +601,7 @@
|
||||
::
|
||||
++ bing :: reset to duct
|
||||
|= neh=duct
|
||||
=+ orf=(need (~(get by q.zam.sat) neh))
|
||||
=+ orf=(~(got by q.zam.sat) neh)
|
||||
%_ +>.$
|
||||
hen neh
|
||||
ost p.orf
|
||||
@ -652,7 +654,7 @@
|
||||
%= +>.$
|
||||
vey.sat
|
||||
%- ~(put to vey.sat)
|
||||
:- (need (~(get by r.zam.sat) p.i.pys))
|
||||
:- (~(got by r.zam.sat) p.i.pys)
|
||||
[%show q.i.pys]
|
||||
==
|
||||
::
|
||||
@ -920,8 +922,8 @@
|
||||
?~ pex +>.^$
|
||||
%= $
|
||||
pex t.pex
|
||||
+>.^$ %- quem(hen (need (~(get by r.zam.sat) p.i.pex)))
|
||||
[%show (need (~(get by sup.sat) p.i.pex))]
|
||||
+>.^$ %- quem(hen (~(got by r.zam.sat) p.i.pex))
|
||||
[%show (~(got by sup.sat) p.i.pex)]
|
||||
==
|
||||
::
|
||||
++ mort :: failed boot
|
||||
@ -1058,6 +1060,7 @@
|
||||
(xeno t.imp %cide i.imp)
|
||||
?. (~(has by bum.mat) [p.kon imp])
|
||||
~& > [%cide-missed p.kon imp] +>.$(qic.sat ~)
|
||||
::~& [%cide-found p.kon imp]
|
||||
=. +>.$ (xeno [p.kon imp] %cede ~)
|
||||
%_ +>.$
|
||||
cub.sat (~(del by cub.sat) p.kon)
|
||||
@ -1119,6 +1122,7 @@
|
||||
%sire
|
||||
?: (~(has by bum.mat) [q.kon imp])
|
||||
~& > %sire-redundant +>.$(qic.sat ~)
|
||||
::~& [%sire-made p.kon imp]
|
||||
=: cub.sat (~(put by cub.sat) q.kon p.kon)
|
||||
qic.sat ~
|
||||
bum.mat
|
||||
|
@ -30,8 +30,6 @@
|
||||
[%end p=(each ,@u cord)] ::
|
||||
[%path p=path] ::
|
||||
[%hoon p=twig] ::
|
||||
[%var p=term q=twig] ::
|
||||
[%rvar p=term] ::
|
||||
[%pipe p=term q=(list twig) r=term s=(list twig)] ::
|
||||
== ::
|
||||
++ sign ::
|
||||
@ -52,7 +50,6 @@
|
||||
act=(unit span)
|
||||
pip=(map span span)
|
||||
pop=(map span span)
|
||||
var=(map term vase)
|
||||
==
|
||||
++ maybe
|
||||
|* fel=_rule
|
||||
@ -79,8 +76,6 @@
|
||||
(stag %end ;~(pfix sem ;~(pose (stag %& dem) (stag %| sym))))
|
||||
(stag %path (sear plex rood):(vang & pax))
|
||||
(stag %pipe pipe(pax paf))
|
||||
(stag %var ;~(plug ;~(pfix tis sym) ;~(pfix ace tall:(vang & paf))))
|
||||
(stag %rvar ;~(pfix ;~(plug tis tis) sym))
|
||||
(stag %hoon tall:(vang & paf))
|
||||
==
|
||||
::
|
||||
@ -158,7 +153,7 @@
|
||||
:~ :^ ost %pass /child/[cil]/main
|
||||
:+ %g %meta !>
|
||||
:* %mess [our.hid cil imp.hid] you
|
||||
(cat 3 p.u.com '-args') (run [%clsg q.u.com])
|
||||
(cat 3 p.u.com '-args') (slap seeb [%clsg q.u.com])
|
||||
==
|
||||
[ost %pass /child/[cil]/out %g %show [our.hid cil imp.hid] you /out]
|
||||
[ost %pass /child/[cil] %g %sire p.u.com cil] :: XX strange order?
|
||||
@ -194,33 +189,23 @@
|
||||
:~ :^ ost %pass /child/[cia]/main
|
||||
:+ %g %meta !>
|
||||
:* %mess [our.hid cia imp.hid] you
|
||||
(cat 3 p.u.com '-args') (run [%clsg q.u.com])
|
||||
(cat 3 p.u.com '-args') (slap seeb [%clsg q.u.com])
|
||||
==
|
||||
:^ ost %pass /child/[cib]/main
|
||||
:+ %g %meta !>
|
||||
:* %mess [our.hid cib imp.hid] you
|
||||
(cat 3 r.u.com '-args') (run [%clsg s.u.com])
|
||||
(cat 3 r.u.com '-args') (slap seeb [%clsg s.u.com])
|
||||
==
|
||||
[ost %pass /child/[cia]/out %g %show [our.hid cia imp.hid] you /out]
|
||||
[ost %pass /child/[cia] %g %sire p.u.com cia] :: XX strange order?
|
||||
[ost %pass /child/[cib]/out %g %show [our.hid cib imp.hid] you /out]
|
||||
[ost %pass /child/[cib] %g %sire r.u.com cib]
|
||||
[ost %pass /child/[cib] %g %sire r.u.com cib] :: XX strange order?
|
||||
(print ost you leaf/"running {(trip p.u.com)} into {(trip r.u.com)}" ~)
|
||||
==
|
||||
::
|
||||
%var
|
||||
:_ +>.$(var (~(put by var) p.u.com (run %ktts p.u.com q.u.com)))
|
||||
:- (print ost you leaf/"created variable '{(trip p.u.com)}'" ~)
|
||||
[ost %give %nice ~]~
|
||||
::
|
||||
%rvar
|
||||
:_ +>.$(var (~(del by var) p.u.com))
|
||||
:- (print ost you leaf/"deleted variable '{(trip p.u.com)}'" ~)
|
||||
[ost %give %nice ~]~
|
||||
::
|
||||
%hoon
|
||||
:_ +>.$
|
||||
:~ (print ost you (sell (run p.u.com)) ~)
|
||||
:~ (print ost you (sell (slap seeb p.u.com)) ~)
|
||||
[ost %give %nice ~]
|
||||
==
|
||||
==
|
||||
@ -273,14 +258,6 @@
|
||||
%term-line (slop !>(pro) tan)
|
||||
==
|
||||
::
|
||||
++ run
|
||||
|= gen=twig
|
||||
%- slap :_ gen
|
||||
%+ roll (~(tap by var))
|
||||
=< .(q seeb)
|
||||
|= [[term v=vase] q=vase]
|
||||
(slop v q)
|
||||
::
|
||||
++ spam
|
||||
|= [pax=path gip=gift]
|
||||
^- (list move)
|
||||
|
@ -39,7 +39,7 @@
|
||||
== == ==
|
||||
--
|
||||
::
|
||||
::::
|
||||
:::: libs
|
||||
::
|
||||
|%
|
||||
++ encode
|
||||
@ -116,7 +116,9 @@
|
||||
})
|
||||
$(prom).focus()
|
||||
$(prem).on('click', function() { $(prom).focus(); })
|
||||
urb.subscribe({path: '/lines' + urb.term.pax}, function(e, dat){
|
||||
var pax = '/lines'
|
||||
if(urb.term.pax != "/") pax += urb.term.pax
|
||||
urb.subscribe({path: pax}, function(e, dat){
|
||||
if(dat.data.ok) return;
|
||||
cont.textContent = dat.data.lines.join('\n')
|
||||
prem.textContent = dat.data.prompt + '> '
|
||||
@ -143,7 +145,8 @@
|
||||
[~ q.tel]
|
||||
:- [ost %pass hi/mar/pax %g %sire [aut (encode aut t.pax)]]~
|
||||
:_(q.tel leaf/"+ {(trip aut)}")
|
||||
:_ +>.$(hiz (~(put by hiz) t.pax tel))
|
||||
=. hiz (~(put by hiz) pax tel)
|
||||
:_ +>.$
|
||||
[[ost %give %rust %hymn (page t.pax)] mof]
|
||||
==
|
||||
::
|
||||
@ -162,9 +165,10 @@
|
||||
[~ q.tel]
|
||||
:_ :_(q.tel leaf/"- {(trip p.jof)}")
|
||||
[ost %pass hi/mar/pax %g %cide (encode p.jof pax)]~
|
||||
~& poke-sire/jof
|
||||
::~& poke-sire/[jof cub.hid]
|
||||
=. q.tel :_(q.tel leaf/"+ {(trip p.jof)}")
|
||||
:_ +>.$(hiz (~(put by hiz) pax tel))
|
||||
=. hiz (~(put by hiz) pax tel)
|
||||
:_ +>.$
|
||||
%+ welp mof
|
||||
:+ [ost %give %nice ~]
|
||||
[ost %pass hi/mar/pax %g %sire [p.jof (encode p.jof pax)]]
|
||||
@ -172,7 +176,8 @@
|
||||
::
|
||||
%line
|
||||
=. q.tel :_(q.tel leaf/"{(trip p.tel)}> {(trip p.jof)}")
|
||||
:_ +>.$(hiz (~(put by hiz) pax tel))
|
||||
=. hiz (~(put by hiz) pax tel)
|
||||
:_ +>.$
|
||||
%+ murn (~(tap by cub.hid))
|
||||
|= [p=span q=term]
|
||||
?. =(pax q:(decode p)) ~
|
||||
@ -183,6 +188,7 @@
|
||||
++ jell
|
||||
|= [a=bone b=path]
|
||||
[a %give %rust %json (tel-to-jon (fall (~(get by hiz) b) *term-line))]
|
||||
::
|
||||
++ spam
|
||||
|= pax=path
|
||||
%+ murn
|
||||
@ -190,14 +196,16 @@
|
||||
|= [ost=bone @ paf=path]
|
||||
?. =([%lines pax] paf) ~
|
||||
(some (jell ost pax))
|
||||
::
|
||||
++ poke-term-line
|
||||
|= [ost=bone you=ship tel=term-line]
|
||||
^- [(list move) _+>]
|
||||
~& tel-poke/tel
|
||||
::~& tel-poke/tel
|
||||
=| pax=path :: XX subscriptions
|
||||
=+ tol=(fall (~(get by hiz) pax) *term-line)
|
||||
=. tol [p.tel (weld q.tel q.tol)]
|
||||
:_ +>.$(hiz (~(put by hiz) pax tol))
|
||||
=. hiz (~(put by hiz) pax tol)
|
||||
:_ +>.$
|
||||
:- [ost %give %nice ~]
|
||||
(spam pax)
|
||||
::
|
||||
@ -218,7 +226,8 @@
|
||||
?~ p.sih ~
|
||||
:- leaf/(trip p.u.p.sih)
|
||||
(flop q.u.p.sih)
|
||||
:_ +>.$(hiz (~(put by hiz) |2.pax tel))
|
||||
=. hiz (~(put by hiz) pax tel)
|
||||
:_ +>.$
|
||||
:- [ost %give +.sih]
|
||||
?:(=(old q.tel) ~ (spam pax))
|
||||
::
|
||||
|
Loading…
Reference in New Issue
Block a user