All Downloads are FREE. Search and download functionalities are using the official Maven repository.

de.carne.check.Check Maven / Gradle / Ivy

There is a newer version: 10.2.0
Show newest version
/*
 * Copyright (c) 2016-2017 Holger de Carne and contributors, All Rights Reserved.
 *
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see .
 */
package de.carne.check;

/**
 * Utility class providing code check related functions.
 */
public final class Check {

	private Check() {
		// Prevent instantiation
	}

	/**
	 * Check and ensure that an {@link Object} is not {@code null}.
	 *
	 * @param  The actual object type.
	 * @param object The {@link Object} to check.
	 * @return The checked {@link Object} (never {@code null}).
	 * @throws NullPointerException if the submitted argument is {@code null}.
	 */
	public static  T notNull(@Nullable T object) {
		if (object == null) {
			throw new NullPointerException();
		}
		return object;
	}

	/**
	 * Check and ensure that an {@link Object} is not {@code null}.
	 *
	 * @param  The actual object type.
	 * @param object The {@link Object} to check.
	 * @param message The message to issue if the check fails.
	 * @return The checked {@link Object} (never {@code null}).
	 * @throws NullPointerException if the submitted argument is {@code null}.
	 */
	public static  T notNull(@Nullable T object, String message) {
		if (object == null) {
			throw new NullPointerException(message);
		}
		return object;
	}

	/**
	 * Check and ensure that a specific condition is met.
	 *
	 * @param condition The condition to check.
	 * @throws IllegalStateException if the condition is not met.
	 */
	public static void assertTrue(boolean condition) {
		if (!condition) {
			throw new IllegalStateException();
		}
	}

	/**
	 * Check and ensure that a specific condition is met.
	 *
	 * @param condition The condition to check.
	 * @param message The message to issue if the check fails.
	 * @throws IllegalStateException if the condition is not met.
	 */
	public static void assertTrue(boolean condition, String message) {
		if (!condition) {
			throw new IllegalStateException(message);
		}
	}

	/**
	 * Throw an {@link IllegalStateException} to indicate that an unexpected execution state occurred.
	 *
	 * @param  The generic return type.
	 * @return Nothing (function never returns).
	 * @throws IllegalStateException any time this function is called.
	 */
	public static  T fail() {
		throw new IllegalStateException();
	}

	/**
	 * Throw an {@link IllegalStateException} to indicate that an unexpected execution state occurred.
	 *
	 * @param  The generic return type.
	 * @param message The message to issue if the check fails.
	 * @return Nothing (function never returns).
	 * @throws IllegalStateException any time this function is called.
	 */
	public static  T fail(String message) {
		throw new IllegalStateException(message);
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy