package org.eclipse.stem.analysis.automaticexperiment; | |
/******************************************************************************* | |
* Copyright (c) 2009, 2010, 2011, 2012, 2013, 2014, 2015, 2016, 2017, 2018 | |
* IBM Corporation, BfR, and others. | |
* All rights reserved. This program and the accompanying materials | |
* are made available under the terms of the Eclipse Public License v2.0 | |
* which accompanies this distribution, and is available at | |
* https://www.eclipse.org/legal/epl-2.0/ | |
* | |
* Contributors: | |
* IBM Corporation - initial API and implementation and new features | |
* Bundesinstitut für Risikobewertung - Pajek Graph interface, new Veterinary Models | |
*******************************************************************************/ | |
import org.eclipse.core.runtime.IStatus; | |
import org.eclipse.core.runtime.Status; | |
import org.eclipse.jface.resource.ImageDescriptor; | |
import org.eclipse.stem.analysis.automaticexperiment.executable.AutomaticExperimentExecutableAdapterFactory; | |
import org.eclipse.stem.analysis.automaticexperiment.ui.AutomaticExperimentCompositeEditorAdapterFactory; | |
import org.eclipse.ui.plugin.AbstractUIPlugin; | |
import org.osgi.framework.BundleContext; | |
/** | |
* The activator class controls the plug-in life cycle | |
*/ | |
public class Activator extends AbstractUIPlugin { | |
// The plug-in ID | |
public static final String PLUGIN_ID = "org.eclipse.stem.analysis.automaticexperiment"; //$NON-NLS-1$ | |
// The shared instance | |
private static Activator plugin; | |
/** | |
* The constructor | |
*/ | |
public Activator() { | |
} | |
/* | |
* (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; | |
new AutomaticExperimentExecutableAdapterFactory(); | |
new AutomaticExperimentCompositeEditorAdapterFactory(); | |
} | |
/* | |
* (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 Activator 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); | |
} | |
/** | |
* Log an error to the ILog for this plugin | |
* | |
* @param message | |
* the localized error message text | |
* @param exception | |
* the associated exception, or null | |
*/ | |
public static void logError(String message, Throwable exception) { | |
// Do we have a plugin? | |
if (plugin != null) { | |
// Yes | |
plugin.getLog().log( | |
new Status(IStatus.ERROR, plugin.getBundle() | |
.getSymbolicName(), 0, message, exception)); | |
} else { | |
// No | |
System.out.println(message); | |
// Exception? | |
if (exception != null) { | |
// Yes | |
System.out.println(exception.getMessage()); | |
} // if | |
} | |
} // logError | |
/** | |
* Log information to the ILog for this plugin | |
* | |
* @param message | |
* the localized information message text | |
* @param exception | |
* the associated exception, or null | |
*/ | |
public static void logInformation(String message, Throwable exception) { | |
// Do we have a plugin? | |
if (plugin != null) { | |
// Yes | |
plugin.getLog().log( | |
new Status(IStatus.INFO, plugin.getBundle().getSymbolicName(), | |
0, message, exception)); | |
} | |
else { | |
// No | |
System.out.println(message); | |
// Exception? | |
if (exception != null) { | |
// Yes | |
System.out.println(exception.getMessage()); | |
} // if | |
} | |
} // logInformation | |
/** | |
* Log information to the ILog for this plugin | |
* The method is overloaded to allow for logInformation without an error | |
* method sets the error to null. This should be used instead of System.out.println | |
* throughout the code. | |
* @param message | |
* the localized information message text | |
* | |
*/ | |
public static void logInformation(String message) { | |
// Do we have a plugin? | |
if (plugin != null) { | |
// Yes | |
plugin.getLog().log( | |
new Status(IStatus.INFO, plugin.getBundle().getSymbolicName(), | |
0, message, null)); | |
} | |
else { | |
// No | |
System.out.println(message); | |
} | |
} // logInformation | |
} |