// Copyright (c) 2011 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #include "base/i18n/number_formatting.h" #include "base/format_macros.h" #include "base/logging.h" #include "base/lazy_instance.h" #include "base/memory/scoped_ptr.h" #include "base/string_util.h" #include "base/utf_string_conversions.h" #include "unicode/numfmt.h" #include "unicode/ustring.h" namespace base { namespace { struct NumberFormatWrapper { NumberFormatWrapper() { // There's no ICU call to destroy a NumberFormat object other than // operator delete, so use the default Delete, which calls operator delete. // This can cause problems if a different allocator is used by this file // than by ICU. UErrorCode status = U_ZERO_ERROR; number_format.reset(icu::NumberFormat::createInstance(status)); DCHECK(U_SUCCESS(status)); } scoped_ptr<icu::NumberFormat> number_format; }; } // namespace static LazyInstance<NumberFormatWrapper> g_number_format(LINKER_INITIALIZED); string16 FormatNumber(int64 number) { icu::NumberFormat* number_format = g_number_format.Get().number_format.get(); if (!number_format) { // As a fallback, just return the raw number in a string. return UTF8ToUTF16(StringPrintf("%" PRId64, number)); } icu::UnicodeString ustr; number_format->format(number, ustr); return string16(ustr.getBuffer(), static_cast<size_t>(ustr.length())); } } // namespace base