com.helger.commons.ValueEnforcer Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of ph-commons Show documentation
Show all versions of ph-commons Show documentation
Java 1.6+ Library with tons of utility classes required in all projects
/**
* Copyright (C) 2014-2016 Philip Helger (www.helger.com)
* philip[at]helger[dot]com
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.helger.commons;
import java.math.BigDecimal;
import java.math.BigInteger;
import java.util.Collection;
import java.util.Map;
import java.util.concurrent.atomic.AtomicBoolean;
import java.util.function.Supplier;
import javax.annotation.Nonnegative;
import javax.annotation.Nonnull;
import javax.annotation.Nullable;
import javax.annotation.concurrent.Immutable;
import com.helger.commons.annotation.CodingStyleguideUnaware;
import com.helger.commons.equals.EqualsHelper;
/**
* This class contains "runtime assertions" utility methods.
*
* @author Philip Helger
*/
@Immutable
public final class ValueEnforcer
{
private static final AtomicBoolean s_aEnabled = new AtomicBoolean (true);
private ValueEnforcer ()
{}
/**
* @return true
if the assertions are enabled, false
* otherwise. By default the checks are enabled.
*/
public static boolean isEnabled ()
{
return s_aEnabled.get ();
}
/**
* Enable or disable the checks. By default checks are enabled.
*
* @param bEnabled
* true
to enable it, false
otherwise.
*/
public static void setEnabled (final boolean bEnabled)
{
s_aEnabled.set (bEnabled);
}
/**
* Check that the passed value is true
.
*
* @param bValue
* The value to check.
* @param sMsg
* The message to be emitted in case the value is false
* @throws IllegalArgumentException
* if the passed value is not null
.
*/
public static void isTrue (final boolean bValue, final String sMsg)
{
isTrue (bValue, () -> sMsg);
}
/**
* Check that the passed value is true
.
*
* @param bValue
* The value to check.
* @param aMsg
* The message to be emitted in case the value is false
* @throws IllegalArgumentException
* if the passed value is not null
.
*/
public static void isTrue (final boolean bValue, @Nonnull final Supplier aMsg)
{
if (isEnabled ())
if (!bValue)
throw new IllegalArgumentException ("The expression must be true but it is not: " + aMsg.get ());
}
/**
* Check that the passed value is false
.
*
* @param bValue
* The value to check.
* @param sMsg
* The message to be emitted in case the value is true
* @throws IllegalArgumentException
* if the passed value is not null
.
*/
public static void isFalse (final boolean bValue, final String sMsg)
{
isFalse (bValue, () -> sMsg);
}
/**
* Check that the passed value is false
.
*
* @param bValue
* The value to check.
* @param aMsg
* The message to be emitted in case the value is true
* @throws IllegalArgumentException
* if the passed value is not null
.
*/
public static void isFalse (final boolean bValue, @Nonnull final Supplier aMsg)
{
if (isEnabled ())
if (bValue)
throw new IllegalArgumentException ("The expression must be false but it is not: " + aMsg.get ());
}
/**
* Check that the passed value is not null
.
*
* @param
* Type to be checked and returned
* @param aValue
* The value to check.
* @param sName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws NullPointerException
* if the passed value is null
.
*/
public static T notNull (final T aValue, final String sName)
{
return notNull (aValue, () -> sName);
}
/**
* Check that the passed value is not null
.
*
* @param
* Type to be checked and returned
* @param aValue
* The value to check.
* @param aName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws NullPointerException
* if the passed value is null
.
*/
public static T notNull (final T aValue, @Nonnull final Supplier aName)
{
if (isEnabled ())
if (aValue == null)
throw new NullPointerException ("The value of '" + aName.get () + "' may not be null!");
return aValue;
}
/**
* Check that the passed value is null
.
*
* @param aValue
* The value to check.
* @param sName
* The name of the value (e.g. the parameter name)
* @throws IllegalArgumentException
* if the passed value is not null
.
*/
public static void isNull (final Object aValue, final String sName)
{
isNull (aValue, () -> sName);
}
/**
* Check that the passed value is null
.
*
* @param aValue
* The value to check.
* @param aName
* The name of the value (e.g. the parameter name)
* @throws IllegalArgumentException
* if the passed value is not null
.
*/
public static void isNull (final Object aValue, @Nonnull final Supplier aName)
{
if (isEnabled ())
if (aValue != null)
throw new IllegalArgumentException ("The value of '" + aName.get () + "' must be null but is " + aValue);
}
/**
* Check that the passed String is neither null
nor empty.
*
* @param
* Type to be checked and returned
* @param aValue
* The String to check.
* @param sName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is empty
*/
public static T notEmpty (final T aValue, final String sName)
{
return notEmpty (aValue, () -> sName);
}
/**
* Check that the passed String is neither null
nor empty.
*
* @param
* Type to be checked and returned
* @param aValue
* The String to check.
* @param aName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is empty
*/
public static T notEmpty (final T aValue, @Nonnull final Supplier aName)
{
notNull (aValue, aName);
if (isEnabled ())
if (aValue.length () == 0)
throw new IllegalArgumentException ("The value of the string '" + aName.get () + "' may not be empty!");
return aValue;
}
/**
* Check that the passed Array is neither null
nor empty.
*
* @param
* Type to be checked and returned
* @param aValue
* The Array to check.
* @param sName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is empty
*/
public static T [] notEmpty (final T [] aValue, final String sName)
{
return notEmpty (aValue, () -> sName);
}
/**
* Check that the passed Array is neither null
nor empty.
*
* @param
* Type to be checked and returned
* @param aValue
* The Array to check.
* @param aName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is empty
*/
public static T [] notEmpty (final T [] aValue, @Nonnull final Supplier aName)
{
notNull (aValue, aName);
if (isEnabled ())
if (aValue.length == 0)
throw new IllegalArgumentException ("The value of the array '" + aName.get () + "' may not be empty!");
return aValue;
}
/**
* Check that the passed Array is neither null
nor empty.
*
* @param aValue
* The Array to check.
* @param sName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is empty
*/
public static boolean [] notEmpty (final boolean [] aValue, final String sName)
{
return notEmpty (aValue, () -> sName);
}
/**
* Check that the passed Array is neither null
nor empty.
*
* @param aValue
* The Array to check.
* @param aName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is empty
*/
public static boolean [] notEmpty (final boolean [] aValue, @Nonnull final Supplier aName)
{
notNull (aValue, aName);
if (isEnabled ())
if (aValue.length == 0)
throw new IllegalArgumentException ("The value of the array '" + aName.get () + "' may not be empty!");
return aValue;
}
/**
* Check that the passed Array is neither null
nor empty.
*
* @param aValue
* The Array to check.
* @param sName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is empty
*/
public static byte [] notEmpty (final byte [] aValue, final String sName)
{
return notEmpty (aValue, () -> sName);
}
/**
* Check that the passed Array is neither null
nor empty.
*
* @param aValue
* The Array to check.
* @param aName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is empty
*/
public static byte [] notEmpty (final byte [] aValue, @Nonnull final Supplier aName)
{
notNull (aValue, aName);
if (isEnabled ())
if (aValue.length == 0)
throw new IllegalArgumentException ("The value of the array '" + aName.get () + "' may not be empty!");
return aValue;
}
/**
* Check that the passed Array is neither null
nor empty.
*
* @param aValue
* The Array to check.
* @param sName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is empty
*/
public static char [] notEmpty (final char [] aValue, final String sName)
{
return notEmpty (aValue, () -> sName);
}
/**
* Check that the passed Array is neither null
nor empty.
*
* @param aValue
* The Array to check.
* @param aName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is empty
*/
public static char [] notEmpty (final char [] aValue, @Nonnull final Supplier aName)
{
notNull (aValue, aName);
if (isEnabled ())
if (aValue.length == 0)
throw new IllegalArgumentException ("The value of the array '" + aName.get () + "' may not be empty!");
return aValue;
}
/**
* Check that the passed Array is neither null
nor empty.
*
* @param aValue
* The Array to check.
* @param sName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is empty
*/
public static double [] notEmpty (final double [] aValue, final String sName)
{
return notEmpty (aValue, () -> sName);
}
/**
* Check that the passed Array is neither null
nor empty.
*
* @param aValue
* The Array to check.
* @param aName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is empty
*/
public static double [] notEmpty (final double [] aValue, @Nonnull final Supplier aName)
{
notNull (aValue, aName);
if (isEnabled ())
if (aValue.length == 0)
throw new IllegalArgumentException ("The value of the array '" + aName.get () + "' may not be empty!");
return aValue;
}
/**
* Check that the passed Array is neither null
nor empty.
*
* @param aValue
* The Array to check.
* @param sName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is empty
*/
public static float [] notEmpty (final float [] aValue, final String sName)
{
return notEmpty (aValue, () -> sName);
}
/**
* Check that the passed Array is neither null
nor empty.
*
* @param aValue
* The Array to check.
* @param aName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is empty
*/
public static float [] notEmpty (final float [] aValue, @Nonnull final Supplier aName)
{
notNull (aValue, aName);
if (isEnabled ())
if (aValue.length == 0)
throw new IllegalArgumentException ("The value of the array '" + aName.get () + "' may not be empty!");
return aValue;
}
/**
* Check that the passed Array is neither null
nor empty.
*
* @param aValue
* The Array to check.
* @param sName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is empty
*/
public static int [] notEmpty (final int [] aValue, final String sName)
{
return notEmpty (aValue, () -> sName);
}
/**
* Check that the passed Array is neither null
nor empty.
*
* @param aValue
* The Array to check.
* @param aName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is empty
*/
public static int [] notEmpty (final int [] aValue, @Nonnull final Supplier aName)
{
notNull (aValue, aName);
if (isEnabled ())
if (aValue.length == 0)
throw new IllegalArgumentException ("The value of the array '" + aName.get () + "' may not be empty!");
return aValue;
}
/**
* Check that the passed Array is neither null
nor empty.
*
* @param aValue
* The Array to check.
* @param sName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is empty
*/
public static long [] notEmpty (final long [] aValue, final String sName)
{
return notEmpty (aValue, () -> sName);
}
/**
* Check that the passed Array is neither null
nor empty.
*
* @param aValue
* The Array to check.
* @param aName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is empty
*/
public static long [] notEmpty (final long [] aValue, @Nonnull final Supplier aName)
{
notNull (aValue, aName);
if (isEnabled ())
if (aValue.length == 0)
throw new IllegalArgumentException ("The value of the array '" + aName.get () + "' may not be empty!");
return aValue;
}
/**
* Check that the passed Array is neither null
nor empty.
*
* @param aValue
* The Array to check.
* @param sName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is empty
*/
public static short [] notEmpty (final short [] aValue, final String sName)
{
return notEmpty (aValue, () -> sName);
}
/**
* Check that the passed Array is neither null
nor empty.
*
* @param aValue
* The Array to check.
* @param aName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is empty
*/
public static short [] notEmpty (final short [] aValue, @Nonnull final Supplier aName)
{
notNull (aValue, aName);
if (isEnabled ())
if (aValue.length == 0)
throw new IllegalArgumentException ("The value of the array '" + aName.get () + "' may not be empty!");
return aValue;
}
/**
* Check that the passed {@link Collection} is neither null
nor
* empty.
*
* @param
* Type to be checked and returned
* @param aValue
* The String to check.
* @param sName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is empty
*/
@CodingStyleguideUnaware
public static > T notEmpty (final T aValue, final String sName)
{
return notEmpty (aValue, () -> sName);
}
/**
* Check that the passed {@link Collection} is neither null
nor
* empty.
*
* @param
* Type to be checked and returned
* @param aValue
* The String to check.
* @param aName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is empty
*/
@CodingStyleguideUnaware
public static > T notEmpty (final T aValue, @Nonnull final Supplier aName)
{
notNull (aValue, aName);
if (isEnabled ())
if (aValue.isEmpty ())
throw new IllegalArgumentException ("The value of the collection '" + aName.get () + "' may not be empty!");
return aValue;
}
/**
* Check that the passed {@link Iterable} is neither null
nor
* empty.
*
* @param
* Type to be checked and returned
* @param aValue
* The String to check.
* @param sName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is empty
*/
@CodingStyleguideUnaware
public static > T notEmpty (final T aValue, final String sName)
{
return notEmpty (aValue, () -> sName);
}
/**
* Check that the passed {@link Iterable} is neither null
nor
* empty.
*
* @param
* Type to be checked and returned
* @param aValue
* The String to check.
* @param aName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is empty
*/
@CodingStyleguideUnaware
public static > T notEmpty (final T aValue, @Nonnull final Supplier aName)
{
notNull (aValue, aName);
if (isEnabled ())
if (!aValue.iterator ().hasNext ())
throw new IllegalArgumentException ("The value of the iterable '" + aName.get () + "' may not be empty!");
return aValue;
}
/**
* Check that the passed Collection is neither null
nor empty.
*
* @param
* Type to be checked and returned
* @param aValue
* The String to check.
* @param sName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is empty
*/
@CodingStyleguideUnaware
public static > T notEmpty (final T aValue, final String sName)
{
return notEmpty (aValue, () -> sName);
}
/**
* Check that the passed Collection is neither null
nor empty.
*
* @param
* Type to be checked and returned
* @param aValue
* The String to check.
* @param aName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is empty
*/
@CodingStyleguideUnaware
public static > T notEmpty (final T aValue, @Nonnull final Supplier aName)
{
notNull (aValue, aName);
if (isEnabled ())
if (aValue.isEmpty ())
throw new IllegalArgumentException ("The value of the map '" + aName.get () + "' may not be empty!");
return aValue;
}
/**
* Check that the passed Array contains no null
value. But the
* whole array can be null
or empty.
*
* @param
* Type to be checked and returned
* @param aValue
* The Array to check. May be null
.
* @param sName
* The name of the value (e.g. the parameter name)
* @return The passed value. Maybe null
.
* @throws IllegalArgumentException
* if the passed value is not empty and a null
value is
* contained
*/
@Nullable
public static T [] noNullValue (final T [] aValue, final String sName)
{
return noNullValue (aValue, () -> sName);
}
/**
* Check that the passed Array contains no null
value. But the
* whole array can be null
or empty.
*
* @param
* Type to be checked and returned
* @param aValue
* The Array to check. May be null
.
* @param aName
* The name of the value (e.g. the parameter name)
* @return The passed value. Maybe null
.
* @throws IllegalArgumentException
* if the passed value is not empty and a null
value is
* contained
*/
@Nullable
public static T [] noNullValue (final T [] aValue, @Nonnull final Supplier aName)
{
if (isEnabled ())
if (aValue != null)
{
int nIndex = 0;
for (final T aItem : aValue)
{
if (aItem == null)
throw new IllegalArgumentException ("Item " + nIndex + " of array '" + aName.get () + "' may not be null!");
++nIndex;
}
}
return aValue;
}
/**
* Check that the passed iterable contains no null
value. But the
* whole iterable can be null
or empty.
*
* @param
* Type to be checked and returned
* @param aValue
* The collection to check. May be null
.
* @param sName
* The name of the value (e.g. the parameter name)
* @return The passed value. Maybe null
.
* @throws IllegalArgumentException
* if the passed value is not empty and a null
value is
* contained
*/
@Nullable
public static > T noNullValue (final T aValue, final String sName)
{
return noNullValue (aValue, () -> sName);
}
/**
* Check that the passed iterable contains no null
value. But the
* whole iterable can be null
or empty.
*
* @param
* Type to be checked and returned
* @param aValue
* The collection to check. May be null
.
* @param aName
* The name of the value (e.g. the parameter name)
* @return The passed value. Maybe null
.
* @throws IllegalArgumentException
* if the passed value is not empty and a null
value is
* contained
*/
@Nullable
public static > T noNullValue (final T aValue, @Nonnull final Supplier aName)
{
if (isEnabled ())
if (aValue != null)
{
int nIndex = 0;
for (final Object aItem : aValue)
{
if (aItem == null)
throw new IllegalArgumentException ("Item " +
nIndex +
" of iterable '" +
aName.get () +
"' may not be null!");
++nIndex;
}
}
return aValue;
}
/**
* Check that the passed map is neither null
nor empty and that
* no null
key or value is contained.
*
* @param
* Type to be checked and returned
* @param aValue
* The map to check. May be null
.
* @param sName
* The name of the value (e.g. the parameter name)
* @return The passed value. Maybe null
.
* @throws IllegalArgumentException
* if the passed value is not empty and a null
key or
* null
value is contained
*/
@Nullable
@CodingStyleguideUnaware
public static > T noNullValue (final T aValue, final String sName)
{
return noNullValue (aValue, () -> sName);
}
/**
* Check that the passed map is neither null
nor empty and that
* no null
key or value is contained.
*
* @param
* Type to be checked and returned
* @param aValue
* The map to check. May be null
.
* @param aName
* The name of the value (e.g. the parameter name)
* @return The passed value. Maybe null
.
* @throws IllegalArgumentException
* if the passed value is not empty and a null
key or
* null
value is contained
*/
@Nullable
@CodingStyleguideUnaware
public static > T noNullValue (final T aValue, @Nonnull final Supplier aName)
{
if (isEnabled ())
if (aValue != null)
{
for (final Map.Entry , ?> aEntry : aValue.entrySet ())
{
if (aEntry.getKey () == null)
throw new IllegalArgumentException ("A key of map '" + aName.get () + "' may not be null!");
if (aEntry.getValue () == null)
throw new IllegalArgumentException ("A value of map '" + aName.get () + "' may not be null!");
}
}
return aValue;
}
/**
* Check that the passed Array is not null
and that no
* null
value is contained.
*
* @param
* Type to be checked and returned
* @param aValue
* The Array to check.
* @param sName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is null or a null
value is
* contained
*/
public static T [] notNullNoNullValue (final T [] aValue, final String sName)
{
return notNullNoNullValue (aValue, () -> sName);
}
/**
* Check that the passed Array is not null
and that no
* null
value is contained.
*
* @param
* Type to be checked and returned
* @param aValue
* The Array to check.
* @param aName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is null or a null
value is
* contained
*/
public static T [] notNullNoNullValue (final T [] aValue, @Nonnull final Supplier aName)
{
notNull (aValue, aName);
noNullValue (aValue, aName);
return aValue;
}
/**
* Check that the passed collection is not null
and that no
* null
value is contained.
*
* @param
* Type to be checked and returned
* @param aValue
* The collection to check.
* @param sName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is null
or a null
* value is contained
*/
public static > T notNullNoNullValue (final T aValue, final String sName)
{
return notNullNoNullValue (aValue, () -> sName);
}
/**
* Check that the passed collection is not null
and that no
* null
value is contained.
*
* @param
* Type to be checked and returned
* @param aValue
* The collection to check.
* @param aName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is null
or a null
* value is contained
*/
public static > T notNullNoNullValue (final T aValue, @Nonnull final Supplier aName)
{
notNull (aValue, aName);
noNullValue (aValue, aName);
return aValue;
}
/**
* Check that the passed map is not null
and that no
* null
value is contained.
*
* @param
* Type to be checked and returned
* @param aValue
* The map to check.
* @param sName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is null
or a null
* value is contained
*/
@CodingStyleguideUnaware
public static > T notNullNoNullValue (final T aValue, final String sName)
{
return notNullNoNullValue (aValue, () -> sName);
}
/**
* Check that the passed map is not null
and that no
* null
value is contained.
*
* @param
* Type to be checked and returned
* @param aValue
* The map to check.
* @param aName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is null
or a null
* value is contained
*/
@CodingStyleguideUnaware
public static > T notNullNoNullValue (final T aValue, @Nonnull final Supplier aName)
{
notNull (aValue, aName);
noNullValue (aValue, aName);
return aValue;
}
/**
* Check that the passed Array is neither null
nor empty and that
* no null
value is contained.
*
* @param
* Type to be checked and returned
* @param aValue
* The Array to check.
* @param sName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is empty or a null
value is
* contained
*/
public static T [] notEmptyNoNullValue (final T [] aValue, final String sName)
{
return notEmptyNoNullValue (aValue, () -> sName);
}
/**
* Check that the passed Array is neither null
nor empty and that
* no null
value is contained.
*
* @param
* Type to be checked and returned
* @param aValue
* The Array to check.
* @param aName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is empty or a null
value is
* contained
*/
public static T [] notEmptyNoNullValue (final T [] aValue, @Nonnull final Supplier aName)
{
notEmpty (aValue, aName);
noNullValue (aValue, aName);
return aValue;
}
/**
* Check that the passed collection is neither null
nor empty and
* that no null
value is contained.
*
* @param
* Type to be checked and returned
* @param aValue
* The collection to check.
* @param sName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is empty or a null
value is
* contained
*/
public static > T notEmptyNoNullValue (final T aValue, final String sName)
{
return notEmptyNoNullValue (aValue, () -> sName);
}
/**
* Check that the passed collection is neither null
nor empty and
* that no null
value is contained.
*
* @param
* Type to be checked and returned
* @param aValue
* The collection to check.
* @param aName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is empty or a null
value is
* contained
*/
public static > T notEmptyNoNullValue (final T aValue, @Nonnull final Supplier aName)
{
notEmpty (aValue, aName);
noNullValue (aValue, aName);
return aValue;
}
/**
* Check that the passed map is neither null
nor empty and that
* no null
value is contained.
*
* @param
* Type to be checked and returned
* @param aValue
* The map to check.
* @param sName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is empty or a null
value is
* contained
*/
@CodingStyleguideUnaware
public static > T notEmptyNoNullValue (final T aValue, final String sName)
{
return notEmptyNoNullValue (aValue, () -> sName);
}
/**
* Check that the passed map is neither null
nor empty and that
* no null
value is contained.
*
* @param
* Type to be checked and returned
* @param aValue
* The map to check.
* @param aName
* The name of the value (e.g. the parameter name)
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is empty or a null
value is
* contained
*/
@CodingStyleguideUnaware
public static > T notEmptyNoNullValue (final T aValue, @Nonnull final Supplier aName)
{
notEmpty (aValue, aName);
noNullValue (aValue, aName);
return aValue;
}
/**
* Check that the passed value is not null
and not equal to the
* provided value.
*
* @param
* Type to be checked and returned
* @param aValue
* The value to check. May not be null
.
* @param sName
* The name of the value (e.g. the parameter name)
* @param aUnexpectedValue
* The value that may not be equal to aValue. May not be
* null
.
* @return The passed value.
*/
public static T notNullNotEquals (final T aValue, final String sName, @Nonnull final T aUnexpectedValue)
{
return notNullNotEquals (aValue, () -> sName, aUnexpectedValue);
}
/**
* Check that the passed value is not null
and not equal to the
* provided value.
*
* @param
* Type to be checked and returned
* @param aValue
* The value to check. May not be null
.
* @param aName
* The name of the value (e.g. the parameter name)
* @param aUnexpectedValue
* The value that may not be equal to aValue. May not be
* null
.
* @return The passed value.
*/
public static T notNullNotEquals (final T aValue,
@Nonnull final Supplier aName,
@Nonnull final T aUnexpectedValue)
{
notNull (aValue, aName);
notNull (aUnexpectedValue, "UnexpectedValue");
if (isEnabled ())
if (aValue.equals (aUnexpectedValue))
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' may not be equal to " +
aUnexpectedValue +
"!");
return aValue;
}
/**
* Check that the passed value is not null
and equal to the
* provided expected value.
*
* @param
* Type to be checked and returned
* @param aValue
* The value to check.
* @param sName
* The name of the value (e.g. the parameter name)
* @param aExpectedValue
* The expected value. May not be null
.
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is not null
.
*/
public static T notNullAndEquals (final T aValue, final String sName, @Nonnull final T aExpectedValue)
{
return notNullAndEquals (aValue, () -> sName, aExpectedValue);
}
/**
* Check that the passed value is not null
and equal to the
* provided expected value.
*
* @param
* Type to be checked and returned
* @param aValue
* The value to check.
* @param aName
* The name of the value (e.g. the parameter name)
* @param aExpectedValue
* The expected value. May not be null
.
* @return The passed value.
* @throws IllegalArgumentException
* if the passed value is not null
.
*/
public static T notNullAndEquals (final T aValue,
@Nonnull final Supplier aName,
@Nonnull final T aExpectedValue)
{
notNull (aValue, aName);
if (isEnabled ())
if (!aValue.equals (aExpectedValue))
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' does not match the expected value. Passed value: " +
aValue +
" -- Expected value: " +
aExpectedValue);
return aValue;
}
/**
* Check that the passed value is the same as the provided expected value
* using ==
to check comparison.
*
* @param
* Type to be checked and returned
* @param aValue
* The value to check.
* @param sName
* The name of the value (e.g. the parameter name)
* @param aExpectedValue
* The expected value. May be null
.
* @return The passed value and maybe null
if the expected value
* is null.
* @throws IllegalArgumentException
* if the passed value is not null
.
*/
public static T isSame (final T aValue, final String sName, @Nullable final T aExpectedValue)
{
return isSame (aValue, () -> sName, aExpectedValue);
}
/**
* Check that the passed value is the same as the provided expected value
* using ==
to check comparison.
*
* @param
* Type to be checked and returned
* @param aValue
* The value to check.
* @param aName
* The name of the value (e.g. the parameter name)
* @param aExpectedValue
* The expected value. May be null
.
* @return The passed value and maybe null
if the expected value
* is null.
* @throws IllegalArgumentException
* if the passed value is not null
.
*/
public static T isSame (final T aValue, @Nonnull final Supplier aName, @Nullable final T aExpectedValue)
{
if (isEnabled ())
if (aValue != aExpectedValue)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' does not match the expected value. Passed value: " +
aValue +
" -- Expected value: " +
aExpectedValue);
return aValue;
}
/**
* Check that the passed value is the same as the provided expected value
* using equals
to check comparison.
*
* @param
* Type to be checked and returned
* @param aValue
* The value to check.
* @param sName
* The name of the value (e.g. the parameter name)
* @param aExpectedValue
* The expected value. May be null
.
* @return The passed value and maybe null
if the expected value
* is null.
* @throws IllegalArgumentException
* if the passed value is not null
.
*/
public static T isEqual (final T aValue, @Nullable final T aExpectedValue, final String sName)
{
return isSame (aValue, () -> sName, aExpectedValue);
}
/**
* Check that the passed value is the same as the provided expected value
* using equals
to check comparison.
*
* @param
* Type to be checked and returned
* @param aValue
* The value to check.
* @param aName
* The name of the value (e.g. the parameter name)
* @param aExpectedValue
* The expected value. May be null
.
* @return The passed value and maybe null
if the expected value
* is null.
* @throws IllegalArgumentException
* if the passed value is not null
.
*/
public static T isEqual (final T aValue, @Nullable final T aExpectedValue, @Nonnull final Supplier aName)
{
if (isEnabled ())
if (!EqualsHelper.equals (aValue, aExpectedValue))
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' does not match the expected value. Passed value: " +
aValue +
" -- Expected value: " +
aExpectedValue);
return aValue;
}
/**
* Check that the passed value is the same as the provided expected value
* using ==
to check comparison.
*
* @param nValue
* The First value.
* @param nExpectedValue
* The expected value.
* @param sName
* The name of the value (e.g. the parameter name)
* @throws IllegalArgumentException
* if the passed value is not null
.
*/
public static void isEqual (final int nValue, final int nExpectedValue, final String sName)
{
isEqual (nValue, nExpectedValue, () -> sName);
}
/**
* Check that the passed value is the same as the provided expected value
* using ==
to check comparison.
*
* @param nValue
* The First value.
* @param nExpectedValue
* The expected value.
* @param aName
* The name of the value (e.g. the parameter name)
* @throws IllegalArgumentException
* if the passed value is not null
.
*/
public static void isEqual (final int nValue, final int nExpectedValue, @Nonnull final Supplier aName)
{
if (isEnabled ())
if (nValue != nExpectedValue)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' does not match the expected value. Passed value: " +
nValue +
" -- Expected value: " +
nExpectedValue);
}
/**
* Check that the passed value is the same as the provided expected value
* using ==
to check comparison.
*
* @param nValue
* The First value.
* @param nExpectedValue
* The expected value.
* @param sName
* The name of the value (e.g. the parameter name)
* @throws IllegalArgumentException
* if the passed value is not null
.
*/
public static void isEqual (final long nValue, final long nExpectedValue, final String sName)
{
isEqual (nValue, nExpectedValue, () -> sName);
}
/**
* Check that the passed value is the same as the provided expected value
* using ==
to check comparison.
*
* @param nValue
* The First value.
* @param nExpectedValue
* The expected value.
* @param aName
* The name of the value (e.g. the parameter name)
* @throws IllegalArgumentException
* if the passed value is not null
.
*/
public static void isEqual (final long nValue, final long nExpectedValue, @Nonnull final Supplier aName)
{
if (isEnabled ())
if (nValue != nExpectedValue)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' does not match the expected value. Passed value: " +
nValue +
" -- Expected value: " +
nExpectedValue);
}
/**
* Check that the passed value is the same as the provided expected value
* using ==
to check comparison.
*
* @param dValue
* The First value.
* @param dExpectedValue
* The expected value.
* @param sName
* The name of the value (e.g. the parameter name)
* @throws IllegalArgumentException
* if the passed value is not null
.
*/
public static void isEqual (final double dValue, final double dExpectedValue, final String sName)
{
isEqual (dValue, dExpectedValue, () -> sName);
}
/**
* Check that the passed value is the same as the provided expected value
* using ==
to check comparison.
*
* @param dValue
* The First value.
* @param dExpectedValue
* The expected value.
* @param aName
* The name of the value (e.g. the parameter name)
* @throws IllegalArgumentException
* if the passed value is not null
.
*/
public static void isEqual (final double dValue, final double dExpectedValue, @Nonnull final Supplier aName)
{
if (isEnabled ())
if (!EqualsHelper.equals (dValue, dExpectedValue))
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' does not match the expected value. Passed value: " +
dValue +
" -- Expected value: " +
dExpectedValue);
}
public static int isGE0 (final int nValue, final String sName)
{
return isGE0 (nValue, () -> sName);
}
public static int isGE0 (final int nValue, @Nonnull final Supplier aName)
{
if (isEnabled ())
if (nValue < 0)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be >= 0! The current value is: " +
nValue);
return nValue;
}
public static long isGE0 (final long nValue, final String sName)
{
return isGE0 (nValue, () -> sName);
}
public static long isGE0 (final long nValue, @Nonnull final Supplier aName)
{
if (isEnabled ())
if (nValue < 0)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be >= 0! The current value is: " +
nValue);
return nValue;
}
public static short isGE0 (final short nValue, final String sName)
{
return isGE0 (nValue, () -> sName);
}
public static short isGE0 (final short nValue, @Nonnull final Supplier aName)
{
if (isEnabled ())
if (nValue < 0)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be >= 0! The current value is: " +
nValue);
return nValue;
}
public static double isGE0 (final double dValue, final String sName)
{
return isGE0 (dValue, () -> sName);
}
public static double isGE0 (final double dValue, @Nonnull final Supplier aName)
{
if (isEnabled ())
if (dValue < 0)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be >= 0! The current value is: " +
dValue);
return dValue;
}
public static float isGE0 (final float fValue, final String sName)
{
return isGE0 (fValue, () -> sName);
}
public static float isGE0 (final float fValue, @Nonnull final Supplier aName)
{
if (isEnabled ())
if (fValue < 0)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be >= 0! The current value is: " +
fValue);
return fValue;
}
public static BigDecimal isGE0 (final BigDecimal aValue, final String sName)
{
return isGE0 (aValue, () -> sName);
}
public static BigDecimal isGE0 (final BigDecimal aValue, @Nonnull final Supplier aName)
{
notNull (aValue, aName);
if (isEnabled ())
if (aValue.compareTo (BigDecimal.ZERO) < 0)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be >= 0! The current value is: " +
aValue);
return aValue;
}
public static BigInteger isGE0 (final BigInteger aValue, final String sName)
{
return isGE0 (aValue, () -> sName);
}
public static BigInteger isGE0 (final BigInteger aValue, @Nonnull final Supplier aName)
{
notNull (aValue, aName);
if (isEnabled ())
if (aValue.compareTo (BigInteger.ZERO) < 0)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be >= 0! The current value is: " +
aValue);
return aValue;
}
public static int isGT0 (final int nValue, final String sName)
{
return isGT0 (nValue, () -> sName);
}
public static int isGT0 (final int nValue, @Nonnull final Supplier aName)
{
if (isEnabled ())
if (nValue <= 0)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be > 0! The current value is: " +
nValue);
return nValue;
}
public static long isGT0 (final long nValue, final String sName)
{
return isGT0 (nValue, () -> sName);
}
public static long isGT0 (final long nValue, @Nonnull final Supplier aName)
{
if (isEnabled ())
if (nValue <= 0)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be > 0! The current value is: " +
nValue);
return nValue;
}
public static short isGT0 (final short nValue, final String sName)
{
return isGT0 (nValue, () -> sName);
}
public static short isGT0 (final short nValue, @Nonnull final Supplier aName)
{
if (isEnabled ())
if (nValue <= 0)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be > 0! The current value is: " +
nValue);
return nValue;
}
public static double isGT0 (final double dValue, final String sName)
{
return isGT0 (dValue, () -> sName);
}
public static double isGT0 (final double dValue, @Nonnull final Supplier aName)
{
if (isEnabled ())
if (dValue <= 0)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be > 0! The current value is: " +
dValue);
return dValue;
}
public static float isGT0 (final float fValue, final String sName)
{
return isGT0 (fValue, () -> sName);
}
public static float isGT0 (final float fValue, @Nonnull final Supplier aName)
{
if (isEnabled ())
if (fValue <= 0)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be > 0! The current value is: " +
fValue);
return fValue;
}
public static BigDecimal isGT0 (final BigDecimal aValue, final String sName)
{
return isGT0 (aValue, () -> sName);
}
public static BigDecimal isGT0 (final BigDecimal aValue, @Nonnull final Supplier aName)
{
notNull (aValue, aName);
if (isEnabled ())
if (aValue.compareTo (BigDecimal.ZERO) <= 0)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be > 0! The current value is: " +
aValue);
return aValue;
}
public static BigInteger isGT0 (final BigInteger aValue, final String sName)
{
return isGT0 (aValue, () -> sName);
}
public static BigInteger isGT0 (final BigInteger aValue, @Nonnull final Supplier aName)
{
notNull (aValue, aName);
if (isEnabled ())
if (aValue.compareTo (BigInteger.ZERO) <= 0)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be > 0! The current value is: " +
aValue);
return aValue;
}
public static int isLE0 (final int nValue, final String sName)
{
return isLE0 (nValue, () -> sName);
}
public static int isLE0 (final int nValue, @Nonnull final Supplier aName)
{
if (isEnabled ())
if (nValue > 0)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be <= 0! The current value is: " +
nValue);
return nValue;
}
public static long isLE0 (final long nValue, final String sName)
{
return isLE0 (nValue, () -> sName);
}
public static long isLE0 (final long nValue, @Nonnull final Supplier aName)
{
if (isEnabled ())
if (nValue > 0)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be <= 0! The current value is: " +
nValue);
return nValue;
}
public static short isLE0 (final short nValue, final String sName)
{
return isLE0 (nValue, () -> sName);
}
public static short isLE0 (final short nValue, @Nonnull final Supplier aName)
{
if (isEnabled ())
if (nValue > 0)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be <= 0! The current value is: " +
nValue);
return nValue;
}
public static double isLE0 (final double dValue, final String sName)
{
return isLE0 (dValue, () -> sName);
}
public static double isLE0 (final double dValue, @Nonnull final Supplier aName)
{
if (isEnabled ())
if (dValue > 0)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be <= 0! The current value is: " +
dValue);
return dValue;
}
public static float isLE0 (final float fValue, final String sName)
{
return isLE0 (fValue, () -> sName);
}
public static float isLE0 (final float fValue, @Nonnull final Supplier aName)
{
if (isEnabled ())
if (fValue > 0)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be <= 0! The current value is: " +
fValue);
return fValue;
}
public static BigDecimal isLE0 (final BigDecimal aValue, final String sName)
{
return isLE0 (aValue, () -> sName);
}
public static BigDecimal isLE0 (final BigDecimal aValue, @Nonnull final Supplier aName)
{
notNull (aValue, aName);
if (isEnabled ())
if (aValue.compareTo (BigDecimal.ZERO) > 0)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be <= 0! The current value is: " +
aValue);
return aValue;
}
public static BigInteger isLE0 (final BigInteger aValue, final String sName)
{
return isLE0 (aValue, () -> sName);
}
public static BigInteger isLE0 (final BigInteger aValue, @Nonnull final Supplier aName)
{
notNull (aValue, aName);
if (isEnabled ())
if (aValue.compareTo (BigInteger.ZERO) > 0)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be <= 0! The current value is: " +
aValue);
return aValue;
}
public static int isLT0 (final int nValue, final String sName)
{
return isLT0 (nValue, () -> sName);
}
public static int isLT0 (final int nValue, @Nonnull final Supplier aName)
{
if (isEnabled ())
if (nValue >= 0)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be < 0! The current value is: " +
nValue);
return nValue;
}
public static long isLT0 (final long nValue, final String sName)
{
return isLT0 (nValue, () -> sName);
}
public static long isLT0 (final long nValue, @Nonnull final Supplier aName)
{
if (isEnabled ())
if (nValue >= 0)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be < 0! The current value is: " +
nValue);
return nValue;
}
public static short isLT0 (final short nValue, final String sName)
{
return isLT0 (nValue, () -> sName);
}
public static short isLT0 (final short nValue, @Nonnull final Supplier aName)
{
if (isEnabled ())
if (nValue >= 0)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be < 0! The current value is: " +
nValue);
return nValue;
}
public static double isLT0 (final double dValue, final String sName)
{
return isLT0 (dValue, () -> sName);
}
public static double isLT0 (final double dValue, @Nonnull final Supplier aName)
{
if (isEnabled ())
if (dValue >= 0)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be < 0! The current value is: " +
dValue);
return dValue;
}
public static float isLT0 (final float fValue, final String sName)
{
return isLT0 (fValue, () -> sName);
}
public static float isLT0 (final float fValue, @Nonnull final Supplier aName)
{
if (isEnabled ())
if (fValue >= 0)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be < 0! The current value is: " +
fValue);
return fValue;
}
public static BigDecimal isLT0 (final BigDecimal aValue, final String sName)
{
return isLT0 (aValue, () -> sName);
}
public static BigDecimal isLT0 (final BigDecimal aValue, @Nonnull final Supplier aName)
{
notNull (aValue, aName);
if (isEnabled ())
if (aValue.compareTo (BigDecimal.ZERO) >= 0)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be < 0! The current value is: " +
aValue);
return aValue;
}
public static BigInteger isLT0 (final BigInteger aValue, final String sName)
{
return isLT0 (aValue, () -> sName);
}
public static BigInteger isLT0 (final BigInteger aValue, @Nonnull final Supplier aName)
{
notNull (aValue, aName);
if (isEnabled ())
if (aValue.compareTo (BigInteger.ZERO) >= 0)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be < 0! The current value is: " +
aValue);
return aValue;
}
/**
* Check if
* nValue ≥ nLowerBoundInclusive && nValue ≤ nUpperBoundInclusive
*
* @param nValue
* Value
* @param sName
* Name
* @param nLowerBoundInclusive
* Lower bound
* @param nUpperBoundInclusive
* Upper bound
* @return The value
*/
public static int isBetweenInclusive (final int nValue,
final String sName,
final int nLowerBoundInclusive,
final int nUpperBoundInclusive)
{
return isBetweenInclusive (nValue, () -> sName, nLowerBoundInclusive, nUpperBoundInclusive);
}
/**
* Check if
* nValue ≥ nLowerBoundInclusive && nValue ≤ nUpperBoundInclusive
*
* @param nValue
* Value
* @param aName
* Name
* @param nLowerBoundInclusive
* Lower bound
* @param nUpperBoundInclusive
* Upper bound
* @return The value
*/
public static int isBetweenInclusive (final int nValue,
@Nonnull final Supplier aName,
final int nLowerBoundInclusive,
final int nUpperBoundInclusive)
{
if (isEnabled ())
if (nValue < nLowerBoundInclusive || nValue > nUpperBoundInclusive)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be >= " +
nLowerBoundInclusive +
" and <= " +
nUpperBoundInclusive +
"! The current value is: " +
nValue);
return nValue;
}
/**
* Check if
* nValue ≥ nLowerBoundInclusive && nValue ≤ nUpperBoundInclusive
*
* @param nValue
* Value
* @param sName
* Name
* @param nLowerBoundInclusive
* Lower bound
* @param nUpperBoundInclusive
* Upper bound
* @return The value
*/
public static long isBetweenInclusive (final long nValue,
final String sName,
final long nLowerBoundInclusive,
final long nUpperBoundInclusive)
{
return isBetweenInclusive (nValue, () -> sName, nLowerBoundInclusive, nUpperBoundInclusive);
}
/**
* Check if
* nValue ≥ nLowerBoundInclusive && nValue ≤ nUpperBoundInclusive
*
* @param nValue
* Value
* @param aName
* Name
* @param nLowerBoundInclusive
* Lower bound
* @param nUpperBoundInclusive
* Upper bound
* @return The value
*/
public static long isBetweenInclusive (final long nValue,
@Nonnull final Supplier aName,
final long nLowerBoundInclusive,
final long nUpperBoundInclusive)
{
if (isEnabled ())
if (nValue < nLowerBoundInclusive || nValue > nUpperBoundInclusive)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be >= " +
nLowerBoundInclusive +
" and <= " +
nUpperBoundInclusive +
"! The current value is: " +
nValue);
return nValue;
}
/**
* Check if
* nValue ≥ nLowerBoundInclusive && nValue ≤ nUpperBoundInclusive
*
* @param nValue
* Value
* @param sName
* Name
* @param nLowerBoundInclusive
* Lower bound
* @param nUpperBoundInclusive
* Upper bound
* @return The value
*/
public static short isBetweenInclusive (final short nValue,
final String sName,
final short nLowerBoundInclusive,
final short nUpperBoundInclusive)
{
return isBetweenInclusive (nValue, () -> sName, nLowerBoundInclusive, nUpperBoundInclusive);
}
/**
* Check if
* nValue ≥ nLowerBoundInclusive && nValue ≤ nUpperBoundInclusive
*
* @param nValue
* Value
* @param aName
* Name
* @param nLowerBoundInclusive
* Lower bound
* @param nUpperBoundInclusive
* Upper bound
* @return The value
*/
public static short isBetweenInclusive (final short nValue,
@Nonnull final Supplier aName,
final short nLowerBoundInclusive,
final short nUpperBoundInclusive)
{
if (isEnabled ())
if (nValue < nLowerBoundInclusive || nValue > nUpperBoundInclusive)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be >= " +
nLowerBoundInclusive +
" and <= " +
nUpperBoundInclusive +
"! The current value is: " +
nValue);
return nValue;
}
/**
* Check if
* nValue ≥ nLowerBoundInclusive && nValue ≤ nUpperBoundInclusive
*
* @param dValue
* Value
* @param sName
* Name
* @param dLowerBoundInclusive
* Lower bound
* @param dUpperBoundInclusive
* Upper bound
* @return The value
*/
public static double isBetweenInclusive (final double dValue,
final String sName,
final double dLowerBoundInclusive,
final double dUpperBoundInclusive)
{
return isBetweenInclusive (dValue, () -> sName, dLowerBoundInclusive, dUpperBoundInclusive);
}
/**
* Check if
* nValue ≥ nLowerBoundInclusive && nValue ≤ nUpperBoundInclusive
*
* @param dValue
* Value
* @param aName
* Name
* @param dLowerBoundInclusive
* Lower bound
* @param dUpperBoundInclusive
* Upper bound
* @return The value
*/
public static double isBetweenInclusive (final double dValue,
@Nonnull final Supplier aName,
final double dLowerBoundInclusive,
final double dUpperBoundInclusive)
{
if (isEnabled ())
if (dValue < dLowerBoundInclusive || dValue > dUpperBoundInclusive)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be >= " +
dLowerBoundInclusive +
" and <= " +
dUpperBoundInclusive +
"! The current value is: " +
dValue);
return dValue;
}
/**
* Check if
* nValue ≥ nLowerBoundInclusive && nValue ≤ nUpperBoundInclusive
*
* @param fValue
* Value
* @param sName
* Name
* @param fLowerBoundInclusive
* Lower bound
* @param fUpperBoundInclusive
* Upper bound
* @return The value
*/
public static float isBetweenInclusive (final float fValue,
final String sName,
final float fLowerBoundInclusive,
final float fUpperBoundInclusive)
{
return isBetweenInclusive (fValue, () -> sName, fLowerBoundInclusive, fUpperBoundInclusive);
}
/**
* Check if
* nValue ≥ nLowerBoundInclusive && nValue ≤ nUpperBoundInclusive
*
* @param fValue
* Value
* @param aName
* Name
* @param fLowerBoundInclusive
* Lower bound
* @param fUpperBoundInclusive
* Upper bound
* @return The value
*/
public static float isBetweenInclusive (final float fValue,
@Nonnull final Supplier aName,
final float fLowerBoundInclusive,
final float fUpperBoundInclusive)
{
if (isEnabled ())
if (fValue < fLowerBoundInclusive || fValue > fUpperBoundInclusive)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be >= " +
fLowerBoundInclusive +
" and <= " +
fUpperBoundInclusive +
"! The current value is: " +
fValue);
return fValue;
}
/**
* Check if
* nValue ≥ nLowerBoundInclusive && nValue ≤ nUpperBoundInclusive
*
* @param aValue
* Value
* @param sName
* Name
* @param aLowerBoundInclusive
* Lower bound
* @param aUpperBoundInclusive
* Upper bound
* @return The value
*/
public static BigDecimal isBetweenInclusive (final BigDecimal aValue,
final String sName,
@Nonnull final BigDecimal aLowerBoundInclusive,
@Nonnull final BigDecimal aUpperBoundInclusive)
{
return isBetweenInclusive (aValue, () -> sName, aLowerBoundInclusive, aUpperBoundInclusive);
}
/**
* Check if
* nValue ≥ nLowerBoundInclusive && nValue ≤ nUpperBoundInclusive
*
* @param aValue
* Value
* @param aName
* Name
* @param aLowerBoundInclusive
* Lower bound
* @param aUpperBoundInclusive
* Upper bound
* @return The value
*/
public static BigDecimal isBetweenInclusive (final BigDecimal aValue,
@Nonnull final Supplier aName,
@Nonnull final BigDecimal aLowerBoundInclusive,
@Nonnull final BigDecimal aUpperBoundInclusive)
{
notNull (aValue, aName);
notNull (aLowerBoundInclusive, "LowerBoundInclusive");
notNull (aUpperBoundInclusive, "UpperBoundInclusive");
if (isEnabled ())
if (aValue.compareTo (aLowerBoundInclusive) < 0 || aValue.compareTo (aUpperBoundInclusive) > 0)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be >= " +
aLowerBoundInclusive +
" and <= " +
aUpperBoundInclusive +
"! The current value is: " +
aValue);
return aValue;
}
/**
* Check if
* nValue ≥ nLowerBoundInclusive && nValue ≤ nUpperBoundInclusive
*
* @param aValue
* Value
* @param sName
* Name
* @param aLowerBoundInclusive
* Lower bound
* @param aUpperBoundInclusive
* Upper bound
* @return The value
*/
public static BigInteger isBetweenInclusive (final BigInteger aValue,
final String sName,
@Nonnull final BigInteger aLowerBoundInclusive,
@Nonnull final BigInteger aUpperBoundInclusive)
{
return isBetweenInclusive (aValue, () -> sName, aLowerBoundInclusive, aUpperBoundInclusive);
}
/**
* Check if
* nValue ≥ nLowerBoundInclusive && nValue ≤ nUpperBoundInclusive
*
* @param aValue
* Value
* @param aName
* Name
* @param aLowerBoundInclusive
* Lower bound
* @param aUpperBoundInclusive
* Upper bound
* @return The value
*/
public static BigInteger isBetweenInclusive (final BigInteger aValue,
@Nonnull final Supplier aName,
@Nonnull final BigInteger aLowerBoundInclusive,
@Nonnull final BigInteger aUpperBoundInclusive)
{
notNull (aValue, aName);
notNull (aLowerBoundInclusive, "LowerBoundInclusive");
notNull (aUpperBoundInclusive, "UpperBoundInclusive");
if (isEnabled ())
if (aValue.compareTo (aLowerBoundInclusive) < 0 || aValue.compareTo (aUpperBoundInclusive) > 0)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be >= " +
aLowerBoundInclusive +
" and <= " +
aUpperBoundInclusive +
"! The current value is: " +
aValue);
return aValue;
}
/**
* Check if
* nValue > nLowerBoundInclusive && nValue < nUpperBoundInclusive
*
* @param nValue
* Value
* @param sName
* Name
* @param nLowerBoundExclusive
* Lower bound
* @param nUpperBoundExclusive
* Upper bound
* @return The value
*/
public static int isBetweenExclusive (final int nValue,
final String sName,
final int nLowerBoundExclusive,
final int nUpperBoundExclusive)
{
return isBetweenExclusive (nValue, () -> sName, nLowerBoundExclusive, nUpperBoundExclusive);
}
/**
* Check if
* nValue > nLowerBoundInclusive && nValue < nUpperBoundInclusive
*
* @param nValue
* Value
* @param aName
* Name
* @param nLowerBoundExclusive
* Lower bound
* @param nUpperBoundExclusive
* Upper bound
* @return The value
*/
public static int isBetweenExclusive (final int nValue,
@Nonnull final Supplier aName,
final int nLowerBoundExclusive,
final int nUpperBoundExclusive)
{
if (isEnabled ())
if (nValue <= nLowerBoundExclusive || nValue >= nUpperBoundExclusive)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be > " +
nLowerBoundExclusive +
" and < " +
nUpperBoundExclusive +
"! The current value is: " +
nValue);
return nValue;
}
/**
* Check if
* nValue > nLowerBoundInclusive && nValue < nUpperBoundInclusive
*
* @param nValue
* Value
* @param sName
* Name
* @param nLowerBoundExclusive
* Lower bound
* @param nUpperBoundExclusive
* Upper bound
* @return The value
*/
public static long isBetweenExclusive (final long nValue,
final String sName,
final long nLowerBoundExclusive,
final long nUpperBoundExclusive)
{
return isBetweenExclusive (nValue, () -> sName, nLowerBoundExclusive, nUpperBoundExclusive);
}
/**
* Check if
* nValue > nLowerBoundInclusive && nValue < nUpperBoundInclusive
*
* @param nValue
* Value
* @param aName
* Name
* @param nLowerBoundExclusive
* Lower bound
* @param nUpperBoundExclusive
* Upper bound
* @return The value
*/
public static long isBetweenExclusive (final long nValue,
@Nonnull final Supplier aName,
final long nLowerBoundExclusive,
final long nUpperBoundExclusive)
{
if (isEnabled ())
if (nValue <= nLowerBoundExclusive || nValue >= nUpperBoundExclusive)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be > " +
nLowerBoundExclusive +
" and < " +
nUpperBoundExclusive +
"! The current value is: " +
nValue);
return nValue;
}
/**
* Check if
* nValue > nLowerBoundInclusive && nValue < nUpperBoundInclusive
*
* @param nValue
* Value
* @param sName
* Name
* @param nLowerBoundExclusive
* Lower bound
* @param nUpperBoundExclusive
* Upper bound
* @return The value
*/
public static short isBetweenExclusive (final short nValue,
final String sName,
final short nLowerBoundExclusive,
final short nUpperBoundExclusive)
{
return isBetweenExclusive (nValue, () -> sName, nLowerBoundExclusive, nUpperBoundExclusive);
}
/**
* Check if
* nValue > nLowerBoundInclusive && nValue < nUpperBoundInclusive
*
* @param nValue
* Value
* @param aName
* Name
* @param nLowerBoundExclusive
* Lower bound
* @param nUpperBoundExclusive
* Upper bound
* @return The value
*/
public static short isBetweenExclusive (final short nValue,
@Nonnull final Supplier aName,
final short nLowerBoundExclusive,
final short nUpperBoundExclusive)
{
if (isEnabled ())
if (nValue <= nLowerBoundExclusive || nValue >= nUpperBoundExclusive)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be > " +
nLowerBoundExclusive +
" and < " +
nUpperBoundExclusive +
"! The current value is: " +
nValue);
return nValue;
}
/**
* Check if
* nValue > nLowerBoundInclusive && nValue < nUpperBoundInclusive
*
* @param dValue
* Value
* @param sName
* Name
* @param dLowerBoundExclusive
* Lower bound
* @param dUpperBoundExclusive
* Upper bound
* @return The value
*/
public static double isBetweenExclusive (final double dValue,
final String sName,
final double dLowerBoundExclusive,
final double dUpperBoundExclusive)
{
return isBetweenExclusive (dValue, () -> sName, dLowerBoundExclusive, dUpperBoundExclusive);
}
/**
* Check if
* nValue > nLowerBoundInclusive && nValue < nUpperBoundInclusive
*
* @param dValue
* Value
* @param aName
* Name
* @param dLowerBoundExclusive
* Lower bound
* @param dUpperBoundExclusive
* Upper bound
* @return The value
*/
public static double isBetweenExclusive (final double dValue,
@Nonnull final Supplier aName,
final double dLowerBoundExclusive,
final double dUpperBoundExclusive)
{
if (isEnabled ())
if (dValue <= dLowerBoundExclusive || dValue >= dUpperBoundExclusive)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be > " +
dLowerBoundExclusive +
" and < " +
dUpperBoundExclusive +
"! The current value is: " +
dValue);
return dValue;
}
/**
* Check if
* nValue > nLowerBoundInclusive && nValue < nUpperBoundInclusive
*
* @param fValue
* Value
* @param sName
* Name
* @param fLowerBoundExclusive
* Lower bound
* @param fUpperBoundExclusive
* Upper bound
* @return The value
*/
public static float isBetweenExclusive (final float fValue,
final String sName,
final float fLowerBoundExclusive,
final float fUpperBoundExclusive)
{
return isBetweenExclusive (fValue, () -> sName, fLowerBoundExclusive, fUpperBoundExclusive);
}
/**
* Check if
* nValue > nLowerBoundInclusive && nValue < nUpperBoundInclusive
*
* @param fValue
* Value
* @param aName
* Name
* @param fLowerBoundExclusive
* Lower bound
* @param fUpperBoundExclusive
* Upper bound
* @return The value
*/
public static float isBetweenExclusive (final float fValue,
@Nonnull final Supplier aName,
final float fLowerBoundExclusive,
final float fUpperBoundExclusive)
{
if (isEnabled ())
if (fValue <= fLowerBoundExclusive || fValue >= fUpperBoundExclusive)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be > " +
fLowerBoundExclusive +
" and < " +
fUpperBoundExclusive +
"! The current value is: " +
fValue);
return fValue;
}
/**
* Check if
* nValue > nLowerBoundInclusive && nValue < nUpperBoundInclusive
*
* @param aValue
* Value
* @param sName
* Name
* @param aLowerBoundExclusive
* Lower bound
* @param aUpperBoundExclusive
* Upper bound
* @return The value
*/
public static BigDecimal isBetweenExclusive (final BigDecimal aValue,
final String sName,
@Nonnull final BigDecimal aLowerBoundExclusive,
@Nonnull final BigDecimal aUpperBoundExclusive)
{
return isBetweenExclusive (aValue, () -> sName, aLowerBoundExclusive, aUpperBoundExclusive);
}
/**
* Check if
* nValue > nLowerBoundInclusive && nValue < nUpperBoundInclusive
*
* @param aValue
* Value
* @param aName
* Name
* @param aLowerBoundExclusive
* Lower bound
* @param aUpperBoundExclusive
* Upper bound
* @return The value
*/
public static BigDecimal isBetweenExclusive (final BigDecimal aValue,
@Nonnull final Supplier aName,
@Nonnull final BigDecimal aLowerBoundExclusive,
@Nonnull final BigDecimal aUpperBoundExclusive)
{
notNull (aValue, aName);
notNull (aLowerBoundExclusive, "LowerBoundInclusive");
notNull (aUpperBoundExclusive, "UpperBoundInclusive");
if (isEnabled ())
if (aValue.compareTo (aLowerBoundExclusive) <= 0 || aValue.compareTo (aUpperBoundExclusive) >= 0)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be > " +
aLowerBoundExclusive +
" and < " +
aUpperBoundExclusive +
"! The current value is: " +
aValue);
return aValue;
}
/**
* Check if
* nValue > nLowerBoundInclusive && nValue < nUpperBoundInclusive
*
* @param aValue
* Value
* @param sName
* Name
* @param aLowerBoundExclusive
* Lower bound
* @param aUpperBoundExclusive
* Upper bound
* @return The value
*/
public static BigInteger isBetweenExclusive (final BigInteger aValue,
final String sName,
@Nonnull final BigInteger aLowerBoundExclusive,
@Nonnull final BigInteger aUpperBoundExclusive)
{
return isBetweenExclusive (aValue, () -> sName, aLowerBoundExclusive, aUpperBoundExclusive);
}
/**
* Check if
* nValue > nLowerBoundInclusive && nValue < nUpperBoundInclusive
*
* @param aValue
* Value
* @param aName
* Name
* @param aLowerBoundExclusive
* Lower bound
* @param aUpperBoundExclusive
* Upper bound
* @return The value
*/
public static BigInteger isBetweenExclusive (final BigInteger aValue,
@Nonnull final Supplier aName,
@Nonnull final BigInteger aLowerBoundExclusive,
@Nonnull final BigInteger aUpperBoundExclusive)
{
notNull (aValue, aName);
notNull (aLowerBoundExclusive, "LowerBoundInclusive");
notNull (aUpperBoundExclusive, "UpperBoundInclusive");
if (isEnabled ())
if (aValue.compareTo (aLowerBoundExclusive) <= 0 || aValue.compareTo (aUpperBoundExclusive) >= 0)
throw new IllegalArgumentException ("The value of '" +
aName.get () +
"' must be > " +
aLowerBoundExclusive +
" and < " +
aUpperBoundExclusive +
"! The current value is: " +
aValue);
return aValue;
}
private static void _isArrayOfsLen (@Nonnegative final int nArrayLen,
@Nonnegative final int nOfs,
@Nonnegative final int nLen)
{
isGE0 (nOfs, "Offset");
isGE0 (nLen, "Length");
if (isEnabled ())
if ((nOfs + nLen) > nArrayLen)
throw new IllegalArgumentException ("Offset (" +
nOfs +
") + length (" +
nLen +
") exceeds array length (" +
nArrayLen +
")");
}
public static void isArrayOfsLen (final Object [] aArray, @Nonnegative final int nOfs, @Nonnegative final int nLen)
{
notNull (aArray, "Array");
_isArrayOfsLen (aArray.length, nOfs, nLen);
}
public static void isArrayOfsLen (final boolean [] aArray, @Nonnegative final int nOfs, @Nonnegative final int nLen)
{
notNull (aArray, "Array");
_isArrayOfsLen (aArray.length, nOfs, nLen);
}
public static void isArrayOfsLen (final byte [] aArray, @Nonnegative final int nOfs, @Nonnegative final int nLen)
{
notNull (aArray, "Array");
_isArrayOfsLen (aArray.length, nOfs, nLen);
}
public static void isArrayOfsLen (final char [] aArray, @Nonnegative final int nOfs, @Nonnegative final int nLen)
{
notNull (aArray, "Array");
_isArrayOfsLen (aArray.length, nOfs, nLen);
}
public static void isArrayOfsLen (final double [] aArray, @Nonnegative final int nOfs, @Nonnegative final int nLen)
{
notNull (aArray, "Array");
_isArrayOfsLen (aArray.length, nOfs, nLen);
}
public static void isArrayOfsLen (final float [] aArray, @Nonnegative final int nOfs, @Nonnegative final int nLen)
{
notNull (aArray, "Array");
_isArrayOfsLen (aArray.length, nOfs, nLen);
}
public static void isArrayOfsLen (final int [] aArray, @Nonnegative final int nOfs, @Nonnegative final int nLen)
{
notNull (aArray, "Array");
_isArrayOfsLen (aArray.length, nOfs, nLen);
}
public static void isArrayOfsLen (final long [] aArray, @Nonnegative final int nOfs, @Nonnegative final int nLen)
{
notNull (aArray, "Array");
_isArrayOfsLen (aArray.length, nOfs, nLen);
}
public static void isArrayOfsLen (final short [] aArray, @Nonnegative final int nOfs, @Nonnegative final int nLen)
{
notNull (aArray, "Array");
_isArrayOfsLen (aArray.length, nOfs, nLen);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy