libstdc++: std::num_put< _CharT, _OutIter > Class Template Reference (original) (raw)
#include <[locale_facets.h](a00596%5Fsource.html)>
Public Types | |
---|---|
typedef _CharT | char_type |
typedef _OutIter | iter_type |
Public Member Functions | |
---|---|
num_put (size_t __refs=0) | |
template<typename _ValueT > | |
_OutIter | _M_insert_float (_OutIter __s, ios_base &__io, _CharT __fill, char __mod, _ValueT __v) const |
template<typename _ValueT > | |
_OutIter | _M_insert_int (_OutIter __s, ios_base &__io, _CharT __fill, _ValueT __v) const |
iter_type | put (iter_type __s, ios_base &__io, char_type __fill, bool __v) const |
iter_type | put (iter_type __s, ios_base &__io, char_type __fill, const void *__v) const |
iter_type | put (iter_type __s, ios_base &__io, char_type __fill, long __v) const |
iter_type | put (iter_type __s, ios_base &__io, char_type __fill, unsigned long __v) const |
iter_type | put (iter_type __s, ios_base &__io, char_type __fill, long long __v) const |
iter_type | put (iter_type __s, ios_base &__io, char_type __fill, unsigned long long __v) const |
iter_type | put (iter_type __s, ios_base &__io, char_type __fill, double __v) const |
iter_type | put (iter_type __s, ios_base &__io, char_type __fill, long double __v) const |
Protected Member Functions | |
---|---|
virtual | ~num_put () |
void | _M_group_float (const char *__grouping, size_t __grouping_size, char_type __sep, const char_type *__p, char_type *__new, char_type *__cs, int &__len) const |
void | _M_group_int (const char *__grouping, size_t __grouping_size, char_type __sep, ios_base &__io, char_type *__new, char_type *__cs, int &__len) const |
template<typename _ValueT > | |
iter_type | _M_insert_float (iter_type, ios_base &__io, char_type __fill, char __mod, _ValueT __v) const |
template<typename _ValueT > | |
iter_type | _M_insert_int (iter_type, ios_base &__io, char_type __fill, _ValueT __v) const |
void | _M_pad (char_type __fill, streamsize __w, ios_base &__io, char_type *__new, const char_type *__cs, int &__len) const |
virtual iter_type | do_put (iter_type __s, ios_base &__io, char_type __fill, bool __v) const |
virtual iter_type | do_put (iter_type __s, ios_base &__io, char_type __fill, long __v) const |
virtual iter_type | do_put (iter_type __s, ios_base &__io, char_type __fill, unsigned long __v) const |
virtual iter_type | do_put (iter_type __s, ios_base &__io, char_type __fill, long long __v) const |
virtual iter_type | do_put (iter_type __s, ios_base &__io, char_type __fill, unsigned long long __v) const |
virtual iter_type | do_put (iter_type, ios_base &, char_type, double) const |
virtual iter_type | do_put (iter_type, ios_base &, char_type, long double) const |
virtual iter_type | do_put (iter_type, ios_base &, char_type, const void *) const |
Static Protected Member Functions | |
---|---|
static __c_locale | _S_clone_c_locale (__c_locale &__cloc) throw () |
static void | _S_create_c_locale (__c_locale &__cloc, const char *__s, __c_locale __old=0) |
static void | _S_destroy_c_locale (__c_locale &__cloc) |
static __c_locale | _S_get_c_locale () |
static const char * | _S_get_c_name () throw () |
static __c_locale | _S_lc_ctype_c_locale (__c_locale __cloc, const char *__s) |
template<typename _CharT, typename _OutIter>
class std::num_put< _CharT, _OutIter >
Primary class template num_put.
This facet encapsulates the code to convert a number to a string. It is used by the ostream numeric insertion operators.
The num_put template uses protected virtual functions to provide the actual results. The public accessors forward the call to the virtual functions. These virtual functions are hooks for developers to implement the behavior they require from the num_put facet.
Definition at line 2318 of file locale_facets.h.
◆ char_type
template<typename _CharT , typename _OutIter >
◆ iter_type
template<typename _CharT , typename _OutIter >
typedef _OutIter std::num_put< _CharT, _OutIter >::iter_type
template<typename _CharT , typename _OutIter >
std::num_put< _CharT, _OutIter >::num_put ( size_t __refs = 0) | inlineexplicit |
---|
Constructor performs initialization.
This is the constructor provided by the standard.
Parameters
__refs | Passed to the base facet class. |
---|
Definition at line 2339 of file locale_facets.h.
◆ ~num_put()
template<typename _CharT , typename _OutIter >
◆ _M_group_float()
template<typename _CharT , typename _OutIter >
◆ _M_group_int()
template<typename _CharT , typename _OutIter >
◆ _M_insert_float()
template<typename _CharT , typename _OutIter >
template<typename _ValueT >
_OutIter std::num_put< _CharT, _OutIter >::_M_insert_float | ( | _OutIter | __s, |
---|---|---|---|
ios_base & | __io, | ||
_CharT | __fill, | ||
char | __mod, | ||
_ValueT | __v | ||
) | const |
◆ _M_insert_int()
template<typename _CharT , typename _OutIter >
template<typename _ValueT >
_OutIter std::num_put< _CharT, _OutIter >::_M_insert_int | ( | _OutIter | __s, |
---|---|---|---|
ios_base & | __io, | ||
_CharT | __fill, | ||
_ValueT | __v | ||
) | const |
◆ _M_pad()
template<typename _CharT , typename _OutIter >
◆ do_put() [1/8]
template<typename _CharT , typename _OutIter >
Numeric formatting.
These functions do the work of formatting numeric values and inserting them into a stream. This function is a hook for derived classes to change the value returned.
Parameters
__s | Stream to write to. |
---|---|
__io | Source of locale and flags. |
__fill | Char_type to use for filling. |
__v | Value to format and insert. |
Returns
Iterator after writing.
Definition at line 1123 of file locale_facets.tcc.
References std::ios_base::_M_getloc(), std::ios_base::adjustfield, std::ios_base::boolalpha, std::ios_base::flags(), std::ios_base::left, and std::ios_base::width().
Referenced by std::num_put< _CharT, _OutIter >::put(), std::num_put< _CharT, _OutIter >::put(), std::num_put< _CharT, _OutIter >::put(), std::num_put< _CharT, _OutIter >::put(), std::num_put< _CharT, _OutIter >::put(), std::num_put< _CharT, _OutIter >::put(), std::num_put< _CharT, _OutIter >::put(), and std::num_put< _CharT, _OutIter >::put().
◆ do_put() [2/8]
template<typename _CharT , typename _OutIter >
Numeric formatting.
These functions do the work of formatting numeric values and inserting them into a stream. This function is a hook for derived classes to change the value returned.
Parameters
__s | Stream to write to. |
---|---|
__io | Source of locale and flags. |
__fill | Char_type to use for filling. |
__v | Value to format and insert. |
Returns
Iterator after writing.
Definition at line 2538 of file locale_facets.h.
◆ do_put() [3/8]
template<typename _CharT , typename _OutIter >
Numeric formatting.
These functions do the work of formatting numeric values and inserting them into a stream. This function is a hook for derived classes to change the value returned.
Parameters
__s | Stream to write to. |
---|---|
__io | Source of locale and flags. |
__fill | Char_type to use for filling. |
__v | Value to format and insert. |
Returns
Iterator after writing.
Definition at line 2548 of file locale_facets.h.
◆ do_put() [4/8]
template<typename _CharT , typename _OutIter >
Numeric formatting.
These functions do the work of formatting numeric values and inserting them into a stream. This function is a hook for derived classes to change the value returned.
Parameters
__s | Stream to write to. |
---|---|
__io | Source of locale and flags. |
__fill | Char_type to use for filling. |
__v | Value to format and insert. |
Returns
Iterator after writing.
Definition at line 2542 of file locale_facets.h.
◆ do_put() [5/8]
template<typename _CharT , typename _OutIter >
Numeric formatting.
These functions do the work of formatting numeric values and inserting them into a stream. This function is a hook for derived classes to change the value returned.
Parameters
__s | Stream to write to. |
---|---|
__io | Source of locale and flags. |
__fill | Char_type to use for filling. |
__v | Value to format and insert. |
Returns
Iterator after writing.
Definition at line 2553 of file locale_facets.h.
◆ do_put() [6/8]
template<typename _CharT , typename _OutIter >
◆ do_put() [7/8]
template<typename _CharT , typename _OutIter >
Numeric formatting.
These functions do the work of formatting numeric values and inserting them into a stream. This function is a hook for derived classes to change the value returned.
Parameters
__s | Stream to write to. |
---|---|
__io | Source of locale and flags. |
__fill | Char_type to use for filling. |
__v | Value to format and insert. |
Returns
Iterator after writing.
Definition at line 1175 of file locale_facets.tcc.
◆ do_put() [8/8]
template<typename _CharT , typename _OutIter >
Numeric formatting.
These functions do the work of formatting numeric values and inserting them into a stream. This function is a hook for derived classes to change the value returned.
Parameters
__s | Stream to write to. |
---|---|
__io | Source of locale and flags. |
__fill | Char_type to use for filling. |
__v | Value to format and insert. |
Returns
Iterator after writing.
Definition at line 1189 of file locale_facets.tcc.
◆ put() [1/8]
template<typename _CharT , typename _OutIter >
Numeric formatting.
Formats the boolean v and inserts it into a stream. It does so by calling num_put::do_put().
If ios_base::boolalpha is set, writes ctype::truename() or ctype::falsename(). Otherwise formats v as an int.
Parameters
__s | Stream to write to. |
---|---|
__io | Source of locale and flags. |
__fill | Char_type to use for filling. |
__v | Value to format and insert. |
Returns
Iterator after writing.
Definition at line 2357 of file locale_facets.h.
References std::num_put< _CharT, _OutIter >::do_put().
Referenced by std::basic_ostream< _CharT, _Traits >::operator<<().
◆ put() [2/8]
template<typename _CharT , typename _OutIter >
Numeric formatting.
Formats the pointer value v and inserts it into a stream. It does so by calling num_put::do_put().
This function formats v as an unsigned long with ios_base::hex and ios_base::showbase set.
Parameters
__s | Stream to write to. |
---|---|
__io | Source of locale and flags. |
__fill | Char_type to use for filling. |
__v | Value to format and insert. |
Returns
Iterator after writing.
Definition at line 2487 of file locale_facets.h.
References std::num_put< _CharT, _OutIter >::do_put().
◆ put() [3/8]
template<typename _CharT , typename _OutIter >
Numeric formatting.
Formats the floating point value v and inserts it into a stream. It does so by calling num_put::do_put().
Formatting is affected by the flag settings in io.
The basic format is affected by the value of io.flags() & ios_base::floatfield. If equal to ios_base::fixed, formats like the printf f specifier. Else if equal to ios_base::scientific, formats like e or E with ios_base::uppercase unset or set respectively. Otherwise, formats like g or G depending on uppercase. Note that if both fixed and scientific are set, the effect will also be like g or G.
The output precision is given by io.precision(). This precision is capped at numeric_limits::digits10 + 2 (different for double and long double). The default precision is 6.
If ios_base::showpos is set, '+' is output before positive values. If ios_base::showpoint is set, a decimal point will always be output.
The decimal point character used is numpunct::decimal_point(). Thousands separators are inserted according to numpunct::grouping() and numpunct::thousands_sep().
If io.width() is non-zero, enough fill characters are inserted to make the result at least that wide. If (io.flags() & ios_base::adjustfield) == ios_base::left, result is padded at the end. If ios_base::internal, then padding occurs immediately after either a '+' or '-' or after '0x' or '0X'. Otherwise, padding occurs at the beginning.
Parameters
__s | Stream to write to. |
---|---|
__io | Source of locale and flags. |
__fill | Char_type to use for filling. |
__v | Value to format and insert. |
Returns
Iterator after writing.
Definition at line 2462 of file locale_facets.h.
References std::num_put< _CharT, _OutIter >::do_put().
◆ put() [4/8]
template<typename _CharT , typename _OutIter >
Numeric formatting.
Formats the integral value v and inserts it into a stream. It does so by calling num_put::do_put().
Formatting is affected by the flag settings in io.
The basic format is affected by the value of io.flags() & ios_base::basefield. If equal to ios_base::oct, formats like the printf o specifier. Else if equal to ios_base::hex, formats like x or X with ios_base::uppercase unset or set respectively. Otherwise, formats like d, ld, lld for signed and u, lu, llu for unsigned values. Note that if both oct and hex are set, neither will take effect.
If ios_base::showpos is set, '+' is output before positive values. If ios_base::showbase is set, '0' precedes octal values (except 0) and '0[xX]' precedes hex values.
The decimal point character used is numpunct::decimal_point(). Thousands separators are inserted according to numpunct::grouping() and numpunct::thousands_sep().
If io.width() is non-zero, enough fill characters are inserted to make the result at least that wide. If (io.flags() & ios_base::adjustfield) == ios_base::left, result is padded at the end. If ios_base::internal, then padding occurs immediately after either a '+' or '-' or after '0x' or '0X'. Otherwise, padding occurs at the beginning.
Parameters
__s | Stream to write to. |
---|---|
__io | Source of locale and flags. |
__fill | Char_type to use for filling. |
__v | Value to format and insert. |
Returns
Iterator after writing.
Definition at line 2399 of file locale_facets.h.
References std::num_put< _CharT, _OutIter >::do_put().
◆ put() [5/8]
template<typename _CharT , typename _OutIter >
Numeric formatting.
Formats the floating point value v and inserts it into a stream. It does so by calling num_put::do_put().
Formatting is affected by the flag settings in io.
The basic format is affected by the value of io.flags() & ios_base::floatfield. If equal to ios_base::fixed, formats like the printf f specifier. Else if equal to ios_base::scientific, formats like e or E with ios_base::uppercase unset or set respectively. Otherwise, formats like g or G depending on uppercase. Note that if both fixed and scientific are set, the effect will also be like g or G.
The output precision is given by io.precision(). This precision is capped at numeric_limits::digits10 + 2 (different for double and long double). The default precision is 6.
If ios_base::showpos is set, '+' is output before positive values. If ios_base::showpoint is set, a decimal point will always be output.
The decimal point character used is numpunct::decimal_point(). Thousands separators are inserted according to numpunct::grouping() and numpunct::thousands_sep().
If io.width() is non-zero, enough fill characters are inserted to make the result at least that wide. If (io.flags() & ios_base::adjustfield) == ios_base::left, result is padded at the end. If ios_base::internal, then padding occurs immediately after either a '+' or '-' or after '0x' or '0X'. Otherwise, padding occurs at the beginning.
Parameters
__s | Stream to write to. |
---|---|
__io | Source of locale and flags. |
__fill | Char_type to use for filling. |
__v | Value to format and insert. |
Returns
Iterator after writing.
Definition at line 2466 of file locale_facets.h.
References std::num_put< _CharT, _OutIter >::do_put().
◆ put() [6/8]
template<typename _CharT , typename _OutIter >
Numeric formatting.
Formats the integral value v and inserts it into a stream. It does so by calling num_put::do_put().
Formatting is affected by the flag settings in io.
The basic format is affected by the value of io.flags() & ios_base::basefield. If equal to ios_base::oct, formats like the printf o specifier. Else if equal to ios_base::hex, formats like x or X with ios_base::uppercase unset or set respectively. Otherwise, formats like d, ld, lld for signed and u, lu, llu for unsigned values. Note that if both oct and hex are set, neither will take effect.
If ios_base::showpos is set, '+' is output before positive values. If ios_base::showbase is set, '0' precedes octal values (except 0) and '0[xX]' precedes hex values.
The decimal point character used is numpunct::decimal_point(). Thousands separators are inserted according to numpunct::grouping() and numpunct::thousands_sep().
If io.width() is non-zero, enough fill characters are inserted to make the result at least that wide. If (io.flags() & ios_base::adjustfield) == ios_base::left, result is padded at the end. If ios_base::internal, then padding occurs immediately after either a '+' or '-' or after '0x' or '0X'. Otherwise, padding occurs at the beginning.
Parameters
__s | Stream to write to. |
---|---|
__io | Source of locale and flags. |
__fill | Char_type to use for filling. |
__v | Value to format and insert. |
Returns
Iterator after writing.
Definition at line 2409 of file locale_facets.h.
References std::num_put< _CharT, _OutIter >::do_put().
◆ put() [7/8]
template<typename _CharT , typename _OutIter >
Numeric formatting.
Formats the integral value v and inserts it into a stream. It does so by calling num_put::do_put().
Formatting is affected by the flag settings in io.
The basic format is affected by the value of io.flags() & ios_base::basefield. If equal to ios_base::oct, formats like the printf o specifier. Else if equal to ios_base::hex, formats like x or X with ios_base::uppercase unset or set respectively. Otherwise, formats like d, ld, lld for signed and u, lu, llu for unsigned values. Note that if both oct and hex are set, neither will take effect.
If ios_base::showpos is set, '+' is output before positive values. If ios_base::showbase is set, '0' precedes octal values (except 0) and '0[xX]' precedes hex values.
The decimal point character used is numpunct::decimal_point(). Thousands separators are inserted according to numpunct::grouping() and numpunct::thousands_sep().
If io.width() is non-zero, enough fill characters are inserted to make the result at least that wide. If (io.flags() & ios_base::adjustfield) == ios_base::left, result is padded at the end. If ios_base::internal, then padding occurs immediately after either a '+' or '-' or after '0x' or '0X'. Otherwise, padding occurs at the beginning.
Parameters
__s | Stream to write to. |
---|---|
__io | Source of locale and flags. |
__fill | Char_type to use for filling. |
__v | Value to format and insert. |
Returns
Iterator after writing.
Definition at line 2403 of file locale_facets.h.
References std::num_put< _CharT, _OutIter >::do_put().
◆ put() [8/8]
template<typename _CharT , typename _OutIter >
Numeric formatting.
Formats the integral value v and inserts it into a stream. It does so by calling num_put::do_put().
Formatting is affected by the flag settings in io.
The basic format is affected by the value of io.flags() & ios_base::basefield. If equal to ios_base::oct, formats like the printf o specifier. Else if equal to ios_base::hex, formats like x or X with ios_base::uppercase unset or set respectively. Otherwise, formats like d, ld, lld for signed and u, lu, llu for unsigned values. Note that if both oct and hex are set, neither will take effect.
If ios_base::showpos is set, '+' is output before positive values. If ios_base::showbase is set, '0' precedes octal values (except 0) and '0[xX]' precedes hex values.
The decimal point character used is numpunct::decimal_point(). Thousands separators are inserted according to numpunct::grouping() and numpunct::thousands_sep().
If io.width() is non-zero, enough fill characters are inserted to make the result at least that wide. If (io.flags() & ios_base::adjustfield) == ios_base::left, result is padded at the end. If ios_base::internal, then padding occurs immediately after either a '+' or '-' or after '0x' or '0X'. Otherwise, padding occurs at the beginning.
Parameters
__s | Stream to write to. |
---|---|
__io | Source of locale and flags. |
__fill | Char_type to use for filling. |
__v | Value to format and insert. |
Returns
Iterator after writing.
Definition at line 2413 of file locale_facets.h.
References std::num_put< _CharT, _OutIter >::do_put().
◆ id
template<typename _CharT , typename _OutIter >
The documentation for this class was generated from the following files: