diff options
author | Paolo Carlini <paolo.carlini@oracle.com> | 2011-05-16 18:24:01 +0000 |
---|---|---|
committer | Paolo Carlini <paolo@gcc.gnu.org> | 2011-05-16 18:24:01 +0000 |
commit | 7933dc2a80e000c33dfe3981a15e4f948650b2c7 (patch) | |
tree | 5ccff8e4a92f878fbb67cc900dc17d732aa28baa | |
parent | 18eeaec47bc14ce2a1ffc7011a4f7bdb33bc070c (diff) | |
download | gcc-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/ChangeLog | 5 | ||||
-rw-r--r-- | libstdc++-v3/include/std/utility | 30 |
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 |