cgruber | a04c296 | 2014-09-29 16:32:25 -0700 | [diff] [blame] | 1 | /* |
ronshapiro | 5dde42d | 2016-06-17 09:03:35 -0700 | [diff] [blame] | 2 | * Copyright (C) 2012 The Dagger Authors. |
cgruber | a04c296 | 2014-09-29 16:32:25 -0700 | [diff] [blame] | 3 | * |
| 4 | * Licensed under the Apache License, Version 2.0 (the "License"); |
| 5 | * you may not use this file except in compliance with the License. |
| 6 | * You may obtain a copy of the License at |
| 7 | * |
| 8 | * http://www.apache.org/licenses/LICENSE-2.0 |
| 9 | * |
| 10 | * Unless required by applicable law or agreed to in writing, software |
| 11 | * distributed under the License is distributed on an "AS IS" BASIS, |
| 12 | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 13 | * See the License for the specific language governing permissions and |
| 14 | * limitations under the License. |
| 15 | */ |
dpb | 1b65b6a | 2016-07-11 12:11:24 -0700 | [diff] [blame] | 16 | |
cgruber | a04c296 | 2014-09-29 16:32:25 -0700 | [diff] [blame] | 17 | package dagger; |
| 18 | |
ronshapiro | fbb6840 | 2016-08-31 06:44:45 -0700 | [diff] [blame] | 19 | import dagger.internal.Beta; |
ronshapiro | 2e2d327 | 2019-02-07 10:39:44 -0800 | [diff] [blame] | 20 | import java.lang.annotation.Documented; |
cgruber | a04c296 | 2014-09-29 16:32:25 -0700 | [diff] [blame] | 21 | import java.lang.annotation.ElementType; |
| 22 | import java.lang.annotation.Retention; |
| 23 | import java.lang.annotation.RetentionPolicy; |
| 24 | import java.lang.annotation.Target; |
| 25 | |
| 26 | /** |
| 27 | * Annotates a class that contributes to the object graph. |
| 28 | */ |
ronshapiro | 2e2d327 | 2019-02-07 10:39:44 -0800 | [diff] [blame] | 29 | @Documented |
cgruber | a04c296 | 2014-09-29 16:32:25 -0700 | [diff] [blame] | 30 | @Retention(RetentionPolicy.RUNTIME) |
| 31 | @Target(ElementType.TYPE) |
| 32 | public @interface Module { |
| 33 | /** |
cgruber | a04c296 | 2014-09-29 16:32:25 -0700 | [diff] [blame] | 34 | * Additional {@code @Module}-annotated classes from which this module is |
| 35 | * composed. The de-duplicated contributions of the modules in |
| 36 | * {@code includes}, and of their inclusions recursively, are all contributed |
| 37 | * to the object graph. |
| 38 | */ |
cgruber | 70f720b | 2015-04-06 11:44:57 -0700 | [diff] [blame] | 39 | Class<?>[] includes() default {}; |
ronshapiro | fbb6840 | 2016-08-31 06:44:45 -0700 | [diff] [blame] | 40 | |
| 41 | /** |
ronshapiro | 71a7973 | 2016-09-06 11:39:04 -0700 | [diff] [blame] | 42 | * Any {@link Subcomponent}- or {@code @ProductionSubcomponent}-annotated classes which should be |
| 43 | * children of the component in which this module is installed. A subcomponent may be listed in |
| 44 | * more than one module in a component. |
ronshapiro | aae8de1 | 2016-09-07 13:04:52 -0700 | [diff] [blame] | 45 | * |
| 46 | * @since 2.7 |
ronshapiro | fbb6840 | 2016-08-31 06:44:45 -0700 | [diff] [blame] | 47 | */ |
| 48 | @Beta |
| 49 | Class<?>[] subcomponents() default {}; |
cgruber | a04c296 | 2014-09-29 16:32:25 -0700 | [diff] [blame] | 50 | } |