com.strobel.core.VerifyArgument Maven / Gradle / Ivy
/*
* VerifyArgument.java
*
* Copyright (c) 2012 Mike Strobel
*
* This source code is subject to terms and conditions of the Apache License, Version 2.0.
* A copy of the license can be found in the License.html file at the root of this distribution.
* By using this source code in any fashion, you are agreeing to be bound by the terms of the
* Apache License, Version 2.0.
*
* You must not remove this notice, or any other, from this software.
*/
package com.strobel.core;
import java.util.Collection;
import java.util.Iterator;
import java.util.List;
import java.util.RandomAccess;
import static java.lang.String.format;
/**
* @author Mike Strobel
*/
public final class VerifyArgument {
private VerifyArgument() {}
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// GENERIC PRECONDITIONS //
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
public static T notNull(final T value, final String parameterName) {
if (value != null) {
return value;
}
throw new IllegalArgumentException(
format("Argument '%s' cannot be null.", parameterName)
);
}
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// ARRAY AND COLLECTION PRECONDITIONS //
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
public static T[] notEmpty(final T[] array, final String parameterName) {
notNull(array, parameterName);
if (array.length == 0) {
throw new IllegalArgumentException(
format("Argument '%s' must be a non-empty collection.", parameterName)
);
}
return array;
}
public static > T notEmpty(final T collection, final String parameterName) {
notNull(collection, parameterName);
if (collection instanceof Collection>) {
if (!((Collection>)collection).isEmpty()) {
return collection;
}
}
else {
final Iterator> iterator = collection.iterator();
if (iterator.hasNext()) {
return collection;
}
}
throw new IllegalArgumentException(
format("Argument '%s' must be a non-empty collection.", parameterName)
);
}
public static T[] noNullElements(final T[] array, final String parameterName) {
notNull(array, parameterName);
for (final T item : array) {
if (item == null) {
throw new IllegalArgumentException(
format("Argument '%s' must not have any null elements.", parameterName)
);
}
}
return array;
}
public static T[] noNullElements(final T[] array, final int offset, final int length, final String parameterName) {
notNull(array, parameterName);
for (int i = offset, end = offset + length; i < end; i++) {
final T item = array[i];
if (item == null) {
throw new IllegalArgumentException(
format(
"Argument '%s' must not have any null elements in the range (%s, %s].",
parameterName,
offset,
offset + length
)
);
}
}
return array;
}
public static > T noNullElements(final T collection, final String parameterName) {
notNull(collection, parameterName);
if (collection instanceof List && collection instanceof RandomAccess) {
final List> list = (List>)collection;
//noinspection ForLoopReplaceableByForEach
for (int i = 0, n = list.size(); i < n; i++) {
if (list.get(i) == null) {
throw new IllegalArgumentException(
format("Argument '%s' must not have any null elements.", parameterName)
);
}
}
return collection;
}
for (final Object item : collection) {
if (item == null) {
throw new IllegalArgumentException(
format("Argument '%s' must not have any null elements.", parameterName)
);
}
}
return collection;
}
public static T[] noNullElementsAndNotEmpty(final T[] array, final String parameterName) {
notEmpty(array, parameterName);
for (final T item : array) {
if (item == null) {
throw new IllegalArgumentException(
format("Argument '%s' must not have any null elements.", parameterName)
);
}
}
return array;
}
public static T[] noNullElementsAndNotEmpty(final T[] array, final int offset, final int length, final String parameterName) {
notEmpty(array, parameterName);
for (int i = offset, end = offset + length; i < end; i++) {
final T item = array[i];
if (item == null) {
throw new IllegalArgumentException(
format(
"Argument '%s' must not have any null elements in the range (%s, %s].",
parameterName,
offset,
offset + length
)
);
}
}
return array;
}
public static > T noNullElementsAndNotEmpty(final T collection, final String parameterName) {
notNull(collection, parameterName);
if (collection instanceof List && collection instanceof RandomAccess) {
final List> list = (List>)collection;
if (list.isEmpty()) {
throw new IllegalArgumentException(
format("Argument '%s' must be a non-empty collection.", parameterName)
);
}
//noinspection ForLoopReplaceableByForEach
for (int i = 0, n = list.size(); i < n; i++) {
if (list.get(i) == null) {
throw new IllegalArgumentException(
format("Argument '%s' must not have any null elements.", parameterName)
);
}
}
return collection;
}
final Iterator iterator = collection.iterator();
if (!iterator.hasNext()) {
throw new IllegalArgumentException(
format("Argument '%s' must be a non-empty collection.", parameterName)
);
}
do {
final Object item = iterator.next();
if (item == null) {
throw new IllegalArgumentException(
format("Argument '%s' must not have any null elements.", parameterName)
);
}
}
while (iterator.hasNext());
return collection;
}
public static T[] elementsOfType(final Class> elementType, final T[] values, final String parameterName) {
VerifyArgument.notNull(elementType, "elementType");
VerifyArgument.notNull(values, "values");
for (final T value : values) {
if (!elementType.isInstance(value)) {
throw new IllegalArgumentException(
format(
"Argument '%s' must only contain elements of type '%s'.",
parameterName,
elementType
)
);
}
}
return values;
}
public static T[] elementsOfTypeOrNull(final Class elementType, final T[] values, final String parameterName) {
VerifyArgument.notNull(elementType, "elementType");
VerifyArgument.notNull(values, "values");
for (final T value : values) {
if (value != null && !elementType.isInstance(value)) {
throw new IllegalArgumentException(
format(
"Argument '%s' must only contain elements of type '%s'.",
parameterName,
elementType
)
);
}
}
return values;
}
public static int validElementRange(final int size, final int startInclusive, final int endExclusive) {
if (startInclusive >= 0 && endExclusive <= size && endExclusive >= startInclusive) {
return endExclusive - startInclusive;
}
throw new IllegalArgumentException(
format(
"The specified element range is not valid: range=(%d, %d], length=%d",
startInclusive,
endExclusive,
size
)
);
}
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// STRING PRECONDITIONS //
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
public static String notNullOrEmpty(final String value, final String parameterName) {
if (!StringUtilities.isNullOrEmpty(value)) {
return value;
}
throw new IllegalArgumentException(
format("Argument '%s' must be a non-null, non-empty string.", parameterName)
);
}
public static String notNullOrWhitespace(final String value, final String parameterName) {
if (!StringUtilities.isNullOrWhitespace(value)) {
return value;
}
throw new IllegalArgumentException(
format("Argument '%s' must be a non-null, non-empty string.", parameterName)
);
}
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// NUMERIC PRECONDITIONS //
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
public static int isNonZero(final int value, final String parameterName) {
if (value != 0) {
return value;
}
throw new IllegalArgumentException(format("Argument '%s' must be non-zero, but value was: %d.", parameterName, value));
}
public static int isPositive(final int value, final String parameterName) {
if (value > 0) {
return value;
}
throw new IllegalArgumentException(format("Argument '%s' must be positive, but value was: %d.", parameterName, value));
}
public static int isNonNegative(final int value, final String parameterName) {
if (value >= 0) {
return value;
}
throw new IllegalArgumentException(format("Argument '%s' must be non-negative, but value was: %d.", parameterName, value));
}
public static int isNegative(final int value, final String parameterName) {
if (value < 0) {
return value;
}
throw new IllegalArgumentException(format("Argument '%s' must be negative, but value was: %d.", parameterName, value));
}
public static int inRange(final int minInclusive, final int maxInclusive, final int value, final String parameterName) {
if (maxInclusive < minInclusive) {
throw new IllegalArgumentException(
format(
"The specified maximum value (%d) is less than the specified minimum value (%d).",
maxInclusive,
minInclusive
)
);
}
if (value >= minInclusive && value <= maxInclusive) {
return value;
}
throw new IllegalArgumentException(
format(
"Argument '%s' must be in the range [%s, %s], but value was: %d.",
parameterName,
minInclusive,
maxInclusive,
value
)
);
}
public static double isNonZero(final double value, final String parameterName) {
if (value != 0) {
return value;
}
throw new IllegalArgumentException(format("Argument '%s' must be non-zero, but value was: %s.", parameterName, value));
}
public static double isPositive(final double value, final String parameterName) {
if (value > 0) {
return value;
}
throw new IllegalArgumentException(format("Argument '%s' must be positive, but value was: %s.", parameterName, value));
}
public static double isNonNegative(final double value, final String parameterName) {
if (value >= 0) {
return value;
}
throw new IllegalArgumentException(format("Argument '%s' must be non-negative, but value was: %s.", parameterName, value));
}
public static double isNegative(final double value, final String parameterName) {
if (value < 0) {
return value;
}
throw new IllegalArgumentException(format("Argument '%s' must be negative, but value was: %s.", parameterName, value));
}
public static double inRange(
final double minInclusive,
final double maxInclusive,
final double value,
final String parameterName) {
if (Double.isNaN(minInclusive)) {
throw new IllegalArgumentException("The minimum value cannot be NaN.");
}
if (Double.isNaN(maxInclusive)) {
throw new IllegalArgumentException("The maximum value cannot be NaN.");
}
if (maxInclusive < minInclusive) {
throw new IllegalArgumentException(
format(
"The specified maximum value (%s) is less than the specified minimum value (%s).",
maxInclusive,
minInclusive
)
);
}
if (value >= minInclusive && value <= maxInclusive) {
return value;
}
throw new IllegalArgumentException(
format(
"Argument '%s' must be in the range [%s, %s], but value was: %s.",
parameterName,
minInclusive,
maxInclusive,
value
)
);
}
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// TYPE PRECONDITIONS //
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
@SuppressWarnings("unchecked")
public static T instanceOf(final Class type, final Object value, final String parameterName) {
final Class> actualType = getBoxedType(VerifyArgument.notNull(type, "type"));
if (actualType.isInstance(value)) {
return (T) value;
}
throw new IllegalArgumentException(
format(
"Argument '%s' must be an instance of type %s.",
parameterName,
type.getCanonicalName()
)
);
}
@SuppressWarnings("unchecked")
public static T notInstanceOf(final Class type, final Object value, final String parameterName) {
final Class> actualType = getBoxedType(VerifyArgument.notNull(type, "type"));
if (!actualType.isInstance(value)) {
return (T) value;
}
throw new IllegalArgumentException(
format(
"Argument '%s' must not be an instance of type %s.",
parameterName,
type.getCanonicalName()
)
);
}
private static Class> getBoxedType(final Class> type) {
if (!type.isPrimitive()) {
return type;
}
if (type == boolean.class) {
return Boolean.class;
}
if (type == char.class) {
return Character.class;
}
if (type == byte.class) {
return Byte.class;
}
if (type == short.class) {
return Short.class;
}
if (type == int.class) {
return Integer.class;
}
if (type == long.class) {
return Long.class;
}
if (type == float.class) {
return Float.class;
}
if (type == double.class) {
return Double.class;
}
return type;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy