public class org.graalvm.collections.LockFreePrefixTree$Node extends java.util.concurrent.atomic.AtomicLong
{
private static final long serialVersionUID;
private static final org.graalvm.collections.LockFreePrefixTree$Node$FrozenNode FROZEN_NODE;
private static final int INITIAL_LINEAR_NODE_SIZE;
private static final int INITIAL_HASH_NODE_SIZE;
private static final int MAX_LINEAR_NODE_SIZE;
private static final int MAX_HASH_SKIPS;
private static final java.util.concurrent.atomic.AtomicReferenceFieldUpdater CHILDREN_UPDATER;
private long key;
private volatile java.util.concurrent.atomic.AtomicReferenceArray children;
private void <init>(long)
{
org.graalvm.collections.LockFreePrefixTree$Node v;
long v;
v := @this: org.graalvm.collections.LockFreePrefixTree$Node;
v := @parameter: long;
specialinvoke v.<java.util.concurrent.atomic.AtomicLong: void <init>()>();
v.<org.graalvm.collections.LockFreePrefixTree$Node: long key> = v;
return;
}
private void <init>()
{
org.graalvm.collections.LockFreePrefixTree$Node v;
v := @this: org.graalvm.collections.LockFreePrefixTree$Node;
specialinvoke v.<java.util.concurrent.atomic.AtomicLong: void <init>()>();
v.<org.graalvm.collections.LockFreePrefixTree$Node: long key> = 0L;
return;
}
public long value()
{
org.graalvm.collections.LockFreePrefixTree$Node v;
long v;
v := @this: org.graalvm.collections.LockFreePrefixTree$Node;
v = virtualinvoke v.<org.graalvm.collections.LockFreePrefixTree$Node: long get()>();
return v;
}
private long getKey()
{
org.graalvm.collections.LockFreePrefixTree$Node v;
long v;
v := @this: org.graalvm.collections.LockFreePrefixTree$Node;
v = v.<org.graalvm.collections.LockFreePrefixTree$Node: long key>;
return v;
}
public void setValue(long)
{
org.graalvm.collections.LockFreePrefixTree$Node v;
long v;
v := @this: org.graalvm.collections.LockFreePrefixTree$Node;
v := @parameter: long;
virtualinvoke v.<org.graalvm.collections.LockFreePrefixTree$Node: void set(long)>(v);
return;
}
public long incValue()
{
org.graalvm.collections.LockFreePrefixTree$Node v;
long v;
v := @this: org.graalvm.collections.LockFreePrefixTree$Node;
v = virtualinvoke v.<org.graalvm.collections.LockFreePrefixTree$Node: long incrementAndGet()>();
return v;
}
public long bitwiseOrValue(long)
{
org.graalvm.collections.LockFreePrefixTree$Node v;
long v, v, v;
boolean v;
v := @this: org.graalvm.collections.LockFreePrefixTree$Node;
v := @parameter: long;
label:
v = virtualinvoke v.<org.graalvm.collections.LockFreePrefixTree$Node: long get()>();
v = v | v;
v = virtualinvoke v.<org.graalvm.collections.LockFreePrefixTree$Node: boolean compareAndSet(long,long)>(v, v);
if v == 0 goto label;
return v;
}
public org.graalvm.collections.LockFreePrefixTree$Node at(org.graalvm.collections.LockFreePrefixTree$Allocator, long)
{
org.graalvm.collections.LockFreePrefixTree$Allocator v;
org.graalvm.collections.LockFreePrefixTree$Node v, v, v;
long v;
java.util.concurrent.atomic.AtomicReferenceArray v;
org.graalvm.collections.LockFreePrefixTree$FailedAllocationException v;
boolean v;
v := @this: org.graalvm.collections.LockFreePrefixTree$Node;
v := @parameter: org.graalvm.collections.LockFreePrefixTree$Allocator;
v := @parameter: long;
label:
specialinvoke v.<org.graalvm.collections.LockFreePrefixTree$Node: void ensureChildren(org.graalvm.collections.LockFreePrefixTree$Allocator)>(v);
label:
v = specialinvoke v.<org.graalvm.collections.LockFreePrefixTree$Node: java.util.concurrent.atomic.AtomicReferenceArray readChildren()>();
v = v instanceof org.graalvm.collections.LockFreePrefixTree$Node$LinearChildren;
if v == 0 goto label;
v = staticinvoke <org.graalvm.collections.LockFreePrefixTree$Node: org.graalvm.collections.LockFreePrefixTree$Node getOrAddLinear(org.graalvm.collections.LockFreePrefixTree$Allocator,long,java.util.concurrent.atomic.AtomicReferenceArray)>(v, v, v);
if v == null goto label;
label:
return v;
label:
specialinvoke v.<org.graalvm.collections.LockFreePrefixTree$Node: void tryResizeLinear(org.graalvm.collections.LockFreePrefixTree$Allocator,java.util.concurrent.atomic.AtomicReferenceArray)>(v, v);
goto label;
label:
v = staticinvoke <org.graalvm.collections.LockFreePrefixTree$Node: org.graalvm.collections.LockFreePrefixTree$Node getOrAddHash(org.graalvm.collections.LockFreePrefixTree$Allocator,long,java.util.concurrent.atomic.AtomicReferenceArray)>(v, v, v);
if v == null goto label;
label:
return v;
label:
specialinvoke v.<org.graalvm.collections.LockFreePrefixTree$Node: void tryResizeHash(org.graalvm.collections.LockFreePrefixTree$Allocator,java.util.concurrent.atomic.AtomicReferenceArray)>(v, v);
goto label;
label:
v := @caughtexception;
return null;
catch org.graalvm.collections.LockFreePrefixTree$FailedAllocationException from label to label with label;
catch org.graalvm.collections.LockFreePrefixTree$FailedAllocationException from label to label with label;
}
private static org.graalvm.collections.LockFreePrefixTree$Node getOrAddLinear(org.graalvm.collections.LockFreePrefixTree$Allocator, long, java.util.concurrent.atomic.AtomicReferenceArray)
{
org.graalvm.collections.LockFreePrefixTree$Allocator v;
org.graalvm.collections.LockFreePrefixTree$Node v, v, v;
long v, v, v;
java.util.concurrent.atomic.AtomicReferenceArray v;
byte v, v;
int v, v;
boolean v;
v := @parameter: org.graalvm.collections.LockFreePrefixTree$Allocator;
v := @parameter: long;
v := @parameter: java.util.concurrent.atomic.AtomicReferenceArray;
v = 0;
label:
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReferenceArray: int length()>();
if v >= v goto label;
v = staticinvoke <org.graalvm.collections.LockFreePrefixTree$Node: org.graalvm.collections.LockFreePrefixTree$Node read(java.util.concurrent.atomic.AtomicReferenceArray,int)>(v, v);
if v != null goto label;
v = virtualinvoke v.<org.graalvm.collections.LockFreePrefixTree$Allocator: org.graalvm.collections.LockFreePrefixTree$Node newNode(long)>(v);
v = staticinvoke <org.graalvm.collections.LockFreePrefixTree$Node: boolean cas(java.util.concurrent.atomic.AtomicReferenceArray,int,org.graalvm.collections.LockFreePrefixTree$Node,org.graalvm.collections.LockFreePrefixTree$Node)>(v, v, null, v);
if v == 0 goto label;
return v;
label:
v = staticinvoke <org.graalvm.collections.LockFreePrefixTree$Node: org.graalvm.collections.LockFreePrefixTree$Node read(java.util.concurrent.atomic.AtomicReferenceArray,int)>(v, v);
v = specialinvoke v.<org.graalvm.collections.LockFreePrefixTree$Node: long getKey()>();
v = v cmp v;
if v != 0 goto label;
return v;
label:
v = specialinvoke v.<org.graalvm.collections.LockFreePrefixTree$Node: long getKey()>();
v = v cmp v;
if v != 0 goto label;
return v;
label:
v = v + 1;
goto label;
label:
return null;
}
private void tryResizeLinear(org.graalvm.collections.LockFreePrefixTree$Allocator, java.util.concurrent.atomic.AtomicReferenceArray)
{
org.graalvm.collections.LockFreePrefixTree$Allocator v;
java.util.concurrent.atomic.AtomicReferenceFieldUpdater v;
org.graalvm.collections.LockFreePrefixTree$Node v, v, v;
java.util.concurrent.atomic.AtomicReferenceArray v, v;
int v, v, v, v, v, v, v;
v := @this: org.graalvm.collections.LockFreePrefixTree$Node;
v := @parameter: org.graalvm.collections.LockFreePrefixTree$Allocator;
v := @parameter: java.util.concurrent.atomic.AtomicReferenceArray;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReferenceArray: int length()>();
if v >= 8 goto label;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReferenceArray: int length()>();
v = 2 * v;
v = virtualinvoke v.<org.graalvm.collections.LockFreePrefixTree$Allocator: org.graalvm.collections.LockFreePrefixTree$Node$LinearChildren newLinearChildren(int)>(v);
v = 0;
label:
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReferenceArray: int length()>();
if v >= v goto label;
v = staticinvoke <org.graalvm.collections.LockFreePrefixTree$Node: org.graalvm.collections.LockFreePrefixTree$Node read(java.util.concurrent.atomic.AtomicReferenceArray,int)>(v, v);
staticinvoke <org.graalvm.collections.LockFreePrefixTree$Node: void write(java.util.concurrent.atomic.AtomicReferenceArray,int,org.graalvm.collections.LockFreePrefixTree$Node)>(v, v, v);
v = v + 1;
goto label;
label:
v = virtualinvoke v.<org.graalvm.collections.LockFreePrefixTree$Allocator: org.graalvm.collections.LockFreePrefixTree$Node$HashChildren newHashChildren(int)>(16);
v = 0;
label:
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReferenceArray: int length()>();
if v >= v goto label;
v = staticinvoke <org.graalvm.collections.LockFreePrefixTree$Node: org.graalvm.collections.LockFreePrefixTree$Node read(java.util.concurrent.atomic.AtomicReferenceArray,int)>(v, v);
staticinvoke <org.graalvm.collections.LockFreePrefixTree$Node: void addChildToLocalHash(org.graalvm.collections.LockFreePrefixTree$Node,java.util.concurrent.atomic.AtomicReferenceArray)>(v, v);
v = v + 1;
goto label;
label:
v = <org.graalvm.collections.LockFreePrefixTree$Node: java.util.concurrent.atomic.AtomicReferenceFieldUpdater CHILDREN_UPDATER>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicReferenceFieldUpdater: boolean compareAndSet(java.lang.Object,java.lang.Object,java.lang.Object)>(v, v, v);
return;
}
private static org.graalvm.collections.LockFreePrefixTree$Node getOrAddHash(org.graalvm.collections.LockFreePrefixTree$Allocator, long, java.util.concurrent.atomic.AtomicReferenceArray)
{
org.graalvm.collections.LockFreePrefixTree$Allocator v;
org.graalvm.collections.LockFreePrefixTree$Node v, v;
long v, v;
java.util.concurrent.atomic.AtomicReferenceArray v;
org.graalvm.collections.LockFreePrefixTree$Node$FrozenNode v;
byte v;
int v, v, v, v, v, v;
boolean v;
v := @parameter: org.graalvm.collections.LockFreePrefixTree$Allocator;
v := @parameter: long;
v := @parameter: java.util.concurrent.atomic.AtomicReferenceArray;
v = staticinvoke <org.graalvm.collections.LockFreePrefixTree$Node: int hash(long)>(v);
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReferenceArray: int length()>();
v = v % v;
v = 0;
label:
v = staticinvoke <org.graalvm.collections.LockFreePrefixTree$Node: org.graalvm.collections.LockFreePrefixTree$Node read(java.util.concurrent.atomic.AtomicReferenceArray,int)>(v, v);
if v != null goto label;
v = virtualinvoke v.<org.graalvm.collections.LockFreePrefixTree$Allocator: org.graalvm.collections.LockFreePrefixTree$Node newNode(long)>(v);
v = staticinvoke <org.graalvm.collections.LockFreePrefixTree$Node: boolean cas(java.util.concurrent.atomic.AtomicReferenceArray,int,org.graalvm.collections.LockFreePrefixTree$Node,org.graalvm.collections.LockFreePrefixTree$Node)>(v, v, null, v);
if v == 0 goto label;
return v;
label:
v = <org.graalvm.collections.LockFreePrefixTree$Node: org.graalvm.collections.LockFreePrefixTree$Node$FrozenNode FROZEN_NODE>;
if v == v goto label;
v = specialinvoke v.<org.graalvm.collections.LockFreePrefixTree$Node: long getKey()>();
v = v cmp v;
if v != 0 goto label;
return v;
label:
v = v + 1;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReferenceArray: int length()>();
v = v % v;
v = v + 1;
if v <= 10 goto label;
return null;
}
private static void addChildToLocalHash(org.graalvm.collections.LockFreePrefixTree$Node, java.util.concurrent.atomic.AtomicReferenceArray)
{
org.graalvm.collections.LockFreePrefixTree$Node v, v;
long v;
java.util.concurrent.atomic.AtomicReferenceArray v;
int v, v, v, v, v;
v := @parameter: org.graalvm.collections.LockFreePrefixTree$Node;
v := @parameter: java.util.concurrent.atomic.AtomicReferenceArray;
v = specialinvoke v.<org.graalvm.collections.LockFreePrefixTree$Node: long getKey()>();
v = staticinvoke <org.graalvm.collections.LockFreePrefixTree$Node: int hash(long)>(v);
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReferenceArray: int length()>();
v = v % v;
label:
v = staticinvoke <org.graalvm.collections.LockFreePrefixTree$Node: org.graalvm.collections.LockFreePrefixTree$Node read(java.util.concurrent.atomic.AtomicReferenceArray,int)>(v, v);
if v == null goto label;
v = v + 1;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReferenceArray: int length()>();
v = v % v;
goto label;
label:
staticinvoke <org.graalvm.collections.LockFreePrefixTree$Node: void write(java.util.concurrent.atomic.AtomicReferenceArray,int,org.graalvm.collections.LockFreePrefixTree$Node)>(v, v, v);
return;
}
private void tryResizeHash(org.graalvm.collections.LockFreePrefixTree$Allocator, java.util.concurrent.atomic.AtomicReferenceArray)
{
org.graalvm.collections.LockFreePrefixTree$Allocator v;
org.graalvm.collections.LockFreePrefixTree$Node v, v;
org.graalvm.collections.LockFreePrefixTree$Node$HashChildren v;
java.util.concurrent.atomic.AtomicReferenceArray v;
org.graalvm.collections.LockFreePrefixTree$Node$FrozenNode v;
int v, v, v, v;
v := @this: org.graalvm.collections.LockFreePrefixTree$Node;
v := @parameter: org.graalvm.collections.LockFreePrefixTree$Allocator;
v := @parameter: java.util.concurrent.atomic.AtomicReferenceArray;
staticinvoke <org.graalvm.collections.LockFreePrefixTree$Node: void freezeHash(java.util.concurrent.atomic.AtomicReferenceArray)>(v);
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReferenceArray: int length()>();
v = 2 * v;
v = virtualinvoke v.<org.graalvm.collections.LockFreePrefixTree$Allocator: org.graalvm.collections.LockFreePrefixTree$Node$HashChildren newHashChildren(int)>(v);
v = 0;
label:
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReferenceArray: int length()>();
if v >= v goto label;
v = staticinvoke <org.graalvm.collections.LockFreePrefixTree$Node: org.graalvm.collections.LockFreePrefixTree$Node read(java.util.concurrent.atomic.AtomicReferenceArray,int)>(v, v);
v = <org.graalvm.collections.LockFreePrefixTree$Node: org.graalvm.collections.LockFreePrefixTree$Node$FrozenNode FROZEN_NODE>;
if v == v goto label;
staticinvoke <org.graalvm.collections.LockFreePrefixTree$Node: void addChildToLocalHash(org.graalvm.collections.LockFreePrefixTree$Node,java.util.concurrent.atomic.AtomicReferenceArray)>(v, v);
label:
v = v + 1;
goto label;
label:
specialinvoke v.<org.graalvm.collections.LockFreePrefixTree$Node: boolean casChildren(java.util.concurrent.atomic.AtomicReferenceArray,java.util.concurrent.atomic.AtomicReferenceArray)>(v, v);
return;
}
private static void freezeHash(java.util.concurrent.atomic.AtomicReferenceArray)
{
org.graalvm.collections.LockFreePrefixTree$Node$FrozenNode v;
int v, v;
org.graalvm.collections.LockFreePrefixTree$Node v;
java.util.concurrent.atomic.AtomicReferenceArray v;
v := @parameter: java.util.concurrent.atomic.AtomicReferenceArray;
v = 0;
label:
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReferenceArray: int length()>();
if v >= v goto label;
v = staticinvoke <org.graalvm.collections.LockFreePrefixTree$Node: org.graalvm.collections.LockFreePrefixTree$Node read(java.util.concurrent.atomic.AtomicReferenceArray,int)>(v, v);
if v != null goto label;
v = <org.graalvm.collections.LockFreePrefixTree$Node: org.graalvm.collections.LockFreePrefixTree$Node$FrozenNode FROZEN_NODE>;
staticinvoke <org.graalvm.collections.LockFreePrefixTree$Node: boolean cas(java.util.concurrent.atomic.AtomicReferenceArray,int,org.graalvm.collections.LockFreePrefixTree$Node,org.graalvm.collections.LockFreePrefixTree$Node)>(v, v, null, v);
label:
v = v + 1;
goto label;
label:
return;
}
private static boolean cas(java.util.concurrent.atomic.AtomicReferenceArray, int, org.graalvm.collections.LockFreePrefixTree$Node, org.graalvm.collections.LockFreePrefixTree$Node)
{
int v;
org.graalvm.collections.LockFreePrefixTree$Node v, v;
boolean v;
java.util.concurrent.atomic.AtomicReferenceArray v;
v := @parameter: java.util.concurrent.atomic.AtomicReferenceArray;
v := @parameter: int;
v := @parameter: org.graalvm.collections.LockFreePrefixTree$Node;
v := @parameter: org.graalvm.collections.LockFreePrefixTree$Node;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReferenceArray: boolean compareAndSet(int,java.lang.Object,java.lang.Object)>(v, v, v);
return v;
}
private static org.graalvm.collections.LockFreePrefixTree$Node read(java.util.concurrent.atomic.AtomicReferenceArray, int)
{
int v;
java.lang.Object v;
java.util.concurrent.atomic.AtomicReferenceArray v;
v := @parameter: java.util.concurrent.atomic.AtomicReferenceArray;
v := @parameter: int;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReferenceArray: java.lang.Object get(int)>(v);
return v;
}
private static void write(java.util.concurrent.atomic.AtomicReferenceArray, int, org.graalvm.collections.LockFreePrefixTree$Node)
{
int v;
org.graalvm.collections.LockFreePrefixTree$Node v;
java.util.concurrent.atomic.AtomicReferenceArray v;
v := @parameter: java.util.concurrent.atomic.AtomicReferenceArray;
v := @parameter: int;
v := @parameter: org.graalvm.collections.LockFreePrefixTree$Node;
virtualinvoke v.<java.util.concurrent.atomic.AtomicReferenceArray: void set(int,java.lang.Object)>(v, v);
return;
}
private void ensureChildren(org.graalvm.collections.LockFreePrefixTree$Allocator)
{
org.graalvm.collections.LockFreePrefixTree$Allocator v;
org.graalvm.collections.LockFreePrefixTree$Node$LinearChildren v;
org.graalvm.collections.LockFreePrefixTree$Node v;
java.util.concurrent.atomic.AtomicReferenceArray v;
v := @this: org.graalvm.collections.LockFreePrefixTree$Node;
v := @parameter: org.graalvm.collections.LockFreePrefixTree$Allocator;
v = specialinvoke v.<org.graalvm.collections.LockFreePrefixTree$Node: java.util.concurrent.atomic.AtomicReferenceArray readChildren()>();
if v != null goto label;
v = virtualinvoke v.<org.graalvm.collections.LockFreePrefixTree$Allocator: org.graalvm.collections.LockFreePrefixTree$Node$LinearChildren newLinearChildren(int)>(2);
specialinvoke v.<org.graalvm.collections.LockFreePrefixTree$Node: boolean casChildren(java.util.concurrent.atomic.AtomicReferenceArray,java.util.concurrent.atomic.AtomicReferenceArray)>(null, v);
label:
return;
}
private boolean casChildren(java.util.concurrent.atomic.AtomicReferenceArray, java.util.concurrent.atomic.AtomicReferenceArray)
{
java.util.concurrent.atomic.AtomicReferenceFieldUpdater v;
org.graalvm.collections.LockFreePrefixTree$Node v;
boolean v;
java.util.concurrent.atomic.AtomicReferenceArray v, v;
v := @this: org.graalvm.collections.LockFreePrefixTree$Node;
v := @parameter: java.util.concurrent.atomic.AtomicReferenceArray;
v := @parameter: java.util.concurrent.atomic.AtomicReferenceArray;
v = <org.graalvm.collections.LockFreePrefixTree$Node: java.util.concurrent.atomic.AtomicReferenceFieldUpdater CHILDREN_UPDATER>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReferenceFieldUpdater: boolean compareAndSet(java.lang.Object,java.lang.Object,java.lang.Object)>(v, v, v);
return v;
}
private java.util.concurrent.atomic.AtomicReferenceArray readChildren()
{
org.graalvm.collections.LockFreePrefixTree$Node v;
java.util.concurrent.atomic.AtomicReferenceArray v;
v := @this: org.graalvm.collections.LockFreePrefixTree$Node;
v = v.<org.graalvm.collections.LockFreePrefixTree$Node: java.util.concurrent.atomic.AtomicReferenceArray children>;
return v;
}
private static int hash(long)
{
int v;
long v, v, v, v, v, v;
v := @parameter: long;
v = v * -7046033566014671411L;
v = staticinvoke <java.lang.Long: long reverseBytes(long)>(v);
v = v * -7046033566014671411L;
v = v >> 32;
v = v ^ v;
v = 2147483647 & v;
return v;
}
private void topDown(java.lang.Object, java.util.function.BiFunction, java.util.function.BiConsumer)
{
java.util.function.BiFunction v;
org.graalvm.collections.LockFreePrefixTree$Node v, v;
long v, v;
java.util.concurrent.atomic.AtomicReferenceArray v;
org.graalvm.collections.LockFreePrefixTree$Node$FrozenNode v;
java.lang.Long v, v;
int v, v;
java.util.function.BiConsumer v;
java.lang.Object v, v;
v := @this: org.graalvm.collections.LockFreePrefixTree$Node;
v := @parameter: java.lang.Object;
v := @parameter: java.util.function.BiFunction;
v := @parameter: java.util.function.BiConsumer;
v = specialinvoke v.<org.graalvm.collections.LockFreePrefixTree$Node: java.util.concurrent.atomic.AtomicReferenceArray readChildren()>();
v = virtualinvoke v.<org.graalvm.collections.LockFreePrefixTree$Node: long get()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
interfaceinvoke v.<java.util.function.BiConsumer: void accept(java.lang.Object,java.lang.Object)>(v, v);
if v != null goto label;
return;
label:
v = 0;
label:
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReferenceArray: int length()>();
if v >= v goto label;
v = staticinvoke <org.graalvm.collections.LockFreePrefixTree$Node: org.graalvm.collections.LockFreePrefixTree$Node read(java.util.concurrent.atomic.AtomicReferenceArray,int)>(v, v);
if v == null goto label;
v = <org.graalvm.collections.LockFreePrefixTree$Node: org.graalvm.collections.LockFreePrefixTree$Node$FrozenNode FROZEN_NODE>;
if v == v goto label;
v = specialinvoke v.<org.graalvm.collections.LockFreePrefixTree$Node: long getKey()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v = interfaceinvoke v.<java.util.function.BiFunction: java.lang.Object apply(java.lang.Object,java.lang.Object)>(v, v);
specialinvoke v.<org.graalvm.collections.LockFreePrefixTree$Node: void topDown(java.lang.Object,java.util.function.BiFunction,java.util.function.BiConsumer)>(v, v, v);
label:
v = v + 1;
goto label;
label:
return;
}
public java.lang.String toString()
{
org.graalvm.collections.LockFreePrefixTree$Node v;
long v;
java.lang.String v;
v := @this: org.graalvm.collections.LockFreePrefixTree$Node;
v = virtualinvoke v.<org.graalvm.collections.LockFreePrefixTree$Node: long value()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (long)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Node<\u0001>");
return v;
}
static void <clinit>()
{
org.graalvm.collections.LockFreePrefixTree$Node$FrozenNode v;
java.util.concurrent.atomic.AtomicReferenceFieldUpdater v;
v = new org.graalvm.collections.LockFreePrefixTree$Node$FrozenNode;
specialinvoke v.<org.graalvm.collections.LockFreePrefixTree$Node$FrozenNode: void <init>()>();
<org.graalvm.collections.LockFreePrefixTree$Node: org.graalvm.collections.LockFreePrefixTree$Node$FrozenNode FROZEN_NODE> = v;
v = staticinvoke <java.util.concurrent.atomic.AtomicReferenceFieldUpdater: java.util.concurrent.atomic.AtomicReferenceFieldUpdater newUpdater(java.lang.Class,java.lang.Class,java.lang.String)>(class "Lorg/graalvm/collections/LockFreePrefixTree$Node;", class "Ljava/util/concurrent/atomic/AtomicReferenceArray;", "children");
<org.graalvm.collections.LockFreePrefixTree$Node: java.util.concurrent.atomic.AtomicReferenceFieldUpdater CHILDREN_UPDATER> = v;
return;
}
}