public final class org.hibernate.engine.internal.TwoPhaseLoad
  minor version: 0
  major version: 59
  flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
  this_class: org.hibernate.engine.internal.TwoPhaseLoad
  super_class: java.lang.Object
{
  private static final org.hibernate.internal.CoreMessageLogger LOG;
    descriptor: Lorg/hibernate/internal/CoreMessageLogger;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=0, args_size=0
         0: .line 54
            ldc Lorg/hibernate/internal/CoreMessageLogger;
         1: .line 55
            ldc Lorg/hibernate/engine/internal/TwoPhaseLoad;
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
         2: .line 53
            invokestatic org.jboss.logging.Logger.getMessageLogger:(Ljava/lang/Class;Ljava/lang/String;)Ljava/lang/Object;
            checkcast org.hibernate.internal.CoreMessageLogger
            putstatic org.hibernate.engine.internal.TwoPhaseLoad.LOG:Lorg/hibernate/internal/CoreMessageLogger;
         3: .line 56
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  private void <init>();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.hibernate.engine.internal.TwoPhaseLoad this
         0: .line 58
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 59
            return
        end local 0 // org.hibernate.engine.internal.TwoPhaseLoad this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/hibernate/engine/internal/TwoPhaseLoad;

  public static void postHydrate(org.hibernate.persister.entity.EntityPersister, java.io.Serializable, java.lang.Object[], java.lang.Object, java.lang.Object, org.hibernate.LockMode, org.hibernate.engine.spi.SharedSessionContractImplementor);
    descriptor: (Lorg/hibernate/persister/entity/EntityPersister;Ljava/io/Serializable;[Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;Lorg/hibernate/LockMode;Lorg/hibernate/engine/spi/SharedSessionContractImplementor;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=11, locals=9, args_size=7
        start local 0 // org.hibernate.persister.entity.EntityPersister persister
        start local 1 // java.io.Serializable id
        start local 2 // java.lang.Object[] values
        start local 3 // java.lang.Object rowId
        start local 4 // java.lang.Object object
        start local 5 // org.hibernate.LockMode lockMode
        start local 6 // org.hibernate.engine.spi.SharedSessionContractImplementor session
         0: .line 84
            aload 2 /* values */
            aload 0 /* persister */
            invokestatic org.hibernate.engine.internal.Versioning.getVersion:([Ljava/lang/Object;Lorg/hibernate/persister/entity/EntityPersister;)Ljava/lang/Object;
            astore 7 /* version */
        start local 7 // java.lang.Object version
         1: .line 85
            aload 6 /* session */
            invokeinterface org.hibernate.engine.spi.SharedSessionContractImplementor.getPersistenceContext:()Lorg/hibernate/engine/spi/PersistenceContext;
         2: .line 86
            aload 4 /* object */
         3: .line 87
            getstatic org.hibernate.engine.spi.Status.LOADING:Lorg/hibernate/engine/spi/Status;
         4: .line 88
            aload 2 /* values */
         5: .line 89
            aload 3 /* rowId */
         6: .line 90
            aload 1 /* id */
         7: .line 91
            aload 7 /* version */
         8: .line 92
            aload 5 /* lockMode */
         9: .line 93
            iconst_1
        10: .line 94
            aload 0 /* persister */
        11: .line 95
            iconst_0
        12: .line 85
            invokeinterface org.hibernate.engine.spi.PersistenceContext.addEntry:(Ljava/lang/Object;Lorg/hibernate/engine/spi/Status;[Ljava/lang/Object;Ljava/lang/Object;Ljava/io/Serializable;Ljava/lang/Object;Lorg/hibernate/LockMode;ZLorg/hibernate/persister/entity/EntityPersister;Z)Lorg/hibernate/engine/spi/EntityEntry;
            pop
        13: .line 98
            aload 7 /* version */
            ifnull 19
            getstatic org.hibernate.engine.internal.TwoPhaseLoad.LOG:Lorg/hibernate/internal/CoreMessageLogger;
            invokeinterface org.hibernate.internal.CoreMessageLogger.isTraceEnabled:()Z
            ifeq 19
        14: .line 99
            aload 0 /* persister */
            invokeinterface org.hibernate.persister.entity.EntityPersister.isVersioned:()Z
            ifeq 16
        15: .line 100
            aload 0 /* persister */
            invokeinterface org.hibernate.persister.entity.EntityPersister.getVersionType:()Lorg/hibernate/type/VersionType;
            aload 7 /* version */
            aload 6 /* session */
            invokeinterface org.hibernate.engine.spi.SharedSessionContractImplementor.getFactory:()Lorg/hibernate/engine/spi/SessionFactoryImplementor;
            invokeinterface org.hibernate.type.VersionType.toLoggableString:(Ljava/lang/Object;Lorg/hibernate/engine/spi/SessionFactoryImplementor;)Ljava/lang/String;
            goto 17
        16: .line 101
      StackMap locals: java.lang.Object
      StackMap stack:
            ldc "null"
        17: .line 99
      StackMap locals:
      StackMap stack: java.lang.String
            astore 8 /* versionStr */
        start local 8 // java.lang.String versionStr
        18: .line 102
            getstatic org.hibernate.engine.internal.TwoPhaseLoad.LOG:Lorg/hibernate/internal/CoreMessageLogger;
            ldc "Version: %s"
            aload 8 /* versionStr */
            invokeinterface org.hibernate.internal.CoreMessageLogger.tracef:(Ljava/lang/String;Ljava/lang/Object;)V
        end local 8 // java.lang.String versionStr
        19: .line 104
      StackMap locals:
      StackMap stack:
            return
        end local 7 // java.lang.Object version
        end local 6 // org.hibernate.engine.spi.SharedSessionContractImplementor session
        end local 5 // org.hibernate.LockMode lockMode
        end local 4 // java.lang.Object object
        end local 3 // java.lang.Object rowId
        end local 2 // java.lang.Object[] values
        end local 1 // java.io.Serializable id
        end local 0 // org.hibernate.persister.entity.EntityPersister persister
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   20     0   persister  Lorg/hibernate/persister/entity/EntityPersister;
            0   20     1          id  Ljava/io/Serializable;
            0   20     2      values  [Ljava/lang/Object;
            0   20     3       rowId  Ljava/lang/Object;
            0   20     4      object  Ljava/lang/Object;
            0   20     5    lockMode  Lorg/hibernate/LockMode;
            0   20     6     session  Lorg/hibernate/engine/spi/SharedSessionContractImplementor;
            1   20     7     version  Ljava/lang/Object;
           18   19     8  versionStr  Ljava/lang/String;
    MethodParameters:
           Name  Flags
      persister  final
      id         final
      values     final
      rowId      final
      object     final
      lockMode   final
      session    final

  public static void initializeEntity(java.lang.Object, boolean, org.hibernate.engine.spi.SharedSessionContractImplementor, org.hibernate.event.spi.PreLoadEvent);
    descriptor: (Ljava/lang/Object;ZLorg/hibernate/engine/spi/SharedSessionContractImplementor;Lorg/hibernate/event/spi/PreLoadEvent;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=5, locals=6, args_size=4
        start local 0 // java.lang.Object entity
        start local 1 // boolean readOnly
        start local 2 // org.hibernate.engine.spi.SharedSessionContractImplementor session
        start local 3 // org.hibernate.event.spi.PreLoadEvent preLoadEvent
         0: .line 124
            aload 2 /* session */
            invokeinterface org.hibernate.engine.spi.SharedSessionContractImplementor.getPersistenceContext:()Lorg/hibernate/engine/spi/PersistenceContext;
            astore 4 /* persistenceContext */
        start local 4 // org.hibernate.engine.spi.PersistenceContext persistenceContext
         1: .line 125
            aload 4 /* persistenceContext */
            aload 0 /* entity */
            invokeinterface org.hibernate.engine.spi.PersistenceContext.getEntry:(Ljava/lang/Object;)Lorg/hibernate/engine/spi/EntityEntry;
            astore 5 /* entityEntry */
        start local 5 // org.hibernate.engine.spi.EntityEntry entityEntry
         2: .line 126
            aload 5 /* entityEntry */
            ifnonnull 4
         3: .line 127
            new org.hibernate.AssertionFailure
            dup
            ldc "possible non-threadsafe access to the session"
            invokespecial org.hibernate.AssertionFailure.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 129
      StackMap locals: org.hibernate.engine.spi.PersistenceContext org.hibernate.engine.spi.EntityEntry
      StackMap stack:
            aload 0 /* entity */
            aload 5 /* entityEntry */
            iload 1 /* readOnly */
            aload 2 /* session */
            aload 3 /* preLoadEvent */
            invokestatic org.hibernate.engine.internal.TwoPhaseLoad.doInitializeEntity:(Ljava/lang/Object;Lorg/hibernate/engine/spi/EntityEntry;ZLorg/hibernate/engine/spi/SharedSessionContractImplementor;Lorg/hibernate/event/spi/PreLoadEvent;)V
         5: .line 130
            return
        end local 5 // org.hibernate.engine.spi.EntityEntry entityEntry
        end local 4 // org.hibernate.engine.spi.PersistenceContext persistenceContext
        end local 3 // org.hibernate.event.spi.PreLoadEvent preLoadEvent
        end local 2 // org.hibernate.engine.spi.SharedSessionContractImplementor session
        end local 1 // boolean readOnly
        end local 0 // java.lang.Object entity
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0    6     0              entity  Ljava/lang/Object;
            0    6     1            readOnly  Z
            0    6     2             session  Lorg/hibernate/engine/spi/SharedSessionContractImplementor;
            0    6     3        preLoadEvent  Lorg/hibernate/event/spi/PreLoadEvent;
            1    6     4  persistenceContext  Lorg/hibernate/engine/spi/PersistenceContext;
            2    6     5         entityEntry  Lorg/hibernate/engine/spi/EntityEntry;
    MethodParameters:
              Name  Flags
      entity        final
      readOnly      final
      session       final
      preLoadEvent  final

  private static void doInitializeEntity(java.lang.Object, org.hibernate.engine.spi.EntityEntry, boolean, org.hibernate.engine.spi.SharedSessionContractImplementor, org.hibernate.event.spi.PreLoadEvent);
    descriptor: (Ljava/lang/Object;Lorg/hibernate/engine/spi/EntityEntry;ZLorg/hibernate/engine/spi/SharedSessionContractImplementor;Lorg/hibernate/event/spi/PreLoadEvent;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=7, locals=21, args_size=5
        start local 0 // java.lang.Object entity
        start local 1 // org.hibernate.engine.spi.EntityEntry entityEntry
        start local 2 // boolean readOnly
        start local 3 // org.hibernate.engine.spi.SharedSessionContractImplementor session
        start local 4 // org.hibernate.event.spi.PreLoadEvent preLoadEvent
         0: .line 138
            aload 3 /* session */
            invokeinterface org.hibernate.engine.spi.SharedSessionContractImplementor.getPersistenceContext:()Lorg/hibernate/engine/spi/PersistenceContext;
            astore 5 /* persistenceContext */
        start local 5 // org.hibernate.engine.spi.PersistenceContext persistenceContext
         1: .line 139
            aload 1 /* entityEntry */
            invokeinterface org.hibernate.engine.spi.EntityEntry.getPersister:()Lorg/hibernate/persister/entity/EntityPersister;
            astore 6 /* persister */
        start local 6 // org.hibernate.persister.entity.EntityPersister persister
         2: .line 140
            aload 1 /* entityEntry */
            invokeinterface org.hibernate.engine.spi.EntityEntry.getId:()Ljava/io/Serializable;
            astore 7 /* id */
        start local 7 // java.io.Serializable id
         3: .line 141
            aload 1 /* entityEntry */
            invokeinterface org.hibernate.engine.spi.EntityEntry.getLoadedState:()[Ljava/lang/Object;
            astore 8 /* hydratedState */
        start local 8 // java.lang.Object[] hydratedState
         4: .line 143
            getstatic org.hibernate.engine.internal.TwoPhaseLoad.LOG:Lorg/hibernate/internal/CoreMessageLogger;
            invokeinterface org.hibernate.internal.CoreMessageLogger.isDebugEnabled:()Z
            istore 9 /* debugEnabled */
        start local 9 // boolean debugEnabled
         5: .line 144
            iload 9 /* debugEnabled */
            ifeq 10
         6: .line 145
            getstatic org.hibernate.engine.internal.TwoPhaseLoad.LOG:Lorg/hibernate/internal/CoreMessageLogger;
         7: .line 146
            ldc "Resolving associations for %s"
         8: .line 147
            aload 6 /* persister */
            aload 7 /* id */
            aload 3 /* session */
            invokeinterface org.hibernate.engine.spi.SharedSessionContractImplementor.getFactory:()Lorg/hibernate/engine/spi/SessionFactoryImplementor;
            invokestatic org.hibernate.pretty.MessageHelper.infoString:(Lorg/hibernate/persister/entity/EntityPersister;Ljava/lang/Object;Lorg/hibernate/engine/spi/SessionFactoryImplementor;)Ljava/lang/String;
         9: .line 145
            invokeinterface org.hibernate.internal.CoreMessageLogger.debugf:(Ljava/lang/String;Ljava/lang/Object;)V
        10: .line 151
      StackMap locals: java.lang.Object org.hibernate.engine.spi.EntityEntry int org.hibernate.engine.spi.SharedSessionContractImplementor org.hibernate.event.spi.PreLoadEvent org.hibernate.engine.spi.PersistenceContext org.hibernate.persister.entity.EntityPersister java.io.Serializable java.lang.Object[] int
      StackMap stack:
            aload 6 /* persister */
            invokeinterface org.hibernate.persister.entity.EntityPersister.getEntityName:()Ljava/lang/String;
            astore 10 /* entityName */
        start local 10 // java.lang.String entityName
        11: .line 152
            aload 6 /* persister */
            invokeinterface org.hibernate.persister.entity.EntityPersister.getPropertyNames:()[Ljava/lang/String;
            astore 11 /* propertyNames */
        start local 11 // java.lang.String[] propertyNames
        12: .line 153
            aload 6 /* persister */
            invokeinterface org.hibernate.persister.entity.EntityPersister.getPropertyTypes:()[Lorg/hibernate/type/Type;
            astore 12 /* types */
        start local 12 // org.hibernate.type.Type[] types
        13: .line 154
            iconst_0
            istore 13 /* i */
        start local 13 // int i
        14: goto 24
        15: .line 155
      StackMap locals: java.lang.Object org.hibernate.engine.spi.EntityEntry int org.hibernate.engine.spi.SharedSessionContractImplementor org.hibernate.event.spi.PreLoadEvent org.hibernate.engine.spi.PersistenceContext org.hibernate.persister.entity.EntityPersister java.io.Serializable java.lang.Object[] int java.lang.String java.lang.String[] org.hibernate.type.Type[] int
      StackMap stack:
            aload 8 /* hydratedState */
            iload 13 /* i */
            aaload
            astore 14 /* value */
        start local 14 // java.lang.Object value
        16: .line 156
            aload 3 /* session */
            aload 10 /* entityName */
            aload 11 /* propertyNames */
            iload 13 /* i */
            aaload
            aload 12 /* types */
            iload 13 /* i */
            aaload
            invokestatic org.hibernate.engine.internal.TwoPhaseLoad.getOverridingEager:(Lorg/hibernate/engine/spi/SharedSessionContractImplementor;Ljava/lang/String;Ljava/lang/String;Lorg/hibernate/type/Type;)Ljava/lang/Boolean;
            astore 15 /* overridingEager */
        start local 15 // java.lang.Boolean overridingEager
        17: .line 157
            aload 14 /* value */
            getstatic org.hibernate.bytecode.enhance.spi.LazyPropertyInitializer.UNFETCHED_PROPERTY:Ljava/io/Serializable;
            if_acmpne 21
        18: .line 162
            aload 12 /* types */
            iload 13 /* i */
            aaload
            invokeinterface org.hibernate.type.Type.isCollectionType:()Z
            ifeq 23
        19: .line 167
            aload 12 /* types */
            iload 13 /* i */
            aaload
            aload 14 /* value */
            aload 3 /* session */
            aload 0 /* entity */
            aload 15 /* overridingEager */
            invokeinterface org.hibernate.type.Type.resolve:(Ljava/lang/Object;Lorg/hibernate/engine/spi/SharedSessionContractImplementor;Ljava/lang/Object;Ljava/lang/Boolean;)Ljava/lang/Object;
            pop
        20: .line 169
            goto 23
        21: .line 170
      StackMap locals: java.lang.Object java.lang.Boolean
      StackMap stack:
            aload 14 /* value */
            getstatic org.hibernate.property.access.internal.PropertyAccessStrategyBackRefImpl.UNKNOWN:Ljava/io/Serializable;
            if_acmpeq 23
        22: .line 172
            aload 8 /* hydratedState */
            iload 13 /* i */
            aload 12 /* types */
            iload 13 /* i */
            aaload
            aload 14 /* value */
            aload 3 /* session */
            aload 0 /* entity */
            aload 15 /* overridingEager */
            invokeinterface org.hibernate.type.Type.resolve:(Ljava/lang/Object;Lorg/hibernate/engine/spi/SharedSessionContractImplementor;Ljava/lang/Object;Ljava/lang/Boolean;)Ljava/lang/Object;
            aastore
        end local 15 // java.lang.Boolean overridingEager
        end local 14 // java.lang.Object value
        23: .line 154
      StackMap locals:
      StackMap stack:
            iinc 13 /* i */ 1
      StackMap locals:
      StackMap stack:
        24: iload 13 /* i */
            aload 8 /* hydratedState */
            arraylength
            if_icmplt 15
        end local 13 // int i
        25: .line 177
            aload 3 /* session */
            invokeinterface org.hibernate.engine.spi.SharedSessionContractImplementor.isEventSource:()Z
            ifeq 37
        26: .line 178
            aload 4 /* preLoadEvent */
            aload 0 /* entity */
            invokevirtual org.hibernate.event.spi.PreLoadEvent.setEntity:(Ljava/lang/Object;)Lorg/hibernate/event/spi/PreLoadEvent;
            aload 8 /* hydratedState */
            invokevirtual org.hibernate.event.spi.PreLoadEvent.setState:([Ljava/lang/Object;)Lorg/hibernate/event/spi/PreLoadEvent;
            aload 7 /* id */
            invokevirtual org.hibernate.event.spi.PreLoadEvent.setId:(Ljava/io/Serializable;)Lorg/hibernate/event/spi/PreLoadEvent;
            aload 6 /* persister */
            invokevirtual org.hibernate.event.spi.PreLoadEvent.setPersister:(Lorg/hibernate/persister/entity/EntityPersister;)Lorg/hibernate/event/spi/PreLoadEvent;
            pop
        27: .line 180
            aload 3 /* session */
        28: .line 181
            invokeinterface org.hibernate.engine.spi.SharedSessionContractImplementor.getFactory:()Lorg/hibernate/engine/spi/SessionFactoryImplementor;
        29: .line 182
            invokeinterface org.hibernate.engine.spi.SessionFactoryImplementor.getServiceRegistry:()Lorg/hibernate/service/spi/ServiceRegistryImplementor;
        30: .line 183
            ldc Lorg/hibernate/event/service/spi/EventListenerRegistry;
            invokeinterface org.hibernate.service.spi.ServiceRegistryImplementor.getService:(Ljava/lang/Class;)Lorg/hibernate/service/Service;
            checkcast org.hibernate.event.service.spi.EventListenerRegistry
        31: .line 184
            getstatic org.hibernate.event.spi.EventType.PRE_LOAD:Lorg/hibernate/event/spi/EventType;
            invokeinterface org.hibernate.event.service.spi.EventListenerRegistry.getEventListenerGroup:(Lorg/hibernate/event/spi/EventType;)Lorg/hibernate/event/service/spi/EventListenerGroup;
        32: .line 180
            astore 13 /* listenerGroup */
        start local 13 // org.hibernate.event.service.spi.EventListenerGroup listenerGroup
        33: .line 185
            aload 13 /* listenerGroup */
            invokeinterface org.hibernate.event.service.spi.EventListenerGroup.listeners:()Ljava/lang/Iterable;
            invokeinterface java.lang.Iterable.iterator:()Ljava/util/Iterator;
            astore 15
            goto 36
      StackMap locals: java.lang.Object org.hibernate.engine.spi.EntityEntry int org.hibernate.engine.spi.SharedSessionContractImplementor org.hibernate.event.spi.PreLoadEvent org.hibernate.engine.spi.PersistenceContext org.hibernate.persister.entity.EntityPersister java.io.Serializable java.lang.Object[] int java.lang.String java.lang.String[] org.hibernate.type.Type[] org.hibernate.event.service.spi.EventListenerGroup top java.util.Iterator
      StackMap stack:
        34: aload 15
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.hibernate.event.spi.PreLoadEventListener
            astore 14 /* listener */
        start local 14 // org.hibernate.event.spi.PreLoadEventListener listener
        35: .line 186
            aload 14 /* listener */
            aload 4 /* preLoadEvent */
            invokeinterface org.hibernate.event.spi.PreLoadEventListener.onPreLoad:(Lorg/hibernate/event/spi/PreLoadEvent;)V
        end local 14 // org.hibernate.event.spi.PreLoadEventListener listener
        36: .line 185
      StackMap locals:
      StackMap stack:
            aload 15
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 34
        end local 13 // org.hibernate.event.service.spi.EventListenerGroup listenerGroup
        37: .line 190
      StackMap locals: java.lang.Object org.hibernate.engine.spi.EntityEntry int org.hibernate.engine.spi.SharedSessionContractImplementor org.hibernate.event.spi.PreLoadEvent org.hibernate.engine.spi.PersistenceContext org.hibernate.persister.entity.EntityPersister java.io.Serializable java.lang.Object[] int java.lang.String java.lang.String[] org.hibernate.type.Type[]
      StackMap stack:
            aload 6 /* persister */
            aload 0 /* entity */
            aload 8 /* hydratedState */
            invokeinterface org.hibernate.persister.entity.EntityPersister.setPropertyValues:(Ljava/lang/Object;[Ljava/lang/Object;)V
        38: .line 192
            aload 3 /* session */
            invokeinterface org.hibernate.engine.spi.SharedSessionContractImplementor.getFactory:()Lorg/hibernate/engine/spi/SessionFactoryImplementor;
            astore 13 /* factory */
        start local 13 // org.hibernate.engine.spi.SessionFactoryImplementor factory
        39: .line 193
            aload 6 /* persister */
            invokeinterface org.hibernate.persister.entity.EntityPersister.canWriteToCache:()Z
            ifeq 77
            aload 3 /* session */
            invokeinterface org.hibernate.engine.spi.SharedSessionContractImplementor.getCacheMode:()Lorg/hibernate/CacheMode;
            invokevirtual org.hibernate.CacheMode.isPutEnabled:()Z
            ifeq 77
        40: .line 195
            iload 9 /* debugEnabled */
            ifeq 45
        41: .line 196
            getstatic org.hibernate.engine.internal.TwoPhaseLoad.LOG:Lorg/hibernate/internal/CoreMessageLogger;
        42: .line 197
            ldc "Adding entity to second-level cache: %s"
        43: .line 198
            aload 6 /* persister */
            aload 7 /* id */
            aload 3 /* session */
            invokeinterface org.hibernate.engine.spi.SharedSessionContractImplementor.getFactory:()Lorg/hibernate/engine/spi/SessionFactoryImplementor;
            invokestatic org.hibernate.pretty.MessageHelper.infoString:(Lorg/hibernate/persister/entity/EntityPersister;Ljava/lang/Object;Lorg/hibernate/engine/spi/SessionFactoryImplementor;)Ljava/lang/String;
        44: .line 196
            invokeinterface org.hibernate.internal.CoreMessageLogger.debugf:(Ljava/lang/String;Ljava/lang/Object;)V
        45: .line 202
      StackMap locals: org.hibernate.engine.spi.SessionFactoryImplementor
      StackMap stack:
            aload 8 /* hydratedState */
            aload 6 /* persister */
            invokestatic org.hibernate.engine.internal.Versioning.getVersion:([Ljava/lang/Object;Lorg/hibernate/persister/entity/EntityPersister;)Ljava/lang/Object;
            astore 14 /* version */
        start local 14 // java.lang.Object version
        46: .line 203
            aload 6 /* persister */
            aload 0 /* entity */
            aload 8 /* hydratedState */
            aload 14 /* version */
            aload 3 /* session */
            invokeinterface org.hibernate.persister.entity.EntityPersister.buildCacheEntry:(Ljava/lang/Object;[Ljava/lang/Object;Ljava/lang/Object;Lorg/hibernate/engine/spi/SharedSessionContractImplementor;)Lorg/hibernate/cache/spi/entry/CacheEntry;
            astore 15 /* entry */
        start local 15 // org.hibernate.cache.spi.entry.CacheEntry entry
        47: .line 204
            aload 6 /* persister */
            invokeinterface org.hibernate.persister.entity.EntityPersister.getCacheAccessStrategy:()Lorg/hibernate/cache/spi/access/EntityDataAccess;
            astore 16 /* cache */
        start local 16 // org.hibernate.cache.spi.access.EntityDataAccess cache
        48: .line 205
            aload 16 /* cache */
            aload 7 /* id */
            aload 6 /* persister */
            aload 13 /* factory */
            aload 3 /* session */
            invokeinterface org.hibernate.engine.spi.SharedSessionContractImplementor.getTenantIdentifier:()Ljava/lang/String;
            invokeinterface org.hibernate.cache.spi.access.EntityDataAccess.generateCacheKey:(Ljava/lang/Object;Lorg/hibernate/persister/entity/EntityPersister;Lorg/hibernate/engine/spi/SessionFactoryImplementor;Ljava/lang/String;)Ljava/lang/Object;
            astore 17 /* cacheKey */
        start local 17 // java.lang.Object cacheKey
        49: .line 213
            aload 3 /* session */
            invokeinterface org.hibernate.engine.spi.SharedSessionContractImplementor.getPersistenceContext:()Lorg/hibernate/engine/spi/PersistenceContext;
            aload 6 /* persister */
            aload 7 /* id */
            invokeinterface org.hibernate.engine.spi.PersistenceContext.wasInsertedDuringTransaction:(Lorg/hibernate/persister/entity/EntityPersister;Ljava/io/Serializable;)Z
            ifeq 58
        50: .line 214
            aload 16 /* cache */
        51: .line 215
            aload 3 /* session */
        52: .line 216
            aload 17 /* cacheKey */
        53: .line 217
            aload 6 /* persister */
            invokeinterface org.hibernate.persister.entity.EntityPersister.getCacheEntryStructure:()Lorg/hibernate/cache/spi/entry/CacheEntryStructure;
            aload 15 /* entry */
            invokeinterface org.hibernate.cache.spi.entry.CacheEntryStructure.structure:(Ljava/lang/Object;)Ljava/lang/Object;
        54: .line 218
            aload 14 /* version */
        55: .line 219
            aload 14 /* version */
        56: .line 214
            invokeinterface org.hibernate.cache.spi.access.EntityDataAccess.update:(Lorg/hibernate/engine/spi/SharedSessionContractImplementor;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)Z
            pop
        57: .line 221
            goto 77
        58: .line 223
      StackMap locals: java.lang.Object org.hibernate.engine.spi.EntityEntry int org.hibernate.engine.spi.SharedSessionContractImplementor org.hibernate.event.spi.PreLoadEvent org.hibernate.engine.spi.PersistenceContext org.hibernate.persister.entity.EntityPersister java.io.Serializable java.lang.Object[] int java.lang.String java.lang.String[] org.hibernate.type.Type[] org.hibernate.engine.spi.SessionFactoryImplementor java.lang.Object org.hibernate.cache.spi.entry.CacheEntry org.hibernate.cache.spi.access.EntityDataAccess java.lang.Object
      StackMap stack:
            aload 3 /* session */
            invokeinterface org.hibernate.engine.spi.SharedSessionContractImplementor.getEventListenerManager:()Lorg/hibernate/engine/spi/SessionEventListenerManager;
            astore 18 /* eventListenerManager */
        start local 18 // org.hibernate.engine.spi.SessionEventListenerManager eventListenerManager
        59: .line 225
            aload 18 /* eventListenerManager */
            invokeinterface org.hibernate.engine.spi.SessionEventListenerManager.cachePutStart:()V
        60: .line 226
            aload 16 /* cache */
        61: .line 227
            aload 3 /* session */
        62: .line 228
            aload 17 /* cacheKey */
        63: .line 229
            aload 6 /* persister */
            invokeinterface org.hibernate.persister.entity.EntityPersister.getCacheEntryStructure:()Lorg/hibernate/cache/spi/entry/CacheEntryStructure;
            aload 15 /* entry */
            invokeinterface org.hibernate.cache.spi.entry.CacheEntryStructure.structure:(Ljava/lang/Object;)Ljava/lang/Object;
        64: .line 230
            aload 14 /* version */
        65: .line 231
            aload 3 /* session */
            aload 1 /* entityEntry */
            invokestatic org.hibernate.engine.internal.TwoPhaseLoad.useMinimalPuts:(Lorg/hibernate/engine/spi/SharedSessionContractImplementor;Lorg/hibernate/engine/spi/EntityEntry;)Z
        66: .line 226
            invokeinterface org.hibernate.cache.spi.access.EntityDataAccess.putFromLoad:(Lorg/hibernate/engine/spi/SharedSessionContractImplementor;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;Z)Z
            istore 19 /* put */
        start local 19 // boolean put
        67: .line 234
            iload 19 /* put */
            ifeq 76
            aload 13 /* factory */
            invokeinterface org.hibernate.engine.spi.SessionFactoryImplementor.getStatistics:()Lorg/hibernate/stat/spi/StatisticsImplementor;
            invokeinterface org.hibernate.stat.spi.StatisticsImplementor.isStatisticsEnabled:()Z
            ifeq 76
        68: .line 235
            aload 13 /* factory */
            invokeinterface org.hibernate.engine.spi.SessionFactoryImplementor.getStatistics:()Lorg/hibernate/stat/spi/StatisticsImplementor;
        69: .line 236
            getstatic org.hibernate.stat.internal.StatsHelper.INSTANCE:Lorg/hibernate/stat/internal/StatsHelper;
            aload 6 /* persister */
            invokevirtual org.hibernate.stat.internal.StatsHelper.getRootEntityRole:(Lorg/hibernate/persister/entity/EntityPersister;)Lorg/hibernate/metamodel/model/domain/NavigableRole;
        70: .line 237
            aload 16 /* cache */
            invokeinterface org.hibernate.cache.spi.access.EntityDataAccess.getRegion:()Lorg/hibernate/cache/spi/DomainDataRegion;
            invokeinterface org.hibernate.cache.spi.DomainDataRegion.getName:()Ljava/lang/String;
        71: .line 235
            invokeinterface org.hibernate.stat.spi.StatisticsImplementor.entityCachePut:(Lorg/hibernate/metamodel/model/domain/NavigableRole;Ljava/lang/String;)V
        end local 19 // boolean put
        72: .line 240
            goto 76
        73: .line 241
      StackMap locals: java.lang.Object org.hibernate.engine.spi.EntityEntry int org.hibernate.engine.spi.SharedSessionContractImplementor org.hibernate.event.spi.PreLoadEvent org.hibernate.engine.spi.PersistenceContext org.hibernate.persister.entity.EntityPersister java.io.Serializable java.lang.Object[] int java.lang.String java.lang.String[] org.hibernate.type.Type[] org.hibernate.engine.spi.SessionFactoryImplementor java.lang.Object org.hibernate.cache.spi.entry.CacheEntry org.hibernate.cache.spi.access.EntityDataAccess java.lang.Object org.hibernate.engine.spi.SessionEventListenerManager
      StackMap stack: java.lang.Throwable
            astore 20
        74: .line 242
            aload 18 /* eventListenerManager */
            invokeinterface org.hibernate.engine.spi.SessionEventListenerManager.cachePutEnd:()V
        75: .line 243
            aload 20
            athrow
        76: .line 242
      StackMap locals:
      StackMap stack:
            aload 18 /* eventListenerManager */
            invokeinterface org.hibernate.engine.spi.SessionEventListenerManager.cachePutEnd:()V
        end local 18 // org.hibernate.engine.spi.SessionEventListenerManager eventListenerManager
        end local 17 // java.lang.Object cacheKey
        end local 16 // org.hibernate.cache.spi.access.EntityDataAccess cache
        end local 15 // org.hibernate.cache.spi.entry.CacheEntry entry
        end local 14 // java.lang.Object version
        77: .line 247
      StackMap locals: java.lang.Object org.hibernate.engine.spi.EntityEntry int org.hibernate.engine.spi.SharedSessionContractImplementor org.hibernate.event.spi.PreLoadEvent org.hibernate.engine.spi.PersistenceContext org.hibernate.persister.entity.EntityPersister java.io.Serializable java.lang.Object[] int java.lang.String java.lang.String[] org.hibernate.type.Type[] org.hibernate.engine.spi.SessionFactoryImplementor
      StackMap stack:
            aload 6 /* persister */
            invokeinterface org.hibernate.persister.entity.EntityPersister.hasNaturalIdentifier:()Z
            ifeq 83
        78: .line 248
            aload 5 /* persistenceContext */
            invokeinterface org.hibernate.engine.spi.PersistenceContext.getNaturalIdHelper:()Lorg/hibernate/engine/spi/PersistenceContext$NaturalIdHelper;
        79: .line 249
            aload 6 /* persister */
        80: .line 250
            aload 7 /* id */
        81: .line 251
            aload 5 /* persistenceContext */
            invokeinterface org.hibernate.engine.spi.PersistenceContext.getNaturalIdHelper:()Lorg/hibernate/engine/spi/PersistenceContext$NaturalIdHelper;
            aload 8 /* hydratedState */
            aload 6 /* persister */
            invokeinterface org.hibernate.engine.spi.PersistenceContext$NaturalIdHelper.extractNaturalIdValues:([Ljava/lang/Object;Lorg/hibernate/persister/entity/EntityPersister;)[Ljava/lang/Object;
        82: .line 248
            invokeinterface org.hibernate.engine.spi.PersistenceContext$NaturalIdHelper.cacheNaturalIdCrossReferenceFromLoad:(Lorg/hibernate/persister/entity/EntityPersister;Ljava/io/Serializable;[Ljava/lang/Object;)V
        83: .line 255
      StackMap locals:
      StackMap stack:
            iload 2 /* readOnly */
            istore 14 /* isReallyReadOnly */
        start local 14 // boolean isReallyReadOnly
        84: .line 256
            aload 6 /* persister */
            invokeinterface org.hibernate.persister.entity.EntityPersister.isMutable:()Z
            ifne 87
        85: .line 257
            iconst_1
            istore 14 /* isReallyReadOnly */
        86: .line 258
            goto 90
        87: .line 260
      StackMap locals: int
      StackMap stack:
            aload 5 /* persistenceContext */
            aload 1 /* entityEntry */
            invokeinterface org.hibernate.engine.spi.EntityEntry.getEntityKey:()Lorg/hibernate/engine/spi/EntityKey;
            invokeinterface org.hibernate.engine.spi.PersistenceContext.getProxy:(Lorg/hibernate/engine/spi/EntityKey;)Ljava/lang/Object;
            astore 15 /* proxy */
        start local 15 // java.lang.Object proxy
        88: .line 261
            aload 15 /* proxy */
            ifnull 90
        89: .line 264
            aload 15 /* proxy */
            checkcast org.hibernate.proxy.HibernateProxy
            invokeinterface org.hibernate.proxy.HibernateProxy.getHibernateLazyInitializer:()Lorg/hibernate/proxy/LazyInitializer;
            invokeinterface org.hibernate.proxy.LazyInitializer.isReadOnly:()Z
            istore 14 /* isReallyReadOnly */
        end local 15 // java.lang.Object proxy
        90: .line 267
      StackMap locals:
      StackMap stack:
            iload 14 /* isReallyReadOnly */
            ifeq 93
        91: .line 272
            aload 5 /* persistenceContext */
            aload 1 /* entityEntry */
            getstatic org.hibernate.engine.spi.Status.READ_ONLY:Lorg/hibernate/engine/spi/Status;
            invokeinterface org.hibernate.engine.spi.PersistenceContext.setEntryStatus:(Lorg/hibernate/engine/spi/EntityEntry;Lorg/hibernate/engine/spi/Status;)V
        92: .line 273
            goto 100
        93: .line 277
      StackMap locals:
      StackMap stack:
            aload 8 /* hydratedState */
        94: .line 278
            aload 6 /* persister */
            invokeinterface org.hibernate.persister.entity.EntityPersister.getPropertyTypes:()[Lorg/hibernate/type/Type;
        95: .line 279
            aload 6 /* persister */
            invokeinterface org.hibernate.persister.entity.EntityPersister.getPropertyUpdateability:()[Z
        96: .line 281
            aload 8 /* hydratedState */
        97: .line 282
            aload 3 /* session */
        98: .line 276
            invokestatic org.hibernate.type.TypeHelper.deepCopy:([Ljava/lang/Object;[Lorg/hibernate/type/Type;[Z[Ljava/lang/Object;Lorg/hibernate/engine/spi/SharedSessionContractImplementor;)V
        99: .line 284
            aload 5 /* persistenceContext */
            aload 1 /* entityEntry */
            getstatic org.hibernate.engine.spi.Status.MANAGED:Lorg/hibernate/engine/spi/Status;
            invokeinterface org.hibernate.engine.spi.PersistenceContext.setEntryStatus:(Lorg/hibernate/engine/spi/EntityEntry;Lorg/hibernate/engine/spi/Status;)V
       100: .line 287
      StackMap locals:
      StackMap stack:
            aload 6 /* persister */
            aload 0 /* entity */
            aload 3 /* session */
            invokeinterface org.hibernate.persister.entity.EntityPersister.afterInitialize:(Ljava/lang/Object;Lorg/hibernate/engine/spi/SharedSessionContractImplementor;)V
       101: .line 289
            iload 9 /* debugEnabled */
            ifeq 106
       102: .line 290
            getstatic org.hibernate.engine.internal.TwoPhaseLoad.LOG:Lorg/hibernate/internal/CoreMessageLogger;
       103: .line 291
            ldc "Done materializing entity %s"
       104: .line 292
            aload 6 /* persister */
            aload 7 /* id */
            aload 3 /* session */
            invokeinterface org.hibernate.engine.spi.SharedSessionContractImplementor.getFactory:()Lorg/hibernate/engine/spi/SessionFactoryImplementor;
            invokestatic org.hibernate.pretty.MessageHelper.infoString:(Lorg/hibernate/persister/entity/EntityPersister;Ljava/lang/Object;Lorg/hibernate/engine/spi/SessionFactoryImplementor;)Ljava/lang/String;
       105: .line 290
            invokeinterface org.hibernate.internal.CoreMessageLogger.debugf:(Ljava/lang/String;Ljava/lang/Object;)V
       106: .line 296
      StackMap locals:
      StackMap stack:
            aload 13 /* factory */
            invokeinterface org.hibernate.engine.spi.SessionFactoryImplementor.getStatistics:()Lorg/hibernate/stat/spi/StatisticsImplementor;
            invokeinterface org.hibernate.stat.spi.StatisticsImplementor.isStatisticsEnabled:()Z
            ifeq 108
       107: .line 297
            aload 13 /* factory */
            invokeinterface org.hibernate.engine.spi.SessionFactoryImplementor.getStatistics:()Lorg/hibernate/stat/spi/StatisticsImplementor;
            aload 6 /* persister */
            invokeinterface org.hibernate.persister.entity.EntityPersister.getEntityName:()Ljava/lang/String;
            invokeinterface org.hibernate.stat.spi.StatisticsImplementor.loadEntity:(Ljava/lang/String;)V
       108: .line 299
      StackMap locals:
      StackMap stack:
            return
        end local 14 // boolean isReallyReadOnly
        end local 13 // org.hibernate.engine.spi.SessionFactoryImplementor factory
        end local 12 // org.hibernate.type.Type[] types
        end local 11 // java.lang.String[] propertyNames
        end local 10 // java.lang.String entityName
        end local 9 // boolean debugEnabled
        end local 8 // java.lang.Object[] hydratedState
        end local 7 // java.io.Serializable id
        end local 6 // org.hibernate.persister.entity.EntityPersister persister
        end local 5 // org.hibernate.engine.spi.PersistenceContext persistenceContext
        end local 4 // org.hibernate.event.spi.PreLoadEvent preLoadEvent
        end local 3 // org.hibernate.engine.spi.SharedSessionContractImplementor session
        end local 2 // boolean readOnly
        end local 1 // org.hibernate.engine.spi.EntityEntry entityEntry
        end local 0 // java.lang.Object entity
      LocalVariableTable:
        Start  End  Slot                  Name  Signature
            0  109     0                entity  Ljava/lang/Object;
            0  109     1           entityEntry  Lorg/hibernate/engine/spi/EntityEntry;
            0  109     2              readOnly  Z
            0  109     3               session  Lorg/hibernate/engine/spi/SharedSessionContractImplementor;
            0  109     4          preLoadEvent  Lorg/hibernate/event/spi/PreLoadEvent;
            1  109     5    persistenceContext  Lorg/hibernate/engine/spi/PersistenceContext;
            2  109     6             persister  Lorg/hibernate/persister/entity/EntityPersister;
            3  109     7                    id  Ljava/io/Serializable;
            4  109     8         hydratedState  [Ljava/lang/Object;
            5  109     9          debugEnabled  Z
           11  109    10            entityName  Ljava/lang/String;
           12  109    11         propertyNames  [Ljava/lang/String;
           13  109    12                 types  [Lorg/hibernate/type/Type;
           14   25    13                     i  I
           16   23    14                 value  Ljava/lang/Object;
           17   23    15       overridingEager  Ljava/lang/Boolean;
           33   37    13         listenerGroup  Lorg/hibernate/event/service/spi/EventListenerGroup<Lorg/hibernate/event/spi/PreLoadEventListener;>;
           35   36    14              listener  Lorg/hibernate/event/spi/PreLoadEventListener;
           39  109    13               factory  Lorg/hibernate/engine/spi/SessionFactoryImplementor;
           46   77    14               version  Ljava/lang/Object;
           47   77    15                 entry  Lorg/hibernate/cache/spi/entry/CacheEntry;
           48   77    16                 cache  Lorg/hibernate/cache/spi/access/EntityDataAccess;
           49   77    17              cacheKey  Ljava/lang/Object;
           59   77    18  eventListenerManager  Lorg/hibernate/engine/spi/SessionEventListenerManager;
           67   72    19                   put  Z
           84  109    14      isReallyReadOnly  Z
           88   90    15                 proxy  Ljava/lang/Object;
      Exception table:
        from    to  target  type
          59    73      73  any
    Exceptions:
      throws org.hibernate.HibernateException
    MethodParameters:
              Name  Flags
      entity        final
      entityEntry   final
      readOnly      final
      session       final
      preLoadEvent  final

  private static java.lang.Boolean getOverridingEager(org.hibernate.engine.spi.SharedSessionContractImplementor, java.lang.String, java.lang.String, org.hibernate.type.Type);
    descriptor: (Lorg/hibernate/engine/spi/SharedSessionContractImplementor;Ljava/lang/String;Ljava/lang/String;Lorg/hibernate/type/Type;)Ljava/lang/Boolean;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=5, args_size=4
        start local 0 // org.hibernate.engine.spi.SharedSessionContractImplementor session
        start local 1 // java.lang.String entityName
        start local 2 // java.lang.String associationName
        start local 3 // org.hibernate.type.Type type
         0: .line 315
            aload 3 /* type */
            invokeinterface org.hibernate.type.Type.isAssociationType:()Z
            ifne 1
            aload 3 /* type */
            invokeinterface org.hibernate.type.Type.isCollectionType:()Z
            ifeq 11
         1: .line 316
      StackMap locals:
      StackMap stack:
            aload 0 /* session */
            new java.lang.StringBuilder
            dup
            aload 1 /* entityName */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc "."
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 2 /* associationName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic org.hibernate.engine.internal.TwoPhaseLoad.isEagerFetchProfile:(Lorg/hibernate/engine/spi/SharedSessionContractImplementor;Ljava/lang/String;)Ljava/lang/Boolean;
            astore 4 /* overridingEager */
        start local 4 // java.lang.Boolean overridingEager
         2: .line 318
            getstatic org.hibernate.engine.internal.TwoPhaseLoad.LOG:Lorg/hibernate/internal/CoreMessageLogger;
            invokeinterface org.hibernate.internal.CoreMessageLogger.isDebugEnabled:()Z
            ifeq 10
         3: .line 319
            aload 4 /* overridingEager */
            ifnull 10
         4: .line 320
            getstatic org.hibernate.engine.internal.TwoPhaseLoad.LOG:Lorg/hibernate/internal/CoreMessageLogger;
         5: .line 321
            ldc "Overriding eager fetching using active fetch profile. EntityName: %s, associationName: %s, eager fetching: %s"
         6: .line 322
            aload 1 /* entityName */
         7: .line 323
            aload 2 /* associationName */
         8: .line 324
            aload 4 /* overridingEager */
         9: .line 320
            invokeinterface org.hibernate.internal.CoreMessageLogger.debugf:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
        10: .line 329
      StackMap locals: java.lang.Boolean
      StackMap stack:
            aload 4 /* overridingEager */
            areturn
        end local 4 // java.lang.Boolean overridingEager
        11: .line 331
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 3 // org.hibernate.type.Type type
        end local 2 // java.lang.String associationName
        end local 1 // java.lang.String entityName
        end local 0 // org.hibernate.engine.spi.SharedSessionContractImplementor session
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   12     0          session  Lorg/hibernate/engine/spi/SharedSessionContractImplementor;
            0   12     1       entityName  Ljava/lang/String;
            0   12     2  associationName  Ljava/lang/String;
            0   12     3             type  Lorg/hibernate/type/Type;
            2   11     4  overridingEager  Ljava/lang/Boolean;
    MethodParameters:
                 Name  Flags
      session          
      entityName       
      associationName  
      type             

  private static java.lang.Boolean isEagerFetchProfile(org.hibernate.engine.spi.SharedSessionContractImplementor, java.lang.String);
    descriptor: (Lorg/hibernate/engine/spi/SharedSessionContractImplementor;Ljava/lang/String;)Ljava/lang/Boolean;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=7, args_size=2
        start local 0 // org.hibernate.engine.spi.SharedSessionContractImplementor session
        start local 1 // java.lang.String role
         0: .line 335
            aload 0 /* session */
            invokeinterface org.hibernate.engine.spi.SharedSessionContractImplementor.getLoadQueryInfluencers:()Lorg/hibernate/engine/spi/LoadQueryInfluencers;
            astore 2 /* loadQueryInfluencers */
        start local 2 // org.hibernate.engine.spi.LoadQueryInfluencers loadQueryInfluencers
         1: .line 337
            aload 2 /* loadQueryInfluencers */
            invokevirtual org.hibernate.engine.spi.LoadQueryInfluencers.getEnabledFetchProfileNames:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 4
            goto 7
      StackMap locals: org.hibernate.engine.spi.SharedSessionContractImplementor java.lang.String org.hibernate.engine.spi.LoadQueryInfluencers top java.util.Iterator
      StackMap stack:
         2: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.lang.String
            astore 3 /* fetchProfileName */
        start local 3 // java.lang.String fetchProfileName
         3: .line 338
            aload 0 /* session */
            invokeinterface org.hibernate.engine.spi.SharedSessionContractImplementor.getFactory:()Lorg/hibernate/engine/spi/SessionFactoryImplementor;
            aload 3 /* fetchProfileName */
            invokeinterface org.hibernate.engine.spi.SessionFactoryImplementor.getFetchProfile:(Ljava/lang/String;)Lorg/hibernate/engine/profile/FetchProfile;
            astore 5 /* fp */
        start local 5 // org.hibernate.engine.profile.FetchProfile fp
         4: .line 339
            aload 5 /* fp */
            aload 1 /* role */
            invokevirtual org.hibernate.engine.profile.FetchProfile.getFetchByRole:(Ljava/lang/String;)Lorg/hibernate/engine/profile/Fetch;
            astore 6 /* fetch */
        start local 6 // org.hibernate.engine.profile.Fetch fetch
         5: .line 340
            aload 6 /* fetch */
            ifnull 7
            getstatic org.hibernate.engine.profile.Fetch$Style.JOIN:Lorg/hibernate/engine/profile/Fetch$Style;
            aload 6 /* fetch */
            invokevirtual org.hibernate.engine.profile.Fetch.getStyle:()Lorg/hibernate/engine/profile/Fetch$Style;
            if_acmpne 7
         6: .line 341
            iconst_1
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            areturn
        end local 6 // org.hibernate.engine.profile.Fetch fetch
        end local 5 // org.hibernate.engine.profile.FetchProfile fp
        end local 3 // java.lang.String fetchProfileName
         7: .line 337
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         8: .line 345
            aconst_null
            areturn
        end local 2 // org.hibernate.engine.spi.LoadQueryInfluencers loadQueryInfluencers
        end local 1 // java.lang.String role
        end local 0 // org.hibernate.engine.spi.SharedSessionContractImplementor session
      LocalVariableTable:
        Start  End  Slot                  Name  Signature
            0    9     0               session  Lorg/hibernate/engine/spi/SharedSessionContractImplementor;
            0    9     1                  role  Ljava/lang/String;
            1    9     2  loadQueryInfluencers  Lorg/hibernate/engine/spi/LoadQueryInfluencers;
            3    7     3      fetchProfileName  Ljava/lang/String;
            4    7     5                    fp  Lorg/hibernate/engine/profile/FetchProfile;
            5    7     6                 fetch  Lorg/hibernate/engine/profile/Fetch;
    MethodParameters:
         Name  Flags
      session  
      role     

  public static void postLoad(java.lang.Object, org.hibernate.engine.spi.SharedSessionContractImplementor, org.hibernate.event.spi.PostLoadEvent);
    descriptor: (Ljava/lang/Object;Lorg/hibernate/engine/spi/SharedSessionContractImplementor;Lorg/hibernate/event/spi/PostLoadEvent;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=2, locals=8, args_size=3
        start local 0 // java.lang.Object entity
        start local 1 // org.hibernate.engine.spi.SharedSessionContractImplementor session
        start local 2 // org.hibernate.event.spi.PostLoadEvent postLoadEvent
         0: .line 365
            aload 1 /* session */
            invokeinterface org.hibernate.engine.spi.SharedSessionContractImplementor.isEventSource:()Z
            ifeq 14
         1: .line 367
            aload 1 /* session */
            invokeinterface org.hibernate.engine.spi.SharedSessionContractImplementor.getPersistenceContext:()Lorg/hibernate/engine/spi/PersistenceContext;
         2: .line 366
            astore 3 /* persistenceContext */
        start local 3 // org.hibernate.engine.spi.PersistenceContext persistenceContext
         3: .line 368
            aload 3 /* persistenceContext */
            aload 0 /* entity */
            invokeinterface org.hibernate.engine.spi.PersistenceContext.getEntry:(Ljava/lang/Object;)Lorg/hibernate/engine/spi/EntityEntry;
            astore 4 /* entityEntry */
        start local 4 // org.hibernate.engine.spi.EntityEntry entityEntry
         4: .line 370
            aload 2 /* postLoadEvent */
            aload 0 /* entity */
            invokevirtual org.hibernate.event.spi.PostLoadEvent.setEntity:(Ljava/lang/Object;)Lorg/hibernate/event/spi/PostLoadEvent;
            aload 4 /* entityEntry */
            invokeinterface org.hibernate.engine.spi.EntityEntry.getId:()Ljava/io/Serializable;
            invokevirtual org.hibernate.event.spi.PostLoadEvent.setId:(Ljava/io/Serializable;)Lorg/hibernate/event/spi/PostLoadEvent;
            aload 4 /* entityEntry */
            invokeinterface org.hibernate.engine.spi.EntityEntry.getPersister:()Lorg/hibernate/persister/entity/EntityPersister;
            invokevirtual org.hibernate.event.spi.PostLoadEvent.setPersister:(Lorg/hibernate/persister/entity/EntityPersister;)Lorg/hibernate/event/spi/PostLoadEvent;
            pop
         5: .line 372
            aload 1 /* session */
            invokeinterface org.hibernate.engine.spi.SharedSessionContractImplementor.getFactory:()Lorg/hibernate/engine/spi/SessionFactoryImplementor;
         6: .line 373
            invokeinterface org.hibernate.engine.spi.SessionFactoryImplementor.getServiceRegistry:()Lorg/hibernate/service/spi/ServiceRegistryImplementor;
         7: .line 374
            ldc Lorg/hibernate/event/service/spi/EventListenerRegistry;
            invokeinterface org.hibernate.service.spi.ServiceRegistryImplementor.getService:(Ljava/lang/Class;)Lorg/hibernate/service/Service;
            checkcast org.hibernate.event.service.spi.EventListenerRegistry
         8: .line 375
            getstatic org.hibernate.event.spi.EventType.POST_LOAD:Lorg/hibernate/event/spi/EventType;
            invokeinterface org.hibernate.event.service.spi.EventListenerRegistry.getEventListenerGroup:(Lorg/hibernate/event/spi/EventType;)Lorg/hibernate/event/service/spi/EventListenerGroup;
         9: .line 372
            astore 5 /* listenerGroup */
        start local 5 // org.hibernate.event.service.spi.EventListenerGroup listenerGroup
        10: .line 376
            aload 5 /* listenerGroup */
            invokeinterface org.hibernate.event.service.spi.EventListenerGroup.listeners:()Ljava/lang/Iterable;
            invokeinterface java.lang.Iterable.iterator:()Ljava/util/Iterator;
            astore 7
            goto 13
      StackMap locals: java.lang.Object org.hibernate.engine.spi.SharedSessionContractImplementor org.hibernate.event.spi.PostLoadEvent org.hibernate.engine.spi.PersistenceContext org.hibernate.engine.spi.EntityEntry org.hibernate.event.service.spi.EventListenerGroup top java.util.Iterator
      StackMap stack:
        11: aload 7
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.hibernate.event.spi.PostLoadEventListener
            astore 6 /* listener */
        start local 6 // org.hibernate.event.spi.PostLoadEventListener listener
        12: .line 377
            aload 6 /* listener */
            aload 2 /* postLoadEvent */
            invokeinterface org.hibernate.event.spi.PostLoadEventListener.onPostLoad:(Lorg/hibernate/event/spi/PostLoadEvent;)V
        end local 6 // org.hibernate.event.spi.PostLoadEventListener listener
        13: .line 376
      StackMap locals:
      StackMap stack:
            aload 7
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 11
        end local 5 // org.hibernate.event.service.spi.EventListenerGroup listenerGroup
        end local 4 // org.hibernate.engine.spi.EntityEntry entityEntry
        end local 3 // org.hibernate.engine.spi.PersistenceContext persistenceContext
        14: .line 380
      StackMap locals: java.lang.Object org.hibernate.engine.spi.SharedSessionContractImplementor org.hibernate.event.spi.PostLoadEvent
      StackMap stack:
            return
        end local 2 // org.hibernate.event.spi.PostLoadEvent postLoadEvent
        end local 1 // org.hibernate.engine.spi.SharedSessionContractImplementor session
        end local 0 // java.lang.Object entity
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0   15     0              entity  Ljava/lang/Object;
            0   15     1             session  Lorg/hibernate/engine/spi/SharedSessionContractImplementor;
            0   15     2       postLoadEvent  Lorg/hibernate/event/spi/PostLoadEvent;
            3   14     3  persistenceContext  Lorg/hibernate/engine/spi/PersistenceContext;
            4   14     4         entityEntry  Lorg/hibernate/engine/spi/EntityEntry;
           10   14     5       listenerGroup  Lorg/hibernate/event/service/spi/EventListenerGroup<Lorg/hibernate/event/spi/PostLoadEventListener;>;
           12   13     6            listener  Lorg/hibernate/event/spi/PostLoadEventListener;
    MethodParameters:
               Name  Flags
      entity         final
      session        final
      postLoadEvent  final

  private static boolean useMinimalPuts(org.hibernate.engine.spi.SharedSessionContractImplementor, org.hibernate.engine.spi.EntityEntry);
    descriptor: (Lorg/hibernate/engine/spi/SharedSessionContractImplementor;Lorg/hibernate/engine/spi/EntityEntry;)Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.hibernate.engine.spi.SharedSessionContractImplementor session
        start local 1 // org.hibernate.engine.spi.EntityEntry entityEntry
         0: .line 383
            aload 0 /* session */
            invokeinterface org.hibernate.engine.spi.SharedSessionContractImplementor.getFactory:()Lorg/hibernate/engine/spi/SessionFactoryImplementor;
            invokeinterface org.hibernate.engine.spi.SessionFactoryImplementor.getSessionFactoryOptions:()Lorg/hibernate/boot/spi/SessionFactoryOptions;
            invokeinterface org.hibernate.boot.spi.SessionFactoryOptions.isMinimalPutsEnabled:()Z
            ifeq 3
         1: .line 384
            aload 0 /* session */
            invokeinterface org.hibernate.engine.spi.SharedSessionContractImplementor.getCacheMode:()Lorg/hibernate/CacheMode;
            getstatic org.hibernate.CacheMode.REFRESH:Lorg/hibernate/CacheMode;
            if_acmpeq 2
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         2: iconst_0
            ireturn
         3: .line 387
      StackMap locals:
      StackMap stack:
            aload 1 /* entityEntry */
            invokeinterface org.hibernate.engine.spi.EntityEntry.getPersister:()Lorg/hibernate/persister/entity/EntityPersister;
            invokeinterface org.hibernate.persister.entity.EntityPersister.hasLazyProperties:()Z
            ifeq 6
         4: .line 388
            aload 1 /* entityEntry */
            invokeinterface org.hibernate.engine.spi.EntityEntry.getPersister:()Lorg/hibernate/persister/entity/EntityPersister;
            invokeinterface org.hibernate.persister.entity.EntityPersister.isLazyPropertiesCacheable:()Z
            ifeq 6
         5: .line 387
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         6: iconst_0
            ireturn
        end local 1 // org.hibernate.engine.spi.EntityEntry entityEntry
        end local 0 // org.hibernate.engine.spi.SharedSessionContractImplementor session
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    7     0      session  Lorg/hibernate/engine/spi/SharedSessionContractImplementor;
            0    7     1  entityEntry  Lorg/hibernate/engine/spi/EntityEntry;
    MethodParameters:
             Name  Flags
      session      
      entityEntry  

  public static void addUninitializedEntity(org.hibernate.engine.spi.EntityKey, java.lang.Object, org.hibernate.persister.entity.EntityPersister, org.hibernate.LockMode, org.hibernate.engine.spi.SharedSessionContractImplementor);
    descriptor: (Lorg/hibernate/engine/spi/EntityKey;Ljava/lang/Object;Lorg/hibernate/persister/entity/EntityPersister;Lorg/hibernate/LockMode;Lorg/hibernate/engine/spi/SharedSessionContractImplementor;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=10, locals=5, args_size=5
        start local 0 // org.hibernate.engine.spi.EntityKey key
        start local 1 // java.lang.Object object
        start local 2 // org.hibernate.persister.entity.EntityPersister persister
        start local 3 // org.hibernate.LockMode lockMode
        start local 4 // org.hibernate.engine.spi.SharedSessionContractImplementor session
         0: .line 411
            aload 4 /* session */
            invokeinterface org.hibernate.engine.spi.SharedSessionContractImplementor.getPersistenceContext:()Lorg/hibernate/engine/spi/PersistenceContext;
         1: .line 412
            aload 1 /* object */
         2: .line 413
            getstatic org.hibernate.engine.spi.Status.LOADING:Lorg/hibernate/engine/spi/Status;
         3: .line 414
            aconst_null
         4: .line 415
            aload 0 /* key */
         5: .line 416
            aconst_null
         6: .line 417
            aload 3 /* lockMode */
         7: .line 418
            iconst_1
         8: .line 419
            aload 2 /* persister */
         9: .line 420
            iconst_0
        10: .line 411
            invokeinterface org.hibernate.engine.spi.PersistenceContext.addEntity:(Ljava/lang/Object;Lorg/hibernate/engine/spi/Status;[Ljava/lang/Object;Lorg/hibernate/engine/spi/EntityKey;Ljava/lang/Object;Lorg/hibernate/LockMode;ZLorg/hibernate/persister/entity/EntityPersister;Z)Lorg/hibernate/engine/spi/EntityEntry;
            pop
        11: .line 422
            return
        end local 4 // org.hibernate.engine.spi.SharedSessionContractImplementor session
        end local 3 // org.hibernate.LockMode lockMode
        end local 2 // org.hibernate.persister.entity.EntityPersister persister
        end local 1 // java.lang.Object object
        end local 0 // org.hibernate.engine.spi.EntityKey key
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   12     0        key  Lorg/hibernate/engine/spi/EntityKey;
            0   12     1     object  Ljava/lang/Object;
            0   12     2  persister  Lorg/hibernate/persister/entity/EntityPersister;
            0   12     3   lockMode  Lorg/hibernate/LockMode;
            0   12     4    session  Lorg/hibernate/engine/spi/SharedSessionContractImplementor;
    MethodParameters:
           Name  Flags
      key        final
      object     final
      persister  final
      lockMode   final
      session    final

  public static void addUninitializedCachedEntity(org.hibernate.engine.spi.EntityKey, java.lang.Object, org.hibernate.persister.entity.EntityPersister, org.hibernate.LockMode, java.lang.Object, org.hibernate.engine.spi.SharedSessionContractImplementor);
    descriptor: (Lorg/hibernate/engine/spi/EntityKey;Ljava/lang/Object;Lorg/hibernate/persister/entity/EntityPersister;Lorg/hibernate/LockMode;Ljava/lang/Object;Lorg/hibernate/engine/spi/SharedSessionContractImplementor;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=10, locals=6, args_size=6
        start local 0 // org.hibernate.engine.spi.EntityKey key
        start local 1 // java.lang.Object object
        start local 2 // org.hibernate.persister.entity.EntityPersister persister
        start local 3 // org.hibernate.LockMode lockMode
        start local 4 // java.lang.Object version
        start local 5 // org.hibernate.engine.spi.SharedSessionContractImplementor session
         0: .line 441
            aload 5 /* session */
            invokeinterface org.hibernate.engine.spi.SharedSessionContractImplementor.getPersistenceContext:()Lorg/hibernate/engine/spi/PersistenceContext;
         1: .line 442
            aload 1 /* object */
         2: .line 443
            getstatic org.hibernate.engine.spi.Status.LOADING:Lorg/hibernate/engine/spi/Status;
         3: .line 444
            aconst_null
         4: .line 445
            aload 0 /* key */
         5: .line 446
            aload 4 /* version */
         6: .line 447
            aload 3 /* lockMode */
         7: .line 448
            iconst_1
         8: .line 449
            aload 2 /* persister */
         9: .line 450
            iconst_0
        10: .line 441
            invokeinterface org.hibernate.engine.spi.PersistenceContext.addEntity:(Ljava/lang/Object;Lorg/hibernate/engine/spi/Status;[Ljava/lang/Object;Lorg/hibernate/engine/spi/EntityKey;Ljava/lang/Object;Lorg/hibernate/LockMode;ZLorg/hibernate/persister/entity/EntityPersister;Z)Lorg/hibernate/engine/spi/EntityEntry;
            pop
        11: .line 452
            return
        end local 5 // org.hibernate.engine.spi.SharedSessionContractImplementor session
        end local 4 // java.lang.Object version
        end local 3 // org.hibernate.LockMode lockMode
        end local 2 // org.hibernate.persister.entity.EntityPersister persister
        end local 1 // java.lang.Object object
        end local 0 // org.hibernate.engine.spi.EntityKey key
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   12     0        key  Lorg/hibernate/engine/spi/EntityKey;
            0   12     1     object  Ljava/lang/Object;
            0   12     2  persister  Lorg/hibernate/persister/entity/EntityPersister;
            0   12     3   lockMode  Lorg/hibernate/LockMode;
            0   12     4    version  Ljava/lang/Object;
            0   12     5    session  Lorg/hibernate/engine/spi/SharedSessionContractImplementor;
    MethodParameters:
           Name  Flags
      key        final
      object     final
      persister  final
      lockMode   final
      version    final
      session    final
}
SourceFile: "TwoPhaseLoad.java"
InnerClasses:
  public final Style = org.hibernate.engine.profile.Fetch$Style of org.hibernate.engine.profile.Fetch
  public abstract NaturalIdHelper = org.hibernate.engine.spi.PersistenceContext$NaturalIdHelper of org.hibernate.engine.spi.PersistenceContext