#include <wx/numformatter.h>
Helper class for formatting and parsing numbers with thousands separators.
This class contains only static functions, so users must not create instances but directly call the member functions.
Public Types | |
enum | Style { Style_None = 0x00, Style_WithThousandsSep = 0x01, Style_NoTrailingZeroes = 0x02 } |
Bit masks used with ToString(). More... | |
Static Public Member Functions | |
static wxString | ToString (long val, int flags=Style_WithThousandsSep) |
Returns string representation of an integer number. More... | |
static wxString | ToString (double val, int precision, int flags=Style_WithThousandsSep) |
Returns string representation of a floating point number. More... | |
static wxChar | GetDecimalSeparator () |
Get the decimal separator for the current locale. More... | |
static bool | GetThousandsSeparatorIfUsed (wxChar *sep) |
Get the thousands separator if grouping of the digits is used by the current locale. More... | |
static bool | FromString (wxString s, long *val) |
Parse a string representation of a number possibly including thousands separators. More... | |
static bool | FromString (wxString s, double *val) |
Parse a string representation of a number possibly including thousands separators. More... | |
Bit masks used with ToString().
Enumerator | |
---|---|
Style_None |
This flag can be used to indicate absence of any other flags below. |
Style_WithThousandsSep |
If this flag is given, thousands separators will be inserted in the number string representation as defined by the current locale. |
Style_NoTrailingZeroes |
If this flag is given, trailing zeroes in a floating point number string representation will be omitted. If the number is actually integer, the decimal separator will be omitted as well. To give an example, formatting the number This flag can't be used with ToString() overload taking the integer value. |
|
static |
Parse a string representation of a number possibly including thousands separators.
These functions parse number representation in the current locale. On success they return true and store the result at the location pointed to by val (which can't be NULL), otherwise false is returned.
|
static |
Parse a string representation of a number possibly including thousands separators.
These functions parse number representation in the current locale. On success they return true and store the result at the location pointed to by val (which can't be NULL), otherwise false is returned.
|
static |
Get the decimal separator for the current locale.
Decimal separators is always defined and we fall back to returning '.' in case of an error.
|
static |
Get the thousands separator if grouping of the digits is used by the current locale.
The value returned in sep should be only used if the function returns true, otherwise no thousands separator should be used at all.
sep | Points to the variable receiving the thousands separator character if it is used by the current locale. May be NULL if only the function return value is needed. |
|
static |
Returns string representation of an integer number.
By default, the string will use thousands separators if appropriate for the current locale. This can be avoided by passing Style_None as flags in which case the call to the function has exactly the same effect as wxString::Format("%ld", val)
.
Notice that calling ToString() with a value of type int
and non-default flags results in ambiguity between this overload and the one below. To resolve it, you need to cast the value to long
.
val | The variable to convert to a string. |
flags | Combination of values from the Style enumeration (except for Style_NoTrailingZeroes which can't be used with this overload). |
|
static |
Returns string representation of a floating point number.
val | The variable to convert to a string. |
precision | Number of decimals to write in formatted string. |
flags | Combination of values from the Style enumeration. |