functor (VALUE : Lattice_With_Isotropy.S) ->
functor
(LOffset : sig
type t
type y = VALUE.t
type widen_hint = VALUE.widen_hint
module Datatype :
sig
type t = t
val rehash : t -> t
val descr : Unmarshal.t
val copy : t -> t
val name : string
val register_comparable :
?compare:(t -> t -> int) ->
?equal:(t -> t -> bool) ->
?hash:(t -> int) ->
?physical_hash:(t -> int) -> unit -> unit
val is_comparable_set : unit -> bool
val hash : t -> int
val physical_hash : t -> int
val equal : t -> t -> bool
val compare : t -> t -> int
val contain_project :
(Project.project -> t -> bool) option ref
end
val tag : t -> int
val empty : t
val is_empty : t -> bool
val equal : t -> t -> bool
val pretty_typ :
Cil_types.typ option -> Format.formatter -> t -> unit
val pretty : Format.formatter -> t -> unit
val pretty_debug : Format.formatter -> t -> unit
val reduce :
Ival.t -> size:Abstract_interp.Int.t -> y -> t -> t
val is_included : t -> t -> bool
val is_included_exn : t -> t -> unit
val is_included_exn_generic :
(y -> y -> unit) -> t -> t -> unit
val is_included_actual_generic :
BaseUtils.BaseSet.t ->
BaseUtils.BaseSet.t ref ->
Locations.Location_Bytes.t BaseUtils.BaseMap.t ref ->
t -> t -> unit
val join :
t ->
t ->
(Abstract_interp.Int.t * Abstract_interp.Int.t) list * t
val widen : widen_hint -> t -> t -> t
val find_ival :
validity:Base.validity ->
with_alarms:CilE.warn_mode ->
Ival.t -> t -> Abstract_interp.Int.t -> y -> y
val concerned_bindings_ival :
offsets:Ival.t ->
offsetmap:t ->
size:Abstract_interp.Int.t -> y list -> y list
val update_ival :
with_alarms:CilE.warn_mode ->
validity:Base.validity ->
exact:bool ->
offsets:Ival.t ->
size:Abstract_interp.Int.t -> t -> y -> t
val overwrite : t -> y -> Origin.t -> t
val over_intersection : t -> t -> t
val from_string : string -> t
val add_internal :
Offsetmap.itv ->
Abstract_interp.Int.t * Abstract_interp.Int.t * y ->
t -> t
val add_whole : Offsetmap.itv -> y -> t -> t
val remove_whole : Offsetmap.itv -> t -> t
val fold_whole :
size:Abstract_interp.Int.t ->
(Ival.t -> Abstract_interp.Int.t -> y -> 'a -> 'a) ->
t -> 'a -> 'a
val fold_single_bindings :
size:Abstract_interp.Int.t ->
(Ival.t -> Abstract_interp.Int.t -> y -> 'a -> 'a) ->
t -> 'a -> 'a
val fold_internal :
(Offsetmap.itv ->
Abstract_interp.Int.t * Abstract_interp.Int.t * y ->
'a -> 'a) ->
t -> 'a -> 'a
val shift_ival : Ival.t -> t -> t option -> t option
val copy_paste :
t ->
Abstract_interp.Int.t ->
Abstract_interp.Int.t -> Abstract_interp.Int.t -> t -> t
val copy_merge :
t ->
Abstract_interp.Int.t ->
Abstract_interp.Int.t -> Abstract_interp.Int.t -> t -> t
val copy :
t -> Abstract_interp.Int.t -> Abstract_interp.Int.t -> t
val merge_by_itv :
t -> t -> Abstract_value.Int_Intervals.t -> t
val shift : Abstract_interp.Int.t -> t -> t
val sized_zero : size_in_bits:Abstract_interp.Int.t -> t
val reciprocal_image :
t -> Base.t -> Abstract_value.Int_Intervals.t * Ival.t
val create_initial : v:y -> modu:Abstract_interp.Int.t -> t
val reduce_by_int_intervals :
t -> Abstract_value.Int_Intervals.t -> t
val top_stuff : (y -> bool) -> (y -> y) -> t -> t
val iter_contents :
(y -> unit) -> t -> Abstract_interp.Int.t -> unit
val fold :
(Abstract_interp.Int.t * Abstract_interp.Int.t ->
Abstract_interp.Int.t * Abstract_interp.Int.t * y ->
'a -> 'a) ->
t -> 'a -> 'a
end) ->
sig
type y = VALUE.t
type loffset = LOffset.t
type widen_hint_offsetmap = VALUE.widen_hint
module Make :
functor
(Default_offsetmap : sig
val default_offsetmap : Base.t -> loffset
end) ->
sig
type t
type widen_hint =
bool * BaseUtils.BaseSet.t * (Base.t -> widen_hint_offsetmap)
type instanciation =
Locations.Location_Bytes.t BaseUtils.BaseMap.t
module Datatype :
sig
type t = t
val rehash : t -> t
val descr : Unmarshal.t
val copy : t -> t
val name : string
val register_comparable :
?compare:(t -> t -> int) ->
?equal:(t -> t -> bool) ->
?hash:(t -> int) ->
?physical_hash:(t -> int) -> unit -> unit
val is_comparable_set : unit -> bool
val hash : t -> int
val physical_hash : t -> int
val equal : t -> t -> bool
val compare : t -> t -> int
val contain_project :
(Project.project -> t -> bool) option ref
end
val inject : Base.t -> loffset -> t
val add_offsetmap : Base.t -> loffset -> t -> t
val pretty : Format.formatter -> t -> unit
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 -> y -> t
val find :
with_alarms:CilE.warn_mode -> t -> Locations.location -> y
val join : t -> t -> Locations.location list * t
val is_included : t -> t -> bool
val equal : t -> t -> bool
val hash : t -> int
val is_included_actual_generic :
Locations.Zone.t -> t -> t -> instanciation
val empty : t
val is_empty : 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 -> loffset
val remove_base : Base.t -> t -> t
val reduce_binding :
with_alarms:CilE.warn_mode -> t -> Locations.location -> y -> t
val copy_paste :
Locations.location -> Locations.location -> t -> t
val paste_offsetmap :
loffset ->
Locations.Location_Bits.t ->
Abstract_interp.Int.t -> Abstract_interp.Int.t -> t -> t
val copy_offsetmap : Locations.location -> t -> 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 -> y -> 'a -> 'a) -> t -> 'a -> 'a
val fold_single_bindings :
size:Abstract_interp.Int.t ->
(Locations.location -> y -> 'a -> 'a) -> t -> 'a -> 'a
val fold_base : (Base.t -> 'a -> 'a) -> t -> 'a -> 'a
val fold_base_offsetmap :
(Base.t -> loffset -> 'a -> 'a) -> t -> 'a -> 'a
val find_offsetmap_for_location :
Locations.Location_Bits.t -> t -> loffset
val add_whole : Locations.location -> y -> t -> t
val remove_whole : Locations.location -> t -> t
val reciprocal_image :
Base.t -> t -> Locations.Zone.t * Locations.Location_Bits.t
val create_initial :
base:Base.t ->
v:y -> modu:Abstract_interp.Int.t -> state:t -> t
exception Error_Bottom
val cached_fold :
f:(Base.t -> loffset -> 'a) ->
cache:string * int ->
joiner:('a -> 'a -> 'a) -> empty:'a -> t -> 'a
val cached_map :
f:(Base.t -> loffset -> loffset) ->
cache:string * int -> t -> t
end
end