diff options
author | Eduardo Julian | 2019-03-03 02:38:11 -0400 |
---|---|---|
committer | Eduardo Julian | 2019-03-03 02:38:11 -0400 |
commit | 539ad81bbb9034e41e6ca8f5445a9dd239c60be1 (patch) | |
tree | 0bf0a4a2189254a49212a7b5dd6dd6531d8071e7 | |
parent | 56219b002c43690e74e3e0c88fed32143dcc7e28 (diff) |
Macros are used for analysis and statements, so they shouldn't belong to analysis.
-rw-r--r-- | new-luxc/source/program.lux | 7 | ||||
-rw-r--r-- | stdlib/source/lux/tool/compiler/default/evaluation.lux | 4 | ||||
-rw-r--r-- | stdlib/source/lux/tool/compiler/default/init.lux | 4 | ||||
-rw-r--r-- | stdlib/source/lux/tool/compiler/default/platform.lux | 3 | ||||
-rw-r--r-- | stdlib/source/lux/tool/compiler/phase/analysis.lux | 10 | ||||
-rw-r--r-- | stdlib/source/lux/tool/compiler/phase/macro.lux (renamed from stdlib/source/lux/tool/compiler/phase/analysis/macro.lux) | 28 | ||||
-rw-r--r-- | stdlib/source/lux/tool/compiler/phase/statement/total.lux | 4 | ||||
-rw-r--r-- | stdlib/source/lux/tool/compiler/program.lux | 3 |
8 files changed, 31 insertions, 32 deletions
diff --git a/new-luxc/source/program.lux b/new-luxc/source/program.lux index c4fe26e0b..d576e89ae 100644 --- a/new-luxc/source/program.lux +++ b/new-luxc/source/program.lux @@ -13,8 +13,7 @@ ["." cli] ["/" program] [phase - [analysis - [".A" macro]] + ["." macro] ["." translation [".T" js [".JS" runtime] @@ -56,5 +55,5 @@ #platform.runtime runtimeJS.translate}))) (program: [{service cli.service}] - ## (/.compiler ..js commonJVM.bundle service) - (/.compiler macroA.jvm ..js extensionJS.bundle service)) + ## (/.compiler macro.jvm ..jvm commonJVM.bundle service) + (/.compiler macro.jvm ..js extensionJS.bundle service)) diff --git a/stdlib/source/lux/tool/compiler/default/evaluation.lux b/stdlib/source/lux/tool/compiler/default/evaluation.lux index 98da861d7..3310a1fd1 100644 --- a/stdlib/source/lux/tool/compiler/default/evaluation.lux +++ b/stdlib/source/lux/tool/compiler/default/evaluation.lux @@ -8,9 +8,9 @@ format]]] [/// ["." phase + [macro (#+ Expander)] ["." analysis - ["." type] - [macro (#+ Expander)]] + ["." type]] ["." synthesis [".S" expression]] ["." translation] diff --git a/stdlib/source/lux/tool/compiler/default/init.lux b/stdlib/source/lux/tool/compiler/default/init.lux index 465112327..41ecc851a 100644 --- a/stdlib/source/lux/tool/compiler/default/init.lux +++ b/stdlib/source/lux/tool/compiler/default/init.lux @@ -20,9 +20,9 @@ ["." analysis] ["." host] ["." phase + [macro (#+ Expander)] [".P" analysis - ["." module] - [macro (#+ Expander)]] + ["." module]] ["." synthesis [".S" expression]] ["." translation] diff --git a/stdlib/source/lux/tool/compiler/default/platform.lux b/stdlib/source/lux/tool/compiler/default/platform.lux index d751d2321..959478f28 100644 --- a/stdlib/source/lux/tool/compiler/default/platform.lux +++ b/stdlib/source/lux/tool/compiler/default/platform.lux @@ -12,8 +12,7 @@ ["." syntax] ["/." // ["." phase - [analysis - [macro (#+ Expander)]] + [macro (#+ Expander)] ["." translation] ["." statement]] ["." cli (#+ Configuration)] diff --git a/stdlib/source/lux/tool/compiler/phase/analysis.lux b/stdlib/source/lux/tool/compiler/phase/analysis.lux index e9fd18a9d..917ea1632 100644 --- a/stdlib/source/lux/tool/compiler/phase/analysis.lux +++ b/stdlib/source/lux/tool/compiler/phase/analysis.lux @@ -15,9 +15,9 @@ ["/." reference] ["/." case] ["/." function] - ["/." macro (#+ Expander)] ["." // - ["." extension] + ["//." macro (#+ Expander)] + ["//." extension] [// ["." reference] ["/" analysis (#+ Analysis Operation Phase)]]]]) @@ -90,7 +90,7 @@ (/case.case compile input branches) (^ (#.Form (list& [_ (#.Text extension-name)] extension-args))) - (extension.apply compile [extension-name extension-args]) + (//extension.apply compile [extension-name extension-args]) (^ (#.Form (list [_ (#.Tuple (list [_ (#.Identifier ["" function-name])] [_ (#.Identifier ["" arg-name])]))] @@ -104,11 +104,11 @@ (case functionA (#/.Reference (#reference.Constant def-name)) (do @ - [?macro (extension.lift (macro.find-macro def-name))] + [?macro (//extension.lift (macro.find-macro def-name))] (case ?macro (#.Some macro) (do @ - [expansion (extension.lift (/macro.expand-one expander def-name macro argsC+))] + [expansion (//extension.lift (//macro.expand-one expander def-name macro argsC+))] (compile expansion)) _ diff --git a/stdlib/source/lux/tool/compiler/phase/analysis/macro.lux b/stdlib/source/lux/tool/compiler/phase/macro.lux index aae26ada7..0aca19898 100644 --- a/stdlib/source/lux/tool/compiler/phase/analysis/macro.lux +++ b/stdlib/source/lux/tool/compiler/phase/macro.lux @@ -2,7 +2,7 @@ [lux #* [control [monad (#+ do)] - ["ex" exception (#+ exception:)]] + ["." exception (#+ exception:)]] [data ["." error (#+ Error)] ["." text @@ -12,20 +12,22 @@ ["." list ("#/." functor)]]] ["." macro] ["." host (#+ import:)]] - ["." ///]) + ["." //]) (exception: #export (expansion-failed {macro Name} {inputs (List Code)} {error Text}) - (ex.report ["Macro" (%name macro)] - ["Inputs" (|> inputs - (list/map (|>> %code (format text.new-line text.tab))) - (text.join-with ""))] - ["Error" error])) + (exception.report + ["Macro" (%name macro)] + ["Inputs" (|> inputs + (list/map (|>> %code (format text.new-line text.tab))) + (text.join-with ""))] + ["Error" error])) (exception: #export (must-have-single-expansion {macro Name} {inputs (List Code)}) - (ex.report ["Macro" (%name macro)] - ["Inputs" (|> inputs - (list/map (|>> %code (format text.new-line text.tab))) - (text.join-with ""))])) + (exception.report + ["Macro" (%name macro)] + ["Inputs" (|> inputs + (list/map (|>> %code (format text.new-line text.tab))) + (text.join-with ""))])) (import: #long java/lang/reflect/Method (invoke [java/lang/Object (Array java/lang/Object)] #try java/lang/Object)) @@ -74,7 +76,7 @@ (#error.Success output) (#error.Failure error) - ((///.throw expansion-failed [name inputs error]) state))))) + ((//.throw expansion-failed [name inputs error]) state))))) (def: #export (expand-one expander name macro inputs) (-> Expander Name Macro (List Code) (Meta Code)) @@ -85,4 +87,4 @@ (wrap single) _ - (///.throw must-have-single-expansion [name inputs])))) + (//.throw must-have-single-expansion [name inputs])))) diff --git a/stdlib/source/lux/tool/compiler/phase/statement/total.lux b/stdlib/source/lux/tool/compiler/phase/statement/total.lux index e1ba173ad..166425ffa 100644 --- a/stdlib/source/lux/tool/compiler/phase/statement/total.lux +++ b/stdlib/source/lux/tool/compiler/phase/statement/total.lux @@ -9,9 +9,9 @@ ["." macro]] ["." // (#+ Phase) ["/." // + ["///." macro (#+ Expander)] [".P" analysis - ["." type] - ["///." macro (#+ Expander)]] + ["." type]] ["." extension] [// ["." analysis]]]]) diff --git a/stdlib/source/lux/tool/compiler/program.lux b/stdlib/source/lux/tool/compiler/program.lux index 4194e0e8d..167f64221 100644 --- a/stdlib/source/lux/tool/compiler/program.lux +++ b/stdlib/source/lux/tool/compiler/program.lux @@ -16,8 +16,7 @@ [tool [compiler [phase - [analysis - [macro (#+ Expander)]] + [macro (#+ Expander)] ["." translation] ["." statement]] [default |