org.mapstruct.ap.internal.conversion.ConversionUtils 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.conversion;
import java.math.BigDecimal;
import java.math.BigInteger;
import java.net.URL;
import java.sql.Time;
import java.sql.Timestamp;
import java.text.DecimalFormat;
import java.text.SimpleDateFormat;
import java.time.LocalDate;
import java.time.LocalDateTime;
import java.time.ZoneId;
import java.time.ZoneOffset;
import java.time.ZonedDateTime;
import java.time.format.DateTimeFormatter;
import java.util.Currency;
import java.util.Locale;
import java.util.UUID;
import org.mapstruct.ap.internal.model.common.ConversionContext;
import org.mapstruct.ap.internal.util.JodaTimeConstants;
/**
* Methods mainly used in {@link org.mapstruct.ap.internal.conversion.SimpleConversion SimpleConversion} classes, e. g.
* to get the correct String representation of various types that could be used in generated sources.
*
* @author Christian Bandowski
*/
public final class ConversionUtils {
private ConversionUtils() {
}
/**
* Name for the given {@code canonicalName}.
*
* @param conversionContext Conversion context
* @param canonicalName Canonical name of the type
*
* @return Name or fully-qualified name.
*/
private static String typeReferenceName(ConversionContext conversionContext, String canonicalName) {
return conversionContext.getTypeFactory().getType( canonicalName ).createReferenceName();
}
/**
* Name for the given {@code canonicalName}.
*
* @param conversionContext Conversion context
* @param type Type
*
* @return Name or fully-qualified name.
*/
private static String typeReferenceName(ConversionContext conversionContext, Class> type) {
return conversionContext.getTypeFactory().getType( type ).createReferenceName();
}
/**
* Name for {@link java.math.BigDecimal}.
*
* @param conversionContext Conversion context
*
* @return Name or fully-qualified name.
*/
public static String bigDecimal(ConversionContext conversionContext) {
return typeReferenceName( conversionContext, BigDecimal.class );
}
/**
* Name for {@link java.math.BigInteger}.
*
* @param conversionContext Conversion context
*
* @return Name or fully-qualified name.
*/
public static String bigInteger(ConversionContext conversionContext) {
return typeReferenceName( conversionContext, BigInteger.class );
}
/**
* Name for {@link java.util.Locale}.
*
* @param conversionContext Conversion context
*
* @return Name or fully-qualified name.
*/
public static String locale(ConversionContext conversionContext) {
return typeReferenceName( conversionContext, Locale.class );
}
/**
* Name for {@link java.util.Currency}.
*
* @param conversionContext Conversion context
*
* @return Name or fully-qualified name.
*/
public static String currency(ConversionContext conversionContext) {
return typeReferenceName( conversionContext, Currency.class );
}
/**
* Name for {@link java.sql.Date}.
*
* @param conversionContext Conversion context
*
* @return Name or fully-qualified name.
*/
public static String sqlDate(ConversionContext conversionContext) {
return typeReferenceName( conversionContext, java.sql.Date.class );
}
/**
* Name for {@link java.sql.Time}.
*
* @param conversionContext Conversion context
*
* @return Name or fully-qualified name.
*/
public static String time(ConversionContext conversionContext) {
return typeReferenceName( conversionContext, Time.class );
}
/**
* Name for {@link java.sql.Timestamp}.
*
* @param conversionContext Conversion context
*
* @return Name or fully-qualified name.
*/
public static String timestamp(ConversionContext conversionContext) {
return typeReferenceName( conversionContext, Timestamp.class );
}
/**
* Name for {@link java.text.DecimalFormat}.
*
* @param conversionContext Conversion context
*
* @return Name or fully-qualified name.
*/
public static String decimalFormat(ConversionContext conversionContext) {
return typeReferenceName( conversionContext, DecimalFormat.class );
}
/**
* Name for {@link java.text.SimpleDateFormat}.
*
* @param conversionContext Conversion context
*
* @return Name or fully-qualified name.
*/
public static String simpleDateFormat(ConversionContext conversionContext) {
return typeReferenceName( conversionContext, SimpleDateFormat.class );
}
/**
* Name for {@link java.util.Date}.
*
* @param conversionContext Conversion context
*
* @return Name or fully-qualified name.
*/
public static String date(ConversionContext conversionContext) {
return typeReferenceName( conversionContext, java.util.Date.class );
}
/**
* Name for {@link java.time.ZoneOffset}.
*
* @param conversionContext Conversion context
*
* @return Name or fully-qualified name.
*/
public static String zoneOffset(ConversionContext conversionContext) {
return typeReferenceName( conversionContext, ZoneOffset.class );
}
/**
* Name for {@link java.time.ZoneId}.
*
* @param conversionContext Conversion context
*
* @return Name or fully-qualified name.
*/
public static String zoneId(ConversionContext conversionContext) {
return typeReferenceName( conversionContext, ZoneId.class );
}
/**
* Name for {@link java.time.LocalDate}.
*
* @param conversionContext Conversion context
*
* @return Name or fully-qualified name.
*/
public static String localDate(ConversionContext conversionContext) {
return typeReferenceName( conversionContext, LocalDate.class );
}
/**
* Name for {@link java.time.LocalDateTime}.
*
* @param conversionContext Conversion context
*
* @return Name or fully-qualified name.
*/
public static String localDateTime(ConversionContext conversionContext) {
return typeReferenceName( conversionContext, LocalDateTime.class );
}
/**
* Name for {@link java.time.ZonedDateTime}.
*
* @param conversionContext Conversion context
*
* @return Name or fully-qualified name.
*/
public static String zonedDateTime(ConversionContext conversionContext) {
return typeReferenceName( conversionContext, ZonedDateTime.class );
}
/**
* Name for {@link java.time.format.DateTimeFormatter}.
*
* @param conversionContext Conversion context
*
* @return Name or fully-qualified name.
*/
public static String dateTimeFormatter(ConversionContext conversionContext) {
return typeReferenceName( conversionContext, DateTimeFormatter.class );
}
/**
* Name for {@code org.joda.time.format.DateTimeFormat}.
*
* @param conversionContext Conversion context
*
* @return Name or fully-qualified name.
*/
public static String dateTimeFormat(ConversionContext conversionContext) {
return typeReferenceName( conversionContext, JodaTimeConstants.DATE_TIME_FORMAT_FQN );
}
/**
* Name for {@link java.lang.StringBuilder}.
*
* @param conversionContext Conversion context
*
* @return Name or fully-qualified name.
*/
public static String stringBuilder(ConversionContext conversionContext) {
return typeReferenceName( conversionContext, StringBuilder.class );
}
/**
* Name for {@link java.util.UUID}.
*
* @param conversionContext Conversion context
*
* @return Name or fully-qualified name.
*/
public static String uuid(ConversionContext conversionContext) {
return typeReferenceName( conversionContext, UUID.class );
}
/**
* Name for {@link java.net.URL}.
*
* @param conversionContext Conversion context
*
* @return Name or fully-qualified name.
*/
public static String url(ConversionContext conversionContext) {
return typeReferenceName( conversionContext, URL.class );
}
}