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

net.hasor.cobble.provider.Provider Maven / Gradle / Ivy

/*
 * Copyright 2008-2009 the original author or authors.
 *
 * 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 net.hasor.cobble.provider;
import net.hasor.cobble.ExceptionUtils;

import java.util.concurrent.Callable;
import java.util.function.Supplier;

/**
 *  提供者实现这个接口就相当于同时实现了
 *      
  • java.util.function.Supplier
  • *
  • java.util.concurrent.Callable
  • * 三个接口 * @version : 2014年5月22日 * @author 赵永春 ([email protected]) */ @FunctionalInterface public interface Provider extends Supplier, Callable { /** * Gets a result. * @return a result */ default T get() { try { return this.call(); } catch (RuntimeException e) { throw e; } catch (Exception e) { throw ExceptionUtils.toRuntime(e); } } /** * Computes a result, or throws an exception if unable to do so. * @return computed result * @throws Exception if unable to compute a result */ T call() throws Exception; default Provider asSingle() { if (this instanceof SingleProvider) { return this; } else { return new SingleProvider<>(this); } } default Provider asThread() { if (this instanceof ThreadSingleProvider) { return this; } else { return new ThreadSingleProvider<>(this); } } default Provider asLoader() { if (this instanceof LoaderSingleProvider) { return this; } else { return new LoaderSingleProvider<>(this); } } static Provider of(T instance) { return new SingleProvider<>(instance); } static Provider of(Supplier supplier) { return supplier::get; } static Provider of(Callable callable) { return callable::call; } static Provider wrap(T target) { return new InstanceProvider<>(target); } static Provider asThread(T target) { return new ThreadSingleProvider<>(target); } static Provider asLoader(T target) { return new LoaderSingleProvider<>(target); } static Provider toSingle(Supplier supplier) { if (supplier instanceof SingleProvider || supplier instanceof InstanceProvider) { return (Provider) supplier; } else { return new SingleProvider<>(supplier); } } static Provider toThread(Supplier supplier) { if (supplier instanceof ThreadSingleProvider) { return (Provider) supplier; } else { return new ThreadSingleProvider<>(supplier); } } static Provider toLoader(Supplier supplier) { if (supplier instanceof LoaderSingleProvider) { return (Provider) supplier; } else { return new LoaderSingleProvider<>(supplier); } } static Provider toSingle(Callable callable) { if (callable instanceof SingleProvider || callable instanceof InstanceProvider) { return (Provider) callable; } else { return new SingleProvider<>(callable); } } static Provider toThread(Callable callable) { if (callable instanceof ThreadSingleProvider) { return (Provider) callable; } else { return new ThreadSingleProvider<>(callable); } } static Provider toLoader(Callable callable) { if (callable instanceof LoaderSingleProvider) { return (Provider) callable; } else { return new LoaderSingleProvider<>(callable); } } }




    © 2015 - 2025 Weber Informatics LLC | Privacy Policy