hsc3-0.21: Haskell SuperCollider
Safe HaskellSafe-Inferred
LanguageHaskell2010

Sound.Sc3.Common.Monad.Operators

Description

Functions to make writing Applicative and Monad Ugen graphs less clumsy.

Synopsis

Documentation

(.+) :: (Functor f, Num a) => f a -> a -> f a infixl 6 Source #

+ variant with Functor at left.

>>> fmap (== 5) (return 3 .+ 2)
True
>>> [3,4] .+ 2
[5,6]

(+.) :: (Functor f, Num a) => a -> f a -> f a infixl 6 Source #

+ variant with Functor at right.

>>> fmap (== 5) (3 +. return 2)
True
>>> 3 +. [2,3]
[5,6]

(.+.) :: (Applicative m, Num a) => m a -> m a -> m a infixl 6 Source #

+ variant with Applicative at left and right.

>>> fmap (== 5) (return 3 .+. return 2)
True
>>> [3,4] .+. [2,3]
[5,6,6,7]
>>> import Control.Applicative
>>> getZipList (ZipList [3,4] .+. ZipList [2,3])
[5,7]

(.*) :: (Functor f, Num a) => f a -> a -> f a infixl 7 Source #

* variant with Functor at left.

>>> fmap (== 6) (return 3 .* 2)
True

(*.) :: (Functor f, Num a) => a -> f a -> f a infixl 7 Source #

* variant with Functor at right.

>>> fmap (== 6) (3 *. return 2)
True

(.*.) :: (Applicative m, Num a) => m a -> m a -> m a infixl 7 Source #

* variant with Applicative at left and right.

>>> fmap (== 6) (return 3 .*. return 2)
True

(.-) :: (Functor f, Num a) => f a -> a -> f a infixl 6 Source #

- variant with Functor at left.

>>> fmap (== 1) (return 3 .- 2)
True
>>> [3,4] .- 2
[1,2]

(-.) :: (Functor f, Num a) => a -> f a -> f a infixl 6 Source #

- variant with Functor at right.

>>> fmap (== 1) (3 -. return 2)
True
>>> 3 -. [2,3]
[1,0]

(.-.) :: (Applicative m, Num a) => m a -> m a -> m a infixl 6 Source #

- variant with Applicative at left and right.

>>> fmap (== 1) (return 3 .-. return 2)
True
>>> [3,4] .-. [2,3]
[1,0,2,1]
>>> import Control.Applicative
>>> getZipList (ZipList [3,4] .-. ZipList [2,3])
[1,1]

(./) :: (Functor f, Fractional a) => f a -> a -> f a infixl 7 Source #

/ variant with Functor at left.

>>> fmap (== 3) (return 6 ./ 2)
True

(/.) :: (Functor f, Fractional a) => a -> f a -> f a infixl 7 Source #

/ variant with Functor at right.

>>> fmap (== 3) (6 /. return 2)
True

(./.) :: (Applicative m, Fractional a) => m a -> m a -> m a infixl 7 Source #

/ variant with Applicative at left and right.

>>> fmap (== 3) (return 6 ./. return 2)
True
>>> [5,6] ./. [2,3] == [5/2,5/3,3,2]
True