com.feilong.lib.ezmorph.array.AbstractArrayMorpher Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of feilong Show documentation
Show all versions of feilong Show documentation
feilong is a suite of core and expanded libraries that include utility classes, http, excel,cvs, io classes, and much much more.
/*
* Copyright (C) 2008 feilong
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.feilong.lib.ezmorph.array;
import java.lang.reflect.Array;
import com.feilong.lib.ezmorph.ObjectMorpher;
/**
* Base class for array Morphers.
*
* @author Andres Almiray
*/
public abstract class AbstractArrayMorpher implements ObjectMorpher{
/** The use default. */
private boolean useDefault = false;
//---------------------------------------------------------------
/**
* Instantiates a new abstract array morpher.
*/
public AbstractArrayMorpher(){
}
/**
* Instantiates a new abstract array morpher.
*
* @param useDefault
* if morph() should return a default value if the value to
* be morphed is null
*/
public AbstractArrayMorpher(boolean useDefault){
this.useDefault = useDefault;
}
/**
* Returns if this morpher will use a default value.
*
* @return true, if is use default
*/
public boolean isUseDefault(){
return useDefault;
}
/**
* Sets if this morpher will use a default value.
*
* @param useDefault
* the new use default
*/
public void setUseDefault(boolean useDefault){
this.useDefault = useDefault;
}
//---------------------------------------------------------------
/**
* Supports.
*
* @param clazz
* the clazz
* @return true, if successful
*/
@Override
public boolean supports(Class> clazz){
return clazz.isArray();
}
/**
* Creates an array representing the dimensions for comversion.
*
* @param length
* the length
* @param initial
* the initial
* @return the int[]
*/
protected static int[] createDimensions(int length,int initial){
Object dims = Array.newInstance(int.class, length);
Array.set(dims, 0, initial);
return (int[]) dims;
}
//---------------------------------------------------------------
/**
* Returns the number of dimensions in an array class.
*
* @param arrayClass
* the array class
* @return the dimensions
*/
protected int getDimensions(Class> arrayClass){
if (arrayClass == null || !arrayClass.isArray()){
return 0;
}
return 1 + getDimensions(arrayClass.getComponentType());
}
}