aboutsummaryrefslogtreecommitdiff
path: root/stdlib/source/lux/tool/compiler/phase
diff options
context:
space:
mode:
Diffstat (limited to 'stdlib/source/lux/tool/compiler/phase')
-rw-r--r--stdlib/source/lux/tool/compiler/phase/generation/js/primitive.lux5
-rw-r--r--stdlib/source/lux/tool/compiler/phase/generation/jvm.lux65
-rw-r--r--stdlib/source/lux/tool/compiler/phase/generation/jvm/primitive.lux34
-rw-r--r--stdlib/source/lux/tool/compiler/phase/generation/jvm/runtime.lux30
4 files changed, 129 insertions, 5 deletions
diff --git a/stdlib/source/lux/tool/compiler/phase/generation/js/primitive.lux b/stdlib/source/lux/tool/compiler/phase/generation/js/primitive.lux
index da1052d28..09341fd59 100644
--- a/stdlib/source/lux/tool/compiler/phase/generation/js/primitive.lux
+++ b/stdlib/source/lux/tool/compiler/phase/generation/js/primitive.lux
@@ -1,10 +1,5 @@
(.module:
[lux (#- i64)
- [control
- [pipe (#+ cond> new>)]]
- [data
- [number
- ["." frac]]]
[target
["_" js (#+ Computation)]]]
["." // #_
diff --git a/stdlib/source/lux/tool/compiler/phase/generation/jvm.lux b/stdlib/source/lux/tool/compiler/phase/generation/jvm.lux
new file mode 100644
index 000000000..e9ece420f
--- /dev/null
+++ b/stdlib/source/lux/tool/compiler/phase/generation/jvm.lux
@@ -0,0 +1,65 @@
+(.module:
+ [lux #*
+ [abstract
+ [monad (#+ do)]]]
+ ["." / #_
+ [runtime (#+ Phase)]
+ ["#." primitive]
+ ## ["." structure]
+ ## ["." reference ("#@." system)]
+ ## ["." function]
+ ## ["." case]
+ ## ["." loop]
+ ["//#" ///
+ ## ["." extension]
+ [//
+ [analysis (#+)]
+ ["." synthesis]]]])
+
+(def: #export (generate synthesis)
+ Phase
+ (case synthesis
+ (^template [<tag> <generator>]
+ (^ (<tag> value))
+ (:: ///.monad wrap (<generator> value)))
+ ([synthesis.bit /primitive.bit]
+ [synthesis.i64 /primitive.i64]
+ [synthesis.f64 /primitive.f64]
+ [synthesis.text /primitive.text])
+
+ ## (^ (synthesis.variant variantS))
+ ## (/structure.variant generate variantS)
+
+ ## (^ (synthesis.tuple members))
+ ## (/structure.tuple generate members)
+
+ ## (#synthesis.Reference value)
+ ## (/reference@reference value)
+
+ ## (^ (synthesis.branch/case case))
+ ## (/case.case generate case)
+
+ ## (^ (synthesis.branch/let let))
+ ## (/case.let generate let)
+
+ ## (^ (synthesis.branch/if if))
+ ## (/case.if generate if)
+
+ ## (^ (synthesis.loop/scope scope))
+ ## (/loop.scope generate scope)
+
+ ## (^ (synthesis.loop/recur updates))
+ ## (/loop.recur generate updates)
+
+ ## (^ (synthesis.function/abstraction abstraction))
+ ## (/function.function generate abstraction)
+
+ ## (^ (synthesis.function/apply application))
+ ## (/function.apply generate application)
+
+ ## (#synthesis.Extension extension)
+ ## (/extension.apply generate extension)
+
+ _
+ (undefined)
+ ))
diff --git a/stdlib/source/lux/tool/compiler/phase/generation/jvm/primitive.lux b/stdlib/source/lux/tool/compiler/phase/generation/jvm/primitive.lux
new file mode 100644
index 000000000..d0d819925
--- /dev/null
+++ b/stdlib/source/lux/tool/compiler/phase/generation/jvm/primitive.lux
@@ -0,0 +1,34 @@
+(.module:
+ [lux (#- i64)
+ [abstract
+ [monad (#+ do)]]
+ [target
+ [jvm
+ ["|" descriptor]
+ ["." constant]
+ ["_" program (#+ Program)]]]
+ [macro
+ ["." template]]]
+ ["." // #_
+ ["#." runtime]])
+
+(def: #export (bit value)
+ (-> Bit (Program Any))
+ (_.getstatic "java.lang.Boolean"
+ (if value "TRUE" "FALSE")
+ (|.object "java.lang.Boolean")))
+
+(template [<name> <inputT> <ldc> <class> <inputD>]
+ [(def: #export (<name> value)
+ (-> <inputT> (Program Any))
+ (do _.monad
+ [_ (`` (|> value (~~ (template.splice <ldc>))))]
+ (_.invokestatic <class> "valueOf"
+ (list <inputD>)
+ (|.object <class>))))]
+
+ [i64 (I64 Any) [.int constant.long _.ldc/long] "java.lang.Long" |.long]
+ [f64 Frac [constant.double _.ldc/double] "java.lang.Double" |.double]
+ )
+
+(def: #export text _.ldc/string)
diff --git a/stdlib/source/lux/tool/compiler/phase/generation/jvm/runtime.lux b/stdlib/source/lux/tool/compiler/phase/generation/jvm/runtime.lux
new file mode 100644
index 000000000..5a84c4990
--- /dev/null
+++ b/stdlib/source/lux/tool/compiler/phase/generation/jvm/runtime.lux
@@ -0,0 +1,30 @@
+(.module:
+ [lux (#- Definition)
+ [data
+ [binary (#+ Binary)]]
+ [target
+ [jvm
+ ["_" program (#+ Label Program)]]]]
+ ["." ///
+ [///
+ [reference (#+ Register)]]]
+ )
+
+(type: #export Byte-Code Binary)
+
+(type: #export Definition [Text Byte-Code])
+
+(type: #export Anchor [Label Register])
+
+(template [<name> <base>]
+ [(type: #export <name>
+ (<base> Anchor (Program Any) Definition))]
+
+ [Operation ///.Operation]
+ [Phase ///.Phase]
+ [Handler ///.Handler]
+ [Bundle ///.Bundle]
+ )
+
+(type: #export (Generator i)
+ (-> i Phase (Operation (Program Any))))