aboutsummaryrefslogtreecommitdiff
path: root/stdlib/source/library
diff options
context:
space:
mode:
authorEduardo Julian2022-08-17 13:26:39 -0400
committerEduardo Julian2022-08-17 13:26:39 -0400
commit52806bc618b7eee43bb1aa1300247c92e05b7ab1 (patch)
tree396c749c3d03ed0c3b781da3938f25e0b731573b /stdlib/source/library
parent261172e7a4cff7b9978eec4c0d32e963cbe7486e (diff)
Made the compiler's caching system sensitive to the build configuration.
Diffstat (limited to '')
-rw-r--r--stdlib/source/library/lux/control/maybe.lux13
-rw-r--r--stdlib/source/library/lux/control/try.lux53
-rw-r--r--stdlib/source/library/lux/data/collection/list.lux13
-rw-r--r--stdlib/source/library/lux/ffi.lux4
-rw-r--r--stdlib/source/library/lux/meta/compiler/default/platform.lux26
-rw-r--r--stdlib/source/library/lux/meta/compiler/meta/archive.lux35
-rw-r--r--stdlib/source/library/lux/meta/compiler/meta/cache/archive.lux8
-rw-r--r--stdlib/source/library/lux/meta/compiler/meta/io/archive.lux2
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}