public abstract class org.apache.cassandra.dht.Splitter
  minor version: 0
  major version: 59
  flags: flags: (0x0421) ACC_PUBLIC, ACC_SUPER, ACC_ABSTRACT
  this_class: org.apache.cassandra.dht.Splitter
  super_class: java.lang.Object
{
  private final org.apache.cassandra.dht.IPartitioner partitioner;
    descriptor: Lorg/apache/cassandra/dht/IPartitioner;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  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 29
            ldc Lorg/apache/cassandra/dht/Splitter;
            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.Splitter.$assertionsDisabled:Z
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  protected void <init>(org.apache.cassandra.dht.IPartitioner);
    descriptor: (Lorg/apache/cassandra/dht/IPartitioner;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.dht.Splitter this
        start local 1 // org.apache.cassandra.dht.IPartitioner partitioner
         0: .line 33
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 35
            aload 0 /* this */
            aload 1 /* partitioner */
            putfield org.apache.cassandra.dht.Splitter.partitioner:Lorg/apache/cassandra/dht/IPartitioner;
         2: .line 36
            return
        end local 1 // org.apache.cassandra.dht.IPartitioner partitioner
        end local 0 // org.apache.cassandra.dht.Splitter this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    3     0         this  Lorg/apache/cassandra/dht/Splitter;
            0    3     1  partitioner  Lorg/apache/cassandra/dht/IPartitioner;
    MethodParameters:
             Name  Flags
      partitioner  

  protected abstract org.apache.cassandra.dht.Token tokenForValue(java.math.BigInteger);
    descriptor: (Ljava/math/BigInteger;)Lorg/apache/cassandra/dht/Token;
    flags: (0x0404) ACC_PROTECTED, ACC_ABSTRACT
    MethodParameters:
       Name  Flags
      value  

  protected abstract java.math.BigInteger valueForToken(org.apache.cassandra.dht.Token);
    descriptor: (Lorg/apache/cassandra/dht/Token;)Ljava/math/BigInteger;
    flags: (0x0404) ACC_PROTECTED, ACC_ABSTRACT
    MethodParameters:
       Name  Flags
      token  

  public java.util.List<org.apache.cassandra.dht.Token> splitOwnedRanges(int, java.util.List<org.apache.cassandra.dht.Range<org.apache.cassandra.dht.Token>>, boolean);
    descriptor: (ILjava/util/List;Z)Ljava/util/List;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=14, args_size=4
        start local 0 // org.apache.cassandra.dht.Splitter this
        start local 1 // int parts
        start local 2 // java.util.List localRanges
        start local 3 // boolean dontSplitRanges
         0: .line 44
            aload 2 /* localRanges */
            invokeinterface java.util.List.isEmpty:()Z
            ifne 1
            iload 1 /* parts */
            iconst_1
            if_icmpne 2
         1: .line 45
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.dht.Splitter.partitioner:Lorg/apache/cassandra/dht/IPartitioner;
            invokeinterface org.apache.cassandra.dht.IPartitioner.getMaximumToken:()Lorg/apache/cassandra/dht/Token;
            invokestatic java.util.Collections.singletonList:(Ljava/lang/Object;)Ljava/util/List;
            areturn
         2: .line 47
      StackMap locals:
      StackMap stack:
            getstatic java.math.BigInteger.ZERO:Ljava/math/BigInteger;
            astore 4 /* totalTokens */
        start local 4 // java.math.BigInteger totalTokens
         3: .line 48
            aload 2 /* localRanges */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 6
            goto 7
      StackMap locals: org.apache.cassandra.dht.Splitter int java.util.List int java.math.BigInteger top java.util.Iterator
      StackMap stack:
         4: aload 6
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Range
            astore 5 /* r */
        start local 5 // org.apache.cassandra.dht.Range r
         5: .line 50
            aload 0 /* this */
            aload 0 /* this */
            aload 5 /* r */
            getfield org.apache.cassandra.dht.Range.right:Lorg/apache/cassandra/dht/RingPosition;
            checkcast org.apache.cassandra.dht.Token
            invokevirtual org.apache.cassandra.dht.Splitter.token:(Lorg/apache/cassandra/dht/Token;)Lorg/apache/cassandra/dht/Token;
            invokevirtual org.apache.cassandra.dht.Splitter.valueForToken:(Lorg/apache/cassandra/dht/Token;)Ljava/math/BigInteger;
            astore 7 /* right */
        start local 7 // java.math.BigInteger right
         6: .line 51
            aload 4 /* totalTokens */
            aload 7 /* right */
            aload 0 /* this */
            aload 5 /* r */
            getfield org.apache.cassandra.dht.Range.left:Lorg/apache/cassandra/dht/RingPosition;
            checkcast org.apache.cassandra.dht.Token
            invokevirtual org.apache.cassandra.dht.Splitter.valueForToken:(Lorg/apache/cassandra/dht/Token;)Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.subtract:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.add:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
            astore 4 /* totalTokens */
        end local 7 // java.math.BigInteger right
        end local 5 // org.apache.cassandra.dht.Range r
         7: .line 48
      StackMap locals:
      StackMap stack:
            aload 6
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 4
         8: .line 53
            aload 4 /* totalTokens */
            iload 1 /* parts */
            i2l
            invokestatic java.math.BigInteger.valueOf:(J)Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.divide:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
            astore 5 /* perPart */
        start local 5 // java.math.BigInteger perPart
         9: .line 55
            aload 5 /* perPart */
            getstatic java.math.BigInteger.ZERO:Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.equals:(Ljava/lang/Object;)Z
            ifeq 11
        10: .line 56
            aload 0 /* this */
            getfield org.apache.cassandra.dht.Splitter.partitioner:Lorg/apache/cassandra/dht/IPartitioner;
            invokeinterface org.apache.cassandra.dht.IPartitioner.getMaximumToken:()Lorg/apache/cassandra/dht/Token;
            invokestatic java.util.Collections.singletonList:(Ljava/lang/Object;)Ljava/util/List;
            areturn
        11: .line 58
      StackMap locals: org.apache.cassandra.dht.Splitter int java.util.List int java.math.BigInteger java.math.BigInteger
      StackMap stack:
            iload 3 /* dontSplitRanges */
            ifeq 13
        12: .line 59
            aload 0 /* this */
            aload 2 /* localRanges */
            aload 5 /* perPart */
            iload 1 /* parts */
            invokevirtual org.apache.cassandra.dht.Splitter.splitOwnedRangesNoPartialRanges:(Ljava/util/List;Ljava/math/BigInteger;I)Ljava/util/List;
            areturn
        13: .line 61
      StackMap locals:
      StackMap stack:
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 6 /* boundaries */
        start local 6 // java.util.List boundaries
        14: .line 62
            getstatic java.math.BigInteger.ZERO:Ljava/math/BigInteger;
            astore 7 /* sum */
        start local 7 // java.math.BigInteger sum
        15: .line 63
            aload 2 /* localRanges */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 9
            goto 28
      StackMap locals: org.apache.cassandra.dht.Splitter int java.util.List int java.math.BigInteger java.math.BigInteger java.util.List java.math.BigInteger top java.util.Iterator
      StackMap stack:
        16: aload 9
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Range
            astore 8 /* r */
        start local 8 // org.apache.cassandra.dht.Range r
        17: .line 65
            aload 0 /* this */
            aload 8 /* r */
            getfield org.apache.cassandra.dht.Range.right:Lorg/apache/cassandra/dht/RingPosition;
            checkcast org.apache.cassandra.dht.Token
            invokevirtual org.apache.cassandra.dht.Splitter.token:(Lorg/apache/cassandra/dht/Token;)Lorg/apache/cassandra/dht/Token;
            astore 10 /* right */
        start local 10 // org.apache.cassandra.dht.Token right
        18: .line 66
            aload 0 /* this */
            aload 10 /* right */
            invokevirtual org.apache.cassandra.dht.Splitter.valueForToken:(Lorg/apache/cassandra/dht/Token;)Ljava/math/BigInteger;
            aload 0 /* this */
            aload 8 /* r */
            getfield org.apache.cassandra.dht.Range.left:Lorg/apache/cassandra/dht/RingPosition;
            checkcast org.apache.cassandra.dht.Token
            invokevirtual org.apache.cassandra.dht.Splitter.valueForToken:(Lorg/apache/cassandra/dht/Token;)Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.subtract:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.abs:()Ljava/math/BigInteger;
            astore 11 /* currentRangeWidth */
        start local 11 // java.math.BigInteger currentRangeWidth
        19: .line 67
            aload 0 /* this */
            aload 8 /* r */
            getfield org.apache.cassandra.dht.Range.left:Lorg/apache/cassandra/dht/RingPosition;
            checkcast org.apache.cassandra.dht.Token
            invokevirtual org.apache.cassandra.dht.Splitter.valueForToken:(Lorg/apache/cassandra/dht/Token;)Ljava/math/BigInteger;
            astore 12 /* left */
        start local 12 // java.math.BigInteger left
        20: .line 68
            goto 26
        21: .line 70
      StackMap locals: org.apache.cassandra.dht.Splitter int java.util.List int java.math.BigInteger java.math.BigInteger java.util.List java.math.BigInteger org.apache.cassandra.dht.Range java.util.Iterator org.apache.cassandra.dht.Token java.math.BigInteger java.math.BigInteger
      StackMap stack:
            aload 5 /* perPart */
            aload 7 /* sum */
            invokevirtual java.math.BigInteger.subtract:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
            astore 13 /* withinRangeBoundary */
        start local 13 // java.math.BigInteger withinRangeBoundary
        22: .line 71
            aload 12 /* left */
            aload 13 /* withinRangeBoundary */
            invokevirtual java.math.BigInteger.add:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
            astore 12 /* left */
        23: .line 72
            aload 6 /* boundaries */
            aload 0 /* this */
            aload 12 /* left */
            invokevirtual org.apache.cassandra.dht.Splitter.tokenForValue:(Ljava/math/BigInteger;)Lorg/apache/cassandra/dht/Token;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        24: .line 73
            aload 11 /* currentRangeWidth */
            aload 13 /* withinRangeBoundary */
            invokevirtual java.math.BigInteger.subtract:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
            astore 11 /* currentRangeWidth */
        25: .line 74
            getstatic java.math.BigInteger.ZERO:Ljava/math/BigInteger;
            astore 7 /* sum */
        end local 13 // java.math.BigInteger withinRangeBoundary
        26: .line 68
      StackMap locals:
      StackMap stack:
            aload 7 /* sum */
            aload 11 /* currentRangeWidth */
            invokevirtual java.math.BigInteger.add:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
            aload 5 /* perPart */
            invokevirtual java.math.BigInteger.compareTo:(Ljava/math/BigInteger;)I
            ifge 21
        27: .line 76
            aload 7 /* sum */
            aload 11 /* currentRangeWidth */
            invokevirtual java.math.BigInteger.add:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
            astore 7 /* sum */
        end local 12 // java.math.BigInteger left
        end local 11 // java.math.BigInteger currentRangeWidth
        end local 10 // org.apache.cassandra.dht.Token right
        end local 8 // org.apache.cassandra.dht.Range r
        28: .line 63
      StackMap locals: org.apache.cassandra.dht.Splitter int java.util.List int java.math.BigInteger java.math.BigInteger java.util.List java.math.BigInteger top java.util.Iterator
      StackMap stack:
            aload 9
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 16
        29: .line 78
            aload 6 /* boundaries */
            aload 6 /* boundaries */
            invokeinterface java.util.List.size:()I
            iconst_1
            isub
            aload 0 /* this */
            getfield org.apache.cassandra.dht.Splitter.partitioner:Lorg/apache/cassandra/dht/IPartitioner;
            invokeinterface org.apache.cassandra.dht.IPartitioner.getMaximumToken:()Lorg/apache/cassandra/dht/Token;
            invokeinterface java.util.List.set:(ILjava/lang/Object;)Ljava/lang/Object;
            pop
        30: .line 80
            getstatic org.apache.cassandra.dht.Splitter.$assertionsDisabled:Z
            ifne 31
            aload 6 /* boundaries */
            invokeinterface java.util.List.size:()I
            iload 1 /* parts */
            if_icmpeq 31
            new java.lang.AssertionError
            dup
            new java.lang.StringBuilder
            dup
            aload 6 /* boundaries */
            invokeinterface java.util.List.size:()I
            invokestatic java.lang.String.valueOf:(I)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc "!="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            iload 1 /* parts */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 6 /* boundaries */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc ":"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 2 /* localRanges */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
        31: .line 81
      StackMap locals: org.apache.cassandra.dht.Splitter int java.util.List int java.math.BigInteger java.math.BigInteger java.util.List java.math.BigInteger
      StackMap stack:
            aload 6 /* boundaries */
            areturn
        end local 7 // java.math.BigInteger sum
        end local 6 // java.util.List boundaries
        end local 5 // java.math.BigInteger perPart
        end local 4 // java.math.BigInteger totalTokens
        end local 3 // boolean dontSplitRanges
        end local 2 // java.util.List localRanges
        end local 1 // int parts
        end local 0 // org.apache.cassandra.dht.Splitter this
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0   32     0                 this  Lorg/apache/cassandra/dht/Splitter;
            0   32     1                parts  I
            0   32     2          localRanges  Ljava/util/List<Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;>;
            0   32     3      dontSplitRanges  Z
            3   32     4          totalTokens  Ljava/math/BigInteger;
            5    7     5                    r  Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;
            6    7     7                right  Ljava/math/BigInteger;
            9   32     5              perPart  Ljava/math/BigInteger;
           14   32     6           boundaries  Ljava/util/List<Lorg/apache/cassandra/dht/Token;>;
           15   32     7                  sum  Ljava/math/BigInteger;
           17   28     8                    r  Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;
           18   28    10                right  Lorg/apache/cassandra/dht/Token;
           19   28    11    currentRangeWidth  Ljava/math/BigInteger;
           20   28    12                 left  Ljava/math/BigInteger;
           22   26    13  withinRangeBoundary  Ljava/math/BigInteger;
    Signature: (ILjava/util/List<Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;>;Z)Ljava/util/List<Lorg/apache/cassandra/dht/Token;>;
    MethodParameters:
                 Name  Flags
      parts            
      localRanges      
      dontSplitRanges  

  private java.util.List<org.apache.cassandra.dht.Token> splitOwnedRangesNoPartialRanges(java.util.List<org.apache.cassandra.dht.Range<org.apache.cassandra.dht.Token>>, java.math.BigInteger, int);
    descriptor: (Ljava/util/List;Ljava/math/BigInteger;I)Ljava/util/List;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=16, args_size=4
        start local 0 // org.apache.cassandra.dht.Splitter this
        start local 1 // java.util.List localRanges
        start local 2 // java.math.BigInteger perPart
        start local 3 // int parts
         0: .line 86
            new java.util.ArrayList
            dup
            iload 3 /* parts */
            invokespecial java.util.ArrayList.<init>:(I)V
            astore 4 /* boundaries */
        start local 4 // java.util.List boundaries
         1: .line 87
            getstatic java.math.BigInteger.ZERO:Ljava/math/BigInteger;
            astore 5 /* sum */
        start local 5 // java.math.BigInteger sum
         2: .line 89
            iconst_0
            istore 6 /* i */
        start local 6 // int i
         3: .line 90
            aload 1 /* localRanges */
            invokeinterface java.util.List.size:()I
            istore 7 /* rangesCount */
        start local 7 // int rangesCount
         4: .line 91
            goto 19
         5: .line 93
      StackMap locals: org.apache.cassandra.dht.Splitter java.util.List java.math.BigInteger int java.util.List java.math.BigInteger int int
      StackMap stack:
            aload 1 /* localRanges */
            iload 6 /* i */
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Range
            astore 8 /* r */
        start local 8 // org.apache.cassandra.dht.Range r
         6: .line 94
            aload 1 /* localRanges */
            iload 6 /* i */
            iconst_1
            iadd
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Range
            astore 9 /* nextRange */
        start local 9 // org.apache.cassandra.dht.Range nextRange
         7: .line 95
            aload 0 /* this */
            aload 8 /* r */
            getfield org.apache.cassandra.dht.Range.right:Lorg/apache/cassandra/dht/RingPosition;
            checkcast org.apache.cassandra.dht.Token
            invokevirtual org.apache.cassandra.dht.Splitter.token:(Lorg/apache/cassandra/dht/Token;)Lorg/apache/cassandra/dht/Token;
            astore 10 /* right */
        start local 10 // org.apache.cassandra.dht.Token right
         8: .line 96
            aload 0 /* this */
            aload 9 /* nextRange */
            getfield org.apache.cassandra.dht.Range.right:Lorg/apache/cassandra/dht/RingPosition;
            checkcast org.apache.cassandra.dht.Token
            invokevirtual org.apache.cassandra.dht.Splitter.token:(Lorg/apache/cassandra/dht/Token;)Lorg/apache/cassandra/dht/Token;
            astore 11 /* nextRight */
        start local 11 // org.apache.cassandra.dht.Token nextRight
         9: .line 98
            aload 0 /* this */
            aload 10 /* right */
            invokevirtual org.apache.cassandra.dht.Splitter.valueForToken:(Lorg/apache/cassandra/dht/Token;)Ljava/math/BigInteger;
            aload 0 /* this */
            aload 8 /* r */
            getfield org.apache.cassandra.dht.Range.left:Lorg/apache/cassandra/dht/RingPosition;
            checkcast org.apache.cassandra.dht.Token
            invokevirtual org.apache.cassandra.dht.Splitter.valueForToken:(Lorg/apache/cassandra/dht/Token;)Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.subtract:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
            astore 12 /* currentRangeWidth */
        start local 12 // java.math.BigInteger currentRangeWidth
        10: .line 99
            aload 0 /* this */
            aload 11 /* nextRight */
            invokevirtual org.apache.cassandra.dht.Splitter.valueForToken:(Lorg/apache/cassandra/dht/Token;)Ljava/math/BigInteger;
            aload 0 /* this */
            aload 9 /* nextRange */
            getfield org.apache.cassandra.dht.Range.left:Lorg/apache/cassandra/dht/RingPosition;
            checkcast org.apache.cassandra.dht.Token
            invokevirtual org.apache.cassandra.dht.Splitter.valueForToken:(Lorg/apache/cassandra/dht/Token;)Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.subtract:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
            astore 13 /* nextRangeWidth */
        start local 13 // java.math.BigInteger nextRangeWidth
        11: .line 100
            aload 5 /* sum */
            aload 12 /* currentRangeWidth */
            invokevirtual java.math.BigInteger.add:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
            astore 5 /* sum */
        12: .line 103
            aload 5 /* sum */
            aload 2 /* perPart */
            invokevirtual java.math.BigInteger.compareTo:(Ljava/math/BigInteger;)I
            ifgt 13
            aload 5 /* sum */
            aload 13 /* nextRangeWidth */
            invokevirtual java.math.BigInteger.add:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
            aload 2 /* perPart */
            invokevirtual java.math.BigInteger.compareTo:(Ljava/math/BigInteger;)I
            ifle 18
        13: .line 107
      StackMap locals: org.apache.cassandra.dht.Splitter java.util.List java.math.BigInteger int java.util.List java.math.BigInteger int int org.apache.cassandra.dht.Range org.apache.cassandra.dht.Range org.apache.cassandra.dht.Token org.apache.cassandra.dht.Token java.math.BigInteger java.math.BigInteger
      StackMap stack:
            aload 5 /* sum */
            aload 2 /* perPart */
            invokevirtual java.math.BigInteger.subtract:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.abs:()Ljava/math/BigInteger;
            astore 14 /* diffCurrent */
        start local 14 // java.math.BigInteger diffCurrent
        14: .line 108
            aload 5 /* sum */
            aload 13 /* nextRangeWidth */
            invokevirtual java.math.BigInteger.add:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
            aload 2 /* perPart */
            invokevirtual java.math.BigInteger.subtract:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.abs:()Ljava/math/BigInteger;
            astore 15 /* diffNext */
        start local 15 // java.math.BigInteger diffNext
        15: .line 109
            aload 15 /* diffNext */
            aload 14 /* diffCurrent */
            invokevirtual java.math.BigInteger.compareTo:(Ljava/math/BigInteger;)I
            iflt 18
        16: .line 111
            getstatic java.math.BigInteger.ZERO:Ljava/math/BigInteger;
            astore 5 /* sum */
        17: .line 112
            aload 4 /* boundaries */
            aload 10 /* right */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 15 // java.math.BigInteger diffNext
        end local 14 // java.math.BigInteger diffCurrent
        18: .line 115
      StackMap locals:
      StackMap stack:
            iinc 6 /* i */ 1
        end local 13 // java.math.BigInteger nextRangeWidth
        end local 12 // java.math.BigInteger currentRangeWidth
        end local 11 // org.apache.cassandra.dht.Token nextRight
        end local 10 // org.apache.cassandra.dht.Token right
        end local 9 // org.apache.cassandra.dht.Range nextRange
        end local 8 // org.apache.cassandra.dht.Range r
        19: .line 91
      StackMap locals: org.apache.cassandra.dht.Splitter java.util.List java.math.BigInteger int java.util.List java.math.BigInteger int int
      StackMap stack:
            aload 4 /* boundaries */
            invokeinterface java.util.List.size:()I
            iload 3 /* parts */
            iconst_1
            isub
            if_icmpge 20
            iload 6 /* i */
            iload 7 /* rangesCount */
            iconst_1
            isub
            if_icmplt 5
        20: .line 117
      StackMap locals:
      StackMap stack:
            aload 4 /* boundaries */
            aload 0 /* this */
            getfield org.apache.cassandra.dht.Splitter.partitioner:Lorg/apache/cassandra/dht/IPartitioner;
            invokeinterface org.apache.cassandra.dht.IPartitioner.getMaximumToken:()Lorg/apache/cassandra/dht/Token;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        21: .line 118
            aload 4 /* boundaries */
            areturn
        end local 7 // int rangesCount
        end local 6 // int i
        end local 5 // java.math.BigInteger sum
        end local 4 // java.util.List boundaries
        end local 3 // int parts
        end local 2 // java.math.BigInteger perPart
        end local 1 // java.util.List localRanges
        end local 0 // org.apache.cassandra.dht.Splitter this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0   22     0               this  Lorg/apache/cassandra/dht/Splitter;
            0   22     1        localRanges  Ljava/util/List<Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;>;
            0   22     2            perPart  Ljava/math/BigInteger;
            0   22     3              parts  I
            1   22     4         boundaries  Ljava/util/List<Lorg/apache/cassandra/dht/Token;>;
            2   22     5                sum  Ljava/math/BigInteger;
            3   22     6                  i  I
            4   22     7        rangesCount  I
            6   19     8                  r  Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;
            7   19     9          nextRange  Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;
            8   19    10              right  Lorg/apache/cassandra/dht/Token;
            9   19    11          nextRight  Lorg/apache/cassandra/dht/Token;
           10   19    12  currentRangeWidth  Ljava/math/BigInteger;
           11   19    13     nextRangeWidth  Ljava/math/BigInteger;
           14   18    14        diffCurrent  Ljava/math/BigInteger;
           15   18    15           diffNext  Ljava/math/BigInteger;
    Signature: (Ljava/util/List<Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;>;Ljava/math/BigInteger;I)Ljava/util/List<Lorg/apache/cassandra/dht/Token;>;
    MethodParameters:
             Name  Flags
      localRanges  
      perPart      
      parts        

  private org.apache.cassandra.dht.Token token(org.apache.cassandra.dht.Token);
    descriptor: (Lorg/apache/cassandra/dht/Token;)Lorg/apache/cassandra/dht/Token;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.dht.Splitter this
        start local 1 // org.apache.cassandra.dht.Token t
         0: .line 127
            aload 1 /* t */
            aload 0 /* this */
            getfield org.apache.cassandra.dht.Splitter.partitioner:Lorg/apache/cassandra/dht/IPartitioner;
            invokeinterface org.apache.cassandra.dht.IPartitioner.getMinimumToken:()Lorg/apache/cassandra/dht/Token;
            invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
            ifeq 1
            aload 0 /* this */
            getfield org.apache.cassandra.dht.Splitter.partitioner:Lorg/apache/cassandra/dht/IPartitioner;
            invokeinterface org.apache.cassandra.dht.IPartitioner.getMaximumToken:()Lorg/apache/cassandra/dht/Token;
            goto 2
      StackMap locals:
      StackMap stack:
         1: aload 1 /* t */
      StackMap locals:
      StackMap stack: org.apache.cassandra.dht.Token
         2: areturn
        end local 1 // org.apache.cassandra.dht.Token t
        end local 0 // org.apache.cassandra.dht.Splitter this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/apache/cassandra/dht/Splitter;
            0    3     1     t  Lorg/apache/cassandra/dht/Token;
    MethodParameters:
      Name  Flags
      t     
}
SourceFile: "Splitter.java"