functor (M : Monad.MONAD) ->
sig
type 'a t
val ( >>= ) : 'a t -> ('a -> 'b t) -> 'b t
val ( >> ) : 'a t -> 'b t -> 'b t
val return : 'a -> 'a t
val run : 'a t -> 'a
val raise : string -> 'a t
val trywith : 'a t -> (string -> 'a t) -> 'a t
val lift : 'a M.t -> 'a t
end