1*b1cdbd2cSJim Jagielski /************************************************************** 2*b1cdbd2cSJim Jagielski * 3*b1cdbd2cSJim Jagielski * Licensed to the Apache Software Foundation (ASF) under one 4*b1cdbd2cSJim Jagielski * or more contributor license agreements. See the NOTICE file 5*b1cdbd2cSJim Jagielski * distributed with this work for additional information 6*b1cdbd2cSJim Jagielski * regarding copyright ownership. The ASF licenses this file 7*b1cdbd2cSJim Jagielski * to you under the Apache License, Version 2.0 (the 8*b1cdbd2cSJim Jagielski * "License"); you may not use this file except in compliance 9*b1cdbd2cSJim Jagielski * with the License. You may obtain a copy of the License at 10*b1cdbd2cSJim Jagielski * 11*b1cdbd2cSJim Jagielski * http://www.apache.org/licenses/LICENSE-2.0 12*b1cdbd2cSJim Jagielski * 13*b1cdbd2cSJim Jagielski * Unless required by applicable law or agreed to in writing, 14*b1cdbd2cSJim Jagielski * software distributed under the License is distributed on an 15*b1cdbd2cSJim Jagielski * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16*b1cdbd2cSJim Jagielski * KIND, either express or implied. See the License for the 17*b1cdbd2cSJim Jagielski * specific language governing permissions and limitations 18*b1cdbd2cSJim Jagielski * under the License. 19*b1cdbd2cSJim Jagielski * 20*b1cdbd2cSJim Jagielski *************************************************************/ 21*b1cdbd2cSJim Jagielski 22*b1cdbd2cSJim Jagielski // MARKER(update_precomp.py): autogen include statement, do not remove 23*b1cdbd2cSJim Jagielski #include "precompiled_basegfx.hxx" 24*b1cdbd2cSJim Jagielski 25*b1cdbd2cSJim Jagielski #include <stringconversiontools.hxx> 26*b1cdbd2cSJim Jagielski #include <rtl/math.hxx> 27*b1cdbd2cSJim Jagielski 28*b1cdbd2cSJim Jagielski namespace basegfx 29*b1cdbd2cSJim Jagielski { 30*b1cdbd2cSJim Jagielski namespace internal 31*b1cdbd2cSJim Jagielski { lcl_skipSpaces(sal_Int32 & io_rPos,const::rtl::OUString & rStr,const sal_Int32 nLen)32*b1cdbd2cSJim Jagielski void lcl_skipSpaces(sal_Int32& io_rPos, 33*b1cdbd2cSJim Jagielski const ::rtl::OUString& rStr, 34*b1cdbd2cSJim Jagielski const sal_Int32 nLen) 35*b1cdbd2cSJim Jagielski { 36*b1cdbd2cSJim Jagielski while( io_rPos < nLen && 37*b1cdbd2cSJim Jagielski sal_Unicode(' ') == rStr[io_rPos] ) 38*b1cdbd2cSJim Jagielski { 39*b1cdbd2cSJim Jagielski ++io_rPos; 40*b1cdbd2cSJim Jagielski } 41*b1cdbd2cSJim Jagielski } 42*b1cdbd2cSJim Jagielski lcl_skipSpacesAndCommas(sal_Int32 & io_rPos,const::rtl::OUString & rStr,const sal_Int32 nLen)43*b1cdbd2cSJim Jagielski void lcl_skipSpacesAndCommas(sal_Int32& io_rPos, 44*b1cdbd2cSJim Jagielski const ::rtl::OUString& rStr, 45*b1cdbd2cSJim Jagielski const sal_Int32 nLen) 46*b1cdbd2cSJim Jagielski { 47*b1cdbd2cSJim Jagielski while(io_rPos < nLen 48*b1cdbd2cSJim Jagielski && (sal_Unicode(' ') == rStr[io_rPos] || sal_Unicode(',') == rStr[io_rPos])) 49*b1cdbd2cSJim Jagielski { 50*b1cdbd2cSJim Jagielski ++io_rPos; 51*b1cdbd2cSJim Jagielski } 52*b1cdbd2cSJim Jagielski } 53*b1cdbd2cSJim Jagielski lcl_getDoubleChar(double & o_fRetval,sal_Int32 & io_rPos,const::rtl::OUString & rStr)54*b1cdbd2cSJim Jagielski bool lcl_getDoubleChar(double& o_fRetval, 55*b1cdbd2cSJim Jagielski sal_Int32& io_rPos, 56*b1cdbd2cSJim Jagielski const ::rtl::OUString& rStr) 57*b1cdbd2cSJim Jagielski { 58*b1cdbd2cSJim Jagielski sal_Unicode aChar( rStr[io_rPos] ); 59*b1cdbd2cSJim Jagielski ::rtl::OUStringBuffer sNumberString; 60*b1cdbd2cSJim Jagielski 61*b1cdbd2cSJim Jagielski if(sal_Unicode('+') == aChar || sal_Unicode('-') == aChar) 62*b1cdbd2cSJim Jagielski { 63*b1cdbd2cSJim Jagielski sNumberString.append(rStr[io_rPos]); 64*b1cdbd2cSJim Jagielski aChar = rStr[++io_rPos]; 65*b1cdbd2cSJim Jagielski } 66*b1cdbd2cSJim Jagielski 67*b1cdbd2cSJim Jagielski while((sal_Unicode('0') <= aChar && sal_Unicode('9') >= aChar) 68*b1cdbd2cSJim Jagielski || sal_Unicode('.') == aChar) 69*b1cdbd2cSJim Jagielski { 70*b1cdbd2cSJim Jagielski sNumberString.append(rStr[io_rPos]); 71*b1cdbd2cSJim Jagielski aChar = rStr[++io_rPos]; 72*b1cdbd2cSJim Jagielski } 73*b1cdbd2cSJim Jagielski 74*b1cdbd2cSJim Jagielski if(sal_Unicode('e') == aChar || sal_Unicode('E') == aChar) 75*b1cdbd2cSJim Jagielski { 76*b1cdbd2cSJim Jagielski sNumberString.append(rStr[io_rPos]); 77*b1cdbd2cSJim Jagielski aChar = rStr[++io_rPos]; 78*b1cdbd2cSJim Jagielski 79*b1cdbd2cSJim Jagielski if(sal_Unicode('+') == aChar || sal_Unicode('-') == aChar) 80*b1cdbd2cSJim Jagielski { 81*b1cdbd2cSJim Jagielski sNumberString.append(rStr[io_rPos]); 82*b1cdbd2cSJim Jagielski aChar = rStr[++io_rPos]; 83*b1cdbd2cSJim Jagielski } 84*b1cdbd2cSJim Jagielski 85*b1cdbd2cSJim Jagielski while(sal_Unicode('0') <= aChar && sal_Unicode('9') >= aChar) 86*b1cdbd2cSJim Jagielski { 87*b1cdbd2cSJim Jagielski sNumberString.append(rStr[io_rPos]); 88*b1cdbd2cSJim Jagielski aChar = rStr[++io_rPos]; 89*b1cdbd2cSJim Jagielski } 90*b1cdbd2cSJim Jagielski } 91*b1cdbd2cSJim Jagielski 92*b1cdbd2cSJim Jagielski if(sNumberString.getLength()) 93*b1cdbd2cSJim Jagielski { 94*b1cdbd2cSJim Jagielski rtl_math_ConversionStatus eStatus; 95*b1cdbd2cSJim Jagielski o_fRetval = ::rtl::math::stringToDouble( sNumberString.makeStringAndClear(), 96*b1cdbd2cSJim Jagielski (sal_Unicode)('.'), 97*b1cdbd2cSJim Jagielski (sal_Unicode)(','), 98*b1cdbd2cSJim Jagielski &eStatus, 99*b1cdbd2cSJim Jagielski NULL ); 100*b1cdbd2cSJim Jagielski return ( eStatus == rtl_math_ConversionStatus_Ok ); 101*b1cdbd2cSJim Jagielski } 102*b1cdbd2cSJim Jagielski 103*b1cdbd2cSJim Jagielski return false; 104*b1cdbd2cSJim Jagielski } 105*b1cdbd2cSJim Jagielski lcl_importDoubleAndSpaces(double & o_fRetval,sal_Int32 & io_rPos,const::rtl::OUString & rStr,const sal_Int32 nLen)106*b1cdbd2cSJim Jagielski bool lcl_importDoubleAndSpaces( double& o_fRetval, 107*b1cdbd2cSJim Jagielski sal_Int32& io_rPos, 108*b1cdbd2cSJim Jagielski const ::rtl::OUString& rStr, 109*b1cdbd2cSJim Jagielski const sal_Int32 nLen ) 110*b1cdbd2cSJim Jagielski { 111*b1cdbd2cSJim Jagielski if( !lcl_getDoubleChar(o_fRetval, io_rPos, rStr) ) 112*b1cdbd2cSJim Jagielski return false; 113*b1cdbd2cSJim Jagielski 114*b1cdbd2cSJim Jagielski lcl_skipSpacesAndCommas(io_rPos, rStr, nLen); 115*b1cdbd2cSJim Jagielski 116*b1cdbd2cSJim Jagielski return true; 117*b1cdbd2cSJim Jagielski } 118*b1cdbd2cSJim Jagielski lcl_importNumberAndSpaces(sal_Int32 & o_nRetval,sal_Int32 & io_rPos,const::rtl::OUString & rStr,const sal_Int32 nLen)119*b1cdbd2cSJim Jagielski bool lcl_importNumberAndSpaces(sal_Int32& o_nRetval, 120*b1cdbd2cSJim Jagielski sal_Int32& io_rPos, 121*b1cdbd2cSJim Jagielski const ::rtl::OUString& rStr, 122*b1cdbd2cSJim Jagielski const sal_Int32 nLen) 123*b1cdbd2cSJim Jagielski { 124*b1cdbd2cSJim Jagielski sal_Unicode aChar( rStr[io_rPos] ); 125*b1cdbd2cSJim Jagielski ::rtl::OUStringBuffer sNumberString; 126*b1cdbd2cSJim Jagielski 127*b1cdbd2cSJim Jagielski if(sal_Unicode('+') == aChar || sal_Unicode('-') == aChar) 128*b1cdbd2cSJim Jagielski { 129*b1cdbd2cSJim Jagielski sNumberString.append(rStr[io_rPos]); 130*b1cdbd2cSJim Jagielski aChar = rStr[++io_rPos]; 131*b1cdbd2cSJim Jagielski } 132*b1cdbd2cSJim Jagielski 133*b1cdbd2cSJim Jagielski while(sal_Unicode('0') <= aChar && sal_Unicode('9') >= aChar) 134*b1cdbd2cSJim Jagielski { 135*b1cdbd2cSJim Jagielski sNumberString.append(rStr[io_rPos]); 136*b1cdbd2cSJim Jagielski aChar = rStr[++io_rPos]; 137*b1cdbd2cSJim Jagielski } 138*b1cdbd2cSJim Jagielski 139*b1cdbd2cSJim Jagielski if(sNumberString.getLength()) 140*b1cdbd2cSJim Jagielski { 141*b1cdbd2cSJim Jagielski o_nRetval = sNumberString.makeStringAndClear().toInt32(); 142*b1cdbd2cSJim Jagielski lcl_skipSpacesAndCommas(io_rPos, rStr, nLen); 143*b1cdbd2cSJim Jagielski 144*b1cdbd2cSJim Jagielski return true; 145*b1cdbd2cSJim Jagielski } 146*b1cdbd2cSJim Jagielski 147*b1cdbd2cSJim Jagielski return false; 148*b1cdbd2cSJim Jagielski } 149*b1cdbd2cSJim Jagielski lcl_skipNumber(sal_Int32 & io_rPos,const::rtl::OUString & rStr,const sal_Int32 nLen)150*b1cdbd2cSJim Jagielski void lcl_skipNumber(sal_Int32& io_rPos, 151*b1cdbd2cSJim Jagielski const ::rtl::OUString& rStr, 152*b1cdbd2cSJim Jagielski const sal_Int32 nLen) 153*b1cdbd2cSJim Jagielski { 154*b1cdbd2cSJim Jagielski bool bSignAllowed(true); 155*b1cdbd2cSJim Jagielski 156*b1cdbd2cSJim Jagielski while(io_rPos < nLen && lcl_isOnNumberChar(rStr, io_rPos, bSignAllowed)) 157*b1cdbd2cSJim Jagielski { 158*b1cdbd2cSJim Jagielski bSignAllowed = false; 159*b1cdbd2cSJim Jagielski ++io_rPos; 160*b1cdbd2cSJim Jagielski } 161*b1cdbd2cSJim Jagielski } 162*b1cdbd2cSJim Jagielski lcl_skipDouble(sal_Int32 & io_rPos,const::rtl::OUString & rStr)163*b1cdbd2cSJim Jagielski void lcl_skipDouble(sal_Int32& io_rPos, 164*b1cdbd2cSJim Jagielski const ::rtl::OUString& rStr) 165*b1cdbd2cSJim Jagielski { 166*b1cdbd2cSJim Jagielski sal_Unicode aChar( rStr[io_rPos] ); 167*b1cdbd2cSJim Jagielski 168*b1cdbd2cSJim Jagielski if(sal_Unicode('+') == aChar || sal_Unicode('-') == aChar) 169*b1cdbd2cSJim Jagielski aChar = rStr[++io_rPos]; 170*b1cdbd2cSJim Jagielski 171*b1cdbd2cSJim Jagielski while((sal_Unicode('0') <= aChar && sal_Unicode('9') >= aChar) 172*b1cdbd2cSJim Jagielski || sal_Unicode('.') == aChar) 173*b1cdbd2cSJim Jagielski { 174*b1cdbd2cSJim Jagielski aChar = rStr[++io_rPos]; 175*b1cdbd2cSJim Jagielski } 176*b1cdbd2cSJim Jagielski 177*b1cdbd2cSJim Jagielski if(sal_Unicode('e') == aChar || sal_Unicode('E') == aChar) 178*b1cdbd2cSJim Jagielski { 179*b1cdbd2cSJim Jagielski aChar = rStr[++io_rPos]; 180*b1cdbd2cSJim Jagielski 181*b1cdbd2cSJim Jagielski if(sal_Unicode('+') == aChar || sal_Unicode('-') == aChar) 182*b1cdbd2cSJim Jagielski aChar = rStr[++io_rPos]; 183*b1cdbd2cSJim Jagielski 184*b1cdbd2cSJim Jagielski while(sal_Unicode('0') <= aChar && sal_Unicode('9') >= aChar) 185*b1cdbd2cSJim Jagielski { 186*b1cdbd2cSJim Jagielski aChar = rStr[++io_rPos]; 187*b1cdbd2cSJim Jagielski } 188*b1cdbd2cSJim Jagielski } 189*b1cdbd2cSJim Jagielski } 190*b1cdbd2cSJim Jagielski lcl_putNumberCharWithSpace(::rtl::OUStringBuffer & rStr,double fValue,double fOldValue,bool bUseRelativeCoordinates)191*b1cdbd2cSJim Jagielski void lcl_putNumberCharWithSpace( ::rtl::OUStringBuffer& rStr, 192*b1cdbd2cSJim Jagielski double fValue, 193*b1cdbd2cSJim Jagielski double fOldValue, 194*b1cdbd2cSJim Jagielski bool bUseRelativeCoordinates ) 195*b1cdbd2cSJim Jagielski { 196*b1cdbd2cSJim Jagielski if( bUseRelativeCoordinates ) 197*b1cdbd2cSJim Jagielski fValue -= fOldValue; 198*b1cdbd2cSJim Jagielski 199*b1cdbd2cSJim Jagielski const sal_Int32 aLen( rStr.getLength() ); 200*b1cdbd2cSJim Jagielski if(aLen) 201*b1cdbd2cSJim Jagielski { 202*b1cdbd2cSJim Jagielski if( lcl_isOnNumberChar(rStr.charAt(aLen - 1), false) && 203*b1cdbd2cSJim Jagielski fValue >= 0.0 ) 204*b1cdbd2cSJim Jagielski { 205*b1cdbd2cSJim Jagielski rStr.append( sal_Unicode(' ') ); 206*b1cdbd2cSJim Jagielski } 207*b1cdbd2cSJim Jagielski } 208*b1cdbd2cSJim Jagielski 209*b1cdbd2cSJim Jagielski lcl_putNumberChar(rStr, fValue); 210*b1cdbd2cSJim Jagielski } 211*b1cdbd2cSJim Jagielski } // namespace internal 212*b1cdbd2cSJim Jagielski } 213*b1cdbd2cSJim Jagielski 214*b1cdbd2cSJim Jagielski // eof 215