libstdc++
|
Public Types | |
enum | { _S_minus, _S_zero, _S_end } |
typedef __moneypunct_cache< _CharT, _Intl > | __cache_type |
enum | part { none, space, symbol, sign, value } |
typedef _CharT | char_type |
typedef basic_string< _CharT > | string_type |
Public Member Functions | |
moneypunct (size_t __refs=0) | |
moneypunct (__cache_type *__cache, size_t __refs=0) | |
moneypunct (__c_locale __cloc, const char *__s, size_t __refs=0) | |
string_type | curr_symbol () const |
char_type | decimal_point () const |
int | frac_digits () const |
string | grouping () const |
string_type | negative_sign () const |
string_type | positive_sign () const |
char_type | thousands_sep () const |
pattern | pos_format () const |
pattern | neg_format () const |
Static Public Member Functions | |
static pattern | _S_construct_pattern (char __precedes, char __space, char __posn) throw () |
Static Public Attributes | |
static const char * | _S_atoms |
static const pattern | _S_default_pattern |
static locale::id | id |
static const bool | intl |
Protected Member Functions | |
virtual | ~moneypunct () |
void | _M_initialize_moneypunct (__c_locale __cloc=0, const char *__name=0) |
template<> | |
void | _M_initialize_moneypunct (__c_locale, const char *) |
template<> | |
void | _M_initialize_moneypunct (__c_locale, const char *) |
template<> | |
void | _M_initialize_moneypunct (__c_locale, const char *) |
template<> | |
void | _M_initialize_moneypunct (__c_locale, const char *) |
virtual string_type | do_curr_symbol () const |
virtual char_type | do_decimal_point () const |
virtual int | do_frac_digits () const |
virtual string | do_grouping () const |
virtual pattern | do_neg_format () const |
virtual string_type | do_negative_sign () const |
virtual pattern | do_pos_format () const |
virtual string_type | do_positive_sign () const |
virtual char_type | do_thousands_sep () const |
Primary class template moneypunct.
This facet encapsulates the punctuation, grouping and other formatting features of money amount string representations.
Definition at line 1024 of file locale_facets_nonio.h.
typedef _CharT std::moneypunct< _CharT, _Intl >::char_type |
Public typedefs.
Definition at line 1030 of file locale_facets_nonio.h.
typedef basic_string<_CharT> std::moneypunct< _CharT, _Intl >::string_type |
Public typedefs.
Definition at line 1031 of file locale_facets_nonio.h.
|
inlineexplicit |
Constructor performs initialization.
This is the constructor provided by the standard.
__refs | Passed to the base facet class. |
Definition at line 1053 of file locale_facets_nonio.h.
|
inlineexplicit |
Constructor performs initialization.
This is an internal constructor.
__cache | Cache for optimization. |
__refs | Passed to the base facet class. |
Definition at line 1066 of file locale_facets_nonio.h.
|
inlineexplicit |
Internal constructor. Not for general use.
This is a constructor for use by the library itself to set up new locales.
__cloc | The C locale. |
__s | The name of a locale. |
__refs | Passed to the base facet class. |
Definition at line 1081 of file locale_facets_nonio.h.
|
protectedvirtual |
Destructor.
|
inline |
Return currency symbol string.
This function returns a string_type to use as a currency symbol. It does so by returning returning moneypunct<char_type>::do_curr_symbol().
Definition at line 1151 of file locale_facets_nonio.h.
References std::moneypunct< _CharT, _Intl >::do_curr_symbol().
|
inline |
Return decimal point character.
This function returns a char_type to use as a decimal point. It does so by returning returning moneypunct<char_type>::do_decimal_point().
Definition at line 1095 of file locale_facets_nonio.h.
References std::moneypunct< _CharT, _Intl >::do_decimal_point().
|
inlineprotectedvirtual |
Return currency symbol string.
This function returns a string_type to use as a currency symbol. This function is a hook for derived classes to change the value returned.
Definition at line 1297 of file locale_facets_nonio.h.
Referenced by std::moneypunct< _CharT, _Intl >::curr_symbol().
|
inlineprotectedvirtual |
Return decimal point character.
Returns a char_type to use as a decimal point. This function is a hook for derived classes to change the value returned.
Definition at line 1259 of file locale_facets_nonio.h.
Referenced by std::moneypunct< _CharT, _Intl >::decimal_point().
|
inlineprotectedvirtual |
Return number of digits in fraction.
This function returns the exact number of digits that make up the fractional part of a money amount. This function is a hook for derived classes to change the value returned.
Definition at line 1337 of file locale_facets_nonio.h.
Referenced by std::moneypunct< _CharT, _Intl >::frac_digits().
|
inlineprotectedvirtual |
Return grouping specification.
Returns a string representing groupings for the integer part of a number. This function is a hook for derived classes to change the value returned.
Definition at line 1284 of file locale_facets_nonio.h.
Referenced by std::moneypunct< _CharT, _Intl >::grouping().
|
inlineprotectedvirtual |
Return pattern for money values.
This function returns a pattern describing the formatting of a negative valued money amount. This function is a hook for derived classes to change the value returned.
Definition at line 1365 of file locale_facets_nonio.h.
Referenced by std::moneypunct< _CharT, _Intl >::neg_format().
|
inlineprotectedvirtual |
Return negative sign string.
This function returns a string_type to use as a sign for negative amounts. This function is a hook for derived classes to change the value returned.
Definition at line 1323 of file locale_facets_nonio.h.
Referenced by std::moneypunct< _CharT, _Intl >::negative_sign().
|
inlineprotectedvirtual |
Return pattern for money values.
This function returns a pattern describing the formatting of a positive valued money amount. This function is a hook for derived classes to change the value returned.
Definition at line 1351 of file locale_facets_nonio.h.
Referenced by std::moneypunct< _CharT, _Intl >::pos_format().
|
inlineprotectedvirtual |
Return positive sign string.
This function returns a string_type to use as a sign for positive amounts. This function is a hook for derived classes to change the value returned.
Definition at line 1310 of file locale_facets_nonio.h.
Referenced by std::moneypunct< _CharT, _Intl >::positive_sign().
|
inlineprotectedvirtual |
Return thousands separator character.
Returns a char_type to use as a thousands separator. This function is a hook for derived classes to change the value returned.
Definition at line 1271 of file locale_facets_nonio.h.
Referenced by std::moneypunct< _CharT, _Intl >::thousands_sep().
|
inline |
Return number of digits in fraction.
This function returns the exact number of digits that make up the fractional part of a money amount. It does so by returning returning moneypunct<char_type>::do_frac_digits().
The fractional part of a money amount is optional. But if it is present, there must be frac_digits() digits.
Definition at line 1201 of file locale_facets_nonio.h.
References std::moneypunct< _CharT, _Intl >::do_frac_digits().
|
inline |
Return grouping specification.
This function returns a string representing groupings for the integer part of an amount. Groupings indicate where thousands separators should be inserted.
Each char in the return string is interpret as an integer rather than a character. These numbers represent the number of digits in a group. The first char in the string represents the number of digits in the least significant group. If a char is negative, it indicates an unlimited number of digits for the group. If more chars from the string are required to group a number, the last char is used repeatedly.
For example, if the grouping() returns \003\002
and is applied to the number 123456789, this corresponds to 12,34,56,789. Note that if the string was 32
, this would put more than 50 digits into the least significant group if the character set is ASCII.
The string is returned by calling moneypunct<char_type>::do_grouping().
Definition at line 1138 of file locale_facets_nonio.h.
References std::moneypunct< _CharT, _Intl >::do_grouping().
|
inline |
Return pattern for money values.
This function returns a pattern describing the formatting of a positive or negative valued money amount. It does so by returning returning moneypunct<char_type>::do_pos_format() or moneypunct<char_type>::do_neg_format().
The pattern has 4 fields describing the ordering of symbol, sign, value, and none or space. There must be one of each in the pattern. The none and space enums may not appear in the first field and space may not appear in the final field.
The parts of a money string must appear in the order indicated by the fields of the pattern. The symbol field indicates that the value of curr_symbol() may be present. The sign field indicates that the value of positive_sign() or negative_sign() must be present. The value field indicates that the absolute value of the money amount is present. none indicates 0 or more whitespace characters, except at the end, where it permits no whitespace. space indicates that 1 or more whitespace characters must be present.
For example, for the US locale and pos_format() pattern {symbol,sign,value,none}, curr_symbol() == '$' positive_sign() == '+', and value 10.01, and options set to force the symbol, the corresponding string is $+10.01
.
Definition at line 1241 of file locale_facets_nonio.h.
References std::moneypunct< _CharT, _Intl >::do_neg_format().
|
inline |
Return negative sign string.
This function returns a string_type to use as a sign for negative amounts. It does so by returning returning moneypunct<char_type>::do_negative_sign().
If the return value contains more than one character, the first character appears in the position indicated by neg_format() and the remainder appear at the end of the formatted string.
Definition at line 1185 of file locale_facets_nonio.h.
References std::moneypunct< _CharT, _Intl >::do_negative_sign().
|
inline |
Return pattern for money values.
This function returns a pattern describing the formatting of a positive or negative valued money amount. It does so by returning returning moneypunct<char_type>::do_pos_format() or moneypunct<char_type>::do_neg_format().
The pattern has 4 fields describing the ordering of symbol, sign, value, and none or space. There must be one of each in the pattern. The none and space enums may not appear in the first field and space may not appear in the final field.
The parts of a money string must appear in the order indicated by the fields of the pattern. The symbol field indicates that the value of curr_symbol() may be present. The sign field indicates that the value of positive_sign() or negative_sign() must be present. The value field indicates that the absolute value of the money amount is present. none indicates 0 or more whitespace characters, except at the end, where it permits no whitespace. space indicates that 1 or more whitespace characters must be present.
For example, for the US locale and pos_format() pattern {symbol,sign,value,none}, curr_symbol() == '$' positive_sign() == '+', and value 10.01, and options set to force the symbol, the corresponding string is $+10.01
.
Definition at line 1237 of file locale_facets_nonio.h.
References std::moneypunct< _CharT, _Intl >::do_pos_format().
|
inline |
Return positive sign string.
This function returns a string_type to use as a sign for positive amounts. It does so by returning returning moneypunct<char_type>::do_positive_sign().
If the return value contains more than one character, the first character appears in the position indicated by pos_format() and the remainder appear at the end of the formatted string.
Definition at line 1168 of file locale_facets_nonio.h.
References std::moneypunct< _CharT, _Intl >::do_positive_sign().
|
inline |
Return thousands separator character.
This function returns a char_type to use as a thousands separator. It does so by returning returning moneypunct<char_type>::do_thousands_sep().
Definition at line 1108 of file locale_facets_nonio.h.
References std::moneypunct< _CharT, _Intl >::do_thousands_sep().
|
static |
Numpunct facet id.
Definition at line 1043 of file locale_facets_nonio.h.
|
static |
This value is provided by the standard, but no reason for its existence.
Definition at line 1041 of file locale_facets_nonio.h.