Package com.saxonica.ee.bytecode.util
Class Generator
- java.lang.Object
- 
- org.objectweb.asm.MethodVisitor
- 
- org.objectweb.asm.commons.LocalVariablesSorter
- 
- org.objectweb.asm.commons.GeneratorAdapter
- 
- com.saxonica.ee.bytecode.util.Generator
 
 
 
 
- 
 public class Generator extends org.objectweb.asm.commons.GeneratorAdapterThis class is an extension of the ASM-supplied GeneratorAdapter library, containing additional utility and shortcut methods for bytecode generation
- 
- 
Constructor SummaryConstructors Constructor Description Generator(int access, org.objectweb.asm.commons.Method method, boolean throwsXPathException, org.objectweb.asm.ClassVisitor cv)Create a code generator for a particular method
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddComment(CompilerService compiler, java.lang.String message)Add a comment (in the form of an unused label) to the code listingvoidcheckClass(java.lang.Class theClass)Generate a "checking" cast instruction, given a Class to check against.voidconcatenateStrings(int n)Generate code to concatenate a sequence of string objects.voidgetInstanceField(java.lang.Class theClass, java.lang.String fieldName)Helper method to get an instance-level field of an objectorg.objectweb.asm.TypegetLocalType(int local)Returns the type of the given local variable.voidgetStaticField(java.lang.Class theClass, java.lang.String fieldName, java.lang.Class fieldClass)Helper method to generate code that gets a static fieldvoidgoTo(LabelInfo labelInfo)Generate code to go to a LabelInfovoidifFalse(LabelInfo label)Generate code to test whether the object on top of stack is NOT an instance of a given classvoidifInstance(java.lang.Class theClass, LabelInfo label)Generate code to test whether the object on top of stack is an instance of a given classvoidifNotInstance(java.lang.Class theClass, LabelInfo label)Generate code to test whether the object on top of stack is NOT an instance of a given classvoidifNotSameObject(LabelInfo label)Generate code to test whether the two object references on top of stack refer to different objectsvoidifSameObject(LabelInfo label)Generate code to test whether the two object references on top of stack refer to the same objectvoidifTrue(LabelInfo label)Generate code to test whether the object on top of stack is the boolean truevoidinvokeConstructor(java.lang.Class<?> theClass, java.lang.Class<?>... argTypes)Helper method to generate code that invokes a constructor.voidinvokeDefaultConstructor(java.lang.Class<?> theClass)Helper method for a zero-argument constructor.voidinvokeInstanceMethod(java.lang.Class<?> theClass, java.lang.String methodName, java.lang.Class... argTypes)Helper method to generate code that invokes an instance methodvoidinvokeStaticMethod(java.lang.Class<?> theClass, java.lang.String methodName, java.lang.Class... argTypes)Helper method to generate code that invokes a static methodvoidloadArgOrLocal(int slot)Load a local variable or method argumentvoidloadLocal(int local)Generates the instruction to load the given local variable on the stack.voidnewInstance(java.lang.Class theClass)Helper method to generate code that creates a new instance of a classintnewLocal(java.lang.Class<?> theClass)Helper method to generate a local bytecode variablevoidpushNull()Push "null" onto the stackvoidshowIntVariable(CompilerService compiler, java.lang.String name, int slot)Generate code to output the value of a run-time variable (which must hold an int)voidshowLongVariable(CompilerService compiler, java.lang.String name, int slot)Generate code to output the value of a run-time variable (which must hold a long)voidshowMessage(CompilerService compiler, java.lang.String message)Generate code to output a simple diagnostic message at run-timevoidshowObject(CompilerService compiler, java.lang.String label)Generate code to output the value of of the object on the top of the bytecode stackvoidshowObjectVariable(CompilerService compiler, java.lang.String name, int slot)Generate code to output the value of a run-time bytecode variable (which must hold an object)voidstoreArgOrLocal(int slot)Generate code to store the value from top of stack into a local variable or method argument slotvoidstoreLocal(int local)Generates the instruction to store the top stack value in the given local variable.voidvisitTryCatchBlock(LabelInfo start, LabelInfo end, LabelInfo handler, java.lang.String type)Process a try/catch block- 
Methods inherited from class org.objectweb.asm.commons.GeneratorAdapterarrayLength, arrayLoad, arrayStore, box, cast, catchException, checkCast, dup, dup2, dup2X1, dup2X2, dupX1, dupX2, endMethod, getField, getStatic, goTo, ifCmp, ifICmp, ifNonNull, ifNull, ifZCmp, iinc, instanceOf, invokeConstructor, invokeDynamic, invokeInterface, invokeStatic, invokeVirtual, loadArg, loadArgArray, loadArgs, loadArgs, loadLocal, loadThis, mark, mark, math, monitorEnter, monitorExit, newArray, newInstance, newLabel, not, pop, pop2, push, push, push, push, push, push, push, push, putField, putStatic, ret, returnValue, setLocalType, storeArg, storeLocal, swap, swap, tableSwitch, tableSwitch, throwException, throwException, unbox, valueOf
 - 
Methods inherited from class org.objectweb.asm.commons.LocalVariablesSorternewLocal, newLocalMapping, updateNewLocals, visitFrame, visitIincInsn, visitLocalVariable, visitLocalVariableAnnotation, visitMaxs, visitVarInsn
 - 
Methods inherited from class org.objectweb.asm.MethodVisitorvisitAnnotation, visitAnnotationDefault, visitAttribute, visitCode, visitEnd, visitFieldInsn, visitInsn, visitInsnAnnotation, visitIntInsn, visitInvokeDynamicInsn, visitJumpInsn, visitLabel, visitLdcInsn, visitLineNumber, visitLookupSwitchInsn, visitMethodInsn, visitMethodInsn, visitMultiANewArrayInsn, visitParameter, visitParameterAnnotation, visitTableSwitchInsn, visitTryCatchAnnotation, visitTryCatchBlock, visitTypeAnnotation, visitTypeInsn
 
- 
 
- 
- 
- 
Constructor Detail- 
Generatorpublic Generator(int access, org.objectweb.asm.commons.Method method, boolean throwsXPathException, org.objectweb.asm.ClassVisitor cv)Create a code generator for a particular method- Parameters:
- access- the visibility of the method, typically PUBLIC
- method- the Method object containing details of the argument and return types
- throwsXPathException- true if the method throws XPathException on error
- cv- the class visitor for the containing class
 
 
- 
 - 
Method Detail- 
ifInstancepublic void ifInstance(java.lang.Class theClass, LabelInfo label)Generate code to test whether the object on top of stack is an instance of a given class- Parameters:
- theClass- the class to be tested
- label- the label to jump to if the current object is an instance of the class. If it is not an instance, control passes to the next instruction
 
 - 
ifNotInstancepublic void ifNotInstance(java.lang.Class theClass, LabelInfo label)Generate code to test whether the object on top of stack is NOT an instance of a given class- Parameters:
- theClass- the class to be tested
- label- the label to jump to if the current object is an instance of the class. If it is not an instance, control passes to the next instruction
 
 - 
goTopublic void goTo(LabelInfo labelInfo) Generate code to go to a LabelInfo- Parameters:
- labelInfo- the label to jump to
 
 - 
pushNullpublic void pushNull() Push "null" onto the stack
 - 
ifTruepublic void ifTrue(LabelInfo label) Generate code to test whether the object on top of stack is the boolean true- Parameters:
- label- the label to jump to if the value on top of stack is true (non-zero)
 
 - 
ifFalsepublic void ifFalse(LabelInfo label) Generate code to test whether the object on top of stack is NOT an instance of a given class- Parameters:
- label- the label to jump to if the current object is false (zero)
 
 - 
ifSameObjectpublic void ifSameObject(LabelInfo label) Generate code to test whether the two object references on top of stack refer to the same object- Parameters:
- label- the label to jump to if the two object references are equal
 
 - 
ifNotSameObjectpublic void ifNotSameObject(LabelInfo label) Generate code to test whether the two object references on top of stack refer to different objects- Parameters:
- label- the label to jump to if the two object references are different
 
 - 
checkClasspublic void checkClass(java.lang.Class theClass) Generate a "checking" cast instruction, given a Class to check against.- Parameters:
- theClass- the class to be tested
 
 - 
addCommentpublic void addComment(CompilerService compiler, java.lang.String message) Add a comment (in the form of an unused label) to the code listing- Parameters:
- compiler- the compiler service
- message- the comment to be added to the code
 
 - 
showMessagepublic void showMessage(CompilerService compiler, java.lang.String message) Generate code to output a simple diagnostic message at run-time- Parameters:
- compiler- the compiler service
- message- the message to be output at run-time
 
 - 
showObjectpublic void showObject(CompilerService compiler, java.lang.String label) Generate code to output the value of of the object on the top of the bytecode stack- Parameters:
- compiler- the compiler service
- label- a label used to prefix the message to be output at run-time
 
 - 
showObjectVariablepublic void showObjectVariable(CompilerService compiler, java.lang.String name, int slot) Generate code to output the value of a run-time bytecode variable (which must hold an object)- Parameters:
- compiler- the compiler service
- name- a label used to prefix the message to be output at run-time, typically the variable name
- slot- the slot number on the bytecode stack whose value is to be displayed
 
 - 
showLongVariablepublic void showLongVariable(CompilerService compiler, java.lang.String name, int slot) Generate code to output the value of a run-time variable (which must hold a long)- Parameters:
- compiler- the compiler service
- name- a label used to prefix the message to be output at run-time, typically the variable name
- slot- the slot number on the bytecode stack whose value is to be displayed
 
 - 
showIntVariablepublic void showIntVariable(CompilerService compiler, java.lang.String name, int slot) Generate code to output the value of a run-time variable (which must hold an int)- Parameters:
- compiler- the compiler service
- name- a label used to prefix the message to be output at run-time, typically the variable name
- slot- the slot number on the bytecode stack whose value is to be displayed
 
 - 
getStaticFieldpublic void getStaticField(java.lang.Class theClass, java.lang.String fieldName, java.lang.Class fieldClass)Helper method to generate code that gets a static field- Parameters:
- theClass- the class on which the field is defined
- fieldName- the name of the field to be fetched
- fieldClass- the class of the field to be fetched
 
 - 
invokeStaticMethodpublic void invokeStaticMethod(java.lang.Class<?> theClass, java.lang.String methodName, java.lang.Class... argTypes)Helper method to generate code that invokes a static method- Parameters:
- theClass- the class on which the method is defined
- methodName- the name of the method to be invoked
- argTypes- the classes of the arguments to the method
- Throws:
- java.lang.AssertionError- if no suitable method is defined on this class
 
 - 
invokeInstanceMethodpublic void invokeInstanceMethod(java.lang.Class<?> theClass, java.lang.String methodName, java.lang.Class... argTypes)Helper method to generate code that invokes an instance method- Parameters:
- theClass- the instance class on which the method is defined
- methodName- the name of the method to be invoked
- argTypes- the classes of the arguments to the method
- Throws:
- java.lang.AssertionError- if no suitable method is defined on this interface
 
 - 
getInstanceFieldpublic void getInstanceField(java.lang.Class theClass, java.lang.String fieldName)Helper method to get an instance-level field of an object- Parameters:
- theClass- the instance class on which the method is defined
- fieldName- the name of the field to be obtained
- Throws:
- java.lang.AssertionError- if no suitable method is defined on this interface
 
 - 
invokeDefaultConstructorpublic void invokeDefaultConstructor(java.lang.Class<?> theClass) Helper method for a zero-argument constructor. Generates code to invoke the constructor, leaving the constructed instance on the top of the bytecode stack- Parameters:
- theClass- the class of object to be constructed
 
 - 
newInstancepublic void newInstance(java.lang.Class theClass) Helper method to generate code that creates a new instance of a class- Parameters:
- theClass- the class to be instantiated
 
 - 
invokeConstructorpublic void invokeConstructor(java.lang.Class<?> theClass, java.lang.Class<?>... argTypes)Helper method to generate code that invokes a constructor. Precondition: the target of the method and all its arguments are on the stack (the target must first be created using the newInstance() instruction). Postcondition: the above items are removed from the stack- Parameters:
- theClass- the class on which the method is defined
- argTypes- the classes of the arguments to the constructor
- Throws:
- java.lang.AssertionError- if no suitable constructor is defined on this class
 
 - 
newLocalpublic int newLocal(java.lang.Class<?> theClass) Helper method to generate a local bytecode variable- Parameters:
- theClass- the class of the variable
- Returns:
- the slot number allocated to the variable
 
 - 
loadLocalpublic void loadLocal(int local) Generates the instruction to load the given local variable on the stack.- Overrides:
- loadLocalin class- org.objectweb.asm.commons.GeneratorAdapter
- Parameters:
- local- a local variable identifier, as returned by- newLocal().
 
 - 
loadArgOrLocalpublic void loadArgOrLocal(int slot) Load a local variable or method argument- Parameters:
- slot- the slot number to be loaded, which may represent either a method argument or a local variable
 
 - 
storeLocalpublic void storeLocal(int local) Generates the instruction to store the top stack value in the given local variable.- Overrides:
- storeLocalin class- org.objectweb.asm.commons.GeneratorAdapter
- Parameters:
- local- a local variable identifier, as returned by- newLocal().
 
 - 
storeArgOrLocalpublic void storeArgOrLocal(int slot) Generate code to store the value from top of stack into a local variable or method argument slot- Parameters:
- slot- the slot number to be used, which may represent either a method argument or a local variable
 
 - 
getLocalTypepublic org.objectweb.asm.Type getLocalType(int local) Returns the type of the given local variable.- Overrides:
- getLocalTypein class- org.objectweb.asm.commons.GeneratorAdapter
- Parameters:
- local- a local variable identifier, as returned by- newLocal().
- Returns:
- the type of the given local variable.
 
 - 
visitTryCatchBlockpublic void visitTryCatchBlock(LabelInfo start, LabelInfo end, LabelInfo handler, java.lang.String type) Process a try/catch block- Parameters:
- start- the label for the start of the try block
- end- the label for the end of the try block
- handler- the label for the catch block
- type- the type
 
 - 
concatenateStringspublic void concatenateStrings(int n) Generate code to concatenate a sequence of string objects. The strings must be on the stack, in order. On completion, the concatenated string is on the top of the bytecode stack- Parameters:
- n- the number of strings to be concatenated
 
 
- 
 
-