public class org.testng.log4testng.Logger
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.testng.log4testng.Logger
  super_class: java.lang.Object
{
  private static int i;
    descriptor: I
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private static final int TRACE;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final int DEBUG;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final int INFO;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final int WARN;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final int ERROR;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final int FATAL;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final int LEVEL_COUNT;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final java.lang.String PREFIX;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "log4testng."

  private static final java.lang.String LOGGER_PREFIX;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "log4testng.logger."

  private static final java.lang.String ROOT_LOGGER;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "log4testng.rootLogger"

  private static final java.lang.String DEBUG_PROPERTY;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "log4testng.debug"

  private static java.io.PrintStream err;
    descriptor: Ljava/io/PrintStream;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private static java.io.PrintStream out;
    descriptor: Ljava/io/PrintStream;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private static final java.lang.String[] levelNames;
    descriptor: [Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final java.util.Map<java.lang.String, java.lang.Integer> levelMap;
    descriptor: Ljava/util/Map;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/Map<Ljava/lang/String;Ljava/lang/Integer;>;

  private static boolean initialized;
    descriptor: Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private static final java.util.Map<java.lang.String, java.lang.Integer> loggerLevels;
    descriptor: Ljava/util/Map;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/Map<Ljava/lang/String;Ljava/lang/Integer;>;

  private static final java.util.Map<java.lang.Class, org.testng.log4testng.Logger> loggers;
    descriptor: Ljava/util/Map;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/Map<Ljava/lang/Class;Lorg/testng/log4testng/Logger;>;

  private static int rootLoggerLevel;
    descriptor: I
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private static boolean debug;
    descriptor: Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private final int level;
    descriptor: I
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.lang.Class klass;
    descriptor: Ljava/lang/Class;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.lang.String m_className;
    descriptor: Ljava/lang/String;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=0, args_size=0
         0: .line 64
            iconst_0
            putstatic org.testng.log4testng.Logger.i:I
         1: .line 65
            getstatic org.testng.log4testng.Logger.i:I
            dup
            iconst_1
            iadd
            putstatic org.testng.log4testng.Logger.i:I
            putstatic org.testng.log4testng.Logger.TRACE:I
         2: .line 66
            getstatic org.testng.log4testng.Logger.i:I
            dup
            iconst_1
            iadd
            putstatic org.testng.log4testng.Logger.i:I
            putstatic org.testng.log4testng.Logger.DEBUG:I
         3: .line 67
            getstatic org.testng.log4testng.Logger.i:I
            dup
            iconst_1
            iadd
            putstatic org.testng.log4testng.Logger.i:I
            putstatic org.testng.log4testng.Logger.INFO:I
         4: .line 68
            getstatic org.testng.log4testng.Logger.i:I
            dup
            iconst_1
            iadd
            putstatic org.testng.log4testng.Logger.i:I
            putstatic org.testng.log4testng.Logger.WARN:I
         5: .line 69
            getstatic org.testng.log4testng.Logger.i:I
            dup
            iconst_1
            iadd
            putstatic org.testng.log4testng.Logger.i:I
            putstatic org.testng.log4testng.Logger.ERROR:I
         6: .line 70
            getstatic org.testng.log4testng.Logger.i:I
            dup
            iconst_1
            iadd
            putstatic org.testng.log4testng.Logger.i:I
            putstatic org.testng.log4testng.Logger.FATAL:I
         7: .line 71
            getstatic org.testng.log4testng.Logger.i:I
            putstatic org.testng.log4testng.Logger.LEVEL_COUNT:I
         8: .line 86
            getstatic java.lang.System.err:Ljava/io/PrintStream;
            putstatic org.testng.log4testng.Logger.err:Ljava/io/PrintStream;
         9: .line 89
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            putstatic org.testng.log4testng.Logger.out:Ljava/io/PrintStream;
        10: .line 92
            getstatic org.testng.log4testng.Logger.LEVEL_COUNT:I
            anewarray java.lang.String
            putstatic org.testng.log4testng.Logger.levelNames:[Ljava/lang/String;
        11: .line 95
            getstatic org.testng.log4testng.Logger.levelNames:[Ljava/lang/String;
            getstatic org.testng.log4testng.Logger.TRACE:I
            ldc "TRACE"
            aastore
        12: .line 96
            getstatic org.testng.log4testng.Logger.levelNames:[Ljava/lang/String;
            getstatic org.testng.log4testng.Logger.DEBUG:I
            ldc "DEBUG"
            aastore
        13: .line 97
            getstatic org.testng.log4testng.Logger.levelNames:[Ljava/lang/String;
            getstatic org.testng.log4testng.Logger.INFO:I
            ldc "INFO"
            aastore
        14: .line 98
            getstatic org.testng.log4testng.Logger.levelNames:[Ljava/lang/String;
            getstatic org.testng.log4testng.Logger.WARN:I
            ldc "WARN"
            aastore
        15: .line 99
            getstatic org.testng.log4testng.Logger.levelNames:[Ljava/lang/String;
            getstatic org.testng.log4testng.Logger.ERROR:I
            ldc "ERROR"
            aastore
        16: .line 100
            getstatic org.testng.log4testng.Logger.levelNames:[Ljava/lang/String;
            getstatic org.testng.log4testng.Logger.FATAL:I
            ldc "FATAL"
            aastore
        17: .line 104
            invokestatic org.testng.collections.Maps.newHashMap:()Ljava/util/Map;
            putstatic org.testng.log4testng.Logger.levelMap:Ljava/util/Map;
        18: .line 107
            iconst_0
            putstatic org.testng.log4testng.Logger.i:I
            goto 21
        19: .line 108
      StackMap locals:
      StackMap stack:
            getstatic org.testng.log4testng.Logger.levelMap:Ljava/util/Map;
            getstatic org.testng.log4testng.Logger.levelNames:[Ljava/lang/String;
            getstatic org.testng.log4testng.Logger.i:I
            aaload
            getstatic org.testng.log4testng.Logger.i:I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        20: .line 107
            getstatic org.testng.log4testng.Logger.i:I
            iconst_1
            iadd
            putstatic org.testng.log4testng.Logger.i:I
      StackMap locals:
      StackMap stack:
        21: getstatic org.testng.log4testng.Logger.i:I
            getstatic org.testng.log4testng.Logger.LEVEL_COUNT:I
            if_icmplt 19
        22: .line 116
            invokestatic org.testng.collections.Maps.newHashMap:()Ljava/util/Map;
            putstatic org.testng.log4testng.Logger.loggerLevels:Ljava/util/Map;
        23: .line 119
            invokestatic org.testng.collections.Maps.newHashMap:()Ljava/util/Map;
            putstatic org.testng.log4testng.Logger.loggers:Ljava/util/Map;
        24: .line 122
            getstatic org.testng.log4testng.Logger.WARN:I
            putstatic org.testng.log4testng.Logger.rootLoggerLevel:I
        25: .line 125
            iconst_0
            putstatic org.testng.log4testng.Logger.debug:Z
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public static synchronized org.testng.log4testng.Logger getLogger(java.lang.Class);
    descriptor: (Ljava/lang/Class;)Lorg/testng/log4testng/Logger;
    flags: (0x0029) ACC_PUBLIC, ACC_STATIC, ACC_SYNCHRONIZED
    Code:
      stack=4, locals=3, args_size=1
        start local 0 // java.lang.Class pClass
         0: .line 145
            invokestatic org.testng.log4testng.Logger.initialize:()V
         1: .line 146
            getstatic org.testng.log4testng.Logger.loggers:Ljava/util/Map;
            aload 0 /* pClass */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.testng.log4testng.Logger
            astore 1 /* logger */
        start local 1 // org.testng.log4testng.Logger logger
         2: .line 147
            aload 1 /* logger */
            ifnull 4
         3: .line 148
            aload 1 /* logger */
            areturn
         4: .line 150
      StackMap locals: org.testng.log4testng.Logger
      StackMap stack:
            aload 0 /* pClass */
            invokestatic org.testng.log4testng.Logger.getLevel:(Ljava/lang/Class;)I
            istore 2 /* level */
        start local 2 // int level
         5: .line 151
            new org.testng.log4testng.Logger
            dup
            aload 0 /* pClass */
            iload 2 /* level */
            invokespecial org.testng.log4testng.Logger.<init>:(Ljava/lang/Class;I)V
            astore 1 /* logger */
         6: .line 152
            getstatic org.testng.log4testng.Logger.loggers:Ljava/util/Map;
            aload 0 /* pClass */
            aload 1 /* logger */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         7: .line 154
            aload 1 /* logger */
            areturn
        end local 2 // int level
        end local 1 // org.testng.log4testng.Logger logger
        end local 0 // java.lang.Class pClass
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    8     0  pClass  Ljava/lang/Class;
            2    8     1  logger  Lorg/testng/log4testng/Logger;
            5    8     2   level  I
    MethodParameters:
        Name  Flags
      pClass  

  public boolean isTraceEnabled();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.testng.log4testng.Logger this
         0: .line 163
            aload 0 /* this */
            getstatic org.testng.log4testng.Logger.TRACE:I
            invokevirtual org.testng.log4testng.Logger.isLevelEnabled:(I)Z
            ireturn
        end local 0 // org.testng.log4testng.Logger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/testng/log4testng/Logger;

  public void trace(java.lang.Object);
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.testng.log4testng.Logger this
        start local 1 // java.lang.Object message
         0: .line 176
            aload 0 /* this */
            getstatic org.testng.log4testng.Logger.TRACE:I
            aload 1 /* message */
            aconst_null
            invokevirtual org.testng.log4testng.Logger.log:(ILjava/lang/Object;Ljava/lang/Throwable;)V
         1: .line 177
            return
        end local 1 // java.lang.Object message
        end local 0 // org.testng.log4testng.Logger this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lorg/testng/log4testng/Logger;
            0    2     1  message  Ljava/lang/Object;
    MethodParameters:
         Name  Flags
      message  

  public void trace(java.lang.Object, java.lang.Throwable);
    descriptor: (Ljava/lang/Object;Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.testng.log4testng.Logger this
        start local 1 // java.lang.Object message
        start local 2 // java.lang.Throwable t
         0: .line 187
            aload 0 /* this */
            getstatic org.testng.log4testng.Logger.TRACE:I
            aload 1 /* message */
            aload 2 /* t */
            invokevirtual org.testng.log4testng.Logger.log:(ILjava/lang/Object;Ljava/lang/Throwable;)V
         1: .line 188
            return
        end local 2 // java.lang.Throwable t
        end local 1 // java.lang.Object message
        end local 0 // org.testng.log4testng.Logger this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lorg/testng/log4testng/Logger;
            0    2     1  message  Ljava/lang/Object;
            0    2     2        t  Ljava/lang/Throwable;
    MethodParameters:
         Name  Flags
      message  
      t        

  public boolean isDebugEnabled();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.testng.log4testng.Logger this
         0: .line 196
            aload 0 /* this */
            getstatic org.testng.log4testng.Logger.DEBUG:I
            invokevirtual org.testng.log4testng.Logger.isLevelEnabled:(I)Z
            ireturn
        end local 0 // org.testng.log4testng.Logger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/testng/log4testng/Logger;

  public void debug(java.lang.Object);
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.testng.log4testng.Logger this
        start local 1 // java.lang.Object message
         0: .line 206
            aload 0 /* this */
            getstatic org.testng.log4testng.Logger.DEBUG:I
            aload 1 /* message */
            aconst_null
            invokevirtual org.testng.log4testng.Logger.log:(ILjava/lang/Object;Ljava/lang/Throwable;)V
         1: .line 207
            return
        end local 1 // java.lang.Object message
        end local 0 // org.testng.log4testng.Logger this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lorg/testng/log4testng/Logger;
            0    2     1  message  Ljava/lang/Object;
    MethodParameters:
         Name  Flags
      message  

  public void debug(java.lang.Object, java.lang.Throwable);
    descriptor: (Ljava/lang/Object;Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.testng.log4testng.Logger this
        start local 1 // java.lang.Object message
        start local 2 // java.lang.Throwable t
         0: .line 217
            aload 0 /* this */
            getstatic org.testng.log4testng.Logger.DEBUG:I
            aload 1 /* message */
            aload 2 /* t */
            invokevirtual org.testng.log4testng.Logger.log:(ILjava/lang/Object;Ljava/lang/Throwable;)V
         1: .line 218
            return
        end local 2 // java.lang.Throwable t
        end local 1 // java.lang.Object message
        end local 0 // org.testng.log4testng.Logger this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lorg/testng/log4testng/Logger;
            0    2     1  message  Ljava/lang/Object;
            0    2     2        t  Ljava/lang/Throwable;
    MethodParameters:
         Name  Flags
      message  
      t        

  public boolean isInfoEnabled();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.testng.log4testng.Logger this
         0: .line 226
            aload 0 /* this */
            getstatic org.testng.log4testng.Logger.INFO:I
            invokevirtual org.testng.log4testng.Logger.isLevelEnabled:(I)Z
            ireturn
        end local 0 // org.testng.log4testng.Logger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/testng/log4testng/Logger;

  public void info(java.lang.Object);
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.testng.log4testng.Logger this
        start local 1 // java.lang.Object message
         0: .line 236
            aload 0 /* this */
            getstatic org.testng.log4testng.Logger.INFO:I
            aload 1 /* message */
            aconst_null
            invokevirtual org.testng.log4testng.Logger.log:(ILjava/lang/Object;Ljava/lang/Throwable;)V
         1: .line 237
            return
        end local 1 // java.lang.Object message
        end local 0 // org.testng.log4testng.Logger this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lorg/testng/log4testng/Logger;
            0    2     1  message  Ljava/lang/Object;
    MethodParameters:
         Name  Flags
      message  

  public void info(java.lang.Object, java.lang.Throwable);
    descriptor: (Ljava/lang/Object;Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.testng.log4testng.Logger this
        start local 1 // java.lang.Object message
        start local 2 // java.lang.Throwable t
         0: .line 247
            aload 0 /* this */
            getstatic org.testng.log4testng.Logger.INFO:I
            aload 1 /* message */
            aload 2 /* t */
            invokevirtual org.testng.log4testng.Logger.log:(ILjava/lang/Object;Ljava/lang/Throwable;)V
         1: .line 248
            return
        end local 2 // java.lang.Throwable t
        end local 1 // java.lang.Object message
        end local 0 // org.testng.log4testng.Logger this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lorg/testng/log4testng/Logger;
            0    2     1  message  Ljava/lang/Object;
            0    2     2        t  Ljava/lang/Throwable;
    MethodParameters:
         Name  Flags
      message  
      t        

  public void warn(java.lang.Object);
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.testng.log4testng.Logger this
        start local 1 // java.lang.Object message
         0: .line 257
            aload 0 /* this */
            getstatic org.testng.log4testng.Logger.WARN:I
            aload 1 /* message */
            aconst_null
            invokevirtual org.testng.log4testng.Logger.log:(ILjava/lang/Object;Ljava/lang/Throwable;)V
         1: .line 258
            return
        end local 1 // java.lang.Object message
        end local 0 // org.testng.log4testng.Logger this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lorg/testng/log4testng/Logger;
            0    2     1  message  Ljava/lang/Object;
    MethodParameters:
         Name  Flags
      message  

  public void warn(java.lang.Object, java.lang.Throwable);
    descriptor: (Ljava/lang/Object;Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.testng.log4testng.Logger this
        start local 1 // java.lang.Object message
        start local 2 // java.lang.Throwable t
         0: .line 268
            aload 0 /* this */
            getstatic org.testng.log4testng.Logger.WARN:I
            aload 1 /* message */
            aload 2 /* t */
            invokevirtual org.testng.log4testng.Logger.log:(ILjava/lang/Object;Ljava/lang/Throwable;)V
         1: .line 269
            return
        end local 2 // java.lang.Throwable t
        end local 1 // java.lang.Object message
        end local 0 // org.testng.log4testng.Logger this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lorg/testng/log4testng/Logger;
            0    2     1  message  Ljava/lang/Object;
            0    2     2        t  Ljava/lang/Throwable;
    MethodParameters:
         Name  Flags
      message  
      t        

  public void error(java.lang.Object);
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.testng.log4testng.Logger this
        start local 1 // java.lang.Object message
         0: .line 278
            aload 0 /* this */
            getstatic org.testng.log4testng.Logger.ERROR:I
            aload 1 /* message */
            aconst_null
            invokevirtual org.testng.log4testng.Logger.log:(ILjava/lang/Object;Ljava/lang/Throwable;)V
         1: .line 279
            return
        end local 1 // java.lang.Object message
        end local 0 // org.testng.log4testng.Logger this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lorg/testng/log4testng/Logger;
            0    2     1  message  Ljava/lang/Object;
    MethodParameters:
         Name  Flags
      message  

  public void error(java.lang.Object, java.lang.Throwable);
    descriptor: (Ljava/lang/Object;Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.testng.log4testng.Logger this
        start local 1 // java.lang.Object message
        start local 2 // java.lang.Throwable t
         0: .line 289
            aload 0 /* this */
            getstatic org.testng.log4testng.Logger.ERROR:I
            aload 1 /* message */
            aload 2 /* t */
            invokevirtual org.testng.log4testng.Logger.log:(ILjava/lang/Object;Ljava/lang/Throwable;)V
         1: .line 290
            return
        end local 2 // java.lang.Throwable t
        end local 1 // java.lang.Object message
        end local 0 // org.testng.log4testng.Logger this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lorg/testng/log4testng/Logger;
            0    2     1  message  Ljava/lang/Object;
            0    2     2        t  Ljava/lang/Throwable;
    MethodParameters:
         Name  Flags
      message  
      t        

  public void fatal(java.lang.Object);
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.testng.log4testng.Logger this
        start local 1 // java.lang.Object message
         0: .line 299
            aload 0 /* this */
            getstatic org.testng.log4testng.Logger.FATAL:I
            aload 1 /* message */
            aconst_null
            invokevirtual org.testng.log4testng.Logger.log:(ILjava/lang/Object;Ljava/lang/Throwable;)V
         1: .line 300
            return
        end local 1 // java.lang.Object message
        end local 0 // org.testng.log4testng.Logger this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lorg/testng/log4testng/Logger;
            0    2     1  message  Ljava/lang/Object;
    MethodParameters:
         Name  Flags
      message  

  public void fatal(java.lang.Object, java.lang.Throwable);
    descriptor: (Ljava/lang/Object;Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.testng.log4testng.Logger this
        start local 1 // java.lang.Object message
        start local 2 // java.lang.Throwable t
         0: .line 310
            aload 0 /* this */
            getstatic org.testng.log4testng.Logger.FATAL:I
            aload 1 /* message */
            aload 2 /* t */
            invokevirtual org.testng.log4testng.Logger.log:(ILjava/lang/Object;Ljava/lang/Throwable;)V
         1: .line 311
            return
        end local 2 // java.lang.Throwable t
        end local 1 // java.lang.Object message
        end local 0 // org.testng.log4testng.Logger this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lorg/testng/log4testng/Logger;
            0    2     1  message  Ljava/lang/Object;
            0    2     2        t  Ljava/lang/Throwable;
    MethodParameters:
         Name  Flags
      message  
      t        

  private void <init>(java.lang.Class, int);
    descriptor: (Ljava/lang/Class;I)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.testng.log4testng.Logger this
        start local 1 // java.lang.Class pClass
        start local 2 // int pLevel
         0: .line 313
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 314
            aload 0 /* this */
            iload 2 /* pLevel */
            putfield org.testng.log4testng.Logger.level:I
         2: .line 315
            aload 0 /* this */
            aload 1 /* pClass */
            putfield org.testng.log4testng.Logger.klass:Ljava/lang/Class;
         3: .line 316
            aload 0 /* this */
            aload 1 /* pClass */
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            aload 1 /* pClass */
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            bipush 46
            invokevirtual java.lang.String.lastIndexOf:(I)I
            iconst_1
            iadd
            invokevirtual java.lang.String.substring:(I)Ljava/lang/String;
            putfield org.testng.log4testng.Logger.m_className:Ljava/lang/String;
         4: .line 317
            return
        end local 2 // int pLevel
        end local 1 // java.lang.Class pClass
        end local 0 // org.testng.log4testng.Logger this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    5     0    this  Lorg/testng/log4testng/Logger;
            0    5     1  pClass  Ljava/lang/Class;
            0    5     2  pLevel  I
    MethodParameters:
        Name  Flags
      pClass  
      pLevel  

  private static synchronized void initialize();
    descriptor: ()V
    flags: (0x002a) ACC_PRIVATE, ACC_STATIC, ACC_SYNCHRONIZED
    Code:
      stack=3, locals=3, args_size=0
         0: .line 320
            getstatic org.testng.log4testng.Logger.initialized:Z
            ifeq 2
         1: .line 321
            return
         2: .line 326
      StackMap locals:
      StackMap stack:
            iconst_1
            putstatic org.testng.log4testng.Logger.initialized:Z
         3: .line 329
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            invokevirtual java.lang.Thread.getContextClassLoader:()Ljava/lang/ClassLoader;
            ldc "log4testng.properties"
            invokevirtual java.lang.ClassLoader.getResourceAsStream:(Ljava/lang/String;)Ljava/io/InputStream;
         4: .line 328
            astore 0 /* is */
        start local 0 // java.io.InputStream is
         5: .line 330
            aload 0 /* is */
            ifnonnull 7
         6: .line 331
            return
         7: .line 333
      StackMap locals: java.io.InputStream
      StackMap stack:
            new java.util.Properties
            dup
            invokespecial java.util.Properties.<init>:()V
            astore 1 /* properties */
        start local 1 // java.util.Properties properties
         8: .line 335
            aload 1 /* properties */
            aload 0 /* is */
            invokevirtual java.util.Properties.load:(Ljava/io/InputStream;)V
         9: .line 336
            goto 12
      StackMap locals: java.io.InputStream java.util.Properties
      StackMap stack: java.io.IOException
        10: astore 2 /* e */
        start local 2 // java.io.IOException e
        11: .line 337
            new java.lang.RuntimeException
            dup
            aload 2 /* e */
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 2 // java.io.IOException e
        12: .line 340
      StackMap locals:
      StackMap stack:
            aload 1 /* properties */
            invokestatic org.testng.log4testng.Logger.checkProperties:(Ljava/util/Properties;)V
        13: .line 341
            return
        end local 1 // java.util.Properties properties
        end local 0 // java.io.InputStream is
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            5   14     0          is  Ljava/io/InputStream;
            8   14     1  properties  Ljava/util/Properties;
           11   12     2           e  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           8     9      10  Class java.io.IOException

  private static void checkProperties(java.util.Properties);
    descriptor: (Ljava/util/Properties;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=6, args_size=1
        start local 0 // java.util.Properties pProperties
         0: .line 346
            aload 0 /* pProperties */
            ldc "log4testng.debug"
            invokevirtual java.util.Properties.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            astore 1 /* debugStr */
        start local 1 // java.lang.String debugStr
         1: .line 347
            aload 1 /* debugStr */
            ifnull 9
         2: .line 348
            aload 1 /* debugStr */
            ldc "true"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 5
         3: .line 349
            iconst_1
            putstatic org.testng.log4testng.Logger.debug:Z
         4: .line 350
            goto 9
      StackMap locals: java.lang.String
      StackMap stack:
         5: aload 1 /* debugStr */
            ldc "false"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 8
         6: .line 351
            iconst_0
            putstatic org.testng.log4testng.Logger.debug:Z
         7: .line 352
            goto 9
         8: .line 353
      StackMap locals:
      StackMap stack:
            new java.lang.IllegalArgumentException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Unknown log4testng.debug value "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* debugStr */
            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
         9: .line 356
      StackMap locals:
      StackMap stack:
            new java.lang.StringBuilder
            dup
            ldc "log4testng.debug set to "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            getstatic org.testng.log4testng.Logger.debug:Z
            invokevirtual java.lang.StringBuilder.append:(Z)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic org.testng.log4testng.Logger.loglog4testng:(Ljava/lang/String;)V
        end local 1 // java.lang.String debugStr
        10: .line 361
            aload 0 /* pProperties */
            ldc "log4testng.rootLogger"
            invokevirtual java.util.Properties.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            astore 1 /* rootLevelStr */
        start local 1 // java.lang.String rootLevelStr
        11: .line 362
            aload 1 /* rootLevelStr */
            ifnull 22
        12: .line 363
            getstatic org.testng.log4testng.Logger.levelMap:Ljava/util/Map;
            aload 1 /* rootLevelStr */
            invokevirtual java.lang.String.toUpperCase:()Ljava/lang/String;
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Integer
            astore 2 /* ilevel */
        start local 2 // java.lang.Integer ilevel
        13: .line 364
            aload 2 /* ilevel */
            ifnonnull 20
        14: .line 365
            new java.lang.IllegalArgumentException
            dup
        15: .line 366
            new java.lang.StringBuilder
            dup
            ldc "Unknown level for log4testng.rootLogger "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        16: .line 367
            aload 1 /* rootLevelStr */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        17: .line 368
            ldc " in log4testng.properties"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        18: .line 366
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        19: .line 365
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        20: .line 370
      StackMap locals: java.lang.Integer
      StackMap stack:
            aload 2 /* ilevel */
            invokevirtual java.lang.Integer.intValue:()I
            putstatic org.testng.log4testng.Logger.rootLoggerLevel:I
        21: .line 371
            new java.lang.StringBuilder
            dup
            ldc "Root level logger set to "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* rootLevelStr */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " level."
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic org.testng.log4testng.Logger.loglog4testng:(Ljava/lang/String;)V
        end local 2 // java.lang.Integer ilevel
        end local 1 // java.lang.String rootLevelStr
        22: .line 375
      StackMap locals:
      StackMap stack:
            aload 0 /* pProperties */
            invokevirtual java.util.Properties.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 1 /* it */
        start local 1 // java.util.Iterator it
        23: .line 376
            goto 40
        24: .line 377
      StackMap locals: java.util.Iterator
      StackMap stack:
            aload 1 /* it */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 2 /* entry */
        start local 2 // java.util.Map$Entry entry
        25: .line 378
            aload 2 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast java.lang.String
            astore 3 /* logger */
        start local 3 // java.lang.String logger
        26: .line 379
            aload 2 /* entry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast java.lang.String
            astore 4 /* level */
        start local 4 // java.lang.String level
        27: .line 381
            aload 3 /* logger */
            ldc "log4testng."
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifne 29
        28: .line 382
            new java.lang.IllegalArgumentException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Illegal property value: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* logger */
            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
        29: .line 384
      StackMap locals: java.util.Map$Entry java.lang.String java.lang.String
      StackMap stack:
            aload 3 /* logger */
            ldc "log4testng.debug"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 40
        30: .line 386
            aload 3 /* logger */
            ldc "log4testng.rootLogger"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 40
        31: .line 389
            aload 3 /* logger */
            ldc "log4testng.logger."
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifne 33
        32: .line 390
            new java.lang.IllegalArgumentException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Illegal property value: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* logger */
            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
        33: .line 393
      StackMap locals:
      StackMap stack:
            getstatic org.testng.log4testng.Logger.levelMap:Ljava/util/Map;
            aload 4 /* level */
            invokevirtual java.lang.String.toUpperCase:()Ljava/lang/String;
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Integer
            astore 5 /* ilevel */
        start local 5 // java.lang.Integer ilevel
        34: .line 394
            aload 5 /* ilevel */
            ifnonnull 38
        35: .line 395
            new java.lang.IllegalArgumentException
            dup
        36: .line 396
            new java.lang.StringBuilder
            dup
            ldc "Unknown level "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 4 /* level */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " for logger "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 3 /* logger */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " in log4testng.properties"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        37: .line 395
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        38: .line 399
      StackMap locals: java.lang.Integer
      StackMap stack:
            getstatic org.testng.log4testng.Logger.loggerLevels:Ljava/util/Map;
            aload 3 /* logger */
            ldc "log4testng.logger."
            invokevirtual java.lang.String.length:()I
            invokevirtual java.lang.String.substring:(I)Ljava/lang/String;
            aload 5 /* ilevel */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        39: .line 400
            new java.lang.StringBuilder
            dup
            ldc "logger "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* logger */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " set to "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 5 /* ilevel */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc " level."
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic org.testng.log4testng.Logger.loglog4testng:(Ljava/lang/String;)V
        end local 5 // java.lang.Integer ilevel
        end local 4 // java.lang.String level
        end local 3 // java.lang.String logger
        end local 2 // java.util.Map$Entry entry
        40: .line 376
      StackMap locals: java.util.Properties java.util.Iterator
      StackMap stack:
            aload 1 /* it */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 24
        41: .line 403
            return
        end local 1 // java.util.Iterator it
        end local 0 // java.util.Properties pProperties
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   42     0   pProperties  Ljava/util/Properties;
            1   10     1      debugStr  Ljava/lang/String;
           11   22     1  rootLevelStr  Ljava/lang/String;
           13   22     2        ilevel  Ljava/lang/Integer;
           23   42     1            it  Ljava/util/Iterator;
           25   40     2         entry  Ljava/util/Map$Entry;
           26   40     3        logger  Ljava/lang/String;
           27   40     4         level  Ljava/lang/String;
           34   40     5        ilevel  Ljava/lang/Integer;
    MethodParameters:
             Name  Flags
      pProperties  

  private static int getLevel(java.lang.Class);
    descriptor: (Ljava/lang/Class;)I
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=4, args_size=1
        start local 0 // java.lang.Class pClass
         0: .line 421
            aload 0 /* pClass */
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            astore 1 /* name */
        start local 1 // java.lang.String name
         1: .line 422
            new java.lang.StringBuilder
            dup
            ldc "Getting level for logger "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* name */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic org.testng.log4testng.Logger.loglog4testng:(Ljava/lang/String;)V
         2: .line 424
      StackMap locals: java.lang.String
      StackMap stack:
            getstatic org.testng.log4testng.Logger.loggerLevels:Ljava/util/Map;
            aload 1 /* name */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Integer
            astore 2 /* level */
        start local 2 // java.lang.Integer level
         3: .line 425
            aload 2 /* level */
            ifnull 6
         4: .line 426
            new java.lang.StringBuilder
            dup
            ldc "Found level "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* level */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc " for logger "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 1 /* name */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic org.testng.log4testng.Logger.loglog4testng:(Ljava/lang/String;)V
         5: .line 428
            aload 2 /* level */
            invokevirtual java.lang.Integer.intValue:()I
            ireturn
         6: .line 430
      StackMap locals: java.lang.Integer
      StackMap stack:
            aload 1 /* name */
            bipush 46
            invokevirtual java.lang.String.lastIndexOf:(I)I
            istore 3 /* dot */
        start local 3 // int dot
         7: .line 431
            iload 3 /* dot */
            iconst_m1
            if_icmpne 10
         8: .line 432
            new java.lang.StringBuilder
            dup
            ldc "Found level "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            getstatic org.testng.log4testng.Logger.rootLoggerLevel:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " for root logger"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic org.testng.log4testng.Logger.loglog4testng:(Ljava/lang/String;)V
         9: .line 435
            getstatic org.testng.log4testng.Logger.rootLoggerLevel:I
            ireturn
        10: .line 437
      StackMap locals: int
      StackMap stack:
            aload 1 /* name */
            iconst_0
            iload 3 /* dot */
            invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
            astore 1 /* name */
        end local 3 // int dot
        end local 2 // java.lang.Integer level
        11: .line 423
            goto 2
        end local 1 // java.lang.String name
        end local 0 // java.lang.Class pClass
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   12     0  pClass  Ljava/lang/Class;
            1   12     1    name  Ljava/lang/String;
            3   11     2   level  Ljava/lang/Integer;
            7   11     3     dot  I
    MethodParameters:
        Name  Flags
      pClass  

  private boolean isLevelEnabled(int);
    descriptor: (I)Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.testng.log4testng.Logger this
        start local 1 // int pLevel
         0: .line 442
            aload 0 /* this */
            getfield org.testng.log4testng.Logger.level:I
            iload 1 /* pLevel */
            if_icmpgt 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 1 // int pLevel
        end local 0 // org.testng.log4testng.Logger this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0    this  Lorg/testng/log4testng/Logger;
            0    2     1  pLevel  I
    MethodParameters:
        Name  Flags
      pLevel  

  private void log(int, java.lang.Object, java.lang.Throwable);
    descriptor: (ILjava/lang/Object;Ljava/lang/Throwable;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=6, args_size=4
        start local 0 // org.testng.log4testng.Logger this
        start local 1 // int pLevel
        start local 2 // java.lang.Object pMessage
        start local 3 // java.lang.Throwable pT
         0: .line 446
            aload 0 /* this */
            iload 1 /* pLevel */
            invokevirtual org.testng.log4testng.Logger.isLevelEnabled:(I)Z
            ifeq 13
         1: .line 447
            iload 1 /* pLevel */
            getstatic org.testng.log4testng.Logger.ERROR:I
            if_icmplt 2
            getstatic org.testng.log4testng.Logger.err:Ljava/io/PrintStream;
            goto 3
      StackMap locals:
      StackMap stack:
         2: getstatic org.testng.log4testng.Logger.out:Ljava/io/PrintStream;
      StackMap locals:
      StackMap stack: java.io.PrintStream
         3: astore 4 /* ps */
        start local 4 // java.io.PrintStream ps
         4: .line 448
            aload 3 /* pT */
            ifnull 12
         5: .line 449
            aload 4 /* ps */
            dup
            astore 5
            monitorenter
         6: .line 450
            aload 4 /* ps */
            new java.lang.StringBuilder
            dup
            ldc "["
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield org.testng.log4testng.Logger.m_className:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "] ["
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            getstatic org.testng.log4testng.Logger.levelNames:[Ljava/lang/String;
            iload 1 /* pLevel */
            aaload
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "] "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 2 /* pMessage */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         7: .line 451
            aload 3 /* pT */
            aload 4 /* ps */
            invokevirtual java.lang.Throwable.printStackTrace:(Ljava/io/PrintStream;)V
         8: .line 449
            aload 5
            monitorexit
         9: goto 13
      StackMap locals: org.testng.log4testng.Logger int java.lang.Object java.lang.Throwable java.io.PrintStream java.io.PrintStream
      StackMap stack: java.lang.Throwable
        10: aload 5
            monitorexit
        11: athrow
        12: .line 454
      StackMap locals:
      StackMap stack:
            aload 4 /* ps */
            new java.lang.StringBuilder
            dup
            ldc "["
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield org.testng.log4testng.Logger.m_className:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "] ["
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            getstatic org.testng.log4testng.Logger.levelNames:[Ljava/lang/String;
            iload 1 /* pLevel */
            aaload
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "] "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 2 /* pMessage */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        end local 4 // java.io.PrintStream ps
        13: .line 457
      StackMap locals:
      StackMap stack:
            return
        end local 3 // java.lang.Throwable pT
        end local 2 // java.lang.Object pMessage
        end local 1 // int pLevel
        end local 0 // org.testng.log4testng.Logger this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   14     0      this  Lorg/testng/log4testng/Logger;
            0   14     1    pLevel  I
            0   14     2  pMessage  Ljava/lang/Object;
            0   14     3        pT  Ljava/lang/Throwable;
            4   13     4        ps  Ljava/io/PrintStream;
      Exception table:
        from    to  target  type
           6     9      10  any
          10    11      10  any
    MethodParameters:
          Name  Flags
      pLevel    
      pMessage  
      pT        

  private static void loglog4testng(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // java.lang.String pmessage
         0: .line 465
            getstatic org.testng.log4testng.Logger.debug:Z
            ifeq 2
         1: .line 466
            getstatic org.testng.log4testng.Logger.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "[log4testng] [debug] "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* pmessage */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         2: .line 468
      StackMap locals:
      StackMap stack:
            return
        end local 0 // java.lang.String pmessage
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    3     0  pmessage  Ljava/lang/String;
    MethodParameters:
          Name  Flags
      pmessage  

  private static synchronized void testInitialize(java.util.Properties, java.io.PrintStream, java.io.PrintStream);
    descriptor: (Ljava/util/Properties;Ljava/io/PrintStream;Ljava/io/PrintStream;)V
    flags: (0x002a) ACC_PRIVATE, ACC_STATIC, ACC_SYNCHRONIZED
    Code:
      stack=1, locals=3, args_size=3
        start local 0 // java.util.Properties pProperties
        start local 1 // java.io.PrintStream pOut
        start local 2 // java.io.PrintStream pErr
         0: .line 479
            iconst_1
            putstatic org.testng.log4testng.Logger.initialized:Z
         1: .line 480
            getstatic org.testng.log4testng.Logger.loggers:Ljava/util/Map;
            invokeinterface java.util.Map.clear:()V
         2: .line 481
            getstatic org.testng.log4testng.Logger.WARN:I
            putstatic org.testng.log4testng.Logger.rootLoggerLevel:I
         3: .line 482
            iconst_0
            putstatic org.testng.log4testng.Logger.debug:Z
         4: .line 483
            aload 1 /* pOut */
            putstatic org.testng.log4testng.Logger.out:Ljava/io/PrintStream;
         5: .line 484
            aload 2 /* pErr */
            putstatic org.testng.log4testng.Logger.err:Ljava/io/PrintStream;
         6: .line 485
            aload 0 /* pProperties */
            invokestatic org.testng.log4testng.Logger.checkProperties:(Ljava/util/Properties;)V
         7: .line 486
            return
        end local 2 // java.io.PrintStream pErr
        end local 1 // java.io.PrintStream pOut
        end local 0 // java.util.Properties pProperties
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    8     0  pProperties  Ljava/util/Properties;
            0    8     1         pOut  Ljava/io/PrintStream;
            0    8     2         pErr  Ljava/io/PrintStream;
    MethodParameters:
             Name  Flags
      pProperties  
      pOut         
      pErr         

  private static void testDebugDefault();
    descriptor: ()V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=5, args_size=0
         0: .line 490
            new java.util.Properties
            dup
            invokespecial java.util.Properties.<init>:()V
            astore 0 /* props */
        start local 0 // java.util.Properties props
         1: .line 491
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 1 /* out1 */
        start local 1 // java.io.ByteArrayOutputStream out1
         2: .line 492
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 2 /* err1 */
        start local 2 // java.io.ByteArrayOutputStream err1
         3: .line 493
            new java.io.PrintStream
            dup
            aload 1 /* out1 */
            invokespecial java.io.PrintStream.<init>:(Ljava/io/OutputStream;)V
            astore 3 /* out2 */
        start local 3 // java.io.PrintStream out2
         4: .line 494
            new java.io.PrintStream
            dup
            aload 2 /* err1 */
            invokespecial java.io.PrintStream.<init>:(Ljava/io/OutputStream;)V
            astore 4 /* err2 */
        start local 4 // java.io.PrintStream err2
         5: .line 495
            aload 0 /* props */
            ldc "log4testng.rootLogger"
            ldc "WARN"
            invokevirtual java.util.Properties.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         6: .line 496
            aload 0 /* props */
            aload 3 /* out2 */
            aload 4 /* err2 */
            invokestatic org.testng.log4testng.Logger.testInitialize:(Ljava/util/Properties;Ljava/io/PrintStream;Ljava/io/PrintStream;)V
         7: .line 497
            aload 1 /* out1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc ""
            invokestatic org.testng.Assert.assertEquals:(Ljava/lang/String;Ljava/lang/String;)V
         8: .line 498
            aload 2 /* err1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc ""
            invokestatic org.testng.Assert.assertEquals:(Ljava/lang/String;Ljava/lang/String;)V
         9: .line 499
            return
        end local 4 // java.io.PrintStream err2
        end local 3 // java.io.PrintStream out2
        end local 2 // java.io.ByteArrayOutputStream err1
        end local 1 // java.io.ByteArrayOutputStream out1
        end local 0 // java.util.Properties props
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            1   10     0  props  Ljava/util/Properties;
            2   10     1   out1  Ljava/io/ByteArrayOutputStream;
            3   10     2   err1  Ljava/io/ByteArrayOutputStream;
            4   10     3   out2  Ljava/io/PrintStream;
            5   10     4   err2  Ljava/io/PrintStream;

  private static void testDebugOn();
    descriptor: ()V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=5, args_size=0
         0: .line 503
            new java.util.Properties
            dup
            invokespecial java.util.Properties.<init>:()V
            astore 0 /* props */
        start local 0 // java.util.Properties props
         1: .line 504
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 1 /* out1 */
        start local 1 // java.io.ByteArrayOutputStream out1
         2: .line 505
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 2 /* err1 */
        start local 2 // java.io.ByteArrayOutputStream err1
         3: .line 506
            new java.io.PrintStream
            dup
            aload 1 /* out1 */
            invokespecial java.io.PrintStream.<init>:(Ljava/io/OutputStream;)V
            astore 3 /* out2 */
        start local 3 // java.io.PrintStream out2
         4: .line 507
            new java.io.PrintStream
            dup
            aload 2 /* err1 */
            invokespecial java.io.PrintStream.<init>:(Ljava/io/OutputStream;)V
            astore 4 /* err2 */
        start local 4 // java.io.PrintStream err2
         5: .line 508
            aload 0 /* props */
            ldc "log4testng.debug"
            ldc "true"
            invokevirtual java.util.Properties.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         6: .line 509
            aload 0 /* props */
            ldc "log4testng.rootLogger"
            ldc "WARN"
            invokevirtual java.util.Properties.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         7: .line 510
            aload 0 /* props */
            aload 3 /* out2 */
            aload 4 /* err2 */
            invokestatic org.testng.log4testng.Logger.testInitialize:(Ljava/util/Properties;Ljava/io/PrintStream;Ljava/io/PrintStream;)V
         8: .line 511
            aload 1 /* out1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc "[log4testng][debug]"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            invokestatic org.testng.Assert.assertTrue:(Z)V
         9: .line 512
            aload 2 /* err1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc ""
            invokestatic org.testng.Assert.assertEquals:(Ljava/lang/String;Ljava/lang/String;)V
        10: .line 513
            return
        end local 4 // java.io.PrintStream err2
        end local 3 // java.io.PrintStream out2
        end local 2 // java.io.ByteArrayOutputStream err1
        end local 1 // java.io.ByteArrayOutputStream out1
        end local 0 // java.util.Properties props
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            1   11     0  props  Ljava/util/Properties;
            2   11     1   out1  Ljava/io/ByteArrayOutputStream;
            3   11     2   err1  Ljava/io/ByteArrayOutputStream;
            4   11     3   out2  Ljava/io/PrintStream;
            5   11     4   err2  Ljava/io/PrintStream;

  private static void testDebugOff();
    descriptor: ()V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=5, args_size=0
         0: .line 517
            new java.util.Properties
            dup
            invokespecial java.util.Properties.<init>:()V
            astore 0 /* props */
        start local 0 // java.util.Properties props
         1: .line 518
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 1 /* out1 */
        start local 1 // java.io.ByteArrayOutputStream out1
         2: .line 519
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 2 /* err1 */
        start local 2 // java.io.ByteArrayOutputStream err1
         3: .line 520
            new java.io.PrintStream
            dup
            aload 1 /* out1 */
            invokespecial java.io.PrintStream.<init>:(Ljava/io/OutputStream;)V
            astore 3 /* out2 */
        start local 3 // java.io.PrintStream out2
         4: .line 521
            new java.io.PrintStream
            dup
            aload 2 /* err1 */
            invokespecial java.io.PrintStream.<init>:(Ljava/io/OutputStream;)V
            astore 4 /* err2 */
        start local 4 // java.io.PrintStream err2
         5: .line 522
            aload 0 /* props */
            ldc "log4testng.debug"
            ldc "false"
            invokevirtual java.util.Properties.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         6: .line 523
            aload 0 /* props */
            ldc "log4testng.rootLogger"
            ldc "WARN"
            invokevirtual java.util.Properties.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         7: .line 524
            aload 0 /* props */
            aload 3 /* out2 */
            aload 4 /* err2 */
            invokestatic org.testng.log4testng.Logger.testInitialize:(Ljava/util/Properties;Ljava/io/PrintStream;Ljava/io/PrintStream;)V
         8: .line 525
            aload 1 /* out1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc ""
            invokestatic org.testng.Assert.assertEquals:(Ljava/lang/String;Ljava/lang/String;)V
         9: .line 526
            aload 2 /* err1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc ""
            invokestatic org.testng.Assert.assertEquals:(Ljava/lang/String;Ljava/lang/String;)V
        10: .line 527
            return
        end local 4 // java.io.PrintStream err2
        end local 3 // java.io.PrintStream out2
        end local 2 // java.io.ByteArrayOutputStream err1
        end local 1 // java.io.ByteArrayOutputStream out1
        end local 0 // java.util.Properties props
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            1   11     0  props  Ljava/util/Properties;
            2   11     1   out1  Ljava/io/ByteArrayOutputStream;
            3   11     2   err1  Ljava/io/ByteArrayOutputStream;
            4   11     3   out2  Ljava/io/PrintStream;
            5   11     4   err2  Ljava/io/PrintStream;

  private static void testDebugError();
    descriptor: ()V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=5, args_size=0
         0: .line 531
            new java.util.Properties
            dup
            invokespecial java.util.Properties.<init>:()V
            astore 0 /* props */
        start local 0 // java.util.Properties props
         1: .line 532
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 1 /* out1 */
        start local 1 // java.io.ByteArrayOutputStream out1
         2: .line 533
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 2 /* err1 */
        start local 2 // java.io.ByteArrayOutputStream err1
         3: .line 534
            new java.io.PrintStream
            dup
            aload 1 /* out1 */
            invokespecial java.io.PrintStream.<init>:(Ljava/io/OutputStream;)V
            astore 3 /* out2 */
        start local 3 // java.io.PrintStream out2
         4: .line 535
            new java.io.PrintStream
            dup
            aload 2 /* err1 */
            invokespecial java.io.PrintStream.<init>:(Ljava/io/OutputStream;)V
            astore 4 /* err2 */
        start local 4 // java.io.PrintStream err2
         5: .line 536
            aload 0 /* props */
            ldc "log4testng.debug"
            ldc "unknown"
            invokevirtual java.util.Properties.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         6: .line 537
            aload 0 /* props */
            ldc "log4testng.rootLogger"
            ldc "WARN"
            invokevirtual java.util.Properties.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         7: .line 539
            aload 0 /* props */
            aload 3 /* out2 */
            aload 4 /* err2 */
            invokestatic org.testng.log4testng.Logger.testInitialize:(Ljava/util/Properties;Ljava/io/PrintStream;Ljava/io/PrintStream;)V
         8: .line 540
            new java.lang.RuntimeException
            dup
            ldc "failure"
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;)V
            athrow
         9: .line 541
      StackMap locals: java.util.Properties java.io.ByteArrayOutputStream java.io.ByteArrayOutputStream java.io.PrintStream java.io.PrintStream
      StackMap stack: java.lang.IllegalArgumentException
            pop
        10: .line 544
            aload 1 /* out1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc ""
            invokestatic org.testng.Assert.assertEquals:(Ljava/lang/String;Ljava/lang/String;)V
        11: .line 545
            aload 2 /* err1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc ""
            invokestatic org.testng.Assert.assertEquals:(Ljava/lang/String;Ljava/lang/String;)V
        12: .line 547
            return
        end local 4 // java.io.PrintStream err2
        end local 3 // java.io.PrintStream out2
        end local 2 // java.io.ByteArrayOutputStream err1
        end local 1 // java.io.ByteArrayOutputStream out1
        end local 0 // java.util.Properties props
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            1   13     0  props  Ljava/util/Properties;
            2   13     1   out1  Ljava/io/ByteArrayOutputStream;
            3   13     2   err1  Ljava/io/ByteArrayOutputStream;
            4   13     3   out2  Ljava/io/PrintStream;
            5   13     4   err2  Ljava/io/PrintStream;
      Exception table:
        from    to  target  type
           7     9       9  Class java.lang.IllegalArgumentException

  private static void testRootLoggerDefault();
    descriptor: ()V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=7, args_size=0
         0: .line 554
            new java.util.Properties
            dup
            invokespecial java.util.Properties.<init>:()V
            astore 0 /* props */
        start local 0 // java.util.Properties props
         1: .line 555
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 1 /* out1 */
        start local 1 // java.io.ByteArrayOutputStream out1
         2: .line 556
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 2 /* err1 */
        start local 2 // java.io.ByteArrayOutputStream err1
         3: .line 557
            new java.io.PrintStream
            dup
            aload 1 /* out1 */
            invokespecial java.io.PrintStream.<init>:(Ljava/io/OutputStream;)V
            astore 3 /* out2 */
        start local 3 // java.io.PrintStream out2
         4: .line 558
            new java.io.PrintStream
            dup
            aload 2 /* err1 */
            invokespecial java.io.PrintStream.<init>:(Ljava/io/OutputStream;)V
            astore 4 /* err2 */
        start local 4 // java.io.PrintStream err2
         5: .line 559
            aload 0 /* props */
            aload 3 /* out2 */
            aload 4 /* err2 */
            invokestatic org.testng.log4testng.Logger.testInitialize:(Ljava/util/Properties;Ljava/io/PrintStream;Ljava/io/PrintStream;)V
         6: .line 561
            ldc Ljava/lang/String;
            invokestatic org.testng.log4testng.Logger.getLogger:(Ljava/lang/Class;)Lorg/testng/log4testng/Logger;
            astore 5 /* strLogger */
        start local 5 // org.testng.log4testng.Logger strLogger
         7: .line 562
            aload 5 /* strLogger */
            ldc "trace should not appear"
            invokevirtual org.testng.log4testng.Logger.trace:(Ljava/lang/Object;)V
         8: .line 563
            aload 1 /* out1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc ""
            invokestatic org.testng.Assert.assertEquals:(Ljava/lang/String;Ljava/lang/String;)V
         9: .line 564
            aload 2 /* err1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc ""
            invokestatic org.testng.Assert.assertEquals:(Ljava/lang/String;Ljava/lang/String;)V
        10: .line 565
            aload 5 /* strLogger */
            ldc "debug should not appear"
            invokevirtual org.testng.log4testng.Logger.debug:(Ljava/lang/Object;)V
        11: .line 566
            aload 1 /* out1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc ""
            invokestatic org.testng.Assert.assertEquals:(Ljava/lang/String;Ljava/lang/String;)V
        12: .line 567
            aload 2 /* err1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc ""
            invokestatic org.testng.Assert.assertEquals:(Ljava/lang/String;Ljava/lang/String;)V
        13: .line 568
            aload 5 /* strLogger */
            ldc "info should not appear"
            invokevirtual org.testng.log4testng.Logger.info:(Ljava/lang/Object;)V
        14: .line 569
            aload 1 /* out1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc ""
            invokestatic org.testng.Assert.assertEquals:(Ljava/lang/String;Ljava/lang/String;)V
        15: .line 570
            aload 2 /* err1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc ""
            invokestatic org.testng.Assert.assertEquals:(Ljava/lang/String;Ljava/lang/String;)V
        16: .line 571
            aload 5 /* strLogger */
            ldc "warn should appear"
            invokevirtual org.testng.log4testng.Logger.warn:(Ljava/lang/Object;)V
        17: .line 572
            aload 1 /* out1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            invokevirtual java.lang.String.length:()I
            istore 6 /* outlength */
        start local 6 // int outlength
        18: .line 573
            aload 1 /* out1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc "[java.lang.String] [WARN] warn should appear"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            invokestatic org.testng.Assert.assertTrue:(Z)V
        19: .line 574
            aload 2 /* err1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc ""
            invokestatic org.testng.Assert.assertEquals:(Ljava/lang/String;Ljava/lang/String;)V
        20: .line 575
            aload 5 /* strLogger */
            ldc "error should appear"
            invokevirtual org.testng.log4testng.Logger.error:(Ljava/lang/Object;)V
        21: .line 576
            aload 1 /* out1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            invokevirtual java.lang.String.length:()I
            iload 6 /* outlength */
            invokestatic org.testng.Assert.assertEquals:(II)V
        22: .line 577
            aload 2 /* err1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc "[java.lang.String] [ERROR] error should appear"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            invokestatic org.testng.Assert.assertTrue:(Z)V
        23: .line 578
            aload 5 /* strLogger */
            ldc "fatal should appear"
            invokevirtual org.testng.log4testng.Logger.fatal:(Ljava/lang/Object;)V
        24: .line 579
            aload 1 /* out1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            invokevirtual java.lang.String.length:()I
            iload 6 /* outlength */
            invokestatic org.testng.Assert.assertEquals:(II)V
        25: .line 580
            aload 2 /* err1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc "[java.lang.String] [FATAL] fatal should appear"
            invokevirtual java.lang.String.contains:(Ljava/lang/CharSequence;)Z
            invokestatic org.testng.Assert.assertTrue:(Z)V
        26: .line 581
            return
        end local 6 // int outlength
        end local 5 // org.testng.log4testng.Logger strLogger
        end local 4 // java.io.PrintStream err2
        end local 3 // java.io.PrintStream out2
        end local 2 // java.io.ByteArrayOutputStream err1
        end local 1 // java.io.ByteArrayOutputStream out1
        end local 0 // java.util.Properties props
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            1   27     0      props  Ljava/util/Properties;
            2   27     1       out1  Ljava/io/ByteArrayOutputStream;
            3   27     2       err1  Ljava/io/ByteArrayOutputStream;
            4   27     3       out2  Ljava/io/PrintStream;
            5   27     4       err2  Ljava/io/PrintStream;
            7   27     5  strLogger  Lorg/testng/log4testng/Logger;
           18   27     6  outlength  I

  private static void testRootLoggerSet();
    descriptor: ()V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=6, args_size=0
         0: .line 585
            new java.util.Properties
            dup
            invokespecial java.util.Properties.<init>:()V
            astore 0 /* props */
        start local 0 // java.util.Properties props
         1: .line 586
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 1 /* out1 */
        start local 1 // java.io.ByteArrayOutputStream out1
         2: .line 587
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 2 /* err1 */
        start local 2 // java.io.ByteArrayOutputStream err1
         3: .line 588
            new java.io.PrintStream
            dup
            aload 1 /* out1 */
            invokespecial java.io.PrintStream.<init>:(Ljava/io/OutputStream;)V
            astore 3 /* out2 */
        start local 3 // java.io.PrintStream out2
         4: .line 589
            new java.io.PrintStream
            dup
            aload 2 /* err1 */
            invokespecial java.io.PrintStream.<init>:(Ljava/io/OutputStream;)V
            astore 4 /* err2 */
        start local 4 // java.io.PrintStream err2
         5: .line 590
            aload 0 /* props */
            ldc "log4testng.rootLogger"
            ldc "DEBUG"
            invokevirtual java.util.Properties.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         6: .line 591
            aload 0 /* props */
            aload 3 /* out2 */
            aload 4 /* err2 */
            invokestatic org.testng.log4testng.Logger.testInitialize:(Ljava/util/Properties;Ljava/io/PrintStream;Ljava/io/PrintStream;)V
         7: .line 593
            ldc Ljava/lang/String;
            invokestatic org.testng.log4testng.Logger.getLogger:(Ljava/lang/Class;)Lorg/testng/log4testng/Logger;
            astore 5 /* strLogger */
        start local 5 // org.testng.log4testng.Logger strLogger
         8: .line 594
            aload 5 /* strLogger */
            ldc "trace should appear"
            invokevirtual org.testng.log4testng.Logger.trace:(Ljava/lang/Object;)V
         9: .line 595
            aload 1 /* out1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc ""
            invokestatic org.testng.Assert.assertEquals:(Ljava/lang/String;Ljava/lang/String;)V
        10: .line 596
            aload 2 /* err1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc ""
            invokestatic org.testng.Assert.assertEquals:(Ljava/lang/String;Ljava/lang/String;)V
        11: .line 597
            aload 5 /* strLogger */
            ldc "debug should appear"
            invokevirtual org.testng.log4testng.Logger.debug:(Ljava/lang/Object;)V
        12: .line 598
            aload 1 /* out1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc "[java.lang.String] [DEBUG] debug should appear"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            invokestatic org.testng.Assert.assertTrue:(Z)V
        13: .line 599
            aload 2 /* err1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc ""
            invokestatic org.testng.Assert.assertEquals:(Ljava/lang/String;Ljava/lang/String;)V
        14: .line 600
            return
        end local 5 // org.testng.log4testng.Logger strLogger
        end local 4 // java.io.PrintStream err2
        end local 3 // java.io.PrintStream out2
        end local 2 // java.io.ByteArrayOutputStream err1
        end local 1 // java.io.ByteArrayOutputStream out1
        end local 0 // java.util.Properties props
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            1   15     0      props  Ljava/util/Properties;
            2   15     1       out1  Ljava/io/ByteArrayOutputStream;
            3   15     2       err1  Ljava/io/ByteArrayOutputStream;
            4   15     3       out2  Ljava/io/PrintStream;
            5   15     4       err2  Ljava/io/PrintStream;
            8   15     5  strLogger  Lorg/testng/log4testng/Logger;

  private static void testRootLoggerSetError();
    descriptor: ()V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=5, args_size=0
         0: .line 604
            new java.util.Properties
            dup
            invokespecial java.util.Properties.<init>:()V
            astore 0 /* props */
        start local 0 // java.util.Properties props
         1: .line 605
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 1 /* out1 */
        start local 1 // java.io.ByteArrayOutputStream out1
         2: .line 606
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 2 /* err1 */
        start local 2 // java.io.ByteArrayOutputStream err1
         3: .line 607
            new java.io.PrintStream
            dup
            aload 1 /* out1 */
            invokespecial java.io.PrintStream.<init>:(Ljava/io/OutputStream;)V
            astore 3 /* out2 */
        start local 3 // java.io.PrintStream out2
         4: .line 608
            new java.io.PrintStream
            dup
            aload 2 /* err1 */
            invokespecial java.io.PrintStream.<init>:(Ljava/io/OutputStream;)V
            astore 4 /* err2 */
        start local 4 // java.io.PrintStream err2
         5: .line 609
            aload 0 /* props */
            ldc "log4testng.rootLogger"
            ldc "unknown"
            invokevirtual java.util.Properties.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         6: .line 611
            aload 0 /* props */
            aload 3 /* out2 */
            aload 4 /* err2 */
            invokestatic org.testng.log4testng.Logger.testInitialize:(Ljava/util/Properties;Ljava/io/PrintStream;Ljava/io/PrintStream;)V
         7: .line 612
            new java.lang.RuntimeException
            dup
            ldc "failure"
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;)V
            athrow
         8: .line 613
      StackMap locals: java.util.Properties java.io.ByteArrayOutputStream java.io.ByteArrayOutputStream java.io.PrintStream java.io.PrintStream
      StackMap stack: java.lang.IllegalArgumentException
            pop
         9: .line 616
            aload 1 /* out1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc ""
            invokestatic org.testng.Assert.assertEquals:(Ljava/lang/String;Ljava/lang/String;)V
        10: .line 617
            aload 2 /* err1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc ""
            invokestatic org.testng.Assert.assertEquals:(Ljava/lang/String;Ljava/lang/String;)V
        11: .line 619
            return
        end local 4 // java.io.PrintStream err2
        end local 3 // java.io.PrintStream out2
        end local 2 // java.io.ByteArrayOutputStream err1
        end local 1 // java.io.ByteArrayOutputStream out1
        end local 0 // java.util.Properties props
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            1   12     0  props  Ljava/util/Properties;
            2   12     1   out1  Ljava/io/ByteArrayOutputStream;
            3   12     2   err1  Ljava/io/ByteArrayOutputStream;
            4   12     3   out2  Ljava/io/PrintStream;
            5   12     4   err2  Ljava/io/PrintStream;
      Exception table:
        from    to  target  type
           6     8       8  Class java.lang.IllegalArgumentException

  private static void testUserLoggerSet();
    descriptor: ()V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=8, args_size=0
         0: .line 623
            new java.util.Properties
            dup
            invokespecial java.util.Properties.<init>:()V
            astore 0 /* props */
        start local 0 // java.util.Properties props
         1: .line 624
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 1 /* out1 */
        start local 1 // java.io.ByteArrayOutputStream out1
         2: .line 625
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 2 /* err1 */
        start local 2 // java.io.ByteArrayOutputStream err1
         3: .line 626
            new java.io.PrintStream
            dup
            aload 1 /* out1 */
            invokespecial java.io.PrintStream.<init>:(Ljava/io/OutputStream;)V
            astore 3 /* out2 */
        start local 3 // java.io.PrintStream out2
         4: .line 627
            new java.io.PrintStream
            dup
            aload 2 /* err1 */
            invokespecial java.io.PrintStream.<init>:(Ljava/io/OutputStream;)V
            astore 4 /* err2 */
        start local 4 // java.io.PrintStream err2
         5: .line 628
            aload 0 /* props */
            ldc "log4testng.logger.java.lang.String"
            ldc "DEBUG"
            invokevirtual java.util.Properties.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         6: .line 629
            aload 0 /* props */
            aload 3 /* out2 */
            aload 4 /* err2 */
            invokestatic org.testng.log4testng.Logger.testInitialize:(Ljava/util/Properties;Ljava/io/PrintStream;Ljava/io/PrintStream;)V
         7: .line 631
            ldc Ljava/lang/String;
            invokestatic org.testng.log4testng.Logger.getLogger:(Ljava/lang/Class;)Lorg/testng/log4testng/Logger;
            astore 5 /* strLogger */
        start local 5 // org.testng.log4testng.Logger strLogger
         8: .line 632
            aload 5 /* strLogger */
            ldc "trace should not appear"
            invokevirtual org.testng.log4testng.Logger.trace:(Ljava/lang/Object;)V
         9: .line 633
            aload 1 /* out1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc ""
            invokestatic org.testng.Assert.assertEquals:(Ljava/lang/String;Ljava/lang/String;)V
        10: .line 634
            aload 2 /* err1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc ""
            invokestatic org.testng.Assert.assertEquals:(Ljava/lang/String;Ljava/lang/String;)V
        11: .line 635
            aload 5 /* strLogger */
            ldc "debug should appear"
            invokevirtual org.testng.log4testng.Logger.debug:(Ljava/lang/Object;)V
        12: .line 636
            aload 1 /* out1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            invokevirtual java.lang.String.length:()I
            istore 6 /* outLength */
        start local 6 // int outLength
        13: .line 637
            aload 1 /* out1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc "[java.lang.String] [DEBUG] debug should appear"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            invokestatic org.testng.Assert.assertTrue:(Z)V
        14: .line 638
            aload 2 /* err1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc ""
            invokestatic org.testng.Assert.assertEquals:(Ljava/lang/String;Ljava/lang/String;)V
        15: .line 640
            ldc Ljava/lang/Class;
            invokestatic org.testng.log4testng.Logger.getLogger:(Ljava/lang/Class;)Lorg/testng/log4testng/Logger;
            astore 7 /* classLogger */
        start local 7 // org.testng.log4testng.Logger classLogger
        16: .line 641
            aload 7 /* classLogger */
            ldc "debug should not appear"
            invokevirtual org.testng.log4testng.Logger.debug:(Ljava/lang/Object;)V
        17: .line 642
            aload 1 /* out1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            invokevirtual java.lang.String.length:()I
            iload 6 /* outLength */
            invokestatic org.testng.Assert.assertEquals:(II)V
        18: .line 643
            aload 2 /* err1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc ""
            invokestatic org.testng.Assert.assertEquals:(Ljava/lang/String;Ljava/lang/String;)V
        19: .line 644
            aload 7 /* classLogger */
            ldc "warn should appear"
            invokevirtual org.testng.log4testng.Logger.warn:(Ljava/lang/Object;)V
        20: .line 645
            aload 1 /* out1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc "[java.lang.Class] [WARN] warn should appear"
            invokevirtual java.lang.String.contains:(Ljava/lang/CharSequence;)Z
            invokestatic org.testng.Assert.assertTrue:(Z)V
        21: .line 646
            aload 2 /* err1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc ""
            invokestatic org.testng.Assert.assertEquals:(Ljava/lang/String;Ljava/lang/String;)V
        22: .line 647
            return
        end local 7 // org.testng.log4testng.Logger classLogger
        end local 6 // int outLength
        end local 5 // org.testng.log4testng.Logger strLogger
        end local 4 // java.io.PrintStream err2
        end local 3 // java.io.PrintStream out2
        end local 2 // java.io.ByteArrayOutputStream err1
        end local 1 // java.io.ByteArrayOutputStream out1
        end local 0 // java.util.Properties props
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            1   23     0        props  Ljava/util/Properties;
            2   23     1         out1  Ljava/io/ByteArrayOutputStream;
            3   23     2         err1  Ljava/io/ByteArrayOutputStream;
            4   23     3         out2  Ljava/io/PrintStream;
            5   23     4         err2  Ljava/io/PrintStream;
            8   23     5    strLogger  Lorg/testng/log4testng/Logger;
           13   23     6    outLength  I
           16   23     7  classLogger  Lorg/testng/log4testng/Logger;

  private static void testUserLoggerSetError();
    descriptor: ()V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=5, args_size=0
         0: .line 651
            new java.util.Properties
            dup
            invokespecial java.util.Properties.<init>:()V
            astore 0 /* props */
        start local 0 // java.util.Properties props
         1: .line 652
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 1 /* out1 */
        start local 1 // java.io.ByteArrayOutputStream out1
         2: .line 653
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 2 /* err1 */
        start local 2 // java.io.ByteArrayOutputStream err1
         3: .line 654
            new java.io.PrintStream
            dup
            aload 1 /* out1 */
            invokespecial java.io.PrintStream.<init>:(Ljava/io/OutputStream;)V
            astore 3 /* out2 */
        start local 3 // java.io.PrintStream out2
         4: .line 655
            new java.io.PrintStream
            dup
            aload 2 /* err1 */
            invokespecial java.io.PrintStream.<init>:(Ljava/io/OutputStream;)V
            astore 4 /* err2 */
        start local 4 // java.io.PrintStream err2
         5: .line 656
            aload 0 /* props */
            ldc "log4testng.logger.java.lang.String"
            ldc "unknown"
            invokevirtual java.util.Properties.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         6: .line 658
            aload 0 /* props */
            aload 3 /* out2 */
            aload 4 /* err2 */
            invokestatic org.testng.log4testng.Logger.testInitialize:(Ljava/util/Properties;Ljava/io/PrintStream;Ljava/io/PrintStream;)V
         7: .line 659
            new java.lang.RuntimeException
            dup
            ldc "failure"
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;)V
            athrow
         8: .line 660
      StackMap locals: java.util.Properties java.io.ByteArrayOutputStream java.io.ByteArrayOutputStream java.io.PrintStream java.io.PrintStream
      StackMap stack: java.lang.IllegalArgumentException
            pop
         9: .line 663
            aload 1 /* out1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc ""
            invokestatic org.testng.Assert.assertEquals:(Ljava/lang/String;Ljava/lang/String;)V
        10: .line 664
            aload 2 /* err1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc ""
            invokestatic org.testng.Assert.assertEquals:(Ljava/lang/String;Ljava/lang/String;)V
        11: .line 666
            return
        end local 4 // java.io.PrintStream err2
        end local 3 // java.io.PrintStream out2
        end local 2 // java.io.ByteArrayOutputStream err1
        end local 1 // java.io.ByteArrayOutputStream out1
        end local 0 // java.util.Properties props
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            1   12     0  props  Ljava/util/Properties;
            2   12     1   out1  Ljava/io/ByteArrayOutputStream;
            3   12     2   err1  Ljava/io/ByteArrayOutputStream;
            4   12     3   out2  Ljava/io/PrintStream;
            5   12     4   err2  Ljava/io/PrintStream;
      Exception table:
        from    to  target  type
           6     8       8  Class java.lang.IllegalArgumentException

  private static void testUserLoggerSetHierarchy();
    descriptor: ()V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=6, args_size=0
         0: .line 670
            new java.util.Properties
            dup
            invokespecial java.util.Properties.<init>:()V
            astore 0 /* props */
        start local 0 // java.util.Properties props
         1: .line 671
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 1 /* out1 */
        start local 1 // java.io.ByteArrayOutputStream out1
         2: .line 672
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 2 /* err1 */
        start local 2 // java.io.ByteArrayOutputStream err1
         3: .line 673
            new java.io.PrintStream
            dup
            aload 1 /* out1 */
            invokespecial java.io.PrintStream.<init>:(Ljava/io/OutputStream;)V
            astore 3 /* out2 */
        start local 3 // java.io.PrintStream out2
         4: .line 674
            new java.io.PrintStream
            dup
            aload 2 /* err1 */
            invokespecial java.io.PrintStream.<init>:(Ljava/io/OutputStream;)V
            astore 4 /* err2 */
        start local 4 // java.io.PrintStream err2
         5: .line 675
            aload 0 /* props */
            ldc "log4testng.logger.java.lang"
            ldc "DEBUG"
            invokevirtual java.util.Properties.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         6: .line 676
            aload 0 /* props */
            aload 3 /* out2 */
            aload 4 /* err2 */
            invokestatic org.testng.log4testng.Logger.testInitialize:(Ljava/util/Properties;Ljava/io/PrintStream;Ljava/io/PrintStream;)V
         7: .line 678
            ldc Ljava/lang/String;
            invokestatic org.testng.log4testng.Logger.getLogger:(Ljava/lang/Class;)Lorg/testng/log4testng/Logger;
            astore 5 /* strLogger */
        start local 5 // org.testng.log4testng.Logger strLogger
         8: .line 679
            aload 5 /* strLogger */
            ldc "trace should not appear"
            invokevirtual org.testng.log4testng.Logger.trace:(Ljava/lang/Object;)V
         9: .line 680
            aload 1 /* out1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc ""
            invokestatic org.testng.Assert.assertEquals:(Ljava/lang/String;Ljava/lang/String;)V
        10: .line 681
            aload 2 /* err1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc ""
            invokestatic org.testng.Assert.assertEquals:(Ljava/lang/String;Ljava/lang/String;)V
        11: .line 682
            aload 5 /* strLogger */
            ldc "debug should appear"
            invokevirtual org.testng.log4testng.Logger.debug:(Ljava/lang/Object;)V
        12: .line 683
            aload 1 /* out1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc "[java.lang.String] [DEBUG] debug should appear"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            invokestatic org.testng.Assert.assertTrue:(Z)V
        13: .line 684
            aload 2 /* err1 */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            ldc ""
            invokestatic org.testng.Assert.assertEquals:(Ljava/lang/String;Ljava/lang/String;)V
        14: .line 685
            return
        end local 5 // org.testng.log4testng.Logger strLogger
        end local 4 // java.io.PrintStream err2
        end local 3 // java.io.PrintStream out2
        end local 2 // java.io.ByteArrayOutputStream err1
        end local 1 // java.io.ByteArrayOutputStream out1
        end local 0 // java.util.Properties props
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            1   15     0      props  Ljava/util/Properties;
            2   15     1       out1  Ljava/io/ByteArrayOutputStream;
            3   15     2       err1  Ljava/io/ByteArrayOutputStream;
            4   15     3       out2  Ljava/io/PrintStream;
            5   15     4       err2  Ljava/io/PrintStream;
            8   15     5  strLogger  Lorg/testng/log4testng/Logger;

  public static void main(java.lang.String[]);
    descriptor: ([Ljava/lang/String;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=0, locals=1, args_size=1
        start local 0 // java.lang.String[] pArgs
         0: .line 693
            invokestatic org.testng.log4testng.Logger.testDebugDefault:()V
         1: .line 694
            invokestatic org.testng.log4testng.Logger.testDebugOn:()V
         2: .line 695
            invokestatic org.testng.log4testng.Logger.testDebugOff:()V
         3: .line 696
            invokestatic org.testng.log4testng.Logger.testDebugError:()V
         4: .line 697
            invokestatic org.testng.log4testng.Logger.testRootLoggerDefault:()V
         5: .line 698
            invokestatic org.testng.log4testng.Logger.testRootLoggerSet:()V
         6: .line 699
            invokestatic org.testng.log4testng.Logger.testRootLoggerSetError:()V
         7: .line 700
            invokestatic org.testng.log4testng.Logger.testUserLoggerSet:()V
         8: .line 701
            invokestatic org.testng.log4testng.Logger.testUserLoggerSetError:()V
         9: .line 702
            invokestatic org.testng.log4testng.Logger.testUserLoggerSetHierarchy:()V
        10: .line 703
            return
        end local 0 // java.lang.String[] pArgs
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   11     0  pArgs  [Ljava/lang/String;
    MethodParameters:
       Name  Flags
      pArgs  
}
SourceFile: "Logger.java"
InnerClasses:
  public abstract Entry = java.util.Map$Entry of java.util.Map