public class org.apache.logging.log4j.core.impl.ContextDataInjectorFactory
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.apache.logging.log4j.core.impl.ContextDataInjectorFactory
  super_class: java.lang.Object
{
  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.impl.ContextDataInjectorFactory this
         0: .line 43
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // org.apache.logging.log4j.core.impl.ContextDataInjectorFactory this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/impl/ContextDataInjectorFactory;

  public static org.apache.logging.log4j.core.ContextDataInjector createInjector();
    descriptor: ()Lorg/apache/logging/log4j/core/ContextDataInjector;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=5, locals=3, args_size=0
         0: .line 65
            invokestatic org.apache.logging.log4j.util.PropertiesUtil.getProperties:()Lorg/apache/logging/log4j/util/PropertiesUtil;
            ldc "log4j2.ContextDataInjector"
            invokevirtual org.apache.logging.log4j.util.PropertiesUtil.getStringProperty:(Ljava/lang/String;)Ljava/lang/String;
            astore 0 /* className */
        start local 0 // java.lang.String className
         1: .line 66
            aload 0 /* className */
            ifnonnull 3
         2: .line 67
            invokestatic org.apache.logging.log4j.core.impl.ContextDataInjectorFactory.createDefaultInjector:()Lorg/apache/logging/log4j/core/ContextDataInjector;
            areturn
         3: .line 70
      StackMap locals: java.lang.String
      StackMap stack:
            aload 0 /* className */
            invokestatic org.apache.logging.log4j.core.util.Loader.loadClass:(Ljava/lang/String;)Ljava/lang/Class;
         4: .line 71
            ldc Lorg/apache/logging/log4j/core/ContextDataInjector;
         5: .line 70
            invokevirtual java.lang.Class.asSubclass:(Ljava/lang/Class;)Ljava/lang/Class;
            astore 1 /* cls */
        start local 1 // java.lang.Class cls
         6: .line 72
            aload 1 /* cls */
            invokevirtual java.lang.Class.newInstance:()Ljava/lang/Object;
            checkcast org.apache.logging.log4j.core.ContextDataInjector
         7: areturn
        end local 1 // java.lang.Class cls
         8: .line 73
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 1 /* dynamicFailed */
        start local 1 // java.lang.Exception dynamicFailed
         9: .line 74
            invokestatic org.apache.logging.log4j.core.impl.ContextDataInjectorFactory.createDefaultInjector:()Lorg/apache/logging/log4j/core/ContextDataInjector;
            astore 2 /* result */
        start local 2 // org.apache.logging.log4j.core.ContextDataInjector result
        10: .line 75
            invokestatic org.apache.logging.log4j.status.StatusLogger.getLogger:()Lorg/apache/logging/log4j/status/StatusLogger;
        11: .line 76
            ldc "Could not create ContextDataInjector for '{}', using default {}: {}"
        12: .line 77
            aload 0 /* className */
            aload 2 /* result */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            aload 1 /* dynamicFailed */
        13: .line 75
            invokevirtual org.apache.logging.log4j.status.StatusLogger.warn:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
        14: .line 78
            aload 2 /* result */
            areturn
        end local 2 // org.apache.logging.log4j.core.ContextDataInjector result
        end local 1 // java.lang.Exception dynamicFailed
        end local 0 // java.lang.String className
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            1   15     0      className  Ljava/lang/String;
            6    8     1            cls  Ljava/lang/Class<+Lorg/apache/logging/log4j/core/ContextDataInjector;>;
            9   15     1  dynamicFailed  Ljava/lang/Exception;
           10   15     2         result  Lorg/apache/logging/log4j/core/ContextDataInjector;
      Exception table:
        from    to  target  type
           3     7       8  Class java.lang.Exception

  private static org.apache.logging.log4j.core.ContextDataInjector createDefaultInjector();
    descriptor: ()Lorg/apache/logging/log4j/core/ContextDataInjector;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=1, args_size=0
         0: .line 83
            invokestatic org.apache.logging.log4j.ThreadContext.getThreadContextMap:()Lorg/apache/logging/log4j/spi/ReadOnlyThreadContextMap;
            astore 0 /* threadContextMap */
        start local 0 // org.apache.logging.log4j.spi.ReadOnlyThreadContextMap threadContextMap
         1: .line 86
            aload 0 /* threadContextMap */
            instanceof org.apache.logging.log4j.spi.DefaultThreadContextMap
            ifne 2
            aload 0 /* threadContextMap */
            ifnonnull 3
         2: .line 87
      StackMap locals: org.apache.logging.log4j.spi.ReadOnlyThreadContextMap
      StackMap stack:
            new org.apache.logging.log4j.core.impl.ThreadContextDataInjector$ForDefaultThreadContextMap
            dup
            invokespecial org.apache.logging.log4j.core.impl.ThreadContextDataInjector$ForDefaultThreadContextMap.<init>:()V
            areturn
         3: .line 89
      StackMap locals:
      StackMap stack:
            aload 0 /* threadContextMap */
            instanceof org.apache.logging.log4j.spi.CopyOnWrite
            ifeq 5
         4: .line 90
            new org.apache.logging.log4j.core.impl.ThreadContextDataInjector$ForCopyOnWriteThreadContextMap
            dup
            invokespecial org.apache.logging.log4j.core.impl.ThreadContextDataInjector$ForCopyOnWriteThreadContextMap.<init>:()V
            areturn
         5: .line 92
      StackMap locals:
      StackMap stack:
            new org.apache.logging.log4j.core.impl.ThreadContextDataInjector$ForGarbageFreeThreadContextMap
            dup
            invokespecial org.apache.logging.log4j.core.impl.ThreadContextDataInjector$ForGarbageFreeThreadContextMap.<init>:()V
            areturn
        end local 0 // org.apache.logging.log4j.spi.ReadOnlyThreadContextMap threadContextMap
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            1    6     0  threadContextMap  Lorg/apache/logging/log4j/spi/ReadOnlyThreadContextMap;
}
SourceFile: "ContextDataInjectorFactory.java"
InnerClasses:
  public ForCopyOnWriteThreadContextMap = org.apache.logging.log4j.core.impl.ThreadContextDataInjector$ForCopyOnWriteThreadContextMap of org.apache.logging.log4j.core.impl.ThreadContextDataInjector
  public ForDefaultThreadContextMap = org.apache.logging.log4j.core.impl.ThreadContextDataInjector$ForDefaultThreadContextMap of org.apache.logging.log4j.core.impl.ThreadContextDataInjector
  public ForGarbageFreeThreadContextMap = org.apache.logging.log4j.core.impl.ThreadContextDataInjector$ForGarbageFreeThreadContextMap of org.apache.logging.log4j.core.impl.ThreadContextDataInjector