public class org.hibernate.jpa.internal.PersistenceUnitUtilImpl implements javax.persistence.PersistenceUnitUtil, java.io.Serializable
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: org.hibernate.jpa.internal.PersistenceUnitUtilImpl
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.engine.spi.SessionFactoryImplementor sessionFactory;
descriptor: Lorg/hibernate/engine/spi/SessionFactoryImplementor;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final transient org.hibernate.jpa.internal.util.PersistenceUtilHelper$MetadataCache cache;
descriptor: Lorg/hibernate/jpa/internal/util/PersistenceUtilHelper$MetadataCache;
flags: (0x0092) ACC_PRIVATE, ACC_FINAL, ACC_TRANSIENT
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=1, locals=0, args_size=0
0: ldc Lorg/hibernate/jpa/internal/PersistenceUnitUtilImpl;
invokestatic org.jboss.logging.Logger.getLogger:(Ljava/lang/Class;)Lorg/jboss/logging/Logger;
putstatic org.hibernate.jpa.internal.PersistenceUnitUtilImpl.log:Lorg/jboss/logging/Logger;
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
invokespecial java.lang.Object.<init>:()V
1: aload 0
new org.hibernate.jpa.internal.util.PersistenceUtilHelper$MetadataCache
dup
invokespecial org.hibernate.jpa.internal.util.PersistenceUtilHelper$MetadataCache.<init>:()V
putfield org.hibernate.jpa.internal.PersistenceUnitUtilImpl.cache:Lorg/hibernate/jpa/internal/util/PersistenceUtilHelper$MetadataCache;
2: aload 0
aload 1
putfield org.hibernate.jpa.internal.PersistenceUnitUtilImpl.sessionFactory:Lorg/hibernate/engine/spi/SessionFactoryImplementor;
3: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lorg/hibernate/jpa/internal/PersistenceUnitUtilImpl;
0 4 1 sessionFactory Lorg/hibernate/engine/spi/SessionFactoryImplementor;
MethodParameters:
Name Flags
sessionFactory
public boolean isLoaded(java.lang.Object, java.lang.String);
descriptor: (Ljava/lang/Object;Ljava/lang/String;)Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=4, args_size=3
start local 0 start local 1 start local 2 0: getstatic org.hibernate.jpa.internal.PersistenceUnitUtilImpl.log:Lorg/jboss/logging/Logger;
ldc "PersistenceUnitUtil#isLoaded is not always accurate; consider using EntityManager#contains instead"
invokevirtual org.jboss.logging.Logger.debug:(Ljava/lang/Object;)V
1: aload 1
aload 2
aload 0
getfield org.hibernate.jpa.internal.PersistenceUnitUtilImpl.cache:Lorg/hibernate/jpa/internal/util/PersistenceUtilHelper$MetadataCache;
invokestatic org.hibernate.jpa.internal.util.PersistenceUtilHelper.isLoadedWithoutReference:(Ljava/lang/Object;Ljava/lang/String;Lorg/hibernate/jpa/internal/util/PersistenceUtilHelper$MetadataCache;)Ljavax/persistence/spi/LoadState;
astore 3
start local 3 2: aload 3
getstatic javax.persistence.spi.LoadState.LOADED:Ljavax/persistence/spi/LoadState;
if_acmpne 4
3: iconst_1
ireturn
4: StackMap locals: javax.persistence.spi.LoadState
StackMap stack:
aload 3
getstatic javax.persistence.spi.LoadState.NOT_LOADED:Ljavax/persistence/spi/LoadState;
if_acmpne 6
5: iconst_0
ireturn
6: StackMap locals:
StackMap stack:
aload 1
7: aload 2
8: aload 0
getfield org.hibernate.jpa.internal.PersistenceUnitUtilImpl.cache:Lorg/hibernate/jpa/internal/util/PersistenceUtilHelper$MetadataCache;
9: invokestatic org.hibernate.jpa.internal.util.PersistenceUtilHelper.isLoadedWithReference:(Ljava/lang/Object;Ljava/lang/String;Lorg/hibernate/jpa/internal/util/PersistenceUtilHelper$MetadataCache;)Ljavax/persistence/spi/LoadState;
10: getstatic javax.persistence.spi.LoadState.NOT_LOADED:Ljavax/persistence/spi/LoadState;
11: if_acmpeq 12
iconst_1
ireturn
StackMap locals:
StackMap stack:
12: iconst_0
ireturn
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 13 0 this Lorg/hibernate/jpa/internal/PersistenceUnitUtilImpl;
0 13 1 entity Ljava/lang/Object;
0 13 2 attributeName Ljava/lang/String;
2 13 3 state Ljavax/persistence/spi/LoadState;
MethodParameters:
Name Flags
entity
attributeName
public boolean isLoaded(java.lang.Object);
descriptor: (Ljava/lang/Object;)Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: getstatic org.hibernate.jpa.internal.PersistenceUnitUtilImpl.log:Lorg/jboss/logging/Logger;
ldc "PersistenceUnitUtil#isLoaded is not always accurate; consider using EntityManager#contains instead"
invokevirtual org.jboss.logging.Logger.debug:(Ljava/lang/Object;)V
1: aload 1
invokestatic org.hibernate.jpa.internal.util.PersistenceUtilHelper.isLoaded:(Ljava/lang/Object;)Ljavax/persistence/spi/LoadState;
getstatic javax.persistence.spi.LoadState.NOT_LOADED:Ljavax/persistence/spi/LoadState;
if_acmpeq 2
iconst_1
ireturn
StackMap locals:
StackMap stack:
2: iconst_0
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lorg/hibernate/jpa/internal/PersistenceUnitUtilImpl;
0 3 1 entity Ljava/lang/Object;
MethodParameters:
Name Flags
entity
public java.lang.Object getIdentifier(java.lang.Object);
descriptor: (Ljava/lang/Object;)Ljava/lang/Object;
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=3, args_size=2
start local 0 start local 1 0: aload 1
ifnonnull 2
1: new java.lang.IllegalArgumentException
dup
ldc "Passed entity cannot be null"
invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
athrow
2: StackMap locals:
StackMap stack:
aload 1
instanceof org.hibernate.proxy.HibernateProxy
ifeq 4
3: aload 1
checkcast org.hibernate.proxy.HibernateProxy
invokeinterface org.hibernate.proxy.HibernateProxy.getHibernateLazyInitializer:()Lorg/hibernate/proxy/LazyInitializer;
invokeinterface org.hibernate.proxy.LazyInitializer.getIdentifier:()Ljava/io/Serializable;
areturn
4: StackMap locals:
StackMap stack:
aload 1
instanceof org.hibernate.engine.spi.ManagedEntity
ifeq 10
5: aload 1
checkcast org.hibernate.engine.spi.ManagedEntity
invokeinterface org.hibernate.engine.spi.ManagedEntity.$$_hibernate_getEntityEntry:()Lorg/hibernate/engine/spi/EntityEntry;
astore 2
start local 2 6: aload 2
ifnull 8
7: aload 2
invokeinterface org.hibernate.engine.spi.EntityEntry.getId:()Ljava/io/Serializable;
areturn
8: StackMap locals: org.hibernate.engine.spi.EntityEntry
StackMap stack:
getstatic org.hibernate.jpa.internal.PersistenceUnitUtilImpl.log:Lorg/jboss/logging/Logger;
ldc "javax.persistence.PersistenceUnitUtil.getIdentifier may not be able to read identifier of a detached entity"
invokevirtual org.jboss.logging.Logger.debug:(Ljava/lang/Object;)V
9: aload 0
aload 1
invokevirtual org.hibernate.jpa.internal.PersistenceUnitUtilImpl.getIdentifierFromPersister:(Ljava/lang/Object;)Ljava/lang/Object;
areturn
end local 2 10: StackMap locals:
StackMap stack:
getstatic org.hibernate.jpa.internal.PersistenceUnitUtilImpl.log:Lorg/jboss/logging/Logger;
11: ldc "javax.persistence.PersistenceUnitUtil.getIdentifier is only intended to work with enhanced entities (although Hibernate also adapts this support to its proxies); however the passed entity was not enhanced (nor a proxy).. may not be able to read identifier"
iconst_0
anewarray java.lang.Object
12: invokevirtual org.jboss.logging.Logger.debugf:(Ljava/lang/String;[Ljava/lang/Object;)V
13: aload 0
aload 1
invokevirtual org.hibernate.jpa.internal.PersistenceUnitUtilImpl.getIdentifierFromPersister:(Ljava/lang/Object;)Ljava/lang/Object;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 14 0 this Lorg/hibernate/jpa/internal/PersistenceUnitUtilImpl;
0 14 1 entity Ljava/lang/Object;
6 10 2 entityEntry Lorg/hibernate/engine/spi/EntityEntry;
MethodParameters:
Name Flags
entity
private java.lang.Object getIdentifierFromPersister(java.lang.Object);
descriptor: (Ljava/lang/Object;)Ljava/lang/Object;
flags: (0x0002) ACC_PRIVATE
Code:
stack=5, locals=5, args_size=2
start local 0 start local 1 0: aload 1
invokestatic org.hibernate.Hibernate.getClass:(Ljava/lang/Object;)Ljava/lang/Class;
astore 2
start local 2 1: aload 0
getfield org.hibernate.jpa.internal.PersistenceUnitUtilImpl.sessionFactory:Lorg/hibernate/engine/spi/SessionFactoryImplementor;
invokeinterface org.hibernate.engine.spi.SessionFactoryImplementor.getMetamodel:()Lorg/hibernate/metamodel/spi/MetamodelImplementor;
aload 2
invokeinterface org.hibernate.metamodel.spi.MetamodelImplementor.entityPersister:(Ljava/lang/Class;)Lorg/hibernate/persister/entity/EntityPersister;
astore 3
start local 3 2: aload 3
ifnonnull 6
3: new java.lang.IllegalArgumentException
dup
new java.lang.StringBuilder
dup
aload 2
invokevirtual java.lang.Class.getName:()Ljava/lang/String;
invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
ldc " is not an entity"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
athrow
end local 3 4: StackMap locals: org.hibernate.jpa.internal.PersistenceUnitUtilImpl java.lang.Object java.lang.Class
StackMap stack: org.hibernate.MappingException
astore 4
start local 4 5: new java.lang.IllegalArgumentException
dup
new java.lang.StringBuilder
dup
aload 2
invokevirtual java.lang.Class.getName:()Ljava/lang/String;
invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
ldc " is not an entity"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
aload 4
invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
athrow
end local 4 start local 3 6: StackMap locals: org.hibernate.persister.entity.EntityPersister
StackMap stack:
aload 3
aload 1
aconst_null
invokeinterface org.hibernate.persister.entity.EntityPersister.getIdentifier:(Ljava/lang/Object;Lorg/hibernate/engine/spi/SharedSessionContractImplementor;)Ljava/io/Serializable;
areturn
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Lorg/hibernate/jpa/internal/PersistenceUnitUtilImpl;
0 7 1 entity Ljava/lang/Object;
1 7 2 entityClass Ljava/lang/Class<*>;
2 4 3 persister Lorg/hibernate/persister/entity/EntityPersister;
6 7 3 persister Lorg/hibernate/persister/entity/EntityPersister;
5 6 4 ex Lorg/hibernate/MappingException;
Exception table:
from to target type
1 4 4 Class org.hibernate.MappingException
MethodParameters:
Name Flags
entity
}
SourceFile: "PersistenceUnitUtilImpl.java"
InnerClasses:
public MetadataCache = org.hibernate.jpa.internal.util.PersistenceUtilHelper$MetadataCache of org.hibernate.jpa.internal.util.PersistenceUtilHelper