ICU 66.0.1
66.0.1
|
C API: Format a list in a locale-appropriate way. More...
Go to the source code of this file.
Namespaces | |
icu | |
File coll.h. | |
Typedefs | |
typedef struct UListFormatter | UListFormatter |
C typedef for struct UListFormatter. More... | |
typedef struct UFormattedList | UFormattedList |
Opaque struct to contain the results of a UListFormatter operation. More... | |
typedef enum UListFormatterField | UListFormatterField |
FieldPosition and UFieldPosition selectors for format fields defined by ListFormatter. More... | |
Enumerations | |
enum | UListFormatterField { ULISTFMT_LITERAL_FIELD, ULISTFMT_ELEMENT_FIELD } |
FieldPosition and UFieldPosition selectors for format fields defined by ListFormatter. More... | |
Functions | |
U_CAPI UListFormatter * | ulistfmt_open (const char *locale, UErrorCode *status) |
Open a new UListFormatter object using the rules for a given locale. More... | |
U_CAPI void | ulistfmt_close (UListFormatter *listfmt) |
Close a UListFormatter object. More... | |
U_CAPI UFormattedList * | ulistfmt_openResult (UErrorCode *ec) |
Creates an object to hold the result of a UListFormatter operation. More... | |
U_CAPI const UFormattedValue * | ulistfmt_resultAsValue (const UFormattedList *uresult, UErrorCode *ec) |
Returns a representation of a UFormattedList as a UFormattedValue, which can be subsequently passed to any API requiring that type. More... | |
U_CAPI void | ulistfmt_closeResult (UFormattedList *uresult) |
Releases the UFormattedList created by ulistfmt_openResult(). More... | |
U_CAPI int32_t | ulistfmt_format (const UListFormatter *listfmt, const UChar *const strings[], const int32_t *stringLengths, int32_t stringCount, UChar *result, int32_t resultCapacity, UErrorCode *status) |
Formats a list of strings using the conventions established for the UListFormatter object. More... | |
U_CAPI void | ulistfmt_formatStringsToResult (const UListFormatter *listfmt, const UChar *const strings[], const int32_t *stringLengths, int32_t stringCount, UFormattedList *uresult, UErrorCode *status) |
Formats a list of strings to a UFormattedList, which exposes more information than the string exported by ulistfmt_format(). More... | |
C API: Format a list in a locale-appropriate way.
A UListFormatter is used to format a list of items in a locale-appropriate way, using data from CLDR. Example: Input data ["Alice", "Bob", "Charlie", "Delta"] will be formatted as "Alice, Bob, Charlie, and Delta" in English.
Definition in file ulistformatter.h.
typedef struct UFormattedList UFormattedList |
Opaque struct to contain the results of a UListFormatter operation.
Definition at line 43 of file ulistformatter.h.
typedef struct UListFormatter UListFormatter |
typedef enum UListFormatterField UListFormatterField |
FieldPosition and UFieldPosition selectors for format fields defined by ListFormatter.
enum UListFormatterField |
FieldPosition and UFieldPosition selectors for format fields defined by ListFormatter.
Enumerator | |
---|---|
ULISTFMT_LITERAL_FIELD | The literal text in the result which came from the resources.
|
ULISTFMT_ELEMENT_FIELD | The element text in the result which came from the input strings.
|
Definition at line 52 of file ulistformatter.h.
U_CAPI void ulistfmt_close | ( | UListFormatter * | listfmt | ) |
Close a UListFormatter object.
Once closed it may no longer be used.
listfmt | The UListFormatter object to close. |
U_CAPI void ulistfmt_closeResult | ( | UFormattedList * | uresult | ) |
Releases the UFormattedList created by ulistfmt_openResult().
uresult | The object to release. |
U_CAPI int32_t ulistfmt_format | ( | const UListFormatter * | listfmt, |
const UChar *const | strings[], | ||
const int32_t * | stringLengths, | ||
int32_t | stringCount, | ||
UChar * | result, | ||
int32_t | resultCapacity, | ||
UErrorCode * | status | ||
) |
Formats a list of strings using the conventions established for the UListFormatter object.
listfmt | The UListFormatter object specifying the list conventions. |
strings | An array of pointers to UChar strings; the array length is specified by stringCount. Must be non-NULL if stringCount > 0. |
stringLengths | An array of string lengths corresponding to the strings[] parameter; any individual length value may be negative to indicate that the corresponding strings[] entry is 0-terminated, or stringLengths itself may be NULL if all of the strings are 0-terminated. If non-NULL, the stringLengths array must have stringCount entries. |
stringCount | the number of entries in strings[], and the number of entries in the stringLengths array if it is not NULL. Must be >= 0. |
result | A pointer to a buffer to receive the formatted list. |
resultCapacity | The maximum size of result. |
status | A pointer to a standard ICU UErrorCode (input/output parameter). Its input value must pass the U_SUCCESS() test, or else the function returns immediately. The caller should check its output value with U_FAILURE(), or use with function chaining (see User Guide for details). |
U_CAPI void ulistfmt_formatStringsToResult | ( | const UListFormatter * | listfmt, |
const UChar *const | strings[], | ||
const int32_t * | stringLengths, | ||
int32_t | stringCount, | ||
UFormattedList * | uresult, | ||
UErrorCode * | status | ||
) |
Formats a list of strings to a UFormattedList, which exposes more information than the string exported by ulistfmt_format().
listfmt | The UListFormatter object specifying the list conventions. |
strings | An array of pointers to UChar strings; the array length is specified by stringCount. Must be non-NULL if stringCount > 0. |
stringLengths | An array of string lengths corresponding to the strings[] parameter; any individual length value may be negative to indicate that the corresponding strings[] entry is 0-terminated, or stringLengths itself may be NULL if all of the strings are 0-terminated. If non-NULL, the stringLengths array must have stringCount entries. |
stringCount | the number of entries in strings[], and the number of entries in the stringLengths array if it is not NULL. Must be >= 0. |
uresult | The object in which to store the result of the list formatting operation. See ulistfmt_openResult(). |
status | Error code set if an error occurred during formatting. |
U_CAPI UListFormatter* ulistfmt_open | ( | const char * | locale, |
UErrorCode * | status | ||
) |
Open a new UListFormatter object using the rules for a given locale.
locale | The locale whose rules should be used; may be NULL for default locale. |
status | A pointer to a standard ICU UErrorCode (input/output parameter). Its input value must pass the U_SUCCESS() test, or else the function returns immediately. The caller should check its output value with U_FAILURE(), or use with function chaining (see User Guide for details). |
U_CAPI UFormattedList* ulistfmt_openResult | ( | UErrorCode * | ec | ) |
Creates an object to hold the result of a UListFormatter operation.
The object can be used repeatedly; it is cleared whenever passed to a format function.
ec | Set if an error occurs. |
U_CAPI const UFormattedValue* ulistfmt_resultAsValue | ( | const UFormattedList * | uresult, |
UErrorCode * | ec | ||
) |
Returns a representation of a UFormattedList as a UFormattedValue, which can be subsequently passed to any API requiring that type.
The returned object is owned by the UFormattedList and is valid only as long as the UFormattedList is present and unchanged in memory.
You can think of this method as a cast between types.
When calling ufmtval_nextPosition(): The fields are returned from start to end. The special field category UFIELD_CATEGORY_LIST_SPAN is used to indicate which argument was inserted at the given position. The span category will always occur before the corresponding instance of UFIELD_CATEGORY_LIST in the ufmtval_nextPosition() iterator.
uresult | The object containing the formatted string. |
ec | Set if an error occurs. |