ICU 64.2  64.2
udatpg.h
Go to the documentation of this file.
1 // © 2016 and later: Unicode, Inc. and others.
2 // License & terms of use: http://www.unicode.org/copyright.html
3 /*
4 *******************************************************************************
5 *
6 * Copyright (C) 2007-2015, International Business Machines
7 * Corporation and others. All Rights Reserved.
8 *
9 *******************************************************************************
10 * file name: udatpg.h
11 * encoding: UTF-8
12 * tab size: 8 (not used)
13 * indentation:4
14 *
15 * created on: 2007jul30
16 * created by: Markus W. Scherer
17 */
18 
19 #ifndef __UDATPG_H__
20 #define __UDATPG_H__
21 
22 #include "unicode/utypes.h"
23 #include "unicode/uenum.h"
24 #include "unicode/localpointer.h"
25 
48 
55 typedef enum UDateTimePatternField {
88 
89  /* Do not conditionalize the following with #ifndef U_HIDE_DEPRECATED_API,
90  * it is needed for layout of DateTimePatternGenerator object. */
97 
110 
123 #ifndef U_HIDE_INTERNAL_API
124 
128 #endif /* U_HIDE_INTERNAL_API */
129 
132 
144 #ifndef U_HIDE_DEPRECATED_API
145 
150 #endif // U_HIDE_DEPRECATED_API
152 
162 udatpg_open(const char *locale, UErrorCode *pErrorCode);
163 
172 udatpg_openEmpty(UErrorCode *pErrorCode);
173 
179 U_STABLE void U_EXPORT2
181 
182 #if U_SHOW_CPLUSPLUS_API
183 
185 
196 
198 
199 #endif
200 
210 udatpg_clone(const UDateTimePatternGenerator *dtpg, UErrorCode *pErrorCode);
211 
235 U_STABLE int32_t U_EXPORT2
237  const UChar *skeleton, int32_t length,
238  UChar *bestPattern, int32_t capacity,
239  UErrorCode *pErrorCode);
240 
271 U_STABLE int32_t U_EXPORT2
273  const UChar *skeleton, int32_t length,
275  UChar *bestPattern, int32_t capacity,
276  UErrorCode *pErrorCode);
277 
299 U_STABLE int32_t U_EXPORT2
301  const UChar *pattern, int32_t length,
302  UChar *skeleton, int32_t capacity,
303  UErrorCode *pErrorCode);
304 
329 U_STABLE int32_t U_EXPORT2
331  const UChar *pattern, int32_t length,
332  UChar *baseSkeleton, int32_t capacity,
333  UErrorCode *pErrorCode);
334 
361  const UChar *pattern, int32_t patternLength,
362  UBool override,
363  UChar *conflictingPattern, int32_t capacity, int32_t *pLength,
364  UErrorCode *pErrorCode);
365 
386 U_STABLE void U_EXPORT2
388  UDateTimePatternField field,
389  const UChar *value, int32_t length);
390 
401 U_STABLE const UChar * U_EXPORT2
403  UDateTimePatternField field,
404  int32_t *pLength);
405 
419 U_STABLE void U_EXPORT2
421  UDateTimePatternField field,
422  const UChar *value, int32_t length);
423 
436 U_STABLE const UChar * U_EXPORT2
438  UDateTimePatternField field,
439  int32_t *pLength);
440 
466 U_STABLE int32_t U_EXPORT2
468  UDateTimePatternField field,
470  UChar *fieldName, int32_t capacity,
471  UErrorCode *pErrorCode);
472 
496 U_STABLE void U_EXPORT2
498  const UChar *dtFormat, int32_t length);
499 
507 U_STABLE const UChar * U_EXPORT2
509  int32_t *pLength);
510 
524 U_STABLE void U_EXPORT2
526  const UChar *decimal, int32_t length);
527 
536 U_STABLE const UChar * U_EXPORT2
538  int32_t *pLength);
539 
565 U_STABLE int32_t U_EXPORT2
567  const UChar *pattern, int32_t patternLength,
568  const UChar *skeleton, int32_t skeletonLength,
569  UChar *dest, int32_t destCapacity,
570  UErrorCode *pErrorCode);
571 
602 U_STABLE int32_t U_EXPORT2
604  const UChar *pattern, int32_t patternLength,
605  const UChar *skeleton, int32_t skeletonLength,
607  UChar *dest, int32_t destCapacity,
608  UErrorCode *pErrorCode);
609 
621 U_STABLE UEnumeration * U_EXPORT2
623 
634 U_STABLE UEnumeration * U_EXPORT2
636 
647 U_STABLE const UChar * U_EXPORT2
649  const UChar *skeleton, int32_t skeletonLength,
650  int32_t *pLength);
651 
652 #endif
const UChar * udatpg_getAppendItemFormat(const UDateTimePatternGenerator *dtpg, UDateTimePatternField field, int32_t *pLength)
Getter corresponding to setAppendItemFormat.
int32_t udatpg_getBestPatternWithOptions(UDateTimePatternGenerator *dtpg, const UChar *skeleton, int32_t length, UDateTimePatternMatchOptions options, UChar *bestPattern, int32_t capacity, UErrorCode *pErrorCode)
Get the best pattern matching the input skeleton.
int32_t udatpg_getSkeleton(UDateTimePatternGenerator *unusedDtpg, const UChar *pattern, int32_t length, UChar *skeleton, int32_t capacity, UErrorCode *pErrorCode)
Get a unique skeleton from a given pattern.
const UChar * udatpg_getAppendItemName(const UDateTimePatternGenerator *dtpg, UDateTimePatternField field, int32_t *pLength)
Getter corresponding to setAppendItemNames.
int32_t 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.
struct UEnumeration UEnumeration
structure representing an enumeration object instance
Definition: uenum.h:43
void udatpg_setDateTimeFormat(const UDateTimePatternGenerator *dtpg, const UChar *dtFormat, int32_t length)
The DateTimeFormat is a message format pattern used to compose date and time patterns.
"Smart pointer" class, closes a UDateTimePatternGenerator via udatpg_close().
int32_t 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.
One more than the highest normal UDateTimePatternConflict value.
Definition: udatpg.h:149
void udatpg_setAppendItemFormat(UDateTimePatternGenerator *dtpg, UDateTimePatternField field, const UChar *value, int32_t length)
An AppendItem format is a pattern used to append a field if there is no good match.
void udatpg_setAppendItemName(UDateTimePatternGenerator *dtpg, UDateTimePatternField field, const UChar *value, int32_t length)
Set the name of field, eg "era" in English for ERA.
#define U_NAMESPACE_BEGIN
This is used to begin a declaration of a public ICU C++ API.
Definition: uversion.h:137
UDateTimePatternConflict udatpg_addPattern(UDateTimePatternGenerator *dtpg, const UChar *pattern, int32_t patternLength, UBool override, UChar *conflictingPattern, int32_t capacity, int32_t *pLength, UErrorCode *pErrorCode)
Adds a pattern to the generator.
#define U_DEFINE_LOCAL_OPEN_POINTER(LocalPointerClassName, Type, closeFunction)
"Smart pointer" definition macro, deletes objects via the closeFunction.
Definition: localpointer.h:562
C++ API: "Smart pointers" for use with and in ICU4C C++ code.
UDateTimePatternGenerator * udatpg_open(const char *locale, UErrorCode *pErrorCode)
Open a generator according to a given locale.
int32_t udatpg_getFieldDisplayName(const UDateTimePatternGenerator *dtpg, UDateTimePatternField field, UDateTimePGDisplayWidth width, UChar *fieldName, int32_t capacity, UErrorCode *pErrorCode)
The general interface to get a display name for a particular date/time field, in one of several possi...
UDateTimePatternConflict
Status return values from udatpg_addPattern().
Definition: udatpg.h:137
int32_t udatpg_getBaseSkeleton(UDateTimePatternGenerator *unusedDtpg, const UChar *pattern, int32_t length, UChar *baseSkeleton, int32_t capacity, UErrorCode *pErrorCode)
Get a unique base skeleton from a given pattern.
UEnumeration * udatpg_openSkeletons(const UDateTimePatternGenerator *dtpg, UErrorCode *pErrorCode)
Return a UEnumeration list of all the skeletons in canonical form.
UDateTimePatternGenerator * udatpg_clone(const UDateTimePatternGenerator *dtpg, UErrorCode *pErrorCode)
Create a copy pf a generator.
One more than the highest normal UDateTimePatternField value.
Definition: udatpg.h:95
uint16_t UChar
The base type for UTF-16 code units and pointers.
Definition: umachine.h:342
void udatpg_close(UDateTimePatternGenerator *dtpg)
Close a generator.
#define U_NAMESPACE_END
This is used to end a declaration of a public ICU C++ API.
Definition: uversion.h:138
UDateTimePatternField
Field number constants for udatpg_getAppendItemFormats() and similar functions.
Definition: udatpg.h:55
void * UDateTimePatternGenerator
Opaque type for a date/time pattern generator object.
Definition: udatpg.h:47
UErrorCode
Error code to replace exception handling, so that the code is compatible with all C++ compilers...
Definition: utypes.h:401
UDateTimePGDisplayWidth
Field display name width constants for udatpg_getFieldDisplayName().
Definition: udatpg.h:102
UEnumeration * udatpg_openBaseSkeletons(const UDateTimePatternGenerator *dtpg, UErrorCode *pErrorCode)
Return a UEnumeration list of all the base skeletons in canonical form.
UDateTimePatternGenerator * udatpg_openEmpty(UErrorCode *pErrorCode)
Open an empty generator, to be constructed with udatpg_addPattern(...) etc.
C API: String Enumeration.
void udatpg_setDecimal(UDateTimePatternGenerator *dtpg, const UChar *decimal, int32_t length)
The decimal value is used in formatting fractions of seconds.
const UChar * udatpg_getDecimal(const UDateTimePatternGenerator *dtpg, int32_t *pLength)
Getter corresponding to setDecimal.
Basic definitions for ICU, for both C and C++ APIs.
const UChar * udatpg_getDateTimeFormat(const UDateTimePatternGenerator *dtpg, int32_t *pLength)
Getter corresponding to setDateTimeFormat.
int32_t 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)
Adjusts the field types (width and subtype) of a pattern to match what is in a skeleton.
UDateTimePatternMatchOptions
Masks to control forcing the length of specified fields in the returned pattern to match those in the...
Definition: udatpg.h:118
const UChar * udatpg_getPatternForSkeleton(const UDateTimePatternGenerator *dtpg, const UChar *skeleton, int32_t skeletonLength, int32_t *pLength)
Get the pattern corresponding to a given skeleton.
#define U_STABLE
This is used to declare a function as a stable public ICU C API.
Definition: umachine.h:111
int8_t UBool
The ICU boolean type.
Definition: umachine.h:225