package clarity

  1. Overview
  2. Docs

Parameters

module M : Basic

Signature

include Basic with type 'a t := 'a M.t
include Applicative.Basic with type 'a t := 'a M.t
include Functor.Basic with type 'a t := 'a M.t
val bind : ('a -> 'b M.t) -> 'a M.t -> 'b M.t
include Applicative.S with type 'a t := 'a M.t
include Applicative.Basic with type 'a t := 'a M.t
include Functor.Basic with type 'a t := 'a M.t
val pure : 'a -> 'a M.t
val ap : ('a -> 'b) M.t -> (unit -> 'a M.t) -> 'b M.t
include Functor.S with type 'a t := 'a M.t
include Functor.Basic with type 'a t := 'a M.t
val map : ('a -> 'b) -> 'a M.t -> 'b M.t
val (>|=) : 'a M.t -> ('a -> 'b) -> 'b M.t
val replace : 'a -> 'b M.t -> 'a M.t
val void : 'a M.t -> unit M.t
val ap' : ('a -> 'b) M.t -> 'a M.t -> 'b M.t
val (<*>) : ('a -> 'b) M.t -> 'a M.t -> 'b M.t
val (<~>) : ('a -> 'b) M.t -> (unit -> 'a M.t) -> 'b M.t
val discard_left : 'a M.t -> (unit -> 'b M.t) -> 'b M.t
val discard_right : 'a M.t -> (unit -> 'b M.t) -> 'a M.t
val repeat : int -> 'a M.t -> 'a list M.t
val repeat_ : int -> 'a M.t -> unit M.t
val forever : 'a M.t -> 'b M.t
val (>>=) : 'a M.t -> ('a -> 'b M.t) -> 'b M.t
val join : 'a M.t M.t -> 'a M.t
val mcompose : ('b -> 'c M.t) -> ('a -> 'b M.t) -> 'a -> 'c M.t