public abstract class SSACheckCastInstruction extends SSAInstruction
Note that this instruction generalizes the meaning of checkcast in Java since it supports multiple types for which to check. The meaning is that the case succeeds if the object is of any of the desired types.
SSAInstruction.IVisitor, SSAInstruction.VisitorNO_INDEX| Modifier | Constructor and Description |
|---|---|
protected |
SSACheckCastInstruction(int iindex,
int result,
int val,
TypeReference[] types,
boolean isPEI) |
| Modifier and Type | Method and Description |
|---|---|
SSAInstruction |
copyForSSA(SSAInstructionFactory insts,
int[] defs,
int[] uses)
This method is meant to be used during SSA conversion for an IR that is not in SSA form.
|
TypeReference |
getDeclaredResultType()
Deprecated.
the system now supports multiple types, so this accessor will not work for all
languages.
|
TypeReference[] |
getDeclaredResultTypes() |
int |
getDef() |
int |
getDef(int i)
Return the ith def
|
int |
getNumberOfDefs() |
int |
getNumberOfUses() |
int |
getResult() |
int |
getUse(int j) |
int |
getVal() |
boolean |
hasDef()
Does this instruction define a normal value, as distinct from a set of exceptions possibly
thrown by it (e.g.
|
int |
hashCode() |
boolean |
isFallThrough() |
boolean |
isPEI() |
java.lang.String |
toString() |
java.lang.String |
toString(SymbolTable symbolTable) |
void |
visit(SSAInstruction.IVisitor v)
Apply an IVisitor to this instruction.
|
equals, getExceptionTypes, getValueString, iIndex, setInstructionIndexprotected SSACheckCastInstruction(int iindex,
int result,
int val,
TypeReference[] types,
boolean isPEI)
result - A new value number def'fed by this instruction when the type check succeeds.val - The value being checked by this instructiontypes - The types which this instruction checkspublic SSAInstruction copyForSSA(SSAInstructionFactory insts, int[] defs, int[] uses)
SSAInstructionIn particular, if the 'defs' parameter is null, then the new instruction has the same defs as the receiver. If 'defs' is not null, it must be an array with a size equal to the number of defs that the receiver instruction has. In this case, the new instruction has defs taken from the array. The uses of the new instruction work in the same way with the 'uses' parameter.
Note that this only applies to CAst-based IR translation, since Java bytecode-based IR generation uses a different SSA construction mechanism.
TODO: move this into the SSAInstructionFactory
copyForSSA in class SSAInstructionpublic java.lang.String toString(SymbolTable symbolTable)
toString in class SSAInstructionpublic void visit(SSAInstruction.IVisitor v)
SSAInstructionvisit in class SSAInstructionpublic boolean hasDef()
SSAInstructionhasDef in class SSAInstructionpublic int getDef()
getDef in class SSAInstructionpublic int getDef(int i)
SSAInstructiongetDef in class SSAInstructioni - number of the def, starting at 0.public int getNumberOfDefs()
getNumberOfDefs in class SSAInstructionpublic int getNumberOfUses()
getNumberOfUses in class SSAInstructionpublic int getUse(int j)
getUse in class SSAInstruction@Deprecated public TypeReference getDeclaredResultType()
public TypeReference[] getDeclaredResultTypes()
public int getResult()
public int getVal()
public int hashCode()
hashCode in class SSAInstructionpublic boolean isPEI()
isPEI in class SSAInstructionpublic boolean isFallThrough()
isFallThrough in class SSAInstructionpublic java.lang.String toString()
toString in class SSAInstruction