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

fr.landel.utils.assertor.AssertorStepClass Maven / Gradle / Ivy

/*-
 * #%L
 * utils-assertor
 * %%
 * Copyright (C) 2016 - 2018 Gilles Landel
 * %%
 * 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.
 * #L%
 */
package fr.landel.utils.assertor;

import java.util.Locale;

import fr.landel.utils.assertor.commons.MessageAssertor;
import fr.landel.utils.assertor.helper.HelperStep;
import fr.landel.utils.assertor.utils.AssertorClass;

/**
 * This class define methods that can be applied on the checked {@link Class}
 * object. To provide a result, it's also provide a chain builder by returning a
 * {@link StepClass}. The chain looks like:
 * 
 * 
 * {@link AssertorStepClass} > {@link StepClass} > {@link AssertorStepClass} > {@link StepClass}...
 * 
* * This chain always starts with a {@link AssertorStepClass} and ends with * {@link StepClass}. * * @since Aug 3, 2016 * @author Gilles * */ @FunctionalInterface public interface AssertorStepClass extends AssertorStep, Class> { /** * {@inheritDoc} */ @Override default StepClass get(final StepAssertor> result) { return () -> result; } /** * {@inheritDoc} */ @Override default AssertorStepClass not() { return () -> HelperStep.not(getStep()); } /** * Asserts that the given {@link Class} is assignable from the specified * super type {@code clazz}. * *

* precondition: neither classes can be null *

* *
     * Assertor.that(clazz).isAssignableFrom(superType).orElseThrow();
     * 
* * @param clazz * The super {@link Class} (super class or interface) * @return The operator */ @Override default StepClass isAssignableFrom(final Class clazz) { return this.isAssignableFrom(clazz, null); } /** * Asserts that the given {@link Class} is assignable from the specified * super type {@code clazz}. * *

* precondition: neither classes can be null *

* *
     * Assertor.that(clazz).isAssignableFrom(superType, "not assignable").orElseThrow();
     * 
* * @param clazz * The super {@link Class} (super class or interface) * @param message * The message on mismatch * @param arguments * The arguments of the message, use {@link String#format} * @return The operator */ @Override default StepClass isAssignableFrom(final Class clazz, final CharSequence message, final Object... arguments) { return this.isAssignableFrom(clazz, null, message, arguments); } /** * Asserts that the given {@link Class} is assignable from the specified * super type {@code clazz}. * *

* precondition: neither classes can be null *

* *
     * Assertor.that(clazz).isAssignableFrom(superType, Locale.US, "not assignable").orElseThrow();
     * 
* * @param clazz * The super {@link Class} (super class or interface) * @param locale * The locale of the message (only used to format this message, * otherwise use {@link Assertor#setLocale}) * @param message * The message on mismatch * @param arguments * The arguments of the message, use {@link String#format} * @return The operator */ @Override default StepClass isAssignableFrom(final Class clazz, final Locale locale, final CharSequence message, final Object... arguments) { return () -> AssertorClass.isAssignableFrom(this.getStep(), clazz, MessageAssertor.of(locale, message, arguments)); } /** * Asserts that the given {@link Class} has the specified {@code name}. * *

* precondition: {@link Class} cannot be null and {@code name} cannot be * {@code null} or empty *

* *
     * Assertor.that(clazz).hasName(name).orElseThrow();
     * 
* * @param name * The {@link Class} name * @return The operator */ default StepClass hasName(final CharSequence name) { return this.hasName(name, null); } /** * Asserts that the given {@link Class} has the specified {@code name}. * *

* precondition: {@link Class} cannot be null and {@code name} cannot be * {@code null} or empty *

* *
     * Assertor.that(clazz).hasName(name, "bad name").orElseThrow();
     * 
* * @param name * The {@link Class} name * @param message * The message on mismatch * @param arguments * The arguments of the message, use {@link String#format} * @return The operator */ default StepClass hasName(final CharSequence name, final CharSequence message, final Object... arguments) { return this.hasName(name, null, message, arguments); } /** * Asserts that the given {@link Class} has the specified {@code name}. * *

* precondition: {@link Class} cannot be null and {@code name} cannot be * {@code null} or empty *

* *
     * Assertor.that(clazz).hasName(name, Locale.US, "bad name").orElseThrow();
     * 
* * @param name * The {@link Class} name * @param locale * The locale of the message (only used to format this message, * otherwise use {@link Assertor#setLocale}) * @param message * The message on mismatch * @param arguments * The arguments of the message, use {@link String#format} * @return The operator */ default StepClass hasName(final CharSequence name, final Locale locale, final CharSequence message, final Object... arguments) { return () -> AssertorClass.hasName(this.getStep(), name, MessageAssertor.of(locale, message, arguments)); } /** * Asserts that the given {@link Class} has the specified simple * {@code name}. * *

* precondition: {@link Class} cannot be null and {@code name} cannot be * {@code null} or empty *

* *
     * Assertor.that(clazz).hasSimpleName(name).orElseThrow();
     * 
* * @param name * The {@link Class} name * @return The operator */ default StepClass hasSimpleName(final CharSequence name) { return this.hasSimpleName(name, null); } /** * Asserts that the given {@link Class} has the specified simple * {@code name}. * *

* precondition: {@link Class} cannot be null and {@code name} cannot be * {@code null} or empty *

* *
     * Assertor.that(clazz).hasSimpleName(name, "bad name").orElseThrow();
     * 
* * @param name * The {@link Class} name * @param message * The message on mismatch * @param arguments * The arguments of the message, use {@link String#format} * @return The operator */ default StepClass hasSimpleName(final CharSequence name, final CharSequence message, final Object... arguments) { return this.hasSimpleName(name, null, message, arguments); } /** * Asserts that the given {@link Class} has the specified simple * {@code name}. * *

* precondition: {@link Class} cannot be null and {@code name} cannot be * {@code null} or empty *

* *
     * Assertor.that(clazz).hasSimpleName(name, Locale.US, "bad name").orElseThrow();
     * 
* * @param name * The {@link Class} name * @param locale * The locale of the message (only used to format this message, * otherwise use {@link Assertor#setLocale}) * @param message * The message on mismatch * @param arguments * The arguments of the message, use {@link String#format} * @return The operator */ default StepClass hasSimpleName(final CharSequence name, final Locale locale, final CharSequence message, final Object... arguments) { return () -> AssertorClass.hasSimpleName(this.getStep(), name, MessageAssertor.of(locale, message, arguments)); } /** * Asserts that the given {@link Class} has the specified canonical * {@code name}. * *

* precondition: {@link Class} cannot be null and {@code name} cannot be * {@code null} or empty *

* *
     * Assertor.that(clazz).hasCanonicalName(name).orElseThrow();
     * 
* * @param name * The {@link Class} name * @return The operator */ default StepClass hasCanonicalName(final CharSequence name) { return this.hasCanonicalName(name, null); } /** * Asserts that the given {@link Class} has the specified canonical * {@code name}. * *

* precondition: {@link Class} cannot be null and {@code name} cannot be * {@code null} or empty *

* *
     * Assertor.that(clazz).hasCanonicalName(name, "bad name").orElseThrow();
     * 
* * @param name * The {@link Class} name * @param message * The message on mismatch * @param arguments * The arguments of the message, use {@link String#format} * @return The operator */ default StepClass hasCanonicalName(final CharSequence name, final CharSequence message, final Object... arguments) { return this.hasCanonicalName(name, null, message, arguments); } /** * Asserts that the given {@link Class} has the specified canonical * {@code name}. * *

* precondition: {@link Class} cannot be null and {@code name} cannot be * {@code null} or empty *

* *
     * Assertor.that(clazz).hasCanonicalName(name, Locale.US, "bad name").orElseThrow();
     * 
* * @param name * The {@link Class} name * @param locale * The locale of the message (only used to format this message, * otherwise use {@link Assertor#setLocale}) * @param message * The message on mismatch * @param arguments * The arguments of the message, use {@link String#format} * @return The operator */ default StepClass hasCanonicalName(final CharSequence name, final Locale locale, final CharSequence message, final Object... arguments) { return () -> AssertorClass.hasCanonicalName(this.getStep(), name, MessageAssertor.of(locale, message, arguments)); } /** * Asserts that the given {@link Class} has the specified type {@code name}. * *

* precondition: {@link Class} cannot be null and {@code name} cannot be * {@code null} or empty *

* *
     * Assertor.that(clazz).hasTypeName(name).orElseThrow();
     * 
* * @param name * The {@link Class} name * @return The operator */ default StepClass hasTypeName(final CharSequence name) { return this.hasTypeName(name, null); } /** * Asserts that the given {@link Class} has the specified type {@code name}. * *

* precondition: {@link Class} cannot be null and {@code name} cannot be * {@code null} or empty *

* *
     * Assertor.that(clazz).hasTypeName(name, "bad name").orElseThrow();
     * 
* * @param name * The {@link Class} name * @param message * The message on mismatch * @param arguments * The arguments of the message, use {@link String#format} * @return The operator */ default StepClass hasTypeName(final CharSequence name, final CharSequence message, final Object... arguments) { return this.hasTypeName(name, null, message, arguments); } /** * Asserts that the given {@link Class} has the specified type {@code name}. * *

* precondition: {@link Class} cannot be null and {@code name} cannot be * {@code null} or empty *

* *
     * Assertor.that(clazz).hasTypeName(name, Locale.US, "bad name").orElseThrow();
     * 
* * @param name * The {@link Class} name * @param locale * The locale of the message (only used to format this message, * otherwise use {@link Assertor#setLocale}) * @param message * The message on mismatch * @param arguments * The arguments of the message, use {@link String#format} * @return The operator */ default StepClass hasTypeName(final CharSequence name, final Locale locale, final CharSequence message, final Object... arguments) { return () -> AssertorClass.hasTypeName(this.getStep(), name, MessageAssertor.of(locale, message, arguments)); } /** * Asserts that the given {@link Class} has the specified package * {@code name}. * *

* precondition: {@link Class} cannot be null and {@code name} cannot be * {@code null} or empty *

* *
     * Assertor.that(clazz).hasPackageName(name).orElseThrow();
     * 
* * @param name * The {@link Class} name * @return The operator */ default StepClass hasPackageName(final CharSequence name) { return this.hasPackageName(name, null); } /** * Asserts that the given {@link Class} has the specified package * {@code name}. * *

* precondition: {@link Class} cannot be null and {@code name} cannot be * {@code null} or empty *

* *
     * Assertor.that(clazz).hasPackageName(name, "bad name").orElseThrow();
     * 
* * @param name * The {@link Class} name * @param message * The message on mismatch * @param arguments * The arguments of the message, use {@link String#format} * @return The operator */ default StepClass hasPackageName(final CharSequence name, final CharSequence message, final Object... arguments) { return this.hasPackageName(name, null, message, arguments); } /** * Asserts that the given {@link Class} has the specified package * {@code name}. * *

* precondition: {@link Class} cannot be null and {@code name} cannot be * {@code null} or empty *

* *
     * Assertor.that(clazz).hasPackageName(name, Locale.US, "bad name").orElseThrow();
     * 
* * @param name * The {@link Class} name * @param locale * The locale of the message (only used to format this message, * otherwise use {@link Assertor#setLocale}) * @param message * The message on mismatch * @param arguments * The arguments of the message, use {@link String#format} * @return The operator */ default StepClass hasPackageName(final CharSequence name, final Locale locale, final CharSequence message, final Object... arguments) { return () -> AssertorClass.hasPackageName(this.getStep(), name, MessageAssertor.of(locale, message, arguments)); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy