final class org.apache.cassandra.hints.HintsWriteExecutor
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: org.apache.cassandra.hints.HintsWriteExecutor
  super_class: java.lang.Object
{
  private static final org.slf4j.Logger logger;
    descriptor: Lorg/slf4j/Logger;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  static final int WRITE_BUFFER_SIZE;
    descriptor: I
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 262144

  private final org.apache.cassandra.hints.HintsCatalog catalog;
    descriptor: Lorg/apache/cassandra/hints/HintsCatalog;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.nio.ByteBuffer writeBuffer;
    descriptor: Ljava/nio/ByteBuffer;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.util.concurrent.ExecutorService executor;
    descriptor: Ljava/util/concurrent/ExecutorService;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 43
            ldc Lorg/apache/cassandra/hints/HintsWriteExecutor;
            invokestatic org.slf4j.LoggerFactory.getLogger:(Ljava/lang/Class;)Lorg/slf4j/Logger;
            putstatic org.apache.cassandra.hints.HintsWriteExecutor.logger:Lorg/slf4j/Logger;
         1: .line 45
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>(org.apache.cassandra.hints.HintsCatalog);
    descriptor: (Lorg/apache/cassandra/hints/HintsCatalog;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.apache.cassandra.hints.HintsWriteExecutor this
        start local 1 // org.apache.cassandra.hints.HintsCatalog catalog
         0: .line 51
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 53
            aload 0 /* this */
            aload 1 /* catalog */
            putfield org.apache.cassandra.hints.HintsWriteExecutor.catalog:Lorg/apache/cassandra/hints/HintsCatalog;
         2: .line 55
            aload 0 /* this */
            ldc 262144
            invokestatic java.nio.ByteBuffer.allocateDirect:(I)Ljava/nio/ByteBuffer;
            putfield org.apache.cassandra.hints.HintsWriteExecutor.writeBuffer:Ljava/nio/ByteBuffer;
         3: .line 56
            aload 0 /* this */
            ldc "HintsWriteExecutor"
            iconst_1
            invokestatic org.apache.cassandra.concurrent.DebuggableThreadPoolExecutor.createWithFixedPoolSize:(Ljava/lang/String;I)Lorg/apache/cassandra/concurrent/DebuggableThreadPoolExecutor;
            putfield org.apache.cassandra.hints.HintsWriteExecutor.executor:Ljava/util/concurrent/ExecutorService;
         4: .line 57
            return
        end local 1 // org.apache.cassandra.hints.HintsCatalog catalog
        end local 0 // org.apache.cassandra.hints.HintsWriteExecutor this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    5     0     this  Lorg/apache/cassandra/hints/HintsWriteExecutor;
            0    5     1  catalog  Lorg/apache/cassandra/hints/HintsCatalog;
    MethodParameters:
         Name  Flags
      catalog  

  void shutdownBlocking();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=4, locals=2, args_size=1
        start local 0 // org.apache.cassandra.hints.HintsWriteExecutor this
         0: .line 64
            aload 0 /* this */
            getfield org.apache.cassandra.hints.HintsWriteExecutor.executor:Ljava/util/concurrent/ExecutorService;
            invokeinterface java.util.concurrent.ExecutorService.shutdown:()V
         1: .line 67
            aload 0 /* this */
            getfield org.apache.cassandra.hints.HintsWriteExecutor.executor:Ljava/util/concurrent/ExecutorService;
            lconst_1
            getstatic java.util.concurrent.TimeUnit.MINUTES:Ljava/util/concurrent/TimeUnit;
            invokeinterface java.util.concurrent.ExecutorService.awaitTermination:(JLjava/util/concurrent/TimeUnit;)Z
            pop
         2: .line 68
            goto 5
         3: .line 69
      StackMap locals:
      StackMap stack: java.lang.InterruptedException
            astore 1 /* e */
        start local 1 // java.lang.InterruptedException e
         4: .line 71
            new java.lang.AssertionError
            dup
            aload 1 /* e */
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
        end local 1 // java.lang.InterruptedException e
         5: .line 73
      StackMap locals:
      StackMap stack:
            return
        end local 0 // org.apache.cassandra.hints.HintsWriteExecutor this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lorg/apache/cassandra/hints/HintsWriteExecutor;
            4    5     1     e  Ljava/lang/InterruptedException;
      Exception table:
        from    to  target  type
           1     2       3  Class java.lang.InterruptedException

  java.util.concurrent.Future<?> flushBuffer(org.apache.cassandra.hints.HintsBuffer, org.apache.cassandra.hints.HintsBufferPool);
    descriptor: (Lorg/apache/cassandra/hints/HintsBuffer;Lorg/apache/cassandra/hints/HintsBufferPool;)Ljava/util/concurrent/Future;
    flags: (0x0000) 
    Code:
      stack=6, locals=3, args_size=3
        start local 0 // org.apache.cassandra.hints.HintsWriteExecutor this
        start local 1 // org.apache.cassandra.hints.HintsBuffer buffer
        start local 2 // org.apache.cassandra.hints.HintsBufferPool bufferPool
         0: .line 80
            aload 0 /* this */
            getfield org.apache.cassandra.hints.HintsWriteExecutor.executor:Ljava/util/concurrent/ExecutorService;
            new org.apache.cassandra.hints.HintsWriteExecutor$FlushBufferTask
            dup
            aload 0 /* this */
            aload 1 /* buffer */
            aload 2 /* bufferPool */
            invokespecial org.apache.cassandra.hints.HintsWriteExecutor$FlushBufferTask.<init>:(Lorg/apache/cassandra/hints/HintsWriteExecutor;Lorg/apache/cassandra/hints/HintsBuffer;Lorg/apache/cassandra/hints/HintsBufferPool;)V
            invokeinterface java.util.concurrent.ExecutorService.submit:(Ljava/lang/Runnable;)Ljava/util/concurrent/Future;
            areturn
        end local 2 // org.apache.cassandra.hints.HintsBufferPool bufferPool
        end local 1 // org.apache.cassandra.hints.HintsBuffer buffer
        end local 0 // org.apache.cassandra.hints.HintsWriteExecutor this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    1     0        this  Lorg/apache/cassandra/hints/HintsWriteExecutor;
            0    1     1      buffer  Lorg/apache/cassandra/hints/HintsBuffer;
            0    1     2  bufferPool  Lorg/apache/cassandra/hints/HintsBufferPool;
    Signature: (Lorg/apache/cassandra/hints/HintsBuffer;Lorg/apache/cassandra/hints/HintsBufferPool;)Ljava/util/concurrent/Future<*>;
    MethodParameters:
            Name  Flags
      buffer      
      bufferPool  

  java.util.concurrent.Future<?> flushBufferPool(org.apache.cassandra.hints.HintsBufferPool);
    descriptor: (Lorg/apache/cassandra/hints/HintsBufferPool;)Ljava/util/concurrent/Future;
    flags: (0x0000) 
    Code:
      stack=5, locals=2, args_size=2
        start local 0 // org.apache.cassandra.hints.HintsWriteExecutor this
        start local 1 // org.apache.cassandra.hints.HintsBufferPool bufferPool
         0: .line 88
            aload 0 /* this */
            getfield org.apache.cassandra.hints.HintsWriteExecutor.executor:Ljava/util/concurrent/ExecutorService;
            new org.apache.cassandra.hints.HintsWriteExecutor$FlushBufferPoolTask
            dup
            aload 0 /* this */
            aload 1 /* bufferPool */
            invokespecial org.apache.cassandra.hints.HintsWriteExecutor$FlushBufferPoolTask.<init>:(Lorg/apache/cassandra/hints/HintsWriteExecutor;Lorg/apache/cassandra/hints/HintsBufferPool;)V
            invokeinterface java.util.concurrent.ExecutorService.submit:(Ljava/lang/Runnable;)Ljava/util/concurrent/Future;
            areturn
        end local 1 // org.apache.cassandra.hints.HintsBufferPool bufferPool
        end local 0 // org.apache.cassandra.hints.HintsWriteExecutor this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    1     0        this  Lorg/apache/cassandra/hints/HintsWriteExecutor;
            0    1     1  bufferPool  Lorg/apache/cassandra/hints/HintsBufferPool;
    Signature: (Lorg/apache/cassandra/hints/HintsBufferPool;)Ljava/util/concurrent/Future<*>;
    MethodParameters:
            Name  Flags
      bufferPool  

  java.util.concurrent.Future<?> flushBufferPool(org.apache.cassandra.hints.HintsBufferPool, java.lang.Iterable<org.apache.cassandra.hints.HintsStore>);
    descriptor: (Lorg/apache/cassandra/hints/HintsBufferPool;Ljava/lang/Iterable;)Ljava/util/concurrent/Future;
    flags: (0x0000) 
    Code:
      stack=6, locals=3, args_size=3
        start local 0 // org.apache.cassandra.hints.HintsWriteExecutor this
        start local 1 // org.apache.cassandra.hints.HintsBufferPool bufferPool
        start local 2 // java.lang.Iterable stores
         0: .line 96
            aload 0 /* this */
            getfield org.apache.cassandra.hints.HintsWriteExecutor.executor:Ljava/util/concurrent/ExecutorService;
            new org.apache.cassandra.hints.HintsWriteExecutor$PartiallyFlushBufferPoolTask
            dup
            aload 0 /* this */
            aload 1 /* bufferPool */
            aload 2 /* stores */
            invokespecial org.apache.cassandra.hints.HintsWriteExecutor$PartiallyFlushBufferPoolTask.<init>:(Lorg/apache/cassandra/hints/HintsWriteExecutor;Lorg/apache/cassandra/hints/HintsBufferPool;Ljava/lang/Iterable;)V
            invokeinterface java.util.concurrent.ExecutorService.submit:(Ljava/lang/Runnable;)Ljava/util/concurrent/Future;
            areturn
        end local 2 // java.lang.Iterable stores
        end local 1 // org.apache.cassandra.hints.HintsBufferPool bufferPool
        end local 0 // org.apache.cassandra.hints.HintsWriteExecutor this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    1     0        this  Lorg/apache/cassandra/hints/HintsWriteExecutor;
            0    1     1  bufferPool  Lorg/apache/cassandra/hints/HintsBufferPool;
            0    1     2      stores  Ljava/lang/Iterable<Lorg/apache/cassandra/hints/HintsStore;>;
    Signature: (Lorg/apache/cassandra/hints/HintsBufferPool;Ljava/lang/Iterable<Lorg/apache/cassandra/hints/HintsStore;>;)Ljava/util/concurrent/Future<*>;
    MethodParameters:
            Name  Flags
      bufferPool  
      stores      

  void fsyncWritersBlockingly(java.lang.Iterable<org.apache.cassandra.hints.HintsStore>);
    descriptor: (Ljava/lang/Iterable;)V
    flags: (0x0000) 
    Code:
      stack=5, locals=3, args_size=2
        start local 0 // org.apache.cassandra.hints.HintsWriteExecutor this
        start local 1 // java.lang.Iterable stores
         0: .line 103
            aload 0 /* this */
            getfield org.apache.cassandra.hints.HintsWriteExecutor.executor:Ljava/util/concurrent/ExecutorService;
            new org.apache.cassandra.hints.HintsWriteExecutor$FsyncWritersTask
            dup
            aload 0 /* this */
            aload 1 /* stores */
            invokespecial org.apache.cassandra.hints.HintsWriteExecutor$FsyncWritersTask.<init>:(Lorg/apache/cassandra/hints/HintsWriteExecutor;Ljava/lang/Iterable;)V
            invokeinterface java.util.concurrent.ExecutorService.submit:(Ljava/lang/Runnable;)Ljava/util/concurrent/Future;
            invokeinterface java.util.concurrent.Future.get:()Ljava/lang/Object;
            pop
         1: .line 104
            goto 4
         2: .line 105
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 2 /* e */
        start local 2 // java.lang.Exception e
         3: .line 107
            new java.lang.RuntimeException
            dup
            aload 2 /* e */
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 2 // java.lang.Exception e
         4: .line 109
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.Iterable stores
        end local 0 // org.apache.cassandra.hints.HintsWriteExecutor this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    5     0    this  Lorg/apache/cassandra/hints/HintsWriteExecutor;
            0    5     1  stores  Ljava/lang/Iterable<Lorg/apache/cassandra/hints/HintsStore;>;
            3    4     2       e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           0     1       2  Class java.lang.InterruptedException
           0     1       2  Class java.util.concurrent.ExecutionException
    Signature: (Ljava/lang/Iterable<Lorg/apache/cassandra/hints/HintsStore;>;)V
    MethodParameters:
        Name  Flags
      stores  

  java.util.concurrent.Future<?> closeWriter(org.apache.cassandra.hints.HintsStore);
    descriptor: (Lorg/apache/cassandra/hints/HintsStore;)Ljava/util/concurrent/Future;
    flags: (0x0000) 
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.apache.cassandra.hints.HintsWriteExecutor this
        start local 1 // org.apache.cassandra.hints.HintsStore store
         0: .line 113
            aload 0 /* this */
            getfield org.apache.cassandra.hints.HintsWriteExecutor.executor:Ljava/util/concurrent/ExecutorService;
            aload 1 /* store */
            dup
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            pop
            invokedynamic run(Lorg/apache/cassandra/hints/HintsStore;)Ljava/lang/Runnable;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  ()V
                  org/apache/cassandra/hints/HintsStore.closeWriter()V (5)
                  ()V
            invokeinterface java.util.concurrent.ExecutorService.submit:(Ljava/lang/Runnable;)Ljava/util/concurrent/Future;
            areturn
        end local 1 // org.apache.cassandra.hints.HintsStore store
        end local 0 // org.apache.cassandra.hints.HintsWriteExecutor this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    1     0   this  Lorg/apache/cassandra/hints/HintsWriteExecutor;
            0    1     1  store  Lorg/apache/cassandra/hints/HintsStore;
    Signature: (Lorg/apache/cassandra/hints/HintsStore;)Ljava/util/concurrent/Future<*>;
    MethodParameters:
       Name  Flags
      store  

  java.util.concurrent.Future<?> closeAllWriters();
    descriptor: ()Ljava/util/concurrent/Future;
    flags: (0x0000) 
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.cassandra.hints.HintsWriteExecutor this
         0: .line 118
            aload 0 /* this */
            getfield org.apache.cassandra.hints.HintsWriteExecutor.executor:Ljava/util/concurrent/ExecutorService;
            aload 0 /* this */
            invokedynamic run(Lorg/apache/cassandra/hints/HintsWriteExecutor;)Ljava/lang/Runnable;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  ()V
                  org/apache/cassandra/hints/HintsWriteExecutor.lambda$1()V (7)
                  ()V
            invokeinterface java.util.concurrent.ExecutorService.submit:(Ljava/lang/Runnable;)Ljava/util/concurrent/Future;
            areturn
        end local 0 // org.apache.cassandra.hints.HintsWriteExecutor this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/hints/HintsWriteExecutor;
    Signature: ()Ljava/util/concurrent/Future<*>;

  private void flush(org.apache.cassandra.hints.HintsBuffer);
    descriptor: (Lorg/apache/cassandra/hints/HintsBuffer;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.apache.cassandra.hints.HintsWriteExecutor this
        start local 1 // org.apache.cassandra.hints.HintsBuffer buffer
         0: .line 210
            aload 1 /* buffer */
            invokevirtual org.apache.cassandra.hints.HintsBuffer.hostIds:()Ljava/util/Set;
            aload 0 /* this */
            aload 1 /* buffer */
            invokedynamic accept(Lorg/apache/cassandra/hints/HintsWriteExecutor;Lorg/apache/cassandra/hints/HintsBuffer;)Ljava/util/function/Consumer;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  (Ljava/lang/Object;)V
                  org/apache/cassandra/hints/HintsWriteExecutor.lambda$3(Lorg/apache/cassandra/hints/HintsBuffer;Ljava/util/UUID;)V (7)
                  (Ljava/util/UUID;)V
            invokeinterface java.util.Set.forEach:(Ljava/util/function/Consumer;)V
         1: .line 211
            return
        end local 1 // org.apache.cassandra.hints.HintsBuffer buffer
        end local 0 // org.apache.cassandra.hints.HintsWriteExecutor this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0    this  Lorg/apache/cassandra/hints/HintsWriteExecutor;
            0    2     1  buffer  Lorg/apache/cassandra/hints/HintsBuffer;
    MethodParameters:
        Name  Flags
      buffer  

  private void flush(java.util.Iterator<java.nio.ByteBuffer>, org.apache.cassandra.hints.HintsStore);
    descriptor: (Ljava/util/Iterator;Lorg/apache/cassandra/hints/HintsStore;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // org.apache.cassandra.hints.HintsWriteExecutor this
        start local 1 // java.util.Iterator iterator
        start local 2 // org.apache.cassandra.hints.HintsStore store
         0: .line 217
      StackMap locals:
      StackMap stack:
            aload 1 /* iterator */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifeq 2
         1: .line 218
            aload 0 /* this */
            aload 1 /* iterator */
            aload 2 /* store */
            invokevirtual org.apache.cassandra.hints.HintsWriteExecutor.flushInternal:(Ljava/util/Iterator;Lorg/apache/cassandra/hints/HintsStore;)V
         2: .line 220
      StackMap locals:
      StackMap stack:
            aload 1 /* iterator */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 4
         3: .line 221
            goto 6
         4: .line 225
      StackMap locals:
      StackMap stack:
            aload 2 /* store */
            invokevirtual org.apache.cassandra.hints.HintsStore.closeWriter:()V
         5: .line 215
            goto 0
         6: .line 227
      StackMap locals:
      StackMap stack:
            return
        end local 2 // org.apache.cassandra.hints.HintsStore store
        end local 1 // java.util.Iterator iterator
        end local 0 // org.apache.cassandra.hints.HintsWriteExecutor this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    7     0      this  Lorg/apache/cassandra/hints/HintsWriteExecutor;
            0    7     1  iterator  Ljava/util/Iterator<Ljava/nio/ByteBuffer;>;
            0    7     2     store  Lorg/apache/cassandra/hints/HintsStore;
    Signature: (Ljava/util/Iterator<Ljava/nio/ByteBuffer;>;Lorg/apache/cassandra/hints/HintsStore;)V
    MethodParameters:
          Name  Flags
      iterator  
      store     

  private void flushInternal(java.util.Iterator<java.nio.ByteBuffer>, org.apache.cassandra.hints.HintsStore);
    descriptor: (Ljava/util/Iterator;Lorg/apache/cassandra/hints/HintsStore;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=9, args_size=3
        start local 0 // org.apache.cassandra.hints.HintsWriteExecutor this
        start local 1 // java.util.Iterator iterator
        start local 2 // org.apache.cassandra.hints.HintsStore store
         0: .line 232
            invokestatic org.apache.cassandra.config.DatabaseDescriptor.getMaxHintsFileSize:()J
            lstore 3 /* maxHintsFileSize */
        start local 3 // long maxHintsFileSize
         1: .line 234
            aload 2 /* store */
            invokevirtual org.apache.cassandra.hints.HintsStore.getOrOpenWriter:()Lorg/apache/cassandra/hints/HintsWriter;
            astore 5 /* writer */
        start local 5 // org.apache.cassandra.hints.HintsWriter writer
         2: .line 236
            aconst_null
            astore 6
            aconst_null
            astore 7
         3: aload 5 /* writer */
            aload 0 /* this */
            getfield org.apache.cassandra.hints.HintsWriteExecutor.writeBuffer:Ljava/nio/ByteBuffer;
            invokevirtual org.apache.cassandra.hints.HintsWriter.newSession:(Ljava/nio/ByteBuffer;)Lorg/apache/cassandra/hints/HintsWriter$Session;
            astore 8 /* session */
        start local 8 // org.apache.cassandra.hints.HintsWriter$Session session
         4: .line 238
            goto 8
         5: .line 240
      StackMap locals: org.apache.cassandra.hints.HintsWriteExecutor java.util.Iterator org.apache.cassandra.hints.HintsStore long org.apache.cassandra.hints.HintsWriter java.lang.Throwable java.lang.Throwable org.apache.cassandra.hints.HintsWriter$Session
      StackMap stack:
            aload 8 /* session */
            aload 1 /* iterator */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.nio.ByteBuffer
            invokevirtual org.apache.cassandra.hints.HintsWriter$Session.append:(Ljava/nio/ByteBuffer;)V
         6: .line 241
            aload 8 /* session */
            invokevirtual org.apache.cassandra.hints.HintsWriter$Session.position:()J
            lload 3 /* maxHintsFileSize */
            lcmp
            iflt 8
         7: .line 242
            goto 9
         8: .line 238
      StackMap locals:
      StackMap stack:
            aload 1 /* iterator */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 5
         9: .line 244
      StackMap locals:
      StackMap stack:
            aload 8 /* session */
            ifnull 17
            aload 8 /* session */
            invokevirtual org.apache.cassandra.hints.HintsWriter$Session.close:()V
            goto 17
      StackMap locals:
      StackMap stack: java.lang.Throwable
        10: astore 6
            aload 8 /* session */
            ifnull 11
            aload 8 /* session */
            invokevirtual org.apache.cassandra.hints.HintsWriter$Session.close:()V
        end local 8 // org.apache.cassandra.hints.HintsWriter$Session session
      StackMap locals:
      StackMap stack:
        11: aload 6
            athrow
      StackMap locals:
      StackMap stack: java.lang.Throwable
        12: astore 7
            aload 6
            ifnonnull 13
            aload 7
            astore 6
            goto 14
      StackMap locals:
      StackMap stack:
        13: aload 6
            aload 7
            if_acmpeq 14
            aload 6
            aload 7
            invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
      StackMap locals:
      StackMap stack:
        14: aload 6
            athrow
        15: .line 245
      StackMap locals: org.apache.cassandra.hints.HintsWriteExecutor java.util.Iterator org.apache.cassandra.hints.HintsStore long org.apache.cassandra.hints.HintsWriter
      StackMap stack: java.io.IOException
            astore 6 /* e */
        start local 6 // java.io.IOException e
        16: .line 247
            new org.apache.cassandra.io.FSWriteError
            dup
            aload 6 /* e */
            aload 5 /* writer */
            invokevirtual org.apache.cassandra.hints.HintsWriter.descriptor:()Lorg/apache/cassandra/hints/HintsDescriptor;
            invokevirtual org.apache.cassandra.hints.HintsDescriptor.fileName:()Ljava/lang/String;
            invokespecial org.apache.cassandra.io.FSWriteError.<init>:(Ljava/lang/Throwable;Ljava/lang/String;)V
            athrow
        end local 6 // java.io.IOException e
        17: .line 249
      StackMap locals:
      StackMap stack:
            return
        end local 5 // org.apache.cassandra.hints.HintsWriter writer
        end local 3 // long maxHintsFileSize
        end local 2 // org.apache.cassandra.hints.HintsStore store
        end local 1 // java.util.Iterator iterator
        end local 0 // org.apache.cassandra.hints.HintsWriteExecutor this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   18     0              this  Lorg/apache/cassandra/hints/HintsWriteExecutor;
            0   18     1          iterator  Ljava/util/Iterator<Ljava/nio/ByteBuffer;>;
            0   18     2             store  Lorg/apache/cassandra/hints/HintsStore;
            1   18     3  maxHintsFileSize  J
            2   18     5            writer  Lorg/apache/cassandra/hints/HintsWriter;
            4   11     8           session  Lorg/apache/cassandra/hints/HintsWriter$Session;
           16   17     6                 e  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           4     9      10  any
           3    12      12  any
           2    15      15  Class java.io.IOException
    Signature: (Ljava/util/Iterator<Ljava/nio/ByteBuffer;>;Lorg/apache/cassandra/hints/HintsStore;)V
    MethodParameters:
          Name  Flags
      iterator  
      store     

  private void lambda$1();
    descriptor: ()V
    flags: (0x1002) ACC_PRIVATE, ACC_SYNTHETIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.cassandra.hints.HintsWriteExecutor this
         0: .line 118
            aload 0 /* this */
            getfield org.apache.cassandra.hints.HintsWriteExecutor.catalog:Lorg/apache/cassandra/hints/HintsCatalog;
            invokevirtual org.apache.cassandra.hints.HintsCatalog.stores:()Ljava/util/stream/Stream;
            invokedynamic accept()Ljava/util/function/Consumer;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  (Ljava/lang/Object;)V
                  org/apache/cassandra/hints/HintsStore.closeWriter()V (5)
                  (Lorg/apache/cassandra/hints/HintsStore;)V
            invokeinterface java.util.stream.Stream.forEach:(Ljava/util/function/Consumer;)V
            return
        end local 0 // org.apache.cassandra.hints.HintsWriteExecutor this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/hints/HintsWriteExecutor;

  private void lambda$3(org.apache.cassandra.hints.HintsBuffer, java.util.UUID);
    descriptor: (Lorg/apache/cassandra/hints/HintsBuffer;Ljava/util/UUID;)V
    flags: (0x1002) ACC_PRIVATE, ACC_SYNTHETIC
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.apache.cassandra.hints.HintsWriteExecutor this
        start local 2 // java.util.UUID hostId
         0: .line 210
            aload 0 /* this */
            aload 1
            aload 2 /* hostId */
            invokevirtual org.apache.cassandra.hints.HintsBuffer.consumingHintsIterator:(Ljava/util/UUID;)Ljava/util/Iterator;
            aload 0 /* this */
            getfield org.apache.cassandra.hints.HintsWriteExecutor.catalog:Lorg/apache/cassandra/hints/HintsCatalog;
            aload 2 /* hostId */
            invokevirtual org.apache.cassandra.hints.HintsCatalog.get:(Ljava/util/UUID;)Lorg/apache/cassandra/hints/HintsStore;
            invokevirtual org.apache.cassandra.hints.HintsWriteExecutor.flush:(Ljava/util/Iterator;Lorg/apache/cassandra/hints/HintsStore;)V
            return
        end local 2 // java.util.UUID hostId
        end local 0 // org.apache.cassandra.hints.HintsWriteExecutor this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    1     0    this  Lorg/apache/cassandra/hints/HintsWriteExecutor;
            0    1     2  hostId  Ljava/util/UUID;
}
SourceFile: "HintsWriteExecutor.java"
NestMembers:
  org.apache.cassandra.hints.HintsWriteExecutor$FlushBufferPoolTask  org.apache.cassandra.hints.HintsWriteExecutor$FlushBufferTask  org.apache.cassandra.hints.HintsWriteExecutor$FsyncWritersTask  org.apache.cassandra.hints.HintsWriteExecutor$PartiallyFlushBufferPoolTask
InnerClasses:
  public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles
  private final FlushBufferPoolTask = org.apache.cassandra.hints.HintsWriteExecutor$FlushBufferPoolTask of org.apache.cassandra.hints.HintsWriteExecutor
  private final FlushBufferTask = org.apache.cassandra.hints.HintsWriteExecutor$FlushBufferTask of org.apache.cassandra.hints.HintsWriteExecutor
  private final FsyncWritersTask = org.apache.cassandra.hints.HintsWriteExecutor$FsyncWritersTask of org.apache.cassandra.hints.HintsWriteExecutor
  private final PartiallyFlushBufferPoolTask = org.apache.cassandra.hints.HintsWriteExecutor$PartiallyFlushBufferPoolTask of org.apache.cassandra.hints.HintsWriteExecutor
  final Session = org.apache.cassandra.hints.HintsWriter$Session of org.apache.cassandra.hints.HintsWriter