diff options
author | Eduardo Julian | 2015-03-10 01:39:35 -0400 |
---|---|---|
committer | Eduardo Julian | 2015-03-10 01:39:35 -0400 |
commit | e2fcc7ebbb1f423a3137aa5525b9409f870fe191 (patch) | |
tree | a9765d5d44be59bae48b1a411444f1112b1a00a4 /src/lux/compiler/case.clj | |
parent | a386d0c4688b8749db3e4d612658774a24bc61a2 (diff) |
- Modified the compiler so parser syntax tokens are stored in the same format as lux data-structures, to ease communication between the compiler & macros.
Diffstat (limited to 'src/lux/compiler/case.clj')
-rw-r--r-- | src/lux/compiler/case.clj | 28 |
1 files changed, 16 insertions, 12 deletions
diff --git a/src/lux/compiler/case.clj b/src/lux/compiler/case.clj index 37fe6c61f..4f39e5c66 100644 --- a/src/lux/compiler/case.clj +++ b/src/lux/compiler/case.clj @@ -1,7 +1,8 @@ (ns lux.compiler.case (:require (clojure [set :as set] [template :refer [do-template]]) - [clojure.core.match :refer [match]] + [clojure.core.match :as M :refer [match matchv]] + clojure.core.match.array (lux [base :as & :refer [exec return* return fail fail* repeat-m exhaust-m try-m try-all-m map-m reduce-m apply-m @@ -19,36 +20,39 @@ ;; [Utils] (defn ^:private ->match [$body register token] - (match token - [::&parser/Ident ?name] + (matchv ::M/objects [token] + [["Ident" ?name]] [(inc register) [::Pattern $body [::StoreMatch register]]] - [::&parser/Bool ?value] + [["Bool" ?value]] [register [::Pattern $body [::BoolMatch ?value]]] - [::&parser/Int ?value] + [["Int" ?value]] [register [::Pattern $body [::IntMatch ?value]]] - [::&parser/Real ?value] + [["Real" ?value]] [register [::Pattern $body [::RealMatch ?value]]] - [::&parser/Char ?value] + [["Char" ?value]] [register [::Pattern $body [::CharMatch ?value]]] - [::&parser/Text ?value] + [["Text" ?value]] [register [::Pattern $body [::TextMatch ?value]]] - [::&parser/Tuple ?members] + [["Tuple" ?members]] (let [[register* =members] (reduce (fn [[register =members] member] (let [[register* =member] (->match $body register member)] [register* (cons =member =members)])) - [register (list)] ?members)] + [register (list)] + (&/->seq ?members))] [register* [::Pattern $body [::TupleMatch (reverse =members)]]]) - [::&parser/Tag ?tag] + [["Tag" ?tag]] [register [::Pattern $body [::VariantMatch ?tag [::Pattern $body [::TupleMatch (list)]]]]] - [::&parser/Form ([[::&parser/Tag ?tag] ?value] :seq)] + [["Form" ["Cons" [["Tag" ?tag] + ["Cons" [?value + ["Nil" _]]]]]]] (let [[register* =value] (->match $body register ?value)] [register* [::Pattern $body [::VariantMatch ?tag =value]]]) |