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

org.codehaus.jackson.map.BeanProperty Maven / Gradle / Ivy

The newest version!
package org.codehaus.jackson.map;

import java.lang.annotation.Annotation;

import org.codehaus.jackson.map.introspect.AnnotatedMember;
import org.codehaus.jackson.map.util.Annotations;
import org.codehaus.jackson.map.util.Named;
import org.codehaus.jackson.type.JavaType;

/**
 * Bean properties are logical entities that represent data
 * Java objects ("beans", although more accurately POJOs)
 * contain; and that are accessed using some combination
 * of methods (getter, setter), field and constructor
 * parameter.
 * Instances allow access to annotations directly associated
 * to property (via field or method), as well as contextual
 * annotations (annotations for class that contains properties).
 *

* Instances are passed during construction of serializers and * deserializers, and references can be stored by serializers * and deserializers for futher use; mostly to retain access * to annotations when dynamically locating handlers for * sub-properties or dynamic types. * * @since 1.7 */ public interface BeanProperty extends Named { /** * Method to get logical name of the property */ @Override public String getName(); /** * Method to get declared type of the property. */ public JavaType getType(); /** * Method for finding annotation associated with this property; * meaning annotation associated with one of entities used to * access property. */ public A getAnnotation(Class acls); /** * Method for finding annotation associated with context of * this property; usually class in which member is declared * (or its subtype if processing subtype). */ public A getContextAnnotation(Class acls); /** * Method for accessing primary physical entity that represents the property; * annotated field, method or constructor property. */ public AnnotatedMember getMember(); /* /********************************************************** /* Simple stand-alone implementation, useful as a placeholder /* or base class. /********************************************************** */ public static class Std implements BeanProperty { protected final String _name; protected final JavaType _type; /** * Physical entity (field, method or constructor argument) that * is used to access value of property (or in case of constructor * property, just placeholder) */ protected final AnnotatedMember _member; /** * Annotations defined in the context class (if any); may be null * if no annotations were found */ protected final Annotations _contextAnnotations; public Std(String name, JavaType type, Annotations contextAnnotations, AnnotatedMember member) { _name = name; _type = type; _member = member; _contextAnnotations = contextAnnotations; } public Std withType(JavaType type) { return new Std(_name, type, _contextAnnotations, _member); } @Override public A getAnnotation(Class acls) { return _member.getAnnotation(acls); } @Override public A getContextAnnotation(Class acls) { return (_contextAnnotations == null) ? null : _contextAnnotations.get(acls); } @Override public String getName() { return _name; } @Override public JavaType getType() { return _type; } @Override public AnnotatedMember getMember() { return _member; } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy