summaryrefslogtreecommitdiff
path: root/libstdc++-v3/src
diff options
context:
space:
mode:
authorpaolo <paolo@138bc75d-0d04-0410-961f-82ee72b054a4>2008-06-17 13:47:54 +0000
committerpaolo <paolo@138bc75d-0d04-0410-961f-82ee72b054a4>2008-06-17 13:47:54 +0000
commit4bf58fce294df3fb8f41446cb24c96817bdf005a (patch)
tree9afdf5748e2eade826552c5b398c31e494640bc6 /libstdc++-v3/src
parent211b932dc238a53603997ef3016845530110bd97 (diff)
downloadgcc-4bf58fce294df3fb8f41446cb24c96817bdf005a.tar.gz
2008-06-17 Paolo Carlini <paolo.carlini@oracle.com>
* 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
Diffstat (limited to 'libstdc++-v3/src')
-rw-r--r--libstdc++-v3/src/string_conversions.cc62
1 files changed, 33 insertions, 29 deletions
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 <limits>
#include <cerrno>
#include <cstdlib>
+#include <cstdarg>
#ifdef _GLIBCXX_USE_C99
@@ -66,6 +67,27 @@ _GLIBCXX_BEGIN_NAMESPACE(std)
return __ret;
}
+ // Helper for the to_string / to_wstring functions.
+ template<typename _CharT>
+ 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<char*>(__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<char*>(__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<long double>::max_exponent10 + 20;
- char* __s = static_cast<char*>(__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<wchar_t*>(__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<wchar_t*>(__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<long double>::max_exponent10 + 20;
- wchar_t* __s = static_cast<wchar_t*>(__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