/** * Optimus, framework for Model Transformation * * Copyright (C) 2013 Worldline or third-party contributors as * indicated by the @author tags or express copyright attribution * statements applied by the authors. * * This library 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 2.1 of the License. * * This library 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 library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA */ package net.atos.optimus.m2m.engine.sdk.tom.extension.datasource; import net.atos.optimus.m2m.engine.core.requirements.AbstractRequirement; import net.atos.optimus.m2m.engine.core.transformations.TransformationReference; import net.atos.optimus.m2m.engine.sdk.tom.Requirement; import org.osgi.framework.Bundle; /** A chain factory to create abstract requirement * * @author tnachtergaele <nachtergaele.thomas@gmail.com> * * */ public class AbstractRequirementChainFactory { /** The unique instance of AbstractRequirementChainFactory */ public static final AbstractRequirementChainFactory INSTANCE = new AbstractRequirementChainFactory(); protected CreateAbstractRequirementHandler firstHandler; /** Constructor : initialize the factories chain * */ private AbstractRequirementChainFactory(){ this.firstHandler = new CreateObjectRequirementHandler(); CreateAbstractRequirementHandler secondHandler = new CreateParentRequirementHandler(); this.firstHandler.setHandler(secondHandler); secondHandler.setHandler(new CreateCustomRequirementHandler()); } /** * Create an abstract requirement according to the specified requirement * * @param transformationReference * the transformation reference associated to the specified * requirement. * @param requirement * the requirement. * @param bundle * the bundle associated to the requirement. * @return the abstract requirement according to the specified requirement * or null if all handlers fail in the chain. */ public AbstractRequirement createAbstractRequirement(TransformationReference transformationReference, Requirement requirement, Bundle bundle){ return this.firstHandler.postCreateAbstractRequirement(transformationReference, requirement, bundle); } }