Class RealMultibinder.ExtensionRealMultibinderProvider<T>
- All Implemented Interfaces:
InternalFactory<Set<T>>
,MultibinderBinding<Set<T>>
,Provider<Set<T>>
,HasDependencies
,ProviderWithExtensionVisitor<Set<T>>
,javax.inject.Provider<Set<T>>
- Enclosing class:
RealMultibinder<T>
-
Field Summary
FieldsModifier and TypeFieldDescription(package private) final RealMultibinder.RealMultibinderProvider
<T> Fields inherited from class com.google.inject.internal.RealMultibinder.BaseFactory
bindingSelection, dependenciesFn
Fields inherited from class com.google.inject.internal.InternalProviderInstanceBindingImpl.Factory
provisionCallback
-
Constructor Summary
ConstructorsConstructorDescription -
Method Summary
Modifier and TypeMethodDescription<B,
V> V acceptExtensionVisitor
(BindingTargetVisitor<B, V> visitor, ProviderInstanceBinding<? extends B> binding) Instructs the extension determine if the visitor is an instance of a custom extension visitor, and if so, visit it using that method.boolean
containsElement
(Element element) Returns true if this Multibinder uses the given Element.protected void
protected com.google.common.collect.ImmutableSet
<T> doProvision
(InternalContext context, Dependency<?> dependency) Creates an object to be injected.com.google.common.collect.ImmutableSet
<Key<?>> Returns the keys of other bindings that represent this set.Returns all bindings that make up the set.TypeLiteral
<?> Returns the TypeLiteral that describes the type of elements in the set.Returns the key for the set.boolean
Returns true if the multibinder permits duplicates.Methods inherited from class com.google.inject.internal.RealMultibinder.BaseFactory
equals, getDependencies, hashCode, initialize
Methods inherited from class com.google.inject.internal.InternalProviderInstanceBindingImpl.Factory
get, get, getSource
-
Field Details
-
delegate
-
-
Constructor Details
-
ExtensionRealMultibinderProvider
ExtensionRealMultibinderProvider(RealMultibinder.RealMultibinderProvider<T> delegate)
-
-
Method Details
-
doInitialize
protected void doInitialize()- Specified by:
doInitialize
in classRealMultibinder.BaseFactory<T,
Set<T>>
-
doProvision
protected com.google.common.collect.ImmutableSet<T> doProvision(InternalContext context, Dependency<?> dependency) throws InternalProvisionException Description copied from class:InternalProviderInstanceBindingImpl.Factory
Creates an object to be injected.- Specified by:
doProvision
in classInternalProviderInstanceBindingImpl.Factory<Set<T>>
- Returns:
- instance to be injected
- Throws:
InternalProvisionException
- if a value cannot be provided
-
acceptExtensionVisitor
public <B,V> V acceptExtensionVisitor(BindingTargetVisitor<B, V> visitor, ProviderInstanceBinding<? extends B> binding) Description copied from interface:ProviderWithExtensionVisitor
Instructs the extension determine if the visitor is an instance of a custom extension visitor, and if so, visit it using that method. If the visitor is not an instance of the custom extension visitor, this method MUST call visitor.visit(binding).Due to issues with generics, the type parameters of this method do not relate to the type of the provider. In practice, the 'B' type will always be a supertype of 'T'.
- Specified by:
acceptExtensionVisitor
in interfaceProviderWithExtensionVisitor<T>
-
getSetKey
Description copied from interface:MultibinderBinding
Returns the key for the set.- Specified by:
getSetKey
in interfaceMultibinderBinding<T>
-
getAlternateSetKeys
Description copied from interface:MultibinderBinding
Returns the keys of other bindings that represent this set. This will return an entry forCollection<com.google.inject.Provider<V>>
,Collection<javax.inject.Provider<V>>
, andSet<? extends V>
.- Specified by:
getAlternateSetKeys
in interfaceMultibinderBinding<T>
-
getElementTypeLiteral
Description copied from interface:MultibinderBinding
Returns the TypeLiteral that describes the type of elements in the set.The elements will always match the type Set's generic type. For example, if getSetKey returns a key of
Set<String>
, then this will always return aTypeLiteral<String>
.- Specified by:
getElementTypeLiteral
in interfaceMultibinderBinding<T>
-
getElements
Description copied from interface:MultibinderBinding
Returns all bindings that make up the set. This is only supported on bindings returned from an injector. This will throwUnsupportedOperationException
if it is called on an element retrieved fromElements.getElements(com.google.inject.Module...)
.The elements will always match the type Set's generic type. For example, if getSetKey returns a key of
Set<String>
, then this will always return a list of typeList<Binding<String>>
.- Specified by:
getElements
in interfaceMultibinderBinding<T>
-
permitsDuplicates
public boolean permitsDuplicates()Description copied from interface:MultibinderBinding
Returns true if the multibinder permits duplicates. This is only supported on bindings returned from an injector. This will throwUnsupportedOperationException
if it is called on a MultibinderBinding retrieved fromElements.getElements(com.google.inject.Module...)
.- Specified by:
permitsDuplicates
in interfaceMultibinderBinding<T>
-
containsElement
Description copied from interface:MultibinderBinding
Returns true if this Multibinder uses the given Element. This will be true for bindings that derive the elements of the set and other bindings that Multibinder uses internally. This will work for MultibinderBindings retrieved from an injector andElements.getElements(com.google.inject.Module...)
. Usually this is only necessary if you are working with elements retrieved from modules (without an Injector), otherwiseMultibinderBinding.getElements()
andMultibinderBinding.permitsDuplicates()
are better options.If you need to introspect the details of the set, such as the values or if it permits duplicates, it is necessary to pass the elements through an Injector and use
MultibinderBinding.getElements()
andMultibinderBinding.permitsDuplicates()
.- Specified by:
containsElement
in interfaceMultibinderBinding<T>
-