Package org.mapstruct.ap.internal.model
Class MethodReference
- java.lang.Object
-
- org.mapstruct.ap.internal.writer.FreeMarkerWritable
-
- org.mapstruct.ap.internal.model.common.ModelElement
-
- org.mapstruct.ap.internal.model.MethodReference
-
- All Implemented Interfaces:
Assignment,Writable
- Direct Known Subclasses:
LifecycleCallbackMethodReference
public class MethodReference extends ModelElement implements Assignment
Represents a reference to another method, e.g. used to map a bean property from source to target type or to instantiate the return value of a mapping method (rather than calling thenewoperator).- Author:
- Gunnar Morling
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from interface org.mapstruct.ap.internal.model.common.Assignment
Assignment.AssignmentType
-
Nested classes/interfaces inherited from interface org.mapstruct.ap.internal.writer.Writable
Writable.Context
-
-
Constructor Summary
Constructors Modifier Constructor Description protectedMethodReference(Method method, MapperReference declaringMapper, Parameter providingParameter, List<ParameterBinding> parameterBindings)Creates a new reference to the given method.
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description StringcreateUniqueVarName(String desiredName)Creates an unique safe (local) variable name.booleanequals(Object obj)static MethodReferenceforBuiltInMethod(BuiltInMethod method, ConversionContext contextParam)static MethodReferenceforConstructorInvocation(Type type, List<ParameterBinding> parameterBindings)static MethodReferenceforForgedMethod(Method method, List<ParameterBinding> parameterBindings)static MethodReferenceforMapperReference(Method method, MapperReference declaringMapper, List<ParameterBinding> parameterBindings)static MethodReferenceforMethodCall(String methodName)static MethodReferenceforMethodChaining(MethodReference... references)static MethodReferenceforParameterProvidedMethod(Method method, Parameter providingParameter, List<ParameterBinding> parameterBindings)static MethodReferenceforStaticBuilder(String builderCreationMethod, Type definingType)AssignmentgetAssignment()StringgetContextParam()MapperReferencegetDeclaringMapper()TypegetDefiningType()Set<Type>getImportTypes()Returns a set containing thoseTypes referenced by this model element for which an import statement needs to be declared.StringgetMapperVariableName()List<MethodReference>getMethodsToChain()StringgetName()List<ParameterBinding>getParameterBindings()ParametergetProvidingParameter()TypegetReturnType()TypegetSingleSourceParameterType()StringgetSourceLocalVarName()StringgetSourceLoopVarName()SeeAssignment.getSourceLoopVarName()(java.lang.String) }StringgetSourceParameterName()Returns the source parameter name, to which this assignment applies.List<Parameter>getSourceParameters()PresenceCheckgetSourcePresenceCheckerReference()the source presence checker referenceStringgetSourceReference()the source reference being a source-getter, a constant, nested method call, etc.TypegetSourceType()the source type used in the matching processList<Type>getThrownTypes()returns all types exception types thrown by this assignment.Assignment.AssignmentTypegetType()Returns whether the type of assignmentinthashCode()TypeinferTypeWhenEnum(Type type)booleanisCallingUpdateMethod()booleanisConstructor()booleanisMethodChaining()booleanisSourceReferenceParameter()booleanisStatic()voidsetAssignment(Assignment assignment)An assignment in itself can wrap another assignment.voidsetSourceLocalVarName(String sourceLocalVarName)Replaces the sourceReference at the call site in the assignment in the template with this sourceLocalVarName.voidsetSourceLoopVarName(String sourceLoopVarName)Replaces the sourceLocalVar or sourceReference at the call site in the assignment in the template with this sourceLoopVarName.StringtoString()-
Methods inherited from class org.mapstruct.ap.internal.writer.FreeMarkerWritable
getTemplateName, getTemplateNameForClass, write
-
-
-
-
Constructor Detail
-
MethodReference
protected MethodReference(Method method, MapperReference declaringMapper, Parameter providingParameter, List<ParameterBinding> parameterBindings)
Creates a new reference to the given method.- Parameters:
method- the target method of the referencedeclaringMapper- the method declaring the mapper;nullif the current mapper itselfprovidingParameter- The parameter providing the mapper, ornullif the method is defined by the mapper itself or bydeclaringMapper.parameterBindings- the parameter bindings of this method reference
-
-
Method Detail
-
getDeclaringMapper
public MapperReference getDeclaringMapper()
-
getProvidingParameter
public Parameter getProvidingParameter()
-
getMapperVariableName
public String getMapperVariableName()
-
getContextParam
public String getContextParam()
-
getAssignment
public Assignment getAssignment()
-
getName
public String getName()
-
setAssignment
public void setAssignment(Assignment assignment)
Description copied from interface:AssignmentAn assignment in itself can wrap another assignment. E.g.:- a MethodReference can wrap a TypeConversion, another MethodReference and ultimately a Simple
- a TypeConversion can wrap a MethodReference, and ultimately a Simple
- Specified by:
setAssignmentin interfaceAssignment- Parameters:
assignment- the assignment to set
-
getSourceReference
public String getSourceReference()
Description copied from interface:Assignmentthe source reference being a source-getter, a constant, nested method call, etc.- Specified by:
getSourceReferencein interfaceAssignment- Returns:
- source reference
-
getSourcePresenceCheckerReference
public PresenceCheck getSourcePresenceCheckerReference()
Description copied from interface:Assignmentthe source presence checker reference- Specified by:
getSourcePresenceCheckerReferencein interfaceAssignment- Returns:
- source reference
-
getSourceType
public Type getSourceType()
Description copied from interface:Assignmentthe source type used in the matching process- Specified by:
getSourceTypein interfaceAssignment- Returns:
- source type (can be null)
-
createUniqueVarName
public String createUniqueVarName(String desiredName)
Description copied from interface:AssignmentCreates an unique safe (local) variable name.- Specified by:
createUniqueVarNamein interfaceAssignment- Parameters:
desiredName- the desired name- Returns:
- the desired name, made unique in the scope of the bean mapping.
-
getSourceLocalVarName
public String getSourceLocalVarName()
Description copied from interface:Assignment- Specified by:
getSourceLocalVarNamein interfaceAssignment- Returns:
- local variable name (can be null if not set)
-
setSourceLocalVarName
public void setSourceLocalVarName(String sourceLocalVarName)
Description copied from interface:AssignmentReplaces the sourceReference at the call site in the assignment in the template with this sourceLocalVarName. The sourceLocalVarName can subsequently be used for e.g. null checking.- Specified by:
setSourceLocalVarNamein interfaceAssignment- Parameters:
sourceLocalVarName- source local variable name
-
getSourceLoopVarName
public String getSourceLoopVarName()
Description copied from interface:AssignmentSeeAssignment.getSourceLoopVarName()(java.lang.String) }- Specified by:
getSourceLoopVarNamein interfaceAssignment- Returns:
- loop variable (can be null if not set)
-
setSourceLoopVarName
public void setSourceLoopVarName(String sourceLoopVarName)
Description copied from interface:AssignmentReplaces the sourceLocalVar or sourceReference at the call site in the assignment in the template with this sourceLoopVarName. The sourceLocalVar can subsequently be used for e.g. null checking.- Specified by:
setSourceLoopVarNamein interfaceAssignment- Parameters:
sourceLoopVarName- loop variable
-
getSourceParameterName
public String getSourceParameterName()
Description copied from interface:AssignmentReturns the source parameter name, to which this assignment applies. Note: the source parameter itself might be mapped by this assignment, or one of its properties- Specified by:
getSourceParameterNamein interfaceAssignment- Returns:
- the source parameter name
-
isSourceReferenceParameter
public boolean isSourceReferenceParameter()
- Specified by:
isSourceReferenceParameterin interfaceAssignment- Returns:
- true when the source reference is the source parameter (and not a property of the source parameter type)
-
getSingleSourceParameterType
public Type getSingleSourceParameterType()
- Returns:
- the type of the single source parameter that is not the
@TargetTypeparameter
-
getDefiningType
public Type getDefiningType()
-
getImportTypes
public Set<Type> getImportTypes()
Description copied from class:ModelElementReturns a set containing thoseTypes referenced by this model element for which an import statement needs to be declared.- Specified by:
getImportTypesin interfaceAssignment- Specified by:
getImportTypesin classModelElement- Returns:
- A set with type referenced by this model element. Must not be
null.
-
getThrownTypes
public List<Type> getThrownTypes()
Description copied from interface:Assignmentreturns all types exception types thrown by this assignment.- Specified by:
getThrownTypesin interfaceAssignment- Returns:
- exceptions thrown
-
getType
public Assignment.AssignmentType getType()
Description copied from interface:AssignmentReturns whether the type of assignment- Specified by:
getTypein interfaceAssignment- Returns:
Assignment.AssignmentType
-
getReturnType
public Type getReturnType()
-
isCallingUpdateMethod
public boolean isCallingUpdateMethod()
- Specified by:
isCallingUpdateMethodin interfaceAssignment
-
isStatic
public boolean isStatic()
-
isConstructor
public boolean isConstructor()
-
isMethodChaining
public boolean isMethodChaining()
-
getMethodsToChain
public List<MethodReference> getMethodsToChain()
-
getParameterBindings
public List<ParameterBinding> getParameterBindings()
-
forBuiltInMethod
public static MethodReference forBuiltInMethod(BuiltInMethod method, ConversionContext contextParam)
-
forForgedMethod
public static MethodReference forForgedMethod(Method method, List<ParameterBinding> parameterBindings)
-
forParameterProvidedMethod
public static MethodReference forParameterProvidedMethod(Method method, Parameter providingParameter, List<ParameterBinding> parameterBindings)
-
forMapperReference
public static MethodReference forMapperReference(Method method, MapperReference declaringMapper, List<ParameterBinding> parameterBindings)
-
forStaticBuilder
public static MethodReference forStaticBuilder(String builderCreationMethod, Type definingType)
-
forMethodCall
public static MethodReference forMethodCall(String methodName)
-
forConstructorInvocation
public static MethodReference forConstructorInvocation(Type type, List<ParameterBinding> parameterBindings)
-
forMethodChaining
public static MethodReference forMethodChaining(MethodReference... references)
-
-