|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Objectorg.codehaus.groovy.classgen.asm.CompileStack
public class CompileStack
This class is a helper for AsmClassGenerator. It manages different aspects of the code of a code block like handling labels, defining variables, and scopes. After a MethodNode is visited clear should be called, for initialization the method init should be used.
Some Notes:
AsmClassGenerator
Nested Class Summary | |
---|---|
static class |
CompileStack.BlockRecorder
|
protected static class |
CompileStack.LabelRange
|
Field Summary |
---|
Fields inherited from interface org.objectweb.asm.Opcodes |
---|
AALOAD, AASTORE, ACC_ABSTRACT, ACC_ANNOTATION, ACC_BRIDGE, ACC_DEPRECATED, ACC_ENUM, ACC_FINAL, ACC_INTERFACE, ACC_NATIVE, ACC_PRIVATE, ACC_PROTECTED, ACC_PUBLIC, ACC_STATIC, ACC_STRICT, ACC_SUPER, ACC_SYNCHRONIZED, ACC_SYNTHETIC, ACC_TRANSIENT, ACC_VARARGS, ACC_VOLATILE, ACONST_NULL, ALOAD, ANEWARRAY, ARETURN, ARRAYLENGTH, ASTORE, ATHROW, BALOAD, BASTORE, BIPUSH, CALOAD, CASTORE, CHECKCAST, D2F, D2I, D2L, DADD, DALOAD, DASTORE, DCMPG, DCMPL, DCONST_0, DCONST_1, DDIV, DLOAD, DMUL, DNEG, DOUBLE, DREM, DRETURN, DSTORE, DSUB, DUP, DUP_X1, DUP_X2, DUP2, DUP2_X1, DUP2_X2, F_APPEND, F_CHOP, F_FULL, F_NEW, F_SAME, F_SAME1, F2D, F2I, F2L, FADD, FALOAD, FASTORE, FCMPG, FCMPL, FCONST_0, FCONST_1, FCONST_2, FDIV, FLOAD, FLOAT, FMUL, FNEG, FREM, FRETURN, FSTORE, FSUB, GETFIELD, GETSTATIC, GOTO, I2B, I2C, I2D, I2F, I2L, I2S, IADD, IALOAD, IAND, IASTORE, ICONST_0, ICONST_1, ICONST_2, ICONST_3, ICONST_4, ICONST_5, ICONST_M1, IDIV, IF_ACMPEQ, IF_ACMPNE, IF_ICMPEQ, IF_ICMPGE, IF_ICMPGT, IF_ICMPLE, IF_ICMPLT, IF_ICMPNE, IFEQ, IFGE, IFGT, IFLE, IFLT, IFNE, IFNONNULL, IFNULL, IINC, ILOAD, IMUL, INEG, INSTANCEOF, INTEGER, INVOKEDYNAMIC, INVOKEDYNAMIC_OWNER, INVOKEINTERFACE, INVOKESPECIAL, INVOKESTATIC, INVOKEVIRTUAL, IOR, IREM, IRETURN, ISHL, ISHR, ISTORE, ISUB, IUSHR, IXOR, JSR, L2D, L2F, L2I, LADD, LALOAD, LAND, LASTORE, LCMP, LCONST_0, LCONST_1, LDC, LDIV, LLOAD, LMUL, LNEG, LONG, LOOKUPSWITCH, LOR, LREM, LRETURN, LSHL, LSHR, LSTORE, LSUB, LUSHR, LXOR, MONITORENTER, MONITOREXIT, MULTIANEWARRAY, NEW, NEWARRAY, NOP, NULL, POP, POP2, PUTFIELD, PUTSTATIC, RET, RETURN, SALOAD, SASTORE, SIPUSH, SWAP, T_BOOLEAN, T_BYTE, T_CHAR, T_DOUBLE, T_FLOAT, T_INT, T_LONG, T_SHORT, TABLESWITCH, TOP, UNINITIALIZED_THIS, V1_1, V1_2, V1_3, V1_4, V1_5, V1_6, V1_7 |
Constructor Summary | |
---|---|
CompileStack(WriterController wc)
|
Method Summary | |
---|---|
void |
addExceptionBlock(org.objectweb.asm.Label start,
org.objectweb.asm.Label end,
org.objectweb.asm.Label goal,
String sig)
|
void |
applyBlockRecorder()
|
void |
applyFinallyBlocks(org.objectweb.asm.Label label,
boolean isBreakLabel)
|
void |
clear()
Clears the state of the class. |
boolean |
containsVariable(String name)
|
org.objectweb.asm.Label |
createLocalLabel(String name)
creates a new named label |
int |
defineTemporaryVariable(String name,
boolean store)
creates a temporary variable. |
int |
defineTemporaryVariable(String name,
ClassNode node,
boolean store)
creates a temporary variable. |
int |
defineTemporaryVariable(Variable var,
boolean store)
creates a temporary variable. |
BytecodeVariable |
defineVariable(Variable v,
boolean initFromStack)
Defines a new Variable using an AST variable. |
BytecodeVariable |
defineVariable(Variable v,
ClassNode variableType,
boolean initFromStack)
|
org.objectweb.asm.Label |
getBreakLabel()
|
org.objectweb.asm.Label |
getContinueLabel()
|
org.objectweb.asm.Label |
getLabel(String name)
Returns the label for the given name |
org.objectweb.asm.Label |
getNamedBreakLabel(String name)
Used for break foo inside a loop to end the
execution of the marked loop. |
org.objectweb.asm.Label |
getNamedContinueLabel(String name)
Used for continue foo inside a loop to continue
the execution of the marked loop. |
VariableScope |
getScope()
|
BytecodeVariable |
getVariable(String variableName)
|
BytecodeVariable |
getVariable(String variableName,
boolean mustExist)
Returns a normal variable. |
boolean |
hasBlockRecorder()
|
void |
init(VariableScope el,
Parameter[] parameters)
initializes this class for a MethodNode. |
boolean |
isImplicitThis()
|
boolean |
isInSpecialConstructorCall()
|
boolean |
isLHS()
|
void |
pop()
|
void |
popBlockRecorderVisit(CompileStack.BlockRecorder finallyBlock)
|
void |
popImplicitThis()
|
void |
popLHS()
|
void |
pushBlockRecorder(CompileStack.BlockRecorder recorder)
|
void |
pushBlockRecorderVisit(CompileStack.BlockRecorder finallyBlock)
|
void |
pushBooleanExpression()
because a boolean Expression may not be evaluated completely it is important to keep the registers clean |
void |
pushImplicitThis(boolean implicitThis)
|
void |
pushInSpecialConstructorCall()
|
void |
pushLHS(boolean lhs)
|
void |
pushLoop(String labelName)
Should be called when decending into a loop that does not define a scope. |
void |
pushLoop(VariableScope el,
String labelName)
Should be called when decending into a loop that defines also a scope. |
void |
pushState()
|
org.objectweb.asm.Label |
pushSwitch()
Creates a new break label and a element for the state stack so pop has to be called later |
void |
pushVariableScope(VariableScope el)
Causes the statestack to add an element and sets the given scope as new current variable scope. |
void |
removeVar(int tempIndex)
|
void |
writeExceptionTable(CompileStack.BlockRecorder block,
org.objectweb.asm.Label goal,
String sig)
|
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Constructor Detail |
---|
public CompileStack(WriterController wc)
Method Detail |
---|
public void pushState()
public org.objectweb.asm.Label getContinueLabel()
public org.objectweb.asm.Label getBreakLabel()
public void removeVar(int tempIndex)
public void pop()
public VariableScope getScope()
public int defineTemporaryVariable(Variable var, boolean store)
var
- defines type and namestore
- defines if the toplevel argument of the stack should be stored
public BytecodeVariable getVariable(String variableName)
public BytecodeVariable getVariable(String variableName, boolean mustExist)
mustExist
is true and the normal variable doesn't exist,
then this method will throw a GroovyBugError. It is not the intention of
this method to let this happen! And the exception should not be used for
flow control - it is just acting as an assertion. If the exception is thrown
then it indicates a bug in the class using CompileStack.
This method can also not be used to return a temporary variable.
Temporary variables are not normal variables.
variableName
- name of the variablemustExist
- throw exception if variable does not exist
mustExist
not true)public int defineTemporaryVariable(String name, boolean store)
name
- defines type and namestore
- defines if the toplevel argument of the stack should be stored
public int defineTemporaryVariable(String name, ClassNode node, boolean store)
name
- defines the namenode
- defines the nodestore
- defines if the toplevel argument of the stack should be stored
public void clear()
public void addExceptionBlock(org.objectweb.asm.Label start, org.objectweb.asm.Label end, org.objectweb.asm.Label goal, String sig)
public void init(VariableScope el, Parameter[] parameters)
public void pushVariableScope(VariableScope el)
public void pushLoop(VariableScope el, String labelName)
public void pushLoop(String labelName)
public org.objectweb.asm.Label getNamedBreakLabel(String name)
break foo
inside a loop to end the
execution of the marked loop. This method will return the
break label of the loop if there is one found for the name.
If not, the current break label is returned.
public org.objectweb.asm.Label getNamedContinueLabel(String name)
continue foo
inside a loop to continue
the execution of the marked loop. This method will return
the break label of the loop if there is one found for the
name. If not, getLabel is used.
public org.objectweb.asm.Label pushSwitch()
public void pushBooleanExpression()
public BytecodeVariable defineVariable(Variable v, boolean initFromStack)
initFromStack
- if true the last element of the
stack will be used to initialize
the new variable. If false null
will be used.public BytecodeVariable defineVariable(Variable v, ClassNode variableType, boolean initFromStack)
public boolean containsVariable(String name)
name
- the name of the variable of interest
public org.objectweb.asm.Label getLabel(String name)
public org.objectweb.asm.Label createLocalLabel(String name)
public void applyFinallyBlocks(org.objectweb.asm.Label label, boolean isBreakLabel)
public void applyBlockRecorder()
public boolean hasBlockRecorder()
public void pushBlockRecorder(CompileStack.BlockRecorder recorder)
public void pushBlockRecorderVisit(CompileStack.BlockRecorder finallyBlock)
public void popBlockRecorderVisit(CompileStack.BlockRecorder finallyBlock)
public void writeExceptionTable(CompileStack.BlockRecorder block, org.objectweb.asm.Label goal, String sig)
public boolean isLHS()
public void pushLHS(boolean lhs)
public void popLHS()
public void pushImplicitThis(boolean implicitThis)
public boolean isImplicitThis()
public void popImplicitThis()
public boolean isInSpecialConstructorCall()
public void pushInSpecialConstructorCall()
|
Copyright © 2003-2012 The Codehaus. All rights reserved. | ||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |