HHH-7850 BulkAccessorFactory Java 7 verify error resolved by JASSIST-163 BulkAccessorFactory.java.diff2 patch from Shigeru Chiba.

This commit is contained in:
Scott Marlow 2012-12-10 18:43:55 -05:00
parent 598c6d3d25
commit 8463057b85
1 changed files with 18 additions and 3 deletions

View File

@ -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 );
} }