[#1925] Only expose sub-region of ByteBuf on nioBuffer(...)

This commit is contained in:
Norman Maurer 2013-10-16 10:34:33 +02:00
parent da1418e269
commit 9b625d611f
8 changed files with 30 additions and 6 deletions

View File

@ -330,7 +330,7 @@ final class PooledDirectByteBuf extends PooledByteBuf<ByteBuffer> {
public ByteBuffer nioBuffer(int index, int length) { public ByteBuffer nioBuffer(int index, int length) {
checkIndex(index, length); checkIndex(index, length);
index = idx(index); index = idx(index);
return (ByteBuffer) memory.duplicate().position(index).limit(index + length); return ((ByteBuffer) memory.duplicate().position(index).limit(index + length)).slice();
} }
@Override @Override

View File

@ -259,7 +259,8 @@ final class PooledHeapByteBuf extends PooledByteBuf<byte[]> {
public ByteBuffer nioBuffer(int index, int length) { public ByteBuffer nioBuffer(int index, int length) {
checkIndex(index, length); checkIndex(index, length);
index = idx(index); index = idx(index);
return (ByteBuffer) ByteBuffer.wrap(memory).position(index).limit(index + length); ByteBuffer buf = ByteBuffer.wrap(memory, index, length);
return buf.slice();
} }
@Override @Override

View File

@ -339,7 +339,7 @@ final class PooledUnsafeDirectByteBuf extends PooledByteBuf<ByteBuffer> {
public ByteBuffer nioBuffer(int index, int length) { public ByteBuffer nioBuffer(int index, int length) {
checkIndex(index, length); checkIndex(index, length);
index = idx(index); index = idx(index);
return (ByteBuffer) memory.duplicate().position(index).limit(index + length); return ((ByteBuffer) memory.duplicate().position(index).limit(index + length)).slice();
} }
@Override @Override

View File

@ -575,7 +575,7 @@ public class UnpooledDirectByteBuf extends AbstractReferenceCountedByteBuf {
@Override @Override
public ByteBuffer nioBuffer(int index, int length) { public ByteBuffer nioBuffer(int index, int length) {
return (ByteBuffer) buffer.duplicate().position(index).limit(index + length); return ((ByteBuffer) buffer.duplicate().position(index).limit(index + length)).slice();
} }
@Override @Override

View File

@ -267,7 +267,7 @@ public class UnpooledHeapByteBuf extends AbstractReferenceCountedByteBuf {
@Override @Override
public ByteBuffer nioBuffer(int index, int length) { public ByteBuffer nioBuffer(int index, int length) {
ensureAccessible(); ensureAccessible();
return ByteBuffer.wrap(array, index, length); return ByteBuffer.wrap(array, index, length).slice();
} }
@Override @Override

View File

@ -475,7 +475,7 @@ public class UnpooledUnsafeDirectByteBuf extends AbstractReferenceCountedByteBuf
@Override @Override
public ByteBuffer nioBuffer(int index, int length) { public ByteBuffer nioBuffer(int index, int length) {
return (ByteBuffer) buffer.duplicate().position(index).limit(index + length); return ((ByteBuffer) buffer.duplicate().position(index).limit(index + length)).slice();
} }
@Override @Override

View File

@ -1942,6 +1942,23 @@ public abstract class AbstractByteBufTest {
assertEquals((byte) 0 , buffer.readByte()); assertEquals((byte) 0 , buffer.readByte());
buffer.readByte(); buffer.readByte();
} }
@Test
public void testNioBufferExposeOnlyRegion() {
final ByteBuf buffer = freeLater(newBuffer(8));
byte[] data = new byte[8];
random.nextBytes(data);
buffer.writeBytes(data);
ByteBuffer nioBuf = buffer.nioBuffer(1, data.length - 2);
assertEquals(0, nioBuf.position());
assertEquals(6, nioBuf.remaining());
for (int i = 1; nioBuf.hasRemaining(); i++) {
assertEquals(data[i], nioBuf.get());
}
}
static final class TestGatheringByteChannel implements GatheringByteChannel { static final class TestGatheringByteChannel implements GatheringByteChannel {
private final ByteArrayOutputStream out = new ByteArrayOutputStream(); private final ByteArrayOutputStream out = new ByteArrayOutputStream();
private final WritableByteChannel channel = Channels.newChannel(out); private final WritableByteChannel channel = Channels.newChannel(out);

View File

@ -88,4 +88,10 @@ public class SlicedByteBufTest extends AbstractByteBufTest {
public void testSliceBytesInArrayMultipleThreads() throws Exception { public void testSliceBytesInArrayMultipleThreads() throws Exception {
super.testSliceBytesInArrayMultipleThreads(); super.testSliceBytesInArrayMultipleThreads();
} }
@Test(expected = IndexOutOfBoundsException.class)
@Override
public void testNioBufferExposeOnlyRegion() {
super.testNioBufferExposeOnlyRegion();
}
} }