aboutsummaryrefslogtreecommitdiff
path: root/new-luxc
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--new-luxc/source/luxc/lang/extension.lux10
-rw-r--r--new-luxc/test/test/luxc/common.lux4
-rw-r--r--new-luxc/test/test/luxc/lang/analysis/procedure/host.jvm.lux10
-rw-r--r--new-luxc/test/test/luxc/lang/analysis/type.lux2
-rw-r--r--new-luxc/test/test/luxc/lang/synthesis/case/special.lux10
-rw-r--r--new-luxc/test/test/luxc/lang/synthesis/function.lux11
-rw-r--r--new-luxc/test/test/luxc/lang/synthesis/loop.lux9
-rw-r--r--new-luxc/test/test/luxc/lang/synthesis/primitive.lux5
-rw-r--r--new-luxc/test/test/luxc/lang/synthesis/procedure.lux6
-rw-r--r--new-luxc/test/test/luxc/lang/synthesis/structure.lux7
-rw-r--r--new-luxc/test/test/luxc/lang/translation/jvm/case.lux (renamed from new-luxc/test/test/luxc/lang/translation/case.lux)10
-rw-r--r--new-luxc/test/test/luxc/lang/translation/jvm/function.lux (renamed from new-luxc/test/test/luxc/lang/translation/function.lux)8
-rw-r--r--new-luxc/test/test/luxc/lang/translation/jvm/primitive.lux (renamed from new-luxc/test/test/luxc/lang/translation/primitive.lux)8
-rw-r--r--new-luxc/test/test/luxc/lang/translation/jvm/procedure/common.jvm.lux (renamed from new-luxc/test/test/luxc/lang/translation/procedure/common.jvm.lux)8
-rw-r--r--new-luxc/test/test/luxc/lang/translation/jvm/procedure/host.jvm.lux (renamed from new-luxc/test/test/luxc/lang/translation/procedure/host.jvm.lux)8
-rw-r--r--new-luxc/test/test/luxc/lang/translation/jvm/reference.lux (renamed from new-luxc/test/test/luxc/lang/translation/reference.lux)18
-rw-r--r--new-luxc/test/test/luxc/lang/translation/jvm/structure.lux (renamed from new-luxc/test/test/luxc/lang/translation/structure.lux)8
-rw-r--r--new-luxc/test/tests.lux14
18 files changed, 83 insertions, 73 deletions
diff --git a/new-luxc/source/luxc/lang/extension.lux b/new-luxc/source/luxc/lang/extension.lux
index ff3a4d24e..c5e6a8e25 100644
--- a/new-luxc/source/luxc/lang/extension.lux
+++ b/new-luxc/source/luxc/lang/extension.lux
@@ -79,13 +79,17 @@
[find-statement Statement #statement Unknown-Statement]
)
-(do-template [<name> <type> <category>]
- [(def: #export <name>
+(do-template [<no> <all> <type> <category> <empty>]
+ [(def: #export <no>
+ <type>
+ <empty>)
+
+ (def: #export <all>
(Meta <type>)
(|> ..get
(:: macro.Monad<Meta> map (get@ <category>))))]
- [all-syntheses (Dict Text Synthesis) #synthesis]
+ [no-syntheses all-syntheses Syntheses #synthesis (dict.new text.Hash<Text>)]
)
(do-template [<name> <type> <category> <exception>]
diff --git a/new-luxc/test/test/luxc/common.lux b/new-luxc/test/test/luxc/common.lux
index 914e31893..5ec4b1259 100644
--- a/new-luxc/test/test/luxc/common.lux
+++ b/new-luxc/test/test/luxc/common.lux
@@ -2,8 +2,8 @@
lux
(lux [io])
(luxc (lang ["&." host]
- [".L" translation])))
+ [".L" init])))
(def: #export (init-compiler _)
(-> Top Compiler)
- (translationL.init-compiler (io.run &host.init-host)))
+ (initL.compiler (io.run &host.init-host)))
diff --git a/new-luxc/test/test/luxc/lang/analysis/procedure/host.jvm.lux b/new-luxc/test/test/luxc/lang/analysis/procedure/host.jvm.lux
index 41b2dfaa0..382ad87e2 100644
--- a/new-luxc/test/test/luxc/lang/analysis/procedure/host.jvm.lux
+++ b/new-luxc/test/test/luxc/lang/analysis/procedure/host.jvm.lux
@@ -22,10 +22,9 @@
["&." module]
["~" analysis]
(analysis [".A" expression]
- ["@." common]
- ["@" procedure]
- (procedure ["@." host]))
- (translation ["@." runtime])
+ ["@." common])
+ (translation (jvm ["@." runtime]))
+ (extension (analysis ["@." host]))
[".L" eval]))
(/// common)
(test/luxc common))
@@ -37,7 +36,8 @@
[runtime-bytecode @runtime.translate]
(&.with-scope
(&.with-type output-type
- (@.analyse-procedure analyse evalL.eval procedure params))))
+ ((expressionA.analyser evalL.eval)
+ (` ((~ (code.text procedure)) (~+ params)))))))
(&.with-current-module "")
(macro.run (init-compiler []))
(case> (#e.Success _)
diff --git a/new-luxc/test/test/luxc/lang/analysis/type.lux b/new-luxc/test/test/luxc/lang/analysis/type.lux
index 993cacbdf..4de75b989 100644
--- a/new-luxc/test/test/luxc/lang/analysis/type.lux
+++ b/new-luxc/test/test/luxc/lang/analysis/type.lux
@@ -22,7 +22,7 @@
(analysis [".A" expression]
["@" type]
["@." common])
- (translation ["@." runtime])
+ (translation (jvm ["@." runtime]))
[eval]))
(// common)
(test/luxc common))
diff --git a/new-luxc/test/test/luxc/lang/synthesis/case/special.lux b/new-luxc/test/test/luxc/lang/synthesis/case/special.lux
index 4e00163ae..398f98a57 100644
--- a/new-luxc/test/test/luxc/lang/synthesis/case/special.lux
+++ b/new-luxc/test/test/luxc/lang/synthesis/case/special.lux
@@ -9,6 +9,7 @@
(luxc (lang ["la" analysis]
["ls" synthesis]
(synthesis [".S" expression])
+ [".L" extension]
[".L" variable #+ Variable]))
(/// common))
@@ -21,7 +22,8 @@
{("lux case bind" (~ (code.nat temp)))
(~ (la.var (variableL.local temp)))}))]]
(test "Dummy variables created to mask expressions get eliminated during synthesis."
- (|> (expressionS.synthesize maskA)
+ (|> (expressionS.synthesize extensionL.no-syntheses
+ maskA)
(corresponds? maskedA))))))
(context: "Let expressions."
@@ -34,7 +36,8 @@
{("lux case bind" (~ (code.nat registerA)))
(~ outputA)}))]]
(test "Can detect and reify simple 'let' expressions."
- (|> (expressionS.synthesize letA)
+ (|> (expressionS.synthesize extensionL.no-syntheses
+ letA)
(case> (^ [_ (#.Form (list [_ (#.Text "lux let")] [_ (#.Nat registerS)] inputS outputS))])
(and (n/= registerA registerS)
(corresponds? inputA inputS)
@@ -58,7 +61,8 @@
{false (~ elseA)
true (~ thenA)})))]]
(test "Can detect and reify simple 'if' expressions."
- (|> (expressionS.synthesize ifA)
+ (|> (expressionS.synthesize extensionL.no-syntheses
+ ifA)
(case> (^ [_ (#.Form (list [_ (#.Text "lux if")] inputS thenS elseS))])
(and (corresponds? inputA inputS)
(corresponds? thenA thenS)
diff --git a/new-luxc/test/test/luxc/lang/synthesis/function.lux b/new-luxc/test/test/luxc/lang/synthesis/function.lux
index 52a9d78db..bb3aa9204 100644
--- a/new-luxc/test/test/luxc/lang/synthesis/function.lux
+++ b/new-luxc/test/test/luxc/lang/synthesis/function.lux
@@ -16,6 +16,7 @@
(luxc (lang ["la" analysis]
["ls" synthesis]
(synthesis [".S" expression])
+ [".L" extension]
[".L" variable #+ Variable]))
(// common))
@@ -101,7 +102,7 @@
[args3 prediction3 function3] gen-function//local]
($_ seq
(test "Nested functions will get folded together."
- (|> (expressionS.synthesize function1)
+ (|> (expressionS.synthesize extensionL.no-syntheses function1)
(case> (^ [_ (#.Form (list [_ (#.Text "lux function")] [_ (#.Nat args)] [_ (#.Tuple captured)] output))])
(and (n/= args1 args)
(corresponds? prediction1 output))
@@ -109,7 +110,7 @@
_
(n/= +0 args1))))
(test "Folded functions provide direct access to captured variables."
- (|> (expressionS.synthesize function2)
+ (|> (expressionS.synthesize extensionL.no-syntheses function2)
(case> (^ [_ (#.Form (list [_ (#.Text "lux function")] [_ (#.Nat args)] [_ (#.Tuple captured)]
[_ (#.Form (list [_ (#.Int output)]))]))])
(and (n/= args2 args)
@@ -118,7 +119,7 @@
_
false)))
(test "Folded functions properly offset local variables."
- (|> (expressionS.synthesize function3)
+ (|> (expressionS.synthesize extensionL.no-syntheses function3)
(case> (^ [_ (#.Form (list [_ (#.Text "lux function")] [_ (#.Nat args)] [_ (#.Tuple captured)]
[_ (#.Form (list [_ (#.Int output)]))]))])
(and (n/= args3 args)
@@ -136,7 +137,7 @@
argsA (r.list num-args gen-primitive)]
($_ seq
(test "Can synthesize function application."
- (|> (expressionS.synthesize (la.apply argsA funcA))
+ (|> (expressionS.synthesize extensionL.no-syntheses (la.apply argsA funcA))
(case> (^ [_ (#.Form (list& [_ (#.Text "lux call")] funcS argsS))])
(and (corresponds? funcA funcS)
(list.every? (product.uncurry corresponds?)
@@ -145,6 +146,6 @@
_
false)))
(test "Function application on no arguments just synthesizes to the function itself."
- (|> (expressionS.synthesize (la.apply (list) funcA))
+ (|> (expressionS.synthesize extensionL.no-syntheses (la.apply (list) funcA))
(corresponds? funcA)))
))))
diff --git a/new-luxc/test/test/luxc/lang/synthesis/loop.lux b/new-luxc/test/test/luxc/lang/synthesis/loop.lux
index 805c66190..5d2db50a8 100644
--- a/new-luxc/test/test/luxc/lang/synthesis/loop.lux
+++ b/new-luxc/test/test/luxc/lang/synthesis/loop.lux
@@ -13,7 +13,8 @@
(luxc (lang ["la" analysis]
["ls" synthesis]
(synthesis [".S" expression]
- [".S" loop])))
+ [".S" loop])
+ [".L" extension]))
(// common))
(def: (does-recursion? arity exprS)
@@ -129,7 +130,8 @@
[[prediction arity analysis] gen-recursion]
($_ seq
(test "Can accurately identify (and then reify) tail recursion."
- (case (expressionS.synthesize analysis)
+ (case (expressionS.synthesize extensionL.no-syntheses
+ analysis)
(^ [_ (#.Form (list [_ (#.Text "lux function")] [_ (#.Nat _arity)] [_ (#.Tuple _env)] _body))])
(|> _body
(does-recursion? arity)
@@ -145,7 +147,8 @@
[[prediction arity analysis] gen-recursion]
($_ seq
(test "Can reify loops."
- (case (expressionS.synthesize (la.apply (list.repeat arity (' [])) analysis))
+ (case (expressionS.synthesize extensionL.no-syntheses
+ (la.apply (list.repeat arity (' [])) analysis))
(^ [_ (#.Form (list [_ (#.Text "lux loop")] [_ (#.Nat in_register)] [_ (#.Tuple _inits)] _body))])
(and (n/= arity (list.size _inits))
(not (loopS.contains-self-reference? _body)))
diff --git a/new-luxc/test/test/luxc/lang/synthesis/primitive.lux b/new-luxc/test/test/luxc/lang/synthesis/primitive.lux
index 157a9c1c3..57064afd9 100644
--- a/new-luxc/test/test/luxc/lang/synthesis/primitive.lux
+++ b/new-luxc/test/test/luxc/lang/synthesis/primitive.lux
@@ -9,6 +9,7 @@
test)
(luxc (lang ["la" analysis]
["ls" synthesis]
+ [".L" extension]
(synthesis [".S" expression]))))
(context: "Primitives"
@@ -22,7 +23,7 @@
%text% (r.text +5)]
(`` ($_ seq
(test (format "Can synthesize unit.")
- (|> (expressionS.synthesize (' []))
+ (|> (expressionS.synthesize extensionL.no-syntheses (' []))
(case> (^code [])
true
@@ -30,7 +31,7 @@
false)))
(~~ (do-template [<desc> <analysis> <synthesis> <sample>]
[(test (format "Can synthesize " <desc> ".")
- (|> (expressionS.synthesize (<analysis> <sample>))
+ (|> (expressionS.synthesize extensionL.no-syntheses (<analysis> <sample>))
(case> [_ (<synthesis> value)]
(is <sample> value)
diff --git a/new-luxc/test/test/luxc/lang/synthesis/procedure.lux b/new-luxc/test/test/luxc/lang/synthesis/procedure.lux
index 7b8923248..9648e5add 100644
--- a/new-luxc/test/test/luxc/lang/synthesis/procedure.lux
+++ b/new-luxc/test/test/luxc/lang/synthesis/procedure.lux
@@ -10,7 +10,8 @@
test)
(luxc (lang ["la" analysis]
["ls" synthesis]
- (synthesis [".S" expression])))
+ (synthesis [".S" expression])
+ [".L" extension]))
(// common))
(context: "Procedures"
@@ -21,7 +22,8 @@
argsA (r.list num-args gen-primitive)]
($_ seq
(test "Can synthesize procedure calls."
- (|> (expressionS.synthesize (la.procedure nameA argsA))
+ (|> (expressionS.synthesize extensionL.no-syntheses
+ (la.procedure nameA argsA))
(case> (^ [_ (#.Form (list& [_ (#.Text procedure)] argsS))])
(and (text/= nameA procedure)
(list.every? (product.uncurry corresponds?)
diff --git a/new-luxc/test/test/luxc/lang/synthesis/structure.lux b/new-luxc/test/test/luxc/lang/synthesis/structure.lux
index e401149ec..46c9bf2a1 100644
--- a/new-luxc/test/test/luxc/lang/synthesis/structure.lux
+++ b/new-luxc/test/test/luxc/lang/synthesis/structure.lux
@@ -10,7 +10,8 @@
test)
(luxc (lang ["la" analysis]
["ls" synthesis]
- (synthesis [".S" expression])))
+ (synthesis [".S" expression])
+ [".L" extension]))
(// common))
(context: "Variants"
@@ -21,7 +22,7 @@
memberA gen-primitive]
($_ seq
(test "Can synthesize variants."
- (|> (expressionS.synthesize (la.sum tagA size +0 memberA))
+ (|> (expressionS.synthesize extensionL.no-syntheses (la.sum tagA size +0 memberA))
(case> (^ [_ (#.Form (list [_ (#.Nat tagS)] [_ (#.Bool last?S)] memberS))])
(and (n/= tagA tagS)
(B/= (n/= (n/dec size) tagA)
@@ -39,7 +40,7 @@
membersA (r.list size gen-primitive)]
($_ seq
(test "Can synthesize tuple."
- (|> (expressionS.synthesize (la.product membersA))
+ (|> (expressionS.synthesize extensionL.no-syntheses (la.product membersA))
(case> [_ (#.Tuple membersS)]
(and (n/= size (list.size membersS))
(list.every? (product.uncurry corresponds?) (list.zip2 membersA membersS)))
diff --git a/new-luxc/test/test/luxc/lang/translation/case.lux b/new-luxc/test/test/luxc/lang/translation/jvm/case.lux
index 5b3972835..91071be6c 100644
--- a/new-luxc/test/test/luxc/lang/translation/case.lux
+++ b/new-luxc/test/test/luxc/lang/translation/jvm/case.lux
@@ -12,11 +12,11 @@
test)
(luxc [lang]
(lang ["ls" synthesis]
- (translation ["@" case]
- [".T" expression]
- ["@." eval]
- ["@." runtime]
- ["@." common])))
+ (translation (jvm ["@" case]
+ [".T" expression]
+ ["@." eval]
+ ["@." runtime]
+ ["@." common]))))
(test/luxc common))
(def: struct-limit Nat +10)
diff --git a/new-luxc/test/test/luxc/lang/translation/function.lux b/new-luxc/test/test/luxc/lang/translation/jvm/function.lux
index 7a87e71a1..d9ee7ac71 100644
--- a/new-luxc/test/test/luxc/lang/translation/function.lux
+++ b/new-luxc/test/test/luxc/lang/translation/jvm/function.lux
@@ -15,10 +15,10 @@
test)
(luxc [lang]
(lang ["ls" synthesis]
- (translation [".T" expression]
- ["@." eval]
- ["@." runtime]
- ["@." common])))
+ (translation (jvm [".T" expression]
+ ["@." eval]
+ ["@." runtime]
+ ["@." common]))))
(test/luxc common))
(def: arity-limit Nat +10)
diff --git a/new-luxc/test/test/luxc/lang/translation/primitive.lux b/new-luxc/test/test/luxc/lang/translation/jvm/primitive.lux
index d6e316036..9d51490e2 100644
--- a/new-luxc/test/test/luxc/lang/translation/primitive.lux
+++ b/new-luxc/test/test/luxc/lang/translation/jvm/primitive.lux
@@ -14,10 +14,10 @@
(luxc [lang]
(lang [".L" host]
["ls" synthesis]
- (translation [".T" expression]
- ["@." runtime]
- ["@." eval]
- ["@." common])))
+ (translation (jvm [".T" expression]
+ ["@." runtime]
+ ["@." eval]
+ ["@." common]))))
(test/luxc common))
(context: "Primitives."
diff --git a/new-luxc/test/test/luxc/lang/translation/procedure/common.jvm.lux b/new-luxc/test/test/luxc/lang/translation/jvm/procedure/common.jvm.lux
index 96cf8b01e..8e4fd362f 100644
--- a/new-luxc/test/test/luxc/lang/translation/procedure/common.jvm.lux
+++ b/new-luxc/test/test/luxc/lang/translation/jvm/procedure/common.jvm.lux
@@ -18,10 +18,10 @@
test)
(luxc [lang]
(lang ["ls" synthesis]
- (translation [".T" expression]
- ["@." eval]
- ["@." runtime]
- ["@." common])))
+ (translation (jvm [".T" expression]
+ ["@." eval]
+ ["@." runtime]
+ ["@." common]))))
(test/luxc common))
(context: "Bit procedures"
diff --git a/new-luxc/test/test/luxc/lang/translation/procedure/host.jvm.lux b/new-luxc/test/test/luxc/lang/translation/jvm/procedure/host.jvm.lux
index 4af912b2a..a8e53e79e 100644
--- a/new-luxc/test/test/luxc/lang/translation/procedure/host.jvm.lux
+++ b/new-luxc/test/test/luxc/lang/translation/jvm/procedure/host.jvm.lux
@@ -19,10 +19,10 @@
(luxc [lang]
(lang [".L" host]
["ls" synthesis]
- (translation [".T" expression]
- ["@." eval]
- ["@." runtime]
- ["@." common])))
+ (translation (jvm [".T" expression]
+ ["@." eval]
+ ["@." runtime]
+ ["@." common]))))
(test/luxc common))
(context: "Conversions [Part 1]"
diff --git a/new-luxc/test/test/luxc/lang/translation/reference.lux b/new-luxc/test/test/luxc/lang/translation/jvm/reference.lux
index bcdef1a8b..ddbefd8d9 100644
--- a/new-luxc/test/test/luxc/lang/translation/reference.lux
+++ b/new-luxc/test/test/luxc/lang/translation/jvm/reference.lux
@@ -14,11 +14,11 @@
(host ["$" jvm]
(jvm ["$i" inst]))
["ls" synthesis]
- (translation [".T" statement]
- [".T" eval]
- [".T" expression]
- [".T" case]
- [".T" runtime])))
+ (translation (jvm [".T" statement]
+ [".T" eval]
+ [".T" expression]
+ [".T" case]
+ [".T" runtime]))))
(test/luxc common))
(def: nilI $.Inst runtimeT.noneI)
@@ -31,12 +31,6 @@
$i.DUP ($i.int 1) ($i.long 0) ($i.wrap #$.Long) $i.AASTORE
$i.DUP ($i.int 2) ($i.long 0) ($i.wrap #$.Long) $i.AASTORE))
-(def: empty-metaI
- (|>> ($i.int 2)
- ($i.array runtimeT.$Tuple)
- $i.DUP ($i.int 0) cursorI $i.AASTORE
- $i.DUP ($i.int 1) nilI $i.AASTORE))
-
(context: "Definitions."
(<| (times +100)
(do @
@@ -48,7 +42,7 @@
(test "Can refer to definitions."
(|> (do macro.Monad<Meta>
[_ (_module.with-module +0 module-name
- (statementT.translate-def def-name Int valueI empty-metaI (' {})))
+ (statementT.translate-def def-name Int valueI (' {})))
sampleI (expressionT.translate (code.symbol [module-name def-name]))]
(evalT.eval sampleI))
(lang.with-current-module "")
diff --git a/new-luxc/test/test/luxc/lang/translation/structure.lux b/new-luxc/test/test/luxc/lang/translation/jvm/structure.lux
index 078079b6b..2fc377bd6 100644
--- a/new-luxc/test/test/luxc/lang/translation/structure.lux
+++ b/new-luxc/test/test/luxc/lang/translation/jvm/structure.lux
@@ -18,10 +18,10 @@
(luxc [lang]
(lang [".L" host]
["ls" synthesis]
- (translation [".T" expression]
- ["@." eval]
- ["@." runtime]
- ["@." common])))
+ (translation (jvm [".T" expression]
+ ["@." eval]
+ ["@." runtime]
+ ["@." common]))))
(test/luxc common))
(host.import java/lang/Integer)
diff --git a/new-luxc/test/tests.lux b/new-luxc/test/tests.lux
index 98043260b..ce15be88f 100644
--- a/new-luxc/test/tests.lux
+++ b/new-luxc/test/tests.lux
@@ -19,13 +19,13 @@
["_.S" function]
["_.S" procedure]
["_.S" loop])
- (translation ["_.T" primitive]
- ["_.T" structure]
- ["_.T" case]
- ["_.T" function]
- ["_.T" reference]
- (procedure ["_.T" common]
- ["_.T" host])))
+ (translation (jvm ["_.T" primitive]
+ ["_.T" structure]
+ ["_.T" case]
+ ["_.T" function]
+ ["_.T" reference]
+ (procedure ["_.T" common]
+ ["_.T" host]))))
)))
(program: args