public class org.apache.cassandra.db.lifecycle.View
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.apache.cassandra.db.lifecycle.View
  super_class: java.lang.Object
{
  public final java.util.List<org.apache.cassandra.db.Memtable> liveMemtables;
    descriptor: Ljava/util/List;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Signature: Ljava/util/List<Lorg/apache/cassandra/db/Memtable;>;

  public final java.util.List<org.apache.cassandra.db.Memtable> flushingMemtables;
    descriptor: Ljava/util/List;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Signature: Ljava/util/List<Lorg/apache/cassandra/db/Memtable;>;

  final java.util.Set<org.apache.cassandra.io.sstable.format.SSTableReader> compacting;
    descriptor: Ljava/util/Set;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/Set<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;

  final java.util.Set<org.apache.cassandra.io.sstable.format.SSTableReader> sstables;
    descriptor: Ljava/util/Set;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/Set<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;

  final java.util.Map<org.apache.cassandra.io.sstable.format.SSTableReader, org.apache.cassandra.io.sstable.format.SSTableReader> sstablesMap;
    descriptor: Ljava/util/Map;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/Map<Lorg/apache/cassandra/io/sstable/format/SSTableReader;Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;

  final java.util.Map<org.apache.cassandra.io.sstable.format.SSTableReader, org.apache.cassandra.io.sstable.format.SSTableReader> compactingMap;
    descriptor: Ljava/util/Map;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/Map<Lorg/apache/cassandra/io/sstable/format/SSTableReader;Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;

  final org.apache.cassandra.db.lifecycle.SSTableIntervalTree intervalTree;
    descriptor: Lorg/apache/cassandra/db/lifecycle/SSTableIntervalTree;
    flags: (0x0010) ACC_FINAL

  static final boolean $assertionsDisabled;
    descriptor: Z
    flags: (0x1018) ACC_STATIC, ACC_FINAL, ACC_SYNTHETIC

  private static volatile int[] $SWITCH_TABLE$org$apache$cassandra$db$lifecycle$SSTableSet;
    descriptor: [I
    flags: (0x104a) ACC_PRIVATE, ACC_STATIC, ACC_VOLATILE, ACC_SYNTHETIC

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 56
            ldc Lorg/apache/cassandra/db/lifecycle/View;
            invokevirtual java.lang.Class.desiredAssertionStatus:()Z
            ifne 1
            iconst_1
            goto 2
      StackMap locals:
      StackMap stack:
         1: iconst_0
      StackMap locals:
      StackMap stack: int
         2: putstatic org.apache.cassandra.db.lifecycle.View.$assertionsDisabled:Z
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>(java.util.List<org.apache.cassandra.db.Memtable>, java.util.List<org.apache.cassandra.db.Memtable>, java.util.Map<org.apache.cassandra.io.sstable.format.SSTableReader, org.apache.cassandra.io.sstable.format.SSTableReader>, java.util.Map<org.apache.cassandra.io.sstable.format.SSTableReader, org.apache.cassandra.io.sstable.format.SSTableReader>, org.apache.cassandra.db.lifecycle.SSTableIntervalTree);
    descriptor: (Ljava/util/List;Ljava/util/List;Ljava/util/Map;Ljava/util/Map;Lorg/apache/cassandra/db/lifecycle/SSTableIntervalTree;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=6, args_size=6
        start local 0 // org.apache.cassandra.db.lifecycle.View this
        start local 1 // java.util.List liveMemtables
        start local 2 // java.util.List flushingMemtables
        start local 3 // java.util.Map sstables
        start local 4 // java.util.Map compacting
        start local 5 // org.apache.cassandra.db.lifecycle.SSTableIntervalTree intervalTree
         0: .line 80
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 82
            getstatic org.apache.cassandra.db.lifecycle.View.$assertionsDisabled:Z
            ifne 2
            aload 1 /* liveMemtables */
            ifnonnull 2
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         2: .line 83
      StackMap locals: org.apache.cassandra.db.lifecycle.View java.util.List java.util.List java.util.Map java.util.Map org.apache.cassandra.db.lifecycle.SSTableIntervalTree
      StackMap stack:
            getstatic org.apache.cassandra.db.lifecycle.View.$assertionsDisabled:Z
            ifne 3
            aload 2 /* flushingMemtables */
            ifnonnull 3
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         3: .line 84
      StackMap locals:
      StackMap stack:
            getstatic org.apache.cassandra.db.lifecycle.View.$assertionsDisabled:Z
            ifne 4
            aload 3 /* sstables */
            ifnonnull 4
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         4: .line 85
      StackMap locals:
      StackMap stack:
            getstatic org.apache.cassandra.db.lifecycle.View.$assertionsDisabled:Z
            ifne 5
            aload 4 /* compacting */
            ifnonnull 5
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         5: .line 86
      StackMap locals:
      StackMap stack:
            getstatic org.apache.cassandra.db.lifecycle.View.$assertionsDisabled:Z
            ifne 6
            aload 5 /* intervalTree */
            ifnonnull 6
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         6: .line 88
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* liveMemtables */
            putfield org.apache.cassandra.db.lifecycle.View.liveMemtables:Ljava/util/List;
         7: .line 89
            aload 0 /* this */
            aload 2 /* flushingMemtables */
            putfield org.apache.cassandra.db.lifecycle.View.flushingMemtables:Ljava/util/List;
         8: .line 91
            aload 0 /* this */
            aload 3 /* sstables */
            putfield org.apache.cassandra.db.lifecycle.View.sstablesMap:Ljava/util/Map;
         9: .line 92
            aload 0 /* this */
            aload 0 /* this */
            getfield org.apache.cassandra.db.lifecycle.View.sstablesMap:Ljava/util/Map;
            invokeinterface java.util.Map.keySet:()Ljava/util/Set;
            putfield org.apache.cassandra.db.lifecycle.View.sstables:Ljava/util/Set;
        10: .line 93
            aload 0 /* this */
            aload 4 /* compacting */
            putfield org.apache.cassandra.db.lifecycle.View.compactingMap:Ljava/util/Map;
        11: .line 94
            aload 0 /* this */
            aload 0 /* this */
            getfield org.apache.cassandra.db.lifecycle.View.compactingMap:Ljava/util/Map;
            invokeinterface java.util.Map.keySet:()Ljava/util/Set;
            putfield org.apache.cassandra.db.lifecycle.View.compacting:Ljava/util/Set;
        12: .line 95
            aload 0 /* this */
            aload 5 /* intervalTree */
            putfield org.apache.cassandra.db.lifecycle.View.intervalTree:Lorg/apache/cassandra/db/lifecycle/SSTableIntervalTree;
        13: .line 96
            return
        end local 5 // org.apache.cassandra.db.lifecycle.SSTableIntervalTree intervalTree
        end local 4 // java.util.Map compacting
        end local 3 // java.util.Map sstables
        end local 2 // java.util.List flushingMemtables
        end local 1 // java.util.List liveMemtables
        end local 0 // org.apache.cassandra.db.lifecycle.View this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0   14     0               this  Lorg/apache/cassandra/db/lifecycle/View;
            0   14     1      liveMemtables  Ljava/util/List<Lorg/apache/cassandra/db/Memtable;>;
            0   14     2  flushingMemtables  Ljava/util/List<Lorg/apache/cassandra/db/Memtable;>;
            0   14     3           sstables  Ljava/util/Map<Lorg/apache/cassandra/io/sstable/format/SSTableReader;Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;
            0   14     4         compacting  Ljava/util/Map<Lorg/apache/cassandra/io/sstable/format/SSTableReader;Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;
            0   14     5       intervalTree  Lorg/apache/cassandra/db/lifecycle/SSTableIntervalTree;
    Signature: (Ljava/util/List<Lorg/apache/cassandra/db/Memtable;>;Ljava/util/List<Lorg/apache/cassandra/db/Memtable;>;Ljava/util/Map<Lorg/apache/cassandra/io/sstable/format/SSTableReader;Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;Ljava/util/Map<Lorg/apache/cassandra/io/sstable/format/SSTableReader;Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;Lorg/apache/cassandra/db/lifecycle/SSTableIntervalTree;)V
    MethodParameters:
                   Name  Flags
      liveMemtables      
      flushingMemtables  
      sstables           
      compacting         
      intervalTree       

  public org.apache.cassandra.db.Memtable getCurrentMemtable();
    descriptor: ()Lorg/apache/cassandra/db/Memtable;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.apache.cassandra.db.lifecycle.View this
         0: .line 100
            aload 0 /* this */
            getfield org.apache.cassandra.db.lifecycle.View.liveMemtables:Ljava/util/List;
            aload 0 /* this */
            getfield org.apache.cassandra.db.lifecycle.View.liveMemtables:Ljava/util/List;
            invokeinterface java.util.List.size:()I
            iconst_1
            isub
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast org.apache.cassandra.db.Memtable
            areturn
        end local 0 // org.apache.cassandra.db.lifecycle.View this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/db/lifecycle/View;

  public java.lang.Iterable<org.apache.cassandra.db.Memtable> getAllMemtables();
    descriptor: ()Ljava/lang/Iterable;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.cassandra.db.lifecycle.View this
         0: .line 108
            aload 0 /* this */
            getfield org.apache.cassandra.db.lifecycle.View.flushingMemtables:Ljava/util/List;
            aload 0 /* this */
            getfield org.apache.cassandra.db.lifecycle.View.liveMemtables:Ljava/util/List;
            invokestatic com.google.common.collect.Iterables.concat:(Ljava/lang/Iterable;Ljava/lang/Iterable;)Ljava/lang/Iterable;
            areturn
        end local 0 // org.apache.cassandra.db.lifecycle.View this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/db/lifecycle/View;
    Signature: ()Ljava/lang/Iterable<Lorg/apache/cassandra/db/Memtable;>;

  public java.util.Set<org.apache.cassandra.io.sstable.format.SSTableReader> liveSSTables();
    descriptor: ()Ljava/util/Set;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.db.lifecycle.View this
         0: .line 114
            aload 0 /* this */
            getfield org.apache.cassandra.db.lifecycle.View.sstables:Ljava/util/Set;
            areturn
        end local 0 // org.apache.cassandra.db.lifecycle.View this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/db/lifecycle/View;
    Signature: ()Ljava/util/Set<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;

  public java.lang.Iterable<org.apache.cassandra.io.sstable.format.SSTableReader> sstables(org.apache.cassandra.db.lifecycle.SSTableSet, com.google.common.base.Predicate<org.apache.cassandra.io.sstable.format.SSTableReader>);
    descriptor: (Lorg/apache/cassandra/db/lifecycle/SSTableSet;Lcom/google/common/base/Predicate;)Ljava/lang/Iterable;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // org.apache.cassandra.db.lifecycle.View this
        start local 1 // org.apache.cassandra.db.lifecycle.SSTableSet sstableSet
        start local 2 // com.google.common.base.Predicate filter
         0: .line 119
            aload 0 /* this */
            aload 1 /* sstableSet */
            invokevirtual org.apache.cassandra.db.lifecycle.View.select:(Lorg/apache/cassandra/db/lifecycle/SSTableSet;)Ljava/lang/Iterable;
            aload 2 /* filter */
            invokestatic com.google.common.collect.Iterables.filter:(Ljava/lang/Iterable;Lcom/google/common/base/Predicate;)Ljava/lang/Iterable;
            areturn
        end local 2 // com.google.common.base.Predicate filter
        end local 1 // org.apache.cassandra.db.lifecycle.SSTableSet sstableSet
        end local 0 // org.apache.cassandra.db.lifecycle.View this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    1     0        this  Lorg/apache/cassandra/db/lifecycle/View;
            0    1     1  sstableSet  Lorg/apache/cassandra/db/lifecycle/SSTableSet;
            0    1     2      filter  Lcom/google/common/base/Predicate<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;
    Signature: (Lorg/apache/cassandra/db/lifecycle/SSTableSet;Lcom/google/common/base/Predicate<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;)Ljava/lang/Iterable<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;
    MethodParameters:
            Name  Flags
      sstableSet  
      filter      

  public java.lang.Iterable<org.apache.cassandra.io.sstable.format.SSTableReader> allKnownSSTables();
    descriptor: ()Ljava/lang/Iterable;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=1, args_size=1
        start local 0 // org.apache.cassandra.db.lifecycle.View this
         0: .line 127
            aload 0 /* this */
            getfield org.apache.cassandra.db.lifecycle.View.sstables:Ljava/util/Set;
            aload 0 /* this */
            getfield org.apache.cassandra.db.lifecycle.View.compacting:Ljava/util/Set;
            iconst_1
            anewarray java.util.Set
            dup
            iconst_0
            aload 0 /* this */
            getfield org.apache.cassandra.db.lifecycle.View.sstables:Ljava/util/Set;
            aastore
            invokestatic org.apache.cassandra.db.lifecycle.Helpers.filterOut:(Ljava/lang/Iterable;[Ljava/util/Set;)Ljava/lang/Iterable;
            invokestatic com.google.common.collect.Iterables.concat:(Ljava/lang/Iterable;Ljava/lang/Iterable;)Ljava/lang/Iterable;
            areturn
        end local 0 // org.apache.cassandra.db.lifecycle.View this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/db/lifecycle/View;
    Signature: ()Ljava/lang/Iterable<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;
    RuntimeInvisibleAnnotations: 
      com.google.common.annotations.VisibleForTesting()
    RuntimeInvisibleTypeAnnotations: 
      METHOD_RETURN
        com.google.common.annotations.VisibleForTesting()

  public java.lang.Iterable<org.apache.cassandra.io.sstable.format.SSTableReader> select(org.apache.cassandra.db.lifecycle.SSTableSet);
    descriptor: (Lorg/apache/cassandra/db/lifecycle/SSTableSet;)Ljava/lang/Iterable;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=5, args_size=2
        start local 0 // org.apache.cassandra.db.lifecycle.View this
        start local 1 // org.apache.cassandra.db.lifecycle.SSTableSet sstableSet
         0: .line 132
            invokestatic org.apache.cassandra.db.lifecycle.View.$SWITCH_TABLE$org$apache$cassandra$db$lifecycle$SSTableSet:()[I
            aload 1 /* sstableSet */
            invokevirtual org.apache.cassandra.db.lifecycle.SSTableSet.ordinal:()I
            iaload
            tableswitch { // 1 - 3
                    1: 3
                    2: 1
                    3: 2
              default: 15
          }
         1: .line 135
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.db.lifecycle.View.sstables:Ljava/util/Set;
            areturn
         2: .line 137
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.db.lifecycle.View.sstables:Ljava/util/Set;
            aload 0 /* this */
            invokedynamic apply(Lorg/apache/cassandra/db/lifecycle/View;)Lcom/google/common/base/Predicate;
              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;)Z
                  org/apache/cassandra/db/lifecycle/View.lambda$0(Lorg/apache/cassandra/io/sstable/format/SSTableReader;)Z (7)
                  (Lorg/apache/cassandra/io/sstable/format/SSTableReader;)Z
            invokestatic com.google.common.collect.Iterables.filter:(Ljava/lang/Iterable;Lcom/google/common/base/Predicate;)Ljava/lang/Iterable;
            areturn
         3: .line 139
      StackMap locals:
      StackMap stack:
            new java.util.HashSet
            dup
            invokespecial java.util.HashSet.<init>:()V
            astore 2 /* canonicalSSTables */
        start local 2 // java.util.Set canonicalSSTables
         4: .line 140
            aload 0 /* this */
            getfield org.apache.cassandra.db.lifecycle.View.compacting:Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 4
            goto 8
      StackMap locals: org.apache.cassandra.db.lifecycle.View org.apache.cassandra.db.lifecycle.SSTableSet java.util.Set top java.util.Iterator
      StackMap stack:
         5: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.io.sstable.format.SSTableReader
            astore 3 /* sstable */
        start local 3 // org.apache.cassandra.io.sstable.format.SSTableReader sstable
         6: .line 141
            aload 3 /* sstable */
            getfield org.apache.cassandra.io.sstable.format.SSTableReader.openReason:Lorg/apache/cassandra/io/sstable/format/SSTableReader$OpenReason;
            getstatic org.apache.cassandra.io.sstable.format.SSTableReader$OpenReason.EARLY:Lorg/apache/cassandra/io/sstable/format/SSTableReader$OpenReason;
            if_acmpeq 8
         7: .line 142
            aload 2 /* canonicalSSTables */
            aload 3 /* sstable */
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
        end local 3 // org.apache.cassandra.io.sstable.format.SSTableReader sstable
         8: .line 140
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 5
         9: .line 146
            aload 0 /* this */
            getfield org.apache.cassandra.db.lifecycle.View.sstables:Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 4
            goto 13
      StackMap locals:
      StackMap stack:
        10: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.io.sstable.format.SSTableReader
            astore 3 /* sstable */
        start local 3 // org.apache.cassandra.io.sstable.format.SSTableReader sstable
        11: .line 147
            aload 0 /* this */
            getfield org.apache.cassandra.db.lifecycle.View.compacting:Ljava/util/Set;
            aload 3 /* sstable */
            invokeinterface java.util.Set.contains:(Ljava/lang/Object;)Z
            ifne 13
            aload 3 /* sstable */
            getfield org.apache.cassandra.io.sstable.format.SSTableReader.openReason:Lorg/apache/cassandra/io/sstable/format/SSTableReader$OpenReason;
            getstatic org.apache.cassandra.io.sstable.format.SSTableReader$OpenReason.EARLY:Lorg/apache/cassandra/io/sstable/format/SSTableReader$OpenReason;
            if_acmpeq 13
        12: .line 148
            aload 2 /* canonicalSSTables */
            aload 3 /* sstable */
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
        end local 3 // org.apache.cassandra.io.sstable.format.SSTableReader sstable
        13: .line 146
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 10
        14: .line 150
            aload 2 /* canonicalSSTables */
            areturn
        end local 2 // java.util.Set canonicalSSTables
        15: .line 152
      StackMap locals: org.apache.cassandra.db.lifecycle.View org.apache.cassandra.db.lifecycle.SSTableSet
      StackMap stack:
            new java.lang.IllegalStateException
            dup
            invokespecial java.lang.IllegalStateException.<init>:()V
            athrow
        end local 1 // org.apache.cassandra.db.lifecycle.SSTableSet sstableSet
        end local 0 // org.apache.cassandra.db.lifecycle.View this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0   16     0               this  Lorg/apache/cassandra/db/lifecycle/View;
            0   16     1         sstableSet  Lorg/apache/cassandra/db/lifecycle/SSTableSet;
            4   15     2  canonicalSSTables  Ljava/util/Set<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;
            6    8     3            sstable  Lorg/apache/cassandra/io/sstable/format/SSTableReader;
           11   13     3            sstable  Lorg/apache/cassandra/io/sstable/format/SSTableReader;
    Signature: (Lorg/apache/cassandra/db/lifecycle/SSTableSet;)Ljava/lang/Iterable<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;
    MethodParameters:
            Name  Flags
      sstableSet  

  public java.lang.Iterable<org.apache.cassandra.io.sstable.format.SSTableReader> getUncompacting(java.lang.Iterable<org.apache.cassandra.io.sstable.format.SSTableReader>);
    descriptor: (Ljava/lang/Iterable;)Ljava/lang/Iterable;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.apache.cassandra.db.lifecycle.View this
        start local 1 // java.lang.Iterable candidates
         0: .line 158
            aload 1 /* candidates */
            new org.apache.cassandra.db.lifecycle.View$1
            dup
            aload 0 /* this */
            invokespecial org.apache.cassandra.db.lifecycle.View$1.<init>:(Lorg/apache/cassandra/db/lifecycle/View;)V
            invokestatic com.google.common.collect.Iterables.filter:(Ljava/lang/Iterable;Lcom/google/common/base/Predicate;)Ljava/lang/Iterable;
            areturn
        end local 1 // java.lang.Iterable candidates
        end local 0 // org.apache.cassandra.db.lifecycle.View this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    1     0        this  Lorg/apache/cassandra/db/lifecycle/View;
            0    1     1  candidates  Ljava/lang/Iterable<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;
    Signature: (Ljava/lang/Iterable<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;)Ljava/lang/Iterable<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;
    MethodParameters:
            Name  Flags
      candidates  

  public boolean isEmpty();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // org.apache.cassandra.db.lifecycle.View this
         0: .line 169
            aload 0 /* this */
            getfield org.apache.cassandra.db.lifecycle.View.sstables:Ljava/util/Set;
            invokeinterface java.util.Set.isEmpty:()Z
            ifeq 5
         1: .line 170
            aload 0 /* this */
            getfield org.apache.cassandra.db.lifecycle.View.liveMemtables:Ljava/util/List;
            invokeinterface java.util.List.size:()I
            iconst_1
            if_icmpgt 5
         2: .line 171
            aload 0 /* this */
            getfield org.apache.cassandra.db.lifecycle.View.flushingMemtables:Ljava/util/List;
            invokeinterface java.util.List.size:()I
            ifne 5
         3: .line 172
            aload 0 /* this */
            getfield org.apache.cassandra.db.lifecycle.View.liveMemtables:Ljava/util/List;
            invokeinterface java.util.List.size:()I
            ifeq 4
            aload 0 /* this */
            getfield org.apache.cassandra.db.lifecycle.View.liveMemtables:Ljava/util/List;
            iconst_0
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast org.apache.cassandra.db.Memtable
            invokevirtual org.apache.cassandra.db.Memtable.getOperations:()J
            lconst_0
            lcmp
            ifne 5
         4: .line 169
      StackMap locals:
      StackMap stack:
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         5: iconst_0
            ireturn
        end local 0 // org.apache.cassandra.db.lifecycle.View this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lorg/apache/cassandra/db/lifecycle/View;

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=1, args_size=1
        start local 0 // org.apache.cassandra.db.lifecycle.View this
         0: .line 178
            ldc "View(pending_count=%d, sstables=%s, compacting=%s)"
            iconst_3
            anewarray java.lang.Object
            dup
            iconst_0
            aload 0 /* this */
            getfield org.apache.cassandra.db.lifecycle.View.liveMemtables:Ljava/util/List;
            invokeinterface java.util.List.size:()I
            aload 0 /* this */
            getfield org.apache.cassandra.db.lifecycle.View.flushingMemtables:Ljava/util/List;
            invokeinterface java.util.List.size:()I
            iadd
            iconst_1
            isub
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aastore
            dup
            iconst_1
            aload 0 /* this */
            getfield org.apache.cassandra.db.lifecycle.View.sstables:Ljava/util/Set;
            aastore
            dup
            iconst_2
            aload 0 /* this */
            getfield org.apache.cassandra.db.lifecycle.View.compacting:Ljava/util/Set;
            aastore
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            areturn
        end local 0 // org.apache.cassandra.db.lifecycle.View this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/db/lifecycle/View;

  public java.lang.Iterable<org.apache.cassandra.io.sstable.format.SSTableReader> liveSSTablesInBounds(org.apache.cassandra.db.PartitionPosition, org.apache.cassandra.db.PartitionPosition);
    descriptor: (Lorg/apache/cassandra/db/PartitionPosition;Lorg/apache/cassandra/db/PartitionPosition;)Ljava/lang/Iterable;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=3
        start local 0 // org.apache.cassandra.db.lifecycle.View this
        start local 1 // org.apache.cassandra.db.PartitionPosition left
        start local 2 // org.apache.cassandra.db.PartitionPosition right
         0: .line 187
            getstatic org.apache.cassandra.db.lifecycle.View.$assertionsDisabled:Z
            ifne 1
            aload 1 /* left */
            aload 2 /* right */
            invokestatic org.apache.cassandra.dht.AbstractBounds.strictlyWrapsAround:(Lorg/apache/cassandra/dht/RingPosition;Lorg/apache/cassandra/dht/RingPosition;)Z
            ifeq 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 189
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.db.lifecycle.View.intervalTree:Lorg/apache/cassandra/db/lifecycle/SSTableIntervalTree;
            invokevirtual org.apache.cassandra.db.lifecycle.SSTableIntervalTree.isEmpty:()Z
            ifeq 3
         2: .line 190
            invokestatic java.util.Collections.emptyList:()Ljava/util/List;
            areturn
         3: .line 192
      StackMap locals:
      StackMap stack:
            aload 2 /* right */
            invokeinterface org.apache.cassandra.db.PartitionPosition.isMinimum:()Z
            ifeq 4
            aload 0 /* this */
            getfield org.apache.cassandra.db.lifecycle.View.intervalTree:Lorg/apache/cassandra/db/lifecycle/SSTableIntervalTree;
            invokevirtual org.apache.cassandra.db.lifecycle.SSTableIntervalTree.max:()Ljava/lang/Comparable;
            checkcast org.apache.cassandra.db.PartitionPosition
            goto 5
      StackMap locals:
      StackMap stack:
         4: aload 2 /* right */
      StackMap locals:
      StackMap stack: org.apache.cassandra.db.PartitionPosition
         5: astore 3 /* stopInTree */
        start local 3 // org.apache.cassandra.db.PartitionPosition stopInTree
         6: .line 193
            aload 0 /* this */
            getfield org.apache.cassandra.db.lifecycle.View.intervalTree:Lorg/apache/cassandra/db/lifecycle/SSTableIntervalTree;
            aload 1 /* left */
            aload 3 /* stopInTree */
            invokestatic org.apache.cassandra.utils.Interval.create:(Ljava/lang/Object;Ljava/lang/Object;)Lorg/apache/cassandra/utils/Interval;
            invokevirtual org.apache.cassandra.db.lifecycle.SSTableIntervalTree.search:(Lorg/apache/cassandra/utils/Interval;)Ljava/util/List;
            areturn
        end local 3 // org.apache.cassandra.db.PartitionPosition stopInTree
        end local 2 // org.apache.cassandra.db.PartitionPosition right
        end local 1 // org.apache.cassandra.db.PartitionPosition left
        end local 0 // org.apache.cassandra.db.lifecycle.View this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    7     0        this  Lorg/apache/cassandra/db/lifecycle/View;
            0    7     1        left  Lorg/apache/cassandra/db/PartitionPosition;
            0    7     2       right  Lorg/apache/cassandra/db/PartitionPosition;
            6    7     3  stopInTree  Lorg/apache/cassandra/db/PartitionPosition;
    Signature: (Lorg/apache/cassandra/db/PartitionPosition;Lorg/apache/cassandra/db/PartitionPosition;)Ljava/lang/Iterable<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;
    MethodParameters:
       Name  Flags
      left   
      right  

  public static java.util.List<org.apache.cassandra.io.sstable.format.SSTableReader> sstablesInBounds(org.apache.cassandra.db.PartitionPosition, org.apache.cassandra.db.PartitionPosition, org.apache.cassandra.db.lifecycle.SSTableIntervalTree);
    descriptor: (Lorg/apache/cassandra/db/PartitionPosition;Lorg/apache/cassandra/db/PartitionPosition;Lorg/apache/cassandra/db/lifecycle/SSTableIntervalTree;)Ljava/util/List;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=3, locals=4, args_size=3
        start local 0 // org.apache.cassandra.db.PartitionPosition left
        start local 1 // org.apache.cassandra.db.PartitionPosition right
        start local 2 // org.apache.cassandra.db.lifecycle.SSTableIntervalTree intervalTree
         0: .line 198
            getstatic org.apache.cassandra.db.lifecycle.View.$assertionsDisabled:Z
            ifne 1
            aload 0 /* left */
            aload 1 /* right */
            invokestatic org.apache.cassandra.dht.AbstractBounds.strictlyWrapsAround:(Lorg/apache/cassandra/dht/RingPosition;Lorg/apache/cassandra/dht/RingPosition;)Z
            ifeq 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 200
      StackMap locals:
      StackMap stack:
            aload 2 /* intervalTree */
            invokevirtual org.apache.cassandra.db.lifecycle.SSTableIntervalTree.isEmpty:()Z
            ifeq 3
         2: .line 201
            invokestatic java.util.Collections.emptyList:()Ljava/util/List;
            areturn
         3: .line 203
      StackMap locals:
      StackMap stack:
            aload 1 /* right */
            invokeinterface org.apache.cassandra.db.PartitionPosition.isMinimum:()Z
            ifeq 4
            aload 2 /* intervalTree */
            invokevirtual org.apache.cassandra.db.lifecycle.SSTableIntervalTree.max:()Ljava/lang/Comparable;
            checkcast org.apache.cassandra.db.PartitionPosition
            goto 5
      StackMap locals:
      StackMap stack:
         4: aload 1 /* right */
      StackMap locals:
      StackMap stack: org.apache.cassandra.db.PartitionPosition
         5: astore 3 /* stopInTree */
        start local 3 // org.apache.cassandra.db.PartitionPosition stopInTree
         6: .line 204
            aload 2 /* intervalTree */
            aload 0 /* left */
            aload 3 /* stopInTree */
            invokestatic org.apache.cassandra.utils.Interval.create:(Ljava/lang/Object;Ljava/lang/Object;)Lorg/apache/cassandra/utils/Interval;
            invokevirtual org.apache.cassandra.db.lifecycle.SSTableIntervalTree.search:(Lorg/apache/cassandra/utils/Interval;)Ljava/util/List;
            areturn
        end local 3 // org.apache.cassandra.db.PartitionPosition stopInTree
        end local 2 // org.apache.cassandra.db.lifecycle.SSTableIntervalTree intervalTree
        end local 1 // org.apache.cassandra.db.PartitionPosition right
        end local 0 // org.apache.cassandra.db.PartitionPosition left
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    7     0          left  Lorg/apache/cassandra/db/PartitionPosition;
            0    7     1         right  Lorg/apache/cassandra/db/PartitionPosition;
            0    7     2  intervalTree  Lorg/apache/cassandra/db/lifecycle/SSTableIntervalTree;
            6    7     3    stopInTree  Lorg/apache/cassandra/db/PartitionPosition;
    Signature: (Lorg/apache/cassandra/db/PartitionPosition;Lorg/apache/cassandra/db/PartitionPosition;Lorg/apache/cassandra/db/lifecycle/SSTableIntervalTree;)Ljava/util/List<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;
    MethodParameters:
              Name  Flags
      left          
      right         
      intervalTree  

  public static com.google.common.base.Function<org.apache.cassandra.db.lifecycle.View, java.lang.Iterable<org.apache.cassandra.io.sstable.format.SSTableReader>> selectFunction(org.apache.cassandra.db.lifecycle.SSTableSet);
    descriptor: (Lorg/apache/cassandra/db/lifecycle/SSTableSet;)Lcom/google/common/base/Function;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.db.lifecycle.SSTableSet sstableSet
         0: .line 209
            aload 0 /* sstableSet */
            invokedynamic apply(Lorg/apache/cassandra/db/lifecycle/SSTableSet;)Lcom/google/common/base/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/db/lifecycle/View.lambda$1(Lorg/apache/cassandra/db/lifecycle/SSTableSet;Lorg/apache/cassandra/db/lifecycle/View;)Ljava/lang/Iterable; (6)
                  (Lorg/apache/cassandra/db/lifecycle/View;)Ljava/lang/Iterable;
            areturn
        end local 0 // org.apache.cassandra.db.lifecycle.SSTableSet sstableSet
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    1     0  sstableSet  Lorg/apache/cassandra/db/lifecycle/SSTableSet;
    Signature: (Lorg/apache/cassandra/db/lifecycle/SSTableSet;)Lcom/google/common/base/Function<Lorg/apache/cassandra/db/lifecycle/View;Ljava/lang/Iterable<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;>;
    MethodParameters:
            Name  Flags
      sstableSet  

  public static com.google.common.base.Function<org.apache.cassandra.db.lifecycle.View, java.lang.Iterable<org.apache.cassandra.io.sstable.format.SSTableReader>> select(org.apache.cassandra.db.lifecycle.SSTableSet, com.google.common.base.Predicate<org.apache.cassandra.io.sstable.format.SSTableReader>);
    descriptor: (Lorg/apache/cassandra/db/lifecycle/SSTableSet;Lcom/google/common/base/Predicate;)Lcom/google/common/base/Function;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.db.lifecycle.SSTableSet sstableSet
        start local 1 // com.google.common.base.Predicate filter
         0: .line 214
            aload 0 /* sstableSet */
            aload 1 /* filter */
            invokedynamic apply(Lorg/apache/cassandra/db/lifecycle/SSTableSet;Lcom/google/common/base/Predicate;)Lcom/google/common/base/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/db/lifecycle/View.lambda$2(Lorg/apache/cassandra/db/lifecycle/SSTableSet;Lcom/google/common/base/Predicate;Lorg/apache/cassandra/db/lifecycle/View;)Ljava/lang/Iterable; (6)
                  (Lorg/apache/cassandra/db/lifecycle/View;)Ljava/lang/Iterable;
            areturn
        end local 1 // com.google.common.base.Predicate filter
        end local 0 // org.apache.cassandra.db.lifecycle.SSTableSet sstableSet
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    1     0  sstableSet  Lorg/apache/cassandra/db/lifecycle/SSTableSet;
            0    1     1      filter  Lcom/google/common/base/Predicate<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;
    Signature: (Lorg/apache/cassandra/db/lifecycle/SSTableSet;Lcom/google/common/base/Predicate<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;)Lcom/google/common/base/Function<Lorg/apache/cassandra/db/lifecycle/View;Ljava/lang/Iterable<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;>;
    MethodParameters:
            Name  Flags
      sstableSet  
      filter      

  public static com.google.common.base.Function<org.apache.cassandra.db.lifecycle.View, java.lang.Iterable<org.apache.cassandra.io.sstable.format.SSTableReader>> select(org.apache.cassandra.db.lifecycle.SSTableSet, org.apache.cassandra.db.DecoratedKey);
    descriptor: (Lorg/apache/cassandra/db/lifecycle/SSTableSet;Lorg/apache/cassandra/db/DecoratedKey;)Lcom/google/common/base/Function;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.db.lifecycle.SSTableSet sstableSet
        start local 1 // org.apache.cassandra.db.DecoratedKey key
         0: .line 223
            getstatic org.apache.cassandra.db.lifecycle.View.$assertionsDisabled:Z
            ifne 1
            aload 0 /* sstableSet */
            getstatic org.apache.cassandra.db.lifecycle.SSTableSet.LIVE:Lorg/apache/cassandra/db/lifecycle/SSTableSet;
            if_acmpeq 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 224
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            invokedynamic apply(Lorg/apache/cassandra/db/DecoratedKey;)Lcom/google/common/base/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/db/lifecycle/View.lambda$3(Lorg/apache/cassandra/db/DecoratedKey;Lorg/apache/cassandra/db/lifecycle/View;)Ljava/lang/Iterable; (6)
                  (Lorg/apache/cassandra/db/lifecycle/View;)Ljava/lang/Iterable;
            areturn
        end local 1 // org.apache.cassandra.db.DecoratedKey key
        end local 0 // org.apache.cassandra.db.lifecycle.SSTableSet sstableSet
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    2     0  sstableSet  Lorg/apache/cassandra/db/lifecycle/SSTableSet;
            0    2     1         key  Lorg/apache/cassandra/db/DecoratedKey;
    Signature: (Lorg/apache/cassandra/db/lifecycle/SSTableSet;Lorg/apache/cassandra/db/DecoratedKey;)Lcom/google/common/base/Function<Lorg/apache/cassandra/db/lifecycle/View;Ljava/lang/Iterable<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;>;
    MethodParameters:
            Name  Flags
      sstableSet  
      key         

  public static com.google.common.base.Function<org.apache.cassandra.db.lifecycle.View, java.lang.Iterable<org.apache.cassandra.io.sstable.format.SSTableReader>> selectLive(org.apache.cassandra.dht.AbstractBounds<org.apache.cassandra.db.PartitionPosition>);
    descriptor: (Lorg/apache/cassandra/dht/AbstractBounds;)Lcom/google/common/base/Function;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.dht.AbstractBounds rowBounds
         0: .line 238
            aload 0 /* rowBounds */
            invokedynamic apply(Lorg/apache/cassandra/dht/AbstractBounds;)Lcom/google/common/base/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/db/lifecycle/View.lambda$4(Lorg/apache/cassandra/dht/AbstractBounds;Lorg/apache/cassandra/db/lifecycle/View;)Ljava/lang/Iterable; (6)
                  (Lorg/apache/cassandra/db/lifecycle/View;)Ljava/lang/Iterable;
            areturn
        end local 0 // org.apache.cassandra.dht.AbstractBounds rowBounds
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    1     0  rowBounds  Lorg/apache/cassandra/dht/AbstractBounds<Lorg/apache/cassandra/db/PartitionPosition;>;
    Signature: (Lorg/apache/cassandra/dht/AbstractBounds<Lorg/apache/cassandra/db/PartitionPosition;>;)Lcom/google/common/base/Function<Lorg/apache/cassandra/db/lifecycle/View;Ljava/lang/Iterable<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;>;
    MethodParameters:
           Name  Flags
      rowBounds  

  static com.google.common.base.Function<org.apache.cassandra.db.lifecycle.View, org.apache.cassandra.db.lifecycle.View> updateCompacting(java.util.Set<org.apache.cassandra.io.sstable.format.SSTableReader>, java.lang.Iterable<org.apache.cassandra.io.sstable.format.SSTableReader>);
    descriptor: (Ljava/util/Set;Ljava/lang/Iterable;)Lcom/google/common/base/Function;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // java.util.Set unmark
        start local 1 // java.lang.Iterable mark
         0: .line 246
            aload 0 /* unmark */
            invokeinterface java.util.Set.isEmpty:()Z
            ifeq 2
            aload 1 /* mark */
            invokestatic com.google.common.collect.Iterables.isEmpty:(Ljava/lang/Iterable;)Z
            ifeq 2
         1: .line 247
            invokestatic com.google.common.base.Functions.identity:()Lcom/google/common/base/Function;
            areturn
         2: .line 248
      StackMap locals:
      StackMap stack:
            new org.apache.cassandra.db.lifecycle.View$2
            dup
            aload 1 /* mark */
            aload 0 /* unmark */
            invokespecial org.apache.cassandra.db.lifecycle.View$2.<init>:(Ljava/lang/Iterable;Ljava/util/Set;)V
            areturn
        end local 1 // java.lang.Iterable mark
        end local 0 // java.util.Set unmark
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    3     0  unmark  Ljava/util/Set<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;
            0    3     1    mark  Ljava/lang/Iterable<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;
    Signature: (Ljava/util/Set<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;Ljava/lang/Iterable<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;)Lcom/google/common/base/Function<Lorg/apache/cassandra/db/lifecycle/View;Lorg/apache/cassandra/db/lifecycle/View;>;
    MethodParameters:
        Name  Flags
      unmark  final
      mark    final

  static com.google.common.base.Predicate<org.apache.cassandra.db.lifecycle.View> permitCompacting(java.lang.Iterable<org.apache.cassandra.io.sstable.format.SSTableReader>);
    descriptor: (Ljava/lang/Iterable;)Lcom/google/common/base/Predicate;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // java.lang.Iterable readers
         0: .line 264
            new org.apache.cassandra.db.lifecycle.View$3
            dup
            aload 0 /* readers */
            invokespecial org.apache.cassandra.db.lifecycle.View$3.<init>:(Ljava/lang/Iterable;)V
            areturn
        end local 0 // java.lang.Iterable readers
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    1     0  readers  Ljava/lang/Iterable<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;
    Signature: (Ljava/lang/Iterable<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;)Lcom/google/common/base/Predicate<Lorg/apache/cassandra/db/lifecycle/View;>;
    MethodParameters:
         Name  Flags
      readers  final

  static com.google.common.base.Function<org.apache.cassandra.db.lifecycle.View, org.apache.cassandra.db.lifecycle.View> updateLiveSet(java.util.Set<org.apache.cassandra.io.sstable.format.SSTableReader>, java.lang.Iterable<org.apache.cassandra.io.sstable.format.SSTableReader>);
    descriptor: (Ljava/util/Set;Ljava/lang/Iterable;)Lcom/google/common/base/Function;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // java.util.Set remove
        start local 1 // java.lang.Iterable add
         0: .line 279
            aload 0 /* remove */
            invokeinterface java.util.Set.isEmpty:()Z
            ifeq 2
            aload 1 /* add */
            invokestatic com.google.common.collect.Iterables.isEmpty:(Ljava/lang/Iterable;)Z
            ifeq 2
         1: .line 280
            invokestatic com.google.common.base.Functions.identity:()Lcom/google/common/base/Function;
            areturn
         2: .line 281
      StackMap locals:
      StackMap stack:
            new org.apache.cassandra.db.lifecycle.View$4
            dup
            aload 0 /* remove */
            aload 1 /* add */
            invokespecial org.apache.cassandra.db.lifecycle.View$4.<init>:(Ljava/util/Set;Ljava/lang/Iterable;)V
            areturn
        end local 1 // java.lang.Iterable add
        end local 0 // java.util.Set remove
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    3     0  remove  Ljava/util/Set<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;
            0    3     1     add  Ljava/lang/Iterable<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;
    Signature: (Ljava/util/Set<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;Ljava/lang/Iterable<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;)Lcom/google/common/base/Function<Lorg/apache/cassandra/db/lifecycle/View;Lorg/apache/cassandra/db/lifecycle/View;>;
    MethodParameters:
        Name  Flags
      remove  final
      add     final

  static com.google.common.base.Function<org.apache.cassandra.db.lifecycle.View, org.apache.cassandra.db.lifecycle.View> switchMemtable(org.apache.cassandra.db.Memtable);
    descriptor: (Lorg/apache/cassandra/db/Memtable;)Lcom/google/common/base/Function;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.apache.cassandra.db.Memtable newMemtable
         0: .line 295
            new org.apache.cassandra.db.lifecycle.View$5
            dup
            aload 0 /* newMemtable */
            invokespecial org.apache.cassandra.db.lifecycle.View$5.<init>:(Lorg/apache/cassandra/db/Memtable;)V
            areturn
        end local 0 // org.apache.cassandra.db.Memtable newMemtable
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    1     0  newMemtable  Lorg/apache/cassandra/db/Memtable;
    Signature: (Lorg/apache/cassandra/db/Memtable;)Lcom/google/common/base/Function<Lorg/apache/cassandra/db/lifecycle/View;Lorg/apache/cassandra/db/lifecycle/View;>;
    MethodParameters:
             Name  Flags
      newMemtable  final

  static com.google.common.base.Function<org.apache.cassandra.db.lifecycle.View, org.apache.cassandra.db.lifecycle.View> markFlushing(org.apache.cassandra.db.Memtable);
    descriptor: (Lorg/apache/cassandra/db/Memtable;)Lcom/google/common/base/Function;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.apache.cassandra.db.Memtable toFlush
         0: .line 309
            new org.apache.cassandra.db.lifecycle.View$6
            dup
            aload 0 /* toFlush */
            invokespecial org.apache.cassandra.db.lifecycle.View$6.<init>:(Lorg/apache/cassandra/db/Memtable;)V
            areturn
        end local 0 // org.apache.cassandra.db.Memtable toFlush
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    1     0  toFlush  Lorg/apache/cassandra/db/Memtable;
    Signature: (Lorg/apache/cassandra/db/Memtable;)Lcom/google/common/base/Function<Lorg/apache/cassandra/db/lifecycle/View;Lorg/apache/cassandra/db/lifecycle/View;>;
    MethodParameters:
         Name  Flags
      toFlush  final

  static com.google.common.base.Function<org.apache.cassandra.db.lifecycle.View, org.apache.cassandra.db.lifecycle.View> replaceFlushed(org.apache.cassandra.db.Memtable, java.lang.Iterable<org.apache.cassandra.io.sstable.format.SSTableReader>);
    descriptor: (Lorg/apache/cassandra/db/Memtable;Ljava/lang/Iterable;)Lcom/google/common/base/Function;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.apache.cassandra.db.Memtable memtable
        start local 1 // java.lang.Iterable flushed
         0: .line 328
            new org.apache.cassandra.db.lifecycle.View$7
            dup
            aload 0 /* memtable */
            aload 1 /* flushed */
            invokespecial org.apache.cassandra.db.lifecycle.View$7.<init>:(Lorg/apache/cassandra/db/Memtable;Ljava/lang/Iterable;)V
            areturn
        end local 1 // java.lang.Iterable flushed
        end local 0 // org.apache.cassandra.db.Memtable memtable
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    1     0  memtable  Lorg/apache/cassandra/db/Memtable;
            0    1     1   flushed  Ljava/lang/Iterable<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;
    Signature: (Lorg/apache/cassandra/db/Memtable;Ljava/lang/Iterable<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;)Lcom/google/common/base/Function<Lorg/apache/cassandra/db/lifecycle/View;Lorg/apache/cassandra/db/lifecycle/View;>;
    MethodParameters:
          Name  Flags
      memtable  final
      flushed   final

  private static <T extends java.lang.Comparable<T>> com.google.common.base.Predicate<T> lessThan(T);
    descriptor: (Ljava/lang/Comparable;)Lcom/google/common/base/Predicate;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // java.lang.Comparable lessThan
         0: .line 348
            new org.apache.cassandra.db.lifecycle.View$8
            dup
            aload 0 /* lessThan */
            invokespecial org.apache.cassandra.db.lifecycle.View$8.<init>:(Ljava/lang/Comparable;)V
            areturn
        end local 0 // java.lang.Comparable lessThan
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    1     0  lessThan  TT;
    Signature: <T::Ljava/lang/Comparable<TT;>;>(TT;)Lcom/google/common/base/Predicate<TT;>;
    MethodParameters:
          Name  Flags
      lessThan  final

  static int[] $SWITCH_TABLE$org$apache$cassandra$db$lifecycle$SSTableSet();
    descriptor: ()[I
    flags: (0x1008) ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=3, locals=1, args_size=0
         0: .line 56
            getstatic org.apache.cassandra.db.lifecycle.View.$SWITCH_TABLE$org$apache$cassandra$db$lifecycle$SSTableSet:[I
            dup
            ifnull 1
            areturn
      StackMap locals:
      StackMap stack: int[]
         1: pop
            invokestatic org.apache.cassandra.db.lifecycle.SSTableSet.values:()[Lorg/apache/cassandra/db/lifecycle/SSTableSet;
            arraylength
            newarray 10
            astore 0
         2: aload 0
            getstatic org.apache.cassandra.db.lifecycle.SSTableSet.CANONICAL:Lorg/apache/cassandra/db/lifecycle/SSTableSet;
            invokevirtual org.apache.cassandra.db.lifecycle.SSTableSet.ordinal:()I
            iconst_1
            iastore
         3: goto 5
      StackMap locals: int[]
      StackMap stack: java.lang.NoSuchFieldError
         4: pop
      StackMap locals:
      StackMap stack:
         5: aload 0
            getstatic org.apache.cassandra.db.lifecycle.SSTableSet.LIVE:Lorg/apache/cassandra/db/lifecycle/SSTableSet;
            invokevirtual org.apache.cassandra.db.lifecycle.SSTableSet.ordinal:()I
            iconst_2
            iastore
         6: goto 8
      StackMap locals:
      StackMap stack: java.lang.NoSuchFieldError
         7: pop
      StackMap locals:
      StackMap stack:
         8: aload 0
            getstatic org.apache.cassandra.db.lifecycle.SSTableSet.NONCOMPACTING:Lorg/apache/cassandra/db/lifecycle/SSTableSet;
            invokevirtual org.apache.cassandra.db.lifecycle.SSTableSet.ordinal:()I
            iconst_3
            iastore
         9: goto 11
      StackMap locals:
      StackMap stack: java.lang.NoSuchFieldError
        10: pop
      StackMap locals:
      StackMap stack:
        11: aload 0
            dup
            putstatic org.apache.cassandra.db.lifecycle.View.$SWITCH_TABLE$org$apache$cassandra$db$lifecycle$SSTableSet:[I
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
      Exception table:
        from    to  target  type
           2     3       4  Class java.lang.NoSuchFieldError
           5     6       7  Class java.lang.NoSuchFieldError
           8     9      10  Class java.lang.NoSuchFieldError

  private boolean lambda$0(org.apache.cassandra.io.sstable.format.SSTableReader);
    descriptor: (Lorg/apache/cassandra/io/sstable/format/SSTableReader;)Z
    flags: (0x1002) ACC_PRIVATE, ACC_SYNTHETIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.db.lifecycle.View this
        start local 1 // org.apache.cassandra.io.sstable.format.SSTableReader s
         0: .line 137
            aload 0 /* this */
            getfield org.apache.cassandra.db.lifecycle.View.compacting:Ljava/util/Set;
            aload 1 /* s */
            invokeinterface java.util.Set.contains:(Ljava/lang/Object;)Z
            ifeq 1
            iconst_0
            goto 2
      StackMap locals:
      StackMap stack:
         1: iconst_1
      StackMap locals:
      StackMap stack: int
         2: ireturn
        end local 1 // org.apache.cassandra.io.sstable.format.SSTableReader s
        end local 0 // org.apache.cassandra.db.lifecycle.View this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/apache/cassandra/db/lifecycle/View;
            0    3     1     s  Lorg/apache/cassandra/io/sstable/format/SSTableReader;

  private static java.lang.Iterable lambda$1(org.apache.cassandra.db.lifecycle.SSTableSet, org.apache.cassandra.db.lifecycle.View);
    descriptor: (Lorg/apache/cassandra/db/lifecycle/SSTableSet;Lorg/apache/cassandra/db/lifecycle/View;)Ljava/lang/Iterable;
    flags: (0x100a) ACC_PRIVATE, ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=2, locals=2, args_size=2
        start local 1 // org.apache.cassandra.db.lifecycle.View view
         0: .line 209
            aload 1 /* view */
            aload 0
            invokevirtual org.apache.cassandra.db.lifecycle.View.select:(Lorg/apache/cassandra/db/lifecycle/SSTableSet;)Ljava/lang/Iterable;
            areturn
        end local 1 // org.apache.cassandra.db.lifecycle.View view
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     1  view  Lorg/apache/cassandra/db/lifecycle/View;

  private static java.lang.Iterable lambda$2(org.apache.cassandra.db.lifecycle.SSTableSet, com.google.common.base.Predicate, org.apache.cassandra.db.lifecycle.View);
    descriptor: (Lorg/apache/cassandra/db/lifecycle/SSTableSet;Lcom/google/common/base/Predicate;Lorg/apache/cassandra/db/lifecycle/View;)Ljava/lang/Iterable;
    flags: (0x100a) ACC_PRIVATE, ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=3, locals=3, args_size=3
        start local 2 // org.apache.cassandra.db.lifecycle.View view
         0: .line 214
            aload 2 /* view */
            aload 0
            aload 1
            invokevirtual org.apache.cassandra.db.lifecycle.View.sstables:(Lorg/apache/cassandra/db/lifecycle/SSTableSet;Lcom/google/common/base/Predicate;)Ljava/lang/Iterable;
            areturn
        end local 2 // org.apache.cassandra.db.lifecycle.View view
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     2  view  Lorg/apache/cassandra/db/lifecycle/View;

  private static java.lang.Iterable lambda$3(org.apache.cassandra.db.DecoratedKey, org.apache.cassandra.db.lifecycle.View);
    descriptor: (Lorg/apache/cassandra/db/DecoratedKey;Lorg/apache/cassandra/db/lifecycle/View;)Ljava/lang/Iterable;
    flags: (0x100a) ACC_PRIVATE, ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=2, locals=2, args_size=2
        start local 1 // org.apache.cassandra.db.lifecycle.View view
         0: .line 224
            aload 1 /* view */
            getfield org.apache.cassandra.db.lifecycle.View.intervalTree:Lorg/apache/cassandra/db/lifecycle/SSTableIntervalTree;
            aload 0
            invokevirtual org.apache.cassandra.db.lifecycle.SSTableIntervalTree.search:(Ljava/lang/Comparable;)Ljava/util/List;
            areturn
        end local 1 // org.apache.cassandra.db.lifecycle.View view
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     1  view  Lorg/apache/cassandra/db/lifecycle/View;

  private static java.lang.Iterable lambda$4(org.apache.cassandra.dht.AbstractBounds, org.apache.cassandra.db.lifecycle.View);
    descriptor: (Lorg/apache/cassandra/dht/AbstractBounds;Lorg/apache/cassandra/db/lifecycle/View;)Ljava/lang/Iterable;
    flags: (0x100a) ACC_PRIVATE, ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=3, locals=2, args_size=2
        start local 1 // org.apache.cassandra.db.lifecycle.View view
         0: .line 238
            aload 1 /* view */
            aload 0
            getfield org.apache.cassandra.dht.AbstractBounds.left:Lorg/apache/cassandra/dht/RingPosition;
            checkcast org.apache.cassandra.db.PartitionPosition
            aload 0
            getfield org.apache.cassandra.dht.AbstractBounds.right:Lorg/apache/cassandra/dht/RingPosition;
            checkcast org.apache.cassandra.db.PartitionPosition
            invokevirtual org.apache.cassandra.db.lifecycle.View.liveSSTablesInBounds:(Lorg/apache/cassandra/db/PartitionPosition;Lorg/apache/cassandra/db/PartitionPosition;)Ljava/lang/Iterable;
            areturn
        end local 1 // org.apache.cassandra.db.lifecycle.View view
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     1  view  Lorg/apache/cassandra/db/lifecycle/View;
}
SourceFile: "View.java"
NestMembers:
  org.apache.cassandra.db.lifecycle.View$1  org.apache.cassandra.db.lifecycle.View$2  org.apache.cassandra.db.lifecycle.View$3  org.apache.cassandra.db.lifecycle.View$4  org.apache.cassandra.db.lifecycle.View$5  org.apache.cassandra.db.lifecycle.View$6  org.apache.cassandra.db.lifecycle.View$7  org.apache.cassandra.db.lifecycle.View$8
InnerClasses:
  public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles
  org.apache.cassandra.db.lifecycle.View$1
  org.apache.cassandra.db.lifecycle.View$2
  org.apache.cassandra.db.lifecycle.View$3
  org.apache.cassandra.db.lifecycle.View$4
  org.apache.cassandra.db.lifecycle.View$5
  org.apache.cassandra.db.lifecycle.View$6
  org.apache.cassandra.db.lifecycle.View$7
  org.apache.cassandra.db.lifecycle.View$8
  public final OpenReason = org.apache.cassandra.io.sstable.format.SSTableReader$OpenReason of org.apache.cassandra.io.sstable.format.SSTableReader