ICU 64.2
64.2
|
FieldPosition
is a simple class used by Format
and its subclasses to identify fields in formatted output.
More...
#include <fieldpos.h>
Public Types | |
enum | { DONT_CARE = -1 } |
DONT_CARE may be specified as the field to indicate that the caller doesn't need to specify a field. More... | |
Public Member Functions | |
FieldPosition () | |
Creates a FieldPosition object with a non-specified field. More... | |
FieldPosition (int32_t field) | |
Creates a FieldPosition object for the given field. More... | |
FieldPosition (const FieldPosition ©) | |
Copy constructor. More... | |
virtual | ~FieldPosition () |
Destructor. More... | |
FieldPosition & | operator= (const FieldPosition ©) |
Assignment operator. More... | |
UBool | operator== (const FieldPosition &that) const |
Equality operator. More... | |
UBool | operator!= (const FieldPosition &that) const |
Equality operator. More... | |
FieldPosition * | clone () const |
Clone this object. More... | |
int32_t | getField (void) const |
Retrieve the field identifier. More... | |
int32_t | getBeginIndex (void) const |
Retrieve the index of the first character in the requested field. More... | |
int32_t | getEndIndex (void) const |
Retrieve the index of the character following the last character in the requested field. More... | |
void | setField (int32_t f) |
Set the field. More... | |
void | setBeginIndex (int32_t bi) |
Set the begin index. More... | |
void | setEndIndex (int32_t ei) |
Set the end index. More... | |
virtual UClassID | getDynamicClassID () const |
ICU "poor man's RTTI", returns a UClassID for the actual class. More... | |
Public Member Functions inherited from icu::UObject | |
virtual | ~UObject () |
Destructor. More... | |
Static Public Member Functions | |
static UClassID | getStaticClassID () |
ICU "poor man's RTTI", returns a UClassID for this class. More... | |
FieldPosition
is a simple class used by Format
and its subclasses to identify fields in formatted output.
Fields are identified by constants, whose names typically end with _FIELD
, defined in the various subclasses of Format
. See ERA_FIELD
and its friends in DateFormat
for an example.
FieldPosition
keeps track of the position of the field within the formatted output with two indices: the index of the first character of the field and the index of the last character of the field.
One version of the format
method in the various Format
classes requires a FieldPosition
object as an argument. You use this format
method to perform partial formatting or to get information about the formatted output (such as the position of a field).
The FieldPosition class is not intended for public subclassing.
Below is an example of using FieldPosition
to aid alignment of an array of formatted floating-point numbers on their decimal points:
double doubleNum[] = {123456789.0, -12345678.9, 1234567.89, -123456.789,12345.6789, -1234.56789, 123.456789, -12.3456789, 1.23456789};int dNumSize = (int)(sizeof(doubleNum)/sizeof(double));UErrorCode status = U_ZERO_ERROR;DecimalFormat* fmt = (DecimalFormat*) NumberFormat::createInstance(status);fmt->setDecimalSeparatorAlwaysShown(true);const int tempLen = 20;char temp[tempLen];for (int i=0; i<dNumSize; i++) {UnicodeString buf;char fmtText[tempLen];ToCharString(fmt->format(doubleNum[i], buf, pos), fmtText);for (int j=0; j<tempLen; j++) temp[j] = ' '; // clear with spacestemp[__min(tempLen, tempLen-pos.getEndIndex())] = '\0';cout << temp << fmtText << endl;}delete fmt;
The code will generate the following output:
123,456,789.000-12,345,678.9001,234,567.880-123,456.78912,345.678-1,234.567123.456-12.3451.234
Definition at line 108 of file fieldpos.h.
anonymous enum |
DONT_CARE may be specified as the field to indicate that the caller doesn't need to specify a field.
Definition at line 115 of file fieldpos.h.
|
inline |
Creates a FieldPosition object with a non-specified field.
Definition at line 121 of file fieldpos.h.
|
inline |
Creates a FieldPosition object for the given field.
Fields are identified by constants, whose names typically end with _FIELD, in the various subclasses of Format.
Definition at line 135 of file fieldpos.h.
|
inline |
Copy constructor.
copy | the object to be copied from. |
Definition at line 143 of file fieldpos.h.
References icu::operator!=(), and icu::operator==().
|
virtual |
Destructor.
FieldPosition* icu::FieldPosition::clone | ( | ) | const |
Clone this object.
Clones can be used concurrently in multiple threads. If an error occurs, then NULL is returned. The caller must delete the clone.
|
inline |
Retrieve the index of the first character in the requested field.
Definition at line 200 of file fieldpos.h.
|
virtual |
ICU "poor man's RTTI", returns a UClassID for the actual class.
Reimplemented from icu::UObject.
|
inline |
Retrieve the index of the character following the last character in the requested field.
Definition at line 209 of file fieldpos.h.
|
inline |
Retrieve the field identifier.
Definition at line 193 of file fieldpos.h.
|
static |
ICU "poor man's RTTI", returns a UClassID for this class.
|
inline |
Equality operator.
that | the object to be compared with. |
Definition at line 284 of file fieldpos.h.
References icu::operator==(), and U_NAMESPACE_END.
|
inline |
Assignment operator.
copy | the object to be copied from. |
Definition at line 267 of file fieldpos.h.
|
inline |
Equality operator.
that | the object to be compared with. |
Definition at line 276 of file fieldpos.h.
|
inline |
Set the begin index.
For use by subclasses of Format.
bi | the new value of the begin index |
Definition at line 223 of file fieldpos.h.
|
inline |
Set the end index.
For use by subclasses of Format.
ei | the new value of the end index |
Definition at line 230 of file fieldpos.h.
References icu::UObject::getDynamicClassID().
|
inline |
Set the field.
f | the new value of the field. |
Definition at line 216 of file fieldpos.h.