From 300c3433b03065a470719c9e556b25ba62eb6b51 Mon Sep 17 00:00:00 2001 From: Eike Rathke Date: Tue, 8 Oct 2002 15:11:19 +0000 Subject: #i8026# #103991# localize decimal separator of conditions --- xmloff/source/style/xmlnumfi.cxx | 22 ++++++++++++++++++---- 1 file changed, 18 insertions(+), 4 deletions(-) (limited to 'xmloff/source/style/xmlnumfi.cxx') diff --git a/xmloff/source/style/xmlnumfi.cxx b/xmloff/source/style/xmlnumfi.cxx index 8fe36fdc52f1..8cd586a08e31 100644 --- a/xmloff/source/style/xmlnumfi.cxx +++ b/xmloff/source/style/xmlnumfi.cxx @@ -2,9 +2,9 @@ * * $RCSfile: xmlnumfi.cxx,v $ * - * $Revision: 1.27 $ + * $Revision: 1.28 $ * - * last change: $Author: nn $ $Date: 2002-06-28 11:37:30 $ + * last change: $Author: er $ $Date: 2002-10-08 16:11:19 $ * * The Contents of this file are made available subject to the terms of * either of the following licenses @@ -1455,7 +1455,7 @@ void SvXMLNumFormatContext::GetFormat(rtl::OUString& rFormatString, lang::Locale if (pStyle) { pStyle->GetFormat(sFormat, aLoc); - AddCondition(i, sFormat, aLoc); + AddCondition(i, sFormat, pStyle->GetLocaleData()); } } } @@ -1966,6 +1966,13 @@ void SvXMLNumFormatContext::AddCondition( const sal_Int32 nIndex ) if (!bDefaultCond) { + sal_Int32 nPos = sRealCond.indexOf( '.' ); + if ( nPos >= 0 ) + { // #i8026# #103991# localize decimal separator + const String& rDecSep = GetLocaleData().getNumDecimalSep(); + if ( rDecSep.Len() > 1 || rDecSep.GetChar(0) != '.' ) + sRealCond = sRealCond.replaceAt( nPos, 1, rDecSep ); + } aConditions.append( (sal_Unicode) '[' ); aConditions.append( sRealCond ); aConditions.append( (sal_Unicode) ']' ); @@ -1979,7 +1986,7 @@ void SvXMLNumFormatContext::AddCondition( const sal_Int32 nIndex ) } } -void SvXMLNumFormatContext::AddCondition( const sal_Int32 nIndex, const rtl::OUString& rFormat, const lang::Locale& rLocale ) +void SvXMLNumFormatContext::AddCondition( const sal_Int32 nIndex, const rtl::OUString& rFormat, const LocaleDataWrapper& rData ) { rtl::OUString rCondition = aMyConditions[nIndex].sCondition; OUString sValue = OUString::createFromAscii( "value()" ); //! define constant @@ -2001,6 +2008,13 @@ void SvXMLNumFormatContext::AddCondition( const sal_Int32 nIndex, const rtl::OUS if (!bDefaultCond) { + sal_Int32 nPos = sRealCond.indexOf( '.' ); + if ( nPos >= 0 ) + { // #i8026# #103991# localize decimal separator + const String& rDecSep = rData.getNumDecimalSep(); + if ( rDecSep.Len() > 1 || rDecSep.GetChar(0) != '.' ) + sRealCond = sRealCond.replaceAt( nPos, 1, rDecSep ); + } aConditions.append( (sal_Unicode) '[' ); aConditions.append( sRealCond ); aConditions.append( (sal_Unicode) ']' ); -- cgit