public class Validate extends Object
This class assists in validating arguments. The validation methods are based along the following principles:
null
argument causes a NullPointerException
.null
argument causes an IllegalArgumentException
.IndexOutOfBoundsException
.All exceptions messages are format strings as defined by the Java platform. For example:
Validate.isTrue(i > 0, "The value must be greater than zero: %d", i); Validate.notNull(surname, "The surname must not be %s", null);
#ThreadSafe#
String.format(String, Object...)
Constructor and Description |
---|
Validate()
Constructor.
|
Modifier and Type | Method and Description |
---|---|
static void |
exclusiveBetween(double start,
double end,
double value)
Validate that the specified primitive value falls between the two
exclusive values specified; otherwise, throws an exception.
|
static void |
exclusiveBetween(double start,
double end,
double value,
String message)
Validate that the specified primitive value falls between the two
exclusive values specified; otherwise, throws an exception with the
specified message.
|
static void |
exclusiveBetween(long start,
long end,
long value)
Validate that the specified primitive value falls between the two
exclusive values specified; otherwise, throws an exception.
|
static void |
exclusiveBetween(long start,
long end,
long value,
String message)
Validate that the specified primitive value falls between the two
exclusive values specified; otherwise, throws an exception with the
specified message.
|
static <T> void |
exclusiveBetween(T start,
T end,
Comparable<T> value)
Validate that the specified argument object fall between the two
exclusive values specified; otherwise, throws an exception.
|
static <T> void |
exclusiveBetween(T start,
T end,
Comparable<T> value,
String message,
Object... values)
Validate that the specified argument object fall between the two
exclusive values specified; otherwise, throws an exception with the
specified message.
|
static void |
finite(double value)
Validates that the specified argument is not infinite or
NaN ;
otherwise throwing an exception. |
static void |
finite(double value,
String message,
Object... values)
Validates that the specified argument is not infinite or
NaN ;
otherwise throwing an exception with the specified message. |
static void |
inclusiveBetween(double start,
double end,
double value)
Validate that the specified primitive value falls between the two
inclusive values specified; otherwise, throws an exception.
|
static void |
inclusiveBetween(double start,
double end,
double value,
String message)
Validate that the specified primitive value falls between the two
inclusive values specified; otherwise, throws an exception with the
specified message.
|
static void |
inclusiveBetween(long start,
long end,
long value)
Validate that the specified primitive value falls between the two
inclusive values specified; otherwise, throws an exception.
|
static void |
inclusiveBetween(long start,
long end,
long value,
String message)
Validate that the specified primitive value falls between the two
inclusive values specified; otherwise, throws an exception with the
specified message.
|
static <T> void |
inclusiveBetween(T start,
T end,
Comparable<T> value)
Validate that the specified argument object fall between the two
inclusive values specified; otherwise, throws an exception.
|
static <T> void |
inclusiveBetween(T start,
T end,
Comparable<T> value,
String message,
Object... values)
Validate that the specified argument object fall between the two
inclusive values specified; otherwise, throws an exception with the
specified message.
|
static void |
isAssignableFrom(Class<?> superType,
Class<?> type)
Validates that the argument can be converted to the specified class, if not, throws an exception.
|
static void |
isAssignableFrom(Class<?> superType,
Class<?> type,
String message,
Object... values)
Validates that the argument can be converted to the specified class, if not throws an exception.
|
static void |
isInstanceOf(Class<?> type,
Object obj)
Validates that the argument is an instance of the specified class, if not throws an exception.
|
static void |
isInstanceOf(Class<?> type,
Object obj,
String message,
Object... values)
Validate that the argument is an instance of the specified class; otherwise
throwing an exception with the specified message.
|
static void |
isTrue(boolean expression)
Validate that the argument condition is
true ; otherwise
throwing an exception. |
static void |
isTrue(boolean expression,
String message,
double value)
Validate that the argument condition is
true ; otherwise
throwing an exception with the specified message. |
static void |
isTrue(boolean expression,
String message,
long value)
Validate that the argument condition is
true ; otherwise
throwing an exception with the specified message. |
static void |
isTrue(boolean expression,
String message,
Object... values)
Validate that the argument condition is
true ; otherwise
throwing an exception with the specified message. |
static void |
matchesPattern(CharSequence input,
String pattern)
Validate that the specified argument character sequence matches the specified regular
expression pattern; otherwise throwing an exception.
|
static void |
matchesPattern(CharSequence input,
String pattern,
String message,
Object... values)
Validate that the specified argument character sequence matches the specified regular
expression pattern; otherwise throwing an exception with the specified message.
|
static <T extends Iterable<?>> |
noNullElements(T iterable)
Validate that the specified argument iterable is neither
null nor contains any elements that are null ;
otherwise throwing an exception. |
static <T> T[] |
noNullElements(T[] array)
Validate that the specified argument array is neither
null nor contains any elements that are null ;
otherwise throwing an exception. |
static <T> T[] |
noNullElements(T[] array,
String message,
Object... values)
Validate that the specified argument array is neither
null nor contains any elements that are null ;
otherwise throwing an exception with the specified message. |
static <T extends Iterable<?>> |
noNullElements(T iterable,
String message,
Object... values)
Validate that the specified argument iterable is neither
null nor contains any elements that are null ;
otherwise throwing an exception with the specified message. |
static <T extends CharSequence> |
notBlank(T chars)
Validate that the specified argument character sequence is
neither
null , a length of zero (no characters), empty
nor whitespace; otherwise throwing an exception. |
static <T extends CharSequence> |
notBlank(T chars,
String message,
Object... values)
Validate that the specified argument character sequence is
neither
null , a length of zero (no characters), empty
nor whitespace; otherwise throwing an exception with the specified
message. |
static <T extends CharSequence> |
notEmpty(T chars)
Validate that the specified argument character sequence is
neither
null nor a length of zero (no characters);
otherwise throwing an exception with the specified message. |
static <T extends Collection<?>> |
notEmpty(T collection)
Validate that the specified argument collection is neither
null
nor a size of zero (no elements); otherwise throwing an exception. |
static <T extends Map<?,?>> |
notEmpty(T map)
Validate that the specified argument map is neither
null
nor a size of zero (no elements); otherwise throwing an exception. |
static <T> T[] |
notEmpty(T[] array)
Validate that the specified argument array is neither
null
nor a length of zero (no elements); otherwise throwing an exception. |
static <T> T[] |
notEmpty(T[] array,
String message,
Object... values)
Validate that the specified argument array is neither
null
nor a length of zero (no elements); otherwise throwing an exception
with the specified message. |
static <T extends CharSequence> |
notEmpty(T chars,
String message,
Object... values)
Validate that the specified argument character sequence is
neither
null nor a length of zero (no characters);
otherwise throwing an exception with the specified message. |
static <T extends Collection<?>> |
notEmpty(T collection,
String message,
Object... values)
Validate that the specified argument collection is neither
null
nor a size of zero (no elements); otherwise throwing an exception
with the specified message. |
static <T extends Map<?,?>> |
notEmpty(T map,
String message,
Object... values)
Validate that the specified argument map is neither
null
nor a size of zero (no elements); otherwise throwing an exception
with the specified message. |
static void |
notNaN(double value)
Validates that the specified argument is not
NaN ; otherwise
throwing an exception. |
static void |
notNaN(double value,
String message,
Object... values)
Validates that the specified argument is not
NaN ; otherwise
throwing an exception with the specified message. |
static <T> T |
notNull(T object)
Validate that the specified argument is not
null ;
otherwise throwing an exception. |
static <T> T |
notNull(T object,
String message,
Object... values)
Validate that the specified argument is not
null ;
otherwise throwing an exception with the specified message. |
static <T> T[] |
validIndex(T[] array,
int index)
Validates that the index is within the bounds of the argument
array; otherwise throwing an exception.
|
static <T> T[] |
validIndex(T[] array,
int index,
String message,
Object... values)
Validates that the index is within the bounds of the argument
array; otherwise throwing an exception with the specified message.
|
static <T extends CharSequence> |
validIndex(T chars,
int index)
Validates that the index is within the bounds of the argument
character sequence; otherwise throwing an exception.
|
static <T extends Collection<?>> |
validIndex(T collection,
int index)
Validates that the index is within the bounds of the argument
collection; otherwise throwing an exception.
|
static <T extends CharSequence> |
validIndex(T chars,
int index,
String message,
Object... values)
Validates that the index is within the bounds of the argument
character sequence; otherwise throwing an exception with the
specified message.
|
static <T extends Collection<?>> |
validIndex(T collection,
int index,
String message,
Object... values)
Validates that the index is within the bounds of the argument
collection; otherwise throwing an exception with the specified message.
|
static void |
validState(boolean expression)
Validate that the stateful condition is
true ; otherwise
throwing an exception. |
static void |
validState(boolean expression,
String message,
Object... values)
Validate that the stateful condition is
true ; otherwise
throwing an exception with the specified message. |
public Validate()
public static void isTrue(boolean expression, String message, long value)
Validate that the argument condition is true
; otherwise
throwing an exception with the specified message. This method is useful when
validating according to an arbitrary boolean expression, such as validating a
primitive number or using your own custom validation expression.
Validate.isTrue(i > 0.0, "The value must be greater than zero: %d", i);
For performance reasons, the long value is passed as a separate parameter and appended to the exception message only in the case of an error.
expression
- the boolean expression to checkmessage
- the String.format(String, Object...)
exception message if invalid, not nullvalue
- the value to append to the message when invalidIllegalArgumentException
- if expression is false
isTrue(boolean)
,
isTrue(boolean, String, double)
,
isTrue(boolean, String, Object...)
public static void isTrue(boolean expression, String message, double value)
Validate that the argument condition is true
; otherwise
throwing an exception with the specified message. This method is useful when
validating according to an arbitrary boolean expression, such as validating a
primitive number or using your own custom validation expression.
Validate.isTrue(d > 0.0, "The value must be greater than zero: %s", d);
For performance reasons, the double value is passed as a separate parameter and appended to the exception message only in the case of an error.
expression
- the boolean expression to checkmessage
- the String.format(String, Object...)
exception message if invalid, not nullvalue
- the value to append to the message when invalidIllegalArgumentException
- if expression is false
isTrue(boolean)
,
isTrue(boolean, String, long)
,
isTrue(boolean, String, Object...)
public static void isTrue(boolean expression, String message, Object... values)
Validate that the argument condition is true
; otherwise
throwing an exception with the specified message. This method is useful when
validating according to an arbitrary boolean expression, such as validating a
primitive number or using your own custom validation expression.
Validate.isTrue(i >= min && i <= max, "The value must be between %d and %d", min, max); Validate.isTrue(myObject.isOk(), "The object is not okay");
expression
- the boolean expression to checkmessage
- the String.format(String, Object...)
exception message if invalid, not nullvalues
- the optional values for the formatted exception message, null array not recommendedIllegalArgumentException
- if expression is false
isTrue(boolean)
,
isTrue(boolean, String, long)
,
isTrue(boolean, String, double)
public static void isTrue(boolean expression)
Validate that the argument condition is true
; otherwise
throwing an exception. This method is useful when validating according
to an arbitrary boolean expression, such as validating a
primitive number or using your own custom validation expression.
Validate.isTrue(i > 0); Validate.isTrue(myObject.isOk());
The message of the exception is "The validated expression is false".
expression
- the boolean expression to checkIllegalArgumentException
- if expression is false
isTrue(boolean, String, long)
,
isTrue(boolean, String, double)
,
isTrue(boolean, String, Object...)
public static <T> T notNull(T object)
Validate that the specified argument is not null
;
otherwise throwing an exception.
Validate.notNull(myObject, "The object must not be null");
The message of the exception is "The validated object is null".
T
- the object typeobject
- the object to checknull
for method chaining)NullPointerException
- if the object is null
notNull(Object, String, Object...)
public static <T> T notNull(T object, String message, Object... values)
Validate that the specified argument is not null
;
otherwise throwing an exception with the specified message.
Validate.notNull(myObject, "The object must not be null");
T
- the object typeobject
- the object to checkmessage
- the String.format(String, Object...)
exception message if invalid, not nullvalues
- the optional values for the formatted exception messagenull
for method chaining)NullPointerException
- if the object is null
notNull(Object)
public static <T> T[] notEmpty(T[] array, String message, Object... values)
Validate that the specified argument array is neither null
nor a length of zero (no elements); otherwise throwing an exception
with the specified message.
Validate.notEmpty(myArray, "The array must not be empty");
T
- the array typearray
- the array to check, validated not null by this methodmessage
- the String.format(String, Object...)
exception message if invalid, not nullvalues
- the optional values for the formatted exception message, null array not recommendednull
method for chaining)NullPointerException
- if the array is null
IllegalArgumentException
- if the array is emptynotEmpty(Object[])
public static <T> T[] notEmpty(T[] array)
Validate that the specified argument array is neither null
nor a length of zero (no elements); otherwise throwing an exception.
Validate.notEmpty(myArray);
The message in the exception is "The validated array is empty".
T
- the array typearray
- the array to check, validated not null by this methodnull
method for chaining)NullPointerException
- if the array is null
IllegalArgumentException
- if the array is emptynotEmpty(Object[], String, Object...)
public static <T extends Collection<?>> T notEmpty(T collection, String message, Object... values)
Validate that the specified argument collection is neither null
nor a size of zero (no elements); otherwise throwing an exception
with the specified message.
Validate.notEmpty(myCollection, "The collection must not be empty");
T
- the collection typecollection
- the collection to check, validated not null by this methodmessage
- the String.format(String, Object...)
exception message if invalid, not nullvalues
- the optional values for the formatted exception message, null array not recommendednull
method for chaining)NullPointerException
- if the collection is null
IllegalArgumentException
- if the collection is emptynotEmpty(Object[])
public static <T extends Collection<?>> T notEmpty(T collection)
Validate that the specified argument collection is neither null
nor a size of zero (no elements); otherwise throwing an exception.
Validate.notEmpty(myCollection);
The message in the exception is "The validated collection is empty".
T
- the collection typecollection
- the collection to check, validated not null by this methodnull
method for chaining)NullPointerException
- if the collection is null
IllegalArgumentException
- if the collection is emptynotEmpty(Collection, String, Object...)
public static <T extends Map<?,?>> T notEmpty(T map, String message, Object... values)
Validate that the specified argument map is neither null
nor a size of zero (no elements); otherwise throwing an exception
with the specified message.
Validate.notEmpty(myMap, "The map must not be empty");
T
- the map typemap
- the map to check, validated not null by this methodmessage
- the String.format(String, Object...)
exception message if invalid, not nullvalues
- the optional values for the formatted exception message, null array not recommendednull
method for chaining)NullPointerException
- if the map is null
IllegalArgumentException
- if the map is emptynotEmpty(Object[])
public static <T extends Map<?,?>> T notEmpty(T map)
Validate that the specified argument map is neither null
nor a size of zero (no elements); otherwise throwing an exception.
Validate.notEmpty(myMap);
The message in the exception is "The validated map is empty".
T
- the map typemap
- the map to check, validated not null by this methodnull
method for chaining)NullPointerException
- if the map is null
IllegalArgumentException
- if the map is emptynotEmpty(Map, String, Object...)
public static <T extends CharSequence> T notEmpty(T chars, String message, Object... values)
Validate that the specified argument character sequence is
neither null
nor a length of zero (no characters);
otherwise throwing an exception with the specified message.
Validate.notEmpty(myString, "The string must not be empty");
T
- the character sequence typechars
- the character sequence to check, validated not null by this methodmessage
- the String.format(String, Object...)
exception message if invalid, not nullvalues
- the optional values for the formatted exception message, null array not recommendednull
method for chaining)NullPointerException
- if the character sequence is null
IllegalArgumentException
- if the character sequence is emptynotEmpty(CharSequence)
public static <T extends CharSequence> T notEmpty(T chars)
Validate that the specified argument character sequence is
neither null
nor a length of zero (no characters);
otherwise throwing an exception with the specified message.
Validate.notEmpty(myString);
The message in the exception is "The validated character sequence is empty".
T
- the character sequence typechars
- the character sequence to check, validated not null by this methodnull
method for chaining)NullPointerException
- if the character sequence is null
IllegalArgumentException
- if the character sequence is emptynotEmpty(CharSequence, String, Object...)
public static <T extends CharSequence> T notBlank(T chars, String message, Object... values)
Validate that the specified argument character sequence is
neither null
, a length of zero (no characters), empty
nor whitespace; otherwise throwing an exception with the specified
message.
Validate.notBlank(myString, "The string must not be blank");
T
- the character sequence typechars
- the character sequence to check, validated not null by this methodmessage
- the String.format(String, Object...)
exception message if invalid, not nullvalues
- the optional values for the formatted exception message, null array not recommendednull
method for chaining)NullPointerException
- if the character sequence is null
IllegalArgumentException
- if the character sequence is blanknotBlank(CharSequence)
public static <T extends CharSequence> T notBlank(T chars)
Validate that the specified argument character sequence is
neither null
, a length of zero (no characters), empty
nor whitespace; otherwise throwing an exception.
Validate.notBlank(myString);
The message in the exception is "The validated character sequence is blank".
T
- the character sequence typechars
- the character sequence to check, validated not null by this methodnull
method for chaining)NullPointerException
- if the character sequence is null
IllegalArgumentException
- if the character sequence is blanknotBlank(CharSequence, String, Object...)
public static <T> T[] noNullElements(T[] array, String message, Object... values)
Validate that the specified argument array is neither
null
nor contains any elements that are null
;
otherwise throwing an exception with the specified message.
Validate.noNullElements(myArray, "The array contain null at position %d");
If the array is null
, then the message in the exception
is "The validated object is null".
If the array has a null
element, then the iteration
index of the invalid element is appended to the values
argument.
T
- the array typearray
- the array to check, validated not null by this methodmessage
- the String.format(String, Object...)
exception message if invalid, not nullvalues
- the optional values for the formatted exception message, null array not recommendednull
method for chaining)NullPointerException
- if the array is null
IllegalArgumentException
- if an element is null
noNullElements(Object[])
public static <T> T[] noNullElements(T[] array)
Validate that the specified argument array is neither
null
nor contains any elements that are null
;
otherwise throwing an exception.
Validate.noNullElements(myArray);
If the array is null
, then the message in the exception
is "The validated object is null".
If the array has a null
element, then the message in the
exception is "The validated array contains null element at index:
" followed by the index.
T
- the array typearray
- the array to check, validated not null by this methodnull
method for chaining)NullPointerException
- if the array is null
IllegalArgumentException
- if an element is null
noNullElements(Object[], String, Object...)
public static <T extends Iterable<?>> T noNullElements(T iterable, String message, Object... values)
Validate that the specified argument iterable is neither
null
nor contains any elements that are null
;
otherwise throwing an exception with the specified message.
Validate.noNullElements(myCollection, "The collection contains null at position %d");
If the iterable is null
, then the message in the exception
is "The validated object is null".
If the iterable has a null
element, then the iteration
index of the invalid element is appended to the values
argument.
T
- the iterable typeiterable
- the iterable to check, validated not null by this methodmessage
- the String.format(String, Object...)
exception message if invalid, not nullvalues
- the optional values for the formatted exception message, null array not recommendednull
method for chaining)NullPointerException
- if the array is null
IllegalArgumentException
- if an element is null
noNullElements(Iterable)
public static <T extends Iterable<?>> T noNullElements(T iterable)
Validate that the specified argument iterable is neither
null
nor contains any elements that are null
;
otherwise throwing an exception.
Validate.noNullElements(myCollection);
If the iterable is null
, then the message in the exception
is "The validated object is null".
If the array has a null
element, then the message in the
exception is "The validated iterable contains null element at index:
" followed by the index.
T
- the iterable typeiterable
- the iterable to check, validated not null by this methodnull
method for chaining)NullPointerException
- if the array is null
IllegalArgumentException
- if an element is null
noNullElements(Iterable, String, Object...)
public static <T> T[] validIndex(T[] array, int index, String message, Object... values)
Validates that the index is within the bounds of the argument array; otherwise throwing an exception with the specified message.
Validate.validIndex(myArray, 2, "The array index is invalid: ");
If the array is null
, then the message of the exception
is "The validated object is null".
T
- the array typearray
- the array to check, validated not null by this methodindex
- the index to checkmessage
- the String.format(String, Object...)
exception message if invalid, not nullvalues
- the optional values for the formatted exception message, null array not recommendednull
for method chaining)NullPointerException
- if the array is null
IndexOutOfBoundsException
- if the index is invalidvalidIndex(Object[], int)
public static <T> T[] validIndex(T[] array, int index)
Validates that the index is within the bounds of the argument array; otherwise throwing an exception.
Validate.validIndex(myArray, 2);
If the array is null
, then the message of the exception
is "The validated object is null".
If the index is invalid, then the message of the exception is "The validated array index is invalid: " followed by the index.
T
- the array typearray
- the array to check, validated not null by this methodindex
- the index to checknull
for method chaining)NullPointerException
- if the array is null
IndexOutOfBoundsException
- if the index is invalidvalidIndex(Object[], int, String, Object...)
public static <T extends Collection<?>> T validIndex(T collection, int index, String message, Object... values)
Validates that the index is within the bounds of the argument collection; otherwise throwing an exception with the specified message.
Validate.validIndex(myCollection, 2, "The collection index is invalid: ");
If the collection is null
, then the message of the
exception is "The validated object is null".
T
- the collection typecollection
- the collection to check, validated not null by this methodindex
- the index to checkmessage
- the String.format(String, Object...)
exception message if invalid, not nullvalues
- the optional values for the formatted exception message, null array not recommendednull
for chaining)NullPointerException
- if the collection is null
IndexOutOfBoundsException
- if the index is invalidvalidIndex(Collection, int)
public static <T extends Collection<?>> T validIndex(T collection, int index)
Validates that the index is within the bounds of the argument collection; otherwise throwing an exception.
Validate.validIndex(myCollection, 2);
If the index is invalid, then the message of the exception is "The validated collection index is invalid: " followed by the index.
T
- the collection typecollection
- the collection to check, validated not null by this methodindex
- the index to checknull
for method chaining)NullPointerException
- if the collection is null
IndexOutOfBoundsException
- if the index is invalidvalidIndex(Collection, int, String, Object...)
public static <T extends CharSequence> T validIndex(T chars, int index, String message, Object... values)
Validates that the index is within the bounds of the argument character sequence; otherwise throwing an exception with the specified message.
Validate.validIndex(myStr, 2, "The string index is invalid: ");
If the character sequence is null
, then the message
of the exception is "The validated object is null".
T
- the character sequence typechars
- the character sequence to check, validated not null by this methodindex
- the index to checkmessage
- the String.format(String, Object...)
exception message if invalid, not nullvalues
- the optional values for the formatted exception message, null array not recommendednull
for method chaining)NullPointerException
- if the character sequence is null
IndexOutOfBoundsException
- if the index is invalidvalidIndex(CharSequence, int)
public static <T extends CharSequence> T validIndex(T chars, int index)
Validates that the index is within the bounds of the argument character sequence; otherwise throwing an exception.
Validate.validIndex(myStr, 2);
If the character sequence is null
, then the message
of the exception is "The validated object is
null".
If the index is invalid, then the message of the exception is "The validated character sequence index is invalid: " followed by the index.
T
- the character sequence typechars
- the character sequence to check, validated not null by this methodindex
- the index to checknull
for method chaining)NullPointerException
- if the character sequence is null
IndexOutOfBoundsException
- if the index is invalidvalidIndex(CharSequence, int, String, Object...)
public static void validState(boolean expression)
Validate that the stateful condition is true
; otherwise
throwing an exception. This method is useful when validating according
to an arbitrary boolean expression, such as validating a
primitive number or using your own custom validation expression.
Validate.validState(field > 0); Validate.validState(this.isOk());
The message of the exception is "The validated state is false".
expression
- the boolean expression to checkIllegalStateException
- if expression is false
validState(boolean, String, Object...)
public static void validState(boolean expression, String message, Object... values)
Validate that the stateful condition is true
; otherwise
throwing an exception with the specified message. This method is useful when
validating according to an arbitrary boolean expression, such as validating a
primitive number or using your own custom validation expression.
Validate.validState(this.isOk(), "The state is not OK: %s", myObject);
expression
- the boolean expression to checkmessage
- the String.format(String, Object...)
exception message if invalid, not nullvalues
- the optional values for the formatted exception message, null array not recommendedIllegalStateException
- if expression is false
validState(boolean)
public static void matchesPattern(CharSequence input, String pattern)
Validate that the specified argument character sequence matches the specified regular expression pattern; otherwise throwing an exception.
Validate.matchesPattern("hi", "[a-z]*");
The syntax of the pattern is the one used in the Pattern
class.
input
- the character sequence to validate, not nullpattern
- the regular expression pattern, not nullIllegalArgumentException
- if the character sequence does not match the patternmatchesPattern(CharSequence, String, String, Object...)
public static void matchesPattern(CharSequence input, String pattern, String message, Object... values)
Validate that the specified argument character sequence matches the specified regular expression pattern; otherwise throwing an exception with the specified message.
Validate.matchesPattern("hi", "[a-z]*", "%s does not match %s", "hi" "[a-z]*");
The syntax of the pattern is the one used in the Pattern
class.
input
- the character sequence to validate, not nullpattern
- the regular expression pattern, not nullmessage
- the String.format(String, Object...)
exception message if invalid, not nullvalues
- the optional values for the formatted exception message, null array not recommendedIllegalArgumentException
- if the character sequence does not match the patternmatchesPattern(CharSequence, String)
public static void notNaN(double value)
Validates that the specified argument is not NaN
; otherwise
throwing an exception.
Validate.notNaN(myDouble);
The message of the exception is "The validated value is not a number".
value
- the value to validateIllegalArgumentException
- if the value is not a numbernotNaN(double, java.lang.String, java.lang.Object...)
public static void notNaN(double value, String message, Object... values)
Validates that the specified argument is not NaN
; otherwise
throwing an exception with the specified message.
Validate.notNaN(myDouble, "The value must be a number");
value
- the value to validatemessage
- the String.format(String, Object...)
exception message if invalid, not nullvalues
- the optional values for the formatted exception messageIllegalArgumentException
- if the value is not a numbernotNaN(double)
public static void finite(double value)
Validates that the specified argument is not infinite or NaN
;
otherwise throwing an exception.
Validate.finite(myDouble);
The message of the exception is "The value is invalid: %f".
value
- the value to validateIllegalArgumentException
- if the value is infinite or NaN
finite(double, java.lang.String, java.lang.Object...)
public static void finite(double value, String message, Object... values)
Validates that the specified argument is not infinite or NaN
;
otherwise throwing an exception with the specified message.
Validate.finite(myDouble, "The argument must contain a numeric value");
value
- the value to validatemessage
- the String.format(String, Object...)
exception message if invalid, not nullvalues
- the optional values for the formatted exception messageIllegalArgumentException
- if the value is infinite or NaN
finite(double)
public static <T> void inclusiveBetween(T start, T end, Comparable<T> value)
Validate that the specified argument object fall between the two inclusive values specified; otherwise, throws an exception.
Validate.inclusiveBetween(0, 2, 1);
T
- the type of the argument objectstart
- the inclusive start value, not nullend
- the inclusive end value, not nullvalue
- the object to validate, not nullIllegalArgumentException
- if the value falls outside the boundariesinclusiveBetween(Object, Object, Comparable, String, Object...)
public static <T> void inclusiveBetween(T start, T end, Comparable<T> value, String message, Object... values)
Validate that the specified argument object fall between the two inclusive values specified; otherwise, throws an exception with the specified message.
Validate.inclusiveBetween(0, 2, 1, "Not in boundaries");
T
- the type of the argument objectstart
- the inclusive start value, not nullend
- the inclusive end value, not nullvalue
- the object to validate, not nullmessage
- the String.format(String, Object...)
exception message if invalid, not nullvalues
- the optional values for the formatted exception message, null array not recommendedIllegalArgumentException
- if the value falls outside the boundariesinclusiveBetween(Object, Object, Comparable)
public static void inclusiveBetween(long start, long end, long value)
Validate.inclusiveBetween(0, 2, 1);
start
- the inclusive start valueend
- the inclusive end valuevalue
- the value to validateIllegalArgumentException
- if the value falls outside the boundaries (inclusive)public static void inclusiveBetween(long start, long end, long value, String message)
Validate.inclusiveBetween(0, 2, 1, "Not in range");
start
- the inclusive start valueend
- the inclusive end valuevalue
- the value to validatemessage
- the exception message if invalid, not nullIllegalArgumentException
- if the value falls outside the boundariespublic static void inclusiveBetween(double start, double end, double value)
Validate.inclusiveBetween(0.1, 2.1, 1.1);
start
- the inclusive start valueend
- the inclusive end valuevalue
- the value to validateIllegalArgumentException
- if the value falls outside the boundaries (inclusive)public static void inclusiveBetween(double start, double end, double value, String message)
Validate.inclusiveBetween(0.1, 2.1, 1.1, "Not in range");
start
- the inclusive start valueend
- the inclusive end valuevalue
- the value to validatemessage
- the exception message if invalid, not nullIllegalArgumentException
- if the value falls outside the boundariespublic static <T> void exclusiveBetween(T start, T end, Comparable<T> value)
Validate that the specified argument object fall between the two exclusive values specified; otherwise, throws an exception.
Validate.exclusiveBetween(0, 2, 1);
T
- the type of the argument objectstart
- the exclusive start value, not nullend
- the exclusive end value, not nullvalue
- the object to validate, not nullIllegalArgumentException
- if the value falls outside the boundariesexclusiveBetween(Object, Object, Comparable, String, Object...)
public static <T> void exclusiveBetween(T start, T end, Comparable<T> value, String message, Object... values)
Validate that the specified argument object fall between the two exclusive values specified; otherwise, throws an exception with the specified message.
Validate.exclusiveBetween(0, 2, 1, "Not in boundaries");
T
- the type of the argument objectstart
- the exclusive start value, not nullend
- the exclusive end value, not nullvalue
- the object to validate, not nullmessage
- the String.format(String, Object...)
exception message if invalid, not nullvalues
- the optional values for the formatted exception message, null array not recommendedIllegalArgumentException
- if the value falls outside the boundariesexclusiveBetween(Object, Object, Comparable)
public static void exclusiveBetween(long start, long end, long value)
Validate.exclusiveBetween(0, 2, 1);
start
- the exclusive start valueend
- the exclusive end valuevalue
- the value to validateIllegalArgumentException
- if the value falls out of the boundariespublic static void exclusiveBetween(long start, long end, long value, String message)
Validate.exclusiveBetween(0, 2, 1, "Not in range");
start
- the exclusive start valueend
- the exclusive end valuevalue
- the value to validatemessage
- the exception message if invalid, not nullIllegalArgumentException
- if the value falls outside the boundariespublic static void exclusiveBetween(double start, double end, double value)
Validate.exclusiveBetween(0.1, 2.1, 1.1);
start
- the exclusive start valueend
- the exclusive end valuevalue
- the value to validateIllegalArgumentException
- if the value falls out of the boundariespublic static void exclusiveBetween(double start, double end, double value, String message)
Validate.exclusiveBetween(0.1, 2.1, 1.1, "Not in range");
start
- the exclusive start valueend
- the exclusive end valuevalue
- the value to validatemessage
- the exception message if invalid, not nullIllegalArgumentException
- if the value falls outside the boundariespublic static void isInstanceOf(Class<?> type, Object obj)
This method is useful when validating according to an arbitrary class
Validate.isInstanceOf(OkClass.class, object);
The message of the exception is "Expected type: {type}, actual: {obj_type}"
type
- the class the object must be validated against, not nullobj
- the object to check, null throws an exceptionIllegalArgumentException
- if argument is not of specified classisInstanceOf(Class, Object, String, Object...)
public static void isInstanceOf(Class<?> type, Object obj, String message, Object... values)
Validate that the argument is an instance of the specified class; otherwise throwing an exception with the specified message. This method is useful when validating according to an arbitrary class
Validate.isInstanceOf(OkClass.class, object, "Wrong class, object is of class %s", object.getClass().getName());
type
- the class the object must be validated against, not nullobj
- the object to check, null throws an exceptionmessage
- the String.format(String, Object...)
exception message if invalid, not nullvalues
- the optional values for the formatted exception message, null array not recommendedIllegalArgumentException
- if argument is not of specified classisInstanceOf(Class, Object)
public static void isAssignableFrom(Class<?> superType, Class<?> type)
This method is useful when validating that there will be no casting errors.
Validate.isAssignableFrom(SuperClass.class, object.getClass());
The message format of the exception is "Cannot assign {type} to {superType}"
superType
- the class the class must be validated against, not nulltype
- the class to check, not nullIllegalArgumentException
- if type argument is not assignable to the specified superTypeisAssignableFrom(Class, Class, String, Object...)
public static void isAssignableFrom(Class<?> superType, Class<?> type, String message, Object... values)
This method is useful when validating if there will be no casting errors.
Validate.isAssignableFrom(SuperClass.class, object.getClass());
The message of the exception is "The validated object can not be converted to the" followed by the name of the class and "class"
superType
- the class the class must be validated against, not nulltype
- the class to check, not nullmessage
- the String.format(String, Object...)
exception message if invalid, not nullvalues
- the optional values for the formatted exception message, null array not recommendedIllegalArgumentException
- if argument can not be converted to the specified classisAssignableFrom(Class, Class)
Copyright © 2001–2019 The Apache Software Foundation. All rights reserved.