|
|
|
(*
|
|
|
|
* Copyright (c) 2009-2013, Monoidics ltd.
|
|
|
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
|
|
*
|
|
|
|
* This source code is licensed under the MIT license found in the
|
|
|
|
* LICENSE file in the root directory of this source tree.
|
|
|
|
*)
|
|
|
|
|
|
|
|
open! IStd
|
|
|
|
|
|
|
|
(** Module for Mangled Names *)
|
|
|
|
|
|
|
|
(** Type of mangled names *)
|
[pulse] define PulseSummary.yojson_of_t
Summary:
Emit the crucial parts of Pulse summaries as json to enable
post-processing by external tools. Stop somewhat arbitrarily at some
datatypes that are just emitted as "opaque" values.
For example:
```
$ infer debug --procedures --procedures-summary-json --select 0
[[["pulse",[["ContinueProgram",{"post":{"heap":[["v3",[[["Dereference"],["v4","_"]]]],["v7",[[["Dereference"],["v3","_"]]]]],"stack":[[["ProgramVar",{"plain":"return","mangled":null}],["v7","_"]]],"attrs":"_"},"pre":{"heap":[],"stack":[],"attrs":"_"},"skipped_calls":"_","path_condition":"_"}],["ContinueProgram",{"post":{"heap":[["v3",[[["Dereference"],["v4","_"]]]],["v8",[[["Dereference"],["v3","_"]]]]],"stack":[[["ProgramVar",{"plain":"return","mangled":null}],["v8","_"]]],"attrs":"_"},"pre":{"heap":[],"stack":[],"attrs":"_"},"skipped_calls":"_","path_condition":"_"}]]]]]
```
Reviewed By: ezgicicek
Differential Revision: D24503387
fbshipit-source-id: 9bd08e93b
4 years ago
|
|
|
type t [@@deriving compare, yojson_of]
|
|
|
|
|
|
|
|
val equal : t -> t -> bool
|
|
|
|
(** Equality for mangled names *)
|
|
|
|
|
|
|
|
val from_string : string -> t
|
|
|
|
(** Convert a string to a mangled name *)
|
|
|
|
|
|
|
|
val mangled : string -> string -> t
|
|
|
|
(** Create a mangled name from a plain and mangled string *)
|
|
|
|
|
|
|
|
val to_string : t -> string
|
|
|
|
(** Convert a mangled name to a string *)
|
|
|
|
|
|
|
|
val to_string_full : t -> string
|
|
|
|
(** Convert a full mangled name to a string *)
|
|
|
|
|
|
|
|
val pp : Format.formatter -> t -> unit
|
|
|
|
(** Pretty print a mangled name *)
|
|
|
|
|
|
|
|
val this : t
|
|
|
|
|
|
|
|
val is_this : t -> bool
|
|
|
|
|
|
|
|
val self : t [@@warning "-32"]
|
|
|
|
|
|
|
|
val is_self : t -> bool
|
|
|
|
|
|
|
|
(** Set of Mangled. *)
|
|
|
|
module Set : PrettyPrintable.PPSet with type elt = t
|
|
|
|
|
|
|
|
(** Map with Mangled as key *)
|
|
|
|
module Map : PrettyPrintable.PPMap with type key = t
|