blob: 862be7aedd003635a190967339ab8eb162658e96 [file] [log] [blame]
cgrubera04c2962014-09-29 16:32:25 -07001/*
ronshapiro5dde42d2016-06-17 09:03:35 -07002 * Copyright (C) 2012 The Dagger Authors.
cgrubera04c2962014-09-29 16:32:25 -07003 *
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 */
dpb1b65b6a2016-07-11 12:11:24 -070016
cgrubera04c2962014-09-29 16:32:25 -070017package dagger;
18
ronshapirofbb68402016-08-31 06:44:45 -070019import dagger.internal.Beta;
cgrubera04c2962014-09-29 16:32:25 -070020import java.lang.annotation.ElementType;
21import java.lang.annotation.Retention;
22import java.lang.annotation.RetentionPolicy;
23import java.lang.annotation.Target;
24
25/**
26 * Annotates a class that contributes to the object graph.
27 */
28@Retention(RetentionPolicy.RUNTIME)
29@Target(ElementType.TYPE)
30public @interface Module {
31 /**
cgrubera04c2962014-09-29 16:32:25 -070032 * Additional {@code @Module}-annotated classes from which this module is
33 * composed. The de-duplicated contributions of the modules in
34 * {@code includes}, and of their inclusions recursively, are all contributed
35 * to the object graph.
36 */
cgruber70f720b2015-04-06 11:44:57 -070037 Class<?>[] includes() default {};
ronshapirofbb68402016-08-31 06:44:45 -070038
39 /**
ronshapiro71a79732016-09-06 11:39:04 -070040 * Any {@link Subcomponent}- or {@code @ProductionSubcomponent}-annotated classes which should be
41 * children of the component in which this module is installed. A subcomponent may be listed in
42 * more than one module in a component.
ronshapiroaae8de12016-09-07 13:04:52 -070043 *
44 * @since 2.7
ronshapirofbb68402016-08-31 06:44:45 -070045 */
46 @Beta
47 Class<?>[] subcomponents() default {};
cgrubera04c2962014-09-29 16:32:25 -070048}