From 7b74c1258f345d576b0c798303b0ed28f1734368 Mon Sep 17 00:00:00 2001 From: Eduardo Julian Date: Sun, 7 May 2017 20:45:54 -0400 Subject: - Added custom equalities for a variety of collections. --- stdlib/source/lux/macro/poly.lux | 39 +++++++++++++++++++++++-------------- stdlib/source/lux/macro/poly/eq.lux | 34 +++++++++++++++++++++++++++++--- 2 files changed, 55 insertions(+), 18 deletions(-) (limited to 'stdlib') diff --git a/stdlib/source/lux/macro/poly.lux b/stdlib/source/lux/macro/poly.lux index 24e9c0be9..ecf5e2019 100644 --- a/stdlib/source/lux/macro/poly.lux +++ b/stdlib/source/lux/macro/poly.lux @@ -1,5 +1,5 @@ (;module: - [lux #- list function] + [lux #- function] (lux (control monad [eq]) (data [text] @@ -10,7 +10,8 @@ [product] [bool] [char] - [maybe]) + [maybe] + [ident "Ident/" Eq]) [macro #+ Monad with-gensyms] (macro [code] ["s" syntax #+ syntax: Syntax] @@ -209,21 +210,29 @@ _ (wrap [:func: (list;reverse :args:)]))))) -(do-template [ ] - [(def: #export - (Matcher Type) - (;function [:type:] - (case (type;un-name :type:) - (^=> (#;App :quant: :arg:) - [(type;un-alias :quant:) (#;Named ["lux" ] _)]) - (:: macro;Monad wrap :arg:) +(def: #export (apply-1 name) + (-> Ident (Matcher Type)) + (;function [:type:] + (case (type;un-name :type:) + (^=> (#;App :quant: :arg:) + [(type;un-alias :quant:) (#;Named actual _)] + (Ident/= name actual)) + (:: macro;Monad wrap :arg:) - _ - (macro;fail (format "Not " " type: " (%type :type:))))))] + _ + (macro;fail (format "Not " (%ident name) " type: " (%type :type:)))))) - [maybe "Maybe"] - [list "List"] - ) +(def: #export (apply-2 name) + (-> Ident (Matcher [Type Type])) + (;function [:type:] + (case (type;un-name :type:) + (^=> (#;App (#;App :quant: :arg0:) :arg1:) + [(type;un-alias :quant:) (#;Named actual _)] + (Ident/= name actual)) + (:: macro;Monad wrap [:arg0: :arg1:]) + + _ + (macro;fail (format "Not " (%ident name) " type: " (%type :type:)))))) (def: (adjusted-idx env idx) (-> Env Nat Nat) diff --git a/stdlib/source/lux/macro/poly/eq.lux b/stdlib/source/lux/macro/poly/eq.lux index f1a184c85..953891e1c 100644 --- a/stdlib/source/lux/macro/poly/eq.lux +++ b/stdlib/source/lux/macro/poly/eq.lux @@ -5,7 +5,13 @@ (data [text] text/format (coll [list "List/" Monad] - [dict #+ Dict]) + [vector] + [array] + [queue] + [set] + [seq] + [dict #+ Dict] + (tree [rose])) [number] [product] [bool] @@ -46,13 +52,35 @@ [Bool poly;bool bool;Eq] [Nat poly;nat number;Eq] [Int poly;int number;Eq] - [Deg poly;deg number;Eq] + [Deg poly;deg number;Eq] [Real poly;real number;Eq] [Char poly;char char;Eq] - [Text poly;text text;Eq])] + [Text poly;text text;Eq]) + (do-template [ ] + [(do @ + [:arg: (poly;apply-1 (ident-for ) :x:) + g!arg (Eq env :arg:)] + (wrap (` (: (~ (->Eq (type;to-ast :x:))) + ( (~ g!arg))))))] + + [list;List list;Eq] + [vector;Vector vector;Eq] + [array;Array array;Eq] + [queue;Queue queue;Eq] + [set;Set set;Eq] + [seq;Seq seq;Eq] + [rose;Tree rose;Eq] + )] ($_ macro;either ## Primitive types + ## Composite types + + (do @ + [[:key: :val:] (poly;apply-2 (ident-for dict;Dict) :x:) + g!val (Eq env :val:)] + (wrap (` (: (~ (->Eq (type;to-ast :x:))) + (dict;Eq (~ g!val)))))) ## Variants (with-gensyms [g!type-fun g!left g!right] (do @ -- cgit v1.2.3