[#707] Hopefully now the correct fix for it which also takes the index into account when consolidate
This commit is contained in:
parent
36ac52a4bd
commit
d293e6c389
@ -61,7 +61,8 @@ public class DefaultCompositeByteBuf extends AbstractByteBuf implements Composit
|
||||
|
||||
this.maxNumComponents = maxNumComponents;
|
||||
|
||||
addComponents(0, buffers);
|
||||
addComponents0(0, buffers);
|
||||
consolidateIfNeeded();
|
||||
setIndex(0, capacity());
|
||||
}
|
||||
|
||||
@ -74,30 +75,41 @@ public class DefaultCompositeByteBuf extends AbstractByteBuf implements Composit
|
||||
}
|
||||
|
||||
this.maxNumComponents = maxNumComponents;
|
||||
addComponents(0, buffers);
|
||||
addComponents0(0, buffers);
|
||||
consolidateIfNeeded();
|
||||
setIndex(0, capacity());
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public CompositeByteBuf addComponent(ByteBuf buffer) {
|
||||
addComponent(components.size(), buffer);
|
||||
addComponent0(components.size(), buffer);
|
||||
consolidateIfNeeded();
|
||||
return this;
|
||||
}
|
||||
|
||||
@Override
|
||||
public CompositeByteBuf addComponents(ByteBuf... buffers) {
|
||||
addComponents(components.size(), buffers);
|
||||
addComponents0(components.size(), buffers);
|
||||
consolidateIfNeeded();
|
||||
return this;
|
||||
}
|
||||
|
||||
@Override
|
||||
public CompositeByteBuf addComponents(Iterable<ByteBuf> buffers) {
|
||||
addComponents(components.size(), buffers);
|
||||
addComponents0(components.size(), buffers);
|
||||
consolidateIfNeeded();
|
||||
return this;
|
||||
}
|
||||
|
||||
@Override
|
||||
public CompositeByteBuf addComponent(int cIndex, ByteBuf buffer) {
|
||||
addComponent0(cIndex, buffer);
|
||||
consolidateIfNeeded();
|
||||
return this;
|
||||
}
|
||||
|
||||
private int addComponent0(int cIndex, ByteBuf buffer) {
|
||||
checkComponentIndex(cIndex);
|
||||
|
||||
if (buffer == null) {
|
||||
@ -107,34 +119,12 @@ public class DefaultCompositeByteBuf extends AbstractByteBuf implements Composit
|
||||
if (buffer instanceof Iterable) {
|
||||
@SuppressWarnings("unchecked")
|
||||
Iterable<ByteBuf> composite = (Iterable<ByteBuf>) buffer;
|
||||
addComponents(cIndex, composite);
|
||||
return this;
|
||||
return addComponents0(cIndex, composite);
|
||||
}
|
||||
|
||||
int readableBytes = buffer.readableBytes();
|
||||
if (readableBytes == 0) {
|
||||
return this;
|
||||
}
|
||||
|
||||
// Consolidate if the number of components will exceed the allowed maximum by the current
|
||||
// operation.
|
||||
final int numComponents = components.size();
|
||||
if (numComponents >= maxNumComponents) {
|
||||
final int capacity = components.get(numComponents - 1).endOffset + readableBytes;
|
||||
|
||||
ByteBuf consolidated = buffer.unsafe().newBuffer(capacity);
|
||||
for (int i = 0; i < numComponents; i ++) {
|
||||
ByteBuf b = components.get(i).buf;
|
||||
consolidated.writeBytes(b);
|
||||
b.unsafe().release();
|
||||
}
|
||||
consolidated.writeBytes(buffer, buffer.readerIndex(), readableBytes);
|
||||
|
||||
Component c = new Component(consolidated);
|
||||
c.endOffset = c.length;
|
||||
components.clear();
|
||||
components.add(c);
|
||||
return this;
|
||||
return cIndex;
|
||||
}
|
||||
|
||||
// No need to consolidate - just add a component to the list.
|
||||
@ -152,74 +142,33 @@ public class DefaultCompositeByteBuf extends AbstractByteBuf implements Composit
|
||||
components.add(cIndex, c);
|
||||
updateComponentOffsets(cIndex);
|
||||
}
|
||||
return cIndex;
|
||||
}
|
||||
@Override
|
||||
public CompositeByteBuf addComponents(int cIndex, ByteBuf... buffers) {
|
||||
addComponents0(cIndex, buffers);
|
||||
consolidateIfNeeded();
|
||||
return this;
|
||||
}
|
||||
|
||||
@Override
|
||||
public CompositeByteBuf addComponents(int cIndex, ByteBuf... buffers) {
|
||||
private int addComponents0(int cIndex, ByteBuf... buffers) {
|
||||
checkComponentIndex(cIndex);
|
||||
|
||||
if (buffers == null) {
|
||||
throw new NullPointerException("buffers");
|
||||
}
|
||||
|
||||
ByteBuf lastBuf = null;
|
||||
int cnt = 0;
|
||||
|
||||
int readableBytes = 0;
|
||||
for (ByteBuf b: buffers) {
|
||||
if (b == null) {
|
||||
break;
|
||||
}
|
||||
lastBuf = b;
|
||||
cnt ++;
|
||||
readableBytes += b.readableBytes();
|
||||
}
|
||||
|
||||
if (readableBytes == 0) {
|
||||
return this;
|
||||
}
|
||||
|
||||
// Consolidate if the number of components will exceed the maximum by this operation.
|
||||
final int numComponents = components.size();
|
||||
if (numComponents + cnt >= maxNumComponents) {
|
||||
final ByteBuf consolidated;
|
||||
if (numComponents != 0) {
|
||||
final int capacity = components.get(numComponents - 1).endOffset + readableBytes;
|
||||
consolidated = lastBuf.unsafe().newBuffer(capacity);
|
||||
for (int i = 0; i < cIndex; i ++) {
|
||||
ByteBuf b = components.get(i).buf;
|
||||
consolidated.writeBytes(b);
|
||||
b.unsafe().release();
|
||||
}
|
||||
|
||||
for (ByteBuf b: buffers) {
|
||||
if (b == null) {
|
||||
break;
|
||||
}
|
||||
consolidated.writeBytes(b, b.readerIndex(), b.readableBytes());
|
||||
}
|
||||
|
||||
for (int i = cIndex; i < numComponents; i ++) {
|
||||
ByteBuf b = components.get(i).buf;
|
||||
consolidated.writeBytes(b);
|
||||
b.unsafe().release();
|
||||
}
|
||||
} else {
|
||||
consolidated = lastBuf.unsafe().newBuffer(readableBytes);
|
||||
for (ByteBuf b: buffers) {
|
||||
if (b == null) {
|
||||
break;
|
||||
}
|
||||
consolidated.writeBytes(b, b.readerIndex(), b.readableBytes());
|
||||
}
|
||||
}
|
||||
|
||||
Component c = new Component(consolidated);
|
||||
c.endOffset = c.length;
|
||||
components.clear();
|
||||
components.add(c);
|
||||
updateComponentOffsets(0);
|
||||
return this;
|
||||
return cIndex;
|
||||
}
|
||||
|
||||
// No need for consolidation
|
||||
@ -228,15 +177,24 @@ public class DefaultCompositeByteBuf extends AbstractByteBuf implements Composit
|
||||
break;
|
||||
}
|
||||
if (b.readable()) {
|
||||
// Always add b to the end of the component list because we are appending buffers
|
||||
addComponent(components.size(), b);
|
||||
cIndex = addComponent0(cIndex, b) + 1;
|
||||
int size = components.size();
|
||||
if (cIndex > size) {
|
||||
cIndex = size;
|
||||
}
|
||||
}
|
||||
return this;
|
||||
}
|
||||
return cIndex;
|
||||
}
|
||||
|
||||
@Override
|
||||
public CompositeByteBuf addComponents(int cIndex, Iterable<ByteBuf> buffers) {
|
||||
addComponents0(cIndex, buffers);
|
||||
consolidateIfNeeded();
|
||||
return this;
|
||||
}
|
||||
|
||||
private int addComponents0(int cIndex, Iterable<ByteBuf> buffers) {
|
||||
if (buffers == null) {
|
||||
throw new NullPointerException("buffers");
|
||||
}
|
||||
@ -247,8 +205,7 @@ public class DefaultCompositeByteBuf extends AbstractByteBuf implements Composit
|
||||
for (int i = 0; i < array.length; i ++) {
|
||||
array[i] = list.get(i).buf;
|
||||
}
|
||||
addComponents(cIndex, array);
|
||||
return this;
|
||||
return addComponents0(cIndex, array);
|
||||
}
|
||||
|
||||
if (buffers instanceof List) {
|
||||
@ -257,8 +214,7 @@ public class DefaultCompositeByteBuf extends AbstractByteBuf implements Composit
|
||||
for (int i = 0; i < array.length; i ++) {
|
||||
array[i] = list.get(i);
|
||||
}
|
||||
addComponents(cIndex, array);
|
||||
return this;
|
||||
return addComponents0(cIndex, array);
|
||||
}
|
||||
|
||||
if (buffers instanceof Collection) {
|
||||
@ -268,16 +224,39 @@ public class DefaultCompositeByteBuf extends AbstractByteBuf implements Composit
|
||||
for (ByteBuf b: col) {
|
||||
array[i ++] = b;
|
||||
}
|
||||
addComponents(cIndex, array);
|
||||
return this;
|
||||
return addComponents0(cIndex, array);
|
||||
}
|
||||
|
||||
List<ByteBuf> list = new ArrayList<ByteBuf>();
|
||||
for (ByteBuf b: buffers) {
|
||||
list.add(b);
|
||||
}
|
||||
addComponents(cIndex, list.toArray(new ByteBuf[list.size()]));
|
||||
return this;
|
||||
return addComponents0(cIndex, list.toArray(new ByteBuf[list.size()]));
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* This should only be called as last operation from a method as this may adjust the underlying
|
||||
* array of components and so affect the index etc.
|
||||
*/
|
||||
private void consolidateIfNeeded() {
|
||||
// Consolidate if the number of components will exceed the allowed maximum by the current
|
||||
// operation.
|
||||
final int numComponents = components.size();
|
||||
if (numComponents > maxNumComponents) {
|
||||
final int capacity = components.get(numComponents - 1).endOffset;
|
||||
|
||||
ByteBuf consolidated = components.get(numComponents - 1).buf.unsafe().newBuffer(capacity);
|
||||
for (int i = 0; i < numComponents; i ++) {
|
||||
ByteBuf b = components.get(i).buf;
|
||||
consolidated.writeBytes(b);
|
||||
b.unsafe().release();
|
||||
}
|
||||
Component c = new Component(consolidated);
|
||||
c.endOffset = c.length;
|
||||
components.clear();
|
||||
components.add(c);
|
||||
}
|
||||
}
|
||||
|
||||
private void checkComponentIndex(int cIndex) {
|
||||
|
Loading…
Reference in New Issue
Block a user