final class com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes
  super_class: java.lang.Object
{
  private static final int DEFAULT_SIZE;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 10

  private com.oracle.truffle.api.nodes.Node[] nodes;
    descriptor: [Lcom/oracle/truffle/api/nodes/Node;
    flags: (0x0002) ACC_PRIVATE

  int[] nodeOffsets;
    descriptor: [I
    flags: (0x0000) 

  int size;
    descriptor: I
    flags: (0x0000) 

  private void <init>();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes this
         0: .line 283
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 287
            aload 0 /* this */
            aconst_null
            putfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.nodes:[Lcom/oracle/truffle/api/nodes/Node;
         2: .line 288
            aload 0 /* this */
            aconst_null
            putfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.nodeOffsets:[I
         3: .line 289
            aload 0 /* this */
            iconst_0
            putfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.size:I
         4: .line 283
            return
        end local 0 // com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lcom/oracle/truffle/api/instrumentation/DefaultNearestNodeSearch$SortedNodes;

  void add(com.oracle.truffle.api.nodes.Node, int);
    descriptor: (Lcom/oracle/truffle/api/nodes/Node;I)V
    flags: (0x0000) 
    Code:
      stack=6, locals=4, args_size=3
        start local 0 // com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes this
        start local 1 // com.oracle.truffle.api.nodes.Node node
        start local 2 // int offset
         0: .line 292
            aload 0 /* this */
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.nodes:[Lcom/oracle/truffle/api/nodes/Node;
            ifnonnull 7
         1: .line 293
            aload 0 /* this */
            bipush 10
            anewarray com.oracle.truffle.api.nodes.Node
            putfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.nodes:[Lcom/oracle/truffle/api/nodes/Node;
         2: .line 294
            aload 0 /* this */
            bipush 10
            newarray 10
            putfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.nodeOffsets:[I
         3: .line 295
            aload 0 /* this */
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.nodes:[Lcom/oracle/truffle/api/nodes/Node;
            iconst_0
            aload 1 /* node */
            aastore
         4: .line 296
            aload 0 /* this */
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.nodeOffsets:[I
            iconst_0
            iload 2 /* offset */
            iastore
         5: .line 297
            aload 0 /* this */
            dup
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.size:I
            iconst_1
            iadd
            putfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.size:I
         6: .line 298
            goto 20
         7: .line 299
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.size:I
            iconst_1
            iadd
            invokevirtual com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.ensureCapacity:(I)V
         8: .line 300
            aload 0 /* this */
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.nodeOffsets:[I
            aload 0 /* this */
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.size:I
            iconst_1
            isub
            iaload
            iload 2 /* offset */
            if_icmpge 12
         9: .line 301
            aload 0 /* this */
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.nodes:[Lcom/oracle/truffle/api/nodes/Node;
            aload 0 /* this */
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.size:I
            aload 1 /* node */
            aastore
        10: .line 302
            aload 0 /* this */
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.nodeOffsets:[I
            aload 0 /* this */
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.size:I
            iload 2 /* offset */
            iastore
        11: .line 303
            goto 19
        12: .line 304
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.nodeOffsets:[I
            iconst_0
            aload 0 /* this */
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.size:I
            iload 2 /* offset */
            invokestatic java.util.Arrays.binarySearch:([IIII)I
            istore 3 /* index */
        start local 3 // int index
        13: .line 305
            iload 3 /* index */
            ifge 15
        14: .line 306
            iload 3 /* index */
            ineg
            iconst_1
            isub
            istore 3 /* index */
        15: .line 308
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.nodes:[Lcom/oracle/truffle/api/nodes/Node;
            iload 3 /* index */
            aload 0 /* this */
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.nodes:[Lcom/oracle/truffle/api/nodes/Node;
            iload 3 /* index */
            iconst_1
            iadd
            aload 0 /* this */
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.size:I
            iload 3 /* index */
            isub
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        16: .line 309
            aload 0 /* this */
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.nodes:[Lcom/oracle/truffle/api/nodes/Node;
            iload 3 /* index */
            aload 1 /* node */
            aastore
        17: .line 310
            aload 0 /* this */
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.nodeOffsets:[I
            iload 3 /* index */
            aload 0 /* this */
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.nodeOffsets:[I
            iload 3 /* index */
            iconst_1
            iadd
            aload 0 /* this */
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.size:I
            iload 3 /* index */
            isub
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        18: .line 311
            aload 0 /* this */
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.nodeOffsets:[I
            iload 3 /* index */
            iload 2 /* offset */
            iastore
        end local 3 // int index
        19: .line 313
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            dup
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.size:I
            iconst_1
            iadd
            putfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.size:I
        20: .line 315
      StackMap locals:
      StackMap stack:
            return
        end local 2 // int offset
        end local 1 // com.oracle.truffle.api.nodes.Node node
        end local 0 // com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   21     0    this  Lcom/oracle/truffle/api/instrumentation/DefaultNearestNodeSearch$SortedNodes;
            0   21     1    node  Lcom/oracle/truffle/api/nodes/Node;
            0   21     2  offset  I
           13   19     3   index  I
    MethodParameters:
        Name  Flags
      node    
      offset  

  void ensureCapacity(int);
    descriptor: (I)V
    flags: (0x0000) 
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes this
        start local 1 // int capacity
         0: .line 318
            aload 0 /* this */
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.nodes:[Lcom/oracle/truffle/api/nodes/Node;
            arraylength
            iload 1 /* capacity */
            if_icmpge 6
         1: .line 319
            iload 1 /* capacity */
            iload 1 /* capacity */
            iconst_1
            ishr
            iadd
            istore 2 /* newCapacity */
        start local 2 // int newCapacity
         2: .line 320
            iload 2 /* newCapacity */
            iload 1 /* capacity */
            if_icmpge 4
         3: .line 321
            iload 1 /* capacity */
            istore 2 /* newCapacity */
         4: .line 323
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.nodes:[Lcom/oracle/truffle/api/nodes/Node;
            iload 2 /* newCapacity */
            invokestatic java.util.Arrays.copyOf:([Ljava/lang/Object;I)[Ljava/lang/Object;
            checkcast com.oracle.truffle.api.nodes.Node[]
            putfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.nodes:[Lcom/oracle/truffle/api/nodes/Node;
         5: .line 324
            aload 0 /* this */
            aload 0 /* this */
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.nodeOffsets:[I
            iload 2 /* newCapacity */
            invokestatic java.util.Arrays.copyOf:([II)[I
            putfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.nodeOffsets:[I
        end local 2 // int newCapacity
         6: .line 326
      StackMap locals:
      StackMap stack:
            return
        end local 1 // int capacity
        end local 0 // com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    7     0         this  Lcom/oracle/truffle/api/instrumentation/DefaultNearestNodeSearch$SortedNodes;
            0    7     1     capacity  I
            2    6     2  newCapacity  I
    MethodParameters:
          Name  Flags
      capacity  

  void cutHigherThan(int);
    descriptor: (I)V
    flags: (0x0000) 
    Code:
      stack=4, locals=3, args_size=2
        start local 0 // com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes this
        start local 1 // int offset
         0: .line 329
            aload 0 /* this */
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.nodeOffsets:[I
            iconst_0
            aload 0 /* this */
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.size:I
            iload 1 /* offset */
            invokestatic java.util.Arrays.binarySearch:([IIII)I
            istore 2 /* index */
        start local 2 // int index
         1: .line 330
            iload 2 /* index */
            ifge 4
         2: .line 331
            iload 2 /* index */
            ineg
            iconst_1
            isub
            istore 2 /* index */
         3: .line 332
            goto 5
         4: .line 333
      StackMap locals: int
      StackMap stack:
            iinc 2 /* index */ 1
         5: .line 335
      StackMap locals:
      StackMap stack:
            iload 2 /* index */
            aload 0 /* this */
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.size:I
            if_icmpge 7
         6: .line 336
            aload 0 /* this */
            iload 2 /* index */
            putfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.size:I
         7: .line 338
      StackMap locals:
      StackMap stack:
            return
        end local 2 // int index
        end local 1 // int offset
        end local 0 // com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    8     0    this  Lcom/oracle/truffle/api/instrumentation/DefaultNearestNodeSearch$SortedNodes;
            0    8     1  offset  I
            1    8     2   index  I
    MethodParameters:
        Name  Flags
      offset  

  void cutLowerThan(int);
    descriptor: (I)V
    flags: (0x0000) 
    Code:
      stack=6, locals=3, args_size=2
        start local 0 // com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes this
        start local 1 // int offset
         0: .line 341
            aload 0 /* this */
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.nodeOffsets:[I
            iconst_0
            aload 0 /* this */
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.size:I
            iload 1 /* offset */
            invokestatic java.util.Arrays.binarySearch:([IIII)I
            istore 2 /* index */
        start local 2 // int index
         1: .line 342
            iload 2 /* index */
            ifge 3
         2: .line 343
            iload 2 /* index */
            ineg
            iconst_1
            isub
            istore 2 /* index */
         3: .line 345
      StackMap locals: int
      StackMap stack:
            iload 2 /* index */
            ifle 7
         4: .line 346
            aload 0 /* this */
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.nodes:[Lcom/oracle/truffle/api/nodes/Node;
            iload 2 /* index */
            aload 0 /* this */
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.nodes:[Lcom/oracle/truffle/api/nodes/Node;
            iconst_0
            aload 0 /* this */
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.size:I
            iload 2 /* index */
            isub
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
         5: .line 347
            aload 0 /* this */
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.nodeOffsets:[I
            iload 2 /* index */
            aload 0 /* this */
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.nodeOffsets:[I
            iconst_0
            aload 0 /* this */
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.size:I
            iload 2 /* index */
            isub
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
         6: .line 348
            aload 0 /* this */
            dup
            getfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.size:I
            iload 2 /* index */
            isub
            putfield com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes.size:I
         7: .line 350
      StackMap locals:
      StackMap stack:
            return
        end local 2 // int index
        end local 1 // int offset
        end local 0 // com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    8     0    this  Lcom/oracle/truffle/api/instrumentation/DefaultNearestNodeSearch$SortedNodes;
            0    8     1  offset  I
            1    8     2   index  I
    MethodParameters:
        Name  Flags
      offset  
}
SourceFile: "DefaultNearestNodeSearch.java"
NestHost: com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch
InnerClasses:
  private final SortedNodes = com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch$SortedNodes of com.oracle.truffle.api.instrumentation.DefaultNearestNodeSearch