mirror of
https://github.com/mapstruct/mapstruct.git
synced 2025-07-12 00:00:08 +08:00
#1425 Added findType to VirtualMappingMethod and use it in all builtin templates
Together with the includeModel directive this will ensure that the type will be written to the file as a FQN if required, otherwise as a simple name.
This commit is contained in:
parent
4f5db83de7
commit
5540efc482
@ -73,6 +73,7 @@ public class FullFeatureCompilationTest {
|
|||||||
case ECLIPSE_JDT_JAVA_6:
|
case ECLIPSE_JDT_JAVA_6:
|
||||||
case ORACLE_JAVA_7:
|
case ORACLE_JAVA_7:
|
||||||
case ECLIPSE_JDT_JAVA_7:
|
case ECLIPSE_JDT_JAVA_7:
|
||||||
|
additionalExcludes.add( "org/mapstruct/ap/test/bugs/_1425/*.java" );
|
||||||
additionalExcludes.add( "**/java8*/**/*.java" );
|
additionalExcludes.add( "**/java8*/**/*.java" );
|
||||||
break;
|
break;
|
||||||
case ORACLE_JAVA_9:
|
case ORACLE_JAVA_9:
|
||||||
|
@ -56,6 +56,29 @@ public class VirtualMappingMethod extends MappingMethod {
|
|||||||
return importTypes;
|
return importTypes;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Finds a {@link Type} by a given name. The {@code name} will be compared to the fully-qualified and also simple
|
||||||
|
* names of the {@code importTypes}.
|
||||||
|
*
|
||||||
|
* @param name Fully-qualified or simple name of the type.
|
||||||
|
*
|
||||||
|
* @return Found type, never <code>null</code>.
|
||||||
|
*
|
||||||
|
* @throws IllegalArgumentException In case no {@link Type} was found for given name.
|
||||||
|
*/
|
||||||
|
public Type findType(String name) {
|
||||||
|
for ( Type type : importTypes ) {
|
||||||
|
if ( type.getFullyQualifiedName().contentEquals( name ) ) {
|
||||||
|
return type;
|
||||||
|
}
|
||||||
|
if ( type.getName().contentEquals( name ) ) {
|
||||||
|
return type;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
throw new IllegalArgumentException( "No type for given name '" + name + "' found in 'importTypes'." );
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int hashCode() {
|
public int hashCode() {
|
||||||
final int prime = 31;
|
final int prime = 31;
|
||||||
|
@ -19,17 +19,17 @@
|
|||||||
limitations under the License.
|
limitations under the License.
|
||||||
|
|
||||||
-->
|
-->
|
||||||
private XMLGregorianCalendar ${name}( Calendar cal ) {
|
private <@includeModel object=findType("XMLGregorianCalendar")/> ${name}( <@includeModel object=findType("Calendar")/> cal ) {
|
||||||
if ( cal == null ) {
|
if ( cal == null ) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
GregorianCalendar gcal = new GregorianCalendar();
|
<@includeModel object=findType("GregorianCalendar")/> gcal = new <@includeModel object=findType("GregorianCalendar")/>();
|
||||||
gcal.setTimeInMillis( cal.getTimeInMillis() );
|
gcal.setTimeInMillis( cal.getTimeInMillis() );
|
||||||
return DatatypeFactory.newInstance().newXMLGregorianCalendar( gcal );
|
return <@includeModel object=findType("DatatypeFactory")/>.newInstance().newXMLGregorianCalendar( gcal );
|
||||||
}
|
}
|
||||||
catch ( DatatypeConfigurationException ex ) {
|
catch ( <@includeModel object=findType("DatatypeConfigurationException")/> ex ) {
|
||||||
throw new RuntimeException( ex );
|
throw new RuntimeException( ex );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -19,10 +19,10 @@
|
|||||||
limitations under the License.
|
limitations under the License.
|
||||||
|
|
||||||
-->
|
-->
|
||||||
private ZonedDateTime ${name}(Calendar cal) {
|
private <@includeModel object=findType("ZonedDateTime")/> ${name}(<@includeModel object=findType("Calendar")/> cal) {
|
||||||
if ( cal == null ) {
|
if ( cal == null ) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
return ZonedDateTime.ofInstant( cal.toInstant(), cal.getTimeZone().toZoneId() );
|
return <@includeModel object=findType("ZonedDateTime")/>.ofInstant( cal.toInstant(), cal.getTimeZone().toZoneId() );
|
||||||
}
|
}
|
||||||
|
@ -19,17 +19,17 @@
|
|||||||
limitations under the License.
|
limitations under the License.
|
||||||
|
|
||||||
-->
|
-->
|
||||||
private XMLGregorianCalendar ${name}( Date date ) {
|
private <@includeModel object=findType("XMLGregorianCalendar")/> ${name}( <@includeModel object=findType("Date")/> date ) {
|
||||||
if ( date == null ) {
|
if ( date == null ) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
GregorianCalendar c = new GregorianCalendar();
|
<@includeModel object=findType("GregorianCalendar")/> c = new <@includeModel object=findType("GregorianCalendar")/>();
|
||||||
c.setTime( date );
|
c.setTime( date );
|
||||||
return DatatypeFactory.newInstance().newXMLGregorianCalendar( c );
|
return <@includeModel object=findType("DatatypeFactory")/>.newInstance().newXMLGregorianCalendar( c );
|
||||||
}
|
}
|
||||||
catch ( DatatypeConfigurationException ex ) {
|
catch ( <@includeModel object=findType("DatatypeConfigurationException")/> ex ) {
|
||||||
throw new RuntimeException( ex );
|
throw new RuntimeException( ex );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -19,7 +19,7 @@
|
|||||||
limitations under the License.
|
limitations under the License.
|
||||||
|
|
||||||
-->
|
-->
|
||||||
private <T> T ${name}( JAXBElement<T> element ) {
|
private <T> T ${name}( <@includeModel object=findType("JAXBElement") raw=true/><T> element ) {
|
||||||
if ( element == null ) {
|
if ( element == null ) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
@ -19,13 +19,13 @@
|
|||||||
limitations under the License.
|
limitations under the License.
|
||||||
|
|
||||||
-->
|
-->
|
||||||
private XMLGregorianCalendar ${name}( DateTime dt ) {
|
private <@includeModel object=findType("XMLGregorianCalendar")/> ${name}( <@includeModel object=findType("DateTime")/> dt ) {
|
||||||
if ( dt == null ) {
|
if ( dt == null ) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
return DatatypeFactory.newInstance().newXMLGregorianCalendar(
|
return <@includeModel object=findType("DatatypeFactory")/>.newInstance().newXMLGregorianCalendar(
|
||||||
dt.getYear(),
|
dt.getYear(),
|
||||||
dt.getMonthOfYear(),
|
dt.getMonthOfYear(),
|
||||||
dt.getDayOfMonth(),
|
dt.getDayOfMonth(),
|
||||||
@ -35,7 +35,7 @@ private XMLGregorianCalendar ${name}( DateTime dt ) {
|
|||||||
dt.getMillisOfSecond(),
|
dt.getMillisOfSecond(),
|
||||||
dt.getZone().getOffset( null ) / 60000 );
|
dt.getZone().getOffset( null ) / 60000 );
|
||||||
}
|
}
|
||||||
catch ( DatatypeConfigurationException ex ) {
|
catch ( <@includeModel object=findType("DatatypeConfigurationException")/> ex ) {
|
||||||
throw new RuntimeException( ex );
|
throw new RuntimeException( ex );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -19,13 +19,13 @@
|
|||||||
limitations under the License.
|
limitations under the License.
|
||||||
|
|
||||||
-->
|
-->
|
||||||
private XMLGregorianCalendar ${name}( LocalDateTime dt ) {
|
private <@includeModel object=findType("XMLGregorianCalendar")/> ${name}( <@includeModel object=findType("org.joda.time.LocalDateTime")/> dt ) {
|
||||||
if ( dt == null ) {
|
if ( dt == null ) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
return DatatypeFactory.newInstance().newXMLGregorianCalendar(
|
return <@includeModel object=findType("DatatypeFactory")/>.newInstance().newXMLGregorianCalendar(
|
||||||
dt.getYear(),
|
dt.getYear(),
|
||||||
dt.getMonthOfYear(),
|
dt.getMonthOfYear(),
|
||||||
dt.getDayOfMonth(),
|
dt.getDayOfMonth(),
|
||||||
@ -33,9 +33,9 @@ private XMLGregorianCalendar ${name}( LocalDateTime dt ) {
|
|||||||
dt.getMinuteOfHour(),
|
dt.getMinuteOfHour(),
|
||||||
dt.getSecondOfMinute(),
|
dt.getSecondOfMinute(),
|
||||||
dt.getMillisOfSecond(),
|
dt.getMillisOfSecond(),
|
||||||
DatatypeConstants.FIELD_UNDEFINED );
|
<@includeModel object=findType("DatatypeConstants")/>.FIELD_UNDEFINED );
|
||||||
}
|
}
|
||||||
catch ( DatatypeConfigurationException ex ) {
|
catch ( <@includeModel object=findType("DatatypeConfigurationException")/> ex ) {
|
||||||
throw new RuntimeException( ex );
|
throw new RuntimeException( ex );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -19,19 +19,19 @@
|
|||||||
limitations under the License.
|
limitations under the License.
|
||||||
|
|
||||||
-->
|
-->
|
||||||
private XMLGregorianCalendar ${name}( LocalDate dt ) {
|
private <@includeModel object=findType("XMLGregorianCalendar")/> ${name}( <@includeModel object=findType("org.joda.time.LocalDate")/> dt ) {
|
||||||
if ( dt == null ) {
|
if ( dt == null ) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
return DatatypeFactory.newInstance().newXMLGregorianCalendarDate(
|
return <@includeModel object=findType("DatatypeFactory")/>.newInstance().newXMLGregorianCalendarDate(
|
||||||
dt.getYear(),
|
dt.getYear(),
|
||||||
dt.getMonthOfYear(),
|
dt.getMonthOfYear(),
|
||||||
dt.getDayOfMonth(),
|
dt.getDayOfMonth(),
|
||||||
DatatypeConstants.FIELD_UNDEFINED );
|
<@includeModel object=findType("DatatypeConstants")/>.FIELD_UNDEFINED );
|
||||||
}
|
}
|
||||||
catch ( DatatypeConfigurationException ex ) {
|
catch ( <@includeModel object=findType("DatatypeConfigurationException")/> ex ) {
|
||||||
throw new RuntimeException( ex );
|
throw new RuntimeException( ex );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -19,20 +19,20 @@
|
|||||||
limitations under the License.
|
limitations under the License.
|
||||||
|
|
||||||
-->
|
-->
|
||||||
private XMLGregorianCalendar ${name}( LocalTime dt ) {
|
private <@includeModel object=findType("XMLGregorianCalendar")/> ${name}( <@includeModel object=findType("org.joda.time.LocalTime")/> dt ) {
|
||||||
if ( dt == null ) {
|
if ( dt == null ) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
return DatatypeFactory.newInstance().newXMLGregorianCalendarTime(
|
return <@includeModel object=findType("DatatypeFactory")/>.newInstance().newXMLGregorianCalendarTime(
|
||||||
dt.getHourOfDay(),
|
dt.getHourOfDay(),
|
||||||
dt.getMinuteOfHour(),
|
dt.getMinuteOfHour(),
|
||||||
dt.getSecondOfMinute(),
|
dt.getSecondOfMinute(),
|
||||||
dt.getMillisOfSecond(),
|
dt.getMillisOfSecond(),
|
||||||
DatatypeConstants.FIELD_UNDEFINED );
|
<@includeModel object=findType("DatatypeConstants")/>.FIELD_UNDEFINED );
|
||||||
}
|
}
|
||||||
catch ( DatatypeConfigurationException ex ) {
|
catch ( <@includeModel object=findType("DatatypeConfigurationException")/> ex ) {
|
||||||
throw new RuntimeException( ex );
|
throw new RuntimeException( ex );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -19,20 +19,20 @@
|
|||||||
limitations under the License.
|
limitations under the License.
|
||||||
|
|
||||||
-->
|
-->
|
||||||
private static XMLGregorianCalendar ${name}( java.time.LocalDate localDate ) {
|
private static <@includeModel object=findType("XMLGregorianCalendar")/> ${name}( <@includeModel object=findType("java.time.LocalDate")/> localDate ) {
|
||||||
if ( localDate == null ) {
|
if ( localDate == null ) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
return DatatypeFactory.newInstance().newXMLGregorianCalendarDate(
|
return <@includeModel object=findType("DatatypeFactory")/>.newInstance().newXMLGregorianCalendarDate(
|
||||||
localDate.getYear(),
|
localDate.getYear(),
|
||||||
localDate.getMonthValue(),
|
localDate.getMonthValue(),
|
||||||
localDate.getDayOfMonth(),
|
localDate.getDayOfMonth(),
|
||||||
DatatypeConstants.FIELD_UNDEFINED
|
<@includeModel object=findType("DatatypeConstants")/>.FIELD_UNDEFINED
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
catch ( DatatypeConfigurationException ex ) {
|
catch ( <@includeModel object=findType("DatatypeConfigurationException")/> ex ) {
|
||||||
throw new RuntimeException( ex );
|
throw new RuntimeException( ex );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -19,26 +19,26 @@
|
|||||||
limitations under the License.
|
limitations under the License.
|
||||||
|
|
||||||
-->
|
-->
|
||||||
private XMLGregorianCalendar ${name}( String date, String dateFormat ) {
|
private <@includeModel object=findType("XMLGregorianCalendar")/> ${name}( String date, String dateFormat ) {
|
||||||
if ( date == null ) {
|
if ( date == null ) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
if ( dateFormat != null ) {
|
if ( dateFormat != null ) {
|
||||||
DateFormat df = new SimpleDateFormat( dateFormat );
|
<@includeModel object=findType("DateFormat")/> df = new <@includeModel object=findType("SimpleDateFormat")/>( dateFormat );
|
||||||
GregorianCalendar c = new GregorianCalendar();
|
<@includeModel object=findType("GregorianCalendar")/> c = new <@includeModel object=findType("GregorianCalendar")/>();
|
||||||
c.setTime( df.parse( date ) );
|
c.setTime( df.parse( date ) );
|
||||||
return DatatypeFactory.newInstance().newXMLGregorianCalendar( c );
|
return <@includeModel object=findType("DatatypeFactory")/>.newInstance().newXMLGregorianCalendar( c );
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
return DatatypeFactory.newInstance().newXMLGregorianCalendar( date );
|
return <@includeModel object=findType("DatatypeFactory")/>.newInstance().newXMLGregorianCalendar( date );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch ( DatatypeConfigurationException ex ) {
|
catch ( <@includeModel object=findType("DatatypeConfigurationException")/> ex ) {
|
||||||
throw new RuntimeException( ex );
|
throw new RuntimeException( ex );
|
||||||
}
|
}
|
||||||
catch ( ParseException ex ) {
|
catch ( <@includeModel object=findType("ParseException")/> ex ) {
|
||||||
throw new RuntimeException( ex );
|
throw new RuntimeException( ex );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -19,12 +19,12 @@
|
|||||||
limitations under the License.
|
limitations under the License.
|
||||||
|
|
||||||
-->
|
-->
|
||||||
private Calendar ${name}( XMLGregorianCalendar xcal ) {
|
private <@includeModel object=findType("Calendar")/> ${name}( <@includeModel object=findType("XMLGregorianCalendar")/> xcal ) {
|
||||||
if ( xcal == null ) {
|
if ( xcal == null ) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
Calendar cal = Calendar.getInstance();
|
<@includeModel object=findType("Calendar")/> cal = <@includeModel object=findType("Calendar")/>.getInstance();
|
||||||
cal.setTimeInMillis( xcal.toGregorianCalendar().getTimeInMillis() );
|
cal.setTimeInMillis( xcal.toGregorianCalendar().getTimeInMillis() );
|
||||||
return cal;
|
return cal;
|
||||||
}
|
}
|
||||||
|
@ -19,7 +19,7 @@
|
|||||||
limitations under the License.
|
limitations under the License.
|
||||||
|
|
||||||
-->
|
-->
|
||||||
private static Date ${name}( XMLGregorianCalendar xcal ) {
|
private static <@includeModel object=findType("java.util.Date")/> ${name}( <@includeModel object=findType("XMLGregorianCalendar")/> xcal ) {
|
||||||
if ( xcal == null ) {
|
if ( xcal == null ) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
@ -19,33 +19,33 @@
|
|||||||
limitations under the License.
|
limitations under the License.
|
||||||
|
|
||||||
-->
|
-->
|
||||||
private static DateTime ${name}( XMLGregorianCalendar xcal ) {
|
private static <@includeModel object=findType("DateTime")/> ${name}( <@includeModel object=findType("XMLGregorianCalendar")/> xcal ) {
|
||||||
if ( xcal == null ) {
|
if ( xcal == null ) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( xcal.getYear() != DatatypeConstants.FIELD_UNDEFINED
|
if ( xcal.getYear() != <@includeModel object=findType("DatatypeConstants")/>.FIELD_UNDEFINED
|
||||||
&& xcal.getMonth() != DatatypeConstants.FIELD_UNDEFINED
|
&& xcal.getMonth() != <@includeModel object=findType("DatatypeConstants")/>.FIELD_UNDEFINED
|
||||||
&& xcal.getDay() != DatatypeConstants.FIELD_UNDEFINED
|
&& xcal.getDay() != <@includeModel object=findType("DatatypeConstants")/>.FIELD_UNDEFINED
|
||||||
&& xcal.getHour() != DatatypeConstants.FIELD_UNDEFINED
|
&& xcal.getHour() != <@includeModel object=findType("DatatypeConstants")/>.FIELD_UNDEFINED
|
||||||
&& xcal.getMinute() != DatatypeConstants.FIELD_UNDEFINED
|
&& xcal.getMinute() != <@includeModel object=findType("DatatypeConstants")/>.FIELD_UNDEFINED
|
||||||
) {
|
) {
|
||||||
if ( xcal.getSecond() != DatatypeConstants.FIELD_UNDEFINED
|
if ( xcal.getSecond() != <@includeModel object=findType("DatatypeConstants")/>.FIELD_UNDEFINED
|
||||||
&& xcal.getMillisecond() != DatatypeConstants.FIELD_UNDEFINED
|
&& xcal.getMillisecond() != <@includeModel object=findType("DatatypeConstants")/>.FIELD_UNDEFINED
|
||||||
&& xcal.getTimezone() != DatatypeConstants.FIELD_UNDEFINED ) {
|
&& xcal.getTimezone() != <@includeModel object=findType("DatatypeConstants")/>.FIELD_UNDEFINED ) {
|
||||||
return new DateTime( xcal.getYear(),
|
return new <@includeModel object=findType("DateTime")/>( xcal.getYear(),
|
||||||
xcal.getMonth(),
|
xcal.getMonth(),
|
||||||
xcal.getDay(),
|
xcal.getDay(),
|
||||||
xcal.getHour(),
|
xcal.getHour(),
|
||||||
xcal.getMinute(),
|
xcal.getMinute(),
|
||||||
xcal.getSecond(),
|
xcal.getSecond(),
|
||||||
xcal.getMillisecond(),
|
xcal.getMillisecond(),
|
||||||
DateTimeZone.forOffsetMillis( xcal.getTimezone() * 60000 )
|
<@includeModel object=findType("DateTimeZone")/>.forOffsetMillis( xcal.getTimezone() * 60000 )
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
else if ( xcal.getSecond() != DatatypeConstants.FIELD_UNDEFINED
|
else if ( xcal.getSecond() != <@includeModel object=findType("DatatypeConstants")/>.FIELD_UNDEFINED
|
||||||
&& xcal.getMillisecond() != DatatypeConstants.FIELD_UNDEFINED ) {
|
&& xcal.getMillisecond() != <@includeModel object=findType("DatatypeConstants")/>.FIELD_UNDEFINED ) {
|
||||||
return new DateTime( xcal.getYear(),
|
return new <@includeModel object=findType("DateTime")/>( xcal.getYear(),
|
||||||
xcal.getMonth(),
|
xcal.getMonth(),
|
||||||
xcal.getDay(),
|
xcal.getDay(),
|
||||||
xcal.getHour(),
|
xcal.getHour(),
|
||||||
@ -54,19 +54,19 @@ private static DateTime ${name}( XMLGregorianCalendar xcal ) {
|
|||||||
xcal.getMillisecond()
|
xcal.getMillisecond()
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
else if ( xcal.getSecond() != DatatypeConstants.FIELD_UNDEFINED
|
else if ( xcal.getSecond() != <@includeModel object=findType("DatatypeConstants")/>.FIELD_UNDEFINED
|
||||||
&& xcal.getTimezone() != DatatypeConstants.FIELD_UNDEFINED ) {
|
&& xcal.getTimezone() != <@includeModel object=findType("DatatypeConstants")/>.FIELD_UNDEFINED ) {
|
||||||
return new DateTime( xcal.getYear(),
|
return new <@includeModel object=findType("DateTime")/>( xcal.getYear(),
|
||||||
xcal.getMonth(),
|
xcal.getMonth(),
|
||||||
xcal.getDay(),
|
xcal.getDay(),
|
||||||
xcal.getHour(),
|
xcal.getHour(),
|
||||||
xcal.getMinute(),
|
xcal.getMinute(),
|
||||||
xcal.getSecond(),
|
xcal.getSecond(),
|
||||||
DateTimeZone.forOffsetMillis( xcal.getTimezone() * 60000 )
|
<@includeModel object=findType("DateTimeZone")/>.forOffsetMillis( xcal.getTimezone() * 60000 )
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
else if ( xcal.getSecond() != DatatypeConstants.FIELD_UNDEFINED ) {
|
else if ( xcal.getSecond() != <@includeModel object=findType("DatatypeConstants")/>.FIELD_UNDEFINED ) {
|
||||||
return new DateTime( xcal.getYear(),
|
return new <@includeModel object=findType("DateTime")/>( xcal.getYear(),
|
||||||
xcal.getMonth(),
|
xcal.getMonth(),
|
||||||
xcal.getDay(),
|
xcal.getDay(),
|
||||||
xcal.getHour(),
|
xcal.getHour(),
|
||||||
@ -74,17 +74,17 @@ private static DateTime ${name}( XMLGregorianCalendar xcal ) {
|
|||||||
xcal.getSecond()
|
xcal.getSecond()
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
else if ( xcal.getTimezone() != DatatypeConstants.FIELD_UNDEFINED ) {
|
else if ( xcal.getTimezone() != <@includeModel object=findType("DatatypeConstants")/>.FIELD_UNDEFINED ) {
|
||||||
return new DateTime( xcal.getYear(),
|
return new <@includeModel object=findType("DateTime")/>( xcal.getYear(),
|
||||||
xcal.getMonth(),
|
xcal.getMonth(),
|
||||||
xcal.getDay(),
|
xcal.getDay(),
|
||||||
xcal.getHour(),
|
xcal.getHour(),
|
||||||
xcal.getMinute(),
|
xcal.getMinute(),
|
||||||
DateTimeZone.forOffsetMillis( xcal.getTimezone() * 60000 )
|
<@includeModel object=findType("DateTimeZone")/>.forOffsetMillis( xcal.getTimezone() * 60000 )
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
return new DateTime( xcal.getYear(),
|
return new <@includeModel object=findType("DateTime")/>( xcal.getYear(),
|
||||||
xcal.getMonth(),
|
xcal.getMonth(),
|
||||||
xcal.getDay(),
|
xcal.getDay(),
|
||||||
xcal.getHour(),
|
xcal.getHour(),
|
||||||
|
@ -19,15 +19,15 @@
|
|||||||
limitations under the License.
|
limitations under the License.
|
||||||
|
|
||||||
-->
|
-->
|
||||||
private static LocalDate ${name}( XMLGregorianCalendar xcal ) {
|
private static <@includeModel object=findType("org.joda.time.LocalDate")/> ${name}( <@includeModel object=findType("XMLGregorianCalendar")/> xcal ) {
|
||||||
if ( xcal == null ) {
|
if ( xcal == null ) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( xcal.getYear() != DatatypeConstants.FIELD_UNDEFINED
|
if ( xcal.getYear() != <@includeModel object=findType("DatatypeConstants")/>.FIELD_UNDEFINED
|
||||||
&& xcal.getMonth() != DatatypeConstants.FIELD_UNDEFINED
|
&& xcal.getMonth() != <@includeModel object=findType("DatatypeConstants")/>.FIELD_UNDEFINED
|
||||||
&& xcal.getDay() != DatatypeConstants.FIELD_UNDEFINED ) {
|
&& xcal.getDay() != <@includeModel object=findType("DatatypeConstants")/>.FIELD_UNDEFINED ) {
|
||||||
return new LocalDate( xcal.getYear(), xcal.getMonth(), xcal.getDay() );
|
return new <@includeModel object=findType("org.joda.time.LocalDate")/>( xcal.getYear(), xcal.getMonth(), xcal.getDay() );
|
||||||
}
|
}
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
|
@ -19,20 +19,20 @@
|
|||||||
limitations under the License.
|
limitations under the License.
|
||||||
|
|
||||||
-->
|
-->
|
||||||
private static LocalDateTime ${name}( XMLGregorianCalendar xcal ) {
|
private static <@includeModel object=findType("org.joda.time.LocalDateTime")/> ${name}( <@includeModel object=findType("XMLGregorianCalendar")/> xcal ) {
|
||||||
if ( xcal == null ) {
|
if ( xcal == null ) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( xcal.getYear() != DatatypeConstants.FIELD_UNDEFINED
|
if ( xcal.getYear() != <@includeModel object=findType("DatatypeConstants")/>.FIELD_UNDEFINED
|
||||||
&& xcal.getMonth() != DatatypeConstants.FIELD_UNDEFINED
|
&& xcal.getMonth() != <@includeModel object=findType("DatatypeConstants")/>.FIELD_UNDEFINED
|
||||||
&& xcal.getDay() != DatatypeConstants.FIELD_UNDEFINED
|
&& xcal.getDay() != <@includeModel object=findType("DatatypeConstants")/>.FIELD_UNDEFINED
|
||||||
&& xcal.getHour() != DatatypeConstants.FIELD_UNDEFINED
|
&& xcal.getHour() != <@includeModel object=findType("DatatypeConstants")/>.FIELD_UNDEFINED
|
||||||
&& xcal.getMinute() != DatatypeConstants.FIELD_UNDEFINED
|
&& xcal.getMinute() != <@includeModel object=findType("DatatypeConstants")/>.FIELD_UNDEFINED
|
||||||
) {
|
) {
|
||||||
if ( xcal.getSecond() != DatatypeConstants.FIELD_UNDEFINED
|
if ( xcal.getSecond() != <@includeModel object=findType("DatatypeConstants")/>.FIELD_UNDEFINED
|
||||||
&& xcal.getMillisecond() != DatatypeConstants.FIELD_UNDEFINED ) {
|
&& xcal.getMillisecond() != <@includeModel object=findType("DatatypeConstants")/>.FIELD_UNDEFINED ) {
|
||||||
return new LocalDateTime( xcal.getYear(),
|
return new <@includeModel object=findType("org.joda.time.LocalDateTime")/>( xcal.getYear(),
|
||||||
xcal.getMonth(),
|
xcal.getMonth(),
|
||||||
xcal.getDay(),
|
xcal.getDay(),
|
||||||
xcal.getHour(),
|
xcal.getHour(),
|
||||||
@ -41,8 +41,8 @@ private static LocalDateTime ${name}( XMLGregorianCalendar xcal ) {
|
|||||||
xcal.getMillisecond()
|
xcal.getMillisecond()
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
else if ( xcal.getSecond() != DatatypeConstants.FIELD_UNDEFINED ) {
|
else if ( xcal.getSecond() != <@includeModel object=findType("DatatypeConstants")/>.FIELD_UNDEFINED ) {
|
||||||
return new LocalDateTime( xcal.getYear(),
|
return new <@includeModel object=findType("org.joda.time.LocalDateTime")/>( xcal.getYear(),
|
||||||
xcal.getMonth(),
|
xcal.getMonth(),
|
||||||
xcal.getDay(),
|
xcal.getDay(),
|
||||||
xcal.getHour(),
|
xcal.getHour(),
|
||||||
@ -51,7 +51,7 @@ private static LocalDateTime ${name}( XMLGregorianCalendar xcal ) {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
return new LocalDateTime( xcal.getYear(),
|
return new <@includeModel object=findType("org.joda.time.LocalDateTime")/>( xcal.getYear(),
|
||||||
xcal.getMonth(),
|
xcal.getMonth(),
|
||||||
xcal.getDay(),
|
xcal.getDay(),
|
||||||
xcal.getHour(),
|
xcal.getHour(),
|
||||||
|
@ -19,30 +19,30 @@
|
|||||||
limitations under the License.
|
limitations under the License.
|
||||||
|
|
||||||
-->
|
-->
|
||||||
private static LocalTime ${name}( XMLGregorianCalendar xcal ) {
|
private static <@includeModel object=findType("org.joda.time.LocalTime")/> ${name}( <@includeModel object=findType("XMLGregorianCalendar")/> xcal ) {
|
||||||
if ( xcal == null ) {
|
if ( xcal == null ) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( xcal.getHour() != DatatypeConstants.FIELD_UNDEFINED
|
if ( xcal.getHour() != <@includeModel object=findType("DatatypeConstants")/>.FIELD_UNDEFINED
|
||||||
&& xcal.getMinute() != DatatypeConstants.FIELD_UNDEFINED ) {
|
&& xcal.getMinute() != <@includeModel object=findType("DatatypeConstants")/>.FIELD_UNDEFINED ) {
|
||||||
if ( xcal.getSecond() != DatatypeConstants.FIELD_UNDEFINED
|
if ( xcal.getSecond() != <@includeModel object=findType("DatatypeConstants")/>.FIELD_UNDEFINED
|
||||||
&& xcal.getMillisecond() != DatatypeConstants.FIELD_UNDEFINED ) {
|
&& xcal.getMillisecond() != <@includeModel object=findType("DatatypeConstants")/>.FIELD_UNDEFINED ) {
|
||||||
return new LocalTime( xcal.getHour(),
|
return new <@includeModel object=findType("org.joda.time.LocalTime")/>( xcal.getHour(),
|
||||||
xcal.getMinute(),
|
xcal.getMinute(),
|
||||||
xcal.getSecond(),
|
xcal.getSecond(),
|
||||||
xcal.getMillisecond()
|
xcal.getMillisecond()
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
else if ( xcal.getSecond() != DatatypeConstants.FIELD_UNDEFINED ) {
|
else if ( xcal.getSecond() != <@includeModel object=findType("DatatypeConstants")/>.FIELD_UNDEFINED ) {
|
||||||
return new LocalTime(
|
return new <@includeModel object=findType("org.joda.time.LocalTime")/>(
|
||||||
xcal.getHour(),
|
xcal.getHour(),
|
||||||
xcal.getMinute(),
|
xcal.getMinute(),
|
||||||
xcal.getSecond()
|
xcal.getSecond()
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
return new LocalTime( xcal.getHour(),
|
return new <@includeModel object=findType("org.joda.time.LocalTime")/>( xcal.getHour(),
|
||||||
xcal.getMinute()
|
xcal.getMinute()
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -19,10 +19,10 @@
|
|||||||
limitations under the License.
|
limitations under the License.
|
||||||
|
|
||||||
-->
|
-->
|
||||||
private static java.time.LocalDate ${name}( XMLGregorianCalendar xcal ) {
|
private static <@includeModel object=findType("java.time.LocalDate")/> ${name}( <@includeModel object=findType("XMLGregorianCalendar")/> xcal ) {
|
||||||
if ( xcal == null ) {
|
if ( xcal == null ) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
return java.time.LocalDate.of( xcal.getYear(), xcal.getMonth(), xcal.getDay() );
|
return <@includeModel object=findType("java.time.LocalDate")/>.of( xcal.getYear(), xcal.getMonth(), xcal.getDay() );
|
||||||
}
|
}
|
||||||
|
@ -19,7 +19,7 @@
|
|||||||
limitations under the License.
|
limitations under the License.
|
||||||
|
|
||||||
-->
|
-->
|
||||||
private String ${name}( XMLGregorianCalendar xcal, String dateFormat ) {
|
private String ${name}( <@includeModel object=findType("XMLGregorianCalendar")/> xcal, String dateFormat ) {
|
||||||
if ( xcal == null ) {
|
if ( xcal == null ) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
@ -28,8 +28,8 @@ private String ${name}( XMLGregorianCalendar xcal, String dateFormat ) {
|
|||||||
return xcal.toString();
|
return xcal.toString();
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
Date d = xcal.toGregorianCalendar().getTime();
|
<@includeModel object=findType("java.util.Date")/> d = xcal.toGregorianCalendar().getTime();
|
||||||
SimpleDateFormat sdf = new SimpleDateFormat( dateFormat );
|
<@includeModel object=findType("SimpleDateFormat")/> sdf = new <@includeModel object=findType("SimpleDateFormat")/>( dateFormat );
|
||||||
return sdf.format( d );
|
return sdf.format( d );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -19,12 +19,12 @@
|
|||||||
limitations under the License.
|
limitations under the License.
|
||||||
|
|
||||||
-->
|
-->
|
||||||
private Calendar ${name}(ZonedDateTime dateTime) {
|
private <@includeModel object=findType("Calendar")/> ${name}(<@includeModel object=findType("ZonedDateTime")/> dateTime) {
|
||||||
if ( dateTime == null ) {
|
if ( dateTime == null ) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
Calendar instance = Calendar.getInstance( TimeZone.getTimeZone( dateTime.getZone() ) );
|
<@includeModel object=findType("Calendar")/> instance = <@includeModel object=findType("Calendar")/>.getInstance( TimeZone.getTimeZone( dateTime.getZone() ) );
|
||||||
instance.setTimeInMillis( dateTime.toInstant().toEpochMilli() );
|
instance.setTimeInMillis( dateTime.toInstant().toEpochMilli() );
|
||||||
return instance;
|
return instance;
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,39 @@
|
|||||||
|
/**
|
||||||
|
* Copyright 2012-2017 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.test.bugs._1425;
|
||||||
|
|
||||||
|
import java.time.LocalDate;
|
||||||
|
|
||||||
|
import org.mapstruct.Mapper;
|
||||||
|
import org.mapstruct.factory.Mappers;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author Christian Bandowski
|
||||||
|
*/
|
||||||
|
@Mapper
|
||||||
|
public abstract class Issue1425Mapper {
|
||||||
|
|
||||||
|
public static final Issue1425Mapper INSTANCE = Mappers.getMapper( Issue1425Mapper.class );
|
||||||
|
|
||||||
|
public abstract Target map(Source source);
|
||||||
|
|
||||||
|
LocalDate now() {
|
||||||
|
return LocalDate.now();
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,52 @@
|
|||||||
|
/**
|
||||||
|
* Copyright 2012-2017 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.test.bugs._1425;
|
||||||
|
|
||||||
|
import org.joda.time.LocalDate;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.mapstruct.ap.testutil.IssueKey;
|
||||||
|
import org.mapstruct.ap.testutil.WithClasses;
|
||||||
|
import org.mapstruct.ap.testutil.runner.AnnotationProcessorTestRunner;
|
||||||
|
|
||||||
|
import static org.assertj.core.api.Assertions.assertThat;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author Christian Bandowski
|
||||||
|
*/
|
||||||
|
@WithClasses({
|
||||||
|
Issue1425Mapper.class,
|
||||||
|
Source.class,
|
||||||
|
Target.class
|
||||||
|
})
|
||||||
|
@RunWith(AnnotationProcessorTestRunner.class)
|
||||||
|
@IssueKey("1425")
|
||||||
|
public class Issue1425Test {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void shouldTestMappingLocalDates() {
|
||||||
|
Source source = new Source();
|
||||||
|
source.setValue( LocalDate.parse( "2018-04-18" ) );
|
||||||
|
|
||||||
|
Target target = Issue1425Mapper.INSTANCE.map( source );
|
||||||
|
|
||||||
|
assertThat( target ).isNotNull();
|
||||||
|
assertThat( target.getValue() ).isEqualTo( "2018-04-18" );
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,37 @@
|
|||||||
|
/**
|
||||||
|
* Copyright 2012-2017 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.test.bugs._1425;
|
||||||
|
|
||||||
|
import org.joda.time.LocalDate;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author Christian Bandowski
|
||||||
|
*/
|
||||||
|
public class Source {
|
||||||
|
|
||||||
|
private LocalDate value;
|
||||||
|
|
||||||
|
public LocalDate getValue() {
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setValue(LocalDate value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,37 @@
|
|||||||
|
/**
|
||||||
|
* Copyright 2012-2017 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.test.bugs._1425;
|
||||||
|
|
||||||
|
import java.time.LocalDate;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author Christian Bandowski
|
||||||
|
*/
|
||||||
|
public class Target {
|
||||||
|
|
||||||
|
private LocalDate value;
|
||||||
|
|
||||||
|
public LocalDate getValue() {
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setValue(LocalDate value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user