public class org.hibernate.context.internal.JTASessionContext extends org.hibernate.context.spi.AbstractCurrentSessionContext
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: org.hibernate.context.internal.JTASessionContext
super_class: org.hibernate.context.spi.AbstractCurrentSessionContext
{
private static final org.hibernate.internal.CoreMessageLogger LOG;
descriptor: Lorg/hibernate/internal/CoreMessageLogger;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
private transient java.util.Map<java.lang.Object, org.hibernate.Session> currentSessionMap;
descriptor: Ljava/util/Map;
flags: (0x0082) ACC_PRIVATE, ACC_TRANSIENT
Signature: Ljava/util/Map<Ljava/lang/Object;Lorg/hibernate/Session;>;
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=2, locals=0, args_size=0
0: ldc Lorg/hibernate/internal/CoreMessageLogger;
1: ldc Lorg/hibernate/context/internal/JTASessionContext;
invokevirtual java.lang.Class.getName:()Ljava/lang/String;
2: invokestatic org.jboss.logging.Logger.getMessageLogger:(Ljava/lang/Class;Ljava/lang/String;)Ljava/lang/Object;
checkcast org.hibernate.internal.CoreMessageLogger
putstatic org.hibernate.context.internal.JTASessionContext.LOG:Lorg/hibernate/internal/CoreMessageLogger;
3: return
LocalVariableTable:
Start End Slot Name Signature
public void <init>(org.hibernate.engine.spi.SessionFactoryImplementor);
descriptor: (Lorg/hibernate/engine/spi/SessionFactoryImplementor;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
invokespecial org.hibernate.context.spi.AbstractCurrentSessionContext.<init>:(Lorg/hibernate/engine/spi/SessionFactoryImplementor;)V
1: aload 0
new java.util.concurrent.ConcurrentHashMap
dup
invokespecial java.util.concurrent.ConcurrentHashMap.<init>:()V
putfield org.hibernate.context.internal.JTASessionContext.currentSessionMap:Ljava/util/Map;
2: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lorg/hibernate/context/internal/JTASessionContext;
0 3 1 factory Lorg/hibernate/engine/spi/SessionFactoryImplementor;
MethodParameters:
Name Flags
factory
public org.hibernate.Session currentSession();
descriptor: ()Lorg/hibernate/Session;
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=7, args_size=1
start local 0 0: aload 0
invokevirtual org.hibernate.context.internal.JTASessionContext.factory:()Lorg/hibernate/engine/spi/SessionFactoryImplementor;
invokeinterface org.hibernate.engine.spi.SessionFactoryImplementor.getServiceRegistry:()Lorg/hibernate/service/spi/ServiceRegistryImplementor;
ldc Lorg/hibernate/engine/transaction/jta/platform/spi/JtaPlatform;
invokeinterface org.hibernate.service.spi.ServiceRegistryImplementor.getService:(Ljava/lang/Class;)Lorg/hibernate/service/Service;
checkcast org.hibernate.engine.transaction.jta.platform.spi.JtaPlatform
astore 1
start local 1 1: aload 1
invokeinterface org.hibernate.engine.transaction.jta.platform.spi.JtaPlatform.retrieveTransactionManager:()Ljavax/transaction/TransactionManager;
astore 2
start local 2 2: aload 2
ifnonnull 4
3: new org.hibernate.HibernateException
dup
ldc "No TransactionManagerLookup specified"
invokespecial org.hibernate.HibernateException.<init>:(Ljava/lang/String;)V
athrow
4: StackMap locals: org.hibernate.engine.transaction.jta.platform.spi.JtaPlatform javax.transaction.TransactionManager
StackMap stack:
aload 2
invokeinterface javax.transaction.TransactionManager.getTransaction:()Ljavax/transaction/Transaction;
astore 3
start local 3 5: aload 3
ifnonnull 7
6: new org.hibernate.HibernateException
dup
ldc "Unable to locate current JTA transaction"
invokespecial org.hibernate.HibernateException.<init>:(Ljava/lang/String;)V
athrow
7: StackMap locals: javax.transaction.Transaction
StackMap stack:
aload 3
invokeinterface javax.transaction.Transaction.getStatus:()I
invokestatic org.hibernate.engine.transaction.internal.jta.JtaStatusHelper.isActive:(I)Z
ifne 13
8: new org.hibernate.HibernateException
dup
ldc "Current transaction is not in progress"
invokespecial org.hibernate.HibernateException.<init>:(Ljava/lang/String;)V
athrow
end local 3 9: StackMap locals: org.hibernate.context.internal.JTASessionContext org.hibernate.engine.transaction.jta.platform.spi.JtaPlatform javax.transaction.TransactionManager
StackMap stack: org.hibernate.HibernateException
astore 4
start local 4 10: aload 4
athrow
end local 4 11: StackMap locals:
StackMap stack: java.lang.Throwable
astore 4
start local 4 12: new org.hibernate.HibernateException
dup
ldc "Problem locating/validating JTA transaction"
aload 4
invokespecial org.hibernate.HibernateException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
athrow
end local 4 start local 3 13: StackMap locals: javax.transaction.Transaction
StackMap stack:
aload 1
aload 3
invokeinterface org.hibernate.engine.transaction.jta.platform.spi.JtaPlatform.getTransactionIdentifier:(Ljavax/transaction/Transaction;)Ljava/lang/Object;
astore 4
start local 4 14: aload 0
getfield org.hibernate.context.internal.JTASessionContext.currentSessionMap:Ljava/util/Map;
aload 4
invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast org.hibernate.Session
astore 5
start local 5 15: aload 5
ifnonnull 27
16: aload 0
invokevirtual org.hibernate.context.internal.JTASessionContext.buildOrObtainSession:()Lorg/hibernate/Session;
astore 5
17: aload 3
aload 0
aload 4
invokevirtual org.hibernate.context.internal.JTASessionContext.buildCleanupSynch:(Ljava/lang/Object;)Lorg/hibernate/context/internal/JTASessionContext$CleanupSync;
invokeinterface javax.transaction.Transaction.registerSynchronization:(Ljavax/transaction/Synchronization;)V
18: goto 25
19: StackMap locals: org.hibernate.context.internal.JTASessionContext org.hibernate.engine.transaction.jta.platform.spi.JtaPlatform javax.transaction.TransactionManager javax.transaction.Transaction java.lang.Object org.hibernate.Session
StackMap stack: java.lang.Throwable
pop
20: aload 5
invokeinterface org.hibernate.Session.close:()Ljava/sql/Connection;
pop
21: goto 24
22: StackMap locals:
StackMap stack: java.lang.Throwable
astore 6
start local 6 23: getstatic org.hibernate.context.internal.JTASessionContext.LOG:Lorg/hibernate/internal/CoreMessageLogger;
ldc "Unable to release generated current-session on failed synch registration"
aload 6
invokeinterface org.hibernate.internal.CoreMessageLogger.debug:(Ljava/lang/Object;Ljava/lang/Throwable;)V
end local 6 24: StackMap locals:
StackMap stack:
new org.hibernate.HibernateException
dup
ldc "Unable to register cleanup Synchronization with TransactionManager"
invokespecial org.hibernate.HibernateException.<init>:(Ljava/lang/String;)V
athrow
25: StackMap locals:
StackMap stack:
aload 0
getfield org.hibernate.context.internal.JTASessionContext.currentSessionMap:Ljava/util/Map;
aload 4
aload 5
invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
pop
26: goto 28
27: StackMap locals:
StackMap stack:
aload 0
aload 5
invokevirtual org.hibernate.context.internal.JTASessionContext.validateExistingSession:(Lorg/hibernate/Session;)V
28: StackMap locals:
StackMap stack:
aload 5
areturn
end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 29 0 this Lorg/hibernate/context/internal/JTASessionContext;
1 29 1 jtaPlatform Lorg/hibernate/engine/transaction/jta/platform/spi/JtaPlatform;
2 29 2 transactionManager Ljavax/transaction/TransactionManager;
5 9 3 txn Ljavax/transaction/Transaction;
13 29 3 txn Ljavax/transaction/Transaction;
10 11 4 e Lorg/hibernate/HibernateException;
12 13 4 t Ljava/lang/Throwable;
14 29 4 txnIdentifier Ljava/lang/Object;
15 29 5 currentSession Lorg/hibernate/Session;
23 24 6 ignore Ljava/lang/Throwable;
Exception table:
from to target type
4 9 9 Class org.hibernate.HibernateException
4 9 11 Class java.lang.Throwable
17 18 19 Class java.lang.Throwable
20 21 22 Class java.lang.Throwable
Exceptions:
throws org.hibernate.HibernateException
private org.hibernate.context.internal.JTASessionContext$CleanupSync buildCleanupSynch(java.lang.Object);
descriptor: (Ljava/lang/Object;)Lorg/hibernate/context/internal/JTASessionContext$CleanupSync;
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=2, args_size=2
start local 0 start local 1 0: new org.hibernate.context.internal.JTASessionContext$CleanupSync
dup
aload 1
aload 0
invokespecial org.hibernate.context.internal.JTASessionContext$CleanupSync.<init>:(Ljava/lang/Object;Lorg/hibernate/context/internal/JTASessionContext;)V
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/hibernate/context/internal/JTASessionContext;
0 1 1 transactionIdentifier Ljava/lang/Object;
MethodParameters:
Name Flags
transactionIdentifier
protected org.hibernate.Session buildOrObtainSession();
descriptor: ()Lorg/hibernate/Session;
flags: (0x0004) ACC_PROTECTED
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
invokevirtual org.hibernate.context.internal.JTASessionContext.baseSessionBuilder:()Lorg/hibernate/SessionBuilder;
1: aload 0
invokevirtual org.hibernate.context.internal.JTASessionContext.isAutoCloseEnabled:()Z
invokeinterface org.hibernate.SessionBuilder.autoClose:(Z)Lorg/hibernate/SessionBuilder;
2: aload 0
invokevirtual org.hibernate.context.internal.JTASessionContext.getConnectionReleaseMode:()Lorg/hibernate/ConnectionReleaseMode;
invokeinterface org.hibernate.SessionBuilder.connectionReleaseMode:(Lorg/hibernate/ConnectionReleaseMode;)Lorg/hibernate/SessionBuilder;
3: aload 0
invokevirtual org.hibernate.context.internal.JTASessionContext.isAutoFlushEnabled:()Z
invokeinterface org.hibernate.SessionBuilder.flushBeforeCompletion:(Z)Lorg/hibernate/SessionBuilder;
4: invokeinterface org.hibernate.SessionBuilder.openSession:()Lorg/hibernate/Session;
5: areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lorg/hibernate/context/internal/JTASessionContext;
protected boolean isAutoCloseEnabled();
descriptor: ()Z
flags: (0x0004) ACC_PROTECTED
Code:
stack=1, locals=1, args_size=1
start local 0 0: iconst_1
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/hibernate/context/internal/JTASessionContext;
protected boolean isAutoFlushEnabled();
descriptor: ()Z
flags: (0x0004) ACC_PROTECTED
Code:
stack=1, locals=1, args_size=1
start local 0 0: iconst_1
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/hibernate/context/internal/JTASessionContext;
protected org.hibernate.ConnectionReleaseMode getConnectionReleaseMode();
descriptor: ()Lorg/hibernate/ConnectionReleaseMode;
flags: (0x0004) ACC_PROTECTED
Code:
stack=1, locals=1, args_size=1
start local 0 0: getstatic org.hibernate.ConnectionReleaseMode.AFTER_STATEMENT:Lorg/hibernate/ConnectionReleaseMode;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/hibernate/context/internal/JTASessionContext;
}
SourceFile: "JTASessionContext.java"
NestMembers:
org.hibernate.context.internal.JTASessionContext$CleanupSync
InnerClasses:
protected CleanupSync = org.hibernate.context.internal.JTASessionContext$CleanupSync of org.hibernate.context.internal.JTASessionContext