Linux moon.hostseba.com 4.18.0-553.51.1.lve.el8.x86_64 #1 SMP Tue May 6 15:14:12 UTC 2025 x86_64
LiteSpeed
Server IP : 103.174.152.68 & Your IP : 216.73.216.150
Domains :
Cant Read [ /etc/named.conf ]
User : julaysp1
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-07-11 10:39
appendable.h
8.54
KB
-rw-r--r--
2025-07-11 10:39
basictz.h
9.99
KB
-rw-r--r--
2025-07-11 10:39
brkiter.h
27.84
KB
-rw-r--r--
2025-07-11 10:39
bytestream.h
10.77
KB
-rw-r--r--
2025-07-11 10:39
bytestrie.h
20.83
KB
-rw-r--r--
2025-07-11 10:39
bytestriebuilder.h
7.48
KB
-rw-r--r--
2025-07-11 10:39
calendar.h
107.54
KB
-rw-r--r--
2025-07-11 10:39
caniter.h
7.53
KB
-rw-r--r--
2025-07-11 10:39
casemap.h
25.42
KB
-rw-r--r--
2025-07-11 10:39
char16ptr.h
10.79
KB
-rw-r--r--
2025-07-11 10:39
chariter.h
23.79
KB
-rw-r--r--
2025-07-11 10:39
choicfmt.h
23.99
KB
-rw-r--r--
2025-07-11 10:39
coleitr.h
13.78
KB
-rw-r--r--
2025-07-11 10:39
coll.h
59.6
KB
-rw-r--r--
2025-07-11 10:39
compactdecimalformat.h
6.88
KB
-rw-r--r--
2025-07-11 10:39
curramt.h
3.67
KB
-rw-r--r--
2025-07-11 10:39
currpinf.h
7.3
KB
-rw-r--r--
2025-07-11 10:39
currunit.h
4.02
KB
-rw-r--r--
2025-07-11 10:39
datefmt.h
40.7
KB
-rw-r--r--
2025-07-11 10:39
dbbi.h
1.19
KB
-rw-r--r--
2025-07-11 10:39
dcfmtsym.h
20.96
KB
-rw-r--r--
2025-07-11 10:39
decimfmt.h
87.46
KB
-rw-r--r--
2025-07-11 10:39
displayoptions.h
7.08
KB
-rw-r--r--
2025-07-11 10:39
docmain.h
7.6
KB
-rw-r--r--
2025-07-11 10:39
dtfmtsym.h
38.22
KB
-rw-r--r--
2025-07-11 10:39
dtintrv.h
3.84
KB
-rw-r--r--
2025-07-11 10:39
dtitvfmt.h
48.87
KB
-rw-r--r--
2025-07-11 10:39
dtitvinf.h
18.63
KB
-rw-r--r--
2025-07-11 10:39
dtptngen.h
28.05
KB
-rw-r--r--
2025-07-11 10:39
dtrule.h
8.66
KB
-rw-r--r--
2025-07-11 10:39
edits.h
20.74
KB
-rw-r--r--
2025-07-11 10:39
enumset.h
2.08
KB
-rw-r--r--
2025-07-11 10:39
errorcode.h
4.84
KB
-rw-r--r--
2025-07-11 10:39
fieldpos.h
8.69
KB
-rw-r--r--
2025-07-11 10:39
filteredbrk.h
5.37
KB
-rw-r--r--
2025-07-11 10:39
fmtable.h
24.37
KB
-rw-r--r--
2025-07-11 10:39
format.h
12.51
KB
-rw-r--r--
2025-07-11 10:39
formattednumber.h
6.28
KB
-rw-r--r--
2025-07-11 10:39
formattedvalue.h
9.75
KB
-rw-r--r--
2025-07-11 10:39
fpositer.h
3.03
KB
-rw-r--r--
2025-07-11 10:39
gender.h
3.35
KB
-rw-r--r--
2025-07-11 10:39
gregocal.h
30.32
KB
-rw-r--r--
2025-07-11 10:39
icudataver.h
1.02
KB
-rw-r--r--
2025-07-11 10:39
icuplug.h
12.1
KB
-rw-r--r--
2025-07-11 10:39
idna.h
12.93
KB
-rw-r--r--
2025-07-11 10:39
listformatter.h
8.59
KB
-rw-r--r--
2025-07-11 10:39
localebuilder.h
11.08
KB
-rw-r--r--
2025-07-11 10:39
localematcher.h
26.86
KB
-rw-r--r--
2025-07-11 10:39
localpointer.h
19.55
KB
-rw-r--r--
2025-07-11 10:39
locdspnm.h
7.12
KB
-rw-r--r--
2025-07-11 10:39
locid.h
48.62
KB
-rw-r--r--
2025-07-11 10:39
measfmt.h
11.41
KB
-rw-r--r--
2025-07-11 10:39
measunit.h
111.44
KB
-rw-r--r--
2025-07-11 10:39
measure.h
4.63
KB
-rw-r--r--
2025-07-11 10:39
messageformat2.h
21.05
KB
-rw-r--r--
2025-07-11 10:39
messageformat2_arguments.h
4.49
KB
-rw-r--r--
2025-07-11 10:39
messageformat2_data_model.h
101.89
KB
-rw-r--r--
2025-07-11 10:39
messageformat2_data_model_names.h
784
B
-rw-r--r--
2025-07-11 10:39
messageformat2_formattable.h
38.36
KB
-rw-r--r--
2025-07-11 10:39
messageformat2_function_registry.h
18.07
KB
-rw-r--r--
2025-07-11 10:39
messagepattern.h
33.79
KB
-rw-r--r--
2025-07-11 10:39
msgfmt.h
44.2
KB
-rw-r--r--
2025-07-11 10:39
normalizer2.h
34.68
KB
-rw-r--r--
2025-07-11 10:39
normlzr.h
30.79
KB
-rw-r--r--
2025-07-11 10:39
nounit.h
2.24
KB
-rw-r--r--
2025-07-11 10:39
numberformatter.h
90.69
KB
-rw-r--r--
2025-07-11 10:39
numberrangeformatter.h
26
KB
-rw-r--r--
2025-07-11 10:39
numfmt.h
50.16
KB
-rw-r--r--
2025-07-11 10:39
numsys.h
7.22
KB
-rw-r--r--
2025-07-11 10:39
parseerr.h
3.08
KB
-rw-r--r--
2025-07-11 10:39
parsepos.h
5.56
KB
-rw-r--r--
2025-07-11 10:39
platform.h
27.18
KB
-rw-r--r--
2025-07-11 10:39
plurfmt.h
25.07
KB
-rw-r--r--
2025-07-11 10:39
plurrule.h
20.63
KB
-rw-r--r--
2025-07-11 10:39
ptypes.h
2.16
KB
-rw-r--r--
2025-07-11 10:39
putil.h
6.32
KB
-rw-r--r--
2025-07-11 10:39
rbbi.h
32.04
KB
-rw-r--r--
2025-07-11 10:39
rbnf.h
56.16
KB
-rw-r--r--
2025-07-11 10:39
rbtz.h
15.75
KB
-rw-r--r--
2025-07-11 10:39
regex.h
84.45
KB
-rw-r--r--
2025-07-11 10:39
region.h
9.2
KB
-rw-r--r--
2025-07-11 10:39
reldatefmt.h
22.48
KB
-rw-r--r--
2025-07-11 10:39
rep.h
9.38
KB
-rw-r--r--
2025-07-11 10:39
resbund.h
18.02
KB
-rw-r--r--
2025-07-11 10:39
schriter.h
6.09
KB
-rw-r--r--
2025-07-11 10:39
scientificnumberformatter.h
6.44
KB
-rw-r--r--
2025-07-11 10:39
search.h
22.21
KB
-rw-r--r--
2025-07-11 10:39
selfmt.h
14.35
KB
-rw-r--r--
2025-07-11 10:39
simpleformatter.h
12.6
KB
-rw-r--r--
2025-07-11 10:39
simplenumberformatter.h
8.87
KB
-rw-r--r--
2025-07-11 10:39
simpletz.h
45.62
KB
-rw-r--r--
2025-07-11 10:39
smpdtfmt.h
57.06
KB
-rw-r--r--
2025-07-11 10:39
sortkey.h
11.13
KB
-rw-r--r--
2025-07-11 10:39
std_string.h
1.05
KB
-rw-r--r--
2025-07-11 10:39
strenum.h
9.96
KB
-rw-r--r--
2025-07-11 10:39
stringoptions.h
5.79
KB
-rw-r--r--
2025-07-11 10:39
stringpiece.h
10.28
KB
-rw-r--r--
2025-07-11 10:39
stringtriebuilder.h
15.53
KB
-rw-r--r--
2025-07-11 10:39
stsearch.h
21.43
KB
-rw-r--r--
2025-07-11 10:39
symtable.h
4.28
KB
-rw-r--r--
2025-07-11 10:39
tblcoll.h
36.96
KB
-rw-r--r--
2025-07-11 10:39
timezone.h
45.59
KB
-rw-r--r--
2025-07-11 10:39
tmunit.h
3.4
KB
-rw-r--r--
2025-07-11 10:39
tmutamt.h
4.9
KB
-rw-r--r--
2025-07-11 10:39
tmutfmt.h
7.42
KB
-rw-r--r--
2025-07-11 10:39
translit.h
65.81
KB
-rw-r--r--
2025-07-11 10:39
tzfmt.h
42.95
KB
-rw-r--r--
2025-07-11 10:39
tznames.h
16.85
KB
-rw-r--r--
2025-07-11 10:39
tzrule.h
34.81
KB
-rw-r--r--
2025-07-11 10:39
tztrans.h
6.11
KB
-rw-r--r--
2025-07-11 10:39
ubidi.h
89.61
KB
-rw-r--r--
2025-07-11 10:39
ubiditransform.h
12.71
KB
-rw-r--r--
2025-07-11 10:39
ubrk.h
24.43
KB
-rw-r--r--
2025-07-11 10:39
ucal.h
63.96
KB
-rw-r--r--
2025-07-11 10:39
ucasemap.h
15.27
KB
-rw-r--r--
2025-07-11 10:39
ucat.h
5.35
KB
-rw-r--r--
2025-07-11 10:39
uchar.h
151.74
KB
-rw-r--r--
2025-07-11 10:39
ucharstrie.h
22.59
KB
-rw-r--r--
2025-07-11 10:39
ucharstriebuilder.h
7.48
KB
-rw-r--r--
2025-07-11 10:39
uchriter.h
13.24
KB
-rw-r--r--
2025-07-11 10:39
uclean.h
11.21
KB
-rw-r--r--
2025-07-11 10:39
ucnv.h
83.34
KB
-rw-r--r--
2025-07-11 10:39
ucnv_cb.h
6.58
KB
-rw-r--r--
2025-07-11 10:39
ucnv_err.h
20.98
KB
-rw-r--r--
2025-07-11 10:39
ucnvsel.h
6.24
KB
-rw-r--r--
2025-07-11 10:39
ucol.h
67.28
KB
-rw-r--r--
2025-07-11 10:39
ucoleitr.h
9.82
KB
-rw-r--r--
2025-07-11 10:39
uconfig.h
12.56
KB
-rw-r--r--
2025-07-11 10:39
ucpmap.h
5.54
KB
-rw-r--r--
2025-07-11 10:39
ucptrie.h
22.51
KB
-rw-r--r--
2025-07-11 10:39
ucsdet.h
14.69
KB
-rw-r--r--
2025-07-11 10:39
ucurr.h
16.72
KB
-rw-r--r--
2025-07-11 10:39
udat.h
62.36
KB
-rw-r--r--
2025-07-11 10:39
udata.h
15.63
KB
-rw-r--r--
2025-07-11 10:39
udateintervalformat.h
11.93
KB
-rw-r--r--
2025-07-11 10:39
udatpg.h
30.13
KB
-rw-r--r--
2025-07-11 10:39
udisplaycontext.h
5.94
KB
-rw-r--r--
2025-07-11 10:39
udisplayoptions.h
8.86
KB
-rw-r--r--
2025-07-11 10:39
uenum.h
7.79
KB
-rw-r--r--
2025-07-11 10:39
ufieldpositer.h
4.41
KB
-rw-r--r--
2025-07-11 10:39
uformattable.h
10.97
KB
-rw-r--r--
2025-07-11 10:39
uformattednumber.h
8.09
KB
-rw-r--r--
2025-07-11 10:39
uformattedvalue.h
12.25
KB
-rw-r--r--
2025-07-11 10:39
ugender.h
2.06
KB
-rw-r--r--
2025-07-11 10:39
uidna.h
34.12
KB
-rw-r--r--
2025-07-11 10:39
uiter.h
22.75
KB
-rw-r--r--
2025-07-11 10:39
uldnames.h
10.48
KB
-rw-r--r--
2025-07-11 10:39
ulistformatter.h
10.78
KB
-rw-r--r--
2025-07-11 10:39
uloc.h
55.38
KB
-rw-r--r--
2025-07-11 10:39
ulocale.h
6.31
KB
-rw-r--r--
2025-07-11 10:39
ulocbuilder.h
16.69
KB
-rw-r--r--
2025-07-11 10:39
ulocdata.h
11.3
KB
-rw-r--r--
2025-07-11 10:39
umachine.h
14.59
KB
-rw-r--r--
2025-07-11 10:39
umisc.h
1.34
KB
-rw-r--r--
2025-07-11 10:39
umsg.h
24.25
KB
-rw-r--r--
2025-07-11 10:39
umutablecptrie.h
8.3
KB
-rw-r--r--
2025-07-11 10:39
unifilt.h
4
KB
-rw-r--r--
2025-07-11 10:39
unifunct.h
4.05
KB
-rw-r--r--
2025-07-11 10:39
unimatch.h
6.1
KB
-rw-r--r--
2025-07-11 10:39
unirepl.h
3.38
KB
-rw-r--r--
2025-07-11 10:39
uniset.h
70.4
KB
-rw-r--r--
2025-07-11 10:39
unistr.h
182.08
KB
-rw-r--r--
2025-07-11 10:39
unorm.h
20.55
KB
-rw-r--r--
2025-07-11 10:39
unorm2.h
25.66
KB
-rw-r--r--
2025-07-11 10:39
unum.h
55.16
KB
-rw-r--r--
2025-07-11 10:39
unumberformatter.h
19.68
KB
-rw-r--r--
2025-07-11 10:39
unumberoptions.h
5.23
KB
-rw-r--r--
2025-07-11 10:39
unumberrangeformatter.h
15.35
KB
-rw-r--r--
2025-07-11 10:39
unumsys.h
7.26
KB
-rw-r--r--
2025-07-11 10:39
uobject.h
10.66
KB
-rw-r--r--
2025-07-11 10:39
upluralrules.h
8.79
KB
-rw-r--r--
2025-07-11 10:39
uregex.h
71.99
KB
-rw-r--r--
2025-07-11 10:39
uregion.h
9.81
KB
-rw-r--r--
2025-07-11 10:39
ureldatefmt.h
16.98
KB
-rw-r--r--
2025-07-11 10:39
urename.h
141.99
KB
-rw-r--r--
2025-07-11 10:39
urep.h
5.38
KB
-rw-r--r--
2025-07-11 10:39
ures.h
36.65
KB
-rw-r--r--
2025-07-11 10:39
uscript.h
28.51
KB
-rw-r--r--
2025-07-11 10:39
usearch.h
39.21
KB
-rw-r--r--
2025-07-11 10:39
uset.h
63.08
KB
-rw-r--r--
2025-07-11 10:39
usetiter.h
9.63
KB
-rw-r--r--
2025-07-11 10:39
ushape.h
18
KB
-rw-r--r--
2025-07-11 10:39
usimplenumberformatter.h
7.31
KB
-rw-r--r--
2025-07-11 10:39
uspoof.h
80
KB
-rw-r--r--
2025-07-11 10:39
usprep.h
8.19
KB
-rw-r--r--
2025-07-11 10:39
ustdio.h
38.58
KB
-rw-r--r--
2025-07-11 10:39
ustream.h
1.89
KB
-rw-r--r--
2025-07-11 10:39
ustring.h
72.16
KB
-rw-r--r--
2025-07-11 10:39
ustringtrie.h
3.15
KB
-rw-r--r--
2025-07-11 10:39
utext.h
58.1
KB
-rw-r--r--
2025-07-11 10:39
utf.h
7.87
KB
-rw-r--r--
2025-07-11 10:39
utf16.h
23.35
KB
-rw-r--r--
2025-07-11 10:39
utf32.h
763
B
-rw-r--r--
2025-07-11 10:39
utf8.h
30.83
KB
-rw-r--r--
2025-07-11 10:39
utf_old.h
45.8
KB
-rw-r--r--
2025-07-11 10:39
utmscale.h
13.78
KB
-rw-r--r--
2025-07-11 10:39
utrace.h
17.18
KB
-rw-r--r--
2025-07-11 10:39
utrans.h
25.54
KB
-rw-r--r--
2025-07-11 10:39
utypes.h
34.48
KB
-rw-r--r--
2025-07-11 10:39
uvernum.h
6.33
KB
-rw-r--r--
2025-07-11 10:39
uversion.h
8.21
KB
-rw-r--r--
2025-07-11 10:39
vtzone.h
20.68
KB
-rw-r--r--
2025-07-11 10:39
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