{-# LANGUAGE AllowAmbiguousTypes #-}
{-# LANGUAGE DataKinds #-}
{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE FlexibleInstances #-}
{-# LANGUAGE GADTs #-}
{-# LANGUAGE KindSignatures #-}
{-# LANGUAGE MultiParamTypeClasses #-}
{-# LANGUAGE QuantifiedConstraints #-}
{-# LANGUAGE RankNTypes #-}
{-# LANGUAGE ScopedTypeVariables #-}
{-# LANGUAGE TemplateHaskell #-}
{-# LANGUAGE TypeApplications #-}
{-# LANGUAGE TypeOperators #-}
{-# LANGUAGE UndecidableInstances #-}
module Grisette.Internal.Internal.Impl.Unified.Class.UnifiedSimpleMergeable
( mrgIf,
liftBaseMonad,
mrgIte,
mrgIte1,
liftMrgIte,
mrgIte2,
liftMrgIte2,
simpleMerge,
)
where
import Control.Monad.Cont (ContT)
import Control.Monad.Except (ExceptT)
import Control.Monad.Identity (Identity (runIdentity), IdentityT)
import Control.Monad.Trans.Maybe (MaybeT)
import qualified Control.Monad.Trans.RWS.Lazy as RWSLazy
import qualified Control.Monad.Trans.RWS.Strict as RWSStrict
import Control.Monad.Trans.Reader (ReaderT)
import qualified Control.Monad.Trans.State.Lazy as StateLazy
import qualified Control.Monad.Trans.State.Strict as StateStrict
import qualified Control.Monad.Trans.Writer.Lazy as WriterLazy
import qualified Control.Monad.Trans.Writer.Strict as WriterStrict
import Data.Kind (Constraint)
import Data.Type.Bool (If)
import Grisette.Internal.Core.Control.Exception (AssertionError)
import Grisette.Internal.Core.Control.Monad.Union (liftUnion)
import Grisette.Internal.Core.Data.Class.GenSym (FreshT)
import Grisette.Internal.Core.Data.Class.Mergeable (Mergeable, Mergeable1)
import qualified Grisette.Internal.Core.Data.Class.PlainUnion as Grisette
import Grisette.Internal.Core.Data.Class.SimpleMergeable
( SimpleMergeable,
SimpleMergeable1,
SimpleMergeable2,
SymBranching,
)
import qualified Grisette.Internal.Core.Data.Class.SimpleMergeable
import qualified Grisette.Internal.Core.Data.Class.SimpleMergeable as Grisette
import Grisette.Internal.Core.Data.Class.TryMerge
( TryMerge,
mrgSingle,
)
import Grisette.Internal.Internal.Decl.Unified.Class.UnifiedSimpleMergeable
( UnifiedBranching (withBaseBranching),
UnifiedSimpleMergeable (withBaseSimpleMergeable),
UnifiedSimpleMergeable1 (withBaseSimpleMergeable1),
UnifiedSimpleMergeable2 (withBaseSimpleMergeable2),
)
import Grisette.Internal.TH.Derivation.Derive (derive)
import Grisette.Internal.Unified.BaseMonad (BaseMonad)
import Grisette.Internal.Unified.EvalModeTag (IsConMode)
import Grisette.Internal.Unified.UnifiedBool (UnifiedBool (GetBool))
import Grisette.Internal.Unified.Util (DecideEvalMode, withMode)
mrgIf ::
forall mode a m.
(DecideEvalMode mode, Mergeable a, UnifiedBranching mode m) =>
GetBool mode ->
m a ->
m a ->
m a
mrgIf :: forall (mode :: EvalModeTag) a (m :: * -> *).
(DecideEvalMode mode, Mergeable a, UnifiedBranching mode m) =>
GetBool mode -> m a -> m a -> m a
mrgIf GetBool mode
c m a
t m a
e =
forall (mode :: EvalModeTag) r.
DecideEvalMode mode =>
((mode ~ 'C) => r) -> ((mode ~ 'S) => r) -> r
withMode @mode
(if Bool
GetBool mode
c then m a
t else m a
e)
(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
$ SymBool -> m a -> m a -> m a
forall (u :: * -> *) a.
(SymBranching u, Mergeable a) =>
SymBool -> u a -> u a -> u a
Grisette.mrgIf SymBool
GetBool mode
c m a
t m a
e)
{-# INLINE mrgIf #-}
liftBaseMonad ::
forall mode a m.
( Applicative m,
UnifiedBranching mode m,
Mergeable a
) =>
BaseMonad mode a ->
m a
liftBaseMonad :: forall (mode :: EvalModeTag) a (m :: * -> *).
(Applicative m, UnifiedBranching mode m, Mergeable a) =>
BaseMonad mode a -> m a
liftBaseMonad BaseMonad mode a
b =
forall (mode :: EvalModeTag) r.
DecideEvalMode mode =>
((mode ~ 'C) => r) -> ((mode ~ 'S) => r) -> r
withMode @mode
(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 -> m a
forall (m :: * -> *) a.
(TryMerge m, Applicative m, Mergeable a) =>
a -> m a
mrgSingle (a -> m a) -> (BaseMonad mode a -> a) -> BaseMonad mode a -> m a
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Identity a -> a
BaseMonad mode a -> a
forall a. Identity a -> a
runIdentity (BaseMonad mode a -> m a) -> BaseMonad mode a -> m a
forall a b. (a -> b) -> a -> b
$ BaseMonad mode 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
$ Union a -> m a
forall (u :: * -> *) a.
(Mergeable a, SymBranching u, Applicative u) =>
Union a -> u a
liftUnion Union a
BaseMonad mode a
b)
{-# INLINE liftBaseMonad #-}
simpleMerge ::
forall mode a.
(DecideEvalMode mode, UnifiedSimpleMergeable mode a) =>
BaseMonad mode a ->
a
simpleMerge :: forall (mode :: EvalModeTag) a.
(DecideEvalMode mode, UnifiedSimpleMergeable mode a) =>
BaseMonad mode a -> a
simpleMerge =
forall (mode :: EvalModeTag) r.
DecideEvalMode mode =>
((mode ~ 'C) => r) -> ((mode ~ 'S) => r) -> r
withMode @mode
(mode ~ 'C) => BaseMonad mode a -> a
Identity a -> a
BaseMonad mode a -> a
forall a. Identity a -> a
runIdentity
(forall (mode :: EvalModeTag) a r.
UnifiedSimpleMergeable mode a =>
(If (IsConMode mode) (() :: Constraint) (SimpleMergeable a) => r)
-> r
withBaseSimpleMergeable @mode @a If (IsConMode mode) (() :: Constraint) (SimpleMergeable a) =>
BaseMonad mode a -> a
Union a -> a
BaseMonad mode a -> a
forall (u :: * -> *) a.
(SimpleMergeable a, PlainUnion u) =>
u a -> a
Grisette.simpleMerge)
mrgIte ::
forall mode a.
(DecideEvalMode mode, UnifiedSimpleMergeable mode a) =>
GetBool mode ->
a ->
a ->
a
mrgIte :: forall (mode :: EvalModeTag) a.
(DecideEvalMode mode, UnifiedSimpleMergeable mode a) =>
GetBool mode -> a -> a -> a
mrgIte GetBool mode
c a
t a
e =
forall (mode :: EvalModeTag) r.
DecideEvalMode mode =>
((mode ~ 'C) => r) -> ((mode ~ 'S) => r) -> r
withMode @mode
(if Bool
GetBool mode
c then a
t else a
e)
( forall (mode :: EvalModeTag) a r.
UnifiedSimpleMergeable mode a =>
(If (IsConMode mode) (() :: Constraint) (SimpleMergeable a) => r)
-> r
withBaseSimpleMergeable @mode @a ((If (IsConMode mode) (() :: Constraint) (SimpleMergeable a) => a)
-> a)
-> (If (IsConMode mode) (() :: Constraint) (SimpleMergeable a) =>
a)
-> a
forall a b. (a -> b) -> a -> b
$
SymBool -> a -> a -> a
forall a. SimpleMergeable a => SymBool -> a -> a -> a
Grisette.Internal.Core.Data.Class.SimpleMergeable.mrgIte SymBool
GetBool mode
c a
t a
e
)
mrgIte1 ::
forall mode f a.
( DecideEvalMode mode,
UnifiedSimpleMergeable1 mode f,
UnifiedSimpleMergeable mode a
) =>
GetBool mode ->
f a ->
f a ->
f a
mrgIte1 :: forall (mode :: EvalModeTag) (f :: * -> *) a.
(DecideEvalMode mode, UnifiedSimpleMergeable1 mode f,
UnifiedSimpleMergeable mode a) =>
GetBool mode -> f a -> f a -> f a
mrgIte1 GetBool mode
c f a
t f a
e =
forall (mode :: EvalModeTag) r.
DecideEvalMode mode =>
((mode ~ 'C) => r) -> ((mode ~ 'S) => r) -> r
withMode @mode
(if Bool
GetBool mode
c then f a
t else f a
e)
( forall (mode :: EvalModeTag) a r.
UnifiedSimpleMergeable mode a =>
(If (IsConMode mode) (() :: Constraint) (SimpleMergeable a) => r)
-> r
withBaseSimpleMergeable @mode @a ((If (IsConMode mode) (() :: Constraint) (SimpleMergeable a) =>
f a)
-> f a)
-> (If (IsConMode mode) (() :: Constraint) (SimpleMergeable a) =>
f a)
-> f a
forall a b. (a -> b) -> a -> b
$
forall (mode :: EvalModeTag) (f :: * -> *) r.
UnifiedSimpleMergeable1 mode f =>
(If (IsConMode mode) (() :: Constraint) (SimpleMergeable1 f) => r)
-> r
withBaseSimpleMergeable1 @mode @f ((If (IsConMode mode) (() :: Constraint) (SimpleMergeable1 f) =>
f a)
-> f a)
-> (If (IsConMode mode) (() :: Constraint) (SimpleMergeable1 f) =>
f a)
-> f a
forall a b. (a -> b) -> a -> b
$
SymBool -> f a -> f a -> f a
forall (u :: * -> *) a.
(SimpleMergeable1 u, SimpleMergeable a) =>
SymBool -> u a -> u a -> u a
Grisette.Internal.Core.Data.Class.SimpleMergeable.mrgIte1 SymBool
GetBool mode
c f a
t f a
e
)
liftMrgIte ::
forall mode f a.
( DecideEvalMode mode,
UnifiedSimpleMergeable1 mode f
) =>
(GetBool mode -> a -> a -> a) ->
GetBool mode ->
f a ->
f a ->
f a
liftMrgIte :: forall (mode :: EvalModeTag) (f :: * -> *) a.
(DecideEvalMode mode, UnifiedSimpleMergeable1 mode f) =>
(GetBool mode -> a -> a -> a) -> GetBool mode -> f a -> f a -> f a
liftMrgIte GetBool mode -> a -> a -> a
f GetBool mode
c f a
t f a
e =
forall (mode :: EvalModeTag) r.
DecideEvalMode mode =>
((mode ~ 'C) => r) -> ((mode ~ 'S) => r) -> r
withMode @mode
(if Bool
GetBool mode
c then f a
t else f a
e)
( forall (mode :: EvalModeTag) (f :: * -> *) r.
UnifiedSimpleMergeable1 mode f =>
(If (IsConMode mode) (() :: Constraint) (SimpleMergeable1 f) => r)
-> r
withBaseSimpleMergeable1 @mode @f ((If (IsConMode mode) (() :: Constraint) (SimpleMergeable1 f) =>
f a)
-> f a)
-> (If (IsConMode mode) (() :: Constraint) (SimpleMergeable1 f) =>
f a)
-> f a
forall a b. (a -> b) -> a -> b
$
(SymBool -> a -> a -> a) -> SymBool -> f a -> f a -> f a
forall a. (SymBool -> a -> a -> a) -> SymBool -> f a -> f a -> f a
forall (u :: * -> *) a.
SimpleMergeable1 u =>
(SymBool -> a -> a -> a) -> SymBool -> u a -> u a -> u a
Grisette.Internal.Core.Data.Class.SimpleMergeable.liftMrgIte SymBool -> a -> a -> a
GetBool mode -> a -> a -> a
f SymBool
GetBool mode
c f a
t f a
e
)
mrgIte2 ::
forall mode f a b.
( DecideEvalMode mode,
UnifiedSimpleMergeable2 mode f,
UnifiedSimpleMergeable mode a,
UnifiedSimpleMergeable mode b
) =>
GetBool mode ->
f a b ->
f a b ->
f a b
mrgIte2 :: forall (mode :: EvalModeTag) (f :: * -> * -> *) a b.
(DecideEvalMode mode, UnifiedSimpleMergeable2 mode f,
UnifiedSimpleMergeable mode a, UnifiedSimpleMergeable mode b) =>
GetBool mode -> f a b -> f a b -> f a b
mrgIte2 GetBool mode
c f a b
t f a b
e =
forall (mode :: EvalModeTag) r.
DecideEvalMode mode =>
((mode ~ 'C) => r) -> ((mode ~ 'S) => r) -> r
withMode @mode
(if Bool
GetBool mode
c then f a b
t else f a b
e)
( forall (mode :: EvalModeTag) a r.
UnifiedSimpleMergeable mode a =>
(If (IsConMode mode) (() :: Constraint) (SimpleMergeable a) => r)
-> r
withBaseSimpleMergeable @mode @a ((If (IsConMode mode) (() :: Constraint) (SimpleMergeable a) =>
f a b)
-> f a b)
-> (If (IsConMode mode) (() :: Constraint) (SimpleMergeable a) =>
f a b)
-> f a b
forall a b. (a -> b) -> a -> b
$
forall (mode :: EvalModeTag) a r.
UnifiedSimpleMergeable mode a =>
(If (IsConMode mode) (() :: Constraint) (SimpleMergeable a) => r)
-> r
withBaseSimpleMergeable @mode @b ((If (IsConMode mode) (() :: Constraint) (SimpleMergeable b) =>
f a b)
-> f a b)
-> (If (IsConMode mode) (() :: Constraint) (SimpleMergeable b) =>
f a b)
-> f a b
forall a b. (a -> b) -> a -> b
$
forall (mode :: EvalModeTag) (f :: * -> * -> *) r.
UnifiedSimpleMergeable2 mode f =>
(If (IsConMode mode) (() :: Constraint) (SimpleMergeable2 f) => r)
-> r
withBaseSimpleMergeable2 @mode @f ((If (IsConMode mode) (() :: Constraint) (SimpleMergeable2 f) =>
f a b)
-> f a b)
-> (If (IsConMode mode) (() :: Constraint) (SimpleMergeable2 f) =>
f a b)
-> f a b
forall a b. (a -> b) -> a -> b
$
SymBool -> f a b -> f a b -> f a b
forall (u :: * -> * -> *) a b.
(SimpleMergeable2 u, SimpleMergeable a, SimpleMergeable b) =>
SymBool -> u a b -> u a b -> u a b
Grisette.Internal.Core.Data.Class.SimpleMergeable.mrgIte2 SymBool
GetBool mode
c f a b
t f a b
e
)
liftMrgIte2 ::
forall mode f a b.
( DecideEvalMode mode,
UnifiedSimpleMergeable2 mode f
) =>
(GetBool mode -> a -> a -> a) ->
(GetBool mode -> b -> b -> b) ->
GetBool mode ->
f a b ->
f a b ->
f a b
liftMrgIte2 :: forall (mode :: EvalModeTag) (f :: * -> * -> *) a b.
(DecideEvalMode mode, UnifiedSimpleMergeable2 mode f) =>
(GetBool mode -> a -> a -> a)
-> (GetBool mode -> b -> b -> b)
-> GetBool mode
-> f a b
-> f a b
-> f a b
liftMrgIte2 GetBool mode -> a -> a -> a
f GetBool mode -> b -> b -> b
g GetBool mode
c f a b
t f a b
e =
forall (mode :: EvalModeTag) r.
DecideEvalMode mode =>
((mode ~ 'C) => r) -> ((mode ~ 'S) => r) -> r
withMode @mode
(if Bool
GetBool mode
c then f a b
t else f a b
e)
( forall (mode :: EvalModeTag) (f :: * -> * -> *) r.
UnifiedSimpleMergeable2 mode f =>
(If (IsConMode mode) (() :: Constraint) (SimpleMergeable2 f) => r)
-> r
withBaseSimpleMergeable2 @mode @f ((If (IsConMode mode) (() :: Constraint) (SimpleMergeable2 f) =>
f a b)
-> f a b)
-> (If (IsConMode mode) (() :: Constraint) (SimpleMergeable2 f) =>
f a b)
-> f a b
forall a b. (a -> b) -> a -> b
$
(SymBool -> a -> a -> a)
-> (SymBool -> b -> b -> b) -> SymBool -> f a b -> f a b -> f a b
forall a b.
(SymBool -> a -> a -> a)
-> (SymBool -> b -> b -> b) -> SymBool -> f a b -> f a b -> f a b
forall (u :: * -> * -> *) a b.
SimpleMergeable2 u =>
(SymBool -> a -> a -> a)
-> (SymBool -> b -> b -> b) -> SymBool -> u a b -> u a b -> u a b
Grisette.Internal.Core.Data.Class.SimpleMergeable.liftMrgIte2 SymBool -> a -> a -> a
GetBool mode -> a -> a -> a
f SymBool -> b -> b -> b
GetBool mode -> b -> b -> b
g SymBool
GetBool mode
c f a b
t f a b
e
)
instance
{-# INCOHERENT #-}
( DecideEvalMode mode,
TryMerge m,
If (IsConMode mode) ((TryMerge m) :: Constraint) (SymBranching m)
) =>
UnifiedBranching mode m
where
withBaseBranching :: forall r.
(If (IsConMode mode) (TryMerge m) (SymBranching m) => r) -> r
withBaseBranching If (IsConMode mode) (TryMerge m) (SymBranching m) => r
r = r
If (IsConMode mode) (TryMerge m) (SymBranching m) => r
r
{-# INLINE withBaseBranching #-}
instance
{-# INCOHERENT #-}
( DecideEvalMode mode,
Mergeable m,
If (IsConMode mode) (() :: Constraint) (SimpleMergeable m)
) =>
UnifiedSimpleMergeable mode m
where
withBaseSimpleMergeable :: forall r.
(If (IsConMode mode) (() :: Constraint) (SimpleMergeable m) => r)
-> r
withBaseSimpleMergeable If (IsConMode mode) (() :: Constraint) (SimpleMergeable m) => r
r = r
If (IsConMode mode) (() :: Constraint) (SimpleMergeable m) => r
r
{-# INLINE withBaseSimpleMergeable #-}
instance
{-# INCOHERENT #-}
( DecideEvalMode mode,
If (IsConMode mode) (() :: Constraint) (SimpleMergeable1 m)
) =>
UnifiedSimpleMergeable1 mode m
where
withBaseSimpleMergeable1 :: forall r.
(If (IsConMode mode) (() :: Constraint) (SimpleMergeable1 m) => r)
-> r
withBaseSimpleMergeable1 If (IsConMode mode) (() :: Constraint) (SimpleMergeable1 m) => r
r = r
If (IsConMode mode) (() :: Constraint) (SimpleMergeable1 m) => r
r
{-# INLINE withBaseSimpleMergeable1 #-}
instance
{-# INCOHERENT #-}
( DecideEvalMode mode,
If (IsConMode mode) (() :: Constraint) (SimpleMergeable2 m)
) =>
UnifiedSimpleMergeable2 mode m
where
withBaseSimpleMergeable2 :: forall r.
(If (IsConMode mode) (() :: Constraint) (SimpleMergeable2 m) => r)
-> r
withBaseSimpleMergeable2 If (IsConMode mode) (() :: Constraint) (SimpleMergeable2 m) => r
r = r
If (IsConMode mode) (() :: Constraint) (SimpleMergeable2 m) => r
r
{-# INLINE withBaseSimpleMergeable2 #-}