org.elasticsearch.common.inject.State Maven / Gradle / Ivy
The newest version!
/*
* Copyright (C) 2008 Google Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.elasticsearch.common.inject;
import com.google.common.collect.ImmutableSet;
import org.elasticsearch.common.inject.internal.BindingImpl;
import org.elasticsearch.common.inject.internal.Errors;
import org.elasticsearch.common.inject.internal.MatcherAndConverter;
import org.elasticsearch.common.inject.spi.TypeListenerBinding;
import java.lang.annotation.Annotation;
import java.util.Collections;
import java.util.List;
import java.util.Map;
/**
* The inheritable data within an injector. This class is intended to allow parent and local
* injector data to be accessed as a unit.
*
* @author [email protected] (Jesse Wilson)
*/
interface State {
static final State NONE = new State() {
@Override
public State parent() {
throw new UnsupportedOperationException();
}
@Override
public BindingImpl getExplicitBinding(Key key) {
return null;
}
@Override
public Map, Binding>> getExplicitBindingsThisLevel() {
throw new UnsupportedOperationException();
}
@Override
public void putBinding(Key> key, BindingImpl> binding) {
throw new UnsupportedOperationException();
}
@Override
public Scope getScope(Class extends Annotation> scopingAnnotation) {
return null;
}
@Override
public void putAnnotation(Class extends Annotation> annotationType, Scope scope) {
throw new UnsupportedOperationException();
}
@Override
public void addConverter(MatcherAndConverter matcherAndConverter) {
throw new UnsupportedOperationException();
}
@Override
public MatcherAndConverter getConverter(String stringValue, TypeLiteral> type, Errors errors,
Object source) {
throw new UnsupportedOperationException();
}
@Override
public Iterable getConvertersThisLevel() {
return ImmutableSet.of();
}
@Override
public void addTypeListener(TypeListenerBinding typeListenerBinding) {
throw new UnsupportedOperationException();
}
@Override
public List getTypeListenerBindings() {
return Collections.emptyList();
}
@Override
public void blacklist(Key> key) {
}
@Override
public boolean isBlacklisted(Key> key) {
return true;
}
@Override
public void clearBlacklisted() {
}
@Override
public void makeAllBindingsToEagerSingletons(Injector injector) {
}
@Override
public Object lock() {
throw new UnsupportedOperationException();
}
};
State parent();
/**
* Gets a binding which was specified explicitly in a module, or null.
*/
BindingImpl getExplicitBinding(Key key);
/**
* Returns the explicit bindings at this level only.
*/
Map, Binding>> getExplicitBindingsThisLevel();
void putBinding(Key> key, BindingImpl> binding);
/**
* Returns the matching scope, or null.
*/
Scope getScope(Class extends Annotation> scopingAnnotation);
void putAnnotation(Class extends Annotation> annotationType, Scope scope);
void addConverter(MatcherAndConverter matcherAndConverter);
/**
* Returns the matching converter for {@code type}, or null if none match.
*/
MatcherAndConverter getConverter(
String stringValue, TypeLiteral> type, Errors errors, Object source);
/**
* Returns all converters at this level only.
*/
Iterable getConvertersThisLevel();
void addTypeListener(TypeListenerBinding typeListenerBinding);
List getTypeListenerBindings();
/**
* Forbids the corresponding injector from creating a binding to {@code key}. Child injectors
* blacklist their bound keys on their parent injectors to prevent just-in-time bindings on the
* parent injector that would conflict.
*/
void blacklist(Key> key);
/**
* Returns true if {@code key} is forbidden from being bound in this injector. This indicates that
* one of this injector's descendent's has bound the key.
*/
boolean isBlacklisted(Key> key);
/**
* Returns the shared lock for all injector data. This is a low-granularity, high-contention lock
* to be used when reading mutable data (ie. just-in-time bindings, and binding blacklists).
*/
Object lock();
// ES_GUICE: clean blacklist keys
void clearBlacklisted();
void makeAllBindingsToEagerSingletons(Injector injector);
}