Package groovy.transform
Annotation Type TupleConstructor
Class annotation used to assist in the creation of tuple constructors in classes.
It allows you to write classes in this shortened form:
@TupleConstructor class Customer {
String first, last
int age
Date since
Collection favItems
}
def c1 = new Customer(first:'Tom', last:'Jones', age:21, since:new Date(), favItems:['Books', 'Games'])
def c2 = new Customer('Tom', 'Jones', 21, new Date(), ['Books', 'Games'])
def c3 = new Customer('Tom', 'Jones')
The @TupleConstructor annotation instructs the compiler to execute an
AST transformation which adds the necessary constructor method to your class.
A tuple constructor is created with a parameter for each property (and optionally field and
super properties).
A default value is provided (using Java's default values) for all parameters in the constructor.
Groovy's normal conventions then allows any number of parameters to be left off the end of the parameter list
including all of the parameters - giving a no-arg constructor which can be used with the map-style naming conventions.
The order of parameters is given by the properties of any super classes with most super first
(if includeSuperProperties is set) followed by the properties of the class followed by the
by the fields of the class (if includeFields is set). Within each grouping the order
is as attributes appear within the respective class.
Limitations: currently not designed to support inner classes.- Since:
- 1.8.0
- Author:
- Paul King
-
Optional Element Summary
Optional ElementsModifier and TypeOptional ElementDescriptionbooleanShould super properties be called within a call to the parent constructor rather than set as propertiesComma separated list of field and/or property names to exclude from the constructor.booleanBy default, this annotation becomes a no-op if you provide your own constructor.booleanInclude fields in the constructorbooleanInclude properties in the constructorComma separated list of field and/or property names to include within the constructor.booleanInclude fields from super classes in the constructorbooleanInclude properties from super classes in the constructor
-
Element Details
-
excludes
String excludesComma separated list of field and/or property names to exclude from the constructor. Must not be used if 'includes' is used.- Default:
""
-
includes
String includesComma separated list of field and/or property names to include within the constructor. Must not be used if 'excludes' is used.- Default:
""
-
includeFields
boolean includeFieldsInclude fields in the constructor- Default:
false
-
includeProperties
boolean includePropertiesInclude properties in the constructor- Default:
true
-
includeSuperFields
boolean includeSuperFieldsInclude fields from super classes in the constructor- Default:
false
-
includeSuperProperties
boolean includeSuperPropertiesInclude properties from super classes in the constructor- Default:
false
-
callSuper
boolean callSuperShould super properties be called within a call to the parent constructor rather than set as properties- Default:
false
-
force
boolean forceBy default, this annotation becomes a no-op if you provide your own constructor. By settingforce=truethen the tuple constructor(s) will be added regardless of whether existing constructors exist. It is up to you to avoid creating duplicate constructors.- Default:
false
-