Package org.apache.bcel.generic
Class LocalVariableGen
- java.lang.Object
-
- org.apache.bcel.generic.LocalVariableGen
-
- All Implemented Interfaces:
java.lang.Cloneable,InstructionTargeter,NamedAndTyped
public class LocalVariableGen extends java.lang.Object implements InstructionTargeter, NamedAndTyped, java.lang.Cloneable
Represents a local variable within a method. It contains its scope, name and type. The generated LocalVariable object can be obtained with getLocalVariable which needs the instruction list and the constant pool as parameters.- See Also:
LocalVariable,MethodGen
-
-
Field Summary
Fields Modifier and Type Field Description private InstructionHandleendprivate intindexprivate booleanliveToEndprivate java.lang.Stringnameprivate intorigIndexprivate InstructionHandlestartprivate Typetype
-
Constructor Summary
Constructors Constructor Description LocalVariableGen(int index, java.lang.String name, Type type, InstructionHandle start, InstructionHandle end)Generate a local variable that with index 'index'.LocalVariableGen(int index, java.lang.String name, Type type, InstructionHandle start, InstructionHandle end, int origIndex)Generates a local variable that with index 'index'.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description java.lang.Objectclone()booleancontainsTarget(InstructionHandle ih)Tests whether this targeter targets the specified instruction handle.(package private) voiddispose()Clear the references from and to this variable when it's removed.booleanequals(java.lang.Object o)We consider to local variables to be equal, if the use the same index and are valid in the same range.InstructionHandlegetEnd()Gets the end instruction handle.intgetIndex()Gets the index.booleangetLiveToEnd()Gets whether the variable lives to the end.LocalVariablegetLocalVariable(ConstantPoolGen cp)Gets LocalVariable object.java.lang.StringgetName()Gets the name.intgetOrigIndex()Gets the original index.InstructionHandlegetStart()Gets the start instruction handle.TypegetType()Gets the type.inthashCode()voidsetEnd(InstructionHandle end)Sets the end instruction handle.voidsetIndex(int index)Sets the index.voidsetLiveToEnd(boolean liveToEnd)Sets whether the variable lives to the end.voidsetName(java.lang.String name)Sets the name.voidsetStart(InstructionHandle start)Sets the start instruction handle.voidsetType(Type type)Sets the type.java.lang.StringtoString()voidupdateTarget(InstructionHandle oldIh, InstructionHandle newIh)Replaces the target of this targeter from this old handle to the new handle.
-
-
-
Field Detail
-
index
private int index
-
name
private java.lang.String name
-
type
private Type type
-
start
private InstructionHandle start
-
end
private InstructionHandle end
-
origIndex
private int origIndex
-
liveToEnd
private boolean liveToEnd
-
-
Constructor Detail
-
LocalVariableGen
public LocalVariableGen(int index, java.lang.String name, Type type, InstructionHandle start, InstructionHandle end)Generate a local variable that with index 'index'. Note that double and long variables need two indexs. Index indices have to be provided by the user.- Parameters:
index- index of local variable.name- its name.type- its type.start- from where the instruction is valid (null means from the start).end- until where the instruction is valid (null means to the end).
-
LocalVariableGen
public LocalVariableGen(int index, java.lang.String name, Type type, InstructionHandle start, InstructionHandle end, int origIndex)Generates a local variable that with index 'index'. Note that double and long variables need two indexs. Index indices have to be provided by the user.- Parameters:
index- index of local variable.name- its name.type- its type.start- from where the instruction is valid (null means from the start).end- until where the instruction is valid (null means to the end).origIndex- index of local variable prior to any changes to index.
-
-
Method Detail
-
clone
public java.lang.Object clone()
- Overrides:
clonein classjava.lang.Object
-
containsTarget
public boolean containsTarget(InstructionHandle ih)
Description copied from interface:InstructionTargeterTests whether this targeter targets the specified instruction handle.- Specified by:
containsTargetin interfaceInstructionTargeter- Parameters:
ih- the instruction handle to test.- Returns:
- true, if ih is target of this variable.
-
dispose
void dispose()
Clear the references from and to this variable when it's removed.
-
equals
public boolean equals(java.lang.Object o)
We consider to local variables to be equal, if the use the same index and are valid in the same range.- Overrides:
equalsin classjava.lang.Object
-
getEnd
public InstructionHandle getEnd()
Gets the end instruction handle.- Returns:
- the end instruction handle.
-
getIndex
public int getIndex()
Gets the index.- Returns:
- the index.
-
getLiveToEnd
public boolean getLiveToEnd()
Gets whether the variable lives to the end.- Returns:
- true if the variable lives to the end.
-
getLocalVariable
public LocalVariable getLocalVariable(ConstantPoolGen cp)
Gets LocalVariable object. This relies on that the instruction list has already been dumped to byte code or that the 'setPositions' methods has been called for the instruction list. Note that due to the conversion from byte code offset to InstructionHandle, it is impossible to tell the difference between a live range that ends BEFORE the last insturction of the method or a live range that ends AFTER the last instruction of the method. Hence the liveToEnd flag to differentiate between these two cases.- Parameters:
cp- constant pool.- Returns:
- the local variable.
-
getName
public java.lang.String getName()
Description copied from interface:NamedAndTypedGets the name.- Specified by:
getNamein interfaceNamedAndTyped- Returns:
- the name.
-
getOrigIndex
public int getOrigIndex()
Gets the original index.- Returns:
- the original index.
-
getStart
public InstructionHandle getStart()
Gets the start instruction handle.- Returns:
- the start instruction handle.
-
getType
public Type getType()
Description copied from interface:NamedAndTypedGets the type.- Specified by:
getTypein interfaceNamedAndTyped- Returns:
- the type.
-
hashCode
public int hashCode()
- Overrides:
hashCodein classjava.lang.Object
-
setEnd
public void setEnd(InstructionHandle end)
Sets the end instruction handle.- Parameters:
end- the end instruction handle.
-
setIndex
public void setIndex(int index)
Sets the index.- Parameters:
index- the index.
-
setLiveToEnd
public void setLiveToEnd(boolean liveToEnd)
Sets whether the variable lives to the end.- Parameters:
liveToEnd- true if the variable lives to the end.
-
setName
public void setName(java.lang.String name)
Description copied from interface:NamedAndTypedSets the name.- Specified by:
setNamein interfaceNamedAndTyped- Parameters:
name- the name.
-
setStart
public void setStart(InstructionHandle start)
Sets the start instruction handle.- Parameters:
start- the start instruction handle.
-
setType
public void setType(Type type)
Description copied from interface:NamedAndTypedSets the type.- Specified by:
setTypein interfaceNamedAndTyped- Parameters:
type- the type.
-
toString
public java.lang.String toString()
- Overrides:
toStringin classjava.lang.Object
-
updateTarget
public void updateTarget(InstructionHandle oldIh, InstructionHandle newIh)
Description copied from interface:InstructionTargeterReplaces the target of this targeter from this old handle to the new handle.- Specified by:
updateTargetin interfaceInstructionTargeter- Parameters:
oldIh- old target, either start or end.newIh- new target.
-
-