Class SourceMethod
- java.lang.Object
-
- org.mapstruct.ap.internal.model.source.SourceMethod
-
- All Implemented Interfaces:
Method
public class SourceMethod extends Object implements Method
Represents a mapping method with source and target type and the mappings between the properties of source and target type.A method can either be configured by itself or by another method for the inverse mapping direction (the appropriate setter on
MappingMethodOptionswill be called in this case).- Author:
- Gunnar Morling
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static classSourceMethod.Builder
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description booleancanInheritFrom(SourceMethod method)static booleancontainsTargetTypeParameter(List<Parameter> parameters)Stringdescribe()AccessibilitygetAccessibility()Returns theAccessibilityof this method.List<SourceMethod>getApplicablePrototypeMethods()List<SourceMethod>getApplicableReversePrototypeMethods()ConditionMethodOptionsgetConditionOptions()List<Parameter>getContextParameters()returns the list of mapping context parameters, i.e. those parameters that are annotated withContext.ParameterProvidedMethodsgetContextProvidedMethods()TypegetDeclaringMapper()Returns the mapper type declaring this method if it is not declared by the mapper interface currently processed but by another mapper imported viaMapper#users().TypegetDefiningType()ExecutableElementgetExecutable()ParametergetMappingTargetParameter()Returns the parameter designated as mapping target (if present)MappingTargetStringgetName()Returns then name of the method.MappingMethodOptionsgetOptions()List<String>getParameterNames()List<Parameter>getParameters()In contrast toMethod.getSourceParameters()this method returns all parametersTypegetResultType()Returns the type of the result.TypegetReturnType()Returns the return type of the methodList<Parameter>getSourceParameters()returns the list of 'true' source parameters excluding the parameter(s) that are designated as target, target type or context parameter.ParametergetSourcePropertyNameParameter()ParametergetTargetPropertyNameParameter()ParametergetTargetTypeParameter()Returns the parameter designated as target type (if present)TargetTypeList<Type>getThrownTypes()Returns all exceptions thrown by this methodList<Type>getTypeParameters()Returns the formal type parameters of this method in declaration order.booleanhasObjectFactoryAnnotation()booleaninverses(SourceMethod method)booleanisAbstract()booleanisAfterMappingMethod()booleanisBeforeMappingMethod()booleanisDefault()Whether this method is Java 8 default methodbooleanisIterableMapping()booleanisLifecycleCallbackMethod()booleanisMapMapping()booleanisObjectFactory()Returns whether the meethod is designated as bean factory for mapping targetObjectFactorybooleanisRemovedEnumMapping()Enum Mapping was realized with @Mapping in stead of @ValueMapping.booleanisStatic()Whether this method is static or an instance methodbooleanisStreamMapping()booleanisUpdateMethod()booleanisValueMapping()The default enum mapping (no mappings specified) will from now on be handled as a value mapping.booleanmatches(List<Type> sourceTypes, Type targetType)Checks whether the provided sourceType and provided targetType match with the parameter respectively return type of the method.booleanoverridesMethod()Whether an implementation of this method must be generated or not.StringtoString()-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface org.mapstruct.ap.internal.model.source.Method
getMappingSourceType, isMappingTargetAssignableToReturnType
-
-
-
-
Method Detail
-
getDeclaringMapper
public Type getDeclaringMapper()
Description copied from interface:MethodReturns the mapper type declaring this method if it is not declared by the mapper interface currently processed but by another mapper imported viaMapper#users().- Specified by:
getDeclaringMapperin interfaceMethod- Returns:
- The declaring mapper type
-
getExecutable
public ExecutableElement getExecutable()
- Specified by:
getExecutablein interfaceMethod
-
getName
public String getName()
Description copied from interface:MethodReturns then name of the method.
-
getParameters
public List<Parameter> getParameters()
Description copied from interface:MethodIn contrast toMethod.getSourceParameters()this method returns all parameters- Specified by:
getParametersin interfaceMethod- Returns:
- all parameters
-
getSourceParameters
public List<Parameter> getSourceParameters()
Description copied from interface:Methodreturns the list of 'true' source parameters excluding the parameter(s) that are designated as target, target type or context parameter.- Specified by:
getSourceParametersin interfaceMethod- Returns:
- list of 'true' source parameters
-
getContextParameters
public List<Parameter> getContextParameters()
Description copied from interface:Methodreturns the list of mapping context parameters, i.e. those parameters that are annotated withContext.- Specified by:
getContextParametersin interfaceMethod- Returns:
- list of context parameters
-
getContextProvidedMethods
public ParameterProvidedMethods getContextProvidedMethods()
- Specified by:
getContextProvidedMethodsin interfaceMethod- Returns:
- a mapping between
Method.getContextParameters()to factory and lifecycle methods provided by them.
-
getParameterNames
public List<String> getParameterNames()
- Specified by:
getParameterNamesin interfaceMethod- Returns:
- the names of the parameters of this mapping method
-
getResultType
public Type getResultType()
Description copied from interface:MethodReturns the type of the result. The result is defined as the type of the parameter designated withMappingTarget, or in absence the return type.- Specified by:
getResultTypein interfaceMethod- Returns:
- result type
-
getReturnType
public Type getReturnType()
Description copied from interface:MethodReturns the return type of the method- Specified by:
getReturnTypein interfaceMethod- Returns:
- return type
-
getAccessibility
public Accessibility getAccessibility()
Description copied from interface:MethodReturns theAccessibilityof this method.- Specified by:
getAccessibilityin interfaceMethod- Returns:
- the
Accessibilityof this method
-
inverses
public boolean inverses(SourceMethod method)
-
canInheritFrom
public boolean canInheritFrom(SourceMethod method)
-
getMappingTargetParameter
public Parameter getMappingTargetParameter()
Description copied from interface:MethodReturns the parameter designated as mapping target (if present)MappingTarget- Specified by:
getMappingTargetParameterin interfaceMethod- Returns:
- mapping target parameter (when present) null otherwise.
-
isObjectFactory
public boolean isObjectFactory()
Description copied from interface:MethodReturns whether the meethod is designated as bean factory for mapping targetObjectFactory- Specified by:
isObjectFactoryin interfaceMethod- Returns:
- true if it is a target bean factory.
-
getTargetTypeParameter
public Parameter getTargetTypeParameter()
Description copied from interface:MethodReturns the parameter designated as target type (if present)TargetType- Specified by:
getTargetTypeParameterin interfaceMethod- Returns:
- target type parameter (when present) null otherwise.
-
getSourcePropertyNameParameter
public Parameter getSourcePropertyNameParameter()
-
getTargetPropertyNameParameter
public Parameter getTargetPropertyNameParameter()
-
isIterableMapping
public boolean isIterableMapping()
-
isStreamMapping
public boolean isStreamMapping()
-
isMapMapping
public boolean isMapMapping()
-
isRemovedEnumMapping
public boolean isRemovedEnumMapping()
Enum Mapping was realized with @Mapping in stead of @ValueMapping. @Mapping is no longer supported.- Returns:
- true when @Mapping is used in stead of @ValueMapping
-
isValueMapping
public boolean isValueMapping()
The default enum mapping (no mappings specified) will from now on be handled as a value mapping. If there are any @Mapping / @Mappings defined on the method, then the deprecated enum behavior should be executed.- Returns:
- whether (true) or not (false) to execute value mappings
-
getApplicablePrototypeMethods
public List<SourceMethod> getApplicablePrototypeMethods()
-
getApplicableReversePrototypeMethods
public List<SourceMethod> getApplicableReversePrototypeMethods()
-
overridesMethod
public boolean overridesMethod()
Whether an implementation of this method must be generated or not.- Specified by:
overridesMethodin interfaceMethod- Returns:
- true when an implementation is required
-
matches
public boolean matches(List<Type> sourceTypes, Type targetType)
Description copied from interface:MethodChecks whether the provided sourceType and provided targetType match with the parameter respectively return type of the method. The check also should incorporate wild card and generic type variables
-
containsTargetTypeParameter
public static boolean containsTargetTypeParameter(List<Parameter> parameters)
- Parameters:
parameters- the parameter list to check- Returns:
trueif the parameter list contains a parameter annotated with@TargetType
-
getThrownTypes
public List<Type> getThrownTypes()
Description copied from interface:MethodReturns all exceptions thrown by this method- Specified by:
getThrownTypesin interfaceMethod- Returns:
- exceptions thrown
-
getOptions
public MappingMethodOptions getOptions()
- Specified by:
getOptionsin interfaceMethod- Returns:
- the mapping options for this method
-
getConditionOptions
public ConditionMethodOptions getConditionOptions()
- Specified by:
getConditionOptionsin interfaceMethod
-
isStatic
public boolean isStatic()
Description copied from interface:MethodWhether this method is static or an instance method
-
isDefault
public boolean isDefault()
Description copied from interface:MethodWhether this method is Java 8 default method
-
getDefiningType
public Type getDefiningType()
- Specified by:
getDefiningTypein interfaceMethod- Returns:
- the Type (class or interface) that defines this method.
-
isLifecycleCallbackMethod
public boolean isLifecycleCallbackMethod()
- Specified by:
isLifecycleCallbackMethodin interfaceMethod- Returns:
true, if the method represents a mapping lifecycle callback (Before/After mapping method)
-
isAfterMappingMethod
public boolean isAfterMappingMethod()
-
isBeforeMappingMethod
public boolean isBeforeMappingMethod()
-
isAbstract
public boolean isAbstract()
- Returns:
- returns true for interface methods (see jls 9.4) lacking a default or static modifier and for abstract methods
-
isUpdateMethod
public boolean isUpdateMethod()
- Specified by:
isUpdateMethodin interfaceMethod- Returns:
true, if the method is an update method, i.e. it has a parameter annotated with@MappingTarget.
-
hasObjectFactoryAnnotation
public boolean hasObjectFactoryAnnotation()
-
getTypeParameters
public List<Type> getTypeParameters()
Description copied from interface:MethodReturns the formal type parameters of this method in declaration order.- Specified by:
getTypeParametersin interfaceMethod- Returns:
- the formal type parameters, or an empty list if there are none
-
-