1 | // © 2016 and later: Unicode, Inc. and others. |
2 | // License & terms of use: http://www.unicode.org/copyright.html |
3 | /* |
4 | ******************************************************************************* |
5 | * |
6 | * Copyright (C) 1998-2014, International Business Machines |
7 | * Corporation and others. All Rights Reserved. |
8 | * |
9 | ******************************************************************************* |
10 | * |
11 | * Private implementation header for C collation |
12 | * file name: ucol_imp.h |
13 | * encoding: UTF-8 |
14 | * tab size: 8 (not used) |
15 | * indentation:4 |
16 | * |
17 | * created on: 2000dec11 |
18 | * created by: Vladimir Weinstein |
19 | * |
20 | * Modification history |
21 | * Date Name Comments |
22 | * 02/16/2001 synwee Added UCOL_GETPREVCE for the use in ucoleitr |
23 | * 02/27/2001 synwee Added getMaxExpansion data structure in UCollator |
24 | * 03/02/2001 synwee Added UCOL_IMPLICIT_CE |
25 | * 03/12/2001 synwee Added pointer start to collIterate. |
26 | */ |
27 | |
28 | #ifndef UCOL_IMP_H |
29 | #define UCOL_IMP_H |
30 | |
31 | #include "unicode/utypes.h" |
32 | |
33 | #if !UCONFIG_NO_COLLATION |
34 | |
35 | // This part needs to compile as plain C code, for cintltst. |
36 | |
37 | #include "unicode/ucol.h" |
38 | |
39 | /** Check whether two collators are equal. Collators are considered equal if they |
40 | * will sort strings the same. This means that both the current attributes and the |
41 | * rules must be equivalent. |
42 | * @param source first collator |
43 | * @param target second collator |
44 | * @return TRUE or FALSE |
45 | * @internal ICU 3.0 |
46 | */ |
47 | U_INTERNAL UBool U_EXPORT2 |
48 | ucol_equals(const UCollator *source, const UCollator *target); |
49 | |
50 | /** |
51 | * Convenience string denoting the Collation data tree |
52 | */ |
53 | #define U_ICUDATA_COLL U_ICUDATA_NAME U_TREE_SEPARATOR_STRING "coll" |
54 | |
55 | #ifdef __cplusplus |
56 | |
57 | #include "unicode/locid.h" |
58 | #include "unicode/ures.h" |
59 | |
60 | U_NAMESPACE_BEGIN |
61 | |
62 | struct CollationCacheEntry; |
63 | |
64 | class Locale; |
65 | class UnicodeString; |
66 | class UnifiedCache; |
67 | |
68 | /** Implemented in ucol_res.cpp. */ |
69 | class CollationLoader { |
70 | public: |
71 | static void appendRootRules(UnicodeString &s); |
72 | static void loadRules(const char *localeID, const char *collationType, |
73 | UnicodeString &rules, UErrorCode &errorCode); |
74 | // Adds a reference to returned value. |
75 | static const CollationCacheEntry *loadTailoring(const Locale &locale, UErrorCode &errorCode); |
76 | |
77 | // Cache callback. Adds a reference to returned value. |
78 | const CollationCacheEntry *createCacheEntry(UErrorCode &errorCode); |
79 | |
80 | private: |
81 | static void U_CALLCONV loadRootRules(UErrorCode &errorCode); |
82 | |
83 | // The following members are used by loadTailoring() |
84 | // and the cache callback. |
85 | static const uint32_t TRIED_SEARCH = 1; |
86 | static const uint32_t TRIED_DEFAULT = 2; |
87 | static const uint32_t TRIED_STANDARD = 4; |
88 | |
89 | CollationLoader(const CollationCacheEntry *re, const Locale &requested, UErrorCode &errorCode); |
90 | ~CollationLoader(); |
91 | |
92 | // All loadFromXXX methods add a reference to the returned value. |
93 | const CollationCacheEntry *loadFromLocale(UErrorCode &errorCode); |
94 | const CollationCacheEntry *loadFromBundle(UErrorCode &errorCode); |
95 | const CollationCacheEntry *loadFromCollations(UErrorCode &errorCode); |
96 | const CollationCacheEntry *loadFromData(UErrorCode &errorCode); |
97 | |
98 | // Adds a reference to returned value. |
99 | const CollationCacheEntry *getCacheEntry(UErrorCode &errorCode); |
100 | |
101 | /** |
102 | * Returns the rootEntry (with one addRef()) if loc==root, |
103 | * or else returns a new cache entry with ref count 1 for the loc and |
104 | * the root tailoring. |
105 | */ |
106 | const CollationCacheEntry *makeCacheEntryFromRoot( |
107 | const Locale &loc, UErrorCode &errorCode) const; |
108 | |
109 | /** |
110 | * Returns the entryFromCache as is if loc==validLocale, |
111 | * or else returns a new cache entry with ref count 1 for the loc and |
112 | * the same tailoring. In the latter case, a ref count is removed from |
113 | * entryFromCache. |
114 | */ |
115 | static const CollationCacheEntry *makeCacheEntry( |
116 | const Locale &loc, |
117 | const CollationCacheEntry *entryFromCache, |
118 | UErrorCode &errorCode); |
119 | |
120 | const UnifiedCache *cache; |
121 | const CollationCacheEntry *rootEntry; |
122 | Locale validLocale; |
123 | Locale locale; |
124 | char type[16]; |
125 | char defaultType[16]; |
126 | uint32_t typesTried; |
127 | UBool typeFallback; |
128 | UResourceBundle *bundle; |
129 | UResourceBundle *collations; |
130 | UResourceBundle *data; |
131 | }; |
132 | |
133 | U_NAMESPACE_END |
134 | |
135 | #endif /* __cplusplus */ |
136 | |
137 | #endif /* #if !UCONFIG_NO_COLLATION */ |
138 | |
139 | #endif |
140 | |