com.jidesoft.converter.EnumConverter Maven / Gradle / Ivy
/*
* @(#)IntegerEnumConverter.java 4/1/2005
*
* Copyright 2002 - 2005 JIDE Software Inc. All rights reserved.
*/
package com.jidesoft.converter;
import com.jidesoft.utils.ReflectionUtils;
import java.lang.reflect.Array;
/**
* A typical way to define a constant is to use int as the value type. For example, in SwingConstants, the following
* values are defined.
*
* public static final int CENTER = 0;
* public static final int TOP = 1;
* public static final int LEFT = 2;
* public static final int BOTTOM = 3;
* public static final int RIGHT = 4;
*
* Before JDK1.5, there is no enum type, so this is one way to define enumeration. When you use it, you just need to
* define a int field say _locaton and the valid value for _location is one of the values above. If you want to display
* it in UI and allow user to specify the value of _location, problem comes. You don't want to use 0, 1, 2, 3, 4 as the
* value doesn't mean anything from user point of view. You want user to be able to use meaningful names such as
* "Center", "Top", "Left", "Bottom", "Right". Obviously you need a converter here to convert from integer in an enum to
* string, such as converting from 0 to "Center" and vice verse. That's what EnumConverter for.
*
* Combining with EnumCellConverter, EnumCellEditor, you can easily use combobox to choose value for _location like the
* example above using meaningful strings.
*/
public class EnumConverter implements ObjectConverter {
private String _name;
private Object _default;
private Class> _type;
private Object[] _objects;
private String[] _strings;
private boolean _strict = true;
/**
* The constructor to convert a enum type class.
*
* Reflection is used to invoke Enum#getValues(). Please consider make the enum class protected or public if you
* want to release your version after obfuscated. Otherwise, this constructor may not be able to find correct class
* method to work.
*
* @param enumType the enum type
* @since 3.4.0
*/
public EnumConverter(Class extends Enum> enumType) {
if (enumType == null || !enumType.isEnum()) {
throw new IllegalArgumentException("To use this constructor, the type has to be an enum type.");
}
String name = enumType.getName();
if (name == null || name.trim().length() == 0) {
throw new IllegalArgumentException("Empty enum type name.");
}
int index = name.lastIndexOf("$");
if (index >= 0) {
_name = name.substring(index + 1);
}
else {
_name = name;
}
_type = enumType;
try {
Object values = ReflectionUtils.callStatic(enumType, "values", null, null);
if (!values.getClass().isArray()) {
throw new IllegalArgumentException("Illegal enum type.");
}
int length = Array.getLength(values);
_objects = new Object[length];
_strings = new String[length];
for (int i = 0; i < length; i++) {
_objects[i] = Array.get(values, i);
_strings[i] = "" + _objects[i];
}
}
catch (Exception e) {
throw new IllegalArgumentException("Illegal enum type.");
}
}
public EnumConverter(String name, Object[] values, String[] strings) {
this(name, values[0] == null ? (values.length > 1 ? values[1].getClass() : Object.class) : values[0].getClass(), values, strings);
}
public EnumConverter(String name, Class> type, Object[] values, String[] strings) {
this(name, type, values, strings, null);
}
/**
* Creates an EnumConverter.
*
* @param name the name of the converter. The name is used to create ConverterContext and later on the
* EditorContext.
* @param type the type of the element in objects
array.
* @param objects the objects
array. All elements in the objects
array should have
* the same type.
* @param strings the strings
array. It contains the meaningful names for the elements in
* objects
array. They should one to one match with each other. The length of
* strings
array should be the same as that of objects
array.
* Otherwise IllegalArgumentExceptio will be thrown.
* @param defaultValue the default value
*/
public EnumConverter(String name, Class> type, Object[] objects, String[] strings, Object defaultValue) {
if (name == null || name.trim().length() == 0) {
throw new IllegalArgumentException("The \"name\" parameter cannot be null or empty. Please use a unique string to represent the name of the converter.");
}
_name = name;
if (objects == null) {
throw new IllegalArgumentException("The \"objects\" parameter cannot be null.");
}
if (strings == null) {
throw new IllegalArgumentException("The \"strings\" parameter cannot be null.");
}
if (strings.length != objects.length) {
throw new IllegalArgumentException("The \"objects\" and \"strings\" parameters should have the same length.");
}
_type = type;
_objects = objects;
_strings = strings;
_default = defaultValue;
}
transient private ConverterContext _context;
/**
* Gets the converter context of this converter. The name of the context is the name of the converter where you pass
* in to EnumConverter's constructor.
*
* @return the converter context of this converter.
*/
public ConverterContext getContext() {
if (_context == null) {
_context = new ConverterContext(_name);
}
return _context;
}
/**
* Converts the object to string. It will find the object from the objects
array and find the matching
* string from strings
array. If {@link #isStrict()} is true, null will be returned if nothing matches.
* Otherwise, it will return the string value of the object using toString.
*
* @param object the object to be converted.
* @param context the converter context.
* @return the string for the object.
*/
public String toString(Object object, ConverterContext context) {
for (int i = 0; i < _objects.length; i++) {
if ((_objects[i] == null && object == null) || (_objects[i] != null && _objects[i].equals(object))) {
if (i < _strings.length) {
return _strings[i];
}
}
}
return isStrict() ? null : "" + object;
}
public boolean supportToString(Object object, ConverterContext context) {
return true;
}
/**
* Converts the string to the object. It will find the string from the strings
array and find the
* matching object from objects
array. If {@link #isStrict()} is true, the default value will be
* returned if nothing matches. Otherwise, it will return the string itself that is passed in.
*
* @param string the string to be converted
* @param context the converter context.
* @return the object of the string.
*/
public Object fromString(String string, ConverterContext context) {
for (int i = 0; i < _strings.length; i++) {
if (_strings[i].equals(string)) {
if (i < _objects.length) {
return _objects[i];
}
}
}
return isStrict() ? _default : string;
}
public boolean supportFromString(String string, ConverterContext context) {
return true;
}
/**
* Gets the name of the converter.
*
* @return the name of the converter.
*/
public String getName() {
return _name;
}
/**
* Gets the type of the converter.
*
* @return the type of the converter.
*/
public Class> getType() {
return _type;
}
/**
* Gets the default value of the converter if it failed to find the matching object for a particular string.
*
* @return the default value.
*/
public Object getDefault() {
return _default;
}
/**
* Gets the objects
array.
*
* @return the objects
array.
*/
public Object[] getObjects() {
return _objects;
}
/**
* Gets a partial object array from the complete enum objects
array.
*
* @param indices of the partial enum values.
* @return the objects
array.
*/
public Object[] getObjects(int[] indices) {
Object[] objects = new Object[indices.length];
for (int i = 0; i < objects.length; i++) {
objects[i] = _objects[indices[i]];
}
return objects;
}
/**
* Gets the strings
array.
*
* @return the strings
array.
*/
public String[] getStrings() {
return _strings;
}
/**
* Converts an object array to a String array using ObjectConverterManager.
*
* This method can be used, for example, for Enum type, to provide a default string representation of the enum
* values.
*
* ObjectConverter converter = new EnumConverter("Rank", Rank.values(),
* EnumConverter.toStrings(Rank.values()));
*
* Of course, you can still define your own string array for the enum values if the default one doesn't work well.
*
* @param values the object array.
* @return the string array.
*/
public static String[] toStrings(Object[] values) {
return toStrings(values, null);
}
/**
* Converts an object array to a String array using ObjectConverterManager.
*
* @param values the object array.
* @param converterContext the converter context used when calling ObjectConverterManager.toString.
* @return the string array.
*/
public static String[] toStrings(Object[] values, ConverterContext converterContext) {
String[] s = new String[values.length];
for (int i = 0; i < s.length; i++) {
s[i] = ObjectConverterManager.toString(values[i], values[i].getClass(), converterContext);
}
return s;
}
/**
* Checks if the EnumConverter is strict about the value that passed to fromString and toString. If true, fromString
* will convert any String that doesn't match to the default value, toString will return null if the value doesn't
* match. If false, the string itself will be return from fromString. Default is true.
*
* @return true or false.
*/
public boolean isStrict() {
return _strict;
}
/**
* Sets if the EnumConverter is strict about the value that passed to fromString and toString. Default is true.
*
* @param strict true or false.
*/
public void setStrict(boolean strict) {
_strict = strict;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy