package org.eclipse.tm.te.ui.terminals.process.activator; import org.eclipse.jface.resource.ImageDescriptor; import org.eclipse.jface.resource.ImageRegistry; import org.eclipse.swt.graphics.Image; import org.eclipse.tm.te.runtime.tracing.TraceHandler; import org.eclipse.ui.plugin.AbstractUIPlugin; import org.osgi.framework.BundleContext; /** * The activator class controls the plug-in life cycle */ public class UIPlugin extends AbstractUIPlugin { // The shared instance private static UIPlugin plugin; // The trace handler instance private static TraceHandler traceHandler; /** * The constructor */ public UIPlugin() { } /** * Returns the shared instance * * @return the shared instance */ public static UIPlugin getDefault() { return plugin; } /** * Convenience method which returns the unique identifier of this plugin. */ public static String getUniqueIdentifier() { if (getDefault() != null && getDefault().getBundle() != null) { return getDefault().getBundle().getSymbolicName(); } return null; } /** * Returns the bundles trace handler. * * @return The bundles trace handler. */ public static TraceHandler getTraceHandler() { if (traceHandler == null) { traceHandler = new TraceHandler(getUniqueIdentifier()); } return traceHandler; } /* (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; } /* (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); } /* (non-Javadoc) * @see org.eclipse.ui.plugin.AbstractUIPlugin#initializeImageRegistry(org.eclipse.jface.resource.ImageRegistry) */ @Override protected void initializeImageRegistry(ImageRegistry registry) { super.initializeImageRegistry(registry); } /** * Loads the image registered under the specified key from the image * registry and returns the <code>Image</code> object instance. * * @param key The key the image is registered with. * @return The <code>Image</code> object instance or <code>null</code>. */ public static Image getImage(String key) { return getDefault().getImageRegistry().get(key); } /** * Loads the image registered under the specified key from the image * registry and returns the <code>ImageDescriptor</code> object instance. * * @param key The key the image is registered with. * @return The <code>ImageDescriptor</code> object instance or <code>null</code>. */ public static ImageDescriptor getImageDescriptor(String key) { return getDefault().getImageRegistry().getDescriptor(key); } }