aboutsummaryrefslogtreecommitdiff
path: root/stdlib/source/library
diff options
context:
space:
mode:
Diffstat (limited to 'stdlib/source/library')
-rw-r--r--stdlib/source/library/lux/math.lux10
-rw-r--r--stdlib/source/library/lux/meta/compiler/default/init.lux6
-rw-r--r--stdlib/source/library/lux/meta/compiler/default/platform.lux56
-rw-r--r--stdlib/source/library/lux/meta/compiler/language/lux/analysis.lux22
-rw-r--r--stdlib/source/library/lux/meta/compiler/language/lux/analysis/evaluation.lux11
-rw-r--r--stdlib/source/library/lux/meta/compiler/language/lux/analysis/module.lux198
-rw-r--r--stdlib/source/library/lux/meta/compiler/language/lux/analysis/scope.lux79
-rw-r--r--stdlib/source/library/lux/meta/compiler/language/lux/analysis/type.lux23
-rw-r--r--stdlib/source/library/lux/meta/compiler/language/lux/declaration.lux26
-rw-r--r--stdlib/source/library/lux/meta/compiler/language/lux/generation.lux23
-rw-r--r--stdlib/source/library/lux/meta/compiler/language/lux/phase/analysis.lux30
-rw-r--r--stdlib/source/library/lux/meta/compiler/language/lux/phase/analysis/complex.lux27
-rw-r--r--stdlib/source/library/lux/meta/compiler/language/lux/phase/analysis/function.lux3
-rw-r--r--stdlib/source/library/lux/meta/compiler/language/lux/phase/analysis/reference.lux11
-rw-r--r--stdlib/source/library/lux/meta/compiler/language/lux/phase/analysis/when.lux5
-rw-r--r--stdlib/source/library/lux/meta/compiler/language/lux/phase/declaration.lux41
-rw-r--r--stdlib/source/library/lux/meta/compiler/language/lux/phase/extension.lux136
-rw-r--r--stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/analysis/jvm.lux64
-rw-r--r--stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/analysis/lux.lux86
-rw-r--r--stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/bundle.lux19
-rw-r--r--stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/declaration/jvm.lux8
-rw-r--r--stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/declaration/lux.lux44
-rw-r--r--stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/generation/jvm/common.lux8
-rw-r--r--stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/generation/jvm/host.lux82
-rw-r--r--stdlib/source/library/lux/meta/compiler/language/lux/phase/generation/extension.lux19
-rw-r--r--stdlib/source/library/lux/meta/compiler/language/lux/phase/generation/jvm.lux4
-rw-r--r--stdlib/source/library/lux/meta/compiler/language/lux/phase/synthesis.lux4
-rw-r--r--stdlib/source/library/lux/meta/compiler/language/lux/synthesis.lux13
-rw-r--r--stdlib/source/library/lux/meta/compiler/phase.lux39
-rw-r--r--stdlib/source/library/lux/meta/extension.lux14
30 files changed, 498 insertions, 613 deletions
diff --git a/stdlib/source/library/lux/math.lux b/stdlib/source/library/lux/math.lux
index f5b4ec12a..063593890 100644
--- a/stdlib/source/library/lux/math.lux
+++ b/stdlib/source/library/lux/math.lux
@@ -70,7 +70,7 @@
[(with_expansions [<scenarios> (template.spliced <scenarios>')]
(these (def .public <name>
.Analysis
- (analysis (_ self phase archive [operands (<>.some <code>.any)])
+ (analysis (_ phase archive [operands (<>.some <code>.any)])
(<| type.with_var
(function (_ [$it :it:]))
(do [! phase.monad]
@@ -137,8 +137,8 @@
[(with_expansions [<scenarios> (template.spliced <scenarios>')]
(these (def .public <name>
.Analysis
- (analysis (_ self phase archive [left <code>.any
- right <code>.any])
+ (analysis (_ phase archive [left <code>.any
+ right <code>.any])
(<| type.with_var
(function (_ [$it :it:]))
(do [! phase.monad]
@@ -189,8 +189,8 @@
[(with_expansions [<scenarios> (template.spliced <scenarios>')]
(these (def .public <name>
.Analysis
- (analysis (_ self phase archive [left <code>.any
- right <code>.any])
+ (analysis (_ phase archive [left <code>.any
+ right <code>.any])
(<| type.with_var
(function (_ [$it :it:]))
(do [! phase.monad]
diff --git a/stdlib/source/library/lux/meta/compiler/default/init.lux b/stdlib/source/library/lux/meta/compiler/default/init.lux
index 3ec4e3632..6f9051947 100644
--- a/stdlib/source/library/lux/meta/compiler/default/init.lux
+++ b/stdlib/source/library/lux/meta/compiler/default/init.lux
@@ -60,7 +60,7 @@
extension.Extender Expander
(///generation.Host expression declaration)
(-> extension.Extender Lux (///generation.Phase anchor expression declaration))
- (///declaration.State+ anchor expression declaration)))
+ (///declaration.State anchor expression declaration)))
(let [lux (///analysis.state (///analysis.info version.latest target configuration))]
[///declaration.#analysis [///declaration.#state lux
///declaration.#phase (analysisP.phase extender expander)]
@@ -187,7 +187,6 @@
(moduleA.set_compiled module))
analysis_module (<| (is (Operation .Module))
///declaration.lifted_analysis
- extension.lifted
meta.current_module)
final_buffer (///declaration.lifted_generation
///generation.buffer)
@@ -288,7 +287,7 @@
///phase.Wrapper (Extender <parameters>) Expander descriptor.Module (-> declaration Binary)
descriptor.Module (Maybe Text)
(Extensions <parameters>)
- (Instancer (///declaration.State+ <parameters>) .Module)))
+ (Instancer (///declaration.State <parameters>) .Module)))
(let [execute! (declarationP.phase wrapper extender expander)]
(function (_ key parameters input)
(let [dependencies (default_dependencies prelude input)]
@@ -344,7 +343,6 @@
(do [! ///phase.monad]
[analysis_module (<| (is (Operation .Module))
///declaration.lifted_analysis
- extension.lifted
meta.current_module)
_ (///declaration.lifted_generation
(///generation.set_buffer temporary_buffer))
diff --git a/stdlib/source/library/lux/meta/compiler/default/platform.lux b/stdlib/source/library/lux/meta/compiler/default/platform.lux
index 09d58919e..a9a8aaee0 100644
--- a/stdlib/source/library/lux/meta/compiler/default/platform.lux
+++ b/stdlib/source/library/lux/meta/compiler/default/platform.lux
@@ -93,7 +93,7 @@
(try.with async.monad)))
(with_expansions [<Platform> (these (Platform <type_vars>))
- <State+> (these (///declaration.State+ <type_vars>))]
+ <State> (these (///declaration.State <type_vars>))]
(def (format //)
(All (_ a)
@@ -190,10 +190,10 @@
(def (initialize_state analysis_state state)
(All (_ <type_vars>)
- (-> .Lux <State+>
- (Try <State+>)))
+ (-> .Lux <State>
+ (Try <State>)))
(|> (sharing [<type_vars>]
- (is <State+>
+ (is <State>
state)
(is (///declaration.Operation <type_vars> Any)
(do [! ///phase.monad]
@@ -213,7 +213,7 @@
(Program expression declaration)
extension.Extender
Import (List _io.Context) Configuration
- (Async (Try [<State+> Archive ///phase.Wrapper]))))
+ (Async (Try [<State> Archive ///phase.Wrapper]))))
(do [! ..monad]
[.let [phase_wrapper (the #phase_wrapper platform)
state (//init.state (the context.#host context)
@@ -228,7 +228,7 @@
[archive analysis_state bundles] (ioW.thaw (list) compilation_configuration (the #host platform) (the #file_system platform) context import compilation_sources)
.let [with_missing_extensions
(is (All (_ <type_vars>)
- (-> <State+> (Async (Try <State+>))))
+ (-> <State> (Async (Try <State>))))
(function (_ state)
(|> state
(initialize_state analysis_state)
@@ -251,7 +251,7 @@
(def (module_compilation_log module)
(All (_ <type_vars>)
- (-> descriptor.Module <State+> Text))
+ (-> descriptor.Module <State> Text))
(|>> (the [///declaration.#generation
///declaration.#state
///generation.#log])
@@ -261,7 +261,7 @@
(def with_reset_log
(All (_ <type_vars>)
- (-> <State+> <State+>))
+ (-> <State> <State>))
(has [///declaration.#generation
///declaration.#state
///generation.#log]
@@ -405,12 +405,12 @@
(type (Compiler state)
(-> (List ///.Custom) descriptor.Module (Importer state) module.ID (Context state) descriptor.Module (Return state)))
- (with_expansions [Lux_Context (..Context <State+>)
- Lux_Return (..Return <State+>)
- Lux_Signal (..Signal <State+>)
- Lux_Pending (..Pending <State+>)
- Lux_Importer (..Importer <State+>)
- Lux_Compiler (..Compiler <State+>)]
+ (with_expansions [Lux_Context (..Context <State>)
+ Lux_Return (..Return <State>)
+ Lux_Signal (..Signal <State>)
+ Lux_Pending (..Pending <State>)
+ Lux_Importer (..Importer <State>)
+ Lux_Compiler (..Compiler <State>)]
(def (parallel initial)
(All (_ <type_vars>)
(-> Lux_Context
@@ -505,7 +505,7 @@
... TODO: Find a better way, as this only works for the Lux compiler.
(def (updated_state archive extended_states state)
(All (_ <type_vars>)
- (-> Archive (List <State+>) <State+> (Try <State+>)))
+ (-> Archive (List <State>) <State> (Try <State>)))
(do [! try.monad]
[modules (monad.each ! (function (_ module)
(do !
@@ -519,7 +519,7 @@
(list#each product.left)
(set.of_list text.hash))
with_modules (is (All (_ <type_vars>)
- (-> <State+> <State+>))
+ (-> <State> <State>))
(revised [///declaration.#analysis
///declaration.#state]
(is (All (_ a) (-> a a))
@@ -537,7 +537,7 @@
(def (set_current_module module state)
(All (_ <type_vars>)
- (-> descriptor.Module <State+> <State+>))
+ (-> descriptor.Module <State> <State>))
(|> (///declaration.set_current_module module)
(///phase.result' state)
try.trusted
@@ -588,7 +588,7 @@
(def (after_lux_imports customs import! module duplicates new_dependencies [archive state])
(All (_ <type_vars>)
(-> (List ///.Custom) Lux_Importer descriptor.Module (Set descriptor.Module) (List descriptor.Module) Lux_Context
- (..Return [<State+> (List Text)])))
+ (..Return [<State> (List Text)])))
(do ..monad
[[archive state/* errors] (after_imports customs import! module duplicates new_dependencies archive)]
(when errors
@@ -607,9 +607,9 @@
(def (next_compilation module [archive state] compilation)
(All (_ <type_vars>)
- (-> descriptor.Module Lux_Context (///.Compilation <State+> .Module)
- (Try [<State+> (Either (///.Compilation <State+> .Module)
- (archive.Entry Any))])))
+ (-> descriptor.Module Lux_Context (///.Compilation <State> .Module)
+ (Try [<State> (Either (///.Compilation <State> .Module)
+ (archive.Entry Any))])))
((the ///.#process compilation)
... TODO: The "///declaration.set_current_module" below shouldn't be necessary. Remove it ASAP.
... TODO: The context shouldn't need to be re-set either.
@@ -625,7 +625,7 @@
(-> (Program expression declaration) (-> Archive Symbol (///generation.Operation <type_vars> expression))
///phase.Wrapper (Extender <type_vars>) Expander <Platform> Text (Maybe Module)
(//init.Extensions <type_vars>)
- (///.Compiler <State+> .Module)))
+ (///.Compiler <State> .Module)))
(let [instancer (//init.compiler program global phase_wrapper extender expander syntax.prelude (the #write platform) program_module program_definition
all_extensions)]
(instancer $.key (list))))
@@ -634,7 +634,7 @@
compiler custom_key custom_format custom_compilation)
(All (_ <type_vars>
state document)
- (-> Import context.Context <Platform> (List _io.Context) Configuration (///.Compiler <State+> .Module)
+ (-> Import context.Context <Platform> (List _io.Context) Configuration (///.Compiler <State> .Module)
(Key document) (Format document) (///.Compilation state document)
(-> (List ///.Custom) descriptor.Module Lux_Importer module.ID (..Context state) descriptor.Module (..Return state))))
(function (_ customs importer import! @module [archive state] module)
@@ -679,8 +679,8 @@
(-> context.Context <Platform>
(Set descriptor.Module)
module.ID Text (archive.Entry Any)
- Archive <State+>
- (Return <State+>)))
+ Archive <State>
+ (Return <State>)))
(do ..monad
[_ (let [report (..module_compilation_log module state)]
(with_expansions [<else> (in (debug.log! report))]
@@ -701,8 +701,8 @@
(def (lux_compiler import context platform compilation_sources configuration compiler compilation)
(All (_ <type_vars>)
- (-> Import context.Context <Platform> (List _io.Context) Configuration (///.Compiler <State+> .Module)
- (///.Compilation <State+> .Module)
+ (-> Import context.Context <Platform> (List _io.Context) Configuration (///.Compiler <State> .Module)
+ (///.Compilation <State> .Module)
Lux_Compiler))
(function (_ customs importer import! @module [archive state] module)
(loop (again [[archive state] [archive (..set_current_module module state)]
@@ -747,7 +747,7 @@
(def (serial_compiler import context platform compilation_sources configuration compiler)
(All (_ <type_vars>)
- (-> Import context.Context <Platform> (List _io.Context) Configuration (///.Compiler <State+> .Module)
+ (-> Import context.Context <Platform> (List _io.Context) Configuration (///.Compiler <State> .Module)
Lux_Compiler))
(function (_ all_customs importer import! @module [archive lux_state] module)
(do [! ..monad]
diff --git a/stdlib/source/library/lux/meta/compiler/language/lux/analysis.lux b/stdlib/source/library/lux/meta/compiler/language/lux/analysis.lux
index c3a746cb1..406af1954 100644
--- a/stdlib/source/library/lux/meta/compiler/language/lux/analysis.lux
+++ b/stdlib/source/library/lux/meta/compiler/language/lux/analysis.lux
@@ -246,13 +246,19 @@
(%.format (%.symbol name) " ")
(text.enclosed ["(" ")"]))))
+(type .public State
+ Lux)
+
+(type .public Operation
+ (phase.Operation State))
+
+(type .public Phase
+ (phase.Phase State Code Analysis))
+
(with_template [<special> <general>]
[(type .public <special>
- (<general> .Lux Code Analysis))]
+ (<general> State Code Analysis))]
- [State+ extension.State]
- [Operation extension.Operation]
- [Phase extension.Phase]
[Handler extension.Handler]
[Bundle extension.Bundle]
[Extender extension.Extender]
@@ -272,9 +278,9 @@
(def .public (with_current_module name)
(All (_ a) (-> Text (Operation a) (Operation a)))
- (extension.localized (the .#current_module)
- (has .#current_module)
- (function.constant {.#Some name})))
+ (phase.localized (the .#current_module)
+ (has .#current_module)
+ (function.constant {.#Some name})))
(def .public (with_location location action)
(All (_ a) (-> Location (Operation a) (Operation a)))
@@ -339,7 +345,7 @@
(with_template [<name> <type> <field> <value>]
[(def .public (<name> value)
(-> <type> (Operation Any))
- (extension.update (has <field> <value>)))]
+ (phase.update (has <field> <value>)))]
[set_source_code Source .#source value]
[set_current_module Text .#current_module {.#Some value}]
diff --git a/stdlib/source/library/lux/meta/compiler/language/lux/analysis/evaluation.lux b/stdlib/source/library/lux/meta/compiler/language/lux/analysis/evaluation.lux
index 03543aa35..2e80fdb66 100644
--- a/stdlib/source/library/lux/meta/compiler/language/lux/analysis/evaluation.lux
+++ b/stdlib/source/library/lux/meta/compiler/language/lux/analysis/evaluation.lux
@@ -24,7 +24,6 @@
[//
[phase
["[0]P" analysis]
- ["[0]" extension]
[//
["[0]" synthesis]
["[0]" generation]
@@ -46,9 +45,9 @@
[generation_state generation])
(All (_ anchor expression artifact)
(-> //.Phase
- [synthesis.State+
+ [synthesis.State
(-> Lux synthesis.Phase)]
- [(generation.State+ anchor expression artifact)
+ [(generation.State anchor expression artifact)
(-> Lux (generation.Phase anchor expression artifact))]
Eval))
(function (eval archive type exprC)
@@ -56,10 +55,8 @@
[exprA (<| (//type.expecting type)
//scope.reset
(analysis archive exprC))
- module (extension.lifted
- meta.current_module_name)
- lux (extension.lifted
- meta.compiler_state)]
+ module meta.current_module_name
+ lux meta.compiler_state]
(<| phase.lifted
(do try.monad
[exprS (|> exprA
diff --git a/stdlib/source/library/lux/meta/compiler/language/lux/analysis/module.lux b/stdlib/source/library/lux/meta/compiler/language/lux/analysis/module.lux
index 8c4dc9032..6fa95812d 100644
--- a/stdlib/source/library/lux/meta/compiler/language/lux/analysis/module.lux
+++ b/stdlib/source/library/lux/meta/compiler/language/lux/analysis/module.lux
@@ -16,8 +16,6 @@
["[0]" property]]]]]]
["/" // (.only Operation)
["//[1]" //
- [phase
- ["[1][0]" extension]]
[///
["[1]" phase]]]])
@@ -59,88 +57,82 @@
(def .public (import module)
(-> Text (Operation Any))
- (///extension.lifted
- (do ///.monad
- [self_name meta.current_module_name]
- (function (_ state)
- {try.#Success [(revised .#modules
- (property.revised self_name (revised .#imports (function (_ current)
- (if (list.any? (text#= module)
- current)
- current
- {.#Item module current}))))
- state)
- []]}))))
+ (do ///.monad
+ [self_name meta.current_module_name]
+ (function (_ state)
+ {try.#Success [(revised .#modules
+ (property.revised self_name (revised .#imports (function (_ current)
+ (if (list.any? (text#= module)
+ current)
+ current
+ {.#Item module current}))))
+ state)
+ []]})))
(def .public (alias alias module)
(-> Text Text (Operation Any))
- (///extension.lifted
- (do ///.monad
- [self_name meta.current_module_name]
- (function (_ state)
- {try.#Success [(revised .#modules
- (property.revised self_name (revised .#module_aliases (is (-> (List [Text Text]) (List [Text Text]))
- (|>> {.#Item [alias module]}))))
- state)
- []]}))))
+ (do ///.monad
+ [self_name meta.current_module_name]
+ (function (_ state)
+ {try.#Success [(revised .#modules
+ (property.revised self_name (revised .#module_aliases (is (-> (List [Text Text]) (List [Text Text]))
+ (|>> {.#Item [alias module]}))))
+ state)
+ []]})))
(def .public (exists? module)
(-> Text (Operation Bit))
- (///extension.lifted
- (function (_ state)
- (|> state
- (the .#modules)
- (property.value module)
- (pipe.when
- {.#Some _}
- true
-
- {.#None}
- false)
- [state]
- {try.#Success}))))
+ (function (_ state)
+ (|> state
+ (the .#modules)
+ (property.value module)
+ (pipe.when
+ {.#Some _}
+ true
+
+ {.#None}
+ false)
+ [state]
+ {try.#Success})))
(def .public (define name definition)
(-> Text Global (Operation Any))
- (///extension.lifted
- (do ///.monad
- [self_name meta.current_module_name
- self meta.current_module]
- (function (_ state)
- (when (property.value name (the .#definitions self))
- {.#None}
- {try.#Success [(revised .#modules
- (property.has self_name
- (revised .#definitions
- (is (-> (List [Text Global]) (List [Text Global]))
- (|>> {.#Item [name definition]}))
- self))
- state)
- []]}
-
- {.#Some already_existing}
- ((///extension.up (/.except ..cannot_define_more_than_once [[self_name name] already_existing]))
- state))))))
+ (do ///.monad
+ [self_name meta.current_module_name
+ self meta.current_module]
+ (function (_ state)
+ (when (property.value name (the .#definitions self))
+ {.#None}
+ {try.#Success [(revised .#modules
+ (property.has self_name
+ (revised .#definitions
+ (is (-> (List [Text Global]) (List [Text Global]))
+ (|>> {.#Item [name definition]}))
+ self))
+ state)
+ []]}
+
+ {.#Some already_existing}
+ ((/.except ..cannot_define_more_than_once [[self_name name] already_existing])
+ state)))))
(def .public (override_definition [module short] definition)
(-> Symbol Global (Operation Any))
- (///extension.lifted
- (function (_ state)
- {try.#Success [(revised .#modules
- (property.revised module
- (revised .#definitions
- (property.has short definition)))
- state)
- []]})))
+ (function (_ state)
+ {try.#Success [(revised .#modules
+ (property.revised module
+ (revised .#definitions
+ (property.has short definition)))
+ state)
+ []]}))
(def .public (create hash name)
(-> Nat Text (Operation Any))
- (///extension.lifted
- (function (_ state)
- {try.#Success [(revised .#modules
- (property.has name (..empty hash))
- state)
- []]})))
+ (function (_ state)
+ {try.#Success [(revised .#modules
+ (property.has name (..empty hash))
+ state)
+ []]}))
(def .public (with hash name action)
(All (_ a) (-> Nat Text (Operation a) (Operation [Module a])))
@@ -148,51 +140,49 @@
[_ (..create hash name)
output (/.with_current_module name
action)
- module (///extension.lifted (meta.module name))]
+ module (meta.module name)]
(in [module output])))
(with_template [<setter> <asker> <tag>]
[(def .public (<setter> module_name)
(-> Text (Operation Any))
- (///extension.lifted
- (function (_ state)
- (when (|> state (the .#modules) (property.value module_name))
- {.#Some module}
- (let [active? (when (the .#module_state module)
- {.#Active}
- true
-
- _
- false)]
- (if active?
- {try.#Success [(revised .#modules
- (property.has module_name (has .#module_state {<tag>} module))
- state)
- []]}
- ((///extension.up (/.except ..can_only_change_state_of_active_module [module_name {<tag>}]))
- state)))
+ (function (_ state)
+ (when (|> state (the .#modules) (property.value module_name))
+ {.#Some module}
+ (let [active? (when (the .#module_state module)
+ {.#Active}
+ true
+
+ _
+ false)]
+ (if active?
+ {try.#Success [(revised .#modules
+ (property.has module_name (has .#module_state {<tag>} module))
+ state)
+ []]}
+ ((/.except ..can_only_change_state_of_active_module [module_name {<tag>}])
+ state)))
- {.#None}
- ((///extension.up (/.except ..unknown_module module_name))
- state)))))
+ {.#None}
+ ((/.except ..unknown_module module_name)
+ state))))
(def .public (<asker> module_name)
(-> Text (Operation Bit))
- (///extension.lifted
- (function (_ state)
- (when (|> state (the .#modules) (property.value module_name))
- {.#Some module}
- {try.#Success [state
- (when (the .#module_state module)
- {<tag>}
- true
-
- _
- false)]}
+ (function (_ state)
+ (when (|> state (the .#modules) (property.value module_name))
+ {.#Some module}
+ {try.#Success [state
+ (when (the .#module_state module)
+ {<tag>}
+ true
+
+ _
+ false)]}
- {.#None}
- ((///extension.up (/.except ..unknown_module module_name))
- state)))))]
+ {.#None}
+ ((/.except ..unknown_module module_name)
+ state))))]
[set_active active? .#Active]
[set_compiled compiled? .#Compiled]
diff --git a/stdlib/source/library/lux/meta/compiler/language/lux/analysis/scope.lux b/stdlib/source/library/lux/meta/compiler/language/lux/analysis/scope.lux
index c262ad1b8..bdfa5b776 100644
--- a/stdlib/source/library/lux/meta/compiler/language/lux/analysis/scope.lux
+++ b/stdlib/source/library/lux/meta/compiler/language/lux/analysis/scope.lux
@@ -14,13 +14,10 @@
["[0]" list (.use "[1]#[0]" functor mix monoid)
["[0]" property]]]]]]
["/" // (.only Environment Operation Phase)
- [//
- [phase
- ["[0]" extension]]
- [///
- ["[0]" phase]
- [reference
- ["[0]" variable (.only Register Variable)]]]]])
+ [////
+ ["[0]" phase]
+ [reference
+ ["[0]" variable (.only Register Variable)]]]])
(type Local
(Bindings Text [Type Register]))
@@ -77,33 +74,32 @@
(def .public (variable name)
(-> Text (Operation (Maybe [Type Variable])))
- (extension.lifted
- (function (_ state)
- (let [[inner outer] (|> state
- (the .#scopes)
- (list.split_when (|>> (reference? name))))]
- (when outer
- {.#End}
- {.#Right [state {.#None}]}
-
- {.#Item top_outer _}
- (let [[ref_type init_ref] (maybe.else (undefined)
- (..reference name top_outer))
- [ref inner'] (list#mix (is (-> Scope [Variable (List Scope)] [Variable (List Scope)])
- (function (_ scope ref+inner)
- [{variable.#Foreign (the [.#captured .#counter] scope)}
- {.#Item (revised .#captured
- (is (-> Foreign Foreign)
- (|>> (revised .#counter ++)
- (revised .#mappings (property.has name [ref_type (product.left ref+inner)]))))
- scope)
- (product.right ref+inner)}]))
- [init_ref {.#End}]
- (list.reversed inner))
- scopes (list#composite inner' outer)]
- {.#Right [(has .#scopes scopes state)
- {.#Some [ref_type ref]}]})
- )))))
+ (function (_ state)
+ (let [[inner outer] (|> state
+ (the .#scopes)
+ (list.split_when (|>> (reference? name))))]
+ (when outer
+ {.#End}
+ {.#Right [state {.#None}]}
+
+ {.#Item top_outer _}
+ (let [[ref_type init_ref] (maybe.else (undefined)
+ (..reference name top_outer))
+ [ref inner'] (list#mix (is (-> Scope [Variable (List Scope)] [Variable (List Scope)])
+ (function (_ scope ref+inner)
+ [{variable.#Foreign (the [.#captured .#counter] scope)}
+ {.#Item (revised .#captured
+ (is (-> Foreign Foreign)
+ (|>> (revised .#counter ++)
+ (revised .#mappings (property.has name [ref_type (product.left ref+inner)]))))
+ scope)
+ (product.right ref+inner)}]))
+ [init_ref {.#End}]
+ (list.reversed inner))
+ scopes (list#composite inner' outer)]
+ {.#Right [(has .#scopes scopes state)
+ {.#Some [ref_type ref]}]})
+ ))))
(exception.def .public no_scope)
(exception.def .public drained)
@@ -178,14 +174,13 @@
(def .public next
(Operation Register)
- (extension.lifted
- (function (_ state)
- (when (the .#scopes state)
- {.#Item top _}
- {try.#Success [state (the [.#locals .#counter] top)]}
-
- {.#End}
- (exception.except ..no_scope [])))))
+ (function (_ state)
+ (when (the .#scopes state)
+ {.#Item top _}
+ {try.#Success [state (the [.#locals .#counter] top)]}
+
+ {.#End}
+ (exception.except ..no_scope []))))
(def .public environment
(-> Scope (Environment Variable))
diff --git a/stdlib/source/library/lux/meta/compiler/language/lux/analysis/type.lux b/stdlib/source/library/lux/meta/compiler/language/lux/analysis/type.lux
index b983f83b4..ddb530480 100644
--- a/stdlib/source/library/lux/meta/compiler/language/lux/analysis/type.lux
+++ b/stdlib/source/library/lux/meta/compiler/language/lux/analysis/type.lux
@@ -20,11 +20,8 @@
[type
["[0]" check (.only Check)]]]]]
["/" // (.only Operation)
- [//
- [phase
- ["[0]" extension]]
- [///
- ["[0]" phase]]]])
+ [////
+ ["[0]" phase]]])
(def .public (check action)
(All (_ a) (-> (Check a) (Operation a)))
@@ -56,25 +53,25 @@
(def .public existential
(Operation Type)
(do phase.monad
- [module (extension.lifted meta.current_module_name)
- id (extension.lifted meta.seed)]
+ [module meta.current_module_name
+ id meta.seed]
(in (..existential' module id))))
(def .public (expecting expected)
(All (_ a) (-> Type (Operation a) (Operation a)))
- (extension.localized (the .#expected) (has .#expected)
- (function.constant {.#Some expected})))
+ (phase.localized (the .#expected) (has .#expected)
+ (function.constant {.#Some expected})))
(def .public fresh
(All (_ a) (-> (Operation a) (Operation a)))
- (extension.localized (the .#type_context) (has .#type_context)
- (function.constant check.fresh_context)))
+ (phase.localized (the .#type_context) (has .#type_context)
+ (function.constant check.fresh_context)))
(def .public (inference actualT)
(-> Type (Operation Any))
(do phase.monad
- [module (extension.lifted meta.current_module_name)
- expectedT (extension.lifted meta.expected_type)]
+ [module meta.current_module_name
+ expectedT meta.expected_type]
(..check (check.check expectedT actualT)
... (do [! check.monad]
... [pre check.context
diff --git a/stdlib/source/library/lux/meta/compiler/language/lux/declaration.lux b/stdlib/source/library/lux/meta/compiler/language/lux/declaration.lux
index 71cfff604..5e3a91a34 100644
--- a/stdlib/source/library/lux/meta/compiler/language/lux/declaration.lux
+++ b/stdlib/source/library/lux/meta/compiler/language/lux/declaration.lux
@@ -28,11 +28,11 @@
(type .public (State anchor expression declaration)
(Record
- [#analysis (Component analysis.State+
+ [#analysis (Component analysis.State
analysis.Phase)
- #synthesis (Component synthesis.State+
+ #synthesis (Component synthesis.State
(-> Lux synthesis.Phase))
- #generation (Component (generation.State+ anchor expression declaration)
+ #generation (Component (generation.State anchor expression declaration)
(-> Lux (generation.Phase anchor expression declaration)))]))
(type .public Import
@@ -55,13 +55,16 @@
[#imports (list#composite (the #imports left) (the #imports right))
#referrals (list#composite (the #referrals left) (the #referrals right))])
+(type .public (Operation anchor expression declaration)
+ (phase.Operation (State anchor expression declaration)))
+
+(type .public (Phase anchor expression declaration)
+ (phase.Phase (State anchor expression declaration) Code Requirements))
+
(with_template [<special> <general>]
[(type .public (<special> anchor expression declaration)
(<general> (..State anchor expression declaration) Code Requirements))]
- [State+ extension.State]
- [Operation extension.Operation]
- [Phase extension.Phase]
[Handler extension.Handler]
[Bundle extension.Bundle]
[Extender extension.Extender]
@@ -84,9 +87,8 @@
(All (_ anchor expression declaration output)
(-> (<operation> output)
(Operation anchor expression declaration output)))
- (|>> (phase.sub [(the [<component> ..#state])
- (has [<component> ..#state])])
- extension.lifted))]
+ (phase.sub [(the [<component> ..#state])
+ (has [<component> ..#state])]))]
[lifted_analysis ..#analysis analysis.Operation]
[lifted_synthesis ..#synthesis synthesis.Operation]
@@ -97,7 +99,5 @@
(All (_ anchor expression declaration)
(-> Module (Operation anchor expression declaration Any)))
(do phase.monad
- [_ (..lifted_analysis
- (analysis.set_current_module module))]
- (..lifted_generation
- (generation.enter_module module))))
+ [_ (..lifted_analysis (analysis.set_current_module module))]
+ (..lifted_generation (generation.enter_module module))))
diff --git a/stdlib/source/library/lux/meta/compiler/language/lux/generation.lux b/stdlib/source/library/lux/meta/compiler/language/lux/generation.lux
index e0c5e0fea..a79b9afcf 100644
--- a/stdlib/source/library/lux/meta/compiler/language/lux/generation.lux
+++ b/stdlib/source/library/lux/meta/compiler/language/lux/generation.lux
@@ -86,13 +86,16 @@
#log (Sequence Text)
#interim_artifacts (List artifact.ID)]))
+(type .public (Operation anchor expression declaration)
+ (phase.Operation (State anchor expression declaration)))
+
+(type .public (Phase anchor expression declaration)
+ (phase.Phase (State anchor expression declaration) Synthesis expression))
+
(with_template [<special> <general>]
[(type .public (<special> anchor expression declaration)
(<general> (State anchor expression declaration) Synthesis expression))]
- [State+ extension.State]
- [Operation extension.Operation]
- [Phase extension.Phase]
[Handler extension.Handler]
[Bundle extension.Bundle]
[Extender extension.Extender]
@@ -185,8 +188,8 @@
(All (_ anchor expression declaration)
(Operation anchor expression declaration Nat))
(do phase.monad
- [count (extension.read (the #counter))
- _ (extension.update (revised #counter ++))]
+ [count (phase.read (the #counter))
+ _ (phase.update (revised #counter ++))]
(in count)))
(def .public (symbol prefix)
@@ -197,12 +200,12 @@
(def .public (enter_module module)
(All (_ anchor expression declaration)
(-> descriptor.Module (Operation anchor expression declaration Any)))
- (extension.update (has #module module)))
+ (phase.update (has #module module)))
(def .public module
(All (_ anchor expression declaration)
(Operation anchor expression declaration descriptor.Module))
- (extension.read (the #module)))
+ (phase.read (the #module)))
(def .public (evaluate! label code)
(All (_ anchor expression declaration)
@@ -241,13 +244,13 @@
(All (_ anchor expression declaration)
(-> artifact.ID (Maybe Text) declaration (Operation anchor expression declaration Any)))
(do [! phase.monad]
- [?buffer (extension.read (the #buffer))]
+ [?buffer (phase.read (the #buffer))]
(when ?buffer
{.#Some buffer}
... TODO: Optimize by no longer checking for overwrites...
(if (sequence.any? (|>> product.left (n.= artifact_id)) buffer)
(phase.except ..cannot_overwrite_output [artifact_id])
- (extension.update (has #buffer {.#Some (sequence.suffix [artifact_id custom code] buffer)})))
+ (phase.update (has #buffer {.#Some (sequence.suffix [artifact_id custom code] buffer)})))
{.#None}
(phase.except ..no_buffer_for_saving_code [artifact_id]))))
@@ -388,7 +391,7 @@
(-> Archive (Operation anchor expression declaration a)
(Operation anchor expression declaration [(List unit.ID) a])))
(do phase.monad
- [module (extension.read (the #module))]
+ [module (phase.read (the #module))]
(function (_ state)
(do try.monad
[@module (archive.id module archive)
diff --git a/stdlib/source/library/lux/meta/compiler/language/lux/phase/analysis.lux b/stdlib/source/library/lux/meta/compiler/language/lux/phase/analysis.lux
index fb9a479db..3354d05fe 100644
--- a/stdlib/source/library/lux/meta/compiler/language/lux/phase/analysis.lux
+++ b/stdlib/source/library/lux/meta/compiler/language/lux/phase/analysis.lux
@@ -28,17 +28,15 @@
["[1][0]" reference]
["[1][0]" when]
["[1][0]" function]
- ["/[1]" //
- ["[1][0]" extension]
- ["/[1]" //
- ["/" analysis (.only Analysis Operation Phase Handler Extender)
- ["[1][0]" macro (.only Expander)]
- ["[1][0]" type]]
- [///
- ["//" phase]
- ["[0]" reference]
- [meta
- [archive (.only Archive)]]]]]])
+ ["//[1]" ///
+ ["/" analysis (.only Analysis Operation Phase Handler Extender)
+ ["[1][0]" macro (.only Expander)]
+ ["[1][0]" type]]
+ [///
+ ["//" phase]
+ ["[0]" reference]
+ [meta
+ [archive (.only Archive)]]]]])
(exception.def .public (invalid syntax)
(Exception Code)
@@ -119,17 +117,17 @@
Symbol (List Code)
(Operation (Maybe Analysis)))
(do [! //.monad]
- [value (//extension.lifted (global_analysis name))
+ [value (global_analysis name)
.let [[module short] name]]
(when value
{.#Some value}
(do !
[it (when value
{#Normal definition}
- ((extender definition) short phase archive parameters)
+ ((extender definition) phase archive parameters)
{#Special default}
- ((as Handler default) short phase archive parameters))]
+ ((as Handler default) phase archive parameters))]
(in {.#Some it}))
{.#None}
@@ -144,11 +142,11 @@
(def (macro_application extender expander analysis archive def_name argsC+)
(-> Extender Expander Phase Archive Symbol (List Code) (Operation Analysis))
(do [! //.monad]
- [?macro (//extension.lifted (meta.macro def_name))]
+ [?macro (meta.macro def_name)]
(when ?macro
{.#Some macro}
(do !
- [expansion (//extension.lifted (/macro.single_expansion expander def_name macro argsC+))]
+ [expansion (/macro.single_expansion expander def_name macro argsC+)]
(analysis archive expansion))
_
diff --git a/stdlib/source/library/lux/meta/compiler/language/lux/phase/analysis/complex.lux b/stdlib/source/library/lux/meta/compiler/language/lux/phase/analysis/complex.lux
index a7f8bd83b..eb01fd9e0 100644
--- a/stdlib/source/library/lux/meta/compiler/language/lux/phase/analysis/complex.lux
+++ b/stdlib/source/library/lux/meta/compiler/language/lux/phase/analysis/complex.lux
@@ -26,7 +26,6 @@
["[0]" //
["[1][0]" simple]
["/[1]" //
- ["[1][0]" extension]
[//
["/" analysis (.only Analysis Operation Phase)
["[1][0]" complex (.only Tag)]
@@ -117,7 +116,7 @@
(let [tag (/complex.tag right? lefts)]
(function (again valueC)
(do [! ///.monad]
- [expectedT (///extension.lifted meta.expected_type)
+ [expectedT meta.expected_type
expectedT' (/type.check (check.clean (list) expectedT))]
(/.with_exception ..cannot_analyse_sum [expectedT' lefts right? valueC]
(when expectedT
@@ -186,15 +185,15 @@
(def .public (variant analyse tag archive valueC)
(-> Phase Symbol Phase)
(do [! ///.monad]
- [tag (///extension.lifted (meta.normal tag))
- [lefts,right? variantT] (///extension.lifted (meta.tag tag))
+ [tag (meta.normal tag)
+ [lefts,right? variantT] (meta.tag tag)
[lefts right?] (when lefts,right?
{.#Some [lefts right? family]}
(in [lefts right?])
{.#None}
(in [0 false]))
- expectedT (///extension.lifted meta.expected_type)]
+ expectedT meta.expected_type]
(when expectedT
{.#Var _}
(do !
@@ -240,7 +239,7 @@
(def .public (product analyse archive membersC)
(-> Phase Archive (List Code) (Operation Analysis))
(do [! ///.monad]
- [expectedT (///extension.lifted meta.expected_type)]
+ [expectedT meta.expected_type]
(/.with_exception ..cannot_analyse_tuple [expectedT membersC]
(when expectedT
{.#Product _}
@@ -318,12 +317,12 @@
(if pattern_matching?
(///#in {.#None})
(do ///.monad
- [slotH (///extension.lifted (meta.normal ["" slotH]))]
+ [slotH (meta.normal ["" slotH])]
(again tail {.#Item [slotH valueH] output})))
(list.partial [_ {.#Symbol slotH}] valueH tail)
(do ///.monad
- [slotH (///extension.lifted (meta.normal slotH))]
+ [slotH (meta.normal slotH)]
(again tail {.#Item [slotH valueH] output}))
{.#End}
@@ -395,8 +394,7 @@
(def (order' head_k original_record)
(-> Symbol (List [Symbol Code]) (Operation (Maybe [Nat (List Code) Type])))
(do [! ///.monad]
- [record (<| ///extension.lifted
- meta.try
+ [record (<| meta.try
(monad.each ! (function (_ [slot value])
(do !
[slot (..slot slot)]
@@ -432,8 +430,7 @@
(if pattern_matching?
(///#in {.#None})
(do ///.monad
- [local_binding? (///extension.lifted
- (..local_binding? head_k'))]
+ [local_binding? (..local_binding? head_k')]
(if local_binding?
(in {.#None})
(order' head_k record))))
@@ -452,8 +449,8 @@
(list [_ {.#Symbol pseudo_slot}] singletonC)
(do [! ///.monad]
- [head_k (///extension.lifted (meta.normal pseudo_slot))
- slot (///extension.lifted (meta.try (meta.slot head_k)))]
+ [head_k (meta.normal pseudo_slot)
+ slot (meta.try (meta.slot head_k))]
(when slot
{try.#Success [lefts,right? recordT]}
(when lefts,right?
@@ -482,7 +479,7 @@
{.#Some [record_size membersC recordT]}
(do !
- [expectedT (///extension.lifted meta.expected_type)]
+ [expectedT meta.expected_type]
(when expectedT
{.#Var _}
(do !
diff --git a/stdlib/source/library/lux/meta/compiler/language/lux/phase/analysis/function.lux b/stdlib/source/library/lux/meta/compiler/language/lux/phase/analysis/function.lux
index a6d191510..2065c0773 100644
--- a/stdlib/source/library/lux/meta/compiler/language/lux/phase/analysis/function.lux
+++ b/stdlib/source/library/lux/meta/compiler/language/lux/phase/analysis/function.lux
@@ -20,7 +20,6 @@
["[0]" type (.only)
["[0]" check]]]]]
["[0]" ///
- ["[1][0]" extension]
[//
["/" analysis (.only Analysis Operation Phase)
["[1][0]" type]
@@ -53,7 +52,7 @@
(def .public (function analyse function_name arg_name archive body)
(-> Phase Text Text Phase)
(do [! ///.monad]
- [expectedT (///extension.lifted meta.expected_type)]
+ [expectedT meta.expected_type]
(loop (again [expectedT expectedT])
(/.with_exception ..cannot_analyse [expectedT function_name arg_name body]
(when expectedT
diff --git a/stdlib/source/library/lux/meta/compiler/language/lux/phase/analysis/reference.lux b/stdlib/source/library/lux/meta/compiler/language/lux/phase/analysis/reference.lux
index 730131ef1..d9c88a463 100644
--- a/stdlib/source/library/lux/meta/compiler/language/lux/phase/analysis/reference.lux
+++ b/stdlib/source/library/lux/meta/compiler/language/lux/phase/analysis/reference.lux
@@ -13,7 +13,6 @@
["^" pattern]]]]]
["[0]" //
["/[1]" //
- ["[1][0]" extension]
[//
["/" analysis (.only Analysis Operation)
["[1][0]" type]
@@ -44,7 +43,7 @@
(-> Text Symbol (Operation Analysis))
(with_expansions [<return> (in (|> def_name ///reference.constant {/.#Reference}))]
(do [! ///.monad]
- [constant (///extension.lifted (meta.definition def_name))]
+ [constant (meta.definition def_name)]
(when constant
{.#Alias real_def_name}
(definition quoted_module real_def_name)
@@ -52,13 +51,13 @@
{.#Definition [exported? actualT _]}
(do !
[_ (/type.inference actualT)
- (^.let def_name [::module ::name]) (///extension.lifted (meta.normal def_name))
- current (///extension.lifted meta.current_module_name)]
+ (^.let def_name [::module ::name]) (meta.normal def_name)
+ current meta.current_module_name]
(if (text#= current ::module)
<return>
(if exported?
(do !
- [imported! (///extension.lifted (meta.imported_by? ::module current))]
+ [imported! (meta.imported_by? ::module current)]
(if (or imported!
(text#= quoted_module ::module))
<return>
@@ -93,7 +92,7 @@
{.#None}
(do !
- [this_module (///extension.lifted meta.current_module_name)]
+ [this_module meta.current_module_name]
(definition quoted_module [this_module short]))))
_
diff --git a/stdlib/source/library/lux/meta/compiler/language/lux/phase/analysis/when.lux b/stdlib/source/library/lux/meta/compiler/language/lux/phase/analysis/when.lux
index 5a214df20..5f839c67a 100644
--- a/stdlib/source/library/lux/meta/compiler/language/lux/phase/analysis/when.lux
+++ b/stdlib/source/library/lux/meta/compiler/language/lux/phase/analysis/when.lux
@@ -26,7 +26,6 @@
["/[1]" //
["[1][0]" complex]
["/[1]" //
- ["[1][0]" extension]
[//
["/" analysis (.only Analysis Operation Phase)
["[1][0]" simple]
@@ -325,8 +324,8 @@
[location {.#Variant (list.partial [_ {.#Symbol tag}] values)}]
(/.with_location location
(do ///.monad
- [tag (///extension.lifted (meta.normal tag))
- [lefts,right? variantT] (///extension.lifted (meta.tag tag))
+ [tag (meta.normal tag)
+ [lefts,right? variantT] (meta.tag tag)
[lefts right?] (in (.when lefts,right?
{.#Some [lefts right? family]}
[lefts right?]
diff --git a/stdlib/source/library/lux/meta/compiler/language/lux/phase/declaration.lux b/stdlib/source/library/lux/meta/compiler/language/lux/phase/declaration.lux
index 1ef820bc9..4cd82397c 100644
--- a/stdlib/source/library/lux/meta/compiler/language/lux/phase/declaration.lux
+++ b/stdlib/source/library/lux/meta/compiler/language/lux/phase/declaration.lux
@@ -15,7 +15,6 @@
[type (.only sharing)
["[0]" check]]]]]
["[0]" //
- ["[1][0]" extension]
["[1][0]" analysis]
["/[1]" //
["/" declaration (.only Operation Phase Handler Extender)]
@@ -24,7 +23,7 @@
["[1]/[0]" macro (.only Expander)]
["[1]/[0]" type]]
[///
- ["//" phase]
+ ["//" phase (.use "[1]#[0]" monad)]
[reference (.only)
[variable (.only)]]
[meta
@@ -47,21 +46,15 @@
(All (_ anchor expression declaration)
(-> (Phase anchor expression declaration) Archive (List Code)
(Operation anchor expression declaration /.Requirements)))
- (function (_ state)
- (loop (again [state state
- input expansion
- output /.no_requirements])
- (when input
- {.#End}
- {try.#Success [state output]}
-
- {.#Item head tail}
- (when (phase archive head state)
- {try.#Success [state' head']}
- (again state' tail (/.merge_requirements head' output))
-
- {try.#Failure error}
- {try.#Failure error})))))
+ (when expansion
+ {.#End}
+ (//#in /.no_requirements)
+
+ {.#Item head tail}
+ (do //.monad
+ [head' (phase archive head)
+ tail' (requiring phase archive tail)]
+ (in (/.merge_requirements head' tail')))))
(exception.def .public (not_an_extension [name expected actual])
(Exception [Symbol Type Type])
@@ -106,12 +99,10 @@
Symbol (List Code)
(Operation anchor expression declaration /.Requirements)))
(do //.monad
- [value (<| /.lifted_analysis
- //extension.lifted
- (global_declaration name))]
+ [value (/.lifted_analysis (global_declaration name))]
(when value
{#Normal definition}
- ((extender definition) "" phase archive parameters)
+ ((extender definition) phase archive parameters)
{#Special default}
(let [default (sharing [anchor expression declaration]
@@ -119,7 +110,7 @@
extender)
(is (Handler anchor expression declaration)
(as_expected default)))]
- (default "" phase archive parameters)))))
+ (default phase archive parameters)))))
(type Outcome
(Variant
@@ -146,15 +137,13 @@
[_ {.#Form (list.partial [_ {.#Symbol macro|extension}] inputs)}]
(do !
[expansion|requirements (do !
- [[def_type def_value] (<| /.lifted_analysis
- //extension.lifted
- (global_value macro|extension))]
+ [[def_type def_value] (/.lifted_analysis (global_value macro|extension))]
(when def_value
{#Normal def_value}
(cond (check.subsumes? Macro def_type)
(/.lifted_analysis
(do !
- [expansion (//extension.lifted (///analysis/macro.expansion expander macro|extension (as Macro def_value) inputs))]
+ [expansion (///analysis/macro.expansion expander macro|extension (as Macro def_value) inputs)]
(in {#More expansion})))
(check.subsumes? .Declaration def_type)
diff --git a/stdlib/source/library/lux/meta/compiler/language/lux/phase/extension.lux b/stdlib/source/library/lux/meta/compiler/language/lux/phase/extension.lux
index 34786e94f..adf9d20a0 100644
--- a/stdlib/source/library/lux/meta/compiler/language/lux/phase/extension.lux
+++ b/stdlib/source/library/lux/meta/compiler/language/lux/phase/extension.lux
@@ -1,71 +1,50 @@
(.require
[library
- [lux (.except with)
+ [lux (.except)
[abstract
[equivalence (.only Equivalence)]
- [hash (.only Hash)]
- ["[0]" monad (.only do)]]
+ [hash (.only Hash)]]
[control
- ["[0]" function]
- ["[0]" try (.only Try)]
["[0]" exception (.only Exception)]]
[data
["[0]" product]
- ["[0]" text (.use "[1]#[0]" order)
- ["%" \\format (.only Format format)]]
+ ["[0]" text (.only)
+ ["%" \\format (.only Format)]]
[collection
["[0]" list]
- ["[0]" dictionary (.only Dictionary)]]]
- [meta
- [macro
- ["^" pattern]]]]]
+ ["[0]" dictionary (.only Dictionary)]]]]]
[/////
- ["//" phase]
- [meta
- [archive (.only Archive)]]])
+ ["[0]" phase]])
(type .public Name
Text)
(type .public (Extension a)
- [Name (List a)])
+ (Record
+ [#name Name
+ #parameters (List a)]))
(def .public equivalence
- (All (_ a) (-> (Equivalence a) (Equivalence (Extension a))))
+ (All (_ a)
+ (-> (Equivalence a)
+ (Equivalence (Extension a))))
(|>> list.equivalence
(product.equivalence text.equivalence)))
(def .public hash
- (All (_ a) (-> (Hash a) (Hash (Extension a))))
+ (All (_ a)
+ (-> (Hash a)
+ (Hash (Extension a))))
(|>> list.hash
(product.hash text.hash)))
(type .public (Handler s i o)
- (-> Name
- (//.Phase s i o)
- (//.Phase s (List i) o)))
+ (-> (phase.Phase s i o)
+ (phase.Phase s (List i) o)))
(type .public (Bundle s i o)
(Dictionary Name (Handler s i o)))
-(def .public empty
- Bundle
- (dictionary.empty text.hash))
-
-(type .public (State s i o)
- s)
-
-(type .public (Operation s i o v)
- (//.Operation (State s i o) v))
-
-(type .public (Phase s i o)
- (//.Phase (State s i o) i o))
-
-(exception.def .public (cannot_overwrite name)
- (Exception Name)
- (exception.report
- (list ["Extension" (%.text name)])))
-
(exception.def .public (incorrect_arity [name arity args])
(Exception [Name Nat Nat])
(exception.report
@@ -74,85 +53,12 @@
["Actual" (%.nat args)])))
(exception.def .public (invalid_syntax [name %format inputs])
- (All (_ a) (Exception [Name (Format a) (List a)]))
+ (All (_ a)
+ (Exception [Name (Format a) (List a)]))
(exception.report
(list ["Extension" (%.text name)]
["Inputs" (exception.listing %format inputs)])))
-(exception.def .public (unknown [name bundle])
- (All (_ s i o) (Exception [Name (Bundle s i o)]))
- (exception.report
- (list ["Extension" (%.text name)]
- ["Available" (|> bundle
- dictionary.keys
- (list.sorted text#<)
- (exception.listing %.text))])))
-
(type .public (Extender s i o)
- (-> Any (Handler s i o)))
-
-(def .public (localized get set transform)
- (All (_ s s' i o v)
- (-> (-> s s') (-> s' s s) (-> s' s')
- (-> (Operation s i o v) (Operation s i o v))))
- (function (_ operation)
- (function (_ state)
- (let [old (get state)]
- (when (operation (set (transform old) state))
- {try.#Success [state' output]}
- {try.#Success [(set old state') output]}
-
- failure
- failure)))))
-
-(def .public (temporary transform)
- (All (_ s i o v)
- (-> (-> s s)
- (-> (Operation s i o v) (Operation s i o v))))
- (function (_ operation)
- (function (_ state)
- (when (operation (transform state))
- {try.#Success [state' output]}
- {try.#Success [state output]}
-
- failure
- failure))))
-
-(def .public (with_state state)
- (All (_ s i o v)
- (-> s (-> (Operation s i o v) (Operation s i o v))))
- (..temporary (function.constant state)))
-
-(def .public (read get)
- (All (_ s i o v)
- (-> (-> s v) (Operation s i o v)))
- (function (_ state)
- {try.#Success [state (get state)]}))
-
-(def .public (update transform)
- (All (_ s i o)
- (-> (-> s s) (Operation s i o Any)))
- (function (_ state)
- {try.#Success [(transform state) []]}))
-
-(def .public (lifted action)
- (All (_ s i o v)
- (-> (//.Operation s v) (Operation s i o v)))
- (function (_ state)
- (when (action state)
- {try.#Success [state' output]}
- {try.#Success [state' output]}
-
- {try.#Failure error}
- {try.#Failure error})))
-
-(def .public (up it)
- (All (_ s i o v)
- (-> (Operation s i o v) (//.Operation s v)))
- (function (_ state)
- (when (it state)
- {try.#Success [state' output]}
- {try.#Success [state' output]}
-
- {try.#Failure error}
- {try.#Failure error})))
+ (-> Any
+ (Handler s i o)))
diff --git a/stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/analysis/jvm.lux b/stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/analysis/jvm.lux
index 4b118d972..89b18beb8 100644
--- a/stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/analysis/jvm.lux
+++ b/stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/analysis/jvm.lux
@@ -450,7 +450,7 @@
phase.lifted)))
(def (primitive_array_length_handler primitive_type)
- (-> (Type Primitive) Handler)
+ (-> (Type Primitive) (-> Text Handler))
(function (_ extension_name analyse archive args)
(when args
(list arrayC)
@@ -467,7 +467,7 @@
(/////analysis.except ///.incorrect_arity [extension_name 1 (list.size args)]))))
(def array::length::object
- Handler
+ (-> Text Handler)
(function (_ extension_name analyse archive args)
(when args
(list arrayC)
@@ -490,7 +490,7 @@
(/////analysis.except ///.incorrect_arity [extension_name 1 (list.size args)]))))
(def (new_primitive_array_handler primitive_type)
- (-> (Type Primitive) Handler)
+ (-> (Type Primitive) (-> Text Handler))
(function (_ extension_name analyse archive args)
(when args
(list lengthC)
@@ -506,14 +506,14 @@
(/////analysis.except ///.incorrect_arity [extension_name 1 (list.size args)]))))
(def array::new::object
- Handler
+ (-> Text Handler)
(function (_ extension_name analyse archive args)
(when args
(list lengthC)
(do phase.monad
[lengthA (<| (typeA.expecting ..int)
(analyse archive lengthC))
- expectedT (///.lifted meta.expected_type)
+ expectedT meta.expected_type
expectedJT (jvm_array_type expectedT)
elementJT (when (parser.array? expectedJT)
{.#Some elementJT}
@@ -691,7 +691,7 @@
(check_jvm type)))
(def (read_primitive_array_handler lux_type jvm_type)
- (-> .Type (Type Primitive) Handler)
+ (-> .Type (Type Primitive) (-> Text Handler))
(function (_ extension_name analyse archive args)
(when args
(list idxC arrayC)
@@ -709,7 +709,7 @@
(/////analysis.except ///.incorrect_arity [extension_name 2 (list.size args)]))))
(def array::read::object
- Handler
+ (-> Text Handler)
(function (_ extension_name analyse archive args)
(when args
(list idxC arrayC)
@@ -735,7 +735,7 @@
(/////analysis.except ///.incorrect_arity [extension_name 2 (list.size args)]))))
(def (write_primitive_array_handler lux_type jvm_type)
- (-> .Type (Type Primitive) Handler)
+ (-> .Type (Type Primitive) (-> Text Handler))
(let [array_type {.#Primitive (|> (jvm.array jvm_type) ..reflection)
(list)}]
(function (_ extension_name analyse archive args)
@@ -758,7 +758,7 @@
(/////analysis.except ///.incorrect_arity [extension_name 3 (list.size args)])))))
(def array::write::object
- Handler
+ (-> Text Handler)
(function (_ extension_name analyse archive args)
(when args
(list idxC valueC arrayC)
@@ -830,12 +830,12 @@
))
(def object::null
- Handler
+ (-> Text Handler)
(function (_ extension_name analyse archive args)
(when args
(list)
(do phase.monad
- [expectedT (///.lifted meta.expected_type)
+ [expectedT meta.expected_type
[_ :object:] (check_object expectedT)
_ (typeA.inference :object:)]
(in {/////analysis.#Extension [.prelude (%.format extension_name "|generation")]
@@ -845,7 +845,7 @@
(/////analysis.except ///.incorrect_arity [extension_name 0 (list.size args)]))))
(def object::null?
- Handler
+ (-> Text Handler)
(function (_ extension_name analyse archive args)
(when args
(list objectC)
@@ -861,7 +861,7 @@
(/////analysis.except ///.incorrect_arity [extension_name 1 (list.size args)]))))
(def object::synchronized
- Handler
+ (-> Text Handler)
(function (_ extension_name analyse archive args)
(when args
(list monitorC exprC)
@@ -877,7 +877,7 @@
(/////analysis.except ///.incorrect_arity [extension_name 2 (list.size args)]))))
(def (object::throw class_loader)
- (-> java/lang/ClassLoader Handler)
+ (-> java/lang/ClassLoader (-> Text Handler))
(function (_ extension_name analyse archive args)
(when args
(list exceptionC)
@@ -898,7 +898,7 @@
(/////analysis.except ///.incorrect_arity [extension_name 1 (list.size args)]))))
(def (object::class class_loader)
- (-> java/lang/ClassLoader Handler)
+ (-> java/lang/ClassLoader (-> Text Handler))
(function (_ extension_name analyse archive args)
(when args
(list classC)
@@ -918,7 +918,7 @@
(/////analysis.except ///.incorrect_arity [extension_name 1 (list.size args)]))))
(def (object::instance? class_loader)
- (-> java/lang/ClassLoader Handler)
+ (-> java/lang/ClassLoader (-> Text Handler))
(..custom
[(all <>.and <code>.text <code>.any)
(function (_ extension_name analyse archive [sub_class objectC])
@@ -958,12 +958,12 @@
(array.list {.#None} (java/lang/Class::getGenericInterfaces from_class)))))))
(def (object::cast class_loader)
- (-> java/lang/ClassLoader Handler)
+ (-> java/lang/ClassLoader (-> Text Handler))
(function (_ extension_name analyse archive args)
(when args
(list fromC)
(do [! phase.monad]
- [toT (///.lifted meta.expected_type)
+ [toT meta.expected_type
toJT (check_jvm toT)
[fromT fromA] (typeA.inferring
(analyse archive fromC))
@@ -1041,7 +1041,7 @@
))
(def (get::static class_loader)
- (-> java/lang/ClassLoader Handler)
+ (-> java/lang/ClassLoader (-> Text Handler))
(..custom
[..member
(function (_ extension_name analyse archive [class field])
@@ -1061,7 +1061,7 @@
(/////analysis.text (..signature fieldJT)))))))]))
(def (put::static class_loader)
- (-> java/lang/ClassLoader Handler)
+ (-> java/lang/ClassLoader (-> Text Handler))
(..custom
[(all <>.and ..member <code>.any)
(function (_ extension_name analyse archive [[class field] valueC])
@@ -1086,7 +1086,7 @@
valueA)))))]))
(def (get::virtual class_loader)
- (-> java/lang/ClassLoader Handler)
+ (-> java/lang/ClassLoader (-> Text Handler))
(..custom
[(all <>.and ..member <code>.any)
(function (_ extension_name analyse archive [[class field] objectC])
@@ -1111,7 +1111,7 @@
objectA)))))]))
(def (put::virtual class_loader)
- (-> java/lang/ClassLoader Handler)
+ (-> java/lang/ClassLoader (-> Text Handler))
(..custom
[(all <>.and ..member <code>.any <code>.any)
(function (_ extension_name analyse archive [[class field] valueC objectC])
@@ -1507,7 +1507,7 @@
(<code>.tuple (<>.some ..var)))
(def (invoke::static class_loader)
- (-> java/lang/ClassLoader Handler)
+ (-> java/lang/ClassLoader (-> Text Handler))
(..custom
[(all <>.and ..type_vars ..member ..type_vars (<>.some ..input))
(function (_ extension_name analyse archive [class_tvars [class method] method_tvars argsTC])
@@ -1526,7 +1526,7 @@
(decorate_inputs argsT argsA))})))]))
(def (invoke::virtual class_loader)
- (-> java/lang/ClassLoader Handler)
+ (-> java/lang/ClassLoader (-> Text Handler))
(..custom
[(all <>.and ..type_vars ..member ..type_vars <code>.any (<>.some ..input))
(function (_ extension_name analyse archive [class_tvars [class method] method_tvars objectC argsTC])
@@ -1552,7 +1552,7 @@
(decorate_inputs argsT argsA))})))]))
(def (invoke::special class_loader)
- (-> java/lang/ClassLoader Handler)
+ (-> java/lang/ClassLoader (-> Text Handler))
(..custom
[(all <>.and ..type_vars ..member ..type_vars <code>.any (<>.some ..input))
(function (_ extension_name analyse archive [class_tvars [class method] method_tvars objectC argsTC])
@@ -1578,7 +1578,7 @@
(decorate_inputs argsT argsA))})))]))
(def (invoke::interface class_loader)
- (-> java/lang/ClassLoader Handler)
+ (-> java/lang/ClassLoader (-> Text Handler))
(..custom
[(all <>.and ..type_vars ..member ..type_vars <code>.any (<>.some ..input))
(function (_ extension_name analyse archive [class_tvars [class_name method] method_tvars objectC argsTC])
@@ -1607,7 +1607,7 @@
(decorate_inputs argsT argsA))})))]))
(def (invoke::constructor class_loader)
- (-> java/lang/ClassLoader Handler)
+ (-> java/lang/ClassLoader (-> Text Handler))
(..custom
[(all <>.and ..type_vars <code>.text ..type_vars (<>.some ..input))
(function (_ extension_name analyse archive [class_tvars class method_tvars argsTC])
@@ -2659,7 +2659,7 @@
inheritance))
(def (class::anonymous class_loader host)
- (-> java/lang/ClassLoader runtime.Host Handler)
+ (-> java/lang/ClassLoader runtime.Host (-> Text Handler))
(..custom
[(all <>.and
(<code>.tuple (<>.some ..var))
@@ -2676,10 +2676,10 @@
[_ (..ensure_fresh_class! class_loader (..reflection super_class))
_ (monad.each ! (|>> ..reflection (..ensure_fresh_class! class_loader)) super_interfaces)
- self_name (///.lifted (do meta.monad
- [where meta.current_module_name
- id meta.seed]
- (in (..anonymous_class_name where id))))
+ self_name (do meta.monad
+ [where meta.current_module_name
+ id meta.seed]
+ (in (..anonymous_class_name where id)))
.let [selfT {.#Primitive self_name (list)}]
mock (<| phase.lifted
(..mock [self_name parameters]
diff --git a/stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/analysis/lux.lux b/stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/analysis/lux.lux
index f7e4393d9..c8b1a5d50 100644
--- a/stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/analysis/lux.lux
+++ b/stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/analysis/lux.lux
@@ -39,12 +39,12 @@
[meta
[archive (.only Archive)]]]]]])
-(def .public (custom [syntax handler])
+(def .public (custom [syntax handler] extension_name)
(All (_ s)
(-> [(Parser s)
(-> Text Phase Archive s (Operation Analysis))]
- Handler))
- (function (_ extension_name analyse archive args)
+ (-> Text Handler)))
+ (function (_ analyse archive args)
(when (<code>.result syntax args)
{try.#Success inputs}
(handler extension_name analyse archive inputs)
@@ -52,10 +52,10 @@
{try.#Failure _}
(analysis.except ///.invalid_syntax [extension_name %.code args]))))
-(def (simple inputsT+ outputT)
- (-> (List Type) Type Handler)
+(def (simple inputsT+ outputT extension_name)
+ (-> (List Type) Type (-> Text Handler))
(let [num_expected (list.size inputsT+)]
- (function (_ extension_name analyse archive args)
+ (function (_ analyse archive args)
(let [num_actual (list.size args)]
(if (n.= num_expected num_actual)
(do [! ////.monad]
@@ -69,19 +69,19 @@
(analysis.except ///.incorrect_arity [extension_name num_expected num_actual]))))))
(def .public (nullary valueT)
- (-> Type Handler)
+ (-> Type (-> Text Handler))
(simple (list) valueT))
(def .public (unary inputT outputT)
- (-> Type Type Handler)
+ (-> Type Type (-> Text Handler))
(simple (list inputT) outputT))
(def .public (binary subjectT paramT outputT)
- (-> Type Type Type Handler)
+ (-> Type Type Type (-> Text Handler))
(simple (list subjectT paramT) outputT))
(def .public (trinary subjectT param0T param1T outputT)
- (-> Type Type Type Type Handler)
+ (-> Type Type Type Type (-> Text Handler))
(simple (list subjectT param0T param1T) outputT))
... TODO: Get rid of this ASAP
@@ -100,6 +100,7 @@
_ (<>.failure (exception.error ..char_text_must_be_size_1 [raw])))))
(def lux::syntax_char_case!
+ (-> Text Handler)
(..custom
[(all <>.and
<code>.any
@@ -110,7 +111,7 @@
(do [! ////.monad]
[input (<| (typeA.expecting text.Char)
(phase archive input))
- expectedT (///.lifted meta.expected_type)
+ expectedT meta.expected_type
conditionals (monad.each ! (function (_ [cases branch])
(do !
[branch (<| (typeA.expecting expectedT)
@@ -128,21 +129,20 @@
{analysis.#Extension [.prelude (format extension_name "|generation")]}))))])))
... .is?# represents reference/pointer equality.
-(def lux::is?
- Handler
- (function (_ extension_name analyse archive args)
+(def (lux::is? extension_name)
+ (-> Text Handler)
+ (function (_ analyse archive args)
(<| typeA.with_var
(function (_ [@var :var:]))
((binary :var: :var: Bit extension_name)
analyse archive args))))
-... .try# provides a simple way to interact with the host platform's
-... error_handling facilities.
+... .try# provides a unified way to interact with the host platform's runtime error-handling facilities.
(def lux::try
- Handler
- (function (_ extension_name analyse archive args)
- (when args
- (list opC)
+ (-> Text Handler)
+ (..custom
+ [<code>.any
+ (function (_ extension_name analyse archive opC)
(<| typeA.with_var
(function (_ [@var :var:]))
(do [! ////.monad]
@@ -150,55 +150,43 @@
(|> opC
(analyse archive)
(typeA.expecting (type_literal (-> .Any :var:)))
- (at ! each (|>> list {analysis.#Extension [.prelude (format extension_name "|generation")]})))))
-
- _
- (analysis.except ///.incorrect_arity [extension_name 1 (list.size args)]))))
+ (at ! each (|>> list {analysis.#Extension [.prelude (format extension_name "|generation")]}))))))]))
(def lux::in_module
- Handler
- (function (_ extension_name analyse archive argsC+)
- (when argsC+
- (list [_ {.#Text module_name}] exprC)
+ (-> Text Handler)
+ (..custom
+ [(<>.and <code>.text <code>.any)
+ (function (_ extension_name analyse archive [module_name exprC])
(analysis.with_current_module module_name
- (analyse archive exprC))
-
- _
- (analysis.except ///.invalid_syntax [extension_name %.code argsC+]))))
+ (analyse archive exprC)))]))
(def .public (is#_extension eval)
- (-> Eval Handler)
- (function (_ extension_name analyse archive args)
- (when args
- (list typeC valueC)
+ (-> Eval (-> Text Handler))
+ (..custom
+ [(<>.and <code>.any <code>.any)
+ (function (_ extension_name analyse archive [typeC valueC])
(do [! ////.monad]
[actualT (at ! each (|>> (as Type))
(eval archive Type typeC))
_ (typeA.inference actualT)]
(<| (typeA.expecting actualT)
- (analyse archive valueC)))
-
- _
- (analysis.except ///.incorrect_arity [extension_name 2 (list.size args)]))))
+ (analyse archive valueC))))]))
(def .public (as#_extension eval)
- (-> Eval Handler)
- (function (_ extension_name analyse archive args)
- (when args
- (list typeC valueC)
+ (-> Eval (-> Text Handler))
+ (..custom
+ [(<>.and <code>.any <code>.any)
+ (function (_ extension_name analyse archive [typeC valueC])
(do [! ////.monad]
[actualT (at ! each (|>> (as Type))
(eval archive Type typeC))
_ (typeA.inference actualT)
[valueT valueA] (typeA.inferring
(analyse archive valueC))]
- (in valueA))
-
- _
- (analysis.except ///.incorrect_arity [extension_name 2 (list.size args)]))))
+ (in valueA)))]))
(def (caster input output)
- (-> Type Type Handler)
+ (-> Type Type (-> Text Handler))
(..custom
[<code>.any
(function (_ extension_name phase archive valueC)
diff --git a/stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/bundle.lux b/stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/bundle.lux
index 1436c1002..d9b0fb4d2 100644
--- a/stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/bundle.lux
+++ b/stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/bundle.lux
@@ -1,14 +1,10 @@
(.require
[library
[lux (.except)
- [abstract
- [monad (.only do)]]
[data
- ["[0]" text (.only)
- ["%" \\format (.only format)]]
+ ["[0]" text]
[collection
- ["[0]" list (.use "[1]#[0]" functor)]
- ["[0]" dictionary (.only Dictionary)]]]]]
+ ["[0]" dictionary]]]]]
[// (.only Handler Bundle)])
(def .public empty
@@ -17,13 +13,6 @@
(def .public (install name anonymous)
(All (_ s i o)
- (-> Text (Handler s i o)
+ (-> Text (-> Text (Handler s i o))
(-> (Bundle s i o) (Bundle s i o))))
- (dictionary.has name anonymous))
-
-(def .public (prefix prefix)
- (All (_ s i o)
- (-> Text (-> (Bundle s i o) (Bundle s i o))))
- (|>> dictionary.entries
- (list#each (function (_ [key val]) [(format prefix " " key) val]))
- (dictionary.of_list text.hash)))
+ (dictionary.has name (anonymous name)))
diff --git a/stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/declaration/jvm.lux b/stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/declaration/jvm.lux
index a164ee5b9..6028be070 100644
--- a/stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/declaration/jvm.lux
+++ b/stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/declaration/jvm.lux
@@ -78,7 +78,7 @@
[jvm
["[0]" runtime (.only Anchor Definition Extender)]
["[0]" value]]]
- ["[0]" extension (.only)
+ [extension
["[0]" bundle]
[analysis
["[0]" jvm]]
@@ -864,7 +864,7 @@
(<code>.tuple (<>.some ..annotation))
(<code>.tuple (<>.some ..field))
(<code>.tuple (<>.some ..method)))
- (function (_ extension phase archive
+ (function (_ phase archive
[class_declaration
super
interfaces
@@ -895,7 +895,7 @@
luxT.fresh
parameters)
selfT {.#Primitive name (list#each product.right parameters)}]
- state (extension.lifted phase.state)
+ state phase.state
methods (monad.each ! (let [analysis_state (the [declaration.#analysis declaration.#state] state)]
(..method_definition archive super interfaces [mapping selfT]
[(the [declaration.#analysis declaration.#phase] state)
@@ -939,7 +939,7 @@
... TODO: Handle annotations.
(<code>.tuple (<>.some ..annotation))
(<>.some jvm.method_declaration))
- (function (_ extension_name phase archive [[name parameters] supers annotations method_declarations])
+ (function (_ phase archive [[name parameters] supers annotations method_declarations])
(declaration.lifted_generation
(do [! phase.monad]
[bytecode (<| (at ! each (\\format.result class.format))
diff --git a/stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/declaration/lux.lux b/stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/declaration/lux.lux
index 2a96f19a0..9052c2384 100644
--- a/stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/declaration/lux.lux
+++ b/stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/declaration/lux.lux
@@ -63,19 +63,18 @@
(def .public (custom [syntax handler])
(All (_ anchor expression declaration s)
(-> [(Parser s)
- (-> Text
- (Phase anchor expression declaration)
+ (-> (Phase anchor expression declaration)
Archive
s
(Operation anchor expression declaration Requirements))]
(Handler anchor expression declaration)))
- (function (_ extension_name phase archive inputs)
+ (function (_ phase archive inputs)
(when (<code>.result syntax inputs)
{try.#Success inputs}
- (handler extension_name phase archive inputs)
+ (handler phase archive inputs)
{try.#Failure error}
- (phase.except ///.invalid_syntax [extension_name %.code inputs]))))
+ (phase.except ///.invalid_syntax ["" %.code inputs]))))
(def (context [@module @artifact])
(-> unit.ID unit.ID)
@@ -103,7 +102,7 @@
(All (_ anchor expression declaration)
(-> Archive Type Code (Operation anchor expression declaration [Type expression Any])))
(do phase.monad
- [state (///.lifted phase.state)
+ [state phase.state
.let [analysis_state (the [/////declaration.#analysis /////declaration.#state] state)
analysis (the [/////declaration.#analysis /////declaration.#phase] state)
synthesis ((the [/////declaration.#synthesis /////declaration.#phase] state) analysis_state)
@@ -150,7 +149,7 @@
(-> Archive Symbol (Maybe Type) Code
(Operation anchor expression declaration [Type expression Any])))
(do [! phase.monad]
- [state (///.lifted phase.state)
+ [state phase.state
.let [analysis_state (the [/////declaration.#analysis /////declaration.#state] state)
analysis (the [/////declaration.#analysis /////declaration.#phase] state)
synthesis ((the [/////declaration.#synthesis /////declaration.#phase] state) analysis_state)
@@ -186,8 +185,7 @@
Synthesis
(Operation anchor expression declaration [expression Any])))
(do phase.monad
- [current_module (/////declaration.lifted_analysis
- (///.lifted meta.current_module_name))]
+ [current_module (/////declaration.lifted_analysis meta.current_module_name)]
(/////declaration.lifted_generation
(do phase.monad
[dependencies (cache/artifact.dependencies archive codeS)
@@ -204,7 +202,7 @@
(-> Archive Text Type Code
(Operation anchor expression declaration [expression Any])))
(do phase.monad
- [state (///.lifted phase.state)
+ [state phase.state
.let [analysis_state (the [/////declaration.#analysis /////declaration.#state] state)
analysis (the [/////declaration.#analysis /////declaration.#phase] state)
synthesis ((the [/////declaration.#synthesis /////declaration.#phase] state) analysis_state)
@@ -237,8 +235,8 @@
(the [/////declaration.#generation /////declaration.#phase] state)])]
_ (/////declaration.lifted_analysis
(do !
- [_ (moduleA.override_definition [.prelude "is#"] {.#Default [true .Analysis (analysisE.is#_extension eval)]})
- _ (moduleA.override_definition [.prelude "as#"] {.#Default [true .Analysis (analysisE.as#_extension eval)]})]
+ [_ (moduleA.override_definition [.prelude "is#"] {.#Default [true .Analysis (analysisE.is#_extension eval "is#")]})
+ _ (moduleA.override_definition [.prelude "as#"] {.#Default [true .Analysis (analysisE.as#_extension eval "as#")]})]
(in [])))]
(in [])))
@@ -250,13 +248,12 @@
(def lux::def
Handler
- (function (_ extension_name phase archive inputsC+)
+ (function (_ phase archive inputsC+)
(when inputsC+
(list [_ {.#Symbol ["" short_name]}] valueC exported?C)
(do phase.monad
[_ ..refresh
- current_module (/////declaration.lifted_analysis
- (///.lifted meta.current_module_name))
+ current_module (/////declaration.lifted_analysis meta.current_module_name)
.let [full_name [current_module short_name]]
[type valueT value] (..definition archive full_name {.#None} valueC)
[_ _ exported?] (evaluate! archive Bit exported?C)
@@ -266,7 +263,7 @@
(in /////declaration.no_requirements))
_
- (phase.except ///.invalid_syntax [extension_name %.code inputsC+]))))
+ (phase.except ///.invalid_syntax ["" %.code inputsC+]))))
(def imports
(Parser (List Import))
@@ -278,7 +275,7 @@
Handler
(..custom
[..imports
- (function (_ extension_name phase archive imports)
+ (function (_ phase archive imports)
(do [! phase.monad]
[_ (/////declaration.lifted_analysis
(monad.each ! (function (_ [module alias])
@@ -301,8 +298,8 @@
(def (define_alias alias original)
(-> Text Symbol (/////analysis.Operation Any))
(do phase.monad
- [current_module (///.lifted meta.current_module_name)
- constant (///.lifted (meta.definition original))]
+ [current_module meta.current_module_name
+ constant (meta.definition original)]
(when constant
{.#Alias de_aliased}
(phase.except ..cannot_alias_an_alias [[current_module alias] original de_aliased])
@@ -314,12 +311,11 @@
Handler
(..custom
[(all <>.and <code>.local <code>.symbol)
- (function (_ extension_name phase archive [alias def_name])
+ (function (_ phase archive [alias def_name])
(do phase.monad
- [_ (///.lifted
- (phase.sub [(the [/////declaration.#analysis /////declaration.#state])
- (has [/////declaration.#analysis /////declaration.#state])]
- (define_alias alias def_name)))]
+ [_ (phase.sub [(the [/////declaration.#analysis /////declaration.#state])
+ (has [/////declaration.#analysis /////declaration.#state])]
+ (define_alias alias def_name))]
(in /////declaration.no_requirements)))]))
... TODO: Stop requiring these types and the "swapped" function below to make types line-up.
diff --git a/stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/generation/jvm/common.lux b/stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/generation/jvm/common.lux
index e9980d164..a598e96c5 100644
--- a/stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/generation/jvm/common.lux
+++ b/stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/generation/jvm/common.lux
@@ -46,12 +46,12 @@
(def .public (custom [parser handler])
(All (_ s)
(-> [(Parser s)
- (-> Text Phase Archive s (Operation (Bytecode Any)))]
- Handler))
+ (-> Phase Archive s (Operation (Bytecode Any)))]
+ (-> Text Handler)))
(function (_ extension_name phase archive input)
(when (<synthesis>.result parser input)
{try.#Success input'}
- (handler extension_name phase archive input')
+ (handler phase archive input')
{try.#Failure error}
(/////.except /////extension.invalid_syntax [extension_name synthesis.%synthesis input]))))
@@ -101,7 +101,7 @@
(<>.some (<synthesis>.tuple (all <>.and
(<synthesis>.tuple (<>.many <synthesis>.i64))
<synthesis>.any))))
- (function (_ extension_name phase archive [inputS elseS conditionalsS])
+ (function (_ phase archive [inputS elseS conditionalsS])
(do [! /////.monad]
[@end ///runtime.forge_label
inputG (phase archive inputS)
diff --git a/stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/generation/jvm/host.lux b/stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/generation/jvm/host.lux
index 18981ce1c..b72d1754a 100644
--- a/stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/generation/jvm/host.lux
+++ b/stdlib/source/library/lux/meta/compiler/language/lux/phase/extension/generation/jvm/host.lux
@@ -379,10 +379,10 @@
(undefined))))
(def (primitive_array_length_handler jvm_primitive)
- (-> (Type Primitive) Handler)
+ (-> (Type Primitive) (-> Text Handler))
(..custom
[<synthesis>.any
- (function (_ extension_name generate archive arrayS)
+ (function (_ generate archive arrayS)
(do //////.monad
[arrayG (generate archive arrayS)]
(in (all _.composite
@@ -391,10 +391,10 @@
_.arraylength))))]))
(def array::length::object
- Handler
+ (-> Text Handler)
(..custom
[(all <>.and ..object_array <synthesis>.any)
- (function (_ extension_name generate archive [elementJT arrayS])
+ (function (_ generate archive [elementJT arrayS])
(do //////.monad
[arrayG (generate archive arrayS)]
(in (all _.composite
@@ -403,10 +403,10 @@
_.arraylength))))]))
(def (new_primitive_array_handler jvm_primitive)
- (-> Primitive_Array_Type Handler)
+ (-> Primitive_Array_Type (-> Text Handler))
(..custom
[<synthesis>.any
- (function (_ extension_name generate archive [lengthS])
+ (function (_ generate archive [lengthS])
(do //////.monad
[lengthG (generate archive lengthS)]
(in (all _.composite
@@ -414,10 +414,10 @@
(_.newarray jvm_primitive)))))]))
(def array::new::object
- Handler
+ (-> Text Handler)
(..custom
[(all <>.and ..object <synthesis>.any)
- (function (_ extension_name generate archive [objectJT lengthS])
+ (function (_ generate archive [objectJT lengthS])
(do //////.monad
[lengthG (generate archive lengthS)]
(in (all _.composite
@@ -425,10 +425,10 @@
(_.anewarray objectJT)))))]))
(def (read_primitive_array_handler jvm_primitive loadG)
- (-> (Type Primitive) (Bytecode Any) Handler)
+ (-> (Type Primitive) (Bytecode Any) (-> Text Handler))
(..custom
[(all <>.and <synthesis>.any <synthesis>.any)
- (function (_ extension_name generate archive [idxS arrayS])
+ (function (_ generate archive [idxS arrayS])
(do //////.monad
[arrayG (generate archive arrayS)
idxG (generate archive idxS)]
@@ -439,10 +439,10 @@
loadG))))]))
(def array::read::object
- Handler
+ (-> Text Handler)
(..custom
[(all <>.and ..object_array <synthesis>.any <synthesis>.any)
- (function (_ extension_name generate archive [elementJT idxS arrayS])
+ (function (_ generate archive [elementJT idxS arrayS])
(do //////.monad
[arrayG (generate archive arrayS)
idxG (generate archive idxS)]
@@ -453,10 +453,10 @@
_.aaload))))]))
(def (write_primitive_array_handler jvm_primitive storeG)
- (-> (Type Primitive) (Bytecode Any) Handler)
+ (-> (Type Primitive) (Bytecode Any) (-> Text Handler))
(..custom
[(all <>.and <synthesis>.any <synthesis>.any <synthesis>.any)
- (function (_ extension_name generate archive [idxS valueS arrayS])
+ (function (_ generate archive [idxS valueS arrayS])
(do //////.monad
[arrayG (generate archive arrayS)
idxG (generate archive idxS)
@@ -470,10 +470,10 @@
storeG))))]))
(def array::write::object
- Handler
+ (-> Text Handler)
(..custom
[(all <>.and ..object_array <synthesis>.any <synthesis>.any <synthesis>.any)
- (function (_ extension_name generate archive [elementJT idxS valueS arrayS])
+ (function (_ generate archive [elementJT idxS valueS arrayS])
(do //////.monad
[arrayG (generate archive arrayS)
idxG (generate archive idxS)
@@ -572,10 +572,10 @@
(def $String (type.class "java.lang.String" (list)))
(def object::class
- Handler
+ (-> Text Handler)
(..custom
[<synthesis>.text
- (function (_ extension_name generate archive [class])
+ (function (_ generate archive [class])
(do //////.monad
[]
(in (all _.composite
@@ -583,10 +583,10 @@
(_.invokestatic ..$Class "forName" (type.method [(list) (list ..$String) ..$Class (list)]))))))]))
(def object::instance?
- Handler
+ (-> Text Handler)
(..custom
[(all <>.and <synthesis>.text <synthesis>.any)
- (function (_ extension_name generate archive [class objectS])
+ (function (_ generate archive [class objectS])
(do //////.monad
[objectG (generate archive objectS)]
(in (all _.composite
@@ -595,10 +595,10 @@
(///value.wrap type.boolean)))))]))
(def object::cast
- Handler
+ (-> Text Handler)
(..custom
[(all <>.and <synthesis>.text <synthesis>.text <synthesis>.any)
- (function (_ extension_name generate archive [from to valueS])
+ (function (_ generate archive [from to valueS])
(do //////.monad
[valueG (generate archive valueS)]
(in (`` (cond (,, (with_template [<object> <type>]
@@ -637,17 +637,17 @@
))
(def get::static
- Handler
+ (-> Text Handler)
(..custom
[(all <>.and <synthesis>.text <synthesis>.text ..value)
- (function (_ extension_name generate archive [class field :unboxed:])
+ (function (_ generate archive [class field :unboxed:])
(at //////.monad in (_.getstatic (type.class class (list)) field :unboxed:)))]))
(def put::static
- Handler
+ (-> Text Handler)
(..custom
[(all <>.and <synthesis>.text <synthesis>.text ..value <synthesis>.any)
- (function (_ extension_name generate archive [class field :unboxed: valueS])
+ (function (_ generate archive [class field :unboxed: valueS])
(do //////.monad
[valueG (generate archive valueS)]
(in (all _.composite
@@ -662,10 +662,10 @@
..unitG))))]))
(def get::virtual
- Handler
+ (-> Text Handler)
(..custom
[(all <>.and <synthesis>.text <synthesis>.text ..value <synthesis>.any)
- (function (_ extension_name generate archive [class field :unboxed: objectS])
+ (function (_ generate archive [class field :unboxed: objectS])
(do //////.monad
[objectG (generate archive objectS)
.let [:class: (type.class class (list))
@@ -676,10 +676,10 @@
getG))))]))
(def put::virtual
- Handler
+ (-> Text Handler)
(..custom
[(all <>.and <synthesis>.text <synthesis>.text ..value <synthesis>.any <synthesis>.any)
- (function (_ extension_name generate archive [class field :unboxed: valueS objectS])
+ (function (_ generate archive [class field :unboxed: valueS objectS])
(do //////.monad
[valueG (generate archive valueS)
objectG (generate archive objectS)
@@ -729,10 +729,10 @@
(_#in [])))
(def invoke::static
- Handler
+ (-> Text Handler)
(..custom
[(all <>.and ..class <synthesis>.text ..return (<>.some ..input))
- (function (_ extension_name generate archive [class method outputT inputsTS])
+ (function (_ generate archive [class method outputT inputsTS])
(do [! //////.monad]
[inputsTG (monad.each ! (generate_input generate archive) inputsTS)]
(in (all _.composite
@@ -742,10 +742,10 @@
(with_template [<check_cast?> <name> <invoke>]
[(def <name>
- Handler
+ (-> Text Handler)
(..custom
[(all <>.and ..class <synthesis>.text ..return <synthesis>.any (<>.some ..input))
- (function (_ extension_name generate archive [class method outputT objectS inputsTS])
+ (function (_ generate archive [class method outputT objectS inputsTS])
(do [! //////.monad]
[objectG (generate archive objectS)
inputsTG (monad.each ! (generate_input generate archive) inputsTS)]
@@ -764,10 +764,10 @@
)
(def invoke::constructor
- Handler
+ (-> Text Handler)
(..custom
[(all <>.and ..class (<>.some ..input))
- (function (_ extension_name generate archive [class inputsTS])
+ (function (_ generate archive [class inputsTS])
(do [! //////.monad]
[inputsTG (monad.each ! (generate_input generate archive) inputsTS)]
(in (all _.composite
@@ -1309,17 +1309,17 @@
(returnG returnT))})))))
(def class::anonymous
- Handler
+ (-> Text Handler)
(..custom
[(all <>.and
..class
(<synthesis>.tuple (<>.some ..class))
(<synthesis>.tuple (<>.some ..input))
(<synthesis>.tuple (<>.some ..overriden_method_definition)))
- (function (_ extension_name generate archive [super_class
- super_interfaces
- inputsTS
- overriden_methods])
+ (function (_ generate archive [super_class
+ super_interfaces
+ inputsTS
+ overriden_methods])
(do [! //////.monad]
[all_dependencies (anonymous_dependencies archive inputsTS overriden_methods)
[context _] (//////generation.with_new_context archive all_dependencies (in []))
diff --git a/stdlib/source/library/lux/meta/compiler/language/lux/phase/generation/extension.lux b/stdlib/source/library/lux/meta/compiler/language/lux/phase/generation/extension.lux
index 321e8ca7b..fde10a521 100644
--- a/stdlib/source/library/lux/meta/compiler/language/lux/phase/generation/extension.lux
+++ b/stdlib/source/library/lux/meta/compiler/language/lux/phase/generation/extension.lux
@@ -31,12 +31,12 @@
(def arity
(syntax (_ [arity <code>.nat])
- (with_symbols [g!_ g!extension g!name g!phase g!archive g!inputs g!anchor g!expression g!declaration]
+ (with_symbols [g!_ g!name g!extension g!phase g!archive g!inputs g!anchor g!expression g!declaration]
(do [! meta.monad]
[g!input+ (monad.all ! (list.repeated arity (macro.symbol "input")))]
(in (list (` (is (All ((, g!_) (, g!anchor) (, g!expression) (, g!declaration))
(-> ((Arity (, (code.nat arity))) (, g!expression))
- (generation.Handler (, g!anchor) (, g!expression) (, g!declaration))))
+ (-> Text (generation.Handler (, g!anchor) (, g!expression) (, g!declaration)))))
(function ((, g!_) (, g!extension))
(function ((, g!_) (, g!name) (, g!phase) (, g!archive) (, g!inputs))
(when (, g!inputs)
@@ -49,7 +49,7 @@
((,' in) ((, g!extension) [(,* g!input+)])))
(, g!_)
- (///.except ///extension.incorrect_arity [(, g!name)
+ (///.except ///extension.incorrect_arity [""
(, (code.nat arity))
(list.size (, g!inputs))]))
))))))))))
@@ -69,10 +69,9 @@
(def .public (variadic extension)
(All (_ anchor expression declaration)
- (-> (Variadic expression) (generation.Handler anchor expression declaration)))
- (function (_ extension_name)
- (function (_ phase archive inputsS)
- (let [! ///.monad]
- (|> inputsS
- (monad.each ! (phase archive))
- (at ! each extension))))))
+ (-> (Variadic expression) (-> Text (generation.Handler anchor expression declaration))))
+ (function (_ extension_name phase archive inputsS)
+ (let [! ///.monad]
+ (|> inputsS
+ (monad.each ! (phase archive))
+ (at ! each extension)))))
diff --git a/stdlib/source/library/lux/meta/compiler/language/lux/phase/generation/jvm.lux b/stdlib/source/library/lux/meta/compiler/language/lux/phase/generation/jvm.lux
index 44fb80a79..d25fe3fcf 100644
--- a/stdlib/source/library/lux/meta/compiler/language/lux/phase/generation/jvm.lux
+++ b/stdlib/source/library/lux/meta/compiler/language/lux/phase/generation/jvm.lux
@@ -73,10 +73,10 @@
(if (check.subsumes? .Generation type)
(when value
{.#Left definition}
- ((extender definition) "" phase archive parameters)
+ ((extender definition) phase archive parameters)
{.#Right default}
- ((as Handler default) "" phase archive parameters))
+ ((as Handler default) phase archive parameters))
(///.except ..not_an_extension [name .Generation type]))
{try.#Failure error}
diff --git a/stdlib/source/library/lux/meta/compiler/language/lux/phase/synthesis.lux b/stdlib/source/library/lux/meta/compiler/language/lux/phase/synthesis.lux
index e1b4ebc8e..3f6d6cb65 100644
--- a/stdlib/source/library/lux/meta/compiler/language/lux/phase/synthesis.lux
+++ b/stdlib/source/library/lux/meta/compiler/language/lux/phase/synthesis.lux
@@ -85,10 +85,10 @@
(if (check.subsumes? .Synthesis type)
(when value
{.#Left definition}
- ((extender definition) "" phase archive parameters)
+ ((extender definition) phase archive parameters)
{.#Right default}
- ((as Handler default) "" phase archive parameters))
+ ((as Handler default) phase archive parameters))
... (phase.except ..not_an_extension [name .Synthesis type])
(|> parameters
(monad.each phase.monad (phase archive))
diff --git a/stdlib/source/library/lux/meta/compiler/language/lux/synthesis.lux b/stdlib/source/library/lux/meta/compiler/language/lux/synthesis.lux
index 6ef3645d3..80182d03d 100644
--- a/stdlib/source/library/lux/meta/compiler/language/lux/synthesis.lux
+++ b/stdlib/source/library/lux/meta/compiler/language/lux/synthesis.lux
@@ -132,13 +132,16 @@
{#Control (Control Synthesis)}
{#Extension [Symbol (List Synthesis)]})))
+(type .public Operation
+ (phase.Operation State))
+
+(type .public Phase
+ (phase.Phase State Analysis Synthesis))
+
(with_template [<special> <general>]
[(type .public <special>
(<general> ..State Analysis Synthesis))]
- [State+ extension.State]
- [Operation extension.Operation]
- [Phase extension.Phase]
[Handler extension.Handler]
[Bundle extension.Bundle]
[Extender extension.Extender]
@@ -217,11 +220,11 @@
(with_template [<with> <query> <tag> <type>]
[(def .public (<with> value)
(-> <type> (All (_ a) (-> (Operation a) (Operation a))))
- (extension.temporary (has <tag> value)))
+ (phase.temporary (has <tag> value)))
(def .public <query>
(Operation <type>)
- (extension.read (the <tag>)))]
+ (phase.read (the <tag>)))]
[with_locals locals #locals Nat]
[with_currying? currying? #currying? Bit]
diff --git a/stdlib/source/library/lux/meta/compiler/phase.lux b/stdlib/source/library/lux/meta/compiler/phase.lux
index dd87d5866..d67fb5633 100644
--- a/stdlib/source/library/lux/meta/compiler/phase.lux
+++ b/stdlib/source/library/lux/meta/compiler/phase.lux
@@ -140,3 +140,42 @@
[[pre/state' temp] (pre archive input pre/state)
[post/state' output] (post archive temp post/state)]
(in [[pre/state' post/state'] output]))))
+
+(def .public (read get)
+ (All (_ s v)
+ (-> (-> s v) (Operation s v)))
+ (function (_ state)
+ {try.#Success [state (get state)]}))
+
+(def .public (update transform)
+ (All (_ s)
+ (-> (-> s s) (Operation s Any)))
+ (function (_ state)
+ {try.#Success [(transform state) []]}))
+
+(def .public (localized get set transform)
+ (All (_ s s' v)
+ (-> (-> s s') (-> s' s s) (-> s' s')
+ (-> (Operation s v) (Operation s v))))
+ (function (_ operation)
+ (function (_ state)
+ (let [old (get state)]
+ (when (operation (set (transform old) state))
+ {try.#Success [state' output]}
+ {try.#Success [(set old state') output]}
+
+ failure
+ failure)))))
+
+(def .public (temporary transform)
+ (All (_ s v)
+ (-> (-> s s)
+ (-> (Operation s v) (Operation s v))))
+ (function (_ operation)
+ (function (_ state)
+ (when (operation (transform state))
+ {try.#Success [state' output]}
+ {try.#Success [state output]}
+
+ failure
+ failure))))
diff --git a/stdlib/source/library/lux/meta/extension.lux b/stdlib/source/library/lux/meta/extension.lux
index a713dd596..913acaec9 100644
--- a/stdlib/source/library/lux/meta/extension.lux
+++ b/stdlib/source/library/lux/meta/extension.lux
@@ -43,21 +43,19 @@
(with_template [<any> <end> <and> <result> <name> <extension_type> <handler_type>]
[(def .public <name>
- (syntax (_ [[handler extension phase archive inputs] (<c>.form (all <>.and
- <c>.local
- <c>.local
- <c>.local
- <c>.local
- (<c>.tuple (<>.some <c>.any))))
+ (syntax (_ [[handler phase archive inputs] (<c>.form (all <>.and
+ <c>.local
+ <c>.local
+ <c>.local
+ (<c>.tuple (<>.some <c>.any))))
body <c>.any])
(let [g!handler (code.local handler)
- g!name (code.local extension)
g!phase (code.local phase)
g!archive (code.local archive)]
(with_symbols [g!inputs g!error g!_]
(in (list (` (<| (as <extension_type>)
(is <handler_type>)
- (.function ((, g!handler) (, g!name) (, g!phase) (, g!archive) (, g!inputs))
+ (.function ((, g!handler) (, g!phase) (, g!archive) (, g!inputs))
(.when (<result>
(monad.do <>.monad
[(,* inputs)