/*
* $Id$
*
* SARL is an general-purpose agent programming language.
* More details on http://www.sarl.io
*
* Copyright (C) 2014-2017 the original authors or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package io.janusproject.eclipse;
import com.google.common.base.Strings;
import org.eclipse.core.runtime.IStatus;
import org.eclipse.core.runtime.Status;
import org.eclipse.ui.plugin.AbstractUIPlugin;
/**
* The eclipse plugin providing the JANUS platform as default SRE.
* @author $Author: ngaud$
* @version $FullVersion$
* @mavengroupid $GroupId$
* @mavenartifactid $ArtifactId$
*
*/
public class JanusEclipsePlugin extends AbstractUIPlugin {
/** Identifier of the plugin.
*/
public static final String PLUGIN_ID = "io.janusproject.plugin"; //$NON-NLS-1$
private static JanusEclipsePlugin instance;
/** Construct an Eclipse plugin for SARL.
*/
public JanusEclipsePlugin() {
setDefault(this);
}
/** Set the default instance of the plugin.
*
* @param defaultInstance - the default plugin instance.
*/
public static void setDefault(JanusEclipsePlugin defaultInstance) {
instance = defaultInstance;
}
/** Replies the instance of the plugin.
*
* @return the default plugin instance.
*/
public static JanusEclipsePlugin getDefault() {
return instance;
}
/** Create a status.
*
* @param severity - the severity level, see {@link IStatus}.
* @param message - the message associated to the status.
* @param cause - the cause of the problem.
* @return the status.
*/
@SuppressWarnings("static-method")
public IStatus createStatus(int severity, String message, Throwable cause) {
return new Status(severity, PLUGIN_ID, message, cause);
}
/** Create a status.
*
* @param severity - the severity level, see {@link IStatus}.
* @param code - the code of the error.
* @param message - the message associated to the status.
* @param cause - the cause of the problem.
* @return the status.
*/
@SuppressWarnings("static-method")
public IStatus createStatus(int severity, int code, String message, Throwable cause) {
return new Status(severity, PLUGIN_ID, code, message, cause);
}
/** Create a status.
*
* @param severity - the severity level, see {@link IStatus}.
* @param cause - the cause of the problem.
* @return the status.
*/
public IStatus createStatus(int severity, Throwable cause) {
String message = cause.getLocalizedMessage();
if (Strings.isNullOrEmpty(message)) {
message = cause.getMessage();
}
if (Strings.isNullOrEmpty(message)) {
message = cause.getClass().getSimpleName();
}
return createStatus(severity, message, cause);
}
/** Create a status.
*
* @param severity - the severity level, see {@link IStatus}.
* @param code - the code of the error.
* @param cause - the cause of the problem.
* @return the status.
*/
public IStatus createStatus(int severity, int code, Throwable cause) {
String message = cause.getLocalizedMessage();
if (Strings.isNullOrEmpty(message)) {
message = cause.getMessage();
}
if (Strings.isNullOrEmpty(message)) {
message = cause.getClass().getSimpleName();
}
return createStatus(severity, code, message, cause);
}
/** Create a status.
*
* @param severity - the severity level, see {@link IStatus}.
* @param message - the message associated to the status.
* @return the status.
*/
@SuppressWarnings("static-method")
public IStatus createStatus(int severity, String message) {
return new Status(severity, PLUGIN_ID, message);
}
/** Create a status.
*
* @param severity - the severity level, see {@link IStatus}.
* @param code - the code of the error.
* @param message - the message associated to the status.
* @return the status.
*/
@SuppressWarnings("static-method")
public IStatus createStatus(int severity, int code, String message) {
return new Status(severity, PLUGIN_ID, code, message, null);
}
/** Create a ok status.
*
* @return the status.
*/
@SuppressWarnings("static-method")
public IStatus createOkStatus() {
return Status.OK_STATUS;
}
}