HHH-7850 BulkAccessorFactory Java 7 verify error resolved by JASSIST-163 BulkAccessorFactory.java.diff2 patch from Shigeru Chiba.
This commit is contained in:
parent
598c6d3d25
commit
8463057b85
|
@ -31,9 +31,11 @@ import javassist.CannotCompileException;
|
||||||
import javassist.bytecode.AccessFlag;
|
import javassist.bytecode.AccessFlag;
|
||||||
import javassist.bytecode.Bytecode;
|
import javassist.bytecode.Bytecode;
|
||||||
import javassist.bytecode.ClassFile;
|
import javassist.bytecode.ClassFile;
|
||||||
|
import javassist.bytecode.CodeAttribute;
|
||||||
import javassist.bytecode.ConstPool;
|
import javassist.bytecode.ConstPool;
|
||||||
import javassist.bytecode.MethodInfo;
|
import javassist.bytecode.MethodInfo;
|
||||||
import javassist.bytecode.Opcode;
|
import javassist.bytecode.Opcode;
|
||||||
|
import javassist.bytecode.StackMapTable;
|
||||||
import javassist.util.proxy.FactoryHelper;
|
import javassist.util.proxy.FactoryHelper;
|
||||||
import javassist.util.proxy.RuntimeSupport;
|
import javassist.util.proxy.RuntimeSupport;
|
||||||
|
|
||||||
|
@ -244,6 +246,7 @@ class BulkAccessorFactory {
|
||||||
MethodInfo mi = new MethodInfo( cp, GENERATED_SETTER_NAME, desc );
|
MethodInfo mi = new MethodInfo( cp, GENERATED_SETTER_NAME, desc );
|
||||||
|
|
||||||
Bytecode code = new Bytecode( cp, 4, 6 );
|
Bytecode code = new Bytecode( cp, 4, 6 );
|
||||||
|
StackMapTable stackmap = null;
|
||||||
/* | this | bean | args | i | raw bean | exception | */
|
/* | this | bean | args | i | raw bean | exception | */
|
||||||
if ( setters.length > 0 ) {
|
if ( setters.length > 0 ) {
|
||||||
int start, end; // required to exception table
|
int start, end; // required to exception table
|
||||||
|
@ -321,7 +324,8 @@ class BulkAccessorFactory {
|
||||||
/* current stack len = 0 */
|
/* current stack len = 0 */
|
||||||
// register in exception table
|
// register in exception table
|
||||||
int throwableType_index = cp.addClassInfo( THROWABLE_CLASS_NAME );
|
int throwableType_index = cp.addClassInfo( THROWABLE_CLASS_NAME );
|
||||||
code.addExceptionHandler( start, end, code.currentPc(), throwableType_index );
|
int handler_pc = code.currentPc();
|
||||||
|
code.addExceptionHandler( start, end, handler_pc, throwableType_index );
|
||||||
// astore 5 // store exception
|
// astore 5 // store exception
|
||||||
code.addAstore( 5 );
|
code.addAstore( 5 );
|
||||||
// new // BulkAccessorException
|
// new // BulkAccessorException
|
||||||
|
@ -337,13 +341,24 @@ class BulkAccessorFactory {
|
||||||
code.addInvokespecial( BULKEXCEPTION_CLASS_NAME, MethodInfo.nameInit, cons_desc );
|
code.addInvokespecial( BULKEXCEPTION_CLASS_NAME, MethodInfo.nameInit, cons_desc );
|
||||||
// athrow
|
// athrow
|
||||||
code.addOpcode( Opcode.ATHROW );
|
code.addOpcode( Opcode.ATHROW );
|
||||||
|
StackMapTable.Writer writer = new StackMapTable.Writer(32);
|
||||||
|
int[] localTags = { StackMapTable.OBJECT, StackMapTable.OBJECT, StackMapTable.OBJECT, StackMapTable.INTEGER };
|
||||||
|
int[] localData = { cp.getThisClassInfo(), cp.addClassInfo("java/lang/Object"),
|
||||||
|
cp.addClassInfo("[Ljava/lang/Object;"), 0};
|
||||||
|
int[] stackTags = { StackMapTable.OBJECT };
|
||||||
|
int[] stackData = { throwableType_index };
|
||||||
|
writer.fullFrame(handler_pc, localTags, localData, stackTags, stackData);
|
||||||
|
stackmap = writer.toStackMapTable(cp);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
// return
|
// return
|
||||||
code.addOpcode( Opcode.RETURN );
|
code.addOpcode( Opcode.RETURN );
|
||||||
}
|
}
|
||||||
|
CodeAttribute ca = code.toCodeAttribute();
|
||||||
mi.setCodeAttribute( code.toCodeAttribute() );
|
if (stackmap != null) {
|
||||||
|
ca.setAttribute(stackmap);
|
||||||
|
}
|
||||||
|
mi.setCodeAttribute( ca );
|
||||||
mi.setAccessFlags( AccessFlag.PUBLIC );
|
mi.setAccessFlags( AccessFlag.PUBLIC );
|
||||||
classfile.addMethod( mi );
|
classfile.addMethod( mi );
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue