module type Basic = sig .. end
sig
end
include Functor.Basic
val pure : 'a -> 'a t
'a -> 'a t
val ap : ('a -> 'b) t -> (unit -> 'a t) -> 'b t
('a -> 'b) t -> (unit -> 'a t) -> 'b t