/** * Copyright (C) 2009 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 java.net.URL; import java.util.Map; import org.ow2.mind.GenericResourceLocator; import org.ow2.mind.InputResource; /** * ADL location interface. */ public interface ADLLocator extends GenericResourceLocator { /** Default name of this interface. */ String ITF_NAME = "adl-locator"; /** * The value of {@link InputResource#getKind() input-resource's kind} that is * used to reference an ADL {@link InputResource}. */ String ADL_RESOURCE_KIND = "adl"; /** * Locate the ADL source for the given name. * * @param name an ADL name. * @param context additional parameters. * @return the {@link URL} of the ADL source file or <code>null</code> if no * source file can be found for the given name. */ URL findSourceADL(String name, Map<Object, Object> context); /** * Locate the ADL binary for the given name. * * @param name an ADL name. * @param context additional parameters. * @return the {@link URL} of the ADL binary file or <code>null</code> if no * binary file can be found for the given name. */ URL findBinaryADL(String name, Map<Object, Object> context); /** * Returns an {@link InputResource} corresponding to the ADL of the given * name. * * @param name an ADL name * @return an {@link InputResource} corresponding to the ADL of the given * name. */ InputResource toInputResource(String name); }