diff options
author | Eike Rathke <erack@redhat.com> | 2011-11-30 02:05:25 +0100 |
---|---|---|
committer | Eike Rathke <erack@redhat.com> | 2011-11-30 02:05:25 +0100 |
commit | 7613359985a89a42417a746bcdbb25f072784733 (patch) | |
tree | d7ed828c6839d323a1766adeaf57b92e3b8b8e88 /sax | |
parent | 07a7b2937a9427b2feb3307804ec0f527091bb92 (diff) |
handle dates with year < 1000
* Read dates with years consisting of less than 4 digits.
ISO 8601 specifies that years are to be written with a minimum of 4 digits.
However, be lenient in what we accept.
* Write years < 1000 with leading zeros to comply with ISO 8601 YYYY.
Diffstat (limited to 'sax')
-rw-r--r-- | sax/qa/cppunit/test_converter.cxx | 9 | ||||
-rw-r--r-- | sax/source/tools/converter.cxx | 19 |
2 files changed, 22 insertions, 6 deletions
diff --git a/sax/qa/cppunit/test_converter.cxx b/sax/qa/cppunit/test_converter.cxx index 923c7eb2413e..17d1303e901c 100644 --- a/sax/qa/cppunit/test_converter.cxx +++ b/sax/qa/cppunit/test_converter.cxx @@ -215,8 +215,13 @@ void ConverterTest::testDateTime() doTest( util::DateTime(0, 0, 0, 24, 1, 1, 333) /*(0, 0, 0, 0, 2, 1, 333)*/, "0333-01-01T24:00:00"/*, "0333-01-02T00:00:00"*/ ); - doTestDateTimeF( "+0001-01-01T00:00:00" ); // invalid: ^+ - doTestDateTimeF( "1-01-01T00:00:00" ); // invalid: < 4 Y + // A leading ^+ is NOT invalid, ISO 8601 specifies this for explicit AD/CE. + doTest( util::DateTime(0, 0, 0, 0, 1, 1, 1), + "+0001-01-01T00:00:00", "0001-01-01T00:00:00" ); + // While ISO 8601 specifies a minimum of 4 year digits we are lenient in + // what we accept. + doTest( util::DateTime(0, 0, 0, 0, 1, 1, 1), + "1-01-01T00:00:00", "0001-01-01T00:00:00" ); doTestDateTimeF( "0001-1-01T00:00:00" ); // invalid: < 2 M doTestDateTimeF( "0001-01-1T00:00:00" ); // invalid: < 2 D doTestDateTimeF( "0001-01-01T0:00:00" ); // invalid: < 2 H diff --git a/sax/source/tools/converter.cxx b/sax/source/tools/converter.cxx index b1629c8ec572..0c0779bac959 100644 --- a/sax/source/tools/converter.cxx +++ b/sax/source/tools/converter.cxx @@ -1345,15 +1345,26 @@ bool Converter::convertDateOrDateTime( const ::rtl::OUString string = rString.trim().toAsciiUpperCase(); sal_Int32 nPos(0); - if ((string.getLength() > nPos) && (sal_Unicode('-') == string[nPos])) + if (string.getLength() > nPos) { - //Negative Number - ++nPos; + if (sal_Unicode('-') == string[nPos]) + { + //Negative Number + ++nPos; + } + else if (sal_Unicode('+') == string[nPos]) + { + //Positive Number, explicit AD/CE + ++nPos; + } } sal_Int32 nYear(0); { - bSuccess = readDateTimeComponent(string, nPos, nYear, 4, false); + // While ISO 8601 specifies years with a minimum of 4 digits, be + // leninent in what we accept for years < 1000. One digit is acceptable + // if the remainders match. + bSuccess = readDateTimeComponent(string, nPos, nYear, 1, false); bSuccess &= (0 < nYear); bSuccess &= (nPos < string.getLength()); // not last token } |