1*f585d8a3SJacky Wang /* 2*f585d8a3SJacky Wang * Copyright (C) 2014 The Dagger Authors. 3*f585d8a3SJacky Wang * 4*f585d8a3SJacky Wang * Licensed under the Apache License, Version 2.0 (the "License"); 5*f585d8a3SJacky Wang * you may not use this file except in compliance with the License. 6*f585d8a3SJacky Wang * You may obtain a copy of the License at 7*f585d8a3SJacky Wang * 8*f585d8a3SJacky Wang * http://www.apache.org/licenses/LICENSE-2.0 9*f585d8a3SJacky Wang * 10*f585d8a3SJacky Wang * Unless required by applicable law or agreed to in writing, software 11*f585d8a3SJacky Wang * distributed under the License is distributed on an "AS IS" BASIS, 12*f585d8a3SJacky Wang * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13*f585d8a3SJacky Wang * See the License for the specific language governing permissions and 14*f585d8a3SJacky Wang * limitations under the License. 15*f585d8a3SJacky Wang */ 16*f585d8a3SJacky Wang 17*f585d8a3SJacky Wang package dagger.internal; 18*f585d8a3SJacky Wang 19*f585d8a3SJacky Wang import static dagger.internal.Preconditions.checkNotNull; 20*f585d8a3SJacky Wang 21*f585d8a3SJacky Wang import dagger.Lazy; 22*f585d8a3SJacky Wang 23*f585d8a3SJacky Wang /** 24*f585d8a3SJacky Wang * A {@link Factory} implementation that returns a single instance for all invocations of {@link 25*f585d8a3SJacky Wang * #get}. 26*f585d8a3SJacky Wang * 27*f585d8a3SJacky Wang * <p>Note that while this is a {@link Factory} implementation, and thus unscoped, each call to 28*f585d8a3SJacky Wang * {@link #get} will always return the same instance. As such, any scoping applied to this factory 29*f585d8a3SJacky Wang * is redundant and unnecessary. However, using this with {@link DoubleCheck#provider} is valid and 30*f585d8a3SJacky Wang * may be desired for testing or contractual guarantees. 31*f585d8a3SJacky Wang */ 32*f585d8a3SJacky Wang public final class InstanceFactory<T> implements Factory<T>, Lazy<T> { create(T instance)33*f585d8a3SJacky Wang public static <T> Factory<T> create(T instance) { 34*f585d8a3SJacky Wang return new InstanceFactory<T>(checkNotNull(instance, "instance cannot be null")); 35*f585d8a3SJacky Wang } 36*f585d8a3SJacky Wang createNullable(T instance)37*f585d8a3SJacky Wang public static <T> Factory<T> createNullable(T instance) { 38*f585d8a3SJacky Wang return instance == null 39*f585d8a3SJacky Wang ? InstanceFactory.<T>nullInstanceFactory() 40*f585d8a3SJacky Wang : new InstanceFactory<T>(instance); 41*f585d8a3SJacky Wang } 42*f585d8a3SJacky Wang 43*f585d8a3SJacky Wang @SuppressWarnings("unchecked") // bivariant implementation nullInstanceFactory()44*f585d8a3SJacky Wang private static <T> InstanceFactory<T> nullInstanceFactory() { 45*f585d8a3SJacky Wang return (InstanceFactory<T>) NULL_INSTANCE_FACTORY; 46*f585d8a3SJacky Wang } 47*f585d8a3SJacky Wang 48*f585d8a3SJacky Wang private static final InstanceFactory<Object> NULL_INSTANCE_FACTORY = 49*f585d8a3SJacky Wang new InstanceFactory<Object>(null); 50*f585d8a3SJacky Wang 51*f585d8a3SJacky Wang private final T instance; 52*f585d8a3SJacky Wang InstanceFactory(T instance)53*f585d8a3SJacky Wang private InstanceFactory(T instance) { 54*f585d8a3SJacky Wang this.instance = instance; 55*f585d8a3SJacky Wang } 56*f585d8a3SJacky Wang 57*f585d8a3SJacky Wang @Override get()58*f585d8a3SJacky Wang public T get() { 59*f585d8a3SJacky Wang return instance; 60*f585d8a3SJacky Wang } 61*f585d8a3SJacky Wang } 62