/* * Copyright (C) 2014 SCVNGR, Inc. d/b/a LevelUp * * 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.scvngr.levelup.core.util; import android.support.annotation.NonNull; import android.support.annotation.Nullable; import com.scvngr.levelup.core.annotation.LevelUpApi; import com.scvngr.levelup.core.annotation.LevelUpApi.Contract; import net.jcip.annotations.ThreadSafe; import java.util.Locale; /** * This is a utility class to enforce preconditions. */ @LevelUpApi(contract = Contract.INTERNAL) @ThreadSafe public final class PreconditionUtil { /** * * @param objectToCheck Reference to check for nullness. * @param objectName Human-readable name of the object reference, to be formatted into any * errors generated by this method. * @throws AssertionError if {@code objectToCheck} is null and * {@link CoreLibConstants#IS_PARAMETER_CHECKING_ENABLED}. */ public static void assertNotNull(@Nullable final Object objectToCheck, @NonNull final String objectName) { if (CoreLibConstants.IS_PARAMETER_CHECKING_ENABLED) { if (null == objectToCheck) { final String message = String.format(Locale.US, "%s cannot be null", objectName); throw new AssertionError(message); } } } /** * Private constructor prevents instantiation. * * @throws UnsupportedOperationException because this class cannot be instantiated. */ private PreconditionUtil() { throw new UnsupportedOperationException("This class is non-instantiable"); } }