blob: 037c3656432597e434d15ea3ea84ea7a92bd25ac [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2016 ALL4TEC & CEA LIST.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License 2.0
* which accompanies this distribution, and is available at
* https://www.eclipse.org/legal/epl-2.0/
*
* SPDX-License-Identifier: EPL-2.0
*
* Contributors:
* ALL4TEC & CEA LIST - initial API and implementation
******************************************************************************/
package org.polarsys.esf.core.help;
import java.util.ResourceBundle;
import org.eclipse.core.runtime.IStatus;
import org.eclipse.core.runtime.Status;
import org.eclipse.emf.common.EMFPlugin;
import org.eclipse.emf.common.ui.EclipseUIPlugin;
import org.eclipse.emf.common.util.ResourceLocator;
import org.polarsys.esf.core.common.messages.Messages;
/**
* The activator class controls the plug-in life cycle.
*
* @author $Author: jdumont $
* @version $Revision: 83 $
*/
public class CoreHelpActivator
extends EMFPlugin {
/** Keep track of this singleton activator. */
private static final CoreHelpActivator INSTANCE = new CoreHelpActivator();
/** Keep track of this singleton concrete implementation. */
private static Implementation sPlugin = null;
/** Messages class used to find localised string. */
private static Messages sMessages = new Messages(ResourceBundle.getBundle(Messages.BUNDLE_NAME));
/**
* Default constructor.
*/
public CoreHelpActivator() {
super(new ResourceLocator[] {});
}
/**
* Returns the singleton instance of the Eclipse plugin used as resource locator.
*
* @return The singleton instance
*/
@Override
public ResourceLocator getPluginResourceLocator() {
return sPlugin;
}
/**
* Returns the singleton instance of the Eclipse plugin.
*
* @return The singleton instance
*/
public static Implementation getPlugin() {
return sPlugin;
}
/**
* @return The messages class used to return localised string
*/
public static Messages getMessages() {
return sMessages;
}
/**
* Create an Error status with the data given in parameter and log it.
*
* @param pMessage The message to log
* @param pException The exception to log
*/
public static void logError(final String pMessage, final Exception pException) {
// Create the Error status
IStatus vStatus = new Status(IStatus.ERROR, sPlugin.getSymbolicName(), IStatus.ERROR, pMessage, pException);
// Log it
INSTANCE.log(vStatus);
}
/**
* Create a Warning status with the data given in parameter and log it.
*
* @param pMessage The message to log
* @param pException The exception to log
*/
public static void logWarning(final String pMessage, final Exception pException) {
// Create the Warning status
IStatus vStatus = new Status(IStatus.WARNING, sPlugin.getSymbolicName(), IStatus.WARNING, pMessage, pException);
// Log it
INSTANCE.log(vStatus);
}
/**
* Create an Info status with the data given in parameter and log it.
*
* @param pMessage The message to log
* @param pException The exception to log
*/
public static void logInfo(final String pMessage, final Exception pException) {
// Create the Info status
IStatus vStatus = new Status(IStatus.INFO, sPlugin.getSymbolicName(), IStatus.INFO, pMessage, pException);
// Log it
INSTANCE.log(vStatus);
}
/**
* The actual implementation of the Eclipse <b>UIPlugin</b>.
*/
public static class Implementation
extends EclipseUIPlugin {
/**
* Default constructor.
*/
public Implementation() {
super();
// Remember the static instance.
sPlugin = this;
}
}
}