diff -r 666f914201fb -r 2fe1408b6811 epoc32/include/stdapis/stlport/stl/_num_put.h --- a/epoc32/include/stdapis/stlport/stl/_num_put.h Tue Nov 24 13:55:44 2009 +0000 +++ b/epoc32/include/stdapis/stlport/stl/_num_put.h Tue Mar 16 16:12:26 2010 +0000 @@ -1,1 +1,202 @@ -_num_put.h +/* + * © Portions copyright (c) 2006-2007 Nokia Corporation. All rights reserved. + * + * Copyright (c) 1999 + * Silicon Graphics Computer Systems, Inc. + * + * Copyright (c) 1999 + * Boris Fomitchev + * + * This material is provided "as is", with absolutely no warranty expressed + * or implied. Any use is at your own risk. + * + * Permission to use or copy this software for any purpose is hereby granted + * without fee, provided the above notices are retained on all copies. + * Permission to modify the code and to distribute modified code is granted, + * provided the above notices are retained, and a notice that the code was + * modified is included with the above copyright notice. + * + */ +// WARNING: This is an internal header file, included by other C++ +// standard library headers. You should not attempt to use this header +// file directly. + + +#ifndef _STLP_INTERNAL_NUM_PUT_H +#define _STLP_INTERNAL_NUM_PUT_H + +#ifndef _STLP_INTERNAL_NUMPUNCT_H +# include +#endif +#ifndef _STLP_INTERNAL_CTYPE_H +# include +#endif +#ifndef _STLP_INTERNAL_OSTREAMBUF_ITERATOR_H +# include +#endif + +_STLP_BEGIN_NAMESPACE + +//---------------------------------------------------------------------- +// num_put facet + +# ifdef _STLP_LIMITED_DEFAULT_TEMPLATES +template +# else +template > > +# endif +class num_put: public locale::facet +{ + friend class _Locale; +public: + typedef _CharT char_type; + typedef _OutputIter iter_type; + + explicit num_put(size_t __refs = 0) : _BaseFacet(__refs) {} + +# ifndef _STLP_NO_BOOL + iter_type put(iter_type __s, ios_base& __f, char_type __fill, + bool __val) const { + return do_put(__s, __f, __fill, __val); + } +# endif + iter_type put(iter_type __s, ios_base& __f, char_type __fill, + long __val) const { + return do_put(__s, __f, __fill, __val); + } + + iter_type put(iter_type __s, ios_base& __f, char_type __fill, + unsigned long __val) const { + return do_put(__s, __f, __fill, __val); + } + +#ifdef _STLP_LONG_LONG + iter_type put(iter_type __s, ios_base& __f, char_type __fill, + _STLP_LONG_LONG __val) const { + return do_put(__s, __f, __fill, __val); + } + + iter_type put(iter_type __s, ios_base& __f, char_type __fill, + unsigned _STLP_LONG_LONG __val) const { + return do_put(__s, __f, __fill, __val); + } +#endif + + iter_type put(iter_type __s, ios_base& __f, char_type __fill, + double __val) const { + return do_put(__s, __f, __fill, (double)__val); + } + +#ifndef _STLP_NO_LONG_DOUBLE + iter_type put(iter_type __s, ios_base& __f, char_type __fill, + long double __val) const { + return do_put(__s, __f, __fill, __val); + } +# endif + + iter_type put(iter_type __s, ios_base& __f, char_type __fill, + const void * __val) const { + return do_put(__s, __f, __fill, __val); + } + +#if defined(__LIBSTD_CPP_SYMBIAN32_WSD__) || defined(_STLP_LIBSTD_CPP_NO_STATIC_VAR_) + _STLP_STATIC_MEMBER_DECLSPEC static locale::id& GetFacetLocaleId(); + _STLP_STATIC_MEMBER_DECLSPEC static locale::id& + GetFacetLocaleId(ostreambuf_iterator > *); + _STLP_STATIC_MEMBER_DECLSPEC static locale::id& GetFacetLocaleId(char**); + //wchar_t + _STLP_STATIC_MEMBER_DECLSPEC static locale::id& + GetFacetLocaleId(ostreambuf_iterator > *); + _STLP_STATIC_MEMBER_DECLSPEC static locale::id& GetFacetLocaleId(wchar_t**); + //adding for new iterator type + _STLP_STATIC_MEMBER_DECLSPEC static locale::id& + GetFacetLocaleId(back_insert_iterator *); +#else + _STLP_STATIC_MEMBER_DECLSPEC static locale::id id; +#endif + +protected: + ~num_put() {} +# ifndef _STLP_NO_BOOL + virtual _OutputIter do_put(_OutputIter __s, ios_base& __f, _CharT __fill, bool __val) const; +# endif + virtual _OutputIter do_put(_OutputIter __s, ios_base& __f, _CharT __fill, long __val) const; + virtual _OutputIter do_put(_OutputIter __s, ios_base& __f, _CharT __fill, unsigned long __val) const; + virtual _OutputIter do_put(_OutputIter __s, ios_base& __f, _CharT __fill, double __val) const; +#ifndef _STLP_NO_LONG_DOUBLE + virtual _OutputIter do_put(_OutputIter __s, ios_base& __f, _CharT __fill, long double __val) const; +#endif + +#ifdef _STLP_LONG_LONG + virtual _OutputIter do_put(_OutputIter __s, ios_base& __f, _CharT __fill, _STLP_LONG_LONG __val) const; + virtual _OutputIter do_put(_OutputIter __s, ios_base& __f, _CharT __fill, + unsigned _STLP_LONG_LONG __val) const ; +#endif /* _STLP_LONG_LONG */ + virtual _OutputIter do_put(_OutputIter __s, ios_base& __f, _CharT __fill, const void* __val) const; +}; + +# ifdef _STLP_USE_TEMPLATE_EXPORT +_STLP_EXPORT_TEMPLATE_CLASS num_put > >; +// _STLP_EXPORT_TEMPLATE_CLASS num_put; +# ifndef _STLP_NO_WCHAR_T +_STLP_EXPORT_TEMPLATE_CLASS num_put > >; +// _STLP_EXPORT_TEMPLATE_CLASS num_put; +# endif /* _STLP_NO_WCHAR_T */ +# endif + +# if defined (_STLP_EXPOSE_STREAM_IMPLEMENTATION) + +template +char* _STLP_CALL +__write_integer_backward(char* __buf, ios_base::fmtflags __flags, _Integer __x); + +extern _STLP_DECLSPEC int _STLP_CALL __string_to_float(const string&, float&); +extern _STLP_DECLSPEC int _STLP_CALL __string_to_float(const string&, double&); +extern _STLP_DECLSPEC void _STLP_CALL __write_float(string&, ios_base::fmtflags, int, double); +# ifndef _STLP_NO_LONG_DOUBLE +int _STLP_CALL __string_to_float(const string&, long double&); +extern _STLP_DECLSPEC void _STLP_CALL __write_float(string&, ios_base::fmtflags, int, long double); +# endif + +#ifndef _STLP_NO_WCHAR_T +extern _STLP_DECLSPEC wchar_t* _STLP_CALL __convert_float_buffer(const char*, const char*, wchar_t*, const ctype&, wchar_t); +#endif +extern _STLP_DECLSPEC void _STLP_CALL __adjust_float_buffer(char*, char*, char); + +extern _STLP_DECLSPEC char* _STLP_CALL +__write_integer(char* buf, ios_base::fmtflags flags, long x); + +extern _STLP_DECLSPEC ptrdiff_t _STLP_CALL __insert_grouping(char* first, char* last, const string&, char, char, char, int); +# ifndef _STLP_NO_WCHAR_T +extern _STLP_DECLSPEC ptrdiff_t _STLP_CALL __insert_grouping(wchar_t*, wchar_t*, const string&, wchar_t, wchar_t, wchar_t, int); +# endif + +# endif + +# if defined (__BORLANDC__) && defined (_RTLDLL) +inline void _Stl_loc_init_num_put() { + + num_put > >::id._M_index = 14; + num_put::id._M_index = 15; + +# ifndef _STLP_NO_WCHAR_T + num_put > > ::id._M_index = 33; + num_put::id._M_index = 34; +# endif + +} + +# endif + +_STLP_END_NAMESPACE + +# if defined (_STLP_EXPOSE_STREAM_IMPLEMENTATION) && ! defined (_STLP_LINK_TIME_INSTANTIATION) +# include +# endif + +#endif /* _STLP_INTERNAL_NUMERIC_FACETS_H */ + +// Local Variables: +// mode:C++ +// End: +