Implement Promise/Future cancellation properly for outbound traffic

- Related issue: #1432
- Make sure the Promise of a write operation is not cancellable before writing out
This commit is contained in:
Trustin Lee 2013-06-11 17:54:35 +09:00
parent 41af9a1eb3
commit 7a5cf48b8d

View File

@ -684,6 +684,8 @@ public abstract class AbstractChannel extends DefaultAttributeMap implements Cha
MessageList<Object> messages = outboundBuffer.currentMessages; MessageList<Object> messages = outboundBuffer.currentMessages;
int messageIndex = outboundBuffer.currentMessageIndex; int messageIndex = outboundBuffer.currentMessageIndex;
int messageCount = messages.size(); int messageCount = messages.size();
// Make sure the message list is not empty.
if (messageCount == 0) { if (messageCount == 0) {
messages.recycle(); messages.recycle();
promise.trySuccess(); promise.trySuccess();
@ -694,6 +696,17 @@ public abstract class AbstractChannel extends DefaultAttributeMap implements Cha
} }
} }
// Make sure the promise has not been cancelled yet.
if (!promise.setUncancellable()) {
messages.releaseAllAndRecycle();
if (!outboundBuffer.next()) {
break;
} else {
continue;
}
}
// Write the messages.
int writtenMessages = doWrite(messages, messageIndex); int writtenMessages = doWrite(messages, messageIndex);
outboundBuffer.currentMessageIndex = messageIndex += writtenMessages; outboundBuffer.currentMessageIndex = messageIndex += writtenMessages;
if (messageIndex >= messageCount) { if (messageIndex >= messageCount) {