num_put Class Template Reference

Facet for converting numbers to strings. More...

Inheritance diagram for num_put:

Inheritance graph

List of all members.

Public Types

Public Member Functions

Static Public Attributes

Protected Member Functions

Static Protected Member Functions

Friends


Detailed Description

template<typename _CharT, typename _OutIter>
class std::num_put< _CharT, _OutIter >

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 2220 of file locale_facets.h.


Member Typedef Documentation

typedef _CharT char_type

Public typedefs.

Definition at line 2226 of file locale_facets.h.

typedef _OutIter iter_type

Public typedefs.

Definition at line 2227 of file locale_facets.h.


Constructor & Destructor Documentation

num_put ( size_t  __refs = 0  )  [inline, explicit]

Constructor performs initialization.

This is the constructor provided by the standard.

Parameters:
refs Passed to the base facet class.

Definition at line 2241 of file locale_facets.h.

virtual ~num_put (  )  [inline, protected, virtual]

Destructor.

Definition at line 2420 of file locale_facets.h.


Member Function Documentation

_OutIter do_put ( iter_type  __s,
ios_base __io,
char_type  __fill,
const void *  __v 
) const [inline, protected, virtual]

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 1279 of file locale_facets.tcc.

References ios_base::flags(), ios_base::hex, ios_base::internal, ios_base::showbase, and ios_base::uppercase.

_OutIter do_put ( iter_type  __s,
ios_base __io,
char_type  __fill,
long double  __v 
) const [inline, protected, virtual]

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 1272 of file locale_facets.tcc.

_OutIter do_put ( iter_type  __s,
ios_base __io,
char_type  __fill,
double  __v 
) const [inline, protected, virtual]

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 1258 of file locale_facets.tcc.

_OutIter do_put ( iter_type  __s,
ios_base __io,
char_type  __fill,
unsigned long long  __v 
) const [inline, protected, virtual]

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 1250 of file locale_facets.tcc.

_OutIter do_put ( iter_type  __s,
ios_base __io,
char_type  __fill,
long long  __v 
) const [inline, protected, virtual]

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 1244 of file locale_facets.tcc.

_OutIter do_put ( iter_type  __s,
ios_base __io,
char_type  __fill,
unsigned long  __v 
) const [inline, protected, virtual]

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 1236 of file locale_facets.tcc.

_OutIter do_put ( iter_type  __s,
ios_base __io,
char_type  __fill,
long  __v 
) const [inline, protected, virtual]

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 1230 of file locale_facets.tcc.

_OutIter do_put ( iter_type  __s,
ios_base __io,
char_type  __fill,
bool  __v 
) const [inline, protected, virtual]

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 1192 of file locale_facets.tcc.

References ios_base::_M_getloc(), ios_base::boolalpha, ios_base::flags(), and ios_base::width().

Referenced by num_put::put().

iter_type put ( iter_type  __s,
ios_base __f,
char_type  __fill,
const void *  __v 
) const [inline]

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 2389 of file locale_facets.h.

References num_put::do_put().

iter_type put ( iter_type  __s,
ios_base __f,
char_type  __fill,
long double  __v 
) const [inline]

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.

Thousands separators are inserted according to numpunct::grouping() and numpunct::thousands_sep(). The decimal point character used is numpunct::decimal_point().

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 2368 of file locale_facets.h.

References num_put::do_put().

iter_type put ( iter_type  __s,
ios_base __f,
char_type  __fill,
double  __v 
) const [inline]

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.

Thousands separators are inserted according to numpunct::grouping() and numpunct::thousands_sep(). The decimal point character used is numpunct::decimal_point().

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 2364 of file locale_facets.h.

References num_put::do_put().

iter_type put ( iter_type  __s,
ios_base __f,
char_type  __fill,
unsigned long long  __v 
) const [inline]

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.

Thousands separators are inserted according to numpunct::grouping() and numpunct::thousands_sep(). The decimal point character used is numpunct::decimal_point().

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 2315 of file locale_facets.h.

References num_put::do_put().

iter_type put ( iter_type  __s,
ios_base __f,
char_type  __fill,
long long  __v 
) const [inline]

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.

Thousands separators are inserted according to numpunct::grouping() and numpunct::thousands_sep(). The decimal point character used is numpunct::decimal_point().

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 2311 of file locale_facets.h.

References num_put::do_put().

iter_type put ( iter_type  __s,
ios_base __f,
char_type  __fill,
unsigned long  __v 
) const [inline]

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.

Thousands separators are inserted according to numpunct::grouping() and numpunct::thousands_sep(). The decimal point character used is numpunct::decimal_point().

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 2305 of file locale_facets.h.

References num_put::do_put().

iter_type put ( iter_type  __s,
ios_base __f,
char_type  __fill,
long  __v 
) const [inline]

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.

Thousands separators are inserted according to numpunct::grouping() and numpunct::thousands_sep(). The decimal point character used is numpunct::decimal_point().

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 2301 of file locale_facets.h.

References num_put::do_put().

iter_type put ( iter_type  __s,
ios_base __f,
char_type  __fill,
bool  __v 
) const [inline]

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<CharT>::truename() or ctype<CharT>::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 2259 of file locale_facets.h.

References num_put::do_put().

Referenced by basic_ostream::operator<<().


Member Data Documentation

locale::id id [inline, static]

Numpunct facet id.

Definition at line 2231 of file locale_facets.h.


The documentation for this class was generated from the following files:

Generated on Tue Dec 2 03:59:53 2008 for libstdc++ by  doxygen 1.5.7.1