[Libreoffice-commits] core.git: Branch 'libreoffice-5-0' - connectivity/source

Lionel Elie Mamane lionel at mamane.lu
Thu Jun 18 05:03:19 PDT 2015


 connectivity/source/drivers/postgresql/pq_tools.cxx |   34 ++++++++++++++------
 1 file changed, 24 insertions(+), 10 deletions(-)

New commits:
commit 35d939bb69fdc02b6baa47dc1e3181e5cfe23980
Author: Lionel Elie Mamane <lionel at mamane.lu>
Date:   Wed Jun 17 14:00:46 2015 +0200

    postgresql-sdbc: fixup string2intarray
    
    this allows getGeneratedValues to work
    
    Change-Id: Ia87e87afa8cdb01f1d39c84bc7d7143c101d8891
    Reviewed-on: https://gerrit.libreoffice.org/16341
    Tested-by: Jenkins <ci at libreoffice.org>
    Reviewed-by: Michael Stahl <mstahl at redhat.com>

diff --git a/connectivity/source/drivers/postgresql/pq_tools.cxx b/connectivity/source/drivers/postgresql/pq_tools.cxx
index 8cd156f..4d75e8c3 100644
--- a/connectivity/source/drivers/postgresql/pq_tools.cxx
+++ b/connectivity/source/drivers/postgresql/pq_tools.cxx
@@ -862,33 +862,46 @@ com::sun::star::uno::Sequence< sal_Int32 > string2intarray( const OUString & str
     if( str.getLength() > 1 )
     {
         sal_Int32 start = 0;
-        while ( iswspace( str.iterateCodePoints(&start) ) )
+        sal_uInt32 c;
+        while ( iswspace( (c=str.iterateCodePoints(&start)) ) )
             if ( start == strlen)
                 return ret;
-        if ( str.iterateCodePoints(&start) != L'{' )
+        if ( c != L'{' )
             return ret;
-        while ( iswspace( str.iterateCodePoints(&start) ) )
+        while ( iswspace( c=str.iterateCodePoints(&start) ) )
             if ( start == strlen)
                 return ret;
-        if ( str.iterateCodePoints(&start, 0) == L'}' )
+        if ( c == L'}' )
             return ret;
 
         std::vector< sal_Int32 > vec;
         do
         {
             OUString digits;
-            sal_Int32 c;
-            while ( isdigit( c = str.iterateCodePoints(&start) ) )
+            do
             {
+                if(!iswspace(c))
+                    break;
                 if ( start == strlen)
                     return ret;
-                digits += OUString(c);
-            }
+            } while ( (c=str.iterateCodePoints(&start)) );
+            do
+            {
+                if (!iswdigit(c))
+                    break;
+                if ( start == strlen)
+                    return ret;
+                digits += OUString(&c, 1);
+            } while ( (c = str.iterateCodePoints(&start)) );
             vec.push_back( digits.toInt32() );
-            while ( iswspace( str.iterateCodePoints(&start) ) )
+            do
+            {
+                if(!iswspace(c))
+                    break;
                 if ( start == strlen)
                     return ret;
-            if ( str.iterateCodePoints(&start, 0) == L'}' )
+            } while ( (c=str.iterateCodePoints(&start)) );
+            if ( c == L'}' )
                 break;
             if ( str.iterateCodePoints(&start) != L',' )
                 return ret;
@@ -896,6 +909,7 @@ com::sun::star::uno::Sequence< sal_Int32 > string2intarray( const OUString & str
                 return ret;
         } while( true );
         // vec is guaranteed non-empty
+        assert(vec.size() > 0);
         ret = com::sun::star::uno::Sequence< sal_Int32 > ( &vec[0] , vec.size() );
     }
     return ret;


More information about the Libreoffice-commits mailing list