/****************************************************************************** * Copyright (c) 2009-2013, Linagora * * 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: * Linagora - initial API and implementation *******************************************************************************/ package com.ebmwebsourcing.petals.services; import org.eclipse.core.runtime.IStatus; import org.eclipse.core.runtime.Status; import org.eclipse.emf.ecore.EPackage; import org.eclipse.emf.ecore.impl.EPackageRegistryImpl; import org.eclipse.jface.resource.ImageDescriptor; import org.eclipse.swt.graphics.Image; import org.eclipse.ui.plugin.AbstractUIPlugin; import org.osgi.framework.BundleContext; import com.ebmwebsourcing.petals.services.su.editor.extensibility.InitializeModelExtensionCommand; import com.ebmwebsourcing.petals.services.su.extensions.ComponentVersionDescription; import com.ebmwebsourcing.petals.services.su.extensions.ExtensionManager; /** * The activator class controls the plug-in life cycle * @author Vincent Zurczak - EBM WebSourcing */ public class PetalsServicesPlugin extends AbstractUIPlugin { // The plug-in ID public static final String PLUGIN_ID = "com.ebmwebsourcing.petals.services"; // The shared instance private static PetalsServicesPlugin plugin; /** * The constructor */ public PetalsServicesPlugin() { // nothing } /* * (non-Javadoc) * @see org.eclipse.ui.plugin.AbstractUIPlugin * #start(org.osgi.framework.BundleContext) */ @Override public void start( BundleContext context ) throws Exception { super.start( context ); plugin = this; // Initialize feature IDs // FIXME: Seems to be required for the wizards (but why?) try { for (ComponentVersionDescription description : ExtensionManager.INSTANCE.findAllComponentVersionDescriptions()) { EPackage extensionPackage = EPackageRegistryImpl.INSTANCE.getEPackage(description.getNamespace()); if (extensionPackage != null) { new InitializeModelExtensionCommand( extensionPackage, null ).initializeFeatures(); } else { log("Could not load model for component [" + description.getComponentName() + "] (ns=" + description.getNamespace() + ")", IStatus.ERROR); } } } catch( Exception e ) { log( e, IStatus.ERROR ); } } /* * (non-Javadoc) * @see org.eclipse.ui.plugin.AbstractUIPlugin * #stop(org.osgi.framework.BundleContext) */ @Override public void stop( BundleContext context ) throws Exception { plugin = null; super.stop( context ); } /** * Returns the shared instance * @return the shared instance */ public static PetalsServicesPlugin getDefault() { return plugin; } /** * Returns an image descriptor for the image file at the given * plug-in relative path * * @param path the path * @return the image descriptor */ public static ImageDescriptor getImageDescriptor( String path ) { return imageDescriptorFromPlugin( PLUGIN_ID, path ); } /** * Loads the image located by this path in the current plug-in. * <p> * If the path is invalid or if the image could not be loaded, a log entry is created. * </p> * * @param path the relative image path in the plug-in * @return the image or null if it could not be loaded */ public static Image loadImage( String path ) { Image img = null; try { ImageDescriptor desc = getImageDescriptor( path ); if( desc != null ) img = desc.createImage(); } catch( Exception e ) { log( e, IStatus.WARNING ); } return img; } /** * Logs an exception. * @param e the exception to log * @param severity the severity, given as one of the {@link IStatus} constants */ public static void log( Exception e, int severity ) { String msg = e.getMessage(); if( msg == null || msg.trim().length() == 0 ) msg = "An error occurred."; IStatus status = new Status( severity, PLUGIN_ID, msg, e ); getDefault().getLog().log( status ); } /** * Logs a message. * @param message the message to log * @param severity the severity, given as one of the {@link IStatus} constants */ public static void log( String message, int severity ) { IStatus status = new Status( severity, PLUGIN_ID, message ); getDefault().getLog().log( status ); } /** * Logs a message and an exception. * @param e the exception to log * @param severity the severity, given as one of the {@link IStatus} constants * @param message the message to log */ public static void log( Exception e, int severity, String message ) { IStatus status = new Status( severity, PLUGIN_ID, message, e ); getDefault().getLog().log( status ); } }