type ('a, 'e) t
val map : ('a, 'e) t ‑> f:('a ‑> 'b) ‑> ('b, 'e) t
val both : ('a, 'e) t ‑> ('b, 'e) t ‑> ('a * 'b, 'e) t