From 4bf58fce294df3fb8f41446cb24c96817bdf005a Mon Sep 17 00:00:00 2001 From: paolo Date: Tue, 17 Jun 2008 13:47:54 +0000 Subject: 2008-06-17 Paolo Carlini * src/string_conversions.cc (__to_xstring<>): New. (to_string, to_wstring): Use it. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@136865 138bc75d-0d04-0410-961f-82ee72b054a4 --- libstdc++-v3/src/string_conversions.cc | 62 ++++++++++++++++++---------------- 1 file changed, 33 insertions(+), 29 deletions(-) (limited to 'libstdc++-v3/src') diff --git a/libstdc++-v3/src/string_conversions.cc b/libstdc++-v3/src/string_conversions.cc index 627ddfad413..ef402ea0c39 100644 --- a/libstdc++-v3/src/string_conversions.cc +++ b/libstdc++-v3/src/string_conversions.cc @@ -31,6 +31,7 @@ #include #include #include +#include #ifdef _GLIBCXX_USE_C99 @@ -66,6 +67,27 @@ _GLIBCXX_BEGIN_NAMESPACE(std) return __ret; } + // Helper for the to_string / to_wstring functions. + template + inline basic_string<_CharT> + __to_xstring(int (*__convf) (_CharT*, size_t, const _CharT*, va_list), + size_t __n, const _CharT* __fmt, ...) + { + // XXX Eventually the result will be constructed in place in + // the C++0x string, likely with the help of internal hooks. + _CharT* __s = static_cast<_CharT*>(__builtin_alloca(sizeof(_CharT) + * __n)); + + va_list __args; + va_start(__args, __fmt); + + const int __len = __convf(__s, __n, __fmt, __args); + + va_end(__args); + + return basic_string<_CharT>(__s, __s + __len); + } + int stoi(const string& __str, size_t* __idx, int __base) @@ -101,30 +123,22 @@ _GLIBCXX_BEGIN_NAMESPACE(std) stold(const string& __str, size_t* __idx) { return std::__stoa(&std::strtold, "stold", __str, __idx); } + // NB: (v)snprintf vs sprintf. string to_string(long long __val) - { - // XXX Eventually the result will be constructed in place in - // the C++0x string, likely with the help of internal hooks. - const int __n = 4 * sizeof(long long); - char* __s = static_cast(__builtin_alloca(__n)); - return string(__s, __s + std::snprintf(__s, __n, "%lld", __val)); - } + { return std::__to_xstring(&std::vsnprintf, 4 * sizeof(long long), + "%lld", __val); } string to_string(unsigned long long __val) - { - const int __n = 4 * sizeof(unsigned long long); - char* __s = static_cast(__builtin_alloca(__n)); - return string(__s, __s + std::snprintf(__s, __n, "%llu", __val)); - } + { return std::__to_xstring(&std::vsnprintf, 4 * sizeof(unsigned long long), + "%llu", __val); } string to_string(long double __val) { const int __n = numeric_limits::max_exponent10 + 20; - char* __s = static_cast(__builtin_alloca(__n)); - return string(__s, __s + std::snprintf(__s, __n, "%Lf", __val)); + return std::__to_xstring(&std::vsnprintf, __n, "%Lf", __val); } #ifdef _GLIBCXX_USE_WCHAR_T @@ -164,29 +178,19 @@ _GLIBCXX_BEGIN_NAMESPACE(std) wstring to_wstring(long long __val) - { - const int __n = 4 * sizeof(long long); - wchar_t* __s = static_cast(__builtin_alloca(sizeof(wchar_t) - * __n)); - return wstring(__s, __s + std::swprintf(__s, __n, L"%lld", __val)); - } + { return std::__to_xstring(&std::vswprintf, 4 * sizeof(long long), + L"%lld", __val); } wstring to_wstring(unsigned long long __val) - { - const int __n = 4 * sizeof(unsigned long long); - wchar_t* __s = static_cast(__builtin_alloca(sizeof(wchar_t) - * __n)); - return wstring(__s, __s + std::swprintf(__s, __n, L"%llu", __val)); - } + { return std::__to_xstring(&std::vswprintf, 4 * sizeof(unsigned long long), + L"%llu", __val); } wstring to_wstring(long double __val) { const int __n = numeric_limits::max_exponent10 + 20; - wchar_t* __s = static_cast(__builtin_alloca(sizeof(wchar_t) - * __n)); - return wstring(__s, __s + std::swprintf(__s, __n, L"%Lf", __val)); + return std::__to_xstring(&std::vswprintf, __n, L"%Lf", __val); } #endif -- cgit v1.2.1