xref: /aosp_15_r20/external/dagger2/java/dagger/model/DependencyRequest.java (revision f585d8a307d0621d6060bd7e80091fdcbf94fe27)
1*f585d8a3SJacky Wang /*
2*f585d8a3SJacky Wang  * Copyright (C) 2014 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.model;
18*f585d8a3SJacky Wang 
19*f585d8a3SJacky Wang import com.google.auto.value.AutoValue;
20*f585d8a3SJacky Wang import com.google.errorprone.annotations.CanIgnoreReturnValue;
21*f585d8a3SJacky Wang import dagger.Provides;
22*f585d8a3SJacky Wang import java.util.Optional;
23*f585d8a3SJacky Wang import javax.inject.Inject;
24*f585d8a3SJacky Wang import javax.lang.model.element.Element;
25*f585d8a3SJacky Wang 
26*f585d8a3SJacky Wang /**
27*f585d8a3SJacky Wang  * Represents a request for a {@link Key} at an injection point. For example, parameters to {@link
28*f585d8a3SJacky Wang  * Inject} constructors, {@link Provides} methods, and component methods are all dependency
29*f585d8a3SJacky Wang  * requests.
30*f585d8a3SJacky Wang  *
31*f585d8a3SJacky Wang  * <p id="synthetic">A dependency request is considered to be <em>synthetic</em> if it does not have
32*f585d8a3SJacky Wang  * an {@link Element} in code that requests the key directly. For example, an {@link
33*f585d8a3SJacky Wang  * java.util.concurrent.Executor} is required for all {@code @Produces} methods to run
34*f585d8a3SJacky Wang  * asynchronously even though it is not directly specified as a parameter to the binding method.
35*f585d8a3SJacky Wang  */
36*f585d8a3SJacky Wang @AutoValue
37*f585d8a3SJacky Wang public abstract class DependencyRequest {
38*f585d8a3SJacky Wang   /** The kind of this request. */
kind()39*f585d8a3SJacky Wang   public abstract RequestKind kind();
40*f585d8a3SJacky Wang 
41*f585d8a3SJacky Wang   /** The key of this request. */
key()42*f585d8a3SJacky Wang   public abstract Key key();
43*f585d8a3SJacky Wang 
44*f585d8a3SJacky Wang   /**
45*f585d8a3SJacky Wang    * The element that declares this dependency request. Absent for <a href="#synthetic">synthetic
46*f585d8a3SJacky Wang    * </a> requests.
47*f585d8a3SJacky Wang    */
requestElement()48*f585d8a3SJacky Wang   public abstract Optional<Element> requestElement();
49*f585d8a3SJacky Wang 
50*f585d8a3SJacky Wang   /**
51*f585d8a3SJacky Wang    * Returns {@code true} if this request allows null objects. A request is nullable if it is
52*f585d8a3SJacky Wang    * has an annotation with "Nullable" as its simple name.
53*f585d8a3SJacky Wang    */
isNullable()54*f585d8a3SJacky Wang   public abstract boolean isNullable();
55*f585d8a3SJacky Wang 
56*f585d8a3SJacky Wang   /** Returns a new builder of dependency requests. */
builder()57*f585d8a3SJacky Wang   public static DependencyRequest.Builder builder() {
58*f585d8a3SJacky Wang     return new AutoValue_DependencyRequest.Builder().isNullable(false);
59*f585d8a3SJacky Wang   }
60*f585d8a3SJacky Wang 
61*f585d8a3SJacky Wang   /** A builder of {@link DependencyRequest}s. */
62*f585d8a3SJacky Wang   @AutoValue.Builder
63*f585d8a3SJacky Wang   public abstract static class Builder {
kind(RequestKind kind)64*f585d8a3SJacky Wang     public abstract Builder kind(RequestKind kind);
65*f585d8a3SJacky Wang 
key(Key key)66*f585d8a3SJacky Wang     public abstract Builder key(Key key);
67*f585d8a3SJacky Wang 
68*f585d8a3SJacky Wang     @CanIgnoreReturnValue // TODO(kak): remove this once open-source checkers understand AutoValue
requestElement(Element element)69*f585d8a3SJacky Wang     public abstract Builder requestElement(Element element);
70*f585d8a3SJacky Wang 
isNullable(boolean isNullable)71*f585d8a3SJacky Wang     public abstract Builder isNullable(boolean isNullable);
72*f585d8a3SJacky Wang 
build()73*f585d8a3SJacky Wang     public abstract DependencyRequest build();
74*f585d8a3SJacky Wang   }
75*f585d8a3SJacky Wang }
76