org.mapstruct.ap.internal.model.DefaultMapperReference Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of mapstruct-processor Show documentation
Show all versions of mapstruct-processor Show documentation
An annotation processor for generating type-safe bean mappers
/*
* Copyright MapStruct Authors.
*
* Licensed under the Apache License version 2.0, available at http://www.apache.org/licenses/LICENSE-2.0
*/
package org.mapstruct.ap.internal.model;
import java.util.List;
import java.util.Set;
import org.mapstruct.ap.internal.model.common.Type;
import org.mapstruct.ap.internal.model.common.TypeFactory;
import org.mapstruct.ap.internal.util.Collections;
import org.mapstruct.ap.internal.util.Strings;
/**
* Mapper reference which is retrieved via the {@code Mappers#getMapper()} method. Used by default if no other component
* model is specified via {@code Mapper#uses()}.
*
* @author Gunnar Morling
*/
public class DefaultMapperReference extends MapperReference {
private final boolean isAnnotatedMapper;
private final Set importTypes;
private DefaultMapperReference(Type type, boolean isAnnotatedMapper, Set importTypes, String variableName) {
super( type, variableName );
this.isAnnotatedMapper = isAnnotatedMapper;
this.importTypes = importTypes;
}
public static DefaultMapperReference getInstance(Type type, boolean isAnnotatedMapper, TypeFactory typeFactory,
List otherMapperReferences) {
Set importTypes = Collections.asSet( type );
if ( isAnnotatedMapper ) {
importTypes.add( typeFactory.getType( "org.mapstruct.factory.Mappers" ) );
}
String variableName = Strings.getSafeVariableName(
type.getName(),
otherMapperReferences
);
return new DefaultMapperReference( type, isAnnotatedMapper, importTypes, variableName );
}
@Override
public Set getImportTypes() {
return importTypes;
}
public boolean isAnnotatedMapper() {
return isAnnotatedMapper;
}
}