public class org.apache.activemq.transport.mqtt.MQTTInactivityMonitor extends org.apache.activemq.transport.TransportFilter
{
private static final org.slf4j.Logger LOG;
private static final long DEFAULT_CHECK_TIME_MILLS;
private static java.util.concurrent.ThreadPoolExecutor ASYNC_TASKS;
private static int CHECKER_COUNTER;
private static java.util.Timer READ_CHECK_TIMER;
private final java.util.concurrent.atomic.AtomicBoolean failed;
private final java.util.concurrent.atomic.AtomicBoolean inReceive;
private final java.util.concurrent.atomic.AtomicInteger lastReceiveCounter;
private final java.util.concurrent.locks.ReentrantLock sendLock;
private org.apache.activemq.thread.SchedulerTimerTask readCheckerTask;
private long readGraceTime;
private long readKeepAliveTime;
private org.apache.activemq.transport.mqtt.MQTTProtocolConverter protocolConverter;
private long connectionTimeout;
private org.apache.activemq.thread.SchedulerTimerTask connectCheckerTask;
private final java.lang.Runnable connectChecker;
private final java.lang.Runnable readChecker;
private final java.util.concurrent.ThreadFactory factory;
public void <init>(org.apache.activemq.transport.Transport, org.apache.activemq.wireformat.WireFormat)
{
java.util.concurrent.locks.ReentrantLock v;
org.apache.activemq.wireformat.WireFormat v;
java.util.concurrent.atomic.AtomicBoolean v, v;
org.apache.activemq.transport.Transport v;
org.apache.activemq.transport.mqtt.MQTTInactivityMonitor v;
org.apache.activemq.transport.mqtt.MQTTInactivityMonitor$2 v;
java.util.concurrent.atomic.AtomicInteger v;
org.apache.activemq.transport.mqtt.MQTTInactivityMonitor$1 v;
org.apache.activemq.transport.mqtt.MQTTInactivityMonitor$3 v;
v := @this: org.apache.activemq.transport.mqtt.MQTTInactivityMonitor;
v := @parameter: org.apache.activemq.transport.Transport;
v := @parameter: org.apache.activemq.wireformat.WireFormat;
specialinvoke v.<org.apache.activemq.transport.TransportFilter: void <init>(org.apache.activemq.transport.Transport)>(v);
v = new java.util.concurrent.atomic.AtomicBoolean;
specialinvoke v.<java.util.concurrent.atomic.AtomicBoolean: void <init>(boolean)>(0);
v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.util.concurrent.atomic.AtomicBoolean failed> = v;
v = new java.util.concurrent.atomic.AtomicBoolean;
specialinvoke v.<java.util.concurrent.atomic.AtomicBoolean: void <init>(boolean)>(0);
v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.util.concurrent.atomic.AtomicBoolean inReceive> = v;
v = new java.util.concurrent.atomic.AtomicInteger;
specialinvoke v.<java.util.concurrent.atomic.AtomicInteger: void <init>(int)>(0);
v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.util.concurrent.atomic.AtomicInteger lastReceiveCounter> = v;
v = new java.util.concurrent.locks.ReentrantLock;
specialinvoke v.<java.util.concurrent.locks.ReentrantLock: void <init>()>();
v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.util.concurrent.locks.ReentrantLock sendLock> = v;
v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: long readGraceTime> = 30000L;
v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: long readKeepAliveTime> = 30000L;
v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: long connectionTimeout> = 30000L;
v = new org.apache.activemq.transport.mqtt.MQTTInactivityMonitor$1;
specialinvoke v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor$1: void <init>(org.apache.activemq.transport.mqtt.MQTTInactivityMonitor)>(v);
v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.lang.Runnable connectChecker> = v;
v = new org.apache.activemq.transport.mqtt.MQTTInactivityMonitor$2;
specialinvoke v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor$2: void <init>(org.apache.activemq.transport.mqtt.MQTTInactivityMonitor)>(v);
v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.lang.Runnable readChecker> = v;
v = new org.apache.activemq.transport.mqtt.MQTTInactivityMonitor$3;
specialinvoke v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor$3: void <init>(org.apache.activemq.transport.mqtt.MQTTInactivityMonitor)>(v);
v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.util.concurrent.ThreadFactory factory> = v;
return;
}
public void start() throws java.lang.Exception
{
org.apache.activemq.transport.Transport v;
org.apache.activemq.transport.mqtt.MQTTInactivityMonitor v;
v := @this: org.apache.activemq.transport.mqtt.MQTTInactivityMonitor;
v = v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: org.apache.activemq.transport.Transport next>;
interfaceinvoke v.<org.apache.activemq.transport.Transport: void start()>();
return;
}
public void stop() throws java.lang.Exception
{
org.apache.activemq.transport.Transport v;
org.apache.activemq.transport.mqtt.MQTTInactivityMonitor v;
v := @this: org.apache.activemq.transport.mqtt.MQTTInactivityMonitor;
virtualinvoke v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: void stopReadChecker()>();
virtualinvoke v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: void stopConnectChecker()>();
v = v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: org.apache.activemq.transport.Transport next>;
interfaceinvoke v.<org.apache.activemq.transport.Transport: void stop()>();
return;
}
public void onCommand(java.lang.Object)
{
java.lang.Throwable v;
org.apache.activemq.transport.TransportListener v;
java.util.concurrent.atomic.AtomicBoolean v, v, v;
java.lang.Object v;
org.apache.activemq.transport.mqtt.MQTTInactivityMonitor v;
v := @this: org.apache.activemq.transport.mqtt.MQTTInactivityMonitor;
v := @parameter: java.lang.Object;
v = v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.util.concurrent.atomic.AtomicBoolean inReceive>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: void set(boolean)>(1);
label:
v = v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: org.apache.activemq.transport.TransportListener transportListener>;
interfaceinvoke v.<org.apache.activemq.transport.TransportListener: void onCommand(java.lang.Object)>(v);
label:
v = v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.util.concurrent.atomic.AtomicBoolean inReceive>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: void set(boolean)>(0);
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.util.concurrent.atomic.AtomicBoolean inReceive>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: void set(boolean)>(0);
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
public void oneway(java.lang.Object) throws java.io.IOException
{
java.lang.Throwable v;
java.util.concurrent.locks.ReentrantLock v, v, v;
java.lang.Object v;
org.apache.activemq.transport.mqtt.MQTTInactivityMonitor v;
v := @this: org.apache.activemq.transport.mqtt.MQTTInactivityMonitor;
v := @parameter: java.lang.Object;
v = v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.util.concurrent.locks.ReentrantLock sendLock>;
virtualinvoke v.<java.util.concurrent.locks.ReentrantLock: void lock()>();
label:
specialinvoke v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: void doOnewaySend(java.lang.Object)>(v);
label:
v = v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.util.concurrent.locks.ReentrantLock sendLock>;
virtualinvoke v.<java.util.concurrent.locks.ReentrantLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.util.concurrent.locks.ReentrantLock sendLock>;
virtualinvoke v.<java.util.concurrent.locks.ReentrantLock: void unlock()>();
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
private void doOnewaySend(java.lang.Object) throws java.io.IOException
{
org.apache.activemq.transport.InactivityIOException v;
java.util.concurrent.atomic.AtomicBoolean v;
org.apache.activemq.transport.Transport v, v;
org.apache.activemq.transport.mqtt.MQTTInactivityMonitor v;
java.lang.Object v;
java.lang.String v, v;
boolean v;
v := @this: org.apache.activemq.transport.mqtt.MQTTInactivityMonitor;
v := @parameter: java.lang.Object;
v = v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.util.concurrent.atomic.AtomicBoolean failed>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean get()>();
if v == 0 goto label;
v = new org.apache.activemq.transport.InactivityIOException;
v = v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: org.apache.activemq.transport.Transport next>;
v = interfaceinvoke v.<org.apache.activemq.transport.Transport: java.lang.String getRemoteAddress()>();
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[])>("Cannot send, channel has already failed: \u0001");
specialinvoke v.<org.apache.activemq.transport.InactivityIOException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: org.apache.activemq.transport.Transport next>;
interfaceinvoke v.<org.apache.activemq.transport.Transport: void oneway(java.lang.Object)>(v);
return;
}
public void onException(java.io.IOException)
{
org.apache.activemq.transport.TransportListener v;
java.util.concurrent.atomic.AtomicBoolean v;
java.io.IOException v;
org.apache.activemq.transport.mqtt.MQTTInactivityMonitor v;
org.apache.activemq.transport.mqtt.MQTTProtocolConverter v, v;
boolean v;
v := @this: org.apache.activemq.transport.mqtt.MQTTInactivityMonitor;
v := @parameter: java.io.IOException;
v = v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.util.concurrent.atomic.AtomicBoolean failed>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean compareAndSet(boolean,boolean)>(0, 1);
if v == 0 goto label;
virtualinvoke v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: void stopConnectChecker()>();
virtualinvoke v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: void stopReadChecker()>();
v = v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: org.apache.activemq.transport.mqtt.MQTTProtocolConverter protocolConverter>;
if v == null goto label;
v = v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: org.apache.activemq.transport.mqtt.MQTTProtocolConverter protocolConverter>;
virtualinvoke v.<org.apache.activemq.transport.mqtt.MQTTProtocolConverter: void onTransportError()>();
label:
v = v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: org.apache.activemq.transport.TransportListener transportListener>;
interfaceinvoke v.<org.apache.activemq.transport.TransportListener: void onException(java.io.IOException)>(v);
label:
return;
}
public long getReadGraceTime()
{
long v;
org.apache.activemq.transport.mqtt.MQTTInactivityMonitor v;
v := @this: org.apache.activemq.transport.mqtt.MQTTInactivityMonitor;
v = v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: long readGraceTime>;
return v;
}
public void setReadGraceTime(long)
{
long v;
org.apache.activemq.transport.mqtt.MQTTInactivityMonitor v;
v := @this: org.apache.activemq.transport.mqtt.MQTTInactivityMonitor;
v := @parameter: long;
v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: long readGraceTime> = v;
return;
}
public long getReadKeepAliveTime()
{
long v;
org.apache.activemq.transport.mqtt.MQTTInactivityMonitor v;
v := @this: org.apache.activemq.transport.mqtt.MQTTInactivityMonitor;
v = v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: long readKeepAliveTime>;
return v;
}
public void setReadKeepAliveTime(long)
{
long v;
org.apache.activemq.transport.mqtt.MQTTInactivityMonitor v;
v := @this: org.apache.activemq.transport.mqtt.MQTTInactivityMonitor;
v := @parameter: long;
v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: long readKeepAliveTime> = v;
return;
}
public void setProtocolConverter(org.apache.activemq.transport.mqtt.MQTTProtocolConverter)
{
org.apache.activemq.transport.mqtt.MQTTInactivityMonitor v;
org.apache.activemq.transport.mqtt.MQTTProtocolConverter v;
v := @this: org.apache.activemq.transport.mqtt.MQTTInactivityMonitor;
v := @parameter: org.apache.activemq.transport.mqtt.MQTTProtocolConverter;
v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: org.apache.activemq.transport.mqtt.MQTTProtocolConverter protocolConverter> = v;
return;
}
public org.apache.activemq.transport.mqtt.MQTTProtocolConverter getProtocolConverter()
{
org.apache.activemq.transport.mqtt.MQTTInactivityMonitor v;
org.apache.activemq.transport.mqtt.MQTTProtocolConverter v;
v := @this: org.apache.activemq.transport.mqtt.MQTTInactivityMonitor;
v = v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: org.apache.activemq.transport.mqtt.MQTTProtocolConverter protocolConverter>;
return v;
}
public synchronized void startConnectChecker(long)
{
java.lang.Throwable v;
java.util.concurrent.ThreadPoolExecutor v, v, v;
java.util.Timer v, v;
long v, v;
java.lang.Runnable v;
byte v;
int v, v, v;
boolean v;
org.apache.activemq.thread.SchedulerTimerTask v, v, v;
org.apache.activemq.transport.mqtt.MQTTInactivityMonitor v;
v := @this: org.apache.activemq.transport.mqtt.MQTTInactivityMonitor;
v := @parameter: long;
v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: long connectionTimeout> = v;
v = v cmp 0L;
if v <= 0 goto label;
v = v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: org.apache.activemq.thread.SchedulerTimerTask connectCheckerTask>;
if v != null goto label;
v = new org.apache.activemq.thread.SchedulerTimerTask;
v = v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.lang.Runnable connectChecker>;
specialinvoke v.<org.apache.activemq.thread.SchedulerTimerTask: void <init>(java.lang.Runnable)>(v);
v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: org.apache.activemq.thread.SchedulerTimerTask connectCheckerTask> = v;
v = staticinvoke <java.lang.Math: long min(long,long)>(v, 1000L);
entermonitor class "Lorg/apache/activemq/transport/AbstractInactivityMonitor;";
label:
v = <org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: int CHECKER_COUNTER>;
if v != 0 goto label;
v = <org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.util.concurrent.ThreadPoolExecutor ASYNC_TASKS>;
if v == null goto label;
v = <org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.util.concurrent.ThreadPoolExecutor ASYNC_TASKS>;
v = virtualinvoke v.<java.util.concurrent.ThreadPoolExecutor: boolean isShutdown()>();
if v == 0 goto label;
label:
v = specialinvoke v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.util.concurrent.ThreadPoolExecutor createExecutor()>();
<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.util.concurrent.ThreadPoolExecutor ASYNC_TASKS> = v;
label:
v = new java.util.Timer;
specialinvoke v.<java.util.Timer: void <init>(java.lang.String,boolean)>("InactivityMonitor ReadCheck", 1);
<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.util.Timer READ_CHECK_TIMER> = v;
label:
v = <org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: int CHECKER_COUNTER>;
v = v + 1;
<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: int CHECKER_COUNTER> = v;
v = <org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.util.Timer READ_CHECK_TIMER>;
v = v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: org.apache.activemq.thread.SchedulerTimerTask connectCheckerTask>;
virtualinvoke v.<java.util.Timer: void schedule(java.util.TimerTask,long,long)>(v, v, v);
exitmonitor class "Lorg/apache/activemq/transport/AbstractInactivityMonitor;";
label:
goto label;
label:
v := @caughtexception;
exitmonitor class "Lorg/apache/activemq/transport/AbstractInactivityMonitor;";
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
synchronized void startReadChecker()
{
java.lang.Throwable v;
java.util.concurrent.ThreadPoolExecutor v, v, v;
java.util.Timer v, v;
long v, v, v;
java.lang.Runnable v;
byte v;
int v, v, v;
boolean v;
org.apache.activemq.thread.SchedulerTimerTask v, v, v;
org.apache.activemq.transport.mqtt.MQTTInactivityMonitor v;
v := @this: org.apache.activemq.transport.mqtt.MQTTInactivityMonitor;
v = v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: long readKeepAliveTime>;
v = v cmp 0L;
if v <= 0 goto label;
v = v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: org.apache.activemq.thread.SchedulerTimerTask readCheckerTask>;
if v != null goto label;
v = new org.apache.activemq.thread.SchedulerTimerTask;
v = v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.lang.Runnable readChecker>;
specialinvoke v.<org.apache.activemq.thread.SchedulerTimerTask: void <init>(java.lang.Runnable)>(v);
v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: org.apache.activemq.thread.SchedulerTimerTask readCheckerTask> = v;
entermonitor class "Lorg/apache/activemq/transport/AbstractInactivityMonitor;";
label:
v = <org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: int CHECKER_COUNTER>;
if v != 0 goto label;
v = <org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.util.concurrent.ThreadPoolExecutor ASYNC_TASKS>;
if v == null goto label;
v = <org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.util.concurrent.ThreadPoolExecutor ASYNC_TASKS>;
v = virtualinvoke v.<java.util.concurrent.ThreadPoolExecutor: boolean isShutdown()>();
if v == 0 goto label;
label:
v = specialinvoke v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.util.concurrent.ThreadPoolExecutor createExecutor()>();
<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.util.concurrent.ThreadPoolExecutor ASYNC_TASKS> = v;
label:
v = new java.util.Timer;
specialinvoke v.<java.util.Timer: void <init>(java.lang.String,boolean)>("InactivityMonitor ReadCheck", 1);
<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.util.Timer READ_CHECK_TIMER> = v;
label:
v = <org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: int CHECKER_COUNTER>;
v = v + 1;
<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: int CHECKER_COUNTER> = v;
v = <org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.util.Timer READ_CHECK_TIMER>;
v = v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: org.apache.activemq.thread.SchedulerTimerTask readCheckerTask>;
v = v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: long readKeepAliveTime>;
v = v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: long readGraceTime>;
virtualinvoke v.<java.util.Timer: void schedule(java.util.TimerTask,long,long)>(v, v, v);
exitmonitor class "Lorg/apache/activemq/transport/AbstractInactivityMonitor;";
label:
goto label;
label:
v := @caughtexception;
exitmonitor class "Lorg/apache/activemq/transport/AbstractInactivityMonitor;";
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
synchronized void stopConnectChecker()
{
java.lang.Throwable v;
org.apache.activemq.thread.SchedulerTimerTask v, v;
java.util.Timer v, v;
org.apache.activemq.transport.mqtt.MQTTInactivityMonitor v;
int v, v, v;
v := @this: org.apache.activemq.transport.mqtt.MQTTInactivityMonitor;
v = v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: org.apache.activemq.thread.SchedulerTimerTask connectCheckerTask>;
if v == null goto label;
v = v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: org.apache.activemq.thread.SchedulerTimerTask connectCheckerTask>;
virtualinvoke v.<org.apache.activemq.thread.SchedulerTimerTask: boolean cancel()>();
v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: org.apache.activemq.thread.SchedulerTimerTask connectCheckerTask> = null;
entermonitor class "Lorg/apache/activemq/transport/AbstractInactivityMonitor;";
label:
v = <org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.util.Timer READ_CHECK_TIMER>;
virtualinvoke v.<java.util.Timer: int purge()>();
v = <org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: int CHECKER_COUNTER>;
v = v - 1;
<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: int CHECKER_COUNTER> = v;
v = <org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: int CHECKER_COUNTER>;
if v != 0 goto label;
v = <org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.util.Timer READ_CHECK_TIMER>;
virtualinvoke v.<java.util.Timer: void cancel()>();
<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.util.Timer READ_CHECK_TIMER> = null;
label:
exitmonitor class "Lorg/apache/activemq/transport/AbstractInactivityMonitor;";
label:
goto label;
label:
v := @caughtexception;
exitmonitor class "Lorg/apache/activemq/transport/AbstractInactivityMonitor;";
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
synchronized void stopReadChecker()
{
java.lang.Throwable v;
org.apache.activemq.thread.SchedulerTimerTask v, v;
java.util.Timer v, v;
org.apache.activemq.transport.mqtt.MQTTInactivityMonitor v;
int v, v, v;
v := @this: org.apache.activemq.transport.mqtt.MQTTInactivityMonitor;
v = v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: org.apache.activemq.thread.SchedulerTimerTask readCheckerTask>;
if v == null goto label;
v = v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: org.apache.activemq.thread.SchedulerTimerTask readCheckerTask>;
virtualinvoke v.<org.apache.activemq.thread.SchedulerTimerTask: boolean cancel()>();
v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: org.apache.activemq.thread.SchedulerTimerTask readCheckerTask> = null;
entermonitor class "Lorg/apache/activemq/transport/AbstractInactivityMonitor;";
label:
v = <org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.util.Timer READ_CHECK_TIMER>;
virtualinvoke v.<java.util.Timer: int purge()>();
v = <org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: int CHECKER_COUNTER>;
v = v - 1;
<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: int CHECKER_COUNTER> = v;
v = <org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: int CHECKER_COUNTER>;
if v != 0 goto label;
v = <org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.util.Timer READ_CHECK_TIMER>;
virtualinvoke v.<java.util.Timer: void cancel()>();
<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.util.Timer READ_CHECK_TIMER> = null;
label:
exitmonitor class "Lorg/apache/activemq/transport/AbstractInactivityMonitor;";
label:
goto label;
label:
v := @caughtexception;
exitmonitor class "Lorg/apache/activemq/transport/AbstractInactivityMonitor;";
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
private java.util.concurrent.ThreadPoolExecutor createExecutor()
{
java.util.concurrent.TimeUnit v;
java.util.concurrent.SynchronousQueue v;
java.util.concurrent.ThreadPoolExecutor v;
java.util.concurrent.ThreadFactory v;
org.apache.activemq.transport.mqtt.MQTTInactivityMonitor v;
v := @this: org.apache.activemq.transport.mqtt.MQTTInactivityMonitor;
v = new java.util.concurrent.ThreadPoolExecutor;
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit SECONDS>;
v = new java.util.concurrent.SynchronousQueue;
specialinvoke v.<java.util.concurrent.SynchronousQueue: void <init>()>();
v = v.<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: java.util.concurrent.ThreadFactory factory>;
specialinvoke v.<java.util.concurrent.ThreadPoolExecutor: void <init>(int,int,long,java.util.concurrent.TimeUnit,java.util.concurrent.BlockingQueue,java.util.concurrent.ThreadFactory)>(0, 2147483647, 60L, v, v, v);
virtualinvoke v.<java.util.concurrent.ThreadPoolExecutor: void allowCoreThreadTimeOut(boolean)>(1);
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/transport/mqtt/MQTTInactivityMonitor;");
<org.apache.activemq.transport.mqtt.MQTTInactivityMonitor: org.slf4j.Logger LOG> = v;
return;
}
}