final class com.mongodb.async.client.gridfs.GridFSUploadStreamImpl implements com.mongodb.async.client.gridfs.GridFSUploadStream
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: com.mongodb.async.client.gridfs.GridFSUploadStreamImpl
  super_class: java.lang.Object
{
  private static final com.mongodb.diagnostics.logging.Logger LOGGER;
    descriptor: Lcom/mongodb/diagnostics/logging/Logger;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private final com.mongodb.async.client.ClientSession clientSession;
    descriptor: Lcom/mongodb/async/client/ClientSession;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final com.mongodb.async.client.MongoCollection<com.mongodb.client.gridfs.model.GridFSFile> filesCollection;
    descriptor: Lcom/mongodb/async/client/MongoCollection;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Lcom/mongodb/async/client/MongoCollection<Lcom/mongodb/client/gridfs/model/GridFSFile;>;

  private final com.mongodb.async.client.MongoCollection<org.bson.Document> chunksCollection;
    descriptor: Lcom/mongodb/async/client/MongoCollection;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Lcom/mongodb/async/client/MongoCollection<Lorg/bson/Document;>;

  private final org.bson.BsonValue fileId;
    descriptor: Lorg/bson/BsonValue;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

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

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

  private final org.bson.Document metadata;
    descriptor: Lorg/bson/Document;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.security.MessageDigest md5;
    descriptor: Ljava/security/MessageDigest;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final boolean disableMD5;
    descriptor: Z
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final com.mongodb.async.client.gridfs.GridFSIndexCheck indexCheck;
    descriptor: Lcom/mongodb/async/client/gridfs/GridFSIndexCheck;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

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

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

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

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

  private byte[] buffer;
    descriptor: [B
    flags: (0x0002) ACC_PRIVATE

  private long lengthInBytes;
    descriptor: J
    flags: (0x0002) ACC_PRIVATE

  private int bufferOffset;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private int chunkIndex;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 43
            ldc "client.gridfs"
            invokestatic com.mongodb.diagnostics.logging.Loggers.getLogger:(Ljava/lang/String;)Lcom/mongodb/diagnostics/logging/Logger;
            putstatic com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.LOGGER:Lcom/mongodb/diagnostics/logging/Logger;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>(com.mongodb.async.client.ClientSession, com.mongodb.async.client.MongoCollection<com.mongodb.client.gridfs.model.GridFSFile>, com.mongodb.async.client.MongoCollection<org.bson.Document>, org.bson.BsonValue, java.lang.String, int, boolean, org.bson.Document, com.mongodb.async.client.gridfs.GridFSIndexCheck);
    descriptor: (Lcom/mongodb/async/client/ClientSession;Lcom/mongodb/async/client/MongoCollection;Lcom/mongodb/async/client/MongoCollection;Lorg/bson/BsonValue;Ljava/lang/String;IZLorg/bson/Document;Lcom/mongodb/async/client/gridfs/GridFSIndexCheck;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=10, args_size=10
        start local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
        start local 1 // com.mongodb.async.client.ClientSession clientSession
        start local 2 // com.mongodb.async.client.MongoCollection filesCollection
        start local 3 // com.mongodb.async.client.MongoCollection chunksCollection
        start local 4 // org.bson.BsonValue fileId
        start local 5 // java.lang.String filename
        start local 6 // int chunkSizeBytes
        start local 7 // boolean disableMD5
        start local 8 // org.bson.Document metadata
        start local 9 // com.mongodb.async.client.gridfs.GridFSIndexCheck indexCheck
         0: .line 70
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 54
            aload 0 /* this */
            new java.lang.Object
            dup
            invokespecial java.lang.Object.<init>:()V
            putfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.closeAndWritingLock:Ljava/lang/Object;
         2: .line 74
            aload 0 /* this */
            aload 1 /* clientSession */
            putfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.clientSession:Lcom/mongodb/async/client/ClientSession;
         3: .line 75
            aload 0 /* this */
            ldc "files collection"
            aload 2 /* filesCollection */
            invokestatic com.mongodb.assertions.Assertions.notNull:(Ljava/lang/String;Ljava/lang/Object;)Ljava/lang/Object;
            checkcast com.mongodb.async.client.MongoCollection
            putfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.filesCollection:Lcom/mongodb/async/client/MongoCollection;
         4: .line 76
            aload 0 /* this */
            ldc "chunks collection"
            aload 3 /* chunksCollection */
            invokestatic com.mongodb.assertions.Assertions.notNull:(Ljava/lang/String;Ljava/lang/Object;)Ljava/lang/Object;
            checkcast com.mongodb.async.client.MongoCollection
            putfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.chunksCollection:Lcom/mongodb/async/client/MongoCollection;
         5: .line 77
            aload 0 /* this */
            ldc "File Id"
            aload 4 /* fileId */
            invokestatic com.mongodb.assertions.Assertions.notNull:(Ljava/lang/String;Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.bson.BsonValue
            putfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.fileId:Lorg/bson/BsonValue;
         6: .line 78
            aload 0 /* this */
            ldc "filename"
            aload 5 /* filename */
            invokestatic com.mongodb.assertions.Assertions.notNull:(Ljava/lang/String;Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.String
            putfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.filename:Ljava/lang/String;
         7: .line 79
            aload 0 /* this */
            iload 6 /* chunkSizeBytes */
            putfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.chunkSizeBytes:I
         8: .line 80
            aload 0 /* this */
            aload 8 /* metadata */
            putfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.metadata:Lorg/bson/Document;
         9: .line 81
            aload 0 /* this */
            aload 9 /* indexCheck */
            putfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.indexCheck:Lcom/mongodb/async/client/gridfs/GridFSIndexCheck;
        10: .line 82
            aload 0 /* this */
            iload 7 /* disableMD5 */
            putfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.disableMD5:Z
        11: .line 83
            aload 0 /* this */
            aload 0 /* this */
            invokevirtual com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.createMD5Digest:()Ljava/security/MessageDigest;
            putfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.md5:Ljava/security/MessageDigest;
        12: .line 84
            aload 0 /* this */
            iconst_0
            putfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.chunkIndex:I
        13: .line 85
            aload 0 /* this */
            iconst_0
            putfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.bufferOffset:I
        14: .line 86
            aload 0 /* this */
            iload 6 /* chunkSizeBytes */
            newarray 8
            putfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.buffer:[B
        15: .line 87
            return
        end local 9 // com.mongodb.async.client.gridfs.GridFSIndexCheck indexCheck
        end local 8 // org.bson.Document metadata
        end local 7 // boolean disableMD5
        end local 6 // int chunkSizeBytes
        end local 5 // java.lang.String filename
        end local 4 // org.bson.BsonValue fileId
        end local 3 // com.mongodb.async.client.MongoCollection chunksCollection
        end local 2 // com.mongodb.async.client.MongoCollection filesCollection
        end local 1 // com.mongodb.async.client.ClientSession clientSession
        end local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   16     0              this  Lcom/mongodb/async/client/gridfs/GridFSUploadStreamImpl;
            0   16     1     clientSession  Lcom/mongodb/async/client/ClientSession;
            0   16     2   filesCollection  Lcom/mongodb/async/client/MongoCollection<Lcom/mongodb/client/gridfs/model/GridFSFile;>;
            0   16     3  chunksCollection  Lcom/mongodb/async/client/MongoCollection<Lorg/bson/Document;>;
            0   16     4            fileId  Lorg/bson/BsonValue;
            0   16     5          filename  Ljava/lang/String;
            0   16     6    chunkSizeBytes  I
            0   16     7        disableMD5  Z
            0   16     8          metadata  Lorg/bson/Document;
            0   16     9        indexCheck  Lcom/mongodb/async/client/gridfs/GridFSIndexCheck;
    Signature: (Lcom/mongodb/async/client/ClientSession;Lcom/mongodb/async/client/MongoCollection<Lcom/mongodb/client/gridfs/model/GridFSFile;>;Lcom/mongodb/async/client/MongoCollection<Lorg/bson/Document;>;Lorg/bson/BsonValue;Ljava/lang/String;IZLorg/bson/Document;Lcom/mongodb/async/client/gridfs/GridFSIndexCheck;)V
    RuntimeVisibleParameterAnnotations: 
      0:
        com.mongodb.lang.Nullable()
      1:
      2:
      3:
      4:
      5:
      6:
      7:
        com.mongodb.lang.Nullable()
      8:
    MethodParameters:
                  Name  Flags
      clientSession     final
      filesCollection   final
      chunksCollection  final
      fileId            final
      filename          final
      chunkSizeBytes    final
      disableMD5        final
      metadata          final
      indexCheck        final

  public org.bson.types.ObjectId getObjectId();
    descriptor: ()Lorg/bson/types/ObjectId;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
         0: .line 91
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.fileId:Lorg/bson/BsonValue;
            invokevirtual org.bson.BsonValue.isObjectId:()Z
            ifne 2
         1: .line 92
            new com.mongodb.MongoGridFSException
            dup
            ldc "Custom id type used for this GridFS upload stream"
            invokespecial com.mongodb.MongoGridFSException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 94
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.fileId:Lorg/bson/BsonValue;
            invokevirtual org.bson.BsonValue.asObjectId:()Lorg/bson/BsonObjectId;
            invokevirtual org.bson.BsonObjectId.getValue:()Lorg/bson/types/ObjectId;
            areturn
        end local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lcom/mongodb/async/client/gridfs/GridFSUploadStreamImpl;

  public org.bson.BsonValue getId();
    descriptor: ()Lorg/bson/BsonValue;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
         0: .line 99
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.fileId:Lorg/bson/BsonValue;
            areturn
        end local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/mongodb/async/client/gridfs/GridFSUploadStreamImpl;

  public void abort(com.mongodb.async.SingleResultCallback<java.lang.Void>);
    descriptor: (Lcom/mongodb/async/SingleResultCallback;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=4, args_size=2
        start local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
        start local 1 // com.mongodb.async.SingleResultCallback callback
         0: .line 104
            ldc "callback"
            aload 1 /* callback */
            invokestatic com.mongodb.assertions.Assertions.notNull:(Ljava/lang/String;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         1: .line 105
            aload 1 /* callback */
            getstatic com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.LOGGER:Lcom/mongodb/diagnostics/logging/Logger;
            invokestatic com.mongodb.internal.async.ErrorHandlingResultCallback.errorHandlingCallback:(Lcom/mongodb/async/SingleResultCallback;Lcom/mongodb/diagnostics/logging/Logger;)Lcom/mongodb/async/SingleResultCallback;
            astore 2 /* errHandlingCallback */
        start local 2 // com.mongodb.async.SingleResultCallback errHandlingCallback
         2: .line 106
            aload 0 /* this */
            aload 2 /* errHandlingCallback */
            invokevirtual com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.takeWritingLock:(Lcom/mongodb/async/SingleResultCallback;)Z
            ifne 4
         3: .line 107
            return
         4: .line 110
      StackMap locals: com.mongodb.async.SingleResultCallback
      StackMap stack:
            new com.mongodb.async.client.gridfs.GridFSUploadStreamImpl$1
            dup
            aload 0 /* this */
            aload 2 /* errHandlingCallback */
            invokespecial com.mongodb.async.client.gridfs.GridFSUploadStreamImpl$1.<init>:(Lcom/mongodb/async/client/gridfs/GridFSUploadStreamImpl;Lcom/mongodb/async/SingleResultCallback;)V
            astore 3 /* deleteCallback */
        start local 3 // com.mongodb.async.SingleResultCallback deleteCallback
         5: .line 118
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.clientSession:Lcom/mongodb/async/client/ClientSession;
            ifnull 8
         6: .line 119
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.chunksCollection:Lcom/mongodb/async/client/MongoCollection;
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.clientSession:Lcom/mongodb/async/client/ClientSession;
            new org.bson.Document
            dup
            ldc "files_id"
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.fileId:Lorg/bson/BsonValue;
            invokespecial org.bson.Document.<init>:(Ljava/lang/String;Ljava/lang/Object;)V
            aload 3 /* deleteCallback */
            invokeinterface com.mongodb.async.client.MongoCollection.deleteMany:(Lcom/mongodb/async/client/ClientSession;Lorg/bson/conversions/Bson;Lcom/mongodb/async/SingleResultCallback;)V
         7: .line 120
            goto 9
         8: .line 121
      StackMap locals: com.mongodb.async.SingleResultCallback
      StackMap stack:
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.chunksCollection:Lcom/mongodb/async/client/MongoCollection;
            new org.bson.Document
            dup
            ldc "files_id"
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.fileId:Lorg/bson/BsonValue;
            invokespecial org.bson.Document.<init>:(Ljava/lang/String;Ljava/lang/Object;)V
            aload 3 /* deleteCallback */
            invokeinterface com.mongodb.async.client.MongoCollection.deleteMany:(Lorg/bson/conversions/Bson;Lcom/mongodb/async/SingleResultCallback;)V
         9: .line 123
      StackMap locals:
      StackMap stack:
            return
        end local 3 // com.mongodb.async.SingleResultCallback deleteCallback
        end local 2 // com.mongodb.async.SingleResultCallback errHandlingCallback
        end local 1 // com.mongodb.async.SingleResultCallback callback
        end local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0   10     0                 this  Lcom/mongodb/async/client/gridfs/GridFSUploadStreamImpl;
            0   10     1             callback  Lcom/mongodb/async/SingleResultCallback<Ljava/lang/Void;>;
            2   10     2  errHandlingCallback  Lcom/mongodb/async/SingleResultCallback<Ljava/lang/Void;>;
            5   10     3       deleteCallback  Lcom/mongodb/async/SingleResultCallback<Lcom/mongodb/client/result/DeleteResult;>;
    Signature: (Lcom/mongodb/async/SingleResultCallback<Ljava/lang/Void;>;)V
    MethodParameters:
          Name  Flags
      callback  final

  public void write(java.nio.ByteBuffer, com.mongodb.async.SingleResultCallback<java.lang.Integer>);
    descriptor: (Ljava/nio/ByteBuffer;Lcom/mongodb/async/SingleResultCallback;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=6, args_size=3
        start local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
        start local 1 // java.nio.ByteBuffer src
        start local 2 // com.mongodb.async.SingleResultCallback callback
         0: .line 127
            ldc "src"
            aload 1 /* src */
            invokestatic com.mongodb.assertions.Assertions.notNull:(Ljava/lang/String;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         1: .line 128
            ldc "callback"
            aload 2 /* callback */
            invokestatic com.mongodb.assertions.Assertions.notNull:(Ljava/lang/String;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         2: .line 129
            aload 2 /* callback */
            getstatic com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.LOGGER:Lcom/mongodb/diagnostics/logging/Logger;
            invokestatic com.mongodb.internal.async.ErrorHandlingResultCallback.errorHandlingCallback:(Lcom/mongodb/async/SingleResultCallback;Lcom/mongodb/diagnostics/logging/Logger;)Lcom/mongodb/async/SingleResultCallback;
            astore 3 /* errHandlingCallback */
        start local 3 // com.mongodb.async.SingleResultCallback errHandlingCallback
         3: .line 130
            iconst_0
            istore 4 /* checkIndexes */
        start local 4 // boolean checkIndexes
         4: .line 131
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.closeAndWritingLock:Ljava/lang/Object;
            dup
            astore 5
            monitorenter
         5: .line 132
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.checkedIndexes:Z
            ifeq 6
            iconst_0
            goto 7
      StackMap locals: com.mongodb.async.SingleResultCallback int java.lang.Object
      StackMap stack:
         6: iconst_1
      StackMap locals:
      StackMap stack: int
         7: istore 4 /* checkIndexes */
         8: .line 131
            aload 5
            monitorexit
         9: goto 12
      StackMap locals:
      StackMap stack: java.lang.Throwable
        10: aload 5
            monitorexit
        11: athrow
        12: .line 135
      StackMap locals:
      StackMap stack:
            iload 4 /* checkIndexes */
            ifeq 17
        13: .line 136
            aload 0 /* this */
            aload 3 /* errHandlingCallback */
            invokevirtual com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.takeWritingLock:(Lcom/mongodb/async/SingleResultCallback;)Z
            ifne 15
        14: .line 137
            return
        15: .line 139
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.indexCheck:Lcom/mongodb/async/client/gridfs/GridFSIndexCheck;
            new com.mongodb.async.client.gridfs.GridFSUploadStreamImpl$2
            dup
            aload 0 /* this */
            aload 3 /* errHandlingCallback */
            aload 1 /* src */
            invokespecial com.mongodb.async.client.gridfs.GridFSUploadStreamImpl$2.<init>:(Lcom/mongodb/async/client/gridfs/GridFSUploadStreamImpl;Lcom/mongodb/async/SingleResultCallback;Ljava/nio/ByteBuffer;)V
            invokeinterface com.mongodb.async.client.gridfs.GridFSIndexCheck.checkAndCreateIndex:(Lcom/mongodb/async/SingleResultCallback;)V
        16: .line 153
            goto 20
        17: .line 154
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* src */
            invokevirtual java.nio.ByteBuffer.remaining:()I
            ifne 18
            iconst_m1
            goto 19
      StackMap locals:
      StackMap stack: com.mongodb.async.client.gridfs.GridFSUploadStreamImpl
        18: aload 1 /* src */
            invokevirtual java.nio.ByteBuffer.remaining:()I
      StackMap locals: com.mongodb.async.client.gridfs.GridFSUploadStreamImpl java.nio.ByteBuffer com.mongodb.async.SingleResultCallback com.mongodb.async.SingleResultCallback int
      StackMap stack: com.mongodb.async.client.gridfs.GridFSUploadStreamImpl int
        19: aload 1 /* src */
            aload 3 /* errHandlingCallback */
            invokevirtual com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.write:(ILjava/nio/ByteBuffer;Lcom/mongodb/async/SingleResultCallback;)V
        20: .line 156
      StackMap locals:
      StackMap stack:
            return
        end local 4 // boolean checkIndexes
        end local 3 // com.mongodb.async.SingleResultCallback errHandlingCallback
        end local 2 // com.mongodb.async.SingleResultCallback callback
        end local 1 // java.nio.ByteBuffer src
        end local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0   21     0                 this  Lcom/mongodb/async/client/gridfs/GridFSUploadStreamImpl;
            0   21     1                  src  Ljava/nio/ByteBuffer;
            0   21     2             callback  Lcom/mongodb/async/SingleResultCallback<Ljava/lang/Integer;>;
            3   21     3  errHandlingCallback  Lcom/mongodb/async/SingleResultCallback<Ljava/lang/Integer;>;
            4   21     4         checkIndexes  Z
      Exception table:
        from    to  target  type
           5     9      10  any
          10    11      10  any
    Signature: (Ljava/nio/ByteBuffer;Lcom/mongodb/async/SingleResultCallback<Ljava/lang/Integer;>;)V
    MethodParameters:
          Name  Flags
      src       final
      callback  final

  public void close(com.mongodb.async.SingleResultCallback<java.lang.Void>);
    descriptor: (Lcom/mongodb/async/SingleResultCallback;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=5, args_size=2
        start local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
        start local 1 // com.mongodb.async.SingleResultCallback callback
         0: .line 160
            ldc "callback"
            aload 1 /* callback */
            invokestatic com.mongodb.assertions.Assertions.notNull:(Ljava/lang/String;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         1: .line 161
            aload 1 /* callback */
            getstatic com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.LOGGER:Lcom/mongodb/diagnostics/logging/Logger;
            invokestatic com.mongodb.internal.async.ErrorHandlingResultCallback.errorHandlingCallback:(Lcom/mongodb/async/SingleResultCallback;Lcom/mongodb/diagnostics/logging/Logger;)Lcom/mongodb/async/SingleResultCallback;
            astore 2 /* errHandlingCallback */
        start local 2 // com.mongodb.async.SingleResultCallback errHandlingCallback
         2: .line 162
            iconst_0
            istore 3 /* alreadyClosed */
        start local 3 // boolean alreadyClosed
         3: .line 163
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.closeAndWritingLock:Ljava/lang/Object;
            dup
            astore 4
            monitorenter
         4: .line 164
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.closed:Z
            istore 3 /* alreadyClosed */
         5: .line 165
            aload 0 /* this */
            iconst_1
            putfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.closed:Z
         6: .line 163
            aload 4
            monitorexit
         7: goto 10
      StackMap locals: com.mongodb.async.client.gridfs.GridFSUploadStreamImpl com.mongodb.async.SingleResultCallback com.mongodb.async.SingleResultCallback int java.lang.Object
      StackMap stack: java.lang.Throwable
         8: aload 4
            monitorexit
         9: athrow
        10: .line 167
      StackMap locals:
      StackMap stack:
            iload 3 /* alreadyClosed */
            ifeq 13
        11: .line 168
            aload 2 /* errHandlingCallback */
            aconst_null
            aconst_null
            invokeinterface com.mongodb.async.SingleResultCallback.onResult:(Ljava/lang/Object;Ljava/lang/Throwable;)V
        12: .line 169
            return
        13: .line 170
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.getAndSetWritingLock:()Z
            ifne 16
        14: .line 171
            aload 0 /* this */
            aload 2 /* errHandlingCallback */
            invokevirtual com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.callbackIsWritingException:(Lcom/mongodb/async/SingleResultCallback;)V
        15: .line 172
            return
        16: .line 174
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            new com.mongodb.async.client.gridfs.GridFSUploadStreamImpl$3
            dup
            aload 0 /* this */
            aload 2 /* errHandlingCallback */
            invokespecial com.mongodb.async.client.gridfs.GridFSUploadStreamImpl$3.<init>:(Lcom/mongodb/async/client/gridfs/GridFSUploadStreamImpl;Lcom/mongodb/async/SingleResultCallback;)V
            invokevirtual com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.writeChunk:(Lcom/mongodb/async/SingleResultCallback;)V
        17: .line 201
            return
        end local 3 // boolean alreadyClosed
        end local 2 // com.mongodb.async.SingleResultCallback errHandlingCallback
        end local 1 // com.mongodb.async.SingleResultCallback callback
        end local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0   18     0                 this  Lcom/mongodb/async/client/gridfs/GridFSUploadStreamImpl;
            0   18     1             callback  Lcom/mongodb/async/SingleResultCallback<Ljava/lang/Void;>;
            2   18     2  errHandlingCallback  Lcom/mongodb/async/SingleResultCallback<Ljava/lang/Void;>;
            3   18     3        alreadyClosed  Z
      Exception table:
        from    to  target  type
           4     7       8  any
           8     9       8  any
    Signature: (Lcom/mongodb/async/SingleResultCallback<Ljava/lang/Void;>;)V
    MethodParameters:
          Name  Flags
      callback  final

  private void write(int, java.nio.ByteBuffer, com.mongodb.async.SingleResultCallback<java.lang.Integer>);
    descriptor: (ILjava/nio/ByteBuffer;Lcom/mongodb/async/SingleResultCallback;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=7, locals=6, args_size=4
        start local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
        start local 1 // int amount
        start local 2 // java.nio.ByteBuffer src
        start local 3 // com.mongodb.async.SingleResultCallback callback
         0: .line 204
            aload 0 /* this */
            aload 3 /* callback */
            invokevirtual com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.takeWritingLock:(Lcom/mongodb/async/SingleResultCallback;)Z
            ifne 2
         1: .line 205
            return
         2: .line 208
      StackMap locals:
      StackMap stack:
            aload 2 /* src */
            invokevirtual java.nio.ByteBuffer.remaining:()I
            istore 4 /* len */
        start local 4 // int len
         3: .line 209
            iload 4 /* len */
            ifne 7
         4: .line 210
            aload 0 /* this */
            invokevirtual com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.releaseWritingLock:()V
         5: .line 211
            aload 3 /* callback */
            iload 1 /* amount */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aconst_null
            invokeinterface com.mongodb.async.SingleResultCallback.onResult:(Ljava/lang/Object;Ljava/lang/Throwable;)V
         6: .line 212
            return
         7: .line 215
      StackMap locals: int
      StackMap stack:
            iload 4 /* len */
            istore 5 /* amountToCopy */
        start local 5 // int amountToCopy
         8: .line 216
            iload 5 /* amountToCopy */
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.chunkSizeBytes:I
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.bufferOffset:I
            isub
            if_icmple 10
         9: .line 217
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.chunkSizeBytes:I
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.bufferOffset:I
            isub
            istore 5 /* amountToCopy */
        10: .line 220
      StackMap locals: int
      StackMap stack:
            aload 2 /* src */
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.buffer:[B
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.bufferOffset:I
            iload 5 /* amountToCopy */
            invokevirtual java.nio.ByteBuffer.get:([BII)Ljava/nio/ByteBuffer;
            pop
        11: .line 221
            aload 0 /* this */
            dup
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.bufferOffset:I
            iload 5 /* amountToCopy */
            iadd
            putfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.bufferOffset:I
        12: .line 222
            aload 0 /* this */
            dup
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.lengthInBytes:J
            iload 5 /* amountToCopy */
            i2l
            ladd
            putfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.lengthInBytes:J
        13: .line 223
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.bufferOffset:I
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.chunkSizeBytes:I
            if_icmpne 16
        14: .line 224
            aload 0 /* this */
            new com.mongodb.async.client.gridfs.GridFSUploadStreamImpl$4
            dup
            aload 0 /* this */
            aload 3 /* callback */
            iload 1 /* amount */
            aload 2 /* src */
            invokespecial com.mongodb.async.client.gridfs.GridFSUploadStreamImpl$4.<init>:(Lcom/mongodb/async/client/gridfs/GridFSUploadStreamImpl;Lcom/mongodb/async/SingleResultCallback;ILjava/nio/ByteBuffer;)V
            invokevirtual com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.writeChunk:(Lcom/mongodb/async/SingleResultCallback;)V
        15: .line 235
            goto 18
        16: .line 236
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.releaseWritingLock:()V
        17: .line 237
            aload 3 /* callback */
            iload 1 /* amount */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aconst_null
            invokeinterface com.mongodb.async.SingleResultCallback.onResult:(Ljava/lang/Object;Ljava/lang/Throwable;)V
        18: .line 239
      StackMap locals:
      StackMap stack:
            return
        end local 5 // int amountToCopy
        end local 4 // int len
        end local 3 // com.mongodb.async.SingleResultCallback callback
        end local 2 // java.nio.ByteBuffer src
        end local 1 // int amount
        end local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   19     0          this  Lcom/mongodb/async/client/gridfs/GridFSUploadStreamImpl;
            0   19     1        amount  I
            0   19     2           src  Ljava/nio/ByteBuffer;
            0   19     3      callback  Lcom/mongodb/async/SingleResultCallback<Ljava/lang/Integer;>;
            3   19     4           len  I
            8   19     5  amountToCopy  I
    Signature: (ILjava/nio/ByteBuffer;Lcom/mongodb/async/SingleResultCallback<Ljava/lang/Integer;>;)V
    MethodParameters:
          Name  Flags
      amount    final
      src       final
      callback  final

  private <T> boolean takeWritingLock(com.mongodb.async.SingleResultCallback<T>);
    descriptor: (Lcom/mongodb/async/SingleResultCallback;)Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
        start local 1 // com.mongodb.async.SingleResultCallback errHandlingCallback
         0: .line 242
            aload 0 /* this */
            invokevirtual com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.checkClosed:()Z
            ifeq 3
         1: .line 243
            aload 0 /* this */
            aload 1 /* errHandlingCallback */
            invokevirtual com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.callbackClosedException:(Lcom/mongodb/async/SingleResultCallback;)V
         2: .line 244
            iconst_0
            ireturn
         3: .line 245
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.getAndSetWritingLock:()Z
            ifne 7
         4: .line 246
            aload 0 /* this */
            invokevirtual com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.releaseWritingLock:()V
         5: .line 247
            aload 0 /* this */
            aload 1 /* errHandlingCallback */
            invokevirtual com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.callbackIsWritingException:(Lcom/mongodb/async/SingleResultCallback;)V
         6: .line 248
            iconst_0
            ireturn
         7: .line 250
      StackMap locals:
      StackMap stack:
            iconst_1
            ireturn
        end local 1 // com.mongodb.async.SingleResultCallback errHandlingCallback
        end local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0    8     0                 this  Lcom/mongodb/async/client/gridfs/GridFSUploadStreamImpl;
            0    8     1  errHandlingCallback  Lcom/mongodb/async/SingleResultCallback<TT;>;
    Signature: <T:Ljava/lang/Object;>(Lcom/mongodb/async/SingleResultCallback<TT;>;)Z
    MethodParameters:
                     Name  Flags
      errHandlingCallback  final

  private void writeChunk(com.mongodb.async.SingleResultCallback<java.lang.Void>);
    descriptor: (Lcom/mongodb/async/SingleResultCallback;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=4, args_size=2
        start local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
        start local 1 // com.mongodb.async.SingleResultCallback callback
         0: .line 254
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.md5:Ljava/security/MessageDigest;
            ifnonnull 3
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.disableMD5:Z
            ifne 3
         1: .line 255
            aload 1 /* callback */
            aconst_null
            new com.mongodb.MongoGridFSException
            dup
            ldc "No MD5 message digest available. Use `GridFSBucket.withDisableMD5(true)` to disable creating a MD5 hash."
            invokespecial com.mongodb.MongoGridFSException.<init>:(Ljava/lang/String;)V
            invokeinterface com.mongodb.async.SingleResultCallback.onResult:(Ljava/lang/Object;Ljava/lang/Throwable;)V
         2: .line 257
            goto 12
      StackMap locals:
      StackMap stack:
         3: aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.bufferOffset:I
            ifle 11
         4: .line 258
            new org.bson.Document
            dup
            ldc "files_id"
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.fileId:Lorg/bson/BsonValue;
            invokespecial org.bson.Document.<init>:(Ljava/lang/String;Ljava/lang/Object;)V
            ldc "n"
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.chunkIndex:I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokevirtual org.bson.Document.append:(Ljava/lang/String;Ljava/lang/Object;)Lorg/bson/Document;
            ldc "data"
            aload 0 /* this */
            invokevirtual com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.getData:()Lorg/bson/types/Binary;
            invokevirtual org.bson.Document.append:(Ljava/lang/String;Ljava/lang/Object;)Lorg/bson/Document;
            astore 2 /* insertDocument */
        start local 2 // org.bson.Document insertDocument
         5: .line 259
            new com.mongodb.async.client.gridfs.GridFSUploadStreamImpl$5
            dup
            aload 0 /* this */
            aload 1 /* callback */
            invokespecial com.mongodb.async.client.gridfs.GridFSUploadStreamImpl$5.<init>:(Lcom/mongodb/async/client/gridfs/GridFSUploadStreamImpl;Lcom/mongodb/async/SingleResultCallback;)V
            astore 3 /* insertCallback */
        start local 3 // com.mongodb.async.SingleResultCallback insertCallback
         6: .line 272
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.clientSession:Lcom/mongodb/async/client/ClientSession;
            ifnull 9
         7: .line 273
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.chunksCollection:Lcom/mongodb/async/client/MongoCollection;
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.clientSession:Lcom/mongodb/async/client/ClientSession;
            aload 2 /* insertDocument */
            aload 3 /* insertCallback */
            invokeinterface com.mongodb.async.client.MongoCollection.insertOne:(Lcom/mongodb/async/client/ClientSession;Ljava/lang/Object;Lcom/mongodb/async/SingleResultCallback;)V
         8: .line 274
            goto 12
         9: .line 275
      StackMap locals: org.bson.Document com.mongodb.async.SingleResultCallback
      StackMap stack:
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.chunksCollection:Lcom/mongodb/async/client/MongoCollection;
            aload 2 /* insertDocument */
            aload 3 /* insertCallback */
            invokeinterface com.mongodb.async.client.MongoCollection.insertOne:(Ljava/lang/Object;Lcom/mongodb/async/SingleResultCallback;)V
        end local 3 // com.mongodb.async.SingleResultCallback insertCallback
        end local 2 // org.bson.Document insertDocument
        10: .line 277
            goto 12
        11: .line 278
      StackMap locals:
      StackMap stack:
            aload 1 /* callback */
            aconst_null
            aconst_null
            invokeinterface com.mongodb.async.SingleResultCallback.onResult:(Ljava/lang/Object;Ljava/lang/Throwable;)V
        12: .line 280
      StackMap locals:
      StackMap stack:
            return
        end local 1 // com.mongodb.async.SingleResultCallback callback
        end local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   13     0            this  Lcom/mongodb/async/client/gridfs/GridFSUploadStreamImpl;
            0   13     1        callback  Lcom/mongodb/async/SingleResultCallback<Ljava/lang/Void;>;
            5   10     2  insertDocument  Lorg/bson/Document;
            6   10     3  insertCallback  Lcom/mongodb/async/SingleResultCallback<Ljava/lang/Void;>;
    Signature: (Lcom/mongodb/async/SingleResultCallback<Ljava/lang/Void;>;)V
    MethodParameters:
          Name  Flags
      callback  final

  private org.bson.types.Binary getData();
    descriptor: ()Lorg/bson/types/Binary;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=2, args_size=1
        start local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
         0: .line 283
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.bufferOffset:I
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.chunkSizeBytes:I
            if_icmpge 4
         1: .line 284
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.bufferOffset:I
            newarray 8
            astore 1 /* sizedBuffer */
        start local 1 // byte[] sizedBuffer
         2: .line 285
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.buffer:[B
            iconst_0
            aload 1 /* sizedBuffer */
            iconst_0
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.bufferOffset:I
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
         3: .line 286
            aload 0 /* this */
            aload 1 /* sizedBuffer */
            putfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.buffer:[B
        end local 1 // byte[] sizedBuffer
         4: .line 288
      StackMap locals:
      StackMap stack:
            new org.bson.types.Binary
            dup
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.buffer:[B
            invokespecial org.bson.types.Binary.<init>:([B)V
            areturn
        end local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    5     0         this  Lcom/mongodb/async/client/gridfs/GridFSUploadStreamImpl;
            2    4     1  sizedBuffer  [B

  private boolean checkClosed();
    descriptor: ()Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
         0: .line 292
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.closeAndWritingLock:Ljava/lang/Object;
            dup
            astore 1
            monitorenter
         1: .line 293
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.closed:Z
            aload 1
            monitorexit
         2: ireturn
         3: .line 292
      StackMap locals: com.mongodb.async.client.gridfs.GridFSUploadStreamImpl java.lang.Object
      StackMap stack: java.lang.Throwable
            aload 1
            monitorexit
         4: athrow
        end local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lcom/mongodb/async/client/gridfs/GridFSUploadStreamImpl;
      Exception table:
        from    to  target  type
           1     2       3  any
           3     4       3  any

  private boolean getAndSetWritingLock();
    descriptor: ()Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=3, args_size=1
        start local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
         0: .line 298
            iconst_0
            istore 1 /* gotLock */
        start local 1 // boolean gotLock
         1: .line 299
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.closeAndWritingLock:Ljava/lang/Object;
            dup
            astore 2
            monitorenter
         2: .line 300
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.writing:Z
            ifne 5
         3: .line 301
            aload 0 /* this */
            iconst_1
            putfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.writing:Z
         4: .line 302
            iconst_1
            istore 1 /* gotLock */
         5: .line 299
      StackMap locals: int java.lang.Object
      StackMap stack:
            aload 2
            monitorexit
         6: goto 9
      StackMap locals:
      StackMap stack: java.lang.Throwable
         7: aload 2
            monitorexit
         8: athrow
         9: .line 305
      StackMap locals:
      StackMap stack:
            iload 1 /* gotLock */
            ireturn
        end local 1 // boolean gotLock
        end local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   10     0     this  Lcom/mongodb/async/client/gridfs/GridFSUploadStreamImpl;
            1   10     1  gotLock  Z
      Exception table:
        from    to  target  type
           2     6       7  any
           7     8       7  any

  private void releaseWritingLock();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
         0: .line 309
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.closeAndWritingLock:Ljava/lang/Object;
            dup
            astore 1
            monitorenter
         1: .line 310
            aload 0 /* this */
            iconst_0
            putfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.writing:Z
         2: .line 309
            aload 1
            monitorexit
         3: goto 6
      StackMap locals: com.mongodb.async.client.gridfs.GridFSUploadStreamImpl java.lang.Object
      StackMap stack: java.lang.Throwable
         4: aload 1
            monitorexit
         5: athrow
         6: .line 312
      StackMap locals:
      StackMap stack:
            return
        end local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lcom/mongodb/async/client/gridfs/GridFSUploadStreamImpl;
      Exception table:
        from    to  target  type
           1     3       4  any
           4     5       4  any

  private <T> void callbackClosedException(com.mongodb.async.SingleResultCallback<T>);
    descriptor: (Lcom/mongodb/async/SingleResultCallback;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=2, args_size=2
        start local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
        start local 1 // com.mongodb.async.SingleResultCallback callback
         0: .line 315
            aload 1 /* callback */
            aconst_null
            new com.mongodb.MongoGridFSException
            dup
            ldc "The AsyncOutputStream has been closed"
            invokespecial com.mongodb.MongoGridFSException.<init>:(Ljava/lang/String;)V
            invokeinterface com.mongodb.async.SingleResultCallback.onResult:(Ljava/lang/Object;Ljava/lang/Throwable;)V
         1: .line 316
            return
        end local 1 // com.mongodb.async.SingleResultCallback callback
        end local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    2     0      this  Lcom/mongodb/async/client/gridfs/GridFSUploadStreamImpl;
            0    2     1  callback  Lcom/mongodb/async/SingleResultCallback<TT;>;
    Signature: <T:Ljava/lang/Object;>(Lcom/mongodb/async/SingleResultCallback<TT;>;)V
    MethodParameters:
          Name  Flags
      callback  final

  private <T> void callbackIsWritingException(com.mongodb.async.SingleResultCallback<T>);
    descriptor: (Lcom/mongodb/async/SingleResultCallback;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=2, args_size=2
        start local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
        start local 1 // com.mongodb.async.SingleResultCallback callback
         0: .line 319
            aload 1 /* callback */
            aconst_null
            new com.mongodb.MongoGridFSException
            dup
            ldc "The AsyncOutputStream does not support concurrent writing."
            invokespecial com.mongodb.MongoGridFSException.<init>:(Ljava/lang/String;)V
            invokeinterface com.mongodb.async.SingleResultCallback.onResult:(Ljava/lang/Object;Ljava/lang/Throwable;)V
         1: .line 320
            return
        end local 1 // com.mongodb.async.SingleResultCallback callback
        end local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    2     0      this  Lcom/mongodb/async/client/gridfs/GridFSUploadStreamImpl;
            0    2     1  callback  Lcom/mongodb/async/SingleResultCallback<TT;>;
    Signature: <T:Ljava/lang/Object;>(Lcom/mongodb/async/SingleResultCallback<TT;>;)V
    MethodParameters:
          Name  Flags
      callback  final

  private java.security.MessageDigest createMD5Digest();
    descriptor: ()Ljava/security/MessageDigest;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
         0: .line 324
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.disableMD5:Z
            ifeq 2
         1: .line 325
            aconst_null
            areturn
         2: .line 328
      StackMap locals:
      StackMap stack:
            ldc "MD5"
            invokestatic java.security.MessageDigest.getInstance:(Ljava/lang/String;)Ljava/security/MessageDigest;
         3: areturn
         4: .line 329
      StackMap locals:
      StackMap stack: java.security.NoSuchAlgorithmException
            pop
         5: .line 330
            aconst_null
            areturn
        end local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lcom/mongodb/async/client/gridfs/GridFSUploadStreamImpl;
      Exception table:
        from    to  target  type
           2     3       4  Class java.security.NoSuchAlgorithmException
    RuntimeVisibleAnnotations: 
      com.mongodb.lang.Nullable()

  private java.lang.String getMD5Digest();
    descriptor: ()Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
         0: .line 337
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.md5:Ljava/security/MessageDigest;
            ifnull 1
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.md5:Ljava/security/MessageDigest;
            invokevirtual java.security.MessageDigest.digest:()[B
            invokestatic com.mongodb.internal.HexUtils.toHex:([B)Ljava/lang/String;
            goto 2
      StackMap locals:
      StackMap stack:
         1: aconst_null
      StackMap locals:
      StackMap stack: java.lang.String
         2: areturn
        end local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lcom/mongodb/async/client/gridfs/GridFSUploadStreamImpl;
    RuntimeVisibleAnnotations: 
      com.mongodb.lang.Nullable()

  private void updateMD5();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
         0: .line 341
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.md5:Ljava/security/MessageDigest;
            ifnull 2
         1: .line 342
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.md5:Ljava/security/MessageDigest;
            aload 0 /* this */
            getfield com.mongodb.async.client.gridfs.GridFSUploadStreamImpl.buffer:[B
            invokevirtual java.security.MessageDigest.update:([B)V
         2: .line 344
      StackMap locals:
      StackMap stack:
            return
        end local 0 // com.mongodb.async.client.gridfs.GridFSUploadStreamImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lcom/mongodb/async/client/gridfs/GridFSUploadStreamImpl;
}
SourceFile: "GridFSUploadStreamImpl.java"
NestMembers:
  com.mongodb.async.client.gridfs.GridFSUploadStreamImpl$1  com.mongodb.async.client.gridfs.GridFSUploadStreamImpl$2  com.mongodb.async.client.gridfs.GridFSUploadStreamImpl$3  com.mongodb.async.client.gridfs.GridFSUploadStreamImpl$3$1  com.mongodb.async.client.gridfs.GridFSUploadStreamImpl$4  com.mongodb.async.client.gridfs.GridFSUploadStreamImpl$5
InnerClasses:
  com.mongodb.async.client.gridfs.GridFSUploadStreamImpl$1
  com.mongodb.async.client.gridfs.GridFSUploadStreamImpl$2
  com.mongodb.async.client.gridfs.GridFSUploadStreamImpl$3
  com.mongodb.async.client.gridfs.GridFSUploadStreamImpl$4
  com.mongodb.async.client.gridfs.GridFSUploadStreamImpl$5