org.joda.beans.PropertyDefinition Maven / Gradle / Ivy
/*
* Copyright 2001-2015 Stephen Colebourne
*
* 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 org.joda.beans;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
/**
* Annotation defining a property for code generation.
*
* This annotation must be used on all private instance variables that
* should be treated as properties.
*
* @author Stephen Colebourne
*/
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.FIELD)
public @interface PropertyDefinition {
/**
* An alternative name for the property.
*
* The property can be looked up using the specified alias.
* The primary name is unaffected, and the alias is only used in certain circumstances.
* For example, {@code bean.metaProperty("alias")} and {@code bean.property("alias")}
* will both work, as will getting and setting via an immutable bean builder.
*
* This attribute is most useful in handling change from serialized forms.
*/
String alias() default "";
/**
* The style of the method used to query the property.
*
* The style is a string describing the getter, typically used for code generation.
* By default this is 'smart' which will use the source code knowledge to determine
* what to generate. This will be a method of the form {@code isXxx()} for {@code boolean}
* and {@code getXxx()} for all other types.
*
* Supported style strings are:
*
* - '' - do not generate any form of getter
*
- 'smart' - process intelligently - 'is' for boolean and 'get' for other types
*
- 'private' - process as per 'smart' but set scope as private
*
- 'package' - process as per 'smart' but set scope as package/default
*
- 'protected' - process as per 'smart' but set scope as protected
*
- 'is' - generates isXxx()
*
- 'get' - generates getXxx()
*
- 'clone' - generates getXxx() with a clone of the field (assumed to be of the correct type)
*
- 'cloneCast' - generates getXxx() with a clone of the field with a cast to the property type
*
- 'optional' - generate getXxx() returning a Java 8 {@code Optional} wrapper around the field,
* where the field itself is nullable instead of optional. {@code OptionalDouble}, {@code OptionalInt}
* and {@code OptionalLong} are also handled
*
- 'optionalGuava' - generate getXxx() returning a Guava {@code Optional} wrapper around the field,
* where the field itself is nullable instead of optional
*
- 'field' - generates direct access to the field, enabling a weird manual getter
*
- 'manual' - a method named getXxx() must be manually provided at package scope or greater
*
*/
String get() default "smart";
/**
* The style of the method used to mutate the property.
*
* The style is a string describing the mutator, typically used for code generation.
* By default this is 'smart' which will use the source code knowledge to determine
* what to generate. This will be a method of the form {@code setXxx()} for all types unless
* the field is {@code final}. If the field is a final {@code Collection} or {@code Map}
* of a known type then a set method is generated using {@code addAll} or {@code puAll}
*
* Standard style strings are:
*
* - '' - do not generate any form of setter
*
- 'smart' - process intelligently - uses 'set' unless final, when it will use 'setClearAddAll'
* for common list types or 'setClearPutAll' for common map types and FlexiBean
*
- 'private' - process as per 'smart' but set scope as private
*
- 'package' - process as per 'smart' but set scope as package/default
*
- 'protected' - process as per 'smart' but set scope as protected
*
- 'set' - generates setXxx()
*
- 'setClearAddAll' - generates setXxx() using field.clear() and field.addAll(newData)
*
- 'setClearPutAll' - generates setXxx() using field.clear() and field.putAll(newData)
*
- 'bound' - generates a bound property with {@code PropertyChangeSupport}
*
- 'field' - generates direct access to the field, enabling a weird manual setter
*
- 'manual' - a method named setXxx() must be manually provided at package scope or greater
*
- a pattern, see below
*
*
* A pattern can be used for special behaviour.
* The pattern is a complete piece of code.
* For example, 'new Foo($value)' or '$field = $value.clone()'.
* '$field' for the field to copy into.
* '$value' for the value to copy from.
* '<>' for the generics of the type including angle brackets.
* '\n' for a new line (all lines must then include semi-colons).
*/
String set() default "smart";
/**
* Whether the generated getter should be declared with the {@code Override} annotation.
*
* By default, the annotation is not added.
*/
boolean overrideGet() default false;
/**
* Whether the generated setter should be declared with the {@code Override} annotation.
*
* By default, the annotation is not added.
*/
boolean overrideSet() default false;
/**
* The exposed type of the property.
*
* The style is used to control the exposed type of the property in
* getters and setters, or similar.
*
* This is used when the type of the field is not the same as the type
* that should be used in public methods such as getters and setters.
*
* By default, the declared type will be used as the exposed type.
*/
String type() default "smart";
/**
* The exposed type of the property in the builder and associated constructor.
*
* The style is used to control the exposed type of the property in
* immutable builders and associated constructors, or similar.
*
* This is used when the type of the field is not the same as the type
* that should be used in public methods such as builder setters.
*
* By default, the declared type will be used as the exposed type.
*
* This is typically used to add '? extends' to collection types.
*/
String builderType() default "smart";
/**
* The configuration for equals and hash code.
*
* This flag controls generation of the {@code equals} and {@code hashCode} methods.
* The default is 'smart'.
*
* Standard strings are:
*
* - 'omit' - omit this property from equals and hashCode
*
- 'smart' - process intelligently, equivalent to 'field' for immutable and 'getter' for mutable
*
- 'getter' - include in equals and hashCode using the getter
*
- 'field' - include in equals and hashCode using the field
*
*/
String equalsHashCodeStyle() default "smart";
/**
* The configuration for toString.
*
* This flag controls generation of the {@code toString} method.
* The default is 'smart'.
*
* Standard strings are:
*
* - 'omit' - omit this property from equals and hashCode
*
- 'smart' - process intelligently, equivalent to 'field' for immutable and 'getter' for mutable
*
- 'getter' - include in equals and hashCode using the getter
*
- 'field' - include in equals and hashCode using the field
*
*/
String toStringStyle() default "smart";
/**
* The validator to use.
*
* The property value may be validated by specifying this attribute.
* By default no validation is performed.
* The code generator places the validation into the set method and ensures that
* new objects are validated correctly.
*
* Custom validations, are written by writing a static method and referring to it.
* For example, {@code public void checkMyValue(Integer val, String propertyName) ...}
* The method generally has a {@code void} return, throwing an exception if validation fails.
* There must be two arguments, the value and the property name. The value may be the
* property type or a superclass (like Object). The property name should be a String.
*
* Standard validation strings are:
*
* - '' - do not generate any form of validation
*
- 'notNull' - suitable for checking that the value is non-null,
* calls JodaBeanUtils.notNull() which throws an IllegalArgumentException
*
- 'notEmpty' - suitable for checking that a string is non-null and non-empty,
* calls JodaBeanUtils.notEmpty() which throws an IllegalArgumentException
*
- '{className}.{staticMethodName}' - a custom validation method, described above
*
*/
String validate() default "";
}