/*******************************************************************************
* Copyright (c) 2010-present Sonatype, Inc.
* 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:
* Stuart McCulloch (Sonatype, Inc.) - initial API and implementation
*******************************************************************************/
package org.eclipse.sisu.plexus;
import java.util.Arrays;
import java.util.List;
import org.codehaus.plexus.component.annotations.Requirement;
/**
* Constants and utility methods for dealing with Plexus hints.
*/
public final class Hints
{
// ----------------------------------------------------------------------
// Constants
// ----------------------------------------------------------------------
public static final String[] NO_HINTS = {};
public static final String DEFAULT_HINT = "default";
private static final List<String> NO_HINTS_LIST = Arrays.asList( NO_HINTS );
// ----------------------------------------------------------------------
// Constructors
// ----------------------------------------------------------------------
private Hints()
{
// static utility class, not allowed to create instances
}
// ----------------------------------------------------------------------
// Utility methods
// ----------------------------------------------------------------------
/**
* Returns the canonical form of the given Plexus hint.
*
* @param hint The Plexus hint
* @return Canonical hint denoting the same component as the given hint
*/
public static String canonicalHint( final String hint )
{
// interning hints is a good idea because there's a lot of duplication
return null == hint || hint.length() == 0 ? DEFAULT_HINT : hint.intern();
}
/**
* Determines if the given Plexus hint denotes the default component.
*
* @param hint The Plexus hint
* @return {@code true} if the given hint denotes the default component
*/
public static boolean isDefaultHint( final String hint )
{
return DEFAULT_HINT.equals( hint ) || null == hint || hint.length() == 0;
}
/**
* Returns the canonical form of the given Plexus hints.
*
* @param hints The Plexus hints
* @return Array of canonical hints
*/
public static String[] canonicalHints( final String... hints )
{
final int length = hints.length;
if ( length == 0 || length == 1 && hints[0].length() == 0 )
{
return NO_HINTS;
}
for ( int i = 0; i < length; i++ )
{
hints[i] = canonicalHint( hints[i] );
}
return hints;
}
/**
* Returns the canonical form of the given Plexus hints.
*
* @param hints The Plexus hints
* @return List of canonical hints
*/
public static List<String> canonicalHints( final List<String> hints )
{
final int length = hints.size();
if ( length == 0 || length == 1 && hints.get( 0 ).length() == 0 )
{
return NO_HINTS_LIST;
}
for ( int i = 0; i < length; i++ )
{
hints.set( i, canonicalHint( hints.get( i ) ) );
}
return hints;
}
/**
* Returns the Plexus hints contained in the given @{@link Requirement}.
*
* @param requirement The Plexus requirement
* @return Array of canonical hints
*/
public static String[] canonicalHints( final Requirement requirement )
{
final String[] hints = requirement.hints();
if ( hints.length > 0 )
{
return canonicalHints( hints );
}
final String hint = requirement.hint();
if ( hint.length() > 0 )
{
return canonicalHints( hint );
}
return NO_HINTS;
}
}