Revised exception handling.

This commit is contained in:
Simone Bordet 2012-02-29 00:43:17 +01:00
parent 1238de8a28
commit 3b8c6dfd4c
2 changed files with 42 additions and 117 deletions

View File

@ -142,17 +142,8 @@ public class StandardSession implements ISession, Parser.Listener, Handler<Stand
int streamId = streamIds.getAndAdd(2);
SynStreamFrame synStream = new SynStreamFrame(version, synInfo.getFlags(), streamId, 0, synInfo.getPriority(), synInfo.getHeaders());
final IStream stream = createStream(synStream, listener);
try
{
// May throw if wrong version or headers too big
control(stream, synStream, timeout, unit, handler, stream);
}
catch (StreamException x)
{
removeStream(stream);
handler.failed(x);
}
}
}
}
@ -166,8 +157,6 @@ public class StandardSession implements ISession, Parser.Listener, Handler<Stand
@Override
public void rst(RstInfo rstInfo, long timeout, TimeUnit unit, Handler<Void> handler)
{
try
{
// SPEC v3, 2.2.2
if (goAwaySent.get())
@ -180,12 +169,6 @@ public class StandardSession implements ISession, Parser.Listener, Handler<Stand
control(null, frame, timeout, unit, handler, null);
}
}
catch (StreamException x)
{
logger.info("Could not send reset on stream " + rstInfo.getStreamId(), x);
handler.failed(x);
}
}
@Override
public Future<Void> settings(SettingsInfo settingsInfo)
@ -197,17 +180,10 @@ public class StandardSession implements ISession, Parser.Listener, Handler<Stand
@Override
public void settings(SettingsInfo settingsInfo, long timeout, TimeUnit unit, Handler<Void> handler)
{
try
{
SettingsFrame frame = new SettingsFrame(version, settingsInfo.getFlags(), settingsInfo.getSettings());
control(null, frame, timeout, unit, handler, null);
}
catch (StreamException x)
{
handler.failed(x);
}
}
@Override
public Future<PingInfo> ping()
@ -222,16 +198,9 @@ public class StandardSession implements ISession, Parser.Listener, Handler<Stand
{
int pingId = pingIds.getAndAdd(2);
PingInfo pingInfo = new PingInfo(pingId);
try
{
PingFrame frame = new PingFrame(version, pingId);
control(null, frame, timeout, unit, handler, pingInfo);
}
catch (StreamException x)
{
handler.failed(x);
}
}
@Override
public Future<Void> goAway()
@ -247,18 +216,11 @@ public class StandardSession implements ISession, Parser.Listener, Handler<Stand
if (goAwaySent.compareAndSet(false, true))
{
if (!goAwayReceived.get())
{
try
{
GoAwayFrame frame = new GoAwayFrame(version, lastStreamId.get(), SessionStatus.OK.getCode());
control(null, frame, timeout, unit, handler, null);
return;
}
catch (StreamException x)
{
handler.failed(x);
}
}
}
handler.completed(null);
}
@ -554,8 +516,6 @@ public class StandardSession implements ISession, Parser.Listener, Handler<Stand
}
private void onPing(final PingFrame frame)
{
try
{
int pingId = frame.getPingId();
if (pingId % 2 == pingIds.get() % 2)
@ -576,11 +536,6 @@ public class StandardSession implements ISession, Parser.Listener, Handler<Stand
control(null, frame, 0, TimeUnit.MILLISECONDS, new Promise<>(), null);
}
}
catch (StreamException x)
{
throw new SPDYException(x);
}
}
private void onGoAway(final GoAwayFrame frame)
{

View File

@ -203,14 +203,13 @@ public class StandardStream implements IStream
super.consume(delta);
// This is the algorithm for flow control.
// This method may be called multiple times
// with delta=1, but we only send a window
// update when the whole dataInfo has been
// consumed.
// Other policies may be to send window
// updates when consumed() is greater than
// a certain threshold, etc. but for now
// the policy is not pluggable for simplicity.
// This method may be called multiple times with delta=1, but we only send a window
// update when the whole dataInfo has been consumed.
// Other policies may be to send window updates when consumed() is greater than
// a certain threshold, etc. but for now the policy is not pluggable for simplicity.
// Note that the frequency of window updates depends on the read buffer, that
// should not be too smaller than the window size to avoid frequent window updates.
// Therefore, a pluggable policy should be able to modify the read buffer capacity.
if (consumed() == length() && !isClosed())
windowUpdate(length());
}
@ -259,24 +258,13 @@ public class StandardStream implements IStream
}
private void windowUpdate(int delta)
{
try
{
if (delta > 0)
{
// TODO: if the read buffer is small, but the default window size is big,
// we will send many window update frames... perhaps we can delay
// window update frames until we have a bigger delta to send
WindowUpdateFrame windowUpdateFrame = new WindowUpdateFrame(session.getVersion(), getId(), delta);
session.control(this, windowUpdateFrame, 0, TimeUnit.MILLISECONDS, new Promise<>(), null);
}
}
catch (StreamException x)
{
logger.debug("Could not send window update on stream " + this, x);
session.rst(new RstInfo(getId(), x.getStreamStatus()));
}
}
private void notifyOnReply(ReplyInfo replyInfo)
{
@ -340,20 +328,11 @@ public class StandardStream implements IStream
@Override
public void reply(ReplyInfo replyInfo, long timeout, TimeUnit unit, Handler<Void> handler)
{
try
{
updateCloseState(replyInfo.isClose());
SynReplyFrame frame = new SynReplyFrame(session.getVersion(), replyInfo.getFlags(), getId(), replyInfo.getHeaders());
session.control(this, frame, timeout, unit, handler, null);
}
catch (StreamException x)
{
logger.debug("Could not send reply on stream " + this, x);
handler.failed(x);
session.rst(new RstInfo(getId(), x.getStreamStatus()));
}
}
@Override
public Future<Void> data(DataInfo dataInfo)
@ -381,20 +360,11 @@ public class StandardStream implements IStream
@Override
public void headers(HeadersInfo headersInfo, long timeout, TimeUnit unit, Handler<Void> handler)
{
try
{
updateCloseState(headersInfo.isClose());
HeadersFrame frame = new HeadersFrame(session.getVersion(), headersInfo.getFlags(), getId(), headersInfo.getHeaders());
session.control(this, frame, timeout, unit, handler, null);
}
catch (StreamException x)
{
logger.debug("Could not send headers on stream " + this, x);
handler.failed(x);
session.rst(new RstInfo(getId(), x.getStreamStatus()));
}
}
@Override
public boolean isClosed()