package goblint

  1. Overview
  2. Docs
Legend:
Library
Module
Module type
Parameter
Class
Class type

Parameters

module V : S

Signature

module K = Mval.Exp
module V = V
module MD : sig ... end
include module type of struct include MD end
type t
type key = Mval.Exp.t
type value = V.t
val add : key -> value -> t -> t
val remove : key -> t -> t
val find : key -> t -> value
val find_opt : key -> t -> value option
val mem : key -> t -> bool
val iter : (key -> value -> unit) -> t -> unit
val map : (value -> value) -> t -> t
val filter : (key -> value -> bool) -> t -> t
val mapi : (key -> value -> value) -> t -> t
val fold : (key -> value -> 'a -> 'a) -> t -> 'a -> 'a
val add_list : (key * value) list -> t -> t
val add_list_set : key list -> value -> t -> t
val add_list_fun : key list -> (key -> value) -> t -> t
val for_all : (key -> value -> bool) -> t -> bool
val map2 : (value -> value -> value) -> t -> t -> t
val long_map2 : (value -> value -> value) -> t -> t -> t
val merge : (key -> value option -> value option -> value option) -> t -> t -> t
val cardinal : t -> int
val choose : t -> key * value
val singleton : key -> value -> t
val empty : unit -> t
val is_empty : t -> bool
val exists : (key -> value -> bool) -> t -> bool
val bindings : t -> (key * value) list
val equal : t -> t -> bool
val hash : t -> int
val compare : t -> t -> int
val show : t -> string
val pretty : unit -> t -> Printable.Pretty.doc
val printXml : 'a BatInnerIO.output -> t -> unit
val name : unit -> string
val to_yojson : t -> Yojson.Safe.t
val tag : t -> int
val arbitrary : unit -> t QCheck.arbitrary
val relift : t -> t
val leq : t -> t -> bool
val join : t -> t -> t
val meet : t -> t -> t
val widen : t -> t -> t
val narrow : t -> t -> t
val pretty_diff : unit -> (t * t) -> Lattice.Pretty.doc
val bot : unit -> t
val is_bot : t -> bool
val top : unit -> t
val is_top : t -> bool
val widen_with_fct : (value -> value -> value) -> t -> t -> t
val join_with_fct : (value -> value -> value) -> t -> t -> t
val leq_with_fct : (value -> value -> bool) -> t -> t -> bool
val find' : key -> t -> value
val find_option : key -> t -> value option
val get_alias : key -> t -> V.k option
val get_aliased : V.k -> t -> key list
val get_aliases : key -> t -> key list
val alias : key -> key -> t -> t
val remove' : key -> t -> t
val add' : key -> value -> t -> t
val change : key -> value -> t -> t
val get_record : key -> t -> V.r option
val edit_record : key -> (V.r -> V.r) -> t -> t
val get_value : key -> t -> V.r Batteries.Set.t * V.r Batteries.Set.t
val extend_value : key -> (V.r Batteries.Set.t * V.r Batteries.Set.t) -> t -> t
val union : ('a Batteries.Set.t * 'b Batteries.Set.t) -> ('a Batteries.Set.t * 'b Batteries.Set.t) -> 'a Batteries.Set.t * 'b Batteries.Set.t
val is_special_var : V.k -> bool
val without_special_vars : t -> t
val only_globals : t -> t
val add_all : t -> t -> t
val callstack_var : GoblintCil.varinfo * [> `NoOffset ]
val callstack : t -> Node.t list
val string_of_callstack : t -> string
val edit_callstack : (Node.t list -> Node.t list) -> t -> t
val must : key -> (V.r -> bool) -> t -> bool
val may : key -> (V.r -> bool) -> t -> bool
val is_may : key -> t -> bool
val filter_values : (V.r -> bool) -> t -> V.r Batteries.Set.t * V.r Batteries.Set.t
val filter_records : key -> (V.r -> bool) -> t -> V.r Batteries.Set.t * V.r Batteries.Set.t
val unknown : key -> t -> t
val is_unknown : key -> t -> bool
val string_of_state : key -> t -> string
val string_of_key : V.k -> string
val string_of_keys : V.r Batteries.Set.t -> string
val string_of_entry : V.k -> t -> string
val string_of_map : t -> string list
val warn : ?may:bool -> ?loc:Node.t list -> string -> unit
val keys_from_lval : GoblintCil.lval -> Queries.ask -> (GoblintCil.varinfo * GoblintCil.exp Goblint_lib__Offset_intf.t) list
OCaml

Innovation. Community. Security.