Remove support for marking reader and writerIndex in ByteBuf to reduce overhead and complexity. (#8636)

Motivation:

ByteBuf supports “marker indexes”. The intended use case for these is if a speculative operation (e.g. decode) is in process the user can “mark” and interface and refer to it later if the operation isn’t successful (e.g. not enough data). However this is rarely used in practice,
requires extra memory to maintain, and introduces complexity in the state management for derived/pooled buffer initialization, resizing, and other operations which may modify reader/writer indexes.

Modifications:

Remove support for marking and adjust testcases / code.

Result:

Fixes https://github.com/netty/netty/issues/8535.
This commit is contained in:
Norman Maurer 2018-12-11 14:00:49 +01:00 committed by GitHub
parent 9c594e5068
commit d9a6cf341c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
37 changed files with 127 additions and 419 deletions

View File

@ -68,8 +68,6 @@ public abstract class AbstractByteBuf extends ByteBuf {
int readerIndex; int readerIndex;
int writerIndex; int writerIndex;
private int markedReaderIndex;
private int markedWriterIndex;
private int maxCapacity; private int maxCapacity;
protected AbstractByteBuf(int maxCapacity) { protected AbstractByteBuf(int maxCapacity) {
@ -188,30 +186,6 @@ public abstract class AbstractByteBuf extends ByteBuf {
return maxCapacity() - writerIndex; return maxCapacity() - writerIndex;
} }
@Override
public ByteBuf markReaderIndex() {
markedReaderIndex = readerIndex;
return this;
}
@Override
public ByteBuf resetReaderIndex() {
readerIndex(markedReaderIndex);
return this;
}
@Override
public ByteBuf markWriterIndex() {
markedWriterIndex = writerIndex;
return this;
}
@Override
public ByteBuf resetWriterIndex() {
writerIndex(markedWriterIndex);
return this;
}
@Override @Override
public ByteBuf discardReadBytes() { public ByteBuf discardReadBytes() {
ensureAccessible(); ensureAccessible();
@ -222,10 +196,8 @@ public abstract class AbstractByteBuf extends ByteBuf {
if (readerIndex != writerIndex) { if (readerIndex != writerIndex) {
setBytes(0, this, readerIndex, writerIndex - readerIndex); setBytes(0, this, readerIndex, writerIndex - readerIndex);
writerIndex -= readerIndex; writerIndex -= readerIndex;
adjustMarkers(readerIndex);
readerIndex = 0; readerIndex = 0;
} else { } else {
adjustMarkers(readerIndex);
writerIndex = readerIndex = 0; writerIndex = readerIndex = 0;
} }
return this; return this;
@ -239,7 +211,6 @@ public abstract class AbstractByteBuf extends ByteBuf {
} }
if (readerIndex == writerIndex) { if (readerIndex == writerIndex) {
adjustMarkers(readerIndex);
writerIndex = readerIndex = 0; writerIndex = readerIndex = 0;
return this; return this;
} }
@ -247,28 +218,11 @@ public abstract class AbstractByteBuf extends ByteBuf {
if (readerIndex >= capacity() >>> 1) { if (readerIndex >= capacity() >>> 1) {
setBytes(0, this, readerIndex, writerIndex - readerIndex); setBytes(0, this, readerIndex, writerIndex - readerIndex);
writerIndex -= readerIndex; writerIndex -= readerIndex;
adjustMarkers(readerIndex);
readerIndex = 0; readerIndex = 0;
} }
return this; return this;
} }
protected final void adjustMarkers(int decrement) {
int markedReaderIndex = this.markedReaderIndex;
if (markedReaderIndex <= decrement) {
this.markedReaderIndex = 0;
int markedWriterIndex = this.markedWriterIndex;
if (markedWriterIndex <= decrement) {
this.markedWriterIndex = 0;
} else {
this.markedWriterIndex = markedWriterIndex - decrement;
}
} else {
this.markedReaderIndex = markedReaderIndex - decrement;
markedWriterIndex -= decrement;
}
}
@Override @Override
public ByteBuf ensureWritable(int minWritableBytes) { public ByteBuf ensureWritable(int minWritableBytes) {
if (minWritableBytes < 0) { if (minWritableBytes < 0) {
@ -1463,8 +1417,4 @@ public abstract class AbstractByteBuf extends ByteBuf {
this.readerIndex = readerIndex; this.readerIndex = readerIndex;
this.writerIndex = writerIndex; this.writerIndex = writerIndex;
} }
final void discardMarks() {
markedReaderIndex = markedWriterIndex = 0;
}
} }

View File

@ -183,15 +183,6 @@ import java.nio.charset.UnsupportedCharsetException;
* For complicated searches, use {@link #forEachByte(int, int, ByteProcessor)} with a {@link ByteProcessor} * For complicated searches, use {@link #forEachByte(int, int, ByteProcessor)} with a {@link ByteProcessor}
* implementation. * implementation.
* *
* <h3>Mark and reset</h3>
*
* There are two marker indexes in every buffer. One is for storing
* {@link #readerIndex() readerIndex} and the other is for storing
* {@link #writerIndex() writerIndex}. You can always reposition one of the
* two indexes by calling a reset method. It works in a similar fashion to
* the mark and reset methods in {@link InputStream} except that there's no
* {@code readlimit}.
*
* <h3>Derived buffers</h3> * <h3>Derived buffers</h3>
* *
* You can create a view of an existing buffer by calling one of the following methods: * You can create a view of an existing buffer by calling one of the following methods:
@ -206,7 +197,7 @@ import java.nio.charset.UnsupportedCharsetException;
* <li>{@link #readRetainedSlice(int)}</li> * <li>{@link #readRetainedSlice(int)}</li>
* </ul> * </ul>
* A derived buffer will have an independent {@link #readerIndex() readerIndex}, * A derived buffer will have an independent {@link #readerIndex() readerIndex},
* {@link #writerIndex() writerIndex} and marker indexes, while it shares * {@link #writerIndex() writerIndex}, while it shares
* other internal data representation, just like a NIO buffer does. * other internal data representation, just like a NIO buffer does.
* <p> * <p>
* In case a completely fresh copy of an existing buffer is required, please * In case a completely fresh copy of an existing buffer is required, please
@ -286,8 +277,8 @@ public abstract class ByteBuf implements ReferenceCounted, Comparable<ByteBuf> {
/** /**
* Returns a buffer with the specified {@code endianness} which shares the whole region, * Returns a buffer with the specified {@code endianness} which shares the whole region,
* indexes, and marks of this buffer. Modifying the content, the indexes, or the marks of the * indexes of this buffer. Modifying the content, the indexes of the
* returned buffer or this buffer affects each other's content, indexes, and marks. If the * returned buffer or this buffer affects each other's content, and indexes. If the
* specified {@code endianness} is identical to this buffer's byte order, this method can * specified {@code endianness} is identical to this buffer's byte order, this method can
* return {@code this}. This method does not modify {@code readerIndex} or {@code writerIndex} * return {@code this}. This method does not modify {@code readerIndex} or {@code writerIndex}
* of this buffer. * of this buffer.
@ -458,42 +449,6 @@ public abstract class ByteBuf implements ReferenceCounted, Comparable<ByteBuf> {
*/ */
public abstract ByteBuf clear(); public abstract ByteBuf clear();
/**
* Marks the current {@code readerIndex} in this buffer. You can
* reposition the current {@code readerIndex} to the marked
* {@code readerIndex} by calling {@link #resetReaderIndex()}.
* The initial value of the marked {@code readerIndex} is {@code 0}.
*/
public abstract ByteBuf markReaderIndex();
/**
* Repositions the current {@code readerIndex} to the marked
* {@code readerIndex} in this buffer.
*
* @throws IndexOutOfBoundsException
* if the current {@code writerIndex} is less than the marked
* {@code readerIndex}
*/
public abstract ByteBuf resetReaderIndex();
/**
* Marks the current {@code writerIndex} in this buffer. You can
* reposition the current {@code writerIndex} to the marked
* {@code writerIndex} by calling {@link #resetWriterIndex()}.
* The initial value of the marked {@code writerIndex} is {@code 0}.
*/
public abstract ByteBuf markWriterIndex();
/**
* Repositions the current {@code writerIndex} to the marked
* {@code writerIndex} in this buffer.
*
* @throws IndexOutOfBoundsException
* if the current {@code readerIndex} is greater than the marked
* {@code writerIndex}
*/
public abstract ByteBuf resetWriterIndex();
/** /**
* Discards the bytes between the 0th index and {@code readerIndex}. * Discards the bytes between the 0th index and {@code readerIndex}.
* It moves the bytes between {@code readerIndex} and {@code writerIndex} * It moves the bytes between {@code readerIndex} and {@code writerIndex}
@ -2186,7 +2141,7 @@ public abstract class ByteBuf implements ReferenceCounted, Comparable<ByteBuf> {
/** /**
* Returns a slice of this buffer's readable bytes. Modifying the content * Returns a slice of this buffer's readable bytes. Modifying the content
* of the returned buffer or this buffer affects each other's content * of the returned buffer or this buffer affects each other's content
* while they maintain separate indexes and marks. This method is * while they maintain separate indexes. This method is
* identical to {@code buf.slice(buf.readerIndex(), buf.readableBytes())}. * identical to {@code buf.slice(buf.readerIndex(), buf.readableBytes())}.
* This method does not modify {@code readerIndex} or {@code writerIndex} of * This method does not modify {@code readerIndex} or {@code writerIndex} of
* this buffer. * this buffer.
@ -2199,7 +2154,7 @@ public abstract class ByteBuf implements ReferenceCounted, Comparable<ByteBuf> {
/** /**
* Returns a retained slice of this buffer's readable bytes. Modifying the content * Returns a retained slice of this buffer's readable bytes. Modifying the content
* of the returned buffer or this buffer affects each other's content * of the returned buffer or this buffer affects each other's content
* while they maintain separate indexes and marks. This method is * while they maintain separate indexes. This method is
* identical to {@code buf.slice(buf.readerIndex(), buf.readableBytes())}. * identical to {@code buf.slice(buf.readerIndex(), buf.readableBytes())}.
* This method does not modify {@code readerIndex} or {@code writerIndex} of * This method does not modify {@code readerIndex} or {@code writerIndex} of
* this buffer. * this buffer.
@ -2213,7 +2168,7 @@ public abstract class ByteBuf implements ReferenceCounted, Comparable<ByteBuf> {
/** /**
* Returns a slice of this buffer's sub-region. Modifying the content of * Returns a slice of this buffer's sub-region. Modifying the content of
* the returned buffer or this buffer affects each other's content while * the returned buffer or this buffer affects each other's content while
* they maintain separate indexes and marks. * they maintain separate indexes.
* This method does not modify {@code readerIndex} or {@code writerIndex} of * This method does not modify {@code readerIndex} or {@code writerIndex} of
* this buffer. * this buffer.
* <p> * <p>
@ -2225,7 +2180,7 @@ public abstract class ByteBuf implements ReferenceCounted, Comparable<ByteBuf> {
/** /**
* Returns a retained slice of this buffer's sub-region. Modifying the content of * Returns a retained slice of this buffer's sub-region. Modifying the content of
* the returned buffer or this buffer affects each other's content while * the returned buffer or this buffer affects each other's content while
* they maintain separate indexes and marks. * they maintain separate indexes.
* This method does not modify {@code readerIndex} or {@code writerIndex} of * This method does not modify {@code readerIndex} or {@code writerIndex} of
* this buffer. * this buffer.
* <p> * <p>
@ -2238,11 +2193,11 @@ public abstract class ByteBuf implements ReferenceCounted, Comparable<ByteBuf> {
/** /**
* Returns a buffer which shares the whole region of this buffer. * Returns a buffer which shares the whole region of this buffer.
* Modifying the content of the returned buffer or this buffer affects * Modifying the content of the returned buffer or this buffer affects
* each other's content while they maintain separate indexes and marks. * each other's content while they maintain separate indexes.
* This method does not modify {@code readerIndex} or {@code writerIndex} of * This method does not modify {@code readerIndex} or {@code writerIndex} of
* this buffer. * this buffer.
* <p> * <p>
* The reader and writer marks will not be duplicated. Also be aware that this method will * Be aware that this method will
* NOT call {@link #retain()} and so the reference count will NOT be increased. * NOT call {@link #retain()} and so the reference count will NOT be increased.
* @return A buffer whose readable content is equivalent to the buffer returned by {@link #slice()}. * @return A buffer whose readable content is equivalent to the buffer returned by {@link #slice()}.
* However this buffer will share the capacity of the underlying buffer, and therefore allows access to all of the * However this buffer will share the capacity of the underlying buffer, and therefore allows access to all of the
@ -2253,7 +2208,7 @@ public abstract class ByteBuf implements ReferenceCounted, Comparable<ByteBuf> {
/** /**
* Returns a retained buffer which shares the whole region of this buffer. * Returns a retained buffer which shares the whole region of this buffer.
* Modifying the content of the returned buffer or this buffer affects * Modifying the content of the returned buffer or this buffer affects
* each other's content while they maintain separate indexes and marks. * each other's content while they maintain separate indexes.
* This method is identical to {@code buf.slice(0, buf.capacity())}. * This method is identical to {@code buf.slice(0, buf.capacity())}.
* This method does not modify {@code readerIndex} or {@code writerIndex} of * This method does not modify {@code readerIndex} or {@code writerIndex} of
* this buffer. * this buffer.
@ -2282,7 +2237,7 @@ public abstract class ByteBuf implements ReferenceCounted, Comparable<ByteBuf> {
/** /**
* Exposes this buffer's readable bytes as an NIO {@link ByteBuffer}. The returned buffer * Exposes this buffer's readable bytes as an NIO {@link ByteBuffer}. The returned buffer
* either share or contains the copied content of this buffer, while changing the position * either share or contains the copied content of this buffer, while changing the position
* and limit of the returned NIO buffer does not affect the indexes and marks of this buffer. * and limit of the returned NIO buffer does not affect the indexes of this buffer.
* This method is identical to {@code buf.nioBuffer(buf.readerIndex(), buf.readableBytes())}. * This method is identical to {@code buf.nioBuffer(buf.readerIndex(), buf.readableBytes())}.
* This method does not modify {@code readerIndex} or {@code writerIndex} of this buffer. * This method does not modify {@code readerIndex} or {@code writerIndex} of this buffer.
* Please note that the returned NIO buffer will not see the changes of this buffer if this buffer * Please note that the returned NIO buffer will not see the changes of this buffer if this buffer
@ -2300,7 +2255,7 @@ public abstract class ByteBuf implements ReferenceCounted, Comparable<ByteBuf> {
/** /**
* Exposes this buffer's sub-region as an NIO {@link ByteBuffer}. The returned buffer * Exposes this buffer's sub-region as an NIO {@link ByteBuffer}. The returned buffer
* either share or contains the copied content of this buffer, while changing the position * either share or contains the copied content of this buffer, while changing the position
* and limit of the returned NIO buffer does not affect the indexes and marks of this buffer. * and limit of the returned NIO buffer does not affect the indexes of this buffer.
* This method does not modify {@code readerIndex} or {@code writerIndex} of this buffer. * This method does not modify {@code readerIndex} or {@code writerIndex} of this buffer.
* Please note that the returned NIO buffer will not see the changes of this buffer if this buffer * Please note that the returned NIO buffer will not see the changes of this buffer if this buffer
* is a dynamic buffer and it adjusted its capacity. * is a dynamic buffer and it adjusted its capacity.
@ -2322,7 +2277,7 @@ public abstract class ByteBuf implements ReferenceCounted, Comparable<ByteBuf> {
/** /**
* Exposes this buffer's readable bytes as an NIO {@link ByteBuffer}'s. The returned buffer * Exposes this buffer's readable bytes as an NIO {@link ByteBuffer}'s. The returned buffer
* either share or contains the copied content of this buffer, while changing the position * either share or contains the copied content of this buffer, while changing the position
* and limit of the returned NIO buffer does not affect the indexes and marks of this buffer. * and limit of the returned NIO buffer does not affect the indexes of this buffer.
* This method does not modify {@code readerIndex} or {@code writerIndex} of this buffer. * This method does not modify {@code readerIndex} or {@code writerIndex} of this buffer.
* Please note that the returned NIO buffer will not see the changes of this buffer if this buffer * Please note that the returned NIO buffer will not see the changes of this buffer if this buffer
* is a dynamic buffer and it adjusted its capacity. * is a dynamic buffer and it adjusted its capacity.
@ -2340,7 +2295,7 @@ public abstract class ByteBuf implements ReferenceCounted, Comparable<ByteBuf> {
/** /**
* Exposes this buffer's bytes as an NIO {@link ByteBuffer}'s for the specified index and length * Exposes this buffer's bytes as an NIO {@link ByteBuffer}'s for the specified index and length
* The returned buffer either share or contains the copied content of this buffer, while changing * The returned buffer either share or contains the copied content of this buffer, while changing
* the position and limit of the returned NIO buffer does not affect the indexes and marks of this buffer. * the position and limit of the returned NIO buffer does not affect the indexes of this buffer.
* This method does not modify {@code readerIndex} or {@code writerIndex} of this buffer. Please note that the * This method does not modify {@code readerIndex} or {@code writerIndex} of this buffer. Please note that the
* returned NIO buffer will not see the changes of this buffer if this buffer is a dynamic * returned NIO buffer will not see the changes of this buffer if this buffer is a dynamic
* buffer and it adjusted its capacity. * buffer and it adjusted its capacity.

View File

@ -45,6 +45,8 @@ public class ByteBufInputStream extends InputStream implements DataInput {
private final int startIndex; private final int startIndex;
private final int endIndex; private final int endIndex;
private boolean closed; private boolean closed;
private int markReaderIndex;
/** /**
* To preserve backwards compatibility (which didn't transfer ownership) we support a conditional flag which * To preserve backwards compatibility (which didn't transfer ownership) we support a conditional flag which
* indicates if {@link #buffer} should be released when this {@link InputStream} is closed. * indicates if {@link #buffer} should be released when this {@link InputStream} is closed.
@ -123,7 +125,7 @@ public class ByteBufInputStream extends InputStream implements DataInput {
this.buffer = buffer; this.buffer = buffer;
startIndex = buffer.readerIndex(); startIndex = buffer.readerIndex();
endIndex = startIndex + length; endIndex = startIndex + length;
buffer.markReaderIndex(); markReaderIndex = startIndex;
} }
/** /**
@ -153,7 +155,7 @@ public class ByteBufInputStream extends InputStream implements DataInput {
@Override @Override
public void mark(int readlimit) { public void mark(int readlimit) {
buffer.markReaderIndex(); markReaderIndex = buffer.readerIndex();
} }
@Override @Override
@ -183,7 +185,7 @@ public class ByteBufInputStream extends InputStream implements DataInput {
@Override @Override
public void reset() throws IOException { public void reset() throws IOException {
buffer.resetReaderIndex(); buffer.readerIndex(markReaderIndex);
} }
@Override @Override

View File

@ -1681,7 +1681,6 @@ public class CompositeByteBuf extends AbstractReferenceCountedByteBuf implements
lastAccessed = null; lastAccessed = null;
clearComps(); clearComps();
setIndex(0, 0); setIndex(0, 0);
adjustMarkers(readerIndex);
return this; return this;
} }
@ -1698,7 +1697,6 @@ public class CompositeByteBuf extends AbstractReferenceCountedByteBuf implements
int offset = first.offset; int offset = first.offset;
updateComponentOffsets(0); updateComponentOffsets(0);
setIndex(readerIndex - offset, writerIndex - offset); setIndex(readerIndex - offset, writerIndex - offset);
adjustMarkers(offset);
return this; return this;
} }
@ -1719,7 +1717,6 @@ public class CompositeByteBuf extends AbstractReferenceCountedByteBuf implements
lastAccessed = null; lastAccessed = null;
clearComps(); clearComps();
setIndex(0, 0); setIndex(0, 0);
adjustMarkers(readerIndex);
return this; return this;
} }
@ -1754,7 +1751,6 @@ public class CompositeByteBuf extends AbstractReferenceCountedByteBuf implements
// Update indexes and markers. // Update indexes and markers.
updateComponentOffsets(0); updateComponentOffsets(0);
setIndex(0, writerIndex - readerIndex); setIndex(0, writerIndex - readerIndex);
adjustMarkers(readerIndex);
return this; return this;
} }
@ -1852,30 +1848,6 @@ public class CompositeByteBuf extends AbstractReferenceCountedByteBuf implements
return this; return this;
} }
@Override
public CompositeByteBuf markReaderIndex() {
super.markReaderIndex();
return this;
}
@Override
public CompositeByteBuf resetReaderIndex() {
super.resetReaderIndex();
return this;
}
@Override
public CompositeByteBuf markWriterIndex() {
super.markWriterIndex();
return this;
}
@Override
public CompositeByteBuf resetWriterIndex() {
super.resetWriterIndex();
return this;
}
@Override @Override
public CompositeByteBuf ensureWritable(int minWritableBytes) { public CompositeByteBuf ensureWritable(int minWritableBytes) {
super.ensureWritable(minWritableBytes); super.ensureWritable(minWritableBytes);

View File

@ -54,8 +54,6 @@ public class DuplicatedByteBuf extends AbstractDerivedByteBuf {
} }
setIndex(readerIndex, writerIndex); setIndex(readerIndex, writerIndex);
markReaderIndex();
markWriterIndex();
} }
@Override @Override

View File

@ -191,26 +191,6 @@ public final class EmptyByteBuf extends ByteBuf {
return this; return this;
} }
@Override
public ByteBuf markReaderIndex() {
return this;
}
@Override
public ByteBuf resetReaderIndex() {
return this;
}
@Override
public ByteBuf markWriterIndex() {
return this;
}
@Override
public ByteBuf resetWriterIndex() {
return this;
}
@Override @Override
public ByteBuf discardReadBytes() { public ByteBuf discardReadBytes() {
return this; return this;

View File

@ -74,7 +74,6 @@ abstract class PooledByteBuf<T> extends AbstractReferenceCountedByteBuf {
maxCapacity(maxCapacity); maxCapacity(maxCapacity);
setRefCnt(1); setRefCnt(1);
setIndex0(0, 0); setIndex0(0, 0);
discardMarks();
} }
@Override @Override

View File

@ -41,9 +41,6 @@ final class PooledDuplicatedByteBuf extends AbstractPooledDerivedByteBuf {
int readerIndex, int writerIndex) { int readerIndex, int writerIndex) {
final PooledDuplicatedByteBuf duplicate = RECYCLER.get(); final PooledDuplicatedByteBuf duplicate = RECYCLER.get();
duplicate.init(unwrapped, wrapped, readerIndex, writerIndex, unwrapped.maxCapacity()); duplicate.init(unwrapped, wrapped, readerIndex, writerIndex, unwrapped.maxCapacity());
duplicate.markReaderIndex();
duplicate.markWriterIndex();
return duplicate; return duplicate;
} }

View File

@ -49,7 +49,6 @@ final class PooledSlicedByteBuf extends AbstractPooledDerivedByteBuf {
int adjustment, int length) { int adjustment, int length) {
final PooledSlicedByteBuf slice = RECYCLER.get(); final PooledSlicedByteBuf slice = RECYCLER.get();
slice.init(unwrapped, wrapped, 0, length, length); slice.init(unwrapped, wrapped, 0, length, length);
slice.discardMarks();
slice.adjustment = adjustment; slice.adjustment = adjustment;
return slice; return slice;

View File

@ -177,30 +177,6 @@ public class SwappedByteBuf extends ByteBuf {
return this; return this;
} }
@Override
public ByteBuf markReaderIndex() {
buf.markReaderIndex();
return this;
}
@Override
public ByteBuf resetReaderIndex() {
buf.resetReaderIndex();
return this;
}
@Override
public ByteBuf markWriterIndex() {
buf.markWriterIndex();
return this;
}
@Override
public ByteBuf resetWriterIndex() {
buf.resetWriterIndex();
return this;
}
@Override @Override
public ByteBuf discardReadBytes() { public ByteBuf discardReadBytes() {
buf.discardReadBytes(); buf.discardReadBytes();

View File

@ -167,30 +167,6 @@ class WrappedByteBuf extends ByteBuf {
return this; return this;
} }
@Override
public final ByteBuf markReaderIndex() {
buf.markReaderIndex();
return this;
}
@Override
public final ByteBuf resetReaderIndex() {
buf.resetReaderIndex();
return this;
}
@Override
public final ByteBuf markWriterIndex() {
buf.markWriterIndex();
return this;
}
@Override
public final ByteBuf resetWriterIndex() {
buf.resetWriterIndex();
return this;
}
@Override @Override
public ByteBuf discardReadBytes() { public ByteBuf discardReadBytes() {
buf.discardReadBytes(); buf.discardReadBytes();

View File

@ -921,30 +921,6 @@ class WrappedCompositeByteBuf extends CompositeByteBuf {
return this; return this;
} }
@Override
public final CompositeByteBuf markReaderIndex() {
wrapped.markReaderIndex();
return this;
}
@Override
public final CompositeByteBuf resetReaderIndex() {
wrapped.resetReaderIndex();
return this;
}
@Override
public final CompositeByteBuf markWriterIndex() {
wrapped.markWriterIndex();
return this;
}
@Override
public final CompositeByteBuf resetWriterIndex() {
wrapped.resetWriterIndex();
return this;
}
@Override @Override
public CompositeByteBuf ensureWritable(int minWritableBytes) { public CompositeByteBuf ensureWritable(int minWritableBytes) {
wrapped.ensureWritable(minWritableBytes); wrapped.ensureWritable(minWritableBytes);

View File

@ -1775,9 +1775,9 @@ public abstract class AbstractByteBufTest {
// Make sure there's no effect if called when readerIndex is 0. // Make sure there's no effect if called when readerIndex is 0.
buffer.readerIndex(CAPACITY / 4); buffer.readerIndex(CAPACITY / 4);
buffer.markReaderIndex(); int readerIndex = buffer.readerIndex();
buffer.writerIndex(CAPACITY / 3); buffer.writerIndex(CAPACITY / 3);
buffer.markWriterIndex(); int writerIndex = buffer.writerIndex();
buffer.readerIndex(0); buffer.readerIndex(0);
buffer.writerIndex(CAPACITY / 2); buffer.writerIndex(CAPACITY / 2);
buffer.discardReadBytes(); buffer.discardReadBytes();
@ -1785,9 +1785,9 @@ public abstract class AbstractByteBufTest {
assertEquals(0, buffer.readerIndex()); assertEquals(0, buffer.readerIndex());
assertEquals(CAPACITY / 2, buffer.writerIndex()); assertEquals(CAPACITY / 2, buffer.writerIndex());
assertEquals(copy.slice(0, CAPACITY / 2), buffer.slice(0, CAPACITY / 2)); assertEquals(copy.slice(0, CAPACITY / 2), buffer.slice(0, CAPACITY / 2));
buffer.resetReaderIndex(); buffer.readerIndex(readerIndex);
assertEquals(CAPACITY / 4, buffer.readerIndex()); assertEquals(CAPACITY / 4, buffer.readerIndex());
buffer.resetWriterIndex(); buffer.writerIndex(writerIndex);
assertEquals(CAPACITY / 3, buffer.writerIndex()); assertEquals(CAPACITY / 3, buffer.writerIndex());
// Make sure bytes after writerIndex is not copied. // Make sure bytes after writerIndex is not copied.
@ -1806,11 +1806,6 @@ public abstract class AbstractByteBufTest {
assertEquals(copy.slice(CAPACITY / 2, CAPACITY / 2), buffer.slice(CAPACITY / 2 - 1, CAPACITY / 2)); assertEquals(copy.slice(CAPACITY / 2, CAPACITY / 2), buffer.slice(CAPACITY / 2 - 1, CAPACITY / 2));
} }
// Marks also should be relocated.
buffer.resetReaderIndex();
assertEquals(CAPACITY / 4 - 1, buffer.readerIndex());
buffer.resetWriterIndex();
assertEquals(CAPACITY / 3 - 1, buffer.writerIndex());
copy.release(); copy.release();
} }
@ -3742,11 +3737,11 @@ public abstract class AbstractByteBufTest {
@Test @Test
public void testRetainedSliceAndRetainedDuplicateContentIsExpected() { public void testRetainedSliceAndRetainedDuplicateContentIsExpected() {
ByteBuf buf = newBuffer(8).resetWriterIndex(); ByteBuf buf = newBuffer(8).writerIndex(0);
ByteBuf expected1 = newBuffer(6).resetWriterIndex(); ByteBuf expected1 = newBuffer(6).writerIndex(0);
ByteBuf expected2 = newBuffer(5).resetWriterIndex(); ByteBuf expected2 = newBuffer(5).writerIndex(0);
ByteBuf expected3 = newBuffer(4).resetWriterIndex(); ByteBuf expected3 = newBuffer(4).writerIndex(0);
ByteBuf expected4 = newBuffer(3).resetWriterIndex(); ByteBuf expected4 = newBuffer(3).writerIndex(0);
buf.writeBytes(new byte[] {1, 2, 3, 4, 5, 6, 7, 8}); buf.writeBytes(new byte[] {1, 2, 3, 4, 5, 6, 7, 8});
expected1.writeBytes(new byte[] {2, 3, 4, 5, 6, 7}); expected1.writeBytes(new byte[] {2, 3, 4, 5, 6, 7});
expected2.writeBytes(new byte[] {3, 4, 5, 6, 7}); expected2.writeBytes(new byte[] {3, 4, 5, 6, 7});
@ -3805,10 +3800,10 @@ public abstract class AbstractByteBufTest {
@Test @Test
public void testRetainedDuplicateAndRetainedSliceContentIsExpected() { public void testRetainedDuplicateAndRetainedSliceContentIsExpected() {
ByteBuf buf = newBuffer(8).resetWriterIndex(); ByteBuf buf = newBuffer(8).writerIndex(0);
ByteBuf expected1 = newBuffer(6).resetWriterIndex(); ByteBuf expected1 = newBuffer(6).writerIndex(0);
ByteBuf expected2 = newBuffer(5).resetWriterIndex(); ByteBuf expected2 = newBuffer(5).writerIndex(0);
ByteBuf expected3 = newBuffer(4).resetWriterIndex(); ByteBuf expected3 = newBuffer(4).writerIndex(0);
buf.writeBytes(new byte[] {1, 2, 3, 4, 5, 6, 7, 8}); buf.writeBytes(new byte[] {1, 2, 3, 4, 5, 6, 7, 8});
expected1.writeBytes(new byte[] {2, 3, 4, 5, 6, 7}); expected1.writeBytes(new byte[] {2, 3, 4, 5, 6, 7});
expected2.writeBytes(new byte[] {3, 4, 5, 6, 7}); expected2.writeBytes(new byte[] {3, 4, 5, 6, 7});
@ -4157,8 +4152,8 @@ public abstract class AbstractByteBufTest {
} }
private void testSliceContents(boolean retainedSlice) { private void testSliceContents(boolean retainedSlice) {
ByteBuf buf = newBuffer(8).resetWriterIndex(); ByteBuf buf = newBuffer(8).writerIndex(0);
ByteBuf expected = newBuffer(3).resetWriterIndex(); ByteBuf expected = newBuffer(3).writerIndex(0);
buf.writeBytes(new byte[] {1, 2, 3, 4, 5, 6, 7, 8}); buf.writeBytes(new byte[] {1, 2, 3, 4, 5, 6, 7, 8});
expected.writeBytes(new byte[] {4, 5, 6}); expected.writeBytes(new byte[] {4, 5, 6});
ByteBuf slice = retainedSlice ? buf.retainedSlice(buf.readerIndex() + 3, 3) ByteBuf slice = retainedSlice ? buf.retainedSlice(buf.readerIndex() + 3, 3)
@ -4180,9 +4175,9 @@ public abstract class AbstractByteBufTest {
} }
private void testSliceReleaseOriginal(boolean retainedSlice1, boolean retainedSlice2) { private void testSliceReleaseOriginal(boolean retainedSlice1, boolean retainedSlice2) {
ByteBuf buf = newBuffer(8).resetWriterIndex(); ByteBuf buf = newBuffer(8).writerIndex(0);
ByteBuf expected1 = newBuffer(3).resetWriterIndex(); ByteBuf expected1 = newBuffer(3).writerIndex(0);
ByteBuf expected2 = newBuffer(2).resetWriterIndex(); ByteBuf expected2 = newBuffer(2).writerIndex(0);
buf.writeBytes(new byte[] {1, 2, 3, 4, 5, 6, 7, 8}); buf.writeBytes(new byte[] {1, 2, 3, 4, 5, 6, 7, 8});
expected1.writeBytes(new byte[] {6, 7, 8}); expected1.writeBytes(new byte[] {6, 7, 8});
expected2.writeBytes(new byte[] {7, 8}); expected2.writeBytes(new byte[] {7, 8});
@ -4214,12 +4209,12 @@ public abstract class AbstractByteBufTest {
} }
private void testMultipleLevelRetainedSliceWithNonRetained(boolean doSlice1, boolean doSlice2) { private void testMultipleLevelRetainedSliceWithNonRetained(boolean doSlice1, boolean doSlice2) {
ByteBuf buf = newBuffer(8).resetWriterIndex(); ByteBuf buf = newBuffer(8).writerIndex(0);
ByteBuf expected1 = newBuffer(6).resetWriterIndex(); ByteBuf expected1 = newBuffer(6).writerIndex(0);
ByteBuf expected2 = newBuffer(4).resetWriterIndex(); ByteBuf expected2 = newBuffer(4).writerIndex(0);
ByteBuf expected3 = newBuffer(2).resetWriterIndex(); ByteBuf expected3 = newBuffer(2).writerIndex(0);
ByteBuf expected4SliceSlice = newBuffer(1).resetWriterIndex(); ByteBuf expected4SliceSlice = newBuffer(1).writerIndex(0);
ByteBuf expected4DupSlice = newBuffer(1).resetWriterIndex(); ByteBuf expected4DupSlice = newBuffer(1).writerIndex(0);
buf.writeBytes(new byte[] {1, 2, 3, 4, 5, 6, 7, 8}); buf.writeBytes(new byte[] {1, 2, 3, 4, 5, 6, 7, 8});
expected1.writeBytes(new byte[] {2, 3, 4, 5, 6, 7}); expected1.writeBytes(new byte[] {2, 3, 4, 5, 6, 7});
expected2.writeBytes(new byte[] {3, 4, 5, 6}); expected2.writeBytes(new byte[] {3, 4, 5, 6});
@ -4284,8 +4279,8 @@ public abstract class AbstractByteBufTest {
} }
private void testDuplicateReleaseOriginal(boolean retainedDuplicate1, boolean retainedDuplicate2) { private void testDuplicateReleaseOriginal(boolean retainedDuplicate1, boolean retainedDuplicate2) {
ByteBuf buf = newBuffer(8).resetWriterIndex(); ByteBuf buf = newBuffer(8).writerIndex(0);
ByteBuf expected = newBuffer(8).resetWriterIndex(); ByteBuf expected = newBuffer(8).writerIndex(0);
buf.writeBytes(new byte[] {1, 2, 3, 4, 5, 6, 7, 8}); buf.writeBytes(new byte[] {1, 2, 3, 4, 5, 6, 7, 8});
expected.writeBytes(buf, buf.readerIndex(), buf.readableBytes()); expected.writeBytes(buf, buf.readerIndex(), buf.readableBytes());
ByteBuf dup1 = retainedDuplicate1 ? buf.retainedDuplicate() ByteBuf dup1 = retainedDuplicate1 ? buf.retainedDuplicate()
@ -4315,10 +4310,10 @@ public abstract class AbstractByteBufTest {
} }
private void testMultipleRetainedSliceReleaseOriginal(boolean retainedSlice1, boolean retainedSlice2) { private void testMultipleRetainedSliceReleaseOriginal(boolean retainedSlice1, boolean retainedSlice2) {
ByteBuf buf = newBuffer(8).resetWriterIndex(); ByteBuf buf = newBuffer(8).writerIndex(0);
ByteBuf expected1 = newBuffer(3).resetWriterIndex(); ByteBuf expected1 = newBuffer(3).writerIndex(0);
ByteBuf expected2 = newBuffer(2).resetWriterIndex(); ByteBuf expected2 = newBuffer(2).writerIndex(0);
ByteBuf expected3 = newBuffer(2).resetWriterIndex(); ByteBuf expected3 = newBuffer(2).writerIndex(0);
buf.writeBytes(new byte[] {1, 2, 3, 4, 5, 6, 7, 8}); buf.writeBytes(new byte[] {1, 2, 3, 4, 5, 6, 7, 8});
expected1.writeBytes(new byte[] {6, 7, 8}); expected1.writeBytes(new byte[] {6, 7, 8});
expected2.writeBytes(new byte[] {7, 8}); expected2.writeBytes(new byte[] {7, 8});
@ -4359,8 +4354,8 @@ public abstract class AbstractByteBufTest {
} }
private void testMultipleRetainedDuplicateReleaseOriginal(boolean retainedDuplicate1, boolean retainedDuplicate2) { private void testMultipleRetainedDuplicateReleaseOriginal(boolean retainedDuplicate1, boolean retainedDuplicate2) {
ByteBuf buf = newBuffer(8).resetWriterIndex(); ByteBuf buf = newBuffer(8).writerIndex(0);
ByteBuf expected = newBuffer(8).resetWriterIndex(); ByteBuf expected = newBuffer(8).writerIndex(0);
buf.writeBytes(new byte[] {1, 2, 3, 4, 5, 6, 7, 8}); buf.writeBytes(new byte[] {1, 2, 3, 4, 5, 6, 7, 8});
expected.writeBytes(buf, buf.readerIndex(), buf.readableBytes()); expected.writeBytes(buf, buf.readerIndex(), buf.readableBytes());
ByteBuf dup1 = retainedDuplicate1 ? buf.retainedDuplicate() ByteBuf dup1 = retainedDuplicate1 ? buf.retainedDuplicate()
@ -4406,7 +4401,7 @@ public abstract class AbstractByteBufTest {
} }
private void testDuplicateContents(boolean retainedDuplicate) { private void testDuplicateContents(boolean retainedDuplicate) {
ByteBuf buf = newBuffer(8).resetWriterIndex(); ByteBuf buf = newBuffer(8).writerIndex(0);
buf.writeBytes(new byte[] {1, 2, 3, 4, 5, 6, 7, 8}); buf.writeBytes(new byte[] {1, 2, 3, 4, 5, 6, 7, 8});
ByteBuf dup = retainedDuplicate ? buf.retainedDuplicate() : buf.duplicate(); ByteBuf dup = retainedDuplicate ? buf.retainedDuplicate() : buf.duplicate();
try { try {
@ -4497,9 +4492,7 @@ public abstract class AbstractByteBufTest {
byte[] bytes = {'a', 'b', 'c', 'd'}; byte[] bytes = {'a', 'b', 'c', 'd'};
int len = bytes.length; int len = bytes.length;
ByteBuf buffer = newBuffer(len); ByteBuf buffer = newBuffer(len).writerIndex(0);
buffer.resetReaderIndex();
buffer.resetWriterIndex();
buffer.writeBytes(bytes); buffer.writeBytes(bytes);
int oldReaderIndex = buffer.readerIndex(); int oldReaderIndex = buffer.readerIndex();
@ -4507,9 +4500,7 @@ public abstract class AbstractByteBufTest {
assertEquals(oldReaderIndex + len, buffer.readerIndex()); assertEquals(oldReaderIndex + len, buffer.readerIndex());
assertEquals(channelPosition, channel.position()); assertEquals(channelPosition, channel.position());
ByteBuf buffer2 = newBuffer(len); ByteBuf buffer2 = newBuffer(len).writerIndex(0);
buffer2.resetReaderIndex();
buffer2.resetWriterIndex();
int oldWriterIndex = buffer2.writerIndex(); int oldWriterIndex = buffer2.writerIndex();
assertEquals(len, buffer2.writeBytes(channel, 10, len)); assertEquals(len, buffer2.writeBytes(channel, 10, len));
assertEquals(channelPosition, channel.position()); assertEquals(channelPosition, channel.position());
@ -4540,9 +4531,7 @@ public abstract class AbstractByteBufTest {
byte[] bytes = {'a', 'b', 'c', 'd'}; byte[] bytes = {'a', 'b', 'c', 'd'};
int len = bytes.length; int len = bytes.length;
ByteBuf buffer = newBuffer(len); ByteBuf buffer = newBuffer(len).writerIndex(0);
buffer.resetReaderIndex();
buffer.resetWriterIndex();
buffer.writeBytes(bytes); buffer.writeBytes(bytes);
int oldReaderIndex = buffer.readerIndex(); int oldReaderIndex = buffer.readerIndex();
@ -4550,9 +4539,7 @@ public abstract class AbstractByteBufTest {
assertEquals(oldReaderIndex, buffer.readerIndex()); assertEquals(oldReaderIndex, buffer.readerIndex());
assertEquals(channelPosition, channel.position()); assertEquals(channelPosition, channel.position());
ByteBuf buffer2 = newBuffer(len); ByteBuf buffer2 = newBuffer(len).writerIndex(0);
buffer2.resetReaderIndex();
buffer2.resetWriterIndex();
int oldWriterIndex = buffer2.writerIndex(); int oldWriterIndex = buffer2.writerIndex();
assertEquals(buffer2.setBytes(oldWriterIndex, channel, 10, len), len); assertEquals(buffer2.setBytes(oldWriterIndex, channel, 10, len), len);
assertEquals(channelPosition, channel.position()); assertEquals(channelPosition, channel.position());
@ -4866,14 +4853,13 @@ public abstract class AbstractByteBufTest {
ByteBuf buffer = newBuffer(length); ByteBuf buffer = newBuffer(length);
buffer.setIndex(0, 0); buffer.setIndex(0, 0);
buffer.writeCharSequence(content1, CharsetUtil.US_ASCII); buffer.writeCharSequence(content1, CharsetUtil.US_ASCII);
buffer.markWriterIndex();
buffer.skipBytes(content1.length()); buffer.skipBytes(content1.length());
buffer.writeCharSequence(content2, CharsetUtil.US_ASCII); buffer.writeCharSequence(content2, CharsetUtil.US_ASCII);
buffer.skipBytes(content2.length()); buffer.skipBytes(content2.length());
assertTrue(buffer.readerIndex() <= buffer.writerIndex()); assertTrue(buffer.readerIndex() <= buffer.writerIndex());
try { try {
buffer.resetWriterIndex(); buffer.readerIndex(buffer.writerIndex() + 1);
} finally { } finally {
buffer.release(); buffer.release();
} }

View File

@ -143,17 +143,13 @@ public abstract class AbstractCompositeByteBufTest extends AbstractByteBufTest {
wrappedBuffer(new byte[] { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 }, 0, 5).order(order), wrappedBuffer(new byte[] { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 }, 0, 5).order(order),
wrappedBuffer(new byte[] { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 }, 5, 5).order(order)); wrappedBuffer(new byte[] { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 }, 5, 5).order(order));
a.skipBytes(6); a.skipBytes(6);
a.markReaderIndex();
b.skipBytes(6); b.skipBytes(6);
b.markReaderIndex();
assertEquals(a.readerIndex(), b.readerIndex()); assertEquals(a.readerIndex(), b.readerIndex());
a.readerIndex(a.readerIndex() - 1); a.readerIndex(a.readerIndex() - 1);
b.readerIndex(b.readerIndex() - 1); b.readerIndex(b.readerIndex() - 1);
assertEquals(a.readerIndex(), b.readerIndex()); assertEquals(a.readerIndex(), b.readerIndex());
a.writerIndex(a.writerIndex() - 1); a.writerIndex(a.writerIndex() - 1);
a.markWriterIndex();
b.writerIndex(b.writerIndex() - 1); b.writerIndex(b.writerIndex() - 1);
b.markWriterIndex();
assertEquals(a.writerIndex(), b.writerIndex()); assertEquals(a.writerIndex(), b.writerIndex());
a.writerIndex(a.writerIndex() + 1); a.writerIndex(a.writerIndex() + 1);
b.writerIndex(b.writerIndex() + 1); b.writerIndex(b.writerIndex() + 1);
@ -165,12 +161,6 @@ public abstract class AbstractCompositeByteBufTest extends AbstractByteBufTest {
assertEquals(a.readerIndex(), b.readerIndex()); assertEquals(a.readerIndex(), b.readerIndex());
assertEquals(a.writerIndex(), b.writerIndex()); assertEquals(a.writerIndex(), b.writerIndex());
assertTrue(ByteBufUtil.equals(a, b)); assertTrue(ByteBufUtil.equals(a, b));
a.resetReaderIndex();
b.resetReaderIndex();
assertEquals(a.readerIndex(), b.readerIndex());
a.resetWriterIndex();
b.resetWriterIndex();
assertEquals(a.writerIndex(), b.writerIndex());
assertTrue(ByteBufUtil.equals(a, b)); assertTrue(ByteBufUtil.equals(a, b));
a.release(); a.release();

View File

@ -31,11 +31,7 @@ public abstract class AbstractPooledByteBufTest extends AbstractByteBufTest {
protected ByteBuf newBuffer(int length, int maxCapacity) { protected ByteBuf newBuffer(int length, int maxCapacity) {
ByteBuf buffer = alloc(length, maxCapacity); ByteBuf buffer = alloc(length, maxCapacity);
// Testing if the writerIndex and readerIndex are correct when allocate and also after we reset the mark. // Testing if the writerIndex and readerIndex are correct when allocate.
assertEquals(0, buffer.writerIndex());
assertEquals(0, buffer.readerIndex());
buffer.resetReaderIndex();
buffer.resetWriterIndex();
assertEquals(0, buffer.writerIndex()); assertEquals(0, buffer.writerIndex());
assertEquals(0, buffer.readerIndex()); assertEquals(0, buffer.readerIndex());
return buffer; return buffer;

View File

@ -142,14 +142,14 @@ public class ByteBufUtilTest {
ByteBuf buf = Unpooled.buffer(2).order(ByteOrder.BIG_ENDIAN); ByteBuf buf = Unpooled.buffer(2).order(ByteOrder.BIG_ENDIAN);
ByteBufUtil.writeShortBE(buf, expected); ByteBufUtil.writeShortBE(buf, expected);
assertEquals(expected, buf.readShort()); assertEquals(expected, buf.readShort());
buf.resetReaderIndex(); buf.readerIndex(0);
assertEquals(ByteBufUtil.swapShort((short) expected), buf.readShortLE()); assertEquals(ByteBufUtil.swapShort((short) expected), buf.readShortLE());
buf.release(); buf.release();
buf = Unpooled.buffer(2).order(ByteOrder.LITTLE_ENDIAN); buf = Unpooled.buffer(2).order(ByteOrder.LITTLE_ENDIAN);
ByteBufUtil.writeShortBE(buf, expected); ByteBufUtil.writeShortBE(buf, expected);
assertEquals((short) expected, buf.readShortLE()); assertEquals((short) expected, buf.readShortLE());
buf.resetReaderIndex(); buf.readerIndex(0);
assertEquals(ByteBufUtil.swapShort((short) expected), buf.readShort()); assertEquals(ByteBufUtil.swapShort((short) expected), buf.readShort());
buf.release(); buf.release();
} }
@ -162,14 +162,14 @@ public class ByteBufUtilTest {
ByteBuf buf = Unpooled.wrappedBuffer(new byte[2]).order(ByteOrder.BIG_ENDIAN); ByteBuf buf = Unpooled.wrappedBuffer(new byte[2]).order(ByteOrder.BIG_ENDIAN);
ByteBufUtil.setShortBE(buf, 0, shortValue); ByteBufUtil.setShortBE(buf, 0, shortValue);
assertEquals(shortValue, buf.readShort()); assertEquals(shortValue, buf.readShort());
buf.resetReaderIndex(); buf.readerIndex(0);
assertEquals(ByteBufUtil.swapShort((short) shortValue), buf.readShortLE()); assertEquals(ByteBufUtil.swapShort((short) shortValue), buf.readShortLE());
buf.release(); buf.release();
buf = Unpooled.wrappedBuffer(new byte[2]).order(ByteOrder.LITTLE_ENDIAN); buf = Unpooled.wrappedBuffer(new byte[2]).order(ByteOrder.LITTLE_ENDIAN);
ByteBufUtil.setShortBE(buf, 0, shortValue); ByteBufUtil.setShortBE(buf, 0, shortValue);
assertEquals((short) shortValue, buf.readShortLE()); assertEquals((short) shortValue, buf.readShortLE());
buf.resetReaderIndex(); buf.readerIndex(0);
assertEquals(ByteBufUtil.swapShort((short) shortValue), buf.readShort()); assertEquals(ByteBufUtil.swapShort((short) shortValue), buf.readShort());
buf.release(); buf.release();
} }
@ -182,14 +182,14 @@ public class ByteBufUtilTest {
ByteBuf buf = Unpooled.buffer(4).order(ByteOrder.BIG_ENDIAN); ByteBuf buf = Unpooled.buffer(4).order(ByteOrder.BIG_ENDIAN);
ByteBufUtil.writeMediumBE(buf, mediumValue); ByteBufUtil.writeMediumBE(buf, mediumValue);
assertEquals(mediumValue, buf.readMedium()); assertEquals(mediumValue, buf.readMedium());
buf.resetReaderIndex(); buf.readerIndex(0);
assertEquals(ByteBufUtil.swapMedium(mediumValue), buf.readMediumLE()); assertEquals(ByteBufUtil.swapMedium(mediumValue), buf.readMediumLE());
buf.release(); buf.release();
buf = Unpooled.buffer(4).order(ByteOrder.LITTLE_ENDIAN); buf = Unpooled.buffer(4).order(ByteOrder.LITTLE_ENDIAN);
ByteBufUtil.writeMediumBE(buf, mediumValue); ByteBufUtil.writeMediumBE(buf, mediumValue);
assertEquals(mediumValue, buf.readMediumLE()); assertEquals(mediumValue, buf.readMediumLE());
buf.resetReaderIndex(); buf.readerIndex(0);
assertEquals(ByteBufUtil.swapMedium(mediumValue), buf.readMedium()); assertEquals(ByteBufUtil.swapMedium(mediumValue), buf.readMedium());
buf.release(); buf.release();
} }

View File

@ -50,26 +50,4 @@ public class DuplicatedByteBufTest extends AbstractByteBufTest {
assertEquals((byte) 0, buffer.readByte()); assertEquals((byte) 0, buffer.readByte());
} }
@Test
public void testMarksInitialized() {
ByteBuf wrapped = Unpooled.buffer(8);
try {
wrapped.writerIndex(6);
wrapped.readerIndex(1);
ByteBuf duplicate = new DuplicatedByteBuf(wrapped);
// Test writer mark
duplicate.writerIndex(duplicate.writerIndex() + 1);
duplicate.resetWriterIndex();
assertEquals(wrapped.writerIndex(), duplicate.writerIndex());
// Test reader mark
duplicate.readerIndex(duplicate.readerIndex() + 1);
duplicate.resetReaderIndex();
assertEquals(wrapped.readerIndex(), duplicate.readerIndex());
} finally {
wrapped.release();
}
}
} }

View File

@ -147,23 +147,21 @@ public class SlicedByteBufTest extends AbstractByteBufTest {
} }
@Test @Test
public void testReaderIndexAndMarks() { public void testReaderIndex() {
ByteBuf wrapped = Unpooled.buffer(16); ByteBuf wrapped = Unpooled.buffer(16);
try { try {
wrapped.writerIndex(14); wrapped.writerIndex(14);
wrapped.readerIndex(2); wrapped.readerIndex(2);
wrapped.markWriterIndex();
wrapped.markReaderIndex();
ByteBuf slice = wrapped.slice(4, 4); ByteBuf slice = wrapped.slice(4, 4);
assertEquals(0, slice.readerIndex()); assertEquals(0, slice.readerIndex());
assertEquals(4, slice.writerIndex()); assertEquals(4, slice.writerIndex());
slice.readerIndex(slice.readerIndex() + 1); slice.readerIndex(slice.readerIndex() + 1);
slice.resetReaderIndex(); slice.readerIndex(0);
assertEquals(0, slice.readerIndex()); assertEquals(0, slice.readerIndex());
slice.writerIndex(slice.writerIndex() - 1); slice.writerIndex(slice.writerIndex() - 1);
slice.resetWriterIndex(); slice.writerIndex(0);
assertEquals(0, slice.writerIndex()); assertEquals(0, slice.writerIndex());
} finally { } finally {
wrapped.release(); wrapped.release();

View File

@ -41,8 +41,8 @@ public class HttpRequestEncoderTest {
return new ByteBuf[]{ return new ByteBuf[]{
Unpooled.buffer(128).order(ByteOrder.BIG_ENDIAN), Unpooled.buffer(128).order(ByteOrder.BIG_ENDIAN),
Unpooled.buffer(128).order(ByteOrder.LITTLE_ENDIAN), Unpooled.buffer(128).order(ByteOrder.LITTLE_ENDIAN),
Unpooled.wrappedBuffer(ByteBuffer.allocate(128).order(ByteOrder.BIG_ENDIAN)).resetWriterIndex(), Unpooled.wrappedBuffer(ByteBuffer.allocate(128).order(ByteOrder.BIG_ENDIAN)).writerIndex(0),
Unpooled.wrappedBuffer(ByteBuffer.allocate(128).order(ByteOrder.LITTLE_ENDIAN)).resetWriterIndex() Unpooled.wrappedBuffer(ByteBuffer.allocate(128).order(ByteOrder.LITTLE_ENDIAN)).writerIndex(0)
}; };
} }

View File

@ -255,7 +255,7 @@ public class DataCompressionHttp2Test {
} }
}); });
awaitServer(); awaitServer();
assertEquals(data.resetReaderIndex().toString(CharsetUtil.UTF_8), assertEquals(data.readerIndex(0).toString(CharsetUtil.UTF_8),
serverOut.toString(CharsetUtil.UTF_8.name())); serverOut.toString(CharsetUtil.UTF_8.name()));
} finally { } finally {
data.release(); data.release();

View File

@ -200,7 +200,7 @@ public class Http2MultiplexCodecBuilderTest {
Http2DataFrame dataFrame = serverLastInboundHandler.blockingReadInbound(); Http2DataFrame dataFrame = serverLastInboundHandler.blockingReadInbound();
assertNotNull(dataFrame); assertNotNull(dataFrame);
assertEquals(3, dataFrame.stream().id()); assertEquals(3, dataFrame.stream().id());
assertEquals(data.resetReaderIndex(), dataFrame.content()); assertEquals(data.readerIndex(0), dataFrame.content());
assertTrue(dataFrame.isEndStream()); assertTrue(dataFrame.isEndStream());
dataFrame.release(); dataFrame.release();

View File

@ -89,7 +89,7 @@ public class SocksCmdRequestTest {
ByteBuf buffer = Unpooled.buffer(16); ByteBuf buffer = Unpooled.buffer(16);
rq.encodeAsByteBuf(buffer); rq.encodeAsByteBuf(buffer);
buffer.resetReaderIndex(); buffer.readerIndex(0);
assertEquals(SocksProtocolVersion.SOCKS5.byteValue(), buffer.readByte()); assertEquals(SocksProtocolVersion.SOCKS5.byteValue(), buffer.readByte());
assertEquals(SocksCmdType.BIND.byteValue(), buffer.readByte()); assertEquals(SocksCmdType.BIND.byteValue(), buffer.readByte());
assertEquals((byte) 0x00, buffer.readByte()); assertEquals((byte) 0x00, buffer.readByte());
@ -111,7 +111,7 @@ public class SocksCmdRequestTest {
ByteBuf buffer = Unpooled.buffer(24); ByteBuf buffer = Unpooled.buffer(24);
rq.encodeAsByteBuf(buffer); rq.encodeAsByteBuf(buffer);
buffer.resetReaderIndex(); buffer.readerIndex(0);
assertEquals(SocksProtocolVersion.SOCKS5.byteValue(), buffer.readByte()); assertEquals(SocksProtocolVersion.SOCKS5.byteValue(), buffer.readByte());
assertEquals(SocksCmdType.BIND.byteValue(), buffer.readByte()); assertEquals(SocksCmdType.BIND.byteValue(), buffer.readByte());
assertEquals((byte) 0x00, buffer.readByte()); assertEquals((byte) 0x00, buffer.readByte());

View File

@ -123,7 +123,7 @@ public class SocksCmdResponseTest {
ByteBuf buffer = Unpooled.buffer(16); ByteBuf buffer = Unpooled.buffer(16);
rs.encodeAsByteBuf(buffer); rs.encodeAsByteBuf(buffer);
buffer.resetReaderIndex(); buffer.readerIndex(0);
assertEquals(SocksProtocolVersion.SOCKS5.byteValue(), buffer.readByte()); assertEquals(SocksProtocolVersion.SOCKS5.byteValue(), buffer.readByte());
assertEquals(SocksCmdStatus.SUCCESS.byteValue(), buffer.readByte()); assertEquals(SocksCmdStatus.SUCCESS.byteValue(), buffer.readByte());
assertEquals((byte) 0x00, buffer.readByte()); assertEquals((byte) 0x00, buffer.readByte());
@ -145,7 +145,7 @@ public class SocksCmdResponseTest {
ByteBuf buffer = Unpooled.buffer(24); ByteBuf buffer = Unpooled.buffer(24);
rs.encodeAsByteBuf(buffer); rs.encodeAsByteBuf(buffer);
buffer.resetReaderIndex(); buffer.readerIndex(0);
assertEquals(SocksProtocolVersion.SOCKS5.byteValue(), buffer.readByte()); assertEquals(SocksProtocolVersion.SOCKS5.byteValue(), buffer.readByte());
assertEquals(SocksCmdStatus.SUCCESS.byteValue(), buffer.readByte()); assertEquals(SocksCmdStatus.SUCCESS.byteValue(), buffer.readByte());
assertEquals((byte) 0x00, buffer.readByte()); assertEquals((byte) 0x00, buffer.readByte());

View File

@ -58,7 +58,7 @@ public class StompSubframeEncoderTest {
aggregatedBuffer.writeBytes(byteBuf); aggregatedBuffer.writeBytes(byteBuf);
byteBuf.release(); byteBuf.release();
aggregatedBuffer.resetReaderIndex(); aggregatedBuffer.readerIndex(0);
String content = aggregatedBuffer.toString(CharsetUtil.UTF_8); String content = aggregatedBuffer.toString(CharsetUtil.UTF_8);
assertEquals(StompTestConstants.CONNECT_FRAME, content); assertEquals(StompTestConstants.CONNECT_FRAME, content);
aggregatedBuffer.release(); aggregatedBuffer.release();

View File

@ -454,17 +454,6 @@ final class ReplayingDecoderByteBuf extends ByteBuf {
return buffer.forEachByteDesc(index, length, processor); return buffer.forEachByteDesc(index, length, processor);
} }
@Override
public ByteBuf markReaderIndex() {
buffer.markReaderIndex();
return this;
}
@Override
public ByteBuf markWriterIndex() {
throw reject();
}
@Override @Override
public ByteOrder order() { public ByteOrder order() {
return buffer.order(); return buffer.order();
@ -713,17 +702,6 @@ final class ReplayingDecoderByteBuf extends ByteBuf {
return buffer.readCharSequence(length, charset); return buffer.readCharSequence(length, charset);
} }
@Override
public ByteBuf resetReaderIndex() {
buffer.resetReaderIndex();
return this;
}
@Override
public ByteBuf resetWriterIndex() {
throw reject();
}
@Override @Override
public ByteBuf setBoolean(int index, boolean value) { public ByteBuf setBoolean(int index, boolean value) {
throw reject(); throw reject();

View File

@ -390,7 +390,7 @@ public final class Snappy {
* @return The number of bytes appended to the output buffer, or -1 to indicate "try again later" * @return The number of bytes appended to the output buffer, or -1 to indicate "try again later"
*/ */
static int decodeLiteral(byte tag, ByteBuf in, ByteBuf out) { static int decodeLiteral(byte tag, ByteBuf in, ByteBuf out) {
in.markReaderIndex(); int readerIndex = in.readerIndex();
int length; int length;
switch(tag >> 2 & 0x3F) { switch(tag >> 2 & 0x3F) {
case 60: case 60:
@ -423,7 +423,7 @@ public final class Snappy {
length += 1; length += 1;
if (in.readableBytes() < length) { if (in.readableBytes() < length) {
in.resetReaderIndex(); in.readerIndex(readerIndex);
return NOT_ENOUGH_INPUT; return NOT_ENOUGH_INPUT;
} }
@ -455,7 +455,7 @@ public final class Snappy {
validateOffset(offset, writtenSoFar); validateOffset(offset, writtenSoFar);
out.markReaderIndex(); int readerIndex = out.readerIndex();
if (offset < length) { if (offset < length) {
int copies = length / offset; int copies = length / offset;
for (; copies > 0; copies--) { for (; copies > 0; copies--) {
@ -470,7 +470,7 @@ public final class Snappy {
out.readerIndex(initialIndex - offset); out.readerIndex(initialIndex - offset);
out.readBytes(out, length); out.readBytes(out, length);
} }
out.resetReaderIndex(); out.readerIndex(readerIndex);
return length; return length;
} }
@ -499,7 +499,7 @@ public final class Snappy {
validateOffset(offset, writtenSoFar); validateOffset(offset, writtenSoFar);
out.markReaderIndex(); int readerIndex = out.readerIndex();
if (offset < length) { if (offset < length) {
int copies = length / offset; int copies = length / offset;
for (; copies > 0; copies--) { for (; copies > 0; copies--) {
@ -514,7 +514,7 @@ public final class Snappy {
out.readerIndex(initialIndex - offset); out.readerIndex(initialIndex - offset);
out.readBytes(out, length); out.readBytes(out, length);
} }
out.resetReaderIndex(); out.readerIndex(readerIndex);
return length; return length;
} }
@ -543,7 +543,7 @@ public final class Snappy {
validateOffset(offset, writtenSoFar); validateOffset(offset, writtenSoFar);
out.markReaderIndex(); int readerIndex = out.readerIndex();
if (offset < length) { if (offset < length) {
int copies = length / offset; int copies = length / offset;
for (; copies > 0; copies--) { for (; copies > 0; copies--) {
@ -558,7 +558,7 @@ public final class Snappy {
out.readerIndex(initialIndex - offset); out.readerIndex(initialIndex - offset);
out.readBytes(out, length); out.readBytes(out, length);
} }
out.resetReaderIndex(); out.readerIndex(readerIndex);
return length; return length;
} }

View File

@ -48,7 +48,7 @@ public class ProtobufVarint32FrameDecoder extends ByteToMessageDecoder {
@Override @Override
protected void decode(ChannelHandlerContext ctx, ByteBuf in, List<Object> out) protected void decode(ChannelHandlerContext ctx, ByteBuf in, List<Object> out)
throws Exception { throws Exception {
in.markReaderIndex(); int readerIndex = in.readerIndex();
int preIndex = in.readerIndex(); int preIndex = in.readerIndex();
int length = readRawVarint32(in); int length = readRawVarint32(in);
if (preIndex == in.readerIndex()) { if (preIndex == in.readerIndex()) {
@ -59,7 +59,7 @@ public class ProtobufVarint32FrameDecoder extends ByteToMessageDecoder {
} }
if (in.readableBytes() < length) { if (in.readableBytes() < length) {
in.resetReaderIndex(); in.readerIndex(readerIndex);
} else { } else {
out.add(in.readRetainedSlice(length)); out.add(in.readRetainedSlice(length));
} }
@ -74,14 +74,14 @@ public class ProtobufVarint32FrameDecoder extends ByteToMessageDecoder {
if (!buffer.isReadable()) { if (!buffer.isReadable()) {
return 0; return 0;
} }
buffer.markReaderIndex(); int readerIndex = buffer.readerIndex();
byte tmp = buffer.readByte(); byte tmp = buffer.readByte();
if (tmp >= 0) { if (tmp >= 0) {
return tmp; return tmp;
} else { } else {
int result = tmp & 127; int result = tmp & 127;
if (!buffer.isReadable()) { if (!buffer.isReadable()) {
buffer.resetReaderIndex(); buffer.readerIndex(readerIndex);
return 0; return 0;
} }
if ((tmp = buffer.readByte()) >= 0) { if ((tmp = buffer.readByte()) >= 0) {
@ -89,7 +89,7 @@ public class ProtobufVarint32FrameDecoder extends ByteToMessageDecoder {
} else { } else {
result |= (tmp & 127) << 7; result |= (tmp & 127) << 7;
if (!buffer.isReadable()) { if (!buffer.isReadable()) {
buffer.resetReaderIndex(); buffer.readerIndex(readerIndex);
return 0; return 0;
} }
if ((tmp = buffer.readByte()) >= 0) { if ((tmp = buffer.readByte()) >= 0) {
@ -97,7 +97,7 @@ public class ProtobufVarint32FrameDecoder extends ByteToMessageDecoder {
} else { } else {
result |= (tmp & 127) << 14; result |= (tmp & 127) << 14;
if (!buffer.isReadable()) { if (!buffer.isReadable()) {
buffer.resetReaderIndex(); buffer.readerIndex(readerIndex);
return 0; return 0;
} }
if ((tmp = buffer.readByte()) >= 0) { if ((tmp = buffer.readByte()) >= 0) {
@ -105,7 +105,7 @@ public class ProtobufVarint32FrameDecoder extends ByteToMessageDecoder {
} else { } else {
result |= (tmp & 127) << 21; result |= (tmp & 127) << 21;
if (!buffer.isReadable()) { if (!buffer.isReadable()) {
buffer.resetReaderIndex(); buffer.readerIndex(readerIndex);
return 0; return 0;
} }
result |= (tmp = buffer.readByte()) << 28; result |= (tmp = buffer.readByte()) << 28;

View File

@ -88,7 +88,8 @@ public abstract class AbstractEncoderTest extends AbstractCompressionTest {
assertTrue(channel.finish()); assertTrue(channel.finish());
ByteBuf decompressed = readDecompressed(dataLength); ByteBuf decompressed = readDecompressed(dataLength);
assertEquals(data.resetReaderIndex(), decompressed); data.readerIndex(0);
assertEquals(data, decompressed);
decompressed.release(); decompressed.release();
data.release(); data.release();

View File

@ -160,7 +160,8 @@ public abstract class AbstractIntegrationTest {
while ((msg = decoder.readInbound()) != null) { while ((msg = decoder.readInbound()) != null) {
decompressed.addComponent(true, msg); decompressed.addComponent(true, msg);
} }
assertEquals(in.resetReaderIndex(), decompressed); in.readerIndex(0);
assertEquals(in, decompressed);
compressed.release(); compressed.release();
decompressed.release(); decompressed.release();

View File

@ -83,7 +83,7 @@ public class SnappyFrameEncoderTest {
}); });
channel.writeOutbound(in.retain()); channel.writeOutbound(in.retain());
in.resetReaderIndex(); // rewind the buffer to write the same data in.readerIndex(0); // rewind the buffer to write the same data
channel.writeOutbound(in); channel.writeOutbound(in);
assertTrue(channel.finish()); assertTrue(channel.finish());

View File

@ -118,7 +118,7 @@ public abstract class ZlibTest {
try { try {
chEncoder.writeOutbound(data.retain()); chEncoder.writeOutbound(data.retain());
chEncoder.flush(); chEncoder.flush();
data.resetReaderIndex(); data.readerIndex(0);
for (;;) { for (;;) {
ByteBuf deflatedData = chEncoder.readOutbound(); ByteBuf deflatedData = chEncoder.readOutbound();

View File

@ -38,19 +38,19 @@ public class BigIntegerDecoder extends ByteToMessageDecoder {
return; return;
} }
in.markReaderIndex(); int readerIndex = in.readerIndex();
// Check the magic number. // Check the magic number.
int magicNumber = in.readUnsignedByte(); int magicNumber = in.readUnsignedByte();
if (magicNumber != 'F') { if (magicNumber != 'F') {
in.resetReaderIndex(); in.readerIndex(readerIndex);
throw new CorruptedFrameException("Invalid magic number: " + magicNumber); throw new CorruptedFrameException("Invalid magic number: " + magicNumber);
} }
// Wait until the whole data is available. // Wait until the whole data is available.
int dataLength = in.readInt(); int dataLength = in.readInt();
if (in.readableBytes() < dataLength) { if (in.readableBytes() < dataLength) {
in.resetReaderIndex(); in.readerIndex(readerIndex);
return; return;
} }

View File

@ -1124,7 +1124,7 @@ public abstract class SSLEngineTest {
try { try {
assertTrue(sendChannel.writeAndFlush(message).await(5, TimeUnit.SECONDS)); assertTrue(sendChannel.writeAndFlush(message).await(5, TimeUnit.SECONDS));
receiverLatch.await(5, TimeUnit.SECONDS); receiverLatch.await(5, TimeUnit.SECONDS);
message.resetReaderIndex(); message.readerIndex(0);
ArgumentCaptor<ByteBuf> captor = ArgumentCaptor.forClass(ByteBuf.class); ArgumentCaptor<ByteBuf> captor = ArgumentCaptor.forClass(ByteBuf.class);
verify(receiver).messageReceived(captor.capture()); verify(receiver).messageReceived(captor.capture());
dataCapture = captor.getAllValues(); dataCapture = captor.getAllValues();

View File

@ -43,31 +43,31 @@ public class WriteBytesVsShortOrMediumBenchmark extends AbstractMicrobenchmark {
@Benchmark @Benchmark
public ByteBuf shortInt() { public ByteBuf shortInt() {
return ByteBufUtil.writeShortBE(buf, CRLF_SHORT).resetWriterIndex(); return ByteBufUtil.writeShortBE(buf, CRLF_SHORT).writerIndex(0);
} }
@Benchmark @Benchmark
public ByteBuf mediumInt() { public ByteBuf mediumInt() {
return ByteBufUtil.writeMediumBE(buf, ZERO_CRLF_MEDIUM).resetWriterIndex(); return ByteBufUtil.writeMediumBE(buf, ZERO_CRLF_MEDIUM).writerIndex(0);
} }
@Benchmark @Benchmark
public ByteBuf byteArray2() { public ByteBuf byteArray2() {
return buf.writeBytes(CRLF).resetWriterIndex(); return buf.writeBytes(CRLF).writerIndex(0);
} }
@Benchmark @Benchmark
public ByteBuf byteArray3() { public ByteBuf byteArray3() {
return buf.writeBytes(ZERO_CRLF).resetWriterIndex(); return buf.writeBytes(ZERO_CRLF).writerIndex(0);
} }
@Benchmark @Benchmark
public ByteBuf chainedBytes2() { public ByteBuf chainedBytes2() {
return buf.writeByte(CR).writeByte(LF).resetWriterIndex(); return buf.writeByte(CR).writeByte(LF).writerIndex(0);
} }
@Benchmark @Benchmark
public ByteBuf chainedBytes3() { public ByteBuf chainedBytes3() {
return buf.writeByte('0').writeByte(CR).writeByte(LF).resetWriterIndex(); return buf.writeByte('0').writeByte(CR).writeByte(LF).writerIndex(0);
} }
} }

View File

@ -79,97 +79,97 @@ public class
@Benchmark @Benchmark
public void writeAsciiStringViaArray() { public void writeAsciiStringViaArray() {
buffer.resetWriterIndex(); buffer.writerIndex(0);
buffer.writeBytes(ascii.getBytes(CharsetUtil.US_ASCII)); buffer.writeBytes(ascii.getBytes(CharsetUtil.US_ASCII));
} }
@Benchmark @Benchmark
public void writeAsciiStringViaArrayWrapped() { public void writeAsciiStringViaArrayWrapped() {
wrapped.resetWriterIndex(); wrapped.writerIndex(0);
wrapped.writeBytes(ascii.getBytes(CharsetUtil.US_ASCII)); wrapped.writeBytes(ascii.getBytes(CharsetUtil.US_ASCII));
} }
@Benchmark @Benchmark
public void writeAsciiString() { public void writeAsciiString() {
buffer.resetWriterIndex(); buffer.writerIndex(0);
ByteBufUtil.writeAscii(buffer, ascii); ByteBufUtil.writeAscii(buffer, ascii);
} }
@Benchmark @Benchmark
public void writeAsciiStringWrapped() { public void writeAsciiStringWrapped() {
wrapped.resetWriterIndex(); wrapped.writerIndex(0);
ByteBufUtil.writeAscii(wrapped, ascii); ByteBufUtil.writeAscii(wrapped, ascii);
} }
@Benchmark @Benchmark
public void writeAsciiViaArray() { public void writeAsciiViaArray() {
buffer.resetWriterIndex(); buffer.writerIndex(0);
buffer.writeBytes(asciiSequence.toString().getBytes(CharsetUtil.US_ASCII)); buffer.writeBytes(asciiSequence.toString().getBytes(CharsetUtil.US_ASCII));
} }
@Benchmark @Benchmark
public void writeAsciiViaArrayWrapped() { public void writeAsciiViaArrayWrapped() {
wrapped.resetWriterIndex(); wrapped.writerIndex(0);
wrapped.writeBytes(asciiSequence.toString().getBytes(CharsetUtil.US_ASCII)); wrapped.writeBytes(asciiSequence.toString().getBytes(CharsetUtil.US_ASCII));
} }
@Benchmark @Benchmark
public void writeAscii() { public void writeAscii() {
buffer.resetWriterIndex(); buffer.writerIndex(0);
ByteBufUtil.writeAscii(buffer, asciiSequence); ByteBufUtil.writeAscii(buffer, asciiSequence);
} }
@Benchmark @Benchmark
public void writeAsciiWrapped() { public void writeAsciiWrapped() {
wrapped.resetWriterIndex(); wrapped.writerIndex(0);
ByteBufUtil.writeAscii(wrapped, asciiSequence); ByteBufUtil.writeAscii(wrapped, asciiSequence);
} }
@Benchmark @Benchmark
public void writeUtf8StringViaArray() { public void writeUtf8StringViaArray() {
buffer.resetWriterIndex(); buffer.writerIndex(0);
buffer.writeBytes(utf8.getBytes(CharsetUtil.UTF_8)); buffer.writeBytes(utf8.getBytes(CharsetUtil.UTF_8));
} }
@Benchmark @Benchmark
public void writeUtf8StringViaArrayWrapped() { public void writeUtf8StringViaArrayWrapped() {
wrapped.resetWriterIndex(); wrapped.writerIndex(0);
wrapped.writeBytes(utf8.getBytes(CharsetUtil.UTF_8)); wrapped.writeBytes(utf8.getBytes(CharsetUtil.UTF_8));
} }
@Benchmark @Benchmark
public void writeUtf8String() { public void writeUtf8String() {
buffer.resetWriterIndex(); buffer.writerIndex(0);
ByteBufUtil.writeUtf8(buffer, utf8); ByteBufUtil.writeUtf8(buffer, utf8);
} }
@Benchmark @Benchmark
public void writeUtf8StringWrapped() { public void writeUtf8StringWrapped() {
wrapped.resetWriterIndex(); wrapped.writerIndex(0);
ByteBufUtil.writeUtf8(wrapped, utf8); ByteBufUtil.writeUtf8(wrapped, utf8);
} }
@Benchmark @Benchmark
public void writeUtf8ViaArray() { public void writeUtf8ViaArray() {
buffer.resetWriterIndex(); buffer.writerIndex(0);
buffer.writeBytes(utf8Sequence.toString().getBytes(CharsetUtil.UTF_8)); buffer.writeBytes(utf8Sequence.toString().getBytes(CharsetUtil.UTF_8));
} }
@Benchmark @Benchmark
public void writeUtf8ViaArrayWrapped() { public void writeUtf8ViaArrayWrapped() {
wrapped.resetWriterIndex(); wrapped.writerIndex(0);
wrapped.writeBytes(utf8Sequence.toString().getBytes(CharsetUtil.UTF_8)); wrapped.writeBytes(utf8Sequence.toString().getBytes(CharsetUtil.UTF_8));
} }
@Benchmark @Benchmark
public void writeUtf8() { public void writeUtf8() {
buffer.resetWriterIndex(); buffer.writerIndex(0);
ByteBufUtil.writeUtf8(buffer, utf8Sequence); ByteBufUtil.writeUtf8(buffer, utf8Sequence);
} }
@Benchmark @Benchmark
public void writeUtf8Wrapped() { public void writeUtf8Wrapped() {
wrapped.resetWriterIndex(); wrapped.writerIndex(0);
ByteBufUtil.writeUtf8(wrapped, utf8Sequence); ByteBufUtil.writeUtf8(wrapped, utf8Sequence);
} }

View File

@ -63,13 +63,13 @@ public class SlicedByteBufBenchmark extends AbstractMicrobenchmark {
@Benchmark @Benchmark
public void writeAsciiStringSlice() { public void writeAsciiStringSlice() {
slicedByteBuf.resetWriterIndex(); slicedByteBuf.writerIndex(0);
ByteBufUtil.writeAscii(slicedByteBuf, ascii); ByteBufUtil.writeAscii(slicedByteBuf, ascii);
} }
@Benchmark @Benchmark
public void writeAsciiStringSliceAbstract() { public void writeAsciiStringSliceAbstract() {
slicedAbstractByteBuf.resetWriterIndex(); slicedAbstractByteBuf.writerIndex(0);
ByteBufUtil.writeAscii(slicedAbstractByteBuf, ascii); ByteBufUtil.writeAscii(slicedAbstractByteBuf, ascii);
} }
} }

View File

@ -857,14 +857,14 @@ abstract class DnsResolveContext<T> {
} }
static String decodeDomainName(ByteBuf in) { static String decodeDomainName(ByteBuf in) {
in.markReaderIndex(); int readerIndex = in.readerIndex();
try { try {
return DefaultDnsRecordDecoder.decodeName(in); return DefaultDnsRecordDecoder.decodeName(in);
} catch (CorruptedFrameException e) { } catch (CorruptedFrameException e) {
// In this case we just return null. // In this case we just return null.
return null; return null;
} finally { } finally {
in.resetReaderIndex(); in.readerIndex(readerIndex);
} }
} }