functor (M : Monoid.S->
  sig
    type _ t
    val bind : ('-> 'b t) -> 'a t -> 'b t
    val pure : '-> 'a t
    val ap : ('-> 'b) t -> (unit -> 'a t) -> 'b t
    val map : ('-> 'b) -> 'a t -> 'b t
    val ( >|= ) : 'a t -> ('-> 'b) -> 'b t
    val replace : '-> 'b t -> 'a t
    val void : 'a t -> unit t
    val ap' : ('-> 'b) t -> 'a t -> 'b t
    val ( <*> ) : ('-> 'b) t -> 'a t -> 'b t
    val ( <~> ) : ('-> 'b) t -> (unit -> 'a t) -> 'b t
    val discard_left : 'a t -> (unit -> 'b t) -> 'b t
    val discard_right : 'a t -> (unit -> 'b t) -> 'a t
    val repeat : int -> 'a t -> 'a list t
    val repeat_ : int -> 'a t -> unit t
    val forever : 'a t -> 'b t
    val ( >>= ) : 'a t -> ('-> 'b t) -> 'b t
    val join : 'a t t -> 'a t
    val mcompose : ('-> 'c t) -> ('-> 'b t) -> '-> 'c t
    external run : 'a t -> M.t * 'a = "%identity"
    val writer : '-> M.t -> 'a t
    val tell : M.t -> unit t
    val listen : 'a t -> ('a * M.t) t
    val censor : (M.t -> M.t) -> 'a t -> 'a t
  end