]>
Commit | Line | Data |
---|---|---|
1 | // © 2016 and later: Unicode, Inc. and others. | |
2 | // License & terms of use: http://www.unicode.org/copyright.html | |
3 | /* | |
4 | ******************************************************************************* | |
5 | * Copyright (C) 2007-2013, International Business Machines Corporation and * | |
6 | * others. All Rights Reserved. * | |
7 | ******************************************************************************* | |
8 | */ | |
9 | #ifndef ZONEMETA_H | |
10 | #define ZONEMETA_H | |
11 | ||
12 | #include "unicode/utypes.h" | |
13 | ||
14 | #if !UCONFIG_NO_FORMATTING | |
15 | ||
16 | #include "unicode/unistr.h" | |
17 | #include "hash.h" | |
18 | ||
19 | U_NAMESPACE_BEGIN | |
20 | ||
21 | typedef struct OlsonToMetaMappingEntry { | |
22 | const UChar *mzid; // const because it's a reference to a resource bundle string. | |
23 | UDate from; | |
24 | UDate to; | |
25 | } OlsonToMetaMappingEntry; | |
26 | ||
27 | class UVector; | |
28 | class TimeZone; | |
29 | ||
30 | class U_I18N_API ZoneMeta { | |
31 | public: | |
32 | /** | |
33 | * Return the canonical id for this tzid defined by CLDR, which might be the id itself. | |
34 | * If the given system tzid is not known, U_ILLEGAL_ARGUMENT_ERROR is set in the status. | |
35 | * | |
36 | * Note: this internal API supports all known system IDs and "Etc/Unknown" (which is | |
37 | * NOT a system ID). | |
38 | */ | |
39 | static UnicodeString& U_EXPORT2 getCanonicalCLDRID(const UnicodeString &tzid, UnicodeString &systemID, UErrorCode& status); | |
40 | ||
41 | /** | |
42 | * Return the canonical id for this tzid defined by CLDR, which might be the id itself. | |
43 | * This overload method returns a persistent const UChar*, which is guranteed to persist | |
44 | * (a pointer to a resource). If the given system tzid is not known, U_ILLEGAL_ARGUMENT_ERROR | |
45 | * is set in the status. | |
46 | * @param tzid Zone ID | |
47 | * @param status Receives the status | |
48 | * @return The canonical ID for the input time zone ID | |
49 | */ | |
50 | static const UChar* U_EXPORT2 getCanonicalCLDRID(const UnicodeString &tzid, UErrorCode& status); | |
51 | ||
52 | /* | |
53 | * Conveninent method returning CLDR canonical ID for the given time zone | |
54 | */ | |
55 | static const UChar* U_EXPORT2 getCanonicalCLDRID(const TimeZone& tz); | |
56 | ||
57 | /** | |
58 | * Return the canonical country code for this tzid. If we have none, or if the time zone | |
59 | * is not associated with a country, return bogus string. | |
60 | * @param tzid Zone ID | |
61 | * @param country [output] Country code | |
62 | * @param isPrimary [output] TRUE if the zone is the primary zone for the country | |
63 | * @return A reference to the result country | |
64 | */ | |
65 | static UnicodeString& U_EXPORT2 getCanonicalCountry(const UnicodeString &tzid, UnicodeString &country, UBool *isPrimary = NULL); | |
66 | ||
67 | /** | |
68 | * Returns a CLDR metazone ID for the given Olson tzid and time. | |
69 | */ | |
70 | static UnicodeString& U_EXPORT2 getMetazoneID(const UnicodeString &tzid, UDate date, UnicodeString &result); | |
71 | /** | |
72 | * Returns an Olson ID for the ginve metazone and region | |
73 | */ | |
74 | static UnicodeString& U_EXPORT2 getZoneIdByMetazone(const UnicodeString &mzid, const UnicodeString ®ion, UnicodeString &result); | |
75 | ||
76 | static const UVector* U_EXPORT2 getMetazoneMappings(const UnicodeString &tzid); | |
77 | ||
78 | static const UVector* U_EXPORT2 getAvailableMetazoneIDs(); | |
79 | ||
80 | /** | |
81 | * Returns the pointer to the persistent time zone ID string, or NULL if the given tzid is not in the | |
82 | * tz database. This method is useful when you maintain persistent zone IDs without duplication. | |
83 | */ | |
84 | static const UChar* U_EXPORT2 findTimeZoneID(const UnicodeString& tzid); | |
85 | ||
86 | /** | |
87 | * Returns the pointer to the persistent meta zone ID string, or NULL if the given mzid is not available. | |
88 | * This method is useful when you maintain persistent meta zone IDs without duplication. | |
89 | */ | |
90 | static const UChar* U_EXPORT2 findMetaZoneID(const UnicodeString& mzid); | |
91 | ||
92 | /** | |
93 | * Creates a custom zone for the offset | |
94 | * @param offset GMT offset in milliseconds | |
95 | * @return A custom TimeZone for the offset with normalized time zone id | |
96 | */ | |
97 | static TimeZone* createCustomTimeZone(int32_t offset); | |
98 | ||
99 | /** | |
100 | * Returns the time zone's short ID (null terminated) for the zone. | |
101 | * For example, "uslax" for zone "America/Los_Angeles". | |
102 | * @param tz the time zone | |
103 | * @return the short ID of the time zone, or null if the short ID is not available. | |
104 | */ | |
105 | static const UChar* U_EXPORT2 getShortID(const TimeZone& tz); | |
106 | ||
107 | /** | |
108 | * Returns the time zone's short ID (null terminated) for the zone ID. | |
109 | * For example, "uslax" for zone ID "America/Los_Angeles". | |
110 | * @param tz the time zone ID | |
111 | * @return the short ID of the time zone ID, or null if the short ID is not available. | |
112 | */ | |
113 | static const UChar* U_EXPORT2 getShortID(const UnicodeString& id); | |
114 | ||
115 | private: | |
116 | ZoneMeta(); // Prevent construction. | |
117 | static UVector* createMetazoneMappings(const UnicodeString &tzid); | |
118 | static UnicodeString& formatCustomID(uint8_t hour, uint8_t min, uint8_t sec, UBool negative, UnicodeString& id); | |
119 | static const UChar* getShortIDFromCanonical(const UChar* canonicalID); | |
120 | }; | |
121 | ||
122 | U_NAMESPACE_END | |
123 | ||
124 | #endif /* #if !UCONFIG_NO_FORMATTING */ | |
125 | #endif // ZONEMETA_H |