functor (M : Monad.Basic3->
  sig
    val traverse : ('-> ('u, 'v, 'b) M.t) -> 'a t -> ('u, 'v, 'b t) M.t
    val traverse_ : ('-> ('u, 'v, 'b) M.t) -> 'a t -> ('u, 'v, unit) M.t
    val sequence : ('a, 'b, 'c) M.t t -> ('a, 'b, 'c t) M.t
    val sequence_ : ('a, 'b, 'c) M.t t -> ('a, 'b, unit) M.t
    val foldr_m :
      ('-> '-> ('u, 'v, 'b) M.t) -> '-> 'a t -> ('u, 'v, 'b) M.t
    val foldl_m :
      ('-> '-> ('u, 'v, 'b) M.t) -> '-> 'a t -> ('u, 'v, 'b) M.t
  end