aboutsummaryrefslogtreecommitdiff
path: root/stdlib/source/lux/tool
diff options
context:
space:
mode:
authorEduardo Julian2020-04-16 00:22:24 -0400
committerEduardo Julian2020-04-16 00:22:24 -0400
commit1888b5c3288e4e7653a424e7314ea5c8277ab360 (patch)
treea40768d314bc610f9c17446d86e33eba44d5e6c8 /stdlib/source/lux/tool
parent4f1553c6f6bb579f09749d5b9ca955c43a7440a4 (diff)
Generating definition names in a new way.
Diffstat (limited to 'stdlib/source/lux/tool')
-rw-r--r--stdlib/source/lux/tool/compiler/default/init.lux25
-rw-r--r--stdlib/source/lux/tool/compiler/default/platform.lux3
-rw-r--r--stdlib/source/lux/tool/compiler/language/lux/analysis.lux7
-rw-r--r--stdlib/source/lux/tool/compiler/language/lux/directive.lux20
-rw-r--r--stdlib/source/lux/tool/compiler/language/lux/generation.lux17
-rw-r--r--stdlib/source/lux/tool/compiler/language/lux/phase/analysis/function.lux4
-rw-r--r--stdlib/source/lux/tool/compiler/language/lux/phase/analysis/inference.lux2
-rw-r--r--stdlib/source/lux/tool/compiler/language/lux/phase/analysis/module.lux9
-rw-r--r--stdlib/source/lux/tool/compiler/language/lux/phase/analysis/structure.lux4
-rw-r--r--stdlib/source/lux/tool/compiler/meta/archive.lux22
-rw-r--r--stdlib/source/lux/tool/compiler/meta/archive/artifact.lux10
11 files changed, 79 insertions, 44 deletions
diff --git a/stdlib/source/lux/tool/compiler/default/init.lux b/stdlib/source/lux/tool/compiler/default/init.lux
index 19a71742c..0b0acd8b0 100644
--- a/stdlib/source/lux/tool/compiler/default/init.lux
+++ b/stdlib/source/lux/tool/compiler/default/init.lux
@@ -115,15 +115,16 @@
(All [anchor expression directive]
(///directive.Operation anchor expression directive
[Source (///generation.Buffer directive)])))
- (///directive.lift-analysis
- (do ///phase.monad
- [#let [module (get@ #///.module input)]
- _ (module.create hash module)
- _ (///analysis.set-current-module module)
- _ (monad.map @ module.import dependencies)
- #let [source (///analysis.source (get@ #///.module input) (get@ #///.code input))]
- _ (///analysis.set-source-code source)]
- (wrap [source ///generation.empty-buffer]))))
+ (do ///phase.monad
+ [#let [module (get@ #///.module input)]
+ _ (///directive.set-current-module module)]
+ (///directive.lift-analysis
+ (do ///phase.monad
+ [_ (module.create hash module)
+ _ (monad.map @ module.import dependencies)
+ #let [source (///analysis.source (get@ #///.module input) (get@ #///.code input))]
+ _ (///analysis.set-source-code source)]
+ (wrap [source ///generation.empty-buffer])))))
(def: (end module)
(-> Module
@@ -194,7 +195,7 @@
(#try.Failure error)
(if (ex.match? ///syntax.end-of-file error)
(#try.Success [state #.None])
- (ex.with-stack ///.cannot-compile module (#try.Failure error)))))))
+ (ex.with ///.cannot-compile module (#try.Failure error)))))))
(def: (default-dependencies prelude input)
(-> Module ///.Input (List Module))
@@ -255,7 +256,9 @@
macro.current-module)
_ (///directive.lift-generation
(///generation.set-buffer temporary-buffer))
- _ (monad.map @ (execute! archive) (get@ #///directive.referrals requirements))
+ _ (|> requirements
+ (get@ #///directive.referrals)
+ (monad.map @ (execute! archive)))
temporary-buffer (..get-current-buffer temporary-buffer)]
(..iterate archive expander module source temporary-buffer (..module-aliases analysis-module))))))})])
)))))}))))
diff --git a/stdlib/source/lux/tool/compiler/default/platform.lux b/stdlib/source/lux/tool/compiler/default/platform.lux
index 51f4729c5..f51711289 100644
--- a/stdlib/source/lux/tool/compiler/default/platform.lux
+++ b/stdlib/source/lux/tool/compiler/default/platform.lux
@@ -216,8 +216,7 @@
_
## TODO: The "///analysis.set-current-module" below shouldn't be necessary. Remove it ASAP.
## TODO: The context shouldn't need to be re-set either.
- (|> (///analysis.set-current-module module)
- ///directive.lift-analysis
+ (|> (///directive.set-current-module module)
(///phase.run' state)
try.assume
product.left))
diff --git a/stdlib/source/lux/tool/compiler/language/lux/analysis.lux b/stdlib/source/lux/tool/compiler/language/lux/analysis.lux
index 6c081620c..8537064a4 100644
--- a/stdlib/source/lux/tool/compiler/language/lux/analysis.lux
+++ b/stdlib/source/lux/tool/compiler/language/lux/analysis.lux
@@ -343,15 +343,14 @@
(def: #export (with-stack exception message action)
(All [e o] (-> (Exception e) e (Operation o) (Operation o)))
(function (_ bundle,state)
- (case (action bundle,state)
+ (case (exception.with exception message
+ (action bundle,state))
(#try.Success output)
(#try.Success output)
(#try.Failure error)
(let [[bundle state] bundle,state]
- (#try.Failure (<| (locate-error (get@ #.cursor state))
- (exception.decorate (exception.construct exception message))
- error))))))
+ (#try.Failure (locate-error (get@ #.cursor state) error))))))
(template [<name> <type> <field> <value>]
[(def: #export (<name> value)
diff --git a/stdlib/source/lux/tool/compiler/language/lux/directive.lux b/stdlib/source/lux/tool/compiler/language/lux/directive.lux
index 2c1dd3be6..8a5e0172a 100644
--- a/stdlib/source/lux/tool/compiler/language/lux/directive.lux
+++ b/stdlib/source/lux/tool/compiler/language/lux/directive.lux
@@ -1,5 +1,7 @@
(.module:
[lux (#- Module)
+ [abstract
+ [monad (#+ do)]]
[data
[collection
["." list ("#@." monoid)]]]]
@@ -57,16 +59,24 @@
)
(template [<name> <component> <operation>]
- [(def: #export (<name> operation)
+ [(def: #export <name>
(All [anchor expression directive output]
(-> (<operation> output)
(Operation anchor expression directive output)))
- (extension.lift
- (phase.sub [(get@ [<component> #..state])
- (set@ [<component> #..state])]
- operation)))]
+ (|>> (phase.sub [(get@ [<component> #..state])
+ (set@ [<component> #..state])])
+ extension.lift))]
[lift-analysis #..analysis analysis.Operation]
[lift-synthesis #..synthesis synthesis.Operation]
[lift-generation #..generation (generation.Operation anchor expression directive)]
)
+
+(def: #export (set-current-module module)
+ (All [anchor expression directive output]
+ (-> Module (Operation anchor expression directive Any)))
+ (do phase.monad
+ [_ (..lift-analysis
+ (analysis.set-current-module module))]
+ (..lift-generation
+ (generation.enter-module module))))
diff --git a/stdlib/source/lux/tool/compiler/language/lux/generation.lux b/stdlib/source/lux/tool/compiler/language/lux/generation.lux
index 1cfd7db0f..84f4f35d4 100644
--- a/stdlib/source/lux/tool/compiler/language/lux/generation.lux
+++ b/stdlib/source/lux/tool/compiler/language/lux/generation.lux
@@ -4,7 +4,8 @@
[monad (#+ do)]]
[control
["." try (#+ Try)]
- ["." exception (#+ exception:)]]
+ ["." exception (#+ exception:)]
+ ["." function]]
[data
["." product]
["." name ("#@." equivalence)]
@@ -146,6 +147,11 @@
(-> Text (Operation anchor expression directive Text)))
(:: phase.monad map (|>> %.nat (format prefix)) ..next))
+(def: #export (enter-module module)
+ (All [anchor expression directive]
+ (-> Module (Operation anchor expression directive Any)))
+ (extension.update (set@ #module module)))
+
(template [<name> <inputT>]
[(def: #export (<name> label code)
(All [anchor expression directive]
@@ -200,9 +206,12 @@
(#try.Success [[bundle (set@ #registry registry' state)]
id]))))
-(exception: #export (unknown-definition {name Name})
+(exception: #export (unknown-definition {name Name}
+ {known-definitions (List Text)})
(exception.report
- ["Name" (%.name name)]))
+ ["Definition" (name.short name)]
+ ["Module" (name.module name)]
+ ["Known Definitions" (exception.enumerate function.identity known-definitions)]))
(def: #export (remember archive name)
(All [anchor expression directive]
@@ -217,7 +226,7 @@
(#try.Success (get@ #descriptor.registry descriptor))))]
(case (artifact.remember _name registry)
#.None
- (exception.throw ..unknown-definition name)
+ (exception.throw ..unknown-definition [name (artifact.definitions registry)])
(#.Some id)
(#try.Success [stateE [_module id]]))))))
diff --git a/stdlib/source/lux/tool/compiler/language/lux/phase/analysis/function.lux b/stdlib/source/lux/tool/compiler/language/lux/phase/analysis/function.lux
index a4b94ec4e..6bf5fcf06 100644
--- a/stdlib/source/lux/tool/compiler/language/lux/phase/analysis/function.lux
+++ b/stdlib/source/lux/tool/compiler/language/lux/phase/analysis/function.lux
@@ -44,7 +44,7 @@
(do ///.monad
[functionT (///extension.lift macro.expected-type)]
(loop [expectedT functionT]
- (/.with-stack cannot-analyse [expectedT function-name arg-name body]
+ (/.with-stack ..cannot-analyse [expectedT function-name arg-name body]
(case expectedT
(#.Named name unnamedT)
(recur unnamedT)
@@ -102,7 +102,7 @@
(def: #export (apply analyse argsC+ functionT functionA archive functionC)
(-> Phase (List Code) Type Analysis Phase)
- (<| (/.with-stack cannot-apply [functionT functionC argsC+])
+ (<| (/.with-stack ..cannot-apply [functionT functionC argsC+])
(do ///.monad
[[applyT argsA+] (//inference.general archive analyse functionT argsC+)])
(wrap (/.apply [functionA argsA+]))))
diff --git a/stdlib/source/lux/tool/compiler/language/lux/phase/analysis/inference.lux b/stdlib/source/lux/tool/compiler/language/lux/phase/analysis/inference.lux
index 9a1e07d7a..76315bb6c 100644
--- a/stdlib/source/lux/tool/compiler/language/lux/phase/analysis/inference.lux
+++ b/stdlib/source/lux/tool/compiler/language/lux/phase/analysis/inference.lux
@@ -157,7 +157,7 @@
(#.Function inputT outputT)
(do ///.monad
[[outputT' args'A] (general archive analyse outputT args')
- argA (<| (/.with-stack cannot-infer-argument [inputT argC])
+ argA (<| (/.with-stack ..cannot-infer-argument [inputT argC])
(//type.with-type inputT)
(analyse archive argC))]
(wrap [outputT' (list& argA args'A)]))
diff --git a/stdlib/source/lux/tool/compiler/language/lux/phase/analysis/module.lux b/stdlib/source/lux/tool/compiler/language/lux/phase/analysis/module.lux
index 1764dfdd6..9fae1fa1e 100644
--- a/stdlib/source/lux/tool/compiler/language/lux/phase/analysis/module.lux
+++ b/stdlib/source/lux/tool/compiler/language/lux/phase/analysis/module.lux
@@ -144,11 +144,10 @@
(-> Nat Text (Operation Any))
(///extension.lift
(function (_ state)
- (let [module (new hash)]
- (#try.Success [(update@ #.modules
- (plist.put name module)
- state)
- []])))))
+ (#try.Success [(update@ #.modules
+ (plist.put name (new hash))
+ state)
+ []]))))
(def: #export (with-module hash name action)
(All [a] (-> Nat Text (Operation a) (Operation [Module a])))
diff --git a/stdlib/source/lux/tool/compiler/language/lux/phase/analysis/structure.lux b/stdlib/source/lux/tool/compiler/language/lux/phase/analysis/structure.lux
index cd07f23c4..8d3c03628 100644
--- a/stdlib/source/lux/tool/compiler/language/lux/phase/analysis/structure.lux
+++ b/stdlib/source/lux/tool/compiler/language/lux/phase/analysis/structure.lux
@@ -94,7 +94,7 @@
[expectedT (///extension.lift macro.expected-type)
expectedT' (//type.with-env
(check.clean expectedT))]
- (/.with-stack cannot-analyse-variant [expectedT' tag valueC]
+ (/.with-stack ..cannot-analyse-variant [expectedT' tag valueC]
(case expectedT
(#.Sum _)
(let [flat (type.flatten-variant expectedT)
@@ -199,7 +199,7 @@
(-> Archive Phase (List Code) (Operation Analysis))
(do ///.monad
[expectedT (///extension.lift macro.expected-type)]
- (/.with-stack cannot-analyse-tuple [expectedT membersC]
+ (/.with-stack ..cannot-analyse-tuple [expectedT membersC]
(case expectedT
(#.Product _)
(..typed-product archive analyse membersC)
diff --git a/stdlib/source/lux/tool/compiler/meta/archive.lux b/stdlib/source/lux/tool/compiler/meta/archive.lux
index a7e1ffe16..edab30124 100644
--- a/stdlib/source/lux/tool/compiler/meta/archive.lux
+++ b/stdlib/source/lux/tool/compiler/meta/archive.lux
@@ -5,7 +5,8 @@
["." monad (#+ do)]]
[control
["." try (#+ Try)]
- ["ex" exception (#+ exception:)]]
+ ["." exception (#+ exception:)]
+ ["." function]]
[data
["." name]
["." text]
@@ -21,15 +22,19 @@
["." descriptor (#+ Module Descriptor)]
["." document (#+ Document)]])
-(exception: #export (unknown-document {module Module})
- (ex.report ["Module" module]))
+(exception: #export (unknown-document {module Module}
+ {known-modules (List Module)})
+ (exception.report
+ ["Module" module]
+ ["Known Modules" (exception.enumerate function.identity known-modules)]))
(exception: #export (cannot-replace-document {module Module}
{old (Document Any)}
{new (Document Any)})
- (ex.report ["Module" module]
- ["Old key" (signature.description (document.signature old))]
- ["New key" (signature.description (document.signature new))]))
+ (exception.report
+ ["Module" module]
+ ["Old key" (signature.description (document.signature old))]
+ ["New key" (signature.description (document.signature new))]))
(abstract: #export Archive
{}
@@ -46,7 +51,7 @@
(#.Some [existing-descriptor existing-document])
(if (is? document existing-document)
(#try.Success archive)
- (ex.throw cannot-replace-document [module existing-document document]))
+ (exception.throw cannot-replace-document [module existing-document document]))
#.None
(#try.Success (|> archive
@@ -61,7 +66,8 @@
(#try.Success document)
#.None
- (ex.throw unknown-document [module])))
+ (exception.throw ..unknown-document [module
+ (dictionary.keys (:representation archive))])))
(def: #export (archived? archive module)
(-> Archive Module Bit)
diff --git a/stdlib/source/lux/tool/compiler/meta/archive/artifact.lux b/stdlib/source/lux/tool/compiler/meta/archive/artifact.lux
index 534749ace..256c10a22 100644
--- a/stdlib/source/lux/tool/compiler/meta/archive/artifact.lux
+++ b/stdlib/source/lux/tool/compiler/meta/archive/artifact.lux
@@ -3,6 +3,7 @@
[data
["." text]
[collection
+ ["." list]
["." row (#+ Row)]
["." dictionary (#+ Dictionary)]]]
[type
@@ -46,8 +47,17 @@
(update@ #next inc)
(update@ #artifacts (row.add {#id id
#name (#.Some name)}))
+ (update@ #resolver (dictionary.put name id))
:abstraction)]))
+ (def: #export (definitions registry)
+ (-> Registry (List Text))
+ (|> registry
+ :representation
+ (get@ #artifacts)
+ row.to-list
+ (list.search-all (get@ #name))))
+
(def: #export (remember name registry)
(-> Text Registry (Maybe ID))
(|> (:representation registry)