public class org.apache.activemq.transport.nio.SelectorWorker extends java.lang.Object implements java.lang.Runnable
{
private static final org.slf4j.Logger LOG;
private static final java.util.concurrent.atomic.AtomicInteger NEXT_ID;
final org.apache.activemq.transport.nio.SelectorManager manager;
final java.nio.channels.Selector selector;
final int id;
private final int maxChannelsPerWorker;
final java.util.concurrent.atomic.AtomicInteger retainCounter;
private final java.util.concurrent.ConcurrentLinkedQueue ioTasks;
public void <init>(org.apache.activemq.transport.nio.SelectorManager) throws java.io.IOException
{
java.util.concurrent.Executor v;
java.nio.channels.Selector v;
java.util.concurrent.atomic.AtomicInteger v, v;
int v, v;
org.apache.activemq.transport.nio.SelectorManager v;
java.util.concurrent.ConcurrentLinkedQueue v;
org.apache.activemq.transport.nio.SelectorWorker v;
v := @this: org.apache.activemq.transport.nio.SelectorWorker;
v := @parameter: org.apache.activemq.transport.nio.SelectorManager;
specialinvoke v.<java.lang.Object: void <init>()>();
v = <org.apache.activemq.transport.nio.SelectorWorker: java.util.concurrent.atomic.AtomicInteger NEXT_ID>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int getAndIncrement()>();
v.<org.apache.activemq.transport.nio.SelectorWorker: int id> = v;
v = new java.util.concurrent.atomic.AtomicInteger;
specialinvoke v.<java.util.concurrent.atomic.AtomicInteger: void <init>(int)>(1);
v.<org.apache.activemq.transport.nio.SelectorWorker: java.util.concurrent.atomic.AtomicInteger retainCounter> = v;
v = new java.util.concurrent.ConcurrentLinkedQueue;
specialinvoke v.<java.util.concurrent.ConcurrentLinkedQueue: void <init>()>();
v.<org.apache.activemq.transport.nio.SelectorWorker: java.util.concurrent.ConcurrentLinkedQueue ioTasks> = v;
v.<org.apache.activemq.transport.nio.SelectorWorker: org.apache.activemq.transport.nio.SelectorManager manager> = v;
v = staticinvoke <java.nio.channels.Selector: java.nio.channels.Selector open()>();
v.<org.apache.activemq.transport.nio.SelectorWorker: java.nio.channels.Selector selector> = v;
v = virtualinvoke v.<org.apache.activemq.transport.nio.SelectorManager: int getMaxChannelsPerWorker()>();
v.<org.apache.activemq.transport.nio.SelectorWorker: int maxChannelsPerWorker> = v;
v = virtualinvoke v.<org.apache.activemq.transport.nio.SelectorManager: java.util.concurrent.Executor getSelectorExecutor()>();
interfaceinvoke v.<java.util.concurrent.Executor: void execute(java.lang.Runnable)>(v);
return;
}
void retain()
{
java.util.concurrent.atomic.AtomicInteger v;
int v, v;
org.apache.activemq.transport.nio.SelectorManager v;
org.apache.activemq.transport.nio.SelectorWorker v;
v := @this: org.apache.activemq.transport.nio.SelectorWorker;
v = v.<org.apache.activemq.transport.nio.SelectorWorker: java.util.concurrent.atomic.AtomicInteger retainCounter>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int incrementAndGet()>();
v = v.<org.apache.activemq.transport.nio.SelectorWorker: int maxChannelsPerWorker>;
if v != v goto label;
v = v.<org.apache.activemq.transport.nio.SelectorWorker: org.apache.activemq.transport.nio.SelectorManager manager>;
virtualinvoke v.<org.apache.activemq.transport.nio.SelectorManager: void onWorkerFullEvent(org.apache.activemq.transport.nio.SelectorWorker)>(v);
label:
return;
}
void release()
{
java.util.concurrent.atomic.AtomicInteger v;
int v, v, v;
org.apache.activemq.transport.nio.SelectorManager v, v;
org.apache.activemq.transport.nio.SelectorWorker v;
v := @this: org.apache.activemq.transport.nio.SelectorWorker;
v = v.<org.apache.activemq.transport.nio.SelectorWorker: java.util.concurrent.atomic.AtomicInteger retainCounter>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int decrementAndGet()>();
if v != 0 goto label;
v = v.<org.apache.activemq.transport.nio.SelectorWorker: org.apache.activemq.transport.nio.SelectorManager manager>;
virtualinvoke v.<org.apache.activemq.transport.nio.SelectorManager: void onWorkerEmptyEvent(org.apache.activemq.transport.nio.SelectorWorker)>(v);
goto label;
label:
v = v.<org.apache.activemq.transport.nio.SelectorWorker: int maxChannelsPerWorker>;
v = v - 1;
if v != v goto label;
v = v.<org.apache.activemq.transport.nio.SelectorWorker: org.apache.activemq.transport.nio.SelectorManager manager>;
virtualinvoke v.<org.apache.activemq.transport.nio.SelectorManager: void onWorkerNotFullEvent(org.apache.activemq.transport.nio.SelectorWorker)>(v);
label:
return;
}
boolean isReleased()
{
java.util.concurrent.atomic.AtomicInteger v;
int v;
boolean v;
org.apache.activemq.transport.nio.SelectorWorker v;
v := @this: org.apache.activemq.transport.nio.SelectorWorker;
v = v.<org.apache.activemq.transport.nio.SelectorWorker: java.util.concurrent.atomic.AtomicInteger retainCounter>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public void addIoTask(java.lang.Runnable)
{
java.nio.channels.Selector v;
java.lang.Runnable v;
java.util.concurrent.ConcurrentLinkedQueue v;
org.apache.activemq.transport.nio.SelectorWorker v;
v := @this: org.apache.activemq.transport.nio.SelectorWorker;
v := @parameter: java.lang.Runnable;
v = v.<org.apache.activemq.transport.nio.SelectorWorker: java.util.concurrent.ConcurrentLinkedQueue ioTasks>;
virtualinvoke v.<java.util.concurrent.ConcurrentLinkedQueue: boolean add(java.lang.Object)>(v);
v = v.<org.apache.activemq.transport.nio.SelectorWorker: java.nio.channels.Selector selector>;
virtualinvoke v.<java.nio.channels.Selector: java.nio.channels.Selector wakeup()>();
return;
}
private void processIoTasks()
{
java.lang.Throwable v;
org.slf4j.Logger v;
java.lang.Object v;
java.lang.String v;
java.util.concurrent.ConcurrentLinkedQueue v;
org.apache.activemq.transport.nio.SelectorWorker v;
v := @this: org.apache.activemq.transport.nio.SelectorWorker;
label:
v = v.<org.apache.activemq.transport.nio.SelectorWorker: java.util.concurrent.ConcurrentLinkedQueue ioTasks>;
v = virtualinvoke v.<java.util.concurrent.ConcurrentLinkedQueue: java.lang.Object poll()>();
if v == null goto label;
label:
interfaceinvoke v.<java.lang.Runnable: void run()>();
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.transport.nio.SelectorWorker: org.slf4j.Logger LOG>;
v = virtualinvoke v.<java.lang.Throwable: java.lang.String getMessage()>();
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Throwable)>(v, v);
goto label;
label:
return;
catch java.lang.Throwable from label to label with label;
}
public void run()
{
java.lang.Thread v, v, v, v, v;
org.apache.activemq.transport.nio.SelectorManager v, v, v, v;
boolean v, v, v, v;
java.util.Set v, v;
java.lang.Throwable v, v, v;
java.nio.channels.Selector v, v, v, v, v, v;
org.apache.activemq.transport.nio.SelectorWorker$1 v;
int v, v;
java.lang.String v, v, v, v, v;
org.apache.activemq.transport.nio.SelectorWorker v;
org.slf4j.Logger v, v, v;
java.util.Iterator v, v;
java.util.concurrent.Executor v;
java.io.IOException v, v, v;
java.lang.Object v, v, v, v;
v := @this: org.apache.activemq.transport.nio.SelectorWorker;
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = virtualinvoke v.<java.lang.Thread: java.lang.String getName()>();
label:
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = v.<org.apache.activemq.transport.nio.SelectorWorker: int id>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int)>(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[])>("Selector Worker: \u0001");
virtualinvoke v.<java.lang.Thread: void setName(java.lang.String)>(v);
label:
v = virtualinvoke v.<org.apache.activemq.transport.nio.SelectorWorker: boolean isReleased()>();
if v != 0 goto label;
specialinvoke v.<org.apache.activemq.transport.nio.SelectorWorker: void processIoTasks()>();
v = v.<org.apache.activemq.transport.nio.SelectorWorker: java.nio.channels.Selector selector>;
v = virtualinvoke v.<java.nio.channels.Selector: int select(long)>(10L);
if v == 0 goto label;
v = v.<org.apache.activemq.transport.nio.SelectorWorker: java.nio.channels.Selector selector>;
v = virtualinvoke v.<java.nio.channels.Selector: java.util.Set selectedKeys()>();
v = interfaceinvoke v.<java.util.Set: 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.util.Iterator: void remove()>();
v = virtualinvoke v.<java.nio.channels.SelectionKey: java.lang.Object attachment()>();
label:
v = virtualinvoke v.<java.nio.channels.SelectionKey: boolean isValid()>();
if v == 0 goto label;
virtualinvoke v.<java.nio.channels.SelectionKey: java.nio.channels.SelectionKey interestOps(int)>(0);
label:
v = v.<org.apache.activemq.transport.nio.SelectorWorker: org.apache.activemq.transport.nio.SelectorManager manager>;
v = virtualinvoke v.<org.apache.activemq.transport.nio.SelectorManager: java.util.concurrent.Executor getChannelExecutor()>();
v = new org.apache.activemq.transport.nio.SelectorWorker$1;
specialinvoke v.<org.apache.activemq.transport.nio.SelectorWorker$1: void <init>(org.apache.activemq.transport.nio.SelectorWorker,org.apache.activemq.transport.nio.SelectorSelection)>(v, v);
interfaceinvoke v.<java.util.concurrent.Executor: void execute(java.lang.Runnable)>(v);
label:
goto label;
label:
v := @caughtexception;
virtualinvoke v.<org.apache.activemq.transport.nio.SelectorSelection: void onError(java.lang.Throwable)>(v);
goto label;
label:
v = v.<org.apache.activemq.transport.nio.SelectorWorker: org.apache.activemq.transport.nio.SelectorManager manager>;
virtualinvoke v.<org.apache.activemq.transport.nio.SelectorManager: void onWorkerEmptyEvent(org.apache.activemq.transport.nio.SelectorWorker)>(v);
v = v.<org.apache.activemq.transport.nio.SelectorWorker: java.nio.channels.Selector selector>;
virtualinvoke v.<java.nio.channels.Selector: void close()>();
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.transport.nio.SelectorWorker: org.slf4j.Logger LOG>;
v = virtualinvoke v.<java.io.IOException: java.lang.String getMessage()>();
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Throwable)>(v, v);
label:
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
virtualinvoke v.<java.lang.Thread: void setName(java.lang.String)>(v);
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.transport.nio.SelectorWorker: java.nio.channels.Selector selector>;
v = virtualinvoke v.<java.nio.channels.Selector: java.util.Set keys()>();
v = interfaceinvoke v.<java.util.Set: 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.<java.nio.channels.SelectionKey: java.lang.Object attachment()>();
virtualinvoke v.<org.apache.activemq.transport.nio.SelectorSelection: void onError(java.lang.Throwable)>(v);
goto label;
label:
v = v.<org.apache.activemq.transport.nio.SelectorWorker: org.apache.activemq.transport.nio.SelectorManager manager>;
virtualinvoke v.<org.apache.activemq.transport.nio.SelectorManager: void onWorkerEmptyEvent(org.apache.activemq.transport.nio.SelectorWorker)>(v);
v = v.<org.apache.activemq.transport.nio.SelectorWorker: java.nio.channels.Selector selector>;
virtualinvoke v.<java.nio.channels.Selector: void close()>();
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.transport.nio.SelectorWorker: org.slf4j.Logger LOG>;
v = virtualinvoke v.<java.io.IOException: java.lang.String getMessage()>();
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Throwable)>(v, v);
label:
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
virtualinvoke v.<java.lang.Thread: void setName(java.lang.String)>(v);
goto label;
label:
v := @caughtexception;
label:
v = v.<org.apache.activemq.transport.nio.SelectorWorker: org.apache.activemq.transport.nio.SelectorManager manager>;
virtualinvoke v.<org.apache.activemq.transport.nio.SelectorManager: void onWorkerEmptyEvent(org.apache.activemq.transport.nio.SelectorWorker)>(v);
v = v.<org.apache.activemq.transport.nio.SelectorWorker: java.nio.channels.Selector selector>;
virtualinvoke v.<java.nio.channels.Selector: void close()>();
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.transport.nio.SelectorWorker: org.slf4j.Logger LOG>;
v = virtualinvoke v.<java.io.IOException: java.lang.String getMessage()>();
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Throwable)>(v, v);
label:
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
virtualinvoke v.<java.lang.Thread: void setName(java.lang.String)>(v);
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
catch java.io.IOException from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.io.IOException from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.io.IOException from label to label with label;
}
static void <clinit>()
{
org.slf4j.Logger v;
java.util.concurrent.atomic.AtomicInteger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/activemq/transport/nio/SelectorWorker;");
<org.apache.activemq.transport.nio.SelectorWorker: org.slf4j.Logger LOG> = v;
v = new java.util.concurrent.atomic.AtomicInteger;
specialinvoke v.<java.util.concurrent.atomic.AtomicInteger: void <init>()>();
<org.apache.activemq.transport.nio.SelectorWorker: java.util.concurrent.atomic.AtomicInteger NEXT_ID> = v;
return;
}
}