public abstract class org.apache.activemq.usage.Usage extends java.lang.Object implements org.apache.activemq.Service
{
private static final org.slf4j.Logger LOG;
protected final java.util.concurrent.locks.ReentrantReadWriteLock usageLock;
protected final java.util.concurrent.locks.Condition waitForSpaceCondition;
protected int percentUsage;
protected org.apache.activemq.usage.Usage parent;
protected java.lang.String name;
private org.apache.activemq.usage.UsageCapacity limiter;
private int percentUsageMinDelta;
private final java.util.List listeners;
private final boolean debug;
private float usagePortion;
private final java.util.List children;
private final java.util.List callbacks;
private int pollingTime;
private final java.util.concurrent.atomic.AtomicBoolean started;
private java.util.concurrent.ThreadPoolExecutor executor;
public void <init>(org.apache.activemq.usage.Usage, java.lang.String, float)
{
java.util.concurrent.atomic.AtomicBoolean v;
long v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v;
org.apache.activemq.usage.UsageCapacity v;
java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock v;
org.apache.activemq.usage.Usage v, v;
java.lang.String v, v;
java.util.LinkedList v;
boolean v;
double v;
org.slf4j.Logger v;
org.apache.activemq.usage.DefaultUsageCapacity v;
java.util.concurrent.locks.Condition v;
float v;
java.util.concurrent.CopyOnWriteArrayList v, v;
v := @this: org.apache.activemq.usage.Usage;
v := @parameter: org.apache.activemq.usage.Usage;
v := @parameter: java.lang.String;
v := @parameter: float;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new java.util.concurrent.locks.ReentrantReadWriteLock;
specialinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: void <init>()>();
v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock> = v;
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: java.util.concurrent.locks.Condition newCondition()>();
v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.Condition waitForSpaceCondition> = v;
v = new org.apache.activemq.usage.DefaultUsageCapacity;
specialinvoke v.<org.apache.activemq.usage.DefaultUsageCapacity: void <init>()>();
v.<org.apache.activemq.usage.Usage: org.apache.activemq.usage.UsageCapacity limiter> = v;
v.<org.apache.activemq.usage.Usage: int percentUsageMinDelta> = 1;
v = new java.util.concurrent.CopyOnWriteArrayList;
specialinvoke v.<java.util.concurrent.CopyOnWriteArrayList: void <init>()>();
v.<org.apache.activemq.usage.Usage: java.util.List listeners> = v;
v = <org.apache.activemq.usage.Usage: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
v.<org.apache.activemq.usage.Usage: boolean debug> = v;
v.<org.apache.activemq.usage.Usage: float usagePortion> = 1.0F;
v = new java.util.concurrent.CopyOnWriteArrayList;
specialinvoke v.<java.util.concurrent.CopyOnWriteArrayList: void <init>()>();
v.<org.apache.activemq.usage.Usage: java.util.List children> = v;
v = new java.util.LinkedList;
specialinvoke v.<java.util.LinkedList: void <init>()>();
v.<org.apache.activemq.usage.Usage: java.util.List callbacks> = v;
v.<org.apache.activemq.usage.Usage: int pollingTime> = 100;
v = new java.util.concurrent.atomic.AtomicBoolean;
specialinvoke v.<java.util.concurrent.atomic.AtomicBoolean: void <init>()>();
v.<org.apache.activemq.usage.Usage: java.util.concurrent.atomic.AtomicBoolean started> = v;
v.<org.apache.activemq.usage.Usage: org.apache.activemq.usage.Usage parent> = v;
v.<org.apache.activemq.usage.Usage: float usagePortion> = v;
if v == null goto label;
v = v.<org.apache.activemq.usage.Usage: org.apache.activemq.usage.UsageCapacity limiter>;
v = virtualinvoke v.<org.apache.activemq.usage.Usage: long getLimit()>();
v = v * v;
interfaceinvoke v.<org.apache.activemq.usage.UsageCapacity: void setLimit(long)>(v);
v = v.<org.apache.activemq.usage.Usage: java.lang.String name>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.String)>(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[])>("\u0001:\u0001");
label:
v.<org.apache.activemq.usage.Usage: java.lang.String name> = v;
return;
}
protected abstract long retrieveUsage();
public void waitForSpace() throws java.lang.InterruptedException
{
org.apache.activemq.usage.Usage v;
v := @this: org.apache.activemq.usage.Usage;
virtualinvoke v.<org.apache.activemq.usage.Usage: boolean waitForSpace(long)>(0L);
return;
}
public boolean waitForSpace(long) throws java.lang.InterruptedException
{
long v;
org.apache.activemq.usage.Usage v;
boolean v;
v := @this: org.apache.activemq.usage.Usage;
v := @parameter: long;
v = virtualinvoke v.<org.apache.activemq.usage.Usage: boolean waitForSpace(long,int)>(v, 100);
return v;
}
public boolean waitForSpace(long, int) throws java.lang.InterruptedException
{
java.lang.Throwable v;
long v, v, v, v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock v, v, v;
byte v, v;
int v, v, v, v, v, v, v;
org.apache.activemq.usage.Usage v, v, v;
boolean v, v;
java.util.concurrent.TimeUnit v;
java.util.concurrent.locks.Condition v;
v := @this: org.apache.activemq.usage.Usage;
v := @parameter: long;
v := @parameter: int;
v = v.<org.apache.activemq.usage.Usage: org.apache.activemq.usage.Usage parent>;
if v == null goto label;
v = v.<org.apache.activemq.usage.Usage: org.apache.activemq.usage.Usage parent>;
v = virtualinvoke v.<org.apache.activemq.usage.Usage: boolean waitForSpace(long,int)>(v, v);
if v != 0 goto label;
return 0;
label:
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
v = virtualinvoke v.<org.apache.activemq.usage.Usage: int caclPercentUsage()>();
v.<org.apache.activemq.usage.Usage: int percentUsage> = v;
v = v.<org.apache.activemq.usage.Usage: int percentUsage>;
if v < v goto label;
v = v cmp 0L;
if v <= 0 goto label;
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = v + v;
goto label;
label:
v = 9223372036854775807L;
label:
v = v;
v = v;
label:
v = v cmp 0L;
if v <= 0 goto label;
v = virtualinvoke v.<org.apache.activemq.usage.Usage: int caclPercentUsage()>();
v.<org.apache.activemq.usage.Usage: int percentUsage> = v;
v = v.<org.apache.activemq.usage.Usage: int percentUsage>;
if v < v goto label;
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.Condition waitForSpaceCondition>;
v = v.<org.apache.activemq.usage.Usage: int pollingTime>;
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit MILLISECONDS>;
interfaceinvoke v.<java.util.concurrent.locks.Condition: boolean await(long,java.util.concurrent.TimeUnit)>(v, v);
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = v - v;
goto label;
label:
v = v.<org.apache.activemq.usage.Usage: int percentUsage>;
if v >= v goto label;
v = 1;
goto label;
label:
v = 0;
label:
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
return v;
label:
v := @caughtexception;
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
catch java.lang.Throwable from label to label with label;
}
public boolean isFull()
{
org.apache.activemq.usage.Usage v;
boolean v;
v := @this: org.apache.activemq.usage.Usage;
v = virtualinvoke v.<org.apache.activemq.usage.Usage: boolean isFull(int)>(100);
return v;
}
public boolean isFull(int)
{
java.lang.Throwable v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock v, v, v;
int v, v, v;
org.apache.activemq.usage.Usage v, v, v;
boolean v, v;
v := @this: org.apache.activemq.usage.Usage;
v := @parameter: int;
v = v.<org.apache.activemq.usage.Usage: org.apache.activemq.usage.Usage parent>;
if v == null goto label;
v = v.<org.apache.activemq.usage.Usage: org.apache.activemq.usage.Usage parent>;
v = virtualinvoke v.<org.apache.activemq.usage.Usage: boolean isFull(int)>(v);
if v == 0 goto label;
return 1;
label:
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
v = virtualinvoke v.<org.apache.activemq.usage.Usage: int caclPercentUsage()>();
v.<org.apache.activemq.usage.Usage: int percentUsage> = v;
v = v.<org.apache.activemq.usage.Usage: int percentUsage>;
if v < v goto label;
v = 1;
goto label;
label:
v = 0;
label:
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
return v;
label:
v := @caughtexception;
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
catch java.lang.Throwable from label to label with label;
}
public void addUsageListener(org.apache.activemq.usage.UsageListener)
{
org.apache.activemq.usage.UsageListener v;
java.util.List v;
org.apache.activemq.usage.Usage v;
v := @this: org.apache.activemq.usage.Usage;
v := @parameter: org.apache.activemq.usage.UsageListener;
v = v.<org.apache.activemq.usage.Usage: java.util.List listeners>;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
return;
}
public void removeUsageListener(org.apache.activemq.usage.UsageListener)
{
org.apache.activemq.usage.UsageListener v;
java.util.List v;
org.apache.activemq.usage.Usage v;
v := @this: org.apache.activemq.usage.Usage;
v := @parameter: org.apache.activemq.usage.UsageListener;
v = v.<org.apache.activemq.usage.Usage: java.util.List listeners>;
interfaceinvoke v.<java.util.List: boolean remove(java.lang.Object)>(v);
return;
}
public int getNumUsageListeners()
{
int v;
java.util.List v;
org.apache.activemq.usage.Usage v;
v := @this: org.apache.activemq.usage.Usage;
v = v.<org.apache.activemq.usage.Usage: java.util.List listeners>;
v = interfaceinvoke v.<java.util.List: int size()>();
return v;
}
public long getLimit()
{
java.lang.Throwable v;
long v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
org.apache.activemq.usage.UsageCapacity v;
java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock v, v, v;
org.apache.activemq.usage.Usage v;
v := @this: org.apache.activemq.usage.Usage;
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void lock()>();
label:
v = v.<org.apache.activemq.usage.Usage: org.apache.activemq.usage.UsageCapacity limiter>;
v = interfaceinvoke v.<org.apache.activemq.usage.UsageCapacity: long getLimit()>();
label:
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
return v;
label:
v := @caughtexception;
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
throw v;
catch java.lang.Throwable from label to label with label;
}
public void setLimit(long)
{
java.lang.Throwable v;
long v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
org.apache.activemq.usage.UsageCapacity v;
java.lang.IllegalArgumentException v;
java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock v, v, v;
int v;
org.apache.activemq.usage.Usage v;
v := @this: org.apache.activemq.usage.Usage;
v := @parameter: long;
v = v.<org.apache.activemq.usage.Usage: int percentUsageMinDelta>;
if v >= 0 goto label;
v = new java.lang.IllegalArgumentException;
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>("percentUsageMinDelta must be greater or equal to 0");
throw v;
label:
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
v = v.<org.apache.activemq.usage.Usage: org.apache.activemq.usage.UsageCapacity limiter>;
interfaceinvoke v.<org.apache.activemq.usage.UsageCapacity: void setLimit(long)>(v);
v.<org.apache.activemq.usage.Usage: float usagePortion> = 0.0F;
label:
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
label:
virtualinvoke v.<org.apache.activemq.usage.Usage: void onLimitChange()>();
return;
catch java.lang.Throwable from label to label with label;
}
protected void onLimitChange()
{
java.lang.Throwable v, v;
long v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v, v, v, v;
org.apache.activemq.usage.UsageCapacity v;
java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock v, v, v, v, v, v;
byte v;
int v;
org.apache.activemq.usage.Usage v, v, v;
boolean v;
double v;
java.util.Iterator v;
java.util.List v;
float v, v;
java.lang.Object v;
v := @this: org.apache.activemq.usage.Usage;
v = v.<org.apache.activemq.usage.Usage: float usagePortion>;
v = v cmpl 0.0F;
if v <= 0 goto label;
v = v.<org.apache.activemq.usage.Usage: org.apache.activemq.usage.Usage parent>;
if v == null goto label;
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
v = v.<org.apache.activemq.usage.Usage: org.apache.activemq.usage.UsageCapacity limiter>;
v = v.<org.apache.activemq.usage.Usage: org.apache.activemq.usage.Usage parent>;
v = virtualinvoke v.<org.apache.activemq.usage.Usage: long getLimit()>();
v = v.<org.apache.activemq.usage.Usage: float usagePortion>;
v = v * v;
interfaceinvoke v.<org.apache.activemq.usage.UsageCapacity: void setLimit(long)>(v);
label:
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
label:
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
v = virtualinvoke v.<org.apache.activemq.usage.Usage: int caclPercentUsage()>();
virtualinvoke v.<org.apache.activemq.usage.Usage: void setPercentUsage(int)>(v);
label:
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
label:
v = v.<org.apache.activemq.usage.Usage: java.util.List children>;
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
virtualinvoke v.<org.apache.activemq.usage.Usage: void onLimitChange()>();
goto label;
label:
return;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public float getUsagePortion()
{
java.lang.Throwable v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock v, v, v;
float v;
org.apache.activemq.usage.Usage v;
v := @this: org.apache.activemq.usage.Usage;
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void lock()>();
label:
v = v.<org.apache.activemq.usage.Usage: float usagePortion>;
label:
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
return v;
label:
v := @caughtexception;
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
throw v;
catch java.lang.Throwable from label to label with label;
}
public void setUsagePortion(float)
{
java.lang.Throwable v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock v, v, v;
float v;
org.apache.activemq.usage.Usage v;
v := @this: org.apache.activemq.usage.Usage;
v := @parameter: float;
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
v.<org.apache.activemq.usage.Usage: float usagePortion> = v;
label:
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
label:
virtualinvoke v.<org.apache.activemq.usage.Usage: void onLimitChange()>();
return;
catch java.lang.Throwable from label to label with label;
}
public int getPercentUsage()
{
java.lang.Throwable v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock v, v, v;
int v;
org.apache.activemq.usage.Usage v;
v := @this: org.apache.activemq.usage.Usage;
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void lock()>();
label:
v = v.<org.apache.activemq.usage.Usage: int percentUsage>;
label:
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
return v;
label:
v := @caughtexception;
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
throw v;
catch java.lang.Throwable from label to label with label;
}
public int getPercentUsageMinDelta()
{
java.lang.Throwable v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock v, v, v;
int v;
org.apache.activemq.usage.Usage v;
v := @this: org.apache.activemq.usage.Usage;
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void lock()>();
label:
v = v.<org.apache.activemq.usage.Usage: int percentUsageMinDelta>;
label:
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
return v;
label:
v := @caughtexception;
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
throw v;
catch java.lang.Throwable from label to label with label;
}
public void setPercentUsageMinDelta(int)
{
java.lang.Throwable v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
java.lang.IllegalArgumentException v;
java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock v, v, v;
int v, v;
org.apache.activemq.usage.Usage v;
v := @this: org.apache.activemq.usage.Usage;
v := @parameter: int;
if v >= 1 goto label;
v = new java.lang.IllegalArgumentException;
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>("percentUsageMinDelta must be greater than 0");
throw v;
label:
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
v.<org.apache.activemq.usage.Usage: int percentUsageMinDelta> = v;
v = virtualinvoke v.<org.apache.activemq.usage.Usage: int caclPercentUsage()>();
virtualinvoke v.<org.apache.activemq.usage.Usage: void setPercentUsage(int)>(v);
label:
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
public long getUsage()
{
java.lang.Throwable v;
long v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock v, v, v;
org.apache.activemq.usage.Usage v;
v := @this: org.apache.activemq.usage.Usage;
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void lock()>();
label:
v = virtualinvoke v.<org.apache.activemq.usage.Usage: long retrieveUsage()>();
label:
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
return v;
label:
v := @caughtexception;
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
throw v;
catch java.lang.Throwable from label to label with label;
}
protected void setPercentUsage(int)
{
java.lang.Throwable v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock v, v, v;
int v, v;
org.apache.activemq.usage.Usage v;
v := @this: org.apache.activemq.usage.Usage;
v := @parameter: int;
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
v = v.<org.apache.activemq.usage.Usage: int percentUsage>;
v.<org.apache.activemq.usage.Usage: int percentUsage> = v;
if v == v goto label;
specialinvoke v.<org.apache.activemq.usage.Usage: void fireEvent(int,int)>(v, v);
label:
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
protected int caclPercentUsage()
{
long v, v, v, v, v, v, v;
org.apache.activemq.usage.UsageCapacity v, v;
byte v;
int v, v;
org.apache.activemq.usage.Usage v;
v := @this: org.apache.activemq.usage.Usage;
v = v.<org.apache.activemq.usage.Usage: org.apache.activemq.usage.UsageCapacity limiter>;
v = interfaceinvoke v.<org.apache.activemq.usage.UsageCapacity: long getLimit()>();
v = v cmp 0L;
if v != 0 goto label;
return 0;
label:
v = virtualinvoke v.<org.apache.activemq.usage.Usage: long retrieveUsage()>();
v = v * 100L;
v = v.<org.apache.activemq.usage.Usage: org.apache.activemq.usage.UsageCapacity limiter>;
v = interfaceinvoke v.<org.apache.activemq.usage.UsageCapacity: long getLimit()>();
v = v / v;
v = v.<org.apache.activemq.usage.Usage: int percentUsageMinDelta>;
v = v / v;
v = v.<org.apache.activemq.usage.Usage: int percentUsageMinDelta>;
v = v * v;
return v;
}
private void fireEvent(int, int)
{
java.util.concurrent.ThreadPoolExecutor v, v;
java.util.concurrent.atomic.AtomicBoolean v, v;
org.apache.activemq.usage.Usage$1 v;
int v, v;
org.apache.activemq.usage.Usage v;
java.lang.String v, v;
boolean v, v, v, v, v, v;
org.slf4j.Logger v, v;
java.util.Iterator v;
java.util.List v, v, v, v;
java.util.concurrent.locks.Condition v;
java.lang.Object v;
v := @this: org.apache.activemq.usage.Usage;
v := @parameter: int;
v := @parameter: int;
v = v.<org.apache.activemq.usage.Usage: boolean debug>;
if v == 0 goto label;
v = <org.apache.activemq.usage.Usage: org.slf4j.Logger LOG>;
v = virtualinvoke v.<org.apache.activemq.usage.Usage: java.lang.String getName()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,int,int)>(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[])>("\u0001: usage change from: \u0001% of available memory, to: \u0001% of available memory");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
label:
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.atomic.AtomicBoolean started>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean get()>();
if v == 0 goto label;
if v < 100 goto label;
if v >= 100 goto label;
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.Condition waitForSpaceCondition>;
interfaceinvoke v.<java.util.concurrent.locks.Condition: void signalAll()>();
v = v.<org.apache.activemq.usage.Usage: java.util.List callbacks>;
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v != 0 goto label;
v = v.<org.apache.activemq.usage.Usage: java.util.List callbacks>;
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = virtualinvoke v.<org.apache.activemq.usage.Usage: java.util.concurrent.ThreadPoolExecutor getExecutor()>();
virtualinvoke v.<java.util.concurrent.ThreadPoolExecutor: void execute(java.lang.Runnable)>(v);
goto label;
label:
v = v.<org.apache.activemq.usage.Usage: java.util.List callbacks>;
interfaceinvoke v.<java.util.List: void clear()>();
label:
v = v.<org.apache.activemq.usage.Usage: java.util.List listeners>;
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v != 0 goto label;
v = new org.apache.activemq.usage.Usage$1;
specialinvoke v.<org.apache.activemq.usage.Usage$1: void <init>(org.apache.activemq.usage.Usage,int,int)>(v, v, v);
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.atomic.AtomicBoolean started>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean get()>();
if v == 0 goto label;
v = virtualinvoke v.<org.apache.activemq.usage.Usage: java.util.concurrent.ThreadPoolExecutor getExecutor()>();
virtualinvoke v.<java.util.concurrent.ThreadPoolExecutor: void execute(java.lang.Runnable)>(v);
goto label;
label:
v = <org.apache.activemq.usage.Usage: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String)>("Not notifying memory usage change to listeners on shutdown");
label:
return;
}
public java.lang.String getName()
{
org.apache.activemq.usage.Usage v;
java.lang.String v;
v := @this: org.apache.activemq.usage.Usage;
v = v.<org.apache.activemq.usage.Usage: java.lang.String name>;
return v;
}
public java.lang.String toString()
{
long v, v;
org.apache.activemq.usage.UsageCapacity v;
int v, v;
org.apache.activemq.usage.Usage v, v, v;
java.lang.String v, v, v, v;
v := @this: org.apache.activemq.usage.Usage;
v = virtualinvoke v.<org.apache.activemq.usage.Usage: java.lang.String getName()>();
v = v.<org.apache.activemq.usage.Usage: int percentUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.Usage: long retrieveUsage()>();
v = v.<org.apache.activemq.usage.Usage: org.apache.activemq.usage.UsageCapacity limiter>;
v = interfaceinvoke v.<org.apache.activemq.usage.UsageCapacity: long getLimit()>();
v = v.<org.apache.activemq.usage.Usage: int percentUsageMinDelta>;
v = v.<org.apache.activemq.usage.Usage: org.apache.activemq.usage.Usage parent>;
if v == null goto label;
v = v.<org.apache.activemq.usage.Usage: org.apache.activemq.usage.Usage parent>;
v = virtualinvoke v.<org.apache.activemq.usage.Usage: java.lang.String toString()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(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[])>(";Parent:\u0001");
goto label;
label:
v = "";
label:
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,int,long,long,int,java.lang.String)>(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[])>("Usage(\u) percentUsage=\u0001%, usage=\u, limit=\u, percentUsageMinDelta=\u0001%\u0001");
return v;
}
public void start()
{
java.lang.Object[] v;
java.util.concurrent.atomic.AtomicBoolean v;
long v, v, v, v;
byte v;
java.lang.Long v, v;
org.apache.activemq.usage.Usage v, v, v, v, v;
java.lang.String v;
boolean v, v;
org.slf4j.Logger v;
java.util.Iterator v;
java.util.List v;
java.lang.Object v;
v := @this: org.apache.activemq.usage.Usage;
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.atomic.AtomicBoolean started>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean compareAndSet(boolean,boolean)>(0, 1);
if v == 0 goto label;
v = v.<org.apache.activemq.usage.Usage: org.apache.activemq.usage.Usage parent>;
if v == null goto label;
v = v.<org.apache.activemq.usage.Usage: org.apache.activemq.usage.Usage parent>;
virtualinvoke v.<org.apache.activemq.usage.Usage: void addChild(org.apache.activemq.usage.Usage)>(v);
v = virtualinvoke v.<org.apache.activemq.usage.Usage: long getLimit()>();
v = v.<org.apache.activemq.usage.Usage: org.apache.activemq.usage.Usage parent>;
v = virtualinvoke v.<org.apache.activemq.usage.Usage: long getLimit()>();
v = v cmp v;
if v <= 0 goto label;
v = <org.apache.activemq.usage.Usage: org.slf4j.Logger LOG>;
v = newarray (java.lang.Object)[3];
v = virtualinvoke v.<org.apache.activemq.usage.Usage: java.lang.String getName()>();
v[0] = v;
v = virtualinvoke v.<org.apache.activemq.usage.Usage: long getLimit()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[1] = v;
v = v.<org.apache.activemq.usage.Usage: org.apache.activemq.usage.Usage parent>;
v = virtualinvoke v.<org.apache.activemq.usage.Usage: long getLimit()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[2] = v;
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String,java.lang.Object[])>("Usage({}) limit={} should be smaller than its parent limit={}", v);
label:
v = v.<org.apache.activemq.usage.Usage: java.util.List children>;
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
virtualinvoke v.<org.apache.activemq.usage.Usage: void start()>();
goto label;
label:
return;
}
public void stop()
{
java.lang.Throwable v;
java.util.concurrent.atomic.AtomicBoolean v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock v, v, v;
org.apache.activemq.usage.Usage v, v, v;
boolean v, v, v;
java.util.Iterator v, v;
java.util.List v, v, v;
java.util.concurrent.locks.Condition v;
java.lang.Object v, v;
v := @this: org.apache.activemq.usage.Usage;
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.atomic.AtomicBoolean started>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean compareAndSet(boolean,boolean)>(1, 0);
if v == 0 goto label;
v = v.<org.apache.activemq.usage.Usage: org.apache.activemq.usage.Usage parent>;
if v == null goto label;
v = v.<org.apache.activemq.usage.Usage: org.apache.activemq.usage.Usage parent>;
virtualinvoke v.<org.apache.activemq.usage.Usage: void removeChild(org.apache.activemq.usage.Usage)>(v);
label:
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.Condition waitForSpaceCondition>;
interfaceinvoke v.<java.util.concurrent.locks.Condition: void signalAll()>();
v = v.<org.apache.activemq.usage.Usage: java.util.List callbacks>;
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
interfaceinvoke v.<java.lang.Runnable: void run()>();
goto label;
label:
v = v.<org.apache.activemq.usage.Usage: java.util.List callbacks>;
interfaceinvoke v.<java.util.List: void clear()>();
label:
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
label:
v = v.<org.apache.activemq.usage.Usage: java.util.List children>;
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
virtualinvoke v.<org.apache.activemq.usage.Usage: void stop()>();
goto label;
label:
return;
catch java.lang.Throwable from label to label with label;
}
protected void addChild(org.apache.activemq.usage.Usage)
{
java.util.List v;
java.util.concurrent.atomic.AtomicBoolean v;
org.apache.activemq.usage.Usage v, v;
boolean v;
v := @this: org.apache.activemq.usage.Usage;
v := @parameter: org.apache.activemq.usage.Usage;
v = v.<org.apache.activemq.usage.Usage: java.util.List children>;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.atomic.AtomicBoolean started>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean get()>();
if v == 0 goto label;
virtualinvoke v.<org.apache.activemq.usage.Usage: void start()>();
label:
return;
}
protected void removeChild(org.apache.activemq.usage.Usage)
{
java.util.List v;
org.apache.activemq.usage.Usage v, v;
v := @this: org.apache.activemq.usage.Usage;
v := @parameter: org.apache.activemq.usage.Usage;
v = v.<org.apache.activemq.usage.Usage: java.util.List children>;
interfaceinvoke v.<java.util.List: boolean remove(java.lang.Object)>(v);
return;
}
public boolean notifyCallbackWhenNotFull(java.lang.Runnable)
{
java.lang.Throwable v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock v, v, v, v;
java.lang.Runnable v;
org.apache.activemq.usage.Usage$2 v;
int v;
org.apache.activemq.usage.Usage v, v, v;
boolean v;
java.util.List v;
v := @this: org.apache.activemq.usage.Usage;
v := @parameter: java.lang.Runnable;
v = v.<org.apache.activemq.usage.Usage: org.apache.activemq.usage.Usage parent>;
if v == null goto label;
v = new org.apache.activemq.usage.Usage$2;
specialinvoke v.<org.apache.activemq.usage.Usage$2: void <init>(org.apache.activemq.usage.Usage,java.lang.Runnable)>(v, v);
v = v.<org.apache.activemq.usage.Usage: org.apache.activemq.usage.Usage parent>;
v = virtualinvoke v.<org.apache.activemq.usage.Usage: boolean notifyCallbackWhenNotFull(java.lang.Runnable)>(v);
if v == 0 goto label;
return 1;
label:
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
v = v.<org.apache.activemq.usage.Usage: int percentUsage>;
if v < 100 goto label;
v = v.<org.apache.activemq.usage.Usage: java.util.List callbacks>;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
label:
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
return 1;
label:
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
return 0;
label:
v := @caughtexception;
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.locks.ReentrantReadWriteLock usageLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
catch java.lang.Throwable from label to label with label;
}
public org.apache.activemq.usage.UsageCapacity getLimiter()
{
org.apache.activemq.usage.Usage v;
org.apache.activemq.usage.UsageCapacity v;
v := @this: org.apache.activemq.usage.Usage;
v = v.<org.apache.activemq.usage.Usage: org.apache.activemq.usage.UsageCapacity limiter>;
return v;
}
public void setLimiter(org.apache.activemq.usage.UsageCapacity)
{
org.apache.activemq.usage.Usage v;
org.apache.activemq.usage.UsageCapacity v;
v := @this: org.apache.activemq.usage.Usage;
v := @parameter: org.apache.activemq.usage.UsageCapacity;
v.<org.apache.activemq.usage.Usage: org.apache.activemq.usage.UsageCapacity limiter> = v;
return;
}
public int getPollingTime()
{
int v;
org.apache.activemq.usage.Usage v;
v := @this: org.apache.activemq.usage.Usage;
v = v.<org.apache.activemq.usage.Usage: int pollingTime>;
return v;
}
public void setPollingTime(int)
{
int v;
org.apache.activemq.usage.Usage v;
v := @this: org.apache.activemq.usage.Usage;
v := @parameter: int;
v.<org.apache.activemq.usage.Usage: int pollingTime> = v;
return;
}
public void setName(java.lang.String)
{
org.apache.activemq.usage.Usage v;
java.lang.String v;
v := @this: org.apache.activemq.usage.Usage;
v := @parameter: java.lang.String;
v.<org.apache.activemq.usage.Usage: java.lang.String name> = v;
return;
}
public org.apache.activemq.usage.Usage getParent()
{
org.apache.activemq.usage.Usage v, v;
v := @this: org.apache.activemq.usage.Usage;
v = v.<org.apache.activemq.usage.Usage: org.apache.activemq.usage.Usage parent>;
return v;
}
public void setParent(org.apache.activemq.usage.Usage)
{
org.apache.activemq.usage.Usage v, v;
v := @this: org.apache.activemq.usage.Usage;
v := @parameter: org.apache.activemq.usage.Usage;
v.<org.apache.activemq.usage.Usage: org.apache.activemq.usage.Usage parent> = v;
return;
}
public void setExecutor(java.util.concurrent.ThreadPoolExecutor)
{
org.apache.activemq.usage.Usage v;
java.util.concurrent.ThreadPoolExecutor v;
v := @this: org.apache.activemq.usage.Usage;
v := @parameter: java.util.concurrent.ThreadPoolExecutor;
v.<org.apache.activemq.usage.Usage: java.util.concurrent.ThreadPoolExecutor executor> = v;
return;
}
public java.util.concurrent.ThreadPoolExecutor getExecutor()
{
org.apache.activemq.usage.Usage v;
java.util.concurrent.ThreadPoolExecutor v;
v := @this: org.apache.activemq.usage.Usage;
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.ThreadPoolExecutor executor>;
return v;
}
public boolean isStarted()
{
java.util.concurrent.atomic.AtomicBoolean v;
org.apache.activemq.usage.Usage v;
boolean v;
v := @this: org.apache.activemq.usage.Usage;
v = v.<org.apache.activemq.usage.Usage: java.util.concurrent.atomic.AtomicBoolean started>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean get()>();
return v;
}
static void <clinit>()
{
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/activemq/usage/Usage;");
<org.apache.activemq.usage.Usage: org.slf4j.Logger LOG> = v;
return;
}
}