sig type 'a t = 'a val map : ('a -> 'b) -> 'a t -> 'b t val pure : 'a -> 'a t val ap : ('a -> 'b) t -> (unit -> 'a t) -> 'b t val bind : ('a -> 'b t) -> 'a t -> 'b t end