| Copyright | (C) 2015-2018 Edward Kmett |
|---|---|
| License | BSD-style (see the file LICENSE) |
| Maintainer | Edward Kmett <ekmett@gmail.com> |
| Stability | experimental |
| Portability | portable |
| Safe Haskell | Safe |
| Language | Haskell2010 |
Data.Profunctor.Mapping
Description
Synopsis
- class (Traversing p, Closed p) => Mapping p where
- map' :: Functor f => p a b -> p (f a) (f b)
- roam :: (forall f. (Distributive f, Applicative f) => (a -> f b) -> s -> f t) -> p a b -> p s t
- newtype CofreeMapping p a b = CofreeMapping {
- runCofreeMapping :: forall f. Functor f => p (f a) (f b)
- data FreeMapping p a b where
- FreeMapping :: Functor f => (f y -> b) -> p x y -> (a -> f x) -> FreeMapping p a b
- wanderMapping :: Mapping p => (forall f. Applicative f => (a -> f b) -> s -> f t) -> p a b -> p s t
- traverseMapping :: (Mapping p, Functor f) => p a b -> p (f a) (f b)
- closedMapping :: Mapping p => p a b -> p (x -> a) (x -> b)
Documentation
class (Traversing p, Closed p) => Mapping p where Source #
Minimal complete definition
Nothing
Methods
map' :: Functor f => p a b -> p (f a) (f b) Source #
Laws:
map'.rmapf ≡rmap(fmapf).map'map'.map'≡dimapComposegetCompose.map'dimapIdentityrunIdentity.map'≡id
roam :: (forall f. (Distributive f, Applicative f) => (a -> f b) -> s -> f t) -> p a b -> p s t Source #
Instances
newtype CofreeMapping p a b Source #
Constructors
| CofreeMapping | |
Fields
| |
Instances
data FreeMapping p a b where Source #
FreeMapping -| CofreeMapping
Constructors
| FreeMapping :: Functor f => (f y -> b) -> p x y -> (a -> f x) -> FreeMapping p a b |
Instances
Traversing in terms of Mapping
wanderMapping :: Mapping p => (forall f. Applicative f => (a -> f b) -> s -> f t) -> p a b -> p s t Source #
Closed in terms of Mapping
traverseMapping :: (Mapping p, Functor f) => p a b -> p (f a) (f b) Source #
closedMapping :: Mapping p => p a b -> p (x -> a) (x -> b) Source #