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 : 3.141.244.88
Domains :
Cant Read [ /etc/named.conf ]
User : cleahvkv
Terminal
Auto Root
Create File
Create Folder
Localroot Suggester
Backdoor Destroyer
Readme
/
opt /
alt /
libicu65 /
usr /
include /
unicode /
Delete
Unzip
Name
Size
Permission
Date
Action
alphaindex.h
26.48
KB
-rw-r--r--
2022-02-08 16:22
appendable.h
8.49
KB
-rw-r--r--
2022-02-08 16:22
basictz.h
9.15
KB
-rw-r--r--
2022-02-08 16:22
brkiter.h
27.8
KB
-rw-r--r--
2022-02-08 16:22
bytestream.h
9.6
KB
-rw-r--r--
2022-02-08 16:22
bytestrie.h
20.77
KB
-rw-r--r--
2022-02-08 16:22
bytestriebuilder.h
7.08
KB
-rw-r--r--
2022-02-08 16:22
calendar.h
105.74
KB
-rw-r--r--
2022-02-08 16:22
caniter.h
7.43
KB
-rw-r--r--
2022-02-08 16:22
casemap.h
25.33
KB
-rw-r--r--
2022-02-08 16:22
char16ptr.h
7.22
KB
-rw-r--r--
2022-02-08 16:22
chariter.h
24.05
KB
-rw-r--r--
2022-02-08 16:22
choicfmt.h
23.91
KB
-rw-r--r--
2022-02-08 16:22
coleitr.h
13.76
KB
-rw-r--r--
2022-02-08 16:22
coll.h
56.23
KB
-rw-r--r--
2022-02-08 16:22
compactdecimalformat.h
6.88
KB
-rw-r--r--
2022-02-08 16:22
curramt.h
3.76
KB
-rw-r--r--
2022-02-08 16:22
currpinf.h
7.3
KB
-rw-r--r--
2022-02-08 16:22
currunit.h
4.05
KB
-rw-r--r--
2022-02-08 16:22
datefmt.h
40.67
KB
-rw-r--r--
2022-02-08 16:22
dbbi.h
1.19
KB
-rw-r--r--
2022-02-08 16:22
dcfmtsym.h
20.13
KB
-rw-r--r--
2022-02-08 16:22
decimfmt.h
87.38
KB
-rw-r--r--
2022-02-08 16:22
docmain.h
6.97
KB
-rw-r--r--
2022-02-08 16:22
dtfmtsym.h
37.7
KB
-rw-r--r--
2022-02-08 16:22
dtintrv.h
3.84
KB
-rw-r--r--
2022-02-08 16:22
dtitvfmt.h
46.63
KB
-rw-r--r--
2022-02-08 16:22
dtitvinf.h
18.51
KB
-rw-r--r--
2022-02-08 16:22
dtptngen.h
25.08
KB
-rw-r--r--
2022-02-08 16:22
dtrule.h
8.68
KB
-rw-r--r--
2022-02-08 16:22
edits.h
20.74
KB
-rw-r--r--
2022-02-08 16:22
enumset.h
2.08
KB
-rw-r--r--
2022-02-08 16:22
errorcode.h
4.84
KB
-rw-r--r--
2022-02-08 16:22
fieldpos.h
8.69
KB
-rw-r--r--
2022-02-08 16:22
filteredbrk.h
5.37
KB
-rw-r--r--
2022-02-08 16:22
fmtable.h
24.42
KB
-rw-r--r--
2022-02-08 16:22
format.h
12.5
KB
-rw-r--r--
2022-02-08 16:22
formattedvalue.h
10.27
KB
-rw-r--r--
2022-02-08 16:22
fpositer.h
3.04
KB
-rw-r--r--
2022-02-08 16:22
gender.h
3.33
KB
-rw-r--r--
2022-02-08 16:22
gregocal.h
31.71
KB
-rw-r--r--
2022-02-08 16:22
icudataver.h
1.03
KB
-rw-r--r--
2022-02-08 16:22
icuplug.h
11.88
KB
-rw-r--r--
2022-02-08 16:22
idna.h
12.7
KB
-rw-r--r--
2022-02-08 16:22
listformatter.h
9.47
KB
-rw-r--r--
2022-02-08 16:22
localebuilder.h
11.27
KB
-rw-r--r--
2022-02-08 16:22
localematcher.h
22.5
KB
-rw-r--r--
2022-02-08 16:22
localpointer.h
19.69
KB
-rw-r--r--
2022-02-08 16:22
locdspnm.h
7.12
KB
-rw-r--r--
2022-02-08 16:22
locid.h
47.4
KB
-rw-r--r--
2022-02-08 16:22
measfmt.h
11.33
KB
-rw-r--r--
2022-02-08 16:22
measunit.h
93.31
KB
-rw-r--r--
2022-02-08 16:22
measure.h
4.32
KB
-rw-r--r--
2022-02-08 16:22
messagepattern.h
33.71
KB
-rw-r--r--
2022-02-08 16:22
msgfmt.h
44.11
KB
-rw-r--r--
2022-02-08 16:22
normalizer2.h
34.03
KB
-rw-r--r--
2022-02-08 16:22
normlzr.h
30.94
KB
-rw-r--r--
2022-02-08 16:22
nounit.h
2.69
KB
-rw-r--r--
2022-02-08 16:22
numberformatter.h
86.31
KB
-rw-r--r--
2022-02-08 16:22
numberrangeformatter.h
30.14
KB
-rw-r--r--
2022-02-08 16:22
numfmt.h
49.81
KB
-rw-r--r--
2022-02-08 16:22
numsys.h
7.19
KB
-rw-r--r--
2022-02-08 16:22
parseerr.h
3.08
KB
-rw-r--r--
2022-02-08 16:22
parsepos.h
5.56
KB
-rw-r--r--
2022-02-08 16:22
platform.h
28.08
KB
-rw-r--r--
2022-02-08 16:22
plurfmt.h
25.2
KB
-rw-r--r--
2022-02-08 16:22
plurrule.h
18.39
KB
-rw-r--r--
2022-02-08 16:22
ptypes.h
3.49
KB
-rw-r--r--
2022-02-08 16:22
putil.h
6.33
KB
-rw-r--r--
2022-02-08 16:22
rbbi.h
26.58
KB
-rw-r--r--
2022-02-08 16:22
rbnf.h
48.73
KB
-rw-r--r--
2022-02-08 16:22
rbtz.h
15.6
KB
-rw-r--r--
2022-02-08 16:22
regex.h
84.36
KB
-rw-r--r--
2022-02-08 16:22
region.h
9.18
KB
-rw-r--r--
2022-02-08 16:22
reldatefmt.h
22.62
KB
-rw-r--r--
2022-02-08 16:22
rep.h
9.37
KB
-rw-r--r--
2022-02-08 16:22
resbund.h
18.07
KB
-rw-r--r--
2022-02-08 16:22
schriter.h
6.32
KB
-rw-r--r--
2022-02-08 16:22
scientificnumberformatter.h
6.4
KB
-rw-r--r--
2022-02-08 16:22
search.h
22.22
KB
-rw-r--r--
2022-02-08 16:22
selfmt.h
14.3
KB
-rw-r--r--
2022-02-08 16:22
simpleformatter.h
12.59
KB
-rw-r--r--
2022-02-08 16:22
simpletz.h
45.44
KB
-rw-r--r--
2022-02-08 16:22
smpdtfmt.h
70.97
KB
-rw-r--r--
2022-02-08 16:22
sortkey.h
11.18
KB
-rw-r--r--
2022-02-08 16:22
std_string.h
1.05
KB
-rw-r--r--
2022-02-08 16:22
strenum.h
9.92
KB
-rw-r--r--
2022-02-08 16:22
stringoptions.h
5.79
KB
-rw-r--r--
2022-02-08 16:22
stringpiece.h
7.38
KB
-rw-r--r--
2022-02-08 16:22
stringtriebuilder.h
15.33
KB
-rw-r--r--
2022-02-08 16:22
stsearch.h
21.3
KB
-rw-r--r--
2022-02-08 16:22
symtable.h
4.27
KB
-rw-r--r--
2022-02-08 16:22
tblcoll.h
36.61
KB
-rw-r--r--
2022-02-08 16:22
timezone.h
41.02
KB
-rw-r--r--
2022-02-08 16:22
tmunit.h
3.38
KB
-rw-r--r--
2022-02-08 16:22
tmutamt.h
4.9
KB
-rw-r--r--
2022-02-08 16:22
tmutfmt.h
7.85
KB
-rw-r--r--
2022-02-08 16:22
translit.h
65.82
KB
-rw-r--r--
2022-02-08 16:22
tzfmt.h
42.89
KB
-rw-r--r--
2022-02-08 16:22
tznames.h
16.85
KB
-rw-r--r--
2022-02-08 16:22
tzrule.h
35.37
KB
-rw-r--r--
2022-02-08 16:22
tztrans.h
6.12
KB
-rw-r--r--
2022-02-08 16:22
ubidi.h
89.56
KB
-rw-r--r--
2022-02-08 16:22
ubiditransform.h
12.65
KB
-rw-r--r--
2022-02-08 16:22
ubrk.h
23.97
KB
-rw-r--r--
2022-02-08 16:22
ucal.h
56.9
KB
-rw-r--r--
2022-02-08 16:22
ucasemap.h
15.18
KB
-rw-r--r--
2022-02-08 16:22
ucat.h
5.36
KB
-rw-r--r--
2022-02-08 16:22
uchar.h
140.56
KB
-rw-r--r--
2022-02-08 16:22
ucharstrie.h
22.58
KB
-rw-r--r--
2022-02-08 16:22
ucharstriebuilder.h
7.21
KB
-rw-r--r--
2022-02-08 16:22
uchriter.h
13.2
KB
-rw-r--r--
2022-02-08 16:22
uclean.h
11.21
KB
-rw-r--r--
2022-02-08 16:22
ucnv.h
83.09
KB
-rw-r--r--
2022-02-08 16:22
ucnv_cb.h
6.59
KB
-rw-r--r--
2022-02-08 16:22
ucnv_err.h
20.99
KB
-rw-r--r--
2022-02-08 16:22
ucnvsel.h
6.14
KB
-rw-r--r--
2022-02-08 16:22
ucol.h
61.46
KB
-rw-r--r--
2022-02-08 16:22
ucoleitr.h
9.46
KB
-rw-r--r--
2022-02-08 16:22
uconfig.h
12.07
KB
-rw-r--r--
2022-02-08 16:22
ucpmap.h
5.53
KB
-rw-r--r--
2022-02-08 16:22
ucptrie.h
22.46
KB
-rw-r--r--
2022-02-08 16:22
ucsdet.h
14.67
KB
-rw-r--r--
2022-02-08 16:22
ucurr.h
16.12
KB
-rw-r--r--
2022-02-08 16:22
udat.h
60.88
KB
-rw-r--r--
2022-02-08 16:22
udata.h
15.56
KB
-rw-r--r--
2022-02-08 16:22
udateintervalformat.h
10.03
KB
-rw-r--r--
2022-02-08 16:22
udatpg.h
26.01
KB
-rw-r--r--
2022-02-08 16:22
udisplaycontext.h
5.89
KB
-rw-r--r--
2022-02-08 16:22
uenum.h
7.78
KB
-rw-r--r--
2022-02-08 16:22
ufieldpositer.h
4.36
KB
-rw-r--r--
2022-02-08 16:22
uformattable.h
10.94
KB
-rw-r--r--
2022-02-08 16:22
uformattedvalue.h
12.14
KB
-rw-r--r--
2022-02-08 16:22
ugender.h
2
KB
-rw-r--r--
2022-02-08 16:22
uidna.h
33.37
KB
-rw-r--r--
2022-02-08 16:22
uiter.h
22.77
KB
-rw-r--r--
2022-02-08 16:22
uldnames.h
10.45
KB
-rw-r--r--
2022-02-08 16:22
ulistformatter.h
8.83
KB
-rw-r--r--
2022-02-08 16:22
uloc.h
52.54
KB
-rw-r--r--
2022-02-08 16:22
ulocdata.h
11.26
KB
-rw-r--r--
2022-02-08 16:22
umachine.h
14.53
KB
-rw-r--r--
2022-02-08 16:22
umisc.h
1.33
KB
-rw-r--r--
2022-02-08 16:22
umsg.h
24.23
KB
-rw-r--r--
2022-02-08 16:22
umutablecptrie.h
8.24
KB
-rw-r--r--
2022-02-08 16:22
unifilt.h
3.96
KB
-rw-r--r--
2022-02-08 16:22
unifunct.h
4.04
KB
-rw-r--r--
2022-02-08 16:22
unimatch.h
6.1
KB
-rw-r--r--
2022-02-08 16:22
unirepl.h
3.38
KB
-rw-r--r--
2022-02-08 16:22
uniset.h
64.9
KB
-rw-r--r--
2022-02-08 16:22
unistr.h
170.43
KB
-rw-r--r--
2022-02-08 16:22
unorm.h
20.52
KB
-rw-r--r--
2022-02-08 16:22
unorm2.h
24.66
KB
-rw-r--r--
2022-02-08 16:22
unum.h
53.62
KB
-rw-r--r--
2022-02-08 16:22
unumberformatter.h
25.36
KB
-rw-r--r--
2022-02-08 16:22
unumsys.h
7.21
KB
-rw-r--r--
2022-02-08 16:22
uobject.h
10.68
KB
-rw-r--r--
2022-02-08 16:22
upluralrules.h
7.88
KB
-rw-r--r--
2022-02-08 16:22
uregex.h
72.05
KB
-rw-r--r--
2022-02-08 16:22
uregion.h
9.84
KB
-rw-r--r--
2022-02-08 16:22
ureldatefmt.h
17.26
KB
-rw-r--r--
2022-02-08 16:22
urename.h
130.97
KB
-rw-r--r--
2022-02-08 16:22
urep.h
5.38
KB
-rw-r--r--
2022-02-08 16:22
ures.h
36.54
KB
-rw-r--r--
2022-02-08 16:22
uscript.h
26.87
KB
-rw-r--r--
2022-02-08 16:22
usearch.h
38.12
KB
-rw-r--r--
2022-02-08 16:22
uset.h
40
KB
-rw-r--r--
2022-02-08 16:22
usetiter.h
9.55
KB
-rw-r--r--
2022-02-08 16:22
ushape.h
18
KB
-rw-r--r--
2022-02-08 16:22
uspoof.h
65.9
KB
-rw-r--r--
2022-02-08 16:22
usprep.h
8.14
KB
-rw-r--r--
2022-02-08 16:22
ustdio.h
38.54
KB
-rw-r--r--
2022-02-08 16:22
ustream.h
1.89
KB
-rw-r--r--
2022-02-08 16:22
ustring.h
72.47
KB
-rw-r--r--
2022-02-08 16:22
ustringtrie.h
3.15
KB
-rw-r--r--
2022-02-08 16:22
utext.h
58.13
KB
-rw-r--r--
2022-02-08 16:22
utf.h
7.86
KB
-rw-r--r--
2022-02-08 16:22
utf16.h
23.32
KB
-rw-r--r--
2022-02-08 16:22
utf32.h
763
B
-rw-r--r--
2022-02-08 16:22
utf8.h
30.96
KB
-rw-r--r--
2022-02-08 16:22
utf_old.h
45.83
KB
-rw-r--r--
2022-02-08 16:22
utmscale.h
13.78
KB
-rw-r--r--
2022-02-08 16:22
utrace.h
15.73
KB
-rw-r--r--
2022-02-08 16:22
utrans.h
25.52
KB
-rw-r--r--
2022-02-08 16:22
utypes.h
30.74
KB
-rw-r--r--
2022-02-08 16:22
uvernum.h
6.67
KB
-rw-r--r--
2022-02-08 16:22
uversion.h
6
KB
-rw-r--r--
2022-02-08 16:22
vtzone.h
20.3
KB
-rw-r--r--
2022-02-08 16:22
Save
Rename
// © 2016 and later: Unicode, Inc. and others. // License & terms of use: http://www.unicode.org/copyright.html /* ******************************************************************************* * * Copyright (C) 2007-2015, International Business Machines * Corporation and others. All Rights Reserved. * ******************************************************************************* * file name: udatpg.h * encoding: UTF-8 * tab size: 8 (not used) * indentation:4 * * created on: 2007jul30 * created by: Markus W. Scherer */ #ifndef __UDATPG_H__ #define __UDATPG_H__ #include "unicode/utypes.h" #include "unicode/uenum.h" #include "unicode/localpointer.h" /** * \file * \brief C API: Wrapper for icu::DateTimePatternGenerator (unicode/dtptngen.h). * * UDateTimePatternGenerator 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 udatpg_getBestPattern, since normally * UDateTimePatternGenerator 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> */ /** * Opaque type for a date/time pattern generator object. * @stable ICU 3.8 */ typedef void *UDateTimePatternGenerator; /** * Field number constants for udatpg_getAppendItemFormats() and similar functions. * These constants are separate from UDateFormatField despite semantic overlap * because some fields are merged for the date/time pattern generator. * @stable ICU 3.8 */ typedef enum UDateTimePatternField { /** @stable ICU 3.8 */ UDATPG_ERA_FIELD, /** @stable ICU 3.8 */ UDATPG_YEAR_FIELD, /** @stable ICU 3.8 */ UDATPG_QUARTER_FIELD, /** @stable ICU 3.8 */ UDATPG_MONTH_FIELD, /** @stable ICU 3.8 */ UDATPG_WEEK_OF_YEAR_FIELD, /** @stable ICU 3.8 */ UDATPG_WEEK_OF_MONTH_FIELD, /** @stable ICU 3.8 */ UDATPG_WEEKDAY_FIELD, /** @stable ICU 3.8 */ UDATPG_DAY_OF_YEAR_FIELD, /** @stable ICU 3.8 */ UDATPG_DAY_OF_WEEK_IN_MONTH_FIELD, /** @stable ICU 3.8 */ UDATPG_DAY_FIELD, /** @stable ICU 3.8 */ UDATPG_DAYPERIOD_FIELD, /** @stable ICU 3.8 */ UDATPG_HOUR_FIELD, /** @stable ICU 3.8 */ UDATPG_MINUTE_FIELD, /** @stable ICU 3.8 */ UDATPG_SECOND_FIELD, /** @stable ICU 3.8 */ UDATPG_FRACTIONAL_SECOND_FIELD, /** @stable ICU 3.8 */ UDATPG_ZONE_FIELD, /* Do not conditionalize the following with #ifndef U_HIDE_DEPRECATED_API, * it is needed for layout of DateTimePatternGenerator object. */ #ifndef U_FORCE_HIDE_DEPRECATED_API /** * One more than the highest normal UDateTimePatternField value. * @deprecated ICU 58 The numeric value may change over time, see ICU ticket #12420. */ UDATPG_FIELD_COUNT #endif // U_FORCE_HIDE_DEPRECATED_API } UDateTimePatternField; /** * Field display name width constants for udatpg_getFieldDisplayName(). * @stable ICU 61 */ typedef enum UDateTimePGDisplayWidth { /** @stable ICU 61 */ UDATPG_WIDE, /** @stable ICU 61 */ UDATPG_ABBREVIATED, /** @stable ICU 61 */ UDATPG_NARROW } UDateTimePGDisplayWidth; /** * Masks to control forcing the length of specified fields in the returned * pattern to match those in the skeleton (when this would not happen * otherwise). These may be combined to force the length of multiple fields. * Used with udatpg_getBestPatternWithOptions, udatpg_replaceFieldTypesWithOptions. * @stable ICU 4.4 */ typedef enum UDateTimePatternMatchOptions { /** @stable ICU 4.4 */ UDATPG_MATCH_NO_OPTIONS = 0, /** @stable ICU 4.4 */ UDATPG_MATCH_HOUR_FIELD_LENGTH = 1 << UDATPG_HOUR_FIELD, #ifndef U_HIDE_INTERNAL_API /** @internal ICU 4.4 */ UDATPG_MATCH_MINUTE_FIELD_LENGTH = 1 << UDATPG_MINUTE_FIELD, /** @internal ICU 4.4 */ UDATPG_MATCH_SECOND_FIELD_LENGTH = 1 << UDATPG_SECOND_FIELD, #endif /* U_HIDE_INTERNAL_API */ /** @stable ICU 4.4 */ UDATPG_MATCH_ALL_FIELDS_LENGTH = (1 << UDATPG_FIELD_COUNT) - 1 } UDateTimePatternMatchOptions; /** * Status return values from udatpg_addPattern(). * @stable ICU 3.8 */ typedef enum UDateTimePatternConflict { /** @stable ICU 3.8 */ UDATPG_NO_CONFLICT, /** @stable ICU 3.8 */ UDATPG_BASE_CONFLICT, /** @stable ICU 3.8 */ UDATPG_CONFLICT, #ifndef U_HIDE_DEPRECATED_API /** * One more than the highest normal UDateTimePatternConflict value. * @deprecated ICU 58 The numeric value may change over time, see ICU ticket #12420. */ UDATPG_CONFLICT_COUNT #endif // U_HIDE_DEPRECATED_API } UDateTimePatternConflict; /** * Open a generator according to a given locale. * @param locale * @param pErrorCode a pointer to the UErrorCode which must not indicate a * failure before the function call. * @return a pointer to UDateTimePatternGenerator. * @stable ICU 3.8 */ U_STABLE UDateTimePatternGenerator * U_EXPORT2 udatpg_open(const char *locale, UErrorCode *pErrorCode); /** * Open an empty generator, to be constructed with udatpg_addPattern(...) etc. * @param pErrorCode a pointer to the UErrorCode which must not indicate a * failure before the function call. * @return a pointer to UDateTimePatternGenerator. * @stable ICU 3.8 */ U_STABLE UDateTimePatternGenerator * U_EXPORT2 udatpg_openEmpty(UErrorCode *pErrorCode); /** * Close a generator. * @param dtpg a pointer to UDateTimePatternGenerator. * @stable ICU 3.8 */ U_STABLE void U_EXPORT2 udatpg_close(UDateTimePatternGenerator *dtpg); #if U_SHOW_CPLUSPLUS_API U_NAMESPACE_BEGIN /** * \class LocalUDateTimePatternGeneratorPointer * "Smart pointer" class, closes a UDateTimePatternGenerator via udatpg_close(). * For most methods see the LocalPointerBase base class. * * @see LocalPointerBase * @see LocalPointer * @stable ICU 4.4 */ U_DEFINE_LOCAL_OPEN_POINTER(LocalUDateTimePatternGeneratorPointer, UDateTimePatternGenerator, udatpg_close); U_NAMESPACE_END #endif /** * Create a copy pf a generator. * @param dtpg a pointer to UDateTimePatternGenerator to be copied. * @param pErrorCode a pointer to the UErrorCode which must not indicate a * failure before the function call. * @return a pointer to a new UDateTimePatternGenerator. * @stable ICU 3.8 */ U_STABLE UDateTimePatternGenerator * U_EXPORT2 udatpg_clone(const UDateTimePatternGenerator *dtpg, UErrorCode *pErrorCode); /** * Get the best pattern matching the input skeleton. It is guaranteed to * have all of the fields in the skeleton. * * Note that this function uses a non-const UDateTimePatternGenerator: * It uses a stateful pattern parser which is set up for each generator object, * rather than creating one for each function call. * Consecutive calls to this function do not affect each other, * but this function cannot be used concurrently on a single generator object. * * @param dtpg a pointer to UDateTimePatternGenerator. * @param skeleton * The skeleton is a pattern containing only the variable fields. * For example, "MMMdd" and "mmhh" are skeletons. * @param length the length of skeleton * @param bestPattern * The best pattern found from the given skeleton. * @param capacity the capacity of bestPattern. * @param pErrorCode a pointer to the UErrorCode which must not indicate a * failure before the function call. * @return the length of bestPattern. * @stable ICU 3.8 */ U_STABLE int32_t U_EXPORT2 udatpg_getBestPattern(UDateTimePatternGenerator *dtpg, const UChar *skeleton, int32_t length, UChar *bestPattern, int32_t capacity, UErrorCode *pErrorCode); /** * Get the best pattern matching the input skeleton. It is guaranteed to * have all of the fields in the skeleton. * * Note that this function uses a non-const UDateTimePatternGenerator: * It uses a stateful pattern parser which is set up for each generator object, * rather than creating one for each function call. * Consecutive calls to this function do not affect each other, * but this function cannot be used concurrently on a single generator object. * * @param dtpg a pointer to UDateTimePatternGenerator. * @param skeleton * The skeleton is a pattern containing only the variable fields. * For example, "MMMdd" and "mmhh" are skeletons. * @param length the length of skeleton * @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 bestPattern * The best pattern found from the given skeleton. * @param capacity * the capacity of bestPattern. * @param pErrorCode * a pointer to the UErrorCode which must not indicate a * failure before the function call. * @return the length of bestPattern. * @stable ICU 4.4 */ U_STABLE int32_t U_EXPORT2 udatpg_getBestPatternWithOptions(UDateTimePatternGenerator *dtpg, const UChar *skeleton, int32_t length, UDateTimePatternMatchOptions options, UChar *bestPattern, int32_t capacity, UErrorCode *pErrorCode); /** * Get a unique skeleton from a given pattern. For example, * both "MMM-dd" and "dd/MMM" produce the skeleton "MMMdd". * * Note that this function uses a non-const UDateTimePatternGenerator: * It uses a stateful pattern parser which is set up for each generator object, * rather than creating one for each function call. * Consecutive calls to this function do not affect each other, * but this function cannot be used concurrently on a single generator object. * * @param unusedDtpg a pointer to UDateTimePatternGenerator. * This parameter is no longer used. Callers may pass NULL. * @param pattern input pattern, such as "dd/MMM". * @param length the length of pattern. * @param skeleton such as "MMMdd" * @param capacity the capacity of skeleton. * @param pErrorCode a pointer to the UErrorCode which must not indicate a * failure before the function call. * @return the length of skeleton. * @stable ICU 3.8 */ U_STABLE int32_t U_EXPORT2 udatpg_getSkeleton(UDateTimePatternGenerator *unusedDtpg, const UChar *pattern, int32_t length, UChar *skeleton, int32_t capacity, UErrorCode *pErrorCode); /** * Get 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). * * Note that this function uses a non-const UDateTimePatternGenerator: * It uses a stateful pattern parser which is set up for each generator object, * rather than creating one for each function call. * Consecutive calls to this function do not affect each other, * but this function cannot be used concurrently on a single generator object. * * @param unusedDtpg a pointer to UDateTimePatternGenerator. * This parameter is no longer used. Callers may pass NULL. * @param pattern input pattern, such as "dd/MMM". * @param length the length of pattern. * @param baseSkeleton such as "Md" * @param capacity the capacity of base skeleton. * @param pErrorCode a pointer to the UErrorCode which must not indicate a * failure before the function call. * @return the length of baseSkeleton. * @stable ICU 3.8 */ U_STABLE int32_t U_EXPORT2 udatpg_getBaseSkeleton(UDateTimePatternGenerator *unusedDtpg, const UChar *pattern, int32_t length, UChar *baseSkeleton, int32_t capacity, UErrorCode *pErrorCode); /** * 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 overriden. 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 dtpg a pointer to UDateTimePatternGenerator. * @param pattern input pattern, such as "dd/MMM" * @param patternLength the length of pattern. * @param override When existing values are to be overridden use true, * otherwise use false. * @param conflictingPattern Previous pattern with the same skeleton. * @param capacity the capacity of conflictingPattern. * @param pLength a pointer to the length of conflictingPattern. * @param pErrorCode a pointer to the UErrorCode 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 */ U_STABLE UDateTimePatternConflict U_EXPORT2 udatpg_addPattern(UDateTimePatternGenerator *dtpg, const UChar *pattern, int32_t patternLength, UBool override, UChar *conflictingPattern, int32_t capacity, int32_t *pLength, UErrorCode *pErrorCode); /** * 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 dtpg a pointer to UDateTimePatternGenerator. * @param field UDateTimePatternField, such as UDATPG_ERA_FIELD * @param value pattern, such as "{0}, {1}" * @param length the length of value. * @stable ICU 3.8 */ U_STABLE void U_EXPORT2 udatpg_setAppendItemFormat(UDateTimePatternGenerator *dtpg, UDateTimePatternField field, const UChar *value, int32_t length); /** * Getter corresponding to setAppendItemFormat. Values below 0 or at or * above UDATPG_FIELD_COUNT are illegal arguments. * * @param dtpg A pointer to UDateTimePatternGenerator. * @param field UDateTimePatternField, such as UDATPG_ERA_FIELD * @param pLength A pointer that will receive the length of appendItemFormat. * @return appendItemFormat for field. * @stable ICU 3.8 */ U_STABLE const UChar * U_EXPORT2 udatpg_getAppendItemFormat(const UDateTimePatternGenerator *dtpg, UDateTimePatternField field, int32_t *pLength); /** * Set the name 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 dtpg a pointer to UDateTimePatternGenerator. * @param field UDateTimePatternField * @param value name for the field. * @param length the length of value. * @stable ICU 3.8 */ U_STABLE void U_EXPORT2 udatpg_setAppendItemName(UDateTimePatternGenerator *dtpg, UDateTimePatternField field, const UChar *value, int32_t length); /** * Getter corresponding to setAppendItemNames. Values below 0 or at or above * UDATPG_FIELD_COUNT are illegal arguments. Note: The more general function * for getting date/time field display names is udatpg_getFieldDisplayName. * * @param dtpg a pointer to UDateTimePatternGenerator. * @param field UDateTimePatternField, such as UDATPG_ERA_FIELD * @param pLength A pointer that will receive the length of the name for field. * @return name for field * @see udatpg_getFieldDisplayName * @stable ICU 3.8 */ U_STABLE const UChar * U_EXPORT2 udatpg_getAppendItemName(const UDateTimePatternGenerator *dtpg, UDateTimePatternField field, int32_t *pLength); /** * The general interface to get a display name for a particular date/time field, * in one of several possible display widths. * * @param dtpg * A pointer to the UDateTimePatternGenerator object with the localized * display names. * @param field * The desired UDateTimePatternField, such as UDATPG_ERA_FIELD. * @param width * The desired UDateTimePGDisplayWidth, such as UDATPG_ABBREVIATED. * @param fieldName * A pointer to a buffer to receive the NULL-terminated display name. If the name * fits into fieldName but cannot be NULL-terminated (length == capacity) then * the error code is set to U_STRING_NOT_TERMINATED_WARNING. If the name doesn't * fit into fieldName then the error code is set to U_BUFFER_OVERFLOW_ERROR. * @param capacity * The size of fieldName (in UChars). * @param pErrorCode * A pointer to a UErrorCode to receive any errors * @return * The full length of the name; if greater than capacity, fieldName contains a * truncated result. * @stable ICU 61 */ U_STABLE int32_t U_EXPORT2 udatpg_getFieldDisplayName(const UDateTimePatternGenerator *dtpg, UDateTimePatternField field, UDateTimePGDisplayWidth width, UChar *fieldName, int32_t capacity, UErrorCode *pErrorCode); /** * 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". * * @param dtpg a pointer to UDateTimePatternGenerator. * @param dtFormat * message format pattern, here {1} will be replaced by the date * pattern and {0} will be replaced by the time pattern. * @param length the length of dtFormat. * @stable ICU 3.8 */ U_STABLE void U_EXPORT2 udatpg_setDateTimeFormat(const UDateTimePatternGenerator *dtpg, const UChar *dtFormat, int32_t length); /** * Getter corresponding to setDateTimeFormat. * @param dtpg a pointer to UDateTimePatternGenerator. * @param pLength A pointer that will receive the length of the format * @return dateTimeFormat. * @stable ICU 3.8 */ U_STABLE const UChar * U_EXPORT2 udatpg_getDateTimeFormat(const UDateTimePatternGenerator *dtpg, int32_t *pLength); /** * 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 dtpg a pointer to UDateTimePatternGenerator. * @param decimal * @param length the length of decimal. * @stable ICU 3.8 */ U_STABLE void U_EXPORT2 udatpg_setDecimal(UDateTimePatternGenerator *dtpg, const UChar *decimal, int32_t length); /** * Getter corresponding to setDecimal. * * @param dtpg a pointer to UDateTimePatternGenerator. * @param pLength A pointer that will receive the length of the decimal string. * @return corresponding to the decimal point. * @stable ICU 3.8 */ U_STABLE const UChar * U_EXPORT2 udatpg_getDecimal(const UDateTimePatternGenerator *dtpg, int32_t *pLength); /** * 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. * * Note that this function uses a non-const UDateTimePatternGenerator: * It uses a stateful pattern parser which is set up for each generator object, * rather than creating one for each function call. * Consecutive calls to this function do not affect each other, * but this function cannot be used concurrently on a single generator object. * * @param dtpg a pointer to UDateTimePatternGenerator. * @param pattern Input pattern * @param patternLength the length of input pattern. * @param skeleton * @param skeletonLength the length of input skeleton. * @param dest pattern adjusted to match the skeleton fields widths and subtypes. * @param destCapacity the capacity of dest. * @param pErrorCode a pointer to the UErrorCode which must not indicate a * failure before the function call. * @return the length of dest. * @stable ICU 3.8 */ U_STABLE int32_t U_EXPORT2 udatpg_replaceFieldTypes(UDateTimePatternGenerator *dtpg, const UChar *pattern, int32_t patternLength, const UChar *skeleton, int32_t skeletonLength, UChar *dest, int32_t destCapacity, UErrorCode *pErrorCode); /** * 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. * * Note that this function uses a non-const UDateTimePatternGenerator: * It uses a stateful pattern parser which is set up for each generator object, * rather than creating one for each function call. * Consecutive calls to this function do not affect each other, * but this function cannot be used concurrently on a single generator object. * * @param dtpg a pointer to UDateTimePatternGenerator. * @param pattern Input pattern * @param patternLength the length of input pattern. * @param skeleton * @param skeletonLength the length of input skeleton. * @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 dest pattern adjusted to match the skeleton fields widths and subtypes. * @param destCapacity the capacity of dest. * @param pErrorCode a pointer to the UErrorCode which must not indicate a * failure before the function call. * @return the length of dest. * @stable ICU 4.4 */ U_STABLE int32_t U_EXPORT2 udatpg_replaceFieldTypesWithOptions(UDateTimePatternGenerator *dtpg, const UChar *pattern, int32_t patternLength, const UChar *skeleton, int32_t skeletonLength, UDateTimePatternMatchOptions options, UChar *dest, int32_t destCapacity, UErrorCode *pErrorCode); /** * Return a UEnumeration list of all the skeletons in canonical form. * Call udatpg_getPatternForSkeleton() to get the corresponding pattern. * * @param dtpg a pointer to UDateTimePatternGenerator. * @param pErrorCode a pointer to the UErrorCode which must not indicate a * failure before the function call * @return a UEnumeration list of all the skeletons * The caller must close the object. * @stable ICU 3.8 */ U_STABLE UEnumeration * U_EXPORT2 udatpg_openSkeletons(const UDateTimePatternGenerator *dtpg, UErrorCode *pErrorCode); /** * Return a UEnumeration list of all the base skeletons in canonical form. * * @param dtpg a pointer to UDateTimePatternGenerator. * @param pErrorCode a pointer to the UErrorCode which must not indicate a * failure before the function call. * @return a UEnumeration list of all the base skeletons * The caller must close the object. * @stable ICU 3.8 */ U_STABLE UEnumeration * U_EXPORT2 udatpg_openBaseSkeletons(const UDateTimePatternGenerator *dtpg, UErrorCode *pErrorCode); /** * Get the pattern corresponding to a given skeleton. * * @param dtpg a pointer to UDateTimePatternGenerator. * @param skeleton * @param skeletonLength pointer to the length of skeleton. * @param pLength pointer to the length of return pattern. * @return pattern corresponding to a given skeleton. * @stable ICU 3.8 */ U_STABLE const UChar * U_EXPORT2 udatpg_getPatternForSkeleton(const UDateTimePatternGenerator *dtpg, const UChar *skeleton, int32_t skeletonLength, int32_t *pLength); #endif