set-algebra-1.1.0.3: Set Algebra
Safe HaskellSafe-Inferred
LanguageHaskell2010

Control.Iterate.Collect

Synopsis

Documentation

newtype Cont ans x Source #

Constructors

Cont 

Fields

Instances

Instances details
Applicative (Cont ans) Source # 
Instance details

Defined in Control.Iterate.Collect

Methods

pure ∷ a → Cont ans a #

(<*>)Cont ans (a → b) → Cont ans a → Cont ans b #

liftA2 ∷ (a → b → c) → Cont ans a → Cont ans b → Cont ans c #

(*>)Cont ans a → Cont ans b → Cont ans b #

(<*)Cont ans a → Cont ans b → Cont ans a #

Functor (Cont ans) Source # 
Instance details

Defined in Control.Iterate.Collect

Methods

fmap ∷ (a → b) → Cont ans a → Cont ans b #

(<$) ∷ a → Cont ans b → Cont ans a #

Monad (Cont r) Source # 
Instance details

Defined in Control.Iterate.Collect

Methods

(>>=)Cont r a → (a → Cont r b) → Cont r b #

(>>)Cont r a → Cont r b → Cont r b #

return ∷ a → Cont r a #

newtype Collect tuple Source #

Constructors

Collect 

Fields

  • runCollect ∷ ∀ ans. ans → (tuple → ans → ans) → ans
     

Instances

Instances details
Foldable Collect Source # 
Instance details

Defined in Control.Iterate.Collect

Methods

foldMonoid m ⇒ Collect m → m #

foldMapMonoid m ⇒ (a → m) → Collect a → m #

foldMap'Monoid m ⇒ (a → m) → Collect a → m

foldr ∷ (a → b → b) → b → Collect a → b #

foldr' ∷ (a → b → b) → b → Collect a → b

foldl ∷ (b → a → b) → b → Collect a → b #

foldl' ∷ (b → a → b) → b → Collect a → b #

foldr1 ∷ (a → a → a) → Collect a → a #

foldl1 ∷ (a → a → a) → Collect a → a #

toListCollect a → [a] #

nullCollect a → Bool #

lengthCollect a → Int #

elemEq a ⇒ a → Collect a → Bool #

maximumOrd a ⇒ Collect a → a #

minimumOrd a ⇒ Collect a → a #

sumNum a ⇒ Collect a → a #

productNum a ⇒ Collect a → a #

Applicative Collect Source # 
Instance details

Defined in Control.Iterate.Collect

Methods

pure ∷ a → Collect a #

(<*>)Collect (a → b) → Collect a → Collect b #

liftA2 ∷ (a → b → c) → Collect a → Collect b → Collect c #

(*>)Collect a → Collect b → Collect b #

(<*)Collect a → Collect b → Collect a #

Functor Collect Source # 
Instance details

Defined in Control.Iterate.Collect

Methods

fmap ∷ (a → b) → Collect a → Collect b #

(<$) ∷ a → Collect b → Collect a #

Monad Collect Source # 
Instance details

Defined in Control.Iterate.Collect

Methods

(>>=)Collect a → (a → Collect b) → Collect b #

(>>)Collect a → Collect b → Collect b #

return ∷ a → Collect a #

Show t ⇒ Show (Collect t) Source #

Even though a (Collect t) is a function, if we can (Show t), we can pick an action that collects all the shown t, and turn them into a big multi-line string.

Instance details

Defined in Control.Iterate.Collect

Methods

showsPrecIntCollect t → ShowS #

showCollect t → String #

showList ∷ [Collect t] → ShowS #

fixActionCollect tuple → ans → (tuple → ans → ans) → ans Source #

A (Collect t) is completely agnostic over how ts are beging collected. We can make this abstraction concrete by using fixAction.

mapifyOrd a ⇒ Collect (a, b) → Map a b Source #

listifyCollect (a, b) → [(a, b)] Source #

countCollect (a, b) → Int Source #

one ∷ t → Collect t Source #

Here are several ways to add a new t to what is being collected.

The one and none interface are used when we want collections with 0 or 1 elements

front ∷ t → Collect t → Collect t Source #

The front and rear interface can add to either end of the sequence (both in constant time)

rearCollect t → t → Collect t Source #

whenBoolCollect () Source #

Conditional collecting

takeCIntCollect t → [t] Source #

newtype ColPlus tuple Source #

Constructors

ColPlus 

Fields

  • runColPlus ∷ ∀ ans. ans → (tuple → ans → ans) → (ans → ans → ans) → ans
     

Instances

Instances details
Alternative ColPlus Source # 
Instance details

Defined in Control.Iterate.Collect

Methods

emptyColPlus a #

(<|>)ColPlus a → ColPlus a → ColPlus a #

someColPlus a → ColPlus [a] #

manyColPlus a → ColPlus [a] #

Applicative ColPlus Source # 
Instance details

Defined in Control.Iterate.Collect

Methods

pure ∷ a → ColPlus a #

(<*>)ColPlus (a → b) → ColPlus a → ColPlus b #

liftA2 ∷ (a → b → c) → ColPlus a → ColPlus b → ColPlus c #

(*>)ColPlus a → ColPlus b → ColPlus b #

(<*)ColPlus a → ColPlus b → ColPlus a #

Functor ColPlus Source # 
Instance details

Defined in Control.Iterate.Collect

Methods

fmap ∷ (a → b) → ColPlus a → ColPlus b #

(<$) ∷ a → ColPlus b → ColPlus a #

Monad ColPlus Source # 
Instance details

Defined in Control.Iterate.Collect

Methods

(>>=)ColPlus a → (a → ColPlus b) → ColPlus b #

(>>)ColPlus a → ColPlus b → ColPlus b #

return ∷ a → ColPlus a #

MonadPlus ColPlus Source # 
Instance details

Defined in Control.Iterate.Collect

Methods

mzeroColPlus a #

mplusColPlus a → ColPlus a → ColPlus a #

runPlusMonoid a ⇒ ColPlus t → a → (t → a → a) → a Source #