public class org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator<Unit> extends org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase<Unit>
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator
  super_class: org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase
{
  java.util.PriorityQueue<org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted<org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo>> sortedUnits;
    descriptor: Ljava/util/PriorityQueue;
    flags: (0x0000) 
    Signature: Ljava/util/PriorityQueue<Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$Weighted<Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$UnitInfo;>;>;

  java.util.Map<Unit, java.util.PriorityQueue<org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted<org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo>>> tokensInUnits;
    descriptor: Ljava/util/Map;
    flags: (0x0000) 
    Signature: Ljava/util/Map<TUnit;Ljava/util/PriorityQueue<Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$Weighted<Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$TokenInfo;>;>;>;

  private static final double MAX_TAKEOVER_RATIO;
    descriptor: D
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 0.9

  private static final double MIN_TAKEOVER_RATIO;
    descriptor: D
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 0.09999999999999998

  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=1, locals=0, args_size=0
         0: .line 39
            ldc Lorg/apache/cassandra/dht/tokenallocator/NoReplicationTokenAllocator;
            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.dht.tokenallocator.NoReplicationTokenAllocator.$assertionsDisabled:Z
         3: .line 45
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>(java.util.NavigableMap<org.apache.cassandra.dht.Token, Unit>, org.apache.cassandra.dht.tokenallocator.ReplicationStrategy<Unit>, org.apache.cassandra.dht.IPartitioner);
    descriptor: (Ljava/util/NavigableMap;Lorg/apache/cassandra/dht/tokenallocator/ReplicationStrategy;Lorg/apache/cassandra/dht/IPartitioner;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=4
        start local 0 // org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator this
        start local 1 // java.util.NavigableMap sortedTokens
        start local 2 // org.apache.cassandra.dht.tokenallocator.ReplicationStrategy strategy
        start local 3 // org.apache.cassandra.dht.IPartitioner partitioner
         0: .line 51
            aload 0 /* this */
            aload 1 /* sortedTokens */
            aload 2 /* strategy */
            aload 3 /* partitioner */
            invokespecial org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase.<init>:(Ljava/util/NavigableMap;Lorg/apache/cassandra/dht/tokenallocator/ReplicationStrategy;Lorg/apache/cassandra/dht/IPartitioner;)V
         1: .line 41
            aload 0 /* this */
            invokestatic com.google.common.collect.Queues.newPriorityQueue:()Ljava/util/PriorityQueue;
            putfield org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.sortedUnits:Ljava/util/PriorityQueue;
         2: .line 42
            aload 0 /* this */
            invokestatic com.google.common.collect.Maps.newHashMap:()Ljava/util/HashMap;
            putfield org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.tokensInUnits:Ljava/util/Map;
         3: .line 52
            return
        end local 3 // org.apache.cassandra.dht.IPartitioner partitioner
        end local 2 // org.apache.cassandra.dht.tokenallocator.ReplicationStrategy strategy
        end local 1 // java.util.NavigableMap sortedTokens
        end local 0 // org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    4     0          this  Lorg/apache/cassandra/dht/tokenallocator/NoReplicationTokenAllocator<TUnit;>;
            0    4     1  sortedTokens  Ljava/util/NavigableMap<Lorg/apache/cassandra/dht/Token;TUnit;>;
            0    4     2      strategy  Lorg/apache/cassandra/dht/tokenallocator/ReplicationStrategy<TUnit;>;
            0    4     3   partitioner  Lorg/apache/cassandra/dht/IPartitioner;
    Signature: (Ljava/util/NavigableMap<Lorg/apache/cassandra/dht/Token;TUnit;>;Lorg/apache/cassandra/dht/tokenallocator/ReplicationStrategy<TUnit;>;Lorg/apache/cassandra/dht/IPartitioner;)V
    MethodParameters:
              Name  Flags
      sortedTokens  
      strategy      
      partitioner   

  private org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo<Unit> createTokenInfos(java.util.Map<Unit, org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo<Unit>>);
    descriptor: (Ljava/util/Map;)Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$TokenInfo;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=9, args_size=2
        start local 0 // org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator this
        start local 1 // java.util.Map units
         0: .line 60
            aload 1 /* units */
            invokeinterface java.util.Map.isEmpty:()Z
            ifeq 2
         1: .line 61
            aconst_null
            areturn
         2: .line 64
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 2 /* prev */
        start local 2 // org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo prev
         3: .line 65
            aconst_null
            astore 3 /* first */
        start local 3 // org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo first
         4: .line 66
            aload 0 /* this */
            getfield org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.sortedTokens:Ljava/util/NavigableMap;
            invokeinterface java.util.NavigableMap.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 5
            goto 11
      StackMap locals: org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator java.util.Map org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo top java.util.Iterator
      StackMap stack:
         5: aload 5
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 4 /* en */
        start local 4 // java.util.Map$Entry en
         6: .line 68
            aload 4 /* en */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Token
            astore 6 /* t */
        start local 6 // org.apache.cassandra.dht.Token t
         7: .line 69
            aload 1 /* units */
            aload 4 /* en */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo
            astore 7 /* ni */
        start local 7 // org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo ni
         8: .line 70
            new org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo
            dup
            aload 6 /* t */
            aload 7 /* ni */
            invokespecial org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo.<init>:(Lorg/apache/cassandra/dht/Token;Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$UnitInfo;)V
            astore 8 /* ti */
        start local 8 // org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo ti
         9: .line 71
            aload 8 /* ti */
            aload 3 /* first */
            aload 2 /* prev */
            invokevirtual org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo.insertAfter:(Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$CircularList;Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$CircularList;)Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$CircularList;
            checkcast org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo
            astore 3 /* first */
        10: .line 72
            aload 8 /* ti */
            astore 2 /* prev */
        end local 8 // org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo ti
        end local 7 // org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo ni
        end local 6 // org.apache.cassandra.dht.Token t
        end local 4 // java.util.Map$Entry en
        11: .line 66
      StackMap locals:
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 5
        12: .line 75
            aload 3 /* first */
            astore 4 /* curr */
        start local 4 // org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo curr
        13: .line 76
            aload 0 /* this */
            getfield org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.tokensInUnits:Ljava/util/Map;
            invokeinterface java.util.Map.clear:()V
        14: .line 77
            aload 0 /* this */
            getfield org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.sortedUnits:Ljava/util/PriorityQueue;
            invokevirtual java.util.PriorityQueue.clear:()V
        15: .line 80
      StackMap locals: org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator java.util.Map org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo
      StackMap stack:
            aload 0 /* this */
            aload 4 /* curr */
            invokevirtual org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.populateTokenInfoAndAdjustUnit:(Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$TokenInfo;)V
        16: .line 81
            aload 4 /* curr */
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo.next:Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$CircularList;
            checkcast org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo
            astore 4 /* curr */
        17: .line 82
            aload 4 /* curr */
            aload 3 /* first */
            if_acmpne 15
        18: .line 84
            aload 1 /* units */
            invokeinterface java.util.Map.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 6
            goto 21
      StackMap locals: org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator java.util.Map org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo top java.util.Iterator
      StackMap stack:
        19: aload 6
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo
            astore 5 /* unitInfo */
        start local 5 // org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo unitInfo
        20: .line 86
            aload 0 /* this */
            getfield org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.sortedUnits:Ljava/util/PriorityQueue;
            new org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted
            dup
            aload 5 /* unitInfo */
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo.ownership:D
            aload 5 /* unitInfo */
            invokespecial org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted.<init>:(DLjava/lang/Object;)V
            invokevirtual java.util.PriorityQueue.add:(Ljava/lang/Object;)Z
            pop
        end local 5 // org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo unitInfo
        21: .line 84
      StackMap locals:
      StackMap stack:
            aload 6
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 19
        22: .line 89
            aload 3 /* first */
            areturn
        end local 4 // org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo curr
        end local 3 // org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo first
        end local 2 // org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo prev
        end local 1 // java.util.Map units
        end local 0 // org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   23     0      this  Lorg/apache/cassandra/dht/tokenallocator/NoReplicationTokenAllocator<TUnit;>;
            0   23     1     units  Ljava/util/Map<TUnit;Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$UnitInfo<TUnit;>;>;
            3   23     2      prev  Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$TokenInfo<TUnit;>;
            4   23     3     first  Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$TokenInfo<TUnit;>;
            6   11     4        en  Ljava/util/Map$Entry<Lorg/apache/cassandra/dht/Token;TUnit;>;
            7   11     6         t  Lorg/apache/cassandra/dht/Token;
            8   11     7        ni  Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$UnitInfo<TUnit;>;
            9   11     8        ti  Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$TokenInfo<TUnit;>;
           13   23     4      curr  Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$TokenInfo<TUnit;>;
           20   21     5  unitInfo  Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$UnitInfo<TUnit;>;
    Signature: (Ljava/util/Map<TUnit;Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$UnitInfo<TUnit;>;>;)Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$TokenInfo<TUnit;>;
    MethodParameters:
       Name  Flags
      units  

  protected void createTokenInfos();
    descriptor: ()V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator this
         0: .line 97
            aload 0 /* this */
            aload 0 /* this */
            invokestatic com.google.common.collect.Maps.newHashMap:()Ljava/util/HashMap;
            invokevirtual org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.createUnitInfos:(Ljava/util/Map;)Ljava/util/Map;
            invokevirtual org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.createTokenInfos:(Ljava/util/Map;)Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$TokenInfo;
            pop
         1: .line 98
            return
        end local 0 // org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/cassandra/dht/tokenallocator/NoReplicationTokenAllocator<TUnit;>;

  private void populateTokenInfoAndAdjustUnit(org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo<Unit>);
    descriptor: (Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$TokenInfo;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=3, args_size=2
        start local 0 // org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator this
        start local 1 // org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo token
         0: .line 102
            aload 1 /* token */
            aload 1 /* token */
            invokevirtual org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo.prevInRing:()Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$TokenInfo;
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo.token:Lorg/apache/cassandra/dht/Token;
            putfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo.replicationStart:Lorg/apache/cassandra/dht/Token;
         1: .line 103
            aload 1 /* token */
            aload 1 /* token */
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo.token:Lorg/apache/cassandra/dht/Token;
            putfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo.replicationThreshold:Lorg/apache/cassandra/dht/Token;
         2: .line 104
            aload 1 /* token */
            aload 1 /* token */
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo.replicationStart:Lorg/apache/cassandra/dht/Token;
            aload 1 /* token */
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo.token:Lorg/apache/cassandra/dht/Token;
            invokevirtual org.apache.cassandra.dht.Token.size:(Lorg/apache/cassandra/dht/Token;)D
            putfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo.replicatedOwnership:D
         3: .line 105
            aload 1 /* token */
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo.owningUnit:Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$UnitInfo;
            dup
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo.ownership:D
            aload 1 /* token */
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo.replicatedOwnership:D
            dadd
            putfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo.ownership:D
         4: .line 107
            aload 0 /* this */
            getfield org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.tokensInUnits:Ljava/util/Map;
            aload 1 /* token */
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo.owningUnit:Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$UnitInfo;
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo.unit:Ljava/lang/Object;
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.util.PriorityQueue
            astore 2 /* unitTokens */
        start local 2 // java.util.PriorityQueue unitTokens
         5: .line 108
            aload 2 /* unitTokens */
            ifnonnull 8
         6: .line 110
            invokestatic com.google.common.collect.Queues.newPriorityQueue:()Ljava/util/PriorityQueue;
            astore 2 /* unitTokens */
         7: .line 111
            aload 0 /* this */
            getfield org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.tokensInUnits:Ljava/util/Map;
            aload 1 /* token */
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo.owningUnit:Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$UnitInfo;
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo.unit:Ljava/lang/Object;
            aload 2 /* unitTokens */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         8: .line 113
      StackMap locals: java.util.PriorityQueue
      StackMap stack:
            aload 2 /* unitTokens */
            new org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted
            dup
            aload 1 /* token */
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo.replicatedOwnership:D
            aload 1 /* token */
            invokespecial org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted.<init>:(DLjava/lang/Object;)V
            invokevirtual java.util.PriorityQueue.add:(Ljava/lang/Object;)Z
            pop
         9: .line 114
            return
        end local 2 // java.util.PriorityQueue unitTokens
        end local 1 // org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo token
        end local 0 // org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   10     0        this  Lorg/apache/cassandra/dht/tokenallocator/NoReplicationTokenAllocator<TUnit;>;
            0   10     1       token  Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$TokenInfo<TUnit;>;
            5   10     2  unitTokens  Ljava/util/PriorityQueue<Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$Weighted<Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$TokenInfo;>;>;
    Signature: (Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$TokenInfo<TUnit;>;)V
    MethodParameters:
       Name  Flags
      token  

  private java.util.Collection<org.apache.cassandra.dht.Token> generateRandomTokens(org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo<Unit>, int, java.util.Map<Unit, org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo<Unit>>);
    descriptor: (Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$UnitInfo;ILjava/util/Map;)Ljava/util/Collection;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=6, args_size=4
        start local 0 // org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator this
        start local 1 // org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo newUnit
        start local 2 // int numTokens
        start local 3 // java.util.Map unitInfos
         0: .line 118
            new java.util.HashSet
            dup
            iload 2 /* numTokens */
            invokespecial java.util.HashSet.<init>:(I)V
            astore 4 /* tokens */
        start local 4 // java.util.Set tokens
         1: .line 119
            goto 6
         2: .line 121
      StackMap locals: java.util.Set
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.partitioner:Lorg/apache/cassandra/dht/IPartitioner;
            invokeinterface org.apache.cassandra.dht.IPartitioner.getRandomToken:()Lorg/apache/cassandra/dht/Token;
            astore 5 /* token */
        start local 5 // org.apache.cassandra.dht.Token token
         3: .line 122
            aload 0 /* this */
            getfield org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.sortedTokens:Ljava/util/NavigableMap;
            aload 5 /* token */
            invokeinterface java.util.NavigableMap.containsKey:(Ljava/lang/Object;)Z
            ifne 6
         4: .line 124
            aload 4 /* tokens */
            aload 5 /* token */
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
         5: .line 125
            aload 0 /* this */
            getfield org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.sortedTokens:Ljava/util/NavigableMap;
            aload 5 /* token */
            aload 1 /* newUnit */
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo.unit:Ljava/lang/Object;
            invokeinterface java.util.NavigableMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 5 // org.apache.cassandra.dht.Token token
         6: .line 119
      StackMap locals:
      StackMap stack:
            aload 4 /* tokens */
            invokeinterface java.util.Set.size:()I
            iload 2 /* numTokens */
            if_icmplt 2
         7: .line 128
            aload 3 /* unitInfos */
            aload 1 /* newUnit */
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo.unit:Ljava/lang/Object;
            aload 1 /* newUnit */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         8: .line 129
            aload 0 /* this */
            aload 3 /* unitInfos */
            invokevirtual org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.createTokenInfos:(Ljava/util/Map;)Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$TokenInfo;
            pop
         9: .line 130
            aload 4 /* tokens */
            areturn
        end local 4 // java.util.Set tokens
        end local 3 // java.util.Map unitInfos
        end local 2 // int numTokens
        end local 1 // org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo newUnit
        end local 0 // org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   10     0       this  Lorg/apache/cassandra/dht/tokenallocator/NoReplicationTokenAllocator<TUnit;>;
            0   10     1    newUnit  Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$UnitInfo<TUnit;>;
            0   10     2  numTokens  I
            0   10     3  unitInfos  Ljava/util/Map<TUnit;Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$UnitInfo<TUnit;>;>;
            1   10     4     tokens  Ljava/util/Set<Lorg/apache/cassandra/dht/Token;>;
            3    6     5      token  Lorg/apache/cassandra/dht/Token;
    Signature: (Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$UnitInfo<TUnit;>;ILjava/util/Map<TUnit;Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$UnitInfo<TUnit;>;>;)Ljava/util/Collection<Lorg/apache/cassandra/dht/Token;>;
    MethodParameters:
           Name  Flags
      newUnit    
      numTokens  
      unitInfos  

  public java.util.Collection<org.apache.cassandra.dht.Token> addUnit(Unit, int);
    descriptor: (Ljava/lang/Object;I)Ljava/util/Collection;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=29, args_size=3
        start local 0 // org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator this
        start local 1 // java.lang.Object newUnit
        start local 2 // int numTokens
         0: .line 135
            getstatic org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.$assertionsDisabled:Z
            ifne 1
            aload 0 /* this */
            getfield org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.tokensInUnits:Ljava/util/Map;
            aload 1 /* newUnit */
            invokeinterface java.util.Map.containsKey:(Ljava/lang/Object;)Z
            ifeq 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 137
      StackMap locals:
      StackMap stack:
            invokestatic com.google.common.collect.Maps.newHashMap:()Ljava/util/HashMap;
            astore 3 /* groups */
        start local 3 // java.util.Map groups
         2: .line 138
            new org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo
            dup
            aload 1 /* newUnit */
            dconst_0
            aload 3 /* groups */
            aload 0 /* this */
            getfield org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.strategy:Lorg/apache/cassandra/dht/tokenallocator/ReplicationStrategy;
            invokespecial org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo.<init>:(Ljava/lang/Object;DLjava/util/Map;Lorg/apache/cassandra/dht/tokenallocator/ReplicationStrategy;)V
            astore 4 /* newUnitInfo */
        start local 4 // org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo newUnitInfo
         3: .line 139
            aload 0 /* this */
            aload 3 /* groups */
            invokevirtual org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.createUnitInfos:(Ljava/util/Map;)Ljava/util/Map;
            astore 5 /* unitInfos */
        start local 5 // java.util.Map unitInfos
         4: .line 141
            aload 5 /* unitInfos */
            invokeinterface java.util.Map.isEmpty:()Z
            ifeq 6
         5: .line 142
            aload 0 /* this */
            aload 4 /* newUnitInfo */
            iload 2 /* numTokens */
            aload 5 /* unitInfos */
            invokevirtual org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.generateRandomTokens:(Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$UnitInfo;ILjava/util/Map;)Ljava/util/Collection;
            areturn
         6: .line 144
      StackMap locals: java.util.Map org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo java.util.Map
      StackMap stack:
            iload 2 /* numTokens */
            aload 0 /* this */
            getfield org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.sortedTokens:Ljava/util/NavigableMap;
            invokeinterface java.util.NavigableMap.size:()I
            if_icmple 8
         7: .line 145
            aload 0 /* this */
            aload 4 /* newUnitInfo */
            iload 2 /* numTokens */
            aload 5 /* unitInfos */
            invokevirtual org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.generateRandomTokens:(Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$UnitInfo;ILjava/util/Map;)Ljava/util/Collection;
            areturn
         8: .line 147
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 5 /* unitInfos */
            invokevirtual org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.createTokenInfos:(Ljava/util/Map;)Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$TokenInfo;
            astore 6 /* head */
        start local 6 // org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo head
         9: .line 150
            dconst_0
            dstore 7 /* targetAverage */
        start local 7 // double targetAverage
        10: .line 151
            dconst_0
            dstore 9 /* sum */
        start local 9 // double sum
        11: .line 152
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 11 /* unitsToChange */
        start local 11 // java.util.List unitsToChange
        12: .line 154
            iconst_0
            istore 12 /* i */
        start local 12 // int i
        13: goto 25
        14: .line 156
      StackMap locals: org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator java.lang.Object int java.util.Map org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo java.util.Map org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo double double java.util.List int
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.sortedUnits:Ljava/util/PriorityQueue;
            invokevirtual java.util.PriorityQueue.peek:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted
            astore 13 /* unit */
        start local 13 // org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted unit
        15: .line 158
            aload 13 /* unit */
            ifnonnull 17
        16: .line 159
            goto 26
        17: .line 161
      StackMap locals: org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted
      StackMap stack:
            dload 9 /* sum */
            aload 13 /* unit */
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted.weight:D
            dadd
            dstore 9 /* sum */
        18: .line 162
            dload 9 /* sum */
            aload 11 /* unitsToChange */
            invokeinterface java.util.List.size:()I
            iconst_2
            iadd
            i2d
            ddiv
            dstore 14 /* average */
        start local 14 // double average
        19: .line 163
            aload 13 /* unit */
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted.weight:D
            dload 14 /* average */
            dcmpg
            ifgt 21
        20: .line 165
            goto 26
        21: .line 167
      StackMap locals: double
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.sortedUnits:Ljava/util/PriorityQueue;
            invokevirtual java.util.PriorityQueue.remove:()Ljava/lang/Object;
            pop
        22: .line 168
            aload 11 /* unitsToChange */
            aload 13 /* unit */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        23: .line 169
            dload 14 /* average */
            dstore 7 /* targetAverage */
        end local 14 // double average
        end local 13 // org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted unit
        24: .line 154
            iinc 12 /* i */ 1
      StackMap locals:
      StackMap stack:
        25: iload 12 /* i */
            iload 2 /* numTokens */
            if_icmplt 14
        end local 12 // int i
        26: .line 172
      StackMap locals:
      StackMap stack:
            iload 2 /* numTokens */
            invokestatic com.google.common.collect.Lists.newArrayListWithCapacity:(I)Ljava/util/ArrayList;
            astore 12 /* newTokens */
        start local 12 // java.util.List newTokens
        27: .line 174
            iconst_0
            istore 13 /* nr */
        start local 13 // int nr
        28: .line 176
            aload 11 /* unitsToChange */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 15
            goto 65
      StackMap locals: org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator java.lang.Object int java.util.Map org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo java.util.Map org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo double double java.util.List java.util.List int top java.util.Iterator
      StackMap stack:
        29: aload 15
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted
            astore 14 /* unit */
        start local 14 // org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted unit
        30: .line 179
            iload 2 /* numTokens */
            aload 11 /* unitsToChange */
            invokeinterface java.util.List.size:()I
            idiv
            iload 13 /* nr */
            iload 2 /* numTokens */
            aload 11 /* unitsToChange */
            invokeinterface java.util.List.size:()I
            irem
            if_icmpge 31
            iconst_1
            goto 32
      StackMap locals: org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator java.lang.Object int java.util.Map org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo java.util.Map org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo double double java.util.List java.util.List int org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted java.util.Iterator
      StackMap stack: int
        31: iconst_0
      StackMap locals: org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator java.lang.Object int java.util.Map org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo java.util.Map org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo double double java.util.List java.util.List int org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted java.util.Iterator
      StackMap stack: int int
        32: iadd
            istore 16 /* tokensToChange */
        start local 16 // int tokensToChange
        33: .line 181
            aload 0 /* this */
            getfield org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.tokensInUnits:Ljava/util/Map;
            aload 14 /* unit */
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted.value:Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo.unit:Ljava/lang/Object;
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.util.Queue
            astore 17 /* unitTokens */
        start local 17 // java.util.Queue unitTokens
        34: .line 182
            iload 16 /* tokensToChange */
            invokestatic com.google.common.collect.Lists.newArrayListWithCapacity:(I)Ljava/util/ArrayList;
            astore 18 /* tokens */
        start local 18 // java.util.List tokens
        35: .line 184
            dconst_0
            dstore 19 /* workWeight */
        start local 19 // double workWeight
        36: .line 186
            iconst_0
            istore 21 /* i */
        start local 21 // int i
        37: goto 43
        38: .line 188
      StackMap locals: org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator java.lang.Object int java.util.Map org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo java.util.Map org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo double double java.util.List java.util.List int org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted java.util.Iterator int java.util.Queue java.util.List double int
      StackMap stack:
            aload 17 /* unitTokens */
            invokeinterface java.util.Queue.remove:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted
            astore 22 /* wt */
        start local 22 // org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted wt
        39: .line 189
            aload 18 /* tokens */
            aload 22 /* wt */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        40: .line 190
            dload 19 /* workWeight */
            aload 22 /* wt */
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted.weight:D
            dadd
            dstore 19 /* workWeight */
        41: .line 191
            aload 14 /* unit */
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted.value:Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo
            dup
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo.ownership:D
            aload 22 /* wt */
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted.weight:D
            dsub
            putfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo.ownership:D
        end local 22 // org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted wt
        42: .line 186
            iinc 21 /* i */ 1
      StackMap locals:
      StackMap stack:
        43: iload 21 /* i */
            iload 16 /* tokensToChange */
            if_icmplt 38
        end local 21 // int i
        44: .line 194
            aload 14 /* unit */
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted.weight:D
            dload 7 /* targetAverage */
            dsub
            dstore 21 /* toTakeOver */
        start local 21 // double toTakeOver
        45: .line 196
            aload 18 /* tokens */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 24
            goto 62
      StackMap locals: org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator java.lang.Object int java.util.Map org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo java.util.Map org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo double double java.util.List java.util.List int org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted java.util.Iterator int java.util.Queue java.util.List double double top java.util.Iterator
      StackMap stack:
        46: aload 24
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted
            astore 23 /* wt */
        start local 23 // org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted wt
        47: .line 201
            dload 21 /* toTakeOver */
            dload 19 /* workWeight */
            dcmpg
            ifge 54
        48: .line 204
            dload 21 /* toTakeOver */
            dload 19 /* workWeight */
            ddiv
            dstore 25 /* slice */
        start local 25 // double slice
        49: .line 206
            dload 25 /* slice */
            ldc 0.09999999999999998
            dcmpg
            ifge 51
        50: .line 207
            ldc 0.09999999999999998
            dstore 25 /* slice */
        51: .line 208
      StackMap locals: org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator java.lang.Object int java.util.Map org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo java.util.Map org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo double double java.util.List java.util.List int org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted java.util.Iterator int java.util.Queue java.util.List double double org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted java.util.Iterator double
      StackMap stack:
            dload 25 /* slice */
            ldc 0.9
            dcmpl
            ifle 55
        52: .line 209
            ldc 0.9
            dstore 25 /* slice */
        53: .line 210
            goto 55
        end local 25 // double slice
        54: .line 213
      StackMap locals:
      StackMap stack:
            ldc 0.9
            dstore 25 /* slice */
        start local 25 // double slice
        55: .line 215
      StackMap locals: double
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.partitioner:Lorg/apache/cassandra/dht/IPartitioner;
            aload 23 /* wt */
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted.value:Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo
            invokevirtual org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo.prevInRing:()Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$TokenInfo;
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo.token:Lorg/apache/cassandra/dht/Token;
            aload 23 /* wt */
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted.value:Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo.token:Lorg/apache/cassandra/dht/Token;
            dload 25 /* slice */
            invokeinterface org.apache.cassandra.dht.IPartitioner.split:(Lorg/apache/cassandra/dht/Token;Lorg/apache/cassandra/dht/Token;D)Lorg/apache/cassandra/dht/Token;
            astore 27 /* token */
        start local 27 // org.apache.cassandra.dht.Token token
        56: .line 218
            aload 0 /* this */
            getfield org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.sortedTokens:Ljava/util/NavigableMap;
            aload 27 /* token */
            aload 1 /* newUnit */
            invokeinterface java.util.NavigableMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        57: .line 220
            new org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo
            dup
            aload 27 /* token */
            aload 4 /* newUnitInfo */
            invokespecial org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo.<init>:(Lorg/apache/cassandra/dht/Token;Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$UnitInfo;)V
            astore 28 /* ti */
        start local 28 // org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo ti
        58: .line 222
            aload 28 /* ti */
            aload 6 /* head */
            aload 23 /* wt */
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted.value:Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo
            invokevirtual org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo.prevInRing:()Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$TokenInfo;
            invokevirtual org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo.insertAfter:(Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$CircularList;Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$CircularList;)Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$CircularList;
            pop
        59: .line 224
            aload 0 /* this */
            aload 28 /* ti */
            invokevirtual org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.populateTokenInfoAndAdjustUnit:(Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$TokenInfo;)V
        60: .line 225
            aload 0 /* this */
            aload 23 /* wt */
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted.value:Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo
            invokevirtual org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.populateTokenInfoAndAdjustUnit:(Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$TokenInfo;)V
        61: .line 226
            aload 12 /* newTokens */
            aload 27 /* token */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 28 // org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo ti
        end local 27 // org.apache.cassandra.dht.Token token
        end local 25 // double slice
        end local 23 // org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted wt
        62: .line 196
      StackMap locals: org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator java.lang.Object int java.util.Map org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo java.util.Map org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo double double java.util.List java.util.List int org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted java.util.Iterator int java.util.Queue java.util.List double double top java.util.Iterator
      StackMap stack:
            aload 24
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 46
        63: .line 230
            aload 0 /* this */
            getfield org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.sortedUnits:Ljava/util/PriorityQueue;
            new org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted
            dup
            aload 14 /* unit */
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted.value:Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo.ownership:D
            aload 14 /* unit */
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted.value:Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo
            invokespecial org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted.<init>:(DLjava/lang/Object;)V
            invokevirtual java.util.PriorityQueue.add:(Ljava/lang/Object;)Z
            pop
        64: .line 231
            iinc 13 /* nr */ 1
        end local 21 // double toTakeOver
        end local 19 // double workWeight
        end local 18 // java.util.List tokens
        end local 17 // java.util.Queue unitTokens
        end local 16 // int tokensToChange
        end local 14 // org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted unit
        65: .line 176
      StackMap locals: org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator java.lang.Object int java.util.Map org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo java.util.Map org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo double double java.util.List java.util.List int top java.util.Iterator
      StackMap stack:
            aload 15
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 29
        66: .line 233
            aload 0 /* this */
            getfield org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.sortedUnits:Ljava/util/PriorityQueue;
            new org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted
            dup
            aload 4 /* newUnitInfo */
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo.ownership:D
            aload 4 /* newUnitInfo */
            invokespecial org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted.<init>:(DLjava/lang/Object;)V
            invokevirtual java.util.PriorityQueue.add:(Ljava/lang/Object;)Z
            pop
        67: .line 235
            aload 12 /* newTokens */
            areturn
        end local 13 // int nr
        end local 12 // java.util.List newTokens
        end local 11 // java.util.List unitsToChange
        end local 9 // double sum
        end local 7 // double targetAverage
        end local 6 // org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo head
        end local 5 // java.util.Map unitInfos
        end local 4 // org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo newUnitInfo
        end local 3 // java.util.Map groups
        end local 2 // int numTokens
        end local 1 // java.lang.Object newUnit
        end local 0 // org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   68     0            this  Lorg/apache/cassandra/dht/tokenallocator/NoReplicationTokenAllocator<TUnit;>;
            0   68     1         newUnit  TUnit;
            0   68     2       numTokens  I
            2   68     3          groups  Ljava/util/Map<Ljava/lang/Object;Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$GroupInfo;>;
            3   68     4     newUnitInfo  Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$UnitInfo<TUnit;>;
            4   68     5       unitInfos  Ljava/util/Map<TUnit;Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$UnitInfo<TUnit;>;>;
            9   68     6            head  Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$TokenInfo<TUnit;>;
           10   68     7   targetAverage  D
           11   68     9             sum  D
           12   68    11   unitsToChange  Ljava/util/List<Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$Weighted<Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$UnitInfo;>;>;
           13   26    12               i  I
           15   24    13            unit  Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$Weighted<Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$UnitInfo;>;
           19   24    14         average  D
           27   68    12       newTokens  Ljava/util/List<Lorg/apache/cassandra/dht/Token;>;
           28   68    13              nr  I
           30   65    14            unit  Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$Weighted<Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$UnitInfo;>;
           33   65    16  tokensToChange  I
           34   65    17      unitTokens  Ljava/util/Queue<Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$Weighted<Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$TokenInfo;>;>;
           35   65    18          tokens  Ljava/util/List<Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$Weighted<Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$TokenInfo;>;>;
           36   65    19      workWeight  D
           37   44    21               i  I
           39   42    22              wt  Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$Weighted<Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$TokenInfo;>;
           45   65    21      toTakeOver  D
           47   62    23              wt  Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$Weighted<Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$TokenInfo;>;
           49   54    25           slice  D
           55   62    25           slice  D
           56   62    27           token  Lorg/apache/cassandra/dht/Token;
           58   62    28              ti  Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$TokenInfo<TUnit;>;
    Signature: (TUnit;I)Ljava/util/Collection<Lorg/apache/cassandra/dht/Token;>;
    MethodParameters:
           Name  Flags
      newUnit    
      numTokens  

  void removeUnit();
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=7, args_size=2
        start local 0 // org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator this
        start local 1 // java.lang.Object n
         0: .line 243
            aload 0 /* this */
            getfield org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.sortedUnits:Ljava/util/PriorityQueue;
            invokevirtual java.util.PriorityQueue.iterator:()Ljava/util/Iterator;
            astore 2 /* it */
        start local 2 // java.util.Iterator it
         1: .line 244
            goto 5
         2: .line 246
      StackMap locals: java.util.Iterator
      StackMap stack:
            aload 2 /* it */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted.value:Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo.unit:Ljava/lang/Object;
            aload 1 /* n */
            invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
            ifeq 5
         3: .line 248
            aload 2 /* it */
            invokeinterface java.util.Iterator.remove:()V
         4: .line 249
            goto 6
         5: .line 244
      StackMap locals:
      StackMap stack:
            aload 2 /* it */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         6: .line 253
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.tokensInUnits:Ljava/util/Map;
            aload 1 /* n */
            invokeinterface java.util.Map.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.util.PriorityQueue
            astore 3 /* tokenInfos */
        start local 3 // java.util.PriorityQueue tokenInfos
         7: .line 254
            aload 3 /* tokenInfos */
            invokevirtual java.util.PriorityQueue.size:()I
            invokestatic com.google.common.collect.Lists.newArrayListWithCapacity:(I)Ljava/util/ArrayList;
            astore 4 /* tokens */
        start local 4 // java.util.Collection tokens
         8: .line 255
            aload 3 /* tokenInfos */
            invokevirtual java.util.PriorityQueue.iterator:()Ljava/util/Iterator;
            astore 6
            goto 11
      StackMap locals: org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator java.lang.Object java.util.Iterator java.util.PriorityQueue java.util.Collection top java.util.Iterator
      StackMap stack:
         9: aload 6
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted
            astore 5 /* tokenInfo */
        start local 5 // org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted tokenInfo
        10: .line 257
            aload 4 /* tokens */
            aload 5 /* tokenInfo */
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted.value:Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo
            getfield org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo.token:Lorg/apache/cassandra/dht/Token;
            invokeinterface java.util.Collection.add:(Ljava/lang/Object;)Z
            pop
        end local 5 // org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted tokenInfo
        11: .line 255
      StackMap locals:
      StackMap stack:
            aload 6
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 9
        12: .line 259
            aload 0 /* this */
            getfield org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator.sortedTokens:Ljava/util/NavigableMap;
            invokeinterface java.util.NavigableMap.keySet:()Ljava/util/Set;
            aload 4 /* tokens */
            invokeinterface java.util.Set.removeAll:(Ljava/util/Collection;)Z
            pop
        13: .line 260
            return
        end local 4 // java.util.Collection tokens
        end local 3 // java.util.PriorityQueue tokenInfos
        end local 2 // java.util.Iterator it
        end local 1 // java.lang.Object n
        end local 0 // org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   14     0        this  Lorg/apache/cassandra/dht/tokenallocator/NoReplicationTokenAllocator<TUnit;>;
            0   14     1           n  TUnit;
            1   14     2          it  Ljava/util/Iterator<Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$Weighted<Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$UnitInfo;>;>;
            7   14     3  tokenInfos  Ljava/util/PriorityQueue<Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$Weighted<Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$TokenInfo;>;>;
            8   14     4      tokens  Ljava/util/Collection<Lorg/apache/cassandra/dht/Token;>;
           10   11     5   tokenInfo  Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$Weighted<Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase$TokenInfo;>;
    Signature: (TUnit;)V
    MethodParameters:
      Name  Flags
      n     

  public int getReplicas();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator this
         0: .line 264
            iconst_1
            ireturn
        end local 0 // org.apache.cassandra.dht.tokenallocator.NoReplicationTokenAllocator this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/dht/tokenallocator/NoReplicationTokenAllocator<TUnit;>;
}
Signature: <Unit:Ljava/lang/Object;>Lorg/apache/cassandra/dht/tokenallocator/TokenAllocatorBase<TUnit;>;
SourceFile: "NoReplicationTokenAllocator.java"
InnerClasses:
  public abstract Entry = java.util.Map$Entry of java.util.Map
  GroupInfo = org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$GroupInfo of org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase
  TokenInfo = org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$TokenInfo of org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase
  UnitInfo = org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$UnitInfo of org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase
  Weighted = org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$Weighted of org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase
  private CircularList = org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase$CircularList of org.apache.cassandra.dht.tokenallocator.TokenAllocatorBase