From c2866a9da4822fe886683efabe223db97d0296cb Mon Sep 17 00:00:00 2001 From: Caolán McNamara Date: Mon, 20 Jan 2014 10:41:32 +0000 Subject: Related: #i56998# provide a way to format % per-locale rules Change-Id: Ic27b230cc9dce366f281ff720ded5873e94f6191 --- i18nutil/source/utility/unicode.cxx | 26 ++++++++++++++++++++++++++ 1 file changed, 26 insertions(+) (limited to 'i18nutil/source/utility/unicode.cxx') diff --git a/i18nutil/source/utility/unicode.cxx b/i18nutil/source/utility/unicode.cxx index 009896987b6e..56daacdacd1a 100644 --- a/i18nutil/source/utility/unicode.cxx +++ b/i18nutil/source/utility/unicode.cxx @@ -17,10 +17,14 @@ * the License at http://www.apache.org/licenses/LICENSE-2.0 . */ +#include #include #include #include +#include +#include #include +#include #include "unicode_data.h" // Workaround for glibc braindamage: @@ -934,4 +938,26 @@ OString SAL_CALL unicode::getExemplarLanguageForUScriptCode(UScriptCode eScript) return sRet; } +//Format a number as a percentage according to the rules of the given +//language, e.g. 100 -> "100%" for en-US vs "100 %" for de-DE +OUString SAL_CALL unicode::formatPercent(double dNumber, + const LanguageTag &rLangTag) +{ + // get a currency formatter for this locale ID + UErrorCode errorCode=U_ZERO_ERROR; + icu::Locale aLocale = LanguageTagIcu::getIcuLocale(rLangTag); + boost::scoped_ptr xF( + NumberFormat::createPercentInstance(aLocale, errorCode)); + if(U_FAILURE(errorCode)) + { + SAL_WARN("i18n", "NumberFormat::createPercentInstance failed"); + return OUString::number(dNumber) + "%"; + } + + UnicodeString output; + xF->format(dNumber, output); + return OUString(reinterpret_cast(output.getBuffer()), + output.length()); +} + /* vim:set shiftwidth=4 softtabstop=4 expandtab: */ -- cgit