aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPaolo Carlini <paolo.carlini@oracle.com>2011-05-16 18:24:01 +0000
committerPaolo Carlini <paolo@gcc.gnu.org>2011-05-16 18:24:01 +0000
commit7933dc2a80e000c33dfe3981a15e4f948650b2c7 (patch)
tree5ccff8e4a92f878fbb67cc900dc17d732aa28baa
parent18eeaec47bc14ce2a1ffc7011a4f7bdb33bc070c (diff)
downloadgcc-7933dc2a80e000c33dfe3981a15e4f948650b2c7.zip
gcc-7933dc2a80e000c33dfe3981a15e4f948650b2c7.tar.gz
gcc-7933dc2a80e000c33dfe3981a15e4f948650b2c7.tar.bz2
utility: Simplify the last commit, the whole std::get code is C++0x only.
2011-05-16 Paolo Carlini <paolo.carlini@oracle.com> * include/std/utility: Simplify the last commit, the whole std::get code is C++0x only. From-SVN: r173799
-rw-r--r--libstdc++-v3/ChangeLog5
-rw-r--r--libstdc++-v3/include/std/utility30
2 files changed, 17 insertions, 18 deletions
diff --git a/libstdc++-v3/ChangeLog b/libstdc++-v3/ChangeLog
index d4554d1..9b99d8b 100644
--- a/libstdc++-v3/ChangeLog
+++ b/libstdc++-v3/ChangeLog
@@ -1,5 +1,10 @@
2011-05-16 Paolo Carlini <paolo.carlini@oracle.com>
+ * include/std/utility: Simplify the last commit, the whole
+ std::get code is C++0x only.
+
+2011-05-16 Paolo Carlini <paolo.carlini@oracle.com>
+
* include/std/utility (get(std::pair<>&&)): Add.
* include/bits/stl_pair.h (pair::swap(pair&),
swap(pair<>&, pair<>&)): Use noexcept.
diff --git a/libstdc++-v3/include/std/utility b/libstdc++-v3/include/std/utility
index 6c1dd36..5c6bd03 100644
--- a/libstdc++-v3/include/std/utility
+++ b/libstdc++-v3/include/std/utility
@@ -87,7 +87,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
// Various functions which give std::pair a tuple-like interface.
template<class _Tp1, class _Tp2>
- struct tuple_size<std::pair<_Tp1, _Tp2> >
+ struct tuple_size<std::pair<_Tp1, _Tp2>>
{ static const std::size_t value = 2; };
template<class _Tp1, class _Tp2>
@@ -95,11 +95,11 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
tuple_size<std::pair<_Tp1, _Tp2> >::value;
template<class _Tp1, class _Tp2>
- struct tuple_element<0, std::pair<_Tp1, _Tp2> >
+ struct tuple_element<0, std::pair<_Tp1, _Tp2>>
{ typedef _Tp1 type; };
template<class _Tp1, class _Tp2>
- struct tuple_element<1, std::pair<_Tp1, _Tp2> >
+ struct tuple_element<1, std::pair<_Tp1, _Tp2>>
{ typedef _Tp2 type; };
template<std::size_t _Int>
@@ -110,19 +110,17 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
{
template<typename _Tp1, typename _Tp2>
static _Tp1&
- __get(std::pair<_Tp1, _Tp2>& __pair) _GLIBCXX_NOEXCEPT
+ __get(std::pair<_Tp1, _Tp2>& __pair) noexcept
{ return __pair.first; }
-#ifdef __GXX_EXPERIMENTAL_CXX0X__
template<typename _Tp1, typename _Tp2>
static _Tp1&&
__move_get(std::pair<_Tp1, _Tp2>&& __pair) noexcept
{ return std::forward<_Tp1>(__pair.first); }
-#endif
template<typename _Tp1, typename _Tp2>
static const _Tp1&
- __const_get(const std::pair<_Tp1, _Tp2>& __pair) _GLIBCXX_NOEXCEPT
+ __const_get(const std::pair<_Tp1, _Tp2>& __pair) noexcept
{ return __pair.first; }
};
@@ -131,37 +129,33 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
{
template<typename _Tp1, typename _Tp2>
static _Tp2&
- __get(std::pair<_Tp1, _Tp2>& __pair) _GLIBCXX_NOEXCEPT
+ __get(std::pair<_Tp1, _Tp2>& __pair) noexcept
{ return __pair.second; }
-#ifdef __GXX_EXPERIMENTAL_CXX0X__
template<typename _Tp1, typename _Tp2>
static _Tp2&&
__move_get(std::pair<_Tp1, _Tp2>&& __pair) noexcept
{ return std::forward<_Tp2>(__pair.second); }
-#endif
template<typename _Tp1, typename _Tp2>
static const _Tp2&
- __const_get(const std::pair<_Tp1, _Tp2>& __pair) _GLIBCXX_NOEXCEPT
+ __const_get(const std::pair<_Tp1, _Tp2>& __pair) noexcept
{ return __pair.second; }
};
template<std::size_t _Int, class _Tp1, class _Tp2>
- inline typename tuple_element<_Int, std::pair<_Tp1, _Tp2> >::type&
- get(std::pair<_Tp1, _Tp2>& __in) _GLIBCXX_NOEXCEPT
+ inline typename tuple_element<_Int, std::pair<_Tp1, _Tp2>>::type&
+ get(std::pair<_Tp1, _Tp2>& __in) noexcept
{ return __pair_get<_Int>::__get(__in); }
-#ifdef __GXX_EXPERIMENTAL_CXX0X__
template<std::size_t _Int, class _Tp1, class _Tp2>
- inline typename tuple_element<_Int, std::pair<_Tp1, _Tp2> >::type&&
+ inline typename tuple_element<_Int, std::pair<_Tp1, _Tp2>>::type&&
get(std::pair<_Tp1, _Tp2>&& __in) noexcept
{ return __pair_get<_Int>::__move_get(std::move(__in)); }
-#endif
template<std::size_t _Int, class _Tp1, class _Tp2>
- inline const typename tuple_element<_Int, std::pair<_Tp1, _Tp2> >::type&
- get(const std::pair<_Tp1, _Tp2>& __in) _GLIBCXX_NOEXCEPT
+ inline const typename tuple_element<_Int, std::pair<_Tp1, _Tp2>>::type&
+ get(const std::pair<_Tp1, _Tp2>& __in) noexcept
{ return __pair_get<_Int>::__const_get(__in); }
_GLIBCXX_END_NAMESPACE_VERSION