1*f585d8a3SJacky Wang /* 2*f585d8a3SJacky Wang * Copyright (C) 2015 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; 18*f585d8a3SJacky Wang 19*f585d8a3SJacky Wang import static java.lang.annotation.ElementType.TYPE; 20*f585d8a3SJacky Wang import static java.lang.annotation.RetentionPolicy.RUNTIME; 21*f585d8a3SJacky Wang 22*f585d8a3SJacky Wang import java.lang.annotation.Documented; 23*f585d8a3SJacky Wang import java.lang.annotation.Retention; 24*f585d8a3SJacky Wang import java.lang.annotation.Target; 25*f585d8a3SJacky Wang 26*f585d8a3SJacky Wang /** 27*f585d8a3SJacky Wang * A subcomponent that inherits the bindings from a parent {@link Component} or 28*f585d8a3SJacky Wang * {@link Subcomponent}. The details of how to associate a subcomponent with a parent are described 29*f585d8a3SJacky Wang * in the documentation for {@link Component}. 30*f585d8a3SJacky Wang * 31*f585d8a3SJacky Wang * @since 2.0 32*f585d8a3SJacky Wang */ 33*f585d8a3SJacky Wang @Retention(RUNTIME) // Allows runtimes to have specialized behavior interoperating with Dagger. 34*f585d8a3SJacky Wang @Target(TYPE) 35*f585d8a3SJacky Wang @Documented 36*f585d8a3SJacky Wang public @interface Subcomponent { 37*f585d8a3SJacky Wang /** 38*f585d8a3SJacky Wang * A list of classes annotated with {@link Module} whose bindings are used to generate the 39*f585d8a3SJacky Wang * subcomponent implementation. Note that through the use of {@link Module#includes} the full set 40*f585d8a3SJacky Wang * of modules used to implement the subcomponent may include more modules that just those listed 41*f585d8a3SJacky Wang * here. 42*f585d8a3SJacky Wang */ modules()43*f585d8a3SJacky Wang Class<?>[] modules() default {}; 44*f585d8a3SJacky Wang 45*f585d8a3SJacky Wang /** 46*f585d8a3SJacky Wang * A builder for a subcomponent. 47*f585d8a3SJacky Wang * 48*f585d8a3SJacky Wang * <p>This follows all the rules of {@link Component.Builder}, except it must appear in classes 49*f585d8a3SJacky Wang * annotated with {@link Subcomponent} instead of {@code Component}. 50*f585d8a3SJacky Wang * 51*f585d8a3SJacky Wang * <p>If a subcomponent defines a builder, its parent component(s) will have a binding for that 52*f585d8a3SJacky Wang * builder type, allowing an instance or {@code Provider} of that builder to be injected or 53*f585d8a3SJacky Wang * returned from a method on that component like any other binding. 54*f585d8a3SJacky Wang */ 55*f585d8a3SJacky Wang @Retention(RUNTIME) // Allows runtimes to have specialized behavior interoperating with Dagger. 56*f585d8a3SJacky Wang @Target(TYPE) 57*f585d8a3SJacky Wang @Documented 58*f585d8a3SJacky Wang @interface Builder {} 59*f585d8a3SJacky Wang 60*f585d8a3SJacky Wang /** 61*f585d8a3SJacky Wang * A factory for a subcomponent. 62*f585d8a3SJacky Wang * 63*f585d8a3SJacky Wang * <p>This follows all the rules of {@link Component.Factory}, except it must appear in classes 64*f585d8a3SJacky Wang * annotated with {@link Subcomponent} instead of {@code Component}. 65*f585d8a3SJacky Wang * 66*f585d8a3SJacky Wang * <p>If a subcomponent defines a factory, its parent component(s) will have a binding for that 67*f585d8a3SJacky Wang * factory type, allowing an instance of that factory to be injected or returned from a method on 68*f585d8a3SJacky Wang * that component like any other binding. 69*f585d8a3SJacky Wang * 70*f585d8a3SJacky Wang * @since 2.22 71*f585d8a3SJacky Wang */ 72*f585d8a3SJacky Wang @Retention(RUNTIME) // Allows runtimes to have specialized behavior interoperating with Dagger. 73*f585d8a3SJacky Wang @Target(TYPE) 74*f585d8a3SJacky Wang @Documented 75*f585d8a3SJacky Wang @interface Factory {} 76*f585d8a3SJacky Wang } 77