Copyright | (C) 2008-2016 Jesse Selover Edward Kmett |
---|---|
License | BSD-style (see the file LICENSE) |
Maintainer | Edward Kmett <ekmett@gmail.com> |
Stability | provisional |
Portability | portable |
Safe Haskell | Safe |
Language | Haskell2010 |
The product of two bifunctors.
Documentation
Form the product of two bifunctors
Pair (f a b) (g a b) |
Instances
BifunctorFunctor ( Product p :: (k1 -> k2 -> Type ) -> k1 -> k2 -> Type ) Source # | |
BifunctorComonad ( Product p :: (k1 -> k2 -> Type ) -> k1 -> k2 -> Type ) Source # | |
Defined in Data.Bifunctor.Product biextract :: forall (p0 :: k -> k -> Type ). Product p p0 :-> p0 Source # biextend :: forall (p0 :: k -> k -> Type ) (q :: k -> k -> Type ). ( Product p p0 :-> q) -> Product p p0 :-> Product p q Source # biduplicate :: forall (p0 :: k -> k -> Type ). Product p p0 :-> Product p ( Product p p0) Source # |
|
( Category p, Category q) => Category ( Product p q :: k -> k -> Type ) Source # | |
Generic1 ( Product f g a :: k1 -> Type ) Source # | |
( Bitraversable f, Bitraversable g) => Bitraversable ( Product f g) Source # | |
Defined in Data.Bifunctor.Product bitraverse :: Applicative f0 => (a -> f0 c) -> (b -> f0 d) -> Product f g a b -> f0 ( Product f g c d) Source # |
|
( Bifoldable f, Bifoldable g) => Bifoldable ( Product f g) Source # | |
Defined in Data.Bifunctor.Product |
|
( Bifunctor f, Bifunctor g) => Bifunctor ( Product f g) Source # | |
( Eq2 f, Eq2 g) => Eq2 ( Product f g) Source # | |
( Ord2 f, Ord2 g) => Ord2 ( Product f g) Source # | |
Defined in Data.Bifunctor.Product |
|
( Read2 f, Read2 g) => Read2 ( Product f g) Source # | |
Defined in Data.Bifunctor.Product liftReadsPrec2 :: ( Int -> ReadS a) -> ReadS [a] -> ( Int -> ReadS b) -> ReadS [b] -> Int -> ReadS ( Product f g a b) Source # liftReadList2 :: ( Int -> ReadS a) -> ReadS [a] -> ( Int -> ReadS b) -> ReadS [b] -> ReadS [ Product f g a b] Source # liftReadPrec2 :: ReadPrec a -> ReadPrec [a] -> ReadPrec b -> ReadPrec [b] -> ReadPrec ( Product f g a b) Source # liftReadListPrec2 :: ReadPrec a -> ReadPrec [a] -> ReadPrec b -> ReadPrec [b] -> ReadPrec [ Product f g a b] Source # |
|
( Show2 f, Show2 g) => Show2 ( Product f g) Source # | |
Defined in Data.Bifunctor.Product |
|
( Arrow p, Arrow q) => Arrow ( Product p q) Source # | |
Defined in Data.Bifunctor.Product arr :: (b -> c) -> Product p q b c Source # first :: Product p q b c -> Product p q (b, d) (c, d) Source # second :: Product p q b c -> Product p q (d, b) (d, c) Source # (***) :: Product p q b c -> Product p q b' c' -> Product p q (b, b') (c, c') Source # (&&&) :: Product p q b c -> Product p q b c' -> Product p q b (c, c') Source # |
|
( ArrowZero p, ArrowZero q) => ArrowZero ( Product p q) Source # | |
Defined in Data.Bifunctor.Product |
|
( ArrowPlus p, ArrowPlus q) => ArrowPlus ( Product p q) Source # | |
( ArrowChoice p, ArrowChoice q) => ArrowChoice ( Product p q) Source # | |
Defined in Data.Bifunctor.Product left :: Product p q b c -> Product p q ( Either b d) ( Either c d) Source # right :: Product p q b c -> Product p q ( Either d b) ( Either d c) Source # (+++) :: Product p q b c -> Product p q b' c' -> Product p q ( Either b b') ( Either c c') Source # (|||) :: Product p q b d -> Product p q c d -> Product p q ( Either b c) d Source # |
|
( ArrowLoop p, ArrowLoop q) => ArrowLoop ( Product p q) Source # | |
( Biapplicative f, Biapplicative g) => Biapplicative ( Product f g) Source # | |
Defined in Data.Bifunctor.Product bipure :: a -> b -> Product f g a b Source # (<<*>>) :: Product f g (a -> b) (c -> d) -> Product f g a c -> Product f g b d Source # biliftA2 :: (a -> b -> c) -> (d -> e -> f0) -> Product f g a d -> Product f g b e -> Product f g c f0 Source # (*>>) :: Product f g a b -> Product f g c d -> Product f g c d Source # (<<*) :: Product f g a b -> Product f g c d -> Product f g a b Source # |
|
( Functor (f a), Functor (g a)) => Functor ( Product f g a) Source # | |
( Foldable (f a), Foldable (g a)) => Foldable ( Product f g a) Source # | |
Defined in Data.Bifunctor.Product fold :: Monoid m => Product f g a m -> m Source # foldMap :: Monoid m => (a0 -> m) -> Product f g a a0 -> m Source # foldMap' :: Monoid m => (a0 -> m) -> Product f g a a0 -> m Source # foldr :: (a0 -> b -> b) -> b -> Product f g a a0 -> b Source # foldr' :: (a0 -> b -> b) -> b -> Product f g a a0 -> b Source # foldl :: (b -> a0 -> b) -> b -> Product f g a a0 -> b Source # foldl' :: (b -> a0 -> b) -> b -> Product f g a a0 -> b Source # foldr1 :: (a0 -> a0 -> a0) -> Product f g a a0 -> a0 Source # foldl1 :: (a0 -> a0 -> a0) -> Product f g a a0 -> a0 Source # toList :: Product f g a a0 -> [a0] Source # null :: Product f g a a0 -> Bool Source # length :: Product f g a a0 -> Int Source # elem :: Eq a0 => a0 -> Product f g a a0 -> Bool Source # maximum :: Ord a0 => Product f g a a0 -> a0 Source # minimum :: Ord a0 => Product f g a a0 -> a0 Source # |
|
( Traversable (f a), Traversable (g a)) => Traversable ( Product f g a) Source # | |
Defined in Data.Bifunctor.Product traverse :: Applicative f0 => (a0 -> f0 b) -> Product f g a a0 -> f0 ( Product f g a b) Source # sequenceA :: Applicative f0 => Product f g a (f0 a0) -> f0 ( Product f g a a0) Source # mapM :: Monad m => (a0 -> m b) -> Product f g a a0 -> m ( Product f g a b) Source # sequence :: Monad m => Product f g a (m a0) -> m ( Product f g a a0) Source # |
|
( Eq2 f, Eq2 g, Eq a) => Eq1 ( Product f g a) Source # | |
( Ord2 f, Ord2 g, Ord a) => Ord1 ( Product f g a) Source # | |
Defined in Data.Bifunctor.Product |
|
( Read2 f, Read2 g, Read a) => Read1 ( Product f g a) Source # | |
Defined in Data.Bifunctor.Product liftReadsPrec :: ( Int -> ReadS a0) -> ReadS [a0] -> Int -> ReadS ( Product f g a a0) Source # liftReadList :: ( Int -> ReadS a0) -> ReadS [a0] -> ReadS [ Product f g a a0] Source # liftReadPrec :: ReadPrec a0 -> ReadPrec [a0] -> ReadPrec ( Product f g a a0) Source # liftReadListPrec :: ReadPrec a0 -> ReadPrec [a0] -> ReadPrec [ Product f g a a0] Source # |
|
( Show2 f, Show2 g, Show a) => Show1 ( Product f g a) Source # | |
( Eq (f a b), Eq (g a b)) => Eq ( Product f g a b) Source # | |
( Ord (f a b), Ord (g a b)) => Ord ( Product f g a b) Source # | |
Defined in Data.Bifunctor.Product compare :: Product f g a b -> Product f g a b -> Ordering Source # (<) :: Product f g a b -> Product f g a b -> Bool Source # (<=) :: Product f g a b -> Product f g a b -> Bool Source # (>) :: Product f g a b -> Product f g a b -> Bool Source # (>=) :: Product f g a b -> Product f g a b -> Bool Source # max :: Product f g a b -> Product f g a b -> Product f g a b Source # min :: Product f g a b -> Product f g a b -> Product f g a b Source # |
|
( Read (f a b), Read (g a b)) => Read ( Product f g a b) Source # | |
( Show (f a b), Show (g a b)) => Show ( Product f g a b) Source # | |
Generic ( Product f g a b) Source # | |
type Rep1 ( Product f g a :: k1 -> Type ) Source # | |
Defined in Data.Bifunctor.Product
type
Rep1
(
Product
f g a :: k1 ->
Type
) =
D1
('
MetaData
"Product" "Data.Bifunctor.Product" "bifunctors-5.5.14-4o2vxpA6iYN8K0rfLgtyzm" '
False
) (
C1
('
MetaCons
"Pair" '
PrefixI
'
False
) (
S1
('
MetaSel
('
Nothing
::
Maybe
Symbol
) '
NoSourceUnpackedness
'
NoSourceStrictness
'
DecidedLazy
) (
Rec1
(f a))
:*:
S1
('
MetaSel
('
Nothing
::
Maybe
Symbol
) '
NoSourceUnpackedness
'
NoSourceStrictness
'
DecidedLazy
) (
Rec1
(g a))))
|
|
type Rep ( Product f g a b) Source # | |
Defined in Data.Bifunctor.Product
type
Rep
(
Product
f g a b) =
D1
('
MetaData
"Product" "Data.Bifunctor.Product" "bifunctors-5.5.14-4o2vxpA6iYN8K0rfLgtyzm" '
False
) (
C1
('
MetaCons
"Pair" '
PrefixI
'
False
) (
S1
('
MetaSel
('
Nothing
::
Maybe
Symbol
) '
NoSourceUnpackedness
'
NoSourceStrictness
'
DecidedLazy
) (
Rec0
(f a b))
:*:
S1
('
MetaSel
('
Nothing
::
Maybe
Symbol
) '
NoSourceUnpackedness
'
NoSourceStrictness
'
DecidedLazy
) (
Rec0
(g a b))))
|