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) t -> ('-> ('p, 'b) t) -> ('p, 'b) t
  val join : ('p, ('p, 'a) t) t -> ('p, 'a) t
  val mcompose : ('-> ('p, 'c) t) -> ('-> ('p, 'b) t) -> '-> ('p, 'c) t
  external run : ('s, 'a) t -> '-> 's * 'a = "%identity"
  external state : ('-> 's * 'a) -> ('s, 'a) t = "%identity"
  val get : ('s, 's) t
  val gets : ('-> 'a) -> ('s, 'a) t
  val put : '-> ('s, unit) t
  val modify : ('-> 's) -> ('s, unit) t
end