Linux premium71.web-hosting.com 4.18.0-513.11.1.lve.el8.x86_64 #1 SMP Thu Jan 18 16:21:02 UTC 2024 x86_64
LiteSpeed
Server IP : 198.187.29.8 & Your IP : 216.73.216.206
Domains :
Cant Read [ /etc/named.conf ]
User : cleahvkv
Terminal
Auto Root
Create File
Create Folder
Localroot Suggester
Backdoor Destroyer
Readme
/
opt /
alt /
alt-nodejs19 /
root /
usr /
include /
unicode /
Delete
Unzip
Name
Size
Permission
Date
Action
alphaindex.h
26.53
KB
-rw-r--r--
2023-02-22 10:03
appendable.h
8.53
KB
-rw-r--r--
2023-02-22 10:03
basictz.h
9.98
KB
-rw-r--r--
2023-02-22 10:03
brkiter.h
27.81
KB
-rw-r--r--
2023-02-22 10:03
bytestream.h
10.75
KB
-rw-r--r--
2023-02-22 10:03
bytestrie.h
20.78
KB
-rw-r--r--
2023-02-22 10:03
bytestriebuilder.h
7.48
KB
-rw-r--r--
2023-02-22 10:03
calendar.h
102.25
KB
-rw-r--r--
2023-02-22 10:03
caniter.h
7.47
KB
-rw-r--r--
2023-02-22 10:03
casemap.h
25.33
KB
-rw-r--r--
2023-02-22 10:03
char16ptr.h
7.22
KB
-rw-r--r--
2023-02-22 10:03
chariter.h
24.06
KB
-rw-r--r--
2023-02-22 10:03
choicfmt.h
23.98
KB
-rw-r--r--
2023-02-22 10:03
coleitr.h
13.78
KB
-rw-r--r--
2023-02-22 10:03
coll.h
56.27
KB
-rw-r--r--
2023-02-22 10:03
compactdecimalformat.h
6.88
KB
-rw-r--r--
2023-02-22 10:03
curramt.h
3.78
KB
-rw-r--r--
2023-02-22 10:03
currpinf.h
7.3
KB
-rw-r--r--
2023-02-22 10:03
currunit.h
4.02
KB
-rw-r--r--
2023-02-22 10:03
datefmt.h
40.71
KB
-rw-r--r--
2023-02-22 10:03
dbbi.h
1.19
KB
-rw-r--r--
2023-02-22 10:03
dcfmtsym.h
20.61
KB
-rw-r--r--
2023-02-22 10:03
decimfmt.h
87.57
KB
-rw-r--r--
2023-02-22 10:03
displayoptions.h
7.11
KB
-rw-r--r--
2023-02-22 10:03
docmain.h
7.21
KB
-rw-r--r--
2023-02-22 10:03
dtfmtsym.h
38.22
KB
-rw-r--r--
2023-02-22 10:03
dtintrv.h
3.85
KB
-rw-r--r--
2023-02-22 10:03
dtitvfmt.h
49.27
KB
-rw-r--r--
2023-02-22 10:03
dtitvinf.h
18.63
KB
-rw-r--r--
2023-02-22 10:03
dtptngen.h
28.69
KB
-rw-r--r--
2023-02-22 10:03
dtrule.h
8.69
KB
-rw-r--r--
2023-02-22 10:03
edits.h
20.74
KB
-rw-r--r--
2023-02-22 10:03
enumset.h
2.08
KB
-rw-r--r--
2023-02-22 10:03
errorcode.h
4.84
KB
-rw-r--r--
2023-02-22 10:03
fieldpos.h
8.7
KB
-rw-r--r--
2023-02-22 10:03
filteredbrk.h
5.37
KB
-rw-r--r--
2023-02-22 10:03
fmtable.h
24.43
KB
-rw-r--r--
2023-02-22 10:03
format.h
12.5
KB
-rw-r--r--
2023-02-22 10:03
formattedvalue.h
9.75
KB
-rw-r--r--
2023-02-22 10:03
fpositer.h
3.03
KB
-rw-r--r--
2023-02-22 10:03
gender.h
3.35
KB
-rw-r--r--
2023-02-22 10:03
gregocal.h
31.04
KB
-rw-r--r--
2023-02-22 10:03
icudataver.h
1.02
KB
-rw-r--r--
2023-02-22 10:03
icuplug.h
11.83
KB
-rw-r--r--
2023-02-22 10:03
idna.h
12.71
KB
-rw-r--r--
2023-02-22 10:03
listformatter.h
8.61
KB
-rw-r--r--
2023-02-22 10:03
localebuilder.h
11.08
KB
-rw-r--r--
2023-02-22 10:03
localematcher.h
26.84
KB
-rw-r--r--
2023-02-22 10:03
localpointer.h
19.36
KB
-rw-r--r--
2023-02-22 10:03
locdspnm.h
7.12
KB
-rw-r--r--
2023-02-22 10:03
locid.h
47.66
KB
-rw-r--r--
2023-02-22 10:03
measfmt.h
11.42
KB
-rw-r--r--
2023-02-22 10:03
measunit.h
106.33
KB
-rw-r--r--
2023-02-22 10:03
measure.h
4.33
KB
-rw-r--r--
2023-02-22 10:03
messagepattern.h
33.71
KB
-rw-r--r--
2023-02-22 10:03
msgfmt.h
44.17
KB
-rw-r--r--
2023-02-22 10:03
normalizer2.h
33.66
KB
-rw-r--r--
2023-02-22 10:03
normlzr.h
30.96
KB
-rw-r--r--
2023-02-22 10:03
nounit.h
2.25
KB
-rw-r--r--
2023-02-22 10:03
numberformatter.h
94.82
KB
-rw-r--r--
2023-02-22 10:03
numberrangeformatter.h
25.02
KB
-rw-r--r--
2023-02-22 10:03
numfmt.h
49.84
KB
-rw-r--r--
2023-02-22 10:03
numsys.h
7.22
KB
-rw-r--r--
2023-02-22 10:03
parseerr.h
3.08
KB
-rw-r--r--
2023-02-22 10:03
parsepos.h
5.57
KB
-rw-r--r--
2023-02-22 10:03
platform.h
28.55
KB
-rw-r--r--
2023-02-22 10:03
plurfmt.h
25.25
KB
-rw-r--r--
2023-02-22 10:03
plurrule.h
20.62
KB
-rw-r--r--
2023-02-22 10:03
ptypes.h
3.49
KB
-rw-r--r--
2023-02-22 10:03
putil.h
6.32
KB
-rw-r--r--
2023-02-22 10:03
rbbi.h
28.46
KB
-rw-r--r--
2023-02-22 10:03
rbnf.h
49.82
KB
-rw-r--r--
2023-02-22 10:03
rbtz.h
15.77
KB
-rw-r--r--
2023-02-22 10:03
regex.h
84.41
KB
-rw-r--r--
2023-02-22 10:03
region.h
9.18
KB
-rw-r--r--
2023-02-22 10:03
reldatefmt.h
22.22
KB
-rw-r--r--
2023-02-22 10:03
rep.h
9.37
KB
-rw-r--r--
2023-02-22 10:03
resbund.h
18.09
KB
-rw-r--r--
2023-02-22 10:03
schriter.h
6.1
KB
-rw-r--r--
2023-02-22 10:03
scientificnumberformatter.h
6.44
KB
-rw-r--r--
2023-02-22 10:03
search.h
22.22
KB
-rw-r--r--
2023-02-22 10:03
selfmt.h
14.35
KB
-rw-r--r--
2023-02-22 10:03
simpleformatter.h
12.59
KB
-rw-r--r--
2023-02-22 10:03
simpletz.h
45.65
KB
-rw-r--r--
2023-02-22 10:03
smpdtfmt.h
71.93
KB
-rw-r--r--
2023-02-22 10:03
sortkey.h
11.18
KB
-rw-r--r--
2023-02-22 10:03
std_string.h
1.05
KB
-rw-r--r--
2023-02-22 10:03
strenum.h
9.92
KB
-rw-r--r--
2023-02-22 10:03
stringoptions.h
5.79
KB
-rw-r--r--
2023-02-22 10:03
stringpiece.h
10.05
KB
-rw-r--r--
2023-02-22 10:03
stringtriebuilder.h
15.47
KB
-rw-r--r--
2023-02-22 10:03
stsearch.h
21.42
KB
-rw-r--r--
2023-02-22 10:03
symtable.h
4.27
KB
-rw-r--r--
2023-02-22 10:03
tblcoll.h
36.92
KB
-rw-r--r--
2023-02-22 10:03
timezone.h
43.81
KB
-rw-r--r--
2023-02-22 10:03
tmunit.h
3.4
KB
-rw-r--r--
2023-02-22 10:03
tmutamt.h
4.91
KB
-rw-r--r--
2023-02-22 10:03
tmutfmt.h
7.42
KB
-rw-r--r--
2023-02-22 10:03
translit.h
65.82
KB
-rw-r--r--
2023-02-22 10:03
tzfmt.h
42.93
KB
-rw-r--r--
2023-02-22 10:03
tznames.h
16.85
KB
-rw-r--r--
2023-02-22 10:03
tzrule.h
34.86
KB
-rw-r--r--
2023-02-22 10:03
tztrans.h
6.13
KB
-rw-r--r--
2023-02-22 10:03
ubidi.h
89.61
KB
-rw-r--r--
2023-02-22 10:03
ubiditransform.h
12.71
KB
-rw-r--r--
2023-02-22 10:03
ubrk.h
24.43
KB
-rw-r--r--
2023-02-22 10:03
ucal.h
60.68
KB
-rw-r--r--
2023-02-22 10:03
ucasemap.h
15.21
KB
-rw-r--r--
2023-02-22 10:03
ucat.h
5.35
KB
-rw-r--r--
2023-02-22 10:03
uchar.h
145.09
KB
-rw-r--r--
2023-02-22 10:03
ucharstrie.h
22.53
KB
-rw-r--r--
2023-02-22 10:03
ucharstriebuilder.h
7.48
KB
-rw-r--r--
2023-02-22 10:03
uchriter.h
13.42
KB
-rw-r--r--
2023-02-22 10:03
uclean.h
11.2
KB
-rw-r--r--
2023-02-22 10:03
ucnv.h
83.46
KB
-rw-r--r--
2023-02-22 10:03
ucnv_cb.h
6.58
KB
-rw-r--r--
2023-02-22 10:03
ucnv_err.h
20.98
KB
-rw-r--r--
2023-02-22 10:03
ucnvsel.h
6.24
KB
-rw-r--r--
2023-02-22 10:03
ucol.h
61.95
KB
-rw-r--r--
2023-02-22 10:03
ucoleitr.h
9.82
KB
-rw-r--r--
2023-02-22 10:03
uconfig.h
12.07
KB
-rw-r--r--
2023-02-22 10:03
ucpmap.h
5.54
KB
-rw-r--r--
2023-02-22 10:03
ucptrie.h
22.51
KB
-rw-r--r--
2023-02-22 10:03
ucsdet.h
14.69
KB
-rw-r--r--
2023-02-22 10:03
ucurr.h
16.72
KB
-rw-r--r--
2023-02-22 10:03
udat.h
62.36
KB
-rw-r--r--
2023-02-22 10:03
udata.h
15.63
KB
-rw-r--r--
2023-02-22 10:03
udateintervalformat.h
11.93
KB
-rw-r--r--
2023-02-22 10:03
udatpg.h
30.18
KB
-rw-r--r--
2023-02-22 10:03
udisplaycontext.h
5.94
KB
-rw-r--r--
2023-02-22 10:03
udisplayoptions.h
8.8
KB
-rw-r--r--
2023-02-22 10:03
uenum.h
7.79
KB
-rw-r--r--
2023-02-22 10:03
ufieldpositer.h
4.41
KB
-rw-r--r--
2023-02-22 10:03
uformattable.h
10.97
KB
-rw-r--r--
2023-02-22 10:03
uformattedvalue.h
12.25
KB
-rw-r--r--
2023-02-22 10:03
ugender.h
2.06
KB
-rw-r--r--
2023-02-22 10:03
uidna.h
33.43
KB
-rw-r--r--
2023-02-22 10:03
uiter.h
22.75
KB
-rw-r--r--
2023-02-22 10:03
uldnames.h
10.48
KB
-rw-r--r--
2023-02-22 10:03
ulistformatter.h
10.78
KB
-rw-r--r--
2023-02-22 10:03
uloc.h
54.66
KB
-rw-r--r--
2023-02-22 10:03
ulocdata.h
11.3
KB
-rw-r--r--
2023-02-22 10:03
umachine.h
15.73
KB
-rw-r--r--
2023-02-22 10:03
umisc.h
1.34
KB
-rw-r--r--
2023-02-22 10:03
umsg.h
24.25
KB
-rw-r--r--
2023-02-22 10:03
umutablecptrie.h
8.3
KB
-rw-r--r--
2023-02-22 10:03
unifilt.h
4
KB
-rw-r--r--
2023-02-22 10:03
unifunct.h
4.05
KB
-rw-r--r--
2023-02-22 10:03
unimatch.h
6.1
KB
-rw-r--r--
2023-02-22 10:03
unirepl.h
3.38
KB
-rw-r--r--
2023-02-22 10:03
uniset.h
66.12
KB
-rw-r--r--
2023-02-22 10:03
unistr.h
170.53
KB
-rw-r--r--
2023-02-22 10:03
unorm.h
20.55
KB
-rw-r--r--
2023-02-22 10:03
unorm2.h
24.68
KB
-rw-r--r--
2023-02-22 10:03
unum.h
56.6
KB
-rw-r--r--
2023-02-22 10:03
unumberformatter.h
30.26
KB
-rw-r--r--
2023-02-22 10:03
unumberrangeformatter.h
15.35
KB
-rw-r--r--
2023-02-22 10:03
unumsys.h
7.26
KB
-rw-r--r--
2023-02-22 10:03
uobject.h
10.68
KB
-rw-r--r--
2023-02-22 10:03
upluralrules.h
8.79
KB
-rw-r--r--
2023-02-22 10:03
uregex.h
71.99
KB
-rw-r--r--
2023-02-22 10:03
uregion.h
9.81
KB
-rw-r--r--
2023-02-22 10:03
ureldatefmt.h
17.04
KB
-rw-r--r--
2023-02-22 10:03
urename.h
135.69
KB
-rw-r--r--
2023-02-22 10:03
urep.h
5.38
KB
-rw-r--r--
2023-02-22 10:03
ures.h
36.54
KB
-rw-r--r--
2023-02-22 10:03
uscript.h
27.8
KB
-rw-r--r--
2023-02-22 10:03
usearch.h
39.21
KB
-rw-r--r--
2023-02-22 10:03
uset.h
44.19
KB
-rw-r--r--
2023-02-22 10:03
usetiter.h
9.63
KB
-rw-r--r--
2023-02-22 10:03
ushape.h
18
KB
-rw-r--r--
2023-02-22 10:03
uspoof.h
65.84
KB
-rw-r--r--
2023-02-22 10:03
usprep.h
8.19
KB
-rw-r--r--
2023-02-22 10:03
ustdio.h
38.56
KB
-rw-r--r--
2023-02-22 10:03
ustream.h
1.89
KB
-rw-r--r--
2023-02-22 10:03
ustring.h
72.36
KB
-rw-r--r--
2023-02-22 10:03
ustringtrie.h
3.15
KB
-rw-r--r--
2023-02-22 10:03
utext.h
58.08
KB
-rw-r--r--
2023-02-22 10:03
utf.h
7.87
KB
-rw-r--r--
2023-02-22 10:03
utf16.h
23.35
KB
-rw-r--r--
2023-02-22 10:03
utf32.h
763
B
-rw-r--r--
2023-02-22 10:03
utf8.h
30.83
KB
-rw-r--r--
2023-02-22 10:03
utf_old.h
45.8
KB
-rw-r--r--
2023-02-22 10:03
utmscale.h
13.78
KB
-rw-r--r--
2023-02-22 10:03
utrace.h
17.18
KB
-rw-r--r--
2023-02-22 10:03
utrans.h
25.54
KB
-rw-r--r--
2023-02-22 10:03
utypes.h
31.06
KB
-rw-r--r--
2023-02-22 10:03
uvernum.h
6.33
KB
-rw-r--r--
2023-02-22 10:03
uversion.h
5.99
KB
-rw-r--r--
2023-02-22 10:03
vtzone.h
20.68
KB
-rw-r--r--
2023-02-22 10:03
Save
Rename
// © 2016 and later: Unicode, Inc. and others. // License & terms of use: http://www.unicode.org/copyright.html /* ******************************************************************************* * Copyright (C) 2007-2016, International Business Machines Corporation and * others. All Rights Reserved. ******************************************************************************* * * File DTPTNGEN.H * ******************************************************************************* */ #ifndef __DTPTNGEN_H__ #define __DTPTNGEN_H__ #include "unicode/utypes.h" #if U_SHOW_CPLUSPLUS_API #include "unicode/datefmt.h" #include "unicode/locid.h" #include "unicode/udat.h" #include "unicode/udatpg.h" #include "unicode/unistr.h" U_NAMESPACE_BEGIN /** * \file * \brief C++ API: Date/Time Pattern Generator */ class CharString; class Hashtable; class FormatParser; class DateTimeMatcher; class DistanceInfo; class PatternMap; class PtnSkeleton; class SharedDateTimePatternGenerator; /** * This class provides flexible generation of date format patterns, like "yy-MM-dd". * The user can build up the generator by adding successive patterns. Once that * is done, a query can be made using a "skeleton", which is a pattern which just * includes the desired fields and lengths. The generator will return the "best fit" * pattern corresponding to that skeleton. * <p>The main method people will use is getBestPattern(String skeleton), * since normally this class is pre-built with data from a particular locale. * However, generators can be built directly from other data as well. * <p><i>Issue: may be useful to also have a function that returns the list of * fields in a pattern, in order, since we have that internally. * That would be useful for getting the UI order of field elements.</i> * @stable ICU 3.8 **/ class U_I18N_API DateTimePatternGenerator : public UObject { public: /** * Construct a flexible generator according to default locale. * @param status Output param set to success/failure code on exit, * which must not indicate a failure before the function call. * @stable ICU 3.8 */ static DateTimePatternGenerator* U_EXPORT2 createInstance(UErrorCode& status); /** * Construct a flexible generator according to data for a given locale. * @param uLocale * @param status Output param set to success/failure code on exit, * which must not indicate a failure before the function call. * @stable ICU 3.8 */ static DateTimePatternGenerator* U_EXPORT2 createInstance(const Locale& uLocale, UErrorCode& status); #ifndef U_HIDE_INTERNAL_API /** * For ICU use only. Skips loading the standard date/time patterns (which is done via DateFormat). * * @internal */ static DateTimePatternGenerator* U_EXPORT2 createInstanceNoStdPat(const Locale& uLocale, UErrorCode& status); #endif /* U_HIDE_INTERNAL_API */ /** * Create an empty generator, to be constructed with addPattern(...) etc. * @param status Output param set to success/failure code on exit, * which must not indicate a failure before the function call. * @stable ICU 3.8 */ static DateTimePatternGenerator* U_EXPORT2 createEmptyInstance(UErrorCode& status); /** * Destructor. * @stable ICU 3.8 */ virtual ~DateTimePatternGenerator(); /** * Clone DateTimePatternGenerator object. Clients are responsible for * deleting the DateTimePatternGenerator object cloned. * @stable ICU 3.8 */ DateTimePatternGenerator* clone() const; /** * Return true if another object is semantically equal to this one. * * @param other the DateTimePatternGenerator object to be compared with. * @return true if other is semantically equal to this. * @stable ICU 3.8 */ bool operator==(const DateTimePatternGenerator& other) const; /** * Return true if another object is semantically unequal to this one. * * @param other the DateTimePatternGenerator object to be compared with. * @return true if other is semantically unequal to this. * @stable ICU 3.8 */ bool operator!=(const DateTimePatternGenerator& other) const; /** * Utility to return a unique skeleton from a given pattern. For example, * both "MMM-dd" and "dd/MMM" produce the skeleton "MMMdd". * * @param pattern Input pattern, such as "dd/MMM" * @param status Output param set to success/failure code on exit, * which must not indicate a failure before the function call. * @return skeleton such as "MMMdd" * @stable ICU 56 */ static UnicodeString staticGetSkeleton(const UnicodeString& pattern, UErrorCode& status); /** * Utility to return a unique skeleton from a given pattern. For example, * both "MMM-dd" and "dd/MMM" produce the skeleton "MMMdd". * getSkeleton() works exactly like staticGetSkeleton(). * Use staticGetSkeleton() instead of getSkeleton(). * * @param pattern Input pattern, such as "dd/MMM" * @param status Output param set to success/failure code on exit, * which must not indicate a failure before the function call. * @return skeleton such as "MMMdd" * @stable ICU 3.8 */ UnicodeString getSkeleton(const UnicodeString& pattern, UErrorCode& status); /* { The function is commented out because it is a stable API calling a draft API. After staticGetSkeleton becomes stable, staticGetSkeleton can be used and these comments and the definition of getSkeleton in dtptngen.cpp should be removed. return staticGetSkeleton(pattern, status); }*/ /** * Utility to return a unique base skeleton from a given pattern. This is * the same as the skeleton, except that differences in length are minimized * so as to only preserve the difference between string and numeric form. So * for example, both "MMM-dd" and "d/MMM" produce the skeleton "MMMd" * (notice the single d). * * @param pattern Input pattern, such as "dd/MMM" * @param status Output param set to success/failure code on exit, * which must not indicate a failure before the function call. * @return base skeleton, such as "MMMd" * @stable ICU 56 */ static UnicodeString staticGetBaseSkeleton(const UnicodeString& pattern, UErrorCode& status); /** * Utility to return a unique base skeleton from a given pattern. This is * the same as the skeleton, except that differences in length are minimized * so as to only preserve the difference between string and numeric form. So * for example, both "MMM-dd" and "d/MMM" produce the skeleton "MMMd" * (notice the single d). * getBaseSkeleton() works exactly like staticGetBaseSkeleton(). * Use staticGetBaseSkeleton() instead of getBaseSkeleton(). * * @param pattern Input pattern, such as "dd/MMM" * @param status Output param set to success/failure code on exit, * which must not indicate a failure before the function call. * @return base skeleton, such as "MMMd" * @stable ICU 3.8 */ UnicodeString getBaseSkeleton(const UnicodeString& pattern, UErrorCode& status); /* { The function is commented out because it is a stable API calling a draft API. After staticGetBaseSkeleton becomes stable, staticGetBaseSkeleton can be used and these comments and the definition of getBaseSkeleton in dtptngen.cpp should be removed. return staticGetBaseSkeleton(pattern, status); }*/ /** * Adds a pattern to the generator. If the pattern has the same skeleton as * an existing pattern, and the override parameter is set, then the previous * value is overridden. Otherwise, the previous value is retained. In either * case, the conflicting status is set and previous vale is stored in * conflicting pattern. * <p> * Note that single-field patterns (like "MMM") are automatically added, and * don't need to be added explicitly! * * @param pattern Input pattern, such as "dd/MMM" * @param override When existing values are to be overridden use true, * otherwise use false. * @param conflictingPattern Previous pattern with the same skeleton. * @param status Output param set to success/failure code on exit, * which must not indicate a failure before the function call. * @return conflicting status. The value could be UDATPG_NO_CONFLICT, * UDATPG_BASE_CONFLICT or UDATPG_CONFLICT. * @stable ICU 3.8 * <p> * <h4>Sample code</h4> * \snippet samples/dtptngsample/dtptngsample.cpp getBestPatternExample1 * \snippet samples/dtptngsample/dtptngsample.cpp addPatternExample * <p> */ UDateTimePatternConflict addPattern(const UnicodeString& pattern, UBool override, UnicodeString& conflictingPattern, UErrorCode& status); /** * An AppendItem format is a pattern used to append a field if there is no * good match. For example, suppose that the input skeleton is "GyyyyMMMd", * and there is no matching pattern internally, but there is a pattern * matching "yyyyMMMd", say "d-MM-yyyy". Then that pattern is used, plus the * G. The way these two are conjoined is by using the AppendItemFormat for G * (era). So if that value is, say "{0}, {1}" then the final resulting * pattern is "d-MM-yyyy, G". * <p> * There are actually three available variables: {0} is the pattern so far, * {1} is the element we are adding, and {2} is the name of the element. * <p> * This reflects the way that the CLDR data is organized. * * @param field such as UDATPG_ERA_FIELD. * @param value pattern, such as "{0}, {1}" * @stable ICU 3.8 */ void setAppendItemFormat(UDateTimePatternField field, const UnicodeString& value); /** * Getter corresponding to setAppendItemFormat. Values below 0 or at or * above UDATPG_FIELD_COUNT are illegal arguments. * * @param field such as UDATPG_ERA_FIELD. * @return append pattern for field * @stable ICU 3.8 */ const UnicodeString& getAppendItemFormat(UDateTimePatternField field) const; /** * Sets the names of field, eg "era" in English for ERA. These are only * used if the corresponding AppendItemFormat is used, and if it contains a * {2} variable. * <p> * This reflects the way that the CLDR data is organized. * * @param field such as UDATPG_ERA_FIELD. * @param value name of the field * @stable ICU 3.8 */ void setAppendItemName(UDateTimePatternField field, const UnicodeString& value); /** * Getter corresponding to setAppendItemNames. Values below 0 or at or above * UDATPG_FIELD_COUNT are illegal arguments. Note: The more general method * for getting date/time field display names is getFieldDisplayName. * * @param field such as UDATPG_ERA_FIELD. * @return name for field * @see getFieldDisplayName * @stable ICU 3.8 */ const UnicodeString& getAppendItemName(UDateTimePatternField field) const; /** * The general interface to get a display name for a particular date/time field, * in one of several possible display widths. * * @param field The desired UDateTimePatternField, such as UDATPG_ERA_FIELD. * @param width The desired UDateTimePGDisplayWidth, such as UDATPG_ABBREVIATED. * @return The display name for field * @stable ICU 61 */ UnicodeString getFieldDisplayName(UDateTimePatternField field, UDateTimePGDisplayWidth width) const; /** * The DateTimeFormat is a message format pattern used to compose date and * time patterns. The default pattern in the root locale is "{1} {0}", where * {1} will be replaced by the date pattern and {0} will be replaced by the * time pattern; however, other locales may specify patterns such as * "{1}, {0}" or "{1} 'at' {0}", etc. * <p> * This is used when the input skeleton contains both date and time fields, * but there is not a close match among the added patterns. For example, * suppose that this object was created by adding "dd-MMM" and "hh:mm", and * its datetimeFormat is the default "{1} {0}". Then if the input skeleton * is "MMMdhmm", there is not an exact match, so the input skeleton is * broken up into two components "MMMd" and "hmm". There are close matches * for those two skeletons, so the result is put together with this pattern, * resulting in "d-MMM h:mm". * * There are four DateTimeFormats in a DateTimePatternGenerator object, * corresponding to date styles UDAT_FULL..UDAT_SHORT. This method sets * all of them to the specified pattern. To set them individually, see * setDateTimeFormat(UDateFormatStyle style, ...). * * @param dateTimeFormat * message format pattern, here {1} will be replaced by the date * pattern and {0} will be replaced by the time pattern. * @stable ICU 3.8 */ void setDateTimeFormat(const UnicodeString& dateTimeFormat); /** * Getter corresponding to setDateTimeFormat. * * There are four DateTimeFormats in a DateTimePatternGenerator object, * corresponding to date styles UDAT_FULL..UDAT_SHORT. This method gets * the style for UDAT_MEDIUM (the default). To get them individually, see * getDateTimeFormat(UDateFormatStyle style). * * @return DateTimeFormat. * @stable ICU 3.8 */ const UnicodeString& getDateTimeFormat() const; #if !UCONFIG_NO_FORMATTING #ifndef U_HIDE_DRAFT_API /** * dateTimeFormats are message patterns used to compose combinations of date * and time patterns. There are four length styles, corresponding to the * inferred style of the date pattern; these are UDateFormatStyle values: * - UDAT_FULL (for date pattern with weekday and long month), else * - UDAT_LONG (for a date pattern with long month), else * - UDAT_MEDIUM (for a date pattern with abbreviated month), else * - UDAT_SHORT (for any other date pattern). * For details on dateTimeFormats, see * https://www.unicode.org/reports/tr35/tr35-dates.html#dateTimeFormats. * The default pattern in the root locale for all styles is "{1} {0}". * * @param style * one of DateFormat.FULL..DateFormat.SHORT. Error if out of range. * @param dateTimeFormat * the new dateTimeFormat to set for the the specified style * @param status * in/out parameter; if no failure status is already set, * it will be set according to result of the function (e.g. * U_ILLEGAL_ARGUMENT_ERROR for style out of range). * @draft ICU 71 */ void setDateTimeFormat(UDateFormatStyle style, const UnicodeString& dateTimeFormat, UErrorCode& status); /** * Getter corresponding to setDateTimeFormat. * * @param style * one of UDAT_FULL..UDAT_SHORT. Error if out of range. * @param status * in/out parameter; if no failure status is already set, * it will be set according to result of the function (e.g. * U_ILLEGAL_ARGUMENT_ERROR for style out of range). * @return * the current dateTimeFormat for the the specified style, or * empty string in case of error. The UnicodeString reference, * or the contents of the string, may no longer be valid if * setDateTimeFormat is called, or the DateTimePatternGenerator * object is deleted. * @draft ICU 71 */ const UnicodeString& getDateTimeFormat(UDateFormatStyle style, UErrorCode& status) const; #endif /* U_HIDE_DRAFT_API */ #endif /* #if !UCONFIG_NO_FORMATTING */ /** * Return the best pattern matching the input skeleton. It is guaranteed to * have all of the fields in the skeleton. * * @param skeleton * The skeleton is a pattern containing only the variable fields. * For example, "MMMdd" and "mmhh" are skeletons. * @param status Output param set to success/failure code on exit, * which must not indicate a failure before the function call. * @return bestPattern * The best pattern found from the given skeleton. * @stable ICU 3.8 * <p> * <h4>Sample code</h4> * \snippet samples/dtptngsample/dtptngsample.cpp getBestPatternExample1 * \snippet samples/dtptngsample/dtptngsample.cpp getBestPatternExample * <p> */ UnicodeString getBestPattern(const UnicodeString& skeleton, UErrorCode& status); /** * Return the best pattern matching the input skeleton. It is guaranteed to * have all of the fields in the skeleton. * * @param skeleton * The skeleton is a pattern containing only the variable fields. * For example, "MMMdd" and "mmhh" are skeletons. * @param options * Options for forcing the length of specified fields in the * returned pattern to match those in the skeleton (when this * would not happen otherwise). For default behavior, use * UDATPG_MATCH_NO_OPTIONS. * @param status * Output param set to success/failure code on exit, * which must not indicate a failure before the function call. * @return bestPattern * The best pattern found from the given skeleton. * @stable ICU 4.4 */ UnicodeString getBestPattern(const UnicodeString& skeleton, UDateTimePatternMatchOptions options, UErrorCode& status); /** * Adjusts the field types (width and subtype) of a pattern to match what is * in a skeleton. That is, if you supply a pattern like "d-M H:m", and a * skeleton of "MMMMddhhmm", then the input pattern is adjusted to be * "dd-MMMM hh:mm". This is used internally to get the best match for the * input skeleton, but can also be used externally. * * @param pattern Input pattern * @param skeleton * The skeleton is a pattern containing only the variable fields. * For example, "MMMdd" and "mmhh" are skeletons. * @param status Output param set to success/failure code on exit, * which must not indicate a failure before the function call. * @return pattern adjusted to match the skeleton fields widths and subtypes. * @stable ICU 3.8 * <p> * <h4>Sample code</h4> * \snippet samples/dtptngsample/dtptngsample.cpp getBestPatternExample1 * \snippet samples/dtptngsample/dtptngsample.cpp replaceFieldTypesExample * <p> */ UnicodeString replaceFieldTypes(const UnicodeString& pattern, const UnicodeString& skeleton, UErrorCode& status); /** * Adjusts the field types (width and subtype) of a pattern to match what is * in a skeleton. That is, if you supply a pattern like "d-M H:m", and a * skeleton of "MMMMddhhmm", then the input pattern is adjusted to be * "dd-MMMM hh:mm". This is used internally to get the best match for the * input skeleton, but can also be used externally. * * @param pattern Input pattern * @param skeleton * The skeleton is a pattern containing only the variable fields. * For example, "MMMdd" and "mmhh" are skeletons. * @param options * Options controlling whether the length of specified fields in the * pattern are adjusted to match those in the skeleton (when this * would not happen otherwise). For default behavior, use * UDATPG_MATCH_NO_OPTIONS. * @param status * Output param set to success/failure code on exit, * which must not indicate a failure before the function call. * @return pattern adjusted to match the skeleton fields widths and subtypes. * @stable ICU 4.4 */ UnicodeString replaceFieldTypes(const UnicodeString& pattern, const UnicodeString& skeleton, UDateTimePatternMatchOptions options, UErrorCode& status); /** * Return a list of all the skeletons (in canonical form) from this class. * * Call getPatternForSkeleton() to get the corresponding pattern. * * @param status Output param set to success/failure code on exit, * which must not indicate a failure before the function call. * @return StringEnumeration with the skeletons. * The caller must delete the object. * @stable ICU 3.8 */ StringEnumeration* getSkeletons(UErrorCode& status) const; /** * Get the pattern corresponding to a given skeleton. * @param skeleton * @return pattern corresponding to a given skeleton. * @stable ICU 3.8 */ const UnicodeString& getPatternForSkeleton(const UnicodeString& skeleton) const; /** * Return a list of all the base skeletons (in canonical form) from this class. * * @param status Output param set to success/failure code on exit, * which must not indicate a failure before the function call. * @return a StringEnumeration with the base skeletons. * The caller must delete the object. * @stable ICU 3.8 */ StringEnumeration* getBaseSkeletons(UErrorCode& status) const; #ifndef U_HIDE_INTERNAL_API /** * Return a list of redundant patterns are those which if removed, make no * difference in the resulting getBestPattern values. This method returns a * list of them, to help check the consistency of the patterns used to build * this generator. * * @param status Output param set to success/failure code on exit, * which must not indicate a failure before the function call. * @return a StringEnumeration with the redundant pattern. * The caller must delete the object. * @internal ICU 3.8 */ StringEnumeration* getRedundants(UErrorCode& status); #endif /* U_HIDE_INTERNAL_API */ /** * The decimal value is used in formatting fractions of seconds. If the * skeleton contains fractional seconds, then this is used with the * fractional seconds. For example, suppose that the input pattern is * "hhmmssSSSS", and the best matching pattern internally is "H:mm:ss", and * the decimal string is ",". Then the resulting pattern is modified to be * "H:mm:ss,SSSS" * * @param decimal * @stable ICU 3.8 */ void setDecimal(const UnicodeString& decimal); /** * Getter corresponding to setDecimal. * @return UnicodeString corresponding to the decimal point * @stable ICU 3.8 */ const UnicodeString& getDecimal() const; #if !UCONFIG_NO_FORMATTING /** * Get the default hour cycle for a locale. Uses the locale that the * DateTimePatternGenerator was initially created with. * * Cannot be used on an empty DateTimePatternGenerator instance. * * @param status Output param set to success/failure code on exit, which * which must not indicate a failure before the function call. * Set to U_UNSUPPORTED_ERROR if used on an empty instance. * @return the default hour cycle. * @stable ICU 67 */ UDateFormatHourCycle getDefaultHourCycle(UErrorCode& status) const; #endif /* #if !UCONFIG_NO_FORMATTING */ /** * ICU "poor man's RTTI", returns a UClassID for the actual class. * * @stable ICU 3.8 */ virtual UClassID getDynamicClassID() const override; /** * ICU "poor man's RTTI", returns a UClassID for this class. * * @stable ICU 3.8 */ static UClassID U_EXPORT2 getStaticClassID(void); private: /** * Constructor. */ DateTimePatternGenerator(UErrorCode & status); /** * Constructor. */ DateTimePatternGenerator(const Locale& locale, UErrorCode & status, UBool skipStdPatterns = false); /** * Copy constructor. * @param other DateTimePatternGenerator to copy */ DateTimePatternGenerator(const DateTimePatternGenerator& other); /** * Default assignment operator. * @param other DateTimePatternGenerator to copy */ DateTimePatternGenerator& operator=(const DateTimePatternGenerator& other); static const int32_t UDATPG_WIDTH_COUNT = UDATPG_NARROW + 1; Locale pLocale; // pattern locale FormatParser *fp; DateTimeMatcher* dtMatcher; DistanceInfo *distanceInfo; PatternMap *patternMap; UnicodeString appendItemFormats[UDATPG_FIELD_COUNT]; UnicodeString fieldDisplayNames[UDATPG_FIELD_COUNT][UDATPG_WIDTH_COUNT]; UnicodeString dateTimeFormat[4]; UnicodeString decimal; DateTimeMatcher *skipMatcher; Hashtable *fAvailableFormatKeyHash; UnicodeString emptyString; char16_t fDefaultHourFormatChar; int32_t fAllowedHourFormats[7]; // Actually an array of AllowedHourFormat enum type, ending with UNKNOWN. // Internal error code used for recording/reporting errors that occur during methods that do not // have a UErrorCode parameter. For example: the Copy Constructor, or the ::clone() method. // When this is set to an error the object is in an invalid state. UErrorCode internalErrorCode; /* internal flags masks for adjustFieldTypes etc. */ enum { kDTPGNoFlags = 0, kDTPGFixFractionalSeconds = 1, kDTPGSkeletonUsesCapJ = 2 // with #13183, no longer need flags for b, B }; void initData(const Locale &locale, UErrorCode &status, UBool skipStdPatterns = false); void addCanonicalItems(UErrorCode &status); void addICUPatterns(const Locale& locale, UErrorCode& status); void hackTimes(const UnicodeString& hackPattern, UErrorCode& status); void getCalendarTypeToUse(const Locale& locale, CharString& destination, UErrorCode& err); void consumeShortTimePattern(const UnicodeString& shortTimePattern, UErrorCode& status); void addCLDRData(const Locale& locale, UErrorCode& status); UDateTimePatternConflict addPatternWithSkeleton(const UnicodeString& pattern, const UnicodeString * skeletonToUse, UBool override, UnicodeString& conflictingPattern, UErrorCode& status); void initHashtable(UErrorCode& status); void setDateTimeFromCalendar(const Locale& locale, UErrorCode& status); void setDecimalSymbols(const Locale& locale, UErrorCode& status); UDateTimePatternField getAppendFormatNumber(const char* field) const; // Note for the next 3: UDateTimePGDisplayWidth is now stable ICU 61 UDateTimePatternField getFieldAndWidthIndices(const char* key, UDateTimePGDisplayWidth* widthP) const; void setFieldDisplayName(UDateTimePatternField field, UDateTimePGDisplayWidth width, const UnicodeString& value); UnicodeString& getMutableFieldDisplayName(UDateTimePatternField field, UDateTimePGDisplayWidth width); void getAppendName(UDateTimePatternField field, UnicodeString& value); UnicodeString mapSkeletonMetacharacters(const UnicodeString& patternForm, int32_t* flags, UErrorCode& status); const UnicodeString* getBestRaw(DateTimeMatcher& source, int32_t includeMask, DistanceInfo* missingFields, UErrorCode& status, const PtnSkeleton** specifiedSkeletonPtr = 0); UnicodeString adjustFieldTypes(const UnicodeString& pattern, const PtnSkeleton* specifiedSkeleton, int32_t flags, UDateTimePatternMatchOptions options = UDATPG_MATCH_NO_OPTIONS); UnicodeString getBestAppending(int32_t missingFields, int32_t flags, UErrorCode& status, UDateTimePatternMatchOptions options = UDATPG_MATCH_NO_OPTIONS); int32_t getTopBitNumber(int32_t foundMask) const; void setAvailableFormat(const UnicodeString &key, UErrorCode& status); UBool isAvailableFormatSet(const UnicodeString &key) const; void copyHashtable(Hashtable *other, UErrorCode &status); UBool isCanonicalItem(const UnicodeString& item) const; static void U_CALLCONV loadAllowedHourFormatsData(UErrorCode &status); void getAllowedHourFormats(const Locale &locale, UErrorCode &status); struct U_HIDDEN AppendItemFormatsSink; struct U_HIDDEN AppendItemNamesSink; struct U_HIDDEN AvailableFormatsSink; } ;// end class DateTimePatternGenerator U_NAMESPACE_END #endif /* U_SHOW_CPLUSPLUS_API */ #endif