Package org.apache.bcel.generic
Class LocalVariableGen
java.lang.Object
org.apache.bcel.generic.LocalVariableGen
- All Implemented Interfaces:
- Cloneable,- InstructionTargeter,- NamedAndTyped
public class LocalVariableGen
extends Object
implements InstructionTargeter, NamedAndTyped, 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:
- 
Constructor SummaryConstructorsConstructorDescriptionLocalVariableGen(int index, String name, Type type, InstructionHandle start, InstructionHandle end) Generate a local variable that with index 'index'.LocalVariableGen(int index, String name, Type type, InstructionHandle start, InstructionHandle end, int origIndex) Generates a local variable that with index 'index'.
- 
Method SummaryModifier and TypeMethodDescriptionclone()booleanChecks whether this targeter targets the specified instruction handle.booleanWe consider to local variables to be equal, if the use the same index and are valid in the same range.getEnd()intgetIndex()booleanGets LocalVariable object.getName()intgetStart()getType()inthashCode()voidsetEnd(InstructionHandle end) voidsetIndex(int index) voidsetLiveToEnd(boolean liveToEnd) voidvoidsetStart(InstructionHandle start) voidtoString()voidupdateTarget(InstructionHandle oldIh, InstructionHandle newIh) Replaces the target of this targeter from this old handle to the new handle.
- 
Constructor Details- 
LocalVariableGenpublic LocalVariableGen(int index, 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)
 
- 
LocalVariableGenpublic LocalVariableGen(int index, 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 Details- 
clone
- 
containsTargetDescription copied from interface:InstructionTargeterChecks whether this targeter targets the specified instruction handle.- Specified by:
- containsTargetin interface- InstructionTargeter
- Returns:
- true, if ih is target of this variable
 
- 
equalsWe consider to local variables to be equal, if the use the same index and are valid in the same range.
- 
getEnd
- 
getIndex
- 
getLiveToEnd
- 
getLocalVariableGets 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
 
- 
getName- Specified by:
- getNamein interface- NamedAndTyped
 
- 
getOrigIndex
- 
getStart
- 
getType- Specified by:
- getTypein interface- NamedAndTyped
 
- 
hashCode
- 
setEnd
- 
setIndex
- 
setLiveToEnd
- 
setName- Specified by:
- setNamein interface- NamedAndTyped
 
- 
setStart
- 
setType- Specified by:
- setTypein interface- NamedAndTyped
 
- 
toString
- 
updateTargetDescription copied from interface:InstructionTargeterReplaces the target of this targeter from this old handle to the new handle.- Specified by:
- updateTargetin interface- InstructionTargeter
- Parameters:
- oldIh- old target, either start or end
- newIh- new target
 
 
-