final class org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak extends java.lang.ref.WeakReference implements org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakTracker, org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeak
{
private static final java.util.concurrent.atomic.AtomicReferenceFieldUpdater headUpdater;
private static final java.util.concurrent.atomic.AtomicIntegerFieldUpdater droppedRecordsUpdater;
private volatile org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$Record head;
private volatile int droppedRecords;
private final java.util.Set allLeaks;
private final int trackedHash;
static final boolean $assertionsDisabled;
void <init>(java.lang.Object, java.lang.ref.ReferenceQueue, java.util.Set)
{
org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$Record v, v;
java.util.concurrent.atomic.AtomicReferenceFieldUpdater v;
java.util.Set v;
java.lang.AssertionError v;
java.lang.ref.ReferenceQueue v;
int v;
org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak v;
java.lang.Object v;
boolean v;
v := @this: org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak;
v := @parameter: java.lang.Object;
v := @parameter: java.lang.ref.ReferenceQueue;
v := @parameter: java.util.Set;
specialinvoke v.<java.lang.ref.WeakReference: void <init>(java.lang.Object,java.lang.ref.ReferenceQueue)>(v, v);
v = <org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak: boolean $assertionsDisabled>;
if v != 0 goto label;
if v != null goto label;
v = new java.lang.AssertionError;
specialinvoke v.<java.lang.AssertionError: void <init>()>();
throw v;
label:
v = staticinvoke <java.lang.System: int identityHashCode(java.lang.Object)>(v);
v.<org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak: int trackedHash> = v;
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
v = <org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak: java.util.concurrent.atomic.AtomicReferenceFieldUpdater headUpdater>;
v = new org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$Record;
v = <org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$Record: org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$Record BOTTOM>;
specialinvoke v.<org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$Record: void <init>(org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$Record)>(v);
virtualinvoke v.<java.util.concurrent.atomic.AtomicReferenceFieldUpdater: void set(java.lang.Object,java.lang.Object)>(v, v);
v.<org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak: java.util.Set allLeaks> = v;
return;
}
public void record()
{
org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak v;
v := @this: org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak;
specialinvoke v.<org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak: void record0(java.lang.Object)>(null);
return;
}
public void record(java.lang.Object)
{
org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak v;
java.lang.Object v;
v := @this: org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak;
v := @parameter: java.lang.Object;
specialinvoke v.<org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak: void record0(java.lang.Object)>(v);
return;
}
private void record0(java.lang.Object)
{
java.util.concurrent.atomic.AtomicIntegerFieldUpdater v;
org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$Record v, v;
java.util.Random v;
int v, v, v, v, v, v, v, v, v;
boolean v, v, v;
java.util.concurrent.atomic.AtomicReferenceFieldUpdater v, v;
org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak v;
java.lang.Object v, v;
v := @this: org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak;
v := @parameter: java.lang.Object;
v = <org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector: int TARGET_RECORDS>;
if v <= 0 goto label;
label:
v = <org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak: java.util.concurrent.atomic.AtomicReferenceFieldUpdater headUpdater>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReferenceFieldUpdater: java.lang.Object get(java.lang.Object)>(v);
v = v;
if v != null goto label;
return;
label:
v = v.<org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$Record: int pos>;
v = v + 1;
v = <org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector: int TARGET_RECORDS>;
if v < v goto label;
v = <org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector: int TARGET_RECORDS>;
v = v - v;
v = staticinvoke <java.lang.Math: int min(int,int)>(v, 30);
v = staticinvoke <org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.internal.PlatformDependent: java.util.Random threadLocalRandom()>();
v = 1 << v;
v = virtualinvoke v.<java.util.Random: int nextInt(int)>(v);
if v == 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
v = v;
if v == 0 goto label;
v = v.<org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$Record: org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$Record next>;
goto label;
label:
v = 0;
label:
if v == null goto label;
v = new org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$Record;
specialinvoke v.<org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$Record: void <init>(org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$Record,java.lang.Object)>(v, v);
goto label;
label:
v = new org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$Record;
specialinvoke v.<org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$Record: void <init>(org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$Record)>(v);
label:
v = <org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak: java.util.concurrent.atomic.AtomicReferenceFieldUpdater headUpdater>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReferenceFieldUpdater: boolean compareAndSet(java.lang.Object,java.lang.Object,java.lang.Object)>(v, v, v);
if v == 0 goto label;
if v == 0 goto label;
v = <org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak: java.util.concurrent.atomic.AtomicIntegerFieldUpdater droppedRecordsUpdater>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicIntegerFieldUpdater: int incrementAndGet(java.lang.Object)>(v);
label:
return;
}
boolean dispose()
{
org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak v;
java.util.Set v;
boolean v;
v := @this: org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak;
virtualinvoke v.<org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak: void clear()>();
v = v.<org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak: java.util.Set allLeaks>;
v = interfaceinvoke v.<java.util.Set: boolean remove(java.lang.Object)>(v);
return v;
}
public boolean close()
{
java.util.concurrent.atomic.AtomicReferenceFieldUpdater v;
org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak v;
java.util.Set v;
boolean v;
v := @this: org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak;
v = v.<org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak: java.util.Set allLeaks>;
v = interfaceinvoke v.<java.util.Set: boolean remove(java.lang.Object)>(v);
if v == 0 goto label;
virtualinvoke v.<org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak: void clear()>();
v = <org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak: java.util.concurrent.atomic.AtomicReferenceFieldUpdater headUpdater>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicReferenceFieldUpdater: void set(java.lang.Object,java.lang.Object)>(v, null);
return 1;
label:
return 0;
}
public boolean close(java.lang.Object)
{
java.lang.Throwable v;
java.lang.AssertionError v;
int v, v;
org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak v;
java.lang.Object v;
boolean v, v;
v := @this: org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak;
v := @parameter: java.lang.Object;
v = <org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak: boolean $assertionsDisabled>;
if v != 0 goto label;
v = v.<org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak: int trackedHash>;
v = staticinvoke <java.lang.System: int identityHashCode(java.lang.Object)>(v);
if v == v goto label;
v = new java.lang.AssertionError;
specialinvoke v.<java.lang.AssertionError: void <init>()>();
throw v;
label:
v = virtualinvoke v.<org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak: boolean close()>();
label:
staticinvoke <org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak: void reachabilityFence0(java.lang.Object)>(v);
return v;
label:
v := @caughtexception;
staticinvoke <org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak: void reachabilityFence0(java.lang.Object)>(v);
throw v;
catch java.lang.Throwable from label to label with label;
}
private static void reachabilityFence0(java.lang.Object)
{
java.lang.Throwable v;
java.lang.Object v;
v := @parameter: java.lang.Object;
if v == null goto label;
entermonitor v;
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
public java.lang.String toString()
{
org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$Record v, v, v;
boolean v;
java.util.concurrent.atomic.AtomicReferenceFieldUpdater v;
java.lang.StringBuilder v, v, v, v, v, v, v;
java.util.concurrent.atomic.AtomicIntegerFieldUpdater v;
java.util.HashSet v;
int v, v, v, v, v, v, v, v, v, v, v;
java.lang.String v, v, v, v, v, v, v, v, v;
org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak v;
java.lang.Object v;
v := @this: org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak;
v = <org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak: java.util.concurrent.atomic.AtomicReferenceFieldUpdater headUpdater>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReferenceFieldUpdater: java.lang.Object getAndSet(java.lang.Object,java.lang.Object)>(v, null);
if v != null goto label;
return "";
label:
v = <org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak: java.util.concurrent.atomic.AtomicIntegerFieldUpdater droppedRecordsUpdater>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicIntegerFieldUpdater: int get(java.lang.Object)>(v);
v = 0;
v = v.<org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$Record: int pos>;
v = v + 1;
v = v * 2048;
specialinvoke v.<java.lang.StringBuilder: void <init>(int)>(v);
v = <org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.internal.StringUtil: java.lang.String NEWLINE>;
v = <org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.internal.StringUtil: java.lang.String NEWLINE>;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
v = 1;
v = new java.util.HashSet;
specialinvoke v.<java.util.HashSet: void <init>(int)>(v);
label:
v = <org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$Record: org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$Record BOTTOM>;
if v == v goto label;
v = virtualinvoke v.<org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$Record: java.lang.String toString()>();
v = interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
if v == 0 goto label;
v = v.<org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$Record: org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$Record next>;
v = <org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$Record: org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$Record BOTTOM>;
if v != v goto label;
v = <org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.internal.StringUtil: java.lang.String NEWLINE>;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
goto label;
label:
v = v;
v = v + 1;
v = <org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.internal.StringUtil: java.lang.String NEWLINE>;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
goto label;
label:
v = v + 1;
label:
v = v.<org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$Record: org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$Record next>;
goto label;
label:
if v <= 0 goto label;
v = <org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.internal.StringUtil: java.lang.String NEWLINE>;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
label:
if v <= 0 goto label;
v = <org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector: int TARGET_RECORDS>;
v = <org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.internal.StringUtil: java.lang.String NEWLINE>;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
label:
v = virtualinvoke v.<java.lang.StringBuilder: int length()>();
v = <org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.internal.StringUtil: java.lang.String NEWLINE>;
v = virtualinvoke v.<java.lang.String: int length()>();
v = v - v;
virtualinvoke v.<java.lang.StringBuilder: void setLength(int)>(v);
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.String,int,java.lang.String,int,int,int)>(v, v, v, v, v, v, 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[])>("\u0001Recent access records: Created at:\u0001#\u0001:\u0001: \u leak records were discarded because they were duplicates: \u leak records were discarded because the leak record count is targeted to \u. Use system property org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.leakDetection.targetRecords to increase the limit.");
return v;
}
static void <clinit>()
{
java.util.concurrent.atomic.AtomicIntegerFieldUpdater v;
java.util.concurrent.atomic.AtomicReferenceFieldUpdater v;
java.lang.Class v;
boolean v, v;
v = class "Lorg/apache/hive/kudu/org/apache/kudu/shaded/io/netty/util/ResourceLeakDetector;";
v = virtualinvoke v.<java.lang.Class: boolean desiredAssertionStatus()>();
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
<org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak: boolean $assertionsDisabled> = 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/apache/hive/kudu/org/apache/kudu/shaded/io/netty/util/ResourceLeakDetector$DefaultResourceLeak;", class "Lorg/apache/hive/kudu/org/apache/kudu/shaded/io/netty/util/ResourceLeakDetector$Record;", "head");
<org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak: java.util.concurrent.atomic.AtomicReferenceFieldUpdater headUpdater> = v;
v = staticinvoke <java.util.concurrent.atomic.AtomicIntegerFieldUpdater: java.util.concurrent.atomic.AtomicIntegerFieldUpdater newUpdater(java.lang.Class,java.lang.String)>(class "Lorg/apache/hive/kudu/org/apache/kudu/shaded/io/netty/util/ResourceLeakDetector$DefaultResourceLeak;", "droppedRecords");
<org.apache.hive.kudu.org.apache.kudu.shaded.io.netty.util.ResourceLeakDetector$DefaultResourceLeak: java.util.concurrent.atomic.AtomicIntegerFieldUpdater droppedRecordsUpdater> = v;
return;
}
}