sig
type t =
Lmap.Make_LOffset(V_Or_Uninitialized)(V_Offsetmap_ext).Make(Default_offsetmap).t
val ty : t Type.t
val name : string
val descr : t Descr.t
val packed_descr : Structural_descr.pack
val reprs : t list
val equal : t -> t -> bool
val compare : t -> t -> int
val hash : t -> int
val pretty_code : Format.formatter -> t -> unit
val internal_pretty_code : Type.precedence -> Format.formatter -> t -> unit
val pretty : Format.formatter -> t -> unit
val varname : t -> string
val mem_project : (Project_skeleton.t -> bool) -> t -> bool
val copy : t -> t
type widen_hint =
bool * Base.Set.t * (Base.t -> Partial_lmap.widen_hint_offsetmap)
type instanciation = Locations.Location_Bytes.t Base.Map.t
val inject : Base.t -> Partial_lmap.loffset -> t
val add_offsetmap : Base.t -> Partial_lmap.loffset -> t -> t
val pretty_without_null : Format.formatter -> t -> unit
val pretty_filter :
Format.formatter -> t -> Locations.Zone.t -> (Base.t -> bool) -> unit
val add_binding :
with_alarms:CilE.warn_mode ->
exact:bool -> t -> Locations.location -> Partial_lmap.y -> t
val find :
conflate_bottom:bool ->
with_alarms:CilE.warn_mode -> t -> Locations.location -> Partial_lmap.y
val join : t -> t -> Locations.location list * t
val is_included : t -> t -> bool
val is_included_actual_generic :
Locations.Zone.t -> t -> t -> instanciation
val top : t
val empty_map : t
val is_empty_map : t -> bool
val bottom : t
val is_reachable : t -> bool
val widen : widen_hint -> t -> t -> bool * t
val filter_base : (Base.t -> bool) -> t -> t
val find_base : Base.t -> t -> Partial_lmap.loffset
val remove_base : Base.t -> t -> t
val reduce_binding :
with_alarms:CilE.warn_mode ->
t -> Locations.location -> Partial_lmap.y -> t
val copy_paste : Locations.location -> Locations.location -> t -> t
val paste_offsetmap :
Partial_lmap.loffset ->
Locations.Location_Bits.t ->
Abstract_interp.Int.t -> Abstract_interp.Int.t -> t -> t
val copy_offsetmap :
with_alarms:CilE.warn_mode ->
Locations.location -> t -> Partial_lmap.loffset option
val compute_actual_final_from_generic :
t ->
t ->
Locations.Zone.t ->
instanciation -> t * Locations.Location_Bits.Top_Param.t
val is_included_by_location_enum : t -> t -> Locations.Zone.t -> bool
val fold :
size:Abstract_interp.Int.t ->
(Locations.location -> Partial_lmap.y -> 'a -> 'a) -> t -> 'a -> 'a
val fold_single_bindings :
size:Abstract_interp.Int.t ->
(Locations.location -> Partial_lmap.y -> 'a -> 'a) -> t -> 'a -> 'a
val fold_base : (Base.t -> 'a -> 'a) -> t -> 'a -> 'a
val fold_base_offsetmap :
(Base.t -> Partial_lmap.loffset -> 'a -> 'a) -> t -> 'a -> 'a
val find_offsetmap_for_location :
Locations.Location_Bits.t -> t -> Partial_lmap.loffset
val add_whole : Locations.location -> Partial_lmap.y -> t -> t
val remove_whole : Locations.location -> t -> t
val comp_prefixes : t -> t -> unit
type subtree =
Lmap.Make_LOffset(V_Or_Uninitialized)(V_Offsetmap_ext).Make(Default_offsetmap).subtree
val find_prefix : t -> Hptmap.prefix -> subtree option
val hash_subtree : subtree -> int
val equal_subtree : subtree -> subtree -> bool
val reciprocal_image :
Base.t -> t -> Locations.Zone.t * Locations.Location_Bits.t
val create_initial :
base:Base.t ->
v:Partial_lmap.y -> modu:Abstract_interp.Int.t -> state:t -> t
exception Error_Bottom
val cached_fold :
f:(Base.t -> Partial_lmap.loffset -> 'a) ->
cache:string * int ->
temporary:bool -> joiner:('a -> 'a -> 'a) -> empty:'a -> t -> 'a
val cached_map :
f:(Base.t -> Partial_lmap.loffset -> Partial_lmap.loffset) ->
cache:string * int -> temporary:bool -> t -> t
exception Found_prefix of Hptmap.prefix * subtree * subtree
type y = Cvalue_type.V.t
val find_unspecified :
with_alarms:CilE.warn_mode ->
t -> Locations.location -> Cvalue_type.Partial_lmap.y
val find :
conflate_bottom:bool ->
with_alarms:CilE.warn_mode -> t -> Locations.location -> Cvalue_type.V.t
val add_binding_unspecified : t -> Locations.location -> t
val add_binding :
with_alarms:CilE.warn_mode ->
exact:bool -> t -> Locations.location -> Cvalue_type.V.t -> t
val reduce_binding :
with_alarms:CilE.warn_mode ->
t -> Locations.location -> Cvalue_type.V.t -> t
val create_initial :
base:Base.t ->
v:Cvalue_type.V.t -> modu:Abstract_interp.Int.t -> state:t -> t
end