Base.Either
val hash_fold_t :
( Hash.state -> 'f -> Hash.state ) ->
( Hash.state -> 's -> Hash.state ) ->
Hash.state ->
( 'f, 's ) t ->
Hash.state
include Sexpable.S2 with type ('f, 's) t := ( 'f, 's ) t
val t_of_sexp :
( Sexplib0__.Sexp.t -> 'a ) ->
( Sexplib0__.Sexp.t -> 'b ) ->
Sexplib0__.Sexp.t ->
( 'a, 'b ) t
val sexp_of_t :
( 'a -> Sexplib0__.Sexp.t ) ->
( 'b -> Sexplib0__.Sexp.t ) ->
( 'a, 'b ) t ->
Sexplib0__.Sexp.t
include Invariant.S2 with type ('a, 'b) t := ( 'a, 'b ) t
val invariant : ( 'a -> unit ) -> ( 'b -> unit ) -> ( 'a, 'b ) t -> unit
val value : ( 'a, 'a ) t -> 'a
val iter :
( 'a, 'b ) t ->
first:( 'a -> unit ) ->
second:( 'b -> unit ) ->
unit
val value_map : ( 'a, 'b ) t -> first:( 'a -> 'c ) -> second:( 'b -> 'c ) -> 'c
module type Focused = sig ... end
val is_first : ( _, _ ) t -> bool
val is_second : ( _, _ ) t -> bool
val first : 'f -> ( 'f, _ ) t
first
and second
are First.return
and Second.return
.
val second : 's -> ( _, 's ) t