All Downloads are FREE. Search and download functionalities are using the official Maven repository.

gu.sql2java.IBeanConverter Maven / Gradle / Ivy

package gu.sql2java;
import java.lang.reflect.ParameterizedType;
import java.lang.reflect.Type;
import java.util.ArrayList;
import java.util.Collection;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;

import static com.google.common.base.Preconditions.*;
/**
 * 
 * @author guyadong
 *
 * @param  left type
 * @param  right type
 */
public interface IBeanConverter {

    /**
     * Default abstract implementation of {@link IBeanConverter}
* * @author guyadong * * @param left type * @param right type */ public static abstract class AbstractHandle implements IBeanConverter { /** L type */ protected final Class leftType; /** R type */ protected final Class rightType; private static Class getRawClass(Type type){ if(type instanceof Class){ return (Class) type; } else if(type instanceof ParameterizedType){ return getRawClass(((ParameterizedType) type).getRawType()); } else{ throw new IllegalArgumentException("invalid type"); } } public AbstractHandle() { Type superClass = getClass().getGenericSuperclass(); this.leftType = getRawClass(((ParameterizedType) superClass).getActualTypeArguments()[0]); this.rightType = getRawClass(((ParameterizedType) superClass).getActualTypeArguments()[1]); } public AbstractHandle(Class leftClass,Class rightClass) { this.leftType = checkNotNull(leftClass,"leftClass is null"); this.rightType = checkNotNull(rightClass,"rightClass is null"); } /** * copy right TO left, left and right must not be null * @param left * @param right */ protected abstract void doFromRight(L left, R right); /** * copy left TO right, left and right must not be null * @param left * @param right */ protected abstract void doToRight(L left, R right); /** * Creates a new L instance by calling constructor with an empty argument list
* you must override the method if the L class haven't default constructor. * @return */ @SuppressWarnings("unchecked") protected L newInstanceL(){ return (L) newInstance(this.leftType); } /** * Creates a new R instance by calling constructor with an empty argument list
* you must override the method if the R class haven't default constructor. * @return */ @SuppressWarnings("unchecked") protected R newInstanceR(){ return (R) newInstance(this.rightType); } protected static T newInstance(Classclazz){ try { return (T) clazz.newInstance(); } catch (InstantiationException e) { throw new RuntimeException(e); } catch (IllegalAccessException e) { throw new RuntimeException(e); } } @Override public L fromRight(L left, R right) { if(null != right && null != left){ this.doFromRight(left, right); } return left; } @Override public R toRight(L left, R right) { if(null != left && null != right){ this.doToRight(left, right); } return right; } @Override public L fromRight(R bean) { return null == bean? null : fromRight(newInstanceL(),bean); } @Override public R toRight(L bean) { return null == bean? null : toRight(bean,newInstanceR()); } @Override public R[] toRight(L[] lefts, R[] rights) { if(null != lefts && null != rights){ if( lefts.length != rights.length){ throw new IllegalArgumentException("mismatched length between left and right array"); } for(int i=0;i toRight(Collection beans) { if(null==beans){ return null; } ArrayList rights = new ArrayList(beans.size()); for(L g:beans){ rights.add(this.toRight(g)); } return rights; } @Override public List fromRight(Collection beans) { if(null==beans){ return null; } ArrayList lefts = new ArrayList(beans.size()); for(R n:beans){ lefts.add(this.fromRight(n)); } return lefts; } @Override public List toRight(List lefts, List rights) { if(null != lefts && null != rights){ if( lefts.size() != rights.size()){ throw new IllegalArgumentException("mismatched length between left and right list"); } for(int i=0;i fromRight(List lefts, List rights) { if(null != rights && null != lefts){ if( lefts.size() != rights.size()){ throw new IllegalArgumentException("mismatched length between left and right list"); } for(int i=0;i toRight(List lefts) { List rights = null; if(null != lefts ){ rights = new ArrayList<>(); for(L l:lefts){ rights.add(toRight(l)); } } return rights; } @Override public List fromRight(List rights) { List lefts = null; if(null != rights ){ lefts = new ArrayList<>(); for(R r:rights){ lefts.add(fromRight(r)); } } return lefts; } @Override public Map toRightKey(Map lmap) { if(null == lmap){ return null; } HashMap rmap = new HashMap(16); for(Entry entry:lmap.entrySet()){ rmap.put(this.toRight(entry.getKey()),entry.getValue()); } return rmap; } @Override public Map toRightValue(Map lmap) { if(null == lmap){ return null; } HashMap rmap = new HashMap(16); for(Entry entry:lmap.entrySet()){ rmap.put(entry.getKey(), this.toRight(entry.getValue())); } return rmap; } @Override public Map fromRightKey(Map rmap) { if(null == rmap){ return null; } HashMap lmap = new HashMap(16); for(Entry entry:rmap.entrySet()){ lmap.put(this.fromRight(entry.getKey()),entry.getValue()); } return lmap; } @Override public Map fromRightValue(Map rmap) { if(null == rmap){ return null; } HashMap lmap = new HashMap(16); for(Entry entry:rmap.entrySet()){ lmap.put(entry.getKey(), this.fromRight(entry.getValue())); } return lmap; } @Override public Map toRight(Map lmap) { if(null == lmap){ return null; } HashMap rmap = new HashMap(16); for(Entry entry:lmap.entrySet()){ rmap.put(this.toRight(entry.getKey()),this.toRight(entry.getValue())); } return rmap; } @Override public Map fromRight(Map rmap) { if(null == rmap){ return null; } HashMap lmap = new HashMap(16); for(Entry entry:rmap.entrySet()){ lmap.put(this.fromRight(entry.getKey()),this.fromRight(entry.getValue())); } return lmap; } } /** * copy right TO left * @param left * @param right * @return left,or new instance if left is null */ public L fromRight(L left, R right); /** * copy left TO right * @param left * @param right * @return right,or new instance if right is null */ public R toRight(L left, R right); /** * return an new instance converted from R bean * @param bean * @return L bean */ public L fromRight(R bean); /** * return an new instance converted from L bean * @param bean * @return R bean */ public R toRight( L bean); /** * copy rights TO lefts * @param lefts * @param rights * @return lefts,or new array if lefts is null */ public L[] fromRight(L[] lefts,R[] rights); /** * copy lefts TO rights * @param lefts * @param rights * @return rights,or new array if rights is null */ public R[] toRight(L[] lefts,R[] rights); /** * return an new array converted from R beans * @param beans * @return L bean array */ public L[] fromRight(R[] beans); /** * an new array converted from L beans * @param beans * @return R bean array */ public R[] toRight(L[] beans); /** * copy rights TO lefts * @param lefts * @param rights * @return lefts,or new array if lefts is null */ public List fromRight(List lefts,List rights); /** * copy lefts TO rights * @param lefts * @param rights * @return rights,or new array if rights is null */ public List toRight(List lefts,List rights); /** * return an new list converted from R beans * @param beans * @return L bean list */ public List fromRight(List beans); /** * return an new list converted from L beans * @param beans * @return R bean list */ public List toRight(List beans); /** * return an new list converted from R beans * @param beans * @return L bean list */ public List fromRight(Collection beans); /** * an new list converted from L beans * @param beans * @return R bean list */ public List toRight(Collection beans); /** * return an new map with R key converted from map with L key * @param lmap * @return Map with R key */ public Map toRightKey(Map lmap); /** * return an new map with R value converted from map with L value * @param lmap * @return Map with R value */ public Map toRightValue(Map lmap); /** * return an new map with L key converted from map with R key * @param rmap * @return Map with L key */ public Map fromRightKey(Map rmap); /** * return an new map with L value converted from map with R value * @param rmap * @return Map with L value */ public Map fromRightValue(Map rmap); /** * an new map with R key and R value converted from map with L key and L value * @param lmap * @return Map with R key and value */ public Map toRight(Map lmap); /** * return an new map with L key and L value converted from map with R key and R value * @param rmap * @return Map with L key and value */ public Map fromRight(Map rmap); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy