public class org.apache.cassandra.db.lifecycle.SSTableIntervalTree extends org.apache.cassandra.utils.IntervalTree<org.apache.cassandra.db.PartitionPosition, org.apache.cassandra.io.sstable.format.SSTableReader, org.apache.cassandra.utils.Interval<org.apache.cassandra.db.PartitionPosition, org.apache.cassandra.io.sstable.format.SSTableReader>>
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.apache.cassandra.db.lifecycle.SSTableIntervalTree
  super_class: org.apache.cassandra.utils.IntervalTree
{
  private static final org.apache.cassandra.db.lifecycle.SSTableIntervalTree EMPTY;
    descriptor: Lorg/apache/cassandra/db/lifecycle/SSTableIntervalTree;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=0, args_size=0
         0: .line 36
            new org.apache.cassandra.db.lifecycle.SSTableIntervalTree
            dup
            aconst_null
            invokespecial org.apache.cassandra.db.lifecycle.SSTableIntervalTree.<init>:(Ljava/util/Collection;)V
            putstatic org.apache.cassandra.db.lifecycle.SSTableIntervalTree.EMPTY:Lorg/apache/cassandra/db/lifecycle/SSTableIntervalTree;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>(java.util.Collection<org.apache.cassandra.utils.Interval<org.apache.cassandra.db.PartitionPosition, org.apache.cassandra.io.sstable.format.SSTableReader>>);
    descriptor: (Ljava/util/Collection;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.db.lifecycle.SSTableIntervalTree this
        start local 1 // java.util.Collection intervals
         0: .line 40
            aload 0 /* this */
            aload 1 /* intervals */
            invokespecial org.apache.cassandra.utils.IntervalTree.<init>:(Ljava/util/Collection;)V
         1: .line 41
            return
        end local 1 // java.util.Collection intervals
        end local 0 // org.apache.cassandra.db.lifecycle.SSTableIntervalTree this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    2     0       this  Lorg/apache/cassandra/db/lifecycle/SSTableIntervalTree;
            0    2     1  intervals  Ljava/util/Collection<Lorg/apache/cassandra/utils/Interval<Lorg/apache/cassandra/db/PartitionPosition;Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;>;
    Signature: (Ljava/util/Collection<Lorg/apache/cassandra/utils/Interval<Lorg/apache/cassandra/db/PartitionPosition;Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;>;)V
    MethodParameters:
           Name  Flags
      intervals  

  public static org.apache.cassandra.db.lifecycle.SSTableIntervalTree empty();
    descriptor: ()Lorg/apache/cassandra/db/lifecycle/SSTableIntervalTree;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 45
            getstatic org.apache.cassandra.db.lifecycle.SSTableIntervalTree.EMPTY:Lorg/apache/cassandra/db/lifecycle/SSTableIntervalTree;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public static org.apache.cassandra.db.lifecycle.SSTableIntervalTree build(java.lang.Iterable<org.apache.cassandra.io.sstable.format.SSTableReader>);
    descriptor: (Ljava/lang/Iterable;)Lorg/apache/cassandra/db/lifecycle/SSTableIntervalTree;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // java.lang.Iterable sstables
         0: .line 50
            new org.apache.cassandra.db.lifecycle.SSTableIntervalTree
            dup
            aload 0 /* sstables */
            invokestatic org.apache.cassandra.db.lifecycle.SSTableIntervalTree.buildIntervals:(Ljava/lang/Iterable;)Ljava/util/List;
            invokespecial org.apache.cassandra.db.lifecycle.SSTableIntervalTree.<init>:(Ljava/util/Collection;)V
            areturn
        end local 0 // java.lang.Iterable sstables
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    1     0  sstables  Ljava/lang/Iterable<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;
    Signature: (Ljava/lang/Iterable<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;)Lorg/apache/cassandra/db/lifecycle/SSTableIntervalTree;
    MethodParameters:
          Name  Flags
      sstables  

  public static java.util.List<org.apache.cassandra.utils.Interval<org.apache.cassandra.db.PartitionPosition, org.apache.cassandra.io.sstable.format.SSTableReader>> buildIntervals(java.lang.Iterable<org.apache.cassandra.io.sstable.format.SSTableReader>);
    descriptor: (Ljava/lang/Iterable;)Ljava/util/List;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=4, locals=4, args_size=1
        start local 0 // java.lang.Iterable sstables
         0: .line 55
            new java.util.ArrayList
            dup
            aload 0 /* sstables */
            invokestatic com.google.common.collect.Iterables.size:(Ljava/lang/Iterable;)I
            invokespecial java.util.ArrayList.<init>:(I)V
            astore 1 /* intervals */
        start local 1 // java.util.List intervals
         1: .line 56
            aload 0 /* sstables */
            invokeinterface java.lang.Iterable.iterator:()Ljava/util/Iterator;
            astore 3
            goto 4
      StackMap locals: java.lang.Iterable java.util.List top java.util.Iterator
      StackMap stack:
         2: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.io.sstable.format.SSTableReader
            astore 2 /* sstable */
        start local 2 // org.apache.cassandra.io.sstable.format.SSTableReader sstable
         3: .line 57
            aload 1 /* intervals */
            aload 2 /* sstable */
            getfield org.apache.cassandra.io.sstable.format.SSTableReader.first:Lorg/apache/cassandra/db/DecoratedKey;
            aload 2 /* sstable */
            getfield org.apache.cassandra.io.sstable.format.SSTableReader.last:Lorg/apache/cassandra/db/DecoratedKey;
            aload 2 /* sstable */
            invokestatic org.apache.cassandra.utils.Interval.create:(Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)Lorg/apache/cassandra/utils/Interval;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 2 // org.apache.cassandra.io.sstable.format.SSTableReader sstable
         4: .line 56
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 58
            aload 1 /* intervals */
            areturn
        end local 1 // java.util.List intervals
        end local 0 // java.lang.Iterable sstables
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    6     0   sstables  Ljava/lang/Iterable<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;
            1    6     1  intervals  Ljava/util/List<Lorg/apache/cassandra/utils/Interval<Lorg/apache/cassandra/db/PartitionPosition;Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;>;
            3    4     2    sstable  Lorg/apache/cassandra/io/sstable/format/SSTableReader;
    Signature: (Ljava/lang/Iterable<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;)Ljava/util/List<Lorg/apache/cassandra/utils/Interval<Lorg/apache/cassandra/db/PartitionPosition;Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;>;
    MethodParameters:
          Name  Flags
      sstables  
}
Signature: Lorg/apache/cassandra/utils/IntervalTree<Lorg/apache/cassandra/db/PartitionPosition;Lorg/apache/cassandra/io/sstable/format/SSTableReader;Lorg/apache/cassandra/utils/Interval<Lorg/apache/cassandra/db/PartitionPosition;Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;>;
SourceFile: "SSTableIntervalTree.java"