ROSE 0.11.145.192
|
Reference to a function, basic block, instruction, or address.
A reference can be an empty reference, or it points to a function and/or basic block and/or instruction, or it is an address in any combination. A reference has a granularity depending on the finest thing to which it points (see granularity). All non-empty references have a computable address regardless of whether an address is actually stored. References are comparable.
Definition at line 25 of file Reference.h.
#include <Rose/BinaryAnalysis/Partitioner2/Reference.h>
Public Types | |
enum | Granularity { EMPTY , ADDRESS , INSTRUCTION , BASIC_BLOCK , FUNCTION } |
Granularity. More... | |
Public Member Functions | |
Granularity | granularity () const |
Reference granularity. | |
bool | isEmpty () const |
Predicate for emptiness. | |
bool | hasFunction () const |
Predicate for having a function. | |
FunctionPtr | function () const |
Optional function pointer. | |
bool | hasBasicBlock () const |
Predicate for having a basic block. | |
BasicBlockPtr | basicBlock () const |
Optional basic block pointer. | |
bool | hasInstruction () const |
Predicate for having an instruction. | |
SgAsmInstruction * | instruction () const |
Optional instruction pointer. | |
bool | hasExplicitAddress () const |
Predicate for having a stored address. | |
rose_addr_t | address () const |
Address. | |
bool | operator== (const Reference &other) const |
Whether two references are equal. | |
bool | operator< (const Reference &other) const |
Compare two references. | |
Reference (const FunctionPtr &) | |
Constructor. | |
Reference (const FunctionPtr &, const BasicBlockPtr &, SgAsmInstruction *=nullptr, const Sawyer::Optional< rose_addr_t > &=Sawyer::Nothing()) | |
Constructor. | |
Reference (const BasicBlockPtr &, SgAsmInstruction *=nullptr, const Sawyer::Optional< rose_addr_t > &=Sawyer::Nothing()) | |
Constructor. | |
Reference (SgAsmInstruction *, const Sawyer::Optional< rose_addr_t > &=Sawyer::Nothing()) | |
Constructor. | |
Reference (rose_addr_t address) | |
Constructor. | |
Granularity.
Enumerator | |
---|---|
EMPTY | Reference points to nothing and has no address. |
ADDRESS | Reference points to nothing but has an address. |
INSTRUCTION | Reference points to an instruction but no stored address. |
BASIC_BLOCK | Reference points to a basic block but not an instruction or a stored address. |
FUNCTION | Reference points to a function but not a basic block or instruction, and has no stored address. |
Definition at line 32 of file Reference.h.
|
explicit |
Constructor.
A reference can be constructed from any combination of a function, basic block, instruction, and address.
|
explicit |
Constructor.
A reference can be constructed from any combination of a function, basic block, instruction, and address.
|
explicit |
Constructor.
A reference can be constructed from any combination of a function, basic block, instruction, and address.
|
explicit |
Constructor.
A reference can be constructed from any combination of a function, basic block, instruction, and address.
|
explicit |
Constructor.
A reference can be constructed from any combination of a function, basic block, instruction, and address.
Rose::BinaryAnalysis::Partitioner2::Reference::Reference | ( | ) |
Constructor.
A reference can be constructed from any combination of a function, basic block, instruction, and address.
Granularity Rose::BinaryAnalysis::Partitioner2::Reference::granularity | ( | ) | const |
Reference granularity.
Returns the granularity for the reference. The granularity is the finest thing stored in the reference. The order from finest to coarsest is: EMPTY, ADDRESS, INSTRUCTION, BASIC_BLOCK, FUNCTION.
bool Rose::BinaryAnalysis::Partitioner2::Reference::isEmpty | ( | ) | const |
Predicate for emptiness.
Returns true if this reference points to nothing and has no stored address.
bool Rose::BinaryAnalysis::Partitioner2::Reference::hasFunction | ( | ) | const |
Predicate for having a function.
Returns true if the reference points to a function.
bool Rose::BinaryAnalysis::Partitioner2::Reference::hasBasicBlock | ( | ) | const |
Predicate for having a basic block.
Returns true if the reference points to a basic block.
bool Rose::BinaryAnalysis::Partitioner2::Reference::hasInstruction | ( | ) | const |
Predicate for having an instruction.
Returns true if the reference points to an instruction.
bool Rose::BinaryAnalysis::Partitioner2::Reference::hasExplicitAddress | ( | ) | const |
Predicate for having a stored address.
All non-empty references have a computable address, but an address can also be stored explicitly. This predicate returns true when an address is stored explicitly.
rose_addr_t Rose::BinaryAnalysis::Partitioner2::Reference::address | ( | ) | const |
Address.
All non-empty references have either an explicitly stored address or an address that can be obtained from an instruction, basic block, or function. This method returns the first address found from that list.
bool Rose::BinaryAnalysis::Partitioner2::Reference::operator== | ( | const Reference & | other | ) | const |
Whether two references are equal.
Two references are equal if they are both empty, or else if they have the same address and granularity.
bool Rose::BinaryAnalysis::Partitioner2::Reference::operator< | ( | const Reference & | other | ) | const |
Compare two references.
Returns true when this reference is less than the other
reference. The empty reference is less than all non-empty references. A non-empty reference is less than or greater than another non-empty reference if its address is less than or greater than the other reference's address. When two references have the same address then the finer granularity reference is less than the coarser reference.