| Safe Haskell | None |
|---|---|
| Language | GHC2024 |
Proarrow.Category.Instance.Coproduct
Documentation
data COPRODUCT j k Source Comments #
Instances
data ((p :: j1 +-> k1) :++: (q :: j2 +-> k2)) (a :: COPRODUCT k1 k2) (b :: COPRODUCT j1 j2) where Source Comments #
Constructors
| InjL :: forall {j1} {k1} {j2} {k2} (p :: j1 +-> k1) (a1 :: k1) (b1 :: j1) (q :: j2 +-> k2). p a1 b1 -> (p :++: q) ('L a1 :: COPRODUCT k1 k2) ('L b1 :: COPRODUCT j1 j2) | |
| InjR :: forall {j2} {k2} {j1} {k1} (q :: j2 +-> k2) (a1 :: k2) (b1 :: j2) (p :: j1 +-> k1). q a1 b1 -> (p :++: q) ('R a1 :: COPRODUCT k1 k2) ('R b1 :: COPRODUCT j1 j2) |
Instances
| (Profunctor p, Profunctor q) => Profunctor (p :++: q :: COPRODUCT k1 k2 -> COPRODUCT j1 j2 -> Type) Source Comments # | |
Defined in Proarrow.Category.Instance.Coproduct Methods dimap :: forall (c :: COPRODUCT k1 k2) (a :: COPRODUCT k1 k2) (b :: COPRODUCT j1 j2) (d :: COPRODUCT j1 j2). (c ~> a) -> (b ~> d) -> (p :++: q) a b -> (p :++: q) c d Source Comments # (\\) :: forall (a :: COPRODUCT k1 k2) (b :: COPRODUCT j1 j2) r. ((Ob a, Ob b) => r) -> (p :++: q) a b -> r Source Comments # | |
| (DaggerProfunctor p, DaggerProfunctor q) => DaggerProfunctor (p :++: q :: COPRODUCT j1 j2 -> COPRODUCT j1 j2 -> Type) Source Comments # | |
| (Promonad p, Promonad q) => Promonad (p :++: q :: COPRODUCT j1 j2 -> COPRODUCT j1 j2 -> Type) Source Comments # | The coproduct of two promonads. |