semigroupoids-6: Semigroupoids: Category sans id
Copyright(C) 2011-2015 Edward Kmett
LicenseBSD-style (see the file LICENSE)
MaintainerEdward Kmett <ekmett@gmail.com>
Stabilityprovisional
Portabilityportable
Safe HaskellSafe
LanguageHaskell2010

Data.Semigroup.Bifoldable

Description

Re-exports a subset of the Data.Bifoldable1 module along with some additional combinators that require Bifoldable1 constraints.

Synopsis

Documentation

class Bifoldable t => Bifoldable1 (t :: TYPE LiftedRep -> TYPE LiftedRep -> Type) where #

Minimal complete definition

bifoldMap1

Methods

bifold1 :: Semigroup m => t m m -> m #

bifoldMap1 :: Semigroup m => (a -> m) -> (b -> m) -> t a b -> m #

Instances

Instances details
Bifoldable1 Either 
Instance details

Defined in Data.Bifoldable1

Methods

bifold1 :: Semigroup m => Either m m -> m #

bifoldMap1 :: Semigroup m => (a -> m) -> (b -> m) -> Either a b -> m #

Bifoldable1 Arg 
Instance details

Defined in Data.Bifoldable1

Methods

bifold1 :: Semigroup m => Arg m m -> m #

bifoldMap1 :: Semigroup m => (a -> m) -> (b -> m) -> Arg a b -> m #

Bifoldable1 (,) 
Instance details

Defined in Data.Bifoldable1

Methods

bifold1 :: Semigroup m => (m, m) -> m #

bifoldMap1 :: Semigroup m => (a -> m) -> (b -> m) -> (a, b) -> m #

Bifoldable1 (Const :: Type -> TYPE LiftedRep -> Type) 
Instance details

Defined in Data.Bifoldable1

Methods

bifold1 :: Semigroup m => Const m m -> m #

bifoldMap1 :: Semigroup m => (a -> m) -> (b -> m) -> Const a b -> m #

Bifoldable1 (Tagged :: TYPE LiftedRep -> Type -> Type) 
Instance details

Defined in Data.Bifoldable1

Methods

bifold1 :: Semigroup m => Tagged m m -> m #

bifoldMap1 :: Semigroup m => (a -> m) -> (b -> m) -> Tagged a b -> m #

Bifoldable1 ((,,) x) 
Instance details

Defined in Data.Bifoldable1

Methods

bifold1 :: Semigroup m => (x, m, m) -> m #

bifoldMap1 :: Semigroup m => (a -> m) -> (b -> m) -> (x, a, b) -> m #

Bifoldable1 ((,,,) x y) 
Instance details

Defined in Data.Bifoldable1

Methods

bifold1 :: Semigroup m => (x, y, m, m) -> m #

bifoldMap1 :: Semigroup m => (a -> m) -> (b -> m) -> (x, y, a, b) -> m #

Foldable1 f => Bifoldable1 (Clown f :: TYPE LiftedRep -> TYPE LiftedRep -> Type) 
Instance details

Defined in Data.Bifunctor.Clown

Methods

bifold1 :: Semigroup m => Clown f m m -> m #

bifoldMap1 :: Semigroup m => (a -> m) -> (b -> m) -> Clown f a b -> m #

Bifoldable1 p => Bifoldable1 (Flip p) 
Instance details

Defined in Data.Bifunctor.Flip

Methods

bifold1 :: Semigroup m => Flip p m m -> m #

bifoldMap1 :: Semigroup m => (a -> m) -> (b -> m) -> Flip p a b -> m #

Foldable1 g => Bifoldable1 (Joker g :: TYPE LiftedRep -> TYPE LiftedRep -> Type) 
Instance details

Defined in Data.Bifunctor.Joker

Methods

bifold1 :: Semigroup m => Joker g m m -> m #

bifoldMap1 :: Semigroup m => (a -> m) -> (b -> m) -> Joker g a b -> m #

Bifoldable1 p => Bifoldable1 (WrappedBifunctor p) 
Instance details

Defined in Data.Bifunctor.Wrapped

Methods

bifold1 :: Semigroup m => WrappedBifunctor p m m -> m #

bifoldMap1 :: Semigroup m => (a -> m) -> (b -> m) -> WrappedBifunctor p a b -> m #

Bifoldable1 ((,,,,) x y z) 
Instance details

Defined in Data.Bifoldable1

Methods

bifold1 :: Semigroup m => (x, y, z, m, m) -> m #

bifoldMap1 :: Semigroup m => (a -> m) -> (b -> m) -> (x, y, z, a, b) -> m #

(Bifoldable1 f, Bifoldable1 g) => Bifoldable1 (Product f g) 
Instance details

Defined in Data.Bifunctor.Product

Methods

bifold1 :: Semigroup m => Product f g m m -> m #

bifoldMap1 :: Semigroup m => (a -> m) -> (b -> m) -> Product f g a b -> m #

(Foldable1 f, Bifoldable1 p) => Bifoldable1 (Tannen f p) 
Instance details

Defined in Data.Bifunctor.Tannen

Methods

bifold1 :: Semigroup m => Tannen f p m m -> m #

bifoldMap1 :: Semigroup m => (a -> m) -> (b -> m) -> Tannen f p a b -> m #

(Bifoldable1 p, Foldable1 f, Foldable1 g) => Bifoldable1 (Biff p f g) 
Instance details

Defined in Data.Bifunctor.Biff

Methods

bifold1 :: Semigroup m => Biff p f g m m -> m #

bifoldMap1 :: Semigroup m => (a -> m) -> (b -> m) -> Biff p f g a b -> m #

bitraverse1_ :: (Bifoldable1 t, Apply f) => (a -> f b) -> (c -> f d) -> t a c -> f () Source #

bifor1_ :: (Bifoldable1 t, Apply f) => t a c -> (a -> f b) -> (c -> f d) -> f () Source #

bisequenceA1_ :: (Bifoldable1 t, Apply f) => t (f a) (f b) -> f () Source #

bifoldMapDefault1 :: (Bifoldable1 t, Monoid m) => (a -> m) -> (b -> m) -> t a b -> m Source #

Usable default for foldMap, but only if you define bifoldMap1 yourself