|
|
|
(*
|
|
|
|
* Copyright (c) 2009 - 2013 Monoidics ltd.
|
|
|
|
* Copyright (c) 2013 - present Facebook, Inc.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* This source code is licensed under the BSD style license found in the
|
|
|
|
* LICENSE file in the root directory of this source tree. An additional grant
|
|
|
|
* of patent rights can be found in the PATENTS file in the same directory.
|
|
|
|
*)
|
|
|
|
|
|
|
|
(** Execution Paths *)
|
|
|
|
|
|
|
|
open Utils
|
|
|
|
|
|
|
|
module Path : sig
|
|
|
|
(** type for paths *)
|
|
|
|
type t
|
|
|
|
|
|
|
|
type session = int
|
|
|
|
|
|
|
|
(** add a call with its sub-path, the boolean indicates whether the subtrace for the procedure should be included *)
|
|
|
|
val add_call : bool -> t -> Procname.t -> t -> t
|
|
|
|
|
|
|
|
(** check whether a path contains another path *)
|
|
|
|
val contains : t -> t -> bool
|
|
|
|
|
|
|
|
(** check wether the path contains the given position *)
|
|
|
|
val contains_position : t -> Sil.path_pos -> bool
|
|
|
|
|
|
|
|
(** Create the location trace of the path, up to the path position if specified *)
|
|
|
|
val create_loc_trace : t -> Sil.path_pos option -> Errlog.loc_trace
|
|
|
|
|
|
|
|
(** return the current node of the path *)
|
|
|
|
val curr_node : t -> Cfg.node
|
|
|
|
|
|
|
|
(** dump a path *)
|
|
|
|
val d : t -> unit
|
|
|
|
|
|
|
|
(** dump statistics of the path *)
|
|
|
|
val d_stats : t -> unit
|
|
|
|
|
|
|
|
(** extend a path with a new node reached from the given session, with an optional string for exceptions *)
|
|
|
|
val extend : Cfg.node -> Mangled.t option -> session -> t -> t
|
|
|
|
|
|
|
|
val add_description : t -> string -> t
|
|
|
|
|
|
|
|
(** iterate over each node in the path, excluding calls, once *)
|
|
|
|
val iter_all_nodes_nocalls : (Cfg.node -> unit) -> t -> unit
|
|
|
|
|
|
|
|
(** iterate over the longest sequence belonging to the path, restricting to those containing the given position if given.
|
|
|
|
Do not iterate past the given position.
|
|
|
|
[f level path session exn_opt] is passed the current nesting [level] and [path] and previous [session] and possible exception [exn_opt] *)
|
|
|
|
val iter_longest_sequence : (int -> t -> int -> Mangled.t option -> unit) -> Sil.path_pos option -> t -> unit
|
|
|
|
|
|
|
|
(** join two paths *)
|
|
|
|
val join : t -> t -> t
|
|
|
|
|
|
|
|
(** pretty print a path *)
|
|
|
|
val pp : Format.formatter -> t -> unit
|
|
|
|
|
|
|
|
(** pretty print statistics of the path *)
|
|
|
|
val pp_stats : Format.formatter -> t -> unit
|
|
|
|
|
|
|
|
(** create a new path with given start node *)
|
|
|
|
val start : Cfg.node -> t
|
|
|
|
end
|
|
|
|
|
|
|
|
(** Set of (prop,path) pairs, where the identity is given by prop *)
|
|
|
|
module PathSet : sig
|
|
|
|
type t
|
|
|
|
|
|
|
|
(** It's the caller's resposibility to ensure that Prop.prop_rename_primed_footprint_vars was called on the prop *)
|
|
|
|
val add_renamed_prop : Prop.normal Prop.t -> Path.t -> t -> t
|
|
|
|
|
|
|
|
(** dump the pathset *)
|
|
|
|
val d : t -> unit
|
|
|
|
|
|
|
|
(** difference between two pathsets *)
|
|
|
|
val diff : t -> t -> t
|
|
|
|
|
|
|
|
(** empty pathset *)
|
|
|
|
val empty : t
|
|
|
|
|
|
|
|
(** list of elements in a pathset *)
|
|
|
|
val elements : t -> (Prop.normal Prop.t * Path.t) list
|
|
|
|
|
|
|
|
(** equality for pathsets *)
|
|
|
|
val equal : t -> t -> bool
|
|
|
|
|
|
|
|
(** filter a pathset on the prop component *)
|
|
|
|
val filter : (Prop.normal Prop.t -> bool) -> t -> t
|
|
|
|
|
|
|
|
(** find the list of props whose associated path contains the given path *)
|
|
|
|
val filter_path : Path.t -> t -> Prop.normal Prop.t list
|
|
|
|
|
|
|
|
(** fold over a pathset *)
|
|
|
|
val fold : (Prop.normal Prop.t -> Path.t -> 'a -> 'a) -> t -> 'a -> 'a
|
|
|
|
|
|
|
|
(** It's the caller's resposibility to ensure that Prop.prop_rename_primed_footprint_vars was called on the list *)
|
|
|
|
val from_renamed_list: (Prop.normal Prop.t * Path.t) list -> t
|
|
|
|
|
|
|
|
(** check whether the pathset is empty *)
|
|
|
|
val is_empty : t -> bool
|
|
|
|
|
|
|
|
(** iterate over a pathset *)
|
|
|
|
val iter : (Prop.normal Prop.t -> Path.t -> unit) -> t -> unit
|
|
|
|
|
|
|
|
(** map over the prop component of a pathset. *)
|
|
|
|
val map : (Prop.normal Prop.t -> Prop.normal Prop.t) -> t -> t
|
|
|
|
|
|
|
|
(** map over the prop component of a pathset using a partial function; elements mapped to None are discarded *)
|
|
|
|
val map_option : (Prop.normal Prop.t -> Prop.normal Prop.t option) -> t -> t
|
|
|
|
|
|
|
|
(** partition a pathset on the prop component *)
|
|
|
|
val partition : (Prop.normal Prop.t -> bool) -> t -> t * t
|
|
|
|
|
|
|
|
(** pretty print the pathset *)
|
|
|
|
val pp : printenv -> Format.formatter -> t -> unit
|
|
|
|
|
|
|
|
(** number of elements in the pathset *)
|
|
|
|
val size : t -> int
|
|
|
|
|
|
|
|
(** convert to a list of props *)
|
|
|
|
val to_proplist : t -> Prop.normal Prop.t list
|
|
|
|
|
|
|
|
(** convert to a set of props *)
|
|
|
|
val to_propset : t -> Propset.t
|
|
|
|
|
|
|
|
(** union of two pathsets *)
|
|
|
|
val union : t -> t -> t
|
|
|
|
end
|