functor (M : Basic->
  sig
    val bind : ('-> 'M.t) -> 'M.t -> 'M.t
    val pure : '-> 'M.t
    val ap : ('-> 'b) M.t -> (unit -> 'M.t) -> 'M.t
    val map : ('-> 'b) -> 'M.t -> 'M.t
    val ( >|= ) : 'M.t -> ('-> 'b) -> 'M.t
    val replace : '-> 'M.t -> 'M.t
    val void : 'M.t -> unit M.t
    val ap' : ('-> 'b) M.t -> 'M.t -> 'M.t
    val ( <*> ) : ('-> 'b) M.t -> 'M.t -> 'M.t
    val ( <~> ) : ('-> 'b) M.t -> (unit -> 'M.t) -> 'M.t
    val discard_left : 'M.t -> (unit -> 'M.t) -> 'M.t
    val discard_right : 'M.t -> (unit -> 'M.t) -> 'M.t
    val repeat : int -> 'M.t -> 'a list M.t
    val repeat_ : int -> 'M.t -> unit M.t
    val forever : 'M.t -> 'M.t
    val ( >>= ) : 'M.t -> ('-> 'M.t) -> 'M.t
    val join : 'M.t M.t -> 'M.t
    val mcompose : ('-> 'M.t) -> ('-> 'M.t) -> '-> 'M.t
  end