Package com.google.inject.spi
Class ProviderLookup<T>
- java.lang.Object
-
- com.google.inject.spi.ProviderLookup<T>
-
- All Implemented Interfaces:
Element
public final class ProviderLookup<T> extends Object implements Element
A lookup of the provider for a type. Lookups are created explicitly in a module usinggetProvider()
statements:Provider<PaymentService> paymentServiceProvider = getProvider(PaymentService.class);
- Since:
- 2.0
- Author:
- jessewilson@google.com (Jesse Wilson)
-
-
Constructor Summary
Constructors Constructor Description ProviderLookup(Object source, Key<T> key)
ProviderLookup(Object source, Dependency<T> dependency)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description <T> T
acceptVisitor(ElementVisitor<T> visitor)
Accepts an element visitor.void
applyTo(Binder binder)
Writes this module element to the given binder (optional operation).boolean
equals(Object obj)
Provider<T>
getDelegate()
Returns the delegate provider, ornull
if it has not yet been initialized.Dependency<T>
getDependency()
Key<T>
getKey()
Provider<T>
getProvider()
Returns the looked up provider.Object
getSource()
Returns an arbitrary object containing information about the "place" where this element was configured.int
hashCode()
void
initializeDelegate(Provider<T> delegate)
Sets the actual provider.String
toString()
-
-
-
Method Detail
-
getSource
public Object getSource()
Description copied from interface:Element
Returns an arbitrary object containing information about the "place" where this element was configured. Used by Guice in the production of descriptive error messages.Tools might specially handle types they know about;
StackTraceElement
is a good example. Tools should simply calltoString()
on the source object if the type is unfamiliar.
-
getDependency
public Dependency<T> getDependency()
- Since:
- 4.0
-
acceptVisitor
public <T> T acceptVisitor(ElementVisitor<T> visitor)
Description copied from interface:Element
Accepts an element visitor. Invokes the visitor method specific to this element's type.- Specified by:
acceptVisitor
in interfaceElement
- Parameters:
visitor
- to call back on
-
initializeDelegate
public void initializeDelegate(Provider<T> delegate)
Sets the actual provider.- Throws:
IllegalStateException
- if the delegate is already set
-
applyTo
public void applyTo(Binder binder)
Description copied from interface:Element
Writes this module element to the given binder (optional operation).
-
getDelegate
public Provider<T> getDelegate()
Returns the delegate provider, ornull
if it has not yet been initialized. The delegate will be initialized when this element is processed, or otherwise used to create an injector.
-
getProvider
public Provider<T> getProvider()
Returns the looked up provider. The result is not valid until this lookup has been initialized, which usually happens when the injector is created. The provider will throw anIllegalStateException
if you try to use it beforehand.
-
-