blob: 977ad6c3c43653249b5f4f325a07c299b8fc0796 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2000, 2017 IBM Corporation and others.
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v. 2.0 which is available at
* http://www.eclipse.org/legal/epl-2.0.
*
* SPDX-License-Identifier: EPL-2.0
*
*******************************************************************************/
package org.eclipse.dltk.ui.dialogs;
import org.eclipse.core.runtime.Assert;
import org.eclipse.core.runtime.IStatus;
import org.eclipse.core.runtime.Status;
import org.eclipse.dltk.ui.DLTKUIPlugin;
/**
* A settable IStatus.
* Can be an error, warning, info or ok. For error, info and warning states,
* a message describes the problem.
*/
public class StatusInfo implements IStatus {
/**
* The static OK instance similar to the {@link Status#OK_STATUS}, but this
* instance returns <code>null</code> message.
*/
public static final IStatus OK_STATUS = new StatusInfo() {
@Override
public void setOK() {
throw new UnsupportedOperationException();
}
@Override
public void setError(String arg0) {
throw new UnsupportedOperationException();
}
@Override
public void setWarning(String arg0) {
throw new UnsupportedOperationException();
}
@Override
public void setInfo(String arg0) {
throw new UnsupportedOperationException();
}
};
private String fStatusMessage;
private int fSeverity;
/**
* Creates a status set to OK (no message)
*/
public StatusInfo() {
this(OK, null);
}
/**
* Creates a status .
* @param severity The status severity: ERROR, WARNING, INFO and OK.
* @param message The message of the status. Applies only for ERROR,
* WARNING and INFO.
*/
public StatusInfo(int severity, String message) {
fStatusMessage= message;
fSeverity= severity;
}
/**
* Returns if the status' severity is OK.
*/
@Override
public boolean isOK() {
return fSeverity == IStatus.OK;
}
/**
* Returns if the status' severity is WARNING.
*/
public boolean isWarning() {
return fSeverity == IStatus.WARNING;
}
/**
* Returns if the status' severity is INFO.
*/
public boolean isInfo() {
return fSeverity == IStatus.INFO;
}
/**
* Returns if the status' severity is ERROR.
*/
public boolean isError() {
return fSeverity == IStatus.ERROR;
}
/**
* @see IStatus#getMessage
*/
@Override
public String getMessage() {
return fStatusMessage;
}
/**
* Sets the status to ERROR.
* @param errorMessage The error message (can be empty, but not null)
*/
public void setError(String errorMessage) {
Assert.isNotNull(errorMessage);
fStatusMessage= errorMessage;
fSeverity= IStatus.ERROR;
}
/**
* Sets the status to WARNING.
* @param warningMessage The warning message (can be empty, but not null)
*/
public void setWarning(String warningMessage) {
Assert.isNotNull(warningMessage);
fStatusMessage= warningMessage;
fSeverity= IStatus.WARNING;
}
/**
* Sets the status to INFO.
* @param infoMessage The info message (can be empty, but not null)
*/
public void setInfo(String infoMessage) {
Assert.isNotNull(infoMessage);
fStatusMessage= infoMessage;
fSeverity= IStatus.INFO;
}
/**
* Sets the status to OK.
*/
public void setOK() {
fStatusMessage= null;
fSeverity= IStatus.OK;
}
@Override
public boolean matches(int severityMask) {
return (fSeverity & severityMask) != 0;
}
/**
* Returns always <code>false</code>.
* @see IStatus#isMultiStatus()
*/
@Override
public boolean isMultiStatus() {
return false;
}
@Override
public int getSeverity() {
return fSeverity;
}
@Override
public String getPlugin() {
return DLTKUIPlugin.PLUGIN_ID;
}
/**
* Returns always <code>null</code>.
* @see IStatus#getException()
*/
@Override
public Throwable getException() {
return null;
}
/**
* Returns always the error severity.
* @see IStatus#getCode()
*/
@Override
public int getCode() {
return fSeverity;
}
/**
* Returns always an empty array.
* @see IStatus#getChildren()
*/
@Override
public IStatus[] getChildren() {
return Status.OK_STATUS.getChildren();
}
/**
* Returns a string representation of the status, suitable
* for debugging purposes only.
*/
@Override
public String toString() {
StringBuffer buf = new StringBuffer();
buf.append("StatusInfo "); //$NON-NLS-1$
if (fSeverity == OK) {
buf.append("OK"); //$NON-NLS-1$
} else if (fSeverity == ERROR) {
buf.append("ERROR"); //$NON-NLS-1$
} else if (fSeverity == WARNING) {
buf.append("WARNING"); //$NON-NLS-1$
} else if (fSeverity == INFO) {
buf.append("INFO"); //$NON-NLS-1$
} else {
buf.append("severity="); //$NON-NLS-1$
buf.append(fSeverity);
}
buf.append(": "); //$NON-NLS-1$
buf.append(fStatusMessage);
return buf.toString();
}
}