public abstract class org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter extends org.glassfish.grizzly.AbstractWriter implements org.glassfish.grizzly.asyncqueue.AsyncQueueWriter
{
private static final java.util.logging.Logger LOGGER;
protected final org.glassfish.grizzly.nio.NIOTransport transport;
protected volatile int maxPendingBytes;
protected volatile int maxWriteReentrants;
private volatile boolean isAllowDirectWrite;
public void <init>(org.glassfish.grizzly.nio.NIOTransport)
{
int v;
org.glassfish.grizzly.nio.NIOTransport v;
org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter v;
v := @this: org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter;
v := @parameter: org.glassfish.grizzly.nio.NIOTransport;
specialinvoke v.<org.glassfish.grizzly.AbstractWriter: void <init>()>();
v = (int) -2;
v.<org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: int maxPendingBytes> = v;
v.<org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: int maxWriteReentrants> = 10;
v.<org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: boolean isAllowDirectWrite> = 1;
v.<org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: org.glassfish.grizzly.nio.NIOTransport transport> = v;
return;
}
public boolean canWrite(org.glassfish.grizzly.Connection, int)
{
int v;
org.glassfish.grizzly.Connection v;
org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter v;
boolean v;
v := @this: org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter;
v := @parameter: org.glassfish.grizzly.Connection;
v := @parameter: int;
v = virtualinvoke v.<org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: boolean canWrite(org.glassfish.grizzly.Connection)>(v);
return v;
}
public boolean canWrite(org.glassfish.grizzly.Connection)
{
org.glassfish.grizzly.asyncqueue.TaskQueue v;
int v, v;
org.glassfish.grizzly.Connection v;
org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter v;
boolean v;
v := @this: org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter;
v := @parameter: org.glassfish.grizzly.Connection;
v = virtualinvoke v.<org.glassfish.grizzly.nio.NIOConnection: int getMaxAsyncWriteQueueSize()>();
if v >= 0 goto label;
return 1;
label:
v = virtualinvoke v.<org.glassfish.grizzly.nio.NIOConnection: org.glassfish.grizzly.asyncqueue.TaskQueue getAsyncWriteQueue()>();
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.TaskQueue: int spaceInBytes()>();
if v == 0 goto label;
if v >= v goto label;
label:
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public void notifyWritePossible(org.glassfish.grizzly.Connection, org.glassfish.grizzly.WriteHandler, int)
{
int v;
org.glassfish.grizzly.Connection v;
org.glassfish.grizzly.WriteHandler v;
org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter v;
v := @this: org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter;
v := @parameter: org.glassfish.grizzly.Connection;
v := @parameter: org.glassfish.grizzly.WriteHandler;
v := @parameter: int;
virtualinvoke v.<org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: void notifyWritePossible(org.glassfish.grizzly.Connection,org.glassfish.grizzly.WriteHandler)>(v, v);
return;
}
public void notifyWritePossible(org.glassfish.grizzly.Connection, org.glassfish.grizzly.WriteHandler)
{
org.glassfish.grizzly.asyncqueue.TaskQueue v;
org.glassfish.grizzly.Connection v;
org.glassfish.grizzly.WriteHandler v;
org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter v;
v := @this: org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter;
v := @parameter: org.glassfish.grizzly.Connection;
v := @parameter: org.glassfish.grizzly.WriteHandler;
v = virtualinvoke v.<org.glassfish.grizzly.nio.NIOConnection: org.glassfish.grizzly.asyncqueue.TaskQueue getAsyncWriteQueue()>();
virtualinvoke v.<org.glassfish.grizzly.asyncqueue.TaskQueue: void notifyWritePossible(org.glassfish.grizzly.WriteHandler)>(v);
return;
}
public void setMaxPendingBytesPerConnection(int)
{
int v, v, v, v;
org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter v;
v := @this: org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter;
v := @parameter: int;
v = (int) -2;
if v >= v goto label;
v = (int) -2;
v = v;
goto label;
label:
v = v;
label:
v.<org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: int maxPendingBytes> = v;
return;
}
public int getMaxPendingBytesPerConnection()
{
int v;
org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter v;
v := @this: org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter;
v = v.<org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: int maxPendingBytes>;
return v;
}
public boolean isAllowDirectWrite()
{
org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter v;
boolean v;
v := @this: org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter;
v = v.<org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: boolean isAllowDirectWrite>;
return v;
}
public void setAllowDirectWrite(boolean)
{
org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter v;
boolean v;
v := @this: org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter;
v := @parameter: boolean;
v.<org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: boolean isAllowDirectWrite> = v;
return;
}
public void write(org.glassfish.grizzly.Connection, java.net.SocketAddress, org.glassfish.grizzly.asyncqueue.WritableMessage, org.glassfish.grizzly.CompletionHandler, org.glassfish.grizzly.asyncqueue.MessageCloner)
{
java.net.SocketAddress v;
org.glassfish.grizzly.Connection v;
org.glassfish.grizzly.asyncqueue.MessageCloner v;
org.glassfish.grizzly.asyncqueue.WritableMessage v;
org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter v;
org.glassfish.grizzly.CompletionHandler v;
v := @this: org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter;
v := @parameter: org.glassfish.grizzly.Connection;
v := @parameter: java.net.SocketAddress;
v := @parameter: org.glassfish.grizzly.asyncqueue.WritableMessage;
v := @parameter: org.glassfish.grizzly.CompletionHandler;
v := @parameter: org.glassfish.grizzly.asyncqueue.MessageCloner;
virtualinvoke v.<org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: void write(org.glassfish.grizzly.Connection,java.net.SocketAddress,org.glassfish.grizzly.asyncqueue.WritableMessage,org.glassfish.grizzly.CompletionHandler,org.glassfish.grizzly.asyncqueue.PushBackHandler,org.glassfish.grizzly.asyncqueue.MessageCloner)>(v, v, v, v, null, v);
return;
}
public void write(org.glassfish.grizzly.Connection, java.net.SocketAddress, org.glassfish.grizzly.asyncqueue.WritableMessage, org.glassfish.grizzly.CompletionHandler, org.glassfish.grizzly.asyncqueue.PushBackHandler)
{
java.net.SocketAddress v;
org.glassfish.grizzly.asyncqueue.PushBackHandler v;
org.glassfish.grizzly.Connection v;
org.glassfish.grizzly.asyncqueue.WritableMessage v;
org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter v;
org.glassfish.grizzly.CompletionHandler v;
v := @this: org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter;
v := @parameter: org.glassfish.grizzly.Connection;
v := @parameter: java.net.SocketAddress;
v := @parameter: org.glassfish.grizzly.asyncqueue.WritableMessage;
v := @parameter: org.glassfish.grizzly.CompletionHandler;
v := @parameter: org.glassfish.grizzly.asyncqueue.PushBackHandler;
virtualinvoke v.<org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: void write(org.glassfish.grizzly.Connection,java.net.SocketAddress,org.glassfish.grizzly.asyncqueue.WritableMessage,org.glassfish.grizzly.CompletionHandler,org.glassfish.grizzly.asyncqueue.PushBackHandler,org.glassfish.grizzly.asyncqueue.MessageCloner)>(v, v, v, v, v, null);
return;
}
public void write(org.glassfish.grizzly.Connection, java.net.SocketAddress, org.glassfish.grizzly.asyncqueue.WritableMessage, org.glassfish.grizzly.CompletionHandler, org.glassfish.grizzly.asyncqueue.PushBackHandler, org.glassfish.grizzly.asyncqueue.MessageCloner)
{
java.net.SocketAddress v;
org.glassfish.grizzly.asyncqueue.RecordWriteResult v;
org.glassfish.grizzly.asyncqueue.PushBackHandler v;
java.lang.Integer v, v, v, v;
org.glassfish.grizzly.asyncqueue.TaskQueue v;
java.lang.Long v, v, v;
org.glassfish.grizzly.asyncqueue.MessageCloner v;
org.glassfish.grizzly.asyncqueue.WritableMessage v, v, v;
boolean v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
java.util.logging.Logger v, v;
org.glassfish.grizzly.Connection v;
org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord v;
java.lang.Throwable v;
java.lang.Object[] v, v, v;
long v, v, v, v, v;
org.glassfish.grizzly.IOEvent v, v;
java.util.logging.Level v, v;
int v, v;
java.lang.Boolean v, v, v, v, v;
java.lang.String v;
org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter v;
java.io.IOException v, v, v;
org.glassfish.grizzly.Writer$Reentrant v;
org.glassfish.grizzly.CloseReason v;
org.glassfish.grizzly.CompletionHandler v;
v := @this: org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter;
v := @parameter: org.glassfish.grizzly.Connection;
v := @parameter: java.net.SocketAddress;
v := @parameter: org.glassfish.grizzly.asyncqueue.WritableMessage;
v := @parameter: org.glassfish.grizzly.CompletionHandler;
v := @parameter: org.glassfish.grizzly.asyncqueue.PushBackHandler;
v := @parameter: org.glassfish.grizzly.asyncqueue.MessageCloner;
v = interfaceinvoke v.<org.glassfish.grizzly.asyncqueue.WritableMessage: boolean hasRemaining()>();
if v == 0 goto label;
v = interfaceinvoke v.<org.glassfish.grizzly.asyncqueue.WritableMessage: boolean isExternal()>();
if v == 0 goto label;
label:
v = 1;
goto label;
label:
v = 0;
label:
v = virtualinvoke v.<org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord createRecord(org.glassfish.grizzly.Connection,org.glassfish.grizzly.asyncqueue.WritableMessage,org.glassfish.grizzly.CompletionHandler,java.net.SocketAddress,org.glassfish.grizzly.asyncqueue.PushBackHandler,boolean)>(v, v, v, v, v, v);
if v != null goto label;
v = new java.io.IOException;
specialinvoke v.<java.io.IOException: void <init>(java.lang.String)>("Connection is null");
virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: void notifyFailure(java.lang.Throwable)>(v);
return;
label:
v = virtualinvoke v.<org.glassfish.grizzly.nio.NIOConnection: boolean isOpen()>();
if v != 0 goto label;
v = virtualinvoke v.<org.glassfish.grizzly.nio.NIOConnection: org.glassfish.grizzly.CloseReason getCloseReason()>();
v = virtualinvoke v.<org.glassfish.grizzly.CloseReason: java.io.IOException getCause()>();
staticinvoke <org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: void onWriteFailure(org.glassfish.grizzly.Connection,org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord,java.lang.Throwable)>(v, v, v);
return;
label:
v = virtualinvoke v.<org.glassfish.grizzly.nio.NIOConnection: org.glassfish.grizzly.asyncqueue.TaskQueue getAsyncWriteQueue()>();
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: long getBytesToReserve()>();
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.TaskQueue: int reserveSpace(int)>(v);
if v != v goto label;
v = 1;
goto label;
label:
v = 0;
label:
v = v;
v = <org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: java.util.logging.Logger LOGGER>;
v = <java.util.logging.Level: java.util.logging.Level FINEST>;
v = virtualinvoke v.<java.util.logging.Logger: boolean isLoggable(java.util.logging.Level)>(v);
if v == 0 goto label;
v = newarray (java.lang.Object)[7];
v[0] = v;
v[1] = v;
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(boolean)>(v);
v[2] = v;
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: long remaining()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[3] = v;
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: boolean isUncountable()>();
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(boolean)>(v);
v[4] = v;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[5] = v;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[6] = v;
staticinvoke <org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: void doFineLog(java.lang.String,java.lang.Object[])>("AsyncQueueWriter.write connection={0}, record={1}, directWrite={2}, size={3}, isUncountable={4}, bytesToReserve={5}, pendingBytes={6}", v);
label:
v = staticinvoke <org.glassfish.grizzly.Writer$Reentrant: org.glassfish.grizzly.Writer$Reentrant getWriteReentrant()>();
label:
v = virtualinvoke v.<org.glassfish.grizzly.Writer$Reentrant: boolean inc()>();
if v != 0 goto label;
v = staticinvoke <org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: org.glassfish.grizzly.asyncqueue.WritableMessage cloneRecordIfNeeded(org.glassfish.grizzly.Connection,org.glassfish.grizzly.asyncqueue.MessageCloner,org.glassfish.grizzly.asyncqueue.WritableMessage)>(v, v, v);
virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: void setMessage(java.lang.Object)>(v);
if v == 0 goto label;
virtualinvoke v.<org.glassfish.grizzly.asyncqueue.TaskQueue: void setCurrentElement(org.glassfish.grizzly.asyncqueue.AsyncQueueRecord)>(v);
v = <org.glassfish.grizzly.IOEvent: org.glassfish.grizzly.IOEvent WRITE>;
virtualinvoke v.<org.glassfish.grizzly.nio.NIOConnection: void simulateIOEvent(org.glassfish.grizzly.IOEvent)>(v);
goto label;
label:
virtualinvoke v.<org.glassfish.grizzly.asyncqueue.TaskQueue: void offer(org.glassfish.grizzly.asyncqueue.AsyncQueueRecord)>(v);
label:
virtualinvoke v.<org.glassfish.grizzly.Writer$Reentrant: boolean dec()>();
return;
label:
if v == 0 goto label;
v = v.<org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: boolean isAllowDirectWrite>;
if v == 0 goto label;
v = virtualinvoke v.<org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: org.glassfish.grizzly.asyncqueue.RecordWriteResult write0(org.glassfish.grizzly.nio.NIOConnection,org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord)>(v, v);
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.RecordWriteResult: long bytesToReleaseAfterLastWrite()>();
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: boolean isFinished()>();
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.TaskQueue: int releaseSpaceAndNotify(int)>(v);
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
v = v;
if v == 0 goto label;
v = newarray (java.lang.Object)[7];
v[0] = v;
v[1] = v;
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(boolean)>(v);
v[2] = v;
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: long remaining()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[3] = v;
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: boolean isUncountable()>();
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(boolean)>(v);
v[4] = v;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[5] = v;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[6] = v;
staticinvoke <org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: void doFineLog(java.lang.String,java.lang.Object[])>("AsyncQueueWriter.write directWrite connection={0}, record={1}, isFinished={2}, remaining={3}, isUncountable={4}, bytesToRelease={5}, pendingBytesAfterRelease={6}", v);
label:
if v == 0 goto label;
virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: void notifyCompleteAndRecycle()>();
if v != 0 goto label;
v = <org.glassfish.grizzly.IOEvent: org.glassfish.grizzly.IOEvent WRITE>;
virtualinvoke v.<org.glassfish.grizzly.nio.NIOConnection: void simulateIOEvent(org.glassfish.grizzly.IOEvent)>(v);
label:
virtualinvoke v.<org.glassfish.grizzly.Writer$Reentrant: boolean dec()>();
return;
label:
v = staticinvoke <org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: org.glassfish.grizzly.asyncqueue.WritableMessage cloneRecordIfNeeded(org.glassfish.grizzly.Connection,org.glassfish.grizzly.asyncqueue.MessageCloner,org.glassfish.grizzly.asyncqueue.WritableMessage)>(v, v, v);
virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: void setMessage(java.lang.Object)>(v);
if v == 0 goto label;
v = newarray (java.lang.Object)[4];
v[0] = v;
v[1] = v;
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: long remaining()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[2] = v;
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: boolean isUncountable()>();
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(boolean)>(v);
v[3] = v;
staticinvoke <org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: void doFineLog(java.lang.String,java.lang.Object[])>("AsyncQueueWriter.write queuing connection={0}, record={1}, size={2}, isUncountable={3}", v);
label:
if v == 0 goto label;
virtualinvoke v.<org.glassfish.grizzly.asyncqueue.TaskQueue: void setCurrentElement(org.glassfish.grizzly.asyncqueue.AsyncQueueRecord)>(v);
virtualinvoke v.<org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: void onReadyToWrite(org.glassfish.grizzly.nio.NIOConnection)>(v);
goto label;
label:
virtualinvoke v.<org.glassfish.grizzly.asyncqueue.TaskQueue: void offer(org.glassfish.grizzly.asyncqueue.AsyncQueueRecord)>(v);
label:
virtualinvoke v.<org.glassfish.grizzly.Writer$Reentrant: boolean dec()>();
goto label;
label:
v := @caughtexception;
if v == 0 goto label;
v = <org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: java.util.logging.Logger LOGGER>;
v = <java.util.logging.Level: java.util.logging.Level FINEST>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.glassfish.grizzly.nio.NIOConnection,org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord)>(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[])>("AsyncQueueWriter.write exception. connection=\u record=\u0001");
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Throwable)>(v, v, v);
label:
staticinvoke <org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: void onWriteFailure(org.glassfish.grizzly.Connection,org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord,java.lang.Throwable)>(v, v, v);
label:
virtualinvoke v.<org.glassfish.grizzly.Writer$Reentrant: boolean dec()>();
goto label;
label:
v := @caughtexception;
virtualinvoke v.<org.glassfish.grizzly.Writer$Reentrant: boolean dec()>();
throw v;
label:
return;
catch java.io.IOException from label to label with label;
catch java.io.IOException 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.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public org.glassfish.grizzly.asyncqueue.AsyncQueue$AsyncResult processAsync(org.glassfish.grizzly.Context)
{
org.glassfish.grizzly.asyncqueue.RecordWriteResult v;
java.lang.Integer v, v, v, v;
org.glassfish.grizzly.asyncqueue.TaskQueue v;
java.lang.Long v;
boolean v, v, v, v, v, v;
java.util.logging.Logger v, v;
org.glassfish.grizzly.ProcessorResult v;
org.glassfish.grizzly.Connection v;
org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord v, v;
java.lang.Object[] v, v, v, v, v;
long v, v;
java.util.logging.Level v, v;
int v, v, v, v, v;
java.lang.Boolean v, v, v;
java.lang.String v;
org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter v;
java.io.IOException v;
org.glassfish.grizzly.asyncqueue.AsyncQueue$AsyncResult v, v, v, v;
org.glassfish.grizzly.Context v;
v := @this: org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter;
v := @parameter: org.glassfish.grizzly.Context;
v = <org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: java.util.logging.Logger LOGGER>;
v = <java.util.logging.Level: java.util.logging.Level FINEST>;
v = virtualinvoke v.<java.util.logging.Logger: boolean isLoggable(java.util.logging.Level)>(v);
v = virtualinvoke v.<org.glassfish.grizzly.Context: org.glassfish.grizzly.Connection getConnection()>();
v = virtualinvoke v.<org.glassfish.grizzly.nio.NIOConnection: boolean isOpen()>();
if v != 0 goto label;
v = <org.glassfish.grizzly.asyncqueue.AsyncQueue$AsyncResult: org.glassfish.grizzly.asyncqueue.AsyncQueue$AsyncResult COMPLETE>;
return v;
label:
v = virtualinvoke v.<org.glassfish.grizzly.nio.NIOConnection: org.glassfish.grizzly.asyncqueue.TaskQueue getAsyncWriteQueue()>();
v = 0;
v = 1;
v = null;
label:
v = virtualinvoke v.<org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord aggregate(org.glassfish.grizzly.asyncqueue.TaskQueue)>(v);
v = v;
if v == null goto label;
if v == 0 goto label;
v = newarray (java.lang.Object)[2];
v[0] = v;
v[1] = v;
staticinvoke <org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: void doFineLog(java.lang.String,java.lang.Object[])>("AsyncQueueWriter.processAsync beforeWrite connection={0} record={1}", v);
label:
v = virtualinvoke v.<org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: org.glassfish.grizzly.asyncqueue.RecordWriteResult write0(org.glassfish.grizzly.nio.NIOConnection,org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord)>(v, v);
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.RecordWriteResult: long bytesToReleaseAfterLastWrite()>();
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: boolean isFinished()>();
v = v + v;
if v == 0 goto label;
v = newarray (java.lang.Object)[5];
v[0] = v;
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.RecordWriteResult: long lastWrittenBytes()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[1] = v;
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(boolean)>(v);
v[2] = v;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[3] = v;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[4] = v;
staticinvoke <org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: void doFineLog(java.lang.String,java.lang.Object[])>("AsyncQueueWriter.processAsync written connection={0}, written={1}, done={2}, bytesToRelease={3}, bytesReleased={4}", v);
label:
if v == 0 goto label;
staticinvoke <org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: void finishQueueRecord(org.glassfish.grizzly.nio.NIOConnection,org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord)>(v, v);
goto label;
label:
virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: void notifyIncomplete()>();
virtualinvoke v.<org.glassfish.grizzly.asyncqueue.TaskQueue: void setCurrentElement(org.glassfish.grizzly.asyncqueue.AsyncQueueRecord)>(v);
if v == 0 goto label;
v = newarray (java.lang.Object)[2];
v[0] = v;
v[1] = v;
staticinvoke <org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: void doFineLog(java.lang.String,java.lang.Object[])>("AsyncQueueWriter.processAsync onReadyToWrite connection={0} peekRecord={1}", v);
label:
v = 0;
if v <= 0 goto label;
if v == 0 goto label;
v = virtualinvoke v.<org.glassfish.grizzly.Context: boolean isManualIOEventControl()>();
if v != 0 goto label;
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.TaskQueue: int spaceInBytes()>();
v = v - v;
if v > 0 goto label;
if v == 0 goto label;
v = newarray (java.lang.Object)[1];
v[0] = v;
staticinvoke <org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: void doFineLog(java.lang.String,java.lang.Object[])>("AsyncQueueWriter.processAsync setManualIOEventControl connection={0}", v);
label:
virtualinvoke v.<org.glassfish.grizzly.Context: void setManualIOEventControl()>();
label:
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.TaskQueue: int releaseSpace(int)>(v);
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
v = v;
label:
if v == 0 goto label;
v = newarray (java.lang.Object)[5];
v[0] = v;
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(boolean)>(v);
v[1] = v;
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(boolean)>(v);
v[2] = v;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[3] = v;
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.TaskQueue: int size()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[4] = v;
staticinvoke <org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: void doFineLog(java.lang.String,java.lang.Object[])>("AsyncQueueWriter.processAsync exit connection={0}, done={1}, isComplete={2}, bytesReleased={3}, queueSize={4}", v);
label:
if v != 0 goto label;
v = <org.glassfish.grizzly.asyncqueue.AsyncQueue$AsyncResult: org.glassfish.grizzly.asyncqueue.AsyncQueue$AsyncResult INCOMPLETE>;
goto label;
label:
if v != 0 goto label;
v = <org.glassfish.grizzly.asyncqueue.AsyncQueue$AsyncResult: org.glassfish.grizzly.asyncqueue.AsyncQueue$AsyncResult EXPECTING_MORE>;
goto label;
label:
v = <org.glassfish.grizzly.asyncqueue.AsyncQueue$AsyncResult: org.glassfish.grizzly.asyncqueue.AsyncQueue$AsyncResult COMPLETE>;
label:
if v <= 0 goto label;
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncQueue$AsyncResult: org.glassfish.grizzly.ProcessorResult toProcessorResult()>();
virtualinvoke v.<org.glassfish.grizzly.Context: void complete(org.glassfish.grizzly.ProcessorResult)>(v);
virtualinvoke v.<org.glassfish.grizzly.asyncqueue.TaskQueue: void doNotify()>();
v = <org.glassfish.grizzly.asyncqueue.AsyncQueue$AsyncResult: org.glassfish.grizzly.asyncqueue.AsyncQueue$AsyncResult TERMINATE>;
label:
return v;
label:
return v;
label:
v := @caughtexception;
if v == 0 goto label;
v = <org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: java.util.logging.Logger LOGGER>;
v = <java.util.logging.Level: java.util.logging.Level FINEST>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.glassfish.grizzly.nio.NIOConnection,org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord)>(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[])>("AsyncQueueWriter.processAsync exception connection=\u peekRecord=\u0001");
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Throwable)>(v, v, v);
label:
staticinvoke <org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: void onWriteFailure(org.glassfish.grizzly.Connection,org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord,java.lang.Throwable)>(v, v, v);
v = <org.glassfish.grizzly.asyncqueue.AsyncQueue$AsyncResult: org.glassfish.grizzly.asyncqueue.AsyncQueue$AsyncResult COMPLETE>;
return v;
catch java.io.IOException from label to label with label;
}
private static void finishQueueRecord(org.glassfish.grizzly.nio.NIOConnection, org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord)
{
java.lang.Object[] v, v;
org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord v;
java.util.logging.Logger v;
org.glassfish.grizzly.nio.NIOConnection v;
boolean v;
java.util.logging.Level v;
v := @parameter: org.glassfish.grizzly.nio.NIOConnection;
v := @parameter: org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord;
v = <org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: java.util.logging.Logger LOGGER>;
v = <java.util.logging.Level: java.util.logging.Level FINEST>;
v = virtualinvoke v.<java.util.logging.Logger: boolean isLoggable(java.util.logging.Level)>(v);
if v == 0 goto label;
v = newarray (java.lang.Object)[2];
v[0] = v;
v[1] = v;
staticinvoke <org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: void doFineLog(java.lang.String,java.lang.Object[])>("AsyncQueueWriter.processAsync finished connection={0} record={1}", v);
label:
if v == null goto label;
virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: void notifyCompleteAndRecycle()>();
label:
if v == 0 goto label;
v = newarray (java.lang.Object)[2];
v[0] = v;
v[1] = v;
staticinvoke <org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: void doFineLog(java.lang.String,java.lang.Object[])>("AsyncQueueWriter.processAsync finishQueueRecord connection={0} queueRecord={1}", v);
label:
return;
}
private static org.glassfish.grizzly.asyncqueue.WritableMessage cloneRecordIfNeeded(org.glassfish.grizzly.Connection, org.glassfish.grizzly.asyncqueue.MessageCloner, org.glassfish.grizzly.asyncqueue.WritableMessage)
{
java.lang.Object[] v;
java.util.logging.Logger v, v;
java.lang.Integer v;
java.util.logging.Level v, v;
int v;
org.glassfish.grizzly.Connection v;
java.lang.Object v;
org.glassfish.grizzly.asyncqueue.MessageCloner v;
org.glassfish.grizzly.asyncqueue.WritableMessage v;
boolean v;
v := @parameter: org.glassfish.grizzly.Connection;
v := @parameter: org.glassfish.grizzly.asyncqueue.MessageCloner;
v := @parameter: org.glassfish.grizzly.asyncqueue.WritableMessage;
v = <org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: java.util.logging.Logger LOGGER>;
v = <java.util.logging.Level: java.util.logging.Level FINEST>;
v = virtualinvoke v.<java.util.logging.Logger: boolean isLoggable(java.util.logging.Level)>(v);
if v == 0 goto label;
v = <org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: java.util.logging.Logger LOGGER>;
v = <java.util.logging.Level: java.util.logging.Level FINEST>;
v = newarray (java.lang.Object)[3];
v[0] = v;
v[1] = v;
v = interfaceinvoke v.<org.glassfish.grizzly.asyncqueue.WritableMessage: int remaining()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[2] = v;
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Object[])>(v, "AsyncQueueWriter.write clone. connection={0} cloner={1} size={2}", v);
label:
if v == null goto label;
v = interfaceinvoke v.<org.glassfish.grizzly.asyncqueue.MessageCloner: java.lang.Object clone(org.glassfish.grizzly.Connection,java.lang.Object)>(v, v);
label:
return v;
}
protected org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord createRecord(org.glassfish.grizzly.Connection, org.glassfish.grizzly.asyncqueue.WritableMessage, org.glassfish.grizzly.CompletionHandler, java.net.SocketAddress, org.glassfish.grizzly.asyncqueue.PushBackHandler, boolean)
{
java.net.SocketAddress v;
org.glassfish.grizzly.asyncqueue.PushBackHandler v;
org.glassfish.grizzly.Connection v;
org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord v;
org.glassfish.grizzly.asyncqueue.WritableMessage v;
org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter v;
boolean v;
org.glassfish.grizzly.CompletionHandler v;
v := @this: org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter;
v := @parameter: org.glassfish.grizzly.Connection;
v := @parameter: org.glassfish.grizzly.asyncqueue.WritableMessage;
v := @parameter: org.glassfish.grizzly.CompletionHandler;
v := @parameter: java.net.SocketAddress;
v := @parameter: org.glassfish.grizzly.asyncqueue.PushBackHandler;
v := @parameter: boolean;
v = staticinvoke <org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord create(org.glassfish.grizzly.Connection,org.glassfish.grizzly.asyncqueue.WritableMessage,org.glassfish.grizzly.CompletionHandler,java.lang.Object,org.glassfish.grizzly.asyncqueue.PushBackHandler,boolean)>(v, v, v, v, v, v);
return v;
}
public final boolean isReady(org.glassfish.grizzly.Connection)
{
org.glassfish.grizzly.asyncqueue.TaskQueue v;
org.glassfish.grizzly.Connection v;
org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter v;
boolean v, v;
v := @this: org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter;
v := @parameter: org.glassfish.grizzly.Connection;
v = virtualinvoke v.<org.glassfish.grizzly.nio.NIOConnection: org.glassfish.grizzly.asyncqueue.TaskQueue getAsyncWriteQueue()>();
if v == null goto label;
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.TaskQueue: boolean isEmpty()>();
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
private static transient void doFineLog(java.lang.String, java.lang.Object[])
{
java.lang.Object[] v;
java.lang.String v;
java.util.logging.Logger v;
java.util.logging.Level v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.Object[];
v = <org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: java.util.logging.Logger LOGGER>;
v = <java.util.logging.Level: java.util.logging.Level FINEST>;
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Object[])>(v, v, v);
return;
}
public void onClose(org.glassfish.grizzly.Connection)
{
org.glassfish.grizzly.asyncqueue.TaskQueue v;
org.glassfish.grizzly.Connection v;
java.io.IOException v;
org.glassfish.grizzly.CloseReason v;
org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter v;
v := @this: org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter;
v := @parameter: org.glassfish.grizzly.Connection;
v = virtualinvoke v.<org.glassfish.grizzly.nio.NIOConnection: org.glassfish.grizzly.asyncqueue.TaskQueue getAsyncWriteQueue()>();
v = virtualinvoke v.<org.glassfish.grizzly.nio.NIOConnection: org.glassfish.grizzly.CloseReason getCloseReason()>();
v = virtualinvoke v.<org.glassfish.grizzly.CloseReason: java.io.IOException getCause()>();
virtualinvoke v.<org.glassfish.grizzly.asyncqueue.TaskQueue: void onClose(java.lang.Throwable)>(v);
return;
}
public final void close()
{
org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter v;
v := @this: org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter;
return;
}
protected static void onWriteFailure(org.glassfish.grizzly.Connection, org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord, java.lang.Throwable)
{
java.lang.Throwable v;
org.glassfish.grizzly.Connection v;
org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord v;
v := @parameter: org.glassfish.grizzly.Connection;
v := @parameter: org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord;
v := @parameter: java.lang.Throwable;
virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: void notifyFailure(java.lang.Throwable)>(v);
interfaceinvoke v.<org.glassfish.grizzly.Connection: void closeSilently()>();
return;
}
protected abstract org.glassfish.grizzly.asyncqueue.RecordWriteResult write0(org.glassfish.grizzly.nio.NIOConnection, org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord) throws java.io.IOException;
protected abstract void onReadyToWrite(org.glassfish.grizzly.nio.NIOConnection) throws java.io.IOException;
protected org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord aggregate(org.glassfish.grizzly.asyncqueue.TaskQueue)
{
org.glassfish.grizzly.asyncqueue.TaskQueue v;
org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter v;
org.glassfish.grizzly.asyncqueue.AsyncQueueRecord v;
v := @this: org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter;
v := @parameter: org.glassfish.grizzly.asyncqueue.TaskQueue;
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.TaskQueue: org.glassfish.grizzly.asyncqueue.AsyncQueueRecord poll()>();
return v;
}
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/AbstractNIOAsyncQueueWriter;");
<org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: java.util.logging.Logger LOGGER> = v;
return;
}
}