module type MONAD = sig .. end
sig
end
type 'a t
'a
val return : 'a -> 'a t
'a -> 'a t
val (>>=) : 'a t -> ('a -> 'b t) -> 'b t
'a t -> ('a -> 'b t) -> 'b t