Module Type_equal.IdSource
Id provides identifiers for types, and the ability to test (via Id.same) at runtime if two identifiers are equal, and if so to get a proof of equality of their types. Unlike values of type Type_equal.t, values of type Id.t do have semantic content and must have a nontrivial runtime representation.
include sig ... end
val sexp_of_t :
('a : any). (('a : any) -> Sexplib0.Sexp.t) ->
('a : any) Base.Type_equal.Id.t ->
Sexplib0.Sexp.tinclude sig ... end
module type Arg0 = sig ... endmodule type S0 = sig ... endmodule type Arg1 = sig ... endmodule type S1 = sig ... endmodule type Arg2 = sig ... endmodule type Arg2__immediate64__value = sig ... endmodule type S2 = sig ... endmodule type S2__immediate64__value = sig ... endmodule type Arg3 = sig ... endmodule type S3 = sig ... endmodule type Arg4 = sig ... endmodule type S4 = sig ... endEvery Id.t contains a unique id that is distinct from the Uid.t in any other Id.t.
create ~name defines a new type identity. Two calls to create will result in two distinct identifiers, even for the same arguments with the same type. If the type 'a doesn't support sexp conversion, then a good practice is to have the converter be [%sexp_of: _], (or sexp_of_opaque, if not using ppx_sexp_conv).
Accessors
val hash_fold_t :
Ppx_hash_lib.Std.Hash.state ->
_ Base.Type_equal.Id.t ->
Ppx_hash_lib.Std.Hash.statesame_witness t1 t2 and same_witness_exn t1 t2 return a type equality proof iff the two identifiers are the same (i.e., physically equal, resulting from the same call to create). This is a useful way to achieve a sort of dynamic typing. same_witness does not allocate a Some every time it is called.
same t1 t2 = is_some (same_witness t1 t2).
val same_witness :
('a : any) ('b : any). 'a Base.Type_equal.Id.t ->
'b Base.Type_equal.Id.t ->
('a, 'b) Base.Type_equal.t optionval same_witness_exn :
('a : any) ('b : any). 'a Base.Type_equal.Id.t ->
'b Base.Type_equal.Id.t ->
('a, 'b) Base.Type_equal.t