mirror of
https://review.haiku-os.org/haiku
synced 2025-01-21 22:04:49 +01:00
44f11d0982
* Move relevant parts up into BFormat so other format classes can use those * Adjust BDurationFormat and BTimeUnitFormat for the changes * Remove the "default" date format, it is better to keep only a default locale and let applications create B*Formats from it as needed. * Creating a B*Format without arguments to the constructor now configures it for the default locale, which allows for easy use in standard cases (formatting something with the current language and format) * Creating a B*Format is potentially an expansive operation, it is advised to keep the instance around and reuse it whenever possible. However it must be "refreshed" when the locale changes, for apps which supports that, since it keeps a copy of the language and formatting convention, rather than a pointer to the locale as it did before.
114 lines
2.6 KiB
C++
114 lines
2.6 KiB
C++
/*
|
|
* Copyright 2003-2011, Haiku. All rights reserved.
|
|
* Distributed under the terms of the MIT license.
|
|
*/
|
|
#ifndef _LOCALE_ROSTER_H_
|
|
#define _LOCALE_ROSTER_H_
|
|
|
|
|
|
#include <pthread.h>
|
|
|
|
#include <Entry.h>
|
|
#include <String.h>
|
|
|
|
|
|
class BBitmap;
|
|
class BCatalog;
|
|
class BCollator;
|
|
class BCountry;
|
|
class BDateFormat;
|
|
class BFormattingConventions;
|
|
class BLanguage;
|
|
class BLocale;
|
|
class BMessage;
|
|
class BTimeZone;
|
|
|
|
|
|
namespace BPrivate {
|
|
class LocaleRosterData;
|
|
}
|
|
|
|
|
|
enum {
|
|
B_LOCALE_CHANGED = '_LCC',
|
|
};
|
|
|
|
|
|
class BLocaleRoster {
|
|
|
|
public:
|
|
~BLocaleRoster();
|
|
|
|
static BLocaleRoster* Default();
|
|
|
|
status_t GetDefaultTimeZone(BTimeZone* timezone) const;
|
|
|
|
status_t GetLanguage(const char* languageCode,
|
|
BLanguage** _language) const;
|
|
|
|
status_t GetPreferredLanguages(BMessage* message) const;
|
|
|
|
status_t GetAvailableLanguages(BMessage* message) const;
|
|
status_t GetAvailableCountries(
|
|
BMessage* timeZones) const;
|
|
status_t GetAvailableTimeZones(
|
|
BMessage* timeZones) const;
|
|
status_t GetAvailableTimeZonesWithRegionInfo(
|
|
BMessage* timeZonesWithRegonInfo) const;
|
|
status_t GetAvailableTimeZonesForCountry(
|
|
BMessage* message,
|
|
const char* countryCode) const;
|
|
|
|
status_t GetFlagIconForCountry(BBitmap* flagIcon,
|
|
const char* countryCode);
|
|
status_t GetFlagIconForLanguage(BBitmap* flagIcon,
|
|
const char* languageCode);
|
|
|
|
status_t GetAvailableCatalogs(BMessage* message,
|
|
const char* sigPattern = NULL,
|
|
const char* langPattern = NULL,
|
|
int32 fingerprint = 0) const;
|
|
// the message contains...
|
|
|
|
status_t Refresh();
|
|
// Refresh the internal data from the
|
|
// settings file(s)
|
|
|
|
BCatalog* GetCatalog();
|
|
// Get the catalog for the calling image
|
|
// (that needs to link with liblocalestub.a)
|
|
|
|
const BLocale* GetDefaultLocale() const;
|
|
|
|
bool IsFilesystemTranslationPreferred() const;
|
|
|
|
status_t GetLocalizedFileName(BString& localizedFileName,
|
|
const entry_ref& ref,
|
|
bool traverse = false);
|
|
|
|
static const char* kCatLangAttr;
|
|
static const char* kCatSigAttr;
|
|
static const char* kCatFingerprintAttr;
|
|
|
|
static const char* kEmbeddedCatAttr;
|
|
static int32 kEmbeddedCatResId;
|
|
|
|
protected:
|
|
BLocaleRoster();
|
|
|
|
protected:
|
|
BPrivate::LocaleRosterData* fData;
|
|
|
|
private:
|
|
static BCatalog* _GetCatalog(BCatalog* catalog,
|
|
int32* catalogInitStatus);
|
|
|
|
status_t _PrepareCatalogEntry(const entry_ref& ref,
|
|
BString& signature, BString& context,
|
|
BString& string, bool traverse);
|
|
|
|
};
|
|
|
|
|
|
#endif // _LOCALE_ROSTER_H_
|