Package serp.bytecode
Class WideInstruction
- java.lang.Object
-
- serp.bytecode.CodeEntry
-
- serp.bytecode.Instruction
-
- serp.bytecode.TypedInstruction
-
- serp.bytecode.LocalVariableInstruction
-
- serp.bytecode.WideInstruction
-
- All Implemented Interfaces:
BCEntity,VisitAcceptor
public class WideInstruction extends LocalVariableInstruction
Thewideinstruction, which is used to allow other instructions to index values beyond what they can normally index baed on the length of their arguments.
-
-
Constructor Summary
Constructors Constructor Description WideInstruction(Code owner)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidacceptVisit(BCVisitor visit)Accept a visit from aBCVisitor, calling the appropriate methods to notify the visitor that it has entered this entity, and to provide it with the proper callbacks for each sub-entity owned by this one.WideInstructionaload()Set the type of instruction this wide instruction modifies.WideInstructionastore()Set the type of instruction this wide instruction modifies.WideInstructiondload()Set the type of instruction this wide instruction modifies.WideInstructiondstore()Set the type of instruction this wide instruction modifies.booleanequalsInstruction(Instruction other)WideInstructions are equal if the instruction they augment is the same or unset.WideInstructionfload()Set the type of instruction this wide instruction modifies.WideInstructionfstore()Set the type of instruction this wide instruction modifies.intgetIncrement()Return the increment for this instruction if it augments IINC, or -1 if unset.intgetInstruction()Return the opcode of the instruction to modify; this will return one of the constants defined inConstants.(package private) intgetLength()Return the length in bytes of this opcode, including all arguments.intgetLogicalStackChange()Return the logical number of stack positions changed by this instruction.intgetStackChange()Return the number of stack positions this instruction pushes or pops during its execution.java.lang.StringgetTypeName()Return the type name for this instruction.WideInstructioniinc()Set the type of instruction this wide instruction modifies.WideInstructioniload()Set the type of instruction this wide instruction modifies.WideInstructionistore()Set the type of instruction this wide instruction modifies.WideInstructionlload()Set the type of instruction this wide instruction modifies.WideInstructionlstore()Set the type of instruction this wide instruction modifies.(package private) voidread(java.io.DataInput in)Read the arguments for this opcode from the given stream.(package private) voidread(Instruction orig)Copy the given instruction data.WideInstructionret()Set the type of instruction this wide instruction modifies.WideInstructionsetIncrement(int val)Set the increment on this instruction if it augments IINC.WideInstructionsetInstruction(int opcode)Set the type of instruction this wide instruction modifies.WideInstructionsetInstruction(Instruction ins)Set the type of instruction this wide instruction modifies.TypedInstructionsetType(java.lang.String type)Set the type of this instruction.(package private) voidwrite(java.io.DataOutput out)Write the arguments for this opcode to the given stream.-
Methods inherited from class serp.bytecode.LocalVariableInstruction
calculateLocal, calculateOpcode, getLocal, getLocalVariable, getParam, setLocal, setLocalVariable, setParam
-
Methods inherited from class serp.bytecode.TypedInstruction
getType, getTypeBC, mapType, setType, setType
-
Methods inherited from class serp.bytecode.Instruction
getByteIndex, getClassLoader, getCode, getLineNumber, getName, getOpcode, getPool, getProject, invalidate, invalidateByteIndexes, isValid, setOpcode
-
-
-
-
Constructor Detail
-
WideInstruction
WideInstruction(Code owner)
-
-
Method Detail
-
getLength
int getLength()
Description copied from class:InstructionReturn the length in bytes of this opcode, including all arguments. For many opcodes this method relies on an up-to-date byte index.- Overrides:
getLengthin classInstruction
-
getStackChange
public int getStackChange()
Description copied from class:InstructionReturn the number of stack positions this instruction pushes or pops during its execution.- Overrides:
getStackChangein classInstruction- Returns:
- 0 if the stack is not affected by this instruction, a positive number if it pushes onto the stack, and a negative number if it pops from the stack
-
getLogicalStackChange
public int getLogicalStackChange()
Description copied from class:InstructionReturn the logical number of stack positions changed by this instruction. In other words, ignore weirdness with longs and doubles taking two stack positions.- Overrides:
getLogicalStackChangein classInstruction
-
getTypeName
public java.lang.String getTypeName()
Description copied from class:TypedInstructionReturn the type name for this instruction. If the type has not been set, this method will return null.- Overrides:
getTypeNamein classLocalVariableInstruction
-
setType
public TypedInstruction setType(java.lang.String type)
Description copied from class:TypedInstructionSet the type of this instruction. Types that have no direct support will be converted accordingly.- Overrides:
setTypein classLocalVariableInstruction- Returns:
- this instruction, for method chaining
-
getInstruction
public int getInstruction()
Return the opcode of the instruction to modify; this will return one of the constants defined inConstants.
-
setInstruction
public WideInstruction setInstruction(Instruction ins)
Set the type of instruction this wide instruction modifies.
-
setInstruction
public WideInstruction setInstruction(int opcode)
Set the type of instruction this wide instruction modifies.
-
iinc
public WideInstruction iinc()
Set the type of instruction this wide instruction modifies.- Returns:
- this instruction, for method chaining
-
ret
public WideInstruction ret()
Set the type of instruction this wide instruction modifies.- Returns:
- this instruction, for method chaining
-
iload
public WideInstruction iload()
Set the type of instruction this wide instruction modifies.- Returns:
- this instruction, for method chaining
-
fload
public WideInstruction fload()
Set the type of instruction this wide instruction modifies.- Returns:
- this instruction, for method chaining
-
aload
public WideInstruction aload()
Set the type of instruction this wide instruction modifies.- Returns:
- this instruction, for method chaining
-
lload
public WideInstruction lload()
Set the type of instruction this wide instruction modifies.- Returns:
- this instruction, for method chaining
-
dload
public WideInstruction dload()
Set the type of instruction this wide instruction modifies.- Returns:
- this instruction, for method chaining
-
istore
public WideInstruction istore()
Set the type of instruction this wide instruction modifies.- Returns:
- this instruction, for method chaining
-
fstore
public WideInstruction fstore()
Set the type of instruction this wide instruction modifies.- Returns:
- this instruction, for method chaining
-
astore
public WideInstruction astore()
Set the type of instruction this wide instruction modifies.- Returns:
- this instruction, for method chaining
-
lstore
public WideInstruction lstore()
Set the type of instruction this wide instruction modifies.- Returns:
- this instruction, for method chaining
-
dstore
public WideInstruction dstore()
Set the type of instruction this wide instruction modifies.- Returns:
- this instruction, for method chaining
-
getIncrement
public int getIncrement()
Return the increment for this instruction if it augments IINC, or -1 if unset.
-
setIncrement
public WideInstruction setIncrement(int val)
Set the increment on this instruction if it augments IINC.- Returns:
- this Instruction, for method chaining
-
equalsInstruction
public boolean equalsInstruction(Instruction other)
WideInstructions are equal if the instruction they augment is the same or unset.- Overrides:
equalsInstructionin classLocalVariableInstruction
-
acceptVisit
public void acceptVisit(BCVisitor visit)
Description copied from interface:VisitAcceptorAccept a visit from aBCVisitor, calling the appropriate methods to notify the visitor that it has entered this entity, and to provide it with the proper callbacks for each sub-entity owned by this one.- Specified by:
acceptVisitin interfaceVisitAcceptor- Overrides:
acceptVisitin classInstruction
-
read
void read(Instruction orig)
Description copied from class:InstructionCopy the given instruction data.- Overrides:
readin classLocalVariableInstruction
-
read
void read(java.io.DataInput in) throws java.io.IOException
Description copied from class:InstructionRead the arguments for this opcode from the given stream. This method should be overridden by opcodes that take arguments.- Overrides:
readin classInstruction- Throws:
java.io.IOException
-
write
void write(java.io.DataOutput out) throws java.io.IOExceptionDescription copied from class:InstructionWrite the arguments for this opcode to the given stream. This method should be overridden by opcodes that take arguments.- Overrides:
writein classInstruction- Throws:
java.io.IOException
-
-