public class ch.qos.logback.core.OutputStreamAppender<E> extends ch.qos.logback.core.UnsynchronizedAppenderBase<E>
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: ch.qos.logback.core.OutputStreamAppender
  super_class: ch.qos.logback.core.UnsynchronizedAppenderBase
{
  protected ch.qos.logback.core.encoder.Encoder<E> encoder;
    descriptor: Lch/qos/logback/core/encoder/Encoder;
    flags: (0x0004) ACC_PROTECTED
    Signature: Lch/qos/logback/core/encoder/Encoder<TE;>;

  protected final java.util.concurrent.locks.ReentrantLock lock;
    descriptor: Ljava/util/concurrent/locks/ReentrantLock;
    flags: (0x0014) ACC_PROTECTED, ACC_FINAL

  private java.io.OutputStream outputStream;
    descriptor: Ljava/io/OutputStream;
    flags: (0x0002) ACC_PRIVATE

  boolean immediateFlush;
    descriptor: Z
    flags: (0x0000) 

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // ch.qos.logback.core.OutputStreamAppender this
         0: .line 36
            aload 0 /* this */
            invokespecial ch.qos.logback.core.UnsynchronizedAppenderBase.<init>:()V
         1: .line 47
            aload 0 /* this */
            new java.util.concurrent.locks.ReentrantLock
            dup
            iconst_0
            invokespecial java.util.concurrent.locks.ReentrantLock.<init>:(Z)V
            putfield ch.qos.logback.core.OutputStreamAppender.lock:Ljava/util/concurrent/locks/ReentrantLock;
         2: .line 54
            aload 0 /* this */
            iconst_1
            putfield ch.qos.logback.core.OutputStreamAppender.immediateFlush:Z
         3: .line 36
            return
        end local 0 // ch.qos.logback.core.OutputStreamAppender this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lch/qos/logback/core/OutputStreamAppender<TE;>;

  public java.io.OutputStream getOutputStream();
    descriptor: ()Ljava/io/OutputStream;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // ch.qos.logback.core.OutputStreamAppender this
         0: .line 62
            aload 0 /* this */
            getfield ch.qos.logback.core.OutputStreamAppender.outputStream:Ljava/io/OutputStream;
            areturn
        end local 0 // ch.qos.logback.core.OutputStreamAppender this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lch/qos/logback/core/OutputStreamAppender<TE;>;

  public void start();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=2, args_size=1
        start local 0 // ch.qos.logback.core.OutputStreamAppender this
         0: .line 70
            iconst_0
            istore 1 /* errors */
        start local 1 // int errors
         1: .line 71
            aload 0 /* this */
            getfield ch.qos.logback.core.OutputStreamAppender.encoder:Lch/qos/logback/core/encoder/Encoder;
            ifnonnull 4
         2: .line 72
            aload 0 /* this */
            new ch.qos.logback.core.status.ErrorStatus
            dup
            new java.lang.StringBuilder
            dup
            ldc "No encoder set for the appender named \""
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield ch.qos.logback.core.OutputStreamAppender.name: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;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 0 /* this */
            invokespecial ch.qos.logback.core.status.ErrorStatus.<init>:(Ljava/lang/String;Ljava/lang/Object;)V
            invokevirtual ch.qos.logback.core.OutputStreamAppender.addStatus:(Lch/qos/logback/core/status/Status;)V
         3: .line 73
            iinc 1 /* errors */ 1
         4: .line 76
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield ch.qos.logback.core.OutputStreamAppender.outputStream:Ljava/io/OutputStream;
            ifnonnull 7
         5: .line 77
            aload 0 /* this */
            new ch.qos.logback.core.status.ErrorStatus
            dup
            new java.lang.StringBuilder
            dup
            ldc "No output stream set for the appender named \""
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield ch.qos.logback.core.OutputStreamAppender.name: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;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 0 /* this */
            invokespecial ch.qos.logback.core.status.ErrorStatus.<init>:(Ljava/lang/String;Ljava/lang/Object;)V
            invokevirtual ch.qos.logback.core.OutputStreamAppender.addStatus:(Lch/qos/logback/core/status/Status;)V
         6: .line 78
            iinc 1 /* errors */ 1
         7: .line 81
      StackMap locals:
      StackMap stack:
            iload 1 /* errors */
            ifne 9
         8: .line 82
            aload 0 /* this */
            invokespecial ch.qos.logback.core.UnsynchronizedAppenderBase.start:()V
         9: .line 84
      StackMap locals:
      StackMap stack:
            return
        end local 1 // int errors
        end local 0 // ch.qos.logback.core.OutputStreamAppender this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   10     0    this  Lch/qos/logback/core/OutputStreamAppender<TE;>;
            1   10     1  errors  I

  public void setLayout(ch.qos.logback.core.Layout<E>);
    descriptor: (Lch/qos/logback/core/Layout;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // ch.qos.logback.core.OutputStreamAppender this
        start local 1 // ch.qos.logback.core.Layout layout
         0: .line 87
            aload 0 /* this */
            ldc "This appender no longer admits a layout as a sub-component, set an encoder instead."
            invokevirtual ch.qos.logback.core.OutputStreamAppender.addWarn:(Ljava/lang/String;)V
         1: .line 88
            aload 0 /* this */
            ldc "To ensure compatibility, wrapping your layout in LayoutWrappingEncoder."
            invokevirtual ch.qos.logback.core.OutputStreamAppender.addWarn:(Ljava/lang/String;)V
         2: .line 89
            aload 0 /* this */
            ldc "See also http://logback.qos.ch/codes.html#layoutInsteadOfEncoder for details"
            invokevirtual ch.qos.logback.core.OutputStreamAppender.addWarn:(Ljava/lang/String;)V
         3: .line 90
            new ch.qos.logback.core.encoder.LayoutWrappingEncoder
            dup
            invokespecial ch.qos.logback.core.encoder.LayoutWrappingEncoder.<init>:()V
            astore 2 /* lwe */
        start local 2 // ch.qos.logback.core.encoder.LayoutWrappingEncoder lwe
         4: .line 91
            aload 2 /* lwe */
            aload 1 /* layout */
            invokevirtual ch.qos.logback.core.encoder.LayoutWrappingEncoder.setLayout:(Lch/qos/logback/core/Layout;)V
         5: .line 92
            aload 2 /* lwe */
            aload 0 /* this */
            getfield ch.qos.logback.core.OutputStreamAppender.context:Lch/qos/logback/core/Context;
            invokevirtual ch.qos.logback.core.encoder.LayoutWrappingEncoder.setContext:(Lch/qos/logback/core/Context;)V
         6: .line 93
            aload 0 /* this */
            aload 2 /* lwe */
            putfield ch.qos.logback.core.OutputStreamAppender.encoder:Lch/qos/logback/core/encoder/Encoder;
         7: .line 94
            return
        end local 2 // ch.qos.logback.core.encoder.LayoutWrappingEncoder lwe
        end local 1 // ch.qos.logback.core.Layout layout
        end local 0 // ch.qos.logback.core.OutputStreamAppender this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    8     0    this  Lch/qos/logback/core/OutputStreamAppender<TE;>;
            0    8     1  layout  Lch/qos/logback/core/Layout<TE;>;
            4    8     2     lwe  Lch/qos/logback/core/encoder/LayoutWrappingEncoder<TE;>;
    Signature: (Lch/qos/logback/core/Layout<TE;>;)V
    MethodParameters:
        Name  Flags
      layout  

  protected void append();
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // ch.qos.logback.core.OutputStreamAppender this
        start local 1 // java.lang.Object eventObject
         0: .line 98
            aload 0 /* this */
            invokevirtual ch.qos.logback.core.OutputStreamAppender.isStarted:()Z
            ifne 2
         1: .line 99
            return
         2: .line 102
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* eventObject */
            invokevirtual ch.qos.logback.core.OutputStreamAppender.subAppend:(Ljava/lang/Object;)V
         3: .line 103
            return
        end local 1 // java.lang.Object eventObject
        end local 0 // ch.qos.logback.core.OutputStreamAppender this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    4     0         this  Lch/qos/logback/core/OutputStreamAppender<TE;>;
            0    4     1  eventObject  TE;
    Signature: (TE;)V
    MethodParameters:
             Name  Flags
      eventObject  

  public void stop();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=2, args_size=1
        start local 0 // ch.qos.logback.core.OutputStreamAppender this
         0: .line 113
            aload 0 /* this */
            getfield ch.qos.logback.core.OutputStreamAppender.lock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.lock:()V
         1: .line 115
            aload 0 /* this */
            invokevirtual ch.qos.logback.core.OutputStreamAppender.closeOutputStream:()V
         2: .line 116
            aload 0 /* this */
            invokespecial ch.qos.logback.core.UnsynchronizedAppenderBase.stop:()V
         3: .line 117
            goto 7
      StackMap locals:
      StackMap stack: java.lang.Throwable
         4: astore 1
         5: .line 118
            aload 0 /* this */
            getfield ch.qos.logback.core.OutputStreamAppender.lock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
         6: .line 119
            aload 1
            athrow
         7: .line 118
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield ch.qos.logback.core.OutputStreamAppender.lock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
         8: .line 120
            return
        end local 0 // ch.qos.logback.core.OutputStreamAppender this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    9     0  this  Lch/qos/logback/core/OutputStreamAppender<TE;>;
      Exception table:
        from    to  target  type
           1     4       4  any

  protected void closeOutputStream();
    descriptor: ()V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=6, locals=2, args_size=1
        start local 0 // ch.qos.logback.core.OutputStreamAppender this
         0: .line 126
            aload 0 /* this */
            getfield ch.qos.logback.core.OutputStreamAppender.outputStream:Ljava/io/OutputStream;
            ifnull 7
         1: .line 129
            aload 0 /* this */
            invokevirtual ch.qos.logback.core.OutputStreamAppender.encoderClose:()V
         2: .line 130
            aload 0 /* this */
            getfield ch.qos.logback.core.OutputStreamAppender.outputStream:Ljava/io/OutputStream;
            invokevirtual java.io.OutputStream.close:()V
         3: .line 131
            aload 0 /* this */
            aconst_null
            putfield ch.qos.logback.core.OutputStreamAppender.outputStream:Ljava/io/OutputStream;
         4: .line 132
            goto 7
      StackMap locals:
      StackMap stack: java.io.IOException
         5: astore 1 /* e */
        start local 1 // java.io.IOException e
         6: .line 133
            aload 0 /* this */
            new ch.qos.logback.core.status.ErrorStatus
            dup
            ldc "Could not close output stream for OutputStreamAppender."
            aload 0 /* this */
            aload 1 /* e */
            invokespecial ch.qos.logback.core.status.ErrorStatus.<init>:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Throwable;)V
            invokevirtual ch.qos.logback.core.OutputStreamAppender.addStatus:(Lch/qos/logback/core/status/Status;)V
        end local 1 // java.io.IOException e
         7: .line 136
      StackMap locals:
      StackMap stack:
            return
        end local 0 // ch.qos.logback.core.OutputStreamAppender this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Lch/qos/logback/core/OutputStreamAppender<TE;>;
            6    7     1     e  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           1     4       5  Class java.io.IOException

  void encoderClose();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=6, locals=2, args_size=1
        start local 0 // ch.qos.logback.core.OutputStreamAppender this
         0: .line 139
            aload 0 /* this */
            getfield ch.qos.logback.core.OutputStreamAppender.encoder:Lch/qos/logback/core/encoder/Encoder;
            ifnull 7
            aload 0 /* this */
            getfield ch.qos.logback.core.OutputStreamAppender.outputStream:Ljava/io/OutputStream;
            ifnull 7
         1: .line 141
            aload 0 /* this */
            getfield ch.qos.logback.core.OutputStreamAppender.encoder:Lch/qos/logback/core/encoder/Encoder;
            invokeinterface ch.qos.logback.core.encoder.Encoder.footerBytes:()[B
            astore 1 /* footer */
        start local 1 // byte[] footer
         2: .line 142
            aload 0 /* this */
            aload 1 /* footer */
            invokevirtual ch.qos.logback.core.OutputStreamAppender.writeBytes:([B)V
        end local 1 // byte[] footer
         3: .line 143
            goto 7
      StackMap locals:
      StackMap stack: java.io.IOException
         4: astore 1 /* ioe */
        start local 1 // java.io.IOException ioe
         5: .line 144
            aload 0 /* this */
            iconst_0
            putfield ch.qos.logback.core.OutputStreamAppender.started:Z
         6: .line 145
            aload 0 /* this */
            new ch.qos.logback.core.status.ErrorStatus
            dup
            new java.lang.StringBuilder
            dup
            ldc "Failed to write footer for appender named ["
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield ch.qos.logback.core.OutputStreamAppender.name: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;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 0 /* this */
            aload 1 /* ioe */
            invokespecial ch.qos.logback.core.status.ErrorStatus.<init>:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Throwable;)V
            invokevirtual ch.qos.logback.core.OutputStreamAppender.addStatus:(Lch/qos/logback/core/status/Status;)V
        end local 1 // java.io.IOException ioe
         7: .line 148
      StackMap locals:
      StackMap stack:
            return
        end local 0 // ch.qos.logback.core.OutputStreamAppender this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    8     0    this  Lch/qos/logback/core/OutputStreamAppender<TE;>;
            2    3     1  footer  [B
            5    7     1     ioe  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           1     3       4  Class java.io.IOException

  public void setOutputStream(java.io.OutputStream);
    descriptor: (Ljava/io/OutputStream;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // ch.qos.logback.core.OutputStreamAppender this
        start local 1 // java.io.OutputStream outputStream
         0: .line 161
            aload 0 /* this */
            getfield ch.qos.logback.core.OutputStreamAppender.lock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.lock:()V
         1: .line 164
            aload 0 /* this */
            invokevirtual ch.qos.logback.core.OutputStreamAppender.closeOutputStream:()V
         2: .line 165
            aload 0 /* this */
            aload 1 /* outputStream */
            putfield ch.qos.logback.core.OutputStreamAppender.outputStream:Ljava/io/OutputStream;
         3: .line 166
            aload 0 /* this */
            getfield ch.qos.logback.core.OutputStreamAppender.encoder:Lch/qos/logback/core/encoder/Encoder;
            ifnonnull 7
         4: .line 167
            aload 0 /* this */
            ldc "Encoder has not been set. Cannot invoke its init method."
            invokevirtual ch.qos.logback.core.OutputStreamAppender.addWarn:(Ljava/lang/String;)V
         5: .line 173
            aload 0 /* this */
            getfield ch.qos.logback.core.OutputStreamAppender.lock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
         6: .line 168
            return
         7: .line 171
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual ch.qos.logback.core.OutputStreamAppender.encoderInit:()V
         8: .line 172
            goto 12
      StackMap locals:
      StackMap stack: java.lang.Throwable
         9: astore 2
        10: .line 173
            aload 0 /* this */
            getfield ch.qos.logback.core.OutputStreamAppender.lock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        11: .line 174
            aload 2
            athrow
        12: .line 173
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield ch.qos.logback.core.OutputStreamAppender.lock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        13: .line 175
            return
        end local 1 // java.io.OutputStream outputStream
        end local 0 // ch.qos.logback.core.OutputStreamAppender this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   14     0          this  Lch/qos/logback/core/OutputStreamAppender<TE;>;
            0   14     1  outputStream  Ljava/io/OutputStream;
      Exception table:
        from    to  target  type
           1     5       9  any
           7     9       9  any
    MethodParameters:
              Name  Flags
      outputStream  

  void encoderInit();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=6, locals=2, args_size=1
        start local 0 // ch.qos.logback.core.OutputStreamAppender this
         0: .line 178
            aload 0 /* this */
            getfield ch.qos.logback.core.OutputStreamAppender.encoder:Lch/qos/logback/core/encoder/Encoder;
            ifnull 7
            aload 0 /* this */
            getfield ch.qos.logback.core.OutputStreamAppender.outputStream:Ljava/io/OutputStream;
            ifnull 7
         1: .line 180
            aload 0 /* this */
            getfield ch.qos.logback.core.OutputStreamAppender.encoder:Lch/qos/logback/core/encoder/Encoder;
            invokeinterface ch.qos.logback.core.encoder.Encoder.headerBytes:()[B
            astore 1 /* header */
        start local 1 // byte[] header
         2: .line 181
            aload 0 /* this */
            aload 1 /* header */
            invokevirtual ch.qos.logback.core.OutputStreamAppender.writeBytes:([B)V
        end local 1 // byte[] header
         3: .line 182
            goto 7
      StackMap locals:
      StackMap stack: java.io.IOException
         4: astore 1 /* ioe */
        start local 1 // java.io.IOException ioe
         5: .line 183
            aload 0 /* this */
            iconst_0
            putfield ch.qos.logback.core.OutputStreamAppender.started:Z
         6: .line 184
            aload 0 /* this */
            new ch.qos.logback.core.status.ErrorStatus
            dup
            new java.lang.StringBuilder
            dup
            ldc "Failed to initialize encoder for appender named ["
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield ch.qos.logback.core.OutputStreamAppender.name: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;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 0 /* this */
            aload 1 /* ioe */
            invokespecial ch.qos.logback.core.status.ErrorStatus.<init>:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Throwable;)V
            invokevirtual ch.qos.logback.core.OutputStreamAppender.addStatus:(Lch/qos/logback/core/status/Status;)V
        end local 1 // java.io.IOException ioe
         7: .line 187
      StackMap locals:
      StackMap stack:
            return
        end local 0 // ch.qos.logback.core.OutputStreamAppender this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    8     0    this  Lch/qos/logback/core/OutputStreamAppender<TE;>;
            2    3     1  header  [B
            5    7     1     ioe  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           1     3       4  Class java.io.IOException

  protected void writeOut();
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // ch.qos.logback.core.OutputStreamAppender this
        start local 1 // java.lang.Object event
         0: .line 189
            aload 0 /* this */
            getfield ch.qos.logback.core.OutputStreamAppender.encoder:Lch/qos/logback/core/encoder/Encoder;
            aload 1 /* event */
            invokeinterface ch.qos.logback.core.encoder.Encoder.encode:(Ljava/lang/Object;)[B
            astore 2 /* byteArray */
        start local 2 // byte[] byteArray
         1: .line 190
            aload 0 /* this */
            aload 2 /* byteArray */
            invokevirtual ch.qos.logback.core.OutputStreamAppender.writeBytes:([B)V
         2: .line 191
            return
        end local 2 // byte[] byteArray
        end local 1 // java.lang.Object event
        end local 0 // ch.qos.logback.core.OutputStreamAppender this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    3     0       this  Lch/qos/logback/core/OutputStreamAppender<TE;>;
            0    3     1      event  TE;
            1    3     2  byteArray  [B
    Exceptions:
      throws java.io.IOException
    Signature: (TE;)V
    MethodParameters:
       Name  Flags
      event  

  private void writeBytes(byte[]);
    descriptor: ([B)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // ch.qos.logback.core.OutputStreamAppender this
        start local 1 // byte[] byteArray
         0: .line 194
            aload 1 /* byteArray */
            ifnull 1
            aload 1 /* byteArray */
            arraylength
            ifne 2
         1: .line 195
      StackMap locals:
      StackMap stack:
            return
         2: .line 197
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield ch.qos.logback.core.OutputStreamAppender.lock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.lock:()V
         3: .line 199
            aload 0 /* this */
            getfield ch.qos.logback.core.OutputStreamAppender.outputStream:Ljava/io/OutputStream;
            aload 1 /* byteArray */
            invokevirtual java.io.OutputStream.write:([B)V
         4: .line 200
            aload 0 /* this */
            getfield ch.qos.logback.core.OutputStreamAppender.immediateFlush:Z
            ifeq 10
         5: .line 201
            aload 0 /* this */
            getfield ch.qos.logback.core.OutputStreamAppender.outputStream:Ljava/io/OutputStream;
            invokevirtual java.io.OutputStream.flush:()V
         6: .line 203
            goto 10
      StackMap locals:
      StackMap stack: java.lang.Throwable
         7: astore 2
         8: .line 204
            aload 0 /* this */
            getfield ch.qos.logback.core.OutputStreamAppender.lock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
         9: .line 205
            aload 2
            athrow
        10: .line 204
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield ch.qos.logback.core.OutputStreamAppender.lock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        11: .line 206
            return
        end local 1 // byte[] byteArray
        end local 0 // ch.qos.logback.core.OutputStreamAppender this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   12     0       this  Lch/qos/logback/core/OutputStreamAppender<TE;>;
            0   12     1  byteArray  [B
      Exception table:
        from    to  target  type
           3     7       7  any
    Exceptions:
      throws java.io.IOException
    MethodParameters:
           Name  Flags
      byteArray  

  protected void subAppend();
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=6, locals=3, args_size=2
        start local 0 // ch.qos.logback.core.OutputStreamAppender this
        start local 1 // java.lang.Object event
         0: .line 217
            aload 0 /* this */
            invokevirtual ch.qos.logback.core.OutputStreamAppender.isStarted:()Z
            ifne 2
         1: .line 218
            return
         2: .line 222
      StackMap locals:
      StackMap stack:
            aload 1 /* event */
            instanceof ch.qos.logback.core.spi.DeferredProcessingAware
            ifeq 4
         3: .line 223
            aload 1 /* event */
            checkcast ch.qos.logback.core.spi.DeferredProcessingAware
            invokeinterface ch.qos.logback.core.spi.DeferredProcessingAware.prepareForDeferredProcessing:()V
         4: .line 230
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield ch.qos.logback.core.OutputStreamAppender.encoder:Lch/qos/logback/core/encoder/Encoder;
            aload 1 /* event */
            invokeinterface ch.qos.logback.core.encoder.Encoder.encode:(Ljava/lang/Object;)[B
            astore 2 /* byteArray */
        start local 2 // byte[] byteArray
         5: .line 231
            aload 0 /* this */
            aload 2 /* byteArray */
            invokevirtual ch.qos.logback.core.OutputStreamAppender.writeBytes:([B)V
        end local 2 // byte[] byteArray
         6: .line 233
            goto 10
      StackMap locals:
      StackMap stack: java.io.IOException
         7: astore 2 /* ioe */
        start local 2 // java.io.IOException ioe
         8: .line 236
            aload 0 /* this */
            iconst_0
            putfield ch.qos.logback.core.OutputStreamAppender.started:Z
         9: .line 237
            aload 0 /* this */
            new ch.qos.logback.core.status.ErrorStatus
            dup
            ldc "IO failure in appender"
            aload 0 /* this */
            aload 2 /* ioe */
            invokespecial ch.qos.logback.core.status.ErrorStatus.<init>:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Throwable;)V
            invokevirtual ch.qos.logback.core.OutputStreamAppender.addStatus:(Lch/qos/logback/core/status/Status;)V
        end local 2 // java.io.IOException ioe
        10: .line 239
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.Object event
        end local 0 // ch.qos.logback.core.OutputStreamAppender this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   11     0       this  Lch/qos/logback/core/OutputStreamAppender<TE;>;
            0   11     1      event  TE;
            5    6     2  byteArray  [B
            8   10     2        ioe  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           2     6       7  Class java.io.IOException
    Signature: (TE;)V
    MethodParameters:
       Name  Flags
      event  

  public ch.qos.logback.core.encoder.Encoder<E> getEncoder();
    descriptor: ()Lch/qos/logback/core/encoder/Encoder;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // ch.qos.logback.core.OutputStreamAppender this
         0: .line 242
            aload 0 /* this */
            getfield ch.qos.logback.core.OutputStreamAppender.encoder:Lch/qos/logback/core/encoder/Encoder;
            areturn
        end local 0 // ch.qos.logback.core.OutputStreamAppender this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lch/qos/logback/core/OutputStreamAppender<TE;>;
    Signature: ()Lch/qos/logback/core/encoder/Encoder<TE;>;

  public void setEncoder(ch.qos.logback.core.encoder.Encoder<E>);
    descriptor: (Lch/qos/logback/core/encoder/Encoder;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // ch.qos.logback.core.OutputStreamAppender this
        start local 1 // ch.qos.logback.core.encoder.Encoder encoder
         0: .line 246
            aload 0 /* this */
            aload 1 /* encoder */
            putfield ch.qos.logback.core.OutputStreamAppender.encoder:Lch/qos/logback/core/encoder/Encoder;
         1: .line 247
            return
        end local 1 // ch.qos.logback.core.encoder.Encoder encoder
        end local 0 // ch.qos.logback.core.OutputStreamAppender this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lch/qos/logback/core/OutputStreamAppender<TE;>;
            0    2     1  encoder  Lch/qos/logback/core/encoder/Encoder<TE;>;
    Signature: (Lch/qos/logback/core/encoder/Encoder<TE;>;)V
    MethodParameters:
         Name  Flags
      encoder  

  public boolean isImmediateFlush();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // ch.qos.logback.core.OutputStreamAppender this
         0: .line 250
            aload 0 /* this */
            getfield ch.qos.logback.core.OutputStreamAppender.immediateFlush:Z
            ireturn
        end local 0 // ch.qos.logback.core.OutputStreamAppender this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lch/qos/logback/core/OutputStreamAppender<TE;>;

  public void setImmediateFlush(boolean);
    descriptor: (Z)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // ch.qos.logback.core.OutputStreamAppender this
        start local 1 // boolean immediateFlush
         0: .line 254
            aload 0 /* this */
            iload 1 /* immediateFlush */
            putfield ch.qos.logback.core.OutputStreamAppender.immediateFlush:Z
         1: .line 255
            return
        end local 1 // boolean immediateFlush
        end local 0 // ch.qos.logback.core.OutputStreamAppender this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    2     0            this  Lch/qos/logback/core/OutputStreamAppender<TE;>;
            0    2     1  immediateFlush  Z
    MethodParameters:
                Name  Flags
      immediateFlush  
}
Signature: <E:Ljava/lang/Object;>Lch/qos/logback/core/UnsynchronizedAppenderBase<TE;>;
SourceFile: "OutputStreamAppender.java"