diff options
author | Eike Rathke <erack@redhat.com> | 2015-02-20 15:11:36 +0100 |
---|---|---|
committer | Eike Rathke <erack@redhat.com> | 2015-02-20 15:16:45 +0100 |
commit | 5d572e673dec3396487b14bb1f9e86aa8ab86786 (patch) | |
tree | 9f12c9403663a0430f6d61c3ffa28ef9dd2600af | |
parent | a33f97bae6edd1cac4df8cdb3d4fb3996f29a82e (diff) |
Resolves: tdf#89500 catch ISO 8601 datetime in all locales
Change-Id: I906ebdc6aa5c365df98a29e9e0f319f89f6833c6
-rw-r--r-- | svl/source/numbers/zforfind.cxx | 33 |
1 files changed, 26 insertions, 7 deletions
diff --git a/svl/source/numbers/zforfind.cxx b/svl/source/numbers/zforfind.cxx index 94498741f848..5011fe805fd4 100644 --- a/svl/source/numbers/zforfind.cxx +++ b/svl/source/numbers/zforfind.cxx @@ -2451,16 +2451,35 @@ bool ImpSvNumberInputScan::ScanMidString( const OUString& rString, SkipBlanks( rString, nPos ); } } - else if (nStringPos == 5 && nPos == 0 && rString.getLength() == 1 && - rString[ 0 ] == 'T' && MayBeIso8601()) + else if (nPos == 0 && rString.getLength() == 1 && MayBeIso8601()) { - // ISO 8601 combined date and time, yyyy-mm-ddThh:mm - ++nPos; + if (nStringPos == 5 && rString[0] == 'T') + { + // ISO 8601 combined date and time, yyyy-mm-ddThh:mm + ++nPos; + } + else if (nStringPos == 7 && rString[0] == ':') + { + // ISO 8601 combined date and time, the time part; we reach + // here if the locale's separator is not ':' so it couldn't + // be detected above in the time block. + if (nAnzNums >= 5) + eScannedType = NUMBERFORMAT_DATETIME; + ++nPos; + } } break; -#if NF_RECOGNIZE_ISO8601_TIMEZONES case NUMBERFORMAT_DATETIME: - if (nPos == 0 && rString.getLength() == 1 && nStringPos >= 9 && MayBeIso8601()) + if (nPos == 0 && rString.getLength() == 1 && MayBeIso8601()) + { + if (nStringPos == 9 && rString[0] == ':') + { + // ISO 8601 combined date and time, the time part continued. + ++nPos; + } + } +#if NF_RECOGNIZE_ISO8601_TIMEZONES + else if (nPos == 0 && rString.getLength() == 1 && nStringPos >= 9 && MayBeIso8601()) { // ISO 8601 timezone offset switch (rString[ 0 ]) @@ -2487,8 +2506,8 @@ bool ImpSvNumberInputScan::ScanMidString( const OUString& rString, break; } } - break; #endif + break; } } |