diff options
author | Eduardo Julian | 2019-03-03 01:11:26 -0400 |
---|---|---|
committer | Eduardo Julian | 2019-03-03 01:11:26 -0400 |
commit | bd433efacc33492705b09953d321b844d2b1c9f0 (patch) | |
tree | d58a49155ebae18f7cc0f66cf60853d4ffa568ad /new-luxc/source | |
parent | 8dfd0e3992f5ae60d568793a6843dc9fb472eba7 (diff) |
Factored-out general compiler program machinery.
Diffstat (limited to 'new-luxc/source')
-rw-r--r-- | new-luxc/source/luxc/lang/translation/jvm.lux | 2 | ||||
-rw-r--r-- | new-luxc/source/program.lux | 122 |
2 files changed, 39 insertions, 85 deletions
diff --git a/new-luxc/source/luxc/lang/translation/jvm.lux b/new-luxc/source/luxc/lang/translation/jvm.lux index 5ffb60482..01bc2b36f 100644 --- a/new-luxc/source/luxc/lang/translation/jvm.lux +++ b/new-luxc/source/luxc/lang/translation/jvm.lux @@ -120,7 +120,7 @@ [value (evaluate! library loader class-name valueI)] (wrap [class-name value])))) -(def: #export init +(def: #export host (IO Host) (io (let [library (loader.new-library []) loader (loader.memory library)] diff --git a/new-luxc/source/program.lux b/new-luxc/source/program.lux index 0f761d70d..c4fe26e0b 100644 --- a/new-luxc/source/program.lux +++ b/new-luxc/source/program.lux @@ -3,104 +3,58 @@ [cli (#+ program:)] [control [monad (#+ do)]] - [data - ["." error (#+ Error)] - ["." text - format]] - ["." io (#+ IO io)] - [time - ["." instant (#+ Instant)]] + ["." io (#+ IO)] [world - ["." file (#+ File)] - ["." console]] + ["." file]] + [host + ["." js]] [tool - ["." compiler - ["." cli (#+ Configuration)] - [meta - ["." archive] - [io - ["." context]]] - ["." phase - ["." translation] + [compiler + ["." cli] + ["/" program] + [phase + [analysis + [".A" macro]] + ["." translation + [".T" js + [".JS" runtime] + [".JS" expression] + [".JS" extension]]] ["." statement]] [default - ["." platform (#+ Platform)] - ["." init] - ["." syntax]]] - ## ["." interpreter] - ]] + ["." platform (#+ Platform)]]]]] [luxc [lang - ["." host/jvm] + [host + ["." jvm]] [translation - ["." jvm - ["." runtime] - ["." expression] + [".T" jvm + [".JVM" runtime] + [".JVM" expression] [procedure - ["." common]]]]]]) + [".JVM" common]]]]]] + ) -(def: (or-crash! failure-description action) - (All [a] - (-> Text (IO (Error a)) (IO a))) +(def: jvm + (IO (Platform IO jvm.Anchor jvm.Inst jvm.Definition)) (do io.monad - [?output action] - (case ?output - (#error.Failure error) - (exec (log! (format text.new-line - failure-description text.new-line - error text.new-line)) - (io.exit +1)) - - (#error.Success output) - (wrap output)))) - -(def: (timed action) - (All [a] - (-> (-> Any (IO (Error a))) (IO (Error a)))) - (do (error.with io.monad) - [start (: (IO (Error Instant)) - (error.lift io.monad instant.now)) - result (action []) - finish (: (IO (Error Instant)) - (error.lift io.monad instant.now)) - #let [elapsed-time (instant.span start finish) - _ (log! (format text.new-line - "Elapsed time: " (%duration elapsed-time)))]] - (wrap result))) + [host jvmT.host] + (wrap {#platform.&monad io.monad + #platform.&file-system file.system + #platform.host host + #platform.phase expressionJVM.translate + #platform.runtime runtimeJVM.translate}))) -(def: jvm-platform - (IO (Platform IO host/jvm.Anchor host/jvm.Inst host/jvm.Definition)) +(def: js + (IO (Platform IO js.Var js.Expression js.Statement)) (do io.monad - [host jvm.init] + [host jsT.host] (wrap {#platform.&monad io.monad #platform.&file-system file.system #platform.host host - #platform.phase expression.translate - #platform.runtime runtime.translate}))) + #platform.phase expressionJS.translate + #platform.runtime runtimeJS.translate}))) (program: [{service cli.service}] - (do io.monad - [platform (: (IO (Platform IO host/jvm.Anchor host/jvm.Inst host/jvm.Definition)) - ..jvm-platform) - console (:: @ map error.assume console.system)] - (case service - (#cli.Compilation configuration) - (<| (or-crash! "Compilation failed:") - ..timed - (function (_ _) - (do (error.with io.monad) - [state (: (IO (Error (statement.State+ host/jvm.Anchor host/jvm.Inst host/jvm.Definition))) - (platform.initialize platform common.bundle)) - ## _ (platform.compile platform (set@ #cli.module syntax.prelude configuration) state) - _ (: (IO (Error Any)) - (platform.compile platform configuration state)) - ## _ (cache/io.clean target ...) - ] - (wrap (log! "Compilation complete!"))))) - - (#cli.Interpretation configuration) - ## TODO: Fix the interpreter... - (undefined) - ## (<| (or-crash! "Interpretation failed:") - ## (interpreter.run (error.with io.monad) console platform configuration common.bundle)) - ))) + ## (/.compiler ..js commonJVM.bundle service) + (/.compiler macroA.jvm ..js extensionJS.bundle service)) |