2009-11-26 22:48:15 +03:00
|
|
|
/*
|
|
|
|
* Copyright 2003-2009, Axel Dörfler, axeld@pinc-software.de.
|
|
|
|
* Copyright 2009, Destugues, pulkomandy@gmail.com.
|
|
|
|
* Distributed under the terms of the MIT License.
|
|
|
|
*/
|
2009-05-01 23:23:59 +04:00
|
|
|
|
|
|
|
|
|
|
|
#include <Country.h>
|
2009-09-19 02:23:34 +04:00
|
|
|
|
|
|
|
#include <assert.h>
|
|
|
|
|
2010-07-02 21:15:55 +04:00
|
|
|
#include <CalendarView.h>
|
2010-04-15 19:57:30 +04:00
|
|
|
#include <IconUtils.h>
|
2010-04-15 22:52:20 +04:00
|
|
|
#include <Resources.h>
|
2009-05-01 23:23:59 +04:00
|
|
|
#include <String.h>
|
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
#include <unicode/datefmt.h>
|
|
|
|
#include <unicode/dcfmtsym.h>
|
|
|
|
#include <unicode/decimfmt.h>
|
|
|
|
#include <unicode/dtfmtsym.h>
|
|
|
|
#include <unicode/smpdtfmt.h>
|
|
|
|
#include <ICUWrapper.h>
|
|
|
|
|
2009-05-01 23:23:59 +04:00
|
|
|
#include <monetary.h>
|
|
|
|
#include <stdarg.h>
|
|
|
|
|
|
|
|
|
2010-07-02 21:15:55 +04:00
|
|
|
using BPrivate::B_WEEK_START_MONDAY;
|
|
|
|
using BPrivate::B_WEEK_START_SUNDAY;
|
|
|
|
|
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
const char* gStrings[] = {
|
2009-05-01 23:23:59 +04:00
|
|
|
// date/time format
|
|
|
|
"",
|
|
|
|
"",
|
|
|
|
// short date/time format
|
|
|
|
"",
|
|
|
|
"",
|
|
|
|
// am/pm string
|
|
|
|
"AM",
|
|
|
|
"PM",
|
|
|
|
// separators
|
|
|
|
".",
|
|
|
|
":",
|
2009-09-19 02:23:34 +04:00
|
|
|
|
2009-05-01 23:23:59 +04:00
|
|
|
// currency/monetary
|
|
|
|
"."
|
|
|
|
","
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
BCountry::BCountry(const char* languageCode, const char* countryCode)
|
2009-05-01 23:23:59 +04:00
|
|
|
:
|
2009-09-21 02:16:30 +04:00
|
|
|
fStrings(gStrings)
|
2009-05-01 23:23:59 +04:00
|
|
|
{
|
2009-09-21 02:16:30 +04:00
|
|
|
fICULocale = new icu_4_2::Locale(languageCode, countryCode);
|
2010-07-08 13:14:09 +04:00
|
|
|
fICULongDateFormatter = DateFormat::createDateInstance(
|
|
|
|
DateFormat::FULL, *fICULocale);
|
|
|
|
fICUShortDateFormatter = DateFormat::createDateInstance(
|
|
|
|
DateFormat::SHORT, *fICULocale);
|
|
|
|
fICULongTimeFormatter = DateFormat::createTimeInstance(
|
|
|
|
DateFormat::MEDIUM, *fICULocale);
|
|
|
|
fICUShortTimeFormatter = DateFormat::createTimeInstance(
|
|
|
|
DateFormat::SHORT, *fICULocale);
|
2009-05-01 23:23:59 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
BCountry::BCountry(const char* languageAndCountryCode)
|
2009-05-01 23:23:59 +04:00
|
|
|
:
|
2009-09-21 02:16:30 +04:00
|
|
|
fStrings(gStrings)
|
2009-05-01 23:23:59 +04:00
|
|
|
{
|
2009-09-21 02:16:30 +04:00
|
|
|
fICULocale = new icu_4_2::Locale(languageAndCountryCode);
|
2009-09-19 02:23:34 +04:00
|
|
|
fICULongDateFormatter = DateFormat::createDateInstance(
|
2009-09-21 02:16:30 +04:00
|
|
|
DateFormat::FULL, *fICULocale);
|
2009-09-19 02:23:34 +04:00
|
|
|
fICUShortDateFormatter = DateFormat::createDateInstance(
|
2009-09-21 02:16:30 +04:00
|
|
|
DateFormat::SHORT, *fICULocale);
|
2010-07-08 13:14:09 +04:00
|
|
|
fICULongTimeFormatter = DateFormat::createTimeInstance(
|
|
|
|
DateFormat::MEDIUM, *fICULocale);
|
|
|
|
fICUShortTimeFormatter = DateFormat::createTimeInstance(
|
|
|
|
DateFormat::SHORT, *fICULocale);
|
2009-05-01 23:23:59 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
BCountry::~BCountry()
|
|
|
|
{
|
2010-07-08 13:14:09 +04:00
|
|
|
delete fICULongTimeFormatter;
|
|
|
|
delete fICUShortTimeFormatter;
|
|
|
|
delete fICULongDateFormatter;
|
|
|
|
delete fICUShortDateFormatter;
|
2009-09-21 02:16:30 +04:00
|
|
|
delete fICULocale;
|
2009-05-01 23:23:59 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
bool
|
|
|
|
BCountry::Name(BString& name) const
|
2009-05-01 23:23:59 +04:00
|
|
|
{
|
2009-09-19 02:23:34 +04:00
|
|
|
UnicodeString uString;
|
2009-09-21 02:16:30 +04:00
|
|
|
fICULocale->getDisplayName(uString);
|
2009-09-19 02:23:34 +04:00
|
|
|
BStringByteSink stringConverter(&name);
|
|
|
|
uString.toUTF8(stringConverter);
|
|
|
|
return true;
|
2009-05-01 23:23:59 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
const char*
|
|
|
|
BCountry::Code() const
|
|
|
|
{
|
2009-09-21 02:16:30 +04:00
|
|
|
return fICULocale->getName();
|
2009-09-19 02:23:34 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2010-04-15 19:57:30 +04:00
|
|
|
status_t
|
|
|
|
BCountry::GetIcon(BBitmap* result)
|
|
|
|
{
|
2010-04-16 01:34:00 +04:00
|
|
|
if (result == NULL)
|
|
|
|
return B_BAD_DATA;
|
2010-04-15 19:57:30 +04:00
|
|
|
// TODO: a proper way to locate the library being used ?
|
2010-04-15 22:52:20 +04:00
|
|
|
BResources storage("/boot/system/lib/liblocale.so");
|
2010-04-15 19:57:30 +04:00
|
|
|
if (storage.InitCheck() != B_OK)
|
|
|
|
return B_ERROR;
|
2010-04-15 22:52:20 +04:00
|
|
|
size_t size;
|
2010-04-16 01:34:00 +04:00
|
|
|
const char* code = fICULocale->getCountry();
|
|
|
|
if (code != NULL) {
|
|
|
|
const void* buffer = storage.LoadResource(B_VECTOR_ICON_TYPE, code,
|
|
|
|
&size);
|
|
|
|
if (buffer != NULL && size != 0) {
|
|
|
|
return BIconUtils::GetVectorIcon(static_cast<const uint8*>(buffer),
|
|
|
|
size, result);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return B_BAD_DATA;
|
2010-04-15 19:57:30 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
// TODO use ICU backend keywords instead
|
|
|
|
const char*
|
2009-05-01 23:23:59 +04:00
|
|
|
BCountry::GetString(uint32 id) const
|
|
|
|
{
|
|
|
|
if (id < B_COUNTRY_STRINGS_BASE || id >= B_NUM_COUNTRY_STRINGS)
|
|
|
|
return NULL;
|
|
|
|
|
|
|
|
return gStrings[id - B_COUNTRY_STRINGS_BASE];
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
void
|
|
|
|
BCountry::FormatDate(char* string, size_t maxSize, time_t time, bool longFormat)
|
2009-05-01 23:23:59 +04:00
|
|
|
{
|
2009-09-19 02:23:34 +04:00
|
|
|
BString fullString;
|
|
|
|
FormatDate(&fullString, time, longFormat);
|
|
|
|
strncpy(string, fullString.String(), maxSize);
|
2009-05-01 23:23:59 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
void
|
2009-05-01 23:23:59 +04:00
|
|
|
BCountry::FormatDate(BString *string, time_t time, bool longFormat)
|
|
|
|
{
|
2009-09-19 02:23:34 +04:00
|
|
|
// TODO: ICU allows for 4 different levels of expansion :
|
|
|
|
// short, medium, long, and full. Our bool parameter is not enough...
|
|
|
|
icu_4_2::DateFormat* dateFormatter
|
|
|
|
= longFormat ? fICULongDateFormatter : fICUShortDateFormatter;
|
|
|
|
UnicodeString ICUString;
|
|
|
|
ICUString = dateFormatter->format((UDate)time * 1000, ICUString);
|
|
|
|
|
|
|
|
string->Truncate(0);
|
|
|
|
BStringByteSink stringConverter(string);
|
|
|
|
|
|
|
|
ICUString.toUTF8(stringConverter);
|
2009-05-01 23:23:59 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
void
|
|
|
|
BCountry::FormatTime(char* string, size_t maxSize, time_t time, bool longFormat)
|
2009-05-01 23:23:59 +04:00
|
|
|
{
|
2009-09-19 02:23:34 +04:00
|
|
|
BString fullString;
|
|
|
|
FormatTime(&fullString, time, longFormat);
|
|
|
|
strncpy(string, fullString.String(), maxSize);
|
2009-05-01 23:23:59 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
void
|
|
|
|
BCountry::FormatTime(BString* string, time_t time, bool longFormat)
|
2009-05-01 23:23:59 +04:00
|
|
|
{
|
2009-09-19 02:23:34 +04:00
|
|
|
// TODO: ICU allows for 4 different levels of expansion :
|
|
|
|
// short, medium, long, and full. Our bool parameter is not enough...
|
|
|
|
icu_4_2::DateFormat* timeFormatter;
|
2010-07-08 13:14:09 +04:00
|
|
|
timeFormatter = longFormat ? fICULongTimeFormatter : fICUShortTimeFormatter;
|
2009-09-19 02:23:34 +04:00
|
|
|
UnicodeString ICUString;
|
|
|
|
ICUString = timeFormatter->format((UDate)time * 1000, ICUString);
|
|
|
|
|
|
|
|
string->Truncate(0);
|
|
|
|
BStringByteSink stringConverter(string);
|
|
|
|
|
|
|
|
ICUString.toUTF8(stringConverter);
|
2009-05-01 23:23:59 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
bool
|
|
|
|
BCountry::DateFormat(BString& format, bool longFormat) const
|
2009-05-01 23:23:59 +04:00
|
|
|
{
|
2009-09-19 02:23:34 +04:00
|
|
|
icu_4_2::DateFormat* dateFormatter
|
|
|
|
= longFormat ? fICULongDateFormatter : fICUShortDateFormatter;
|
|
|
|
SimpleDateFormat* dateFormatterImpl
|
|
|
|
= static_cast<SimpleDateFormat*>(dateFormatter);
|
|
|
|
|
|
|
|
UnicodeString ICUString;
|
|
|
|
ICUString = dateFormatterImpl->toPattern(ICUString);
|
|
|
|
|
|
|
|
BStringByteSink stringConverter(&format);
|
|
|
|
|
|
|
|
ICUString.toUTF8(stringConverter);
|
|
|
|
|
|
|
|
return true;
|
2009-05-01 23:23:59 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
void
|
|
|
|
BCountry::SetDateFormat(const char* formatString, bool longFormat)
|
2009-05-01 23:23:59 +04:00
|
|
|
{
|
2009-09-19 02:23:34 +04:00
|
|
|
icu_4_2::DateFormat* dateFormatter
|
|
|
|
= longFormat ? fICULongDateFormatter : fICUShortDateFormatter;
|
|
|
|
SimpleDateFormat* dateFormatterImpl
|
|
|
|
= static_cast<SimpleDateFormat*>(dateFormatter);
|
|
|
|
|
|
|
|
UnicodeString pattern(formatString);
|
|
|
|
dateFormatterImpl->applyPattern(pattern);
|
2009-05-01 23:23:59 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2010-07-08 13:14:09 +04:00
|
|
|
void
|
|
|
|
BCountry::SetTimeFormat(const char* formatString, bool longFormat)
|
|
|
|
{
|
|
|
|
icu_4_2::DateFormat* dateFormatter
|
|
|
|
= longFormat ? fICULongTimeFormatter : fICUShortTimeFormatter;
|
|
|
|
SimpleDateFormat* dateFormatterImpl
|
|
|
|
= static_cast<SimpleDateFormat*>(dateFormatter);
|
|
|
|
|
|
|
|
UnicodeString pattern(formatString);
|
|
|
|
dateFormatterImpl->applyPattern(pattern);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
bool
|
|
|
|
BCountry::TimeFormat(BString& format, bool longFormat) const
|
|
|
|
{
|
|
|
|
icu_4_2::DateFormat* dateFormatter;
|
2010-07-08 13:14:09 +04:00
|
|
|
dateFormatter = longFormat ? fICULongTimeFormatter : fICUShortTimeFormatter;
|
2009-09-19 02:23:34 +04:00
|
|
|
SimpleDateFormat* dateFormatterImpl
|
|
|
|
= static_cast<SimpleDateFormat*>(dateFormatter);
|
|
|
|
|
|
|
|
UnicodeString ICUString;
|
|
|
|
ICUString = dateFormatterImpl->toPattern(ICUString);
|
|
|
|
|
|
|
|
BStringByteSink stringConverter(&format);
|
|
|
|
|
|
|
|
ICUString.toUTF8(stringConverter);
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2010-07-02 21:15:55 +04:00
|
|
|
int
|
|
|
|
BCountry::StartOfWeek()
|
|
|
|
{
|
|
|
|
UErrorCode err = U_ZERO_ERROR;
|
|
|
|
Calendar* c = Calendar::createInstance(*fICULocale, err);
|
|
|
|
|
|
|
|
if (err == U_ZERO_ERROR && c->getFirstDayOfWeek(err) == UCAL_SUNDAY) {
|
|
|
|
delete c;
|
|
|
|
return B_WEEK_START_SUNDAY;
|
|
|
|
} else {
|
|
|
|
delete c;
|
|
|
|
// Might be another day, but BeAPI will not handle it
|
|
|
|
return B_WEEK_START_MONDAY;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
// TODO find how to get it from ICU (setting it is ok, we use the pattern-string
|
|
|
|
// for that)
|
|
|
|
// Or remove this function ?
|
|
|
|
const char*
|
2009-05-01 23:23:59 +04:00
|
|
|
BCountry::DateSeparator() const
|
|
|
|
{
|
|
|
|
return fStrings[B_DATE_SEPARATOR];
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
const char*
|
2009-05-01 23:23:59 +04:00
|
|
|
BCountry::TimeSeparator() const
|
|
|
|
{
|
|
|
|
return fStrings[B_TIME_SEPARATOR];
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
void
|
|
|
|
BCountry::FormatNumber(char* string, size_t maxSize, double value)
|
2009-05-01 23:23:59 +04:00
|
|
|
{
|
2009-09-19 02:23:34 +04:00
|
|
|
BString fullString;
|
|
|
|
FormatNumber(&fullString, value);
|
|
|
|
strncpy(string, fullString.String(), maxSize);
|
2009-05-01 23:23:59 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-09-21 02:16:30 +04:00
|
|
|
status_t
|
2009-09-19 02:23:34 +04:00
|
|
|
BCountry::FormatNumber(BString* string, double value)
|
2009-05-01 23:23:59 +04:00
|
|
|
{
|
2009-09-19 02:23:34 +04:00
|
|
|
UErrorCode err = U_ZERO_ERROR;
|
|
|
|
NumberFormat* numberFormatter
|
2009-09-21 02:16:30 +04:00
|
|
|
= NumberFormat::createInstance(*fICULocale, NumberFormat::kNumberStyle,
|
2009-09-19 02:23:34 +04:00
|
|
|
err);
|
|
|
|
|
2009-09-21 02:16:30 +04:00
|
|
|
// Warning: we're returning an ICU error here but the type is status_t.
|
2009-09-19 02:23:34 +04:00
|
|
|
if (U_FAILURE(err)) return err;
|
|
|
|
|
|
|
|
UnicodeString ICUString;
|
|
|
|
ICUString = numberFormatter->format(value, ICUString);
|
|
|
|
|
|
|
|
string->Truncate(0);
|
|
|
|
BStringByteSink stringConverter(string);
|
|
|
|
|
|
|
|
ICUString.toUTF8(stringConverter);
|
|
|
|
|
|
|
|
return U_ZERO_ERROR;
|
2009-05-01 23:23:59 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
void
|
|
|
|
BCountry::FormatNumber(char* string, size_t maxSize, int32 value)
|
2009-05-01 23:23:59 +04:00
|
|
|
{
|
2009-09-19 02:23:34 +04:00
|
|
|
BString fullString;
|
|
|
|
FormatNumber(&fullString, value);
|
|
|
|
strncpy(string, fullString.String(), maxSize);
|
2009-05-01 23:23:59 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
void
|
|
|
|
BCountry::FormatNumber(BString* string, int32 value)
|
2009-05-01 23:23:59 +04:00
|
|
|
{
|
2009-09-19 02:23:34 +04:00
|
|
|
UErrorCode err;
|
|
|
|
NumberFormat* numberFormatter
|
2009-09-21 02:16:30 +04:00
|
|
|
= NumberFormat::createInstance(*fICULocale, err);
|
2009-09-19 02:23:34 +04:00
|
|
|
|
|
|
|
assert(err == U_ZERO_ERROR);
|
|
|
|
|
|
|
|
UnicodeString ICUString;
|
|
|
|
ICUString = numberFormatter->format((int32_t)value, ICUString);
|
|
|
|
|
|
|
|
string->Truncate(0);
|
|
|
|
BStringByteSink stringConverter(string);
|
|
|
|
|
|
|
|
ICUString.toUTF8(stringConverter);
|
2009-05-01 23:23:59 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
// This will only work for locales using the decimal system...
|
|
|
|
bool
|
|
|
|
BCountry::DecimalPoint(BString& format) const
|
2009-05-01 23:23:59 +04:00
|
|
|
{
|
2009-09-19 02:23:34 +04:00
|
|
|
UErrorCode err;
|
|
|
|
NumberFormat* numberFormatter
|
2009-09-21 02:16:30 +04:00
|
|
|
= NumberFormat::createInstance(*fICULocale, err);
|
2009-09-19 02:23:34 +04:00
|
|
|
|
|
|
|
assert(err == U_ZERO_ERROR);
|
|
|
|
|
|
|
|
DecimalFormat* decimalFormatter
|
|
|
|
= dynamic_cast<DecimalFormat*>(numberFormatter);
|
|
|
|
|
|
|
|
assert(decimalFormatter != NULL);
|
|
|
|
|
|
|
|
const DecimalFormatSymbols* syms
|
|
|
|
= decimalFormatter->getDecimalFormatSymbols();
|
|
|
|
|
|
|
|
UnicodeString ICUString;
|
|
|
|
ICUString = syms->getSymbol(DecimalFormatSymbols::kDecimalSeparatorSymbol);
|
|
|
|
|
|
|
|
BStringByteSink stringConverter(&format);
|
|
|
|
|
|
|
|
ICUString.toUTF8(stringConverter);
|
|
|
|
|
|
|
|
return true;
|
2009-05-01 23:23:59 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
bool
|
|
|
|
BCountry::ThousandsSeparator(BString& separator) const
|
2009-05-01 23:23:59 +04:00
|
|
|
{
|
2009-09-19 02:23:34 +04:00
|
|
|
UErrorCode err;
|
|
|
|
NumberFormat* numberFormatter
|
2009-09-21 02:16:30 +04:00
|
|
|
= NumberFormat::createInstance(*fICULocale, err);
|
2009-09-19 02:23:34 +04:00
|
|
|
assert(err == U_ZERO_ERROR);
|
|
|
|
DecimalFormat* decimalFormatter
|
|
|
|
= dynamic_cast<DecimalFormat*>(numberFormatter);
|
|
|
|
|
|
|
|
assert(decimalFormatter != NULL);
|
|
|
|
|
|
|
|
const DecimalFormatSymbols* syms
|
|
|
|
= decimalFormatter->getDecimalFormatSymbols();
|
|
|
|
|
|
|
|
UnicodeString ICUString;
|
|
|
|
ICUString = syms->getSymbol(DecimalFormatSymbols::kPatternSeparatorSymbol);
|
|
|
|
|
|
|
|
BStringByteSink stringConverter(&separator);
|
|
|
|
|
|
|
|
ICUString.toUTF8(stringConverter);
|
|
|
|
|
|
|
|
return true;
|
2009-05-01 23:23:59 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
bool
|
|
|
|
BCountry::Grouping(BString& grouping) const
|
2009-05-01 23:23:59 +04:00
|
|
|
{
|
2009-09-19 02:23:34 +04:00
|
|
|
UErrorCode err;
|
|
|
|
NumberFormat* numberFormatter
|
2009-09-21 02:16:30 +04:00
|
|
|
= NumberFormat::createInstance(*fICULocale, err);
|
2009-09-19 02:23:34 +04:00
|
|
|
assert(err == U_ZERO_ERROR);
|
|
|
|
DecimalFormat* decimalFormatter
|
|
|
|
= dynamic_cast<DecimalFormat*>(numberFormatter);
|
|
|
|
|
|
|
|
assert(decimalFormatter != NULL);
|
|
|
|
|
|
|
|
const DecimalFormatSymbols* syms
|
|
|
|
= decimalFormatter->getDecimalFormatSymbols();
|
|
|
|
|
|
|
|
UnicodeString ICUString;
|
|
|
|
ICUString = syms->getSymbol(DecimalFormatSymbols::kGroupingSeparatorSymbol);
|
|
|
|
|
|
|
|
BStringByteSink stringConverter(&grouping);
|
|
|
|
|
|
|
|
ICUString.toUTF8(stringConverter);
|
|
|
|
|
|
|
|
return true;
|
2009-05-01 23:23:59 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
bool
|
|
|
|
BCountry::PositiveSign(BString& sign) const
|
2009-05-01 23:23:59 +04:00
|
|
|
{
|
2009-09-19 02:23:34 +04:00
|
|
|
UErrorCode err;
|
|
|
|
NumberFormat* numberFormatter
|
2009-09-21 02:16:30 +04:00
|
|
|
= NumberFormat::createInstance(*fICULocale, err);
|
2009-09-19 02:23:34 +04:00
|
|
|
assert(err == U_ZERO_ERROR);
|
|
|
|
DecimalFormat* decimalFormatter
|
|
|
|
= dynamic_cast<DecimalFormat*>(numberFormatter);
|
|
|
|
|
|
|
|
assert(decimalFormatter != NULL);
|
|
|
|
|
|
|
|
const DecimalFormatSymbols* syms
|
|
|
|
= decimalFormatter->getDecimalFormatSymbols();
|
|
|
|
|
|
|
|
UnicodeString ICUString;
|
|
|
|
ICUString = syms->getSymbol(DecimalFormatSymbols::kPlusSignSymbol);
|
|
|
|
|
|
|
|
BStringByteSink stringConverter(&sign);
|
|
|
|
|
|
|
|
ICUString.toUTF8(stringConverter);
|
|
|
|
|
|
|
|
return true;
|
2009-05-01 23:23:59 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
bool
|
|
|
|
BCountry::NegativeSign(BString& sign) const
|
2009-05-01 23:23:59 +04:00
|
|
|
{
|
2009-09-19 02:23:34 +04:00
|
|
|
UErrorCode err;
|
|
|
|
NumberFormat* numberFormatter
|
2009-09-21 02:16:30 +04:00
|
|
|
= NumberFormat::createInstance(*fICULocale, err);
|
2009-09-19 02:23:34 +04:00
|
|
|
assert(err == U_ZERO_ERROR);
|
|
|
|
DecimalFormat* decimalFormatter
|
|
|
|
= dynamic_cast<DecimalFormat*>(numberFormatter);
|
|
|
|
|
|
|
|
assert(decimalFormatter != NULL);
|
|
|
|
|
|
|
|
const DecimalFormatSymbols* syms
|
|
|
|
= decimalFormatter->getDecimalFormatSymbols();
|
|
|
|
|
|
|
|
UnicodeString ICUString;
|
|
|
|
ICUString = syms->getSymbol(DecimalFormatSymbols::kMinusSignSymbol);
|
|
|
|
|
|
|
|
BStringByteSink stringConverter(&sign);
|
|
|
|
|
|
|
|
ICUString.toUTF8(stringConverter);
|
|
|
|
|
|
|
|
return true;
|
2009-05-01 23:23:59 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
// TODO does ICU even support this ? Is it in the keywords ?
|
|
|
|
int8
|
2009-05-01 23:23:59 +04:00
|
|
|
BCountry::Measurement() const
|
|
|
|
{
|
|
|
|
return B_US;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
ssize_t
|
2009-09-19 02:23:34 +04:00
|
|
|
BCountry::FormatMonetary(char* string, size_t maxSize, double value)
|
2009-05-01 23:23:59 +04:00
|
|
|
{
|
2009-09-19 02:23:34 +04:00
|
|
|
BString fullString;
|
2009-11-26 22:48:15 +03:00
|
|
|
ssize_t written = FormatMonetary(&fullString, value);
|
|
|
|
if (written < 0)
|
|
|
|
return written;
|
|
|
|
|
|
|
|
return strlcpy(string, fullString.String(), maxSize);
|
2009-09-19 02:23:34 +04:00
|
|
|
}
|
2009-05-01 23:23:59 +04:00
|
|
|
|
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
ssize_t
|
|
|
|
BCountry::FormatMonetary(BString* string, double value)
|
|
|
|
{
|
2009-11-26 22:48:15 +03:00
|
|
|
if (string == NULL)
|
|
|
|
return B_BAD_VALUE;
|
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
UErrorCode err;
|
|
|
|
NumberFormat* numberFormatter
|
2009-09-21 02:16:30 +04:00
|
|
|
= NumberFormat::createCurrencyInstance(*fICULocale, err);
|
2009-05-01 23:23:59 +04:00
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
assert(err == U_ZERO_ERROR);
|
2009-05-01 23:23:59 +04:00
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
UnicodeString ICUString;
|
|
|
|
ICUString = numberFormatter->format(value, ICUString);
|
|
|
|
|
|
|
|
string->Truncate(0);
|
|
|
|
BStringByteSink stringConverter(string);
|
|
|
|
|
|
|
|
ICUString.toUTF8(stringConverter);
|
2009-05-01 23:23:59 +04:00
|
|
|
|
2009-11-26 22:48:15 +03:00
|
|
|
return string->Length();
|
2009-05-01 23:23:59 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
bool
|
|
|
|
BCountry::CurrencySymbol(BString& symbol) const
|
2009-05-01 23:23:59 +04:00
|
|
|
{
|
2009-09-19 02:23:34 +04:00
|
|
|
UErrorCode err;
|
|
|
|
NumberFormat* numberFormatter
|
2009-09-21 02:16:30 +04:00
|
|
|
= NumberFormat::createCurrencyInstance(*fICULocale, err);
|
2009-09-19 02:23:34 +04:00
|
|
|
assert(err == U_ZERO_ERROR);
|
|
|
|
DecimalFormat* decimalFormatter
|
|
|
|
= dynamic_cast<DecimalFormat*>(numberFormatter);
|
|
|
|
|
|
|
|
assert(decimalFormatter != NULL);
|
|
|
|
|
|
|
|
const DecimalFormatSymbols* syms
|
|
|
|
= decimalFormatter->getDecimalFormatSymbols();
|
|
|
|
|
|
|
|
UnicodeString ICUString;
|
|
|
|
ICUString = syms->getSymbol(DecimalFormatSymbols::kCurrencySymbol);
|
|
|
|
|
|
|
|
BStringByteSink stringConverter(&symbol);
|
|
|
|
|
|
|
|
ICUString.toUTF8(stringConverter);
|
|
|
|
|
|
|
|
return true;
|
2009-05-01 23:23:59 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
bool
|
|
|
|
BCountry::InternationalCurrencySymbol(BString& symbol) const
|
2009-05-01 23:23:59 +04:00
|
|
|
{
|
2009-09-19 02:23:34 +04:00
|
|
|
UErrorCode err;
|
|
|
|
NumberFormat* numberFormatter
|
2009-09-21 02:16:30 +04:00
|
|
|
= NumberFormat::createCurrencyInstance(*fICULocale, err);
|
2009-09-19 02:23:34 +04:00
|
|
|
assert(err == U_ZERO_ERROR);
|
|
|
|
DecimalFormat* decimalFormatter
|
|
|
|
= dynamic_cast<DecimalFormat*>(numberFormatter);
|
|
|
|
|
|
|
|
assert(decimalFormatter != NULL);
|
|
|
|
|
|
|
|
const DecimalFormatSymbols* syms
|
|
|
|
= decimalFormatter->getDecimalFormatSymbols();
|
|
|
|
|
|
|
|
UnicodeString ICUString;
|
|
|
|
ICUString = syms->getSymbol(DecimalFormatSymbols::kIntlCurrencySymbol);
|
|
|
|
|
|
|
|
BStringByteSink stringConverter(&symbol);
|
|
|
|
|
|
|
|
ICUString.toUTF8(stringConverter);
|
|
|
|
|
|
|
|
return true;
|
2009-05-01 23:23:59 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
bool
|
|
|
|
BCountry::MonDecimalPoint(BString& decimal) const
|
2009-05-01 23:23:59 +04:00
|
|
|
{
|
2009-09-19 02:23:34 +04:00
|
|
|
UErrorCode err;
|
|
|
|
NumberFormat* numberFormatter
|
2009-09-21 02:16:30 +04:00
|
|
|
= NumberFormat::createCurrencyInstance(*fICULocale, err);
|
2009-09-19 02:23:34 +04:00
|
|
|
assert(err == U_ZERO_ERROR);
|
|
|
|
DecimalFormat* decimalFormatter
|
|
|
|
= dynamic_cast<DecimalFormat*>(numberFormatter);
|
|
|
|
|
|
|
|
assert(decimalFormatter != NULL);
|
|
|
|
|
|
|
|
const DecimalFormatSymbols* syms
|
|
|
|
= decimalFormatter->getDecimalFormatSymbols();
|
|
|
|
|
|
|
|
UnicodeString ICUString;
|
|
|
|
ICUString = syms->getSymbol(DecimalFormatSymbols::kMonetarySeparatorSymbol);
|
|
|
|
|
|
|
|
BStringByteSink stringConverter(&decimal);
|
|
|
|
|
|
|
|
ICUString.toUTF8(stringConverter);
|
|
|
|
|
|
|
|
return true;
|
2009-05-01 23:23:59 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
bool
|
|
|
|
BCountry::MonThousandsSeparator(BString& separator) const
|
2009-05-01 23:23:59 +04:00
|
|
|
{
|
2009-09-19 02:23:34 +04:00
|
|
|
UErrorCode err;
|
|
|
|
NumberFormat* numberFormatter
|
2009-09-21 02:16:30 +04:00
|
|
|
= NumberFormat::createCurrencyInstance(*fICULocale, err);
|
2009-09-19 02:23:34 +04:00
|
|
|
assert(err == U_ZERO_ERROR);
|
|
|
|
DecimalFormat* decimalFormatter
|
|
|
|
= dynamic_cast<DecimalFormat*>(numberFormatter);
|
|
|
|
|
|
|
|
assert(decimalFormatter != NULL);
|
|
|
|
|
|
|
|
const DecimalFormatSymbols* syms
|
|
|
|
= decimalFormatter->getDecimalFormatSymbols();
|
|
|
|
|
|
|
|
UnicodeString ICUString;
|
|
|
|
ICUString = syms->getSymbol(DecimalFormatSymbols::kPatternSeparatorSymbol);
|
|
|
|
|
|
|
|
BStringByteSink stringConverter(&separator);
|
|
|
|
|
|
|
|
ICUString.toUTF8(stringConverter);
|
|
|
|
|
|
|
|
return true;
|
2009-05-01 23:23:59 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
bool
|
|
|
|
BCountry::MonGrouping(BString& grouping) const
|
2009-05-01 23:23:59 +04:00
|
|
|
{
|
2009-09-19 02:23:34 +04:00
|
|
|
UErrorCode err;
|
|
|
|
NumberFormat* numberFormatter
|
2009-09-21 02:16:30 +04:00
|
|
|
= NumberFormat::createCurrencyInstance(*fICULocale, err);
|
2009-09-19 02:23:34 +04:00
|
|
|
assert(err == U_ZERO_ERROR);
|
|
|
|
DecimalFormat* decimalFormatter
|
|
|
|
= dynamic_cast<DecimalFormat*>(numberFormatter);
|
|
|
|
|
|
|
|
assert(decimalFormatter != NULL);
|
|
|
|
|
|
|
|
const DecimalFormatSymbols* syms
|
|
|
|
= decimalFormatter->getDecimalFormatSymbols();
|
|
|
|
|
|
|
|
UnicodeString ICUString;
|
|
|
|
ICUString = syms->getSymbol(
|
|
|
|
DecimalFormatSymbols::kMonetaryGroupingSeparatorSymbol);
|
|
|
|
|
|
|
|
BStringByteSink stringConverter(&grouping);
|
|
|
|
|
|
|
|
ICUString.toUTF8(stringConverter);
|
|
|
|
|
|
|
|
return true;
|
2009-05-01 23:23:59 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-09-19 02:23:34 +04:00
|
|
|
// TODO: is this possible to get from ICU ?
|
|
|
|
int32
|
2009-05-01 23:23:59 +04:00
|
|
|
BCountry::MonFracDigits() const
|
|
|
|
{
|
|
|
|
return 2;
|
|
|
|
}
|
|
|
|
|