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: .line 28
            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 // org.hibernate.jpa.internal.PersistenceUnitUtilImpl this
        start local 1 // org.hibernate.engine.spi.SessionFactoryImplementor sessionFactory
         0: .line 33
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 31
            aload 0 /* this */
            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: .line 34
            aload 0 /* this */
            aload 1 /* sessionFactory */
            putfield org.hibernate.jpa.internal.PersistenceUnitUtilImpl.sessionFactory:Lorg/hibernate/engine/spi/SessionFactoryImplementor;
         3: .line 35
            return
        end local 1 // org.hibernate.engine.spi.SessionFactoryImplementor sessionFactory
        end local 0 // org.hibernate.jpa.internal.PersistenceUnitUtilImpl this
      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 // org.hibernate.jpa.internal.PersistenceUnitUtilImpl this
        start local 1 // java.lang.Object entity
        start local 2 // java.lang.String attributeName
         0: .line 40
            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: .line 41
            aload 1 /* entity */
            aload 2 /* attributeName */
            aload 0 /* this */
            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 /* state */
        start local 3 // javax.persistence.spi.LoadState state
         2: .line 42
            aload 3 /* state */
            getstatic javax.persistence.spi.LoadState.LOADED:Ljavax/persistence/spi/LoadState;
            if_acmpne 4
         3: .line 43
            iconst_1
            ireturn
         4: .line 45
      StackMap locals: javax.persistence.spi.LoadState
      StackMap stack:
            aload 3 /* state */
            getstatic javax.persistence.spi.LoadState.NOT_LOADED:Ljavax/persistence/spi/LoadState;
            if_acmpne 6
         5: .line 46
            iconst_0
            ireturn
         6: .line 50
      StackMap locals:
      StackMap stack:
            aload 1 /* entity */
         7: .line 51
            aload 2 /* attributeName */
         8: .line 52
            aload 0 /* this */
            getfield org.hibernate.jpa.internal.PersistenceUnitUtilImpl.cache:Lorg/hibernate/jpa/internal/util/PersistenceUtilHelper$MetadataCache;
         9: .line 49
            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: .line 53
            getstatic javax.persistence.spi.LoadState.NOT_LOADED:Ljavax/persistence/spi/LoadState;
        11: .line 49
            if_acmpeq 12
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
        12: iconst_0
            ireturn
        end local 3 // javax.persistence.spi.LoadState state
        end local 2 // java.lang.String attributeName
        end local 1 // java.lang.Object entity
        end local 0 // org.hibernate.jpa.internal.PersistenceUnitUtilImpl this
      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 // org.hibernate.jpa.internal.PersistenceUnitUtilImpl this
        start local 1 // java.lang.Object entity
         0: .line 60
            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: .line 61
            aload 1 /* entity */
            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 // java.lang.Object entity
        end local 0 // org.hibernate.jpa.internal.PersistenceUnitUtilImpl this
      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 // org.hibernate.jpa.internal.PersistenceUnitUtilImpl this
        start local 1 // java.lang.Object entity
         0: .line 66
            aload 1 /* entity */
            ifnonnull 2
         1: .line 67
            new java.lang.IllegalArgumentException
            dup
            ldc "Passed entity cannot be null"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 70
      StackMap locals:
      StackMap stack:
            aload 1 /* entity */
            instanceof org.hibernate.proxy.HibernateProxy
            ifeq 4
         3: .line 71
            aload 1 /* entity */
            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: .line 73
      StackMap locals:
      StackMap stack:
            aload 1 /* entity */
            instanceof org.hibernate.engine.spi.ManagedEntity
            ifeq 10
         5: .line 74
            aload 1 /* entity */
            checkcast org.hibernate.engine.spi.ManagedEntity
            invokeinterface org.hibernate.engine.spi.ManagedEntity.$$_hibernate_getEntityEntry:()Lorg/hibernate/engine/spi/EntityEntry;
            astore 2 /* entityEntry */
        start local 2 // org.hibernate.engine.spi.EntityEntry entityEntry
         6: .line 75
            aload 2 /* entityEntry */
            ifnull 8
         7: .line 76
            aload 2 /* entityEntry */
            invokeinterface org.hibernate.engine.spi.EntityEntry.getId:()Ljava/io/Serializable;
            areturn
         8: .line 80
      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: .line 81
            aload 0 /* this */
            aload 1 /* entity */
            invokevirtual org.hibernate.jpa.internal.PersistenceUnitUtilImpl.getIdentifierFromPersister:(Ljava/lang/Object;)Ljava/lang/Object;
            areturn
        end local 2 // org.hibernate.engine.spi.EntityEntry entityEntry
        10: .line 85
      StackMap locals:
      StackMap stack:
            getstatic org.hibernate.jpa.internal.PersistenceUnitUtilImpl.log:Lorg/jboss/logging/Logger;
        11: .line 86
            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: .line 85
            invokevirtual org.jboss.logging.Logger.debugf:(Ljava/lang/String;[Ljava/lang/Object;)V
        13: .line 90
            aload 0 /* this */
            aload 1 /* entity */
            invokevirtual org.hibernate.jpa.internal.PersistenceUnitUtilImpl.getIdentifierFromPersister:(Ljava/lang/Object;)Ljava/lang/Object;
            areturn
        end local 1 // java.lang.Object entity
        end local 0 // org.hibernate.jpa.internal.PersistenceUnitUtilImpl this
      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 // org.hibernate.jpa.internal.PersistenceUnitUtilImpl this
        start local 1 // java.lang.Object entity
         0: .line 95
            aload 1 /* entity */
            invokestatic org.hibernate.Hibernate.getClass:(Ljava/lang/Object;)Ljava/lang/Class;
            astore 2 /* entityClass */
        start local 2 // java.lang.Class entityClass
         1: .line 98
            aload 0 /* this */
            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 /* entityClass */
            invokeinterface org.hibernate.metamodel.spi.MetamodelImplementor.entityPersister:(Ljava/lang/Class;)Lorg/hibernate/persister/entity/EntityPersister;
            astore 3 /* persister */
        start local 3 // org.hibernate.persister.entity.EntityPersister persister
         2: .line 99
            aload 3 /* persister */
            ifnonnull 6
         3: .line 100
            new java.lang.IllegalArgumentException
            dup
            new java.lang.StringBuilder
            dup
            aload 2 /* entityClass */
            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 // org.hibernate.persister.entity.EntityPersister persister
         4: .line 103
      StackMap locals: org.hibernate.jpa.internal.PersistenceUnitUtilImpl java.lang.Object java.lang.Class
      StackMap stack: org.hibernate.MappingException
            astore 4 /* ex */
        start local 4 // org.hibernate.MappingException ex
         5: .line 104
            new java.lang.IllegalArgumentException
            dup
            new java.lang.StringBuilder
            dup
            aload 2 /* entityClass */
            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 /* ex */
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 4 // org.hibernate.MappingException ex
        start local 3 // org.hibernate.persister.entity.EntityPersister persister
         6: .line 106
      StackMap locals: org.hibernate.persister.entity.EntityPersister
      StackMap stack:
            aload 3 /* persister */
            aload 1 /* entity */
            aconst_null
            invokeinterface org.hibernate.persister.entity.EntityPersister.getIdentifier:(Ljava/lang/Object;Lorg/hibernate/engine/spi/SharedSessionContractImplementor;)Ljava/io/Serializable;
            areturn
        end local 3 // org.hibernate.persister.entity.EntityPersister persister
        end local 2 // java.lang.Class entityClass
        end local 1 // java.lang.Object entity
        end local 0 // org.hibernate.jpa.internal.PersistenceUnitUtilImpl this
      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