functor (M : Basic) ->
sig
val bind : ('a -> 'b M.t) -> 'a M.t -> 'b M.t
val pure : 'a -> 'a M.t
val ap : ('a -> 'b) M.t -> (unit -> 'a M.t) -> 'b 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
end