Consolidated usage of async handlers into one class only, instead of three.
This commit is contained in:
parent
77cdee95ce
commit
70f6d555bf
|
@ -25,9 +25,9 @@ import org.eclipse.jetty.spdy.frames.ControlFrame;
|
||||||
|
|
||||||
public interface ISession extends Session
|
public interface ISession extends Session
|
||||||
{
|
{
|
||||||
public void control(IStream stream, ControlFrame frame, Handler handler) throws StreamException;
|
public <C> void control(IStream stream, ControlFrame frame, Handler<C> handler, C context) throws StreamException;
|
||||||
|
|
||||||
public void data(IStream stream, DataInfo dataInfo, Handler handler);
|
public <C> void data(IStream stream, DataInfo dataInfo, Handler<C> handler, C context);
|
||||||
|
|
||||||
public int getWindowSize();
|
public int getWindowSize();
|
||||||
|
|
||||||
|
@ -36,10 +36,5 @@ public interface ISession extends Session
|
||||||
public int write(ByteBuffer buffer, Handler<T> handler, T context);
|
public int write(ByteBuffer buffer, Handler<T> handler, T context);
|
||||||
|
|
||||||
public void close(boolean onlyOutput);
|
public void close(boolean onlyOutput);
|
||||||
|
|
||||||
public interface Handler<C>
|
|
||||||
{
|
|
||||||
public void complete(C context);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,9 +22,9 @@ import java.util.concurrent.Future;
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
import java.util.concurrent.TimeoutException;
|
import java.util.concurrent.TimeoutException;
|
||||||
|
|
||||||
import org.eclipse.jetty.spdy.api.ResultHandler;
|
import org.eclipse.jetty.spdy.api.Handler;
|
||||||
|
|
||||||
public class Promise<T> extends ResultHandler<T> implements Future<T>
|
public class Promise<T> implements Handler<T>, Future<T>
|
||||||
{
|
{
|
||||||
private final CountDownLatch latch = new CountDownLatch(1);
|
private final CountDownLatch latch = new CountDownLatch(1);
|
||||||
private boolean cancelled;
|
private boolean cancelled;
|
||||||
|
|
|
@ -32,7 +32,6 @@ import org.eclipse.jetty.spdy.api.DataInfo;
|
||||||
import org.eclipse.jetty.spdy.api.GoAwayInfo;
|
import org.eclipse.jetty.spdy.api.GoAwayInfo;
|
||||||
import org.eclipse.jetty.spdy.api.Handler;
|
import org.eclipse.jetty.spdy.api.Handler;
|
||||||
import org.eclipse.jetty.spdy.api.PingInfo;
|
import org.eclipse.jetty.spdy.api.PingInfo;
|
||||||
import org.eclipse.jetty.spdy.api.ResultHandler;
|
|
||||||
import org.eclipse.jetty.spdy.api.RstInfo;
|
import org.eclipse.jetty.spdy.api.RstInfo;
|
||||||
import org.eclipse.jetty.spdy.api.SPDYException;
|
import org.eclipse.jetty.spdy.api.SPDYException;
|
||||||
import org.eclipse.jetty.spdy.api.Session;
|
import org.eclipse.jetty.spdy.api.Session;
|
||||||
|
@ -59,7 +58,7 @@ import org.eclipse.jetty.spdy.parser.Parser;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
public class StandardSession implements ISession, Parser.Listener, ISession.Controller.Handler<StandardSession.FrameBytes>
|
public class StandardSession implements ISession, Parser.Listener, Handler<StandardSession.FrameBytes>
|
||||||
{
|
{
|
||||||
private static final Logger logger = LoggerFactory.getLogger(Session.class);
|
private static final Logger logger = LoggerFactory.getLogger(Session.class);
|
||||||
private final List<Listener> listeners = new CopyOnWriteArrayList<>();
|
private final List<Listener> listeners = new CopyOnWriteArrayList<>();
|
||||||
|
@ -112,7 +111,7 @@ public class StandardSession implements ISession, Parser.Listener, ISession.Cont
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void syn(SynInfo synInfo, StreamFrameListener listener, final ResultHandler<Stream> handler)
|
public void syn(SynInfo synInfo, StreamFrameListener listener, final Handler<Stream> handler)
|
||||||
{
|
{
|
||||||
// Synchronization is necessary.
|
// Synchronization is necessary.
|
||||||
// SPEC v3, 2.3.1 requires that the stream creation be monotonically crescent
|
// SPEC v3, 2.3.1 requires that the stream creation be monotonically crescent
|
||||||
|
@ -135,27 +134,13 @@ public class StandardSession implements ISession, Parser.Listener, ISession.Cont
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
// May throw if wrong version or headers too big
|
// May throw if wrong version or headers too big
|
||||||
control(stream, synStream, new Handler()
|
control(stream, synStream, handler, stream);
|
||||||
{
|
|
||||||
@Override
|
|
||||||
public void completed()
|
|
||||||
{
|
|
||||||
handler.completed(stream);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void failed(Throwable x)
|
|
||||||
{
|
|
||||||
handler.failed(x);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
flush();
|
flush();
|
||||||
}
|
}
|
||||||
catch (StreamException x)
|
catch (StreamException x)
|
||||||
{
|
{
|
||||||
removeStream(stream);
|
removeStream(stream);
|
||||||
handler.failed(x);
|
handler.failed(x);
|
||||||
throw new SPDYException(x);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -170,19 +155,19 @@ public class StandardSession implements ISession, Parser.Listener, ISession.Cont
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void rst(RstInfo rstInfo, Handler handler)
|
public void rst(RstInfo rstInfo, Handler<Void> handler)
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
// SPEC v3, 2.2.2
|
// SPEC v3, 2.2.2
|
||||||
if (goAwaySent.get())
|
if (goAwaySent.get())
|
||||||
{
|
{
|
||||||
handler.completed();
|
handler.completed(null);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
RstStreamFrame frame = new RstStreamFrame(version, rstInfo.getStreamId(), rstInfo.getStreamStatus().getCode(version));
|
RstStreamFrame frame = new RstStreamFrame(version, rstInfo.getStreamId(), rstInfo.getStreamStatus().getCode(version));
|
||||||
control(null, frame, handler);
|
control(null, frame, handler, null);
|
||||||
flush();
|
flush();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -202,19 +187,17 @@ public class StandardSession implements ISession, Parser.Listener, ISession.Cont
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void settings(SettingsInfo settingsInfo, Handler handler)
|
public void settings(SettingsInfo settingsInfo, Handler<Void> handler)
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
SettingsFrame frame = new SettingsFrame(version, settingsInfo.getFlags(), settingsInfo.getSettings());
|
SettingsFrame frame = new SettingsFrame(version, settingsInfo.getFlags(), settingsInfo.getSettings());
|
||||||
control(null, frame, handler);
|
control(null, frame, handler, null);
|
||||||
flush();
|
flush();
|
||||||
}
|
}
|
||||||
catch (StreamException x)
|
catch (StreamException x)
|
||||||
{
|
{
|
||||||
// Should never happen, but just in case we rethrow
|
|
||||||
handler.failed(x);
|
handler.failed(x);
|
||||||
throw new SPDYException(x);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -227,34 +210,19 @@ public class StandardSession implements ISession, Parser.Listener, ISession.Cont
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void ping(final ResultHandler<PingInfo> handler)
|
public void ping(final Handler<PingInfo> handler)
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
int pingId = pingIds.getAndAdd(2);
|
int pingId = pingIds.getAndAdd(2);
|
||||||
final PingInfo pingInfo = new PingInfo(pingId);
|
final PingInfo pingInfo = new PingInfo(pingId);
|
||||||
PingFrame frame = new PingFrame(version, pingId);
|
PingFrame frame = new PingFrame(version, pingId);
|
||||||
control(null, frame, new Handler()
|
control(null, frame, handler, pingInfo);
|
||||||
{
|
|
||||||
@Override
|
|
||||||
public void completed()
|
|
||||||
{
|
|
||||||
handler.completed(pingInfo);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void failed(Throwable x)
|
|
||||||
{
|
|
||||||
handler.failed(x);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
flush();
|
flush();
|
||||||
}
|
}
|
||||||
catch (StreamException x)
|
catch (StreamException x)
|
||||||
{
|
{
|
||||||
// Should never happen, but just in case we rethrow
|
|
||||||
handler.failed(x);
|
handler.failed(x);
|
||||||
throw new SPDYException(x);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -267,7 +235,7 @@ public class StandardSession implements ISession, Parser.Listener, ISession.Cont
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void goAway(Handler handler)
|
public void goAway(Handler<Void> handler)
|
||||||
{
|
{
|
||||||
if (goAwaySent.compareAndSet(false, true))
|
if (goAwaySent.compareAndSet(false, true))
|
||||||
{
|
{
|
||||||
|
@ -276,19 +244,17 @@ public class StandardSession implements ISession, Parser.Listener, ISession.Cont
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
GoAwayFrame frame = new GoAwayFrame(version, lastStreamId.get(), SessionStatus.OK.getCode());
|
GoAwayFrame frame = new GoAwayFrame(version, lastStreamId.get(), SessionStatus.OK.getCode());
|
||||||
control(null, frame, handler);
|
control(null, frame, handler, null);
|
||||||
flush();
|
flush();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
catch (StreamException x)
|
catch (StreamException x)
|
||||||
{
|
{
|
||||||
// Should never happen, but just in case we rethrow
|
|
||||||
handler.failed(x);
|
handler.failed(x);
|
||||||
throw new SPDYException(x);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
handler.completed();
|
handler.completed(null);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -535,7 +501,7 @@ public class StandardSession implements ISession, Parser.Listener, ISession.Cont
|
||||||
if (pingId % 2 == pingIds.get() % 2)
|
if (pingId % 2 == pingIds.get() % 2)
|
||||||
notifyOnPing(frame);
|
notifyOnPing(frame);
|
||||||
else
|
else
|
||||||
control(null, frame, new Promise<>());
|
control(null, frame, new Promise<>(), null);
|
||||||
flush();
|
flush();
|
||||||
}
|
}
|
||||||
catch (StreamException x)
|
catch (StreamException x)
|
||||||
|
@ -664,13 +630,13 @@ public class StandardSession implements ISession, Parser.Listener, ISession.Cont
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void control(IStream stream, ControlFrame frame, Handler handler) throws StreamException
|
public <C> void control(IStream stream, ControlFrame frame, Handler<C> handler, C context) throws StreamException
|
||||||
{
|
{
|
||||||
if (stream != null)
|
if (stream != null)
|
||||||
updateLastStreamId(stream);
|
updateLastStreamId(stream);
|
||||||
ByteBuffer buffer = generator.control(frame);
|
ByteBuffer buffer = generator.control(frame);
|
||||||
logger.debug("Posting {} on {}", frame, stream);
|
logger.debug("Posting {} on {}", frame, stream);
|
||||||
enqueueLast(new ControlFrameBytes(frame, buffer, handler));
|
enqueueLast(new ControlFrameBytes<>(frame, buffer, handler, context));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void updateLastStreamId(IStream stream)
|
private void updateLastStreamId(IStream stream)
|
||||||
|
@ -690,10 +656,10 @@ public class StandardSession implements ISession, Parser.Listener, ISession.Cont
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void data(IStream stream, DataInfo dataInfo, Handler handler)
|
public <C> void data(IStream stream, DataInfo dataInfo, Handler<C> handler, C context)
|
||||||
{
|
{
|
||||||
logger.debug("Posting {} on {}", dataInfo, stream);
|
logger.debug("Posting {} on {}", dataInfo, stream);
|
||||||
enqueueLast(new DataFrameBytes(stream, dataInfo, handler));
|
enqueueLast(new DataFrameBytes<>(stream, dataInfo, handler, context));
|
||||||
flush();
|
flush();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -752,7 +718,7 @@ public class StandardSession implements ISession, Parser.Listener, ISession.Cont
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void complete(FrameBytes frameBytes)
|
public void completed(FrameBytes frameBytes)
|
||||||
{
|
{
|
||||||
synchronized (queue)
|
synchronized (queue)
|
||||||
{
|
{
|
||||||
|
@ -763,7 +729,13 @@ public class StandardSession implements ISession, Parser.Listener, ISession.Cont
|
||||||
flush();
|
flush();
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void write(final ByteBuffer buffer, Controller.Handler<FrameBytes> handler, FrameBytes frameBytes)
|
@Override
|
||||||
|
public void failed(Throwable x)
|
||||||
|
{
|
||||||
|
throw new SPDYException(x);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void write(final ByteBuffer buffer, Handler<FrameBytes> handler, FrameBytes frameBytes)
|
||||||
{
|
{
|
||||||
controller.write(buffer, handler, frameBytes);
|
controller.write(buffer, handler, frameBytes);
|
||||||
}
|
}
|
||||||
|
@ -775,17 +747,19 @@ public class StandardSession implements ISession, Parser.Listener, ISession.Cont
|
||||||
public abstract void complete();
|
public abstract void complete();
|
||||||
}
|
}
|
||||||
|
|
||||||
private class ControlFrameBytes implements FrameBytes
|
private class ControlFrameBytes<C> implements FrameBytes
|
||||||
{
|
{
|
||||||
private final ControlFrame frame;
|
private final ControlFrame frame;
|
||||||
private final ByteBuffer buffer;
|
private final ByteBuffer buffer;
|
||||||
private final Handler handler;
|
private final Handler<C> handler;
|
||||||
|
private final C context;
|
||||||
|
|
||||||
private ControlFrameBytes(ControlFrame frame, ByteBuffer buffer, Handler handler)
|
private ControlFrameBytes(ControlFrame frame, ByteBuffer buffer, Handler<C> handler, C context)
|
||||||
{
|
{
|
||||||
this.frame = frame;
|
this.frame = frame;
|
||||||
this.buffer = buffer;
|
this.buffer = buffer;
|
||||||
this.handler = handler;
|
this.handler = handler;
|
||||||
|
this.context = context;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -803,7 +777,7 @@ public class StandardSession implements ISession, Parser.Listener, ISession.Cont
|
||||||
// Recipients will know the last good stream id and act accordingly.
|
// Recipients will know the last good stream id and act accordingly.
|
||||||
controller.close(false);
|
controller.close(false);
|
||||||
}
|
}
|
||||||
handler.completed();
|
handler.completed(context);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -813,18 +787,20 @@ public class StandardSession implements ISession, Parser.Listener, ISession.Cont
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private class DataFrameBytes implements FrameBytes
|
private class DataFrameBytes<C> implements FrameBytes
|
||||||
{
|
{
|
||||||
private final IStream stream;
|
private final IStream stream;
|
||||||
private final DataInfo data;
|
private final DataInfo data;
|
||||||
private final Handler handler;
|
private final Handler<C> handler;
|
||||||
|
private final C context;
|
||||||
private int dataLength;
|
private int dataLength;
|
||||||
|
|
||||||
private DataFrameBytes(IStream stream, DataInfo data, Handler handler)
|
private DataFrameBytes(IStream stream, DataInfo data, Handler<C> handler, C context)
|
||||||
{
|
{
|
||||||
this.stream = stream;
|
this.stream = stream;
|
||||||
this.data = data;
|
this.data = data;
|
||||||
this.handler = handler;
|
this.handler = handler;
|
||||||
|
this.context = context;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -856,7 +832,7 @@ public class StandardSession implements ISession, Parser.Listener, ISession.Cont
|
||||||
stream.updateCloseState(data.isClose());
|
stream.updateCloseState(data.isClose());
|
||||||
if (stream.isClosed())
|
if (stream.isClosed())
|
||||||
removeStream(stream);
|
removeStream(stream);
|
||||||
handler.completed();
|
handler.completed(context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -205,7 +205,7 @@ public class StandardStream implements IStream
|
||||||
// we will send many window update frames... perhaps we can delay
|
// we will send many window update frames... perhaps we can delay
|
||||||
// window update frames until we have a bigger delta to send
|
// window update frames until we have a bigger delta to send
|
||||||
WindowUpdateFrame windowUpdateFrame = new WindowUpdateFrame(session.getVersion(), getId(), delta);
|
WindowUpdateFrame windowUpdateFrame = new WindowUpdateFrame(session.getVersion(), getId(), delta);
|
||||||
session.control(this, windowUpdateFrame, new Promise<>());
|
session.control(this, windowUpdateFrame, new Promise<>(), null);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch (StreamException x)
|
catch (StreamException x)
|
||||||
|
@ -275,13 +275,13 @@ public class StandardStream implements IStream
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void reply(ReplyInfo replyInfo, Handler handler)
|
public void reply(ReplyInfo replyInfo, Handler<Void> handler)
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
updateCloseState(replyInfo.isClose());
|
updateCloseState(replyInfo.isClose());
|
||||||
SynReplyFrame frame = new SynReplyFrame(session.getVersion(), replyInfo.getFlags(), getId(), replyInfo.getHeaders());
|
SynReplyFrame frame = new SynReplyFrame(session.getVersion(), replyInfo.getFlags(), getId(), replyInfo.getHeaders());
|
||||||
session.control(this, frame, handler);
|
session.control(this, frame, handler, null);
|
||||||
}
|
}
|
||||||
catch (StreamException x)
|
catch (StreamException x)
|
||||||
{
|
{
|
||||||
|
@ -300,11 +300,11 @@ public class StandardStream implements IStream
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void data(DataInfo dataInfo, Handler handler)
|
public void data(DataInfo dataInfo, Handler<Void> handler)
|
||||||
{
|
{
|
||||||
// Cannot update the close state here, because the data that we send may
|
// Cannot update the close state here, because the data that we send may
|
||||||
// be flow controlled, so we need the stream to update the window size.
|
// be flow controlled, so we need the stream to update the window size.
|
||||||
session.data(this, dataInfo, handler);
|
session.data(this, dataInfo, handler, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -316,13 +316,13 @@ public class StandardStream implements IStream
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void headers(HeadersInfo headersInfo, Handler handler)
|
public void headers(HeadersInfo headersInfo, Handler<Void> handler)
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
updateCloseState(headersInfo.isClose());
|
updateCloseState(headersInfo.isClose());
|
||||||
HeadersFrame frame = new HeadersFrame(session.getVersion(), headersInfo.getFlags(), getId(), headersInfo.getHeaders());
|
HeadersFrame frame = new HeadersFrame(session.getVersion(), headersInfo.getFlags(), getId(), headersInfo.getHeaders());
|
||||||
session.control(this, frame, handler);
|
session.control(this, frame, handler, null);
|
||||||
}
|
}
|
||||||
catch (StreamException x)
|
catch (StreamException x)
|
||||||
{
|
{
|
||||||
|
|
|
@ -16,28 +16,23 @@
|
||||||
|
|
||||||
package org.eclipse.jetty.spdy.api;
|
package org.eclipse.jetty.spdy.api;
|
||||||
|
|
||||||
import java.util.concurrent.TimeUnit;
|
public interface Handler<C>
|
||||||
|
|
||||||
public abstract class Handler
|
|
||||||
{
|
{
|
||||||
private final int timeout;
|
public abstract void completed(C context);
|
||||||
private final TimeUnit timeUnit;
|
|
||||||
|
|
||||||
protected Handler()
|
public void failed(Throwable x);
|
||||||
|
|
||||||
|
public static class Adapter<C> implements Handler<C>
|
||||||
|
{
|
||||||
|
@Override
|
||||||
|
public void completed(C context)
|
||||||
{
|
{
|
||||||
this(0, TimeUnit.MILLISECONDS);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected Handler(int timeout, TimeUnit timeUnit)
|
@Override
|
||||||
{
|
|
||||||
this.timeout = timeout;
|
|
||||||
this.timeUnit = timeUnit;
|
|
||||||
}
|
|
||||||
|
|
||||||
public abstract void completed();
|
|
||||||
|
|
||||||
public void failed(Throwable x)
|
public void failed(Throwable x)
|
||||||
{
|
{
|
||||||
throw new SPDYException(x);
|
throw new SPDYException(x);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,28 +0,0 @@
|
||||||
/*
|
|
||||||
* Copyright (c) 2012 the original author or authors.
|
|
||||||
*
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package org.eclipse.jetty.spdy.api;
|
|
||||||
|
|
||||||
public abstract class ResultHandler<R> extends Handler
|
|
||||||
{
|
|
||||||
@Override
|
|
||||||
public final void completed()
|
|
||||||
{
|
|
||||||
completed(null);
|
|
||||||
}
|
|
||||||
|
|
||||||
public abstract void completed(R result);
|
|
||||||
}
|
|
|
@ -71,7 +71,7 @@ public interface Session
|
||||||
* @param synInfo the metadata to send on stream creation
|
* @param synInfo the metadata to send on stream creation
|
||||||
* @param listener the listener to invoke when events happen on the stream just created
|
* @param listener the listener to invoke when events happen on the stream just created
|
||||||
* @return a future for the stream that will be created
|
* @return a future for the stream that will be created
|
||||||
* @see #syn(SynInfo, StreamFrameListener, ResultHandler)
|
* @see #syn(SynInfo, StreamFrameListener, Handler)
|
||||||
*/
|
*/
|
||||||
public Future<Stream> syn(SynInfo synInfo, StreamFrameListener listener);
|
public Future<Stream> syn(SynInfo synInfo, StreamFrameListener listener);
|
||||||
|
|
||||||
|
@ -85,7 +85,7 @@ public interface Session
|
||||||
* @param handler the completion handler that gets notified of stream creation
|
* @param handler the completion handler that gets notified of stream creation
|
||||||
* @see #syn(SynInfo, StreamFrameListener)
|
* @see #syn(SynInfo, StreamFrameListener)
|
||||||
*/
|
*/
|
||||||
public void syn(SynInfo synInfo, StreamFrameListener listener, ResultHandler<Stream> handler);
|
public void syn(SynInfo synInfo, StreamFrameListener listener, Handler<Stream> handler);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>Sends asynchronously a RST_STREAM to abort a stream.</p>
|
* <p>Sends asynchronously a RST_STREAM to abort a stream.</p>
|
||||||
|
@ -104,7 +104,7 @@ public interface Session
|
||||||
* @param rstInfo the metadata to reset the stream
|
* @param rstInfo the metadata to reset the stream
|
||||||
* @param handler the completion handler that gets notified of reset's send
|
* @param handler the completion handler that gets notified of reset's send
|
||||||
*/
|
*/
|
||||||
public void rst(RstInfo rstInfo, Handler handler);
|
public void rst(RstInfo rstInfo, Handler<Void> handler);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>Sends asynchronously a SETTINGS to configure the SPDY connection.</p>
|
* <p>Sends asynchronously a SETTINGS to configure the SPDY connection.</p>
|
||||||
|
@ -123,7 +123,7 @@ public interface Session
|
||||||
* @param settingsInfo the metadata to send
|
* @param settingsInfo the metadata to send
|
||||||
* @param handler the completion handler that gets notified of settings' send
|
* @param handler the completion handler that gets notified of settings' send
|
||||||
*/
|
*/
|
||||||
public void settings(SettingsInfo settingsInfo, Handler handler);
|
public void settings(SettingsInfo settingsInfo, Handler<Void> handler);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>Sends asynchronously a PING, normally to measure round-trip time.</p>
|
* <p>Sends asynchronously a PING, normally to measure round-trip time.</p>
|
||||||
|
@ -140,7 +140,7 @@ public interface Session
|
||||||
*
|
*
|
||||||
* @param handler the completion handler that gets notified of ping's send
|
* @param handler the completion handler that gets notified of ping's send
|
||||||
*/
|
*/
|
||||||
public void ping(ResultHandler<PingInfo> handler);
|
public void ping(Handler<PingInfo> handler);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>Closes gracefully this session, sending a GO_AWAY frame and then closing the TCP connection.</p>
|
* <p>Closes gracefully this session, sending a GO_AWAY frame and then closing the TCP connection.</p>
|
||||||
|
@ -157,7 +157,7 @@ public interface Session
|
||||||
*
|
*
|
||||||
* @param handler the completion handler that gets notified of go away's send
|
* @param handler the completion handler that gets notified of go away's send
|
||||||
*/
|
*/
|
||||||
public void goAway(Handler handler);
|
public void goAway(Handler<Void> handler);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>Initiates the flush of data to the other peer.</p>
|
* <p>Initiates the flush of data to the other peer.</p>
|
||||||
|
@ -213,27 +213,4 @@ public interface Session
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/*
|
|
||||||
public static abstract class SynHandler extends Promise<Stream>
|
|
||||||
{
|
|
||||||
@Override
|
|
||||||
public final void completed()
|
|
||||||
{
|
|
||||||
// Applications should not override this method, but the one below
|
|
||||||
}
|
|
||||||
|
|
||||||
public abstract void completed(Stream stream);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static abstract class PingHandler extends Promise<PingInfo>
|
|
||||||
{
|
|
||||||
@Override
|
|
||||||
public final void completed()
|
|
||||||
{
|
|
||||||
// Applications should not override this method, but the one below
|
|
||||||
}
|
|
||||||
|
|
||||||
public abstract void completed(PingInfo stream);
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -69,7 +69,7 @@ public interface Stream
|
||||||
* @param replyInfo the metadata to send
|
* @param replyInfo the metadata to send
|
||||||
* @param handler the completion handler that gets notified of reply sent
|
* @param handler the completion handler that gets notified of reply sent
|
||||||
*/
|
*/
|
||||||
public void reply(ReplyInfo replyInfo, Handler handler);
|
public void reply(ReplyInfo replyInfo, Handler<Void> handler);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>Sends asynchronously a DATA frame on this stream.</p>
|
* <p>Sends asynchronously a DATA frame on this stream.</p>
|
||||||
|
@ -91,7 +91,7 @@ public interface Stream
|
||||||
* @param dataInfo the metadata to send
|
* @param dataInfo the metadata to send
|
||||||
* @param handler the completion handler that gets notified of data sent
|
* @param handler the completion handler that gets notified of data sent
|
||||||
*/
|
*/
|
||||||
public void data(DataInfo dataInfo, Handler handler);
|
public void data(DataInfo dataInfo, Handler<Void> handler);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>Sends asynchronously a HEADER frame on this stream.</p>
|
* <p>Sends asynchronously a HEADER frame on this stream.</p>
|
||||||
|
@ -113,7 +113,7 @@ public interface Stream
|
||||||
* @param headersInfo the metadata to send
|
* @param headersInfo the metadata to send
|
||||||
* @param handler the completion handler that gets notified of headers sent
|
* @param handler the completion handler that gets notified of headers sent
|
||||||
*/
|
*/
|
||||||
public void headers(HeadersInfo headersInfo, Handler handler);
|
public void headers(HeadersInfo headersInfo, Handler<Void> handler);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return whether this stream has been closed by both parties
|
* @return whether this stream has been closed by both parties
|
||||||
|
|
|
@ -82,7 +82,7 @@ public class ClientUsageTest
|
||||||
// Then issue another similar request
|
// Then issue another similar request
|
||||||
stream.getSession().syn(new SynInfo(true), this);
|
stream.getSession().syn(new SynInfo(true), this);
|
||||||
}
|
}
|
||||||
}, new ResultHandler<Stream>()
|
}, new Handler.Adapter<Stream>()
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
public void completed(Stream stream)
|
public void completed(Stream stream)
|
||||||
|
@ -137,7 +137,7 @@ public class ClientUsageTest
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}, new ResultHandler<Stream>()
|
}, new Handler.Adapter<Stream>()
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
public void completed(Stream stream)
|
public void completed(Stream stream)
|
||||||
|
|
|
@ -71,7 +71,7 @@ public class ServerUsageTest
|
||||||
//
|
//
|
||||||
// However, the API may allow to initiate the stream
|
// However, the API may allow to initiate the stream
|
||||||
|
|
||||||
session.syn(new SynInfo(false), null, new ResultHandler<Stream>()
|
session.syn(new SynInfo(false), null, new Handler.Adapter<Stream>()
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
public void completed(Stream stream)
|
public void completed(Stream stream)
|
||||||
|
@ -101,7 +101,7 @@ public class ServerUsageTest
|
||||||
|
|
||||||
Session session = stream.getSession();
|
Session session = stream.getSession();
|
||||||
// Since it's unidirectional, no need to pass the listener
|
// Since it's unidirectional, no need to pass the listener
|
||||||
session.syn(new SynInfo(new Headers(), false, true, stream.getId(), (byte)0), null, new ResultHandler<Stream>()
|
session.syn(new SynInfo(new Headers(), false, true, stream.getId(), (byte)0), null, new Handler.Adapter<Stream>()
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
public void completed(Stream pushStream)
|
public void completed(Stream pushStream)
|
||||||
|
|
|
@ -19,8 +19,7 @@
|
||||||
<version>2.11</version>
|
<version>2.11</version>
|
||||||
<configuration>
|
<configuration>
|
||||||
<argLine>
|
<argLine>
|
||||||
-Xbootclasspath/a:${settings.localRepository}/org/eclipse/jetty/jetty-npn-boot/${npn.version}/jetty-npn-boot-${npn.version}.jar
|
-Xbootclasspath/p:${settings.localRepository}/org/eclipse/jetty/npn-boot/${npn.version}/npn-boot-${npn.version}.jar
|
||||||
-javaagent:${settings.localRepository}/org/eclipse/jetty/jetty-npn-agent/${npn.version}/jetty-npn-agent-${npn.version}.jar
|
|
||||||
</argLine>
|
</argLine>
|
||||||
</configuration>
|
</configuration>
|
||||||
</plugin>
|
</plugin>
|
||||||
|
|
|
@ -28,7 +28,7 @@ import org.eclipse.jetty.io.nio.DirectNIOBuffer;
|
||||||
import org.eclipse.jetty.io.nio.IndirectNIOBuffer;
|
import org.eclipse.jetty.io.nio.IndirectNIOBuffer;
|
||||||
import org.eclipse.jetty.io.nio.NIOBuffer;
|
import org.eclipse.jetty.io.nio.NIOBuffer;
|
||||||
import org.eclipse.jetty.spdy.ISession.Controller;
|
import org.eclipse.jetty.spdy.ISession.Controller;
|
||||||
import org.eclipse.jetty.spdy.api.SPDYException;
|
import org.eclipse.jetty.spdy.api.Handler;
|
||||||
import org.eclipse.jetty.spdy.api.Session;
|
import org.eclipse.jetty.spdy.api.Session;
|
||||||
import org.eclipse.jetty.spdy.parser.Parser;
|
import org.eclipse.jetty.spdy.parser.Parser;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
|
@ -121,7 +121,7 @@ public class SPDYAsyncConnection extends AbstractConnection implements AsyncConn
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int write(ByteBuffer buffer, ISession.Controller.Handler<StandardSession.FrameBytes> handler, StandardSession.FrameBytes context)
|
public int write(ByteBuffer buffer, Handler<StandardSession.FrameBytes> handler, StandardSession.FrameBytes context)
|
||||||
{
|
{
|
||||||
int remaining = buffer.remaining();
|
int remaining = buffer.remaining();
|
||||||
Buffer jettyBuffer = buffer.isDirect() ? new DirectNIOBuffer(buffer, false) : new IndirectNIOBuffer(buffer, false);
|
Buffer jettyBuffer = buffer.isDirect() ? new DirectNIOBuffer(buffer, false) : new IndirectNIOBuffer(buffer, false);
|
||||||
|
@ -131,10 +131,10 @@ public class SPDYAsyncConnection extends AbstractConnection implements AsyncConn
|
||||||
int written = endPoint.flush(jettyBuffer);
|
int written = endPoint.flush(jettyBuffer);
|
||||||
logger.debug("Written {} bytes, {} remaining", written, jettyBuffer.length());
|
logger.debug("Written {} bytes, {} remaining", written, jettyBuffer.length());
|
||||||
}
|
}
|
||||||
catch (IOException x)
|
catch (Exception x)
|
||||||
{
|
{
|
||||||
close(false);
|
close(false);
|
||||||
throw new SPDYException(x);
|
handler.failed(x);
|
||||||
}
|
}
|
||||||
finally
|
finally
|
||||||
{
|
{
|
||||||
|
@ -162,7 +162,7 @@ public class SPDYAsyncConnection extends AbstractConnection implements AsyncConn
|
||||||
// Volatile write to ensure visibility of write fields
|
// Volatile write to ensure visibility of write fields
|
||||||
writePending = false;
|
writePending = false;
|
||||||
}
|
}
|
||||||
handler.complete(context);
|
handler.completed(context);
|
||||||
}
|
}
|
||||||
|
|
||||||
return remaining - buffer.remaining();
|
return remaining - buffer.remaining();
|
||||||
|
|
|
@ -20,8 +20,8 @@ import java.util.concurrent.CountDownLatch;
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
import java.util.concurrent.atomic.AtomicReference;
|
import java.util.concurrent.atomic.AtomicReference;
|
||||||
|
|
||||||
|
import org.eclipse.jetty.spdy.api.Handler;
|
||||||
import org.eclipse.jetty.spdy.api.PingInfo;
|
import org.eclipse.jetty.spdy.api.PingInfo;
|
||||||
import org.eclipse.jetty.spdy.api.ResultHandler;
|
|
||||||
import org.eclipse.jetty.spdy.api.Session;
|
import org.eclipse.jetty.spdy.api.Session;
|
||||||
import org.eclipse.jetty.spdy.api.SessionFrameListener;
|
import org.eclipse.jetty.spdy.api.SessionFrameListener;
|
||||||
import org.eclipse.jetty.spdy.api.server.ServerSessionFrameListener;
|
import org.eclipse.jetty.spdy.api.server.ServerSessionFrameListener;
|
||||||
|
@ -65,7 +65,7 @@ public class PingTest extends AbstractTest
|
||||||
@Override
|
@Override
|
||||||
public void onConnect(Session session)
|
public void onConnect(Session session)
|
||||||
{
|
{
|
||||||
session.ping(new ResultHandler<PingInfo>()
|
session.ping(new Handler.Adapter<PingInfo>()
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
public void completed(PingInfo pingInfo)
|
public void completed(PingInfo pingInfo)
|
||||||
|
|
|
@ -27,9 +27,9 @@ import java.util.concurrent.atomic.AtomicReference;
|
||||||
|
|
||||||
import org.eclipse.jetty.spdy.api.BytesDataInfo;
|
import org.eclipse.jetty.spdy.api.BytesDataInfo;
|
||||||
import org.eclipse.jetty.spdy.api.DataInfo;
|
import org.eclipse.jetty.spdy.api.DataInfo;
|
||||||
|
import org.eclipse.jetty.spdy.api.Handler;
|
||||||
import org.eclipse.jetty.spdy.api.Headers;
|
import org.eclipse.jetty.spdy.api.Headers;
|
||||||
import org.eclipse.jetty.spdy.api.ReplyInfo;
|
import org.eclipse.jetty.spdy.api.ReplyInfo;
|
||||||
import org.eclipse.jetty.spdy.api.ResultHandler;
|
|
||||||
import org.eclipse.jetty.spdy.api.RstInfo;
|
import org.eclipse.jetty.spdy.api.RstInfo;
|
||||||
import org.eclipse.jetty.spdy.api.Session;
|
import org.eclipse.jetty.spdy.api.Session;
|
||||||
import org.eclipse.jetty.spdy.api.SessionFrameListener;
|
import org.eclipse.jetty.spdy.api.SessionFrameListener;
|
||||||
|
@ -280,7 +280,7 @@ public class SynReplyTest extends AbstractTest
|
||||||
Assert.assertEquals(clientData, data);
|
Assert.assertEquals(clientData, data);
|
||||||
clientDataLatch.countDown();
|
clientDataLatch.countDown();
|
||||||
}
|
}
|
||||||
}, new ResultHandler<Stream>()
|
}, new Handler.Adapter<Stream>()
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
public void completed(Stream stream)
|
public void completed(Stream stream)
|
||||||
|
|
Loading…
Reference in New Issue