include APPLICATIVE
include APPLY
include FUNCTOR
type 'a t
val map : ('a -> 'b) -> 'a t -> 'b t
val apply : ('a -> 'b) t -> 'a t -> 'b t
val pure : 'a -> 'a t
include PLUS with type 'a t := 'a t
include ALT
include FUNCTOR
type 'a t
val map : ('a -> 'b) -> 'a t -> 'b t
val alt : 'a t -> 'a t -> 'a t
val empty : 'a t