module type T = sig .. end
sig
end
type 'a t
'a
val fold : 'a t -> init:'b -> f:('b -> 'a -> 'b) -> 'b
'a t -> init:'b -> f:('b -> 'a -> 'b) -> 'b