From 9534bd214df2983f4f5918ddcff3703f63bd1de1 Mon Sep 17 00:00:00 2001 From: Jan Mas Rovira Date: Fri, 22 Nov 2024 10:00:22 +0100 Subject: [PATCH] move Ordering to its own module --- Stdlib/Data/Ordering.juvix | 38 ++++++++++++++++++++++++++++++++++++++ Stdlib/Trait/Ord.juvix | 25 +------------------------ Stdlib/Trait/Show.juvix | 2 +- 3 files changed, 40 insertions(+), 25 deletions(-) create mode 100644 Stdlib/Data/Ordering.juvix diff --git a/Stdlib/Data/Ordering.juvix b/Stdlib/Data/Ordering.juvix new file mode 100644 index 00000000..b399d754 --- /dev/null +++ b/Stdlib/Data/Ordering.juvix @@ -0,0 +1,38 @@ +module Stdlib.Data.Ordering; + +import Stdlib.Trait.Eq open; +import Stdlib.Data.Bool.Base open; +import Stdlib.Trait.Show open; + +builtin ordering +type Ordering := + | LessThan + | Equal + | GreaterThan; + +isLessThan (ordering : Ordering) : Bool := + case ordering of + | LessThan := true + | _ := false; + +isEqual (ordering : Ordering) : Bool := + case ordering of + | Equal := true + | _ := false; + +isGreaterThan (ordering : Ordering) : Bool := + case ordering of + | GreaterThan := true + | _ := false; + +deriving instance +orderingEqI : Eq Ordering; + +instance +orderingShowI : Show Ordering := + mkShow@{ + show : Ordering -> String + | Equal := "Equal" + | LessThan := "LessThan" + | GreaterThan := "GreaterThan"; + }; diff --git a/Stdlib/Trait/Ord.juvix b/Stdlib/Trait/Ord.juvix index d1222b6e..f79a5ee4 100644 --- a/Stdlib/Trait/Ord.juvix +++ b/Stdlib/Trait/Ord.juvix @@ -3,30 +3,7 @@ module Stdlib.Trait.Ord; import Stdlib.Data.Fixity open; import Stdlib.Data.Bool.Base open; import Stdlib.Trait.Eq open; - -builtin ordering -type Ordering := - | LessThan - | Equal - | GreaterThan; - -isLessThan (ordering : Ordering) : Bool := - case ordering of - | LessThan := true - | _ := false; - -isEqual (ordering : Ordering) : Bool := - case ordering of - | Equal := true - | _ := false; - -isGreaterThan (ordering : Ordering) : Bool := - case ordering of - | GreaterThan := true - | _ := false; - -deriving instance -orderingEqI : Eq Ordering; +import Stdlib.Data.Ordering open public; --- A trait for defining a total order builtin ord diff --git a/Stdlib/Trait/Show.juvix b/Stdlib/Trait/Show.juvix index 099513b0..07319430 100644 --- a/Stdlib/Trait/Show.juvix +++ b/Stdlib/Trait/Show.juvix @@ -1,6 +1,6 @@ module Stdlib.Trait.Show; -import Stdlib.Data.String.Base open; +import Juvix.Builtin.V1.String open public; trait type Show A := mkShow@{show : A -> String};