class com.mongodb.gridfs.GridFSInputFile$GridFSOutputStream extends java.io.OutputStream
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: com.mongodb.gridfs.GridFSInputFile$GridFSOutputStream
  super_class: java.io.OutputStream
{
  final com.mongodb.gridfs.GridFSInputFile this$0;
    descriptor: Lcom/mongodb/gridfs/GridFSInputFile;
    flags: (0x1010) ACC_FINAL, ACC_SYNTHETIC

  private void <init>(com.mongodb.gridfs.GridFSInputFile);
    descriptor: (Lcom/mongodb/gridfs/GridFSInputFile;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // com.mongodb.gridfs.GridFSInputFile$GridFSOutputStream this
         0: .line 339
            aload 0 /* this */
            aload 1
            putfield com.mongodb.gridfs.GridFSInputFile$GridFSOutputStream.this$0:Lcom/mongodb/gridfs/GridFSInputFile;
            aload 0 /* this */
            invokespecial java.io.OutputStream.<init>:()V
            return
        end local 0 // com.mongodb.gridfs.GridFSInputFile$GridFSOutputStream this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/mongodb/gridfs/GridFSInputFile$GridFSOutputStream;
    MethodParameters:
        Name  Flags
      this$0  final

  public void write(int);
    descriptor: (I)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=2
        start local 0 // com.mongodb.gridfs.GridFSInputFile$GridFSOutputStream this
        start local 1 // int b
         0: .line 343
            iconst_1
            newarray 8
            astore 2 /* byteArray */
        start local 2 // byte[] byteArray
         1: .line 344
            aload 2 /* byteArray */
            iconst_0
            iload 1 /* b */
            sipush 255
            iand
            i2b
            bastore
         2: .line 345
            aload 0 /* this */
            aload 2 /* byteArray */
            iconst_0
            iconst_1
            invokevirtual com.mongodb.gridfs.GridFSInputFile$GridFSOutputStream.write:([BII)V
         3: .line 346
            return
        end local 2 // byte[] byteArray
        end local 1 // int b
        end local 0 // com.mongodb.gridfs.GridFSInputFile$GridFSOutputStream this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    4     0       this  Lcom/mongodb/gridfs/GridFSInputFile$GridFSOutputStream;
            0    4     1          b  I
            1    4     2  byteArray  [B
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      b     final

  public void write(byte[], int, int);
    descriptor: ([BII)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=7, args_size=4
        start local 0 // com.mongodb.gridfs.GridFSInputFile$GridFSOutputStream this
        start local 1 // byte[] b
        start local 2 // int off
        start local 3 // int len
         0: .line 350
            iload 2 /* off */
            istore 4 /* offset */
        start local 4 // int offset
         1: .line 351
            iload 3 /* len */
            istore 5 /* length */
        start local 5 // int length
         2: .line 352
            iconst_0
            istore 6 /* toCopy */
        start local 6 // int toCopy
         3: .line 353
            goto 13
         4: .line 354
      StackMap locals: int int int
      StackMap stack:
            iload 5 /* length */
            istore 6 /* toCopy */
         5: .line 355
            iload 6 /* toCopy */
            i2l
            aload 0 /* this */
            getfield com.mongodb.gridfs.GridFSInputFile$GridFSOutputStream.this$0:Lcom/mongodb/gridfs/GridFSInputFile;
            getfield com.mongodb.gridfs.GridFSInputFile.chunkSize:J
            aload 0 /* this */
            getfield com.mongodb.gridfs.GridFSInputFile$GridFSOutputStream.this$0:Lcom/mongodb/gridfs/GridFSInputFile;
            getfield com.mongodb.gridfs.GridFSInputFile.currentBufferPosition:I
            i2l
            lsub
            lcmp
            ifle 7
         6: .line 356
            aload 0 /* this */
            getfield com.mongodb.gridfs.GridFSInputFile$GridFSOutputStream.this$0:Lcom/mongodb/gridfs/GridFSInputFile;
            getfield com.mongodb.gridfs.GridFSInputFile.chunkSize:J
            l2i
            aload 0 /* this */
            getfield com.mongodb.gridfs.GridFSInputFile$GridFSOutputStream.this$0:Lcom/mongodb/gridfs/GridFSInputFile;
            getfield com.mongodb.gridfs.GridFSInputFile.currentBufferPosition:I
            isub
            istore 6 /* toCopy */
         7: .line 358
      StackMap locals:
      StackMap stack:
            aload 1 /* b */
            iload 4 /* offset */
            aload 0 /* this */
            getfield com.mongodb.gridfs.GridFSInputFile$GridFSOutputStream.this$0:Lcom/mongodb/gridfs/GridFSInputFile;
            getfield com.mongodb.gridfs.GridFSInputFile.buffer:[B
            aload 0 /* this */
            getfield com.mongodb.gridfs.GridFSInputFile$GridFSOutputStream.this$0:Lcom/mongodb/gridfs/GridFSInputFile;
            getfield com.mongodb.gridfs.GridFSInputFile.currentBufferPosition:I
            iload 6 /* toCopy */
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
         8: .line 359
            aload 0 /* this */
            getfield com.mongodb.gridfs.GridFSInputFile$GridFSOutputStream.this$0:Lcom/mongodb/gridfs/GridFSInputFile;
            dup
            getfield com.mongodb.gridfs.GridFSInputFile.currentBufferPosition:I
            iload 6 /* toCopy */
            iadd
            putfield com.mongodb.gridfs.GridFSInputFile.currentBufferPosition:I
         9: .line 360
            iload 4 /* offset */
            iload 6 /* toCopy */
            iadd
            istore 4 /* offset */
        10: .line 361
            iload 5 /* length */
            iload 6 /* toCopy */
            isub
            istore 5 /* length */
        11: .line 362
            aload 0 /* this */
            getfield com.mongodb.gridfs.GridFSInputFile$GridFSOutputStream.this$0:Lcom/mongodb/gridfs/GridFSInputFile;
            getfield com.mongodb.gridfs.GridFSInputFile.currentBufferPosition:I
            i2l
            aload 0 /* this */
            getfield com.mongodb.gridfs.GridFSInputFile$GridFSOutputStream.this$0:Lcom/mongodb/gridfs/GridFSInputFile;
            getfield com.mongodb.gridfs.GridFSInputFile.chunkSize:J
            lcmp
            ifne 13
        12: .line 363
            aload 0 /* this */
            getfield com.mongodb.gridfs.GridFSInputFile$GridFSOutputStream.this$0:Lcom/mongodb/gridfs/GridFSInputFile;
            iconst_0
            invokevirtual com.mongodb.gridfs.GridFSInputFile.dumpBuffer:(Z)V
        13: .line 353
      StackMap locals:
      StackMap stack:
            iload 5 /* length */
            ifgt 4
        14: .line 366
            return
        end local 6 // int toCopy
        end local 5 // int length
        end local 4 // int offset
        end local 3 // int len
        end local 2 // int off
        end local 1 // byte[] b
        end local 0 // com.mongodb.gridfs.GridFSInputFile$GridFSOutputStream this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   15     0    this  Lcom/mongodb/gridfs/GridFSInputFile$GridFSOutputStream;
            0   15     1       b  [B
            0   15     2     off  I
            0   15     3     len  I
            1   15     4  offset  I
            2   15     5  length  I
            3   15     6  toCopy  I
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      b     final
      off   final
      len   final

  public void close();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // com.mongodb.gridfs.GridFSInputFile$GridFSOutputStream this
         0: .line 375
            aload 0 /* this */
            getfield com.mongodb.gridfs.GridFSInputFile$GridFSOutputStream.this$0:Lcom/mongodb/gridfs/GridFSInputFile;
            iconst_1
            invokevirtual com.mongodb.gridfs.GridFSInputFile.dumpBuffer:(Z)V
         1: .line 377
            aload 0 /* this */
            getfield com.mongodb.gridfs.GridFSInputFile$GridFSOutputStream.this$0:Lcom/mongodb/gridfs/GridFSInputFile;
            invokevirtual com.mongodb.gridfs.GridFSInputFile.finishData:()V
         2: .line 379
            aload 0 /* this */
            getfield com.mongodb.gridfs.GridFSInputFile$GridFSOutputStream.this$0:Lcom/mongodb/gridfs/GridFSInputFile;
            invokestatic com.mongodb.gridfs.GridFSInputFile.access$0:(Lcom/mongodb/gridfs/GridFSInputFile;)V
         3: .line 380
            return
        end local 0 // com.mongodb.gridfs.GridFSInputFile$GridFSOutputStream this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lcom/mongodb/gridfs/GridFSInputFile$GridFSOutputStream;
}
SourceFile: "GridFSInputFile.java"
NestHost: com.mongodb.gridfs.GridFSInputFile
InnerClasses:
  private GridFSOutputStream = com.mongodb.gridfs.GridFSInputFile$GridFSOutputStream of com.mongodb.gridfs.GridFSInputFile