|
Control.Arrow | Portability | portable | Stability | experimental | Maintainer | ross@soi.city.ac.uk |
|
|
|
|
Contents |
- Arrows
- Derived combinators
- Monoid operations
- Conditionals
- Arrow application
- Feedback
|
|
Description |
Basic arrow definitions, based on
Generalising Monads to Arrows, by John Hughes,
Science of Computer Programming 37, pp67-111, May 2000.
plus a couple of definitions (returnA and loop) from
A New Notation for Arrows, by Ross Paterson, in ICFP 2001,
Firenze, Italy, pp229-240.
See these papers for the equations these combinators are expected to
satisfy. These papers and more information on arrows can be found at
http://www.haskell.org/arrows/. |
|
Synopsis |
|
|
|
|
Arrows |
|
class Arrow a where |
The basic arrow class.
Any instance must define either arr or pure (which are synonyms),
as well as >>> and first. The other combinators have sensible
default definitions, which may be overridden for efficiency. | | Methods | (&&&) :: a b c -> a b c' -> a b (c, c') | | (***) :: a b c -> a b' c' -> a (b, b') (c, c') | | second :: a b c -> a (d, b) (d, c) | | first :: a b c -> a (b, d) (c, d) | A mirror image of first. The default definition may be overridden with a more efficient
version if desired. | | (>>>) :: a b c -> a c d -> a b d | Send the first component of the input through the argument
arrow, and copy the rest unchanged to the output. | | pure :: (b -> c) -> a b c | | arr :: (b -> c) -> a b c |
| | Instances | |
|
|
data Kleisli m a b |
Kleisli arrows of a monad. | Constructors | | Instances | |
|
|
Derived combinators |
|
returnA :: (Arrow a) => a b b |
The identity arrow, which plays the role of return in arrow notation. |
|
(<<<) :: (Arrow a) => a c d -> a b c -> a b d |
Right-to-left composition, for a better fit with arrow notation. |
|
Monoid operations |
|
class (Arrow a) => ArrowZero a where |
|
|
class (ArrowZero a) => ArrowPlus a where |
| Methods | (<+>) :: a b c -> a b c -> a b c |
| | Instances | |
|
|
Conditionals |
|
class (Arrow a) => ArrowChoice a where |
Choice, for arrows that support it. This class underlies the
if and case constructs in arrow notation.
Any instance must define left. The other combinators have sensible
default definitions, which may be overridden for efficiency. | | Methods | (|||) :: a b d -> a c d -> a (Either b c) d | | (+++) :: a b c -> a b' c' -> a (Either b b') (Either c c') | | right :: a b c -> a (Either d b) (Either d c) | | left :: a b c -> a (Either b d) (Either c d) | A mirror image of left. The default definition may be overridden with a more efficient
version if desired. |
| | Instances | |
|
|
Arrow application |
|
class (Arrow a) => ArrowApply a where |
Some arrows allow application of arrow inputs to other inputs. | | Methods | | | Instances | |
|
|
data ArrowMonad a b |
|
|
leftApp :: (ArrowApply a) => a b c -> a (Either b d) (Either c d) |
Any instance of ArrowApply can be made into an instance of
ArrowChoice by defining left = leftApp. |
|
Feedback |
|
class (Arrow a) => ArrowLoop a where |
The loop operator expresses computations in which an output value is
fed back as input, even though the computation occurs only once.
It underlies the rec value recursion construct in arrow notation. | | Methods | loop :: a (b, d) (c, d) -> a b c |
| | Instances | |
|
|
Produced by Haddock version 0.3 |