package bap-std
Basic block.
Basic block is piece of code, that has single entry and single exit. It can be seen as a container for instructions. Also, basic blocks are nodes of control flow graphs.
The following invariants must be preserved:
- there is no known jump in the program, that points to an instruction that is not a leader of a basic block;
- any jump instruction is a terminator of some basic block;
- each basic block consists of at least one instruction.
type t = block
val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t
Since block
contains a region of memory, that is not regular, the block itself is also non-regular. But it is, at least, printable.
include Regular.Std.Opaque.S with type t := t
val comparator : (t, comparator_witness) Base__Comparator.comparator
module Replace_polymorphic_compare : sig ... end
module Map : sig ... end
module Set : sig ... end
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 : sig ... end
module Hash_set : sig ... end
module Hash_queue : sig ... end
all the printing stuff, including to_string
function
sectionYPositions = computeSectionYPositions($el), 10)" x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)">