{-# LANGUAGE CPP #-}
{-# LANGUAGE PolyKinds #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE UndecidableInstances #-}
#if __GLASGOW_HASKELL__ >= 806
{-# LANGUAGE QuantifiedConstraints #-}
#endif
{-# OPTIONS_GHC -Wno-orphans #-}
module Barbies.Internal.ApplicativeT
  ( ApplicativeT(tpure, tprod)
  , tzip, tunzip, tzipWith, tzipWith3, tzipWith4
  , CanDeriveApplicativeT
  , gtprodDefault, gtpureDefault
  )
where
import Barbies.Generics.Applicative(GApplicative(..))
import Barbies.Internal.FunctorT (FunctorT (..))
import Control.Applicative (Alternative(..))
import Data.Functor.Compose (Compose (..))
import Data.Functor.Product (Product (..))
import Data.Functor.Reverse (Reverse (..))
import Data.Functor.Sum (Sum (..))
import Data.Kind (Type)
import Data.Proxy (Proxy (..))
import Data.Generics.GenericN
class FunctorT t => ApplicativeT (t :: (k -> Type) -> (k' -> Type)) where
  tpure
    :: (forall a . f a)
    -> t f x
  tprod
    :: t f x
    -> t g x
    -> t (f `Product` g) x
  default tpure
    :: CanDeriveApplicativeT t f f x
    => (forall a . f a)
    -> t f x
  tpure = (forall (a :: k). f a) -> t f x
forall k k (t :: (k -> *) -> k -> *) (f :: k -> *) (x :: k).
CanDeriveApplicativeT t f f x =>
(forall (a :: k). f a) -> t f x
gtpureDefault
  default tprod
    :: CanDeriveApplicativeT t f g x
    => t f x
    -> t g x
    -> t (f `Product` g) x
  tprod = t f x -> t g x -> t (Product f g) x
forall k k (t :: (k -> *) -> k -> *) (f :: k -> *) (g :: k -> *)
       (x :: k).
CanDeriveApplicativeT t f g x =>
t f x -> t g x -> t (Product f g) x
gtprodDefault
tzip
  :: ApplicativeT t
  => t f x
  -> t g x
  -> t (f `Product` g) x
tzip :: t f x -> t g x -> t (Product f g) x
tzip = t f x -> t g x -> t (Product f g) x
forall k k' (t :: (k -> *) -> k' -> *) (f :: k -> *) (x :: k')
       (g :: k -> *).
ApplicativeT t =>
t f x -> t g x -> t (Product f g) x
tprod
tunzip
  :: ApplicativeT t
  => t (f `Product` g) x
  -> (t f x, t g x)
tunzip :: t (Product f g) x -> (t f x, t g x)
tunzip t (Product f g) x
tfg
  = ((forall (a :: k). Product f g a -> f a)
-> t (Product f g) x -> t f x
forall k k' (t :: (k -> *) -> k' -> *) (f :: k -> *) (g :: k -> *)
       (x :: k').
FunctorT t =>
(forall (a :: k). f a -> g a) -> t f x -> t g x
tmap (\(Pair a _) -> f a
a) t (Product f g) x
tfg, (forall (a :: k). Product f g a -> g a)
-> t (Product f g) x -> t g x
forall k k' (t :: (k -> *) -> k' -> *) (f :: k -> *) (g :: k -> *)
       (x :: k').
FunctorT t =>
(forall (a :: k). f a -> g a) -> t f x -> t g x
tmap (\(Pair _ b) -> g a
b) t (Product f g) x
tfg)
tzipWith
  :: ApplicativeT t
  => (forall a. f a -> g a -> h a)
  -> t f x
  -> t g x
  -> t h x
tzipWith :: (forall (a :: k). f a -> g a -> h a) -> t f x -> t g x -> t h x
tzipWith forall (a :: k). f a -> g a -> h a
f t f x
tf t g x
tg
  = (forall (a :: k). Product f g a -> h a)
-> t (Product f g) x -> t h x
forall k k' (t :: (k -> *) -> k' -> *) (f :: k -> *) (g :: k -> *)
       (x :: k').
FunctorT t =>
(forall (a :: k). f a -> g a) -> t f x -> t g x
tmap (\(Pair fa ga) -> f a -> g a -> h a
forall (a :: k). f a -> g a -> h a
f f a
fa g a
ga) (t f x
tf t f x -> t g x -> t (Product f g) x
forall k k' (t :: (k -> *) -> k' -> *) (f :: k -> *) (x :: k')
       (g :: k -> *).
ApplicativeT t =>
t f x -> t g x -> t (Product f g) x
`tprod` t g x
tg)
tzipWith3
  :: ApplicativeT t
  => (forall a. f a -> g a -> h a -> i a)
  -> t f x
  -> t g x
  -> t h x
  -> t i x
tzipWith3 :: (forall (a :: k). f a -> g a -> h a -> i a)
-> t f x -> t g x -> t h x -> t i x
tzipWith3 forall (a :: k). f a -> g a -> h a -> i a
f t f x
tf t g x
tg t h x
th
  = (forall (a :: k). Product (Product f g) h a -> i a)
-> t (Product (Product f g) h) x -> t i x
forall k k' (t :: (k -> *) -> k' -> *) (f :: k -> *) (g :: k -> *)
       (x :: k').
FunctorT t =>
(forall (a :: k). f a -> g a) -> t f x -> t g x
tmap (\(Pair (Pair fa ga) ha) -> f a -> g a -> h a -> i a
forall (a :: k). f a -> g a -> h a -> i a
f f a
fa g a
ga h a
ha)
         (t f x
tf t f x -> t g x -> t (Product f g) x
forall k k' (t :: (k -> *) -> k' -> *) (f :: k -> *) (x :: k')
       (g :: k -> *).
ApplicativeT t =>
t f x -> t g x -> t (Product f g) x
`tprod` t g x
tg t (Product f g) x -> t h x -> t (Product (Product f g) h) x
forall k k' (t :: (k -> *) -> k' -> *) (f :: k -> *) (x :: k')
       (g :: k -> *).
ApplicativeT t =>
t f x -> t g x -> t (Product f g) x
`tprod` t h x
th)
tzipWith4
  :: ApplicativeT t
  => (forall a. f a -> g a -> h a -> i a -> j a)
  -> t f x
  -> t g x
  -> t h x
  -> t i x
  -> t j x
tzipWith4 :: (forall (a :: k). f a -> g a -> h a -> i a -> j a)
-> t f x -> t g x -> t h x -> t i x -> t j x
tzipWith4 forall (a :: k). f a -> g a -> h a -> i a -> j a
f t f x
tf t g x
tg t h x
th t i x
ti
  = (forall (a :: k). Product (Product (Product f g) h) i a -> j a)
-> t (Product (Product (Product f g) h) i) x -> t j x
forall k k' (t :: (k -> *) -> k' -> *) (f :: k -> *) (g :: k -> *)
       (x :: k').
FunctorT t =>
(forall (a :: k). f a -> g a) -> t f x -> t g x
tmap (\(Pair (Pair (Pair fa ga) ha) ia) -> f a -> g a -> h a -> i a -> j a
forall (a :: k). f a -> g a -> h a -> i a -> j a
f f a
fa g a
ga h a
ha i a
ia)
         (t f x
tf t f x -> t g x -> t (Product f g) x
forall k k' (t :: (k -> *) -> k' -> *) (f :: k -> *) (x :: k')
       (g :: k -> *).
ApplicativeT t =>
t f x -> t g x -> t (Product f g) x
`tprod` t g x
tg t (Product f g) x -> t h x -> t (Product (Product f g) h) x
forall k k' (t :: (k -> *) -> k' -> *) (f :: k -> *) (x :: k')
       (g :: k -> *).
ApplicativeT t =>
t f x -> t g x -> t (Product f g) x
`tprod` t h x
th t (Product (Product f g) h) x
-> t i x -> t (Product (Product (Product f g) h) i) x
forall k k' (t :: (k -> *) -> k' -> *) (f :: k -> *) (x :: k')
       (g :: k -> *).
ApplicativeT t =>
t f x -> t g x -> t (Product f g) x
`tprod` t i x
ti)
type CanDeriveApplicativeT t f g x
  = ( GenericP 1 (t f x)
    , GenericP 1 (t g x)
    , GenericP 1 (t (f `Product` g) x)
    , GApplicative 1 f g (RepP 1 (t f x)) (RepP 1 (t g x)) (RepP 1 (t (f `Product` g) x))
    )
gtprodDefault
  :: forall t f g x
  .  CanDeriveApplicativeT t f g x
  => t f x
  -> t g x
  -> t (f `Product` g) x
gtprodDefault :: t f x -> t g x -> t (Product f g) x
gtprodDefault t f x
l t g x
r
  = Proxy 1 -> RepP 1 (t (Product f g) x) Any -> t (Product f g) x
forall (n :: Nat) a x. GenericP n a => Proxy n -> RepP n a x -> a
toP Proxy 1
p1 (RepP 1 (t (Product f g) x) Any -> t (Product f g) x)
-> RepP 1 (t (Product f g) x) Any -> t (Product f g) x
forall a b. (a -> b) -> a -> b
$ Proxy 1
-> Proxy f
-> Proxy g
-> Zip
     (Rep (FilterIndex 1 (Indexed t 2) (Param 1 f) x)) (Rep (t f x)) Any
-> Zip
     (Rep (FilterIndex 1 (Indexed t 2) (Param 1 g) x)) (Rep (t g x)) Any
-> Zip
     (Rep (FilterIndex 1 (Indexed t 2) (Param 1 (Product f g)) x))
     (Rep (t (Product f g) x))
     Any
forall k k k (n :: k) (f :: k -> *) (g :: k -> *) (repbf :: k -> *)
       (repbg :: k -> *) (repbfg :: k -> *) (x :: k).
GApplicative n f g repbf repbg repbfg =>
Proxy n -> Proxy f -> Proxy g -> repbf x -> repbg x -> repbfg x
gprod Proxy 1
p1 (Proxy f
forall k (t :: k). Proxy t
Proxy @f) (Proxy g
forall k (t :: k). Proxy t
Proxy @g) (Proxy 1 -> t f x -> RepP 1 (t f x) Any
forall (n :: Nat) a x. GenericP n a => Proxy n -> a -> RepP n a x
fromP Proxy 1
p1 t f x
l) (Proxy 1 -> t g x -> RepP 1 (t g x) Any
forall (n :: Nat) a x. GenericP n a => Proxy n -> a -> RepP n a x
fromP Proxy 1
p1 t g x
r)
  where
      p1 :: Proxy 1
p1 = Proxy 1
forall k (t :: k). Proxy t
Proxy @1
{-# INLINE gtprodDefault #-}
gtpureDefault
  :: forall t f x
  .  CanDeriveApplicativeT t f f x
  => (forall a . f a)
  -> t f x
gtpureDefault :: (forall (a :: k). f a) -> t f x
gtpureDefault forall (a :: k). f a
fa
  = Proxy 1 -> RepP 1 (t f x) Any -> t f x
forall (n :: Nat) a x. GenericP n a => Proxy n -> RepP n a x -> a
toP (Proxy 1
forall k (t :: k). Proxy t
Proxy @1) (RepP 1 (t f x) Any -> t f x) -> RepP 1 (t f x) Any -> t f x
forall a b. (a -> b) -> a -> b
$ Proxy 1
-> Proxy f
-> Proxy
     (Zip
        (Rep (FilterIndex 1 (Indexed t 2) (Param 1 f) x)) (Rep (t f x)))
-> Proxy
     (Zip
        (Rep (FilterIndex 1 (Indexed t 2) (Param 1 (Product f f)) x))
        (Rep (t (Product f f) x)))
-> (forall (a :: k). f a)
-> Zip
     (Rep (FilterIndex 1 (Indexed t 2) (Param 1 f) x)) (Rep (t f x)) Any
forall k k k (n :: k) (f :: k -> *) (g :: k -> *) (repbf :: k -> *)
       (repbg :: k -> *) (repbfg :: k -> *) (x :: k).
(GApplicative n f g repbf repbg repbfg, f ~ g, repbf ~ repbg) =>
Proxy n
-> Proxy f
-> Proxy repbf
-> Proxy repbfg
-> (forall (a :: k). f a)
-> repbf x
gpure
      (Proxy 1
forall k (t :: k). Proxy t
Proxy @1)
      (Proxy f
forall k (t :: k). Proxy t
Proxy @f)
      (Proxy (RepP 1 (t f x))
forall k (t :: k). Proxy t
Proxy @(RepP 1 (t f x)))
      (Proxy (RepP 1 (t (Product f f) x))
forall k (t :: k). Proxy t
Proxy @(RepP 1 (t (f `Product` f) x)))
      forall (a :: k). f a
fa
{-# INLINE gtpureDefault #-}
type P = Param
instance
  (  ApplicativeT t
  ) => GApplicative 1 f g (Rec (t (P 1 f) x) (t f x))
                          (Rec (t (P 1 g) x) (t g x))
                          (Rec (t (P 1 (f `Product` g)) x) (t (f `Product` g) x))
  where
  gpure :: Proxy 1
-> Proxy f
-> Proxy (Rec (t (P 1 f) x) (t f x))
-> Proxy (Rec (t (P 1 (Product f g)) x) (t (Product f g) x))
-> (forall (a :: k). f a)
-> Rec (t (P 1 f) x) (t f x) x
gpure Proxy 1
_ Proxy f
_ Proxy (Rec (t (P 1 f) x) (t f x))
_ Proxy (Rec (t (P 1 (Product f g)) x) (t (Product f g) x))
_ forall (a :: k). f a
fa
    = K1 R (t f x) x -> Rec (t (P 1 f) x) (t f x) x
forall k p a (x :: k). K1 R a x -> Rec p a x
Rec (t f x -> K1 R (t f x) x
forall k i c (p :: k). c -> K1 i c p
K1 ((forall (a :: k). f a) -> t f x
forall k k' (t :: (k -> *) -> k' -> *) (f :: k -> *) (x :: k').
ApplicativeT t =>
(forall (a :: k). f a) -> t f x
tpure forall (a :: k). f a
fa))
  {-# INLINE gpure #-}
  gprod :: Proxy 1
-> Proxy f
-> Proxy g
-> Rec (t (P 1 f) x) (t f x) x
-> Rec (t (P 1 g) x) (t g x) x
-> Rec (t (P 1 (Product f g)) x) (t (Product f g) x) x
gprod Proxy 1
_ Proxy f
_ Proxy g
_ (Rec (K1 t f x
tf)) (Rec (K1 t g x
tg))
    = K1 R (t (Product f g) x) x
-> Rec (t (P 1 (Product f g)) x) (t (Product f g) x) x
forall k p a (x :: k). K1 R a x -> Rec p a x
Rec (t (Product f g) x -> K1 R (t (Product f g) x) x
forall k i c (p :: k). c -> K1 i c p
K1 (t f x
tf t f x -> t g x -> t (Product f g) x
forall k k' (t :: (k -> *) -> k' -> *) (f :: k -> *) (x :: k')
       (g :: k -> *).
ApplicativeT t =>
t f x -> t g x -> t (Product f g) x
`tprod` t g x
tg))
  {-# INLINE gprod #-}
instance
  ( Applicative h
  , ApplicativeT t
  ) => GApplicative 1 f g (Rec (h (t (P 1 f) x)) (h (t f x)))
                          (Rec (h (t (P 1 g) x)) (h (t g x)))
                          (Rec (h (t (P 1 (f `Product` g)) x)) (h (t (f `Product` g) x)))
  where
  gpure :: Proxy 1
-> Proxy f
-> Proxy (Rec (h (t (P 1 f) x)) (h (t f x)))
-> Proxy
     (Rec (h (t (P 1 (Product f g)) x)) (h (t (Product f g) x)))
-> (forall (a :: k). f a)
-> Rec (h (t (P 1 f) x)) (h (t f x)) x
gpure Proxy 1
_ Proxy f
_ Proxy (Rec (h (t (P 1 f) x)) (h (t f x)))
_ Proxy (Rec (h (t (P 1 (Product f g)) x)) (h (t (Product f g) x)))
_ forall (a :: k). f a
fa
    = K1 R (h (t f x)) x -> Rec (h (t (P 1 f) x)) (h (t f x)) x
forall k p a (x :: k). K1 R a x -> Rec p a x
Rec (h (t f x) -> K1 R (h (t f x)) x
forall k i c (p :: k). c -> K1 i c p
K1 (t f x -> h (t f x)
forall (f :: * -> *) a. Applicative f => a -> f a
pure (t f x -> h (t f x)) -> t f x -> h (t f x)
forall a b. (a -> b) -> a -> b
$ (forall (a :: k). f a) -> t f x
forall k k' (t :: (k -> *) -> k' -> *) (f :: k -> *) (x :: k').
ApplicativeT t =>
(forall (a :: k). f a) -> t f x
tpure forall (a :: k). f a
fa))
  {-# INLINE gpure #-}
  gprod :: Proxy 1
-> Proxy f
-> Proxy g
-> Rec (h (t (P 1 f) x)) (h (t f x)) x
-> Rec (h (t (P 1 g) x)) (h (t g x)) x
-> Rec (h (t (P 1 (Product f g)) x)) (h (t (Product f g) x)) x
gprod Proxy 1
_ Proxy f
_ Proxy g
_ (Rec (K1 h (t f x)
htf)) (Rec (K1 h (t g x)
htg))
    = K1 R (h (t (Product f g) x)) x
-> Rec (h (t (P 1 (Product f g)) x)) (h (t (Product f g) x)) x
forall k p a (x :: k). K1 R a x -> Rec p a x
Rec (h (t (Product f g) x) -> K1 R (h (t (Product f g) x)) x
forall k i c (p :: k). c -> K1 i c p
K1 (t f x -> t g x -> t (Product f g) x
forall k k' (t :: (k -> *) -> k' -> *) (f :: k -> *) (x :: k')
       (g :: k -> *).
ApplicativeT t =>
t f x -> t g x -> t (Product f g) x
tprod (t f x -> t g x -> t (Product f g) x)
-> h (t f x) -> h (t g x -> t (Product f g) x)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> h (t f x)
htf h (t g x -> t (Product f g) x)
-> h (t g x) -> h (t (Product f g) x)
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> h (t g x)
htg))
  {-# INLINE gprod #-}
instance
  ( Applicative h
  , Applicative m
  , ApplicativeT t
  ) => GApplicative 1 f g (Rec (m (h (t (P 1 f) x))) (m (h (t f x))))
                          (Rec (m (h (t (P 1 g) x))) (m (h (t g x))))
                          (Rec (m (h (t (P 1 (f `Product` g)) x))) (m (h (t (f `Product` g) x))))
  where
  gpure :: Proxy 1
-> Proxy f
-> Proxy (Rec (m (h (t (P 1 f) x))) (m (h (t f x))))
-> Proxy
     (Rec (m (h (t (P 1 (Product f g)) x))) (m (h (t (Product f g) x))))
-> (forall (a :: k). f a)
-> Rec (m (h (t (P 1 f) x))) (m (h (t f x))) x
gpure Proxy 1
_ Proxy f
_ Proxy (Rec (m (h (t (P 1 f) x))) (m (h (t f x))))
_ Proxy
  (Rec (m (h (t (P 1 (Product f g)) x))) (m (h (t (Product f g) x))))
_ forall (a :: k). f a
x
    = K1 R (m (h (t f x))) x
-> Rec (m (h (t (P 1 f) x))) (m (h (t f x))) x
forall k p a (x :: k). K1 R a x -> Rec p a x
Rec (m (h (t f x)) -> K1 R (m (h (t f x))) x
forall k i c (p :: k). c -> K1 i c p
K1 (h (t f x) -> m (h (t f x))
forall (f :: * -> *) a. Applicative f => a -> f a
pure (h (t f x) -> m (h (t f x)))
-> (t f x -> h (t f x)) -> t f x -> m (h (t f x))
forall b c a. (b -> c) -> (a -> b) -> a -> c
. t f x -> h (t f x)
forall (f :: * -> *) a. Applicative f => a -> f a
pure (t f x -> m (h (t f x))) -> t f x -> m (h (t f x))
forall a b. (a -> b) -> a -> b
$ (forall (a :: k). f a) -> t f x
forall k k' (t :: (k -> *) -> k' -> *) (f :: k -> *) (x :: k').
ApplicativeT t =>
(forall (a :: k). f a) -> t f x
tpure forall (a :: k). f a
x))
  {-# INLINE gpure #-}
  gprod :: Proxy 1
-> Proxy f
-> Proxy g
-> Rec (m (h (t (P 1 f) x))) (m (h (t f x))) x
-> Rec (m (h (t (P 1 g) x))) (m (h (t g x))) x
-> Rec
     (m (h (t (P 1 (Product f g)) x))) (m (h (t (Product f g) x))) x
gprod Proxy 1
_ Proxy f
_ Proxy g
_ (Rec (K1 m (h (t f x))
htfx)) (Rec (K1 m (h (t g x))
htgx))
    = K1 R (m (h (t (Product f g) x))) x
-> Rec
     (m (h (t (P 1 (Product f g)) x))) (m (h (t (Product f g) x))) x
forall k p a (x :: k). K1 R a x -> Rec p a x
Rec (m (h (t (Product f g) x)) -> K1 R (m (h (t (Product f g) x))) x
forall k i c (p :: k). c -> K1 i c p
K1 (h (t f x) -> h (t g x) -> h (t (Product f g) x)
forall k k' (f :: * -> *) (t :: (k -> *) -> k' -> *) (f :: k -> *)
       (x :: k') (g :: k -> *).
(Applicative f, ApplicativeT t) =>
f (t f x) -> f (t g x) -> f (t (Product f g) x)
go (h (t f x) -> h (t g x) -> h (t (Product f g) x))
-> m (h (t f x)) -> m (h (t g x) -> h (t (Product f g) x))
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> m (h (t f x))
htfx m (h (t g x) -> h (t (Product f g) x))
-> m (h (t g x)) -> m (h (t (Product f g) x))
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> m (h (t g x))
htgx))
    where
      go :: f (t f x) -> f (t g x) -> f (t (Product f g) x)
go f (t f x)
a f (t g x)
b = t f x -> t g x -> t (Product f g) x
forall k k' (t :: (k -> *) -> k' -> *) (f :: k -> *) (x :: k')
       (g :: k -> *).
ApplicativeT t =>
t f x -> t g x -> t (Product f g) x
tprod (t f x -> t g x -> t (Product f g) x)
-> f (t f x) -> f (t g x -> t (Product f g) x)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> f (t f x)
a f (t g x -> t (Product f g) x)
-> f (t g x) -> f (t (Product f g) x)
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> f (t g x)
b
  {-# INLINE gprod #-}
instance Applicative f => ApplicativeT (Compose f) where
  tpure :: (forall (a :: k'). f a) -> Compose f f x
tpure forall (a :: k'). f a
fa
    = f (f x) -> Compose f f x
forall k k1 (f :: k -> *) (g :: k1 -> k) (a :: k1).
f (g a) -> Compose f g a
Compose (f x -> f (f x)
forall (f :: * -> *) a. Applicative f => a -> f a
pure f x
forall (a :: k'). f a
fa)
  {-# INLINE tpure #-}
  tprod :: Compose f f x -> Compose f g x -> Compose f (Product f g) x
tprod (Compose f (f x)
fga) (Compose f (g x)
fha)
    = f (Product f g x) -> Compose f (Product f g) x
forall k k1 (f :: k -> *) (g :: k1 -> k) (a :: k1).
f (g a) -> Compose f g a
Compose (f x -> g x -> Product f g x
forall k (f :: k -> *) (g :: k -> *) (a :: k).
f a -> g a -> Product f g a
Pair (f x -> g x -> Product f g x)
-> f (f x) -> f (g x -> Product f g x)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> f (f x)
fga f (g x -> Product f g x) -> f (g x) -> f (Product f g x)
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> f (g x)
fha)
  {-# INLINE tprod #-}
instance ApplicativeT Reverse where
  tpure :: (forall (a :: k'). f a) -> Reverse f x
tpure forall (a :: k'). f a
fa
    = f x -> Reverse f x
forall k (f :: k -> *) (a :: k). f a -> Reverse f a
Reverse f x
forall (a :: k'). f a
fa
  {-# INLINE tpure #-}
  tprod :: Reverse f x -> Reverse g x -> Reverse (Product f g) x
tprod (Reverse f x
fa) (Reverse g x
ga)
    = Product f g x -> Reverse (Product f g) x
forall k (f :: k -> *) (a :: k). f a -> Reverse f a
Reverse (f x -> g x -> Product f g x
forall k (f :: k -> *) (g :: k -> *) (a :: k).
f a -> g a -> Product f g a
Pair f x
fa g x
ga)
  {-# INLINE tprod #-}
instance Alternative f => ApplicativeT (Product f) where
  tpure :: (forall a. f a) -> Product f f x
tpure forall a. f a
fa
    = f x -> f x -> Product f f x
forall k (f :: k -> *) (g :: k -> *) (a :: k).
f a -> g a -> Product f g a
Pair f x
forall (f :: * -> *) a. Alternative f => f a
empty f x
forall a. f a
fa
  {-# INLINE tpure #-}
  tprod :: Product f f x -> Product f g x -> Product f (Product f g) x
tprod (Pair f x
fl f x
gl) (Pair f x
fr g x
gr)
    = f x -> Product f g x -> Product f (Product f g) x
forall k (f :: k -> *) (g :: k -> *) (a :: k).
f a -> g a -> Product f g a
Pair (f x
fl f x -> f x -> f x
forall (f :: * -> *) a. Alternative f => f a -> f a -> f a
<|> f x
fr) (f x -> g x -> Product f g x
forall k (f :: k -> *) (g :: k -> *) (a :: k).
f a -> g a -> Product f g a
Pair f x
gl g x
gr)
  {-# INLINE tprod #-}
instance Alternative f => ApplicativeT (Sum f) where
  tpure :: (forall a. f a) -> Sum f f x
tpure forall a. f a
fa
    = f x -> Sum f f x
forall k (f :: k -> *) (g :: k -> *) (a :: k). g a -> Sum f g a
InR f x
forall a. f a
fa
  {-# INLINE tpure #-}
  tprod :: Sum f f x -> Sum f g x -> Sum f (Product f g) x
tprod Sum f f x
l Sum f g x
r
    = case (Sum f f x
l, Sum f g x
r) of
        (InR f x
gl, InR g x
gr) -> Product f g x -> Sum f (Product f g) x
forall k (f :: k -> *) (g :: k -> *) (a :: k). g a -> Sum f g a
InR (f x -> g x -> Product f g x
forall k (f :: k -> *) (g :: k -> *) (a :: k).
f a -> g a -> Product f g a
Pair f x
gl g x
gr)
        (InR f x
_,  InL f x
fr) -> f x -> Sum f (Product f g) x
forall k (f :: k -> *) (g :: k -> *) (a :: k). f a -> Sum f g a
InL f x
fr
        (InL f x
fl, InR g x
_)  -> f x -> Sum f (Product f g) x
forall k (f :: k -> *) (g :: k -> *) (a :: k). f a -> Sum f g a
InL f x
fl
        (InL f x
fl, InL f x
fr) -> f x -> Sum f (Product f g) x
forall k (f :: k -> *) (g :: k -> *) (a :: k). f a -> Sum f g a
InL (f x
fl f x -> f x -> f x
forall (f :: * -> *) a. Alternative f => f a -> f a -> f a
<|> f x
fr)
  {-# INLINE tprod #-}