/* * 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 org.elasticsearch.common.inject.internal.Errors; import org.elasticsearch.common.inject.spi.Element; import org.elasticsearch.common.inject.spi.ElementVisitor; import org.elasticsearch.common.inject.spi.InjectionRequest; import org.elasticsearch.common.inject.spi.MembersInjectorLookup; import org.elasticsearch.common.inject.spi.Message; import org.elasticsearch.common.inject.spi.PrivateElements; import org.elasticsearch.common.inject.spi.ProviderLookup; import org.elasticsearch.common.inject.spi.ScopeBinding; import org.elasticsearch.common.inject.spi.StaticInjectionRequest; import org.elasticsearch.common.inject.spi.TypeConverterBinding; import org.elasticsearch.common.inject.spi.TypeListenerBinding; import java.util.Iterator; import java.util.List; /** * Abstract base class for creating an injector from module elements. * <p> * Extending classes must return {@code true} from any overridden * {@code visit*()} methods, in order for the element processor to remove the * handled element. * * @author jessewilson@google.com (Jesse Wilson) */ abstract class AbstractProcessor implements ElementVisitor<Boolean> { protected Errors errors; protected InjectorImpl injector; protected AbstractProcessor(Errors errors) { this.errors = errors; } public void process(Iterable<InjectorShell> isolatedInjectorBuilders) { for (InjectorShell injectorShell : isolatedInjectorBuilders) { process(injectorShell.getInjector(), injectorShell.getElements()); } } public void process(InjectorImpl injector, List<Element> elements) { Errors errorsAnyElement = this.errors; this.injector = injector; try { for (Iterator<Element> i = elements.iterator(); i.hasNext(); ) { Element element = i.next(); this.errors = errorsAnyElement.withSource(element.getSource()); Boolean allDone = element.acceptVisitor(this); if (allDone) { i.remove(); } } } finally { this.errors = errorsAnyElement; this.injector = null; } } @Override public Boolean visit(Message message) { return false; } @Override public Boolean visit(ScopeBinding scopeBinding) { return false; } @Override public Boolean visit(InjectionRequest injectionRequest) { return false; } @Override public Boolean visit(StaticInjectionRequest staticInjectionRequest) { return false; } @Override public Boolean visit(TypeConverterBinding typeConverterBinding) { return false; } @Override public <T> Boolean visit(Binding<T> binding) { return false; } @Override public <T> Boolean visit(ProviderLookup<T> providerLookup) { return false; } @Override public Boolean visit(PrivateElements privateElements) { return false; } @Override public <T> Boolean visit(MembersInjectorLookup<T> lookup) { return false; } @Override public Boolean visit(TypeListenerBinding binding) { return false; } }