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

org.jtransfo.MappedBy Maven / Gradle / Ivy

/*
 * 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 org.jtransfo.internal.SyntheticField;

import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
import java.lang.reflect.Type;

/**
 * Annotation which indicates how the field in the transfer object should be mapped to a field in the domain object.
 * 

* By default fields are mapped in both directions between fields of the same name. *

*/ @Retention(RetentionPolicy.RUNTIME) @Target({ElementType.FIELD, ElementType.ANNOTATION_TYPE}) @Documented public @interface MappedBy { /** * Name of the field in the domain class. *

* By default the field is assumed to have the same name in the domain class. *

*/ String field() default DEFAULT_FIELD; /** * Path to the field when it is transitive. *

* By default the path is empty, meaning that the field is inside the domain object itself. *

*/ String path() default DEFAULT_PATH; /** * Name for the type converter, this is either name (when it implements {@link Named} or the * Fully qualified class name. *

* Using this allows you to avoid a compile dependency on the class name but makes the connection more brittle * when refactoring. The value is ignored if {@link #typeConverterClass()} is set. *

*/ String typeConverter() default DEFAULT_TYPE_CONVERTER; /** * Class to use for type conversion. *

* This requires a compile dependency on the domain class. The value has precedence over {@link #typeConverter()}. *

*/ Class typeConverterClass() default DefaultTypeConverter.class; /** * When set, the field will never be written in the domain class. */ boolean readOnly() default false; /** * Default value for {@link #field} indicating that then domain object field is expected to have the same name as * the annotated field. */ String DEFAULT_FIELD = "?"; /** * Default value for {@link #path} indicating that then domain object field is in the domain object itself. */ String DEFAULT_PATH = ""; /** * Default value for type converter class name, indicating no name specified. */ String DEFAULT_TYPE_CONVERTER = "?"; /** * Default value for {@link #typeConverterClass} indicating the type converter which should be used if * {@link #typeConverter} is not set. */ class DefaultTypeConverter implements TypeConverter { @Override public boolean canConvert(Type realToType, Type realDomainType) { return false; } @Override public Object convert(Object object, SyntheticField domainField, Object domainObject, String... tags) throws JTransfoException { return null; } @Override public Object reverse(Object object, SyntheticField toField, Object toObject, String... tags) throws JTransfoException { return null; } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy