blob: d9a41c9b6cf07403497e14b4c9c8c1e1169f9ca1 [file] [log] [blame]
/******************************************************************************
* Copyright (c) 2008 Oracle
* 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:
* Konstantin Komissarchik - initial implementation and ongoing maintenance
******************************************************************************/
package org.eclipse.wst.common.project.facet.ui.internal;
import java.util.HashSet;
import java.util.Set;
import org.eclipse.core.runtime.IStatus;
import org.eclipse.core.runtime.Platform;
import org.eclipse.core.runtime.Status;
import org.eclipse.jface.resource.ImageDescriptor;
import org.eclipse.ui.plugin.AbstractUIPlugin;
/**
* @author <a href="mailto:konstantin.komissarchik@oracle.com">Konstantin Komissarchik</a>
*/
public final class FacetUiPlugin
extends AbstractUIPlugin
{
public static final String PLUGIN_ID
= "org.eclipse.wst.common.project.facet.ui"; //$NON-NLS-1$
private static final String TRACING_PROP_PAGE_ACTION_CONFIG_VALIDATION
= PLUGIN_ID + "/propPage/actionConfigValidation"; //$NON-NLS-1$
private static FacetUiPlugin plugin;
private static final Set<String> messagesLogged = new HashSet<String>();
public FacetUiPlugin()
{
super();
plugin = this;
}
public static FacetUiPlugin getInstance()
{
return plugin;
}
public static ImageDescriptor getImageDescriptor( final String path )
{
return imageDescriptorFromPlugin( PLUGIN_ID, path );
}
public static void log( final Exception e )
{
final String msg = e.getMessage() + ""; //$NON-NLS-1$
log( new Status( IStatus.ERROR, PLUGIN_ID, IStatus.OK, msg, e ) );
}
public static void log( final IStatus status )
{
getInstance().getLog().log( status );
}
public static void log( final String msg )
{
log( new Status( IStatus.ERROR, PLUGIN_ID, IStatus.OK, msg, null ) );
}
public static void logError( final String msg )
{
logError( msg, false );
}
public static void logError( final String msg,
final boolean suppressDuplicates )
{
if( suppressDuplicates && messagesLogged.contains( msg ) )
{
return;
}
messagesLogged.add( msg );
log( new Status( IStatus.ERROR, PLUGIN_ID, IStatus.OK, msg, null ) );
}
public static void logWarning( final String msg )
{
logWarning( msg, false );
}
public static void logWarning( final String msg,
final boolean suppressDuplicates )
{
if( suppressDuplicates && messagesLogged.contains( msg ) )
{
return;
}
messagesLogged.add( msg );
log( new Status( IStatus.WARNING, PLUGIN_ID, IStatus.OK, msg, null ) );
}
public static IStatus createErrorStatus( final String msg,
final Exception e )
{
return new Status( IStatus.ERROR, FacetUiPlugin.PLUGIN_ID, 0, msg, e );
}
public static boolean isTracingPropPageActionConfigValidation()
{
return checkDebugOption( TRACING_PROP_PAGE_ACTION_CONFIG_VALIDATION );
}
private static boolean checkDebugOption( final String debugOption )
{
final String optionValue = Platform.getDebugOption( debugOption );
return optionValue == null
? false : Boolean.valueOf( optionValue ).equals( Boolean.TRUE );
}
}