/*****************************************************************************
* Copyright (c) 2008 CEA LIST.
*
*
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* Remi Schnekenburger (CEA LIST) Remi.Schnekenburger@cea.fr - Initial API and implementation
*
*****************************************************************************/
package org.eclipse.papyrus.extensionpoints.editors.utils;
import java.util.ArrayList;
import java.util.List;
import org.eclipse.papyrus.extensionpoints.editors.configuration.DefaultDirectEditorConfiguration;
import org.eclipse.papyrus.extensionpoints.editors.configuration.IDirectEditorConfiguration;
import org.eclipse.papyrus.extensionpoints.editors.definition.DirectEditorExtensionPoint;
/**
*
*/
public class DirectEditorsUtil {
/**
* Finds a editor for specific language and object to edit type
*
* @param language
* the language to edit
* @param objectToEdit
* the type of object to edit
* @return the extension point proxy that manages this kind of editor
*/
public static IDirectEditorConfiguration findEditorConfiguration(String language, String objectToEdit) {
DirectEditorExtensionPoint[] extensionPoints = DirectEditorExtensionPoint.getDirectEditorConfigurations();
for(DirectEditorExtensionPoint directEditorExtensionPoint : extensionPoints) {
final String lang = directEditorExtensionPoint.getLanguage();
final String oToEdit = directEditorExtensionPoint.getObjectToEdit();
if(lang.equals(language) && oToEdit.equals(objectToEdit)) {
// extension point found!
return directEditorExtensionPoint.getDirectEditorConfiguration();
}
}
return new DefaultDirectEditorConfiguration();
}
/**
* finds if an editor for specific language and object is available to edit type
*
* @param language
* the language to edit
* @param objectToEdit
* the type of object to edit
* @return <code>true</code> if an editor exists
*/
public static boolean hasSpecificEditorConfiguration(String language, String objectToEdit) {
DirectEditorExtensionPoint[] extensionPoints = DirectEditorExtensionPoint.getDirectEditorConfigurations();
for(DirectEditorExtensionPoint directEditorExtensionPoint : extensionPoints) {
final String lang = directEditorExtensionPoint.getLanguage();
final String oToEdit = directEditorExtensionPoint.getObjectToEdit();
if(lang.equals(language) && oToEdit.equals(objectToEdit)) {
// extension point found!
return true;
}
}
return false;
}
/**
* finds if an editor for specific object is available to edit type
*
* @param language
* the language to edit
* @param objectToEdit
* the type of object to edit
* @return <code>true</code> if an editor exists
*/
public static boolean hasSpecificEditorConfiguration(String objectToEdit) {
DirectEditorExtensionPoint[] extensionPoints = DirectEditorExtensionPoint.getDirectEditorConfigurations();
for(DirectEditorExtensionPoint directEditorExtensionPoint : extensionPoints) {
final String oToEdit = directEditorExtensionPoint.getObjectToEdit();
if(oToEdit.equals(objectToEdit)) {
// extension point found!
return true;
}
}
return false;
}
/**
* returns the list of languages that are available from extension points
*
* @return the list of languages that have an extended editor
*/
// @unused
public static List<String> getLanguages(String objectToEdit) {
List<String> languages = new ArrayList<String>();
DirectEditorExtensionPoint[] extensionPoints = DirectEditorExtensionPoint.getDirectEditorConfigurations();
for(DirectEditorExtensionPoint directEditorExtensionPoint : extensionPoints) {
if(objectToEdit == null || directEditorExtensionPoint.getObjectToEdit().equals(objectToEdit)) {
String lang = directEditorExtensionPoint.getLanguage();
if(!languages.contains(lang)) {
languages.add(lang);
}
}
}
return languages;
}
}