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

org.jtransfo.JTransfo Maven / Gradle / Ivy

There is a newer version: 2.10
Show newest version
/*
 * This file is part of jTransfo, a library for converting to and from transfer objects.
 * Copyright (c) PROGS bvba, Belgium
 *
 * The program is available in open source according to the Apache License, Version 2.0.
 * For full licensing details, see LICENSE.txt in the project root.
 */

package org.jtransfo;

import java.util.List;

/**
 * jTransfo main access point.
 */
public interface JTransfo {

    /**
     * Default tag which is activated when not tags are specified in the convert call.
     */
    String DEFAULT_TAG_WHEN_NO_TAGS = "§#noTags";

    /**
     * Fill the target object with the values from the source object.
     * 

* This will write all values from the transfer object, other fields are not touched. *

* * @param source source object. Should not be null. * @param target target object. Should not be null. * @param tags tags which indicate which fields can be converted based on {@link MapOnly} annotations. * Tags are processed from left to right. * @param type of object for target * @return target object */ T convert(Object source, T target, String... tags); /** * Create a new domain object from the source transfer object. *

* When the source is null, the result is also null. *

* The object finders are used to build the object to copy to. *

* * @param source source transfer object * @return domain object */ Object convert(Object source); /** * Create a new domain object from the source transfer object. *

* When the source is null, the result is also null. *

* The object finders are used to build the object to copy to. *

* * @param source source transfer object * @param targetClass target class to convert to * @param tags tags which indicate which fields can be converted based on {@link MapOnly} annotations. * Tags are processed from left to right. * @param type of object for target * @return domain object */ T convertTo(Object source, Class targetClass, String... tags); /** * Convert a list of object to the given type. Applies {@link #convertTo(Object, Class, String...)} on each object. *

* When the source is null, the result is also null. *

* * @param source source list of objects * @param targetClass target class to convert each object to * @param tags tags which indicate which fields can be converted based on {@link MapOnly} annotations. * Tags are processed from left to right. * @param type of object for target * @return list of target objects */ List convertList(List source, Class targetClass, String... tags); /** * Get the base target (domain) object for the source (transfer) object. *

* When the source is null, the result is also null. *

* The object finders are used to build the object to copy to. *

* * @param source source transfer object * @param targetClass target class to convert to * @param tags tags which indicate how objects need to be found * @param type of object for target * @return domain object */ T findTarget(Object source, Class targetClass, String... tags); /** * Get domain class for transfer object. * * @param toClass transfer object class * @return domain class as annotated on class */ Class getDomainClass(Class toClass); /** * Is the given class a transfer object class? *

* True when there is a {@link DomainClass} annotation on the class. *

* * @param toClass object class to test * @return true when object is a transfer object */ boolean isToClass(Class toClass); /** * Get the correct transfer object type for the given domain object. *

* This searches the DomainClassDelegates (if present) to see of there is a better matching transfer object than * the one given as parameter. *

* * @param toType base transfer object type * @param domainObject domain object (instance) * @return proper transfer object type to use */ Class getToSubType(Class toType, Object domainObject); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy