| /******************************************************************************* |
| * Copyright (c) 2011-2017 EclipseSource Muenchen GmbH and others. |
| * |
| * All rights reserved. This program and the accompanying materials |
| * are made available under the terms of the Eclipse Public License 2.0 |
| * which accompanies this distribution, and is available at |
| * https://www.eclipse.org/legal/epl-2.0/ |
| * |
| * SPDX-License-Identifier: EPL-2.0 |
| * |
| * Contributors: |
| * johannes - initial API and implementation |
| ******************************************************************************/ |
| package org.eclipse.emf.ecp.ide.internal.migration; |
| |
| import org.eclipse.core.runtime.CoreException; |
| import org.eclipse.core.runtime.IStatus; |
| import org.eclipse.core.runtime.Plugin; |
| import org.eclipse.core.runtime.Status; |
| import org.osgi.framework.BundleContext; |
| |
| /** |
| * @author johannes |
| * |
| */ |
| public class Activator extends Plugin { |
| |
| /** |
| * The PlugIn ID. |
| */ |
| public static final String PLUGIN_ID = "org.eclipse.emf.ecp.ide.migration"; //$NON-NLS-1$ |
| |
| private static Activator instance; |
| |
| // BEGIN SUPRESS CATCH EXCEPTION |
| @Override |
| public void start(BundleContext bundleContext) throws Exception { |
| super.start(bundleContext); |
| instance = this; |
| } |
| |
| @Override |
| public void stop(BundleContext bundleContext) throws Exception { |
| instance = null; |
| super.stop(bundleContext); |
| } |
| |
| /** |
| * Logs messages. |
| * |
| * @param message the message |
| */ |
| public static void log(String message) { |
| instance.getLog().log(new Status(IStatus.INFO, PLUGIN_ID, message)); |
| } |
| |
| /** |
| * Logs {@link IStatus}. |
| * |
| * @param status the {@link IStatus} |
| */ |
| public static void log(IStatus status) { |
| instance.getLog().log(status); |
| } |
| |
| /** |
| * Logs {@link Throwable}. |
| * |
| * @param t the {@link Throwable} |
| * @return the message of the created status |
| */ |
| public static String log(Throwable t) { |
| final IStatus status = getStatus(t); |
| log(status); |
| return status.getMessage(); |
| } |
| |
| /** |
| * Gets a {@link IStatus} for a throwable. |
| * |
| * @param t the {@link Throwable} |
| * @return the created {@link IStatus} |
| */ |
| public static IStatus getStatus(Throwable t) { |
| if (t instanceof CoreException) { |
| final CoreException coreException = (CoreException) t; |
| return coreException.getStatus(); |
| } |
| |
| String msg = t.getLocalizedMessage(); |
| if (msg == null || msg.length() == 0) { |
| msg = t.getClass().getName(); |
| } |
| |
| return new Status(IStatus.ERROR, PLUGIN_ID, msg, t); |
| } |
| |
| } |