functor (M : Core.Monad.Basic2->
  sig
    val ( >>= ) : ('a, 'd) M.t -> ('-> ('b, 'd) M.t) -> ('b, 'd) M.t
    val ( >>| ) : ('a, 'd) M.t -> ('-> 'b) -> ('b, 'd) M.t
    module Monad_infix :
      sig
        val ( >>= ) : ('a, 'd) M.t -> ('-> ('b, 'd) M.t) -> ('b, 'd) M.t
        val ( >>| ) : ('a, 'd) M.t -> ('-> 'b) -> ('b, 'd) M.t
      end
    val bind : ('a, 'd) M.t -> ('-> ('b, 'd) M.t) -> ('b, 'd) M.t
    val return : '-> ('a, 'b) M.t
    val map : ('a, 'd) M.t -> f:('-> 'b) -> ('b, 'd) M.t
    val join : (('a, 'd) M.t, 'd) M.t -> ('a, 'd) M.t
    val ignore : ('a, 'd) M.t -> (unit, 'd) M.t
    val all : ('a, 'd) M.t list -> ('a list, 'd) M.t
    val all_ignore : (unit, 'd) M.t list -> (unit, 'd) M.t
    val map_monad : 'a list -> f:('-> ('b, 'c) M.t) -> ('b list, 'c) M.t
    val map_monad_ignore :
      'a list -> f:('-> (unit, 'b) M.t) -> (unit, 'b) M.t
  end