package bap-std
Install
Dune Dependency
Authors
Maintainers
Sources
sha256=7c6d0dfe2640e800829617dd150ffe748493fe3f317ed41be44312b2821deb46
md5=5dbc6677d646bec59fd7414f23e88cf8
doc/bap/Bap/Std/Graphs/Ir/Edge/index.html
Module Ir.Edge
since in IR the order of edges defines semantics, we provide extra functions
include Graphlib.Std.Edge
with type graph = t
and type node = node
and type t = edge
type t = edge
type node = node
type graph = t
create x y l
creates an edge connecting nodes x
and y
labeled with a a given label l
insert e g
returns a graph g'
with a set of edges extended with edge e
. If src e
or dst e
wasn't in the set of nodes N
, then it is extended as well, so that axioms of graph are preserved.
Postconditions:
- E(g') = E(g) ∪ {e}.
update e l g
if edge e
exists in graph g
then return a new graph g'
in which edge e
is associated with label l
. Otherwise return g
unchanged.
Postcondition:
- E(g) ⊆ E(g') - N(g) ⊆ N(g') - e ∉ E(g) → e ∉ E(g'). - e ∈ E(g) → ε(g')e = l.
remove e g
returns a graph g'
that doesn't contain edge e
.
Postconditions:
- E(g') = E(g) \ {e}.
include Regular.Std.Opaque.S with type t := t
include Core_kernel.Comparable.S with type t := t
include Base.Comparable.S with type t := t
ascending
is identical to compare
. descending x y = ascending y x
. These are intended to be mnemonic when used like List.sort ~compare:ascending
and List.sort ~cmp:descending
, since they cause the list to be sorted in ascending or descending order, respectively.
clamp_exn t ~min ~max
returns t'
, the closest value to t
such that between t' ~low:min ~high:max
is true.
Raises if not (min <= max)
.
val comparator : (t, comparator_witness) Base__.Comparator.comparator
module Replace_polymorphic_compare :
Base.Comparable.Polymorphic_compare with type t := t
module Map :
Core_kernel.Map.S
with type Key.t = t
with type Key.comparator_witness = comparator_witness
module Set :
Core_kernel.Set.S
with type Elt.t = t
with type Elt.comparator_witness = comparator_witness
include Core_kernel.Hashable.S with type t := t
include Core_kernel.Hashable.Common with type t := t
val compare : t -> t -> Base.Int.t
val hash_fold_t :
Ppx_hash_lib.Std.Hash.state ->
t ->
Ppx_hash_lib.Std.Hash.state
val hash : t -> Ppx_hash_lib.Std.Hash.hash_value
val hashable : t Core_kernel.Hashtbl.Hashable.t
module Table : Core_kernel.Hashtbl.S with type key = t
module Hash_set : Core_kernel.Hash_set.S with type elt = t
module Hash_queue : Core_kernel.Hash_queue.S with type key = t
jmps dir e g
enumerates all jumps (including calls, interrupts, indirects, etc), that occurs before if dir = `before
or after if dir = `after
an edge e
edges dir e g
enumerates all edges occurring before of after an edge e
in graph g
cond e g
computes a condition expression that is asserted to be true
if this branch is taken.
Note: this is not the same as a condition associated with the jmp term itself, it takes into account all conditions preceding the edge.
include Regular.Std.Printable.S with type t := t
val to_string : t -> string
to_string x
returns a human-readable representation of x
val str : unit -> t -> string
str () t
is formatted output function that matches "%a" conversion format specifier in functions, that prints to string, e.g., sprintf
, failwithf
, errorf
and, surprisingly all Lwt
printing function, including Lwt_io.printf
and logging (or any other function with type ('a,unit,string,...) formatN`. Example:
Or_error.errorf "type %a is not valid for %a"
Type.str ty Exp.str exp
val pps : unit -> t -> string
synonym for str
val ppo : Core_kernel.Out_channel.t -> t -> unit
will print to a standard output_channel
, useful for using in printf
, fprintf
, etc.
val pp_seq : Format.formatter -> t Core_kernel.Sequence.t -> unit
prints a sequence of values of type t
this will include pp
function from Core
that has type t printer
, and can be used in Format.printf
family of functions
include Core_kernel.Pretty_printer.S with type t := t
val pp : Base__.Formatter.t -> t -> unit