* moved support for getting timezones-by-country from BCountry to LocaleRoster,
since we'd like to be able to get the timezones of the global (i.e. empty) country, too. git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@38380 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
bbdb55154d
commit
c91aa9f4e6
@ -47,10 +47,6 @@ public:
|
|||||||
|
|
||||||
int8 Measurement() const;
|
int8 Measurement() const;
|
||||||
|
|
||||||
// timezones
|
|
||||||
|
|
||||||
int GetTimeZones(BList& timezones) const;
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
icu_44::Locale* fICULocale;
|
icu_44::Locale* fICULocale;
|
||||||
};
|
};
|
||||||
|
@ -44,8 +44,13 @@ public:
|
|||||||
// 'language'-string-fields which
|
// 'language'-string-fields which
|
||||||
// contain the language-name(s)
|
// contain the language-name(s)
|
||||||
|
|
||||||
status_t GetAvailableCountries(BMessage* message) const;
|
status_t GetAvailableCountries(
|
||||||
status_t GetAvailableTimeZones(BMessage* message) const;
|
BMessage* timeZones) const;
|
||||||
|
status_t GetAvailableTimeZones(
|
||||||
|
BMessage* timeZones) const;
|
||||||
|
status_t GetAvailableTimeZonesForCountry(
|
||||||
|
BMessage* message,
|
||||||
|
const char* countryCode) const;
|
||||||
|
|
||||||
status_t GetInstalledCatalogs(BMessage* message,
|
status_t GetInstalledCatalogs(BMessage* message,
|
||||||
const char* sigPattern = NULL,
|
const char* sigPattern = NULL,
|
||||||
|
@ -123,39 +123,3 @@ BCountry::Measurement() const
|
|||||||
return B_METRIC;
|
return B_METRIC;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// #pragma mark - Timezones
|
|
||||||
|
|
||||||
|
|
||||||
int
|
|
||||||
BCountry::GetTimeZones(BList& timezones) const
|
|
||||||
{
|
|
||||||
ObjectDeleter<StringEnumeration> icuTimeZoneList
|
|
||||||
= TimeZone::createEnumeration(fICULocale->getCountry());
|
|
||||||
if (icuTimeZoneList.Get() == NULL)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
UErrorCode error = U_ZERO_ERROR;
|
|
||||||
|
|
||||||
const char* tzName;
|
|
||||||
std::map<BString, BTimeZone*> timeZoneMap;
|
|
||||||
// The map allows us to remove duplicates and get a count of the
|
|
||||||
// remaining zones after that
|
|
||||||
while ((tzName = icuTimeZoneList->next(NULL, error)) != NULL) {
|
|
||||||
if (error == U_ZERO_ERROR) {
|
|
||||||
BTimeZone* timeZone = new(std::nothrow) BTimeZone(tzName);
|
|
||||||
timeZoneMap.insert(std::pair<BString, BTimeZone*>(timeZone->Name(),
|
|
||||||
timeZone));
|
|
||||||
} else
|
|
||||||
error = U_ZERO_ERROR;
|
|
||||||
}
|
|
||||||
|
|
||||||
std::map<BString, BTimeZone*>::const_iterator tzIter;
|
|
||||||
for (tzIter = timeZoneMap.begin(); tzIter != timeZoneMap.end(); ++tzIter)
|
|
||||||
timezones.AddItem(tzIter->second);
|
|
||||||
|
|
||||||
return timezones.CountItems();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -237,13 +237,44 @@ BLocaleRoster::GetAvailableTimeZones(BMessage* timeZones) const
|
|||||||
|
|
||||||
status_t status = B_OK;
|
status_t status = B_OK;
|
||||||
|
|
||||||
int32 i;
|
|
||||||
StringEnumeration* zoneList = TimeZone::createEnumeration();
|
StringEnumeration* zoneList = TimeZone::createEnumeration();
|
||||||
|
|
||||||
UErrorCode icuStatus = U_ZERO_ERROR;
|
UErrorCode icuStatus = U_ZERO_ERROR;
|
||||||
int32 count = zoneList->count(icuStatus);
|
int32 count = zoneList->count(icuStatus);
|
||||||
if (U_SUCCESS(icuStatus)) {
|
if (U_SUCCESS(icuStatus)) {
|
||||||
for (i = 0; i < count; ++i) {
|
for (int i = 0; i < count; ++i) {
|
||||||
|
const char* zoneID = zoneList->next(NULL, icuStatus);
|
||||||
|
if (zoneID == NULL || !U_SUCCESS(icuStatus)) {
|
||||||
|
status = B_ERROR;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
timeZones->AddString("timeZone", zoneID);
|
||||||
|
}
|
||||||
|
} else
|
||||||
|
status = B_ERROR;
|
||||||
|
|
||||||
|
delete zoneList;
|
||||||
|
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
status_t
|
||||||
|
BLocaleRoster::GetAvailableTimeZonesForCountry(BMessage* timeZones,
|
||||||
|
const char* countryCode) const
|
||||||
|
{
|
||||||
|
if (!timeZones)
|
||||||
|
return B_BAD_VALUE;
|
||||||
|
|
||||||
|
status_t status = B_OK;
|
||||||
|
|
||||||
|
StringEnumeration* zoneList = TimeZone::createEnumeration(countryCode);
|
||||||
|
// countryCode == NULL will yield all timezones not bound to a country
|
||||||
|
|
||||||
|
UErrorCode icuStatus = U_ZERO_ERROR;
|
||||||
|
int32 count = zoneList->count(icuStatus);
|
||||||
|
if (U_SUCCESS(icuStatus)) {
|
||||||
|
for (int i = 0; i < count; ++i) {
|
||||||
const char* zoneID = zoneList->next(NULL, icuStatus);
|
const char* zoneID = zoneList->next(NULL, icuStatus);
|
||||||
if (zoneID == NULL || !U_SUCCESS(icuStatus)) {
|
if (zoneID == NULL || !U_SUCCESS(icuStatus)) {
|
||||||
status = B_ERROR;
|
status = B_ERROR;
|
||||||
|
Loading…
Reference in New Issue
Block a user