[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