All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.objectweb.fractal.mind.adl.ADLLocator Maven / Gradle / Ivy

The newest version!
/**
 * 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 .
 *
 * Contact: [email protected]
 *
 * Authors: Matthieu Leclercq
 * Contributors: 
 */

package org.objectweb.fractal.mind.adl;

import java.net.URL;
import java.util.Map;

import org.objectweb.fractal.mind.GenericResourceLocator;
import org.objectweb.fractal.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 null if no
   *         source file can be found for the given name.
   */
  URL findSourceADL(String name, Map 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 null if no
   *         binary file can be found for the given name.
   */
  URL findBinaryADL(String name, Map 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);
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy