/**
* Copyright (C) 2010 STMicroelectronics
*
* This file is part of "Mind Compiler" is free software: you can redistribute
* it and/or modify it under the terms of the GNU Lesser General Public License
* as published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
* FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
* details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
* Contact: mind@ow2.org
*
* Authors: Matthieu Leclercq
* Contributors:
*/
package org.ow2.mind.adl;
import org.objectweb.fractal.adl.Loader;
import org.objectweb.fractal.adl.merger.NodeMerger;
import org.ow2.mind.CommonFrontendModule;
import org.ow2.mind.GenericResourceLocator;
import org.ow2.mind.adl.annotation.ADLLoaderPhase;
import org.ow2.mind.adl.annotation.AnnotationProcessorLoader;
import org.ow2.mind.adl.implementation.BasicImplementationLocator;
import org.ow2.mind.adl.implementation.ImplementationLocator;
import org.ow2.mind.adl.parser.ADLJTBParser;
import org.ow2.mind.adl.parser.JTBProcessor;
import org.ow2.mind.inject.AbstractMindModule;
import com.google.inject.Binder;
import com.google.inject.Provider;
import com.google.inject.multibindings.MapBinder;
import com.google.inject.multibindings.Multibinder;
import com.google.inject.name.Names;
/**
* Base configuration for the ADL Front-end module. This class can be
* sub-classed in tests to use custom front-end. Configurations made in this
* module does not depends on IDL Front-end.
*/
public abstract class AbstractADLFrontendModule extends AbstractMindModule {
protected static final String DEFAULT_ADL_DTD = "classpath://org/ow2/mind/adl/mind_v1.dtd";
protected void configureJTBProcessor() {
bind(ADLJTBParser.class).to(JTBProcessor.class);
bind(String.class).annotatedWith(Names.named(JTBProcessor.ADL_DTD))
.toInstance(DEFAULT_ADL_DTD);
}
public static final class AnnotationProcessorProvider
implements
Provider<Loader> {
final Provider<AnnotationProcessorLoader> delegate;
final ADLLoaderPhase phase;
public AnnotationProcessorProvider(final Binder binder,
final ADLLoaderPhase phase) {
this.phase = phase;
delegate = binder.getProvider(AnnotationProcessorLoader.class);
}
public Loader get() {
final AnnotationProcessorLoader loader = delegate.get();
loader.setPhase(phase);
return loader;
}
}
protected void configureADLLocator() {
bind(ADLLocator.class).to(BasicADLLocator.class);
}
protected void configureADLGenericResourceLocator() {
final Multibinder<GenericResourceLocator> multibinder = CommonFrontendModule
.getGenericResourceLocatorBinder(binder());
multibinder.addBinding().to(ADLLocator.class);
}
protected void configureImplementationLocator() {
bind(ImplementationLocator.class).to(BasicImplementationLocator.class);
}
protected void configureImplementationGenericResourceLocator() {
final Multibinder<GenericResourceLocator> multibinder = CommonFrontendModule
.getGenericResourceLocatorBinder(binder());
multibinder.addBinding().to(ImplementationLocator.class);
}
protected void configureADLIDAttributes() {
final MapBinder<String, String> mapBinder = MapBinder.newMapBinder(
binder(), String.class, String.class,
Names.named(ExtendsLoader.ADL_ID_ATTRIBUTES));
mapBinder.addBinding("component").toInstance("name");
mapBinder.addBinding("interface").toInstance("name");
mapBinder.addBinding("attribute").toInstance("name");
mapBinder.addBinding("annotation").toInstance("type");
mapBinder.addBinding("argument").toInstance("name");
mapBinder.addBinding("template").toInstance("name");
}
/**
* This method is not automatically called by {@link AbstractMindModule}, but
* can be called by sub-classes (in tests) to set the default configuration of
* the {@link ExtendsLoader}.
*/
protected void setDefaultExtendsLoaderConfig() {
bind(DefinitionReferenceResolver.class).annotatedWith(
Names.named(ExtendsLoader.EXTENDS_DEFINITION_RESOLVER)).to(
DefinitionReferenceResolver.class);
bind(NodeMerger.class).annotatedWith(
Names.named(ExtendsLoader.EXTENDS_NODE_MERGER))
.to(STCFNodeMerger.class);
}
/**
* This method is not automatically called by {@link AbstractMindModule}, but
* can be called by sub-classes (in tests) to set the default configuration of
* the {@link SubComponentResolverLoader}.
*/
protected void setDefaultSubComponentLoaderConfig() {
bind(DefinitionReferenceResolver.class)
.annotatedWith(
Names
.named(SubComponentResolverLoader.SUB_COMPONENT_DEFINITION_RESOLVER))
.to(DefinitionReferenceResolver.class);
}
}