From 0e2121dbec4f61dc1d9404deb9dd2b3f401ba4df Mon Sep 17 00:00:00 2001 From: Eduardo Julian Date: Sat, 7 Sep 2019 21:07:03 -0400 Subject: Moved polytypic code generators to their own branch. --- stdlib/source/lux/macro/poly/equivalence.lux | 162 ------------ stdlib/source/lux/macro/poly/functor.lux | 103 -------- stdlib/source/lux/macro/poly/json.lux | 333 ------------------------ stdlib/source/poly/lux/abstract/equivalence.lux | 163 ++++++++++++ stdlib/source/poly/lux/abstract/functor.lux | 104 ++++++++ stdlib/source/poly/lux/data/format/json.lux | 333 ++++++++++++++++++++++++ 6 files changed, 600 insertions(+), 598 deletions(-) delete mode 100644 stdlib/source/lux/macro/poly/equivalence.lux delete mode 100644 stdlib/source/lux/macro/poly/functor.lux delete mode 100644 stdlib/source/lux/macro/poly/json.lux create mode 100644 stdlib/source/poly/lux/abstract/equivalence.lux create mode 100644 stdlib/source/poly/lux/abstract/functor.lux create mode 100644 stdlib/source/poly/lux/data/format/json.lux diff --git a/stdlib/source/lux/macro/poly/equivalence.lux b/stdlib/source/lux/macro/poly/equivalence.lux deleted file mode 100644 index 159593800..000000000 --- a/stdlib/source/lux/macro/poly/equivalence.lux +++ /dev/null @@ -1,162 +0,0 @@ -(.module: - [lux #* - [abstract - [monad (#+ Monad do)] - ["/" equivalence]] - [control - ["p" parser - ["<.>" type] - ["s" code (#+ Parser)]]] - [data - ["." product] - ["." bit] - ["." maybe] - [number - ["." nat ("#@." decimal)] - ["." int] - ["." rev] - ["." frac]] - ["." text ("#@." monoid) - ["%" format (#+ format)]] - [collection - ["." list ("#@." monad)] - ["." row] - ["." array] - ["." queue] - ["." set] - ["." dictionary (#+ Dictionary)] - ["." tree]]] - [time - ["." duration] - ["." date] - ["." instant] - ["." day] - ["." month]] - ["." macro - ["." code] - [syntax (#+ syntax:) - ["." common]] - ["." poly (#+ poly:)]] - ["." type - ["." unit]]]) - -(poly: #export equivalence - (`` (do @ - [#let [g!_ (code.local-identifier "_____________")] - *env* .env - inputT .peek - #let [@Equivalence (: (-> Type Code) - (function (_ type) - (` ((~! /.Equivalence) (~ (poly.to-code *env* type))))))]] - ($_ p.either - ## Basic types - (~~ (template [ ] - [(do @ - [_ ] - (wrap (` (: (~ (@Equivalence inputT)) - ))))] - - [(.exactly Any) (function ((~ g!_) (~ g!_) (~ g!_)) #1)] - [(.sub Bit) (~! bit.equivalence)] - [(.sub Nat) (~! nat.equivalence)] - [(.sub Int) (~! int.equivalence)] - [(.sub Rev) (~! rev.equivalence)] - [(.sub Frac) (~! frac.equivalence)] - [(.sub Text) (~! text.equivalence)])) - ## Composite types - (~~ (template [ ] - [(do @ - [[_ argC] (.apply (p.and (.exactly ) - equivalence))] - (wrap (` (: (~ (@Equivalence inputT)) - ( (~ argC))))))] - - [.Maybe (~! maybe.equivalence)] - [.List (~! list.equivalence)] - [row.Row (~! row.equivalence)] - [array.Array (~! array.equivalence)] - [queue.Queue (~! queue.equivalence)] - [set.Set (~! set.equivalence)] - [tree.Tree (~! tree.equivalence)] - )) - (do @ - [[_ _ valC] (.apply ($_ p.and - (.exactly dictionary.Dictionary) - .any - equivalence))] - (wrap (` (: (~ (@Equivalence inputT)) - ((~! dictionary.equivalence) (~ valC)))))) - ## Models - (~~ (template [ ] - [(do @ - [_ (.exactly )] - (wrap (` (: (~ (@Equivalence inputT)) - ))))] - - [duration.Duration duration.equivalence] - [instant.Instant instant.equivalence] - [date.Date date.equivalence] - [day.Day day.equivalence] - [month.Month month.equivalence] - )) - (do @ - [_ (.apply (p.and (.exactly unit.Qty) - .any))] - (wrap (` (: (~ (@Equivalence inputT)) - unit.equivalence)))) - ## Variants - (do @ - [members (.variant (p.many equivalence)) - #let [g!_ (code.local-identifier "_____________") - g!left (code.local-identifier "_____________left") - g!right (code.local-identifier "_____________right")]] - (wrap (` (: (~ (@Equivalence inputT)) - (function ((~ g!_) (~ g!left) (~ g!right)) - (case [(~ g!left) (~ g!right)] - (~+ (list@join (list@map (function (_ [tag g!eq]) - (list (` [((~ (code.nat tag)) (~ g!left)) - ((~ (code.nat tag)) (~ g!right))]) - (` ((~ g!eq) (~ g!left) (~ g!right))))) - (list.enumerate members)))) - (~ g!_) - #0)))))) - ## Tuples - (do @ - [g!eqs (.tuple (p.many equivalence)) - #let [g!_ (code.local-identifier "_____________") - indices (list.indices (list.size g!eqs)) - g!lefts (list@map (|>> nat@encode (text@compose "left") code.local-identifier) indices) - g!rights (list@map (|>> nat@encode (text@compose "right") code.local-identifier) indices)]] - (wrap (` (: (~ (@Equivalence inputT)) - (function ((~ g!_) [(~+ g!lefts)] [(~+ g!rights)]) - (and (~+ (|> (list.zip3 g!eqs g!lefts g!rights) - (list@map (function (_ [g!eq g!left g!right]) - (` ((~ g!eq) (~ g!left) (~ g!right))))))))))))) - ## Type recursion - (do @ - [[g!self bodyC] (.recursive equivalence) - #let [g!_ (code.local-identifier "_____________")]] - (wrap (` (: (~ (@Equivalence inputT)) - ((~! /.rec) (.function ((~ g!_) (~ g!self)) - (~ bodyC))))))) - .recursive-self - ## Type applications - (do @ - [[funcC argsC] (.apply (p.and equivalence (p.many equivalence)))] - (wrap (` ((~ funcC) (~+ argsC))))) - ## Parameters - .parameter - ## Polymorphism - (do @ - [[funcC varsC bodyC] (.polymorphic equivalence)] - (wrap (` (: (All [(~+ varsC)] - (-> (~+ (list@map (|>> (~) ((~! /.Equivalence)) (`)) varsC)) - ((~! /.Equivalence) ((~ (poly.to-code *env* inputT)) (~+ varsC))))) - (function ((~ funcC) (~+ varsC)) - (~ bodyC)))))) - .recursive-call - ## If all else fails... - (|> .any - (:: @ map (|>> %.type (format "Cannot create Equivalence for: ") p.fail)) - (:: @ join)) - )))) diff --git a/stdlib/source/lux/macro/poly/functor.lux b/stdlib/source/lux/macro/poly/functor.lux deleted file mode 100644 index 5ccb65463..000000000 --- a/stdlib/source/lux/macro/poly/functor.lux +++ /dev/null @@ -1,103 +0,0 @@ -(.module: - [lux #* - [abstract - [monad (#+ Monad do)] - ["." functor]] - [control - ["p" parser - ["<.>" type] - ["s" code (#+ Parser)]]] - [data - ["." product] - [number - ["n" nat]] - ["." text - ["%" format (#+ format)]] - [collection - ["." list ("#;." monad monoid)]]] - ["." macro - ["." code] - [syntax (#+ syntax:) - ["." common]] - ["." poly (#+ poly:)]] - ["." type]]) - -(poly: #export functor - (do @ - [#let [type-funcC (code.local-identifier "____________type-funcC") - funcC (code.local-identifier "____________funcC") - inputC (code.local-identifier "____________inputC")] - *env* .env - inputT .peek - [polyC varsC non-functorT] (.local (list inputT) - (.polymorphic .any)) - #let [num-vars (list.size varsC)] - #let [@Functor (: (-> Type Code) - (function (_ unwrappedT) - (if (n.= 1 num-vars) - (` ((~! functor.Functor) (~ (poly.to-code *env* unwrappedT)))) - (let [paramsC (|> num-vars dec list.indices (list;map (|>> %.nat code.local-identifier)))] - (` (All [(~+ paramsC)] - ((~! functor.Functor) ((~ (poly.to-code *env* unwrappedT)) (~+ paramsC))))))))) - Arg (: (-> Code (.Parser Code)) - (function (Arg valueC) - ($_ p.either - ## Type-var - (do p.monad - [#let [varI (|> num-vars (n.* 2) dec)] - _ (.parameter! varI)] - (wrap (` ((~ funcC) (~ valueC))))) - ## Variants - (do @ - [_ (wrap []) - membersC (.variant (p.many (Arg valueC)))] - (wrap (` (case (~ valueC) - (~+ (list;join (list;map (function (_ [tag memberC]) - (list (` ((~ (code.nat tag)) (~ valueC))) - (` ((~ (code.nat tag)) (~ memberC))))) - (list.enumerate membersC)))))))) - ## Tuples - (do p.monad - [pairsCC (: (.Parser (List [Code Code])) - (.tuple (loop [idx 0 - pairsCC (: (List [Code Code]) - (list))] - (p.either (let [slotC (|> idx %.nat (format "____________slot") code.local-identifier)] - (do @ - [_ (wrap []) - memberC (Arg slotC)] - (recur (inc idx) - (list;compose pairsCC (list [slotC memberC]))))) - (wrap pairsCC)))))] - (wrap (` (case (~ valueC) - [(~+ (list;map product.left pairsCC))] - [(~+ (list;map product.right pairsCC))])))) - ## Functions - (do @ - [_ (wrap []) - #let [g! (code.local-identifier "____________") - outL (code.local-identifier "____________outL")] - [inT+ outC] (.function (p.many .any) - (Arg outL)) - #let [inC+ (|> (list.size inT+) - list.indices - (list;map (|>> %.nat (format "____________inC") code.local-identifier)))]] - (wrap (` (function ((~ g!) (~+ inC+)) - (let [(~ outL) ((~ valueC) (~+ inC+))] - (~ outC)))))) - ## Recursion - (do p.monad - [_ .recursive-call] - (wrap (` ((~' map) (~ funcC) (~ valueC))))) - ## Parameters - (do p.monad - [_ .any] - (wrap valueC)) - )))] - [_ _ outputC] (: (.Parser [Code (List Code) Code]) - (p.either (.polymorphic - (Arg inputC)) - (p.fail (format "Cannot create Functor for: " (%.type inputT)))))] - (wrap (` (: (~ (@Functor inputT)) - (structure (def: ((~' map) (~ funcC) (~ inputC)) - (~ outputC)))))))) diff --git a/stdlib/source/lux/macro/poly/json.lux b/stdlib/source/lux/macro/poly/json.lux deleted file mode 100644 index a621f0d20..000000000 --- a/stdlib/source/lux/macro/poly/json.lux +++ /dev/null @@ -1,333 +0,0 @@ -(.module: {#.doc "Codecs for values in the JSON format."} - [lux #* - [abstract - [monad (#+ Monad do)] - [equivalence (#+ Equivalence)] - ["." codec]] - [control - ["e" try] - ["p" parser - ["<.>" type] - ["" json] - ["l" text] - ["s" code]]] - [data - ["." bit] - maybe - ["." sum] - ["." product] - [number - ["." i64] - ["n" nat ("#@." decimal)] - ["." int] - ["." frac ("#@." decimal)]] - ["." text ("#@." equivalence) - ["%" format (#+ format)]] - [format - ["/" json (#+ JSON)]] - [collection - ["." list ("#@." fold monad)] - ["." row (#+ Row row) ("#@." monad)] - ["d" dictionary]]] - [time - ## ["." instant] - ## ["." duration] - ["." date] - ["." day] - ["." month]] - [macro (#+ with-gensyms) - [syntax (#+ syntax:)] - ["." code] - ["." poly (#+ poly:)]] - ["." type - ["." unit]]]) - -(def: tag - (-> Nat Frac) - (|>> .int int.frac)) - -(def: (rec-encode non-rec) - (All [a] (-> (-> (-> a JSON) - (-> a JSON)) - (-> a JSON))) - (function (_ input) - (non-rec (rec-encode non-rec) input))) - -(def: low-mask Nat (|> 1 (i64.left-shift 32) dec)) -(def: high-mask Nat (|> low-mask (i64.left-shift 32))) - -(structure: nat-codec (codec.Codec JSON Nat) - (def: (encode input) - (let [high (|> input (i64.and high-mask) (i64.logic-right-shift 32)) - low (i64.and low-mask input)] - (#/.Array (row (|> high .int int.frac #/.Number) - (|> low .int int.frac #/.Number))))) - (def: (decode input) - (<| (.run input) - .array - (do p.monad - [high .number - low .number]) - (wrap (n.+ (|> high frac.int .nat (i64.left-shift 32)) - (|> low frac.int .nat)))))) - -(structure: int-codec (codec.Codec JSON Int) - (def: encode (|>> .nat (:: nat-codec encode))) - (def: decode - (|>> (:: nat-codec decode) (:: e.functor map .int)))) - -(def: (nullable writer) - {#.doc "Builds a JSON generator for potentially inexistent values."} - (All [a] (-> (-> a JSON) (-> (Maybe a) JSON))) - (function (_ elem) - (case elem - #.None #/.Null - (#.Some value) (writer value)))) - -(structure: qty-codec - (All [unit] (codec.Codec JSON (unit.Qty unit))) - - (def: encode - (|>> unit.out (:: ..int-codec encode))) - (def: decode - (|>> (:: ..int-codec decode) (:: e.functor map unit.in)))) - -(poly: #export codec//encode - (with-expansions - [ (template [ ] - [(do @ - [#let [g!_ (code.local-identifier "_______")] - _ ] - (wrap (` (: (~ (@JSON//encode inputT)) - ))))] - - [(.exactly Any) (function ((~ g!_) (~ (code.identifier ["" "0"]))) #/.Null)] - [(.sub Bit) (|>> #/.Boolean)] - [(.sub Nat) (:: (~! ..nat-codec) (~' encode))] - [(.sub Int) (:: (~! ..int-codec) (~' encode))] - [(.sub Frac) (|>> #/.Number)] - [(.sub Text) (|>> #/.String)]) -