/*
* AspectName.java
* Copyright 2008 (C) James Dempsey
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*
* Created on 20/08/2008 20:04:21
*
* $Id: $
*/
package pcgen.cdom.enumeration;
import java.util.Collection;
import java.util.Collections;
import pcgen.base.enumeration.TypeSafeConstant;
import pcgen.base.util.CaseInsensitiveMap;
/**
* This Class is a Type Safe Constant. It is designed to allow Ability Aspect
* names in a type-safe fashion, so that they can be quickly compared and use
* less memory when identical Aspect names exist in two CDOMObjects.
*
*
* @author James Dempsey <jdempsey@users.sourceforge.net>
*/
public final class AspectName implements TypeSafeConstant,
Comparable<AspectName>
{
/** This Map contains the mappings from Strings to the Type Safe Constant. */
private static CaseInsensitiveMap<AspectName> nameMap;
/** This is used to provide a unique ordinal to each constant in this class. */
private static int ordinalCount = 0;
/** The name of this Constant. */
private final String fieldName;
/** The ordinal of this Constant. */
private final transient int ordinal;
/**
* Instantiates a new ability aspect.
*
* @param name
* the name
*/
private AspectName(String name)
{
if (name == null)
{
throw new IllegalArgumentException(
"Name for AspectName cannot be null");
}
ordinal = ordinalCount++;
fieldName = name;
}
/**
* Converts this Constant to a String (returns the name of this Constant).
*
* @return The string representation (name) of this Constant
*/
@Override
public String toString()
{
return fieldName;
}
/**
* Gets the ordinal of this Constant.
*
* @return the ordinal
*/
@Override
public int getOrdinal()
{
return ordinal;
}
/**
* Returns the constant for the given String (the search for the constant is
* case insensitive). If the constant does not already exist, a new Constant
* is created with the given String as the name of the Constant.
*
* @param name
* The name of the constant to be returned
*
* @return The Constant for the given name
*/
public static AspectName getConstant(String name)
{
initializeNameMap();
AspectName aspect = nameMap.get(name);
if (aspect == null)
{
aspect = new AspectName(name);
nameMap.put(name, aspect);
}
return aspect;
}
/**
* Thread safe construction of typeMap.
*/
private static synchronized void initializeNameMap()
{
if (nameMap == null)
{
nameMap = new CaseInsensitiveMap<>();
}
}
/**
* Returns the constant for the given String (the search for the constant is
* case insensitive). If the constant does not already exist, an
* IllegalArgumentException is thrown.
*
* @param name
* The name of the constant to be returned
*
* @return The Constant for the given name
*
* @throws IllegalArgumentException
* if the given String is not a previously defined RaceSubType
*/
public static AspectName valueOf(String name)
{
initializeNameMap();
AspectName aspect = nameMap.get(name);
if (aspect == null)
{
throw new IllegalArgumentException(name
+ " is not a previously defined AspectName");
}
return aspect;
}
/**
* Returns a Collection of all of the Constants in this Class.
*
* This collection maintains a reference to the Constants in this Class, so
* if a new Constant is created, the Collection returned by this method will
* be modified. (Beware of ConcurrentModificationExceptions)
*
* @return a Collection of all of the Constants in this Class.
*/
public static Collection<AspectName> getAllConstants()
{
if (nameMap == null)
{
return Collections.emptyList();
}
return Collections.unmodifiableCollection(nameMap.values());
}
/**
* Clears all of the Constants in this Class (forgetting the mapping from
* the String to the Constant).
*/
/*
* CONSIDER Need to consider the ramifications of this on TypeSafeMap, since
* this does not (and really cannot) reset the ordinal count... Does this
* method need to be renamed, such that it is clearConstantMap? - Tom
* Parker, Feb 28, 2007
*/
public static void clearConstants()
{
if (nameMap != null)
{
nameMap.clear();
}
}
/*
* (non-Javadoc)
*
* @see java.lang.Comparable#compareTo(java.lang.Object)
*/
@Override
public int compareTo(AspectName aspectName)
{
return fieldName.compareTo(aspectName.fieldName);
}
@Override
public boolean equals(Object obj)
{
return obj == this || obj instanceof AspectName
&& ((AspectName) obj).ordinal == ordinal;
}
@Override
public int hashCode()
{
return ordinal;
}
}