2016-03-21 23:41:37 +01:00
|
|
|
package nodomain.freeyourgadget.gadgetbridge.util;
|
|
|
|
|
2016-12-11 02:10:07 +01:00
|
|
|
import java.util.Collection;
|
|
|
|
|
2016-03-21 23:41:37 +01:00
|
|
|
public class ArrayUtils {
|
|
|
|
/**
|
2016-12-11 23:29:22 +01:00
|
|
|
* Checks the two given arrays for equality, but comparing the second array with a specified
|
|
|
|
* subset of the first array.
|
2016-03-27 17:44:20 +02:00
|
|
|
*
|
2016-12-11 23:29:22 +01:00
|
|
|
* @param first the array in which to look for the second array
|
|
|
|
* @param second the data to look for inside the first array
|
|
|
|
* @param startIndex the start index (inclusive) inside the first array from which to start the comparison
|
|
|
|
* @return whether the second byte array is equal to the specified subset of the first byte array
|
|
|
|
* @throws IllegalArgumentException when one of the arrays is null or start index/length are wrong
|
2016-03-21 23:41:37 +01:00
|
|
|
*/
|
2016-12-11 23:29:22 +01:00
|
|
|
public static boolean equals(byte[] first, byte[] second, int startIndex) {
|
2016-03-21 23:41:37 +01:00
|
|
|
if (first == null) {
|
|
|
|
throw new IllegalArgumentException("first must not be null");
|
|
|
|
}
|
|
|
|
if (second == null) {
|
|
|
|
throw new IllegalArgumentException("second must not be null");
|
|
|
|
}
|
2016-12-11 23:29:22 +01:00
|
|
|
if (startIndex < 0) {
|
|
|
|
throw new IllegalArgumentException("startIndex must be >= 0");
|
2016-03-21 23:41:37 +01:00
|
|
|
}
|
2016-12-11 23:29:22 +01:00
|
|
|
|
|
|
|
if (second.length + startIndex > first.length) {
|
2016-03-21 23:41:37 +01:00
|
|
|
return false;
|
|
|
|
}
|
2016-12-11 23:29:22 +01:00
|
|
|
for (int i = 0; i < second.length; i++) {
|
|
|
|
if (first[startIndex + i] != second[i]) {
|
2016-03-21 23:41:37 +01:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
2016-12-11 02:10:07 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Converts a collection of Integer values to an int[] array.
|
|
|
|
* @param values
|
|
|
|
* @return null if the given collection is null, otherwise an array of the same size as the collection
|
|
|
|
* @throws NullPointerException when an element of the collection is null
|
|
|
|
*/
|
|
|
|
public static int[] toIntArray(Collection<Integer> values) {
|
|
|
|
if (values == null) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
int i = 0;
|
|
|
|
int[] result = new int[values.size()];
|
|
|
|
for (Integer value : values) {
|
|
|
|
result[i++] = value;
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
2016-03-21 23:41:37 +01:00
|
|
|
}
|