[Libreoffice-commits] core.git: shell/inc shell/source

Muhammet Kara muhammet.kara at pardus.org.tr
Tue Apr 19 08:37:06 UTC 2016


 shell/inc/iso8601_converter.hxx                            |    3 ++-
 shell/source/win32/shlxthandler/util/iso8601_converter.cxx |    9 +++++++++
 2 files changed, 11 insertions(+), 1 deletion(-)

New commits:
commit 97dee1df42dc2933d1350eb1e67361674614417a
Author: Muhammet Kara <muhammet.kara at pardus.org.tr>
Date:   Mon Apr 18 17:18:47 2016 +0300

    WIP tdf#89609 Ignore subsecond precision in iso8601
    
    Explorer shell extension fails to convert date
    into locale specific string if it has sub-second
    precision.
    
    Change-Id: I11bd38fc2876aa1f8235dbfb8c7850ff22ac2a8b
    Reviewed-on: https://gerrit.libreoffice.org/24220
    Tested-by: Jenkins <ci at libreoffice.org>
    Reviewed-by: jan iversen <jani at documentfoundation.org>

diff --git a/shell/inc/iso8601_converter.hxx b/shell/inc/iso8601_converter.hxx
index ee68282..570cecb 100644
--- a/shell/inc/iso8601_converter.hxx
+++ b/shell/inc/iso8601_converter.hxx
@@ -25,7 +25,8 @@
 
 /* Converts ISO 8601 conform date/time
    represenation to the representation
-   conforming to the current locale
+   conforming to the current locale,
+   ignoring the milliseconds part if exists
 */
 std::wstring iso8601_date_to_local_date(const std::wstring& iso8601date);
 
diff --git a/shell/source/win32/shlxthandler/util/iso8601_converter.cxx b/shell/source/win32/shlxthandler/util/iso8601_converter.cxx
index 36ab617..9933a9c 100644
--- a/shell/source/win32/shlxthandler/util/iso8601_converter.cxx
+++ b/shell/source/win32/shlxthandler/util/iso8601_converter.cxx
@@ -36,6 +36,15 @@ std::wstring iso8601_date_to_local_date(const std::wstring& isoDate )
 {
     ::std::wstring ws8601DateTime(isoDate);
 
+    // Get rid of the optional milliseconds part if it exists.
+    // Function accepts date/time as a combined date/time string in extended ISO8601 format,
+    // which is yyyy-mm-ddThh:mm:ss[.mmm]. Last part is the optional "fraction of second" part,
+    // that's why we cut off at 19.
+    if (ws8601DateTime.length() > 19)
+    {
+      ws8601DateTime.erase(19, ::std::basic_string<char>::npos);
+    }
+
     if ( ws8601DateTime.length() == 19 )
     {
         std::string asDateTime = WStringToString( ws8601DateTime );


More information about the Libreoffice-commits mailing list