[#2692] Allows notify ChannelFutureProgressListener on complete writes
Motivation: We have some inconsistency when handling writes. Sometimes we call ChannelOutboundBuffer.progress(...) also for complete writes and sometimes not. We should call it always. Modifications: Correctly call ChannelOuboundBuffer.progress(...) for complete and incomplete writes. Result: Consistent behavior
This commit is contained in:
parent
30295138fe
commit
2131edadf2
@ -253,6 +253,8 @@ public final class EpollSocketChannel extends AbstractEpollChannel implements So
|
||||
if (done) {
|
||||
// Release all buffers
|
||||
for (int i = msgCount; i > 0; i --) {
|
||||
final ByteBuf buf = (ByteBuf) in.current();
|
||||
in.progress(buf.readableBytes());
|
||||
in.remove();
|
||||
}
|
||||
in.progress(writtenBytes);
|
||||
@ -268,6 +270,7 @@ public final class EpollSocketChannel extends AbstractEpollChannel implements So
|
||||
final int readableBytes = buf.writerIndex() - readerIndex;
|
||||
|
||||
if (readableBytes < writtenBytes) {
|
||||
in.progress(readableBytes);
|
||||
in.remove();
|
||||
writtenBytes -= readableBytes;
|
||||
} else if (readableBytes > writtenBytes) {
|
||||
@ -275,6 +278,7 @@ public final class EpollSocketChannel extends AbstractEpollChannel implements So
|
||||
in.progress(writtenBytes);
|
||||
break;
|
||||
} else { // readable == writtenBytes
|
||||
in.progress(readableBytes);
|
||||
in.remove();
|
||||
break;
|
||||
}
|
||||
|
@ -193,12 +193,19 @@ public abstract class AbstractOioByteChannel extends AbstractOioChannel {
|
||||
}
|
||||
if (msg instanceof ByteBuf) {
|
||||
ByteBuf buf = (ByteBuf) msg;
|
||||
while (buf.isReadable()) {
|
||||
int readableBytes = buf.readableBytes();
|
||||
while (readableBytes > 0) {
|
||||
doWriteBytes(buf);
|
||||
int newReadableBytes = buf.readableBytes();
|
||||
in.progress(readableBytes - newReadableBytes);
|
||||
readableBytes = newReadableBytes;
|
||||
}
|
||||
in.remove();
|
||||
} else if (msg instanceof FileRegion) {
|
||||
doWriteFileRegion((FileRegion) msg);
|
||||
FileRegion region = (FileRegion) msg;
|
||||
long transfered = region.transfered();
|
||||
doWriteFileRegion(region);
|
||||
in.progress(region.transfered() - transfered);
|
||||
in.remove();
|
||||
} else {
|
||||
in.remove(new UnsupportedOperationException(
|
||||
|
@ -278,7 +278,9 @@ public class NioSocketChannel extends AbstractNioByteChannel implements io.netty
|
||||
if (done) {
|
||||
// Release all buffers
|
||||
for (int i = msgCount; i > 0; i --) {
|
||||
nioIn.remove();
|
||||
final ByteBuf buf = (ByteBuf) in.current();
|
||||
in.progress(buf.readableBytes());
|
||||
in.remove();
|
||||
}
|
||||
|
||||
// Finish the write loop if no new messages were flushed by in.remove().
|
||||
|
Loading…
Reference in New Issue
Block a user