functor (M : MONAD_BARE->
  sig
    type 'a t = 'M.t
    val return : '-> 'a t
    val ( >>= ) : 'a t -> ('-> 'b t) -> 'b t
    val map : ('-> 'b) -> 'a t -> 'b t
    val pure : '-> 'a t
    val ( <*> ) : ('-> 'b) t -> 'a t -> 'b t
  end