{-# LANGUAGE CPP #-}
{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE FlexibleInstances #-}
{-# LANGUAGE KindSignatures #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE TypeOperators #-}
{-# LANGUAGE TypeSynonymInstances #-}
{-# LANGUAGE MagicHash #-}
#if __GLASGOW_HASKELL__ >= 701
{-# LANGUAGE DefaultSignatures #-}
{-# LANGUAGE Trustworthy #-}
#endif
#if __GLASGOW_HASKELL__ >= 705
{-# LANGUAGE PolyKinds #-}
#endif
#include "HsBaseConfig.h"
module Generics.Deriving.Eq (
GEq(..)
, geqdefault
, GEq'(..)
) where
import Control.Applicative (Const, ZipList)
import Data.Char (GeneralCategory)
import Data.Int
import qualified Data.Monoid as Monoid (First, Last)
import Data.Monoid (All, Any, Dual, Product, Sum)
import Data.Version (Version)
import Data.Word
import Foreign.C.Error
import Foreign.C.Types
import Foreign.ForeignPtr (ForeignPtr)
import Foreign.Ptr
import Foreign.StablePtr (StablePtr)
import Generics.Deriving.Base
import GHC.Exts hiding (Any)
import System.Exit (ExitCode)
import System.IO (BufferMode, Handle, HandlePosn, IOMode, SeekMode)
import System.IO.Error (IOErrorType)
import System.Posix.Types
#if MIN_VERSION_base(4,4,0)
import Data.Complex (Complex)
#endif
#if MIN_VERSION_base(4,7,0)
import Data.Proxy (Proxy)
#endif
#if MIN_VERSION_base(4,8,0)
import Data.Functor.Identity (Identity)
import Data.Monoid (Alt)
import Data.Void (Void)
import Numeric.Natural (Natural)
#endif
#if MIN_VERSION_base(4,9,0)
import Data.List.NonEmpty (NonEmpty)
import qualified Data.Semigroup as Semigroup (First, Last)
import Data.Semigroup (Arg(..), Max, Min, WrappedMonoid)
#endif
class GEq' f where
geq' :: f a -> f a -> Bool
instance GEq' V1 where
geq' _ _ = True
instance GEq' U1 where
geq' _ _ = True
instance (GEq c) => GEq' (K1 i c) where
geq' (K1 a) (K1 b) = geq a b
instance (GEq' a) => GEq' (M1 i c a) where
geq' (M1 a) (M1 b) = geq' a b
instance (GEq' a, GEq' b) => GEq' (a :+: b) where
geq' (L1 a) (L1 b) = geq' a b
geq' (R1 a) (R1 b) = geq' a b
geq' _ _ = False
instance (GEq' a, GEq' b) => GEq' (a :*: b) where
geq' (a1 :*: b1) (a2 :*: b2) = geq' a1 a2 && geq' b1 b2
instance GEq' UAddr where
geq' (UAddr a1) (UAddr a2) = isTrue# (eqAddr# a1 a2)
instance GEq' UChar where
geq' (UChar c1) (UChar c2) = isTrue# (eqChar# c1 c2)
instance GEq' UDouble where
geq' (UDouble d1) (UDouble d2) = isTrue# (d1 ==## d2)
instance GEq' UFloat where
geq' (UFloat f1) (UFloat f2) = isTrue# (eqFloat# f1 f2)
instance GEq' UInt where
geq' (UInt i1) (UInt i2) = isTrue# (i1 ==# i2)
instance GEq' UWord where
geq' (UWord w1) (UWord w2) = isTrue# (eqWord# w1 w2)
#if !(MIN_VERSION_base(4,7,0))
isTrue# :: Bool -> Bool
isTrue# = id
#endif
class GEq a where
geq :: a -> a -> Bool
#if __GLASGOW_HASKELL__ >= 701
default geq :: (Generic a, GEq' (Rep a)) => a -> a -> Bool
geq = geqdefault
#endif
geqdefault :: (Generic a, GEq' (Rep a)) => a -> a -> Bool
geqdefault x y = geq' (from x) (from y)
instance GEq () where
geq = geqdefault
instance (GEq a, GEq b) => GEq (a, b) where
geq = geqdefault
instance (GEq a, GEq b, GEq c) => GEq (a, b, c) where
geq = geqdefault
instance (GEq a, GEq b, GEq c, GEq d) => GEq (a, b, c, d) where
geq = geqdefault
instance (GEq a, GEq b, GEq c, GEq d, GEq e) => GEq (a, b, c, d, e) where
geq = geqdefault
instance (GEq a, GEq b, GEq c, GEq d, GEq e, GEq f)
=> GEq (a, b, c, d, e, f) where
geq = geqdefault
instance (GEq a, GEq b, GEq c, GEq d, GEq e, GEq f, GEq g)
=> GEq (a, b, c, d, e, f, g) where
geq = geqdefault
instance GEq a => GEq [a] where
geq = geqdefault
instance (GEq (f p), GEq (g p)) => GEq ((f :+: g) p) where
geq = geqdefault
instance (GEq (f p), GEq (g p)) => GEq ((f :*: g) p) where
geq = geqdefault
instance GEq (f (g p)) => GEq ((f :.: g) p) where
geq = geqdefault
instance GEq All where
geq = geqdefault
#if MIN_VERSION_base(4,8,0)
instance GEq (f a) => GEq (Alt f a) where
geq = geqdefault
#endif
instance GEq Any where
geq = geqdefault
#if !(MIN_VERSION_base(4,9,0))
instance GEq Arity where
geq = geqdefault
#endif
#if MIN_VERSION_base(4,9,0)
instance GEq a => GEq (Arg a b) where
geq (Arg a _) (Arg b _) = geq a b
#endif
instance GEq Associativity where
geq = geqdefault
instance GEq Bool where
geq = geqdefault
instance GEq BufferMode where
geq = (==)
#if defined(HTYPE_CC_T)
instance GEq CCc where
geq = (==)
#endif
instance GEq CChar where
geq = (==)
instance GEq CClock where
geq = (==)
#if defined(HTYPE_DEV_T)
instance GEq CDev where
geq = (==)
#endif
instance GEq CDouble where
geq = (==)
instance GEq CFloat where
geq = (==)
#if defined(HTYPE_GID_T)
instance GEq CGid where
geq = (==)
#endif
instance GEq Char where
geq = (==)
#if defined(HTYPE_INO_T)
instance GEq CIno where
geq = (==)
#endif
instance GEq CInt where
geq = (==)
instance GEq CIntMax where
geq = (==)
instance GEq CIntPtr where
geq = (==)
instance GEq CLLong where
geq = (==)
instance GEq CLong where
geq = (==)
#if defined(HTYPE_MODE_T)
instance GEq CMode where
geq = (==)
#endif
#if defined(HTYPE_NLINK_T)
instance GEq CNlink where
geq = (==)
#endif
#if defined(HTYPE_OFF_T)
instance GEq COff where
geq = (==)
#endif
#if MIN_VERSION_base(4,4,0)
instance GEq a => GEq (Complex a) where
geq = geqdefault
#endif
instance GEq a => GEq (Const a b) where
geq = geqdefault
#if defined(HTYPE_PID_T)
instance GEq CPid where
geq = (==)
#endif
instance GEq CPtrdiff where
geq = (==)
#if defined(HTYPE_RLIM_T)
instance GEq CRLim where
geq = (==)
#endif
instance GEq CSChar where
geq = (==)
#if defined(HTYPE_SPEED_T)
instance GEq CSpeed where
geq = (==)
#endif
#if MIN_VERSION_base(4,4,0)
instance GEq CSUSeconds where
geq = (==)
#endif
instance GEq CShort where
geq = (==)
instance GEq CSigAtomic where
geq = (==)
instance GEq CSize where
geq = (==)
#if defined(HTYPE_SSIZE_T)
instance GEq CSsize where
geq = (==)
#endif
#if defined(HTYPE_TCFLAG_T)
instance GEq CTcflag where
geq = (==)
#endif
instance GEq CTime where
geq = (==)
instance GEq CUChar where
geq = (==)
#if defined(HTYPE_UID_T)
instance GEq CUid where
geq = (==)
#endif
instance GEq CUInt where
geq = (==)
instance GEq CUIntMax where
geq = (==)
instance GEq CUIntPtr where
geq = (==)
instance GEq CULLong where
geq = (==)
instance GEq CULong where
geq = (==)
#if MIN_VERSION_base(4,4,0)
instance GEq CUSeconds where
geq = (==)
#endif
instance GEq CUShort where
geq = (==)
instance GEq CWchar where
geq = (==)
#if MIN_VERSION_base(4,9,0)
instance GEq DecidedStrictness where
geq = geqdefault
#endif
instance GEq Double where
geq = (==)
instance GEq a => GEq (Down a) where
geq = geqdefault
instance GEq a => GEq (Dual a) where
geq = geqdefault
instance (GEq a, GEq b) => GEq (Either a b) where
geq = geqdefault
instance GEq Errno where
geq = (==)
instance GEq ExitCode where
geq = geqdefault
instance GEq Fd where
geq = (==)
instance GEq a => GEq (Monoid.First a) where
geq = geqdefault
#if MIN_VERSION_base(4,9,0)
instance GEq a => GEq (Semigroup.First a) where
geq = geqdefault
#endif
instance GEq Fixity where
geq = geqdefault
instance GEq Float where
geq = (==)
instance GEq (ForeignPtr a) where
geq = (==)
instance GEq (FunPtr a) where
geq = (==)
instance GEq GeneralCategory where
geq = (==)
instance GEq Handle where
geq = (==)
instance GEq HandlePosn where
geq = (==)
#if MIN_VERSION_base(4,8,0)
instance GEq a => GEq (Identity a) where
geq = geqdefault
#endif
instance GEq Int where
geq = (==)
instance GEq Int8 where
geq = (==)
instance GEq Int16 where
geq = (==)
instance GEq Int32 where
geq = (==)
instance GEq Int64 where
geq = (==)
instance GEq Integer where
geq = (==)
instance GEq IntPtr where
geq = (==)
instance GEq IOError where
geq = (==)
instance GEq IOErrorType where
geq = (==)
instance GEq IOMode where
geq = (==)
instance GEq c => GEq (K1 i c p) where
geq = geqdefault
instance GEq a => GEq (Monoid.Last a) where
geq = geqdefault
#if MIN_VERSION_base(4,9,0)
instance GEq a => GEq (Semigroup.Last a) where
geq = geqdefault
#endif
instance GEq (f p) => GEq (M1 i c f p) where
geq = geqdefault
instance GEq a => GEq (Maybe a) where
geq = geqdefault
#if MIN_VERSION_base(4,9,0)
instance GEq a => GEq (Max a) where
geq = geqdefault
instance GEq a => GEq (Min a) where
geq = geqdefault
#endif
#if MIN_VERSION_base(4,8,0)
instance GEq Natural where
geq = (==)
#endif
#if MIN_VERSION_base(4,9,0)
instance GEq a => GEq (NonEmpty a) where
geq = geqdefault
#endif
instance GEq Ordering where
geq = geqdefault
instance GEq p => GEq (Par1 p) where
geq = geqdefault
instance GEq a => GEq (Product a) where
geq = geqdefault
#if MIN_VERSION_base(4,7,0)
instance GEq
# if MIN_VERSION_base(4,9,0)
(Proxy s)
# else
(Proxy (s :: *))
# endif
where
geq = geqdefault
#endif
instance GEq (Ptr a) where
geq = (==)
instance GEq (f p) => GEq (Rec1 f p) where
geq = geqdefault
instance GEq SeekMode where
geq = (==)
instance GEq (StablePtr a) where
geq = (==)
#if MIN_VERSION_base(4,9,0)
instance GEq SourceStrictness where
geq = geqdefault
instance GEq SourceUnpackedness where
geq = geqdefault
#endif
instance GEq a => GEq (Sum a) where
geq = geqdefault
instance GEq (U1 p) where
geq = geqdefault
instance GEq (UAddr p) where
geq = geqdefault
instance GEq (UChar p) where
geq = geqdefault
instance GEq (UDouble p) where
geq = geqdefault
instance GEq (UFloat p) where
geq = geqdefault
instance GEq (UInt p) where
geq = geqdefault
instance GEq (UWord p) where
geq = geqdefault
instance GEq Version where
geq = (==)
#if MIN_VERSION_base(4,8,0)
instance GEq Void where
geq = (==)
#endif
instance GEq Word where
geq = (==)
instance GEq Word8 where
geq = (==)
instance GEq Word16 where
geq = (==)
instance GEq Word32 where
geq = (==)
instance GEq Word64 where
geq = (==)
instance GEq WordPtr where
geq = (==)
#if MIN_VERSION_base(4,9,0)
instance GEq m => GEq (WrappedMonoid m) where
geq = geqdefault
#endif
instance GEq a => GEq (ZipList a) where
geq = geqdefault
#if MIN_VERSION_base(4,10,0)
instance GEq CBool where
geq = (==)
# if defined(HTYPE_BLKSIZE_T)
instance GEq CBlkSize where
geq = (==)
# endif
# if defined(HTYPE_BLKCNT_T)
instance GEq CBlkCnt where
geq = (==)
# endif
# if defined(HTYPE_CLOCKID_T)
instance GEq CClockId where
geq = (==)
# endif
# if defined(HTYPE_FSBLKCNT_T)
instance GEq CFsBlkCnt where
geq = (==)
# endif
# if defined(HTYPE_FSFILCNT_T)
instance GEq CFsFilCnt where
geq = (==)
# endif
# if defined(HTYPE_ID_T)
instance GEq CId where
geq = (==)
# endif
# if defined(HTYPE_KEY_T)
instance GEq CKey where
geq = (==)
# endif
# if defined(HTYPE_TIMER_T)
instance GEq CTimer where
geq = (==)
# endif
#endif