public class org.apache.cassandra.io.util.FileHandle extends org.apache.cassandra.utils.concurrent.SharedCloseableImpl
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.apache.cassandra.io.util.FileHandle
  super_class: org.apache.cassandra.utils.concurrent.SharedCloseableImpl
{
  private static final org.slf4j.Logger logger;
    descriptor: Lorg/slf4j/Logger;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  public final org.apache.cassandra.io.util.ChannelProxy channel;
    descriptor: Lorg/apache/cassandra/io/util/ChannelProxy;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL

  public final long onDiskLength;
    descriptor: J
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL

  private final org.apache.cassandra.io.util.RebuffererFactory rebuffererFactory;
    descriptor: Lorg/apache/cassandra/io/util/RebuffererFactory;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.util.Optional<org.apache.cassandra.io.compress.CompressionMetadata> compressionMetadata;
    descriptor: Ljava/util/Optional;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/Optional<Lorg/apache/cassandra/io/compress/CompressionMetadata;>;

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

  private void <init>(org.apache.cassandra.io.util.FileHandle$Cleanup, org.apache.cassandra.io.util.ChannelProxy, org.apache.cassandra.io.util.RebuffererFactory, org.apache.cassandra.io.compress.CompressionMetadata, long);
    descriptor: (Lorg/apache/cassandra/io/util/FileHandle$Cleanup;Lorg/apache/cassandra/io/util/ChannelProxy;Lorg/apache/cassandra/io/util/RebuffererFactory;Lorg/apache/cassandra/io/compress/CompressionMetadata;J)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=7, args_size=6
        start local 0 // org.apache.cassandra.io.util.FileHandle this
        start local 1 // org.apache.cassandra.io.util.FileHandle$Cleanup cleanup
        start local 2 // org.apache.cassandra.io.util.ChannelProxy channel
        start local 3 // org.apache.cassandra.io.util.RebuffererFactory rebuffererFactory
        start local 4 // org.apache.cassandra.io.compress.CompressionMetadata compressionMetadata
        start local 5 // long onDiskLength
         0: .line 73
            aload 0 /* this */
            aload 1 /* cleanup */
            invokespecial org.apache.cassandra.utils.concurrent.SharedCloseableImpl.<init>:(Lorg/apache/cassandra/utils/concurrent/RefCounted$Tidy;)V
         1: .line 74
            aload 0 /* this */
            aload 3 /* rebuffererFactory */
            putfield org.apache.cassandra.io.util.FileHandle.rebuffererFactory:Lorg/apache/cassandra/io/util/RebuffererFactory;
         2: .line 75
            aload 0 /* this */
            aload 2 /* channel */
            putfield org.apache.cassandra.io.util.FileHandle.channel:Lorg/apache/cassandra/io/util/ChannelProxy;
         3: .line 76
            aload 0 /* this */
            aload 4 /* compressionMetadata */
            invokestatic java.util.Optional.ofNullable:(Ljava/lang/Object;)Ljava/util/Optional;
            putfield org.apache.cassandra.io.util.FileHandle.compressionMetadata:Ljava/util/Optional;
         4: .line 77
            aload 0 /* this */
            lload 5 /* onDiskLength */
            putfield org.apache.cassandra.io.util.FileHandle.onDiskLength:J
         5: .line 78
            return
        end local 5 // long onDiskLength
        end local 4 // org.apache.cassandra.io.compress.CompressionMetadata compressionMetadata
        end local 3 // org.apache.cassandra.io.util.RebuffererFactory rebuffererFactory
        end local 2 // org.apache.cassandra.io.util.ChannelProxy channel
        end local 1 // org.apache.cassandra.io.util.FileHandle$Cleanup cleanup
        end local 0 // org.apache.cassandra.io.util.FileHandle this
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0    6     0                 this  Lorg/apache/cassandra/io/util/FileHandle;
            0    6     1              cleanup  Lorg/apache/cassandra/io/util/FileHandle$Cleanup;
            0    6     2              channel  Lorg/apache/cassandra/io/util/ChannelProxy;
            0    6     3    rebuffererFactory  Lorg/apache/cassandra/io/util/RebuffererFactory;
            0    6     4  compressionMetadata  Lorg/apache/cassandra/io/compress/CompressionMetadata;
            0    6     5         onDiskLength  J
    MethodParameters:
                     Name  Flags
      cleanup              
      channel              
      rebuffererFactory    
      compressionMetadata  
      onDiskLength         

  private void <init>(org.apache.cassandra.io.util.FileHandle);
    descriptor: (Lorg/apache/cassandra/io/util/FileHandle;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.apache.cassandra.io.util.FileHandle this
        start local 1 // org.apache.cassandra.io.util.FileHandle copy
         0: .line 82
            aload 0 /* this */
            aload 1 /* copy */
            invokespecial org.apache.cassandra.utils.concurrent.SharedCloseableImpl.<init>:(Lorg/apache/cassandra/utils/concurrent/SharedCloseableImpl;)V
         1: .line 83
            aload 0 /* this */
            aload 1 /* copy */
            getfield org.apache.cassandra.io.util.FileHandle.channel:Lorg/apache/cassandra/io/util/ChannelProxy;
            putfield org.apache.cassandra.io.util.FileHandle.channel:Lorg/apache/cassandra/io/util/ChannelProxy;
         2: .line 84
            aload 0 /* this */
            aload 1 /* copy */
            getfield org.apache.cassandra.io.util.FileHandle.rebuffererFactory:Lorg/apache/cassandra/io/util/RebuffererFactory;
            putfield org.apache.cassandra.io.util.FileHandle.rebuffererFactory:Lorg/apache/cassandra/io/util/RebuffererFactory;
         3: .line 85
            aload 0 /* this */
            aload 1 /* copy */
            getfield org.apache.cassandra.io.util.FileHandle.compressionMetadata:Ljava/util/Optional;
            putfield org.apache.cassandra.io.util.FileHandle.compressionMetadata:Ljava/util/Optional;
         4: .line 86
            aload 0 /* this */
            aload 1 /* copy */
            getfield org.apache.cassandra.io.util.FileHandle.onDiskLength:J
            putfield org.apache.cassandra.io.util.FileHandle.onDiskLength:J
         5: .line 87
            return
        end local 1 // org.apache.cassandra.io.util.FileHandle copy
        end local 0 // org.apache.cassandra.io.util.FileHandle this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lorg/apache/cassandra/io/util/FileHandle;
            0    6     1  copy  Lorg/apache/cassandra/io/util/FileHandle;
    MethodParameters:
      Name  Flags
      copy  

  public java.lang.String path();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.io.util.FileHandle this
         0: .line 94
            aload 0 /* this */
            getfield org.apache.cassandra.io.util.FileHandle.channel:Lorg/apache/cassandra/io/util/ChannelProxy;
            invokevirtual org.apache.cassandra.io.util.ChannelProxy.filePath:()Ljava/lang/String;
            areturn
        end local 0 // org.apache.cassandra.io.util.FileHandle this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/io/util/FileHandle;

  public long dataLength();
    descriptor: ()J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.apache.cassandra.io.util.FileHandle this
         0: .line 99
            aload 0 /* this */
            getfield org.apache.cassandra.io.util.FileHandle.compressionMetadata:Ljava/util/Optional;
            invokedynamic apply()Ljava/util/function/Function;
              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;)Ljava/lang/Object;
                  org/apache/cassandra/io/util/FileHandle.lambda$0(Lorg/apache/cassandra/io/compress/CompressionMetadata;)Ljava/lang/Long; (6)
                  (Lorg/apache/cassandra/io/compress/CompressionMetadata;)Ljava/lang/Long;
            invokevirtual java.util.Optional.map:(Ljava/util/function/Function;)Ljava/util/Optional;
            aload 0 /* this */
            getfield org.apache.cassandra.io.util.FileHandle.rebuffererFactory:Lorg/apache/cassandra/io/util/RebuffererFactory;
            dup
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            pop
            invokedynamic get(Lorg/apache/cassandra/io/util/RebuffererFactory;)Ljava/util/function/Supplier;
              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;
                  org/apache/cassandra/io/util/ReaderFileProxy.fileLength()J (9 itf)
                  ()Ljava/lang/Long;
            invokevirtual java.util.Optional.orElseGet:(Ljava/util/function/Supplier;)Ljava/lang/Object;
            checkcast java.lang.Long
            invokevirtual java.lang.Long.longValue:()J
            lreturn
        end local 0 // org.apache.cassandra.io.util.FileHandle this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/io/util/FileHandle;

  public org.apache.cassandra.io.util.RebuffererFactory rebuffererFactory();
    descriptor: ()Lorg/apache/cassandra/io/util/RebuffererFactory;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.io.util.FileHandle this
         0: .line 104
            aload 0 /* this */
            getfield org.apache.cassandra.io.util.FileHandle.rebuffererFactory:Lorg/apache/cassandra/io/util/RebuffererFactory;
            areturn
        end local 0 // org.apache.cassandra.io.util.FileHandle this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/io/util/FileHandle;

  public java.util.Optional<org.apache.cassandra.io.compress.CompressionMetadata> compressionMetadata();
    descriptor: ()Ljava/util/Optional;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.io.util.FileHandle this
         0: .line 109
            aload 0 /* this */
            getfield org.apache.cassandra.io.util.FileHandle.compressionMetadata:Ljava/util/Optional;
            areturn
        end local 0 // org.apache.cassandra.io.util.FileHandle this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/io/util/FileHandle;
    Signature: ()Ljava/util/Optional<Lorg/apache/cassandra/io/compress/CompressionMetadata;>;

  public void addTo(org.apache.cassandra.utils.concurrent.Ref$IdentityCollection);
    descriptor: (Lorg/apache/cassandra/utils/concurrent/Ref$IdentityCollection;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.io.util.FileHandle this
        start local 1 // org.apache.cassandra.utils.concurrent.Ref$IdentityCollection identities
         0: .line 115
            aload 0 /* this */
            aload 1 /* identities */
            invokespecial org.apache.cassandra.utils.concurrent.SharedCloseableImpl.addTo:(Lorg/apache/cassandra/utils/concurrent/Ref$IdentityCollection;)V
         1: .line 116
            aload 0 /* this */
            getfield org.apache.cassandra.io.util.FileHandle.compressionMetadata:Ljava/util/Optional;
            aload 1 /* identities */
            invokedynamic accept(Lorg/apache/cassandra/utils/concurrent/Ref$IdentityCollection;)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/io/util/FileHandle.lambda$2(Lorg/apache/cassandra/utils/concurrent/Ref$IdentityCollection;Lorg/apache/cassandra/io/compress/CompressionMetadata;)V (6)
                  (Lorg/apache/cassandra/io/compress/CompressionMetadata;)V
            invokevirtual java.util.Optional.ifPresent:(Ljava/util/function/Consumer;)V
         2: .line 117
            return
        end local 1 // org.apache.cassandra.utils.concurrent.Ref$IdentityCollection identities
        end local 0 // org.apache.cassandra.io.util.FileHandle this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    3     0        this  Lorg/apache/cassandra/io/util/FileHandle;
            0    3     1  identities  Lorg/apache/cassandra/utils/concurrent/Ref$IdentityCollection;
    MethodParameters:
            Name  Flags
      identities  

  public org.apache.cassandra.io.util.FileHandle sharedCopy();
    descriptor: ()Lorg/apache/cassandra/io/util/FileHandle;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.apache.cassandra.io.util.FileHandle this
         0: .line 122
            new org.apache.cassandra.io.util.FileHandle
            dup
            aload 0 /* this */
            invokespecial org.apache.cassandra.io.util.FileHandle.<init>:(Lorg/apache/cassandra/io/util/FileHandle;)V
            areturn
        end local 0 // org.apache.cassandra.io.util.FileHandle this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/io/util/FileHandle;

  public org.apache.cassandra.io.util.RandomAccessReader createReader();
    descriptor: ()Lorg/apache/cassandra/io/util/RandomAccessReader;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.cassandra.io.util.FileHandle this
         0: .line 132
            aload 0 /* this */
            aconst_null
            invokevirtual org.apache.cassandra.io.util.FileHandle.createReader:(Lcom/google/common/util/concurrent/RateLimiter;)Lorg/apache/cassandra/io/util/RandomAccessReader;
            areturn
        end local 0 // org.apache.cassandra.io.util.FileHandle this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/io/util/FileHandle;

  public org.apache.cassandra.io.util.RandomAccessReader createReader(com.google.common.util.concurrent.RateLimiter);
    descriptor: (Lcom/google/common/util/concurrent/RateLimiter;)Lorg/apache/cassandra/io/util/RandomAccessReader;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.apache.cassandra.io.util.FileHandle this
        start local 1 // com.google.common.util.concurrent.RateLimiter limiter
         0: .line 144
            new org.apache.cassandra.io.util.RandomAccessReader
            dup
            aload 0 /* this */
            aload 1 /* limiter */
            invokevirtual org.apache.cassandra.io.util.FileHandle.instantiateRebufferer:(Lcom/google/common/util/concurrent/RateLimiter;)Lorg/apache/cassandra/io/util/Rebufferer;
            invokespecial org.apache.cassandra.io.util.RandomAccessReader.<init>:(Lorg/apache/cassandra/io/util/Rebufferer;)V
            areturn
        end local 1 // com.google.common.util.concurrent.RateLimiter limiter
        end local 0 // org.apache.cassandra.io.util.FileHandle this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    1     0     this  Lorg/apache/cassandra/io/util/FileHandle;
            0    1     1  limiter  Lcom/google/common/util/concurrent/RateLimiter;
    MethodParameters:
         Name  Flags
      limiter  

  public org.apache.cassandra.io.util.FileDataInput createReader(long);
    descriptor: (J)Lorg/apache/cassandra/io/util/FileDataInput;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=2
        start local 0 // org.apache.cassandra.io.util.FileHandle this
        start local 1 // long position
         0: .line 149
            aload 0 /* this */
            invokevirtual org.apache.cassandra.io.util.FileHandle.createReader:()Lorg/apache/cassandra/io/util/RandomAccessReader;
            astore 3 /* reader */
        start local 3 // org.apache.cassandra.io.util.RandomAccessReader reader
         1: .line 150
            aload 3 /* reader */
            lload 1 /* position */
            invokevirtual org.apache.cassandra.io.util.RandomAccessReader.seek:(J)V
         2: .line 151
            aload 3 /* reader */
            areturn
        end local 3 // org.apache.cassandra.io.util.RandomAccessReader reader
        end local 1 // long position
        end local 0 // org.apache.cassandra.io.util.FileHandle this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    3     0      this  Lorg/apache/cassandra/io/util/FileHandle;
            0    3     1  position  J
            1    3     3    reader  Lorg/apache/cassandra/io/util/RandomAccessReader;
    MethodParameters:
          Name  Flags
      position  

  public void dropPageCache(long);
    descriptor: (J)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=5, args_size=2
        start local 0 // org.apache.cassandra.io.util.FileHandle this
        start local 1 // long before
         0: .line 161
            aload 0 /* this */
            getfield org.apache.cassandra.io.util.FileHandle.compressionMetadata:Ljava/util/Optional;
            lload 1 /* before */
            invokedynamic apply(J)Ljava/util/function/Function;
              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;)Ljava/lang/Object;
                  org/apache/cassandra/io/util/FileHandle.lambda$3(JLorg/apache/cassandra/io/compress/CompressionMetadata;)Ljava/lang/Long; (6)
                  (Lorg/apache/cassandra/io/compress/CompressionMetadata;)Ljava/lang/Long;
            invokevirtual java.util.Optional.map:(Ljava/util/function/Function;)Ljava/util/Optional;
         1: .line 166
            lload 1 /* before */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            invokevirtual java.util.Optional.orElse:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Long
            invokevirtual java.lang.Long.longValue:()J
         2: .line 161
            lstore 3 /* position */
        start local 3 // long position
         3: .line 167
            aload 0 /* this */
            getfield org.apache.cassandra.io.util.FileHandle.channel:Lorg/apache/cassandra/io/util/ChannelProxy;
            invokevirtual org.apache.cassandra.io.util.ChannelProxy.getFileDescriptor:()I
            lconst_0
            lload 3 /* position */
            aload 0 /* this */
            invokevirtual org.apache.cassandra.io.util.FileHandle.path:()Ljava/lang/String;
            invokestatic org.apache.cassandra.utils.NativeLibrary.trySkipCache:(IJJLjava/lang/String;)V
         4: .line 168
            return
        end local 3 // long position
        end local 1 // long before
        end local 0 // org.apache.cassandra.io.util.FileHandle this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    5     0      this  Lorg/apache/cassandra/io/util/FileHandle;
            0    5     1    before  J
            3    5     3  position  J
    MethodParameters:
        Name  Flags
      before  

  private org.apache.cassandra.io.util.Rebufferer instantiateRebufferer(com.google.common.util.concurrent.RateLimiter);
    descriptor: (Lcom/google/common/util/concurrent/RateLimiter;)Lorg/apache/cassandra/io/util/Rebufferer;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=3, args_size=2
        start local 0 // org.apache.cassandra.io.util.FileHandle this
        start local 1 // com.google.common.util.concurrent.RateLimiter limiter
         0: .line 172
            aload 0 /* this */
            getfield org.apache.cassandra.io.util.FileHandle.rebuffererFactory:Lorg/apache/cassandra/io/util/RebuffererFactory;
            invokeinterface org.apache.cassandra.io.util.RebuffererFactory.instantiateRebufferer:()Lorg/apache/cassandra/io/util/Rebufferer;
            astore 2 /* rebufferer */
        start local 2 // org.apache.cassandra.io.util.Rebufferer rebufferer
         1: .line 174
            aload 1 /* limiter */
            ifnull 3
         2: .line 175
            new org.apache.cassandra.io.util.LimitingRebufferer
            dup
            aload 2 /* rebufferer */
            aload 1 /* limiter */
            ldc 65536
            invokespecial org.apache.cassandra.io.util.LimitingRebufferer.<init>:(Lorg/apache/cassandra/io/util/Rebufferer;Lcom/google/common/util/concurrent/RateLimiter;I)V
            astore 2 /* rebufferer */
         3: .line 176
      StackMap locals: org.apache.cassandra.io.util.Rebufferer
      StackMap stack:
            aload 2 /* rebufferer */
            areturn
        end local 2 // org.apache.cassandra.io.util.Rebufferer rebufferer
        end local 1 // com.google.common.util.concurrent.RateLimiter limiter
        end local 0 // org.apache.cassandra.io.util.FileHandle this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    4     0        this  Lorg/apache/cassandra/io/util/FileHandle;
            0    4     1     limiter  Lcom/google/common/util/concurrent/RateLimiter;
            1    4     2  rebufferer  Lorg/apache/cassandra/io/util/Rebufferer;
    MethodParameters:
         Name  Flags
      limiter  

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.apache.cassandra.io.util.FileHandle this
         0: .line 438
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.getSimpleName:()Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc "(path='"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            invokevirtual org.apache.cassandra.io.util.FileHandle.path:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            bipush 39
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
         1: .line 439
            ldc ", length="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield org.apache.cassandra.io.util.FileHandle.rebuffererFactory:Lorg/apache/cassandra/io/util/RebuffererFactory;
            invokeinterface org.apache.cassandra.io.util.RebuffererFactory.fileLength:()J
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
         2: .line 440
            bipush 41
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
         3: .line 438
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 0 // org.apache.cassandra.io.util.FileHandle this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lorg/apache/cassandra/io/util/FileHandle;

  public org.apache.cassandra.utils.concurrent.SharedCloseable sharedCopy();
    descriptor: ()Lorg/apache/cassandra/utils/concurrent/SharedCloseable;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 1
            aload 0
            invokevirtual org.apache.cassandra.io.util.FileHandle.sharedCopy:()Lorg/apache/cassandra/io/util/FileHandle;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  private static java.lang.Long lambda$0(org.apache.cassandra.io.compress.CompressionMetadata);
    descriptor: (Lorg/apache/cassandra/io/compress/CompressionMetadata;)Ljava/lang/Long;
    flags: (0x100a) ACC_PRIVATE, ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.cassandra.io.compress.CompressionMetadata c
         0: .line 99
            aload 0 /* c */
            getfield org.apache.cassandra.io.compress.CompressionMetadata.dataLength:J
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            areturn
        end local 0 // org.apache.cassandra.io.compress.CompressionMetadata c
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0     c  Lorg/apache/cassandra/io/compress/CompressionMetadata;

  private static void lambda$2(org.apache.cassandra.utils.concurrent.Ref$IdentityCollection, org.apache.cassandra.io.compress.CompressionMetadata);
    descriptor: (Lorg/apache/cassandra/utils/concurrent/Ref$IdentityCollection;Lorg/apache/cassandra/io/compress/CompressionMetadata;)V
    flags: (0x100a) ACC_PRIVATE, ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=2, locals=2, args_size=2
        start local 1 // org.apache.cassandra.io.compress.CompressionMetadata metadata
         0: .line 116
            aload 1 /* metadata */
            aload 0
            invokevirtual org.apache.cassandra.io.compress.CompressionMetadata.addTo:(Lorg/apache/cassandra/utils/concurrent/Ref$IdentityCollection;)V
            return
        end local 1 // org.apache.cassandra.io.compress.CompressionMetadata metadata
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    1     1  metadata  Lorg/apache/cassandra/io/compress/CompressionMetadata;

  private static java.lang.Long lambda$3(long, org.apache.cassandra.io.compress.CompressionMetadata);
    descriptor: (JLorg/apache/cassandra/io/compress/CompressionMetadata;)Ljava/lang/Long;
    flags: (0x100a) ACC_PRIVATE, ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=4, locals=3, args_size=2
        start local 2 // org.apache.cassandra.io.compress.CompressionMetadata metadata
         0: .line 162
            lload 0
            aload 2 /* metadata */
            getfield org.apache.cassandra.io.compress.CompressionMetadata.dataLength:J
            lcmp
            iflt 2
         1: .line 163
            lconst_0
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            areturn
         2: .line 165
      StackMap locals:
      StackMap stack:
            aload 2 /* metadata */
            lload 0
            invokevirtual org.apache.cassandra.io.compress.CompressionMetadata.chunkFor:(J)Lorg/apache/cassandra/io/compress/CompressionMetadata$Chunk;
            getfield org.apache.cassandra.io.compress.CompressionMetadata$Chunk.offset:J
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            areturn
        end local 2 // org.apache.cassandra.io.compress.CompressionMetadata metadata
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    3     2  metadata  Lorg/apache/cassandra/io/compress/CompressionMetadata;
}
SourceFile: "FileHandle.java"
NestMembers:
  org.apache.cassandra.io.util.FileHandle$Builder  org.apache.cassandra.io.util.FileHandle$Cleanup
InnerClasses:
  public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles
  public Chunk = org.apache.cassandra.io.compress.CompressionMetadata$Chunk of org.apache.cassandra.io.compress.CompressionMetadata
  public Builder = org.apache.cassandra.io.util.FileHandle$Builder of org.apache.cassandra.io.util.FileHandle
  private Cleanup = org.apache.cassandra.io.util.FileHandle$Cleanup of org.apache.cassandra.io.util.FileHandle
  public IdentityCollection = org.apache.cassandra.utils.concurrent.Ref$IdentityCollection of org.apache.cassandra.utils.concurrent.Ref
  public abstract Tidy = org.apache.cassandra.utils.concurrent.RefCounted$Tidy of org.apache.cassandra.utils.concurrent.RefCounted