LANG-1380: FastDateParser too strict on abbreviated short month symbols
This commit is contained in:
parent
ae6a24dd43
commit
f56931c176
|
@ -46,6 +46,7 @@ The <action> type attribute can be add,update,fix,remove.
|
||||||
<body>
|
<body>
|
||||||
|
|
||||||
<release version="3.8" date="2018-MM-DD" description="New features and bug fixes. Requires Java 7, supports Java 8, 9, 10.">
|
<release version="3.8" date="2018-MM-DD" description="New features and bug fixes. Requires Java 7, supports Java 8, 9, 10.">
|
||||||
|
<action issue="LANG-1380" type="fix" dev="chas" due-to="Markus Jelsma">FastDateParser too strict on abbreviated short month symbols</action>
|
||||||
<action issue="LANG-1396" type="fix" dev="sebb">JsonToStringStyle does not escape string names</action>
|
<action issue="LANG-1396" type="fix" dev="sebb">JsonToStringStyle does not escape string names</action>
|
||||||
<action issue="LANG-1395" type="fix" dev="sebb" due-to="Jim Gan">JsonToStringStyle does not escape double quote in a string value</action>
|
<action issue="LANG-1395" type="fix" dev="sebb" due-to="Jim Gan">JsonToStringStyle does not escape double quote in a string value</action>
|
||||||
<action issue="LANG-1384" type="fix" dev="erans" due-to="Ian Young">New Java version ("11") must be handled</action>
|
<action issue="LANG-1384" type="fix" dev="erans" due-to="Ian Young">New Java version ("11") must be handled</action>
|
||||||
|
|
|
@ -448,6 +448,10 @@ public class FastDateParser implements DateParser, Serializable {
|
||||||
sb.append(c);
|
sb.append(c);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if(sb.charAt(sb.length() - 1) == '.') {
|
||||||
|
// trailing '.' is optional
|
||||||
|
sb.append('?');
|
||||||
|
}
|
||||||
return sb;
|
return sb;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -713,7 +717,12 @@ public class FastDateParser implements DateParser, Serializable {
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
void setCalendar(final FastDateParser parser, final Calendar cal, final String value) {
|
void setCalendar(final FastDateParser parser, final Calendar cal, final String value) {
|
||||||
final Integer iVal = lKeyValues.get(value.toLowerCase(locale));
|
final String lowerCase = value.toLowerCase(locale);
|
||||||
|
Integer iVal = lKeyValues.get(lowerCase);
|
||||||
|
if(iVal == null) {
|
||||||
|
// match missing the optional trailing period
|
||||||
|
iVal = lKeyValues.get(lowerCase + '.');
|
||||||
|
}
|
||||||
cal.set(field, iVal.intValue());
|
cal.set(field, iVal.intValue());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -892,7 +901,12 @@ public class FastDateParser implements DateParser, Serializable {
|
||||||
if (tz != null) {
|
if (tz != null) {
|
||||||
cal.setTimeZone(tz);
|
cal.setTimeZone(tz);
|
||||||
} else {
|
} else {
|
||||||
final TzInfo tzInfo = tzNames.get(timeZone.toLowerCase(locale));
|
final String lowerCase = timeZone.toLowerCase(locale);
|
||||||
|
TzInfo tzInfo = tzNames.get(lowerCase);
|
||||||
|
if (tzInfo == null) {
|
||||||
|
// match missing the optional trailing period
|
||||||
|
tzInfo = tzNames.get(lowerCase + '.');
|
||||||
|
}
|
||||||
cal.set(Calendar.DST_OFFSET, tzInfo.dstOffset);
|
cal.set(Calendar.DST_OFFSET, tzInfo.dstOffset);
|
||||||
cal.set(Calendar.ZONE_OFFSET, tzInfo.zone.getRawOffset());
|
cal.set(Calendar.ZONE_OFFSET, tzInfo.zone.getRawOffset());
|
||||||
}
|
}
|
||||||
|
|
|
@ -32,7 +32,6 @@ import java.util.HashMap;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.TimeZone;
|
import java.util.TimeZone;
|
||||||
|
|
||||||
import org.apache.commons.lang3.LocaleUtils;
|
import org.apache.commons.lang3.LocaleUtils;
|
||||||
import org.apache.commons.lang3.SerializationUtils;
|
import org.apache.commons.lang3.SerializationUtils;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
@ -717,4 +716,16 @@ public class FastDateParserTest {
|
||||||
calendar.setTime(parser.parse("7"));
|
calendar.setTime(parser.parse("7"));
|
||||||
assertEquals(Calendar.SUNDAY, calendar.get(Calendar.DAY_OF_WEEK));
|
assertEquals(Calendar.SUNDAY, calendar.get(Calendar.DAY_OF_WEEK));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testLang1380() throws ParseException {
|
||||||
|
final Calendar expected = Calendar.getInstance(GMT, Locale.FRANCE);
|
||||||
|
expected.clear();
|
||||||
|
expected.set(2014, Calendar.APRIL, 14);
|
||||||
|
|
||||||
|
final DateParser fdp = getInstance("dd MMM yyyy", GMT, Locale.FRANCE);
|
||||||
|
assertEquals(expected.getTime(), fdp.parse("14 avril 2014"));
|
||||||
|
assertEquals(expected.getTime(), fdp.parse("14 avr. 2014"));
|
||||||
|
assertEquals(expected.getTime(), fdp.parse("14 avr 2014"));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue