/* * Copyright (c) 2012 Data Harmonisation Panel * * All rights reserved. This program and the accompanying materials are made * available 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. * * You should have received a copy of the GNU Lesser General Public License * along with this distribution. If not, see <http://www.gnu.org/licenses/>. * * Contributors: * 1Spatial PLC <http://www.1spatial.com> * HUMBOLDT EU Integrated Project #030962 * Data Harmonisation Panel <http://www.dhpanel.eu> */ package com.onespatial.jrc.tns.oml_to_rif.api; /** * Translate the contents of the input model into the output model. * * @author Richard Sunderland (Richard.Sunderland@1spatial.com) / 1Spatial Group Ltd. * @author Simon Payne (Simon.Payne@1spatial.com) / 1Spatial Group Ltd. * @param <IM> * the input model to read. * @param <OM> * the output model to write. */ public interface Translator<IM, OM> { /** * Translate the input model into the output model. * * @param source * the model to translate. * @return the populated output model. * @throws TranslationException * if failed to translate. */ OM translate(IM source) throws TranslationException; /** * Create a translator to a different format by connecting a followon * translator that handles the next translation. See * {@link FollowOnTranslator} for class that support the implementation of * this method. * * @param <AOM> * alternative output model. * @param followOnTranslator * the translator that converts the output model to the * alternative output model. * @return translator capable of performing direct translation from input * model to alternative output model. */ <AOM> Translator<IM, AOM> connect(Translator<OM, AOM> followOnTranslator); }