public class org.apache.logging.log4j.core.impl.ThreadContextDataInjector$ForCopyOnWriteThreadContextMap 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$ForCopyOnWriteThreadContextMap
  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$ForCopyOnWriteThreadContextMap this
         0: .line 151
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // org.apache.logging.log4j.core.impl.ThreadContextDataInjector$ForCopyOnWriteThreadContextMap this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/impl/ThreadContextDataInjector$ForCopyOnWriteThreadContextMap;

  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=2, locals=5, args_size=3
        start local 0 // org.apache.logging.log4j.core.impl.ThreadContextDataInjector$ForCopyOnWriteThreadContextMap this
        start local 1 // java.util.List props
        start local 2 // org.apache.logging.log4j.util.StringMap ignore
         0: .line 165
            invokestatic org.apache.logging.log4j.ThreadContext.getThreadContextMap:()Lorg/apache/logging/log4j/spi/ReadOnlyThreadContextMap;
            invokeinterface org.apache.logging.log4j.spi.ReadOnlyThreadContextMap.getReadOnlyContextData:()Lorg/apache/logging/log4j/util/StringMap;
            astore 3 /* immutableCopy */
        start local 3 // org.apache.logging.log4j.util.StringMap immutableCopy
         1: .line 166
            aload 1 /* props */
            ifnull 2
            aload 1 /* props */
            invokeinterface java.util.List.isEmpty:()Z
            ifeq 3
         2: .line 167
      StackMap locals: org.apache.logging.log4j.util.StringMap
      StackMap stack:
            aload 3 /* immutableCopy */
            areturn
         3: .line 173
      StackMap locals:
      StackMap stack:
            aload 1 /* props */
            invokeinterface java.util.List.size:()I
            aload 3 /* immutableCopy */
            invokeinterface org.apache.logging.log4j.util.StringMap.size:()I
            iadd
            invokestatic org.apache.logging.log4j.core.impl.ContextDataFactory.createContextData:(I)Lorg/apache/logging/log4j/util/StringMap;
            astore 4 /* result */
        start local 4 // org.apache.logging.log4j.util.StringMap result
         4: .line 174
            aload 1 /* props */
            aload 4 /* result */
            invokestatic org.apache.logging.log4j.core.impl.ThreadContextDataInjector.copyProperties:(Ljava/util/List;Lorg/apache/logging/log4j/util/StringMap;)V
         5: .line 175
            aload 4 /* result */
            aload 3 /* immutableCopy */
            invokeinterface org.apache.logging.log4j.util.StringMap.putAll:(Lorg/apache/logging/log4j/util/ReadOnlyStringMap;)V
         6: .line 176
            aload 4 /* result */
            areturn
        end local 4 // org.apache.logging.log4j.util.StringMap result
        end local 3 // org.apache.logging.log4j.util.StringMap immutableCopy
        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$ForCopyOnWriteThreadContextMap this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    7     0           this  Lorg/apache/logging/log4j/core/impl/ThreadContextDataInjector$ForCopyOnWriteThreadContextMap;
            0    7     1          props  Ljava/util/List<Lorg/apache/logging/log4j/core/config/Property;>;
            0    7     2         ignore  Lorg/apache/logging/log4j/util/StringMap;
            1    7     3  immutableCopy  Lorg/apache/logging/log4j/util/StringMap;
            4    7     4         result  Lorg/apache/logging/log4j/util/StringMap;
    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

  public org.apache.logging.log4j.util.ReadOnlyStringMap rawContextData();
    descriptor: ()Lorg/apache/logging/log4j/util/ReadOnlyStringMap;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.impl.ThreadContextDataInjector$ForCopyOnWriteThreadContextMap this
         0: .line 181
            invokestatic org.apache.logging.log4j.ThreadContext.getThreadContextMap:()Lorg/apache/logging/log4j/spi/ReadOnlyThreadContextMap;
            invokeinterface org.apache.logging.log4j.spi.ReadOnlyThreadContextMap.getReadOnlyContextData:()Lorg/apache/logging/log4j/util/StringMap;
            areturn
        end local 0 // org.apache.logging.log4j.core.impl.ThreadContextDataInjector$ForCopyOnWriteThreadContextMap this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/impl/ThreadContextDataInjector$ForCopyOnWriteThreadContextMap;
}
SourceFile: "ThreadContextDataInjector.java"
NestHost: org.apache.logging.log4j.core.impl.ThreadContextDataInjector
InnerClasses:
  public ForCopyOnWriteThreadContextMap = org.apache.logging.log4j.core.impl.ThreadContextDataInjector$ForCopyOnWriteThreadContextMap of org.apache.logging.log4j.core.impl.ThreadContextDataInjector