/******************************************************************************* * Copyright (c) 2005 Anyware Technologies * 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: * David Sciamma (Anyware Technologies) - initial API and implementation *******************************************************************************/ package org.eclipse.papyrus.infra.export.internal; import java.lang.reflect.InvocationTargetException; import org.eclipse.core.runtime.CoreException; import org.eclipse.core.runtime.IStatus; import org.eclipse.core.runtime.Status; import org.eclipse.jface.dialogs.MessageDialog; import org.eclipse.swt.widgets.Display; import org.eclipse.swt.widgets.Shell; import org.eclipse.ui.IWorkbench; import org.eclipse.ui.IWorkbenchPage; import org.eclipse.ui.IWorkbenchWindow; 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.papyrus.infra.export"; //$NON-NLS-1$ // The shared instance private static Activator plugin; /** * The constructor */ public Activator() { plugin = this; } /** * @see org.eclipse.ui.plugin.AbstractUIPlugin#start(org.osgi.framework.BundleContext) */ public void start(BundleContext context) throws Exception { super.start(context); } /** * @see org.eclipse.ui.plugin.AbstractUIPlugin#stop(org.osgi.framework.BundleContext) */ 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; } /** * Log an IStatus * * @param status * Status of an operation */ public static void log(IStatus status) { getDefault().getLog().log(status); } /** * Log a message with given level into the Eclipse log file * * @param message * the message to log * @param level * the message priority */ public static void log(String message, int level) { IStatus status = null; status = new Status(level, PLUGIN_ID, IStatus.OK, message, null); log(status); } /** * Log a message with given level into the Eclipse log file * * @param message * the message to log * @param level * the message priority */ public static void log(String message, int level, Throwable t) { IStatus status = null; status = new Status(level, PLUGIN_ID, IStatus.OK, message, t); log(status); } /** * Log an exception into the Eclipse log file * * @param e * the exception to log */ public static void log(Throwable e) { Throwable loggedThrowable = e; if(loggedThrowable instanceof InvocationTargetException) { loggedThrowable = ((InvocationTargetException)loggedThrowable).getTargetException(); } IStatus status = null; if(loggedThrowable instanceof CoreException) { status = ((CoreException)loggedThrowable).getStatus(); } else { status = new Status(IStatus.ERROR, PLUGIN_ID, IStatus.OK, "Error", loggedThrowable); } log(status); } /** * Returns the active workbench shell * * @return the active workbench shell */ public static Shell getActiveWorkbenchShell() { IWorkbenchWindow workBenchWindow = getActiveWorkbenchWindow(); if(workBenchWindow == null) { return null; } return workBenchWindow.getShell(); } /** * Returns the active workbench page or <code>null</code> if none. * * @return the active workbench page */ public static IWorkbenchPage getActivePage() { IWorkbenchWindow window = getActiveWorkbenchWindow(); if(window != null) { return window.getActivePage(); } return null; } /** * Returns the active workbench window * * @return the active workbench window */ public static IWorkbenchWindow getActiveWorkbenchWindow() { if(getDefault() == null) { return null; } IWorkbench workBench = getDefault().getWorkbench(); if(workBench == null) { return null; } return workBench.getActiveWorkbenchWindow(); } /** * Display a dialog box with the specified level * * @param title * title dialog box * @param message * message displayed * @param level * message level */ public static void displayDialog(final String title, final String message, final int level) { if(level == IStatus.INFO) { Display.getDefault().asyncExec(new Runnable() { public void run() { MessageDialog.openInformation(getActiveWorkbenchShell(), (title == null) ? "Information" : title, (message == null) ? "" : message); } }); } else if(level == IStatus.WARNING) { Display.getDefault().asyncExec(new Runnable() { public void run() { MessageDialog.openWarning(getActiveWorkbenchShell(), (title == null) ? "Warning" : title, (message == null) ? "" : message); } }); } else if(level == IStatus.ERROR) { Display.getDefault().asyncExec(new Runnable() { public void run() { MessageDialog.openError(getActiveWorkbenchShell(), (title == null) ? "Error" : title, (message == null) ? "" : message); } }); } } }