Fix sorting

This commit is contained in:
Andrea Cavalli 2023-09-25 18:51:35 +02:00
parent 70f83caf1d
commit ee1e71da84
2 changed files with 63 additions and 1 deletions

View File

@ -25,6 +25,7 @@ import java.util.Arrays;
import java.util.Collection; import java.util.Collection;
import java.util.Comparator; import java.util.Comparator;
import java.util.Iterator; import java.util.Iterator;
import java.util.List;
import java.util.NoSuchElementException; import java.util.NoSuchElementException;
import java.util.function.IntPredicate; import java.util.function.IntPredicate;
import java.util.function.IntUnaryOperator; import java.util.function.IntUnaryOperator;
@ -867,4 +868,60 @@ class ByteListBuf extends ByteArrayList implements Buf {
throw new UnsupportedOperationException(IMMUTABLE_ERROR); throw new UnsupportedOperationException(IMMUTABLE_ERROR);
} }
} }
@Override
public int compareTo(List<? extends Byte> l) {
if (l instanceof ByteArrayList) {
return compareTo((ByteArrayList)l);
}
if (l instanceof SubList) {
// Must negate because we are inverting the order of the comparison.
return -((SubList)l).compareTo(this);
}
return super.compareTo(l);
}
@Override
public int compareTo(ByteArrayList l) {
final int s1 = size(), s2 = l.size();
final byte[] a1 = a, a2 = l.elements();
if (a1 == a2 && s1 == s2) return 0;
return Arrays.compareUnsigned(a, 0, s1, a2, 0, s2);
}
/**
* Compares this type-specific array list to another one.
*
* @apiNote This method exists only for sake of efficiency. The implementation inherited from the
* abstract implementation would already work.
*
* @param l a type-specific array list.
* @return true if the argument contains the same elements of this type-specific array list.
*/
public boolean equals(final ByteArrayList l) {
if (l == this) return true;
int s = size();
if (s != l.size()) return false;
final byte[] a1 = a, a2 = l.elements();
final int s1 = this.size(), s2 = l.size();
return Arrays.equals(a1, 0, s1, a2, 0, s2);
}
@SuppressWarnings("unlikely-arg-type")
@Override
public boolean equals(final Object o) {
if (o == this) return true;
if (o == null) return false;
if (!(o instanceof java.util.List)) return false;
if (o instanceof ByteArrayList) {
// Safe cast because we are only going to take elements from other list, never give them
return equals((ByteArrayList) o);
}
if (o instanceof SubList subList) {
// Safe cast because we are only going to take elements from other list, never give them
// Sublist has an optimized sub-array based comparison, reuse that.
return subList.equals(this);
}
return super.equals(o);
}
} }

View File

@ -78,6 +78,11 @@ public class TestBuffer {
return Stream.concat(primaryBufs.stream(), subListBufs.stream()); return Stream.concat(primaryBufs.stream(), subListBufs.stream());
} }
public static Stream<BufArg> provideBufsCompare() {
return Stream.concat(provideBufs(),
Stream.of(new BufArg("0x50", Buf.wrap((byte) 50), 1, new byte[]{50})));
}
public static List<BufArg> createPrimaryBufs() { public static List<BufArg> createPrimaryBufs() {
var emptyBuf = new BufArg("create()", Buf.create(), 0, new byte[0]); var emptyBuf = new BufArg("create()", Buf.create(), 0, new byte[0]);
var byteListBuf = new BufArg("createByteListBuf()", ByteListBuf.of(), 0, new byte[0]); var byteListBuf = new BufArg("createByteListBuf()", ByteListBuf.of(), 0, new byte[0]);
@ -544,7 +549,7 @@ public class TestBuffer {
} }
@ParameterizedTest @ParameterizedTest
@MethodSource("provideBufs") @MethodSource("provideBufsCompare")
public void testCompareTo(BufArg bufArg) { public void testCompareTo(BufArg bufArg) {
if (bufArg.initialSize > 0) { if (bufArg.initialSize > 0) {
var bigger = Arrays.copyOf(bufArg.initialContent, bufArg.initialSize + 1); var bigger = Arrays.copyOf(bufArg.initialContent, bufArg.initialSize + 1);