profunctors-5.2: Profunctors

Copyright(C) 2011-2015 Edward Kmett,
LicenseBSD-style (see the file LICENSE)
MaintainerEdward Kmett <ekmett@gmail.com>
Stabilityprovisional
Portabilityportable
Safe HaskellTrustworthy
LanguageHaskell2010

Data.Profunctor

Contents

Description

For a good explanation of profunctors in Haskell see Dan Piponi's article:

http://blog.sigfpe.com/2011/07/profunctors-in-haskell.html

For more information on strength and costrength, see:

http://comonad.com/reader/2008/deriving-strength-from-laziness/

Synopsis

Profunctors

class Profunctor p where Source

Formally, the class Profunctor represents a profunctor from Hask -> Hask.

Intuitively it is a bifunctor where the first argument is contravariant and the second argument is covariant.

You can define a Profunctor by either defining dimap or by defining both lmap and rmap.

If you supply dimap, you should ensure that:

dimap id idid

If you supply lmap and rmap, ensure:

lmap idid
rmap idid

If you supply both, you should also ensure:

dimap f g ≡ lmap f . rmap g

These ensure by parametricity:

dimap (f . g) (h . i) ≡ dimap g h . dimap f i
lmap (f . g) ≡ lmap g . lmap f
rmap (f . g) ≡ rmap f . rmap g

Minimal complete definition

dimap | lmap, rmap

Methods

dimap :: (a -> b) -> (c -> d) -> p b c -> p a d Source

Map over both arguments at the same time.

dimap f g ≡ lmap f . rmap g

lmap :: (a -> b) -> p b c -> p a c Source

Map the first argument contravariantly.

lmap f ≡ dimap f id

rmap :: (b -> c) -> p a b -> p a c Source

Map the second argument covariantly.

rmapdimap id

Instances

Profunctor (->) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> (b -> c) -> a -> d Source

lmap :: (a -> b) -> (b -> c) -> a -> c Source

rmap :: (b -> c) -> (a -> b) -> a -> c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> (a -> b) -> a -> c Source

(.#) :: Coercible (TYPE Lifted) b a => (b -> c) -> (a -> b) -> a -> c Source

Monad m => Profunctor (Kleisli m) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> Kleisli m b c -> Kleisli m a d Source

lmap :: (a -> b) -> Kleisli m b c -> Kleisli m a c Source

rmap :: (b -> c) -> Kleisli m a b -> Kleisli m a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> Kleisli m a b -> Kleisli m a c Source

(.#) :: Coercible (TYPE Lifted) b a => Kleisli m b c -> (a -> b) -> Kleisli m a c Source

Profunctor (Tagged (TYPE Lifted)) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> Tagged (TYPE Lifted) b c -> Tagged (TYPE Lifted) a d Source

lmap :: (a -> b) -> Tagged (TYPE Lifted) b c -> Tagged (TYPE Lifted) a c Source

rmap :: (b -> c) -> Tagged (TYPE Lifted) a b -> Tagged (TYPE Lifted) a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> Tagged (TYPE Lifted) a b -> Tagged (TYPE Lifted) a c Source

(.#) :: Coercible (TYPE Lifted) b a => Tagged (TYPE Lifted) b c -> (a -> b) -> Tagged (TYPE Lifted) a c Source

Functor w => Profunctor (Cokleisli w) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> Cokleisli w b c -> Cokleisli w a d Source

lmap :: (a -> b) -> Cokleisli w b c -> Cokleisli w a c Source

rmap :: (b -> c) -> Cokleisli w a b -> Cokleisli w a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> Cokleisli w a b -> Cokleisli w a c Source

(.#) :: Coercible (TYPE Lifted) b a => Cokleisli w b c -> (a -> b) -> Cokleisli w a c Source

Profunctor (Forget r) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> Forget r b c -> Forget r a d Source

lmap :: (a -> b) -> Forget r b c -> Forget r a c Source

rmap :: (b -> c) -> Forget r a b -> Forget r a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> Forget r a b -> Forget r a c Source

(.#) :: Coercible (TYPE Lifted) b a => Forget r b c -> (a -> b) -> Forget r a c Source

Arrow p => Profunctor (WrappedArrow p) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> WrappedArrow p b c -> WrappedArrow p a d Source

lmap :: (a -> b) -> WrappedArrow p b c -> WrappedArrow p a c Source

rmap :: (b -> c) -> WrappedArrow p a b -> WrappedArrow p a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> WrappedArrow p a b -> WrappedArrow p a c Source

(.#) :: Coercible (TYPE Lifted) b a => WrappedArrow p b c -> (a -> b) -> WrappedArrow p a c Source

Functor f => Profunctor (Costar f) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> Costar f b c -> Costar f a d Source

lmap :: (a -> b) -> Costar f b c -> Costar f a c Source

rmap :: (b -> c) -> Costar f a b -> Costar f a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> Costar f a b -> Costar f a c Source

(.#) :: Coercible (TYPE Lifted) b a => Costar f b c -> (a -> b) -> Costar f a c Source

Functor f => Profunctor (Star f) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> Star f b c -> Star f a d Source

lmap :: (a -> b) -> Star f b c -> Star f a c Source

rmap :: (b -> c) -> Star f a b -> Star f a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> Star f a b -> Star f a c Source

(.#) :: Coercible (TYPE Lifted) b a => Star f b c -> (a -> b) -> Star f a c Source

Profunctor (Copastro p) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> Copastro p b c -> Copastro p a d Source

lmap :: (a -> b) -> Copastro p b c -> Copastro p a c Source

rmap :: (b -> c) -> Copastro p a b -> Copastro p a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> Copastro p a b -> Copastro p a c Source

(.#) :: Coercible (TYPE Lifted) b a => Copastro p b c -> (a -> b) -> Copastro p a c Source

Profunctor (Cotambara p) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> Cotambara p b c -> Cotambara p a d Source

lmap :: (a -> b) -> Cotambara p b c -> Cotambara p a c Source

rmap :: (b -> c) -> Cotambara p a b -> Cotambara p a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> Cotambara p a b -> Cotambara p a c Source

(.#) :: Coercible (TYPE Lifted) b a => Cotambara p b c -> (a -> b) -> Cotambara p a c Source

Profunctor (Pastro p) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> Pastro p b c -> Pastro p a d Source

lmap :: (a -> b) -> Pastro p b c -> Pastro p a c Source

rmap :: (b -> c) -> Pastro p a b -> Pastro p a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> Pastro p a b -> Pastro p a c Source

(.#) :: Coercible (TYPE Lifted) b a => Pastro p b c -> (a -> b) -> Pastro p a c Source

Profunctor p => Profunctor (Tambara p) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> Tambara p b c -> Tambara p a d Source

lmap :: (a -> b) -> Tambara p b c -> Tambara p a c Source

rmap :: (b -> c) -> Tambara p a b -> Tambara p a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> Tambara p a b -> Tambara p a c Source

(.#) :: Coercible (TYPE Lifted) b a => Tambara p b c -> (a -> b) -> Tambara p a c Source

Profunctor (Environment p) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> Environment p b c -> Environment p a d Source

lmap :: (a -> b) -> Environment p b c -> Environment p a c Source

rmap :: (b -> c) -> Environment p a b -> Environment p a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> Environment p a b -> Environment p a c Source

(.#) :: Coercible (TYPE Lifted) b a => Environment p b c -> (a -> b) -> Environment p a c Source

Profunctor p => Profunctor (Closure p) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> Closure p b c -> Closure p a d Source

lmap :: (a -> b) -> Closure p b c -> Closure p a c Source

rmap :: (b -> c) -> Closure p a b -> Closure p a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> Closure p a b -> Closure p a c Source

(.#) :: Coercible (TYPE Lifted) b a => Closure p b c -> (a -> b) -> Closure p a c Source

Profunctor (CopastroSum p) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> CopastroSum p b c -> CopastroSum p a d Source

lmap :: (a -> b) -> CopastroSum p b c -> CopastroSum p a c Source

rmap :: (b -> c) -> CopastroSum p a b -> CopastroSum p a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> CopastroSum p a b -> CopastroSum p a c Source

(.#) :: Coercible (TYPE Lifted) b a => CopastroSum p b c -> (a -> b) -> CopastroSum p a c Source

Profunctor (CotambaraSum p) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> CotambaraSum p b c -> CotambaraSum p a d Source

lmap :: (a -> b) -> CotambaraSum p b c -> CotambaraSum p a c Source

rmap :: (b -> c) -> CotambaraSum p a b -> CotambaraSum p a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> CotambaraSum p a b -> CotambaraSum p a c Source

(.#) :: Coercible (TYPE Lifted) b a => CotambaraSum p b c -> (a -> b) -> CotambaraSum p a c Source

Profunctor (PastroSum p) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> PastroSum p b c -> PastroSum p a d Source

lmap :: (a -> b) -> PastroSum p b c -> PastroSum p a c Source

rmap :: (b -> c) -> PastroSum p a b -> PastroSum p a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> PastroSum p a b -> PastroSum p a c Source

(.#) :: Coercible (TYPE Lifted) b a => PastroSum p b c -> (a -> b) -> PastroSum p a c Source

Profunctor p => Profunctor (TambaraSum p) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> TambaraSum p b c -> TambaraSum p a d Source

lmap :: (a -> b) -> TambaraSum p b c -> TambaraSum p a c Source

rmap :: (b -> c) -> TambaraSum p a b -> TambaraSum p a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> TambaraSum p a b -> TambaraSum p a c Source

(.#) :: Coercible (TYPE Lifted) b a => TambaraSum p b c -> (a -> b) -> TambaraSum p a c Source

Profunctor (FreeTraversing p) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> FreeTraversing p b c -> FreeTraversing p a d Source

lmap :: (a -> b) -> FreeTraversing p b c -> FreeTraversing p a c Source

rmap :: (b -> c) -> FreeTraversing p a b -> FreeTraversing p a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> FreeTraversing p a b -> FreeTraversing p a c Source

(.#) :: Coercible (TYPE Lifted) b a => FreeTraversing p b c -> (a -> b) -> FreeTraversing p a c Source

Profunctor p => Profunctor (CofreeTraversing p) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> CofreeTraversing p b c -> CofreeTraversing p a d Source

lmap :: (a -> b) -> CofreeTraversing p b c -> CofreeTraversing p a c Source

rmap :: (b -> c) -> CofreeTraversing p a b -> CofreeTraversing p a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> CofreeTraversing p a b -> CofreeTraversing p a c Source

(.#) :: Coercible (TYPE Lifted) b a => CofreeTraversing p b c -> (a -> b) -> CofreeTraversing p a c Source

Profunctor (FreeMapping p) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> FreeMapping p b c -> FreeMapping p a d Source

lmap :: (a -> b) -> FreeMapping p b c -> FreeMapping p a c Source

rmap :: (b -> c) -> FreeMapping p a b -> FreeMapping p a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> FreeMapping p a b -> FreeMapping p a c Source

(.#) :: Coercible (TYPE Lifted) b a => FreeMapping p b c -> (a -> b) -> FreeMapping p a c Source

Profunctor p => Profunctor (CofreeMapping p) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> CofreeMapping p b c -> CofreeMapping p a d Source

lmap :: (a -> b) -> CofreeMapping p b c -> CofreeMapping p a c Source

rmap :: (b -> c) -> CofreeMapping p a b -> CofreeMapping p a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> CofreeMapping p a b -> CofreeMapping p a c Source

(.#) :: Coercible (TYPE Lifted) b a => CofreeMapping p b c -> (a -> b) -> CofreeMapping p a c Source

Profunctor p => Profunctor (Codensity p) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> Codensity p b c -> Codensity p a d Source

lmap :: (a -> b) -> Codensity p b c -> Codensity p a c Source

rmap :: (b -> c) -> Codensity p a b -> Codensity p a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> Codensity p a b -> Codensity p a c Source

(.#) :: Coercible (TYPE Lifted) b a => Codensity p b c -> (a -> b) -> Codensity p a c Source

(Functor f, Profunctor p) => Profunctor (Cayley f p) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> Cayley f p b c -> Cayley f p a d Source

lmap :: (a -> b) -> Cayley f p b c -> Cayley f p a c Source

rmap :: (b -> c) -> Cayley f p a b -> Cayley f p a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> Cayley f p a b -> Cayley f p a c Source

(.#) :: Coercible (TYPE Lifted) b a => Cayley f p b c -> (a -> b) -> Cayley f p a c Source

(Profunctor p, Profunctor q) => Profunctor (Rift p q) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> Rift p q b c -> Rift p q a d Source

lmap :: (a -> b) -> Rift p q b c -> Rift p q a c Source

rmap :: (b -> c) -> Rift p q a b -> Rift p q a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> Rift p q a b -> Rift p q a c Source

(.#) :: Coercible (TYPE Lifted) b a => Rift p q b c -> (a -> b) -> Rift p q a c Source

(Profunctor p, Profunctor q) => Profunctor (Procompose p q) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> Procompose p q b c -> Procompose p q a d Source

lmap :: (a -> b) -> Procompose p q b c -> Procompose p q a c Source

rmap :: (b -> c) -> Procompose p q a b -> Procompose p q a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> Procompose p q a b -> Procompose p q a c Source

(.#) :: Coercible (TYPE Lifted) b a => Procompose p q b c -> (a -> b) -> Procompose p q a c Source

(Profunctor p, Profunctor q) => Profunctor (Ran p q) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> Ran p q b c -> Ran p q a d Source

lmap :: (a -> b) -> Ran p q b c -> Ran p q a c Source

rmap :: (b -> c) -> Ran p q a b -> Ran p q a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> Ran p q a b -> Ran p q a c Source

(.#) :: Coercible (TYPE Lifted) b a => Ran p q b c -> (a -> b) -> Ran p q a c Source

Contravariant f => Profunctor (Clown (TYPE Lifted) (TYPE Lifted) f) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> Clown (TYPE Lifted) (TYPE Lifted) f b c -> Clown (TYPE Lifted) (TYPE Lifted) f a d Source

lmap :: (a -> b) -> Clown (TYPE Lifted) (TYPE Lifted) f b c -> Clown (TYPE Lifted) (TYPE Lifted) f a c Source

rmap :: (b -> c) -> Clown (TYPE Lifted) (TYPE Lifted) f a b -> Clown (TYPE Lifted) (TYPE Lifted) f a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> Clown (TYPE Lifted) (TYPE Lifted) f a b -> Clown (TYPE Lifted) (TYPE Lifted) f a c Source

(.#) :: Coercible (TYPE Lifted) b a => Clown (TYPE Lifted) (TYPE Lifted) f b c -> (a -> b) -> Clown (TYPE Lifted) (TYPE Lifted) f a c Source

Functor f => Profunctor (Joker (TYPE Lifted) (TYPE Lifted) f) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> Joker (TYPE Lifted) (TYPE Lifted) f b c -> Joker (TYPE Lifted) (TYPE Lifted) f a d Source

lmap :: (a -> b) -> Joker (TYPE Lifted) (TYPE Lifted) f b c -> Joker (TYPE Lifted) (TYPE Lifted) f a c Source

rmap :: (b -> c) -> Joker (TYPE Lifted) (TYPE Lifted) f a b -> Joker (TYPE Lifted) (TYPE Lifted) f a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> Joker (TYPE Lifted) (TYPE Lifted) f a b -> Joker (TYPE Lifted) (TYPE Lifted) f a c Source

(.#) :: Coercible (TYPE Lifted) b a => Joker (TYPE Lifted) (TYPE Lifted) f b c -> (a -> b) -> Joker (TYPE Lifted) (TYPE Lifted) f a c Source

(Profunctor p, Profunctor q) => Profunctor (Product (TYPE Lifted) (TYPE Lifted) p q) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> Product (TYPE Lifted) (TYPE Lifted) p q b c -> Product (TYPE Lifted) (TYPE Lifted) p q a d Source

lmap :: (a -> b) -> Product (TYPE Lifted) (TYPE Lifted) p q b c -> Product (TYPE Lifted) (TYPE Lifted) p q a c Source

rmap :: (b -> c) -> Product (TYPE Lifted) (TYPE Lifted) p q a b -> Product (TYPE Lifted) (TYPE Lifted) p q a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> Product (TYPE Lifted) (TYPE Lifted) p q a b -> Product (TYPE Lifted) (TYPE Lifted) p q a c Source

(.#) :: Coercible (TYPE Lifted) b a => Product (TYPE Lifted) (TYPE Lifted) p q b c -> (a -> b) -> Product (TYPE Lifted) (TYPE Lifted) p q a c Source

(Functor f, Profunctor p) => Profunctor (Tannen (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) f p) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> Tannen (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) f p b c -> Tannen (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) f p a d Source

lmap :: (a -> b) -> Tannen (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) f p b c -> Tannen (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) f p a c Source

rmap :: (b -> c) -> Tannen (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) f p a b -> Tannen (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) f p a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> Tannen (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) f p a b -> Tannen (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) f p a c Source

(.#) :: Coercible (TYPE Lifted) b a => Tannen (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) f p b c -> (a -> b) -> Tannen (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) f p a c Source

(Profunctor p, Functor f, Functor g) => Profunctor (Biff (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) p f g) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> Biff (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) p f g b c -> Biff (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) p f g a d Source

lmap :: (a -> b) -> Biff (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) p f g b c -> Biff (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) p f g a c Source

rmap :: (b -> c) -> Biff (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) p f g a b -> Biff (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) p f g a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> Biff (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) p f g a b -> Biff (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) p f g a c Source

(.#) :: Coercible (TYPE Lifted) b a => Biff (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) p f g b c -> (a -> b) -> Biff (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) p f g a c Source

Profunctorial Strength

class Profunctor p => Strong p where Source

Generalizing Star of a strong Functor

Note: Every Functor in Haskell is strong with respect to (,).

This describes profunctor strength with respect to the product structure of Hask.

http://www-kb.is.s.u-tokyo.ac.jp/~asada/papers/arrStrMnd.pdf

Minimal complete definition

first' | second'

Methods

first' :: p a b -> p (a, c) (b, c) Source

second' :: p a b -> p (c, a) (c, b) Source

Instances

Strong (->) Source 

Methods

first' :: (a -> b) -> (a, c) -> (b, c) Source

second' :: (a -> b) -> (c, a) -> (c, b) Source

Monad m => Strong (Kleisli m) Source 

Methods

first' :: Kleisli m a b -> Kleisli m (a, c) (b, c) Source

second' :: Kleisli m a b -> Kleisli m (c, a) (c, b) Source

Strong (Forget r) Source 

Methods

first' :: Forget r a b -> Forget r (a, c) (b, c) Source

second' :: Forget r a b -> Forget r (c, a) (c, b) Source

Arrow p => Strong (WrappedArrow p) Source

Arrow is Strong Category

Methods

first' :: WrappedArrow p a b -> WrappedArrow p (a, c) (b, c) Source

second' :: WrappedArrow p a b -> WrappedArrow p (c, a) (c, b) Source

Functor m => Strong (Star m) Source 

Methods

first' :: Star m a b -> Star m (a, c) (b, c) Source

second' :: Star m a b -> Star m (c, a) (c, b) Source

Strong (Pastro p) Source 

Methods

first' :: Pastro p a b -> Pastro p (a, c) (b, c) Source

second' :: Pastro p a b -> Pastro p (c, a) (c, b) Source

Profunctor p => Strong (Tambara p) Source 

Methods

first' :: Tambara p a b -> Tambara p (a, c) (b, c) Source

second' :: Tambara p a b -> Tambara p (c, a) (c, b) Source

Strong p => Strong (Closure p) Source 

Methods

first' :: Closure p a b -> Closure p (a, c) (b, c) Source

second' :: Closure p a b -> Closure p (c, a) (c, b) Source

Strong (FreeTraversing p) Source 

Methods

first' :: FreeTraversing p a b -> FreeTraversing p (a, c) (b, c) Source

second' :: FreeTraversing p a b -> FreeTraversing p (c, a) (c, b) Source

Profunctor p => Strong (CofreeTraversing p) Source 

Methods

first' :: CofreeTraversing p a b -> CofreeTraversing p (a, c) (b, c) Source

second' :: CofreeTraversing p a b -> CofreeTraversing p (c, a) (c, b) Source

Strong (FreeMapping p) Source 

Methods

first' :: FreeMapping p a b -> FreeMapping p (a, c) (b, c) Source

second' :: FreeMapping p a b -> FreeMapping p (c, a) (c, b) Source

Profunctor p => Strong (CofreeMapping p) Source 

Methods

first' :: CofreeMapping p a b -> CofreeMapping p (a, c) (b, c) Source

second' :: CofreeMapping p a b -> CofreeMapping p (c, a) (c, b) Source

(Functor f, Strong p) => Strong (Cayley f p) Source 

Methods

first' :: Cayley f p a b -> Cayley f p (a, c) (b, c) Source

second' :: Cayley f p a b -> Cayley f p (c, a) (c, b) Source

(Strong p, Strong q) => Strong (Procompose p q) Source 

Methods

first' :: Procompose p q a b -> Procompose p q (a, c) (b, c) Source

second' :: Procompose p q a b -> Procompose p q (c, a) (c, b) Source

Contravariant f => Strong (Clown (TYPE Lifted) (TYPE Lifted) f) Source 

Methods

first' :: Clown (TYPE Lifted) (TYPE Lifted) f a b -> Clown (TYPE Lifted) (TYPE Lifted) f (a, c) (b, c) Source

second' :: Clown (TYPE Lifted) (TYPE Lifted) f a b -> Clown (TYPE Lifted) (TYPE Lifted) f (c, a) (c, b) Source

(Strong p, Strong q) => Strong (Product (TYPE Lifted) (TYPE Lifted) p q) Source 

Methods

first' :: Product (TYPE Lifted) (TYPE Lifted) p q a b -> Product (TYPE Lifted) (TYPE Lifted) p q (a, c) (b, c) Source

second' :: Product (TYPE Lifted) (TYPE Lifted) p q a b -> Product (TYPE Lifted) (TYPE Lifted) p q (c, a) (c, b) Source

(Functor f, Strong p) => Strong (Tannen (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) f p) Source 

Methods

first' :: Tannen (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) f p a b -> Tannen (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) f p (a, c) (b, c) Source

second' :: Tannen (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) f p a b -> Tannen (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) f p (c, a) (c, b) Source

uncurry' :: Strong p => p a (b -> c) -> p (a, b) c Source

class Profunctor p => Choice p where Source

The generalization of Costar of Functor that is strong with respect to Either.

Note: This is also a notion of strength, except with regards to another monoidal structure that we can choose to equip Hask with: the cocartesian coproduct.

Minimal complete definition

left' | right'

Methods

left' :: p a b -> p (Either a c) (Either b c) Source

right' :: p a b -> p (Either c a) (Either c b) Source

Instances

Choice (->) Source 

Methods

left' :: (a -> b) -> Either a c -> Either b c Source

right' :: (a -> b) -> Either c a -> Either c b Source

Monad m => Choice (Kleisli m) Source 

Methods

left' :: Kleisli m a b -> Kleisli m (Either a c) (Either b c) Source

right' :: Kleisli m a b -> Kleisli m (Either c a) (Either c b) Source

Choice (Tagged (TYPE Lifted)) Source 

Methods

left' :: Tagged (TYPE Lifted) a b -> Tagged (TYPE Lifted) (Either a c) (Either b c) Source

right' :: Tagged (TYPE Lifted) a b -> Tagged (TYPE Lifted) (Either c a) (Either c b) Source

Comonad w => Choice (Cokleisli w) Source

extract approximates costrength

Methods

left' :: Cokleisli w a b -> Cokleisli w (Either a c) (Either b c) Source

right' :: Cokleisli w a b -> Cokleisli w (Either c a) (Either c b) Source

Monoid r => Choice (Forget r) Source 

Methods

left' :: Forget r a b -> Forget r (Either a c) (Either b c) Source

right' :: Forget r a b -> Forget r (Either c a) (Either c b) Source

ArrowChoice p => Choice (WrappedArrow p) Source 

Methods

left' :: WrappedArrow p a b -> WrappedArrow p (Either a c) (Either b c) Source

right' :: WrappedArrow p a b -> WrappedArrow p (Either c a) (Either c b) Source

Traversable w => Choice (Costar w) Source 

Methods

left' :: Costar w a b -> Costar w (Either a c) (Either b c) Source

right' :: Costar w a b -> Costar w (Either c a) (Either c b) Source

Applicative f => Choice (Star f) Source 

Methods

left' :: Star f a b -> Star f (Either a c) (Either b c) Source

right' :: Star f a b -> Star f (Either c a) (Either c b) Source

Choice p => Choice (Tambara p) Source 

Methods

left' :: Tambara p a b -> Tambara p (Either a c) (Either b c) Source

right' :: Tambara p a b -> Tambara p (Either c a) (Either c b) Source

Choice (PastroSum p) Source 

Methods

left' :: PastroSum p a b -> PastroSum p (Either a c) (Either b c) Source

right' :: PastroSum p a b -> PastroSum p (Either c a) (Either c b) Source

Profunctor p => Choice (TambaraSum p) Source 

Methods

left' :: TambaraSum p a b -> TambaraSum p (Either a c) (Either b c) Source

right' :: TambaraSum p a b -> TambaraSum p (Either c a) (Either c b) Source

Choice (FreeTraversing p) Source 

Methods

left' :: FreeTraversing p a b -> FreeTraversing p (Either a c) (Either b c) Source

right' :: FreeTraversing p a b -> FreeTraversing p (Either c a) (Either c b) Source

Profunctor p => Choice (CofreeTraversing p) Source 
Choice (FreeMapping p) Source 

Methods

left' :: FreeMapping p a b -> FreeMapping p (Either a c) (Either b c) Source

right' :: FreeMapping p a b -> FreeMapping p (Either c a) (Either c b) Source

Profunctor p => Choice (CofreeMapping p) Source 

Methods

left' :: CofreeMapping p a b -> CofreeMapping p (Either a c) (Either b c) Source

right' :: CofreeMapping p a b -> CofreeMapping p (Either c a) (Either c b) Source

(Functor f, Choice p) => Choice (Cayley f p) Source 

Methods

left' :: Cayley f p a b -> Cayley f p (Either a c) (Either b c) Source

right' :: Cayley f p a b -> Cayley f p (Either c a) (Either c b) Source

(Choice p, Choice q) => Choice (Procompose p q) Source 

Methods

left' :: Procompose p q a b -> Procompose p q (Either a c) (Either b c) Source

right' :: Procompose p q a b -> Procompose p q (Either c a) (Either c b) Source

Functor f => Choice (Joker (TYPE Lifted) (TYPE Lifted) f) Source 

Methods

left' :: Joker (TYPE Lifted) (TYPE Lifted) f a b -> Joker (TYPE Lifted) (TYPE Lifted) f (Either a c) (Either b c) Source

right' :: Joker (TYPE Lifted) (TYPE Lifted) f a b -> Joker (TYPE Lifted) (TYPE Lifted) f (Either c a) (Either c b) Source

(Choice p, Choice q) => Choice (Product (TYPE Lifted) (TYPE Lifted) p q) Source 

Methods

left' :: Product (TYPE Lifted) (TYPE Lifted) p q a b -> Product (TYPE Lifted) (TYPE Lifted) p q (Either a c) (Either b c) Source

right' :: Product (TYPE Lifted) (TYPE Lifted) p q a b -> Product (TYPE Lifted) (TYPE Lifted) p q (Either c a) (Either c b) Source

(Functor f, Choice p) => Choice (Tannen (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) f p) Source 

Methods

left' :: Tannen (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) f p a b -> Tannen (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) f p (Either a c) (Either b c) Source

right' :: Tannen (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) f p a b -> Tannen (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) f p (Either c a) (Either c b) Source

Closed

class Profunctor p => Closed p where Source

A strong profunctor allows the monoidal structure to pass through.

A closed profunctor allows the closed structure to pass through.

Minimal complete definition

closed

Methods

closed :: p a b -> p (x -> a) (x -> b) Source

Instances

Closed (->) Source 

Methods

closed :: (a -> b) -> (x -> a) -> x -> b Source

(Distributive f, Monad f) => Closed (Kleisli f) Source 

Methods

closed :: Kleisli f a b -> Kleisli f (x -> a) (x -> b) Source

Closed (Tagged (TYPE Lifted)) Source 

Methods

closed :: Tagged (TYPE Lifted) a b -> Tagged (TYPE Lifted) (x -> a) (x -> b) Source

Functor f => Closed (Cokleisli f) Source 

Methods

closed :: Cokleisli f a b -> Cokleisli f (x -> a) (x -> b) Source

Functor f => Closed (Costar f) Source 

Methods

closed :: Costar f a b -> Costar f (x -> a) (x -> b) Source

Distributive f => Closed (Star f) Source 

Methods

closed :: Star f a b -> Star f (x -> a) (x -> b) Source

Closed (Environment p) Source 

Methods

closed :: Environment p a b -> Environment p (x -> a) (x -> b) Source

Profunctor p => Closed (Closure p) Source 

Methods

closed :: Closure p a b -> Closure p (x -> a) (x -> b) Source

Closed (FreeMapping p) Source 

Methods

closed :: FreeMapping p a b -> FreeMapping p (x -> a) (x -> b) Source

Profunctor p => Closed (CofreeMapping p) Source 

Methods

closed :: CofreeMapping p a b -> CofreeMapping p (x -> a) (x -> b) Source

(Closed p, Closed q) => Closed (Procompose p q) Source 

Methods

closed :: Procompose p q a b -> Procompose p q (x -> a) (x -> b) Source

(Closed p, Closed q) => Closed (Product (TYPE Lifted) (TYPE Lifted) p q) Source 

Methods

closed :: Product (TYPE Lifted) (TYPE Lifted) p q a b -> Product (TYPE Lifted) (TYPE Lifted) p q (x -> a) (x -> b) Source

(Functor f, Closed p) => Closed (Tannen (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) f p) Source 

Methods

closed :: Tannen (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) f p a b -> Tannen (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) f p (x -> a) (x -> b) Source

curry' :: Closed p => p (a, b) c -> p a (b -> c) Source

class (Traversing p, Closed p) => Mapping p where Source

Minimal complete definition

map'

Methods

map' :: Functor f => p a b -> p (f a) (f b) Source

Instances

Mapping (->) Source 

Methods

map' :: Functor f => (a -> b) -> f a -> f b Source

(Monad m, Distributive m) => Mapping (Kleisli m) Source 

Methods

map' :: Functor f => Kleisli m a b -> Kleisli m (f a) (f b) Source

(Applicative m, Distributive m) => Mapping (Star m) Source 

Methods

map' :: Functor f => Star m a b -> Star m (f a) (f b) Source

Mapping (FreeMapping p) Source 

Methods

map' :: Functor f => FreeMapping p a b -> FreeMapping p (f a) (f b) Source

Profunctor p => Mapping (CofreeMapping p) Source 

Methods

map' :: Functor f => CofreeMapping p a b -> CofreeMapping p (f a) (f b) Source

Profunctorial Costrength

class Profunctor p => Costrong p where Source

Analogous to ArrowLoop, loop = unfirst

Minimal complete definition

unfirst | unsecond

Methods

unfirst :: p (a, d) (b, d) -> p a b Source

unsecond :: p (d, a) (d, b) -> p a b Source

Instances

Costrong (->) Source 

Methods

unfirst :: ((a, d) -> (b, d)) -> a -> b Source

unsecond :: ((d, a) -> (d, b)) -> a -> b Source

MonadFix m => Costrong (Kleisli m) Source 

Methods

unfirst :: Kleisli m (a, d) (b, d) -> Kleisli m a b Source

unsecond :: Kleisli m (d, a) (d, b) -> Kleisli m a b Source

Costrong (Tagged (TYPE Lifted)) Source 

Methods

unfirst :: Tagged (TYPE Lifted) (a, d) (b, d) -> Tagged (TYPE Lifted) a b Source

unsecond :: Tagged (TYPE Lifted) (d, a) (d, b) -> Tagged (TYPE Lifted) a b Source

Functor f => Costrong (Cokleisli f) Source 

Methods

unfirst :: Cokleisli f (a, d) (b, d) -> Cokleisli f a b Source

unsecond :: Cokleisli f (d, a) (d, b) -> Cokleisli f a b Source

ArrowLoop p => Costrong (WrappedArrow p) Source 

Methods

unfirst :: WrappedArrow p (a, d) (b, d) -> WrappedArrow p a b Source

unsecond :: WrappedArrow p (d, a) (d, b) -> WrappedArrow p a b Source

Functor f => Costrong (Costar f) Source 

Methods

unfirst :: Costar f (a, d) (b, d) -> Costar f a b Source

unsecond :: Costar f (d, a) (d, b) -> Costar f a b Source

Costrong (Copastro p) Source 

Methods

unfirst :: Copastro p (a, d) (b, d) -> Copastro p a b Source

unsecond :: Copastro p (d, a) (d, b) -> Copastro p a b Source

Costrong (Cotambara p) Source 

Methods

unfirst :: Cotambara p (a, d) (b, d) -> Cotambara p a b Source

unsecond :: Cotambara p (d, a) (d, b) -> Cotambara p a b Source

(Corepresentable p, Corepresentable q) => Costrong (Procompose p q) Source 

Methods

unfirst :: Procompose p q (a, d) (b, d) -> Procompose p q a b Source

unsecond :: Procompose p q (d, a) (d, b) -> Procompose p q a b Source

(Costrong p, Costrong q) => Costrong (Product (TYPE Lifted) (TYPE Lifted) p q) Source 

Methods

unfirst :: Product (TYPE Lifted) (TYPE Lifted) p q (a, d) (b, d) -> Product (TYPE Lifted) (TYPE Lifted) p q a b Source

unsecond :: Product (TYPE Lifted) (TYPE Lifted) p q (d, a) (d, b) -> Product (TYPE Lifted) (TYPE Lifted) p q a b Source

(Functor f, Costrong p) => Costrong (Tannen (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) f p) Source 

Methods

unfirst :: Tannen (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) f p (a, d) (b, d) -> Tannen (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) f p a b Source

unsecond :: Tannen (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) f p (d, a) (d, b) -> Tannen (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) f p a b Source

class Profunctor p => Cochoice p where Source

Minimal complete definition

unleft | unright

Methods

unleft :: p (Either a d) (Either b d) -> p a b Source

unright :: p (Either d a) (Either d b) -> p a b Source

Instances

Cochoice (->) Source 

Methods

unleft :: (Either a d -> Either b d) -> a -> b Source

unright :: (Either d a -> Either d b) -> a -> b Source

Applicative f => Cochoice (Costar f) Source 

Methods

unleft :: Costar f (Either a d) (Either b d) -> Costar f a b Source

unright :: Costar f (Either d a) (Either d b) -> Costar f a b Source

Traversable f => Cochoice (Star f) Source 

Methods

unleft :: Star f (Either a d) (Either b d) -> Star f a b Source

unright :: Star f (Either d a) (Either d b) -> Star f a b Source

Cochoice (CopastroSum p) Source 

Methods

unleft :: CopastroSum p (Either a d) (Either b d) -> CopastroSum p a b Source

unright :: CopastroSum p (Either d a) (Either d b) -> CopastroSum p a b Source

Cochoice (CotambaraSum p) Source 

Methods

unleft :: CotambaraSum p (Either a d) (Either b d) -> CotambaraSum p a b Source

unright :: CotambaraSum p (Either d a) (Either d b) -> CotambaraSum p a b Source

(Cochoice p, Cochoice q) => Cochoice (Product (TYPE Lifted) (TYPE Lifted) p q) Source 

Methods

unleft :: Product (TYPE Lifted) (TYPE Lifted) p q (Either a d) (Either b d) -> Product (TYPE Lifted) (TYPE Lifted) p q a b Source

unright :: Product (TYPE Lifted) (TYPE Lifted) p q (Either d a) (Either d b) -> Product (TYPE Lifted) (TYPE Lifted) p q a b Source

(Functor f, Cochoice p) => Cochoice (Tannen (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) f p) Source 

Methods

unleft :: Tannen (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) f p (Either a d) (Either b d) -> Tannen (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) f p a b Source

unright :: Tannen (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) f p (Either d a) (Either d b) -> Tannen (TYPE Lifted) (TYPE Lifted) (TYPE Lifted) f p a b Source

Common Profunctors

newtype Star f d c Source

Lift a Functor into a Profunctor (forwards).

Constructors

Star 

Fields

Instances

Functor f => Profunctor (Star f) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> Star f b c -> Star f a d Source

lmap :: (a -> b) -> Star f b c -> Star f a c Source

rmap :: (b -> c) -> Star f a b -> Star f a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> Star f a b -> Star f a c Source

(.#) :: Coercible (TYPE Lifted) b a => Star f b c -> (a -> b) -> Star f a c Source

Functor m => Strong (Star m) Source 

Methods

first' :: Star m a b -> Star m (a, c) (b, c) Source

second' :: Star m a b -> Star m (c, a) (c, b) Source

Distributive f => Closed (Star f) Source 

Methods

closed :: Star f a b -> Star f (x -> a) (x -> b) Source

Traversable f => Cochoice (Star f) Source 

Methods

unleft :: Star f (Either a d) (Either b d) -> Star f a b Source

unright :: Star f (Either d a) (Either d b) -> Star f a b Source

Applicative f => Choice (Star f) Source 

Methods

left' :: Star f a b -> Star f (Either a c) (Either b c) Source

right' :: Star f a b -> Star f (Either c a) (Either c b) Source

Applicative m => Traversing (Star m) Source 

Methods

traverse' :: Traversable f => Star m a b -> Star m (f a) (f b) Source

wander :: (forall f. Applicative f => (a -> f b) -> s -> f t) -> Star m a b -> Star m s t Source

(Applicative m, Distributive m) => Mapping (Star m) Source 

Methods

map' :: Functor f => Star m a b -> Star m (f a) (f b) Source

Functor f => Representable (Star f) Source 

Associated Types

type Rep (Star f :: TYPE Lifted -> TYPE Lifted -> TYPE Lifted) :: * -> * Source

Methods

tabulate :: (d -> Rep (Star f) c) -> Star f d c Source

Functor f => Sieve (Star f) f Source 

Methods

sieve :: Star f a b -> a -> f b Source

Monad f => Monad (Star f a) Source 

Methods

(>>=) :: Star f a a -> (a -> Star f a b) -> Star f a b

(>>) :: Star f a a -> Star f a b -> Star f a b

return :: a -> Star f a a

fail :: String -> Star f a a

Functor f => Functor (Star f a) Source 

Methods

fmap :: (a -> b) -> Star f a a -> Star f a b

(<$) :: a -> Star f a b -> Star f a a

Applicative f => Applicative (Star f a) Source 

Methods

pure :: a -> Star f a a

(<*>) :: Star f a (a -> b) -> Star f a a -> Star f a b

(*>) :: Star f a a -> Star f a b -> Star f a b

(<*) :: Star f a a -> Star f a b -> Star f a a

Alternative f => Alternative (Star f a) Source 

Methods

empty :: Star f a a

(<|>) :: Star f a a -> Star f a a -> Star f a a

some :: Star f a a -> Star f a [a]

many :: Star f a a -> Star f a [a]

MonadPlus f => MonadPlus (Star f a) Source 

Methods

mzero :: Star f a a

mplus :: Star f a a -> Star f a a -> Star f a a

Distributive f => Distributive (Star f a) Source 

Methods

distribute :: Functor f => f (Star f a a) -> Star f a (f a)

collect :: Functor f => (a -> Star f a b) -> f a -> Star f a (f b)

distributeM :: Monad m => m (Star f a a) -> Star f a (m a)

collectM :: Monad m => (a -> Star f a b) -> m a -> Star f a (m b)

type Rep (Star f) = f Source 

newtype Costar f d c Source

Lift a Functor into a Profunctor (backwards).

Constructors

Costar 

Fields

Instances

Functor f => Profunctor (Costar f) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> Costar f b c -> Costar f a d Source

lmap :: (a -> b) -> Costar f b c -> Costar f a c Source

rmap :: (b -> c) -> Costar f a b -> Costar f a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> Costar f a b -> Costar f a c Source

(.#) :: Coercible (TYPE Lifted) b a => Costar f b c -> (a -> b) -> Costar f a c Source

Functor f => Costrong (Costar f) Source 

Methods

unfirst :: Costar f (a, d) (b, d) -> Costar f a b Source

unsecond :: Costar f (d, a) (d, b) -> Costar f a b Source

Functor f => Closed (Costar f) Source 

Methods

closed :: Costar f a b -> Costar f (x -> a) (x -> b) Source

Applicative f => Cochoice (Costar f) Source 

Methods

unleft :: Costar f (Either a d) (Either b d) -> Costar f a b Source

unright :: Costar f (Either d a) (Either d b) -> Costar f a b Source

Traversable w => Choice (Costar w) Source 

Methods

left' :: Costar w a b -> Costar w (Either a c) (Either b c) Source

right' :: Costar w a b -> Costar w (Either c a) (Either c b) Source

Functor f => Corepresentable (Costar f) Source 

Associated Types

type Corep (Costar f :: TYPE Lifted -> TYPE Lifted -> TYPE Lifted) :: * -> * Source

Methods

cotabulate :: (Corep (Costar f) d -> c) -> Costar f d c Source

Functor f => Cosieve (Costar f) f Source 

Methods

cosieve :: Costar f a b -> f a -> b Source

Monad (Costar f a) Source 

Methods

(>>=) :: Costar f a a -> (a -> Costar f a b) -> Costar f a b

(>>) :: Costar f a a -> Costar f a b -> Costar f a b

return :: a -> Costar f a a

fail :: String -> Costar f a a

Functor (Costar f a) Source 

Methods

fmap :: (a -> b) -> Costar f a a -> Costar f a b

(<$) :: a -> Costar f a b -> Costar f a a

Applicative (Costar f a) Source 

Methods

pure :: a -> Costar f a a

(<*>) :: Costar f a (a -> b) -> Costar f a a -> Costar f a b

(*>) :: Costar f a a -> Costar f a b -> Costar f a b

(<*) :: Costar f a a -> Costar f a b -> Costar f a a

Distributive (Costar f d) Source 

Methods

distribute :: Functor f => f (Costar f d a) -> Costar f d (f a)

collect :: Functor f => (a -> Costar f d b) -> f a -> Costar f d (f b)

distributeM :: Monad m => m (Costar f d a) -> Costar f d (m a)

collectM :: Monad m => (a -> Costar f d b) -> m a -> Costar f d (m b)

type Corep (Costar f) = f Source 

newtype WrappedArrow p a b Source

Wrap an arrow for use as a Profunctor.

Constructors

WrapArrow 

Fields

Instances

Arrow p => Arrow (WrappedArrow p) Source 

Methods

arr :: (b -> c) -> WrappedArrow p b c

first :: WrappedArrow p b c -> WrappedArrow p (b, d) (c, d)

second :: WrappedArrow p b c -> WrappedArrow p (d, b) (d, c)

(***) :: WrappedArrow p b c -> WrappedArrow p b' c' -> WrappedArrow p (b, b') (c, c')

(&&&) :: WrappedArrow p b c -> WrappedArrow p b c' -> WrappedArrow p b (c, c')

ArrowZero p => ArrowZero (WrappedArrow p) Source 

Methods

zeroArrow :: WrappedArrow p b c

ArrowChoice p => ArrowChoice (WrappedArrow p) Source 

Methods

left :: WrappedArrow p b c -> WrappedArrow p (Either b d) (Either c d)

right :: WrappedArrow p b c -> WrappedArrow p (Either d b) (Either d c)

(+++) :: WrappedArrow p b c -> WrappedArrow p b' c' -> WrappedArrow p (Either b b') (Either c c')

(|||) :: WrappedArrow p b d -> WrappedArrow p c d -> WrappedArrow p (Either b c) d

ArrowApply p => ArrowApply (WrappedArrow p) Source 

Methods

app :: WrappedArrow p (WrappedArrow p b c, b) c

ArrowLoop p => ArrowLoop (WrappedArrow p) Source 

Methods

loop :: WrappedArrow p (b, d) (c, d) -> WrappedArrow p b c

Arrow p => Profunctor (WrappedArrow p) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> WrappedArrow p b c -> WrappedArrow p a d Source

lmap :: (a -> b) -> WrappedArrow p b c -> WrappedArrow p a c Source

rmap :: (b -> c) -> WrappedArrow p a b -> WrappedArrow p a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> WrappedArrow p a b -> WrappedArrow p a c Source

(.#) :: Coercible (TYPE Lifted) b a => WrappedArrow p b c -> (a -> b) -> WrappedArrow p a c Source

ArrowLoop p => Costrong (WrappedArrow p) Source 

Methods

unfirst :: WrappedArrow p (a, d) (b, d) -> WrappedArrow p a b Source

unsecond :: WrappedArrow p (d, a) (d, b) -> WrappedArrow p a b Source

Arrow p => Strong (WrappedArrow p) Source

Arrow is Strong Category

Methods

first' :: WrappedArrow p a b -> WrappedArrow p (a, c) (b, c) Source

second' :: WrappedArrow p a b -> WrappedArrow p (c, a) (c, b) Source

ArrowChoice p => Choice (WrappedArrow p) Source 

Methods

left' :: WrappedArrow p a b -> WrappedArrow p (Either a c) (Either b c) Source

right' :: WrappedArrow p a b -> WrappedArrow p (Either c a) (Either c b) Source

Category (TYPE Lifted) p => Category (TYPE Lifted) (WrappedArrow p) Source 

Methods

id :: cat a a

(.) :: cat b c -> cat a b -> cat a c

newtype Forget r a b Source

Constructors

Forget 

Fields

Instances

Profunctor (Forget r) Source 

Methods

dimap :: (a -> b) -> (c -> d) -> Forget r b c -> Forget r a d Source

lmap :: (a -> b) -> Forget r b c -> Forget r a c Source

rmap :: (b -> c) -> Forget r a b -> Forget r a c Source

(#.) :: Coercible (TYPE Lifted) c b => (b -> c) -> Forget r a b -> Forget r a c Source

(.#) :: Coercible (TYPE Lifted) b a => Forget r b c -> (a -> b) -> Forget r a c Source

Strong (Forget r) Source 

Methods

first' :: Forget r a b -> Forget r (a, c) (b, c) Source

second' :: Forget r a b -> Forget r (c, a) (c, b) Source

Monoid r => Choice (Forget r) Source 

Methods

left' :: Forget r a b -> Forget r (Either a c) (Either b c) Source

right' :: Forget r a b -> Forget r (Either c a) (Either c b) Source

Representable (Forget r) Source 

Associated Types

type Rep (Forget r :: TYPE Lifted -> TYPE Lifted -> TYPE Lifted) :: * -> * Source

Methods

tabulate :: (d -> Rep (Forget r) c) -> Forget r d c Source

Sieve (Forget r) (Const (TYPE Lifted) r) Source 

Methods

sieve :: Forget r a b -> a -> Const (TYPE Lifted) r b Source

Functor (Forget r a) Source 

Methods

fmap :: (a -> b) -> Forget r a a -> Forget r a b

(<$) :: a -> Forget r a b -> Forget r a a

Foldable (Forget r a) Source 

Methods

fold :: Monoid m => Forget r a m -> m

foldMap :: Monoid m => (a -> m) -> Forget r a a -> m

foldr :: (a -> b -> b) -> b -> Forget r a a -> b

foldr' :: (a -> b -> b) -> b -> Forget r a a -> b

foldl :: (b -> a -> b) -> b -> Forget r a a -> b

foldl' :: (b -> a -> b) -> b -> Forget r a a -> b

foldr1 :: (a -> a -> a) -> Forget r a a -> a

foldl1 :: (a -> a -> a) -> Forget r a a -> a

toList :: Forget r a a -> [a]

null :: Forget r a a -> Bool

length :: Forget r a a -> Int

elem :: Eq a => a -> Forget r a a -> Bool

maximum :: Ord a => Forget r a a -> a

minimum :: Ord a => Forget r a a -> a

sum :: Num a => Forget r a a -> a

product :: Num a => Forget r a a -> a

Traversable (Forget r a) Source 

Methods

traverse :: Applicative f => (a -> f b) -> Forget r a a -> f (Forget r a b)

sequenceA :: Applicative f => Forget r a (f a) -> f (Forget r a a)

mapM :: Monad m => (a -> m b) -> Forget r a a -> m (Forget r a b)

sequence :: Monad m => Forget r a (m a) -> m (Forget r a a)

type Rep (Forget r) = Const * r Source 

type (:->) p q = forall a b. p a b -> q a b infixr 0 Source