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

  private final org.apache.cassandra.utils.BiMultiValMap<org.apache.cassandra.dht.Token, java.net.InetAddress> tokenToEndpointMap;
    descriptor: Lorg/apache/cassandra/utils/BiMultiValMap;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Lorg/apache/cassandra/utils/BiMultiValMap<Lorg/apache/cassandra/dht/Token;Ljava/net/InetAddress;>;

  private final com.google.common.collect.BiMap<java.net.InetAddress, java.util.UUID> endpointToHostIdMap;
    descriptor: Lcom/google/common/collect/BiMap;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Lcom/google/common/collect/BiMap<Ljava/net/InetAddress;Ljava/util/UUID;>;

  private final org.apache.cassandra.utils.BiMultiValMap<org.apache.cassandra.dht.Token, java.net.InetAddress> bootstrapTokens;
    descriptor: Lorg/apache/cassandra/utils/BiMultiValMap;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Lorg/apache/cassandra/utils/BiMultiValMap<Lorg/apache/cassandra/dht/Token;Ljava/net/InetAddress;>;

  private final com.google.common.collect.BiMap<java.net.InetAddress, java.net.InetAddress> replacementToOriginal;
    descriptor: Lcom/google/common/collect/BiMap;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Lcom/google/common/collect/BiMap<Ljava/net/InetAddress;Ljava/net/InetAddress;>;

  private final java.util.Set<java.net.InetAddress> leavingEndpoints;
    descriptor: Ljava/util/Set;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/Set<Ljava/net/InetAddress;>;

  private final java.util.concurrent.ConcurrentMap<java.lang.String, org.apache.cassandra.locator.PendingRangeMaps> pendingRanges;
    descriptor: Ljava/util/concurrent/ConcurrentMap;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/concurrent/ConcurrentMap<Ljava/lang/String;Lorg/apache/cassandra/locator/PendingRangeMaps;>;

  private final java.util.Set<org.apache.cassandra.utils.Pair<org.apache.cassandra.dht.Token, java.net.InetAddress>> movingEndpoints;
    descriptor: Ljava/util/Set;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/Set<Lorg/apache/cassandra/utils/Pair<Lorg/apache/cassandra/dht/Token;Ljava/net/InetAddress;>;>;

  private final java.util.concurrent.locks.ReadWriteLock lock;
    descriptor: Ljava/util/concurrent/locks/ReadWriteLock;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private volatile java.util.ArrayList<org.apache.cassandra.dht.Token> sortedTokens;
    descriptor: Ljava/util/ArrayList;
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE
    Signature: Ljava/util/ArrayList<Lorg/apache/cassandra/dht/Token;>;

  private volatile org.apache.cassandra.locator.TokenMetadata$Topology topology;
    descriptor: Lorg/apache/cassandra/locator/TokenMetadata$Topology;
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  public final org.apache.cassandra.dht.IPartitioner partitioner;
    descriptor: Lorg/apache/cassandra/dht/IPartitioner;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL

  private static final java.util.Comparator<java.net.InetAddress> inetaddressCmp;
    descriptor: Ljava/util/Comparator;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/Comparator<Ljava/net/InetAddress;>;

  private volatile long ringVersion;
    descriptor: J
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  private final java.util.concurrent.atomic.AtomicReference<org.apache.cassandra.locator.TokenMetadata> cachedTokenMap;
    descriptor: Ljava/util/concurrent/atomic/AtomicReference;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/concurrent/atomic/AtomicReference<Lorg/apache/cassandra/locator/TokenMetadata;>;

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

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=0, args_size=0
         0: .line 46
            ldc Lorg/apache/cassandra/locator/TokenMetadata;
            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.locator.TokenMetadata.$assertionsDisabled:Z
         3: .line 48
            ldc Lorg/apache/cassandra/locator/TokenMetadata;
            invokestatic org.slf4j.LoggerFactory.getLogger:(Ljava/lang/Class;)Lorg/slf4j/Logger;
            putstatic org.apache.cassandra.locator.TokenMetadata.logger:Lorg/slf4j/Logger;
         4: .line 104
            new org.apache.cassandra.locator.TokenMetadata$1
            dup
            invokespecial org.apache.cassandra.locator.TokenMetadata$1.<init>:()V
            putstatic org.apache.cassandra.locator.TokenMetadata.inetaddressCmp:Ljava/util/Comparator;
         5: .line 110
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=1, args_size=1
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
         0: .line 117
            aload 0 /* this */
            aconst_null
            getstatic org.apache.cassandra.locator.TokenMetadata.inetaddressCmp:Ljava/util/Comparator;
            invokestatic org.apache.cassandra.utils.SortedBiMultiValMap.create:(Ljava/util/Comparator;Ljava/util/Comparator;)Lorg/apache/cassandra/utils/SortedBiMultiValMap;
         1: .line 118
            invokestatic com.google.common.collect.HashBiMap.create:()Lcom/google/common/collect/HashBiMap;
         2: .line 119
            invokestatic org.apache.cassandra.locator.TokenMetadata$Topology.empty:()Lorg/apache/cassandra/locator/TokenMetadata$Topology;
         3: .line 120
            invokestatic org.apache.cassandra.config.DatabaseDescriptor.getPartitioner:()Lorg/apache/cassandra/dht/IPartitioner;
            invokespecial org.apache.cassandra.locator.TokenMetadata.<init>:(Lorg/apache/cassandra/utils/BiMultiValMap;Lcom/google/common/collect/BiMap;Lorg/apache/cassandra/locator/TokenMetadata$Topology;Lorg/apache/cassandra/dht/IPartitioner;)V
         4: .line 121
            return
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lorg/apache/cassandra/locator/TokenMetadata;

  private void <init>(org.apache.cassandra.utils.BiMultiValMap<org.apache.cassandra.dht.Token, java.net.InetAddress>, com.google.common.collect.BiMap<java.net.InetAddress, java.util.UUID>, org.apache.cassandra.locator.TokenMetadata$Topology, org.apache.cassandra.dht.IPartitioner);
    descriptor: (Lorg/apache/cassandra/utils/BiMultiValMap;Lcom/google/common/collect/BiMap;Lorg/apache/cassandra/locator/TokenMetadata$Topology;Lorg/apache/cassandra/dht/IPartitioner;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=5, args_size=5
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // org.apache.cassandra.utils.BiMultiValMap tokenToEndpointMap
        start local 2 // com.google.common.collect.BiMap endpointsMap
        start local 3 // org.apache.cassandra.locator.TokenMetadata$Topology topology
        start local 4 // org.apache.cassandra.dht.IPartitioner partitioner
         0: .line 123
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 84
            aload 0 /* this */
            new org.apache.cassandra.utils.BiMultiValMap
            dup
            invokespecial org.apache.cassandra.utils.BiMultiValMap.<init>:()V
            putfield org.apache.cassandra.locator.TokenMetadata.bootstrapTokens:Lorg/apache/cassandra/utils/BiMultiValMap;
         2: .line 86
            aload 0 /* this */
            invokestatic com.google.common.collect.HashBiMap.create:()Lcom/google/common/collect/HashBiMap;
            putfield org.apache.cassandra.locator.TokenMetadata.replacementToOriginal:Lcom/google/common/collect/BiMap;
         3: .line 89
            aload 0 /* this */
            new java.util.HashSet
            dup
            invokespecial java.util.HashSet.<init>:()V
            putfield org.apache.cassandra.locator.TokenMetadata.leavingEndpoints:Ljava/util/Set;
         4: .line 91
            aload 0 /* this */
            new java.util.concurrent.ConcurrentHashMap
            dup
            invokespecial java.util.concurrent.ConcurrentHashMap.<init>:()V
            putfield org.apache.cassandra.locator.TokenMetadata.pendingRanges:Ljava/util/concurrent/ConcurrentMap;
         5: .line 94
            aload 0 /* this */
            new java.util.HashSet
            dup
            invokespecial java.util.HashSet.<init>:()V
            putfield org.apache.cassandra.locator.TokenMetadata.movingEndpoints:Ljava/util/Set;
         6: .line 97
            aload 0 /* this */
            new java.util.concurrent.locks.ReentrantReadWriteLock
            dup
            iconst_1
            invokespecial java.util.concurrent.locks.ReentrantReadWriteLock.<init>:(Z)V
            putfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
         7: .line 113
            aload 0 /* this */
            lconst_0
            putfield org.apache.cassandra.locator.TokenMetadata.ringVersion:J
         8: .line 629
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicReference
            dup
            invokespecial java.util.concurrent.atomic.AtomicReference.<init>:()V
            putfield org.apache.cassandra.locator.TokenMetadata.cachedTokenMap:Ljava/util/concurrent/atomic/AtomicReference;
         9: .line 125
            aload 0 /* this */
            aload 1 /* tokenToEndpointMap */
            putfield org.apache.cassandra.locator.TokenMetadata.tokenToEndpointMap:Lorg/apache/cassandra/utils/BiMultiValMap;
        10: .line 126
            aload 0 /* this */
            aload 3 /* topology */
            putfield org.apache.cassandra.locator.TokenMetadata.topology:Lorg/apache/cassandra/locator/TokenMetadata$Topology;
        11: .line 127
            aload 0 /* this */
            aload 4 /* partitioner */
            putfield org.apache.cassandra.locator.TokenMetadata.partitioner:Lorg/apache/cassandra/dht/IPartitioner;
        12: .line 128
            aload 0 /* this */
            aload 2 /* endpointsMap */
            putfield org.apache.cassandra.locator.TokenMetadata.endpointToHostIdMap:Lcom/google/common/collect/BiMap;
        13: .line 129
            aload 0 /* this */
            aload 0 /* this */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.sortTokens:()Ljava/util/ArrayList;
            putfield org.apache.cassandra.locator.TokenMetadata.sortedTokens:Ljava/util/ArrayList;
        14: .line 130
            return
        end local 4 // org.apache.cassandra.dht.IPartitioner partitioner
        end local 3 // org.apache.cassandra.locator.TokenMetadata$Topology topology
        end local 2 // com.google.common.collect.BiMap endpointsMap
        end local 1 // org.apache.cassandra.utils.BiMultiValMap tokenToEndpointMap
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0   15     0                this  Lorg/apache/cassandra/locator/TokenMetadata;
            0   15     1  tokenToEndpointMap  Lorg/apache/cassandra/utils/BiMultiValMap<Lorg/apache/cassandra/dht/Token;Ljava/net/InetAddress;>;
            0   15     2        endpointsMap  Lcom/google/common/collect/BiMap<Ljava/net/InetAddress;Ljava/util/UUID;>;
            0   15     3            topology  Lorg/apache/cassandra/locator/TokenMetadata$Topology;
            0   15     4         partitioner  Lorg/apache/cassandra/dht/IPartitioner;
    Signature: (Lorg/apache/cassandra/utils/BiMultiValMap<Lorg/apache/cassandra/dht/Token;Ljava/net/InetAddress;>;Lcom/google/common/collect/BiMap<Ljava/net/InetAddress;Ljava/util/UUID;>;Lorg/apache/cassandra/locator/TokenMetadata$Topology;Lorg/apache/cassandra/dht/IPartitioner;)V
    MethodParameters:
                    Name  Flags
      tokenToEndpointMap  
      endpointsMap        
      topology            
      partitioner         

  public org.apache.cassandra.locator.TokenMetadata cloneWithNewPartitioner(org.apache.cassandra.dht.IPartitioner);
    descriptor: (Lorg/apache/cassandra/dht/IPartitioner;)Lorg/apache/cassandra/locator/TokenMetadata;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=2, args_size=2
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // org.apache.cassandra.dht.IPartitioner newPartitioner
         0: .line 138
            new org.apache.cassandra.locator.TokenMetadata
            dup
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.tokenToEndpointMap:Lorg/apache/cassandra/utils/BiMultiValMap;
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.endpointToHostIdMap:Lcom/google/common/collect/BiMap;
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.topology:Lorg/apache/cassandra/locator/TokenMetadata$Topology;
            aload 1 /* newPartitioner */
            invokespecial org.apache.cassandra.locator.TokenMetadata.<init>:(Lorg/apache/cassandra/utils/BiMultiValMap;Lcom/google/common/collect/BiMap;Lorg/apache/cassandra/locator/TokenMetadata$Topology;Lorg/apache/cassandra/dht/IPartitioner;)V
            areturn
        end local 1 // org.apache.cassandra.dht.IPartitioner newPartitioner
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    1     0            this  Lorg/apache/cassandra/locator/TokenMetadata;
            0    1     1  newPartitioner  Lorg/apache/cassandra/dht/IPartitioner;
    RuntimeInvisibleAnnotations: 
      com.google.common.annotations.VisibleForTesting()
    RuntimeInvisibleTypeAnnotations: 
      METHOD_RETURN
        com.google.common.annotations.VisibleForTesting()
    MethodParameters:
                Name  Flags
      newPartitioner  

  private java.util.ArrayList<org.apache.cassandra.dht.Token> sortTokens();
    descriptor: ()Ljava/util/ArrayList;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
         0: .line 143
            new java.util.ArrayList
            dup
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.tokenToEndpointMap:Lorg/apache/cassandra/utils/BiMultiValMap;
            invokevirtual org.apache.cassandra.utils.BiMultiValMap.keySet:()Ljava/util/Set;
            invokespecial java.util.ArrayList.<init>:(Ljava/util/Collection;)V
            areturn
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/locator/TokenMetadata;
    Signature: ()Ljava/util/ArrayList<Lorg/apache/cassandra/dht/Token;>;

  public int pendingRangeChanges(java.net.InetAddress);
    descriptor: (Ljava/net/InetAddress;)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=9, args_size=2
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // java.net.InetAddress source
         0: .line 149
            iconst_0
            istore 2 /* n */
        start local 2 // int n
         1: .line 150
            aload 0 /* this */
            aload 0 /* this */
            aload 1 /* source */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.getTokens:(Ljava/net/InetAddress;)Ljava/util/Collection;
            invokevirtual org.apache.cassandra.locator.TokenMetadata.getPrimaryRangesFor:(Ljava/util/Collection;)Ljava/util/Collection;
            astore 3 /* sourceRanges */
        start local 3 // java.util.Collection sourceRanges
         2: .line 151
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         3: .line 154
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.bootstrapTokens:Lorg/apache/cassandra/utils/BiMultiValMap;
            invokevirtual org.apache.cassandra.utils.BiMultiValMap.keySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 5
            goto 10
      StackMap locals: org.apache.cassandra.locator.TokenMetadata java.net.InetAddress int java.util.Collection top java.util.Iterator
      StackMap stack:
         4: aload 5
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Token
            astore 4 /* token */
        start local 4 // org.apache.cassandra.dht.Token token
         5: .line 155
            aload 3 /* sourceRanges */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 7
            goto 9
      StackMap locals: org.apache.cassandra.locator.TokenMetadata java.net.InetAddress int java.util.Collection org.apache.cassandra.dht.Token java.util.Iterator top java.util.Iterator
      StackMap stack:
         6: aload 7
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Range
            astore 6 /* range */
        start local 6 // org.apache.cassandra.dht.Range range
         7: .line 156
            aload 6 /* range */
            aload 4 /* token */
            invokevirtual org.apache.cassandra.dht.Range.contains:(Lorg/apache/cassandra/dht/RingPosition;)Z
            ifeq 9
         8: .line 157
            iinc 2 /* n */ 1
        end local 6 // org.apache.cassandra.dht.Range range
         9: .line 155
      StackMap locals:
      StackMap stack:
            aload 7
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 6
        end local 4 // org.apache.cassandra.dht.Token token
        10: .line 154
      StackMap locals: org.apache.cassandra.locator.TokenMetadata java.net.InetAddress int java.util.Collection top java.util.Iterator
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 4
        11: .line 158
            goto 15
        12: .line 160
      StackMap locals: org.apache.cassandra.locator.TokenMetadata java.net.InetAddress int java.util.Collection
      StackMap stack: java.lang.Throwable
            astore 8
        13: .line 161
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        14: .line 162
            aload 8
            athrow
        15: .line 161
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        16: .line 163
            iload 2 /* n */
            ireturn
        end local 3 // java.util.Collection sourceRanges
        end local 2 // int n
        end local 1 // java.net.InetAddress source
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   17     0          this  Lorg/apache/cassandra/locator/TokenMetadata;
            0   17     1        source  Ljava/net/InetAddress;
            1   17     2             n  I
            2   17     3  sourceRanges  Ljava/util/Collection<Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;>;
            5   10     4         token  Lorg/apache/cassandra/dht/Token;
            7    9     6         range  Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;
      Exception table:
        from    to  target  type
           3    12      12  any
    MethodParameters:
        Name  Flags
      source  

  public void updateNormalToken(org.apache.cassandra.dht.Token, java.net.InetAddress);
    descriptor: (Lorg/apache/cassandra/dht/Token;Ljava/net/InetAddress;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // org.apache.cassandra.dht.Token token
        start local 2 // java.net.InetAddress endpoint
         0: .line 171
            aload 0 /* this */
            aload 1 /* token */
            invokestatic java.util.Collections.singleton:(Ljava/lang/Object;)Ljava/util/Set;
            aload 2 /* endpoint */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.updateNormalTokens:(Ljava/util/Collection;Ljava/net/InetAddress;)V
         1: .line 172
            return
        end local 2 // java.net.InetAddress endpoint
        end local 1 // org.apache.cassandra.dht.Token token
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    2     0      this  Lorg/apache/cassandra/locator/TokenMetadata;
            0    2     1     token  Lorg/apache/cassandra/dht/Token;
            0    2     2  endpoint  Ljava/net/InetAddress;
    MethodParameters:
          Name  Flags
      token     
      endpoint  

  public void updateNormalTokens(java.util.Collection<org.apache.cassandra.dht.Token>, java.net.InetAddress);
    descriptor: (Ljava/util/Collection;Ljava/net/InetAddress;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=6, args_size=3
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // java.util.Collection tokens
        start local 2 // java.net.InetAddress endpoint
         0: .line 176
            invokestatic com.google.common.collect.HashMultimap.create:()Lcom/google/common/collect/HashMultimap;
            astore 3 /* endpointTokens */
        start local 3 // com.google.common.collect.Multimap endpointTokens
         1: .line 177
            aload 1 /* tokens */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 5
            goto 4
      StackMap locals: org.apache.cassandra.locator.TokenMetadata java.util.Collection java.net.InetAddress com.google.common.collect.Multimap top java.util.Iterator
      StackMap stack:
         2: aload 5
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Token
            astore 4 /* token */
        start local 4 // org.apache.cassandra.dht.Token token
         3: .line 178
            aload 3 /* endpointTokens */
            aload 2 /* endpoint */
            aload 4 /* token */
            invokeinterface com.google.common.collect.Multimap.put:(Ljava/lang/Object;Ljava/lang/Object;)Z
            pop
        end local 4 // org.apache.cassandra.dht.Token token
         4: .line 177
      StackMap locals:
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 179
            aload 0 /* this */
            aload 3 /* endpointTokens */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.updateNormalTokens:(Lcom/google/common/collect/Multimap;)V
         6: .line 180
            return
        end local 3 // com.google.common.collect.Multimap endpointTokens
        end local 2 // java.net.InetAddress endpoint
        end local 1 // java.util.Collection tokens
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    7     0            this  Lorg/apache/cassandra/locator/TokenMetadata;
            0    7     1          tokens  Ljava/util/Collection<Lorg/apache/cassandra/dht/Token;>;
            0    7     2        endpoint  Ljava/net/InetAddress;
            1    7     3  endpointTokens  Lcom/google/common/collect/Multimap<Ljava/net/InetAddress;Lorg/apache/cassandra/dht/Token;>;
            3    4     4           token  Lorg/apache/cassandra/dht/Token;
    Signature: (Ljava/util/Collection<Lorg/apache/cassandra/dht/Token;>;Ljava/net/InetAddress;)V
    MethodParameters:
          Name  Flags
      tokens    
      endpoint  

  public void updateNormalTokens(com.google.common.collect.Multimap<java.net.InetAddress, org.apache.cassandra.dht.Token>);
    descriptor: (Lcom/google/common/collect/Multimap;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=11, args_size=2
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // com.google.common.collect.Multimap endpointTokens
         0: .line 190
            aload 1 /* endpointTokens */
            invokeinterface com.google.common.collect.Multimap.isEmpty:()Z
            ifeq 2
         1: .line 191
            return
         2: .line 193
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         3: .line 196
            iconst_0
            istore 2 /* shouldSortTokens */
        start local 2 // boolean shouldSortTokens
         4: .line 197
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.topology:Lorg/apache/cassandra/locator/TokenMetadata$Topology;
            invokevirtual org.apache.cassandra.locator.TokenMetadata$Topology.unbuild:()Lorg/apache/cassandra/locator/TokenMetadata$Topology$Builder;
            astore 3 /* topologyBuilder */
        start local 3 // org.apache.cassandra.locator.TokenMetadata$Topology$Builder topologyBuilder
         5: .line 198
            aload 1 /* endpointTokens */
            invokeinterface com.google.common.collect.Multimap.keySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 5
            goto 24
      StackMap locals: org.apache.cassandra.locator.TokenMetadata com.google.common.collect.Multimap int org.apache.cassandra.locator.TokenMetadata$Topology$Builder top java.util.Iterator
      StackMap stack:
         6: aload 5
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.net.InetAddress
            astore 4 /* endpoint */
        start local 4 // java.net.InetAddress endpoint
         7: .line 200
            aload 1 /* endpointTokens */
            aload 4 /* endpoint */
            invokeinterface com.google.common.collect.Multimap.get:(Ljava/lang/Object;)Ljava/util/Collection;
            astore 6 /* tokens */
        start local 6 // java.util.Collection tokens
         8: .line 202
            getstatic org.apache.cassandra.locator.TokenMetadata.$assertionsDisabled:Z
            ifne 10
            aload 6 /* tokens */
            ifnull 9
            aload 6 /* tokens */
            invokeinterface java.util.Collection.isEmpty:()Z
            ifeq 10
      StackMap locals: org.apache.cassandra.locator.TokenMetadata com.google.common.collect.Multimap int org.apache.cassandra.locator.TokenMetadata$Topology$Builder java.net.InetAddress java.util.Iterator java.util.Collection
      StackMap stack:
         9: new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
        10: .line 204
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.bootstrapTokens:Lorg/apache/cassandra/utils/BiMultiValMap;
            aload 4 /* endpoint */
            invokevirtual org.apache.cassandra.utils.BiMultiValMap.removeValue:(Ljava/lang/Object;)Ljava/util/Collection;
            pop
        11: .line 205
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.tokenToEndpointMap:Lorg/apache/cassandra/utils/BiMultiValMap;
            aload 4 /* endpoint */
            invokevirtual org.apache.cassandra.utils.BiMultiValMap.removeValue:(Ljava/lang/Object;)Ljava/util/Collection;
            pop
        12: .line 206
            aload 3 /* topologyBuilder */
            aload 4 /* endpoint */
            invokevirtual org.apache.cassandra.locator.TokenMetadata$Topology$Builder.addEndpoint:(Ljava/net/InetAddress;)Lorg/apache/cassandra/locator/TokenMetadata$Topology$Builder;
            pop
        13: .line 207
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.leavingEndpoints:Ljava/util/Set;
            aload 4 /* endpoint */
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
        14: .line 208
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.replacementToOriginal:Lcom/google/common/collect/BiMap;
            aload 4 /* endpoint */
            invokeinterface com.google.common.collect.BiMap.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
        15: .line 209
            aload 0 /* this */
            aload 4 /* endpoint */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.removeFromMoving:(Ljava/net/InetAddress;)V
        16: .line 211
            aload 6 /* tokens */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 8
            goto 23
      StackMap locals: org.apache.cassandra.locator.TokenMetadata com.google.common.collect.Multimap int org.apache.cassandra.locator.TokenMetadata$Topology$Builder java.net.InetAddress java.util.Iterator java.util.Collection top java.util.Iterator
      StackMap stack:
        17: aload 8
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Token
            astore 7 /* token */
        start local 7 // org.apache.cassandra.dht.Token token
        18: .line 213
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.tokenToEndpointMap:Lorg/apache/cassandra/utils/BiMultiValMap;
            aload 7 /* token */
            aload 4 /* endpoint */
            invokevirtual org.apache.cassandra.utils.BiMultiValMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.net.InetAddress
            astore 9 /* prev */
        start local 9 // java.net.InetAddress prev
        19: .line 214
            aload 4 /* endpoint */
            aload 9 /* prev */
            invokevirtual java.net.InetAddress.equals:(Ljava/lang/Object;)Z
            ifne 23
        20: .line 216
            aload 9 /* prev */
            ifnull 22
        21: .line 217
            getstatic org.apache.cassandra.locator.TokenMetadata.logger:Lorg/slf4j/Logger;
            ldc "Token {} changing ownership from {} to {}"
            iconst_3
            anewarray java.lang.Object
            dup
            iconst_0
            aload 7 /* token */
            aastore
            dup
            iconst_1
            aload 9 /* prev */
            aastore
            dup
            iconst_2
            aload 4 /* endpoint */
            aastore
            invokeinterface org.slf4j.Logger.warn:(Ljava/lang/String;[Ljava/lang/Object;)V
        22: .line 218
      StackMap locals: org.apache.cassandra.locator.TokenMetadata com.google.common.collect.Multimap int org.apache.cassandra.locator.TokenMetadata$Topology$Builder java.net.InetAddress java.util.Iterator java.util.Collection org.apache.cassandra.dht.Token java.util.Iterator java.net.InetAddress
      StackMap stack:
            iconst_1
            istore 2 /* shouldSortTokens */
        end local 9 // java.net.InetAddress prev
        end local 7 // org.apache.cassandra.dht.Token token
        23: .line 211
      StackMap locals: org.apache.cassandra.locator.TokenMetadata com.google.common.collect.Multimap int org.apache.cassandra.locator.TokenMetadata$Topology$Builder java.net.InetAddress java.util.Iterator java.util.Collection top java.util.Iterator
      StackMap stack:
            aload 8
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 17
        end local 6 // java.util.Collection tokens
        end local 4 // java.net.InetAddress endpoint
        24: .line 198
      StackMap locals: org.apache.cassandra.locator.TokenMetadata com.google.common.collect.Multimap int org.apache.cassandra.locator.TokenMetadata$Topology$Builder top java.util.Iterator
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 6
        25: .line 222
            aload 0 /* this */
            aload 3 /* topologyBuilder */
            invokevirtual org.apache.cassandra.locator.TokenMetadata$Topology$Builder.build:()Lorg/apache/cassandra/locator/TokenMetadata$Topology;
            putfield org.apache.cassandra.locator.TokenMetadata.topology:Lorg/apache/cassandra/locator/TokenMetadata$Topology;
        26: .line 224
            iload 2 /* shouldSortTokens */
            ifeq 32
        27: .line 225
            aload 0 /* this */
            aload 0 /* this */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.sortTokens:()Ljava/util/ArrayList;
            putfield org.apache.cassandra.locator.TokenMetadata.sortedTokens:Ljava/util/ArrayList;
        end local 3 // org.apache.cassandra.locator.TokenMetadata$Topology$Builder topologyBuilder
        end local 2 // boolean shouldSortTokens
        28: .line 226
            goto 32
        29: .line 228
      StackMap locals: org.apache.cassandra.locator.TokenMetadata com.google.common.collect.Multimap
      StackMap stack: java.lang.Throwable
            astore 10
        30: .line 229
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        31: .line 230
            aload 10
            athrow
        32: .line 229
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        33: .line 231
            return
        end local 1 // com.google.common.collect.Multimap endpointTokens
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   34     0              this  Lorg/apache/cassandra/locator/TokenMetadata;
            0   34     1    endpointTokens  Lcom/google/common/collect/Multimap<Ljava/net/InetAddress;Lorg/apache/cassandra/dht/Token;>;
            4   28     2  shouldSortTokens  Z
            5   28     3   topologyBuilder  Lorg/apache/cassandra/locator/TokenMetadata$Topology$Builder;
            7   24     4          endpoint  Ljava/net/InetAddress;
            8   24     6            tokens  Ljava/util/Collection<Lorg/apache/cassandra/dht/Token;>;
           18   23     7             token  Lorg/apache/cassandra/dht/Token;
           19   23     9              prev  Ljava/net/InetAddress;
      Exception table:
        from    to  target  type
           3    29      29  any
    Signature: (Lcom/google/common/collect/Multimap<Ljava/net/InetAddress;Lorg/apache/cassandra/dht/Token;>;)V
    MethodParameters:
                Name  Flags
      endpointTokens  

  public void updateHostId(java.util.UUID, java.net.InetAddress);
    descriptor: (Ljava/util/UUID;Ljava/net/InetAddress;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=6, args_size=3
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // java.util.UUID hostId
        start local 2 // java.net.InetAddress endpoint
         0: .line 239
            getstatic org.apache.cassandra.locator.TokenMetadata.$assertionsDisabled:Z
            ifne 1
            aload 1 /* hostId */
            ifnonnull 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 240
      StackMap locals:
      StackMap stack:
            getstatic org.apache.cassandra.locator.TokenMetadata.$assertionsDisabled:Z
            ifne 2
            aload 2 /* endpoint */
            ifnonnull 2
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         2: .line 242
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         3: .line 245
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.endpointToHostIdMap:Lcom/google/common/collect/BiMap;
            invokeinterface com.google.common.collect.BiMap.inverse:()Lcom/google/common/collect/BiMap;
            aload 1 /* hostId */
            invokeinterface com.google.common.collect.BiMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.net.InetAddress
            astore 3 /* storedEp */
        start local 3 // java.net.InetAddress storedEp
         4: .line 246
            aload 3 /* storedEp */
            ifnull 11
         5: .line 248
            aload 3 /* storedEp */
            aload 2 /* endpoint */
            invokevirtual java.net.InetAddress.equals:(Ljava/lang/Object;)Z
            ifne 11
            getstatic org.apache.cassandra.gms.FailureDetector.instance:Lorg/apache/cassandra/gms/IFailureDetector;
            aload 3 /* storedEp */
            invokeinterface org.apache.cassandra.gms.IFailureDetector.isAlive:(Ljava/net/InetAddress;)Z
            ifeq 11
         6: .line 250
            new java.lang.RuntimeException
            dup
            ldc "Host ID collision between active endpoint %s and %s (id=%s)"
            iconst_3
            anewarray java.lang.Object
            dup
            iconst_0
         7: .line 251
            aload 3 /* storedEp */
            aastore
            dup
            iconst_1
         8: .line 252
            aload 2 /* endpoint */
            aastore
            dup
            iconst_2
         9: .line 253
            aload 1 /* hostId */
            aastore
        10: .line 250
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;)V
            athrow
        11: .line 257
      StackMap locals: java.net.InetAddress
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.endpointToHostIdMap:Lcom/google/common/collect/BiMap;
            aload 2 /* endpoint */
            invokeinterface com.google.common.collect.BiMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.util.UUID
            astore 4 /* storedId */
        start local 4 // java.util.UUID storedId
        12: .line 258
            aload 4 /* storedId */
            ifnull 14
            aload 4 /* storedId */
            aload 1 /* hostId */
            invokevirtual java.util.UUID.equals:(Ljava/lang/Object;)Z
            ifne 14
        13: .line 259
            getstatic org.apache.cassandra.locator.TokenMetadata.logger:Lorg/slf4j/Logger;
            ldc "Changing {}'s host ID from {} to {}"
            iconst_3
            anewarray java.lang.Object
            dup
            iconst_0
            aload 2 /* endpoint */
            aastore
            dup
            iconst_1
            aload 4 /* storedId */
            aastore
            dup
            iconst_2
            aload 1 /* hostId */
            aastore
            invokeinterface org.slf4j.Logger.warn:(Ljava/lang/String;[Ljava/lang/Object;)V
        14: .line 261
      StackMap locals: java.util.UUID
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.endpointToHostIdMap:Lcom/google/common/collect/BiMap;
            aload 2 /* endpoint */
            aload 1 /* hostId */
            invokeinterface com.google.common.collect.BiMap.forcePut:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 4 // java.util.UUID storedId
        end local 3 // java.net.InetAddress storedEp
        15: .line 262
            goto 19
        16: .line 264
      StackMap locals: org.apache.cassandra.locator.TokenMetadata java.util.UUID java.net.InetAddress
      StackMap stack: java.lang.Throwable
            astore 5
        17: .line 265
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        18: .line 266
            aload 5
            athrow
        19: .line 265
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        20: .line 268
            return
        end local 2 // java.net.InetAddress endpoint
        end local 1 // java.util.UUID hostId
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   21     0      this  Lorg/apache/cassandra/locator/TokenMetadata;
            0   21     1    hostId  Ljava/util/UUID;
            0   21     2  endpoint  Ljava/net/InetAddress;
            4   15     3  storedEp  Ljava/net/InetAddress;
           12   15     4  storedId  Ljava/util/UUID;
      Exception table:
        from    to  target  type
           3    16      16  any
    MethodParameters:
          Name  Flags
      hostId    
      endpoint  

  public java.util.UUID getHostId(java.net.InetAddress);
    descriptor: (Ljava/net/InetAddress;)Ljava/util/UUID;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // java.net.InetAddress endpoint
         0: .line 273
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         1: .line 276
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.endpointToHostIdMap:Lcom/google/common/collect/BiMap;
            aload 1 /* endpoint */
            invokeinterface com.google.common.collect.BiMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.util.UUID
            astore 3
         2: .line 280
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         3: .line 276
            aload 3
            areturn
         4: .line 279
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 2
         5: .line 280
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         6: .line 281
            aload 2
            athrow
        end local 1 // java.net.InetAddress endpoint
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    7     0      this  Lorg/apache/cassandra/locator/TokenMetadata;
            0    7     1  endpoint  Ljava/net/InetAddress;
      Exception table:
        from    to  target  type
           1     2       4  any
    MethodParameters:
          Name  Flags
      endpoint  

  public java.net.InetAddress getEndpointForHostId(java.util.UUID);
    descriptor: (Ljava/util/UUID;)Ljava/net/InetAddress;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // java.util.UUID hostId
         0: .line 287
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         1: .line 290
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.endpointToHostIdMap:Lcom/google/common/collect/BiMap;
            invokeinterface com.google.common.collect.BiMap.inverse:()Lcom/google/common/collect/BiMap;
            aload 1 /* hostId */
            invokeinterface com.google.common.collect.BiMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.net.InetAddress
            astore 3
         2: .line 294
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         3: .line 290
            aload 3
            areturn
         4: .line 293
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 2
         5: .line 294
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         6: .line 295
            aload 2
            athrow
        end local 1 // java.util.UUID hostId
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    7     0    this  Lorg/apache/cassandra/locator/TokenMetadata;
            0    7     1  hostId  Ljava/util/UUID;
      Exception table:
        from    to  target  type
           1     2       4  any
    MethodParameters:
        Name  Flags
      hostId  

  public java.util.Map<java.net.InetAddress, java.util.UUID> getEndpointToHostIdMapForReading();
    descriptor: ()Ljava/util/Map;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=1
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
         0: .line 301
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         1: .line 304
            new java.util.HashMap
            dup
            invokespecial java.util.HashMap.<init>:()V
            astore 1 /* readMap */
        start local 1 // java.util.Map readMap
         2: .line 305
            aload 1 /* readMap */
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.endpointToHostIdMap:Lcom/google/common/collect/BiMap;
            invokeinterface java.util.Map.putAll:(Ljava/util/Map;)V
         3: .line 306
            aload 1 /* readMap */
            astore 3
         4: .line 310
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         5: .line 306
            aload 3
            areturn
        end local 1 // java.util.Map readMap
         6: .line 309
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 2
         7: .line 310
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         8: .line 311
            aload 2
            athrow
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    9     0     this  Lorg/apache/cassandra/locator/TokenMetadata;
            2    6     1  readMap  Ljava/util/Map<Ljava/net/InetAddress;Ljava/util/UUID;>;
      Exception table:
        from    to  target  type
           1     4       6  any
    Signature: ()Ljava/util/Map<Ljava/net/InetAddress;Ljava/util/UUID;>;

  public void addBootstrapToken(org.apache.cassandra.dht.Token, java.net.InetAddress);
    descriptor: (Lorg/apache/cassandra/dht/Token;Ljava/net/InetAddress;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // org.apache.cassandra.dht.Token token
        start local 2 // java.net.InetAddress endpoint
         0: .line 317
            aload 0 /* this */
            aload 1 /* token */
            invokestatic java.util.Collections.singleton:(Ljava/lang/Object;)Ljava/util/Set;
            aload 2 /* endpoint */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.addBootstrapTokens:(Ljava/util/Collection;Ljava/net/InetAddress;)V
         1: .line 318
            return
        end local 2 // java.net.InetAddress endpoint
        end local 1 // org.apache.cassandra.dht.Token token
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    2     0      this  Lorg/apache/cassandra/locator/TokenMetadata;
            0    2     1     token  Lorg/apache/cassandra/dht/Token;
            0    2     2  endpoint  Ljava/net/InetAddress;
    RuntimeVisibleAnnotations: 
      java.lang.Deprecated()
    MethodParameters:
          Name  Flags
      token     
      endpoint  

  public void addBootstrapTokens(java.util.Collection<org.apache.cassandra.dht.Token>, java.net.InetAddress);
    descriptor: (Ljava/util/Collection;Ljava/net/InetAddress;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // java.util.Collection tokens
        start local 2 // java.net.InetAddress endpoint
         0: .line 322
            aload 0 /* this */
            aload 1 /* tokens */
            aload 2 /* endpoint */
            aconst_null
            invokevirtual org.apache.cassandra.locator.TokenMetadata.addBootstrapTokens:(Ljava/util/Collection;Ljava/net/InetAddress;Ljava/net/InetAddress;)V
         1: .line 323
            return
        end local 2 // java.net.InetAddress endpoint
        end local 1 // java.util.Collection tokens
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    2     0      this  Lorg/apache/cassandra/locator/TokenMetadata;
            0    2     1    tokens  Ljava/util/Collection<Lorg/apache/cassandra/dht/Token;>;
            0    2     2  endpoint  Ljava/net/InetAddress;
    Signature: (Ljava/util/Collection<Lorg/apache/cassandra/dht/Token;>;Ljava/net/InetAddress;)V
    MethodParameters:
          Name  Flags
      tokens    
      endpoint  

  private void addBootstrapTokens(java.util.Collection<org.apache.cassandra.dht.Token>, java.net.InetAddress, java.net.InetAddress);
    descriptor: (Ljava/util/Collection;Ljava/net/InetAddress;Ljava/net/InetAddress;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=8, args_size=4
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // java.util.Collection tokens
        start local 2 // java.net.InetAddress endpoint
        start local 3 // java.net.InetAddress original
         0: .line 327
            getstatic org.apache.cassandra.locator.TokenMetadata.$assertionsDisabled:Z
            ifne 2
            aload 1 /* tokens */
            ifnull 1
            aload 1 /* tokens */
            invokeinterface java.util.Collection.isEmpty:()Z
            ifeq 2
      StackMap locals:
      StackMap stack:
         1: new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         2: .line 328
      StackMap locals:
      StackMap stack:
            getstatic org.apache.cassandra.locator.TokenMetadata.$assertionsDisabled:Z
            ifne 3
            aload 2 /* endpoint */
            ifnonnull 3
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         3: .line 330
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         4: .line 336
            aload 1 /* tokens */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 6
            goto 12
      StackMap locals: org.apache.cassandra.locator.TokenMetadata java.util.Collection java.net.InetAddress java.net.InetAddress top top java.util.Iterator
      StackMap stack:
         5: aload 6
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Token
            astore 5 /* token */
        start local 5 // org.apache.cassandra.dht.Token token
         6: .line 338
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.bootstrapTokens:Lorg/apache/cassandra/utils/BiMultiValMap;
            aload 5 /* token */
            invokevirtual org.apache.cassandra.utils.BiMultiValMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.net.InetAddress
            astore 4 /* oldEndpoint */
        start local 4 // java.net.InetAddress oldEndpoint
         7: .line 339
            aload 4 /* oldEndpoint */
            ifnull 9
            aload 4 /* oldEndpoint */
            aload 2 /* endpoint */
            invokevirtual java.net.InetAddress.equals:(Ljava/lang/Object;)Z
            ifne 9
         8: .line 340
            new java.lang.RuntimeException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Bootstrap Token collision between "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 4 /* oldEndpoint */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc " and "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 2 /* endpoint */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc " (token "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 5 /* token */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;)V
            athrow
         9: .line 342
      StackMap locals: org.apache.cassandra.locator.TokenMetadata java.util.Collection java.net.InetAddress java.net.InetAddress java.net.InetAddress org.apache.cassandra.dht.Token java.util.Iterator
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.tokenToEndpointMap:Lorg/apache/cassandra/utils/BiMultiValMap;
            aload 5 /* token */
            invokevirtual org.apache.cassandra.utils.BiMultiValMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.net.InetAddress
            astore 4 /* oldEndpoint */
        10: .line 343
            aload 4 /* oldEndpoint */
            ifnull 12
            aload 4 /* oldEndpoint */
            aload 2 /* endpoint */
            invokevirtual java.net.InetAddress.equals:(Ljava/lang/Object;)Z
            ifne 12
            aload 4 /* oldEndpoint */
            aload 3 /* original */
            invokevirtual java.net.InetAddress.equals:(Ljava/lang/Object;)Z
            ifne 12
        11: .line 344
            new java.lang.RuntimeException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Bootstrap Token collision between "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 4 /* oldEndpoint */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc " and "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 2 /* endpoint */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc " (token "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 5 /* token */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;)V
            athrow
        end local 5 // org.apache.cassandra.dht.Token token
        end local 4 // java.net.InetAddress oldEndpoint
        12: .line 336
      StackMap locals: org.apache.cassandra.locator.TokenMetadata java.util.Collection java.net.InetAddress java.net.InetAddress top top java.util.Iterator
      StackMap stack:
            aload 6
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 5
        13: .line 347
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.bootstrapTokens:Lorg/apache/cassandra/utils/BiMultiValMap;
            aload 2 /* endpoint */
            invokevirtual org.apache.cassandra.utils.BiMultiValMap.removeValue:(Ljava/lang/Object;)Ljava/util/Collection;
            pop
        14: .line 349
            aload 1 /* tokens */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 6
            goto 17
      StackMap locals:
      StackMap stack:
        15: aload 6
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Token
            astore 5 /* token */
        start local 5 // org.apache.cassandra.dht.Token token
        16: .line 350
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.bootstrapTokens:Lorg/apache/cassandra/utils/BiMultiValMap;
            aload 5 /* token */
            aload 2 /* endpoint */
            invokevirtual org.apache.cassandra.utils.BiMultiValMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 5 // org.apache.cassandra.dht.Token token
        17: .line 349
      StackMap locals:
      StackMap stack:
            aload 6
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 15
        18: .line 351
            goto 22
        19: .line 353
      StackMap locals: org.apache.cassandra.locator.TokenMetadata java.util.Collection java.net.InetAddress java.net.InetAddress
      StackMap stack: java.lang.Throwable
            astore 7
        20: .line 354
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        21: .line 355
            aload 7
            athrow
        22: .line 354
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        23: .line 356
            return
        end local 3 // java.net.InetAddress original
        end local 2 // java.net.InetAddress endpoint
        end local 1 // java.util.Collection tokens
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   24     0         this  Lorg/apache/cassandra/locator/TokenMetadata;
            0   24     1       tokens  Ljava/util/Collection<Lorg/apache/cassandra/dht/Token;>;
            0   24     2     endpoint  Ljava/net/InetAddress;
            0   24     3     original  Ljava/net/InetAddress;
            7   12     4  oldEndpoint  Ljava/net/InetAddress;
            6   12     5        token  Lorg/apache/cassandra/dht/Token;
           16   17     5        token  Lorg/apache/cassandra/dht/Token;
      Exception table:
        from    to  target  type
           4    19      19  any
    Signature: (Ljava/util/Collection<Lorg/apache/cassandra/dht/Token;>;Ljava/net/InetAddress;Ljava/net/InetAddress;)V
    MethodParameters:
          Name  Flags
      tokens    
      endpoint  
      original  

  public void addReplaceTokens(java.util.Collection<org.apache.cassandra.dht.Token>, java.net.InetAddress, java.net.InetAddress);
    descriptor: (Ljava/util/Collection;Ljava/net/InetAddress;Ljava/net/InetAddress;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=6, args_size=4
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // java.util.Collection replacingTokens
        start local 2 // java.net.InetAddress newNode
        start local 3 // java.net.InetAddress oldNode
         0: .line 360
            getstatic org.apache.cassandra.locator.TokenMetadata.$assertionsDisabled:Z
            ifne 2
            aload 1 /* replacingTokens */
            ifnull 1
            aload 1 /* replacingTokens */
            invokeinterface java.util.Collection.isEmpty:()Z
            ifeq 2
      StackMap locals:
      StackMap stack:
         1: new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         2: .line 361
      StackMap locals:
      StackMap stack:
            getstatic org.apache.cassandra.locator.TokenMetadata.$assertionsDisabled:Z
            ifne 4
            aload 2 /* newNode */
            ifnull 3
            aload 3 /* oldNode */
            ifnonnull 4
      StackMap locals:
      StackMap stack:
         3: new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         4: .line 363
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         5: .line 366
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.tokenToEndpointMap:Lorg/apache/cassandra/utils/BiMultiValMap;
            invokevirtual org.apache.cassandra.utils.BiMultiValMap.inverse:()Lcom/google/common/collect/Multimap;
            aload 3 /* oldNode */
            invokeinterface com.google.common.collect.Multimap.get:(Ljava/lang/Object;)Ljava/util/Collection;
            astore 4 /* oldNodeTokens */
        start local 4 // java.util.Collection oldNodeTokens
         6: .line 367
            aload 1 /* replacingTokens */
            aload 4 /* oldNodeTokens */
            invokeinterface java.util.Collection.containsAll:(Ljava/util/Collection;)Z
            ifeq 7
            aload 4 /* oldNodeTokens */
            aload 1 /* replacingTokens */
            invokeinterface java.util.Collection.containsAll:(Ljava/util/Collection;)Z
            ifne 11
         7: .line 369
      StackMap locals: java.util.Collection
      StackMap stack:
            new java.lang.RuntimeException
            dup
            ldc "Node %s is trying to replace node %s with tokens %s with a different set of tokens %s."
            iconst_4
            anewarray java.lang.Object
            dup
            iconst_0
         8: .line 370
            aload 2 /* newNode */
            aastore
            dup
            iconst_1
            aload 3 /* oldNode */
            aastore
            dup
            iconst_2
            aload 4 /* oldNodeTokens */
            aastore
            dup
            iconst_3
         9: .line 371
            aload 1 /* replacingTokens */
            aastore
        10: .line 369
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;)V
            athrow
        11: .line 374
      StackMap locals:
      StackMap stack:
            getstatic org.apache.cassandra.locator.TokenMetadata.logger:Lorg/slf4j/Logger;
            ldc "Replacing {} with {}"
            aload 2 /* newNode */
            aload 3 /* oldNode */
            invokeinterface org.slf4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
        12: .line 375
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.replacementToOriginal:Lcom/google/common/collect/BiMap;
            aload 2 /* newNode */
            aload 3 /* oldNode */
            invokeinterface com.google.common.collect.BiMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        13: .line 377
            aload 0 /* this */
            aload 1 /* replacingTokens */
            aload 2 /* newNode */
            aload 3 /* oldNode */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.addBootstrapTokens:(Ljava/util/Collection;Ljava/net/InetAddress;Ljava/net/InetAddress;)V
        end local 4 // java.util.Collection oldNodeTokens
        14: .line 378
            goto 18
        15: .line 380
      StackMap locals: org.apache.cassandra.locator.TokenMetadata java.util.Collection java.net.InetAddress java.net.InetAddress
      StackMap stack: java.lang.Throwable
            astore 5
        16: .line 381
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        17: .line 382
            aload 5
            athrow
        18: .line 381
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        19: .line 383
            return
        end local 3 // java.net.InetAddress oldNode
        end local 2 // java.net.InetAddress newNode
        end local 1 // java.util.Collection replacingTokens
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   20     0             this  Lorg/apache/cassandra/locator/TokenMetadata;
            0   20     1  replacingTokens  Ljava/util/Collection<Lorg/apache/cassandra/dht/Token;>;
            0   20     2          newNode  Ljava/net/InetAddress;
            0   20     3          oldNode  Ljava/net/InetAddress;
            6   14     4    oldNodeTokens  Ljava/util/Collection<Lorg/apache/cassandra/dht/Token;>;
      Exception table:
        from    to  target  type
           5    15      15  any
    Signature: (Ljava/util/Collection<Lorg/apache/cassandra/dht/Token;>;Ljava/net/InetAddress;Ljava/net/InetAddress;)V
    MethodParameters:
                 Name  Flags
      replacingTokens  
      newNode          
      oldNode          

  public java.util.Optional<java.net.InetAddress> getReplacementNode(java.net.InetAddress);
    descriptor: (Ljava/net/InetAddress;)Ljava/util/Optional;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // java.net.InetAddress endpoint
         0: .line 387
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         1: .line 390
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.replacementToOriginal:Lcom/google/common/collect/BiMap;
            invokeinterface com.google.common.collect.BiMap.inverse:()Lcom/google/common/collect/BiMap;
            aload 1 /* endpoint */
            invokeinterface com.google.common.collect.BiMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.net.InetAddress
            invokestatic java.util.Optional.ofNullable:(Ljava/lang/Object;)Ljava/util/Optional;
            astore 3
         2: .line 394
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         3: .line 390
            aload 3
            areturn
         4: .line 393
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 2
         5: .line 394
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         6: .line 395
            aload 2
            athrow
        end local 1 // java.net.InetAddress endpoint
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    7     0      this  Lorg/apache/cassandra/locator/TokenMetadata;
            0    7     1  endpoint  Ljava/net/InetAddress;
      Exception table:
        from    to  target  type
           1     2       4  any
    Signature: (Ljava/net/InetAddress;)Ljava/util/Optional<Ljava/net/InetAddress;>;
    MethodParameters:
          Name  Flags
      endpoint  

  public java.util.Optional<java.net.InetAddress> getReplacingNode(java.net.InetAddress);
    descriptor: (Ljava/net/InetAddress;)Ljava/util/Optional;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // java.net.InetAddress endpoint
         0: .line 400
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         1: .line 403
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.replacementToOriginal:Lcom/google/common/collect/BiMap;
            aload 1 /* endpoint */
            invokeinterface com.google.common.collect.BiMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.net.InetAddress
            invokestatic java.util.Optional.ofNullable:(Ljava/lang/Object;)Ljava/util/Optional;
            astore 3
         2: .line 407
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         3: .line 403
            aload 3
            areturn
         4: .line 406
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 2
         5: .line 407
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         6: .line 408
            aload 2
            athrow
        end local 1 // java.net.InetAddress endpoint
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    7     0      this  Lorg/apache/cassandra/locator/TokenMetadata;
            0    7     1  endpoint  Ljava/net/InetAddress;
      Exception table:
        from    to  target  type
           1     2       4  any
    Signature: (Ljava/net/InetAddress;)Ljava/util/Optional<Ljava/net/InetAddress;>;
    MethodParameters:
          Name  Flags
      endpoint  

  public void removeBootstrapTokens(java.util.Collection<org.apache.cassandra.dht.Token>);
    descriptor: (Ljava/util/Collection;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=5, args_size=2
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // java.util.Collection tokens
         0: .line 413
            getstatic org.apache.cassandra.locator.TokenMetadata.$assertionsDisabled:Z
            ifne 2
            aload 1 /* tokens */
            ifnull 1
            aload 1 /* tokens */
            invokeinterface java.util.Collection.isEmpty:()Z
            ifeq 2
      StackMap locals:
      StackMap stack:
         1: new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         2: .line 415
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         3: .line 418
            aload 1 /* tokens */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 3
            goto 6
      StackMap locals: org.apache.cassandra.locator.TokenMetadata java.util.Collection top java.util.Iterator
      StackMap stack:
         4: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Token
            astore 2 /* token */
        start local 2 // org.apache.cassandra.dht.Token token
         5: .line 419
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.bootstrapTokens:Lorg/apache/cassandra/utils/BiMultiValMap;
            aload 2 /* token */
            invokevirtual org.apache.cassandra.utils.BiMultiValMap.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 2 // org.apache.cassandra.dht.Token token
         6: .line 418
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 4
         7: .line 420
            goto 11
         8: .line 422
      StackMap locals: org.apache.cassandra.locator.TokenMetadata java.util.Collection
      StackMap stack: java.lang.Throwable
            astore 4
         9: .line 423
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        10: .line 424
            aload 4
            athrow
        11: .line 423
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        12: .line 425
            return
        end local 1 // java.util.Collection tokens
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   13     0    this  Lorg/apache/cassandra/locator/TokenMetadata;
            0   13     1  tokens  Ljava/util/Collection<Lorg/apache/cassandra/dht/Token;>;
            5    6     2   token  Lorg/apache/cassandra/dht/Token;
      Exception table:
        from    to  target  type
           3     8       8  any
    Signature: (Ljava/util/Collection<Lorg/apache/cassandra/dht/Token;>;)V
    MethodParameters:
        Name  Flags
      tokens  

  public void addLeavingEndpoint(java.net.InetAddress);
    descriptor: (Ljava/net/InetAddress;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // java.net.InetAddress endpoint
         0: .line 429
            getstatic org.apache.cassandra.locator.TokenMetadata.$assertionsDisabled:Z
            ifne 1
            aload 1 /* endpoint */
            ifnonnull 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 431
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         2: .line 434
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.leavingEndpoints:Ljava/util/Set;
            aload 1 /* endpoint */
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
         3: .line 435
            goto 7
         4: .line 437
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 2
         5: .line 438
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         6: .line 439
            aload 2
            athrow
         7: .line 438
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         8: .line 440
            return
        end local 1 // java.net.InetAddress endpoint
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    9     0      this  Lorg/apache/cassandra/locator/TokenMetadata;
            0    9     1  endpoint  Ljava/net/InetAddress;
      Exception table:
        from    to  target  type
           2     4       4  any
    MethodParameters:
          Name  Flags
      endpoint  

  public void addMovingEndpoint(org.apache.cassandra.dht.Token, java.net.InetAddress);
    descriptor: (Lorg/apache/cassandra/dht/Token;Ljava/net/InetAddress;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=3
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // org.apache.cassandra.dht.Token token
        start local 2 // java.net.InetAddress endpoint
         0: .line 449
            getstatic org.apache.cassandra.locator.TokenMetadata.$assertionsDisabled:Z
            ifne 1
            aload 2 /* endpoint */
            ifnonnull 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 451
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         2: .line 454
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.movingEndpoints:Ljava/util/Set;
            aload 1 /* token */
            aload 2 /* endpoint */
            invokestatic org.apache.cassandra.utils.Pair.create:(Ljava/lang/Object;Ljava/lang/Object;)Lorg/apache/cassandra/utils/Pair;
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
         3: .line 455
            goto 7
         4: .line 457
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 3
         5: .line 458
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         6: .line 459
            aload 3
            athrow
         7: .line 458
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         8: .line 460
            return
        end local 2 // java.net.InetAddress endpoint
        end local 1 // org.apache.cassandra.dht.Token token
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    9     0      this  Lorg/apache/cassandra/locator/TokenMetadata;
            0    9     1     token  Lorg/apache/cassandra/dht/Token;
            0    9     2  endpoint  Ljava/net/InetAddress;
      Exception table:
        from    to  target  type
           2     4       4  any
    MethodParameters:
          Name  Flags
      token     
      endpoint  

  public void removeEndpoint(java.net.InetAddress);
    descriptor: (Ljava/net/InetAddress;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // java.net.InetAddress endpoint
         0: .line 464
            getstatic org.apache.cassandra.locator.TokenMetadata.$assertionsDisabled:Z
            ifne 1
            aload 1 /* endpoint */
            ifnonnull 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 466
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         2: .line 469
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.bootstrapTokens:Lorg/apache/cassandra/utils/BiMultiValMap;
            aload 1 /* endpoint */
            invokevirtual org.apache.cassandra.utils.BiMultiValMap.removeValue:(Ljava/lang/Object;)Ljava/util/Collection;
            pop
         3: .line 470
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.tokenToEndpointMap:Lorg/apache/cassandra/utils/BiMultiValMap;
            aload 1 /* endpoint */
            invokevirtual org.apache.cassandra.utils.BiMultiValMap.removeValue:(Ljava/lang/Object;)Ljava/util/Collection;
            pop
         4: .line 471
            aload 0 /* this */
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.topology:Lorg/apache/cassandra/locator/TokenMetadata$Topology;
            invokevirtual org.apache.cassandra.locator.TokenMetadata$Topology.unbuild:()Lorg/apache/cassandra/locator/TokenMetadata$Topology$Builder;
            aload 1 /* endpoint */
            invokevirtual org.apache.cassandra.locator.TokenMetadata$Topology$Builder.removeEndpoint:(Ljava/net/InetAddress;)Lorg/apache/cassandra/locator/TokenMetadata$Topology$Builder;
            invokevirtual org.apache.cassandra.locator.TokenMetadata$Topology$Builder.build:()Lorg/apache/cassandra/locator/TokenMetadata$Topology;
            putfield org.apache.cassandra.locator.TokenMetadata.topology:Lorg/apache/cassandra/locator/TokenMetadata$Topology;
         5: .line 472
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.leavingEndpoints:Ljava/util/Set;
            aload 1 /* endpoint */
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
         6: .line 473
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.replacementToOriginal:Lcom/google/common/collect/BiMap;
            aload 1 /* endpoint */
            invokeinterface com.google.common.collect.BiMap.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            ifnull 8
         7: .line 475
            getstatic org.apache.cassandra.locator.TokenMetadata.logger:Lorg/slf4j/Logger;
            ldc "Node {} failed during replace."
            aload 1 /* endpoint */
            invokeinterface org.slf4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Object;)V
         8: .line 477
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.endpointToHostIdMap:Lcom/google/common/collect/BiMap;
            aload 1 /* endpoint */
            invokeinterface com.google.common.collect.BiMap.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
         9: .line 478
            aload 0 /* this */
            aload 0 /* this */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.sortTokens:()Ljava/util/ArrayList;
            putfield org.apache.cassandra.locator.TokenMetadata.sortedTokens:Ljava/util/ArrayList;
        10: .line 479
            aload 0 /* this */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.invalidateCachedRings:()V
        11: .line 480
            goto 15
        12: .line 482
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 2
        13: .line 483
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        14: .line 484
            aload 2
            athrow
        15: .line 483
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        16: .line 485
            return
        end local 1 // java.net.InetAddress endpoint
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   17     0      this  Lorg/apache/cassandra/locator/TokenMetadata;
            0   17     1  endpoint  Ljava/net/InetAddress;
      Exception table:
        from    to  target  type
           2    12      12  any
    MethodParameters:
          Name  Flags
      endpoint  

  public org.apache.cassandra.locator.TokenMetadata$Topology updateTopology(java.net.InetAddress);
    descriptor: (Ljava/net/InetAddress;)Lorg/apache/cassandra/locator/TokenMetadata$Topology;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=2
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // java.net.InetAddress endpoint
         0: .line 492
            getstatic org.apache.cassandra.locator.TokenMetadata.$assertionsDisabled:Z
            ifne 1
            aload 1 /* endpoint */
            ifnonnull 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 494
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         2: .line 497
            getstatic org.apache.cassandra.locator.TokenMetadata.logger:Lorg/slf4j/Logger;
            ldc "Updating topology for {}"
            aload 1 /* endpoint */
            invokeinterface org.slf4j.Logger.info:(Ljava/lang/String;Ljava/lang/Object;)V
         3: .line 498
            aload 0 /* this */
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.topology:Lorg/apache/cassandra/locator/TokenMetadata$Topology;
            invokevirtual org.apache.cassandra.locator.TokenMetadata$Topology.unbuild:()Lorg/apache/cassandra/locator/TokenMetadata$Topology$Builder;
            aload 1 /* endpoint */
            invokevirtual org.apache.cassandra.locator.TokenMetadata$Topology$Builder.updateEndpoint:(Ljava/net/InetAddress;)Lorg/apache/cassandra/locator/TokenMetadata$Topology$Builder;
            invokevirtual org.apache.cassandra.locator.TokenMetadata$Topology$Builder.build:()Lorg/apache/cassandra/locator/TokenMetadata$Topology;
            putfield org.apache.cassandra.locator.TokenMetadata.topology:Lorg/apache/cassandra/locator/TokenMetadata$Topology;
         4: .line 499
            aload 0 /* this */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.invalidateCachedRings:()V
         5: .line 500
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.topology:Lorg/apache/cassandra/locator/TokenMetadata$Topology;
            astore 3
         6: .line 504
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         7: .line 500
            aload 3
            areturn
         8: .line 503
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 2
         9: .line 504
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        10: .line 505
            aload 2
            athrow
        end local 1 // java.net.InetAddress endpoint
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   11     0      this  Lorg/apache/cassandra/locator/TokenMetadata;
            0   11     1  endpoint  Ljava/net/InetAddress;
      Exception table:
        from    to  target  type
           2     6       8  any
    MethodParameters:
          Name  Flags
      endpoint  

  public org.apache.cassandra.locator.TokenMetadata$Topology updateTopology();
    descriptor: ()Lorg/apache/cassandra/locator/TokenMetadata$Topology;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=1
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
         0: .line 514
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         1: .line 517
            getstatic org.apache.cassandra.locator.TokenMetadata.logger:Lorg/slf4j/Logger;
            ldc "Updating topology for all endpoints that have changed"
            invokeinterface org.slf4j.Logger.info:(Ljava/lang/String;)V
         2: .line 518
            aload 0 /* this */
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.topology:Lorg/apache/cassandra/locator/TokenMetadata$Topology;
            invokevirtual org.apache.cassandra.locator.TokenMetadata$Topology.unbuild:()Lorg/apache/cassandra/locator/TokenMetadata$Topology$Builder;
            invokevirtual org.apache.cassandra.locator.TokenMetadata$Topology$Builder.updateEndpoints:()Lorg/apache/cassandra/locator/TokenMetadata$Topology$Builder;
            invokevirtual org.apache.cassandra.locator.TokenMetadata$Topology$Builder.build:()Lorg/apache/cassandra/locator/TokenMetadata$Topology;
            putfield org.apache.cassandra.locator.TokenMetadata.topology:Lorg/apache/cassandra/locator/TokenMetadata$Topology;
         3: .line 519
            aload 0 /* this */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.invalidateCachedRings:()V
         4: .line 520
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.topology:Lorg/apache/cassandra/locator/TokenMetadata$Topology;
            astore 2
         5: .line 524
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         6: .line 520
            aload 2
            areturn
         7: .line 523
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 1
         8: .line 524
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         9: .line 525
            aload 1
            athrow
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   10     0  this  Lorg/apache/cassandra/locator/TokenMetadata;
      Exception table:
        from    to  target  type
           1     5       7  any

  public void removeFromMoving(java.net.InetAddress);
    descriptor: (Ljava/net/InetAddress;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=5, args_size=2
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // java.net.InetAddress endpoint
         0: .line 534
            getstatic org.apache.cassandra.locator.TokenMetadata.$assertionsDisabled:Z
            ifne 1
            aload 1 /* endpoint */
            ifnonnull 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 536
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         2: .line 539
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.movingEndpoints:Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 3
            goto 7
      StackMap locals: org.apache.cassandra.locator.TokenMetadata java.net.InetAddress top java.util.Iterator
      StackMap stack:
         3: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.utils.Pair
            astore 2 /* pair */
        start local 2 // org.apache.cassandra.utils.Pair pair
         4: .line 541
            aload 2 /* pair */
            getfield org.apache.cassandra.utils.Pair.right:Ljava/lang/Object;
            checkcast java.net.InetAddress
            aload 1 /* endpoint */
            invokevirtual java.net.InetAddress.equals:(Ljava/lang/Object;)Z
            ifeq 7
         5: .line 543
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.movingEndpoints:Ljava/util/Set;
            aload 2 /* pair */
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
         6: .line 544
            goto 8
        end local 2 // org.apache.cassandra.utils.Pair pair
         7: .line 539
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 3
         8: .line 548
      StackMap locals: org.apache.cassandra.locator.TokenMetadata java.net.InetAddress
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.invalidateCachedRings:()V
         9: .line 549
            goto 13
        10: .line 551
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 4
        11: .line 552
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        12: .line 553
            aload 4
            athrow
        13: .line 552
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        14: .line 554
            return
        end local 1 // java.net.InetAddress endpoint
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   15     0      this  Lorg/apache/cassandra/locator/TokenMetadata;
            0   15     1  endpoint  Ljava/net/InetAddress;
            4    7     2      pair  Lorg/apache/cassandra/utils/Pair<Lorg/apache/cassandra/dht/Token;Ljava/net/InetAddress;>;
      Exception table:
        from    to  target  type
           2    10      10  any
    MethodParameters:
          Name  Flags
      endpoint  

  public java.util.Collection<org.apache.cassandra.dht.Token> getTokens(java.net.InetAddress);
    descriptor: (Ljava/net/InetAddress;)Ljava/util/Collection;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=2
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // java.net.InetAddress endpoint
         0: .line 558
            getstatic org.apache.cassandra.locator.TokenMetadata.$assertionsDisabled:Z
            ifne 1
            aload 1 /* endpoint */
            ifnonnull 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 559
      StackMap locals:
      StackMap stack:
            getstatic org.apache.cassandra.locator.TokenMetadata.$assertionsDisabled:Z
            ifne 2
            aload 0 /* this */
            aload 1 /* endpoint */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.isMember:(Ljava/net/InetAddress;)Z
            ifne 2
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         2: .line 561
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         3: .line 564
            new java.util.ArrayList
            dup
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.tokenToEndpointMap:Lorg/apache/cassandra/utils/BiMultiValMap;
            invokevirtual org.apache.cassandra.utils.BiMultiValMap.inverse:()Lcom/google/common/collect/Multimap;
            aload 1 /* endpoint */
            invokeinterface com.google.common.collect.Multimap.get:(Ljava/lang/Object;)Ljava/util/Collection;
            invokespecial java.util.ArrayList.<init>:(Ljava/util/Collection;)V
            astore 3
         4: .line 568
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         5: .line 564
            aload 3
            areturn
         6: .line 567
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 2
         7: .line 568
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         8: .line 569
            aload 2
            athrow
        end local 1 // java.net.InetAddress endpoint
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    9     0      this  Lorg/apache/cassandra/locator/TokenMetadata;
            0    9     1  endpoint  Ljava/net/InetAddress;
      Exception table:
        from    to  target  type
           3     4       6  any
    Signature: (Ljava/net/InetAddress;)Ljava/util/Collection<Lorg/apache/cassandra/dht/Token;>;
    MethodParameters:
          Name  Flags
      endpoint  

  public org.apache.cassandra.dht.Token getToken(java.net.InetAddress);
    descriptor: (Ljava/net/InetAddress;)Lorg/apache/cassandra/dht/Token;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // java.net.InetAddress endpoint
         0: .line 575
            aload 0 /* this */
            aload 1 /* endpoint */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.getTokens:(Ljava/net/InetAddress;)Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Token
            areturn
        end local 1 // java.net.InetAddress endpoint
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    1     0      this  Lorg/apache/cassandra/locator/TokenMetadata;
            0    1     1  endpoint  Ljava/net/InetAddress;
    RuntimeVisibleAnnotations: 
      java.lang.Deprecated()
    MethodParameters:
          Name  Flags
      endpoint  

  public boolean isMember(java.net.InetAddress);
    descriptor: (Ljava/net/InetAddress;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // java.net.InetAddress endpoint
         0: .line 580
            getstatic org.apache.cassandra.locator.TokenMetadata.$assertionsDisabled:Z
            ifne 1
            aload 1 /* endpoint */
            ifnonnull 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 582
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         2: .line 585
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.tokenToEndpointMap:Lorg/apache/cassandra/utils/BiMultiValMap;
            invokevirtual org.apache.cassandra.utils.BiMultiValMap.inverse:()Lcom/google/common/collect/Multimap;
            aload 1 /* endpoint */
            invokeinterface com.google.common.collect.Multimap.containsKey:(Ljava/lang/Object;)Z
            istore 3
         3: .line 589
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         4: .line 585
            iload 3
            ireturn
         5: .line 588
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 2
         6: .line 589
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         7: .line 590
            aload 2
            athrow
        end local 1 // java.net.InetAddress endpoint
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    8     0      this  Lorg/apache/cassandra/locator/TokenMetadata;
            0    8     1  endpoint  Ljava/net/InetAddress;
      Exception table:
        from    to  target  type
           2     3       5  any
    MethodParameters:
          Name  Flags
      endpoint  

  public boolean isLeaving(java.net.InetAddress);
    descriptor: (Ljava/net/InetAddress;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // java.net.InetAddress endpoint
         0: .line 595
            getstatic org.apache.cassandra.locator.TokenMetadata.$assertionsDisabled:Z
            ifne 1
            aload 1 /* endpoint */
            ifnonnull 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 597
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         2: .line 600
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.leavingEndpoints:Ljava/util/Set;
            aload 1 /* endpoint */
            invokeinterface java.util.Set.contains:(Ljava/lang/Object;)Z
            istore 3
         3: .line 604
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         4: .line 600
            iload 3
            ireturn
         5: .line 603
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 2
         6: .line 604
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         7: .line 605
            aload 2
            athrow
        end local 1 // java.net.InetAddress endpoint
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    8     0      this  Lorg/apache/cassandra/locator/TokenMetadata;
            0    8     1  endpoint  Ljava/net/InetAddress;
      Exception table:
        from    to  target  type
           2     3       5  any
    MethodParameters:
          Name  Flags
      endpoint  

  public boolean isMoving(java.net.InetAddress);
    descriptor: (Ljava/net/InetAddress;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=5, args_size=2
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // java.net.InetAddress endpoint
         0: .line 610
            getstatic org.apache.cassandra.locator.TokenMetadata.$assertionsDisabled:Z
            ifne 1
            aload 1 /* endpoint */
            ifnonnull 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 612
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         2: .line 615
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.movingEndpoints:Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 3
            goto 7
      StackMap locals: org.apache.cassandra.locator.TokenMetadata java.net.InetAddress top java.util.Iterator
      StackMap stack:
         3: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.utils.Pair
            astore 2 /* pair */
        start local 2 // org.apache.cassandra.utils.Pair pair
         4: .line 617
            aload 2 /* pair */
            getfield org.apache.cassandra.utils.Pair.right:Ljava/lang/Object;
            checkcast java.net.InetAddress
            aload 1 /* endpoint */
            invokevirtual java.net.InetAddress.equals:(Ljava/lang/Object;)Z
            ifeq 7
         5: .line 625
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         6: .line 618
            iconst_1
            ireturn
        end local 2 // org.apache.cassandra.utils.Pair pair
         7: .line 615
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 3
         8: .line 625
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         9: .line 621
            iconst_0
            ireturn
        10: .line 624
      StackMap locals: org.apache.cassandra.locator.TokenMetadata java.net.InetAddress
      StackMap stack: java.lang.Throwable
            astore 4
        11: .line 625
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        12: .line 626
            aload 4
            athrow
        end local 1 // java.net.InetAddress endpoint
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   13     0      this  Lorg/apache/cassandra/locator/TokenMetadata;
            0   13     1  endpoint  Ljava/net/InetAddress;
            4    7     2      pair  Lorg/apache/cassandra/utils/Pair<Lorg/apache/cassandra/dht/Token;Ljava/net/InetAddress;>;
      Exception table:
        from    to  target  type
           2     5      10  any
           7     8      10  any
    MethodParameters:
          Name  Flags
      endpoint  

  public org.apache.cassandra.locator.TokenMetadata cloneOnlyTokenMap();
    descriptor: ()Lorg/apache/cassandra/locator/TokenMetadata;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=3, args_size=1
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
         0: .line 637
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         1: .line 640
            new org.apache.cassandra.locator.TokenMetadata
            dup
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.tokenToEndpointMap:Lorg/apache/cassandra/utils/BiMultiValMap;
            aconst_null
            getstatic org.apache.cassandra.locator.TokenMetadata.inetaddressCmp:Ljava/util/Comparator;
            invokestatic org.apache.cassandra.utils.SortedBiMultiValMap.create:(Lorg/apache/cassandra/utils/BiMultiValMap;Ljava/util/Comparator;Ljava/util/Comparator;)Lorg/apache/cassandra/utils/SortedBiMultiValMap;
         2: .line 641
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.endpointToHostIdMap:Lcom/google/common/collect/BiMap;
            invokestatic com.google.common.collect.HashBiMap.create:(Ljava/util/Map;)Lcom/google/common/collect/HashBiMap;
         3: .line 642
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.topology:Lorg/apache/cassandra/locator/TokenMetadata$Topology;
         4: .line 643
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.partitioner:Lorg/apache/cassandra/dht/IPartitioner;
         5: .line 640
            invokespecial org.apache.cassandra.locator.TokenMetadata.<init>:(Lorg/apache/cassandra/utils/BiMultiValMap;Lcom/google/common/collect/BiMap;Lorg/apache/cassandra/locator/TokenMetadata$Topology;Lorg/apache/cassandra/dht/IPartitioner;)V
            astore 2
         6: .line 647
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         7: .line 640
            aload 2
            areturn
         8: .line 646
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 1
         9: .line 647
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        10: .line 648
            aload 1
            athrow
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   11     0  this  Lorg/apache/cassandra/locator/TokenMetadata;
      Exception table:
        from    to  target  type
           1     6       8  any

  public org.apache.cassandra.locator.TokenMetadata cachedOnlyTokenMap();
    descriptor: ()Lorg/apache/cassandra/locator/TokenMetadata;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=1
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
         0: .line 660
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.cachedTokenMap:Ljava/util/concurrent/atomic/AtomicReference;
            invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
            checkcast org.apache.cassandra.locator.TokenMetadata
            astore 1 /* tm */
        start local 1 // org.apache.cassandra.locator.TokenMetadata tm
         1: .line 661
            aload 1 /* tm */
            ifnull 3
         2: .line 662
            aload 1 /* tm */
            areturn
         3: .line 665
      StackMap locals: org.apache.cassandra.locator.TokenMetadata
      StackMap stack:
            aload 0 /* this */
            dup
            astore 2
            monitorenter
         4: .line 667
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.cachedTokenMap:Ljava/util/concurrent/atomic/AtomicReference;
            invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
            checkcast org.apache.cassandra.locator.TokenMetadata
            dup
            astore 1 /* tm */
            ifnull 7
         5: .line 668
            aload 1 /* tm */
            aload 2
            monitorexit
         6: areturn
         7: .line 670
      StackMap locals: org.apache.cassandra.locator.TokenMetadata
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.cloneOnlyTokenMap:()Lorg/apache/cassandra/locator/TokenMetadata;
            astore 1 /* tm */
         8: .line 671
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.cachedTokenMap:Ljava/util/concurrent/atomic/AtomicReference;
            aload 1 /* tm */
            invokevirtual java.util.concurrent.atomic.AtomicReference.set:(Ljava/lang/Object;)V
         9: .line 672
            aload 1 /* tm */
            aload 2
            monitorexit
        10: areturn
        11: .line 665
      StackMap locals:
      StackMap stack: java.lang.Throwable
            aload 2
            monitorexit
        12: athrow
        end local 1 // org.apache.cassandra.locator.TokenMetadata tm
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   13     0  this  Lorg/apache/cassandra/locator/TokenMetadata;
            1   13     1    tm  Lorg/apache/cassandra/locator/TokenMetadata;
      Exception table:
        from    to  target  type
           4     6      11  any
           7    10      11  any
          11    12      11  any

  public org.apache.cassandra.locator.TokenMetadata cloneAfterAllLeft();
    descriptor: ()Lorg/apache/cassandra/locator/TokenMetadata;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=1
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
         0: .line 684
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         1: .line 687
            aload 0 /* this */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.cloneOnlyTokenMap:()Lorg/apache/cassandra/locator/TokenMetadata;
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.leavingEndpoints:Ljava/util/Set;
            invokestatic org.apache.cassandra.locator.TokenMetadata.removeEndpoints:(Lorg/apache/cassandra/locator/TokenMetadata;Ljava/util/Set;)Lorg/apache/cassandra/locator/TokenMetadata;
            astore 2
         2: .line 691
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         3: .line 687
            aload 2
            areturn
         4: .line 690
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 1
         5: .line 691
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         6: .line 692
            aload 1
            athrow
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lorg/apache/cassandra/locator/TokenMetadata;
      Exception table:
        from    to  target  type
           1     2       4  any

  private static org.apache.cassandra.locator.TokenMetadata removeEndpoints(org.apache.cassandra.locator.TokenMetadata, java.util.Set<java.net.InetAddress>);
    descriptor: (Lorg/apache/cassandra/locator/TokenMetadata;Ljava/util/Set;)Lorg/apache/cassandra/locator/TokenMetadata;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // org.apache.cassandra.locator.TokenMetadata allLeftMetadata
        start local 1 // java.util.Set leavingEndpoints
         0: .line 697
            aload 1 /* leavingEndpoints */
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 3
            goto 3
      StackMap locals: org.apache.cassandra.locator.TokenMetadata java.util.Set top java.util.Iterator
      StackMap stack:
         1: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.net.InetAddress
            astore 2 /* endpoint */
        start local 2 // java.net.InetAddress endpoint
         2: .line 698
            aload 0 /* allLeftMetadata */
            aload 2 /* endpoint */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.removeEndpoint:(Ljava/net/InetAddress;)V
        end local 2 // java.net.InetAddress endpoint
         3: .line 697
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 1
         4: .line 700
            aload 0 /* allLeftMetadata */
            areturn
        end local 1 // java.util.Set leavingEndpoints
        end local 0 // org.apache.cassandra.locator.TokenMetadata allLeftMetadata
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0    5     0   allLeftMetadata  Lorg/apache/cassandra/locator/TokenMetadata;
            0    5     1  leavingEndpoints  Ljava/util/Set<Ljava/net/InetAddress;>;
            2    3     2          endpoint  Ljava/net/InetAddress;
    Signature: (Lorg/apache/cassandra/locator/TokenMetadata;Ljava/util/Set<Ljava/net/InetAddress;>;)Lorg/apache/cassandra/locator/TokenMetadata;
    MethodParameters:
                  Name  Flags
      allLeftMetadata   
      leavingEndpoints  

  public org.apache.cassandra.locator.TokenMetadata cloneAfterAllSettled();
    descriptor: ()Lorg/apache/cassandra/locator/TokenMetadata;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=6, args_size=1
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
         0: .line 711
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         1: .line 714
            aload 0 /* this */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.cloneOnlyTokenMap:()Lorg/apache/cassandra/locator/TokenMetadata;
            astore 1 /* metadata */
        start local 1 // org.apache.cassandra.locator.TokenMetadata metadata
         2: .line 716
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.leavingEndpoints:Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 3
            goto 5
      StackMap locals: org.apache.cassandra.locator.TokenMetadata org.apache.cassandra.locator.TokenMetadata top java.util.Iterator
      StackMap stack:
         3: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.net.InetAddress
            astore 2 /* endpoint */
        start local 2 // java.net.InetAddress endpoint
         4: .line 717
            aload 1 /* metadata */
            aload 2 /* endpoint */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.removeEndpoint:(Ljava/net/InetAddress;)V
        end local 2 // java.net.InetAddress endpoint
         5: .line 716
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 3
         6: .line 720
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.movingEndpoints:Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 3
            goto 9
      StackMap locals:
      StackMap stack:
         7: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.utils.Pair
            astore 2 /* pair */
        start local 2 // org.apache.cassandra.utils.Pair pair
         8: .line 721
            aload 1 /* metadata */
            aload 2 /* pair */
            getfield org.apache.cassandra.utils.Pair.left:Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Token
            aload 2 /* pair */
            getfield org.apache.cassandra.utils.Pair.right:Ljava/lang/Object;
            checkcast java.net.InetAddress
            invokevirtual org.apache.cassandra.locator.TokenMetadata.updateNormalToken:(Lorg/apache/cassandra/dht/Token;Ljava/net/InetAddress;)V
        end local 2 // org.apache.cassandra.utils.Pair pair
         9: .line 720
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 7
        10: .line 723
            aload 1 /* metadata */
            astore 5
        11: .line 727
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        12: .line 723
            aload 5
            areturn
        end local 1 // org.apache.cassandra.locator.TokenMetadata metadata
        13: .line 726
      StackMap locals: org.apache.cassandra.locator.TokenMetadata
      StackMap stack: java.lang.Throwable
            astore 4
        14: .line 727
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        15: .line 728
            aload 4
            athrow
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   16     0      this  Lorg/apache/cassandra/locator/TokenMetadata;
            2   13     1  metadata  Lorg/apache/cassandra/locator/TokenMetadata;
            4    5     2  endpoint  Ljava/net/InetAddress;
            8    9     2      pair  Lorg/apache/cassandra/utils/Pair<Lorg/apache/cassandra/dht/Token;Ljava/net/InetAddress;>;
      Exception table:
        from    to  target  type
           1    11      13  any

  public java.net.InetAddress getEndpoint(org.apache.cassandra.dht.Token);
    descriptor: (Lorg/apache/cassandra/dht/Token;)Ljava/net/InetAddress;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // org.apache.cassandra.dht.Token token
         0: .line 733
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         1: .line 736
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.tokenToEndpointMap:Lorg/apache/cassandra/utils/BiMultiValMap;
            aload 1 /* token */
            invokevirtual org.apache.cassandra.utils.BiMultiValMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.net.InetAddress
            astore 3
         2: .line 740
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         3: .line 736
            aload 3
            areturn
         4: .line 739
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 2
         5: .line 740
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         6: .line 741
            aload 2
            athrow
        end local 1 // org.apache.cassandra.dht.Token token
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    7     0   this  Lorg/apache/cassandra/locator/TokenMetadata;
            0    7     1  token  Lorg/apache/cassandra/dht/Token;
      Exception table:
        from    to  target  type
           1     2       4  any
    MethodParameters:
       Name  Flags
      token  

  public java.util.Collection<org.apache.cassandra.dht.Range<org.apache.cassandra.dht.Token>> getPrimaryRangesFor(java.util.Collection<org.apache.cassandra.dht.Token>);
    descriptor: (Ljava/util/Collection;)Ljava/util/Collection;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=5, args_size=2
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // java.util.Collection tokens
         0: .line 746
            new java.util.ArrayList
            dup
            aload 1 /* tokens */
            invokeinterface java.util.Collection.size:()I
            invokespecial java.util.ArrayList.<init>:(I)V
            astore 2 /* ranges */
        start local 2 // java.util.Collection ranges
         1: .line 747
            aload 1 /* tokens */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 4
            goto 4
      StackMap locals: org.apache.cassandra.locator.TokenMetadata java.util.Collection java.util.Collection top java.util.Iterator
      StackMap stack:
         2: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Token
            astore 3 /* right */
        start local 3 // org.apache.cassandra.dht.Token right
         3: .line 748
            aload 2 /* ranges */
            new org.apache.cassandra.dht.Range
            dup
            aload 0 /* this */
            aload 3 /* right */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.getPredecessor:(Lorg/apache/cassandra/dht/Token;)Lorg/apache/cassandra/dht/Token;
            aload 3 /* right */
            invokespecial org.apache.cassandra.dht.Range.<init>:(Lorg/apache/cassandra/dht/RingPosition;Lorg/apache/cassandra/dht/RingPosition;)V
            invokeinterface java.util.Collection.add:(Ljava/lang/Object;)Z
            pop
        end local 3 // org.apache.cassandra.dht.Token right
         4: .line 747
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 749
            aload 2 /* ranges */
            areturn
        end local 2 // java.util.Collection ranges
        end local 1 // java.util.Collection tokens
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    6     0    this  Lorg/apache/cassandra/locator/TokenMetadata;
            0    6     1  tokens  Ljava/util/Collection<Lorg/apache/cassandra/dht/Token;>;
            1    6     2  ranges  Ljava/util/Collection<Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;>;
            3    4     3   right  Lorg/apache/cassandra/dht/Token;
    Signature: (Ljava/util/Collection<Lorg/apache/cassandra/dht/Token;>;)Ljava/util/Collection<Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;>;
    MethodParameters:
        Name  Flags
      tokens  

  public org.apache.cassandra.dht.Range<org.apache.cassandra.dht.Token> getPrimaryRangeFor(org.apache.cassandra.dht.Token);
    descriptor: (Lorg/apache/cassandra/dht/Token;)Lorg/apache/cassandra/dht/Range;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=2, args_size=2
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // org.apache.cassandra.dht.Token right
         0: .line 755
            aload 0 /* this */
            iconst_1
            anewarray org.apache.cassandra.dht.Token
            dup
            iconst_0
            aload 1 /* right */
            aastore
            invokestatic java.util.Arrays.asList:([Ljava/lang/Object;)Ljava/util/List;
            invokevirtual org.apache.cassandra.locator.TokenMetadata.getPrimaryRangesFor:(Ljava/util/Collection;)Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Range
            areturn
        end local 1 // org.apache.cassandra.dht.Token right
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    1     0   this  Lorg/apache/cassandra/locator/TokenMetadata;
            0    1     1  right  Lorg/apache/cassandra/dht/Token;
    Signature: (Lorg/apache/cassandra/dht/Token;)Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;
    RuntimeVisibleAnnotations: 
      java.lang.Deprecated()
    MethodParameters:
       Name  Flags
      right  

  public java.util.ArrayList<org.apache.cassandra.dht.Token> sortedTokens();
    descriptor: ()Ljava/util/ArrayList;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
         0: .line 760
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.sortedTokens:Ljava/util/ArrayList;
            areturn
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/locator/TokenMetadata;
    Signature: ()Ljava/util/ArrayList<Lorg/apache/cassandra/dht/Token;>;

  public com.google.common.collect.Multimap<org.apache.cassandra.dht.Range<org.apache.cassandra.dht.Token>, java.net.InetAddress> getPendingRangesMM(java.lang.String);
    descriptor: (Ljava/lang/String;)Lcom/google/common/collect/Multimap;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=9, args_size=2
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // java.lang.String keyspaceName
         0: .line 765
            invokestatic com.google.common.collect.HashMultimap.create:()Lcom/google/common/collect/HashMultimap;
            astore 2 /* map */
        start local 2 // com.google.common.collect.Multimap map
         1: .line 766
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.pendingRanges:Ljava/util/concurrent/ConcurrentMap;
            aload 1 /* keyspaceName */
            invokeinterface java.util.concurrent.ConcurrentMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.cassandra.locator.PendingRangeMaps
            astore 3 /* pendingRangeMaps */
        start local 3 // org.apache.cassandra.locator.PendingRangeMaps pendingRangeMaps
         2: .line 768
            aload 3 /* pendingRangeMaps */
            ifnull 11
         3: .line 770
            aload 3 /* pendingRangeMaps */
            invokevirtual org.apache.cassandra.locator.PendingRangeMaps.iterator:()Ljava/util/Iterator;
            astore 5
            goto 10
      StackMap locals: org.apache.cassandra.locator.TokenMetadata java.lang.String com.google.common.collect.Multimap org.apache.cassandra.locator.PendingRangeMaps top java.util.Iterator
      StackMap stack:
         4: aload 5
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 4 /* entry */
        start local 4 // java.util.Map$Entry entry
         5: .line 772
            aload 4 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Range
            astore 6 /* range */
        start local 6 // org.apache.cassandra.dht.Range range
         6: .line 773
            aload 4 /* entry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast java.util.List
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 8
            goto 9
      StackMap locals: org.apache.cassandra.locator.TokenMetadata java.lang.String com.google.common.collect.Multimap org.apache.cassandra.locator.PendingRangeMaps java.util.Map$Entry java.util.Iterator org.apache.cassandra.dht.Range top java.util.Iterator
      StackMap stack:
         7: aload 8
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.net.InetAddress
            astore 7 /* address */
        start local 7 // java.net.InetAddress address
         8: .line 775
            aload 2 /* map */
            aload 6 /* range */
            aload 7 /* address */
            invokeinterface com.google.common.collect.Multimap.put:(Ljava/lang/Object;Ljava/lang/Object;)Z
            pop
        end local 7 // java.net.InetAddress address
         9: .line 773
      StackMap locals:
      StackMap stack:
            aload 8
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 7
        end local 6 // org.apache.cassandra.dht.Range range
        end local 4 // java.util.Map$Entry entry
        10: .line 770
      StackMap locals: org.apache.cassandra.locator.TokenMetadata java.lang.String com.google.common.collect.Multimap org.apache.cassandra.locator.PendingRangeMaps top java.util.Iterator
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 4
        11: .line 780
      StackMap locals: org.apache.cassandra.locator.TokenMetadata java.lang.String com.google.common.collect.Multimap org.apache.cassandra.locator.PendingRangeMaps
      StackMap stack:
            aload 2 /* map */
            areturn
        end local 3 // org.apache.cassandra.locator.PendingRangeMaps pendingRangeMaps
        end local 2 // com.google.common.collect.Multimap map
        end local 1 // java.lang.String keyspaceName
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   12     0              this  Lorg/apache/cassandra/locator/TokenMetadata;
            0   12     1      keyspaceName  Ljava/lang/String;
            1   12     2               map  Lcom/google/common/collect/Multimap<Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;Ljava/net/InetAddress;>;
            2   12     3  pendingRangeMaps  Lorg/apache/cassandra/locator/PendingRangeMaps;
            5   10     4             entry  Ljava/util/Map$Entry<Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;Ljava/util/List<Ljava/net/InetAddress;>;>;
            6   10     6             range  Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;
            8    9     7           address  Ljava/net/InetAddress;
    Signature: (Ljava/lang/String;)Lcom/google/common/collect/Multimap<Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;Ljava/net/InetAddress;>;
    MethodParameters:
              Name  Flags
      keyspaceName  

  public org.apache.cassandra.locator.PendingRangeMaps getPendingRanges(java.lang.String);
    descriptor: (Ljava/lang/String;)Lorg/apache/cassandra/locator/PendingRangeMaps;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // java.lang.String keyspaceName
         0: .line 786
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.pendingRanges:Ljava/util/concurrent/ConcurrentMap;
            aload 1 /* keyspaceName */
            invokeinterface java.util.concurrent.ConcurrentMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.cassandra.locator.PendingRangeMaps
            areturn
        end local 1 // java.lang.String keyspaceName
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    1     0          this  Lorg/apache/cassandra/locator/TokenMetadata;
            0    1     1  keyspaceName  Ljava/lang/String;
    MethodParameters:
              Name  Flags
      keyspaceName  

  public java.util.List<org.apache.cassandra.dht.Range<org.apache.cassandra.dht.Token>> getPendingRanges(java.lang.String, java.net.InetAddress);
    descriptor: (Ljava/lang/String;Ljava/net/InetAddress;)Ljava/util/List;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=6, args_size=3
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // java.lang.String keyspaceName
        start local 2 // java.net.InetAddress endpoint
         0: .line 791
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 3 /* ranges */
        start local 3 // java.util.List ranges
         1: .line 792
            aload 0 /* this */
            aload 1 /* keyspaceName */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.getPendingRangesMM:(Ljava/lang/String;)Lcom/google/common/collect/Multimap;
            invokeinterface com.google.common.collect.Multimap.entries:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 5
            goto 5
      StackMap locals: org.apache.cassandra.locator.TokenMetadata java.lang.String java.net.InetAddress java.util.List top java.util.Iterator
      StackMap stack:
         2: aload 5
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 4 /* entry */
        start local 4 // java.util.Map$Entry entry
         3: .line 794
            aload 4 /* entry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast java.net.InetAddress
            aload 2 /* endpoint */
            invokevirtual java.net.InetAddress.equals:(Ljava/lang/Object;)Z
            ifeq 5
         4: .line 796
            aload 3 /* ranges */
            aload 4 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Range
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 4 // java.util.Map$Entry entry
         5: .line 792
      StackMap locals:
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         6: .line 799
            aload 3 /* ranges */
            areturn
        end local 3 // java.util.List ranges
        end local 2 // java.net.InetAddress endpoint
        end local 1 // java.lang.String keyspaceName
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    7     0          this  Lorg/apache/cassandra/locator/TokenMetadata;
            0    7     1  keyspaceName  Ljava/lang/String;
            0    7     2      endpoint  Ljava/net/InetAddress;
            1    7     3        ranges  Ljava/util/List<Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;>;
            3    5     4         entry  Ljava/util/Map$Entry<Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;Ljava/net/InetAddress;>;
    Signature: (Ljava/lang/String;Ljava/net/InetAddress;)Ljava/util/List<Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;>;
    MethodParameters:
              Name  Flags
      keyspaceName  
      endpoint      

  public void calculatePendingRanges(org.apache.cassandra.locator.AbstractReplicationStrategy, java.lang.String);
    descriptor: (Lorg/apache/cassandra/locator/AbstractReplicationStrategy;Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=12, args_size=3
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // org.apache.cassandra.locator.AbstractReplicationStrategy strategy
        start local 2 // java.lang.String keyspaceName
         0: .line 828
            invokestatic java.lang.System.currentTimeMillis:()J
            lstore 3 /* startedAt */
        start local 3 // long startedAt
         1: .line 829
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.pendingRanges:Ljava/util/concurrent/ConcurrentMap;
            dup
            astore 5
            monitorenter
         2: .line 837
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         3: .line 840
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.bootstrapTokens:Lorg/apache/cassandra/utils/BiMultiValMap;
            invokevirtual org.apache.cassandra.utils.BiMultiValMap.isEmpty:()Z
            ifeq 10
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.leavingEndpoints:Ljava/util/Set;
            invokeinterface java.util.Set.isEmpty:()Z
            ifeq 10
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.movingEndpoints:Ljava/util/Set;
            invokeinterface java.util.Set.isEmpty:()Z
            ifeq 10
         4: .line 842
            getstatic org.apache.cassandra.locator.TokenMetadata.logger:Lorg/slf4j/Logger;
            invokeinterface org.slf4j.Logger.isTraceEnabled:()Z
            ifeq 6
         5: .line 843
            getstatic org.apache.cassandra.locator.TokenMetadata.logger:Lorg/slf4j/Logger;
            ldc "No bootstrapping, leaving or moving nodes -> empty pending ranges for {}"
            aload 2 /* keyspaceName */
            invokeinterface org.slf4j.Logger.trace:(Ljava/lang/String;Ljava/lang/Object;)V
         6: .line 845
      StackMap locals: long java.util.concurrent.ConcurrentMap
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.pendingRanges:Ljava/util/concurrent/ConcurrentMap;
            aload 2 /* keyspaceName */
            new org.apache.cassandra.locator.PendingRangeMaps
            dup
            invokespecial org.apache.cassandra.locator.PendingRangeMaps.<init>:()V
            invokeinterface java.util.concurrent.ConcurrentMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         7: .line 860
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         8: .line 847
            aload 5
            monitorexit
         9: return
        10: .line 850
      StackMap locals:
      StackMap stack:
            getstatic org.apache.cassandra.locator.TokenMetadata.logger:Lorg/slf4j/Logger;
            invokeinterface org.slf4j.Logger.isDebugEnabled:()Z
            ifeq 12
        11: .line 851
            getstatic org.apache.cassandra.locator.TokenMetadata.logger:Lorg/slf4j/Logger;
            ldc "Starting pending range calculation for {}"
            aload 2 /* keyspaceName */
            invokeinterface org.slf4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Object;)V
        12: .line 853
      StackMap locals:
      StackMap stack:
            new org.apache.cassandra.utils.BiMultiValMap
            dup
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.bootstrapTokens:Lorg/apache/cassandra/utils/BiMultiValMap;
            invokespecial org.apache.cassandra.utils.BiMultiValMap.<init>:(Lorg/apache/cassandra/utils/BiMultiValMap;)V
            astore 6 /* bootstrapTokensClone */
        start local 6 // org.apache.cassandra.utils.BiMultiValMap bootstrapTokensClone
        13: .line 854
            new java.util.HashSet
            dup
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.leavingEndpoints:Ljava/util/Set;
            invokespecial java.util.HashSet.<init>:(Ljava/util/Collection;)V
            astore 7 /* leavingEndpointsClone */
        start local 7 // java.util.Set leavingEndpointsClone
        14: .line 855
            new java.util.HashSet
            dup
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.movingEndpoints:Ljava/util/Set;
            invokespecial java.util.HashSet.<init>:(Ljava/util/Collection;)V
            astore 8 /* movingEndpointsClone */
        start local 8 // java.util.Set movingEndpointsClone
        15: .line 856
            aload 0 /* this */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.cloneOnlyTokenMap:()Lorg/apache/cassandra/locator/TokenMetadata;
            astore 9 /* metadata */
        start local 9 // org.apache.cassandra.locator.TokenMetadata metadata
        16: .line 857
            goto 20
        end local 9 // org.apache.cassandra.locator.TokenMetadata metadata
        end local 8 // java.util.Set movingEndpointsClone
        end local 7 // java.util.Set leavingEndpointsClone
        end local 6 // org.apache.cassandra.utils.BiMultiValMap bootstrapTokensClone
        17: .line 859
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 10
        18: .line 860
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        19: .line 861
            aload 10
            athrow
        start local 6 // org.apache.cassandra.utils.BiMultiValMap bootstrapTokensClone
        start local 7 // java.util.Set leavingEndpointsClone
        start local 8 // java.util.Set movingEndpointsClone
        start local 9 // org.apache.cassandra.locator.TokenMetadata metadata
        20: .line 860
      StackMap locals: org.apache.cassandra.locator.TokenMetadata org.apache.cassandra.locator.AbstractReplicationStrategy java.lang.String long java.util.concurrent.ConcurrentMap org.apache.cassandra.utils.BiMultiValMap java.util.Set java.util.Set org.apache.cassandra.locator.TokenMetadata
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        21: .line 863
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.pendingRanges:Ljava/util/concurrent/ConcurrentMap;
            aload 2 /* keyspaceName */
            aload 1 /* strategy */
            aload 9 /* metadata */
            aload 6 /* bootstrapTokensClone */
        22: .line 864
            aload 7 /* leavingEndpointsClone */
            aload 8 /* movingEndpointsClone */
        23: .line 863
            invokestatic org.apache.cassandra.locator.TokenMetadata.calculatePendingRanges:(Lorg/apache/cassandra/locator/AbstractReplicationStrategy;Lorg/apache/cassandra/locator/TokenMetadata;Lorg/apache/cassandra/utils/BiMultiValMap;Ljava/util/Set;Ljava/util/Set;)Lorg/apache/cassandra/locator/PendingRangeMaps;
            invokeinterface java.util.concurrent.ConcurrentMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        24: .line 865
            invokestatic java.lang.System.currentTimeMillis:()J
            lload 3 /* startedAt */
            lsub
            lstore 10 /* took */
        start local 10 // long took
        25: .line 867
            getstatic org.apache.cassandra.locator.TokenMetadata.logger:Lorg/slf4j/Logger;
            invokeinterface org.slf4j.Logger.isDebugEnabled:()Z
            ifeq 27
        26: .line 868
            getstatic org.apache.cassandra.locator.TokenMetadata.logger:Lorg/slf4j/Logger;
            ldc "Pending range calculation for {} completed (took: {}ms)"
            aload 2 /* keyspaceName */
            lload 10 /* took */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            invokeinterface org.slf4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
        27: .line 869
      StackMap locals: long
      StackMap stack:
            getstatic org.apache.cassandra.locator.TokenMetadata.logger:Lorg/slf4j/Logger;
            invokeinterface org.slf4j.Logger.isTraceEnabled:()Z
            ifeq 31
        28: .line 870
            getstatic org.apache.cassandra.locator.TokenMetadata.logger:Lorg/slf4j/Logger;
            ldc "Calculated pending ranges for {}:\n{}"
            aload 2 /* keyspaceName */
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.pendingRanges:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.isEmpty:()Z
            ifeq 29
            ldc "<empty>"
            goto 30
      StackMap locals: org.apache.cassandra.locator.TokenMetadata org.apache.cassandra.locator.AbstractReplicationStrategy java.lang.String long java.util.concurrent.ConcurrentMap org.apache.cassandra.utils.BiMultiValMap java.util.Set java.util.Set org.apache.cassandra.locator.TokenMetadata long
      StackMap stack: org.slf4j.Logger java.lang.String java.lang.String
        29: aload 0 /* this */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.printPendingRanges:()Ljava/lang/String;
      StackMap locals: org.apache.cassandra.locator.TokenMetadata org.apache.cassandra.locator.AbstractReplicationStrategy java.lang.String long java.util.concurrent.ConcurrentMap org.apache.cassandra.utils.BiMultiValMap java.util.Set java.util.Set org.apache.cassandra.locator.TokenMetadata long
      StackMap stack: org.slf4j.Logger java.lang.String java.lang.String java.lang.String
        30: invokeinterface org.slf4j.Logger.trace:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
        end local 10 // long took
        end local 9 // org.apache.cassandra.locator.TokenMetadata metadata
        end local 8 // java.util.Set movingEndpointsClone
        end local 7 // java.util.Set leavingEndpointsClone
        end local 6 // org.apache.cassandra.utils.BiMultiValMap bootstrapTokensClone
        31: .line 829
      StackMap locals: org.apache.cassandra.locator.TokenMetadata org.apache.cassandra.locator.AbstractReplicationStrategy java.lang.String long java.util.concurrent.ConcurrentMap
      StackMap stack:
            aload 5
            monitorexit
        32: goto 35
      StackMap locals:
      StackMap stack: java.lang.Throwable
        33: aload 5
            monitorexit
        34: athrow
        35: .line 872
      StackMap locals:
      StackMap stack:
            return
        end local 3 // long startedAt
        end local 2 // java.lang.String keyspaceName
        end local 1 // org.apache.cassandra.locator.AbstractReplicationStrategy strategy
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot                   Name  Signature
            0   36     0                   this  Lorg/apache/cassandra/locator/TokenMetadata;
            0   36     1               strategy  Lorg/apache/cassandra/locator/AbstractReplicationStrategy;
            0   36     2           keyspaceName  Ljava/lang/String;
            1   36     3              startedAt  J
           13   17     6   bootstrapTokensClone  Lorg/apache/cassandra/utils/BiMultiValMap<Lorg/apache/cassandra/dht/Token;Ljava/net/InetAddress;>;
           20   31     6   bootstrapTokensClone  Lorg/apache/cassandra/utils/BiMultiValMap<Lorg/apache/cassandra/dht/Token;Ljava/net/InetAddress;>;
           14   17     7  leavingEndpointsClone  Ljava/util/Set<Ljava/net/InetAddress;>;
           20   31     7  leavingEndpointsClone  Ljava/util/Set<Ljava/net/InetAddress;>;
           15   17     8   movingEndpointsClone  Ljava/util/Set<Lorg/apache/cassandra/utils/Pair<Lorg/apache/cassandra/dht/Token;Ljava/net/InetAddress;>;>;
           20   31     8   movingEndpointsClone  Ljava/util/Set<Lorg/apache/cassandra/utils/Pair<Lorg/apache/cassandra/dht/Token;Ljava/net/InetAddress;>;>;
           16   17     9               metadata  Lorg/apache/cassandra/locator/TokenMetadata;
           20   31     9               metadata  Lorg/apache/cassandra/locator/TokenMetadata;
           25   31    10                   took  J
      Exception table:
        from    to  target  type
           3     7      17  any
          10    17      17  any
           2     9      33  any
          10    32      33  any
          33    34      33  any
    MethodParameters:
              Name  Flags
      strategy      
      keyspaceName  

  private static org.apache.cassandra.locator.PendingRangeMaps calculatePendingRanges(org.apache.cassandra.locator.AbstractReplicationStrategy, org.apache.cassandra.locator.TokenMetadata, org.apache.cassandra.utils.BiMultiValMap<org.apache.cassandra.dht.Token, java.net.InetAddress>, java.util.Set<java.net.InetAddress>, java.util.Set<org.apache.cassandra.utils.Pair<org.apache.cassandra.dht.Token, java.net.InetAddress>>);
    descriptor: (Lorg/apache/cassandra/locator/AbstractReplicationStrategy;Lorg/apache/cassandra/locator/TokenMetadata;Lorg/apache/cassandra/utils/BiMultiValMap;Ljava/util/Set;Ljava/util/Set;)Lorg/apache/cassandra/locator/PendingRangeMaps;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=27, args_size=5
        start local 0 // org.apache.cassandra.locator.AbstractReplicationStrategy strategy
        start local 1 // org.apache.cassandra.locator.TokenMetadata metadata
        start local 2 // org.apache.cassandra.utils.BiMultiValMap bootstrapTokens
        start local 3 // java.util.Set leavingEndpoints
        start local 4 // java.util.Set movingEndpoints
         0: .line 883
            new org.apache.cassandra.locator.PendingRangeMaps
            dup
            invokespecial org.apache.cassandra.locator.PendingRangeMaps.<init>:()V
            astore 5 /* newPendingRanges */
        start local 5 // org.apache.cassandra.locator.PendingRangeMaps newPendingRanges
         1: .line 885
            aload 0 /* strategy */
            aload 1 /* metadata */
            invokevirtual org.apache.cassandra.locator.AbstractReplicationStrategy.getAddressRanges:(Lorg/apache/cassandra/locator/TokenMetadata;)Lcom/google/common/collect/Multimap;
            astore 6 /* addressRanges */
        start local 6 // com.google.common.collect.Multimap addressRanges
         2: .line 888
            aload 1 /* metadata */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.cloneOnlyTokenMap:()Lorg/apache/cassandra/locator/TokenMetadata;
            aload 3 /* leavingEndpoints */
            invokestatic org.apache.cassandra.locator.TokenMetadata.removeEndpoints:(Lorg/apache/cassandra/locator/TokenMetadata;Ljava/util/Set;)Lorg/apache/cassandra/locator/TokenMetadata;
            astore 7 /* allLeftMetadata */
        start local 7 // org.apache.cassandra.locator.TokenMetadata allLeftMetadata
         3: .line 891
            new java.util.HashSet
            dup
            invokespecial java.util.HashSet.<init>:()V
            astore 8 /* affectedRanges */
        start local 8 // java.util.Set affectedRanges
         4: .line 892
            aload 3 /* leavingEndpoints */
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 10
            goto 7
      StackMap locals: org.apache.cassandra.locator.AbstractReplicationStrategy org.apache.cassandra.locator.TokenMetadata org.apache.cassandra.utils.BiMultiValMap java.util.Set java.util.Set org.apache.cassandra.locator.PendingRangeMaps com.google.common.collect.Multimap org.apache.cassandra.locator.TokenMetadata java.util.Set top java.util.Iterator
      StackMap stack:
         5: aload 10
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.net.InetAddress
            astore 9 /* endpoint */
        start local 9 // java.net.InetAddress endpoint
         6: .line 893
            aload 8 /* affectedRanges */
            aload 6 /* addressRanges */
            aload 9 /* endpoint */
            invokeinterface com.google.common.collect.Multimap.get:(Ljava/lang/Object;)Ljava/util/Collection;
            invokeinterface java.util.Set.addAll:(Ljava/util/Collection;)Z
            pop
        end local 9 // java.net.InetAddress endpoint
         7: .line 892
      StackMap locals:
      StackMap stack:
            aload 10
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 5
         8: .line 897
            aload 8 /* affectedRanges */
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 10
            goto 16
      StackMap locals:
      StackMap stack:
         9: aload 10
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Range
            astore 9 /* range */
        start local 9 // org.apache.cassandra.dht.Range range
        10: .line 899
            aload 0 /* strategy */
            aload 9 /* range */
            getfield org.apache.cassandra.dht.Range.right:Lorg/apache/cassandra/dht/RingPosition;
            checkcast org.apache.cassandra.dht.Token
            aload 1 /* metadata */
            invokevirtual org.apache.cassandra.locator.AbstractReplicationStrategy.calculateNaturalEndpoints:(Lorg/apache/cassandra/dht/Token;Lorg/apache/cassandra/locator/TokenMetadata;)Ljava/util/List;
            invokestatic com.google.common.collect.ImmutableSet.copyOf:(Ljava/util/Collection;)Lcom/google/common/collect/ImmutableSet;
            astore 11 /* currentEndpoints */
        start local 11 // java.util.Set currentEndpoints
        11: .line 900
            aload 0 /* strategy */
            aload 9 /* range */
            getfield org.apache.cassandra.dht.Range.right:Lorg/apache/cassandra/dht/RingPosition;
            checkcast org.apache.cassandra.dht.Token
            aload 7 /* allLeftMetadata */
            invokevirtual org.apache.cassandra.locator.AbstractReplicationStrategy.calculateNaturalEndpoints:(Lorg/apache/cassandra/dht/Token;Lorg/apache/cassandra/locator/TokenMetadata;)Ljava/util/List;
            invokestatic com.google.common.collect.ImmutableSet.copyOf:(Ljava/util/Collection;)Lcom/google/common/collect/ImmutableSet;
            astore 12 /* newEndpoints */
        start local 12 // java.util.Set newEndpoints
        12: .line 901
            aload 12 /* newEndpoints */
            aload 11 /* currentEndpoints */
            invokestatic com.google.common.collect.Sets.difference:(Ljava/util/Set;Ljava/util/Set;)Lcom/google/common/collect/Sets$SetView;
            invokevirtual com.google.common.collect.Sets$SetView.iterator:()Ljava/util/Iterator;
            astore 14
            goto 15
      StackMap locals: org.apache.cassandra.locator.AbstractReplicationStrategy org.apache.cassandra.locator.TokenMetadata org.apache.cassandra.utils.BiMultiValMap java.util.Set java.util.Set org.apache.cassandra.locator.PendingRangeMaps com.google.common.collect.Multimap org.apache.cassandra.locator.TokenMetadata java.util.Set org.apache.cassandra.dht.Range java.util.Iterator java.util.Set java.util.Set top java.util.Iterator
      StackMap stack:
        13: aload 14
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.net.InetAddress
            astore 13 /* address */
        start local 13 // java.net.InetAddress address
        14: .line 903
            aload 5 /* newPendingRanges */
            aload 9 /* range */
            aload 13 /* address */
            invokevirtual org.apache.cassandra.locator.PendingRangeMaps.addPendingRange:(Lorg/apache/cassandra/dht/Range;Ljava/net/InetAddress;)V
        end local 13 // java.net.InetAddress address
        15: .line 901
      StackMap locals:
      StackMap stack:
            aload 14
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 13
        end local 12 // java.util.Set newEndpoints
        end local 11 // java.util.Set currentEndpoints
        end local 9 // org.apache.cassandra.dht.Range range
        16: .line 897
      StackMap locals: org.apache.cassandra.locator.AbstractReplicationStrategy org.apache.cassandra.locator.TokenMetadata org.apache.cassandra.utils.BiMultiValMap java.util.Set java.util.Set org.apache.cassandra.locator.PendingRangeMaps com.google.common.collect.Multimap org.apache.cassandra.locator.TokenMetadata java.util.Set top java.util.Iterator
      StackMap stack:
            aload 10
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 9
        17: .line 912
            aload 2 /* bootstrapTokens */
            invokevirtual org.apache.cassandra.utils.BiMultiValMap.inverse:()Lcom/google/common/collect/Multimap;
            astore 9 /* bootstrapAddresses */
        start local 9 // com.google.common.collect.Multimap bootstrapAddresses
        18: .line 913
            aload 9 /* bootstrapAddresses */
            invokeinterface com.google.common.collect.Multimap.keySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 11
            goto 27
      StackMap locals: org.apache.cassandra.locator.AbstractReplicationStrategy org.apache.cassandra.locator.TokenMetadata org.apache.cassandra.utils.BiMultiValMap java.util.Set java.util.Set org.apache.cassandra.locator.PendingRangeMaps com.google.common.collect.Multimap org.apache.cassandra.locator.TokenMetadata java.util.Set com.google.common.collect.Multimap top java.util.Iterator
      StackMap stack:
        19: aload 11
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.net.InetAddress
            astore 10 /* endpoint */
        start local 10 // java.net.InetAddress endpoint
        20: .line 915
            aload 9 /* bootstrapAddresses */
            aload 10 /* endpoint */
            invokeinterface com.google.common.collect.Multimap.get:(Ljava/lang/Object;)Ljava/util/Collection;
            astore 12 /* tokens */
        start local 12 // java.util.Collection tokens
        21: .line 917
            aload 7 /* allLeftMetadata */
            aload 12 /* tokens */
            aload 10 /* endpoint */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.updateNormalTokens:(Ljava/util/Collection;Ljava/net/InetAddress;)V
        22: .line 918
            aload 0 /* strategy */
            aload 7 /* allLeftMetadata */
            invokevirtual org.apache.cassandra.locator.AbstractReplicationStrategy.getAddressRanges:(Lorg/apache/cassandra/locator/TokenMetadata;)Lcom/google/common/collect/Multimap;
            aload 10 /* endpoint */
            invokeinterface com.google.common.collect.Multimap.get:(Ljava/lang/Object;)Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 14
            goto 25
      StackMap locals: org.apache.cassandra.locator.AbstractReplicationStrategy org.apache.cassandra.locator.TokenMetadata org.apache.cassandra.utils.BiMultiValMap java.util.Set java.util.Set org.apache.cassandra.locator.PendingRangeMaps com.google.common.collect.Multimap org.apache.cassandra.locator.TokenMetadata java.util.Set com.google.common.collect.Multimap java.net.InetAddress java.util.Iterator java.util.Collection top java.util.Iterator
      StackMap stack:
        23: aload 14
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Range
            astore 13 /* range */
        start local 13 // org.apache.cassandra.dht.Range range
        24: .line 920
            aload 5 /* newPendingRanges */
            aload 13 /* range */
            aload 10 /* endpoint */
            invokevirtual org.apache.cassandra.locator.PendingRangeMaps.addPendingRange:(Lorg/apache/cassandra/dht/Range;Ljava/net/InetAddress;)V
        end local 13 // org.apache.cassandra.dht.Range range
        25: .line 918
      StackMap locals:
      StackMap stack:
            aload 14
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 23
        26: .line 922
            aload 7 /* allLeftMetadata */
            aload 10 /* endpoint */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.removeEndpoint:(Ljava/net/InetAddress;)V
        end local 12 // java.util.Collection tokens
        end local 10 // java.net.InetAddress endpoint
        27: .line 913
      StackMap locals: org.apache.cassandra.locator.AbstractReplicationStrategy org.apache.cassandra.locator.TokenMetadata org.apache.cassandra.utils.BiMultiValMap java.util.Set java.util.Set org.apache.cassandra.locator.PendingRangeMaps com.google.common.collect.Multimap org.apache.cassandra.locator.TokenMetadata java.util.Set com.google.common.collect.Multimap top java.util.Iterator
      StackMap stack:
            aload 11
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 19
        28: .line 930
            aload 4 /* movingEndpoints */
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 11
            goto 61
      StackMap locals:
      StackMap stack:
        29: aload 11
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.utils.Pair
            astore 10 /* moving */
        start local 10 // org.apache.cassandra.utils.Pair moving
        30: .line 933
            new java.util.HashSet
            dup
            invokespecial java.util.HashSet.<init>:()V
            astore 12 /* moveAffectedRanges */
        start local 12 // java.util.Set moveAffectedRanges
        31: .line 934
            aload 10 /* moving */
            getfield org.apache.cassandra.utils.Pair.right:Ljava/lang/Object;
            checkcast java.net.InetAddress
            astore 13 /* endpoint */
        start local 13 // java.net.InetAddress endpoint
        32: .line 936
            aload 0 /* strategy */
            aload 7 /* allLeftMetadata */
            invokevirtual org.apache.cassandra.locator.AbstractReplicationStrategy.getAddressRanges:(Lorg/apache/cassandra/locator/TokenMetadata;)Lcom/google/common/collect/Multimap;
            aload 13 /* endpoint */
            invokeinterface com.google.common.collect.Multimap.get:(Ljava/lang/Object;)Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 15
            goto 35
      StackMap locals: org.apache.cassandra.locator.AbstractReplicationStrategy org.apache.cassandra.locator.TokenMetadata org.apache.cassandra.utils.BiMultiValMap java.util.Set java.util.Set org.apache.cassandra.locator.PendingRangeMaps com.google.common.collect.Multimap org.apache.cassandra.locator.TokenMetadata java.util.Set com.google.common.collect.Multimap org.apache.cassandra.utils.Pair java.util.Iterator java.util.Set java.net.InetAddress top java.util.Iterator
      StackMap stack:
        33: aload 15
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Range
            astore 14 /* range */
        start local 14 // org.apache.cassandra.dht.Range range
        34: .line 938
            aload 12 /* moveAffectedRanges */
            aload 14 /* range */
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
        end local 14 // org.apache.cassandra.dht.Range range
        35: .line 936
      StackMap locals:
      StackMap stack:
            aload 15
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 33
        36: .line 941
            aload 7 /* allLeftMetadata */
            aload 10 /* moving */
            getfield org.apache.cassandra.utils.Pair.left:Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Token
            aload 13 /* endpoint */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.updateNormalToken:(Lorg/apache/cassandra/dht/Token;Ljava/net/InetAddress;)V
        37: .line 943
            aload 0 /* strategy */
            aload 7 /* allLeftMetadata */
            invokevirtual org.apache.cassandra.locator.AbstractReplicationStrategy.getAddressRanges:(Lorg/apache/cassandra/locator/TokenMetadata;)Lcom/google/common/collect/Multimap;
            aload 13 /* endpoint */
            invokeinterface com.google.common.collect.Multimap.get:(Ljava/lang/Object;)Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 15
            goto 40
      StackMap locals:
      StackMap stack:
        38: aload 15
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Range
            astore 14 /* range */
        start local 14 // org.apache.cassandra.dht.Range range
        39: .line 945
            aload 12 /* moveAffectedRanges */
            aload 14 /* range */
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
        end local 14 // org.apache.cassandra.dht.Range range
        40: .line 943
      StackMap locals:
      StackMap stack:
            aload 15
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 38
        41: .line 948
            aload 12 /* moveAffectedRanges */
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 15
            goto 59
      StackMap locals:
      StackMap stack:
        42: aload 15
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Range
            astore 14 /* range */
        start local 14 // org.apache.cassandra.dht.Range range
        43: .line 950
            aload 0 /* strategy */
            aload 14 /* range */
            getfield org.apache.cassandra.dht.Range.right:Lorg/apache/cassandra/dht/RingPosition;
            checkcast org.apache.cassandra.dht.Token
            aload 1 /* metadata */
            invokevirtual org.apache.cassandra.locator.AbstractReplicationStrategy.calculateNaturalEndpoints:(Lorg/apache/cassandra/dht/Token;Lorg/apache/cassandra/locator/TokenMetadata;)Ljava/util/List;
            invokestatic com.google.common.collect.ImmutableSet.copyOf:(Ljava/util/Collection;)Lcom/google/common/collect/ImmutableSet;
            astore 16 /* currentEndpoints */
        start local 16 // java.util.Set currentEndpoints
        44: .line 951
            aload 0 /* strategy */
            aload 14 /* range */
            getfield org.apache.cassandra.dht.Range.right:Lorg/apache/cassandra/dht/RingPosition;
            checkcast org.apache.cassandra.dht.Token
            aload 7 /* allLeftMetadata */
            invokevirtual org.apache.cassandra.locator.AbstractReplicationStrategy.calculateNaturalEndpoints:(Lorg/apache/cassandra/dht/Token;Lorg/apache/cassandra/locator/TokenMetadata;)Ljava/util/List;
            invokestatic com.google.common.collect.ImmutableSet.copyOf:(Ljava/util/Collection;)Lcom/google/common/collect/ImmutableSet;
            astore 17 /* newEndpoints */
        start local 17 // java.util.Set newEndpoints
        45: .line 952
            aload 17 /* newEndpoints */
            aload 16 /* currentEndpoints */
            invokestatic com.google.common.collect.Sets.difference:(Ljava/util/Set;Ljava/util/Set;)Lcom/google/common/collect/Sets$SetView;
            astore 18 /* difference */
        start local 18 // java.util.Set difference
        46: .line 953
            aload 18 /* difference */
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 20
            goto 58
      StackMap locals: org.apache.cassandra.locator.AbstractReplicationStrategy org.apache.cassandra.locator.TokenMetadata org.apache.cassandra.utils.BiMultiValMap java.util.Set java.util.Set org.apache.cassandra.locator.PendingRangeMaps com.google.common.collect.Multimap org.apache.cassandra.locator.TokenMetadata java.util.Set com.google.common.collect.Multimap org.apache.cassandra.utils.Pair java.util.Iterator java.util.Set java.net.InetAddress org.apache.cassandra.dht.Range java.util.Iterator java.util.Set java.util.Set java.util.Set top java.util.Iterator
      StackMap stack:
        47: aload 20
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.net.InetAddress
            astore 19 /* address */
        start local 19 // java.net.InetAddress address
        48: .line 955
            aload 0 /* strategy */
            aload 7 /* allLeftMetadata */
            invokevirtual org.apache.cassandra.locator.AbstractReplicationStrategy.getAddressRanges:(Lorg/apache/cassandra/locator/TokenMetadata;)Lcom/google/common/collect/Multimap;
            aload 19 /* address */
            invokeinterface com.google.common.collect.Multimap.get:(Ljava/lang/Object;)Ljava/util/Collection;
            astore 21 /* newRanges */
        start local 21 // java.util.Collection newRanges
        49: .line 956
            aload 0 /* strategy */
            aload 1 /* metadata */
            invokevirtual org.apache.cassandra.locator.AbstractReplicationStrategy.getAddressRanges:(Lorg/apache/cassandra/locator/TokenMetadata;)Lcom/google/common/collect/Multimap;
            aload 19 /* address */
            invokeinterface com.google.common.collect.Multimap.get:(Ljava/lang/Object;)Ljava/util/Collection;
            astore 22 /* oldRanges */
        start local 22 // java.util.Collection oldRanges
        50: .line 958
            aload 21 /* newRanges */
            aload 22 /* oldRanges */
            invokeinterface java.util.Collection.removeAll:(Ljava/util/Collection;)Z
            pop
        51: .line 960
            aload 21 /* newRanges */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 24
            goto 57
      StackMap locals: org.apache.cassandra.locator.AbstractReplicationStrategy org.apache.cassandra.locator.TokenMetadata org.apache.cassandra.utils.BiMultiValMap java.util.Set java.util.Set org.apache.cassandra.locator.PendingRangeMaps com.google.common.collect.Multimap org.apache.cassandra.locator.TokenMetadata java.util.Set com.google.common.collect.Multimap org.apache.cassandra.utils.Pair java.util.Iterator java.util.Set java.net.InetAddress org.apache.cassandra.dht.Range java.util.Iterator java.util.Set java.util.Set java.util.Set java.net.InetAddress java.util.Iterator java.util.Collection java.util.Collection top java.util.Iterator
      StackMap stack:
        52: aload 24
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Range
            astore 23 /* newRange */
        start local 23 // org.apache.cassandra.dht.Range newRange
        53: .line 962
            aload 23 /* newRange */
            aload 22 /* oldRanges */
            invokevirtual org.apache.cassandra.dht.Range.subtractAll:(Ljava/util/Collection;)Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 26
            goto 56
      StackMap locals: org.apache.cassandra.locator.AbstractReplicationStrategy org.apache.cassandra.locator.TokenMetadata org.apache.cassandra.utils.BiMultiValMap java.util.Set java.util.Set org.apache.cassandra.locator.PendingRangeMaps com.google.common.collect.Multimap org.apache.cassandra.locator.TokenMetadata java.util.Set com.google.common.collect.Multimap org.apache.cassandra.utils.Pair java.util.Iterator java.util.Set java.net.InetAddress org.apache.cassandra.dht.Range java.util.Iterator java.util.Set java.util.Set java.util.Set java.net.InetAddress java.util.Iterator java.util.Collection java.util.Collection org.apache.cassandra.dht.Range java.util.Iterator top java.util.Iterator
      StackMap stack:
        54: aload 26
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Range
            astore 25 /* pendingRange */
        start local 25 // org.apache.cassandra.dht.Range pendingRange
        55: .line 964
            aload 5 /* newPendingRanges */
            aload 25 /* pendingRange */
            aload 19 /* address */
            invokevirtual org.apache.cassandra.locator.PendingRangeMaps.addPendingRange:(Lorg/apache/cassandra/dht/Range;Ljava/net/InetAddress;)V
        end local 25 // org.apache.cassandra.dht.Range pendingRange
        56: .line 962
      StackMap locals:
      StackMap stack:
            aload 26
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 54
        end local 23 // org.apache.cassandra.dht.Range newRange
        57: .line 960
      StackMap locals: org.apache.cassandra.locator.AbstractReplicationStrategy org.apache.cassandra.locator.TokenMetadata org.apache.cassandra.utils.BiMultiValMap java.util.Set java.util.Set org.apache.cassandra.locator.PendingRangeMaps com.google.common.collect.Multimap org.apache.cassandra.locator.TokenMetadata java.util.Set com.google.common.collect.Multimap org.apache.cassandra.utils.Pair java.util.Iterator java.util.Set java.net.InetAddress org.apache.cassandra.dht.Range java.util.Iterator java.util.Set java.util.Set java.util.Set java.net.InetAddress java.util.Iterator java.util.Collection java.util.Collection top java.util.Iterator
      StackMap stack:
            aload 24
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 52
        end local 22 // java.util.Collection oldRanges
        end local 21 // java.util.Collection newRanges
        end local 19 // java.net.InetAddress address
        58: .line 953
      StackMap locals: org.apache.cassandra.locator.AbstractReplicationStrategy org.apache.cassandra.locator.TokenMetadata org.apache.cassandra.utils.BiMultiValMap java.util.Set java.util.Set org.apache.cassandra.locator.PendingRangeMaps com.google.common.collect.Multimap org.apache.cassandra.locator.TokenMetadata java.util.Set com.google.common.collect.Multimap org.apache.cassandra.utils.Pair java.util.Iterator java.util.Set java.net.InetAddress org.apache.cassandra.dht.Range java.util.Iterator java.util.Set java.util.Set java.util.Set top java.util.Iterator
      StackMap stack:
            aload 20
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 47
        end local 18 // java.util.Set difference
        end local 17 // java.util.Set newEndpoints
        end local 16 // java.util.Set currentEndpoints
        end local 14 // org.apache.cassandra.dht.Range range
        59: .line 948
      StackMap locals: org.apache.cassandra.locator.AbstractReplicationStrategy org.apache.cassandra.locator.TokenMetadata org.apache.cassandra.utils.BiMultiValMap java.util.Set java.util.Set org.apache.cassandra.locator.PendingRangeMaps com.google.common.collect.Multimap org.apache.cassandra.locator.TokenMetadata java.util.Set com.google.common.collect.Multimap org.apache.cassandra.utils.Pair java.util.Iterator java.util.Set java.net.InetAddress top java.util.Iterator
      StackMap stack:
            aload 15
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 42
        60: .line 970
            aload 7 /* allLeftMetadata */
            aload 13 /* endpoint */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.removeEndpoint:(Ljava/net/InetAddress;)V
        end local 13 // java.net.InetAddress endpoint
        end local 12 // java.util.Set moveAffectedRanges
        end local 10 // org.apache.cassandra.utils.Pair moving
        61: .line 930
      StackMap locals: org.apache.cassandra.locator.AbstractReplicationStrategy org.apache.cassandra.locator.TokenMetadata org.apache.cassandra.utils.BiMultiValMap java.util.Set java.util.Set org.apache.cassandra.locator.PendingRangeMaps com.google.common.collect.Multimap org.apache.cassandra.locator.TokenMetadata java.util.Set com.google.common.collect.Multimap top java.util.Iterator
      StackMap stack:
            aload 11
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 29
        62: .line 973
            aload 5 /* newPendingRanges */
            areturn
        end local 9 // com.google.common.collect.Multimap bootstrapAddresses
        end local 8 // java.util.Set affectedRanges
        end local 7 // org.apache.cassandra.locator.TokenMetadata allLeftMetadata
        end local 6 // com.google.common.collect.Multimap addressRanges
        end local 5 // org.apache.cassandra.locator.PendingRangeMaps newPendingRanges
        end local 4 // java.util.Set movingEndpoints
        end local 3 // java.util.Set leavingEndpoints
        end local 2 // org.apache.cassandra.utils.BiMultiValMap bootstrapTokens
        end local 1 // org.apache.cassandra.locator.TokenMetadata metadata
        end local 0 // org.apache.cassandra.locator.AbstractReplicationStrategy strategy
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0   63     0            strategy  Lorg/apache/cassandra/locator/AbstractReplicationStrategy;
            0   63     1            metadata  Lorg/apache/cassandra/locator/TokenMetadata;
            0   63     2     bootstrapTokens  Lorg/apache/cassandra/utils/BiMultiValMap<Lorg/apache/cassandra/dht/Token;Ljava/net/InetAddress;>;
            0   63     3    leavingEndpoints  Ljava/util/Set<Ljava/net/InetAddress;>;
            0   63     4     movingEndpoints  Ljava/util/Set<Lorg/apache/cassandra/utils/Pair<Lorg/apache/cassandra/dht/Token;Ljava/net/InetAddress;>;>;
            1   63     5    newPendingRanges  Lorg/apache/cassandra/locator/PendingRangeMaps;
            2   63     6       addressRanges  Lcom/google/common/collect/Multimap<Ljava/net/InetAddress;Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;>;
            3   63     7     allLeftMetadata  Lorg/apache/cassandra/locator/TokenMetadata;
            4   63     8      affectedRanges  Ljava/util/Set<Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;>;
            6    7     9            endpoint  Ljava/net/InetAddress;
           10   16     9               range  Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;
           11   16    11    currentEndpoints  Ljava/util/Set<Ljava/net/InetAddress;>;
           12   16    12        newEndpoints  Ljava/util/Set<Ljava/net/InetAddress;>;
           14   15    13             address  Ljava/net/InetAddress;
           18   63     9  bootstrapAddresses  Lcom/google/common/collect/Multimap<Ljava/net/InetAddress;Lorg/apache/cassandra/dht/Token;>;
           20   27    10            endpoint  Ljava/net/InetAddress;
           21   27    12              tokens  Ljava/util/Collection<Lorg/apache/cassandra/dht/Token;>;
           24   25    13               range  Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;
           30   61    10              moving  Lorg/apache/cassandra/utils/Pair<Lorg/apache/cassandra/dht/Token;Ljava/net/InetAddress;>;
           31   61    12  moveAffectedRanges  Ljava/util/Set<Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;>;
           32   61    13            endpoint  Ljava/net/InetAddress;
           34   35    14               range  Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;
           39   40    14               range  Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;
           43   59    14               range  Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;
           44   59    16    currentEndpoints  Ljava/util/Set<Ljava/net/InetAddress;>;
           45   59    17        newEndpoints  Ljava/util/Set<Ljava/net/InetAddress;>;
           46   59    18          difference  Ljava/util/Set<Ljava/net/InetAddress;>;
           48   58    19             address  Ljava/net/InetAddress;
           49   58    21           newRanges  Ljava/util/Collection<Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;>;
           50   58    22           oldRanges  Ljava/util/Collection<Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;>;
           53   57    23            newRange  Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;
           55   56    25        pendingRange  Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;
    Signature: (Lorg/apache/cassandra/locator/AbstractReplicationStrategy;Lorg/apache/cassandra/locator/TokenMetadata;Lorg/apache/cassandra/utils/BiMultiValMap<Lorg/apache/cassandra/dht/Token;Ljava/net/InetAddress;>;Ljava/util/Set<Ljava/net/InetAddress;>;Ljava/util/Set<Lorg/apache/cassandra/utils/Pair<Lorg/apache/cassandra/dht/Token;Ljava/net/InetAddress;>;>;)Lorg/apache/cassandra/locator/PendingRangeMaps;
    MethodParameters:
                  Name  Flags
      strategy          
      metadata          
      bootstrapTokens   
      leavingEndpoints  
      movingEndpoints   

  public org.apache.cassandra.dht.Token getPredecessor(org.apache.cassandra.dht.Token);
    descriptor: (Lorg/apache/cassandra/dht/Token;)Lorg/apache/cassandra/dht/Token;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=2
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // org.apache.cassandra.dht.Token token
         0: .line 978
            aload 0 /* this */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.sortedTokens:()Ljava/util/ArrayList;
            astore 2 /* tokens */
        start local 2 // java.util.List tokens
         1: .line 979
            aload 2 /* tokens */
            aload 1 /* token */
            invokestatic java.util.Collections.binarySearch:(Ljava/util/List;Ljava/lang/Object;)I
            istore 3 /* index */
        start local 3 // int index
         2: .line 980
            getstatic org.apache.cassandra.locator.TokenMetadata.$assertionsDisabled:Z
            ifne 3
            iload 3 /* index */
            ifge 3
            new java.lang.AssertionError
            dup
            new java.lang.StringBuilder
            dup
            invokespecial java.lang.StringBuilder.<init>:()V
            aload 1 /* token */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc " not found in "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.tokenToEndpointMapKeysAsStrings:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         3: .line 981
      StackMap locals: java.util.List int
      StackMap stack:
            iload 3 /* index */
            ifne 4
            aload 2 /* tokens */
            aload 2 /* tokens */
            invokeinterface java.util.List.size:()I
            iconst_1
            isub
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Token
            goto 5
      StackMap locals:
      StackMap stack:
         4: aload 2 /* tokens */
            iload 3 /* index */
            iconst_1
            isub
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Token
      StackMap locals:
      StackMap stack: org.apache.cassandra.dht.Token
         5: areturn
        end local 3 // int index
        end local 2 // java.util.List tokens
        end local 1 // org.apache.cassandra.dht.Token token
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    6     0    this  Lorg/apache/cassandra/locator/TokenMetadata;
            0    6     1   token  Lorg/apache/cassandra/dht/Token;
            1    6     2  tokens  Ljava/util/List<Lorg/apache/cassandra/dht/Token;>;
            2    6     3   index  I
    MethodParameters:
       Name  Flags
      token  

  public org.apache.cassandra.dht.Token getSuccessor(org.apache.cassandra.dht.Token);
    descriptor: (Lorg/apache/cassandra/dht/Token;)Lorg/apache/cassandra/dht/Token;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=2
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // org.apache.cassandra.dht.Token token
         0: .line 986
            aload 0 /* this */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.sortedTokens:()Ljava/util/ArrayList;
            astore 2 /* tokens */
        start local 2 // java.util.List tokens
         1: .line 987
            aload 2 /* tokens */
            aload 1 /* token */
            invokestatic java.util.Collections.binarySearch:(Ljava/util/List;Ljava/lang/Object;)I
            istore 3 /* index */
        start local 3 // int index
         2: .line 988
            getstatic org.apache.cassandra.locator.TokenMetadata.$assertionsDisabled:Z
            ifne 3
            iload 3 /* index */
            ifge 3
            new java.lang.AssertionError
            dup
            new java.lang.StringBuilder
            dup
            invokespecial java.lang.StringBuilder.<init>:()V
            aload 1 /* token */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc " not found in "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.tokenToEndpointMapKeysAsStrings:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         3: .line 989
      StackMap locals: java.util.List int
      StackMap stack:
            iload 3 /* index */
            aload 2 /* tokens */
            invokeinterface java.util.List.size:()I
            iconst_1
            isub
            if_icmpne 4
            aload 2 /* tokens */
            iconst_0
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Token
            goto 5
      StackMap locals:
      StackMap stack:
         4: aload 2 /* tokens */
            iload 3 /* index */
            iconst_1
            iadd
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Token
      StackMap locals:
      StackMap stack: org.apache.cassandra.dht.Token
         5: areturn
        end local 3 // int index
        end local 2 // java.util.List tokens
        end local 1 // org.apache.cassandra.dht.Token token
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    6     0    this  Lorg/apache/cassandra/locator/TokenMetadata;
            0    6     1   token  Lorg/apache/cassandra/dht/Token;
            1    6     2  tokens  Ljava/util/List<Lorg/apache/cassandra/dht/Token;>;
            2    6     3   index  I
    MethodParameters:
       Name  Flags
      token  

  private java.lang.String tokenToEndpointMapKeysAsStrings();
    descriptor: ()Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=3, args_size=1
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
         0: .line 994
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         1: .line 997
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.tokenToEndpointMap:Lorg/apache/cassandra/utils/BiMultiValMap;
            invokevirtual org.apache.cassandra.utils.BiMultiValMap.keySet:()Ljava/util/Set;
            ldc ", "
            invokestatic org.apache.commons.lang3.StringUtils.join:(Ljava/lang/Iterable;Ljava/lang/String;)Ljava/lang/String;
            astore 2
         2: .line 1001
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         3: .line 997
            aload 2
            areturn
         4: .line 1000
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 1
         5: .line 1001
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         6: .line 1002
            aload 1
            athrow
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lorg/apache/cassandra/locator/TokenMetadata;
      Exception table:
        from    to  target  type
           1     2       4  any

  public org.apache.cassandra.utils.BiMultiValMap<org.apache.cassandra.dht.Token, java.net.InetAddress> getBootstrapTokens();
    descriptor: ()Lorg/apache/cassandra/utils/BiMultiValMap;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=1
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
         0: .line 1008
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         1: .line 1011
            new org.apache.cassandra.utils.BiMultiValMap
            dup
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.bootstrapTokens:Lorg/apache/cassandra/utils/BiMultiValMap;
            invokespecial org.apache.cassandra.utils.BiMultiValMap.<init>:(Lorg/apache/cassandra/utils/BiMultiValMap;)V
            astore 2
         2: .line 1015
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         3: .line 1011
            aload 2
            areturn
         4: .line 1014
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 1
         5: .line 1015
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         6: .line 1016
            aload 1
            athrow
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lorg/apache/cassandra/locator/TokenMetadata;
      Exception table:
        from    to  target  type
           1     2       4  any
    Signature: ()Lorg/apache/cassandra/utils/BiMultiValMap<Lorg/apache/cassandra/dht/Token;Ljava/net/InetAddress;>;

  public java.util.Set<java.net.InetAddress> getAllEndpoints();
    descriptor: ()Ljava/util/Set;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=3, args_size=1
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
         0: .line 1021
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         1: .line 1024
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.endpointToHostIdMap:Lcom/google/common/collect/BiMap;
            invokeinterface com.google.common.collect.BiMap.keySet:()Ljava/util/Set;
            invokestatic com.google.common.collect.ImmutableSet.copyOf:(Ljava/util/Collection;)Lcom/google/common/collect/ImmutableSet;
            astore 2
         2: .line 1028
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         3: .line 1024
            aload 2
            areturn
         4: .line 1027
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 1
         5: .line 1028
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         6: .line 1029
            aload 1
            athrow
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lorg/apache/cassandra/locator/TokenMetadata;
      Exception table:
        from    to  target  type
           1     2       4  any
    Signature: ()Ljava/util/Set<Ljava/net/InetAddress;>;

  public java.util.Set<java.net.InetAddress> getLeavingEndpoints();
    descriptor: ()Ljava/util/Set;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=3, args_size=1
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
         0: .line 1035
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         1: .line 1038
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.leavingEndpoints:Ljava/util/Set;
            invokestatic com.google.common.collect.ImmutableSet.copyOf:(Ljava/util/Collection;)Lcom/google/common/collect/ImmutableSet;
            astore 2
         2: .line 1042
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         3: .line 1038
            aload 2
            areturn
         4: .line 1041
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 1
         5: .line 1042
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         6: .line 1043
            aload 1
            athrow
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lorg/apache/cassandra/locator/TokenMetadata;
      Exception table:
        from    to  target  type
           1     2       4  any
    Signature: ()Ljava/util/Set<Ljava/net/InetAddress;>;

  public java.util.Set<org.apache.cassandra.utils.Pair<org.apache.cassandra.dht.Token, java.net.InetAddress>> getMovingEndpoints();
    descriptor: ()Ljava/util/Set;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=3, args_size=1
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
         0: .line 1052
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         1: .line 1055
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.movingEndpoints:Ljava/util/Set;
            invokestatic com.google.common.collect.ImmutableSet.copyOf:(Ljava/util/Collection;)Lcom/google/common/collect/ImmutableSet;
            astore 2
         2: .line 1059
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         3: .line 1055
            aload 2
            areturn
         4: .line 1058
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 1
         5: .line 1059
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         6: .line 1060
            aload 1
            athrow
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lorg/apache/cassandra/locator/TokenMetadata;
      Exception table:
        from    to  target  type
           1     2       4  any
    Signature: ()Ljava/util/Set<Lorg/apache/cassandra/utils/Pair<Lorg/apache/cassandra/dht/Token;Ljava/net/InetAddress;>;>;

  public static int firstTokenIndex(java.util.ArrayList<org.apache.cassandra.dht.Token>, org.apache.cassandra.dht.Token, );
    descriptor: (Ljava/util/ArrayList;Lorg/apache/cassandra/dht/Token;Z)I
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=2, locals=4, args_size=3
        start local 0 // java.util.ArrayList ring
        start local 1 // org.apache.cassandra.dht.Token start
        start local 2 // boolean insertMin
         0: .line 1065
            getstatic org.apache.cassandra.locator.TokenMetadata.$assertionsDisabled:Z
            ifne 1
            aload 0 /* ring */
            invokevirtual java.util.ArrayList.size:()I
            ifgt 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 1067
      StackMap locals:
      StackMap stack:
            aload 0 /* ring */
            aload 1 /* start */
            invokestatic java.util.Collections.binarySearch:(Ljava/util/List;Ljava/lang/Object;)I
            istore 3 /* i */
        start local 3 // int i
         2: .line 1068
            iload 3 /* i */
            ifge 8
         3: .line 1070
            iload 3 /* i */
            iconst_1
            iadd
            iconst_m1
            imul
            istore 3 /* i */
         4: .line 1071
            iload 3 /* i */
            aload 0 /* ring */
            invokevirtual java.util.ArrayList.size:()I
            if_icmplt 8
         5: .line 1072
            iload 2 /* insertMin */
            ifeq 6
            iconst_m1
            goto 7
      StackMap locals: int
      StackMap stack:
         6: iconst_0
      StackMap locals:
      StackMap stack: int
         7: istore 3 /* i */
         8: .line 1074
      StackMap locals:
      StackMap stack:
            iload 3 /* i */
            ireturn
        end local 3 // int i
        end local 2 // boolean insertMin
        end local 1 // org.apache.cassandra.dht.Token start
        end local 0 // java.util.ArrayList ring
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    9     0       ring  Ljava/util/ArrayList<Lorg/apache/cassandra/dht/Token;>;
            0    9     1      start  Lorg/apache/cassandra/dht/Token;
            0    9     2  insertMin  Z
            2    9     3          i  I
    Signature: (Ljava/util/ArrayList<Lorg/apache/cassandra/dht/Token;>;Lorg/apache/cassandra/dht/Token;Z)I
    MethodParameters:
           Name  Flags
      ring       final
      start      
      insertMin  

  public static org.apache.cassandra.dht.Token firstToken(java.util.ArrayList<org.apache.cassandra.dht.Token>, org.apache.cassandra.dht.Token);
    descriptor: (Ljava/util/ArrayList;Lorg/apache/cassandra/dht/Token;)Lorg/apache/cassandra/dht/Token;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // java.util.ArrayList ring
        start local 1 // org.apache.cassandra.dht.Token start
         0: .line 1079
            aload 0 /* ring */
            aload 0 /* ring */
            aload 1 /* start */
            iconst_0
            invokestatic org.apache.cassandra.locator.TokenMetadata.firstTokenIndex:(Ljava/util/ArrayList;Lorg/apache/cassandra/dht/Token;Z)I
            invokevirtual java.util.ArrayList.get:(I)Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Token
            areturn
        end local 1 // org.apache.cassandra.dht.Token start
        end local 0 // java.util.ArrayList ring
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    1     0   ring  Ljava/util/ArrayList<Lorg/apache/cassandra/dht/Token;>;
            0    1     1  start  Lorg/apache/cassandra/dht/Token;
    Signature: (Ljava/util/ArrayList<Lorg/apache/cassandra/dht/Token;>;Lorg/apache/cassandra/dht/Token;)Lorg/apache/cassandra/dht/Token;
    MethodParameters:
       Name  Flags
      ring   final
      start  

  public static java.util.Iterator<org.apache.cassandra.dht.Token> ringIterator(java.util.ArrayList<org.apache.cassandra.dht.Token>, org.apache.cassandra.dht.Token, boolean);
    descriptor: (Ljava/util/ArrayList;Lorg/apache/cassandra/dht/Token;Z)Ljava/util/Iterator;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=6, locals=5, args_size=3
        start local 0 // java.util.ArrayList ring
        start local 1 // org.apache.cassandra.dht.Token start
        start local 2 // boolean includeMin
         0: .line 1089
            aload 0 /* ring */
            invokevirtual java.util.ArrayList.isEmpty:()Z
            ifeq 4
         1: .line 1090
            iload 2 /* includeMin */
            ifeq 2
            aload 1 /* start */
            invokevirtual org.apache.cassandra.dht.Token.getPartitioner:()Lorg/apache/cassandra/dht/IPartitioner;
            invokeinterface org.apache.cassandra.dht.IPartitioner.getMinimumToken:()Lorg/apache/cassandra/dht/Token;
            invokestatic com.google.common.collect.Iterators.singletonIterator:(Ljava/lang/Object;)Lcom/google/common/collect/UnmodifiableIterator;
            goto 3
         2: .line 1091
      StackMap locals:
      StackMap stack:
            invokestatic java.util.Collections.emptyIterator:()Ljava/util/Iterator;
         3: .line 1090
      StackMap locals:
      StackMap stack: java.util.Iterator
            areturn
         4: .line 1093
      StackMap locals:
      StackMap stack:
            iload 2 /* includeMin */
            ifeq 5
            aload 0 /* ring */
            iconst_0
            invokevirtual java.util.ArrayList.get:(I)Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Token
            invokevirtual org.apache.cassandra.dht.Token.isMinimum:()Z
            ifne 5
            iconst_1
            goto 6
      StackMap locals:
      StackMap stack:
         5: iconst_0
      StackMap locals:
      StackMap stack: int
         6: istore 3 /* insertMin */
        start local 3 // boolean insertMin
         7: .line 1094
            aload 0 /* ring */
            aload 1 /* start */
            iload 3 /* insertMin */
            invokestatic org.apache.cassandra.locator.TokenMetadata.firstTokenIndex:(Ljava/util/ArrayList;Lorg/apache/cassandra/dht/Token;Z)I
            istore 4 /* startIndex */
        start local 4 // int startIndex
         8: .line 1095
            new org.apache.cassandra.locator.TokenMetadata$2
            dup
            iload 4 /* startIndex */
            aload 0 /* ring */
            iload 3 /* insertMin */
            aload 1 /* start */
            invokespecial org.apache.cassandra.locator.TokenMetadata$2.<init>:(ILjava/util/ArrayList;ZLorg/apache/cassandra/dht/Token;)V
            areturn
        end local 4 // int startIndex
        end local 3 // boolean insertMin
        end local 2 // boolean includeMin
        end local 1 // org.apache.cassandra.dht.Token start
        end local 0 // java.util.ArrayList ring
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    9     0        ring  Ljava/util/ArrayList<Lorg/apache/cassandra/dht/Token;>;
            0    9     1       start  Lorg/apache/cassandra/dht/Token;
            0    9     2  includeMin  Z
            7    9     3   insertMin  Z
            8    9     4  startIndex  I
    Signature: (Ljava/util/ArrayList<Lorg/apache/cassandra/dht/Token;>;Lorg/apache/cassandra/dht/Token;Z)Ljava/util/Iterator<Lorg/apache/cassandra/dht/Token;>;
    MethodParameters:
            Name  Flags
      ring        final
      start       
      includeMin  

  public void clearUnsafe();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
         0: .line 1126
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         1: .line 1129
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.tokenToEndpointMap:Lorg/apache/cassandra/utils/BiMultiValMap;
            invokevirtual org.apache.cassandra.utils.BiMultiValMap.clear:()V
         2: .line 1130
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.endpointToHostIdMap:Lcom/google/common/collect/BiMap;
            invokeinterface com.google.common.collect.BiMap.clear:()V
         3: .line 1131
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.bootstrapTokens:Lorg/apache/cassandra/utils/BiMultiValMap;
            invokevirtual org.apache.cassandra.utils.BiMultiValMap.clear:()V
         4: .line 1132
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.leavingEndpoints:Ljava/util/Set;
            invokeinterface java.util.Set.clear:()V
         5: .line 1133
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.pendingRanges:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.clear:()V
         6: .line 1134
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.movingEndpoints:Ljava/util/Set;
            invokeinterface java.util.Set.clear:()V
         7: .line 1135
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.sortedTokens:Ljava/util/ArrayList;
            invokevirtual java.util.ArrayList.clear:()V
         8: .line 1136
            aload 0 /* this */
            invokestatic org.apache.cassandra.locator.TokenMetadata$Topology.empty:()Lorg/apache/cassandra/locator/TokenMetadata$Topology;
            putfield org.apache.cassandra.locator.TokenMetadata.topology:Lorg/apache/cassandra/locator/TokenMetadata$Topology;
         9: .line 1137
            aload 0 /* this */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.invalidateCachedRings:()V
        10: .line 1138
            goto 14
        11: .line 1140
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 1
        12: .line 1141
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        13: .line 1142
            aload 1
            athrow
        14: .line 1141
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        15: .line 1143
            return
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   16     0  this  Lorg/apache/cassandra/locator/TokenMetadata;
      Exception table:
        from    to  target  type
           1    11      11  any

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=7, args_size=1
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
         0: .line 1147
            new java.lang.StringBuilder
            dup
            invokespecial java.lang.StringBuilder.<init>:()V
            astore 1 /* sb */
        start local 1 // java.lang.StringBuilder sb
         1: .line 1148
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         2: .line 1151
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.tokenToEndpointMap:Lorg/apache/cassandra/utils/BiMultiValMap;
            invokevirtual org.apache.cassandra.utils.BiMultiValMap.inverse:()Lcom/google/common/collect/Multimap;
            astore 2 /* endpointToTokenMap */
        start local 2 // com.google.common.collect.Multimap endpointToTokenMap
         3: .line 1152
            aload 2 /* endpointToTokenMap */
            invokeinterface com.google.common.collect.Multimap.keySet:()Ljava/util/Set;
            astore 3 /* eps */
        start local 3 // java.util.Set eps
         4: .line 1154
            aload 3 /* eps */
            invokeinterface java.util.Set.isEmpty:()Z
            ifne 14
         5: .line 1156
            aload 1 /* sb */
            ldc "Normal Tokens:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         6: .line 1157
            aload 1 /* sb */
            ldc "line.separator"
            invokestatic java.lang.System.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         7: .line 1158
            aload 3 /* eps */
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 5
            goto 13
      StackMap locals: org.apache.cassandra.locator.TokenMetadata java.lang.StringBuilder com.google.common.collect.Multimap java.util.Set top java.util.Iterator
      StackMap stack:
         8: aload 5
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.net.InetAddress
            astore 4 /* ep */
        start local 4 // java.net.InetAddress ep
         9: .line 1160
            aload 1 /* sb */
            aload 4 /* ep */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            pop
        10: .line 1161
            aload 1 /* sb */
            bipush 58
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
        11: .line 1162
            aload 1 /* sb */
            aload 2 /* endpointToTokenMap */
            aload 4 /* ep */
            invokeinterface com.google.common.collect.Multimap.get:(Ljava/lang/Object;)Ljava/util/Collection;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            pop
        12: .line 1163
            aload 1 /* sb */
            ldc "line.separator"
            invokestatic java.lang.System.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        end local 4 // java.net.InetAddress ep
        13: .line 1158
      StackMap locals:
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 8
        14: .line 1167
      StackMap locals: org.apache.cassandra.locator.TokenMetadata java.lang.StringBuilder com.google.common.collect.Multimap java.util.Set
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.bootstrapTokens:Lorg/apache/cassandra/utils/BiMultiValMap;
            invokevirtual org.apache.cassandra.utils.BiMultiValMap.isEmpty:()Z
            ifne 22
        15: .line 1169
            aload 1 /* sb */
            ldc "Bootstrapping Tokens:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        16: .line 1170
            aload 1 /* sb */
            ldc "line.separator"
            invokestatic java.lang.System.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        17: .line 1171
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.bootstrapTokens:Lorg/apache/cassandra/utils/BiMultiValMap;
            invokevirtual org.apache.cassandra.utils.BiMultiValMap.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 5
            goto 21
      StackMap locals: org.apache.cassandra.locator.TokenMetadata java.lang.StringBuilder com.google.common.collect.Multimap java.util.Set top java.util.Iterator
      StackMap stack:
        18: aload 5
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 4 /* entry */
        start local 4 // java.util.Map$Entry entry
        19: .line 1173
            aload 1 /* sb */
            aload 4 /* entry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            bipush 58
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            aload 4 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            pop
        20: .line 1174
            aload 1 /* sb */
            ldc "line.separator"
            invokestatic java.lang.System.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        end local 4 // java.util.Map$Entry entry
        21: .line 1171
      StackMap locals:
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 18
        22: .line 1178
      StackMap locals: org.apache.cassandra.locator.TokenMetadata java.lang.StringBuilder com.google.common.collect.Multimap java.util.Set
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.leavingEndpoints:Ljava/util/Set;
            invokeinterface java.util.Set.isEmpty:()Z
            ifne 30
        23: .line 1180
            aload 1 /* sb */
            ldc "Leaving Endpoints:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        24: .line 1181
            aload 1 /* sb */
            ldc "line.separator"
            invokestatic java.lang.System.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        25: .line 1182
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.leavingEndpoints:Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 5
            goto 29
      StackMap locals: org.apache.cassandra.locator.TokenMetadata java.lang.StringBuilder com.google.common.collect.Multimap java.util.Set top java.util.Iterator
      StackMap stack:
        26: aload 5
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.net.InetAddress
            astore 4 /* ep */
        start local 4 // java.net.InetAddress ep
        27: .line 1184
            aload 1 /* sb */
            aload 4 /* ep */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            pop
        28: .line 1185
            aload 1 /* sb */
            ldc "line.separator"
            invokestatic java.lang.System.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        end local 4 // java.net.InetAddress ep
        29: .line 1182
      StackMap locals:
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 26
        30: .line 1189
      StackMap locals: org.apache.cassandra.locator.TokenMetadata java.lang.StringBuilder com.google.common.collect.Multimap java.util.Set
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.pendingRanges:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.isEmpty:()Z
            ifne 38
        31: .line 1191
            aload 1 /* sb */
            ldc "Pending Ranges:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        32: .line 1192
            aload 1 /* sb */
            ldc "line.separator"
            invokestatic java.lang.System.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        33: .line 1193
            aload 1 /* sb */
            aload 0 /* this */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.printPendingRanges:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        end local 3 // java.util.Set eps
        end local 2 // com.google.common.collect.Multimap endpointToTokenMap
        34: .line 1195
            goto 38
        35: .line 1197
      StackMap locals: org.apache.cassandra.locator.TokenMetadata java.lang.StringBuilder
      StackMap stack: java.lang.Throwable
            astore 6
        36: .line 1198
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        37: .line 1199
            aload 6
            athrow
        38: .line 1198
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        39: .line 1201
            aload 1 /* sb */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 1 // java.lang.StringBuilder sb
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0   40     0                this  Lorg/apache/cassandra/locator/TokenMetadata;
            1   40     1                  sb  Ljava/lang/StringBuilder;
            3   34     2  endpointToTokenMap  Lcom/google/common/collect/Multimap<Ljava/net/InetAddress;Lorg/apache/cassandra/dht/Token;>;
            4   34     3                 eps  Ljava/util/Set<Ljava/net/InetAddress;>;
            9   13     4                  ep  Ljava/net/InetAddress;
           19   21     4               entry  Ljava/util/Map$Entry<Lorg/apache/cassandra/dht/Token;Ljava/net/InetAddress;>;
           27   29     4                  ep  Ljava/net/InetAddress;
      Exception table:
        from    to  target  type
           2    35      35  any

  private java.lang.String printPendingRanges();
    descriptor: ()Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=4, args_size=1
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
         0: .line 1206
            new java.lang.StringBuilder
            dup
            invokespecial java.lang.StringBuilder.<init>:()V
            astore 1 /* sb */
        start local 1 // java.lang.StringBuilder sb
         1: .line 1208
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.pendingRanges:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 3
            goto 4
      StackMap locals: org.apache.cassandra.locator.TokenMetadata java.lang.StringBuilder top java.util.Iterator
      StackMap stack:
         2: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.locator.PendingRangeMaps
            astore 2 /* pendingRangeMaps */
        start local 2 // org.apache.cassandra.locator.PendingRangeMaps pendingRangeMaps
         3: .line 1210
            aload 1 /* sb */
            aload 2 /* pendingRangeMaps */
            invokevirtual org.apache.cassandra.locator.PendingRangeMaps.printPendingRanges:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        end local 2 // org.apache.cassandra.locator.PendingRangeMaps pendingRangeMaps
         4: .line 1208
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 1213
            aload 1 /* sb */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 1 // java.lang.StringBuilder sb
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0    6     0              this  Lorg/apache/cassandra/locator/TokenMetadata;
            1    6     1                sb  Ljava/lang/StringBuilder;
            3    4     2  pendingRangeMaps  Lorg/apache/cassandra/locator/PendingRangeMaps;

  public java.util.Collection<java.net.InetAddress> pendingEndpointsFor(org.apache.cassandra.dht.Token, java.lang.String);
    descriptor: (Lorg/apache/cassandra/dht/Token;Ljava/lang/String;)Ljava/util/Collection;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=3
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // org.apache.cassandra.dht.Token token
        start local 2 // java.lang.String keyspaceName
         0: .line 1218
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.pendingRanges:Ljava/util/concurrent/ConcurrentMap;
            aload 2 /* keyspaceName */
            invokeinterface java.util.concurrent.ConcurrentMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.cassandra.locator.PendingRangeMaps
            astore 3 /* pendingRangeMaps */
        start local 3 // org.apache.cassandra.locator.PendingRangeMaps pendingRangeMaps
         1: .line 1219
            aload 3 /* pendingRangeMaps */
            ifnonnull 3
         2: .line 1220
            invokestatic java.util.Collections.emptyList:()Ljava/util/List;
            areturn
         3: .line 1222
      StackMap locals: org.apache.cassandra.locator.PendingRangeMaps
      StackMap stack:
            aload 3 /* pendingRangeMaps */
            aload 1 /* token */
            invokevirtual org.apache.cassandra.locator.PendingRangeMaps.pendingEndpointsFor:(Lorg/apache/cassandra/dht/Token;)Ljava/util/Collection;
            areturn
        end local 3 // org.apache.cassandra.locator.PendingRangeMaps pendingRangeMaps
        end local 2 // java.lang.String keyspaceName
        end local 1 // org.apache.cassandra.dht.Token token
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0    4     0              this  Lorg/apache/cassandra/locator/TokenMetadata;
            0    4     1             token  Lorg/apache/cassandra/dht/Token;
            0    4     2      keyspaceName  Ljava/lang/String;
            1    4     3  pendingRangeMaps  Lorg/apache/cassandra/locator/PendingRangeMaps;
    Signature: (Lorg/apache/cassandra/dht/Token;Ljava/lang/String;)Ljava/util/Collection<Ljava/net/InetAddress;>;
    MethodParameters:
              Name  Flags
      token         
      keyspaceName  

  public java.util.Collection<java.net.InetAddress> getWriteEndpoints(org.apache.cassandra.dht.Token, java.lang.String, java.util.Collection<java.net.InetAddress>);
    descriptor: (Lorg/apache/cassandra/dht/Token;Ljava/lang/String;Ljava/util/Collection;)Ljava/util/Collection;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=4
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // org.apache.cassandra.dht.Token token
        start local 2 // java.lang.String keyspaceName
        start local 3 // java.util.Collection naturalEndpoints
         0: .line 1230
            aload 3 /* naturalEndpoints */
            aload 0 /* this */
            aload 1 /* token */
            aload 2 /* keyspaceName */
            invokevirtual org.apache.cassandra.locator.TokenMetadata.pendingEndpointsFor:(Lorg/apache/cassandra/dht/Token;Ljava/lang/String;)Ljava/util/Collection;
            invokestatic com.google.common.collect.Iterables.concat:(Ljava/lang/Iterable;Ljava/lang/Iterable;)Ljava/lang/Iterable;
            invokestatic com.google.common.collect.ImmutableList.copyOf:(Ljava/lang/Iterable;)Lcom/google/common/collect/ImmutableList;
            areturn
        end local 3 // java.util.Collection naturalEndpoints
        end local 2 // java.lang.String keyspaceName
        end local 1 // org.apache.cassandra.dht.Token token
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0    1     0              this  Lorg/apache/cassandra/locator/TokenMetadata;
            0    1     1             token  Lorg/apache/cassandra/dht/Token;
            0    1     2      keyspaceName  Ljava/lang/String;
            0    1     3  naturalEndpoints  Ljava/util/Collection<Ljava/net/InetAddress;>;
    Signature: (Lorg/apache/cassandra/dht/Token;Ljava/lang/String;Ljava/util/Collection<Ljava/net/InetAddress;>;)Ljava/util/Collection<Ljava/net/InetAddress;>;
    MethodParameters:
                  Name  Flags
      token             
      keyspaceName      
      naturalEndpoints  

  public com.google.common.collect.Multimap<java.net.InetAddress, org.apache.cassandra.dht.Token> getEndpointToTokenMapForReading();
    descriptor: ()Lcom/google/common/collect/Multimap;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=6, args_size=1
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
         0: .line 1236
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         1: .line 1239
            invokestatic com.google.common.collect.HashMultimap.create:()Lcom/google/common/collect/HashMultimap;
            astore 1 /* cloned */
        start local 1 // com.google.common.collect.Multimap cloned
         2: .line 1240
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.tokenToEndpointMap:Lorg/apache/cassandra/utils/BiMultiValMap;
            invokevirtual org.apache.cassandra.utils.BiMultiValMap.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 3
            goto 5
      StackMap locals: org.apache.cassandra.locator.TokenMetadata com.google.common.collect.Multimap top java.util.Iterator
      StackMap stack:
         3: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 2 /* entry */
        start local 2 // java.util.Map$Entry entry
         4: .line 1241
            aload 1 /* cloned */
            aload 2 /* entry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast java.net.InetAddress
            aload 2 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Token
            invokeinterface com.google.common.collect.Multimap.put:(Ljava/lang/Object;Ljava/lang/Object;)Z
            pop
        end local 2 // java.util.Map$Entry entry
         5: .line 1240
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 3
         6: .line 1242
            aload 1 /* cloned */
            astore 5
         7: .line 1246
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         8: .line 1242
            aload 5
            areturn
        end local 1 // com.google.common.collect.Multimap cloned
         9: .line 1245
      StackMap locals: org.apache.cassandra.locator.TokenMetadata
      StackMap stack: java.lang.Throwable
            astore 4
        10: .line 1246
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        11: .line 1247
            aload 4
            athrow
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   12     0    this  Lorg/apache/cassandra/locator/TokenMetadata;
            2    9     1  cloned  Lcom/google/common/collect/Multimap<Ljava/net/InetAddress;Lorg/apache/cassandra/dht/Token;>;
            4    5     2   entry  Ljava/util/Map$Entry<Lorg/apache/cassandra/dht/Token;Ljava/net/InetAddress;>;
      Exception table:
        from    to  target  type
           1     7       9  any
    Signature: ()Lcom/google/common/collect/Multimap<Ljava/net/InetAddress;Lorg/apache/cassandra/dht/Token;>;

  public java.util.Map<org.apache.cassandra.dht.Token, java.net.InetAddress> getNormalAndBootstrappingTokenToEndpointMap();
    descriptor: ()Ljava/util/Map;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=1
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
         0: .line 1256
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         1: .line 1259
            new java.util.HashMap
            dup
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.tokenToEndpointMap:Lorg/apache/cassandra/utils/BiMultiValMap;
            invokevirtual org.apache.cassandra.utils.BiMultiValMap.size:()I
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.bootstrapTokens:Lorg/apache/cassandra/utils/BiMultiValMap;
            invokevirtual org.apache.cassandra.utils.BiMultiValMap.size:()I
            iadd
            invokespecial java.util.HashMap.<init>:(I)V
            astore 1 /* map */
        start local 1 // java.util.Map map
         2: .line 1260
            aload 1 /* map */
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.tokenToEndpointMap:Lorg/apache/cassandra/utils/BiMultiValMap;
            invokeinterface java.util.Map.putAll:(Ljava/util/Map;)V
         3: .line 1261
            aload 1 /* map */
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.bootstrapTokens:Lorg/apache/cassandra/utils/BiMultiValMap;
            invokeinterface java.util.Map.putAll:(Ljava/util/Map;)V
         4: .line 1262
            aload 1 /* map */
            astore 3
         5: .line 1266
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         6: .line 1262
            aload 3
            areturn
        end local 1 // java.util.Map map
         7: .line 1265
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 2
         8: .line 1266
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         9: .line 1267
            aload 2
            athrow
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   10     0  this  Lorg/apache/cassandra/locator/TokenMetadata;
            2    7     1   map  Ljava/util/Map<Lorg/apache/cassandra/dht/Token;Ljava/net/InetAddress;>;
      Exception table:
        from    to  target  type
           1     5       7  any
    Signature: ()Ljava/util/Map<Lorg/apache/cassandra/dht/Token;Ljava/net/InetAddress;>;

  public org.apache.cassandra.locator.TokenMetadata$Topology getTopology();
    descriptor: ()Lorg/apache/cassandra/locator/TokenMetadata$Topology;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
         0: .line 1278
            getstatic org.apache.cassandra.locator.TokenMetadata.$assertionsDisabled:Z
            ifne 1
            aload 0 /* this */
            getstatic org.apache.cassandra.service.StorageService.instance:Lorg/apache/cassandra/service/StorageService;
            invokevirtual org.apache.cassandra.service.StorageService.getTokenMetadata:()Lorg/apache/cassandra/locator/TokenMetadata;
            if_acmpne 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 1279
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.topology:Lorg/apache/cassandra/locator/TokenMetadata$Topology;
            areturn
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/cassandra/locator/TokenMetadata;

  public long getRingVersion();
    descriptor: ()J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
         0: .line 1284
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.ringVersion:J
            lreturn
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/locator/TokenMetadata;

  public void invalidateCachedRings();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=1, args_size=1
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
         0: .line 1289
            aload 0 /* this */
            dup
            getfield org.apache.cassandra.locator.TokenMetadata.ringVersion:J
            lconst_1
            ladd
            putfield org.apache.cassandra.locator.TokenMetadata.ringVersion:J
         1: .line 1290
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.cachedTokenMap:Ljava/util/concurrent/atomic/AtomicReference;
            aconst_null
            invokevirtual java.util.concurrent.atomic.AtomicReference.set:(Ljava/lang/Object;)V
         2: .line 1291
            return
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/apache/cassandra/locator/TokenMetadata;

  public org.apache.cassandra.db.DecoratedKey decorateKey(java.nio.ByteBuffer);
    descriptor: (Ljava/nio/ByteBuffer;)Lorg/apache/cassandra/db/DecoratedKey;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.locator.TokenMetadata this
        start local 1 // java.nio.ByteBuffer key
         0: .line 1295
            aload 0 /* this */
            getfield org.apache.cassandra.locator.TokenMetadata.partitioner:Lorg/apache/cassandra/dht/IPartitioner;
            aload 1 /* key */
            invokeinterface org.apache.cassandra.dht.IPartitioner.decorateKey:(Ljava/nio/ByteBuffer;)Lorg/apache/cassandra/db/DecoratedKey;
            areturn
        end local 1 // java.nio.ByteBuffer key
        end local 0 // org.apache.cassandra.locator.TokenMetadata this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/locator/TokenMetadata;
            0    1     1   key  Ljava/nio/ByteBuffer;
    MethodParameters:
      Name  Flags
      key   
}
SourceFile: "TokenMetadata.java"
NestMembers:
  org.apache.cassandra.locator.TokenMetadata$1  org.apache.cassandra.locator.TokenMetadata$2  org.apache.cassandra.locator.TokenMetadata$Topology  org.apache.cassandra.locator.TokenMetadata$Topology$Builder
InnerClasses:
  public abstract SetView = com.google.common.collect.Sets$SetView of com.google.common.collect.Sets
  public abstract Entry = java.util.Map$Entry of java.util.Map
  org.apache.cassandra.locator.TokenMetadata$1
  org.apache.cassandra.locator.TokenMetadata$2
  public Topology = org.apache.cassandra.locator.TokenMetadata$Topology of org.apache.cassandra.locator.TokenMetadata
  private Builder = org.apache.cassandra.locator.TokenMetadata$Topology$Builder of org.apache.cassandra.locator.TokenMetadata$Topology