{-# LANGUAGE AllowAmbiguousTypes #-}
{-# LANGUAGE CPP #-}
{-# LANGUAGE DataKinds #-}
{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE FlexibleInstances #-}
{-# LANGUAGE GADTs #-}
{-# LANGUAGE InstanceSigs #-}
{-# LANGUAGE MultiParamTypeClasses #-}
{-# LANGUAGE QuantifiedConstraints #-}
{-# LANGUAGE RankNTypes #-}
{-# LANGUAGE ScopedTypeVariables #-}
{-# LANGUAGE TemplateHaskell #-}
{-# LANGUAGE TypeApplications #-}
{-# LANGUAGE UndecidableInstances #-}
module Grisette.Unified.Internal.Class.UnifiedSymOrd
( UnifiedSymOrd (..),
UnifiedSymOrd1 (..),
UnifiedSymOrd2 (..),
(.<=),
(.<),
(.>=),
(.>),
symCompare,
liftSymCompare,
symCompare1,
liftSymCompare2,
symCompare2,
symMax,
symMin,
mrgMax,
mrgMin,
)
where
import Control.Monad.Except (ExceptT)
import Control.Monad.Identity (Identity (runIdentity), IdentityT)
import Control.Monad.Trans.Maybe (MaybeT)
import qualified Control.Monad.Writer.Lazy as WriterLazy
import qualified Control.Monad.Writer.Strict as WriterStrict
import qualified Data.ByteString as B
import Data.Functor.Classes
( Ord1 (liftCompare),
Ord2 (liftCompare2),
compare1,
compare2,
)
import Data.Functor.Sum (Sum)
import Data.Int (Int16, Int32, Int64, Int8)
import qualified Data.Text as T
import Data.Type.Bool (If)
import Data.Typeable (Typeable)
import Data.Word (Word16, Word32, Word64, Word8)
import Grisette.Internal.Core.Control.Exception
( AssertionError,
VerificationConditions,
)
import Grisette.Internal.Core.Data.Class.Mergeable (Mergeable)
import Grisette.Internal.Core.Data.Class.SymOrd (SymOrd, SymOrd1, SymOrd2)
import qualified Grisette.Internal.Core.Data.Class.SymOrd
import Grisette.Internal.Core.Data.Class.TryMerge (tryMerge)
import Grisette.Internal.SymPrim.BV (IntN, WordN)
import Grisette.Internal.SymPrim.FP (FP, FPRoundingMode, ValidFP)
import Grisette.Internal.TH.DeriveUnifiedInterface
( deriveFunctorArgUnifiedInterfaces,
deriveUnifiedInterface1s,
)
import Grisette.Unified.Internal.BaseMonad (BaseMonad)
import Grisette.Unified.Internal.Class.UnifiedITEOp
( UnifiedITEOp (withBaseITEOp),
)
import Grisette.Unified.Internal.Class.UnifiedSimpleMergeable
( UnifiedBranching (withBaseBranching),
)
import Grisette.Unified.Internal.EvalModeTag
( IsConMode,
)
import Grisette.Unified.Internal.UnifiedBool (UnifiedBool (GetBool))
import Grisette.Unified.Internal.Util (withMode)
(.<=) ::
forall mode a. (Typeable mode, UnifiedSymOrd mode a) => a -> a -> GetBool mode
.<= :: forall (mode :: EvalModeTag) a.
(Typeable mode, UnifiedSymOrd mode a) =>
a -> a -> GetBool mode
(.<=) a
a a
b =
forall (mode :: EvalModeTag) r.
Typeable mode =>
((mode ~ 'Con) => r) -> ((mode ~ 'Sym) => r) -> r
withMode @mode
(forall (mode :: EvalModeTag) a r.
UnifiedSymOrd mode a =>
(If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd @mode @a ((If (IsConMode mode) (Ord a) (SymOrd a) => GetBool mode)
-> GetBool mode)
-> (If (IsConMode mode) (Ord a) (SymOrd a) => GetBool mode)
-> GetBool mode
forall a b. (a -> b) -> a -> b
$ a
a a -> a -> Bool
forall a. Ord a => a -> a -> Bool
<= a
b)
(forall (mode :: EvalModeTag) a r.
UnifiedSymOrd mode a =>
(If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd @mode @a ((If (IsConMode mode) (Ord a) (SymOrd a) => GetBool mode)
-> GetBool mode)
-> (If (IsConMode mode) (Ord a) (SymOrd a) => GetBool mode)
-> GetBool mode
forall a b. (a -> b) -> a -> b
$ a
a a -> a -> SymBool
forall a. SymOrd a => a -> a -> SymBool
Grisette.Internal.Core.Data.Class.SymOrd..<= a
b)
{-# INLINE (.<=) #-}
(.<) ::
forall mode a. (Typeable mode, UnifiedSymOrd mode a) => a -> a -> GetBool mode
.< :: forall (mode :: EvalModeTag) a.
(Typeable mode, UnifiedSymOrd mode a) =>
a -> a -> GetBool mode
(.<) a
a a
b =
forall (mode :: EvalModeTag) r.
Typeable mode =>
((mode ~ 'Con) => r) -> ((mode ~ 'Sym) => r) -> r
withMode @mode
(forall (mode :: EvalModeTag) a r.
UnifiedSymOrd mode a =>
(If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd @mode @a ((If (IsConMode mode) (Ord a) (SymOrd a) => GetBool mode)
-> GetBool mode)
-> (If (IsConMode mode) (Ord a) (SymOrd a) => GetBool mode)
-> GetBool mode
forall a b. (a -> b) -> a -> b
$ a
a a -> a -> Bool
forall a. Ord a => a -> a -> Bool
< a
b)
(forall (mode :: EvalModeTag) a r.
UnifiedSymOrd mode a =>
(If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd @mode @a ((If (IsConMode mode) (Ord a) (SymOrd a) => GetBool mode)
-> GetBool mode)
-> (If (IsConMode mode) (Ord a) (SymOrd a) => GetBool mode)
-> GetBool mode
forall a b. (a -> b) -> a -> b
$ a
a a -> a -> SymBool
forall a. SymOrd a => a -> a -> SymBool
Grisette.Internal.Core.Data.Class.SymOrd..< a
b)
{-# INLINE (.<) #-}
(.>=) ::
forall mode a. (Typeable mode, UnifiedSymOrd mode a) => a -> a -> GetBool mode
.>= :: forall (mode :: EvalModeTag) a.
(Typeable mode, UnifiedSymOrd mode a) =>
a -> a -> GetBool mode
(.>=) a
a a
b =
forall (mode :: EvalModeTag) r.
Typeable mode =>
((mode ~ 'Con) => r) -> ((mode ~ 'Sym) => r) -> r
withMode @mode
(forall (mode :: EvalModeTag) a r.
UnifiedSymOrd mode a =>
(If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd @mode @a ((If (IsConMode mode) (Ord a) (SymOrd a) => GetBool mode)
-> GetBool mode)
-> (If (IsConMode mode) (Ord a) (SymOrd a) => GetBool mode)
-> GetBool mode
forall a b. (a -> b) -> a -> b
$ a
a a -> a -> Bool
forall a. Ord a => a -> a -> Bool
>= a
b)
(forall (mode :: EvalModeTag) a r.
UnifiedSymOrd mode a =>
(If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd @mode @a ((If (IsConMode mode) (Ord a) (SymOrd a) => GetBool mode)
-> GetBool mode)
-> (If (IsConMode mode) (Ord a) (SymOrd a) => GetBool mode)
-> GetBool mode
forall a b. (a -> b) -> a -> b
$ a
a a -> a -> SymBool
forall a. SymOrd a => a -> a -> SymBool
Grisette.Internal.Core.Data.Class.SymOrd..>= a
b)
{-# INLINE (.>=) #-}
(.>) ::
forall mode a. (Typeable mode, UnifiedSymOrd mode a) => a -> a -> GetBool mode
.> :: forall (mode :: EvalModeTag) a.
(Typeable mode, UnifiedSymOrd mode a) =>
a -> a -> GetBool mode
(.>) a
a a
b =
forall (mode :: EvalModeTag) r.
Typeable mode =>
((mode ~ 'Con) => r) -> ((mode ~ 'Sym) => r) -> r
withMode @mode
(forall (mode :: EvalModeTag) a r.
UnifiedSymOrd mode a =>
(If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd @mode @a ((If (IsConMode mode) (Ord a) (SymOrd a) => GetBool mode)
-> GetBool mode)
-> (If (IsConMode mode) (Ord a) (SymOrd a) => GetBool mode)
-> GetBool mode
forall a b. (a -> b) -> a -> b
$ a
a a -> a -> Bool
forall a. Ord a => a -> a -> Bool
> a
b)
(forall (mode :: EvalModeTag) a r.
UnifiedSymOrd mode a =>
(If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd @mode @a ((If (IsConMode mode) (Ord a) (SymOrd a) => GetBool mode)
-> GetBool mode)
-> (If (IsConMode mode) (Ord a) (SymOrd a) => GetBool mode)
-> GetBool mode
forall a b. (a -> b) -> a -> b
$ a
a a -> a -> SymBool
forall a. SymOrd a => a -> a -> SymBool
Grisette.Internal.Core.Data.Class.SymOrd..> a
b)
{-# INLINE (.>) #-}
symCompare ::
forall mode a ctx.
(Typeable mode, UnifiedSymOrd mode a, Monad ctx) =>
a ->
a ->
BaseMonad mode Ordering
symCompare :: forall (mode :: EvalModeTag) a (ctx :: * -> *).
(Typeable mode, UnifiedSymOrd mode a, Monad ctx) =>
a -> a -> BaseMonad mode Ordering
symCompare a
x a
y =
forall (mode :: EvalModeTag) r.
Typeable mode =>
((mode ~ 'Con) => r) -> ((mode ~ 'Sym) => r) -> r
withMode @mode
(forall (mode :: EvalModeTag) a r.
UnifiedSymOrd mode a =>
(If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd @mode @a ((If (IsConMode mode) (Ord a) (SymOrd a) =>
BaseMonad mode Ordering)
-> BaseMonad mode Ordering)
-> (If (IsConMode mode) (Ord a) (SymOrd a) =>
BaseMonad mode Ordering)
-> BaseMonad mode Ordering
forall a b. (a -> b) -> a -> b
$ Ordering -> Identity Ordering
forall a. a -> Identity a
forall (m :: * -> *) a. Monad m => a -> m a
return (Ordering -> Identity Ordering) -> Ordering -> Identity Ordering
forall a b. (a -> b) -> a -> b
$ a -> a -> Ordering
forall a. Ord a => a -> a -> Ordering
compare a
x a
y)
( forall (mode :: EvalModeTag) a r.
UnifiedSymOrd mode a =>
(If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd @mode @a ((If (IsConMode mode) (Ord a) (SymOrd a) =>
BaseMonad mode Ordering)
-> BaseMonad mode Ordering)
-> (If (IsConMode mode) (Ord a) (SymOrd a) =>
BaseMonad mode Ordering)
-> BaseMonad mode Ordering
forall a b. (a -> b) -> a -> b
$
a -> a -> Union Ordering
forall a. SymOrd a => a -> a -> Union Ordering
Grisette.Internal.Core.Data.Class.SymOrd.symCompare a
x a
y
)
{-# INLINE symCompare #-}
liftSymCompare ::
forall mode f a b.
(Typeable mode, UnifiedSymOrd1 mode f) =>
(a -> b -> BaseMonad mode Ordering) ->
f a ->
f b ->
BaseMonad mode Ordering
liftSymCompare :: forall (mode :: EvalModeTag) (f :: * -> *) a b.
(Typeable mode, UnifiedSymOrd1 mode f) =>
(a -> b -> BaseMonad mode Ordering)
-> f a -> f b -> BaseMonad mode Ordering
liftSymCompare a -> b -> BaseMonad mode Ordering
f f a
a f b
b =
forall (mode :: EvalModeTag) r.
Typeable mode =>
((mode ~ 'Con) => r) -> ((mode ~ 'Sym) => r) -> r
withMode @mode
( forall (mode :: EvalModeTag) (f :: * -> *) r.
UnifiedSymOrd1 mode f =>
(If (IsConMode mode) (Ord1 f) (SymOrd1 f) => r) -> r
withBaseSymOrd1 @mode @f ((If (IsConMode mode) (Ord1 f) (SymOrd1 f) =>
BaseMonad mode Ordering)
-> BaseMonad mode Ordering)
-> (If (IsConMode mode) (Ord1 f) (SymOrd1 f) =>
BaseMonad mode Ordering)
-> BaseMonad mode Ordering
forall a b. (a -> b) -> a -> b
$
Ordering -> Identity Ordering
forall a. a -> Identity a
forall (m :: * -> *) a. Monad m => a -> m a
return (Ordering -> Identity Ordering) -> Ordering -> Identity Ordering
forall a b. (a -> b) -> a -> b
$
(a -> b -> Ordering) -> f a -> f b -> Ordering
forall a b. (a -> b -> Ordering) -> f a -> f b -> Ordering
forall (f :: * -> *) a b.
Ord1 f =>
(a -> b -> Ordering) -> f a -> f b -> Ordering
liftCompare (\a
x b
y -> Identity Ordering -> Ordering
forall a. Identity a -> a
runIdentity (Identity Ordering -> Ordering) -> Identity Ordering -> Ordering
forall a b. (a -> b) -> a -> b
$ a -> b -> BaseMonad mode Ordering
f a
x b
y) f a
a f b
b
)
( forall (mode :: EvalModeTag) (f :: * -> *) r.
UnifiedSymOrd1 mode f =>
(If (IsConMode mode) (Ord1 f) (SymOrd1 f) => r) -> r
withBaseSymOrd1 @mode @f ((If (IsConMode mode) (Ord1 f) (SymOrd1 f) =>
BaseMonad mode Ordering)
-> BaseMonad mode Ordering)
-> (If (IsConMode mode) (Ord1 f) (SymOrd1 f) =>
BaseMonad mode Ordering)
-> BaseMonad mode Ordering
forall a b. (a -> b) -> a -> b
$
(a -> b -> Union Ordering) -> f a -> f b -> Union Ordering
forall a b.
(a -> b -> Union Ordering) -> f a -> f b -> Union Ordering
forall (f :: * -> *) a b.
SymOrd1 f =>
(a -> b -> Union Ordering) -> f a -> f b -> Union Ordering
Grisette.Internal.Core.Data.Class.SymOrd.liftSymCompare a -> b -> Union Ordering
a -> b -> BaseMonad mode Ordering
f f a
a f b
b
)
{-# INLINE liftSymCompare #-}
symCompare1 ::
forall mode f a.
(Typeable mode, UnifiedSymOrd mode a, UnifiedSymOrd1 mode f) =>
f a ->
f a ->
BaseMonad mode Ordering
symCompare1 :: forall (mode :: EvalModeTag) (f :: * -> *) a.
(Typeable mode, UnifiedSymOrd mode a, UnifiedSymOrd1 mode f) =>
f a -> f a -> BaseMonad mode Ordering
symCompare1 f a
a f a
b =
forall (mode :: EvalModeTag) r.
Typeable mode =>
((mode ~ 'Con) => r) -> ((mode ~ 'Sym) => r) -> r
withMode @mode
(forall (mode :: EvalModeTag) (f :: * -> *) r.
UnifiedSymOrd1 mode f =>
(If (IsConMode mode) (Ord1 f) (SymOrd1 f) => r) -> r
withBaseSymOrd1 @mode @f ((If (IsConMode mode) (Ord1 f) (SymOrd1 f) =>
BaseMonad mode Ordering)
-> BaseMonad mode Ordering)
-> (If (IsConMode mode) (Ord1 f) (SymOrd1 f) =>
BaseMonad mode Ordering)
-> BaseMonad mode Ordering
forall a b. (a -> b) -> a -> b
$ forall (mode :: EvalModeTag) a r.
UnifiedSymOrd mode a =>
(If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd @mode @a ((If (IsConMode mode) (Ord a) (SymOrd a) =>
BaseMonad mode Ordering)
-> BaseMonad mode Ordering)
-> (If (IsConMode mode) (Ord a) (SymOrd a) =>
BaseMonad mode Ordering)
-> BaseMonad mode Ordering
forall a b. (a -> b) -> a -> b
$ Ordering -> Identity Ordering
forall a. a -> Identity a
forall (m :: * -> *) a. Monad m => a -> m a
return (Ordering -> Identity Ordering) -> Ordering -> Identity Ordering
forall a b. (a -> b) -> a -> b
$ f a -> f a -> Ordering
forall (f :: * -> *) a. (Ord1 f, Ord a) => f a -> f a -> Ordering
compare1 f a
a f a
b)
( forall (mode :: EvalModeTag) (f :: * -> *) r.
UnifiedSymOrd1 mode f =>
(If (IsConMode mode) (Ord1 f) (SymOrd1 f) => r) -> r
withBaseSymOrd1 @mode @f ((If (IsConMode mode) (Ord1 f) (SymOrd1 f) =>
BaseMonad mode Ordering)
-> BaseMonad mode Ordering)
-> (If (IsConMode mode) (Ord1 f) (SymOrd1 f) =>
BaseMonad mode Ordering)
-> BaseMonad mode Ordering
forall a b. (a -> b) -> a -> b
$
forall (mode :: EvalModeTag) a r.
UnifiedSymOrd mode a =>
(If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd @mode @a ((If (IsConMode mode) (Ord a) (SymOrd a) =>
BaseMonad mode Ordering)
-> BaseMonad mode Ordering)
-> (If (IsConMode mode) (Ord a) (SymOrd a) =>
BaseMonad mode Ordering)
-> BaseMonad mode Ordering
forall a b. (a -> b) -> a -> b
$
f a -> f a -> Union Ordering
forall (f :: * -> *) a.
(SymOrd1 f, SymOrd a) =>
f a -> f a -> Union Ordering
Grisette.Internal.Core.Data.Class.SymOrd.symCompare1 f a
a f a
b
)
{-# INLINE symCompare1 #-}
liftSymCompare2 ::
forall mode f a b c d.
(Typeable mode, UnifiedSymOrd2 mode f) =>
(a -> b -> BaseMonad mode Ordering) ->
(c -> d -> BaseMonad mode Ordering) ->
f a c ->
f b d ->
BaseMonad mode Ordering
liftSymCompare2 :: forall (mode :: EvalModeTag) (f :: * -> * -> *) a b c d.
(Typeable mode, UnifiedSymOrd2 mode f) =>
(a -> b -> BaseMonad mode Ordering)
-> (c -> d -> BaseMonad mode Ordering)
-> f a c
-> f b d
-> BaseMonad mode Ordering
liftSymCompare2 a -> b -> BaseMonad mode Ordering
f c -> d -> BaseMonad mode Ordering
g f a c
a f b d
b =
forall (mode :: EvalModeTag) r.
Typeable mode =>
((mode ~ 'Con) => r) -> ((mode ~ 'Sym) => r) -> r
withMode @mode
( forall (mode :: EvalModeTag) (f :: * -> * -> *) r.
UnifiedSymOrd2 mode f =>
(If (IsConMode mode) (Ord2 f) (SymOrd2 f) => r) -> r
withBaseSymOrd2 @mode @f ((If (IsConMode mode) (Ord2 f) (SymOrd2 f) =>
BaseMonad mode Ordering)
-> BaseMonad mode Ordering)
-> (If (IsConMode mode) (Ord2 f) (SymOrd2 f) =>
BaseMonad mode Ordering)
-> BaseMonad mode Ordering
forall a b. (a -> b) -> a -> b
$
Ordering -> Identity Ordering
forall a. a -> Identity a
forall (m :: * -> *) a. Monad m => a -> m a
return (Ordering -> Identity Ordering) -> Ordering -> Identity Ordering
forall a b. (a -> b) -> a -> b
$
(a -> b -> Ordering)
-> (c -> d -> Ordering) -> f a c -> f b d -> Ordering
forall a b c d.
(a -> b -> Ordering)
-> (c -> d -> Ordering) -> f a c -> f b d -> Ordering
forall (f :: * -> * -> *) a b c d.
Ord2 f =>
(a -> b -> Ordering)
-> (c -> d -> Ordering) -> f a c -> f b d -> Ordering
liftCompare2
(\a
x b
y -> Identity Ordering -> Ordering
forall a. Identity a -> a
runIdentity (Identity Ordering -> Ordering) -> Identity Ordering -> Ordering
forall a b. (a -> b) -> a -> b
$ a -> b -> BaseMonad mode Ordering
f a
x b
y)
(\c
x d
y -> Identity Ordering -> Ordering
forall a. Identity a -> a
runIdentity (Identity Ordering -> Ordering) -> Identity Ordering -> Ordering
forall a b. (a -> b) -> a -> b
$ c -> d -> BaseMonad mode Ordering
g c
x d
y)
f a c
a
f b d
b
)
( forall (mode :: EvalModeTag) (f :: * -> * -> *) r.
UnifiedSymOrd2 mode f =>
(If (IsConMode mode) (Ord2 f) (SymOrd2 f) => r) -> r
withBaseSymOrd2 @mode @f ((If (IsConMode mode) (Ord2 f) (SymOrd2 f) =>
BaseMonad mode Ordering)
-> BaseMonad mode Ordering)
-> (If (IsConMode mode) (Ord2 f) (SymOrd2 f) =>
BaseMonad mode Ordering)
-> BaseMonad mode Ordering
forall a b. (a -> b) -> a -> b
$
(a -> b -> Union Ordering)
-> (c -> d -> Union Ordering) -> f a c -> f b d -> Union Ordering
forall a b c d.
(a -> b -> Union Ordering)
-> (c -> d -> Union Ordering) -> f a c -> f b d -> Union Ordering
forall (f :: * -> * -> *) a b c d.
SymOrd2 f =>
(a -> b -> Union Ordering)
-> (c -> d -> Union Ordering) -> f a c -> f b d -> Union Ordering
Grisette.Internal.Core.Data.Class.SymOrd.liftSymCompare2 a -> b -> Union Ordering
a -> b -> BaseMonad mode Ordering
f c -> d -> Union Ordering
c -> d -> BaseMonad mode Ordering
g f a c
a f b d
b
)
{-# INLINE liftSymCompare2 #-}
symCompare2 ::
forall mode f a b.
( Typeable mode,
UnifiedSymOrd mode a,
UnifiedSymOrd mode b,
UnifiedSymOrd2 mode f
) =>
f a b ->
f a b ->
BaseMonad mode Ordering
symCompare2 :: forall (mode :: EvalModeTag) (f :: * -> * -> *) a b.
(Typeable mode, UnifiedSymOrd mode a, UnifiedSymOrd mode b,
UnifiedSymOrd2 mode f) =>
f a b -> f a b -> BaseMonad mode Ordering
symCompare2 f a b
a f a b
b =
forall (mode :: EvalModeTag) r.
Typeable mode =>
((mode ~ 'Con) => r) -> ((mode ~ 'Sym) => r) -> r
withMode @mode
( forall (mode :: EvalModeTag) (f :: * -> * -> *) r.
UnifiedSymOrd2 mode f =>
(If (IsConMode mode) (Ord2 f) (SymOrd2 f) => r) -> r
withBaseSymOrd2 @mode @f ((If (IsConMode mode) (Ord2 f) (SymOrd2 f) =>
BaseMonad mode Ordering)
-> BaseMonad mode Ordering)
-> (If (IsConMode mode) (Ord2 f) (SymOrd2 f) =>
BaseMonad mode Ordering)
-> BaseMonad mode Ordering
forall a b. (a -> b) -> a -> b
$
forall (mode :: EvalModeTag) a r.
UnifiedSymOrd mode a =>
(If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd @mode @a ((If (IsConMode mode) (Ord a) (SymOrd a) =>
BaseMonad mode Ordering)
-> BaseMonad mode Ordering)
-> (If (IsConMode mode) (Ord a) (SymOrd a) =>
BaseMonad mode Ordering)
-> BaseMonad mode Ordering
forall a b. (a -> b) -> a -> b
$
forall (mode :: EvalModeTag) a r.
UnifiedSymOrd mode a =>
(If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd @mode @b ((If (IsConMode mode) (Ord b) (SymOrd b) =>
BaseMonad mode Ordering)
-> BaseMonad mode Ordering)
-> (If (IsConMode mode) (Ord b) (SymOrd b) =>
BaseMonad mode Ordering)
-> BaseMonad mode Ordering
forall a b. (a -> b) -> a -> b
$
Ordering -> Identity Ordering
forall a. a -> Identity a
forall (m :: * -> *) a. Monad m => a -> m a
return (Ordering -> Identity Ordering) -> Ordering -> Identity Ordering
forall a b. (a -> b) -> a -> b
$
f a b -> f a b -> Ordering
forall (f :: * -> * -> *) a b.
(Ord2 f, Ord a, Ord b) =>
f a b -> f a b -> Ordering
compare2 f a b
a f a b
b
)
( forall (mode :: EvalModeTag) (f :: * -> * -> *) r.
UnifiedSymOrd2 mode f =>
(If (IsConMode mode) (Ord2 f) (SymOrd2 f) => r) -> r
withBaseSymOrd2 @mode @f ((If (IsConMode mode) (Ord2 f) (SymOrd2 f) =>
BaseMonad mode Ordering)
-> BaseMonad mode Ordering)
-> (If (IsConMode mode) (Ord2 f) (SymOrd2 f) =>
BaseMonad mode Ordering)
-> BaseMonad mode Ordering
forall a b. (a -> b) -> a -> b
$
forall (mode :: EvalModeTag) a r.
UnifiedSymOrd mode a =>
(If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd @mode @a ((If (IsConMode mode) (Ord a) (SymOrd a) =>
BaseMonad mode Ordering)
-> BaseMonad mode Ordering)
-> (If (IsConMode mode) (Ord a) (SymOrd a) =>
BaseMonad mode Ordering)
-> BaseMonad mode Ordering
forall a b. (a -> b) -> a -> b
$
forall (mode :: EvalModeTag) a r.
UnifiedSymOrd mode a =>
(If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd @mode @b ((If (IsConMode mode) (Ord b) (SymOrd b) =>
BaseMonad mode Ordering)
-> BaseMonad mode Ordering)
-> (If (IsConMode mode) (Ord b) (SymOrd b) =>
BaseMonad mode Ordering)
-> BaseMonad mode Ordering
forall a b. (a -> b) -> a -> b
$
f a b -> f a b -> Union Ordering
forall (f :: * -> * -> *) a b.
(SymOrd2 f, SymOrd a, SymOrd b) =>
f a b -> f a b -> Union Ordering
Grisette.Internal.Core.Data.Class.SymOrd.symCompare2 f a b
a f a b
b
)
{-# INLINE symCompare2 #-}
symMax ::
forall mode a.
(UnifiedSymOrd mode a, UnifiedITEOp mode a, Typeable mode) =>
a ->
a ->
a
symMax :: forall (mode :: EvalModeTag) a.
(UnifiedSymOrd mode a, UnifiedITEOp mode a, Typeable mode) =>
a -> a -> a
symMax a
x a
y =
forall (mode :: EvalModeTag) r.
Typeable mode =>
((mode ~ 'Con) => r) -> ((mode ~ 'Sym) => r) -> r
withMode @mode
(forall (mode :: EvalModeTag) a r.
UnifiedSymOrd mode a =>
(If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd @mode @a ((If (IsConMode mode) (Ord a) (SymOrd a) => a) -> a)
-> (If (IsConMode mode) (Ord a) (SymOrd a) => a) -> a
forall a b. (a -> b) -> a -> b
$ a -> a -> a
forall a. Ord a => a -> a -> a
max a
x a
y)
( forall (mode :: EvalModeTag) a r.
UnifiedSymOrd mode a =>
(If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd @mode @a ((If (IsConMode mode) (Ord a) (SymOrd a) => a) -> a)
-> (If (IsConMode mode) (Ord a) (SymOrd a) => a) -> a
forall a b. (a -> b) -> a -> b
$
forall (mode :: EvalModeTag) v r.
UnifiedITEOp mode v =>
(If (IsConMode mode) (() :: Constraint) (ITEOp v) => r) -> r
withBaseITEOp @mode @a
a -> a -> a
If (IsConMode mode) (() :: Constraint) (ITEOp a) => a -> a -> a
forall a. (SymOrd a, ITEOp a) => a -> a -> a
Grisette.Internal.Core.Data.Class.SymOrd.symMax
a
x
a
y
)
{-# INLINE symMax #-}
symMin ::
forall mode a.
(UnifiedSymOrd mode a, UnifiedITEOp mode a, Typeable mode) =>
a ->
a ->
a
symMin :: forall (mode :: EvalModeTag) a.
(UnifiedSymOrd mode a, UnifiedITEOp mode a, Typeable mode) =>
a -> a -> a
symMin a
x a
y =
forall (mode :: EvalModeTag) r.
Typeable mode =>
((mode ~ 'Con) => r) -> ((mode ~ 'Sym) => r) -> r
withMode @mode
(forall (mode :: EvalModeTag) a r.
UnifiedSymOrd mode a =>
(If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd @mode @a ((If (IsConMode mode) (Ord a) (SymOrd a) => a) -> a)
-> (If (IsConMode mode) (Ord a) (SymOrd a) => a) -> a
forall a b. (a -> b) -> a -> b
$ a -> a -> a
forall a. Ord a => a -> a -> a
min a
x a
y)
( forall (mode :: EvalModeTag) a r.
UnifiedSymOrd mode a =>
(If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd @mode @a ((If (IsConMode mode) (Ord a) (SymOrd a) => a) -> a)
-> (If (IsConMode mode) (Ord a) (SymOrd a) => a) -> a
forall a b. (a -> b) -> a -> b
$
forall (mode :: EvalModeTag) v r.
UnifiedITEOp mode v =>
(If (IsConMode mode) (() :: Constraint) (ITEOp v) => r) -> r
withBaseITEOp @mode @a
a -> a -> a
If (IsConMode mode) (() :: Constraint) (ITEOp a) => a -> a -> a
forall a. (SymOrd a, ITEOp a) => a -> a -> a
Grisette.Internal.Core.Data.Class.SymOrd.symMin
a
x
a
y
)
{-# INLINE symMin #-}
mrgMax ::
forall mode a m.
( UnifiedSymOrd mode a,
UnifiedBranching mode m,
Typeable mode,
Applicative m,
Mergeable a
) =>
a ->
a ->
m a
mrgMax :: forall (mode :: EvalModeTag) a (m :: * -> *).
(UnifiedSymOrd mode a, UnifiedBranching mode m, Typeable mode,
Applicative m, Mergeable a) =>
a -> a -> m a
mrgMax a
x a
y =
forall (mode :: EvalModeTag) r.
Typeable mode =>
((mode ~ 'Con) => r) -> ((mode ~ 'Sym) => r) -> r
withMode @mode
( forall (mode :: EvalModeTag) a r.
UnifiedSymOrd mode a =>
(If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd @mode @a ((If (IsConMode mode) (Ord a) (SymOrd a) => m a) -> m a)
-> (If (IsConMode mode) (Ord a) (SymOrd a) => m a) -> m a
forall a b. (a -> b) -> a -> b
$
forall (mode :: EvalModeTag) (m :: * -> *) r.
UnifiedBranching mode m =>
(If (IsConMode mode) (TryMerge m) (SymBranching m) => r) -> r
withBaseBranching @mode @m ((If (IsConMode mode) (TryMerge m) (SymBranching m) => m a) -> m a)
-> (If (IsConMode mode) (TryMerge m) (SymBranching m) => m a)
-> m a
forall a b. (a -> b) -> a -> b
$
m a -> m a
forall (m :: * -> *) a. (TryMerge m, Mergeable a) => m a -> m a
tryMerge (m a -> m a) -> m a -> m a
forall a b. (a -> b) -> a -> b
$
a -> m a
forall a. a -> m a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (a -> m a) -> a -> m a
forall a b. (a -> b) -> a -> b
$
a -> a -> a
forall a. Ord a => a -> a -> a
max a
x a
y
)
( forall (mode :: EvalModeTag) a r.
UnifiedSymOrd mode a =>
(If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd @mode @a ((If (IsConMode mode) (Ord a) (SymOrd a) => m a) -> m a)
-> (If (IsConMode mode) (Ord a) (SymOrd a) => m a) -> m a
forall a b. (a -> b) -> a -> b
$
forall (mode :: EvalModeTag) (m :: * -> *) r.
UnifiedBranching mode m =>
(If (IsConMode mode) (TryMerge m) (SymBranching m) => r) -> r
withBaseBranching @mode @m ((If (IsConMode mode) (TryMerge m) (SymBranching m) => m a) -> m a)
-> (If (IsConMode mode) (TryMerge m) (SymBranching m) => m a)
-> m a
forall a b. (a -> b) -> a -> b
$
a -> a -> m a
forall a (m :: * -> *).
(SymOrd a, Mergeable a, SymBranching m, Applicative m) =>
a -> a -> m a
Grisette.Internal.Core.Data.Class.SymOrd.mrgMax a
x a
y
)
{-# INLINE mrgMax #-}
mrgMin ::
forall mode a m.
( UnifiedSymOrd mode a,
UnifiedBranching mode m,
Typeable mode,
Applicative m,
Mergeable a
) =>
a ->
a ->
m a
mrgMin :: forall (mode :: EvalModeTag) a (m :: * -> *).
(UnifiedSymOrd mode a, UnifiedBranching mode m, Typeable mode,
Applicative m, Mergeable a) =>
a -> a -> m a
mrgMin a
x a
y =
forall (mode :: EvalModeTag) r.
Typeable mode =>
((mode ~ 'Con) => r) -> ((mode ~ 'Sym) => r) -> r
withMode @mode
( forall (mode :: EvalModeTag) a r.
UnifiedSymOrd mode a =>
(If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd @mode @a ((If (IsConMode mode) (Ord a) (SymOrd a) => m a) -> m a)
-> (If (IsConMode mode) (Ord a) (SymOrd a) => m a) -> m a
forall a b. (a -> b) -> a -> b
$
forall (mode :: EvalModeTag) (m :: * -> *) r.
UnifiedBranching mode m =>
(If (IsConMode mode) (TryMerge m) (SymBranching m) => r) -> r
withBaseBranching @mode @m ((If (IsConMode mode) (TryMerge m) (SymBranching m) => m a) -> m a)
-> (If (IsConMode mode) (TryMerge m) (SymBranching m) => m a)
-> m a
forall a b. (a -> b) -> a -> b
$
m a -> m a
forall (m :: * -> *) a. (TryMerge m, Mergeable a) => m a -> m a
tryMerge (m a -> m a) -> m a -> m a
forall a b. (a -> b) -> a -> b
$
a -> m a
forall a. a -> m a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (a -> m a) -> a -> m a
forall a b. (a -> b) -> a -> b
$
a -> a -> a
forall a. Ord a => a -> a -> a
min a
x a
y
)
( forall (mode :: EvalModeTag) a r.
UnifiedSymOrd mode a =>
(If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd @mode @a ((If (IsConMode mode) (Ord a) (SymOrd a) => m a) -> m a)
-> (If (IsConMode mode) (Ord a) (SymOrd a) => m a) -> m a
forall a b. (a -> b) -> a -> b
$
forall (mode :: EvalModeTag) (m :: * -> *) r.
UnifiedBranching mode m =>
(If (IsConMode mode) (TryMerge m) (SymBranching m) => r) -> r
withBaseBranching @mode @m ((If (IsConMode mode) (TryMerge m) (SymBranching m) => m a) -> m a)
-> (If (IsConMode mode) (TryMerge m) (SymBranching m) => m a)
-> m a
forall a b. (a -> b) -> a -> b
$
a -> a -> m a
forall a (m :: * -> *).
(SymOrd a, Mergeable a, SymBranching m, Applicative m) =>
a -> a -> m a
Grisette.Internal.Core.Data.Class.SymOrd.mrgMin a
x a
y
)
{-# INLINE mrgMin #-}
class UnifiedSymOrd mode a where
withBaseSymOrd :: (((If (IsConMode mode) (Ord a) (SymOrd a)) => r)) -> r
class UnifiedSymOrd1 mode f where
withBaseSymOrd1 :: (((If (IsConMode mode) (Ord1 f) (SymOrd1 f)) => r)) -> r
class UnifiedSymOrd2 mode f where
withBaseSymOrd2 :: (((If (IsConMode mode) (Ord2 f) (SymOrd2 f)) => r)) -> r
instance
{-# INCOHERENT #-}
(Typeable mode, If (IsConMode mode) (Ord a) (SymOrd a)) =>
UnifiedSymOrd mode a
where
withBaseSymOrd :: forall r. (If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd If (IsConMode mode) (Ord a) (SymOrd a) => r
r = r
If (IsConMode mode) (Ord a) (SymOrd a) => r
r
{-# INLINE withBaseSymOrd #-}
instance
{-# INCOHERENT #-}
( Typeable mode,
If (IsConMode mode) (Ord1 f) (SymOrd1 f),
forall a. (UnifiedSymOrd mode a) => UnifiedSymOrd mode (f a)
) =>
UnifiedSymOrd1 mode f
where
withBaseSymOrd1 :: forall r. (If (IsConMode mode) (Ord1 f) (SymOrd1 f) => r) -> r
withBaseSymOrd1 If (IsConMode mode) (Ord1 f) (SymOrd1 f) => r
r = r
If (IsConMode mode) (Ord1 f) (SymOrd1 f) => r
r
{-# INLINE withBaseSymOrd1 #-}
instance
{-# INCOHERENT #-}
( Typeable mode,
If (IsConMode mode) (Ord2 f) (SymOrd2 f),
forall a. (UnifiedSymOrd mode a) => UnifiedSymOrd1 mode (f a)
) =>
UnifiedSymOrd2 mode f
where
withBaseSymOrd2 :: forall r. (If (IsConMode mode) (Ord2 f) (SymOrd2 f) => r) -> r
withBaseSymOrd2 If (IsConMode mode) (Ord2 f) (SymOrd2 f) => r
r = r
If (IsConMode mode) (Ord2 f) (SymOrd2 f) => r
r
{-# INLINE withBaseSymOrd2 #-}
deriveFunctorArgUnifiedInterfaces
''UnifiedSymOrd
'withBaseSymOrd
''UnifiedSymOrd1
'withBaseSymOrd1
[ ''Bool,
''Integer,
''Char,
''Int,
''Int8,
''Int16,
''Int32,
''Int64,
''Word,
''Word8,
''Word16,
''Word32,
''Word64,
''Float,
''Double,
''B.ByteString,
''T.Text,
''FPRoundingMode,
''WordN,
''IntN,
''[],
''Maybe,
''Either,
''(),
''(,),
''(,,),
''(,,,),
''(,,,,),
''(,,,,,),
''(,,,,,,),
''(,,,,,,,),
''(,,,,,,,,),
''(,,,,,,,,,),
''(,,,,,,,,,,),
''(,,,,,,,,,,,),
''(,,,,,,,,,,,,),
''(,,,,,,,,,,,,,),
''(,,,,,,,,,,,,,,),
''AssertionError,
''VerificationConditions,
''ExceptT,
''MaybeT,
''WriterLazy.WriterT,
''WriterStrict.WriterT,
''Identity
]
deriveUnifiedInterface1s
''UnifiedSymOrd
'withBaseSymOrd
''UnifiedSymOrd1
'withBaseSymOrd1
[ ''[],
''Maybe,
''Either,
''(,),
''ExceptT,
''MaybeT,
''WriterLazy.WriterT,
''WriterStrict.WriterT,
''Identity
]
instance
( Typeable mode,
UnifiedSymOrd1 mode f,
UnifiedSymOrd1 mode g,
UnifiedSymOrd mode a
) =>
UnifiedSymOrd mode (Sum f g a)
where
withBaseSymOrd :: forall r.
(If (IsConMode mode) (Ord (Sum f g a)) (SymOrd (Sum f g a)) => r)
-> r
withBaseSymOrd If (IsConMode mode) (Ord (Sum f g a)) (SymOrd (Sum f g a)) => r
r =
forall (mode :: EvalModeTag) r.
Typeable mode =>
((mode ~ 'Con) => r) -> ((mode ~ 'Sym) => r) -> r
withMode @mode
( forall (mode :: EvalModeTag) (f :: * -> *) r.
UnifiedSymOrd1 mode f =>
(If (IsConMode mode) (Ord1 f) (SymOrd1 f) => r) -> r
withBaseSymOrd1 @mode @f ((If (IsConMode mode) (Ord1 f) (SymOrd1 f) => r) -> r)
-> (If (IsConMode mode) (Ord1 f) (SymOrd1 f) => r) -> r
forall a b. (a -> b) -> a -> b
$
forall (mode :: EvalModeTag) (f :: * -> *) r.
UnifiedSymOrd1 mode f =>
(If (IsConMode mode) (Ord1 f) (SymOrd1 f) => r) -> r
withBaseSymOrd1 @mode @g ((If (IsConMode mode) (Ord1 g) (SymOrd1 g) => r) -> r)
-> (If (IsConMode mode) (Ord1 g) (SymOrd1 g) => r) -> r
forall a b. (a -> b) -> a -> b
$
forall (mode :: EvalModeTag) a r.
UnifiedSymOrd mode a =>
(If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd @mode @a r
If (IsConMode mode) (Ord a) (SymOrd a) => r
If (IsConMode mode) (Ord (Sum f g a)) (SymOrd (Sum f g a)) => r
r
)
( forall (mode :: EvalModeTag) (f :: * -> *) r.
UnifiedSymOrd1 mode f =>
(If (IsConMode mode) (Ord1 f) (SymOrd1 f) => r) -> r
withBaseSymOrd1 @mode @f ((If (IsConMode mode) (Ord1 f) (SymOrd1 f) => r) -> r)
-> (If (IsConMode mode) (Ord1 f) (SymOrd1 f) => r) -> r
forall a b. (a -> b) -> a -> b
$
forall (mode :: EvalModeTag) (f :: * -> *) r.
UnifiedSymOrd1 mode f =>
(If (IsConMode mode) (Ord1 f) (SymOrd1 f) => r) -> r
withBaseSymOrd1 @mode @g ((If (IsConMode mode) (Ord1 g) (SymOrd1 g) => r) -> r)
-> (If (IsConMode mode) (Ord1 g) (SymOrd1 g) => r) -> r
forall a b. (a -> b) -> a -> b
$
forall (mode :: EvalModeTag) a r.
UnifiedSymOrd mode a =>
(If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd @mode @a r
If (IsConMode mode) (Ord a) (SymOrd a) => r
If (IsConMode mode) (Ord (Sum f g a)) (SymOrd (Sum f g a)) => r
r
)
{-# INLINE withBaseSymOrd #-}
instance
(Typeable mode, UnifiedSymOrd1 mode f, UnifiedSymOrd1 mode g) =>
UnifiedSymOrd1 mode (Sum f g)
where
withBaseSymOrd1 :: forall r.
(If (IsConMode mode) (Ord1 (Sum f g)) (SymOrd1 (Sum f g)) => r)
-> r
withBaseSymOrd1 If (IsConMode mode) (Ord1 (Sum f g)) (SymOrd1 (Sum f g)) => r
r =
forall (mode :: EvalModeTag) r.
Typeable mode =>
((mode ~ 'Con) => r) -> ((mode ~ 'Sym) => r) -> r
withMode @mode
(forall (mode :: EvalModeTag) (f :: * -> *) r.
UnifiedSymOrd1 mode f =>
(If (IsConMode mode) (Ord1 f) (SymOrd1 f) => r) -> r
withBaseSymOrd1 @mode @f ((If (IsConMode mode) (Ord1 f) (SymOrd1 f) => r) -> r)
-> (If (IsConMode mode) (Ord1 f) (SymOrd1 f) => r) -> r
forall a b. (a -> b) -> a -> b
$ forall (mode :: EvalModeTag) (f :: * -> *) r.
UnifiedSymOrd1 mode f =>
(If (IsConMode mode) (Ord1 f) (SymOrd1 f) => r) -> r
withBaseSymOrd1 @mode @g r
If (IsConMode mode) (Ord1 g) (SymOrd1 g) => r
If (IsConMode mode) (Ord1 (Sum f g)) (SymOrd1 (Sum f g)) => r
r)
(forall (mode :: EvalModeTag) (f :: * -> *) r.
UnifiedSymOrd1 mode f =>
(If (IsConMode mode) (Ord1 f) (SymOrd1 f) => r) -> r
withBaseSymOrd1 @mode @f ((If (IsConMode mode) (Ord1 f) (SymOrd1 f) => r) -> r)
-> (If (IsConMode mode) (Ord1 f) (SymOrd1 f) => r) -> r
forall a b. (a -> b) -> a -> b
$ forall (mode :: EvalModeTag) (f :: * -> *) r.
UnifiedSymOrd1 mode f =>
(If (IsConMode mode) (Ord1 f) (SymOrd1 f) => r) -> r
withBaseSymOrd1 @mode @g r
If (IsConMode mode) (Ord1 g) (SymOrd1 g) => r
If (IsConMode mode) (Ord1 (Sum f g)) (SymOrd1 (Sum f g)) => r
r)
{-# INLINE withBaseSymOrd1 #-}
instance
(Typeable mode, UnifiedSymOrd1 mode m, UnifiedSymOrd mode a) =>
UnifiedSymOrd mode (IdentityT m a)
where
withBaseSymOrd :: forall r.
(If
(IsConMode mode) (Ord (IdentityT m a)) (SymOrd (IdentityT m a)) =>
r)
-> r
withBaseSymOrd If
(IsConMode mode) (Ord (IdentityT m a)) (SymOrd (IdentityT m a)) =>
r
r =
forall (mode :: EvalModeTag) r.
Typeable mode =>
((mode ~ 'Con) => r) -> ((mode ~ 'Sym) => r) -> r
withMode @mode
(forall (mode :: EvalModeTag) (f :: * -> *) r.
UnifiedSymOrd1 mode f =>
(If (IsConMode mode) (Ord1 f) (SymOrd1 f) => r) -> r
withBaseSymOrd1 @mode @m ((If (IsConMode mode) (Ord1 m) (SymOrd1 m) => r) -> r)
-> (If (IsConMode mode) (Ord1 m) (SymOrd1 m) => r) -> r
forall a b. (a -> b) -> a -> b
$ forall (mode :: EvalModeTag) a r.
UnifiedSymOrd mode a =>
(If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd @mode @a r
If (IsConMode mode) (Ord a) (SymOrd a) => r
If
(IsConMode mode) (Ord (IdentityT m a)) (SymOrd (IdentityT m a)) =>
r
r)
(forall (mode :: EvalModeTag) (f :: * -> *) r.
UnifiedSymOrd1 mode f =>
(If (IsConMode mode) (Ord1 f) (SymOrd1 f) => r) -> r
withBaseSymOrd1 @mode @m ((If (IsConMode mode) (Ord1 m) (SymOrd1 m) => r) -> r)
-> (If (IsConMode mode) (Ord1 m) (SymOrd1 m) => r) -> r
forall a b. (a -> b) -> a -> b
$ forall (mode :: EvalModeTag) a r.
UnifiedSymOrd mode a =>
(If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd @mode @a r
If (IsConMode mode) (Ord a) (SymOrd a) => r
If
(IsConMode mode) (Ord (IdentityT m a)) (SymOrd (IdentityT m a)) =>
r
r)
{-# INLINE withBaseSymOrd #-}
instance
(Typeable mode, UnifiedSymOrd1 mode m) =>
UnifiedSymOrd1 mode (IdentityT m)
where
withBaseSymOrd1 :: forall r.
(If
(IsConMode mode) (Ord1 (IdentityT m)) (SymOrd1 (IdentityT m)) =>
r)
-> r
withBaseSymOrd1 If (IsConMode mode) (Ord1 (IdentityT m)) (SymOrd1 (IdentityT m)) =>
r
r =
forall (mode :: EvalModeTag) r.
Typeable mode =>
((mode ~ 'Con) => r) -> ((mode ~ 'Sym) => r) -> r
withMode @mode (forall (mode :: EvalModeTag) (f :: * -> *) r.
UnifiedSymOrd1 mode f =>
(If (IsConMode mode) (Ord1 f) (SymOrd1 f) => r) -> r
withBaseSymOrd1 @mode @m r
If (IsConMode mode) (Ord1 m) (SymOrd1 m) => r
If (IsConMode mode) (Ord1 (IdentityT m)) (SymOrd1 (IdentityT m)) =>
r
r) (forall (mode :: EvalModeTag) (f :: * -> *) r.
UnifiedSymOrd1 mode f =>
(If (IsConMode mode) (Ord1 f) (SymOrd1 f) => r) -> r
withBaseSymOrd1 @mode @m r
If (IsConMode mode) (Ord1 m) (SymOrd1 m) => r
If (IsConMode mode) (Ord1 (IdentityT m)) (SymOrd1 (IdentityT m)) =>
r
r)
{-# INLINE withBaseSymOrd1 #-}
instance (Typeable mode, ValidFP eb sb) => UnifiedSymOrd mode (FP eb sb) where
withBaseSymOrd :: forall r.
(If (IsConMode mode) (Ord (FP eb sb)) (SymOrd (FP eb sb)) => r)
-> r
withBaseSymOrd If (IsConMode mode) (Ord (FP eb sb)) (SymOrd (FP eb sb)) => r
r = forall (mode :: EvalModeTag) r.
Typeable mode =>
((mode ~ 'Con) => r) -> ((mode ~ 'Sym) => r) -> r
withMode @mode r
(mode ~ 'Con) => r
If (IsConMode mode) (Ord (FP eb sb)) (SymOrd (FP eb sb)) => r
r r
(mode ~ 'Sym) => r
If (IsConMode mode) (Ord (FP eb sb)) (SymOrd (FP eb sb)) => r
r
{-# INLINE withBaseSymOrd #-}
instance (Typeable mode) => UnifiedSymOrd2 mode Either where
withBaseSymOrd2 :: forall r.
(If (IsConMode mode) (Ord2 Either) (SymOrd2 Either) => r) -> r
withBaseSymOrd2 If (IsConMode mode) (Ord2 Either) (SymOrd2 Either) => r
r = forall (mode :: EvalModeTag) r.
Typeable mode =>
((mode ~ 'Con) => r) -> ((mode ~ 'Sym) => r) -> r
withMode @mode r
(mode ~ 'Con) => r
If (IsConMode mode) (Ord2 Either) (SymOrd2 Either) => r
r r
(mode ~ 'Sym) => r
If (IsConMode mode) (Ord2 Either) (SymOrd2 Either) => r
r
{-# INLINE withBaseSymOrd2 #-}
instance (Typeable mode) => UnifiedSymOrd2 mode (,) where
withBaseSymOrd2 :: forall r. (If (IsConMode mode) (Ord2 (,)) (SymOrd2 (,)) => r) -> r
withBaseSymOrd2 If (IsConMode mode) (Ord2 (,)) (SymOrd2 (,)) => r
r = forall (mode :: EvalModeTag) r.
Typeable mode =>
((mode ~ 'Con) => r) -> ((mode ~ 'Sym) => r) -> r
withMode @mode r
(mode ~ 'Con) => r
If (IsConMode mode) (Ord2 (,)) (SymOrd2 (,)) => r
r r
(mode ~ 'Sym) => r
If (IsConMode mode) (Ord2 (,)) (SymOrd2 (,)) => r
r
{-# INLINE withBaseSymOrd2 #-}
#if MIN_VERSION_base(4,16,0)
deriveUnifiedInterface1s
''UnifiedSymOrd
'withBaseSymOrd
''UnifiedSymOrd1
'withBaseSymOrd1
[ ''(,,),
''(,,,)
]
instance (Typeable mode, UnifiedSymOrd mode a) =>
UnifiedSymOrd2 mode ((,,) a) where
withBaseSymOrd2 :: forall r.
(If (IsConMode mode) (Ord2 ((,,) a)) (SymOrd2 ((,,) a)) => r) -> r
withBaseSymOrd2 If (IsConMode mode) (Ord2 ((,,) a)) (SymOrd2 ((,,) a)) => r
r =
forall (mode :: EvalModeTag) r.
Typeable mode =>
((mode ~ 'Con) => r) -> ((mode ~ 'Sym) => r) -> r
withMode @mode (forall (mode :: EvalModeTag) a r.
UnifiedSymOrd mode a =>
(If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd @mode @a r
If (IsConMode mode) (Ord a) (SymOrd a) => r
If (IsConMode mode) (Ord2 ((,,) a)) (SymOrd2 ((,,) a)) => r
r) (forall (mode :: EvalModeTag) a r.
UnifiedSymOrd mode a =>
(If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd @mode @a r
If (IsConMode mode) (Ord a) (SymOrd a) => r
If (IsConMode mode) (Ord2 ((,,) a)) (SymOrd2 ((,,) a)) => r
r)
{-# INLINE withBaseSymOrd2 #-}
instance
(Typeable mode, UnifiedSymOrd mode a, UnifiedSymOrd mode b) =>
UnifiedSymOrd2 mode ((,,,) a b)
where
withBaseSymOrd2 :: forall r.
(If (IsConMode mode) (Ord2 ((,,,) a b)) (SymOrd2 ((,,,) a b)) => r)
-> r
withBaseSymOrd2 If (IsConMode mode) (Ord2 ((,,,) a b)) (SymOrd2 ((,,,) a b)) => r
r =
forall (mode :: EvalModeTag) r.
Typeable mode =>
((mode ~ 'Con) => r) -> ((mode ~ 'Sym) => r) -> r
withMode @mode
(forall (mode :: EvalModeTag) a r.
UnifiedSymOrd mode a =>
(If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd @mode @a ((If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r)
-> (If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
forall a b. (a -> b) -> a -> b
$ forall (mode :: EvalModeTag) a r.
UnifiedSymOrd mode a =>
(If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd @mode @b r
If (IsConMode mode) (Ord b) (SymOrd b) => r
If (IsConMode mode) (Ord2 ((,,,) a b)) (SymOrd2 ((,,,) a b)) => r
r)
(forall (mode :: EvalModeTag) a r.
UnifiedSymOrd mode a =>
(If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd @mode @a ((If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r)
-> (If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
forall a b. (a -> b) -> a -> b
$ forall (mode :: EvalModeTag) a r.
UnifiedSymOrd mode a =>
(If (IsConMode mode) (Ord a) (SymOrd a) => r) -> r
withBaseSymOrd @mode @b r
If (IsConMode mode) (Ord b) (SymOrd b) => r
If (IsConMode mode) (Ord2 ((,,,) a b)) (SymOrd2 ((,,,) a b)) => r
r)
{-# INLINE withBaseSymOrd2 #-}
#endif