jetty-9 lots of renaming
This commit is contained in:
parent
f6643ccbe7
commit
3f80ec2bc2
|
@ -14,8 +14,8 @@ import org.eclipse.jetty.util.log.Logger;
|
|||
/** A convenience base implementation of {@link AsyncConnection}.
|
||||
* <p>
|
||||
* This class uses the capabilities of the {@link AsyncEndPoint} API to provide a
|
||||
* more traditional style of async reading. A call to {@link #readInterested()}
|
||||
* will schedule a callback to {@link #onReadable()} or {@link #onReadFail(Throwable)}
|
||||
* more traditional style of async reading. A call to {@link #fillInterested()}
|
||||
* will schedule a callback to {@link #onFillable()} or {@link #onReadFail(Throwable)}
|
||||
* as appropriate.
|
||||
*/
|
||||
public abstract class AbstractAsyncConnection implements AsyncConnection
|
||||
|
@ -44,7 +44,7 @@ public abstract class AbstractAsyncConnection implements AsyncConnection
|
|||
protected void onCompleted(Void context)
|
||||
{
|
||||
if (_readInterested.compareAndSet(true,false))
|
||||
onReadable();
|
||||
onFillable();
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -71,17 +71,19 @@ public abstract class AbstractAsyncConnection implements AsyncConnection
|
|||
|
||||
/* ------------------------------------------------------------ */
|
||||
/** Call to register read interest.
|
||||
* After this call, {@link #onReadable()} or {@link #onReadFail(Throwable)}
|
||||
* After this call, {@link #onFillable()} or {@link #onReadFail(Throwable)}
|
||||
* will be called back as appropriate.
|
||||
*/
|
||||
public void readInterested()
|
||||
public void fillInterested()
|
||||
{
|
||||
if (_readInterested.compareAndSet(false,true))
|
||||
getEndPoint().readable(null,_readCallback);
|
||||
getEndPoint().fillInterested(null,_readCallback);
|
||||
}
|
||||
|
||||
/* ------------------------------------------------------------ */
|
||||
public abstract void onReadable();
|
||||
/** Callback when the endpoint is fillable.
|
||||
*/
|
||||
public abstract void onFillable();
|
||||
|
||||
/* ------------------------------------------------------------ */
|
||||
public void onReadFail(Throwable cause)
|
||||
|
|
|
@ -95,7 +95,7 @@ public class AsyncByteArrayEndPoint extends ByteArrayEndPoint implements AsyncEn
|
|||
}
|
||||
|
||||
@Override
|
||||
public <C> void readable(C context, Callback<C> callback) throws IllegalStateException
|
||||
public <C> void fillInterested(C context, Callback<C> callback) throws IllegalStateException
|
||||
{
|
||||
_readInterest.register(context,callback);
|
||||
}
|
||||
|
|
|
@ -24,14 +24,14 @@ import org.eclipse.jetty.util.FutureCallback;
|
|||
* from:
|
||||
* <blockquote><pre>
|
||||
* FutureCallback<String> future = new FutureCallback<>();
|
||||
* endpoint.readable("ContextObj",future);
|
||||
* endpoint.fillInterested("ContextObj",future);
|
||||
* ...
|
||||
* String context = future.get(); // This blocks
|
||||
* int filled=endpoint.fill(mybuffer);</pre></blockquote>
|
||||
* <h3>Dispatched Read</h3>
|
||||
* By using a different callback, the read can be done asynchronously in its own dispatched thread:
|
||||
* <blockquote><pre>
|
||||
* endpoint.readable("ContextObj",new ExecutorCallback<String>(executor)
|
||||
* endpoint.fillInterested("ContextObj",new ExecutorCallback<String>(executor)
|
||||
* {
|
||||
* public void onCompleted(String context)
|
||||
* {
|
||||
|
@ -71,14 +71,14 @@ import org.eclipse.jetty.util.FutureCallback;
|
|||
public interface AsyncEndPoint extends EndPoint
|
||||
{
|
||||
/* ------------------------------------------------------------ */
|
||||
/** Asynchronous a readable notification.
|
||||
/** Asynchronous a fillable notification.
|
||||
* <p>
|
||||
* This method schedules a callback operations when a call to {@link #fill(ByteBuffer)} will return data or EOF.
|
||||
* @param context Context to return via the callback
|
||||
* @param callback The callback to call when an error occurs or we are readable.
|
||||
* @throws ReadPendingException if another read operation is concurrent.
|
||||
*/
|
||||
<C> void readable(C context, Callback<C> callback) throws ReadPendingException;
|
||||
<C> void fillInterested(C context, Callback<C> callback) throws ReadPendingException;
|
||||
|
||||
/* ------------------------------------------------------------ */
|
||||
/** Asynchronous write operation.
|
||||
|
|
|
@ -10,7 +10,7 @@ import org.eclipse.jetty.util.Callback;
|
|||
|
||||
/* ------------------------------------------------------------ */
|
||||
/**
|
||||
* A Utility class to help implement {@link AsyncEndPoint#readable(Object, Callback)}
|
||||
* A Utility class to help implement {@link AsyncEndPoint#fillInterested(Object, Callback)}
|
||||
* by keeping state and calling the context and callback objects.
|
||||
*
|
||||
*/
|
||||
|
|
|
@ -87,7 +87,7 @@ public class SelectChannelEndPoint extends ChannelEndPoint implements Runnable,
|
|||
|
||||
/* ------------------------------------------------------------ */
|
||||
@Override
|
||||
public <C> void readable(C context, Callback<C> callback) throws IllegalStateException
|
||||
public <C> void fillInterested(C context, Callback<C> callback) throws IllegalStateException
|
||||
{
|
||||
_readInterest.register(context,callback);
|
||||
}
|
||||
|
|
|
@ -124,7 +124,7 @@ public class SslConnection extends AbstractAsyncConnection
|
|||
|
||||
/* ------------------------------------------------------------ */
|
||||
@Override
|
||||
public void onReadable()
|
||||
public void onFillable()
|
||||
{
|
||||
LOG.debug("{} onReadable",this);
|
||||
|
||||
|
@ -262,7 +262,7 @@ public class SslConnection extends AbstractAsyncConnection
|
|||
}
|
||||
else
|
||||
// Normal readable callback
|
||||
readInterested();
|
||||
SslConnection.this.fillInterested();
|
||||
|
||||
return false;
|
||||
}
|
||||
|
@ -285,7 +285,7 @@ public class SslConnection extends AbstractAsyncConnection
|
|||
}
|
||||
else if (_sslEngine.getHandshakeStatus()==HandshakeStatus.NEED_UNWRAP )
|
||||
// we are actually read blocked in order to write
|
||||
readInterested();
|
||||
SslConnection.this.fillInterested();
|
||||
else
|
||||
{
|
||||
// try the flush again
|
||||
|
@ -307,7 +307,7 @@ public class SslConnection extends AbstractAsyncConnection
|
|||
}
|
||||
|
||||
@Override
|
||||
public <C> void readable(C context, Callback<C> callback) throws IllegalStateException
|
||||
public <C> void fillInterested(C context, Callback<C> callback) throws IllegalStateException
|
||||
{
|
||||
_readInterest.register(context,callback);
|
||||
}
|
||||
|
|
|
@ -30,14 +30,14 @@ public class AsyncByteArrayEndPointTest
|
|||
ByteBuffer buffer = BufferUtil.allocate(1024);
|
||||
FutureCallback<String> fcb = new FutureCallback<>();
|
||||
|
||||
endp.readable("CTX",fcb);
|
||||
endp.fillInterested("CTX",fcb);
|
||||
assertTrue(fcb.isDone());
|
||||
assertEquals("CTX",fcb.get());
|
||||
assertEquals(10,endp.fill(buffer));
|
||||
assertEquals("test input",BufferUtil.toString(buffer));
|
||||
|
||||
fcb = new FutureCallback<>();
|
||||
endp.readable("CTX",fcb);
|
||||
endp.fillInterested("CTX",fcb);
|
||||
assertFalse(fcb.isDone());
|
||||
assertEquals(0,endp.fill(buffer));
|
||||
|
||||
|
@ -48,7 +48,7 @@ public class AsyncByteArrayEndPointTest
|
|||
assertEquals("test input more",BufferUtil.toString(buffer));
|
||||
|
||||
fcb = new FutureCallback<>();
|
||||
endp.readable("CTX",fcb);
|
||||
endp.fillInterested("CTX",fcb);
|
||||
assertFalse(fcb.isDone());
|
||||
assertEquals(0,endp.fill(buffer));
|
||||
|
||||
|
@ -58,7 +58,7 @@ public class AsyncByteArrayEndPointTest
|
|||
assertEquals(-1,endp.fill(buffer));
|
||||
|
||||
fcb = new FutureCallback<>();
|
||||
endp.readable("CTX",fcb);
|
||||
endp.fillInterested("CTX",fcb);
|
||||
assertTrue(fcb.isDone());
|
||||
assertEquals("CTX",fcb.get());
|
||||
assertEquals(-1,endp.fill(buffer));
|
||||
|
@ -66,7 +66,7 @@ public class AsyncByteArrayEndPointTest
|
|||
endp.close();
|
||||
|
||||
fcb = new FutureCallback<>();
|
||||
endp.readable("CTX",fcb);
|
||||
endp.fillInterested("CTX",fcb);
|
||||
assertTrue(fcb.isDone());
|
||||
try
|
||||
{
|
||||
|
@ -126,7 +126,7 @@ public class AsyncByteArrayEndPointTest
|
|||
ByteBuffer buffer = BufferUtil.allocate(1024);
|
||||
FutureCallback<Void> fcb = new FutureCallback<>();
|
||||
|
||||
endp.readable(null,fcb);
|
||||
endp.fillInterested(null,fcb);
|
||||
assertTrue(fcb.isDone());
|
||||
assertEquals(null,fcb.get());
|
||||
assertEquals(4,endp.fill(buffer));
|
||||
|
@ -134,7 +134,7 @@ public class AsyncByteArrayEndPointTest
|
|||
|
||||
// read timeout
|
||||
fcb = new FutureCallback<>();
|
||||
endp.readable(null,fcb);
|
||||
endp.fillInterested(null,fcb);
|
||||
long start=System.currentTimeMillis();
|
||||
try
|
||||
{
|
||||
|
|
|
@ -129,11 +129,11 @@ public class SelectChannelEndPointTest
|
|||
@Override
|
||||
public void onOpen()
|
||||
{
|
||||
readInterested();
|
||||
fillInterested();
|
||||
}
|
||||
|
||||
@Override
|
||||
public synchronized void onReadable()
|
||||
public synchronized void onFillable()
|
||||
{
|
||||
AsyncEndPoint _endp = getEndPoint();
|
||||
try
|
||||
|
@ -155,7 +155,7 @@ public class SelectChannelEndPointTest
|
|||
while (_blockAt>0 && _endp.isOpen() && _in.remaining()<_blockAt)
|
||||
{
|
||||
FutureCallback<Void> blockingRead= new FutureCallback<>();
|
||||
_endp.readable(null,blockingRead);
|
||||
_endp.fillInterested(null,blockingRead);
|
||||
blockingRead.get();
|
||||
filled=_endp.fill(_in);
|
||||
progress|=filled>0;
|
||||
|
@ -210,7 +210,7 @@ public class SelectChannelEndPointTest
|
|||
finally
|
||||
{
|
||||
if (_endp.isOpen())
|
||||
readInterested();
|
||||
fillInterested();
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -139,7 +139,7 @@ public class SslConnectionTest
|
|||
public void onOpen()
|
||||
{
|
||||
// System.err.println("onOpen");
|
||||
readInterested();
|
||||
fillInterested();
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -149,7 +149,7 @@ public class SslConnectionTest
|
|||
}
|
||||
|
||||
@Override
|
||||
public synchronized void onReadable()
|
||||
public synchronized void onFillable()
|
||||
{
|
||||
AsyncEndPoint endp = getEndPoint();
|
||||
// System.err.println("onReadable "+endp);
|
||||
|
@ -201,7 +201,7 @@ public class SslConnectionTest
|
|||
finally
|
||||
{
|
||||
if (endp.isOpen())
|
||||
readInterested();
|
||||
fillInterested();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -380,7 +380,7 @@ public abstract class HttpChannel
|
|||
if (threadName!=null)
|
||||
Thread.currentThread().setName(threadName);
|
||||
|
||||
if (_state.isUncompleted())
|
||||
if (_state.isCompleting())
|
||||
{
|
||||
try
|
||||
{
|
||||
|
@ -809,6 +809,8 @@ public abstract class HttpChannel
|
|||
|
||||
protected abstract void execute(Runnable task);
|
||||
|
||||
// TODO replace with ScheduledExecutorService?
|
||||
// TODO constructor inject
|
||||
public abstract Timer getTimer();
|
||||
|
||||
|
||||
|
|
|
@ -51,15 +51,15 @@ public class HttpChannelState implements AsyncContext, Continuation
|
|||
// STATES:
|
||||
// handling() suspend() unhandle() resume() complete() doComplete()
|
||||
// startAsync() dispatch()
|
||||
// IDLE DISPATCHED COMPLETING
|
||||
// IDLE DISPATCHED COMPLETECALLED
|
||||
// DISPATCHED ASYNCSTARTED UNCOMPLETED
|
||||
// ASYNCSTARTED ASYNCWAIT REDISPATCHING COMPLETING
|
||||
// ASYNCSTARTED ASYNCWAIT REDISPATCHING COMPLETECALLED
|
||||
// REDISPATCHING REDISPATCHED
|
||||
// ASYNCWAIT REDISPATCH COMPLETING
|
||||
// ASYNCWAIT REDISPATCH COMPLETECALLED
|
||||
// REDISPATCH REDISPATCHED
|
||||
// REDISPATCHED ASYNCSTARTED UNCOMPLETED
|
||||
// COMPLETING UNCOMPLETED UNCOMPLETED
|
||||
// UNCOMPLETED UNCOMPLETED COMPLETED
|
||||
// REDISPATCHED ASYNCSTARTED COMPLETING
|
||||
// COMPLETECALLED COMPLETING COMPLETING
|
||||
// COMPLETING COMPLETING COMPLETED
|
||||
// COMPLETED
|
||||
|
||||
public enum State
|
||||
|
@ -67,12 +67,12 @@ public class HttpChannelState implements AsyncContext, Continuation
|
|||
IDLE, // Idle request
|
||||
DISPATCHED, // Request dispatched to filter/servlet
|
||||
ASYNCSTARTED, // Suspend called, but not yet returned to container
|
||||
REDISPATCHING,// resumed while dispatched
|
||||
REDISPATCHING, // resumed while dispatched
|
||||
ASYNCWAIT, // Suspended and parked
|
||||
REDISPATCH, // Has been scheduled
|
||||
REDISPATCHED, // Request redispatched to filter/servlet
|
||||
COMPLETING, // complete while dispatched
|
||||
UNCOMPLETED, // Request is completable
|
||||
COMPLETECALLED,// complete called
|
||||
COMPLETING, // Request is completable
|
||||
COMPLETED // Request is complete
|
||||
};
|
||||
|
||||
|
@ -208,7 +208,7 @@ public class HttpChannelState implements AsyncContext, Continuation
|
|||
{
|
||||
case ASYNCSTARTED:
|
||||
case REDISPATCHING:
|
||||
case COMPLETING:
|
||||
case COMPLETECALLED:
|
||||
case ASYNCWAIT:
|
||||
return true;
|
||||
|
||||
|
@ -254,7 +254,7 @@ public class HttpChannelState implements AsyncContext, Continuation
|
|||
case REDISPATCH:
|
||||
case REDISPATCHED:
|
||||
case REDISPATCHING:
|
||||
case COMPLETING:
|
||||
case COMPLETECALLED:
|
||||
return true;
|
||||
|
||||
default:
|
||||
|
@ -312,11 +312,11 @@ public class HttpChannelState implements AsyncContext, Continuation
|
|||
}
|
||||
return true;
|
||||
|
||||
case COMPLETING:
|
||||
_state=State.UNCOMPLETED;
|
||||
case COMPLETECALLED:
|
||||
_state=State.COMPLETING;
|
||||
return false;
|
||||
|
||||
case UNCOMPLETED:
|
||||
case COMPLETING:
|
||||
case ASYNCWAIT:
|
||||
return false;
|
||||
|
||||
|
@ -412,7 +412,7 @@ public class HttpChannelState implements AsyncContext, Continuation
|
|||
{
|
||||
case REDISPATCHED:
|
||||
case DISPATCHED:
|
||||
_state=State.UNCOMPLETED;
|
||||
_state=State.COMPLETING;
|
||||
return true;
|
||||
|
||||
case IDLE:
|
||||
|
@ -424,9 +424,9 @@ public class HttpChannelState implements AsyncContext, Continuation
|
|||
scheduleTimeout();
|
||||
if (_state==State.ASYNCWAIT)
|
||||
return true;
|
||||
else if (_state==State.COMPLETING)
|
||||
else if (_state==State.COMPLETECALLED)
|
||||
{
|
||||
_state=State.UNCOMPLETED;
|
||||
_state=State.COMPLETING;
|
||||
return true;
|
||||
}
|
||||
_initial=false;
|
||||
|
@ -438,9 +438,9 @@ public class HttpChannelState implements AsyncContext, Continuation
|
|||
_state=State.REDISPATCHED;
|
||||
return false;
|
||||
|
||||
case COMPLETING:
|
||||
case COMPLETECALLED:
|
||||
_initial=false;
|
||||
_state=State.UNCOMPLETED;
|
||||
_state=State.COMPLETING;
|
||||
return true;
|
||||
|
||||
default:
|
||||
|
@ -573,11 +573,11 @@ public class HttpChannelState implements AsyncContext, Continuation
|
|||
|
||||
case IDLE:
|
||||
case ASYNCSTARTED:
|
||||
_state=State.COMPLETING;
|
||||
_state=State.COMPLETECALLED;
|
||||
return;
|
||||
|
||||
case ASYNCWAIT:
|
||||
_state=State.COMPLETING;
|
||||
_state=State.COMPLETECALLED;
|
||||
dispatch=!_expired;
|
||||
break;
|
||||
|
||||
|
@ -621,7 +621,7 @@ public class HttpChannelState implements AsyncContext, Continuation
|
|||
{
|
||||
switch(_state)
|
||||
{
|
||||
case UNCOMPLETED:
|
||||
case COMPLETING:
|
||||
_state=State.COMPLETED;
|
||||
cListeners=_continuationListeners;
|
||||
aListeners=_asyncListeners;
|
||||
|
@ -729,7 +729,16 @@ public class HttpChannelState implements AsyncContext, Continuation
|
|||
}
|
||||
|
||||
/* ------------------------------------------------------------ */
|
||||
public boolean isCompleting()
|
||||
public boolean isCompleteCalled()
|
||||
{
|
||||
synchronized (this)
|
||||
{
|
||||
return _state==State.COMPLETECALLED;
|
||||
}
|
||||
}
|
||||
|
||||
/* ------------------------------------------------------------ */
|
||||
boolean isCompleting()
|
||||
{
|
||||
synchronized (this)
|
||||
{
|
||||
|
@ -738,16 +747,7 @@ public class HttpChannelState implements AsyncContext, Continuation
|
|||
}
|
||||
|
||||
/* ------------------------------------------------------------ */
|
||||
boolean isUncompleted()
|
||||
{
|
||||
synchronized (this)
|
||||
{
|
||||
return _state==State.UNCOMPLETED;
|
||||
}
|
||||
}
|
||||
|
||||
/* ------------------------------------------------------------ */
|
||||
public boolean isComplete()
|
||||
public boolean isCompleted()
|
||||
{
|
||||
synchronized (this)
|
||||
{
|
||||
|
@ -785,7 +785,7 @@ public class HttpChannelState implements AsyncContext, Continuation
|
|||
{
|
||||
case IDLE:
|
||||
case DISPATCHED:
|
||||
case UNCOMPLETED:
|
||||
case COMPLETING:
|
||||
case COMPLETED:
|
||||
return false;
|
||||
|
||||
|
|
|
@ -182,7 +182,7 @@ public class HttpConnection extends AbstractAsyncConnection
|
|||
{
|
||||
LOG.debug("Opened HTTP Connection {}",this);
|
||||
super.onOpen();
|
||||
readInterested();
|
||||
fillInterested();
|
||||
}
|
||||
|
||||
/* ------------------------------------------------------------ */
|
||||
|
@ -207,7 +207,7 @@ public class HttpConnection extends AbstractAsyncConnection
|
|||
* the HttpChannel becomes !idle; or the connection has been changed
|
||||
*/
|
||||
@Override
|
||||
public synchronized void onReadable()
|
||||
public synchronized void onFillable()
|
||||
{
|
||||
LOG.debug("{} onReadable {}",this,_channel.isIdle());
|
||||
|
||||
|
@ -232,7 +232,7 @@ public class HttpConnection extends AbstractAsyncConnection
|
|||
if (filled==0)
|
||||
{
|
||||
// Somebody wanted to read, we didn't so schedule another attempt
|
||||
readInterested();
|
||||
fillInterested();
|
||||
releaseRequestBuffer();
|
||||
return;
|
||||
}
|
||||
|
@ -430,7 +430,7 @@ public class HttpConnection extends AbstractAsyncConnection
|
|||
{
|
||||
// it wants to eat more
|
||||
if (_requestBuffer==null)
|
||||
readInterested();
|
||||
fillInterested();
|
||||
else if (getConnector().isStarted())
|
||||
{
|
||||
LOG.debug("{} pipelined",this);
|
||||
|
@ -440,7 +440,7 @@ public class HttpConnection extends AbstractAsyncConnection
|
|||
{
|
||||
execute(new Runnable()
|
||||
{
|
||||
@Override public void run() {onReadable();}
|
||||
@Override public void run() {onFillable();}
|
||||
});
|
||||
}
|
||||
catch(RejectedExecutionException e)
|
||||
|
@ -742,7 +742,7 @@ public class HttpConnection extends AbstractAsyncConnection
|
|||
{
|
||||
// Wait until we can read
|
||||
FutureCallback<Void> block=new FutureCallback<>();
|
||||
getEndPoint().readable(null,block);
|
||||
getEndPoint().fillInterested(null,block);
|
||||
LOG.debug("{} block readable on {}",this,block);
|
||||
block.get();
|
||||
|
||||
|
|
|
@ -81,7 +81,7 @@ public class ResponseTest
|
|||
})
|
||||
{
|
||||
@Override
|
||||
public void onReadable()
|
||||
public void onFillable()
|
||||
{
|
||||
}
|
||||
};
|
||||
|
|
|
@ -44,7 +44,7 @@ public interface Callback<C>
|
|||
*
|
||||
* @param <C> the type of the context object
|
||||
*/
|
||||
public static class Adapter<C> implements Callback<C>
|
||||
public static class Empty<C> implements Callback<C>
|
||||
{
|
||||
@Override
|
||||
public void completed(C context)
|
||||
|
|
Loading…
Reference in New Issue