blob: 34876f8435ca27a961cd7795b73877bcddc493ed [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2000, 2007 IBM Corporation and others.
* 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:
* IBM Corporation - initial API and implementation
*******************************************************************************/
package org.eclipse.ui.internal.misc;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import org.eclipse.core.runtime.Assert;
import org.eclipse.core.runtime.CoreException;
import org.eclipse.core.runtime.IStatus;
import org.eclipse.core.runtime.MultiStatus;
import org.eclipse.core.runtime.Status;
import org.eclipse.swt.widgets.Shell;
import org.eclipse.ui.internal.WorkbenchMessages;
import org.eclipse.ui.internal.WorkbenchPlugin;
import org.eclipse.ui.statushandlers.StatusManager;
/**
* Utility class to create status objects.
*
* @private - This class is an internal implementation class and should
* not be referenced or subclassed outside of the workbench
*/
public class StatusUtil {
/**
* Answer a flat collection of the passed status and its recursive children
*/
protected static List flatten(IStatus aStatus) {
List result = new ArrayList();
if (aStatus.isMultiStatus()) {
IStatus[] children = aStatus.getChildren();
for (int i = 0; i < children.length; i++) {
IStatus currentChild = children[i];
if (currentChild.isMultiStatus()) {
Iterator childStatiiEnum = flatten(currentChild).iterator();
while (childStatiiEnum.hasNext()) {
result.add(childStatiiEnum.next());
}
} else {
result.add(currentChild);
}
}
} else {
result.add(aStatus);
}
return result;
}
/**
* This method must not be called outside the workbench.
*
* Utility method for creating status.
*/
protected static IStatus newStatus(IStatus[] stati, String message,
Throwable exception) {
Assert.isTrue(message != null);
Assert.isTrue(message.trim().length() != 0);
return new MultiStatus(WorkbenchPlugin.PI_WORKBENCH, IStatus.ERROR,
stati, message, exception);
}
public static IStatus newStatus(String pluginId, Throwable exception) {
return newStatus(pluginId, getLocalizedMessage(exception), exception);
}
/**
* Returns a localized message describing the given exception. If the given exception does not
* have a localized message, this returns the string "An error occurred".
*
* @param exception
* @return
*/
public static String getLocalizedMessage(Throwable exception) {
String message = exception.getLocalizedMessage();
if (message != null) {
return message;
}
// Workaround for the fact that CoreException does not implement a getLocalizedMessage() method.
// Remove this branch when and if CoreException implements getLocalizedMessage()
if (exception instanceof CoreException) {
CoreException ce = (CoreException)exception;
return ce.getStatus().getMessage();
}
return WorkbenchMessages.StatusUtil_errorOccurred;
}
/**
* Creates a new Status based on the original status, but with a different message
*
* @param originalStatus
* @param newMessage
* @return
*/
public static IStatus newStatus(IStatus originalStatus, String newMessage) {
return new Status(originalStatus.getSeverity(),
originalStatus.getPlugin(), originalStatus.getCode(), newMessage, originalStatus.getException());
}
public static IStatus newStatus(String pluginId, String message, Throwable exception) {
return new Status(IStatus.ERROR, pluginId, IStatus.OK,
message, getCause(exception));
}
public static Throwable getCause(Throwable exception) {
// Figure out which exception should actually be logged -- if the given exception is
// a wrapper, unwrap it
Throwable cause = null;
if (exception != null) {
if (exception instanceof CoreException) {
// Workaround: CoreException contains a cause, but does not actually implement getCause().
// If we get a CoreException, we need to manually unpack the cause. Otherwise, use
// the general-purpose mechanism. Remove this branch if CoreException ever implements
// a correct getCause() method.
CoreException ce = (CoreException)exception;
cause = ce.getStatus().getException();
} else {
// use reflect instead of a direct call to getCause(), to allow compilation against JCL Foundation (bug 80053)
try {
Method causeMethod = exception.getClass().getMethod("getCause", new Class[0]); //$NON-NLS-1$
Object o = causeMethod.invoke(exception, new Object[0]);
if (o instanceof Throwable) {
cause = (Throwable) o;
}
}
catch (NoSuchMethodException e) {
// ignore
} catch (IllegalArgumentException e) {
// ignore
} catch (IllegalAccessException e) {
// ignore
} catch (InvocationTargetException e) {
// ignore
}
}
if (cause == null) {
cause = exception;
}
}
return cause;
}
/**
* This method must not be called outside the workbench.
*
* Utility method for creating status.
*/
public static IStatus newStatus(int severity, String message,
Throwable exception) {
String statusMessage = message;
if (message == null || message.trim().length() == 0) {
if (exception.getMessage() == null) {
statusMessage = exception.toString();
} else {
statusMessage = exception.getMessage();
}
}
return new Status(severity, WorkbenchPlugin.PI_WORKBENCH, severity,
statusMessage, getCause(exception));
}
/**
* This method must not be called outside the workbench.
*
* Utility method for creating status.
*/
public static IStatus newStatus(List children, String message,
Throwable exception) {
List flatStatusCollection = new ArrayList();
Iterator iter = children.iterator();
while (iter.hasNext()) {
IStatus currentStatus = (IStatus) iter.next();
Iterator childrenIter = flatten(currentStatus).iterator();
while (childrenIter.hasNext()) {
flatStatusCollection.add(childrenIter.next());
}
}
IStatus[] stati = new IStatus[flatStatusCollection.size()];
flatStatusCollection.toArray(stati);
return newStatus(stati, message, exception);
}
/**
* This method must not be called outside the workbench.
*
* Utility method for handling status.
*/
public static void handleStatus(IStatus status, int hint, Shell shell) {
StatusManager.getManager().handle(status, hint);
}
/**
* This method must not be called outside the workbench.
*
* Utility method for handling status.
*/
public static void handleStatus(Throwable e, int hint) {
StatusManager.getManager().handle(
newStatus(WorkbenchPlugin.PI_WORKBENCH, e), hint);
}
/**
* This method must not be called outside the workbench.
*
* Utility method for handling status.
*/
public static void handleStatus(String message, Throwable e, int hint) {
StatusManager.getManager().handle(
newStatus(WorkbenchPlugin.PI_WORKBENCH, message, e), hint);
}
/**
* This method must not be called outside the workbench.
*
* Utility method for handling status.
*/
public static void handleStatus(String message, Throwable e, int hint,
Shell shell) {
StatusManager.getManager().handle(
newStatus(WorkbenchPlugin.PI_WORKBENCH, message, e), hint);
}
/**
* This method must not be called outside the workbench.
*
* Utility method for handling status.
*/
public static void handleStatus(IStatus status, String message, int hint) {
StatusManager.getManager().handle(newStatus(status, message), hint);
}
/**
* This method must not be called outside the workbench.
*
* Utility method for handling status.
*/
public static void handleStatus(IStatus status, String message, int hint,
Shell shell) {
StatusManager.getManager().handle(newStatus(status, message), hint);
}
/**
* This method must not be called outside the workbench.
*
* Utility method for handling status.
*/
public static void handleStatus(String message, int hint) {
handleStatus(message, null, hint);
}
/**
* This method must not be called outside the workbench.
*
* Utility method for handling status.
*/
public static void handleStatus(String message, int hint, Shell shell) {
handleStatus(message, null, hint);
}
}