Option.Make
Make(M)
composes the option monad with the monad M
.
include Monad with type 'a t := 'a T1(M).t
sequence xs
computes a sequence of computations xs
in the left to right order.
module Fn : sig ... end
Various function combinators lifted into the Kleisli category.
module Pair : sig ... end
The pair interface lifted into the monad.
module Triple : sig ... end
The triple interface lifted into a monad.
module Lift : sig ... end
Lifts functions into the monad.
module Exn : sig ... end
Interacting between monads and language exceptions
module Collection : sig ... end
Lifts collection interface into the monad.
module List : Collection.S with type 'a t := 'a list
The Monad.Collection.S interface for lists
module Seq : Collection.S with type 'a t := 'a Core_kernel.Sequence.t
The Monad.Collection.S interface for sequences
include Syntax.Let.S with type 'a t := 'a T1(M).t
include Core_kernel.Monad.S with type 'a t := 'a T1(M).t
module Monad_infix : sig ... end
val return : 'a -> 'a T1(M).t
module Let_syntax : sig ... end
module Let : Syntax.Let.S with type 'a t := 'a T1(M).t
Monadic operators, see Monad.Syntax.S for more.
Monadic operators, see Monad.Syntax.S for more.
include Choice.S with type 'a t := 'a T1(M).t
include Choice.Basic with type 'a t := 'a T1(M).t
val pure : 'a -> 'a T1(M).t
pure x
creates a computation that results in x
.
val accept : 'a -> 'a T1(M).t
accept x
accepts x
as a result of computation. (Same as pure x
.
val reject : unit -> 'a T1(M).t
reject ()
rejects the rest of computation sequence, and terminate the computation with the zero
result (Same as zero ()
val guard : bool -> unit T1(M).t
guard cond
ensures cond
is true
in the rest of computation. Otherwise the rest of the computation is rejected.