Represents a basic block of a method's control flow graph (CFG).
Represents the control flow graph of a method.
Represents the control flow graph of a method.
To compute a CFG use the CFGFactory.
This class is thread-safe; all data is effectively immutable after construction time.
The code for which the CFG was build.
The unique exit node of the control flow graph if the method returns normally. If the method always throws an exception this node will not have any predecessors.
The unique exit node of the control flow graph if the method returns abnormally (throws an exception). If the method is guaranteed to never throw an exception, this node will not have any predecessors.
List of all catch nodes. (Usually, we have one CatchNode per org.opalj.br.ExceptionHandler, but if an exception handler does not catch anything, no CatchNode is created.)
An implicit map between a program counter and its associated BasicBlock; it may be a sparse array!
The common super trait of all nodes belonging to a method's control flow graph.
This node represents an exception handler.
This node represents an exception handler.
CatchNodes are made explicit to handle/identify situations where the same
exception handlers is responsible for handling multiple different exceptions.
This situation generally arises in case of Javas multi-catch expressions.
Represents the artificial exit node of a control flow graph.
Represents the artificial exit node of a control flow graph. The graph contains an explicit exit node to make it trivial to navigate to all instructions that may cause a(n ab)normal return from the method.
A factory for computing control flow graphs for methods.
Represents a basic block of a method's control flow graph (CFG). The basic block is identified by referring to the first and last instruction belonging to the basic block.