public class org.apache.logging.log4j.core.impl.ThreadContextDataInjector$ForDefaultThreadContextMap implements org.apache.logging.log4j.core.ContextDataInjector
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.apache.logging.log4j.core.impl.ThreadContextDataInjector$ForDefaultThreadContextMap
  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.ThreadContextDataInjector$ForDefaultThreadContextMap this
         0: .line 53
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // org.apache.logging.log4j.core.impl.ThreadContextDataInjector$ForDefaultThreadContextMap this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/impl/ThreadContextDataInjector$ForDefaultThreadContextMap;

  public org.apache.logging.log4j.util.StringMap injectContextData(java.util.List<org.apache.logging.log4j.core.config.Property>, org.apache.logging.log4j.util.StringMap);
    descriptor: (Ljava/util/List;Lorg/apache/logging/log4j/util/StringMap;)Lorg/apache/logging/log4j/util/StringMap;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=7, args_size=3
        start local 0 // org.apache.logging.log4j.core.impl.ThreadContextDataInjector$ForDefaultThreadContextMap this
        start local 1 // java.util.List props
        start local 2 // org.apache.logging.log4j.util.StringMap ignore
         0: .line 66
            invokestatic org.apache.logging.log4j.ThreadContext.getImmutableContext:()Ljava/util/Map;
            astore 3 /* copy */
        start local 3 // java.util.Map copy
         1: .line 72
            aload 1 /* props */
            ifnull 2
            aload 1 /* props */
            invokeinterface java.util.List.isEmpty:()Z
            ifeq 5
         2: .line 75
      StackMap locals: java.util.Map
      StackMap stack:
            aload 3 /* copy */
            invokeinterface java.util.Map.isEmpty:()Z
            ifeq 3
            invokestatic org.apache.logging.log4j.core.impl.ContextDataFactory.emptyFrozenContextData:()Lorg/apache/logging/log4j/util/StringMap;
            goto 4
      StackMap locals:
      StackMap stack:
         3: aload 3 /* copy */
            invokestatic org.apache.logging.log4j.core.impl.ThreadContextDataInjector$ForDefaultThreadContextMap.frozenStringMap:(Ljava/util/Map;)Lorg/apache/logging/log4j/core/impl/JdkMapAdapterStringMap;
      StackMap locals:
      StackMap stack: org.apache.logging.log4j.util.StringMap
         4: areturn
         5: .line 81
      StackMap locals:
      StackMap stack:
            new org.apache.logging.log4j.core.impl.JdkMapAdapterStringMap
            dup
            new java.util.HashMap
            dup
            aload 3 /* copy */
            invokespecial java.util.HashMap.<init>:(Ljava/util/Map;)V
            invokespecial org.apache.logging.log4j.core.impl.JdkMapAdapterStringMap.<init>:(Ljava/util/Map;)V
            astore 4 /* result */
        start local 4 // org.apache.logging.log4j.util.StringMap result
         6: .line 82
            iconst_0
            istore 5 /* i */
        start local 5 // int i
         7: goto 12
         8: .line 83
      StackMap locals: org.apache.logging.log4j.util.StringMap int
      StackMap stack:
            aload 1 /* props */
            iload 5 /* i */
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast org.apache.logging.log4j.core.config.Property
            astore 6 /* prop */
        start local 6 // org.apache.logging.log4j.core.config.Property prop
         9: .line 84
            aload 3 /* copy */
            aload 6 /* prop */
            invokevirtual org.apache.logging.log4j.core.config.Property.getName:()Ljava/lang/String;
            invokeinterface java.util.Map.containsKey:(Ljava/lang/Object;)Z
            ifne 11
        10: .line 85
            aload 4 /* result */
            aload 6 /* prop */
            invokevirtual org.apache.logging.log4j.core.config.Property.getName:()Ljava/lang/String;
            aload 6 /* prop */
            invokevirtual org.apache.logging.log4j.core.config.Property.getValue:()Ljava/lang/String;
            invokeinterface org.apache.logging.log4j.util.StringMap.putValue:(Ljava/lang/String;Ljava/lang/Object;)V
        end local 6 // org.apache.logging.log4j.core.config.Property prop
        11: .line 82
      StackMap locals:
      StackMap stack:
            iinc 5 /* i */ 1
      StackMap locals:
      StackMap stack:
        12: iload 5 /* i */
            aload 1 /* props */
            invokeinterface java.util.List.size:()I
            if_icmplt 8
        end local 5 // int i
        13: .line 88
            aload 4 /* result */
            invokeinterface org.apache.logging.log4j.util.StringMap.freeze:()V
        14: .line 89
            aload 4 /* result */
            areturn
        end local 4 // org.apache.logging.log4j.util.StringMap result
        end local 3 // java.util.Map copy
        end local 2 // org.apache.logging.log4j.util.StringMap ignore
        end local 1 // java.util.List props
        end local 0 // org.apache.logging.log4j.core.impl.ThreadContextDataInjector$ForDefaultThreadContextMap this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   15     0    this  Lorg/apache/logging/log4j/core/impl/ThreadContextDataInjector$ForDefaultThreadContextMap;
            0   15     1   props  Ljava/util/List<Lorg/apache/logging/log4j/core/config/Property;>;
            0   15     2  ignore  Lorg/apache/logging/log4j/util/StringMap;
            1   15     3    copy  Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;
            6   15     4  result  Lorg/apache/logging/log4j/util/StringMap;
            7   13     5       i  I
            9   11     6    prop  Lorg/apache/logging/log4j/core/config/Property;
    Signature: (Ljava/util/List<Lorg/apache/logging/log4j/core/config/Property;>;Lorg/apache/logging/log4j/util/StringMap;)Lorg/apache/logging/log4j/util/StringMap;
    MethodParameters:
        Name  Flags
      props   final
      ignore  final

  private static org.apache.logging.log4j.core.impl.JdkMapAdapterStringMap frozenStringMap(java.util.Map<java.lang.String, java.lang.String>);
    descriptor: (Ljava/util/Map;)Lorg/apache/logging/log4j/core/impl/JdkMapAdapterStringMap;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // java.util.Map copy
         0: .line 93
            new org.apache.logging.log4j.core.impl.JdkMapAdapterStringMap
            dup
            aload 0 /* copy */
            invokespecial org.apache.logging.log4j.core.impl.JdkMapAdapterStringMap.<init>:(Ljava/util/Map;)V
            astore 1 /* result */
        start local 1 // org.apache.logging.log4j.core.impl.JdkMapAdapterStringMap result
         1: .line 94
            aload 1 /* result */
            invokevirtual org.apache.logging.log4j.core.impl.JdkMapAdapterStringMap.freeze:()V
         2: .line 95
            aload 1 /* result */
            areturn
        end local 1 // org.apache.logging.log4j.core.impl.JdkMapAdapterStringMap result
        end local 0 // java.util.Map copy
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    3     0    copy  Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;
            1    3     1  result  Lorg/apache/logging/log4j/core/impl/JdkMapAdapterStringMap;
    Signature: (Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;)Lorg/apache/logging/log4j/core/impl/JdkMapAdapterStringMap;
    MethodParameters:
      Name  Flags
      copy  final

  public org.apache.logging.log4j.util.ReadOnlyStringMap rawContextData();
    descriptor: ()Lorg/apache/logging/log4j/util/ReadOnlyStringMap;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=1
        start local 0 // org.apache.logging.log4j.core.impl.ThreadContextDataInjector$ForDefaultThreadContextMap this
         0: .line 100
            invokestatic org.apache.logging.log4j.ThreadContext.getThreadContextMap:()Lorg/apache/logging/log4j/spi/ReadOnlyThreadContextMap;
            astore 1 /* map */
        start local 1 // org.apache.logging.log4j.spi.ReadOnlyThreadContextMap map
         1: .line 101
            aload 1 /* map */
            instanceof org.apache.logging.log4j.util.ReadOnlyStringMap
            ifeq 3
         2: .line 102
            aload 1 /* map */
            checkcast org.apache.logging.log4j.util.ReadOnlyStringMap
            areturn
         3: .line 105
      StackMap locals: org.apache.logging.log4j.spi.ReadOnlyThreadContextMap
      StackMap stack:
            invokestatic org.apache.logging.log4j.ThreadContext.getImmutableContext:()Ljava/util/Map;
            astore 2 /* copy */
        start local 2 // java.util.Map copy
         4: .line 106
            aload 2 /* copy */
            invokeinterface java.util.Map.isEmpty:()Z
            ifeq 5
            invokestatic org.apache.logging.log4j.core.impl.ContextDataFactory.emptyFrozenContextData:()Lorg/apache/logging/log4j/util/StringMap;
            goto 6
      StackMap locals: java.util.Map
      StackMap stack:
         5: new org.apache.logging.log4j.core.impl.JdkMapAdapterStringMap
            dup
            aload 2 /* copy */
            invokespecial org.apache.logging.log4j.core.impl.JdkMapAdapterStringMap.<init>:(Ljava/util/Map;)V
      StackMap locals:
      StackMap stack: org.apache.logging.log4j.util.StringMap
         6: areturn
        end local 2 // java.util.Map copy
        end local 1 // org.apache.logging.log4j.spi.ReadOnlyThreadContextMap map
        end local 0 // org.apache.logging.log4j.core.impl.ThreadContextDataInjector$ForDefaultThreadContextMap this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lorg/apache/logging/log4j/core/impl/ThreadContextDataInjector$ForDefaultThreadContextMap;
            1    7     1   map  Lorg/apache/logging/log4j/spi/ReadOnlyThreadContextMap;
            4    7     2  copy  Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;
}
SourceFile: "ThreadContextDataInjector.java"
NestHost: org.apache.logging.log4j.core.impl.ThreadContextDataInjector
InnerClasses:
  public ForDefaultThreadContextMap = org.apache.logging.log4j.core.impl.ThreadContextDataInjector$ForDefaultThreadContextMap of org.apache.logging.log4j.core.impl.ThreadContextDataInjector