All Downloads are FREE. Search and download functionalities are using the official Maven repository.
Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
com.google.inject.internal.ProviderInstanceBindingImpl Maven / Gradle / Ivy
package com.google.inject.internal;
import com.google.common.base.MoreObjects;
import com.google.common.base.Objects;
import com.google.common.collect.ImmutableSet;
import com.google.inject.Binder;
import com.google.inject.Key;
import com.google.inject.spi.BindingTargetVisitor;
import com.google.inject.spi.Dependency;
import com.google.inject.spi.HasDependencies;
import com.google.inject.spi.InjectionPoint;
import com.google.inject.spi.ProviderInstanceBinding;
import com.google.inject.spi.ProviderWithExtensionVisitor;
import java.util.Set;
class ProviderInstanceBindingImpl extends BindingImpl implements ProviderInstanceBinding {
private final javax.inject.Provider extends T> providerInstance;
private final ImmutableSet injectionPoints;
ProviderInstanceBindingImpl(InjectorImpl injector, Key key,
Object source, InternalFactory extends T> internalFactory, Scoping scoping,
javax.inject.Provider extends T> providerInstance,
Set injectionPoints) {
super(injector, key, source, internalFactory, scoping);
this.providerInstance = providerInstance;
this.injectionPoints = ImmutableSet.copyOf(injectionPoints);
}
ProviderInstanceBindingImpl(Object source, Key key, Scoping scoping,
Set injectionPoints, javax.inject.Provider extends T> providerInstance) {
super(source, key, scoping);
this.injectionPoints = ImmutableSet.copyOf(injectionPoints);
this.providerInstance = providerInstance;
}
@SuppressWarnings("unchecked") // the extension type is always consistent with the provider type
public V acceptTargetVisitor(BindingTargetVisitor super T, V> visitor) {
if (providerInstance instanceof ProviderWithExtensionVisitor) {
return ((ProviderWithExtensionVisitor extends T>) providerInstance)
.acceptExtensionVisitor(visitor, this);
} else {
return visitor.visit(this);
}
}
public javax.inject.Provider extends T> getUserSuppliedProvider() {
return providerInstance;
}
public Set getInjectionPoints() {
return injectionPoints;
}
public Set> getDependencies() {
return providerInstance instanceof HasDependencies
? ImmutableSet.copyOf(((HasDependencies) providerInstance).getDependencies())
: Dependency.forInjectionPoints(injectionPoints);
}
public BindingImpl withScoping(Scoping scoping) {
return new ProviderInstanceBindingImpl<>(getSource(), getKey(), scoping, injectionPoints, providerInstance);
}
public BindingImpl withKey(Key key) {
return new ProviderInstanceBindingImpl<>(getSource(), key, getScoping(), injectionPoints, providerInstance);
}
public void applyTo(Binder binder) {
getScoping().applyTo(
binder.withSource(getSource()).bind(getKey()).toProvider(getUserSuppliedProvider()));
}
@Override
public String toString() {
return MoreObjects.toStringHelper(ProviderInstanceBinding.class)
.add("key", getKey())
.add("source", getSource())
.add("scope", getScoping())
.add("provider", providerInstance)
.toString();
}
@Override
public boolean equals(Object obj) {
if (obj instanceof ProviderInstanceBindingImpl) {
ProviderInstanceBindingImpl> o = (ProviderInstanceBindingImpl>) obj;
return getKey().equals(o.getKey())
&& getScoping().equals(o.getScoping())
&& Objects.equal(providerInstance, o.providerInstance);
} else {
return false;
}
}
@Override
public int hashCode() {
return Objects.hashCode(getKey(), getScoping());
}
}