/* * Copyright (C) 2019 The Dagger 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 dagger.hilt; import static java.lang.annotation.ElementType.TYPE; import static java.lang.annotation.RetentionPolicy.CLASS; import dagger.hilt.internal.definecomponent.DefineComponentNoParent; import java.lang.annotation.Retention; import java.lang.annotation.Target; /** * Defines a Hilt component. * *

Example defining a root component, {@code ParentComponent}: * *


 *   {@literal @}ParentScoped
 *   {@literal @}DefineComponent
 *   interface ParentComponent {}
 * 
* *

Example defining a child component, {@code ChildComponent}: * *


 *   {@literal @}ChildScoped
 *   {@literal @}DefineComponent(parent = ParentComponent.class)
 *   interface ChildComponent {}
 * 
*/ @Retention(CLASS) @Target(TYPE) @GeneratesRootInput public @interface DefineComponent { /** Returns the parent of this component, if it exists. */ Class parent() default DefineComponentNoParent.class; /** * Defines a builder for a Hilt component. * *

   *   {@literal @}DefineComponent.Builder
   *   interface ParentComponentBuilder {
   *     ParentComponentBuilder seedData(SeedData seed);
   *     ParentComponent build();
   *   }
   * 
*/ // TODO(bcorso): Consider making this a top-level class to hint that it doesn't need to be nested. @Retention(CLASS) @Target(TYPE) @GeneratesRootInput public @interface Builder {} }