From 5009bfaa56119a58e675a1e6008623790b54cc1c Mon Sep 17 00:00:00 2001 From: Eduardo Julian Date: Sat, 30 Mar 2019 00:47:26 -0400 Subject: Yet more fixes. --- stdlib/source/lux/data/format/json.lux | 27 ++++++++++++++++++++------- 1 file changed, 20 insertions(+), 7 deletions(-) (limited to 'stdlib/source/lux/data/format/json.lux') diff --git a/stdlib/source/lux/data/format/json.lux b/stdlib/source/lux/data/format/json.lux index b68101e3c..64064fb1f 100644 --- a/stdlib/source/lux/data/format/json.lux +++ b/stdlib/source/lux/data/format/json.lux @@ -2,6 +2,7 @@ "For more information, please see: http://www.json.org/")} [lux #* [control + pipe ["." monad (#+ Monad do)] [equivalence (#+ Equivalence)] codec @@ -192,19 +193,31 @@ ############################################################ ############################################################ -(def: (encode-boolean value) +(def: encode-boolean (-> Bit Text) - (case value - #0 "false" - #1 "true")) + (|>> (case> + #0 "false" + #1 "true"))) + +(def: encode-number + (-> Frac Text) + (|>> (case> + +0.0 "0.0" + -0.0 "0.0" + value (let [raw (:: frac.decimal encode value)] + (if (f/< +0.0 value) + raw + (|> raw (text.split 1) maybe.assume product.right)))))) (def: (show-null _) (-> Null Text) "null") + (do-template [ ] [(def: (-> Text) )] - [show-boolean Boolean encode-boolean] - [show-number Number (:: frac.decimal encode)] - [show-string String text.encode]) + [show-boolean Boolean ..encode-boolean] + [show-number Number ..encode-number] + [show-string String text.encode] + ) (def: (show-array show-json elems) (-> (-> JSON Text) (-> Array Text)) -- cgit v1.2.3