diff options
Diffstat (limited to 'stdlib/source/library')
8 files changed, 83 insertions, 71 deletions
diff --git a/stdlib/source/library/lux/control/maybe.lux b/stdlib/source/library/lux/control/maybe.lux index f760d517d..6ce448249 100644 --- a/stdlib/source/library/lux/control/maybe.lux +++ b/stdlib/source/library/lux/control/maybe.lux @@ -156,12 +156,7 @@ (.list))) (def .public when - (macro (_ tokens state) - (.when tokens - (.list test then) - {.#Right [state (.list (` (.if (, test) - (, then) - {.#None})))]} - - _ - {.#Left "Wrong syntax for 'when'"}))) + (template (_ <test> <then>) + [(if <test> + <then> + {.#None})])) diff --git a/stdlib/source/library/lux/control/try.lux b/stdlib/source/library/lux/control/try.lux index a27c466a6..419f3525d 100644 --- a/stdlib/source/library/lux/control/try.lux +++ b/stdlib/source/library/lux/control/try.lux @@ -135,35 +135,40 @@ {#Success value} {.#None} - {#Failure (`` (("lux in-module" (,, (static .prelude)) .symbol#encoded) - (symbol ..of_maybe)))})) + {#Failure (`` (("lux in-module" (,, (static .prelude)) .symbol#encoded) (symbol ..of_maybe)))})) -(def .public else +(def generated_symbol (macro (_ tokens compiler) (.when tokens - (list else try) - {#Success [compiler (list (` (.when (, try) - {..#Success (,' g!temp)} - (,' g!temp) + (list [_ {.#Text prefix}]) + (let [generated_symbol (`` ("lux in-module" (,, (static .prelude)) .generated_symbol))] + (.when (generated_symbol prefix compiler) + {#Success [compiler g!_]} + {#Success [compiler (list g!_)]} - ... {..#Failure (,' g!temp)} - (,' g!temp) - (, else))))]} + {#Failure error} + {#Failure error})) _ - {#Failure "Wrong syntax for 'else'"}))) + (undefined)))) -(def .public when - (macro (_ tokens state) - (.when tokens - (.list test then) - (let [code#encoded ("lux in-module" "library/lux" .code#encoded) - text$ ("lux in-module" "library/lux" .text$)] - {.#Right [state (.list (` (.if (, test) - (, then) - {..#Failure (, (text$ (all "lux text concat" - "[" (code#encoded (` .when)) "]" - " " "Invalid condition:")))})))]}) +(def .public else + (with_expansions [g!then (generated_symbol "g!then") + g!failure (generated_symbol "g!failure")] + (template (_ <else> <try>) + [(.when <try> + {..#Success g!then} + g!then - _ - {.#Left "Wrong syntax for 'when'"}))) + ... {..#Failure g!failure} + g!failure + <else>)]))) + +(def .public when + (template (_ <test> <then>) + [(if <test> + <then> + {..#Failure (let [symbol#encoded (`` ("lux in-module" (,, (static .prelude)) .symbol#encoded))] + (all "lux text concat" + "[" (symbol#encoded (symbol ..when)) "]" + " " "Invalid condition!"))})])) diff --git a/stdlib/source/library/lux/data/collection/list.lux b/stdlib/source/library/lux/data/collection/list.lux index cddf68036..f6850e380 100644 --- a/stdlib/source/library/lux/data/collection/list.lux +++ b/stdlib/source/library/lux/data/collection/list.lux @@ -629,15 +629,10 @@ {.#Item [idx x] (again (++ idx) xs')}))) (def .public when - (macro (_ tokens state) - (.when tokens - (list test then) - {.#Right [state (.list (` (.if (, test) - (, then) - (.list))))]} - - _ - {.#Left (wrong_syntax_error ..when)}))) + (template (_ <test> <then>) + [(if <test> + <then> + (list))])) (def .public (revised item revision it) (All (_ a) (-> Nat (-> a a) (List a) (List a))) diff --git a/stdlib/source/library/lux/ffi.lux b/stdlib/source/library/lux/ffi.lux index bac9d29bd..ce459e663 100644 --- a/stdlib/source/library/lux/ffi.lux +++ b/stdlib/source/library/lux/ffi.lux @@ -182,7 +182,9 @@ value <code>.any object <code>.any]) (in (list (` (.as .Any (<set> (, field) (, value) (, object)))))))) - ))) + )) + ... else + (these)) (with_expansions [<constant> (for @.js "js constant" @.python "python constant" diff --git a/stdlib/source/library/lux/meta/compiler/default/platform.lux b/stdlib/source/library/lux/meta/compiler/default/platform.lux index d3a60d7b4..e91468af4 100644 --- a/stdlib/source/library/lux/meta/compiler/default/platform.lux +++ b/stdlib/source/library/lux/meta/compiler/default/platform.lux @@ -703,11 +703,11 @@ (let [instancer (//init.compiler program global phase_wrapper expander syntax.prelude (the #write platform) program_module program_definition)] (instancer $.key (list)))) - (def (custom_compiler import context platform compilation_sources compiler - custom_key custom_format custom_compilation) + (def (custom_compiler import context platform compilation_sources configuration + compiler custom_key custom_format custom_compilation) (All (_ <type_vars> state document object) - (-> Import context.Context <Platform> (List _io.Context) (///.Compiler <State+> .Module Any) + (-> Import context.Context <Platform> (List _io.Context) Configuration (///.Compiler <State+> .Module Any) (Key document) (Format document) (///.Compilation state document object) (-> (List ///.Custom) descriptor.Module Lux_Importer module.ID (..Context state) descriptor.Module (..Return state)))) (function (_ customs importer import! @module [archive state] module) @@ -741,12 +741,12 @@ {try.#Failure error} (do ! - [_ (cache/archive.cache! (the #file_system platform) context archive)] + [_ (cache/archive.cache! (the #file_system platform) configuration context archive)] (async#in {try.#Failure error}))))))) - (def (lux_compiler import context platform compilation_sources compiler compilation) + (def (lux_compiler import context platform compilation_sources configuration compiler compilation) (All (_ <type_vars>) - (-> Import context.Context <Platform> (List _io.Context) (///.Compiler <State+> .Module Any) + (-> Import context.Context <Platform> (List _io.Context) Configuration (///.Compiler <State+> .Module Any) (///.Compilation <State+> .Module Any) Lux_Compiler)) (function (_ customs importer import! @module [archive state] module) @@ -791,7 +791,7 @@ {try.#Failure error} (do ! - [_ (cache/archive.cache! (the #file_system platform) context archive)] + [_ (cache/archive.cache! (the #file_system platform) configuration context archive)] (async#in {try.#Failure error}))))))) (for @.old (these (def Fake_State @@ -807,9 +807,9 @@ {.#Primitive (%.nat (static.random_nat)) (list)})) (these)) - (def (serial_compiler import context platform compilation_sources compiler) + (def (serial_compiler import context platform compilation_sources configuration compiler) (All (_ <type_vars>) - (-> Import context.Context <Platform> (List _io.Context) (///.Compiler <State+> .Module Any) + (-> Import context.Context <Platform> (List _io.Context) Configuration (///.Compiler <State+> .Module Any) Lux_Compiler)) (function (_ all_customs importer import! @module [archive lux_state] module) (do [! (try.with async.monad)] @@ -824,7 +824,7 @@ all_customs)]) (when customs {.#End} - ((..lux_compiler import context platform compilation_sources compiler (compiler input)) + ((..lux_compiler import context platform compilation_sources configuration compiler (compiler input)) all_customs importer import! @module [archive lux_state] module) {.#Item [custom_state custom_key custom_format custom_parser custom_compiler] tail} @@ -834,8 +834,8 @@ {try.#Success custom_compilation} (do ! - [[archive' custom_state'] ((..custom_compiler import context platform compilation_sources compiler - custom_key custom_format custom_compilation) + [[archive' custom_state'] ((..custom_compiler import context platform compilation_sources configuration + compiler custom_key custom_format custom_compilation) all_customs importer import! @module [archive custom_state] module)] (in [archive' lux_state])))))))) @@ -878,7 +878,7 @@ Lux_Return)) (let [[host_dependencies libraries compilers sources target program_module program_definition configuration] compilation import! (|> (..compiler program global phase_wrapper expander platform program_module program_definition) - (serial_compiler import file_context platform sources) + (serial_compiler import file_context platform sources configuration) (..parallel context))] (do [! ..monad] [customs (|> compilers diff --git a/stdlib/source/library/lux/meta/compiler/meta/archive.lux b/stdlib/source/library/lux/meta/compiler/meta/archive.lux index f492ed908..994b6cd4b 100644 --- a/stdlib/source/library/lux/meta/compiler/meta/archive.lux +++ b/stdlib/source/library/lux/meta/compiler/meta/archive.lux @@ -26,6 +26,7 @@ [number ["n" nat (.use "[1]#[0]" equivalence)]]] [meta + ["[0]" configuration (.only Configuration)] [type [primitive (.except)]]]]] [/ @@ -216,14 +217,15 @@ (type Reservation [descriptor.Module module.ID]) - + (type Frozen - [Version module.ID (List Reservation)]) + [Version Configuration module.ID (List Reservation)]) - (def reader + (def parser (Parser ..Frozen) (all <>.and <binary>.nat + (<binary>.list (<>.and <binary>.text <binary>.text)) <binary>.nat (<binary>.list (<>.and <binary>.text <binary>.nat)))) @@ -231,11 +233,12 @@ (Format ..Frozen) (all \\format.and \\format.nat + (\\format.list (\\format.and \\format.text \\format.text)) \\format.nat (\\format.list (\\format.and \\format.text \\format.nat)))) - (def .public (export version archive) - (-> Version Archive Binary) + (def .public (export version configuration archive) + (-> Version Configuration Archive Binary) (let [(open "/[0]") (representation archive)] (|> /#resolver dictionary.entries @@ -243,7 +246,7 @@ (when descriptor+document {.#Some _} {.#Some [module id]} {.#None} {.#None}))) - [version /#next] + [version configuration /#next] (\\format.result ..format)))) (exception.def .public (version_mismatch [expected actual]) @@ -252,12 +255,22 @@ (list ["Expected" (%.nat expected)] ["Actual" (%.nat actual)]))) - (def .public (import expected binary) - (-> Version Binary (Try Archive)) + (exception.def .public (configuration_mismatch [expected actual]) + (Exception [Configuration Configuration]) + (exception.report + (list ["Expected" (configuration.format expected)] + ["Actual" (configuration.format actual)]))) + + (def .public (import expected_version expected_configuration binary) + (-> Version Configuration Binary (Try Archive)) (do try.monad - [[actual next reservations] (<binary>.result ..reader binary) - _ (exception.assertion ..version_mismatch [expected actual] - (n#= expected actual))] + [[actual_version actual_configuration next reservations] (<binary>.result ..parser binary) + _ (exception.assertion ..version_mismatch [expected_version actual_version] + (n#= expected_version actual_version)) + _ (exception.assertion ..configuration_mismatch [expected_configuration actual_configuration] + (at configuration.equivalence = + expected_configuration + actual_configuration))] (in (abstraction [#next next #resolver (list#mix (function (_ [module id] archive) diff --git a/stdlib/source/library/lux/meta/compiler/meta/cache/archive.lux b/stdlib/source/library/lux/meta/compiler/meta/cache/archive.lux index 4174ebbe6..214aeffd6 100644 --- a/stdlib/source/library/lux/meta/compiler/meta/cache/archive.lux +++ b/stdlib/source/library/lux/meta/compiler/meta/cache/archive.lux @@ -6,6 +6,8 @@ [data [text ["%" \\format]]] + [meta + ["[0]" configuration (.only Configuration)]] [world ["[0]" file]]]] ["[0]" // (.only) @@ -19,6 +21,6 @@ (at fs separator) "descriptor")) -(def .public (cache! fs context it) - (All (_ !) (-> (file.System !) Context Archive (! (Try Any)))) - (at fs write (..descriptor fs context) (archive.export ///.version it))) +(def .public (cache! fs configuration context it) + (All (_ !) (-> (file.System !) Configuration Context Archive (! (Try Any)))) + (at fs write (..descriptor fs context) (archive.export ///.version configuration it))) diff --git a/stdlib/source/library/lux/meta/compiler/meta/io/archive.lux b/stdlib/source/library/lux/meta/compiler/meta/io/archive.lux index 40e32ad80..29b8539ac 100644 --- a/stdlib/source/library/lux/meta/compiler/meta/io/archive.lux +++ b/stdlib/source/library/lux/meta/compiler/meta/io/archive.lux @@ -383,7 +383,7 @@ (when binary {try.#Success binary} (do (try.with async.monad) - [archive (async#in (archive.import ///.version binary))] + [archive (async#in (archive.import ///.version configuration binary))] (..load_every_reserved_module customs configuration host_environment fs context import contexts archive)) {try.#Failure error} |