deriving.runtime
MonadDefault.M
type +'a m
val return : 'a -> 'a m
val fail : string -> 'a m
val (>>=) : 'a m -> ('a -> 'b m) -> 'b m