X-Git-Url: http://git.phpeclipse.com diff --git a/net.sourceforge.phpeclipse.debug.core/src/net/sourceforge/phpdt/internal/debug/core/PHPDebugCorePlugin.java b/net.sourceforge.phpeclipse.debug.core/src/net/sourceforge/phpdt/internal/debug/core/PHPDebugCorePlugin.java index 038c3d4..4efdb76 100644 --- a/net.sourceforge.phpeclipse.debug.core/src/net/sourceforge/phpdt/internal/debug/core/PHPDebugCorePlugin.java +++ b/net.sourceforge.phpeclipse.debug.core/src/net/sourceforge/phpdt/internal/debug/core/PHPDebugCorePlugin.java @@ -1,34 +1,67 @@ package net.sourceforge.phpdt.internal.debug.core; +import java.util.MissingResourceException; +import java.util.ResourceBundle; + import net.sourceforge.phpeclipse.PHPeclipsePlugin; + import org.eclipse.core.resources.IWorkspace; -import org.eclipse.core.runtime.IPluginDescriptor; import org.eclipse.core.runtime.IStatus; -import org.eclipse.core.runtime.Plugin; import org.eclipse.core.runtime.Status; -import org.eclipse.core.runtime.*; +import org.eclipse.swt.widgets.Shell; +import org.eclipse.ui.IWorkbenchPage; +import org.eclipse.ui.IWorkbenchWindow; +import org.eclipse.ui.plugin.AbstractUIPlugin; +import org.osgi.framework.BundleContext; /** * The main plugin class to be used in the desktop. */ -public class PHPDebugCorePlugin extends Plugin { - public static final String PLUGIN_ID = "net.sourceforge.phpeclipse.debug.core"; //$NON-NLS-1$ +public class PHPDebugCorePlugin extends AbstractUIPlugin { // The shared instance. protected static PHPDebugCorePlugin plugin; + public static final String PLUGIN_ID = "net.sourceforge.phpeclipse.debug.core"; //$NON-NLS-1$ + + public static IWorkbenchPage getActivePage() { + return getDefault().internalGetActivePage(); + } + public static Shell getActiveWorkbenchShell() { + return getActiveWorkbenchWindow().getShell(); + } + public static IWorkbenchWindow getActiveWorkbenchWindow() { + return getDefault().getWorkbench().getActiveWorkbenchWindow(); + } /** - * The constructor. + * Returns the shared instance. */ - public PHPDebugCorePlugin(IPluginDescriptor descriptor) { - super(descriptor); - plugin = this; - } + public static PHPDebugCorePlugin getDefault() { + return plugin; + } + + public static String getFormattedMessage(String key, String arg) { + String text = getResourceString(key); + return java.text.MessageFormat.format(text, new Object[] { arg }); + } + public static String getResourceString(String key) { + ResourceBundle bundle = plugin.getResourceBundle(); + if (bundle != null) { + try { + String bundleString = bundle.getString(key); + //return "$"+bundleString; + return bundleString; + } catch (MissingResourceException e) { + // default actions is to return key, which is OK + } + } + return key; + } /** - * Returns the shared instance. + * Convenience method which returns the unique identifier of this plugin. */ - public static PHPDebugCorePlugin getDefault() { - return plugin; + public static String getUniqueIdentifier() { + return PLUGIN_ID; } /** @@ -50,25 +83,50 @@ public class PHPDebugCorePlugin extends Plugin { public static void log(Throwable e) { log(new Status(IStatus.ERROR, PLUGIN_ID, IStatus.ERROR, "PHPLaunchingPlugin.internalErrorOccurred", e)); //$NON-NLS-1$ } - + private ResourceBundle resourceBundle; /** - * Convenience method which returns the unique identifier of this plugin. + * The constructor. */ - public static String getUniqueIdentifier() { - if (getDefault() == null) { - // If the default instance is not yet initialized, - // return a static identifier. This identifier must - // match the plugin id defined in plugin.xml - return PLUGIN_ID; + public PHPDebugCorePlugin() { + super(); + plugin = this; + try { + resourceBundle = + ResourceBundle.getBundle( + "net.sourceforge.phpdt.internal.debug.core.debugresources"); //$NON-NLS-1$ + } catch (MissingResourceException x) { + resourceBundle = null; } - return getDefault().getDescriptor().getUniqueIdentifier(); + } + + public java.util.ResourceBundle getResourceBundle() { + return resourceBundle; + } + + private IWorkbenchPage internalGetActivePage() { + return getWorkbench().getActiveWorkbenchWindow().getActivePage(); } /** * @see Plugin#shutdown() */ - public void shutdown() throws CoreException { +/* public void shutdown() throws CoreException { plugin = null; super.shutdown(); } +*/ + /** + * This method is called upon plug-in activation + */ + public void start(BundleContext context) throws Exception { + super.start(context); + } + + /** + * This method is called when the plug-in is stopped + */ + public void stop(BundleContext context) throws Exception { + plugin=null; + super.stop(context); + } }