1 /*
2  * Copyright (C) 2015 The Dagger Authors.
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  */
16 
17 package dagger.functional;
18 
19 import dagger.Component;
20 import dagger.functional.sub.OtherThing;
21 import javax.inject.Inject;
22 
23 @Component(dependencies = {NonComponentDependencyComponent.ThingComponent.class})
24 interface NonComponentDependencyComponent {
thingTwo()25   ThingTwo thingTwo();
26 
27   static class ThingTwo {
28     @SuppressWarnings("unused")
29     @Inject
ThingTwo( Thing thing, NonComponentDependencyComponent nonComponentDependencyComponent, NonComponentDependencyComponent.ThingComponent thingComponent)30     ThingTwo(
31         Thing thing,
32         NonComponentDependencyComponent nonComponentDependencyComponent,
33         NonComponentDependencyComponent.ThingComponent thingComponent) {}
34   }
35 
36   // A non-component interface which this interface depends upon.
37   interface ThingComponent {
thing()38     Thing thing();
39   }
40 
41   // The implementation for that interface.
42   static class ThingComponentImpl implements ThingComponent {
43     @Override
thing()44     public Thing thing() {
45       return new Thing(new OtherThing(1));
46     }
47   }
48 }
49