Skip to content

Commit

Permalink
Use quanified superclass of Eq1/Ord1 to derive instance when available
Browse files Browse the repository at this point in the history
The laws of Eq1/Ord1, i.e. `eq1 = liftEq (==) = (==)` guarantee
that this change should be non-breaking (though observable).
  • Loading branch information
phadej committed Apr 24, 2024
1 parent 82ec4bb commit baca669
Showing 1 changed file with 20 additions and 1 deletion.
21 changes: 20 additions & 1 deletion src/Data/Fix.hs
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@
{-# LANGUAGE UndecidableInstances #-}

#define HAS_POLY_TYPEABLE MIN_VERSION_base(4,7,0)
#define HAS_QUANTIFIED_FUNCTOR_CLASSES MIN_VERSION_base(4,18,0)

#if HAS_POLY_TYPEABLE
{-# LANGUAGE StandaloneDeriving #-}
Expand Down Expand Up @@ -97,7 +98,7 @@ import Prelude (const, error, undefined)

import Control.Monad (liftM)
import Data.Function (on)
import Data.Functor.Classes (Eq1, Ord1, Read1, Show1, compare1, eq1, readsPrec1, showsPrec1)
import Data.Functor.Classes (Eq1, Ord1, Read1, Show1, readsPrec1, showsPrec1)
import Data.Hashable (Hashable (..))
import Data.Hashable.Lifted (Hashable1, hashWithSalt1)
import Data.Typeable (Typeable)
Expand All @@ -114,6 +115,10 @@ import Data.Data (Data)
import Data.Data
#endif

#if !HAS_QUANTIFIED_FUNCTOR_CLASSES
import Data.Functor.Classes (compare1, eq1)
#endif

-- $setup
-- >>> :set -XDeriveFunctor
-- >>> import Prelude
Expand Down Expand Up @@ -191,10 +196,24 @@ unwrapFix = unFix
-------------------------------------------------------------------------------

instance Eq1 f => Eq (Fix f) where
#if HAS_QUANTIFIED_FUNCTOR_CLASSES
Fix a == Fix b = a == b
#else
Fix a == Fix b = eq1 a b
#endif

instance Ord1 f => Ord (Fix f) where
#if HAS_QUANTIFIED_FUNCTOR_CLASSES
compare (Fix a) (Fix b) = compare a b
min (Fix a) (Fix b) = Fix (min a b)
max (Fix a) (Fix b) = Fix (max a b)
Fix a >= Fix b = a >= b
Fix a > Fix b = a > b
Fix a < Fix b = a < b
Fix a <= Fix b = a <= b
#else
compare (Fix a) (Fix b) = compare1 a b
#endif

instance Show1 f => Show (Fix f) where
showsPrec d (Fix a) =
Expand Down

0 comments on commit baca669

Please sign in to comment.