public class org.jruby.util.log.OutputStreamLogger implements org.jruby.util.log.Logger
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.jruby.util.log.OutputStreamLogger
  super_class: java.lang.Object
{
  private final java.lang.String loggerName;
    descriptor: Ljava/lang/String;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private boolean debug;
    descriptor: Z
    flags: (0x0002) ACC_PRIVATE

  protected java.io.PrintStream stream;
    descriptor: Ljava/io/PrintStream;
    flags: (0x0004) ACC_PROTECTED

  public void <init>(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.jruby.util.log.OutputStreamLogger this
        start local 1 // java.lang.String loggerName
         0: .line 45
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 42
            aload 0 /* this */
            iconst_0
            putfield org.jruby.util.log.OutputStreamLogger.debug:Z
         2: .line 46
            aload 0 /* this */
            aload 1 /* loggerName */
            putfield org.jruby.util.log.OutputStreamLogger.loggerName:Ljava/lang/String;
         3: .line 47
            return
        end local 1 // java.lang.String loggerName
        end local 0 // org.jruby.util.log.OutputStreamLogger this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    4     0        this  Lorg/jruby/util/log/OutputStreamLogger;
            0    4     1  loggerName  Ljava/lang/String;
    MethodParameters:
            Name  Flags
      loggerName  

  public void <init>(java.lang.String, java.io.PrintStream);
    descriptor: (Ljava/lang/String;Ljava/io/PrintStream;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // org.jruby.util.log.OutputStreamLogger this
        start local 1 // java.lang.String loggerName
        start local 2 // java.io.PrintStream stream
         0: .line 49
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 42
            aload 0 /* this */
            iconst_0
            putfield org.jruby.util.log.OutputStreamLogger.debug:Z
         2: .line 50
            aload 0 /* this */
            aload 1 /* loggerName */
            putfield org.jruby.util.log.OutputStreamLogger.loggerName:Ljava/lang/String;
         3: .line 51
            aload 0 /* this */
            aload 2 /* stream */
            putfield org.jruby.util.log.OutputStreamLogger.stream:Ljava/io/PrintStream;
         4: .line 52
            return
        end local 2 // java.io.PrintStream stream
        end local 1 // java.lang.String loggerName
        end local 0 // org.jruby.util.log.OutputStreamLogger this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    5     0        this  Lorg/jruby/util/log/OutputStreamLogger;
            0    5     1  loggerName  Ljava/lang/String;
            0    5     2      stream  Ljava/io/PrintStream;
    MethodParameters:
            Name  Flags
      loggerName  
      stream      

  public java.lang.String getName();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.jruby.util.log.OutputStreamLogger this
         0: .line 55
            aload 0 /* this */
            getfield org.jruby.util.log.OutputStreamLogger.loggerName:Ljava/lang/String;
            areturn
        end local 0 // org.jruby.util.log.OutputStreamLogger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/jruby/util/log/OutputStreamLogger;

  public java.io.PrintStream getStream();
    descriptor: ()Ljava/io/PrintStream;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.jruby.util.log.OutputStreamLogger this
         0: .line 59
            aload 0 /* this */
            getfield org.jruby.util.log.OutputStreamLogger.stream:Ljava/io/PrintStream;
            areturn
        end local 0 // org.jruby.util.log.OutputStreamLogger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/jruby/util/log/OutputStreamLogger;

  public void setStream(java.io.PrintStream);
    descriptor: (Ljava/io/PrintStream;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.jruby.util.log.OutputStreamLogger this
        start local 1 // java.io.PrintStream stream
         0: .line 63
            aload 0 /* this */
            aload 1 /* stream */
            putfield org.jruby.util.log.OutputStreamLogger.stream:Ljava/io/PrintStream;
         1: .line 64
            return
        end local 1 // java.io.PrintStream stream
        end local 0 // org.jruby.util.log.OutputStreamLogger this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0    this  Lorg/jruby/util/log/OutputStreamLogger;
            0    2     1  stream  Ljava/io/PrintStream;
    MethodParameters:
        Name  Flags
      stream  

  public void warn(java.lang.String, java.lang.Object[]);
    descriptor: (Ljava/lang/String;[Ljava/lang/Object;)V
    flags: (0x0081) ACC_PUBLIC, ACC_VARARGS
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.jruby.util.log.OutputStreamLogger this
        start local 1 // java.lang.String message
        start local 2 // java.lang.Object[] args
         0: .line 67
            aload 0 /* this */
            aload 1 /* message */
            ldc "WARN"
            aload 2 /* args */
            invokevirtual org.jruby.util.log.OutputStreamLogger.write:(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
         1: .line 68
            return
        end local 2 // java.lang.Object[] args
        end local 1 // java.lang.String message
        end local 0 // org.jruby.util.log.OutputStreamLogger this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lorg/jruby/util/log/OutputStreamLogger;
            0    2     1  message  Ljava/lang/String;
            0    2     2     args  [Ljava/lang/Object;
    MethodParameters:
         Name  Flags
      message  
      args     

  public void warn(java.lang.Throwable);
    descriptor: (Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.jruby.util.log.OutputStreamLogger this
        start local 1 // java.lang.Throwable throwable
         0: .line 71
            aload 0 /* this */
            ldc ""
            ldc "WARN"
            aload 1 /* throwable */
            invokevirtual org.jruby.util.log.OutputStreamLogger.write:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
         1: .line 72
            return
        end local 1 // java.lang.Throwable throwable
        end local 0 // org.jruby.util.log.OutputStreamLogger this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    2     0       this  Lorg/jruby/util/log/OutputStreamLogger;
            0    2     1  throwable  Ljava/lang/Throwable;
    MethodParameters:
           Name  Flags
      throwable  

  public void warn(java.lang.String, java.lang.Throwable);
    descriptor: (Ljava/lang/String;Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.jruby.util.log.OutputStreamLogger this
        start local 1 // java.lang.String message
        start local 2 // java.lang.Throwable throwable
         0: .line 75
            aload 0 /* this */
            aload 1 /* message */
            ldc "WARN"
            aload 2 /* throwable */
            invokevirtual org.jruby.util.log.OutputStreamLogger.write:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
         1: .line 76
            return
        end local 2 // java.lang.Throwable throwable
        end local 1 // java.lang.String message
        end local 0 // org.jruby.util.log.OutputStreamLogger this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    2     0       this  Lorg/jruby/util/log/OutputStreamLogger;
            0    2     1    message  Ljava/lang/String;
            0    2     2  throwable  Ljava/lang/Throwable;
    MethodParameters:
           Name  Flags
      message    
      throwable  

  public void error(java.lang.String, java.lang.Object[]);
    descriptor: (Ljava/lang/String;[Ljava/lang/Object;)V
    flags: (0x0081) ACC_PUBLIC, ACC_VARARGS
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.jruby.util.log.OutputStreamLogger this
        start local 1 // java.lang.String message
        start local 2 // java.lang.Object[] args
         0: .line 79
            aload 0 /* this */
            aload 1 /* message */
            ldc "ERROR"
            aload 2 /* args */
            invokevirtual org.jruby.util.log.OutputStreamLogger.write:(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
         1: .line 80
            return
        end local 2 // java.lang.Object[] args
        end local 1 // java.lang.String message
        end local 0 // org.jruby.util.log.OutputStreamLogger this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lorg/jruby/util/log/OutputStreamLogger;
            0    2     1  message  Ljava/lang/String;
            0    2     2     args  [Ljava/lang/Object;
    MethodParameters:
         Name  Flags
      message  
      args     

  public void error(java.lang.Throwable);
    descriptor: (Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.jruby.util.log.OutputStreamLogger this
        start local 1 // java.lang.Throwable throwable
         0: .line 83
            aload 0 /* this */
            ldc ""
            ldc "ERROR"
            aload 1 /* throwable */
            invokevirtual org.jruby.util.log.OutputStreamLogger.write:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
         1: .line 84
            return
        end local 1 // java.lang.Throwable throwable
        end local 0 // org.jruby.util.log.OutputStreamLogger this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    2     0       this  Lorg/jruby/util/log/OutputStreamLogger;
            0    2     1  throwable  Ljava/lang/Throwable;
    MethodParameters:
           Name  Flags
      throwable  

  public void error(java.lang.String, java.lang.Throwable);
    descriptor: (Ljava/lang/String;Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.jruby.util.log.OutputStreamLogger this
        start local 1 // java.lang.String message
        start local 2 // java.lang.Throwable throwable
         0: .line 87
            aload 0 /* this */
            aload 1 /* message */
            ldc "ERROR"
            aload 2 /* throwable */
            invokevirtual org.jruby.util.log.OutputStreamLogger.write:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
         1: .line 88
            return
        end local 2 // java.lang.Throwable throwable
        end local 1 // java.lang.String message
        end local 0 // org.jruby.util.log.OutputStreamLogger this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    2     0       this  Lorg/jruby/util/log/OutputStreamLogger;
            0    2     1    message  Ljava/lang/String;
            0    2     2  throwable  Ljava/lang/Throwable;
    MethodParameters:
           Name  Flags
      message    
      throwable  

  public void info(java.lang.String, java.lang.Object[]);
    descriptor: (Ljava/lang/String;[Ljava/lang/Object;)V
    flags: (0x0081) ACC_PUBLIC, ACC_VARARGS
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.jruby.util.log.OutputStreamLogger this
        start local 1 // java.lang.String message
        start local 2 // java.lang.Object[] args
         0: .line 91
            aload 0 /* this */
            aload 1 /* message */
            ldc "INFO"
            aload 2 /* args */
            invokevirtual org.jruby.util.log.OutputStreamLogger.write:(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
         1: .line 92
            return
        end local 2 // java.lang.Object[] args
        end local 1 // java.lang.String message
        end local 0 // org.jruby.util.log.OutputStreamLogger this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lorg/jruby/util/log/OutputStreamLogger;
            0    2     1  message  Ljava/lang/String;
            0    2     2     args  [Ljava/lang/Object;
    MethodParameters:
         Name  Flags
      message  
      args     

  public void info(java.lang.Throwable);
    descriptor: (Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.jruby.util.log.OutputStreamLogger this
        start local 1 // java.lang.Throwable throwable
         0: .line 95
            aload 0 /* this */
            ldc ""
            ldc "INFO"
            aload 1 /* throwable */
            invokevirtual org.jruby.util.log.OutputStreamLogger.write:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
         1: .line 96
            return
        end local 1 // java.lang.Throwable throwable
        end local 0 // org.jruby.util.log.OutputStreamLogger this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    2     0       this  Lorg/jruby/util/log/OutputStreamLogger;
            0    2     1  throwable  Ljava/lang/Throwable;
    MethodParameters:
           Name  Flags
      throwable  

  public void info(java.lang.String, java.lang.Throwable);
    descriptor: (Ljava/lang/String;Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.jruby.util.log.OutputStreamLogger this
        start local 1 // java.lang.String message
        start local 2 // java.lang.Throwable throwable
         0: .line 99
            aload 0 /* this */
            aload 1 /* message */
            ldc "INFO"
            aload 2 /* throwable */
            invokevirtual org.jruby.util.log.OutputStreamLogger.write:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
         1: .line 100
            return
        end local 2 // java.lang.Throwable throwable
        end local 1 // java.lang.String message
        end local 0 // org.jruby.util.log.OutputStreamLogger this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    2     0       this  Lorg/jruby/util/log/OutputStreamLogger;
            0    2     1    message  Ljava/lang/String;
            0    2     2  throwable  Ljava/lang/Throwable;
    MethodParameters:
           Name  Flags
      message    
      throwable  

  public void debug(java.lang.String, java.lang.Object[]);
    descriptor: (Ljava/lang/String;[Ljava/lang/Object;)V
    flags: (0x0081) ACC_PUBLIC, ACC_VARARGS
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.jruby.util.log.OutputStreamLogger this
        start local 1 // java.lang.String message
        start local 2 // java.lang.Object[] args
         0: .line 103
            aload 0 /* this */
            getfield org.jruby.util.log.OutputStreamLogger.debug:Z
            ifeq 1
            aload 0 /* this */
            aload 1 /* message */
            ldc "DEBUG"
            aload 2 /* args */
            invokevirtual org.jruby.util.log.OutputStreamLogger.write:(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
         1: .line 104
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.lang.Object[] args
        end local 1 // java.lang.String message
        end local 0 // org.jruby.util.log.OutputStreamLogger this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lorg/jruby/util/log/OutputStreamLogger;
            0    2     1  message  Ljava/lang/String;
            0    2     2     args  [Ljava/lang/Object;
    MethodParameters:
         Name  Flags
      message  
      args     

  public void debug(java.lang.Throwable);
    descriptor: (Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.jruby.util.log.OutputStreamLogger this
        start local 1 // java.lang.Throwable throwable
         0: .line 107
            aload 0 /* this */
            getfield org.jruby.util.log.OutputStreamLogger.debug:Z
            ifeq 1
            aload 0 /* this */
            ldc ""
            ldc "DEBUG"
            aload 1 /* throwable */
            invokevirtual org.jruby.util.log.OutputStreamLogger.write:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
         1: .line 108
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.Throwable throwable
        end local 0 // org.jruby.util.log.OutputStreamLogger this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    2     0       this  Lorg/jruby/util/log/OutputStreamLogger;
            0    2     1  throwable  Ljava/lang/Throwable;
    MethodParameters:
           Name  Flags
      throwable  

  public void debug(java.lang.String, java.lang.Throwable);
    descriptor: (Ljava/lang/String;Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.jruby.util.log.OutputStreamLogger this
        start local 1 // java.lang.String message
        start local 2 // java.lang.Throwable throwable
         0: .line 111
            aload 0 /* this */
            getfield org.jruby.util.log.OutputStreamLogger.debug:Z
            ifeq 1
            aload 0 /* this */
            aload 1 /* message */
            ldc "DEBUG"
            aload 2 /* throwable */
            invokevirtual org.jruby.util.log.OutputStreamLogger.write:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
         1: .line 112
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.lang.Throwable throwable
        end local 1 // java.lang.String message
        end local 0 // org.jruby.util.log.OutputStreamLogger this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    2     0       this  Lorg/jruby/util/log/OutputStreamLogger;
            0    2     1    message  Ljava/lang/String;
            0    2     2  throwable  Ljava/lang/Throwable;
    MethodParameters:
           Name  Flags
      message    
      throwable  

  public boolean isDebugEnabled();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.jruby.util.log.OutputStreamLogger this
         0: .line 115
            aload 0 /* this */
            getfield org.jruby.util.log.OutputStreamLogger.debug:Z
            ireturn
        end local 0 // org.jruby.util.log.OutputStreamLogger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/jruby/util/log/OutputStreamLogger;

  public void setDebugEnable(boolean);
    descriptor: (Z)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.jruby.util.log.OutputStreamLogger this
        start local 1 // boolean debug
         0: .line 119
            aload 0 /* this */
            iload 1 /* debug */
            putfield org.jruby.util.log.OutputStreamLogger.debug:Z
         1: .line 120
            return
        end local 1 // boolean debug
        end local 0 // org.jruby.util.log.OutputStreamLogger this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    2     0   this  Lorg/jruby/util/log/OutputStreamLogger;
            0    2     1  debug  Z
    MethodParameters:
       Name  Flags
      debug  

  protected void write(java.lang.String, java.lang.String, java.lang.Object[]);
    descriptor: (Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=5, args_size=4
        start local 0 // org.jruby.util.log.OutputStreamLogger this
        start local 1 // java.lang.String message
        start local 2 // java.lang.String level
        start local 3 // java.lang.Object[] args
         0: .line 123
            aload 1 /* message */
            aload 3 /* args */
            invokestatic org.jruby.util.log.OutputStreamLogger.substitute:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/CharSequence;
            astore 4 /* suble */
        start local 4 // java.lang.CharSequence suble
         1: .line 124
            aload 0 /* this */
            getfield org.jruby.util.log.OutputStreamLogger.stream:Ljava/io/PrintStream;
            aload 0 /* this */
            aload 4 /* suble */
            aload 2 /* level */
            invokevirtual org.jruby.util.log.OutputStreamLogger.formatMessage:(Ljava/lang/CharSequence;Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         2: .line 125
            return
        end local 4 // java.lang.CharSequence suble
        end local 3 // java.lang.Object[] args
        end local 2 // java.lang.String level
        end local 1 // java.lang.String message
        end local 0 // org.jruby.util.log.OutputStreamLogger this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    3     0     this  Lorg/jruby/util/log/OutputStreamLogger;
            0    3     1  message  Ljava/lang/String;
            0    3     2    level  Ljava/lang/String;
            0    3     3     args  [Ljava/lang/Object;
            1    3     4    suble  Ljava/lang/CharSequence;
    MethodParameters:
         Name  Flags
      message  
      level    
      args     

  protected void write(java.lang.String, java.lang.String, java.lang.Throwable);
    descriptor: (Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=5, args_size=4
        start local 0 // org.jruby.util.log.OutputStreamLogger this
        start local 1 // java.lang.String message
        start local 2 // java.lang.String level
        start local 3 // java.lang.Throwable throwable
         0: .line 128
            aload 0 /* this */
            getfield org.jruby.util.log.OutputStreamLogger.stream:Ljava/io/PrintStream;
            dup
            astore 4
            monitorenter
         1: .line 129
            aload 0 /* this */
            getfield org.jruby.util.log.OutputStreamLogger.stream:Ljava/io/PrintStream;
            aload 0 /* this */
            aload 1 /* message */
            aload 2 /* level */
            invokevirtual org.jruby.util.log.OutputStreamLogger.formatMessage:(Ljava/lang/CharSequence;Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         2: .line 131
            aload 0 /* this */
            getfield org.jruby.util.log.OutputStreamLogger.stream:Ljava/io/PrintStream;
            aload 3 /* throwable */
            invokestatic org.jruby.util.log.OutputStreamLogger.writeStackTrace:(Ljava/io/PrintStream;Ljava/lang/Throwable;)V
         3: .line 128
            aload 4
            monitorexit
         4: goto 7
      StackMap locals: org.jruby.util.log.OutputStreamLogger java.lang.String java.lang.String java.lang.Throwable java.io.PrintStream
      StackMap stack: java.lang.Throwable
         5: aload 4
            monitorexit
         6: athrow
         7: .line 133
      StackMap locals:
      StackMap stack:
            return
        end local 3 // java.lang.Throwable throwable
        end local 2 // java.lang.String level
        end local 1 // java.lang.String message
        end local 0 // org.jruby.util.log.OutputStreamLogger this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    8     0       this  Lorg/jruby/util/log/OutputStreamLogger;
            0    8     1    message  Ljava/lang/String;
            0    8     2      level  Ljava/lang/String;
            0    8     3  throwable  Ljava/lang/Throwable;
      Exception table:
        from    to  target  type
           1     4       5  any
           5     6       5  any
    MethodParameters:
           Name  Flags
      message    
      level      
      throwable  

  protected static void writeStackTrace(java.io.PrintStream, java.lang.Throwable);
    descriptor: (Ljava/io/PrintStream;Ljava/lang/Throwable;)V
    flags: (0x000c) ACC_PROTECTED, ACC_STATIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // java.io.PrintStream stream
        start local 1 // java.lang.Throwable throwable
         0: .line 136
            aload 1 /* throwable */
            ifnonnull 2
         1: .line 137
            new java.lang.IllegalArgumentException
            dup
            ldc "null throwable"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 140
      StackMap locals:
      StackMap stack:
            aload 1 /* throwable */
            aload 0 /* stream */
            invokevirtual java.lang.Throwable.printStackTrace:(Ljava/io/PrintStream;)V
         3: .line 141
            return
        end local 1 // java.lang.Throwable throwable
        end local 0 // java.io.PrintStream stream
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    4     0     stream  Ljava/io/PrintStream;
            0    4     1  throwable  Ljava/lang/Throwable;
    MethodParameters:
           Name  Flags
      stream     
      throwable  

  protected java.lang.String formatMessage(java.lang.CharSequence, java.lang.String);
    descriptor: (Ljava/lang/CharSequence;Ljava/lang/String;)Ljava/lang/String;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=3, args_size=3
        start local 0 // org.jruby.util.log.OutputStreamLogger this
        start local 1 // java.lang.CharSequence message
        start local 2 // java.lang.String level
         0: .line 145
            new java.lang.StringBuilder
            dup
            bipush 64
            invokespecial java.lang.StringBuilder.<init>:(I)V
         1: .line 146
            new org.joda.time.DateTime
            dup
            invokestatic java.lang.System.currentTimeMillis:()J
            invokespecial org.joda.time.DateTime.<init>:(J)V
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
         2: .line 147
            bipush 32
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
         3: .line 148
            bipush 91
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            invokevirtual java.lang.Thread.getName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            bipush 93
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
         4: .line 149
            bipush 32
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
         5: .line 150
            aload 2 /* level */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         6: .line 151
            bipush 32
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
         7: .line 152
            aload 0 /* this */
            getfield org.jruby.util.log.OutputStreamLogger.loggerName:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         8: .line 153
            ldc " : "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         9: .line 154
            aload 1 /* message */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/CharSequence;)Ljava/lang/StringBuilder;
        10: .line 155
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        11: .line 145
            areturn
        end local 2 // java.lang.String level
        end local 1 // java.lang.CharSequence message
        end local 0 // org.jruby.util.log.OutputStreamLogger this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   12     0     this  Lorg/jruby/util/log/OutputStreamLogger;
            0   12     1  message  Ljava/lang/CharSequence;
            0   12     2    level  Ljava/lang/String;
    MethodParameters:
         Name  Flags
      message  
      level    

  static java.lang.CharSequence substitute(java.lang.String, java.lang.Object[]);
    descriptor: (Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/CharSequence;
    flags: (0x0088) ACC_STATIC, ACC_VARARGS
    Code:
      stack=4, locals=7, args_size=2
        start local 0 // java.lang.String messagePattern
        start local 1 // java.lang.Object[] args
         0: .line 164
            aload 0 /* messagePattern */
            ifnonnull 7
         1: .line 165
            new java.lang.StringBuilder
            dup
            invokespecial java.lang.StringBuilder.<init>:()V
            astore 2 /* msg */
        start local 2 // java.lang.StringBuilder msg
         2: .line 166
            iconst_0
            istore 3 /* i */
        start local 3 // int i
         3: goto 5
      StackMap locals: java.lang.StringBuilder int
      StackMap stack:
         4: aload 2 /* msg */
            aload 1 /* args */
            iload 3 /* i */
            aaload
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            pop
            iinc 3 /* i */ 1
      StackMap locals:
      StackMap stack:
         5: iload 3 /* i */
            aload 1 /* args */
            arraylength
            if_icmplt 4
        end local 3 // int i
         6: .line 167
            aload 2 /* msg */
            areturn
        end local 2 // java.lang.StringBuilder msg
         7: .line 170
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 2 /* msg */
        start local 2 // java.lang.StringBuilder msg
         8: .line 171
            aload 0 /* messagePattern */
            invokevirtual java.lang.String.length:()I
            istore 3 /* len */
        start local 3 // int len
         9: iconst_0
            istore 4 /* s */
        start local 4 // int s
        10: iconst_0
            istore 5 /* a */
        start local 5 // int a
        11: .line 172
            iconst_0
            istore 6 /* i */
        start local 6 // int i
        12: goto 24
        13: .line 173
      StackMap locals: java.lang.String java.lang.Object[] java.lang.StringBuilder int int int int
      StackMap stack:
            aload 0 /* messagePattern */
            iload 6 /* i */
            invokevirtual java.lang.String.charAt:(I)C
            bipush 123
            if_icmpne 23
        14: .line 174
            iload 6 /* i */
            ifeq 15
            iload 6 /* i */
            ifle 23
            aload 0 /* messagePattern */
            iload 6 /* i */
            iconst_1
            isub
            invokevirtual java.lang.String.charAt:(I)C
            bipush 92
            if_icmpeq 23
        15: .line 175
      StackMap locals:
      StackMap stack:
            iload 6 /* i */
            iload 3 /* len */
            iconst_1
            isub
            if_icmpge 23
            aload 0 /* messagePattern */
            iload 6 /* i */
            iconst_1
            iadd
            invokevirtual java.lang.String.charAt:(I)C
            bipush 125
            if_icmpne 23
        16: .line 177
            aload 2 /* msg */
            ifnonnull 18
        17: .line 178
            new java.lang.StringBuilder
            dup
            iload 3 /* len */
            bipush 48
            iadd
            invokespecial java.lang.StringBuilder.<init>:(I)V
            astore 2 /* msg */
        18: .line 181
      StackMap locals:
      StackMap stack:
            aload 2 /* msg */
            aload 0 /* messagePattern */
            iload 4 /* s */
            iload 6 /* i */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/CharSequence;II)Ljava/lang/StringBuilder;
            pop
            iload 6 /* i */
            iconst_2
            iadd
            istore 4 /* s */
        19: .line 183
            iload 5 /* a */
            aload 1 /* args */
            arraylength
            if_icmpge 22
        20: .line 184
            aload 2 /* msg */
            aload 1 /* args */
            iload 5 /* a */
            iinc 5 /* a */ 1
            aaload
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            pop
        21: .line 185
            goto 23
        22: .line 187
      StackMap locals:
      StackMap stack:
            aload 2 /* msg */
            ldc "{!abs-arg!}"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        23: .line 172
      StackMap locals:
      StackMap stack:
            iinc 6 /* i */ 1
      StackMap locals:
      StackMap stack:
        24: iload 6 /* i */
            iload 3 /* len */
            if_icmplt 13
        end local 6 // int i
        25: .line 192
            aload 2 /* msg */
            ifnull 28
        26: .line 193
            iload 4 /* s */
            iload 3 /* len */
            if_icmpge 27
            aload 2 /* msg */
            aload 0 /* messagePattern */
            iload 4 /* s */
            iload 3 /* len */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/CharSequence;II)Ljava/lang/StringBuilder;
            pop
        27: .line 194
      StackMap locals:
      StackMap stack:
            aload 2 /* msg */
            areturn
        28: .line 196
      StackMap locals:
      StackMap stack:
            aload 0 /* messagePattern */
            areturn
        end local 5 // int a
        end local 4 // int s
        end local 3 // int len
        end local 2 // java.lang.StringBuilder msg
        end local 1 // java.lang.Object[] args
        end local 0 // java.lang.String messagePattern
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   29     0  messagePattern  Ljava/lang/String;
            0   29     1            args  [Ljava/lang/Object;
            2    7     2             msg  Ljava/lang/StringBuilder;
            3    6     3               i  I
            8   29     2             msg  Ljava/lang/StringBuilder;
            9   29     3             len  I
           10   29     4               s  I
           11   29     5               a  I
           12   25     6               i  I
    MethodParameters:
                Name  Flags
      messagePattern  final
      args            
}
SourceFile: "OutputStreamLogger.java"