ICU 66.0.1
66.0.1
|
C API: UFormattable is a thin wrapper for primitive types used for formatting and parsing. More...
Go to the source code of this file.
Namespaces | |
icu | |
File coll.h. | |
Typedefs | |
typedef enum UFormattableType | UFormattableType |
Enum designating the type of a UFormattable instance. More... | |
typedef void * | UFormattable |
Opaque type representing various types of data which may be used for formatting and parsing operations. More... | |
Enumerations | |
enum | UFormattableType { UFMT_DATE = 0, UFMT_DOUBLE, UFMT_LONG, UFMT_STRING, UFMT_ARRAY, UFMT_INT64, UFMT_OBJECT, UFMT_COUNT } |
Enum designating the type of a UFormattable instance. More... | |
Functions | |
UFormattable * | ufmt_open (UErrorCode *status) |
Initialize a UFormattable, to type UNUM_LONG, value 0 may return error if memory allocation failed. More... | |
void | ufmt_close (UFormattable *fmt) |
Cleanup any additional memory allocated by this UFormattable. More... | |
UFormattableType | ufmt_getType (const UFormattable *fmt, UErrorCode *status) |
Return the type of this object. More... | |
UBool | ufmt_isNumeric (const UFormattable *fmt) |
Return whether the object is numeric. More... | |
UDate | ufmt_getDate (const UFormattable *fmt, UErrorCode *status) |
Gets the UDate value of this object. More... | |
double | ufmt_getDouble (UFormattable *fmt, UErrorCode *status) |
Gets the double value of this object. More... | |
int32_t | ufmt_getLong (UFormattable *fmt, UErrorCode *status) |
Gets the long (int32_t) value of this object. More... | |
int64_t | ufmt_getInt64 (UFormattable *fmt, UErrorCode *status) |
Gets the int64_t value of this object. More... | |
const void * | ufmt_getObject (const UFormattable *fmt, UErrorCode *status) |
Returns a pointer to the UObject contained within this formattable (as a const void*), or NULL if this object is not of type UFMT_OBJECT. More... | |
const UChar * | ufmt_getUChars (UFormattable *fmt, int32_t *len, UErrorCode *status) |
Gets the string value of this object as a UChar string. More... | |
int32_t | ufmt_getArrayLength (const UFormattable *fmt, UErrorCode *status) |
Get the number of array objects contained, if an array type UFMT_ARRAY. More... | |
UFormattable * | ufmt_getArrayItemByIndex (UFormattable *fmt, int32_t n, UErrorCode *status) |
Get the specified value from the array of UFormattables. More... | |
const char * | ufmt_getDecNumChars (UFormattable *fmt, int32_t *len, UErrorCode *status) |
Returns a numeric string representation of the number contained within this formattable, or NULL if this object does not contain numeric type. More... | |
C API: UFormattable is a thin wrapper for primitive types used for formatting and parsing.
This is a C interface to the icu::Formattable class. Static functions on this class convert to and from this interface (via reinterpret_cast). Note that Formattables (and thus UFormattables) are mutable, and many operations (even getters) may actually modify the internal state. For this reason, UFormattables are not thread safe, and should not be shared between threads.
See unum_parseToUFormattable for example code.
Definition in file uformattable.h.
typedef void* UFormattable |
Opaque type representing various types of data which may be used for formatting and parsing operations.
Definition at line 70 of file uformattable.h.
typedef enum UFormattableType UFormattableType |
Enum designating the type of a UFormattable instance.
Practically, this indicates which of the getters would return without conversion or error.
enum UFormattableType |
Enum designating the type of a UFormattable instance.
Practically, this indicates which of the getters would return without conversion or error.
Enumerator | |
---|---|
UFMT_DATE | ufmt_getDate() will return without conversion.
|
UFMT_DOUBLE | ufmt_getDouble() will return without conversion.
|
UFMT_LONG | ufmt_getLong() will return without conversion.
|
UFMT_STRING | ufmt_getUChars() will return without conversion.
|
UFMT_ARRAY | ufmt_countArray() and ufmt_getArray() will return the value.
|
UFMT_INT64 | ufmt_getInt64() will return without conversion.
|
UFMT_OBJECT | ufmt_getObject() will return without conversion.
|
UFMT_COUNT | One more than the highest normal UFormattableType value.
|
Definition at line 46 of file uformattable.h.
void ufmt_close | ( | UFormattable * | fmt | ) |
UFormattable* ufmt_getArrayItemByIndex | ( | UFormattable * | fmt, |
int32_t | n, | ||
UErrorCode * | status | ||
) |
Get the specified value from the array of UFormattables.
Invalid if the object is not an array type UFMT_ARRAY
fmt | the UFormattable object |
n | the number of the array to return (0 based). |
status | the error code - any conversion or format errors. Returns an error if n is out of bounds. |
int32_t ufmt_getArrayLength | ( | const UFormattable * | fmt, |
UErrorCode * | status | ||
) |
Get the number of array objects contained, if an array type UFMT_ARRAY.
fmt | the UFormattable object |
status | the error code - any conversion or format errors. U_ILLEGAL_ARGUMENT_ERROR if not an array type. |
UDate ufmt_getDate | ( | const UFormattable * | fmt, |
UErrorCode * | status | ||
) |
Gets the UDate value of this object.
If the type is not of type UFMT_DATE, status is set to U_INVALID_FORMAT_ERROR and the return value is undefined.
fmt | the UFormattable object |
status | the error code - any conversion or format errors |
const char* ufmt_getDecNumChars | ( | UFormattable * | fmt, |
int32_t * | len, | ||
UErrorCode * | status | ||
) |
Returns a numeric string representation of the number contained within this formattable, or NULL if this object does not contain numeric type.
For values obtained by parsing, the returned decimal number retains the full precision and range of the original input, unconstrained by the limits of a double floating point or a 64 bit int.
This function is not thread safe, and therfore is not declared const, even though it is logically const. The resulting buffer is owned by the UFormattable and is invalid if any other functions are called on the UFormattable.
Possible errors include U_MEMORY_ALLOCATION_ERROR, and U_INVALID_STATE if the formattable object has not been set to a numeric type.
fmt | the UFormattable object |
len | if non-null, on exit contains the string length (not including the terminating null) |
status | the error code |
double ufmt_getDouble | ( | UFormattable * | fmt, |
UErrorCode * | status | ||
) |
Gets the double value of this object.
If the type is not a UFMT_DOUBLE, or if there are additional significant digits than fit in a double type, a conversion is performed with possible loss of precision. If the type is UFMT_OBJECT and the object is a Measure, then the result of getNumber().getDouble(status) is returned. If this object is neither a numeric type nor a Measure, then 0 is returned and the status is set to U_INVALID_FORMAT_ERROR.
fmt | the UFormattable object |
status | the error code - any conversion or format errors |
int64_t ufmt_getInt64 | ( | UFormattable * | fmt, |
UErrorCode * | status | ||
) |
Gets the int64_t value of this object.
If this object is of a numeric type and the magnitude is too large to fit in an int64, then the maximum or minimum int64 value, as appropriate, is returned and the status is set to U_INVALID_FORMAT_ERROR. If the magnitude fits in an int64, then a casting conversion is peformed, with truncation of any fractional part. If the type is UFMT_OBJECT and the object is a Measure, then the result of getNumber().getDouble(status) is returned. If this object is neither a numeric type nor a Measure, then 0 is returned and the status is set to U_INVALID_FORMAT_ERROR.
fmt | the UFormattable object |
status | the error code - any conversion or format errors |
int32_t ufmt_getLong | ( | UFormattable * | fmt, |
UErrorCode * | status | ||
) |
Gets the long (int32_t) value of this object.
If the magnitude is too large to fit in a long, then the maximum or minimum long value, as appropriate, is returned and the status is set to U_INVALID_FORMAT_ERROR. If this object is of type UFMT_INT64 and it fits within a long, then no precision is lost. If it is of type kDouble or kDecimalNumber, then a conversion is peformed, with truncation of any fractional part. If the type is UFMT_OBJECT and the object is a Measure, then the result of getNumber().getLong(status) is returned. If this object is neither a numeric type nor a Measure, then 0 is returned and the status is set to U_INVALID_FORMAT_ERROR.
fmt | the UFormattable object |
status | the error code - any conversion or format errors |
const void* ufmt_getObject | ( | const UFormattable * | fmt, |
UErrorCode * | status | ||
) |
Returns a pointer to the UObject contained within this formattable (as a const void*), or NULL if this object is not of type UFMT_OBJECT.
fmt | the UFormattable object |
status | the error code - any conversion or format errors |
UFormattableType ufmt_getType | ( | const UFormattable * | fmt, |
UErrorCode * | status | ||
) |
Return the type of this object.
fmt | the UFormattable object |
status | status code - U_ILLEGAL_ARGUMENT_ERROR is returned if the UFormattable contains data not supported by the API |
const UChar* ufmt_getUChars | ( | UFormattable * | fmt, |
int32_t * | len, | ||
UErrorCode * | status | ||
) |
Gets the string value of this object as a UChar string.
If the type is not a string, status is set to U_INVALID_FORMAT_ERROR and a NULL pointer is returned. This function is not thread safe and may modify the UFormattable if need be to terminate the string. The returned pointer is not valid if any other functions are called on this UFormattable, or if the UFormattable is closed.
fmt | the UFormattable object |
status | the error code - any conversion or format errors |
len | if non null, contains the string length on return |
UBool ufmt_isNumeric | ( | const UFormattable * | fmt | ) |
Return whether the object is numeric.
fmt | the UFormattable object |
UFormattable* ufmt_open | ( | UErrorCode * | status | ) |
Initialize a UFormattable, to type UNUM_LONG, value 0 may return error if memory allocation failed.
parameter status error code. See unum_parseToUFormattable for example code.