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 66
            iconst_0
            putstatic org.testng.log4testng.Logger.i:I
         1: .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.TRACE:I
         2: .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.DEBUG:I
         3: .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.INFO:I
         4: .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.WARN:I
         5: .line 71
            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 72
            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 73
            getstatic org.testng.log4testng.Logger.i:I
            putstatic org.testng.log4testng.Logger.LEVEL_COUNT:I
         8: .line 88
            getstatic java.lang.System.err:Ljava/io/PrintStream;
            putstatic org.testng.log4testng.Logger.err:Ljava/io/PrintStream;
         9: .line 91
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            putstatic org.testng.log4testng.Logger.out:Ljava/io/PrintStream;
        10: .line 94
            getstatic org.testng.log4testng.Logger.LEVEL_COUNT:I
            anewarray java.lang.String
            putstatic org.testng.log4testng.Logger.levelNames:[Ljava/lang/String;
        11: .line 97
            getstatic org.testng.log4testng.Logger.levelNames:[Ljava/lang/String;
            getstatic org.testng.log4testng.Logger.TRACE:I
            ldc "TRACE"
            aastore
        12: .line 98
            getstatic org.testng.log4testng.Logger.levelNames:[Ljava/lang/String;
            getstatic org.testng.log4testng.Logger.DEBUG:I
            ldc "DEBUG"
            aastore
        13: .line 99
            getstatic org.testng.log4testng.Logger.levelNames:[Ljava/lang/String;
            getstatic org.testng.log4testng.Logger.INFO:I
            ldc "INFO"
            aastore
        14: .line 100
            getstatic org.testng.log4testng.Logger.levelNames:[Ljava/lang/String;
            getstatic org.testng.log4testng.Logger.WARN:I
            ldc "WARN"
            aastore
        15: .line 101
            getstatic org.testng.log4testng.Logger.levelNames:[Ljava/lang/String;
            getstatic org.testng.log4testng.Logger.ERROR:I
            ldc "ERROR"
            aastore
        16: .line 102
            getstatic org.testng.log4testng.Logger.levelNames:[Ljava/lang/String;
            getstatic org.testng.log4testng.Logger.FATAL:I
            ldc "FATAL"
            aastore
        17: .line 106
            invokestatic org.testng.collections.Maps.newHashMap:()Ljava/util/Map;
            putstatic org.testng.log4testng.Logger.levelMap:Ljava/util/Map;
        18: .line 109
            iconst_0
            putstatic org.testng.log4testng.Logger.i:I
            goto 21
        19: .line 110
      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 109
            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 118
            invokestatic org.testng.collections.Maps.newHashMap:()Ljava/util/Map;
            putstatic org.testng.log4testng.Logger.loggerLevels:Ljava/util/Map;
        23: .line 121
            invokestatic org.testng.collections.Maps.newHashMap:()Ljava/util/Map;
            putstatic org.testng.log4testng.Logger.loggers:Ljava/util/Map;
        24: .line 124
            getstatic org.testng.log4testng.Logger.WARN:I
            putstatic org.testng.log4testng.Logger.rootLoggerLevel:I
        25: .line 127
            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 147
            invokestatic org.testng.log4testng.Logger.initialize:()V
         1: .line 148
            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 149
            aload 1 /* logger */
            ifnull 4
         3: .line 150
            aload 1 /* logger */
            areturn
         4: .line 152
      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 153
            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 154
            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 156
            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 164
            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 177
            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 178
            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 188
            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 189
            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 205
            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 206
            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 216
            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 217
            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 224
            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 233
            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 234
            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 244
            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 245
            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 253
            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 254
            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 264
            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 265
            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 273
            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 274
            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 284
            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 285
            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 293
            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 294
            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 304
            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 305
            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 307
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 308
            aload 0 /* this */
            iload 2 /* pLevel */
            putfield org.testng.log4testng.Logger.level:I
         2: .line 309
            aload 0 /* this */
            aload 1 /* pClass */
            putfield org.testng.log4testng.Logger.klass:Ljava/lang/Class;
         3: .line 310
            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 311
            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 314
            getstatic org.testng.log4testng.Logger.initialized:Z
            ifeq 2
         1: .line 315
            return
         2: .line 320
      StackMap locals:
      StackMap stack:
            iconst_1
            putstatic org.testng.log4testng.Logger.initialized:Z
         3: .line 322
            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;
            astore 0 /* is */
        start local 0 // java.io.InputStream is
         4: .line 323
            aload 0 /* is */
            ifnonnull 6
         5: .line 324
            return
         6: .line 326
      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
         7: .line 328
            aload 1 /* properties */
            aload 0 /* is */
            invokevirtual java.util.Properties.load:(Ljava/io/InputStream;)V
         8: .line 329
            goto 11
         9: .line 330
      StackMap locals: java.io.InputStream java.util.Properties
      StackMap stack: java.io.IOException
            astore 2 /* e */
        start local 2 // java.io.IOException e
        10: .line 331
            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
        11: .line 334
      StackMap locals:
      StackMap stack:
            aload 1 /* properties */
            invokestatic org.testng.log4testng.Logger.checkProperties:(Ljava/util/Properties;)V
        12: .line 335
            return
        end local 1 // java.util.Properties properties
        end local 0 // java.io.InputStream is
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            4   13     0          is  Ljava/io/InputStream;
            7   13     1  properties  Ljava/util/Properties;
           10   11     2           e  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           7     8       9  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 340
            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 341
            aload 1 /* debugStr */
            ifnull 11
         2: .line 342
            aload 1 /* debugStr */
            ldc "true"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 5
         3: .line 343
            iconst_1
            putstatic org.testng.log4testng.Logger.debug:Z
         4: .line 344
            goto 11
         5: .line 345
      StackMap locals: java.lang.String
      StackMap stack:
            aload 1 /* debugStr */
            ldc "false"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 8
         6: .line 346
            iconst_0
            putstatic org.testng.log4testng.Logger.debug:Z
         7: .line 347
            goto 11
         8: .line 349
      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
         9: .line 350
            aload 1 /* debugStr */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        10: .line 349
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        11: .line 353
      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
        12: .line 358
            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
        13: .line 359
            aload 1 /* rootLevelStr */
            ifnull 21
        14: .line 360
            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
        15: .line 361
            aload 2 /* ilevel */
            ifnonnull 19
        16: .line 362
            new java.lang.IllegalArgumentException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Unknown level for log4testng.rootLogger "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        17: .line 363
            aload 1 /* rootLevelStr */
            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;
        18: .line 362
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        19: .line 365
      StackMap locals: java.lang.Integer
      StackMap stack:
            aload 2 /* ilevel */
            invokevirtual java.lang.Integer.intValue:()I
            putstatic org.testng.log4testng.Logger.rootLoggerLevel:I
        20: .line 366
            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
        21: .line 370
      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
        22: .line 371
            goto 39
        23: .line 372
      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
        24: .line 373
            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
        25: .line 374
            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
        26: .line 376
            aload 3 /* logger */
            ldc "log4testng."
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifne 28
        27: .line 377
            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
        28: .line 379
      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 39
        29: .line 382
            aload 3 /* logger */
            ldc "log4testng.rootLogger"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 39
        30: .line 386
            aload 3 /* logger */
            ldc "log4testng.logger."
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifne 32
        31: .line 387
            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
        32: .line 390
      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
        33: .line 391
            aload 5 /* ilevel */
            ifnonnull 37
        34: .line 392
            new java.lang.IllegalArgumentException
            dup
            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;
        35: .line 393
            ldc " in log4testng.properties"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        36: .line 392
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        37: .line 396
      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
        38: .line 397
            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
        39: .line 371
      StackMap locals: java.util.Properties java.util.Iterator
      StackMap stack:
            aload 1 /* it */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 23
        40: .line 400
            return
        end local 1 // java.util.Iterator it
        end local 0 // java.util.Properties pProperties
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   41     0   pProperties  Ljava/util/Properties;
            1   12     1      debugStr  Ljava/lang/String;
           13   21     1  rootLevelStr  Ljava/lang/String;
           15   21     2        ilevel  Ljava/lang/Integer;
           22   41     1            it  Ljava/util/Iterator;
           24   39     2         entry  Ljava/util/Map$Entry;
           25   39     3        logger  Ljava/lang/String;
           26   39     4         level  Ljava/lang/String;
           33   39     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 417
            aload 0 /* pClass */
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            astore 1 /* name */
        start local 1 // java.lang.String name
         1: .line 418
            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 420
      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 421
            aload 2 /* level */
            ifnull 6
         4: .line 422
            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 424
            aload 2 /* level */
            invokevirtual java.lang.Integer.intValue:()I
            ireturn
         6: .line 426
      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 427
            iload 3 /* dot */
            iconst_m1
            if_icmpne 10
         8: .line 428
            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 431
            getstatic org.testng.log4testng.Logger.rootLoggerLevel:I
            ireturn
        10: .line 433
      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 419
            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 438
            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 442
            aload 0 /* this */
            iload 1 /* pLevel */
            invokevirtual org.testng.log4testng.Logger.isLevelEnabled:(I)Z
            ifeq 13
         1: .line 443
            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 444
            aload 3 /* pT */
            ifnull 12
         5: .line 445
            aload 4 /* ps */
            dup
            astore 5
            monitorenter
         6: .line 446
            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 447
            aload 3 /* pT */
            aload 4 /* ps */
            invokevirtual java.lang.Throwable.printStackTrace:(Ljava/io/PrintStream;)V
         8: .line 445
            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 451
      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 454
      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 461
            getstatic org.testng.log4testng.Logger.debug:Z
            ifeq 2
         1: .line 462
            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 464
      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 477
            iconst_1
            putstatic org.testng.log4testng.Logger.initialized:Z
         1: .line 478
            getstatic org.testng.log4testng.Logger.loggers:Ljava/util/Map;
            invokeinterface java.util.Map.clear:()V
         2: .line 479
            getstatic org.testng.log4testng.Logger.WARN:I
            putstatic org.testng.log4testng.Logger.rootLoggerLevel:I
         3: .line 480
            iconst_0
            putstatic org.testng.log4testng.Logger.debug:Z
         4: .line 481
            aload 1 /* pOut */
            putstatic org.testng.log4testng.Logger.out:Ljava/io/PrintStream;
         5: .line 482
            aload 2 /* pErr */
            putstatic org.testng.log4testng.Logger.err:Ljava/io/PrintStream;
         6: .line 483
            aload 0 /* pProperties */
            invokestatic org.testng.log4testng.Logger.checkProperties:(Ljava/util/Properties;)V
         7: .line 484
            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 505
            new java.util.Properties
            dup
            invokespecial java.util.Properties.<init>:()V
            astore 0 /* props */
        start local 0 // java.util.Properties props
         1: .line 506
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 1 /* out1 */
        start local 1 // java.io.ByteArrayOutputStream out1
         2: .line 507
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 2 /* err1 */
        start local 2 // java.io.ByteArrayOutputStream err1
         3: .line 508
            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 509
            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 510
            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 511
            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 512
            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 513
            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 514
            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 515
            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 521
            new java.util.Properties
            dup
            invokespecial java.util.Properties.<init>:()V
            astore 0 /* props */
        start local 0 // java.util.Properties props
         1: .line 522
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 1 /* out1 */
        start local 1 // java.io.ByteArrayOutputStream out1
         2: .line 523
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 2 /* err1 */
        start local 2 // java.io.ByteArrayOutputStream err1
         3: .line 524
            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 525
            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 526
            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 527
            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 528
            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 529
            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 530
            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 531
            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 537
            new java.util.Properties
            dup
            invokespecial java.util.Properties.<init>:()V
            astore 0 /* props */
        start local 0 // java.util.Properties props
         1: .line 538
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 1 /* out1 */
        start local 1 // java.io.ByteArrayOutputStream out1
         2: .line 539
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 2 /* err1 */
        start local 2 // java.io.ByteArrayOutputStream err1
         3: .line 540
            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 541
            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 542
            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 543
            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 545
            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 546
            new java.lang.RuntimeException
            dup
            ldc "failure"
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;)V
            athrow
         9: .line 548
      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 551
            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 552
            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 554
            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 562
            new java.util.Properties
            dup
            invokespecial java.util.Properties.<init>:()V
            astore 0 /* props */
        start local 0 // java.util.Properties props
         1: .line 563
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 1 /* out1 */
        start local 1 // java.io.ByteArrayOutputStream out1
         2: .line 564
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 2 /* err1 */
        start local 2 // java.io.ByteArrayOutputStream err1
         3: .line 565
            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 566
            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 567
            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 569
            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 570
            aload 5 /* strLogger */
            ldc "trace should not appear"
            invokevirtual org.testng.log4testng.Logger.trace:(Ljava/lang/Object;)V
         8: .line 571
            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 572
            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 573
            aload 5 /* strLogger */
            ldc "debug should not appear"
            invokevirtual org.testng.log4testng.Logger.debug:(Ljava/lang/Object;)V
        11: .line 574
            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 575
            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 576
            aload 5 /* strLogger */
            ldc "info should not appear"
            invokevirtual org.testng.log4testng.Logger.info:(Ljava/lang/Object;)V
        14: .line 577
            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 578
            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 579
            aload 5 /* strLogger */
            ldc "warn should appear"
            invokevirtual org.testng.log4testng.Logger.warn:(Ljava/lang/Object;)V
        17: .line 580
            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 581
            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 582
            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 583
            aload 5 /* strLogger */
            ldc "error should appear"
            invokevirtual org.testng.log4testng.Logger.error:(Ljava/lang/Object;)V
        21: .line 584
            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 585
            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 586
            aload 5 /* strLogger */
            ldc "fatal should appear"
            invokevirtual org.testng.log4testng.Logger.fatal:(Ljava/lang/Object;)V
        24: .line 587
            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 588
            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 589
            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 595
            new java.util.Properties
            dup
            invokespecial java.util.Properties.<init>:()V
            astore 0 /* props */
        start local 0 // java.util.Properties props
         1: .line 596
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 1 /* out1 */
        start local 1 // java.io.ByteArrayOutputStream out1
         2: .line 597
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 2 /* err1 */
        start local 2 // java.io.ByteArrayOutputStream err1
         3: .line 598
            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 599
            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 600
            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 601
            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 603
            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 604
            aload 5 /* strLogger */
            ldc "trace should appear"
            invokevirtual org.testng.log4testng.Logger.trace:(Ljava/lang/Object;)V
         9: .line 605
            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 606
            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 607
            aload 5 /* strLogger */
            ldc "debug should appear"
            invokevirtual org.testng.log4testng.Logger.debug:(Ljava/lang/Object;)V
        12: .line 608
            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 609
            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 610
            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 616
            new java.util.Properties
            dup
            invokespecial java.util.Properties.<init>:()V
            astore 0 /* props */
        start local 0 // java.util.Properties props
         1: .line 617
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 1 /* out1 */
        start local 1 // java.io.ByteArrayOutputStream out1
         2: .line 618
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 2 /* err1 */
        start local 2 // java.io.ByteArrayOutputStream err1
         3: .line 619
            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 620
            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 621
            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 623
            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 624
            new java.lang.RuntimeException
            dup
            ldc "failure"
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;)V
            athrow
         8: .line 626
      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 629
            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 630
            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 632
            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 638
            new java.util.Properties
            dup
            invokespecial java.util.Properties.<init>:()V
            astore 0 /* props */
        start local 0 // java.util.Properties props
         1: .line 639
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 1 /* out1 */
        start local 1 // java.io.ByteArrayOutputStream out1
         2: .line 640
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 2 /* err1 */
        start local 2 // java.io.ByteArrayOutputStream err1
         3: .line 641
            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 642
            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 643
            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 644
            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 646
            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 647
            aload 5 /* strLogger */
            ldc "trace should not appear"
            invokevirtual org.testng.log4testng.Logger.trace:(Ljava/lang/Object;)V
         9: .line 648
            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 649
            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 650
            aload 5 /* strLogger */
            ldc "debug should appear"
            invokevirtual org.testng.log4testng.Logger.debug:(Ljava/lang/Object;)V
        12: .line 651
            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 652
            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 653
            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 655
            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 656
            aload 7 /* classLogger */
            ldc "debug should not appear"
            invokevirtual org.testng.log4testng.Logger.debug:(Ljava/lang/Object;)V
        17: .line 657
            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 658
            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 659
            aload 7 /* classLogger */
            ldc "warn should appear"
            invokevirtual org.testng.log4testng.Logger.warn:(Ljava/lang/Object;)V
        20: .line 660
            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 661
            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 662
            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 668
            new java.util.Properties
            dup
            invokespecial java.util.Properties.<init>:()V
            astore 0 /* props */
        start local 0 // java.util.Properties props
         1: .line 669
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 1 /* out1 */
        start local 1 // java.io.ByteArrayOutputStream out1
         2: .line 670
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 2 /* err1 */
        start local 2 // java.io.ByteArrayOutputStream err1
         3: .line 671
            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 672
            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 673
            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 675
            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 676
            new java.lang.RuntimeException
            dup
            ldc "failure"
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;)V
            athrow
         8: .line 678
      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 681
            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 682
            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 684
            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 690
            new java.util.Properties
            dup
            invokespecial java.util.Properties.<init>:()V
            astore 0 /* props */
        start local 0 // java.util.Properties props
         1: .line 691
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 1 /* out1 */
        start local 1 // java.io.ByteArrayOutputStream out1
         2: .line 692
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 2 /* err1 */
        start local 2 // java.io.ByteArrayOutputStream err1
         3: .line 693
            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 694
            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 695
            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 696
            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 698
            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 699
            aload 5 /* strLogger */
            ldc "trace should not appear"
            invokevirtual org.testng.log4testng.Logger.trace:(Ljava/lang/Object;)V
         9: .line 700
            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 701
            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 702
            aload 5 /* strLogger */
            ldc "debug should appear"
            invokevirtual org.testng.log4testng.Logger.debug:(Ljava/lang/Object;)V
        12: .line 703
            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 704
            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 705
            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 712
            invokestatic org.testng.log4testng.Logger.testDebugDefault:()V
         1: .line 713
            invokestatic org.testng.log4testng.Logger.testDebugOn:()V
         2: .line 714
            invokestatic org.testng.log4testng.Logger.testDebugOff:()V
         3: .line 715
            invokestatic org.testng.log4testng.Logger.testDebugError:()V
         4: .line 716
            invokestatic org.testng.log4testng.Logger.testRootLoggerDefault:()V
         5: .line 717
            invokestatic org.testng.log4testng.Logger.testRootLoggerSet:()V
         6: .line 718
            invokestatic org.testng.log4testng.Logger.testRootLoggerSetError:()V
         7: .line 719
            invokestatic org.testng.log4testng.Logger.testUserLoggerSet:()V
         8: .line 720
            invokestatic org.testng.log4testng.Logger.testUserLoggerSetError:()V
         9: .line 721
            invokestatic org.testng.log4testng.Logger.testUserLoggerSetHierarchy:()V
        10: .line 722
            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