1*f585d8a3SJacky Wang /* 2*f585d8a3SJacky Wang * Copyright (C) 2020 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.assisted; 18*f585d8a3SJacky Wang 19*f585d8a3SJacky Wang import static java.lang.annotation.ElementType.PARAMETER; 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 * Annotates a parameter within an {@link AssistedInject}-annotated constructor. 28*f585d8a3SJacky Wang * 29*f585d8a3SJacky Wang * <p>See {@link AssistedInject}. 30*f585d8a3SJacky Wang */ 31*f585d8a3SJacky Wang @Documented 32*f585d8a3SJacky Wang @Retention(RUNTIME) 33*f585d8a3SJacky Wang @Target(PARAMETER) 34*f585d8a3SJacky Wang public @interface Assisted { 35*f585d8a3SJacky Wang 36*f585d8a3SJacky Wang /** 37*f585d8a3SJacky Wang * Returns an identifier for an {@link Assisted} parameter. 38*f585d8a3SJacky Wang * 39*f585d8a3SJacky Wang * <p>Within an {@link AssistedInject} constructor, each {@link Assisted} parameter must be 40*f585d8a3SJacky Wang * uniquely defined by the combination of its identifier and type. If no identifier is specified, 41*f585d8a3SJacky Wang * the default identifier is an empty string. Thus, the following parameters are equivalent within 42*f585d8a3SJacky Wang * an {@link AssistedInject} constructor: 43*f585d8a3SJacky Wang * 44*f585d8a3SJacky Wang * <ul> 45*f585d8a3SJacky Wang * <li> {@code @Assisted Foo foo} 46*f585d8a3SJacky Wang * <li> {@code @Assisted("") Foo foo} 47*f585d8a3SJacky Wang * </ul> 48*f585d8a3SJacky Wang * 49*f585d8a3SJacky Wang * <p>Within an {@link AssistedFactory} method, each parameter must match an {@link Assisted} 50*f585d8a3SJacky Wang * parameter in the associated {@link AssistedInject} constructor (i.e. identifier + type). 51*f585d8a3SJacky Wang * A parameter with no {@code @Assisted} annotation will be assigned the default identifier. Thus, 52*f585d8a3SJacky Wang * the following parameters are equivalent within an {@link AssistedFactory} method: 53*f585d8a3SJacky Wang * 54*f585d8a3SJacky Wang * <ul> 55*f585d8a3SJacky Wang * <li> {@code Foo foo} 56*f585d8a3SJacky Wang * <li> {@code @Assisted Foo foo} 57*f585d8a3SJacky Wang * <li> {@code @Assisted("") Foo foo} 58*f585d8a3SJacky Wang * </ul> 59*f585d8a3SJacky Wang * 60*f585d8a3SJacky Wang * <p>Example: 61*f585d8a3SJacky Wang * 62*f585d8a3SJacky Wang * <pre><code> 63*f585d8a3SJacky Wang * final class DataService { 64*f585d8a3SJacky Wang * {@literal @}AssistedInject 65*f585d8a3SJacky Wang * DataService( 66*f585d8a3SJacky Wang * BindingFromDagger bindingFromDagger, 67*f585d8a3SJacky Wang * {@literal @}Assisted String name, 68*f585d8a3SJacky Wang * {@literal @}Assisted("id") String id, 69*f585d8a3SJacky Wang * {@literal @}Assisted("repo") String repo) {} 70*f585d8a3SJacky Wang * } 71*f585d8a3SJacky Wang * 72*f585d8a3SJacky Wang * {@literal @}AssistedFactory 73*f585d8a3SJacky Wang * interface DataServiceFactory { 74*f585d8a3SJacky Wang * DataService create( 75*f585d8a3SJacky Wang * String name, 76*f585d8a3SJacky Wang * {@literal @}Assisted("id") String id, 77*f585d8a3SJacky Wang * {@literal @}Assisted("repo") String repo); 78*f585d8a3SJacky Wang * } 79*f585d8a3SJacky Wang * </code></pre> 80*f585d8a3SJacky Wang */ value()81*f585d8a3SJacky Wang String value() default ""; 82*f585d8a3SJacky Wang } 83