sig
  type (_, _) t
  val bind : ('-> ('p, 'b) t) -> ('p, 'a) t -> ('p, 'b) t
  val pure : '-> ('p, 'a) t
  val ap : ('p, '-> 'b) t -> (unit -> ('p, 'a) t) -> ('p, 'b) t
  val map : ('-> 'b) -> ('p, 'a) t -> ('p, 'b) t
  val ( >|= ) : ('p, 'a) t -> ('-> 'b) -> ('p, 'b) t
  val replace : '-> ('p, 'b) t -> ('p, 'a) t
  val void : ('p, 'a) t -> ('p, unit) t
  val ap' : ('p, '-> 'b) t -> ('p, 'a) t -> ('p, 'b) t
  val ( <*> ) : ('p, '-> 'b) t -> ('p, 'a) t -> ('p, 'b) t
  val ( <~> ) : ('p, '-> 'b) t -> (unit -> ('p, 'a) t) -> ('p, 'b) t
  val discard_left : ('p, 'a) t -> (unit -> ('p, 'b) t) -> ('p, 'b) t
  val discard_right : ('p, 'a) t -> (unit -> ('p, 'b) t) -> ('p, 'a) t
  val repeat : int -> ('p, 'a) t -> ('p, 'a list) t
  val repeat_ : int -> ('p, 'a) t -> ('p, unit) t
  val forever : ('p, 'a) t -> ('p, 'b) t
  val ( >>= ) :
    ('p, 'a) Monad.S2.t -> ('-> ('p, 'b) Monad.S2.t) -> ('p, 'b) Monad.S2.t
  val join : ('p, ('p, 'a) Monad.S2.t) Monad.S2.t -> ('p, 'a) Monad.S2.t
  val mcompose :
    ('-> ('p, 'c) Monad.S2.t) ->
    ('-> ('p, 'b) Monad.S2.t) -> '-> ('p, 'c) Monad.S2.t
end