public class org.hibernate.resource.transaction.backend.jta.internal.DdlTransactionIsolatorJtaImpl implements org.hibernate.resource.transaction.spi.DdlTransactionIsolator
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: org.hibernate.resource.transaction.backend.jta.internal.DdlTransactionIsolatorJtaImpl
super_class: java.lang.Object
{
private static final org.jboss.logging.Logger log;
descriptor: Lorg/jboss/logging/Logger;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
private final org.hibernate.tool.schema.internal.exec.JdbcContext jdbcContext;
descriptor: Lorg/hibernate/tool/schema/internal/exec/JdbcContext;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private javax.transaction.Transaction suspendedTransaction;
descriptor: Ljavax/transaction/Transaction;
flags: (0x0002) ACC_PRIVATE
private java.sql.Connection jdbcConnection;
descriptor: Ljava/sql/Connection;
flags: (0x0002) ACC_PRIVATE
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=1, locals=0, args_size=0
0: ldc Lorg/hibernate/resource/transaction/backend/jta/internal/DdlTransactionIsolatorJtaImpl;
invokestatic org.jboss.logging.Logger.getLogger:(Ljava/lang/Class;)Lorg/jboss/logging/Logger;
putstatic org.hibernate.resource.transaction.backend.jta.internal.DdlTransactionIsolatorJtaImpl.log:Lorg/jboss/logging/Logger;
return
LocalVariableTable:
Start End Slot Name Signature
public void <init>(org.hibernate.tool.schema.internal.exec.JdbcContext);
descriptor: (Lorg/hibernate/tool/schema/internal/exec/JdbcContext;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=4, args_size=2
start local 0 start local 1 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
aload 1
putfield org.hibernate.resource.transaction.backend.jta.internal.DdlTransactionIsolatorJtaImpl.jdbcContext:Lorg/hibernate/tool/schema/internal/exec/JdbcContext;
2: aload 1
invokeinterface org.hibernate.tool.schema.internal.exec.JdbcContext.getServiceRegistry:()Lorg/hibernate/service/ServiceRegistry;
ldc Lorg/hibernate/engine/transaction/jta/platform/spi/JtaPlatform;
invokeinterface org.hibernate.service.ServiceRegistry.getService:(Ljava/lang/Class;)Lorg/hibernate/service/Service;
checkcast org.hibernate.engine.transaction.jta.platform.spi.JtaPlatform
astore 2
start local 2 3: getstatic org.hibernate.resource.transaction.backend.jta.internal.DdlTransactionIsolatorJtaImpl.log:Lorg/jboss/logging/Logger;
ldc "DdlTransactionIsolatorJtaImpl#prepare: JtaPlatform -> %s"
aload 2
invokevirtual org.jboss.logging.Logger.tracef:(Ljava/lang/String;Ljava/lang/Object;)V
4: aload 2
invokeinterface org.hibernate.engine.transaction.jta.platform.spi.JtaPlatform.retrieveTransactionManager:()Ljavax/transaction/TransactionManager;
astore 3
start local 3 5: aload 3
ifnonnull 11
6: new org.hibernate.HibernateException
dup
7: new java.lang.StringBuilder
dup
ldc "DdlTransactionIsolatorJtaImpl could not locate TransactionManager to suspend any current transaction; base JtaPlatform impl ("
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
8: aload 2
invokevirtual java.lang.Object.toString:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc ")?"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
9: invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
10: invokespecial org.hibernate.HibernateException.<init>:(Ljava/lang/String;)V
athrow
11: StackMap locals: org.hibernate.resource.transaction.backend.jta.internal.DdlTransactionIsolatorJtaImpl org.hibernate.tool.schema.internal.exec.JdbcContext org.hibernate.engine.transaction.jta.platform.spi.JtaPlatform javax.transaction.TransactionManager
StackMap stack:
getstatic org.hibernate.resource.transaction.backend.jta.internal.DdlTransactionIsolatorJtaImpl.log:Lorg/jboss/logging/Logger;
ldc "DdlTransactionIsolatorJtaImpl#prepare: TransactionManager -> %s"
aload 3
invokevirtual org.jboss.logging.Logger.tracef:(Ljava/lang/String;Ljava/lang/Object;)V
12: aload 0
aload 3
invokeinterface javax.transaction.TransactionManager.suspend:()Ljavax/transaction/Transaction;
putfield org.hibernate.resource.transaction.backend.jta.internal.DdlTransactionIsolatorJtaImpl.suspendedTransaction:Ljavax/transaction/Transaction;
13: getstatic org.hibernate.resource.transaction.backend.jta.internal.DdlTransactionIsolatorJtaImpl.log:Lorg/jboss/logging/Logger;
ldc "DdlTransactionIsolatorJtaImpl#prepare: suspended Transaction -> %s"
aload 0
getfield org.hibernate.resource.transaction.backend.jta.internal.DdlTransactionIsolatorJtaImpl.suspendedTransaction:Ljavax/transaction/Transaction;
invokevirtual org.jboss.logging.Logger.tracef:(Ljava/lang/String;Ljava/lang/Object;)V
end local 3 end local 2 14: goto 17
15: StackMap locals: org.hibernate.resource.transaction.backend.jta.internal.DdlTransactionIsolatorJtaImpl org.hibernate.tool.schema.internal.exec.JdbcContext
StackMap stack: javax.transaction.SystemException
pop
16: new org.hibernate.HibernateException
dup
ldc "Unable to suspend current JTA transaction in preparation for DDL execution"
invokespecial org.hibernate.HibernateException.<init>:(Ljava/lang/String;)V
athrow
17: StackMap locals:
StackMap stack:
aload 0
aload 1
invokeinterface org.hibernate.tool.schema.internal.exec.JdbcContext.getJdbcConnectionAccess:()Lorg/hibernate/engine/jdbc/connections/spi/JdbcConnectionAccess;
invokeinterface org.hibernate.engine.jdbc.connections.spi.JdbcConnectionAccess.obtainConnection:()Ljava/sql/Connection;
putfield org.hibernate.resource.transaction.backend.jta.internal.DdlTransactionIsolatorJtaImpl.jdbcConnection:Ljava/sql/Connection;
18: goto 21
19: StackMap locals:
StackMap stack: java.sql.SQLException
astore 2
start local 2 20: aload 1
invokeinterface org.hibernate.tool.schema.internal.exec.JdbcContext.getSqlExceptionHelper:()Lorg/hibernate/engine/jdbc/spi/SqlExceptionHelper;
aload 2
ldc "Unable to open JDBC Connection for DDL execution"
invokevirtual org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert:(Ljava/sql/SQLException;Ljava/lang/String;)Lorg/hibernate/JDBCException;
athrow
end local 2 21: StackMap locals:
StackMap stack:
aload 0
getfield org.hibernate.resource.transaction.backend.jta.internal.DdlTransactionIsolatorJtaImpl.jdbcConnection:Ljava/sql/Connection;
iconst_1
invokeinterface java.sql.Connection.setAutoCommit:(Z)V
22: goto 25
23: StackMap locals:
StackMap stack: java.sql.SQLException
astore 2
start local 2 24: aload 1
invokeinterface org.hibernate.tool.schema.internal.exec.JdbcContext.getSqlExceptionHelper:()Lorg/hibernate/engine/jdbc/spi/SqlExceptionHelper;
aload 2
ldc "Unable set JDBC Connection for DDL execution to autocommit"
invokevirtual org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert:(Ljava/sql/SQLException;Ljava/lang/String;)Lorg/hibernate/JDBCException;
athrow
end local 2 25: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 26 0 this Lorg/hibernate/resource/transaction/backend/jta/internal/DdlTransactionIsolatorJtaImpl;
0 26 1 jdbcContext Lorg/hibernate/tool/schema/internal/exec/JdbcContext;
3 14 2 jtaPlatform Lorg/hibernate/engine/transaction/jta/platform/spi/JtaPlatform;
5 14 3 tm Ljavax/transaction/TransactionManager;
20 21 2 e Ljava/sql/SQLException;
24 25 2 e Ljava/sql/SQLException;
Exception table:
from to target type
2 14 15 Class javax.transaction.SystemException
17 18 19 Class java.sql.SQLException
21 22 23 Class java.sql.SQLException
MethodParameters:
Name Flags
jdbcContext
public org.hibernate.tool.schema.internal.exec.JdbcContext getJdbcContext();
descriptor: ()Lorg/hibernate/tool/schema/internal/exec/JdbcContext;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.hibernate.resource.transaction.backend.jta.internal.DdlTransactionIsolatorJtaImpl.jdbcContext:Lorg/hibernate/tool/schema/internal/exec/JdbcContext;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/hibernate/resource/transaction/backend/jta/internal/DdlTransactionIsolatorJtaImpl;
public void prepare();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=0, locals=1, args_size=1
start local 0 0: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/hibernate/resource/transaction/backend/jta/internal/DdlTransactionIsolatorJtaImpl;
public java.sql.Connection getIsolatedConnection();
descriptor: ()Ljava/sql/Connection;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.hibernate.resource.transaction.backend.jta.internal.DdlTransactionIsolatorJtaImpl.jdbcConnection:Ljava/sql/Connection;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/hibernate/resource/transaction/backend/jta/internal/DdlTransactionIsolatorJtaImpl;
public void release();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=2, args_size=1
start local 0 0: aload 0
getfield org.hibernate.resource.transaction.backend.jta.internal.DdlTransactionIsolatorJtaImpl.jdbcConnection:Ljava/sql/Connection;
ifnull 5
1: aload 0
getfield org.hibernate.resource.transaction.backend.jta.internal.DdlTransactionIsolatorJtaImpl.jdbcContext:Lorg/hibernate/tool/schema/internal/exec/JdbcContext;
invokeinterface org.hibernate.tool.schema.internal.exec.JdbcContext.getJdbcConnectionAccess:()Lorg/hibernate/engine/jdbc/connections/spi/JdbcConnectionAccess;
aload 0
getfield org.hibernate.resource.transaction.backend.jta.internal.DdlTransactionIsolatorJtaImpl.jdbcConnection:Ljava/sql/Connection;
invokeinterface org.hibernate.engine.jdbc.connections.spi.JdbcConnectionAccess.releaseConnection:(Ljava/sql/Connection;)V
2: goto 5
3: StackMap locals:
StackMap stack: java.sql.SQLException
astore 1
start local 1 4: aload 0
getfield org.hibernate.resource.transaction.backend.jta.internal.DdlTransactionIsolatorJtaImpl.jdbcContext:Lorg/hibernate/tool/schema/internal/exec/JdbcContext;
invokeinterface org.hibernate.tool.schema.internal.exec.JdbcContext.getSqlExceptionHelper:()Lorg/hibernate/engine/jdbc/spi/SqlExceptionHelper;
aload 1
ldc "Unable to release JDBC Connection used for DDL execution"
invokevirtual org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert:(Ljava/sql/SQLException;Ljava/lang/String;)Lorg/hibernate/JDBCException;
athrow
end local 1 5: StackMap locals:
StackMap stack:
aload 0
getfield org.hibernate.resource.transaction.backend.jta.internal.DdlTransactionIsolatorJtaImpl.suspendedTransaction:Ljavax/transaction/Transaction;
ifnull 10
6: aload 0
getfield org.hibernate.resource.transaction.backend.jta.internal.DdlTransactionIsolatorJtaImpl.jdbcContext:Lorg/hibernate/tool/schema/internal/exec/JdbcContext;
invokeinterface org.hibernate.tool.schema.internal.exec.JdbcContext.getServiceRegistry:()Lorg/hibernate/service/ServiceRegistry;
ldc Lorg/hibernate/engine/transaction/jta/platform/spi/JtaPlatform;
invokeinterface org.hibernate.service.ServiceRegistry.getService:(Ljava/lang/Class;)Lorg/hibernate/service/Service;
checkcast org.hibernate.engine.transaction.jta.platform.spi.JtaPlatform
invokeinterface org.hibernate.engine.transaction.jta.platform.spi.JtaPlatform.retrieveTransactionManager:()Ljavax/transaction/TransactionManager;
aload 0
getfield org.hibernate.resource.transaction.backend.jta.internal.DdlTransactionIsolatorJtaImpl.suspendedTransaction:Ljavax/transaction/Transaction;
invokeinterface javax.transaction.TransactionManager.resume:(Ljavax/transaction/Transaction;)V
7: goto 10
8: StackMap locals:
StackMap stack: java.lang.Exception
pop
9: new org.hibernate.HibernateException
dup
ldc "Unable to resume JTA transaction after DDL execution"
invokespecial org.hibernate.HibernateException.<init>:(Ljava/lang/String;)V
athrow
10: StackMap locals:
StackMap stack:
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 11 0 this Lorg/hibernate/resource/transaction/backend/jta/internal/DdlTransactionIsolatorJtaImpl;
4 5 1 e Ljava/sql/SQLException;
Exception table:
from to target type
1 2 3 Class java.sql.SQLException
6 7 8 Class java.lang.Exception
}
SourceFile: "DdlTransactionIsolatorJtaImpl.java"