public final class org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter extends org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter
{
private static final java.util.logging.Logger LOGGER;
private static final org.glassfish.grizzly.attributes.Attribute COMPOSITE_BUFFER_ATTR;
static final boolean $assertionsDisabled;
public void <init>(org.glassfish.grizzly.nio.NIOTransport)
{
org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter v;
org.glassfish.grizzly.nio.NIOTransport v;
v := @this: org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter;
v := @parameter: org.glassfish.grizzly.nio.NIOTransport;
specialinvoke v.<org.glassfish.grizzly.nio.AbstractNIOAsyncQueueWriter: void <init>(org.glassfish.grizzly.nio.NIOTransport)>(v);
return;
}
protected org.glassfish.grizzly.asyncqueue.RecordWriteResult write0(org.glassfish.grizzly.nio.NIOConnection, org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord) throws java.io.IOException
{
org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter v;
org.glassfish.grizzly.asyncqueue.RecordWriteResult v, v, v, v;
long v, v, v;
byte v;
org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord v;
org.glassfish.grizzly.nio.NIOConnection v;
org.glassfish.grizzly.asyncqueue.WritableMessage v;
boolean v, v;
v := @this: org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter;
v := @parameter: org.glassfish.grizzly.nio.NIOConnection;
v := @parameter: org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord;
v = v instanceof org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord;
if v == 0 goto label;
v = specialinvoke v.<org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter: org.glassfish.grizzly.asyncqueue.RecordWriteResult writeCompositeRecord(org.glassfish.grizzly.nio.NIOConnection,org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord)>(v, v);
return v;
label:
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: org.glassfish.grizzly.asyncqueue.RecordWriteResult getCurrentResult()>();
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: long remaining()>();
v = v cmp 0L;
if v != 0 goto label;
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: boolean isUncountable()>();
if v == 0 goto label;
v = 1L;
goto label;
label:
v = 0L;
label:
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.RecordWriteResult: org.glassfish.grizzly.asyncqueue.RecordWriteResult lastWriteResult(long,long)>(0L, v);
return v;
label:
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: org.glassfish.grizzly.asyncqueue.WritableMessage getWritableMessage()>();
v = virtualinvoke v.<org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter: long write0(org.glassfish.grizzly.nio.NIOConnection,org.glassfish.grizzly.asyncqueue.WritableMessage,org.glassfish.grizzly.WriteResult)>(v, v, v);
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.RecordWriteResult: org.glassfish.grizzly.asyncqueue.RecordWriteResult lastWriteResult(long,long)>(v, v);
return v;
}
protected long write0(org.glassfish.grizzly.nio.NIOConnection, org.glassfish.grizzly.asyncqueue.WritableMessage, org.glassfish.grizzly.WriteResult) throws java.io.IOException
{
java.lang.IllegalStateException v;
org.glassfish.grizzly.WriteResult v;
org.glassfish.grizzly.utils.Holder v;
long v, v;
org.glassfish.grizzly.CloseType v;
int v;
org.glassfish.grizzly.asyncqueue.WritableMessage v;
boolean v, v, v, v;
org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter v;
org.glassfish.grizzly.Buffer v;
java.io.IOException v;
java.nio.channels.SelectableChannel v;
org.glassfish.grizzly.CloseReason v;
org.glassfish.grizzly.nio.NIOConnection v;
v := @this: org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter;
v := @parameter: org.glassfish.grizzly.nio.NIOConnection;
v := @parameter: org.glassfish.grizzly.asyncqueue.WritableMessage;
v := @parameter: org.glassfish.grizzly.WriteResult;
v = v instanceof org.glassfish.grizzly.Buffer;
if v == 0 goto label;
label:
v = interfaceinvoke v.<org.glassfish.grizzly.Buffer: boolean hasRemaining()>();
if v == 0 goto label;
v = interfaceinvoke v.<org.glassfish.grizzly.Buffer: boolean isComposite()>();
if v != 0 goto label;
v = staticinvoke <org.glassfish.grizzly.nio.transport.TCPNIOUtils: int writeSimpleBuffer(org.glassfish.grizzly.nio.transport.TCPNIOConnection,org.glassfish.grizzly.Buffer)>(v, v);
goto label;
label:
staticinvoke <org.glassfish.grizzly.nio.transport.TCPNIOUtils: int writeCompositeBuffer(org.glassfish.grizzly.nio.transport.TCPNIOConnection,org.glassfish.grizzly.memory.CompositeBuffer)>(v, v);
label:
virtualinvoke v.<org.glassfish.grizzly.nio.transport.TCPNIOConnection: void onWrite(org.glassfish.grizzly.Buffer,long)>(v, v);
label:
goto label;
label:
v := @caughtexception;
v = new org.glassfish.grizzly.CloseReason;
v = <org.glassfish.grizzly.CloseType: org.glassfish.grizzly.CloseType REMOTELY>;
specialinvoke v.<org.glassfish.grizzly.CloseReason: void <init>(org.glassfish.grizzly.CloseType,java.io.IOException)>(v, v);
virtualinvoke v.<org.glassfish.grizzly.nio.transport.TCPNIOConnection: void terminate0(org.glassfish.grizzly.CompletionHandler,org.glassfish.grizzly.CloseReason)>(null, v);
throw v;
label:
v = v instanceof org.glassfish.grizzly.FileChunk;
if v == 0 goto label;
v = virtualinvoke v.<org.glassfish.grizzly.nio.NIOConnection: java.nio.channels.SelectableChannel getChannel()>();
v = interfaceinvoke v.<org.glassfish.grizzly.FileChunk: long writeTo(java.nio.channels.WritableByteChannel)>(v);
virtualinvoke v.<org.glassfish.grizzly.nio.transport.TCPNIOConnection: void onWrite(org.glassfish.grizzly.Buffer,long)>(null, v);
goto label;
label:
v = new java.lang.IllegalStateException;
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>("Unhandled message type");
throw v;
label:
if v == null goto label;
virtualinvoke v.<org.glassfish.grizzly.WriteResult: void setMessage(java.lang.Object)>(v);
v = virtualinvoke v.<org.glassfish.grizzly.WriteResult: long getWrittenSize()>();
v = v + v;
virtualinvoke v.<org.glassfish.grizzly.WriteResult: void setWrittenSize(long)>(v);
v = v.<org.glassfish.grizzly.nio.transport.TCPNIOConnection: org.glassfish.grizzly.utils.Holder peerSocketAddressHolder>;
virtualinvoke v.<org.glassfish.grizzly.WriteResult: void setDstAddressHolder(org.glassfish.grizzly.utils.Holder)>(v);
label:
return v;
catch java.io.IOException from label to label with label;
}
private org.glassfish.grizzly.asyncqueue.RecordWriteResult writeCompositeRecord(org.glassfish.grizzly.nio.NIOConnection, org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord) throws java.io.IOException
{
org.glassfish.grizzly.asyncqueue.RecordWriteResult v;
java.lang.Integer v;
java.nio.ByteBuffer v;
java.lang.Long v;
org.glassfish.grizzly.CloseType v;
boolean v;
java.nio.ByteBuffer[] v, v;
org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter v;
java.util.logging.Logger v, v;
org.glassfish.grizzly.nio.NIOConnection v;
java.lang.Throwable v;
java.lang.Object[] v;
long v;
java.util.Deque v;
java.util.logging.Level v, v;
int v, v, v, v, v, v, v, v, v, v;
org.glassfish.grizzly.nio.DirectByteBufferRecord v;
java.io.IOException v;
java.nio.channels.SelectableChannel v;
org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord v;
org.glassfish.grizzly.CloseReason v;
v := @this: org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter;
v := @parameter: org.glassfish.grizzly.nio.NIOConnection;
v := @parameter: org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord;
v = 0;
v = <org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter: 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.transport.TCPNIOAsyncQueueWriter: java.util.logging.Logger LOGGER>;
v = <java.util.logging.Level: java.util.logging.Level FINEST>;
v = newarray (java.lang.Object)[4];
v[0] = v;
v[1] = v;
v = virtualinvoke v.<org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord: long remaining()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[2] = v;
v = v.<org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord: java.util.Deque queue>;
v = interfaceinvoke v.<java.util.Deque: int size()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[3] = v;
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Object[])>(v, "writeCompositeRecord connection={0}, queueRecord={1}, queueRecord.remaining={2}, queueRecord.queue.size()={3}", v);
label:
v = v.<org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord: int size>;
if v <= 0 goto label;
v = v.<org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord: int size>;
v = virtualinvoke v.<org.glassfish.grizzly.nio.NIOConnection: int getWriteBufferSize()>();
v = v * 3;
v = v / 2;
v = staticinvoke <java.lang.Math: int min(int,int)>(v, v);
v = staticinvoke <org.glassfish.grizzly.nio.DirectByteBufferRecord: org.glassfish.grizzly.nio.DirectByteBufferRecord get()>();
label:
v = virtualinvoke v.<org.glassfish.grizzly.nio.NIOConnection: java.nio.channels.SelectableChannel getChannel()>();
staticinvoke <org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter: void fill(org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord,int,org.glassfish.grizzly.nio.DirectByteBufferRecord)>(v, v, v);
virtualinvoke v.<org.glassfish.grizzly.nio.DirectByteBufferRecord: void finishBufferSlice()>();
v = virtualinvoke v.<org.glassfish.grizzly.nio.DirectByteBufferRecord: int getArraySize()>();
if v != 1 goto label;
v = virtualinvoke v.<org.glassfish.grizzly.nio.DirectByteBufferRecord: java.nio.ByteBuffer[] getArray()>();
v = v[0];
v = staticinvoke <org.glassfish.grizzly.nio.transport.TCPNIOUtils: int flushByteBuffer(java.nio.channels.SocketChannel,java.nio.ByteBuffer)>(v, v);
goto label;
label:
v = virtualinvoke v.<org.glassfish.grizzly.nio.DirectByteBufferRecord: java.nio.ByteBuffer[] getArray()>();
v = staticinvoke <org.glassfish.grizzly.nio.transport.TCPNIOUtils: int flushByteBuffers(java.nio.channels.SocketChannel,java.nio.ByteBuffer[],int,int)>(v, v, 0, v);
label:
v = v;
label:
virtualinvoke v.<org.glassfish.grizzly.nio.DirectByteBufferRecord: void release()>();
goto label;
label:
v := @caughtexception;
v = new org.glassfish.grizzly.CloseReason;
v = <org.glassfish.grizzly.CloseType: org.glassfish.grizzly.CloseType REMOTELY>;
specialinvoke v.<org.glassfish.grizzly.CloseReason: void <init>(org.glassfish.grizzly.CloseType,java.io.IOException)>(v, v);
virtualinvoke v.<org.glassfish.grizzly.nio.transport.TCPNIOConnection: void terminate0(org.glassfish.grizzly.CompletionHandler,org.glassfish.grizzly.CloseReason)>(null, v);
throw v;
label:
v := @caughtexception;
virtualinvoke v.<org.glassfish.grizzly.nio.DirectByteBufferRecord: void release()>();
throw v;
label:
v = specialinvoke v.<org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter: org.glassfish.grizzly.asyncqueue.RecordWriteResult update(org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord,int)>(v, v);
return v;
catch java.io.IOException from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private static void fill(org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord, int, org.glassfish.grizzly.nio.DirectByteBufferRecord)
{
java.util.Iterator v;
org.glassfish.grizzly.nio.DirectByteBufferRecord v;
java.util.Deque v;
java.util.ArrayList v;
org.glassfish.grizzly.memory.BufferArray v;
org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord v;
int v, v, v, v, v;
java.lang.Object v, v;
boolean v, v;
v := @parameter: org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord;
v := @parameter: int;
v := @parameter: org.glassfish.grizzly.nio.DirectByteBufferRecord;
v = v;
v = v.<org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord: java.util.Deque queue>;
v = v.<org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord: java.util.ArrayList savedBufferStates>;
v = interfaceinvoke v.<java.util.Deque: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
if v <= 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: boolean isUncountable()>();
if v != 0 goto label;
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: java.lang.Object getMessage()>();
v = interfaceinvoke v.<org.glassfish.grizzly.Buffer: int position()>();
v = interfaceinvoke v.<org.glassfish.grizzly.Buffer: int remaining()>();
if v < v goto label;
v = interfaceinvoke v.<org.glassfish.grizzly.Buffer: org.glassfish.grizzly.memory.BufferArray toBufferArray()>();
goto label;
label:
v = v + v;
v = interfaceinvoke v.<org.glassfish.grizzly.Buffer: org.glassfish.grizzly.memory.BufferArray toBufferArray(int,int)>(v, v);
label:
virtualinvoke v.<java.util.ArrayList: boolean add(java.lang.Object)>(v);
staticinvoke <org.glassfish.grizzly.nio.transport.TCPNIOUtils: void fill(org.glassfish.grizzly.memory.BufferArray,int,org.glassfish.grizzly.nio.DirectByteBufferRecord)>(v, v, v);
v = v - v;
goto label;
label:
return;
}
private org.glassfish.grizzly.asyncqueue.RecordWriteResult update(org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord, int)
{
org.glassfish.grizzly.asyncqueue.RecordWriteResult v, v, v, v, v;
byte v;
boolean v, v, v;
org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter v;
org.glassfish.grizzly.Connection v;
long v, v, v, v, v, v, v;
java.lang.AssertionError v;
java.util.Deque v;
java.util.ArrayList v, v, v;
int v, v, v, v, v, v, v, v, v, v, v;
org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord v;
java.lang.Object v, v, v, v;
v := @this: org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter;
v := @parameter: org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord;
v := @parameter: int;
v = 0;
label:
v = v.<org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord: java.util.ArrayList savedBufferStates>;
v = virtualinvoke v.<java.util.ArrayList: int size()>();
if v >= v goto label;
v = v.<org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord: java.util.ArrayList savedBufferStates>;
v = virtualinvoke v.<java.util.ArrayList: java.lang.Object get(int)>(v);
if v == null goto label;
virtualinvoke v.<org.glassfish.grizzly.memory.BufferArray: void restore()>();
virtualinvoke v.<org.glassfish.grizzly.memory.BufferArray: void recycle()>();
label:
v = v + 1;
goto label;
label:
v = 0;
v = v.<org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord: java.util.ArrayList savedBufferStates>;
virtualinvoke v.<java.util.ArrayList: void clear()>();
v = v.<org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord: int size>;
v = v - v;
v.<org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord: int size> = v;
v = virtualinvoke v.<org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord: org.glassfish.grizzly.Connection getConnection()>();
v = v.<org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord: java.util.Deque queue>;
label:
if v <= 0 goto label;
v = interfaceinvoke v.<java.util.Deque: java.lang.Object peekFirst()>();
v = <org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter: boolean $assertionsDisabled>;
if v != 0 goto label;
if v != null goto label;
v = new java.lang.AssertionError;
specialinvoke v.<java.lang.AssertionError: void <init>()>();
throw v;
label:
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: boolean isUncountable()>();
if v == 0 goto label;
interfaceinvoke v.<java.util.Deque: java.lang.Object removeFirst()>();
virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: void notifyCompleteAndRecycle()>();
v = v + 1;
goto label;
label:
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: org.glassfish.grizzly.asyncqueue.RecordWriteResult getCurrentResult()>();
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: java.lang.Object getMessage()>();
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: long getInitialMessageSize()>();
v = virtualinvoke v.<org.glassfish.grizzly.WriteResult: long getWrittenSize()>();
v = v - v;
v = v cmp v;
if v < 0 goto label;
v = v - v;
interfaceinvoke v.<java.util.Deque: java.lang.Object removeFirst()>();
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: long getInitialMessageSize()>();
virtualinvoke v.<org.glassfish.grizzly.WriteResult: void setWrittenSize(long)>(v);
v = interfaceinvoke v.<org.glassfish.grizzly.Buffer: int limit()>();
interfaceinvoke v.<org.glassfish.grizzly.Buffer: org.glassfish.grizzly.Buffer position(int)>(v);
virtualinvoke v.<org.glassfish.grizzly.nio.transport.TCPNIOConnection: void onWrite(org.glassfish.grizzly.Buffer,long)>(v, v);
virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: void notifyCompleteAndRecycle()>();
goto label;
label:
v = interfaceinvoke v.<org.glassfish.grizzly.Buffer: int position()>();
v = v + v;
interfaceinvoke v.<org.glassfish.grizzly.Buffer: org.glassfish.grizzly.Buffer position(int)>(v);
v = virtualinvoke v.<org.glassfish.grizzly.WriteResult: long getWrittenSize()>();
v = v + v;
virtualinvoke v.<org.glassfish.grizzly.WriteResult: void setWrittenSize(long)>(v);
virtualinvoke v.<org.glassfish.grizzly.nio.transport.TCPNIOConnection: void onWrite(org.glassfish.grizzly.Buffer,long)>(v, v);
v = virtualinvoke v.<org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord: org.glassfish.grizzly.asyncqueue.RecordWriteResult getCurrentResult()>();
v = v + v;
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.RecordWriteResult: org.glassfish.grizzly.asyncqueue.RecordWriteResult lastWriteResult(long,long)>(v, v);
return v;
label:
v = interfaceinvoke v.<java.util.Deque: java.lang.Object peekFirst()>();
if v == null goto label;
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: boolean isUncountable()>();
if v == 0 goto label;
interfaceinvoke v.<java.util.Deque: java.lang.Object removeFirst()>();
virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: void notifyCompleteAndRecycle()>();
v = v + 1;
goto label;
label:
v = virtualinvoke v.<org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord: org.glassfish.grizzly.asyncqueue.RecordWriteResult getCurrentResult()>();
v = v + v;
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.RecordWriteResult: org.glassfish.grizzly.asyncqueue.RecordWriteResult lastWriteResult(long,long)>(v, v);
return v;
}
protected void onReadyToWrite(org.glassfish.grizzly.nio.NIOConnection) throws java.io.IOException
{
org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter v;
org.glassfish.grizzly.nio.NIOConnection v;
org.glassfish.grizzly.IOEvent v;
v := @this: org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter;
v := @parameter: org.glassfish.grizzly.nio.NIOConnection;
v = <org.glassfish.grizzly.IOEvent: org.glassfish.grizzly.IOEvent WRITE>;
virtualinvoke v.<org.glassfish.grizzly.nio.NIOConnection: void enableIOEvent(org.glassfish.grizzly.IOEvent)>(v);
return;
}
protected org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord aggregate(org.glassfish.grizzly.asyncqueue.TaskQueue)
{
org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter v;
long v, v;
org.glassfish.grizzly.asyncqueue.AsyncQueueRecord v;
org.glassfish.grizzly.asyncqueue.TaskQueue v;
byte v, v;
org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord v;
int v;
org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord v, v;
boolean v;
v := @this: org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter;
v := @parameter: org.glassfish.grizzly.asyncqueue.TaskQueue;
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.TaskQueue: int size()>();
if v != 0 goto label;
return null;
label:
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.TaskQueue: org.glassfish.grizzly.asyncqueue.AsyncQueueRecord poll()>();
if v == null goto label;
v = staticinvoke <org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter: boolean canBeAggregated(org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord)>(v);
if v == 0 goto label;
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: long remaining()>();
v = v cmp v;
if v != 0 goto label;
label:
return v;
label:
v = staticinvoke <org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter: org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord checkAndGetNextRecord(org.glassfish.grizzly.asyncqueue.TaskQueue)>(v);
if v != null goto label;
return v;
label:
v = specialinvoke v.<org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter: org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord createCompositeQueueRecord(org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord)>(v);
label:
virtualinvoke v.<org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord: void append(org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord)>(v);
v = virtualinvoke v.<org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord: long remaining()>();
v = v cmp v;
if v >= 0 goto label;
v = staticinvoke <org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter: org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord checkAndGetNextRecord(org.glassfish.grizzly.asyncqueue.TaskQueue)>(v);
v = v;
if v != null goto label;
label:
return v;
}
private static org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord checkAndGetNextRecord(org.glassfish.grizzly.asyncqueue.TaskQueue)
{
org.glassfish.grizzly.asyncqueue.TaskQueue v;
java.lang.Object v;
java.util.Queue v;
boolean v;
v := @parameter: org.glassfish.grizzly.asyncqueue.TaskQueue;
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.TaskQueue: java.util.Queue getQueue()>();
v = interfaceinvoke v.<java.util.Queue: java.lang.Object poll()>();
if v != null goto label;
return null;
label:
v = staticinvoke <org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter: boolean canBeAggregated(org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord)>(v);
if v != 0 goto label;
virtualinvoke v.<org.glassfish.grizzly.asyncqueue.TaskQueue: void setCurrentElement(org.glassfish.grizzly.asyncqueue.AsyncQueueRecord)>(v);
return null;
label:
return v;
}
private static boolean canBeAggregated(org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord)
{
org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord v;
boolean v;
v := @parameter: org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord;
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: boolean canBeAggregated()>();
return v;
}
private org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord createCompositeQueueRecord(org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord)
{
org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter v;
org.glassfish.grizzly.attributes.Attribute v, v;
org.glassfish.grizzly.Connection v;
org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord v;
java.lang.Object v;
boolean v;
v := @this: org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter;
v := @parameter: org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord;
v = v instanceof org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord;
if v != 0 goto label;
v = virtualinvoke v.<org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord: org.glassfish.grizzly.Connection getConnection()>();
v = <org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter: org.glassfish.grizzly.attributes.Attribute COMPOSITE_BUFFER_ATTR>;
v = virtualinvoke v.<org.glassfish.grizzly.attributes.Attribute: java.lang.Object get(org.glassfish.grizzly.attributes.AttributeStorage)>(v);
if v != null goto label;
v = staticinvoke <org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord: org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord create(org.glassfish.grizzly.Connection)>(v);
v = <org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter: org.glassfish.grizzly.attributes.Attribute COMPOSITE_BUFFER_ATTR>;
virtualinvoke v.<org.glassfish.grizzly.attributes.Attribute: void set(org.glassfish.grizzly.attributes.AttributeStorage,java.lang.Object)>(v, v);
label:
virtualinvoke v.<org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter$CompositeQueueRecord: void append(org.glassfish.grizzly.asyncqueue.AsyncWriteQueueRecord)>(v);
return v;
label:
return v;
}
static void <clinit>()
{
org.glassfish.grizzly.attributes.Attribute v;
java.util.logging.Logger v;
org.glassfish.grizzly.attributes.AttributeBuilder v;
java.lang.Class v, v;
java.lang.String v, v;
boolean v, v;
v = class "Lorg/glassfish/grizzly/nio/transport/TCPNIOAsyncQueueWriter;";
v = virtualinvoke v.<java.lang.Class: boolean desiredAssertionStatus()>();
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
<org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter: boolean $assertionsDisabled> = v;
v = staticinvoke <org.glassfish.grizzly.Grizzly: java.util.logging.Logger logger(java.lang.Class)>(class "Lorg/glassfish/grizzly/nio/transport/TCPNIOAsyncQueueWriter;");
<org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter: java.util.logging.Logger LOGGER> = v;
v = <org.glassfish.grizzly.Grizzly: org.glassfish.grizzly.attributes.AttributeBuilder DEFAULT_ATTRIBUTE_BUILDER>;
v = class "Lorg/glassfish/grizzly/nio/transport/TCPNIOAsyncQueueWriter;";
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
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[])>("\u.compositeBuffer");
v = interfaceinvoke v.<org.glassfish.grizzly.attributes.AttributeBuilder: org.glassfish.grizzly.attributes.Attribute createAttribute(java.lang.String)>(v);
<org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueWriter: org.glassfish.grizzly.attributes.Attribute COMPOSITE_BUFFER_ATTR> = v;
return;
}
}