Class DexCFG.BasicBlock
java.lang.Object
com.ibm.wala.util.graph.impl.NodeWithNumber
com.ibm.wala.dalvik.classLoader.DexCFG.BasicBlock
- All Implemented Interfaces:
IBasicBlock<Instruction>, INodeWithNumber, Iterable<Instruction>
- Enclosing class:
DexCFG
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionbooleanintGet the index of the first instruction in the basic block.intGet the index of the last instruction in the basic block.intEach basic block should have a unique number in its cfginthashCode()booleanReturn true if the basic block represents a catch block.booleanReturn true if the basic block represents the unique entry block.booleanReturn true if the basic block represents the unique exit block.iterator()toString()Methods inherited from class NodeWithNumber
getGraphNodeId, setGraphNodeIdMethods inherited from interface INodeWithNumber
getGraphNodeId, setGraphNodeIdMethods inherited from interface Iterable
forEach, spliterator
-
Constructor Details
-
BasicBlock
public BasicBlock(int startIndex)
-
-
Method Details
-
isCatchBlock
public boolean isCatchBlock()Description copied from interface:IBasicBlockReturn true if the basic block represents a catch block.- Specified by:
isCatchBlockin interfaceIBasicBlock<Instruction>- Returns:
- true if the basic block represents a catch block.
-
getImplicitExceptionTypes
- Parameters:
pei- a potentially-excepting instruction- Returns:
- the exception types that pei may throw, independent of the class hierarchy. null if
none.
Notes
- this method will NOT return the exception type explicitly thrown by an athrow
- this method will NOT return the exception types that a called method may throw
- this method ignores OutOfMemoryError
- this method ignores linkage errors
- this method ignores IllegalMonitorState exceptions
- Throws:
IllegalArgumentException- if pei is null
-
getLastInstructionIndex
public int getLastInstructionIndex()Description copied from interface:IBasicBlockGet the index of the last instruction in the basic block. The value is an index into the instruction array that contains all the instructions for the method.If the result is < 0, the block has no instructions
- Specified by:
getLastInstructionIndexin interfaceIBasicBlock<Instruction>- Returns:
- the instruction index for the last instruction in the basic block
-
getFirstInstructionIndex
public int getFirstInstructionIndex()Description copied from interface:IBasicBlockGet the index of the first instruction in the basic block. The value is an index into the instruction array that contains all the instructions for the method.If the result is < 0, the block has no instructions
- Specified by:
getFirstInstructionIndexin interfaceIBasicBlock<Instruction>- Returns:
- the instruction index for the first instruction in the basic block.
-
toString
-
isExitBlock
public boolean isExitBlock()Description copied from interface:IBasicBlockReturn true if the basic block represents the unique exit block.- Specified by:
isExitBlockin interfaceIBasicBlock<Instruction>- Returns:
- true if the basic block represents the unique exit block.
-
isEntryBlock
public boolean isEntryBlock()Description copied from interface:IBasicBlockReturn true if the basic block represents the unique entry block.- Specified by:
isEntryBlockin interfaceIBasicBlock<Instruction>- Returns:
- true if the basic block represents the unique entry block.
-
getMethod
- Specified by:
getMethodin interfaceIBasicBlock<Instruction>- Returns:
- governing method for this block
-
hashCode
-
equals
-
getNumber
public int getNumber()Description copied from interface:IBasicBlockEach basic block should have a unique number in its cfg- Specified by:
getNumberin interfaceIBasicBlock<Instruction>- Returns:
- the basic block's number
-
iterator
- Specified by:
iteratorin interfaceIterable<Instruction>
-