SR.Apply
type !'a t
= (Type.t, 'a) state
val map : ('a -> 'b) -> 'a t -> 'b t
val apply : ('a -> 'b) t -> 'a t -> 'b t