blob: d671d1079f93ca05d530cd5c19e2eb843f342978 [file] [log] [blame]
package org.eclipse.core.runtime;
/*
* (c) Copyright IBM Corp. 2000, 2001.
* All Rights Reserved.
*/
import org.eclipse.core.internal.runtime.Assert;
/**
* A concrete multi-status implementation,
* suitable either for instantiating or subclassing.
*/
public class MultiStatus extends Status {
/** List of child statuses.
*/
private IStatus[] children;
/**
* Creates and returns a new multi-status object with the given children.
*
* @param pluginId the unique identifier of the relevant plug-in
* @param code the plug-in-specific status code
* @param children the list of children status objects
* @param message a human-readable message, localized to the
* current locale
* @param exception a low-level exception, or <code>null</code> if not
* applicable
*/
public MultiStatus(String pluginId, int code, IStatus[] children, String message, Throwable exception) {
this(pluginId, code, message, exception);
Assert.isLegal(children != null);
for (int i = 0; i < children.length; i++) {
Assert.isLegal(children[i] != null);
add(children[i]);
}
}
/**
* Creates and returns a new multi-status object with no children.
*
* @param pluginId the unique identifier of the relevant plug-in
* @param code the plug-in-specific status code
* @param message a human-readable message, localized to the
* current locale
* @param exception a low-level exception, or <code>null</code> if not
* applicable
*/
public MultiStatus(String pluginId, int code, String message, Throwable exception) {
super(OK, pluginId, code, message, exception);
children = new IStatus[0];
}
/**
* Adds the given status to this multi-status.
*
* @param status the new child status
*/
public void add(IStatus status) {
Assert.isLegal(status != null);
IStatus[] result = new IStatus[children.length + 1];
System.arraycopy(children, 0, result, 0, children.length);
result[result.length - 1] = status;
children = result;
int newSev = status.getSeverity();
if (newSev > getSeverity()) {
setSeverity(newSev);
}
}
/**
* Adds all of the children of the given status to this multi-status.
* Does nothing if the given status has no children (which includes
* the case where it is not a multi-status).
*
* @param status the status whose children are to be added to this one
*/
public void addAll(IStatus status) {
Assert.isLegal(status != null);
IStatus[] statuses = status.getChildren();
for (int i = 0; i < statuses.length; i++) {
add(statuses[i]);
}
}
/* (Intentionally not javadoc'd)
* Implements the corresponding method on <code>IStatus</code>.
*/
public IStatus[] getChildren() {
return children;
}
/* (Intentionally not javadoc'd)
* Implements the corresponding method on <code>IStatus</code>.
*/
public boolean isMultiStatus() {
return true;
}
/**
* Merges the given status into this multi-status.
* Equivalent to <code>add(status)</code> if the
* given status is not a multi-status.
* Equivalent to <code>addAll(status)</code> if the
* given status is a multi-status.
*
* @param status the status to merge into this one
* @see #add
* @see #addAll
*/
public void merge(IStatus status) {
Assert.isLegal(status != null);
if (!status.isMultiStatus()) {
add(status);
} else {
addAll(status);
}
}
/**
* Returns a string representation of the status, suitable
* for debugging purposes only.
*/
public String toString() {
StringBuffer buf = new StringBuffer(super.toString());
buf.append(" children=[");
for (int i = 0; i < children.length; i++) {
if (i != 0) {
buf.append(" ");
}
buf.append(children[i].toString());
}
buf.append("]");
return buf.toString();
}
}