public class org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool extends java.lang.Object
{
private static final java.util.logging.Logger LOGGER;
public static final int DEFAULT_SELECTORS_COUNT;
private static final int MISS_THRESHOLD;
private volatile int maxPoolSize;
private final java.util.concurrent.atomic.AtomicBoolean isClosed;
private final java.util.Queue selectors;
private final java.util.concurrent.atomic.AtomicInteger poolSize;
private final java.util.concurrent.atomic.AtomicInteger missesCounter;
private final java.nio.channels.spi.SelectorProvider selectorProvider;
public void <init>(java.nio.channels.spi.SelectorProvider)
{
java.nio.channels.spi.SelectorProvider v;
org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool v;
v := @this: org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool;
v := @parameter: java.nio.channels.spi.SelectorProvider;
specialinvoke v.<org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: void <init>(java.nio.channels.spi.SelectorProvider,int)>(v, 32);
return;
}
public void <init>(java.nio.channels.spi.SelectorProvider, int)
{
java.nio.channels.spi.SelectorProvider v;
java.util.concurrent.atomic.AtomicInteger v, v;
int v;
java.util.concurrent.atomic.AtomicBoolean v;
java.util.concurrent.ConcurrentLinkedQueue v;
org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool v;
v := @this: org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool;
v := @parameter: java.nio.channels.spi.SelectorProvider;
v := @parameter: int;
specialinvoke v.<java.lang.Object: void <init>()>();
v.<org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: java.nio.channels.spi.SelectorProvider selectorProvider> = v;
v.<org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: int maxPoolSize> = v;
v = new java.util.concurrent.atomic.AtomicBoolean;
specialinvoke v.<java.util.concurrent.atomic.AtomicBoolean: void <init>()>();
v.<org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: java.util.concurrent.atomic.AtomicBoolean isClosed> = v;
v = new java.util.concurrent.ConcurrentLinkedQueue;
specialinvoke v.<java.util.concurrent.ConcurrentLinkedQueue: void <init>()>();
v.<org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: java.util.Queue selectors> = v;
v = new java.util.concurrent.atomic.AtomicInteger;
specialinvoke v.<java.util.concurrent.atomic.AtomicInteger: void <init>()>();
v.<org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: java.util.concurrent.atomic.AtomicInteger poolSize> = v;
v = new java.util.concurrent.atomic.AtomicInteger;
specialinvoke v.<java.util.concurrent.atomic.AtomicInteger: void <init>()>();
v.<org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: java.util.concurrent.atomic.AtomicInteger missesCounter> = v;
return;
}
public synchronized int size()
{
int v;
org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool v;
v := @this: org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool;
v = v.<org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: int maxPoolSize>;
return v;
}
public synchronized void setSize(int) throws java.io.IOException
{
java.util.concurrent.atomic.AtomicInteger v;
int v;
java.util.concurrent.atomic.AtomicBoolean v;
boolean v;
org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool v;
v := @this: org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool;
v := @parameter: int;
v = v.<org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: java.util.concurrent.atomic.AtomicBoolean isClosed>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean get()>();
if v == 0 goto label;
return;
label:
v = v.<org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: java.util.concurrent.atomic.AtomicInteger missesCounter>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: void set(int)>(0);
v.<org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: int maxPoolSize> = v;
return;
}
public java.nio.channels.spi.SelectorProvider getSelectorProvider()
{
java.nio.channels.spi.SelectorProvider v;
org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool v;
v := @this: org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool;
v = v.<org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: java.nio.channels.spi.SelectorProvider selectorProvider>;
return v;
}
public java.nio.channels.Selector poll() throws java.io.IOException
{
java.lang.Integer v, v;
java.util.logging.Level v, v;
java.nio.channels.spi.SelectorProvider v;
java.util.concurrent.atomic.AtomicInteger v, v;
int v, v, v;
java.lang.String v, v;
org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool v;
java.io.IOException v;
java.util.logging.Logger v, v;
java.lang.Object v;
java.util.Queue v;
v := @this: org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool;
v = v.<org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: java.util.Queue selectors>;
v = interfaceinvoke v.<java.util.Queue: java.lang.Object poll()>();
if v == null goto label;
v = v.<org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: java.util.concurrent.atomic.AtomicInteger poolSize>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int decrementAndGet()>();
goto label;
label:
v = v.<org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: java.nio.channels.spi.SelectorProvider selectorProvider>;
v = staticinvoke <org.glassfish.grizzly.nio.Selectors: java.nio.channels.Selector newSelector(java.nio.channels.spi.SelectorProvider)>(v);
label:
goto label;
label:
v := @caughtexception;
v = <org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: java.util.logging.Logger LOGGER>;
v = <java.util.logging.Level: java.util.logging.Level WARNING>;
v = staticinvoke <org.glassfish.grizzly.localization.LogMessages: java.lang.String WARNING_GRIZZLY_TEMPORARY_SELECTOR_POOL_CREATE_SELECTOR_EXCEPTION()>();
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Throwable)>(v, v, v);
label:
v = v.<org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: java.util.concurrent.atomic.AtomicInteger missesCounter>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int incrementAndGet()>();
v = v % 10000;
if v != 0 goto label;
v = <org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: java.util.logging.Logger LOGGER>;
v = <java.util.logging.Level: java.util.logging.Level WARNING>;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v = v.<org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: int maxPoolSize>;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v = staticinvoke <org.glassfish.grizzly.localization.LogMessages: java.lang.String WARNING_GRIZZLY_TEMPORARY_SELECTOR_POOL_MISSES_EXCEPTION(java.lang.Object,java.lang.Object)>(v, v);
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String)>(v, v);
label:
return v;
catch java.io.IOException from label to label with label;
}
public void offer(java.nio.channels.Selector)
{
java.nio.channels.Selector v, v;
java.util.concurrent.atomic.AtomicBoolean v;
java.util.concurrent.atomic.AtomicInteger v, v;
int v, v;
java.util.Queue v, v;
boolean v, v, v;
org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool v;
v := @this: org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool;
v := @parameter: java.nio.channels.Selector;
if v != null goto label;
return;
label:
v = v.<org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: java.util.concurrent.atomic.AtomicInteger poolSize>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int getAndIncrement()>();
v = v.<org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: int maxPoolSize>;
if v >= v goto label;
v = specialinvoke v.<org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: java.nio.channels.Selector checkSelector(java.nio.channels.Selector)>(v);
v = v;
if v == null goto label;
v = v.<org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: java.util.Queue selectors>;
interfaceinvoke v.<java.util.Queue: boolean offer(java.lang.Object)>(v);
v = 1;
goto label;
label:
v = v.<org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: java.util.concurrent.atomic.AtomicInteger poolSize>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int decrementAndGet()>();
if v != null goto label;
return;
label:
v = 0;
label:
v = v.<org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: java.util.concurrent.atomic.AtomicBoolean isClosed>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean get()>();
if v == 0 goto label;
v = v.<org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: java.util.Queue selectors>;
v = interfaceinvoke v.<java.util.Queue: boolean remove(java.lang.Object)>(v);
if v == 0 goto label;
specialinvoke v.<org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: void closeSelector(java.nio.channels.Selector)>(v);
goto label;
label:
if v != 0 goto label;
specialinvoke v.<org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: void closeSelector(java.nio.channels.Selector)>(v);
label:
return;
}
public synchronized void close()
{
java.util.concurrent.atomic.AtomicBoolean v;
java.lang.Object v;
java.util.Queue v;
boolean v;
org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool v;
v := @this: org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool;
v = v.<org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: java.util.concurrent.atomic.AtomicBoolean isClosed>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean getAndSet(boolean)>(1);
if v != 0 goto label;
label:
v = v.<org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: java.util.Queue selectors>;
v = interfaceinvoke v.<java.util.Queue: java.lang.Object poll()>();
if v == null goto label;
specialinvoke v.<org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: void closeSelector(java.nio.channels.Selector)>(v);
goto label;
label:
return;
}
private void closeSelector(java.nio.channels.Selector)
{
java.nio.channels.Selector v;
org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool v;
v := @this: org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool;
v := @parameter: java.nio.channels.Selector;
return;
}
private java.nio.channels.Selector checkSelector(java.nio.channels.Selector)
{
java.nio.channels.Selector v, v;
java.io.IOException v, v;
java.util.logging.Logger v, v;
java.util.logging.Level v, v;
java.nio.channels.spi.SelectorProvider v;
java.lang.String v, v;
org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool v;
v := @this: org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool;
v := @parameter: java.nio.channels.Selector;
label:
virtualinvoke v.<java.nio.channels.Selector: int selectNow()>();
label:
return v;
label:
v := @caughtexception;
v = <org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: java.util.logging.Logger LOGGER>;
v = <java.util.logging.Level: java.util.logging.Level WARNING>;
v = staticinvoke <org.glassfish.grizzly.localization.LogMessages: java.lang.String WARNING_GRIZZLY_TEMPORARY_SELECTOR_POOL_SELECTOR_FAILURE_EXCEPTION()>();
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Throwable)>(v, v, v);
label:
v = v.<org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: java.nio.channels.spi.SelectorProvider selectorProvider>;
v = staticinvoke <org.glassfish.grizzly.nio.Selectors: java.nio.channels.Selector newSelector(java.nio.channels.spi.SelectorProvider)>(v);
label:
return v;
label:
v := @caughtexception;
v = <org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: java.util.logging.Logger LOGGER>;
v = <java.util.logging.Level: java.util.logging.Level WARNING>;
v = staticinvoke <org.glassfish.grizzly.localization.LogMessages: java.lang.String WARNING_GRIZZLY_TEMPORARY_SELECTOR_POOL_CREATE_SELECTOR_EXCEPTION()>();
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Throwable)>(v, v, v);
return null;
catch java.io.IOException from label to label with label;
catch java.io.IOException from label to label with label;
}
static void <clinit>()
{
java.util.logging.Logger v;
v = staticinvoke <org.glassfish.grizzly.Grizzly: java.util.logging.Logger logger(java.lang.Class)>(class "Lorg/glassfish/grizzly/nio/tmpselectors/TemporarySelectorPool;");
<org.glassfish.grizzly.nio.tmpselectors.TemporarySelectorPool: java.util.logging.Logger LOGGER> = v;
return;
}
}