Module Flambda2_identifiers.Variable
include module type of struct include Flambda2_identifiers.Int_ids.Variable end
type t = private Flambda2_algorithms.Table_by_int_id.Id.ttype exported = Flambda2_identifiers.Int_ids.Variable.exportedinclude Flambda2_algorithms.Container_types.S_plus_iterator
with type t := Flambda2_identifiers.Variable.t
module T = Flambda2_identifiers.Int_ids.Variable.Tinclude Flambda2_algorithms.Container_types_intf.Thing with type t := T.t
include Stdlib.Hashtbl.HashedType with type t := T.t
val hash : T.t -> intA hashing function on keys. It must be such that if two keys are equal according to equal, then they have identical hash values as computed by hash. Examples: suitable (equal, hash) pairs for arbitrary key types include
- (
(=),hash) for comparing objects by structure (provided objects do not contain floats) - (
(fun x y -> compare x y = 0),hash) for comparing objects by structure and handlingStdlib.nancorrectly - (
(==),hash) for comparing objects by physical equality (e.g. for mutable or cyclic objects).
include Stdlib.Map.OrderedType with type t := T.t
A total ordering function over the keys. This is a two-argument function f such that f e1 e2 is zero if the keys e1 and e2 are equal, f e1 e2 is strictly negative if e1 is smaller than e2, and f e1 e2 is strictly positive if e1 is greater than e2. Example: a suitable ordering function is the generic structural comparison function Stdlib.compare.
val print : Stdlib.Format.formatter -> T.t -> unitmodule Set = Flambda2_identifiers.Int_ids.Variable.Setmodule Map = Flambda2_identifiers.Int_ids.Variable.Mapmodule Lmap = Flambda2_identifiers.Int_ids.Variable.Lmapval create :
?user_visible:unit ->
string ->
Flambda2_kinds.Flambda_kind.t ->
Flambda2_identifiers.Variable.tval compilation_unit : Flambda2_identifiers.Variable.t -> Compilation_unit.tval name : Flambda2_identifiers.Variable.t -> stringval name_stamp : Flambda2_identifiers.Variable.t -> intval kind : Flambda2_identifiers.Variable.t -> Flambda2_kinds.Flambda_kind.tval user_visible : Flambda2_identifiers.Variable.t -> boolval create_with_same_name_as_ident :
?user_visible:unit ->
Ident.t ->
Flambda2_kinds.Flambda_kind.t ->
Flambda2_identifiers.Variable.tval rename :
?append:string ->
Flambda2_identifiers.Variable.t ->
Flambda2_identifiers.Variable.trename always returns a variable with a compilation unit set to that of the current unit, not the unit of the variable passed in.
val is_renamed_version_of :
Flambda2_identifiers.Variable.t ->
Flambda2_identifiers.Variable.t ->
boolval unique_name : Flambda2_identifiers.Variable.t -> stringval raw_name : Flambda2_identifiers.Variable.t -> string