diff options
Diffstat (limited to '')
| -rw-r--r-- | new-luxc/source/luxc/lang.lux | 13 | ||||
| -rw-r--r-- | new-luxc/source/luxc/lang/analysis/reference.lux | 57 | ||||
| -rw-r--r-- | new-luxc/source/luxc/lang/translation.lux | 3 | ||||
| -rw-r--r-- | stdlib/source/lux/lang/scope.lux (renamed from new-luxc/source/luxc/lang/scope.lux) | 44 | 
4 files changed, 23 insertions, 94 deletions
| diff --git a/new-luxc/source/luxc/lang.lux b/new-luxc/source/luxc/lang.lux index 28dd302c2..c4dff15ec 100644 --- a/new-luxc/source/luxc/lang.lux +++ b/new-luxc/source/luxc/lang.lux @@ -51,16 +51,3 @@      (if (n/= underflow idx)        output        (recur (n/dec idx) (format (|> (text.nth idx name) maybe.assume normalize-char) output))))) - -(exception: #export (Error {message Text}) -  message) - -(def: #export (with-error-tracking action) -  (All [a] (-> (Meta a) (Meta a))) -  (function (_ compiler) -    (case (action compiler) -      (#e.Error error) -      ((throw Error error) compiler) - -      output -      output))) diff --git a/new-luxc/source/luxc/lang/analysis/reference.lux b/new-luxc/source/luxc/lang/analysis/reference.lux deleted file mode 100644 index 56aba35de..000000000 --- a/new-luxc/source/luxc/lang/analysis/reference.lux +++ /dev/null @@ -1,57 +0,0 @@ -(.module: -  lux -  (lux (control monad) -       [macro] -       (macro [code]) -       (lang (type ["tc" check]))) -  (luxc ["&" lang] -        (lang ["&." scope] -              ["la" analysis #+ Analysis] -              [".L" variable #+ Variable]))) - -## [Analysers] -(def: (analyse-definition def-name) -  (-> Ident (Meta Analysis)) -  (do macro.Monad<Meta> -    [[actualT def-anns _] (&.with-error-tracking -                            (macro.find-def def-name))] -    (case (macro.get-symbol-ann (ident-for #.alias) def-anns) -      (#.Some real-def-name) -      (analyse-definition real-def-name) - -      _ -      (do @ -        [_ (&.infer actualT) -         def-name (macro.normalize def-name)] -        (wrap (code.symbol def-name)))))) - -(def: (analyse-variable var-name) -  (-> Text (Meta (Maybe Analysis))) -  (do macro.Monad<Meta> -    [?var (&scope.find var-name)] -    (case ?var -      (#.Some [actualT ref]) -      (do @ -        [_ (&.infer actualT)] -        (wrap (#.Some (` ((~ (code.int (variableL.from-ref ref)))))))) - -      #.None -      (wrap #.None)))) - -(def: #export (analyse-reference reference) -  (-> Ident (Meta Analysis)) -  (case reference -    ["" simple-name] -    (do macro.Monad<Meta> -      [?var (analyse-variable simple-name)] -      (case ?var -        (#.Some varA) -        (wrap varA) - -        #.None -        (do @ -          [this-module macro.current-module-name] -          (analyse-definition [this-module simple-name])))) - -    _ -    (analyse-definition reference))) diff --git a/new-luxc/source/luxc/lang/translation.lux b/new-luxc/source/luxc/lang/translation.lux index 99328a45f..0899eccf2 100644 --- a/new-luxc/source/luxc/lang/translation.lux +++ b/new-luxc/source/luxc/lang/translation.lux @@ -101,8 +101,7 @@                        (analyse macroC)))         [_macroT _macroM _macroV] (case macroA                                     [_ (#.Symbol macro-name)] -                                   (&.with-error-tracking -                                     (macro.find-def macro-name)) +                                   (macro.find-def macro-name)                                     _                                     (&.throw Invalid-Macro (%code code))) diff --git a/new-luxc/source/luxc/lang/scope.lux b/stdlib/source/lux/lang/scope.lux index 82d7803e2..45008ae24 100644 --- a/new-luxc/source/luxc/lang/scope.lux +++ b/stdlib/source/lux/lang/scope.lux @@ -6,36 +6,36 @@               [maybe "maybe/" Monad<Maybe>]               [product]               ["e" error] -             (coll [list "list/" Functor<List> Fold<List> Monoid<List>])) +             (coll [list "list/" Functor<List> Fold<List> Monoid<List>] +                   (dictionary [plist])))         [macro]) -  (luxc ["&" lang] -        (lang [".L" variable #+ Variable]))) +  (// [analysis #+ Variable]))  (type: Locals (Bindings Text [Type Nat])) -(type: Captured (Bindings Text [Type Ref])) +(type: Foreign (Bindings Text [Type Variable]))  (def: (is-local? name scope)    (-> Text Scope Bool)    (|> scope        (get@ [#.locals #.mappings]) -      (&.pl-contains? name))) +      (plist.contains? name)))  (def: (get-local name scope) -  (-> Text Scope (Maybe [Type Ref])) +  (-> Text Scope (Maybe [Type Variable]))    (|> scope        (get@ [#.locals #.mappings]) -      (&.pl-get name) +      (plist.get name)        (maybe/map (function (_ [type value]) -                   [type (#.Local value)])))) +                   [type (#analysis.Local value)]))))  (def: (is-captured? name scope)    (-> Text Scope Bool)    (|> scope        (get@ [#.captured #.mappings]) -      (&.pl-contains? name))) +      (plist.contains? name)))  (def: (get-captured name scope) -  (-> Text Scope (Maybe [Type Ref])) +  (-> Text Scope (Maybe [Type Variable]))    (loop [idx +0           mappings (get@ [#.captured #.mappings] scope)]      (case mappings @@ -44,8 +44,8 @@        (#.Cons [_name [_source-type _source-ref]] mappings')        (if (text/= name _name) -        (#.Some [_source-type (#.Captured idx)]) -        (recur (n/inc idx) mappings'))))) +        (#.Some [_source-type (#analysis.Foreign idx)]) +        (recur (inc idx) mappings')))))  (def: (is-ref? name scope)    (-> Text Scope Bool) @@ -53,7 +53,7 @@        (is-captured? name scope)))  (def: (get-ref name scope) -  (-> Text Scope (Maybe [Type Ref])) +  (-> Text Scope (Maybe [Type Variable]))    (case (get-local name scope)      (#.Some type)      (#.Some type) @@ -62,7 +62,7 @@      (get-captured name scope)))  (def: #export (find name) -  (-> Text (Meta (Maybe [Type Ref]))) +  (-> Text (Meta (Maybe [Type Variable])))    (function (_ compiler)      (let [[inner outer] (|> compiler                              (get@ #.scopes) @@ -74,13 +74,13 @@          (#.Cons top-outer _)          (let [[ref-type init-ref] (maybe.default (undefined)                                                   (get-ref name top-outer)) -              [ref inner'] (list/fold (: (-> Scope [Ref (List Scope)] [Ref (List Scope)]) +              [ref inner'] (list/fold (: (-> Scope [Variable (List Scope)] [Variable (List Scope)])                                           (function (_ scope ref+inner) -                                           [(#.Captured (get@ [#.captured #.counter] scope)) +                                           [(#analysis.Foreign (get@ [#.captured #.counter] scope))                                              (#.Cons (update@ #.captured -                                                             (: (-> Captured Captured) -                                                                (|>> (update@ #.counter n/inc) -                                                                     (update@ #.mappings (&.pl-put name [ref-type (product.left ref+inner)])))) +                                                             (: (-> Foreign Foreign) +                                                                (|>> (update@ #.counter inc) +                                                                     (update@ #.mappings (plist.put name [ref-type (product.left ref+inner)]))))                                                               scope)                                                      (product.right ref+inner))]))                                        [init-ref #.Nil] @@ -99,8 +99,8 @@              new-var-id (get@ [#.locals #.counter] head)              new-head (update@ #.locals                                (: (-> Locals Locals) -                                 (|>> (update@ #.counter n/inc) -                                      (update@ #.mappings (&.pl-put name [type new-var-id])))) +                                 (|>> (update@ #.counter inc) +                                      (update@ #.mappings (plist.put name [type new-var-id]))))                                head)]          (case (macro.run' (set@ #.scopes (#.Cons new-head tail) compiler)                            action) @@ -129,7 +129,7 @@        #.mappings (list)})]    [init-locals   Nat] -  [init-captured Ref] +  [init-captured Variable]    )  (def: (scope parent-name child-name) | 
