Portability | non-portable |
---|---|
Stability | experimental |
Maintainer | Edward Kmett <ekmett@gmail.com> |
Safe Haskell | Trustworthy |
- newtype Folding f a = Folding {
- getFolding :: f a
- newtype Traversed a f = Traversed {
- getTraversed :: f a
- newtype Sequenced a m = Sequenced {
- getSequenced :: m a
- data Max a
- getMax :: Max a -> Maybe a
- data Min a
- getMin :: Min a -> Maybe a
- data Leftmost a
- getLeftmost :: Leftmost a -> Maybe a
- data Rightmost a
- getRightmost :: Rightmost a -> Maybe a
- data ReifiedMonoid a = ReifiedMonoid {
- reifiedMappend :: a -> a -> a
- reifiedMempty :: a
- newtype M a s = M a
- reifyFold :: (a -> a -> a) -> a -> (forall s. Reifies s (ReifiedMonoid a) => t -> M a s) -> t -> a
Monoids for folding
A Monoid
for a Contravariant
Applicative
.
Folding | |
|
(Contravariant f, Applicative f) => Monoid (Folding f a) | |
(Contravariant f, Apply f) => Semigroup (Folding f a) |
Used internally by traverseOf_
and the like.
The argument a
of the result should not be used!
Traversed | |
|
Used internally by mapM_
and the like.
The argument a
of the result should not be used!
Sequenced | |
|
Used for preview
.
getLeftmost :: Leftmost a -> Maybe aSource
Extract the Leftmost
element. This will fairly eagerly determine that it can return Just
the moment it sees any element at all.
Used for lastOf
.
getRightmost :: Rightmost a -> Maybe aSource
Extract the Rightmost
element. This will fairly eagerly determine that it can return Just
the moment it sees any element at all.
data ReifiedMonoid a Source
ReifiedMonoid | |
|
reifyFold :: (a -> a -> a) -> a -> (forall s. Reifies s (ReifiedMonoid a) => t -> M a s) -> t -> aSource