2014-07-12 22:24:52 +04:00
|
|
|
::::::
|
2014-07-09 07:24:40 +04:00
|
|
|
:: :: %ford, new execution control
|
2014-04-23 21:02:36 +04:00
|
|
|
!? 164
|
|
|
|
::::
|
|
|
|
|= pit=vase
|
|
|
|
=> =~
|
2014-06-03 09:07:32 +04:00
|
|
|
:: structures
|
|
|
|
|%
|
2014-06-17 05:33:31 +04:00
|
|
|
++ bead ,[p=(set beam) q=cage] :: computed result
|
2014-06-03 09:07:32 +04:00
|
|
|
++ gift :: out result <-$
|
2014-06-07 22:36:31 +04:00
|
|
|
$% [%made p=(each bead (list tank))] :: computed result
|
2014-06-03 09:07:32 +04:00
|
|
|
== ::
|
2014-07-12 22:24:52 +04:00
|
|
|
++ hood :: assembly plan
|
2014-07-16 22:56:15 +04:00
|
|
|
$: sys=$|(@ud [@ud @ud]) :: system kelvin
|
|
|
|
pro=(map term beam) :: protocols
|
|
|
|
lib=(map term beam) :: libraries
|
|
|
|
:: res=(map term (trel horn beam path)) :: resource trees
|
|
|
|
src=(list hoop) :: program
|
2014-07-12 22:24:52 +04:00
|
|
|
== ::
|
|
|
|
++ hoop :: source in hood
|
|
|
|
$% [%code p=twig] :: direct twig
|
|
|
|
[%cone p=beam] :: core from folder
|
|
|
|
[%coop p=(map term hoop)] :: complex core
|
2014-07-16 22:56:15 +04:00
|
|
|
[%hood p=beam] :: recursive hood
|
2014-07-12 22:24:52 +04:00
|
|
|
[%text p=@] :: direct text
|
|
|
|
== ::
|
2014-07-16 22:56:15 +04:00
|
|
|
++ horn :: resource tree
|
|
|
|
$| ~ :: leaf
|
|
|
|
$% [%day p=horn] :: list by time
|
|
|
|
[%fan p=(map term horn)] :: tuple
|
|
|
|
[%for p=logo q=horn] :: leaf protocol
|
|
|
|
[%hub p=horn] :: list by number
|
|
|
|
[%nap p=horn] :: soft map
|
|
|
|
== ::
|
2014-06-03 09:07:32 +04:00
|
|
|
++ kiss :: in request ->$
|
|
|
|
$% [%exec p=@p q=(unit silk)] :: make / kill
|
|
|
|
== ::
|
2014-06-22 09:49:10 +04:00
|
|
|
++ move ,[p=duct q=(mold note gift)] :: local move
|
2014-06-03 09:07:32 +04:00
|
|
|
++ note :: out request $->
|
2014-06-22 06:51:12 +04:00
|
|
|
$% $: %c :: to %clay
|
|
|
|
$% [%warp p=sock q=riff] ::
|
|
|
|
== == == ::
|
2014-06-11 18:06:36 +04:00
|
|
|
++ rave :: see %clay
|
|
|
|
$% [& p=mood] :: single request
|
|
|
|
[| p=moat] :: change range
|
|
|
|
== ::
|
|
|
|
++ riff ,[p=desk q=(unit rave)] :: see %clay
|
2014-06-22 09:49:10 +04:00
|
|
|
++ sign :: in result $<-
|
2014-06-22 06:51:12 +04:00
|
|
|
$% $: %c :: by %clay
|
|
|
|
$% [%writ p=riot] ::
|
|
|
|
== == == ::
|
2014-07-12 22:24:52 +04:00
|
|
|
++ silk :: construction layer
|
|
|
|
$& [p=silk q=silk] :: cons
|
|
|
|
$% [%bake p=logo q=beam r=path] :: local synthesis
|
|
|
|
[%boil p=logo q=beam r=path] :: general synthesis
|
|
|
|
[%brew p=logo q=beam r=path] :: specific synthesis
|
|
|
|
[%call p=silk q=silk] :: slam
|
|
|
|
[%cast p=logo q=beak r=silk] :: translate
|
|
|
|
[%done p=(set beam) q=cage] :: literal
|
|
|
|
[%dude p=tank q=silk] :: error wrap
|
2014-07-16 22:56:15 +04:00
|
|
|
[%dune p=(set beam) q=(unit cage)] :: unit literal
|
2014-07-12 22:24:52 +04:00
|
|
|
[%mute p=silk q=(list (pair wing silk))] :: mutant
|
2014-07-16 22:56:15 +04:00
|
|
|
[%plan p=silk q=hood] :: structured build
|
2014-07-12 22:24:52 +04:00
|
|
|
[%reef ~] :: kernel reef
|
2014-07-16 22:56:15 +04:00
|
|
|
[%ride p=silk q=sill] :: obsolete old plan
|
2014-07-12 22:24:52 +04:00
|
|
|
[%vale p=logo q=sack r=*] :: validate [our his]
|
|
|
|
== ::
|
|
|
|
++ sill :: code construction
|
|
|
|
$& [p=sill q=sill] :: compose
|
|
|
|
$% [%dire p=@] :: direct text
|
|
|
|
[%dirt p=twig] :: direct twig
|
|
|
|
[%dish p=toga q=sill] :: tislus
|
|
|
|
[%disk p=(list sill)] :: pipe
|
|
|
|
[%drag p=beam q=path] :: beam to %hoon
|
|
|
|
[%drug p=silk] :: indirect twig
|
|
|
|
[%dust p=silk] :: literal value
|
|
|
|
== ::
|
2014-06-03 09:07:32 +04:00
|
|
|
-- ::
|
2014-04-23 21:02:36 +04:00
|
|
|
|% :: structures
|
|
|
|
++ axle :: all %ford state
|
2014-07-09 07:00:30 +04:00
|
|
|
$: %1 :: version for update
|
2014-05-14 04:04:23 +04:00
|
|
|
pol=(map ship baby) ::
|
|
|
|
== ::
|
|
|
|
++ baby :: state by ship
|
|
|
|
$: tad=[p=@ud q=(map ,@ud task)] :: tasks by number
|
2014-05-16 04:46:48 +04:00
|
|
|
dym=(map duct ,@ud) :: duct to task number
|
|
|
|
jav=(map ,* calx) :: cache
|
2014-04-23 21:02:36 +04:00
|
|
|
== ::
|
2014-05-07 21:42:31 +04:00
|
|
|
++ bolt :: gonadic edge
|
|
|
|
|* a=$+(* *) :: product clam
|
2014-05-14 04:04:23 +04:00
|
|
|
$: p=cafe :: cache
|
|
|
|
$= q ::
|
2014-06-07 22:36:31 +04:00
|
|
|
$% [%0 p=(set beam) q=a] :: depends/product
|
|
|
|
[%1 p=(set ,[p=beam q=(list tank)])] :: blocks
|
2014-05-14 04:04:23 +04:00
|
|
|
[%2 p=(list tank)] :: error
|
|
|
|
== ::
|
2014-04-23 21:02:36 +04:00
|
|
|
== ::
|
2014-05-07 21:42:31 +04:00
|
|
|
:: ::
|
|
|
|
++ burg :: gonadic rule
|
|
|
|
|* [a=$+(* *) b=$+(* *)] :: from and to
|
2014-05-16 00:17:54 +04:00
|
|
|
$+([c=cafe d=a] (bolt b)) ::
|
2014-05-07 21:42:31 +04:00
|
|
|
:: ::
|
2014-05-14 04:04:23 +04:00
|
|
|
++ cafe :: live cache
|
|
|
|
$: p=(set calx) :: used
|
|
|
|
q=(map ,* calx) :: cache
|
|
|
|
== ::
|
|
|
|
:: ::
|
2014-05-14 21:32:00 +04:00
|
|
|
++ calm :: cache metadata
|
|
|
|
$: laz=@da :: last accessed
|
2014-06-07 22:36:31 +04:00
|
|
|
dep=(set beam) :: dependencies
|
2014-05-14 21:32:00 +04:00
|
|
|
== ::
|
2014-05-14 04:04:23 +04:00
|
|
|
++ calx :: concrete cache line
|
2014-07-16 22:56:15 +04:00
|
|
|
$% [%hood p=calm q=(pair path cage) r=hood] :: compile to hood
|
2014-05-16 04:46:48 +04:00
|
|
|
[%slap p=calm q=[p=vase q=twig] r=vase] :: slap
|
2014-07-16 22:56:15 +04:00
|
|
|
[%twig p=calm q=(pair path cage) r=twig] :: compile to twig
|
2014-05-14 04:04:23 +04:00
|
|
|
== ::
|
2014-04-30 21:04:07 +04:00
|
|
|
++ task :: problem in progress
|
2014-05-14 04:04:23 +04:00
|
|
|
$: nah=duct :: cause
|
2014-05-10 11:10:46 +04:00
|
|
|
kas=silk :: problem
|
2014-06-07 22:36:31 +04:00
|
|
|
kig=[p=@ud q=(map ,@ud beam)] :: blocks
|
2014-04-23 21:02:36 +04:00
|
|
|
== ::
|
2014-05-07 21:42:31 +04:00
|
|
|
-- ::
|
2014-04-30 21:04:07 +04:00
|
|
|
|% ::
|
2014-05-16 04:46:48 +04:00
|
|
|
++ calf :: reduce calx
|
|
|
|
|* sem=* :: a typesystem hack
|
|
|
|
|= cax=calx
|
|
|
|
?+ sem !!
|
2014-07-16 22:56:15 +04:00
|
|
|
%twig ?>(?=(%twig -.cax) r.cax)
|
2014-05-16 04:46:48 +04:00
|
|
|
%slap ?>(?=(%slap -.cax) r.cax)
|
|
|
|
==
|
|
|
|
::
|
2014-05-14 04:04:23 +04:00
|
|
|
++ calk :: cache lookup
|
|
|
|
|= a=cafe ::
|
2014-05-14 06:44:44 +04:00
|
|
|
|= [b=@tas c=*] ::
|
|
|
|
^- [(unit calx) cafe] ::
|
2014-05-14 04:04:23 +04:00
|
|
|
=+ d=(~(get by q.a) [b c]) ::
|
|
|
|
?~ d [~ a] ::
|
2014-05-14 06:44:44 +04:00
|
|
|
[d a(p (~(put in p.a) u.d))] ::
|
2014-05-14 04:04:23 +04:00
|
|
|
:: ::
|
2014-05-14 21:32:00 +04:00
|
|
|
++ came ::
|
2014-05-14 04:04:23 +04:00
|
|
|
|= [a=cafe b=calx] :: cache install
|
|
|
|
^- cafe ::
|
|
|
|
a(q (~(put by q.a) [-.b q.b] b)) ::
|
|
|
|
:: ::
|
|
|
|
++ chub :: cache merge
|
|
|
|
|= [a=cafe b=cafe] ::
|
|
|
|
^- cafe ::
|
|
|
|
[(grom p.a p.b) (grum q.a q.b)] ::
|
|
|
|
:: ::
|
2014-04-30 21:04:07 +04:00
|
|
|
++ colt :: reduce to save
|
2014-05-14 04:25:59 +04:00
|
|
|
|= lex=axle ::
|
2014-05-16 04:46:48 +04:00
|
|
|
^- axle
|
|
|
|
%= lex
|
|
|
|
pol
|
|
|
|
%- ~(run by pol.lex)
|
|
|
|
|= bay=baby
|
|
|
|
bay(jav ~)
|
|
|
|
==
|
2014-04-30 21:04:07 +04:00
|
|
|
::
|
2014-05-16 00:17:54 +04:00
|
|
|
++ fine |* [a=cafe b=*] :: bolt from data
|
2014-06-07 22:36:31 +04:00
|
|
|
[p=`cafe`a q=[%0 p=*(set beam) q=b]] ::
|
2014-05-16 00:17:54 +04:00
|
|
|
++ flaw |=([a=cafe b=(list tank)] [p=a q=[%2 p=b]]) :: bolt from error
|
2014-05-07 21:42:31 +04:00
|
|
|
::
|
2014-05-14 04:04:23 +04:00
|
|
|
++ grom :: merge sets
|
|
|
|
|* [one=(set) two=(set)]
|
|
|
|
^+ one
|
2014-05-09 04:34:57 +04:00
|
|
|
(~(gas in one) (~(tap in two) ~)) :: XX ugh
|
|
|
|
::
|
2014-05-14 04:04:23 +04:00
|
|
|
++ grum :: merge maps
|
|
|
|
|* [one=(map) two=(map)]
|
|
|
|
^+ one
|
|
|
|
(~(gas by one) (~(tap by two) ~)) :: XX ugh
|
2014-05-07 21:42:31 +04:00
|
|
|
::
|
2014-04-30 21:04:07 +04:00
|
|
|
++ za :: per event
|
2014-05-14 04:04:23 +04:00
|
|
|
=| $: $: $: our=ship :: computation owner
|
2014-04-25 21:37:54 +04:00
|
|
|
tea=wire :: event place
|
|
|
|
hen=duct :: event floor
|
|
|
|
== ::
|
|
|
|
$: now=@da :: event date
|
|
|
|
eny=@ :: unique entropy
|
2014-05-07 21:42:31 +04:00
|
|
|
ska=$+(* (unit (unit))) :: system namespace
|
2014-04-25 21:37:54 +04:00
|
|
|
== ::
|
|
|
|
mow=(list move) :: pending actions
|
|
|
|
== ::
|
2014-05-14 04:04:23 +04:00
|
|
|
bay=baby :: all owned state
|
2014-04-25 21:37:54 +04:00
|
|
|
== ::
|
|
|
|
|%
|
2014-06-03 09:07:32 +04:00
|
|
|
++ abet :: resolve
|
2014-05-14 04:04:23 +04:00
|
|
|
^- [(list move) baby]
|
|
|
|
[(flop mow) bay]
|
2014-04-30 21:04:07 +04:00
|
|
|
::
|
2014-06-03 09:07:32 +04:00
|
|
|
++ apex :: call
|
2014-06-03 22:25:12 +04:00
|
|
|
|= kus=(unit silk)
|
2014-06-03 09:07:32 +04:00
|
|
|
^+ +>
|
2014-06-03 22:25:12 +04:00
|
|
|
?~ kus
|
2014-05-14 04:04:23 +04:00
|
|
|
=+ num=(need (~(get by dym.bay) hen))
|
|
|
|
=+ tas=(need (~(get by q.tad.bay) num))
|
2014-05-16 04:46:48 +04:00
|
|
|
amok:~(camo zo [num tas])
|
2014-05-22 21:39:51 +04:00
|
|
|
=+ num=p.tad.bay
|
|
|
|
?> !(~(has by dym.bay) hen)
|
|
|
|
=: p.tad.bay +(p.tad.bay)
|
|
|
|
dym.bay (~(put by dym.bay) hen num)
|
|
|
|
==
|
2014-06-03 22:25:12 +04:00
|
|
|
~(exec zo [num `task`[hen u.kus 0 ~]])
|
2014-06-03 09:07:32 +04:00
|
|
|
::
|
|
|
|
++ axon :: take
|
2014-06-22 09:49:10 +04:00
|
|
|
|= [num=@ud tik=@ud sih=sign]
|
2014-06-03 09:07:32 +04:00
|
|
|
^+ +>
|
2014-06-22 06:51:12 +04:00
|
|
|
?- -.+.sih
|
2014-06-03 09:07:32 +04:00
|
|
|
%writ
|
|
|
|
=+ tus=(~(get by q.tad.bay) num)
|
|
|
|
?~ tus
|
|
|
|
~& [%ford-lost num]
|
|
|
|
+>.$
|
2014-06-22 06:51:12 +04:00
|
|
|
(~(resp zo [num u.tus]) tik p.+.sih)
|
2014-06-03 09:07:32 +04:00
|
|
|
==
|
2014-04-30 22:27:01 +04:00
|
|
|
::
|
2014-04-30 21:04:07 +04:00
|
|
|
++ zo
|
|
|
|
|_ [num=@ud task]
|
2014-05-14 04:04:23 +04:00
|
|
|
++ abet %_(..zo q.tad.bay (~(put by q.tad.bay) num +<+))
|
2014-06-04 14:40:09 +04:00
|
|
|
++ amok
|
|
|
|
%_ ..zo
|
|
|
|
q.tad.bay (~(del by q.tad.bay) num)
|
|
|
|
dym.bay (~(del by dym.bay) nah)
|
|
|
|
==
|
2014-05-16 04:46:48 +04:00
|
|
|
++ camo :: stop requests
|
|
|
|
^+ .
|
2014-06-07 22:36:31 +04:00
|
|
|
=+ kiz=(~(tap by q.kig) *(list ,[p=@ud q=beam]))
|
2014-05-16 04:46:48 +04:00
|
|
|
|- ^+ +>
|
|
|
|
?~ kiz +>
|
|
|
|
%= $
|
|
|
|
kiz t.kiz
|
|
|
|
mow :_ mow
|
2014-05-24 00:46:43 +04:00
|
|
|
:- hen
|
2014-06-24 21:32:59 +04:00
|
|
|
:^ %pass [(scot %p our) (scot %ud num) (scot %ud p.i.kiz) ~]
|
2014-06-21 22:42:34 +04:00
|
|
|
%c
|
2014-05-20 21:36:10 +04:00
|
|
|
[%warp [our p.q.i.kiz] q.q.i.kiz ~]
|
2014-05-16 04:46:48 +04:00
|
|
|
==
|
|
|
|
::
|
2014-04-30 21:04:07 +04:00
|
|
|
++ camp :: request a file
|
2014-06-07 22:36:31 +04:00
|
|
|
|= [ren=care bem=beam]
|
2014-04-30 21:04:07 +04:00
|
|
|
^+ +>
|
2014-07-03 02:08:02 +04:00
|
|
|
%= +>
|
|
|
|
kig [+(p.kig) (~(put by q.kig) p.kig bem)]
|
2014-04-30 21:04:07 +04:00
|
|
|
mow :_ mow
|
2014-05-24 00:46:43 +04:00
|
|
|
:- hen
|
2014-07-03 02:08:02 +04:00
|
|
|
:^ %pass [(scot %p our) (scot %ud num) (scot %ud p.kig) ~]
|
2014-06-21 22:42:34 +04:00
|
|
|
%c
|
2014-05-20 21:36:10 +04:00
|
|
|
[%warp [our p.bem] q.bem [~ %& %x r.bem s.bem]]
|
2014-04-30 21:04:07 +04:00
|
|
|
==
|
2014-05-07 21:42:31 +04:00
|
|
|
::
|
2014-05-14 21:32:00 +04:00
|
|
|
++ clef :: cache a result
|
2014-05-14 23:38:37 +04:00
|
|
|
|* sem=*
|
2014-05-14 21:32:00 +04:00
|
|
|
|* [hoc=(bolt) fun=(burg)]
|
|
|
|
?- -.q.hoc
|
|
|
|
%2 hoc
|
|
|
|
%1 hoc
|
|
|
|
%0
|
|
|
|
=^ cux p.hoc ((calk p.hoc) sem q.q.hoc)
|
|
|
|
?~ cux
|
|
|
|
=+ nuf=(cope hoc fun)
|
|
|
|
?- -.q.nuf
|
|
|
|
%2 nuf
|
|
|
|
%1 nuf
|
|
|
|
%0
|
|
|
|
:- p=(came p.nuf `calx`[sem `calm`[now p.q.nuf] q.q.hoc q.q.nuf])
|
2014-05-14 23:38:37 +04:00
|
|
|
q=q.nuf
|
2014-05-14 21:32:00 +04:00
|
|
|
==
|
|
|
|
:- p=p.hoc
|
|
|
|
^= q
|
|
|
|
:+ %0 p.q.hoc
|
2014-05-16 04:46:48 +04:00
|
|
|
((calf sem) u.cux)
|
2014-05-14 21:32:00 +04:00
|
|
|
==
|
|
|
|
::
|
2014-05-07 21:42:31 +04:00
|
|
|
++ coax :: bolt across
|
|
|
|
|* [hoc=(bolt) fun=(burg)]
|
2014-05-14 04:04:23 +04:00
|
|
|
?- -.q.hoc
|
2014-05-16 00:17:54 +04:00
|
|
|
%0 =+ nuf=$:fun(..+<- p.hoc)
|
|
|
|
:- p=p.nuf
|
2014-05-14 04:04:23 +04:00
|
|
|
^= q
|
|
|
|
?- -.q.nuf
|
|
|
|
%0 [%0 p=(grom p.q.hoc p.q.nuf) q=[q.q.hoc q.q.nuf]]
|
|
|
|
%1 q.nuf
|
|
|
|
%2 q.nuf
|
2014-05-07 21:42:31 +04:00
|
|
|
==
|
2014-05-16 00:17:54 +04:00
|
|
|
%1 =+ nuf=$:fun(..+<- p.hoc)
|
|
|
|
:- p=p.nuf
|
2014-05-14 04:04:23 +04:00
|
|
|
^= q
|
|
|
|
?- -.q.nuf
|
|
|
|
%0 q.hoc
|
|
|
|
%1 [%1 p=(grom p.q.nuf p.q.hoc)]
|
|
|
|
%2 q.nuf
|
2014-05-07 21:42:31 +04:00
|
|
|
==
|
|
|
|
%2 hoc
|
|
|
|
==
|
|
|
|
::
|
2014-07-08 03:17:21 +04:00
|
|
|
++ cool :: error caption
|
|
|
|
|* [cyt=trap hoc=(bolt)]
|
2014-07-06 03:38:15 +04:00
|
|
|
?. ?=(%2 -.q.hoc) hoc
|
|
|
|
[p.hoc [%2 *cyt p.q.hoc]]
|
|
|
|
::
|
2014-05-07 21:42:31 +04:00
|
|
|
++ cope :: bolt along
|
|
|
|
|* [hoc=(bolt) fun=(burg)]
|
2014-05-14 04:04:23 +04:00
|
|
|
?- -.q.hoc
|
2014-05-07 21:42:31 +04:00
|
|
|
%2 hoc
|
|
|
|
%1 hoc
|
2014-05-16 00:17:54 +04:00
|
|
|
%0 =+ nuf=(fun p.hoc q.q.hoc)
|
|
|
|
:- p=p.nuf
|
2014-05-14 04:04:23 +04:00
|
|
|
^= q
|
|
|
|
?- -.q.nuf
|
|
|
|
%2 q.nuf
|
|
|
|
%1 q.nuf
|
|
|
|
%0 [%0 p=(grom `_p.q.nuf`p.q.hoc p.q.nuf) q=q.q.nuf]
|
2014-05-14 04:25:59 +04:00
|
|
|
== ==
|
2014-05-07 21:42:31 +04:00
|
|
|
::
|
|
|
|
++ coup :: toon to bolt
|
2014-05-16 00:17:54 +04:00
|
|
|
|= cof=cafe
|
|
|
|
|* [ton=toon fun=$+(* *)]
|
|
|
|
:- p=cof
|
2014-05-14 04:04:23 +04:00
|
|
|
^= q
|
2014-05-07 21:42:31 +04:00
|
|
|
?- -.ton
|
2014-07-10 01:43:30 +04:00
|
|
|
%2 [%2 p=p.ton]
|
2014-06-07 22:36:31 +04:00
|
|
|
%0 [%0 p=*(set beam) q=(fun p.ton)]
|
2014-05-16 00:17:54 +04:00
|
|
|
%1 =- ?- faw
|
2014-06-07 22:36:31 +04:00
|
|
|
& [%1 p=(turn p.faw |=(a=beam [a *(list tank)]))]
|
2014-05-09 04:34:57 +04:00
|
|
|
| [%2 p=p.faw]
|
2014-05-07 21:42:31 +04:00
|
|
|
==
|
2014-05-14 04:25:59 +04:00
|
|
|
^= faw
|
2014-06-07 22:36:31 +04:00
|
|
|
|- ^- (each (list beam) (list tank))
|
2014-05-07 21:42:31 +04:00
|
|
|
?~ p.ton [%& ~]
|
|
|
|
=+ nex=$(p.ton t.p.ton)
|
|
|
|
=+ pax=(path i.p.ton)
|
|
|
|
=+ zis=(tome (path i.p.ton))
|
|
|
|
?~ zis
|
|
|
|
[%| (smyt pax) ?:(?=(& -.nex) ~ p.nex)]
|
|
|
|
?- -.nex
|
2014-05-09 04:34:57 +04:00
|
|
|
& [%& u.zis p.nex]
|
2014-05-07 21:42:31 +04:00
|
|
|
| nex
|
|
|
|
==
|
2014-04-30 21:04:07 +04:00
|
|
|
==
|
2014-05-07 21:42:31 +04:00
|
|
|
::
|
2014-05-16 04:46:48 +04:00
|
|
|
++ dash :: process cache
|
|
|
|
|= cof=cafe
|
|
|
|
^+ +>
|
|
|
|
%_(+> jav.bay q.cof)
|
|
|
|
::
|
2014-05-07 21:42:31 +04:00
|
|
|
++ exec :: execute app
|
2014-04-30 21:04:07 +04:00
|
|
|
^+ ..zo
|
2014-05-09 04:34:57 +04:00
|
|
|
?: !=(~ q.kig) ..zo
|
2014-04-30 21:04:07 +04:00
|
|
|
|- ^+ ..zo
|
2014-05-16 04:46:48 +04:00
|
|
|
=+ bot=(make [~ jav.bay] kas)
|
|
|
|
=. ..exec (dash p.bot)
|
2014-05-14 04:04:23 +04:00
|
|
|
?- -.q.bot
|
|
|
|
%0 amok:(expo [%made %& p.q.bot q.q.bot])
|
|
|
|
%2 amok:(expo [%made %| p.q.bot])
|
|
|
|
%1 =+ zuk=(~(tap by p.q.bot) ~)
|
2014-05-09 04:34:57 +04:00
|
|
|
=< abet
|
|
|
|
|- ^+ ..exec
|
|
|
|
?~ zuk ..exec
|
2014-06-07 22:36:31 +04:00
|
|
|
=+ foo=`_..exec`(camp %x `beam`p.i.zuk)
|
2014-05-09 04:34:57 +04:00
|
|
|
$(zuk t.zuk, ..exec foo)
|
2014-04-30 22:27:01 +04:00
|
|
|
==
|
2014-05-07 21:42:31 +04:00
|
|
|
::
|
2014-06-03 09:07:32 +04:00
|
|
|
++ expo :: return gift
|
|
|
|
|= gef=gift
|
|
|
|
%_(+> mow :_(mow [hen %give gef]))
|
2014-05-09 04:34:57 +04:00
|
|
|
::
|
2014-07-16 22:56:15 +04:00
|
|
|
++ fade :: compile %hood
|
|
|
|
|= [cof=cafe kas=silk]
|
|
|
|
^- (bolt hood)
|
|
|
|
%. [cof %hoon kas]
|
|
|
|
(fado |=(a=path (ifix [gay gay] hall:(vang | a))))
|
|
|
|
::
|
|
|
|
++ fane :: compile %hoon
|
2014-05-16 00:17:54 +04:00
|
|
|
|= [cof=cafe kas=silk]
|
2014-05-14 21:32:00 +04:00
|
|
|
^- (bolt twig)
|
2014-07-16 22:56:15 +04:00
|
|
|
%. [cof %hoon kas]
|
|
|
|
(fado |=(a=path (ifix [gay gay] tall:(vang | a))))
|
|
|
|
::
|
|
|
|
++ fado :: compile by rule
|
|
|
|
|* lur=$+(path rule)
|
|
|
|
|= [cof=cafe for=logo kas=silk]
|
|
|
|
%+ (clef %twig) (maid cof kas)
|
2014-07-09 13:40:49 +04:00
|
|
|
^- (burg (pair path cage) twig)
|
|
|
|
|= [cof=cafe pay=(pair path cage)]
|
2014-07-16 22:56:15 +04:00
|
|
|
?. |(=(for p.q.pay) =(%noun p.q.pay))
|
|
|
|
(flaw cof [%leaf "source error: {<p.pay>} must be %{<(trip for)>}"])
|
2014-07-09 13:40:49 +04:00
|
|
|
?. ?=(@ q.q.q.pay)
|
2014-07-16 22:56:15 +04:00
|
|
|
(flaw cof [%leaf "source error: {<p.pay>} must be flat"]~)
|
|
|
|
=+ vex=((full (lur p.pay)) [[1 1] (trip q.q.q.pay)])
|
2014-05-14 21:32:00 +04:00
|
|
|
?~ q.vex
|
2014-05-16 00:17:54 +04:00
|
|
|
(flaw cof [%leaf "syntax error: {<p.p.vex>} {<q.p.vex>}"] ~)
|
|
|
|
(fine cof p.u.q.vex)
|
2014-05-14 21:32:00 +04:00
|
|
|
::
|
2014-05-31 16:52:06 +04:00
|
|
|
++ gush :: sill to twig
|
|
|
|
|= [cof=cafe sil=sill]
|
|
|
|
^- (bolt twig)
|
2014-07-10 04:16:17 +04:00
|
|
|
?+ -.sil !!
|
2014-07-16 22:56:15 +04:00
|
|
|
%dire (fane cof [%done ~ [%atom [%atom %$] p.sil]])
|
2014-07-10 04:16:17 +04:00
|
|
|
%dirt (fine cof p.sil)
|
2014-07-16 22:56:15 +04:00
|
|
|
%drag (fane cof [%boil %hoon p.sil q.sil])
|
2014-07-10 04:16:17 +04:00
|
|
|
%drug %+ cope (make cof p.sil)
|
|
|
|
|= [cof=cafe cay=cage]
|
|
|
|
(fine cof (twig q.q.cay))
|
2014-05-31 16:52:06 +04:00
|
|
|
==
|
|
|
|
::
|
2014-07-06 01:26:35 +04:00
|
|
|
++ home :: source silk to path
|
|
|
|
|= kas=silk
|
|
|
|
^- path
|
|
|
|
?+ -.kas ~[(end 3 1 (scot %p (mug kas)))]
|
2014-07-11 03:13:42 +04:00
|
|
|
%bake (tope q.kas(s (welp r.kas s.q.kas)))
|
|
|
|
%boil (tope q.kas(s (welp r.kas s.q.kas)))
|
2014-07-06 01:26:35 +04:00
|
|
|
%cast $(kas r.kas)
|
|
|
|
%dude $(kas q.kas)
|
2014-07-10 04:16:17 +04:00
|
|
|
%ride ?+ -.q.kas $(kas [%reef ~])
|
|
|
|
%drag (tope p.q.kas)
|
|
|
|
%drug $(kas p.q.kas)
|
2014-07-06 01:26:35 +04:00
|
|
|
==
|
|
|
|
==
|
2014-05-31 16:52:06 +04:00
|
|
|
++ kale :: mutate
|
|
|
|
|= [cof=cafe kas=silk muy=(list (pair wing silk))]
|
|
|
|
^- (bolt cage)
|
|
|
|
%+ cope
|
|
|
|
|- ^- (bolt (list (pair wing vase)))
|
|
|
|
?~ muy (fine cof ~)
|
|
|
|
%+ cope (make cof q.i.muy)
|
|
|
|
|= [cof=cafe cay=cage]
|
|
|
|
%+ cope ^$(muy t.muy)
|
|
|
|
|= [cof=cafe rex=(list (pair wing vase))]
|
|
|
|
(fine cof [[p.i.muy q.cay] rex])
|
|
|
|
|= [cof=cafe yom=(list (pair wing vase))]
|
|
|
|
%+ cope (make cof kas)
|
|
|
|
|= [cof=cafe cay=cage]
|
|
|
|
=+ ^= vow
|
|
|
|
%+ slop q.cay
|
|
|
|
|- ^- vase
|
|
|
|
?~ yom [[%atom %n] ~]
|
|
|
|
(slop q.i.yom $(yom t.yom))
|
|
|
|
%+ cope
|
|
|
|
%^ maim cof vow
|
|
|
|
^- twig
|
|
|
|
:+ %cncb [%& 2]~
|
|
|
|
=+ axe=3
|
|
|
|
|- ^- (list (pair wing twig))
|
|
|
|
?~ yom ~
|
|
|
|
:- [p.i.yom [%$ (peg axe 2)]]
|
|
|
|
$(yom t.yom, axe (peg axe 3))
|
|
|
|
|= [cof=cafe vax=vase]
|
|
|
|
(fine cof p.cay vax)
|
|
|
|
::
|
2014-07-06 01:26:35 +04:00
|
|
|
++ krab :: load to vase
|
2014-07-10 01:43:30 +04:00
|
|
|
|= [cof=cafe for=logo how=logo bem=beam rem=spur]
|
2014-05-12 02:48:41 +04:00
|
|
|
^- (bolt vase)
|
2014-07-16 22:56:15 +04:00
|
|
|
%+ cope (fane cof %bake how bem rem)
|
2014-05-16 00:17:54 +04:00
|
|
|
|= [cof=cafe gen=twig]
|
2014-07-06 20:57:37 +04:00
|
|
|
(maim cof pit gen)
|
2014-05-07 21:42:31 +04:00
|
|
|
::
|
|
|
|
++ lace :: load and check
|
2014-07-10 01:43:30 +04:00
|
|
|
|= [cof=cafe for=logo bem=beam rem=spur]
|
2014-05-09 04:34:57 +04:00
|
|
|
^- (bolt (unit vase))
|
2014-05-12 02:48:41 +04:00
|
|
|
=+ bek=`beak`[p.bem q.bem r.bem]
|
2014-05-16 00:17:54 +04:00
|
|
|
%+ cope (lend cof bem)
|
|
|
|
|= [cof=cafe arc=arch]
|
2014-05-07 21:42:31 +04:00
|
|
|
?^ q.arc
|
2014-05-16 00:17:54 +04:00
|
|
|
(cope (liar cof bem) (lake for bek))
|
2014-05-12 02:48:41 +04:00
|
|
|
?: (~(has by r.arc) %hook)
|
2014-07-10 01:43:30 +04:00
|
|
|
%+ cope (krab cof for %hook bem rem)
|
2014-05-16 00:17:54 +04:00
|
|
|
|= [cof=cafe vax=vase]
|
|
|
|
%+ cope ((lair for bem) cof vax)
|
|
|
|
|= [cof=cafe vax=vase]
|
|
|
|
(fine cof ~ vax)
|
2014-07-06 01:26:35 +04:00
|
|
|
?: (~(has by r.arc) %hoon)
|
2014-07-10 01:43:30 +04:00
|
|
|
%+ cope (krab cof for %hoon bem rem)
|
2014-07-06 01:26:35 +04:00
|
|
|
(lake for bek)
|
2014-05-16 00:17:54 +04:00
|
|
|
(fine cof ~)
|
2014-05-07 21:42:31 +04:00
|
|
|
::
|
|
|
|
++ lake :: check/coerce
|
|
|
|
|= [for=logo bek=beak]
|
2014-05-16 00:17:54 +04:00
|
|
|
|= [cof=cafe sam=vase]
|
2014-05-09 04:34:57 +04:00
|
|
|
^- (bolt (unit vase))
|
2014-05-12 02:48:41 +04:00
|
|
|
?: ?=(?(%gate %core %hoon %hook) for)
|
2014-05-16 00:17:54 +04:00
|
|
|
(fine cof ~ sam)
|
2014-07-09 07:00:30 +04:00
|
|
|
%+ cope (make cof %boil %gate [[p.bek %main r.bek] /ref/[for]/sys] ~)
|
2014-05-16 00:17:54 +04:00
|
|
|
|= [cof=cafe cay=cage]
|
|
|
|
%+ cope (lane cof p.q.cay [%cnzy %$])
|
|
|
|
|= [cof=cafe ref=type]
|
2014-05-07 21:42:31 +04:00
|
|
|
?: (~(nest ut ref) | p.sam)
|
2014-05-16 00:17:54 +04:00
|
|
|
(fine cof ~ sam)
|
|
|
|
%+ cope (maul cof q.cay sam)
|
|
|
|
|= [cof=cafe pro=vase]
|
|
|
|
(fine cof ~ pro)
|
2014-05-07 21:42:31 +04:00
|
|
|
::
|
2014-06-26 16:18:30 +04:00
|
|
|
++ lave :: validate
|
|
|
|
|= [cof=cafe for=logo sax=sack som=*]
|
|
|
|
=+ lok=`case`[%da now]
|
|
|
|
=+ ^= own ^- ship
|
|
|
|
=+ von=(ska %cy (tope [[p.sax %main lok] /core/ref/[for]/sys]))
|
|
|
|
?~(von q.sax p.sax)
|
|
|
|
((lake for [own %main lok]) cof [%noun som])
|
|
|
|
::
|
2014-05-12 02:48:41 +04:00
|
|
|
++ lair :: metaload
|
2014-06-07 22:36:31 +04:00
|
|
|
|= [for=logo bem=beam]
|
2014-05-16 00:17:54 +04:00
|
|
|
|= [cof=cafe vax=vase]
|
2014-05-12 02:48:41 +04:00
|
|
|
^- (bolt vase)
|
|
|
|
?. (~(nest ut -:!>(*silk)) | p.vax)
|
2014-05-16 00:17:54 +04:00
|
|
|
(flaw cof (smyt (tope bem)) ~)
|
|
|
|
%+ cope (make cof ((hard silk) q.vax))
|
|
|
|
|= [cof=cafe cay=cage]
|
2014-06-19 22:53:16 +04:00
|
|
|
(link cof for p.cay [p.bem q.bem r.bem] q.cay)
|
2014-05-12 02:48:41 +04:00
|
|
|
::
|
2014-05-07 21:42:31 +04:00
|
|
|
++ lane :: type infer
|
2014-05-16 00:17:54 +04:00
|
|
|
|= [cof=cafe typ=type gen=twig]
|
|
|
|
%+ (coup cof) (mule |.((~(play ut typ) gen)))
|
2014-05-07 21:42:31 +04:00
|
|
|
|=(ref=type ref)
|
|
|
|
::
|
|
|
|
++ lend :: load arch
|
2014-06-07 22:36:31 +04:00
|
|
|
|= [cof=cafe bem=beam]
|
2014-05-07 21:42:31 +04:00
|
|
|
^- (bolt arch)
|
|
|
|
=+ von=(ska %cy (tope bem))
|
2014-05-16 00:17:54 +04:00
|
|
|
?~ von [p=cof q=[%1 [bem ~] ~ ~]]
|
|
|
|
(fine cof ((hard arch) (need u.von)))
|
2014-05-07 21:42:31 +04:00
|
|
|
::
|
|
|
|
++ liar :: load vase
|
2014-06-07 22:36:31 +04:00
|
|
|
|= [cof=cafe bem=beam]
|
2014-05-14 04:25:59 +04:00
|
|
|
^- (bolt vase)
|
2014-05-07 21:42:31 +04:00
|
|
|
=+ von=(ska %cx (tope bem))
|
|
|
|
?~ von
|
2014-05-14 04:04:23 +04:00
|
|
|
[p=*cafe q=[%1 [[bem ~] ~ ~]]]
|
2014-05-07 21:42:31 +04:00
|
|
|
?~ u.von
|
2014-05-16 00:17:54 +04:00
|
|
|
(flaw cof (smyt (tope bem)) ~)
|
|
|
|
(fine cof ?^(u.u.von [%cell %noun %noun] [%atom %$]) u.u.von)
|
2014-05-07 21:42:31 +04:00
|
|
|
::
|
|
|
|
++ lily :: translation targets
|
2014-05-16 00:17:54 +04:00
|
|
|
|= [cof=cafe for=logo bek=beak]
|
2014-05-07 21:42:31 +04:00
|
|
|
^- (bolt (list ,@tas))
|
|
|
|
%+ cope
|
2014-07-06 03:38:15 +04:00
|
|
|
%+ cope (lend cof [p.bek %main r.bek] `path`~[%tan for %sys])
|
2014-05-16 00:17:54 +04:00
|
|
|
|= [cof=cafe arc=arch]
|
|
|
|
(fine cof (turn (~(tap by r.arc) ~) |=([a=@tas b=~] a)))
|
|
|
|
|= [cof=cafe all=(list ,@tas)]
|
|
|
|
(fine cof ?.(=(%hoon for) all [%hoot all]))
|
2014-05-07 21:42:31 +04:00
|
|
|
::
|
|
|
|
++ lima :: load at depth
|
2014-07-09 07:24:40 +04:00
|
|
|
|= [cof=cafe for=logo bem=beam rem=spur]
|
2014-05-07 21:42:31 +04:00
|
|
|
^- (bolt (unit vase))
|
2014-05-16 00:17:54 +04:00
|
|
|
%+ cope (lend cof bem)
|
|
|
|
|= [cof=cafe arc=arch]
|
2014-05-09 04:34:57 +04:00
|
|
|
^- (bolt (unit vase))
|
2014-05-07 21:42:31 +04:00
|
|
|
?: (~(has by r.arc) for)
|
2014-07-10 01:43:30 +04:00
|
|
|
(lace cof for bem(s [for s.bem]) rem)
|
2014-07-09 02:46:34 +04:00
|
|
|
=+ haz=(turn (~(tap by r.arc) ~) |=([a=@tas b=~] a))
|
|
|
|
?~ haz (fine cof ~)
|
|
|
|
%+ cope (lion cof for -.bem haz)
|
2014-05-16 00:17:54 +04:00
|
|
|
|= [cof=cafe wuy=(unit (list ,@tas))]
|
|
|
|
?~ wuy (fine cof ~)
|
2014-05-14 04:04:23 +04:00
|
|
|
?> ?=(^ u.wuy)
|
2014-07-09 07:00:30 +04:00
|
|
|
%+ cope (make cof %bake i.u.wuy bem rem)
|
2014-05-16 00:17:54 +04:00
|
|
|
|= [cof=cafe hoc=cage]
|
|
|
|
%+ cope (lope cof i.u.wuy t.u.wuy [p.bem q.bem r.bem] q.hoc)
|
|
|
|
|= [cof=cafe vax=vase]
|
|
|
|
(fine cof ~ vax)
|
2014-05-07 21:42:31 +04:00
|
|
|
::
|
2014-06-07 22:36:31 +04:00
|
|
|
++ lime :: load beam
|
2014-07-10 01:43:30 +04:00
|
|
|
|= [cof=cafe for=logo bem=beam rem=spur]
|
2014-07-11 03:13:42 +04:00
|
|
|
=+ [mob=bem mer=(flop rem)]
|
2014-05-07 21:42:31 +04:00
|
|
|
|- ^- (bolt vase)
|
2014-07-11 03:13:42 +04:00
|
|
|
%+ cope (lima cof for mob (flop mer))
|
2014-05-16 00:17:54 +04:00
|
|
|
|= [cof=cafe vux=(unit vase)]
|
|
|
|
?^ vux (fine cof u.vux)
|
2014-07-09 02:46:34 +04:00
|
|
|
?~ s.mob
|
|
|
|
(flaw cof (smyt (tope bem)) ~)
|
2014-07-11 03:13:42 +04:00
|
|
|
^$(s.mob t.s.mob, mer [i.s.mob mer])
|
2014-05-07 21:42:31 +04:00
|
|
|
::
|
2014-05-14 04:25:59 +04:00
|
|
|
++ link :: translate
|
2014-05-16 00:17:54 +04:00
|
|
|
|= [cof=cafe too=logo for=logo bek=beak vax=vase]
|
2014-05-07 21:42:31 +04:00
|
|
|
^- (bolt vase)
|
2014-05-16 00:17:54 +04:00
|
|
|
?: =(too for) (fine cof vax)
|
2014-07-10 04:48:53 +04:00
|
|
|
?: |(=(%noun for) =(%$ for))
|
|
|
|
%+ cope ((lake too bek) cof vax)
|
|
|
|
|= [cof=cafe vux=(unit vase)]
|
|
|
|
?~ vux (flaw cof [%leaf "ford: link {<too>}"]~)
|
|
|
|
(fine cof u.vux)
|
2014-07-09 07:00:30 +04:00
|
|
|
%+ cope
|
|
|
|
(make cof %boil %gate [[p.bek %main r.bek] /[too]/tan/[for]/sys] ~)
|
2014-05-16 00:17:54 +04:00
|
|
|
|= [cof=cafe cay=cage]
|
|
|
|
(maul cof q.cay vax)
|
2014-05-07 21:42:31 +04:00
|
|
|
::
|
2014-05-09 04:34:57 +04:00
|
|
|
++ lion :: translation search
|
2014-05-16 00:17:54 +04:00
|
|
|
|= [cof=cafe too=@tas bek=beak fro=(list ,@tas)]
|
2014-05-09 04:34:57 +04:00
|
|
|
^- (bolt (unit (list ,@tas)))
|
2014-05-07 21:42:31 +04:00
|
|
|
=| war=(set ,@tas)
|
2014-05-16 00:17:54 +04:00
|
|
|
=< -:(apex (fine cof fro))
|
2014-07-12 22:24:52 +04:00
|
|
|
|%
|
2014-05-07 21:42:31 +04:00
|
|
|
++ apex
|
|
|
|
|= rof=(bolt (list ,@tas))
|
2014-05-09 04:34:57 +04:00
|
|
|
^- [(bolt (unit (list ,@tas))) _+>]
|
2014-05-14 04:04:23 +04:00
|
|
|
?. ?=(%0 -.q.rof) [rof +>.$]
|
|
|
|
?~ q.q.rof
|
|
|
|
[[p.rof [%0 p.q.rof ~]] +>.$]
|
2014-05-16 00:17:54 +04:00
|
|
|
=^ orf +>.$ (apse cof i.q.q.rof)
|
2014-05-14 04:04:23 +04:00
|
|
|
?. ?=(%0 -.q.orf)
|
2014-05-16 00:17:54 +04:00
|
|
|
[orf +>.$]
|
2014-05-14 04:04:23 +04:00
|
|
|
?~ q.q.orf
|
2014-05-16 00:17:54 +04:00
|
|
|
$(cof p.orf, q.q.rof t.q.q.rof)
|
|
|
|
[[p.orf [%0 (grom p.q.rof p.q.orf) q.q.orf]] +>.$]
|
2014-04-30 21:04:07 +04:00
|
|
|
::
|
2014-05-07 21:42:31 +04:00
|
|
|
++ apse
|
2014-05-16 00:17:54 +04:00
|
|
|
|= [cof=cafe for=@tas]
|
2014-05-09 04:34:57 +04:00
|
|
|
^- [(bolt (unit (list ,@tas))) _+>]
|
2014-05-14 04:25:59 +04:00
|
|
|
?: =(for too)
|
2014-05-16 00:17:54 +04:00
|
|
|
[(fine cof [~ too ~]) +>.$]
|
|
|
|
?: (~(has in war) for) [(fine cof ~) +>]
|
2014-05-07 21:42:31 +04:00
|
|
|
=. war (~(put in war) for)
|
2014-05-16 00:17:54 +04:00
|
|
|
=^ hoc +>.$ (apex (lily cof for bek))
|
2014-05-07 21:42:31 +04:00
|
|
|
:_ +>.$
|
2014-05-16 00:17:54 +04:00
|
|
|
%+ cope hoc
|
|
|
|
|= [cof=cafe ked=(unit (list ,@tas))]
|
|
|
|
(fine cof ?~(ked ~ [~ for u.ked]))
|
2014-05-07 21:42:31 +04:00
|
|
|
--
|
|
|
|
::
|
2014-05-16 00:17:54 +04:00
|
|
|
++ lope :: translation pipe
|
|
|
|
|= [cof=cafe for=logo yaw=(list logo) bek=beak vax=vase]
|
2014-05-07 21:42:31 +04:00
|
|
|
^- (bolt vase)
|
2014-05-16 00:17:54 +04:00
|
|
|
?~ yaw (fine cof vax)
|
|
|
|
%+ cope (link cof i.yaw for bek vax)
|
|
|
|
|= [cof=cafe yed=vase]
|
2014-07-08 03:17:21 +04:00
|
|
|
^$(cof cof, for i.yaw, yaw t.yaw, vax yed)
|
2014-05-07 21:42:31 +04:00
|
|
|
::
|
2014-07-09 13:40:49 +04:00
|
|
|
++ maid :: make with path tag
|
2014-07-16 22:56:15 +04:00
|
|
|
|= [cof=cafe kas=silk]
|
2014-07-09 13:40:49 +04:00
|
|
|
^- (bolt (pair path cage))
|
|
|
|
%+ cope (make cof kas)
|
|
|
|
|= [cof=cafe cay=cage]
|
2014-07-16 22:56:15 +04:00
|
|
|
(fine cof (home kas) cay)
|
|
|
|
::
|
|
|
|
++ maim :: slap
|
|
|
|
|= [cof=cafe vax=vase gen=twig]
|
|
|
|
^- (bolt vase)
|
|
|
|
%+ (clef %slap) (fine cof vax gen)
|
|
|
|
|= [cof=cafe vax=vase gen=twig]
|
|
|
|
=+ puz=(mule |.((~(mint ut p.vax) [%noun gen])))
|
|
|
|
?- -.puz
|
|
|
|
| (flaw cof p.puz)
|
|
|
|
& %+ (coup cof) (mock [q.vax q.p.puz] (mole ska))
|
|
|
|
|= val=*
|
|
|
|
`vase`[p.p.puz val]
|
|
|
|
==
|
2014-07-09 13:40:49 +04:00
|
|
|
::
|
2014-05-07 21:42:31 +04:00
|
|
|
++ make :: reduce silk
|
2014-05-16 00:17:54 +04:00
|
|
|
|= [cof=cafe kas=silk]
|
2014-05-07 21:42:31 +04:00
|
|
|
^- (bolt cage)
|
2014-07-09 02:46:34 +04:00
|
|
|
:: ~& [%make -.kas]
|
2014-05-07 21:42:31 +04:00
|
|
|
?- -.kas
|
2014-04-30 21:04:07 +04:00
|
|
|
^
|
2014-05-16 00:17:54 +04:00
|
|
|
%. [cof p.kas q.kas]
|
2014-05-07 21:42:31 +04:00
|
|
|
;~ cope
|
|
|
|
;~ coax
|
2014-05-16 00:17:54 +04:00
|
|
|
|=([cof=cafe p=silk q=silk] ^$(cof cof, kas p.kas))
|
|
|
|
|=([cof=cafe p=silk q=silk] ^$(cof cof, kas q.kas))
|
2014-05-07 21:42:31 +04:00
|
|
|
==
|
|
|
|
::
|
2014-05-16 00:17:54 +04:00
|
|
|
|= [cof=cafe bor=cage heg=cage] ^- (bolt cage)
|
2014-06-19 22:53:16 +04:00
|
|
|
[p=cof q=[%0 ~ [%$ (slop q.bor q.heg)]]]
|
2014-05-07 21:42:31 +04:00
|
|
|
==
|
2014-04-30 21:04:07 +04:00
|
|
|
::
|
2014-05-14 04:25:59 +04:00
|
|
|
%bake
|
2014-07-06 03:38:15 +04:00
|
|
|
%+ cool |.(leaf/"ford: bake {<p.kas>} {<(tope q.kas)>}")
|
2014-07-09 07:24:40 +04:00
|
|
|
%+ cope (lima cof p.kas q.kas r.kas)
|
2014-05-16 00:17:54 +04:00
|
|
|
|= [cof=cafe vux=(unit vase)]
|
2014-05-09 04:34:57 +04:00
|
|
|
?~ vux
|
2014-05-16 00:17:54 +04:00
|
|
|
(flaw cof (smyt (tope q.kas)) ~)
|
|
|
|
(fine cof [p.kas u.vux])
|
|
|
|
::
|
|
|
|
%boil
|
2014-07-09 07:00:30 +04:00
|
|
|
%+ cool |.(leaf/"ford: boil {<p.kas>} {<(tope q.kas)>} {<r.kas>}")
|
|
|
|
%+ cope (lime cof p.kas q.kas r.kas)
|
2014-05-16 00:17:54 +04:00
|
|
|
|= [cof=cafe vax=vase]
|
|
|
|
(fine cof `cage`[p.kas vax])
|
2014-07-10 01:43:30 +04:00
|
|
|
::
|
|
|
|
%brew
|
|
|
|
~& %ford-brew
|
|
|
|
%+ cool |.(leaf/"ford: brew {<p.kas>} {<(tope q.kas)>} {<r.kas>}")
|
|
|
|
%+ cope (krab cof p.kas %hoon q.kas r.kas)
|
|
|
|
|= [cof=cafe vax=vase]
|
|
|
|
(fine cof `cage`[p.kas vax])
|
2014-04-30 21:04:07 +04:00
|
|
|
::
|
|
|
|
%call
|
2014-07-06 03:38:15 +04:00
|
|
|
%+ cool |.(leaf/"ford: call {<`@p`(mug kas)>}")
|
2014-05-16 00:17:54 +04:00
|
|
|
%. [cof p.kas q.kas]
|
2014-05-07 21:42:31 +04:00
|
|
|
;~ cope
|
|
|
|
;~ coax
|
2014-05-16 00:17:54 +04:00
|
|
|
|=([cof=cafe p=silk q=silk] ^$(cof cof, kas p))
|
|
|
|
|=([cof=cafe p=silk q=silk] ^$(cof cof, kas q))
|
2014-05-07 21:42:31 +04:00
|
|
|
==
|
|
|
|
::
|
2014-05-16 00:17:54 +04:00
|
|
|
|= [cof=cafe gat=cage sam=cage]
|
|
|
|
(maul cof q.gat q.sam)
|
2014-05-07 21:42:31 +04:00
|
|
|
::
|
2014-05-16 00:17:54 +04:00
|
|
|
|= [cof=cafe vax=vase]
|
|
|
|
(fine cof %noun vax)
|
2014-05-07 21:42:31 +04:00
|
|
|
==
|
2014-04-30 21:04:07 +04:00
|
|
|
::
|
2014-05-10 11:10:46 +04:00
|
|
|
%cast
|
2014-07-06 03:38:15 +04:00
|
|
|
%+ cool |.(leaf/"ford: cast {<p.kas>} {<(tope q.kas ~)>}")
|
2014-05-10 11:10:46 +04:00
|
|
|
%+ cope $(kas r.kas)
|
2014-05-16 00:17:54 +04:00
|
|
|
|= [cof=cafe cay=cage]
|
2014-06-19 22:53:16 +04:00
|
|
|
%+ cope (link cof p.kas p.cay q.kas q.cay)
|
2014-05-16 00:17:54 +04:00
|
|
|
|= [cof=cafe vax=vase]
|
|
|
|
(fine cof [p.kas vax])
|
2014-04-30 21:04:07 +04:00
|
|
|
::
|
2014-05-31 16:52:06 +04:00
|
|
|
%done [cof %0 p.kas q.kas]
|
2014-07-06 03:38:15 +04:00
|
|
|
%dude (cool |.(p.kas) $(kas q.kas))
|
2014-06-17 05:33:31 +04:00
|
|
|
%dune
|
|
|
|
?~ q.kas [cof [%2 [%leaf "no data"]~]]
|
|
|
|
$(kas [%done p.kas u.q.kas])
|
2014-06-14 04:38:51 +04:00
|
|
|
::
|
2014-05-31 16:52:06 +04:00
|
|
|
%mute (kale cof p.kas q.kas)
|
2014-07-16 22:56:15 +04:00
|
|
|
%plan
|
|
|
|
%+ cope (main cof p.kas)
|
|
|
|
|= [cof=cafe vax=vase]
|
|
|
|
(fine cof [%noun vax])
|
|
|
|
::
|
2014-07-10 04:16:17 +04:00
|
|
|
%reef (fine cof %noun pit)
|
|
|
|
%ride
|
|
|
|
%+ cool |.(leaf/"ford: ride {<`@p`(mug kas)>}")
|
2014-05-31 16:52:06 +04:00
|
|
|
%+ cope $(kas p.kas)
|
|
|
|
|= [cof=cafe cay=cage]
|
|
|
|
%+ cope (gush cof q.kas)
|
|
|
|
|= [cof=cafe gen=twig]
|
|
|
|
%+ cope (maim cof q.cay gen)
|
|
|
|
|= [cof=cafe vax=vase]
|
|
|
|
(fine cof %noun vax)
|
|
|
|
::
|
2014-06-26 16:18:30 +04:00
|
|
|
%vale
|
2014-07-06 03:38:15 +04:00
|
|
|
%+ cool |.(leaf/"ford: vale {<p.kas>} {<q.kas>} {<`@p`(mug r.kas)>}")
|
2014-06-26 16:18:30 +04:00
|
|
|
%+ cope (lave cof p.kas q.kas r.kas)
|
|
|
|
|= [cof=cafe vux=(unit vase)]
|
|
|
|
?~ vux
|
|
|
|
(flaw cof [%leaf "invalid logos: {<[p.kas q.kas]>}"]~)
|
|
|
|
(fine cof `cage`[p.kas u.vux])
|
2014-04-30 21:04:07 +04:00
|
|
|
==
|
|
|
|
::
|
|
|
|
++ maul :: slam
|
2014-05-16 00:17:54 +04:00
|
|
|
|= [cof=cafe gat=vase sam=vase]
|
2014-05-07 21:42:31 +04:00
|
|
|
^- (bolt vase)
|
|
|
|
=+ top=(mule |.((slit p.gat p.sam)))
|
2014-05-14 04:25:59 +04:00
|
|
|
?- -.top
|
2014-05-16 00:17:54 +04:00
|
|
|
| (flaw cof p.top)
|
|
|
|
& %+ (coup cof) (mong [q.gat q.sam] (mole ska))
|
2014-05-14 04:25:59 +04:00
|
|
|
|= val=*
|
2014-05-09 04:34:57 +04:00
|
|
|
`vase`[p.top val]
|
|
|
|
==
|
2014-04-30 21:04:07 +04:00
|
|
|
::
|
2014-07-16 22:56:15 +04:00
|
|
|
++ plow :: true build
|
|
|
|
|= [cof=cafe pix=vase hyd=hood]
|
|
|
|
=| :* rop=(map term twig)
|
|
|
|
bil=(map term (trel beam (set term) twig))
|
|
|
|
ser=(map logo (map term vase)) :: XX update for horn
|
|
|
|
==
|
|
|
|
=< apex
|
|
|
|
|%
|
|
|
|
++ abet :: emit as vase
|
|
|
|
|= [gen=twig rex=vase]
|
|
|
|
^- (bolt vase)
|
|
|
|
%+ cope acme
|
|
|
|
|= [cof=cafe lib=twig]
|
|
|
|
%+ cope (maim cof pix [%tsgr able lib])
|
|
|
|
|= [cof=cafe vax=vase]
|
|
|
|
(maim cof ?~(ser vax (slop acta vax)) gen)
|
|
|
|
::
|
|
|
|
++ able :: assemble preamble
|
|
|
|
^- twig
|
|
|
|
?~(rop [%$ 1] [%brcn (~(run by rop) |=(a=twig [%ash a]))])
|
|
|
|
::
|
|
|
|
++ acta :: assemble resources
|
|
|
|
^- vase
|
|
|
|
=< apex
|
|
|
|
|%
|
|
|
|
++ apex
|
|
|
|
?~ ser !!
|
|
|
|
=+ top=(ayah p.n.ser (axel q.n.ser))
|
|
|
|
?~ l.ser
|
|
|
|
?~(r.ser top (slop top apex(ser r.ser)))
|
|
|
|
=+ lef=apex(ser l.ser)
|
|
|
|
?~(r.ser (slop lef top) :(slop lef top apex(ser r.ser)))
|
|
|
|
::
|
|
|
|
++ axel
|
|
|
|
|= ryz=(map term vase)
|
|
|
|
^= vax
|
|
|
|
|- ^- vase
|
|
|
|
?~ ryz !!
|
|
|
|
=+ top=(ayah n.ryz)
|
|
|
|
?~ l.ryz
|
|
|
|
?~(r.ryz top (slop top $(ryz r.ryz)))
|
|
|
|
=+ lef=$(ryz r.ryz)
|
|
|
|
?~(r.ryz (slop lef top) :(slop lef top $(ryz r.ryz)))
|
|
|
|
::
|
|
|
|
++ ayah
|
|
|
|
|= [cog=term vax=vase]
|
|
|
|
[[%face cog p.vax] q.vax]
|
|
|
|
--
|
|
|
|
::
|
|
|
|
++ acme :: libraries in order
|
|
|
|
^- (bolt twig)
|
|
|
|
%- cope
|
|
|
|
:_ |= [cof=cafe cus=(list twig)]
|
|
|
|
(fine cof [%tssg cus])
|
|
|
|
=+ kop=(turn (~(tap by bil) ~) |=([term *] -))
|
|
|
|
=| [dun=(set term) cus=(list twig)]
|
|
|
|
|- ^- (bolt (list twig))
|
|
|
|
?~ kop (fine cof cus)
|
|
|
|
=+ cog=i.kop
|
|
|
|
?: (~(has in dun) cog) $(kop t.kop)
|
|
|
|
=+ liv=`(set term)`[cog ~ ~]
|
|
|
|
|- ^- (bolt (list twig))
|
|
|
|
=+ zic=(need (~(get by bil) cog))
|
|
|
|
=+ dez=`(list term)`(~(tap in q.zic) ~)
|
|
|
|
|- ^- (bolt (list twig))
|
|
|
|
?~ dez
|
|
|
|
^^$(cus [p.zic cus], dun (~(put in dun) cog), kop t.kop)
|
|
|
|
?: (~(has in dun) i.dez)
|
|
|
|
$(dez t.dez)
|
|
|
|
?: (~(has in liv) cog)
|
|
|
|
(flaw cof [%leaf "build error: {<cog>} depends on itself}"])
|
|
|
|
^$(cog i.dez, liv (~(put in liv) cog), kop [i.kop kop])
|
|
|
|
::
|
|
|
|
++ aloe :: process all
|
|
|
|
^- (bolt (trel vase twig ,_..aloe))
|
|
|
|
%+ cope body
|
|
|
|
|= [cof=cafe cus=(list twig) sel=_..aloe]
|
|
|
|
=. ..aloe sel(cof cof)
|
|
|
|
%+ cope head
|
|
|
|
|= [cof=cafe sel=_..aloe]
|
|
|
|
=. ..aloe sel(cof cof)
|
|
|
|
%+ cope butt
|
|
|
|
|= [cof=cafe sel=_..aloe]
|
|
|
|
:: =. ..aloe sel(cof cof)
|
|
|
|
:: %+ cope eyes
|
|
|
|
:: |= [cof=cafe pix=vase sel=_..aloe]
|
|
|
|
:: (fine cof [%tssg (flop cus)] pix sel(cof cof))
|
|
|
|
(fine cof [%tssg (flop cus)] !>(~) sel(cof cof))
|
|
|
|
::
|
|
|
|
++ apex :: top level
|
|
|
|
^- (bolt vase)
|
|
|
|
%+ cope aloe
|
|
|
|
|= [cof=cafe cus=(list twig) sel=_..aloe]
|
|
|
|
(abet:sel(cof cof) cus)
|
|
|
|
::
|
|
|
|
++ body :: process body
|
|
|
|
=+ cus=(list twig)
|
|
|
|
|- ^- (bolt (pair (list twig) ,_..body))
|
|
|
|
?~ src.hyd
|
|
|
|
(fine cof cus ..body)
|
|
|
|
%+ cope (wilt i.src.hyd)
|
|
|
|
|= [cof=cafe gen=twig sel=_..body]
|
|
|
|
$(src.hyd t.src.hyd, cus [gen cus], ..body sel(cof cof))
|
|
|
|
::
|
|
|
|
++ butt :: process libraries
|
|
|
|
=+ bol=(~(tap by lib.hyd) ~)
|
|
|
|
|- ^- (bolt ,_..butt)
|
|
|
|
?~ bol ..butt
|
|
|
|
?. =+ olb=(~(get by bil) p.i.bol)
|
|
|
|
?~ olb &
|
|
|
|
=(`beam`p.u.olb `beam`q.i.bol)
|
|
|
|
(flaw cof [%leaf "build error: {<p.i.bol>} {<p.u.olb>} {<q.i.bol>}]~)
|
|
|
|
%+ cope (wine q.i.bol)
|
|
|
|
|= [cof=cafe gen=twig dep=(set term) dah=hood]
|
|
|
|
^$(olb
|
|
|
|
::
|
|
|
|
++ wilt :: process body entry
|
|
|
|
|= hop=hoop
|
|
|
|
^- (bolt ,[p=twig q=_..wilt])
|
|
|
|
?+ -.hop !!
|
|
|
|
%code (fine p.hop ..wilt)
|
|
|
|
%hoon (wine p.hop)
|
|
|
|
==
|
|
|
|
::
|
|
|
|
++ wind :: sub-hood, no deps
|
|
|
|
|= bem=beam
|
|
|
|
^- (bolt ,[p=twig r=_..wind])
|
|
|
|
%+ cope (fade cof %bake %hoon bem ~)
|
|
|
|
|= [cof=cafe dah=hood]
|
|
|
|
%+ cope aloe(hyd dah)
|
|
|
|
|= [cof=cafe cus=(list twig) sel=_..wind]
|
|
|
|
(fine [%tssg (flop cus)] sel(hyd hyd, cof cof))
|
|
|
|
::
|
|
|
|
++ wine :: sub-hood, deps
|
|
|
|
|= bem=beam
|
|
|
|
^- (bolt ,[p=twig q=(set term) r=_..wind])
|
|
|
|
%+ cope (fade cof %bake %hoon bem ~)
|
|
|
|
|= [cof=cafe dah=hood]
|
|
|
|
%+ cope aloe(hyd dah, lib ~)
|
|
|
|
|= [cof=cafe cus=(list twig) sel=_..wind]
|
|
|
|
%^ fine
|
|
|
|
[%tssg (flop cus)]
|
|
|
|
lib.sel
|
|
|
|
sel(hyd hyd, lib (~(uni in lib.sel) lib), cof cof)
|
|
|
|
--
|
|
|
|
::
|
2014-04-30 21:04:07 +04:00
|
|
|
++ resp
|
|
|
|
|= [tik=@ud rot=riot]
|
|
|
|
^+ ..zo
|
|
|
|
?> (~(has by q.kig) tik)
|
|
|
|
?~ rot
|
2014-05-09 04:34:57 +04:00
|
|
|
amok:(expo [%made %| (smyt (tope (need (~(get by q.kig) tik)))) ~])
|
2014-04-30 21:04:07 +04:00
|
|
|
exec(q.kig (~(del by q.kig) tik))
|
|
|
|
--
|
|
|
|
--
|
|
|
|
--
|
2014-04-23 21:02:36 +04:00
|
|
|
. ==
|
|
|
|
=| axle
|
|
|
|
=* lex -
|
2014-05-31 23:40:02 +04:00
|
|
|
|= [now=@da eny=@ ski=sled] :: activate
|
2014-04-23 21:02:36 +04:00
|
|
|
^? :: opaque core
|
|
|
|
|% ::
|
2014-06-03 09:07:32 +04:00
|
|
|
++ call :: request
|
2014-06-04 21:56:30 +04:00
|
|
|
|= [hen=duct hic=(hypo (hobo kiss))]
|
2014-06-04 14:40:09 +04:00
|
|
|
^- [p=(list move) q=_..^$]
|
2014-07-09 07:00:30 +04:00
|
|
|
=> .(q.hic ?.(?=(%soft -.q.hic) q.hic ((hard kiss) p.q.hic)))
|
2014-05-31 23:40:02 +04:00
|
|
|
=+ ska=(slod ski)
|
2014-05-22 21:39:51 +04:00
|
|
|
=+ ^= our ^- @p
|
2014-06-03 09:07:32 +04:00
|
|
|
?- -.q.hic
|
|
|
|
%exec p.q.hic
|
2014-05-22 21:39:51 +04:00
|
|
|
==
|
2014-05-14 04:04:23 +04:00
|
|
|
=+ ^= bay ^- baby
|
2014-05-22 21:39:51 +04:00
|
|
|
=+ buy=(~(get by pol.lex) our)
|
2014-05-14 04:04:23 +04:00
|
|
|
?~(buy *baby u.buy)
|
|
|
|
=^ mos bay
|
2014-06-03 09:07:32 +04:00
|
|
|
abet:(~(apex za [[our ~ hen] [now eny ska] ~] bay) q.q.hic)
|
2014-05-22 21:39:51 +04:00
|
|
|
[mos ..^$(pol (~(put by pol) our bay))]
|
|
|
|
::
|
2014-04-23 21:02:36 +04:00
|
|
|
++ doze
|
|
|
|
|= [now=@da hen=duct]
|
|
|
|
^- (unit ,@da)
|
|
|
|
~
|
|
|
|
::
|
2014-07-09 07:00:30 +04:00
|
|
|
++ load :: highly forgiving
|
|
|
|
|= old=*
|
|
|
|
=. old
|
|
|
|
?. ?=([%0 *] old) old :: remove at 1
|
|
|
|
:- %1
|
|
|
|
|- ^- *
|
|
|
|
?~ +.old ~
|
|
|
|
?> ?=([n=[p=* q=[tad=* dym=* jav=*]] l=* r=*] +.old)
|
|
|
|
:- [p.n.+.old [tad.q.n.+.old dym.q.n.+.old ~]]
|
|
|
|
[$(+.old l.+.old) $(+.old r.+.old)]
|
|
|
|
=+ lox=((soft axle) old)
|
2014-05-31 03:51:35 +04:00
|
|
|
^+ ..^$
|
2014-07-09 07:00:30 +04:00
|
|
|
?~ lox
|
|
|
|
~& %ford-reset
|
|
|
|
..^$
|
|
|
|
..^$(+>- u.lox)
|
2014-04-23 21:02:36 +04:00
|
|
|
::
|
|
|
|
++ scry
|
2014-05-27 00:43:40 +04:00
|
|
|
|= [fur=(unit (set monk)) ren=@tas who=ship syd=desk lot=coin tyl=path]
|
2014-06-19 22:53:16 +04:00
|
|
|
^- (unit (unit (pair logo ,*)))
|
2014-04-23 21:02:36 +04:00
|
|
|
~
|
|
|
|
::
|
2014-07-09 07:00:30 +04:00
|
|
|
++ stay :: save w/o cache
|
|
|
|
`axle`+>-.$(pol (~(run by pol) |=(a=baby [tad.a dym.a ~])))
|
|
|
|
::
|
2014-06-03 09:07:32 +04:00
|
|
|
++ take :: response
|
2014-06-22 09:49:10 +04:00
|
|
|
|= [tea=wire hen=duct hin=(hypo sign)]
|
2014-06-03 09:07:32 +04:00
|
|
|
^- [p=(list move) q=_..^$]
|
|
|
|
=+ ska=(slod ski)
|
|
|
|
?> ?=([@ @ @ ~] tea)
|
|
|
|
=+ :* our=(need (slaw %p i.tea))
|
|
|
|
num=(need (slaw %ud i.t.tea))
|
|
|
|
tik=(need (slaw %ud i.t.t.tea))
|
|
|
|
==
|
|
|
|
=+ bay=(need (~(get by pol.lex) our))
|
|
|
|
=^ mos bay
|
2014-06-22 06:51:12 +04:00
|
|
|
abet:(~(axon za [[our tea hen] [now eny ska] ~] bay) num tik q.hin)
|
2014-06-03 09:07:32 +04:00
|
|
|
[mos ..^$(pol (~(put by pol) our bay))]
|
2014-04-23 21:02:36 +04:00
|
|
|
--
|