mirror of
https://github.com/mapstruct/mapstruct.git
synced 2025-07-12 00:00:08 +08:00
#81, removing FactoryMethod in favour of MethodReference
This commit is contained in:
parent
a9d2f788de
commit
9c45c96d8d
@ -38,9 +38,9 @@ import org.mapstruct.ap.model.source.Method;
|
|||||||
public class BeanMappingMethod extends MappingMethod {
|
public class BeanMappingMethod extends MappingMethod {
|
||||||
|
|
||||||
private final List<PropertyMapping> propertyMappings;
|
private final List<PropertyMapping> propertyMappings;
|
||||||
private final FactoryMethod factoryMethod;
|
private final MethodReference factoryMethod;
|
||||||
|
|
||||||
public BeanMappingMethod(Method method, List<PropertyMapping> propertyMappings, FactoryMethod factoryMethod) {
|
public BeanMappingMethod(Method method, List<PropertyMapping> propertyMappings, MethodReference factoryMethod) {
|
||||||
super( method );
|
super( method );
|
||||||
this.propertyMappings = propertyMappings;
|
this.propertyMappings = propertyMappings;
|
||||||
this.factoryMethod = factoryMethod;
|
this.factoryMethod = factoryMethod;
|
||||||
@ -76,7 +76,7 @@ public class BeanMappingMethod extends MappingMethod {
|
|||||||
return types;
|
return types;
|
||||||
}
|
}
|
||||||
|
|
||||||
public FactoryMethod getFactoryMethod() {
|
public MethodReference getFactoryMethod() {
|
||||||
return this.factoryMethod;
|
return this.factoryMethod;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,81 +0,0 @@
|
|||||||
/**
|
|
||||||
* Copyright 2012-2014 Gunnar Morling (http://www.gunnarmorling.de/)
|
|
||||||
* and/or other contributors as indicated by the @authors tag. See the
|
|
||||||
* copyright.txt file in the distribution for a full listing of all
|
|
||||||
* contributors.
|
|
||||||
*
|
|
||||||
* 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.mapstruct.ap.model;
|
|
||||||
|
|
||||||
import java.util.HashSet;
|
|
||||||
import java.util.Set;
|
|
||||||
|
|
||||||
import org.mapstruct.ap.model.source.Method;
|
|
||||||
import org.mapstruct.ap.model.common.Type;
|
|
||||||
import org.mapstruct.ap.model.common.ModelElement;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* A factory method
|
|
||||||
*
|
|
||||||
* @author Sjaak Derksen
|
|
||||||
*/
|
|
||||||
public class FactoryMethod extends ModelElement {
|
|
||||||
|
|
||||||
private final String name;
|
|
||||||
private final boolean hasDeclaringMapper;
|
|
||||||
private final MapperReference declaringMapper;
|
|
||||||
private final Type returnType;
|
|
||||||
|
|
||||||
public FactoryMethod( Method method, MapperReference declaringMapper ) {
|
|
||||||
this.name = method.getName();
|
|
||||||
this.hasDeclaringMapper = method.getDeclaringMapper() != null;
|
|
||||||
this.declaringMapper = declaringMapper;
|
|
||||||
this.returnType = method.getReturnType();
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getName() {
|
|
||||||
return name;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Type getDeclaringMapper() {
|
|
||||||
return declaringMapper.getMapperType();
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getMapperVariableName() {
|
|
||||||
return declaringMapper.getVariableName();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Set<Type> getImportTypes() {
|
|
||||||
Set<Type> types = new HashSet<Type>();
|
|
||||||
types.add( returnType );
|
|
||||||
types.addAll( returnType.getImportTypes() );
|
|
||||||
return types;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* There is no declaring mapper when the factory method is on an abstract
|
|
||||||
* mapper class. If the declaring mapper is a referenced mapper, then this will
|
|
||||||
* result into true.
|
|
||||||
*
|
|
||||||
* @return true when declaring mapper is a referenced mapper (or factory)
|
|
||||||
*/
|
|
||||||
public boolean isHasDeclaringMapper() {
|
|
||||||
return hasDeclaringMapper;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Object getReturnType() {
|
|
||||||
return returnType;
|
|
||||||
}
|
|
||||||
}
|
|
@ -45,7 +45,6 @@ import org.mapstruct.ap.conversion.Conversions;
|
|||||||
import org.mapstruct.ap.conversion.DefaultConversionContext;
|
import org.mapstruct.ap.conversion.DefaultConversionContext;
|
||||||
import org.mapstruct.ap.model.BeanMappingMethod;
|
import org.mapstruct.ap.model.BeanMappingMethod;
|
||||||
import org.mapstruct.ap.model.DefaultMapperReference;
|
import org.mapstruct.ap.model.DefaultMapperReference;
|
||||||
import org.mapstruct.ap.model.FactoryMethod;
|
|
||||||
import org.mapstruct.ap.model.IterableMappingMethod;
|
import org.mapstruct.ap.model.IterableMappingMethod;
|
||||||
import org.mapstruct.ap.model.MapMappingMethod;
|
import org.mapstruct.ap.model.MapMappingMethod;
|
||||||
import org.mapstruct.ap.model.Mapper;
|
import org.mapstruct.ap.model.Mapper;
|
||||||
@ -209,9 +208,9 @@ public class MapperCreationProcessor implements ModelElementProcessor<List<Metho
|
|||||||
return mappingMethods;
|
return mappingMethods;
|
||||||
}
|
}
|
||||||
|
|
||||||
private FactoryMethod getFactoryMethod(List<MapperReference> mapperReferences, List<Method> methods,
|
private MethodReference getFactoryMethod(List<MapperReference> mapperReferences, List<Method> methods,
|
||||||
Type returnType) {
|
Type returnType) {
|
||||||
FactoryMethod result = null;
|
MethodReference result = null;
|
||||||
for ( Method method : methods ) {
|
for ( Method method : methods ) {
|
||||||
if ( !method.requiresImplementation() && !method.isIterableMapping() && !method.isMapMapping()
|
if ( !method.requiresImplementation() && !method.isIterableMapping() && !method.isMapMapping()
|
||||||
&& method.getMappings().isEmpty() && method.getParameters().isEmpty() ) {
|
&& method.getMappings().isEmpty() && method.getParameters().isEmpty() ) {
|
||||||
@ -225,7 +224,7 @@ public class MapperCreationProcessor implements ModelElementProcessor<List<Metho
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
result = new FactoryMethod(method, mapperReference);
|
result = new MethodReference(method, mapperReference);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
messager.printMessage(
|
messager.printMessage(
|
||||||
@ -388,7 +387,7 @@ public class MapperCreationProcessor implements ModelElementProcessor<List<Metho
|
|||||||
mappedTargetProperties
|
mappedTargetProperties
|
||||||
);
|
);
|
||||||
|
|
||||||
FactoryMethod factoryMethod = getFactoryMethod( mapperReferences, methods, method.getReturnType() );
|
MethodReference factoryMethod = getFactoryMethod( mapperReferences, methods, method.getReturnType() );
|
||||||
return new BeanMappingMethod( method, propertyMappings, factoryMethod );
|
return new BeanMappingMethod( method, propertyMappings, factoryMethod );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -24,9 +24,7 @@ public <@includeModel object=returnType/> ${name}(<#list parameters as param><@i
|
|||||||
return<#if returnType.name != "void"> null</#if>;
|
return<#if returnType.name != "void"> null</#if>;
|
||||||
}
|
}
|
||||||
|
|
||||||
<#if !existingInstanceMapping>
|
<#if !existingInstanceMapping>${resultType.name} ${resultName} = <#if factoryMethod??><@includeModel object=factoryMethod/><#else>new ${resultType.name}()</#if>;</#if>
|
||||||
${resultType.name} ${resultName} = <#if factoryMethod??><@includeModel object=factoryMethod/><#else>new ${resultType.name}()</#if>;
|
|
||||||
</#if>
|
|
||||||
<#if (sourceParameters?size > 1)>
|
<#if (sourceParameters?size > 1)>
|
||||||
<#list sourceParameters as sourceParam>
|
<#list sourceParameters as sourceParam>
|
||||||
if ( ${sourceParam.name} != null ) {
|
if ( ${sourceParam.name} != null ) {
|
||||||
|
@ -1,21 +0,0 @@
|
|||||||
<#--
|
|
||||||
|
|
||||||
Copyright 2012-2014 Gunnar Morling (http://www.gunnarmorling.de/)
|
|
||||||
and/or other contributors as indicated by the @authors tag. See the
|
|
||||||
copyright.txt file in the distribution for a full listing of all
|
|
||||||
contributors.
|
|
||||||
|
|
||||||
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.
|
|
||||||
|
|
||||||
-->
|
|
||||||
<#if hasDeclaringMapper>${mapperVariableName}.</#if>${name}()
|
|
Loading…
x
Reference in New Issue
Block a user