functor (F : Basic2->
  sig
    val map : ('-> 'b) -> ('p, 'a) F.t -> ('p, 'b) F.t
    val ( >|= ) : ('p, 'a) F.t -> ('-> 'b) -> ('p, 'b) F.t
    val replace : '-> ('p, 'b) F.t -> ('p, 'a) F.t
    val void : ('p, 'a) F.t -> ('p, unit) F.t
  end