diff options
Diffstat (limited to '8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits')
17 files changed, 82 insertions, 85 deletions
| diff --git a/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/forward_list.h b/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/forward_list.h index d49eb4a..8ec2a5d 100644 --- a/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/forward_list.h +++ b/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/forward_list.h @@ -983,7 +983,7 @@ _GLIBCXX_BEGIN_NAMESPACE(std)         *  function.         */        void -      swap(forward_list&& __list) +      swap(forward_list& __list)        { _Node_base::swap(this->_M_impl._M_head, __list._M_impl._M_head); }        /** diff --git a/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/move.h b/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/move.h index ef86c4d..b82b263 100644 --- a/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/move.h +++ b/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/move.h @@ -48,13 +48,35 @@ _GLIBCXX_BEGIN_NAMESPACE(std)    template<typename _Tp>      inline _Tp&& -    forward(typename std::identity<_Tp>::type&& __t) +    forward(typename std::remove_reference<_Tp>::type& __t) +#ifdef __clang__ +    { return static_cast<_Tp&&>(__t); } +#else      { return __t; } +#endif + +  template<typename _Tp> +    inline _Tp&& +    forward(typename std::remove_reference<_Tp>::type&& __t) +    { +#ifdef __clang__ +      static_assert(!std::is_lvalue_reference<_Tp>::value, +                    "Can't instantiate this forward() with an" +                    " lvalue reference type."); +      return static_cast<_Tp&&>(__t); +#else +      return __t; +#endif +    }    template<typename _Tp>      inline typename std::remove_reference<_Tp>::type&&      move(_Tp&& __t) +#ifdef __clang__ +    { return static_cast<typename std::remove_reference<_Tp>::type&&>(__t); } +#else      { return __t; } +#endif  _GLIBCXX_END_NAMESPACE diff --git a/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/shared_ptr.h b/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/shared_ptr.h index a378ae0..e8cd8ea 100644 --- a/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/shared_ptr.h +++ b/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/shared_ptr.h @@ -833,7 +833,7 @@ _GLIBCXX_BEGIN_NAMESPACE(std)        { return _M_refcount._M_get_use_count(); }        void -      swap(__shared_ptr<_Tp, _Lp>&& __other) // never throws +      swap(__shared_ptr<_Tp, _Lp>& __other) // never throws        {  	std::swap(_M_ptr, __other._M_ptr);  	_M_refcount._M_swap(__other._M_refcount); @@ -943,16 +943,6 @@ _GLIBCXX_BEGIN_NAMESPACE(std)      swap(__shared_ptr<_Tp, _Lp>& __a, __shared_ptr<_Tp, _Lp>& __b)      { __a.swap(__b); } -  template<typename _Tp, _Lock_policy _Lp> -    inline void -    swap(__shared_ptr<_Tp, _Lp>&& __a, __shared_ptr<_Tp, _Lp>& __b) -    { __a.swap(__b); } - -  template<typename _Tp, _Lock_policy _Lp> -    inline void -    swap(__shared_ptr<_Tp, _Lp>& __a, __shared_ptr<_Tp, _Lp>&& __b) -    { __a.swap(__b); } -    // 2.2.3.9 shared_ptr casts    /** @warning The seemingly equivalent     *           <code>shared_ptr<_Tp, _Lp>(static_cast<_Tp*>(__r.get()))</code> @@ -1372,16 +1362,6 @@ _GLIBCXX_BEGIN_NAMESPACE(std)      swap(shared_ptr<_Tp>& __a, shared_ptr<_Tp>& __b)      { __a.swap(__b); } -  template<typename _Tp> -    inline void -    swap(shared_ptr<_Tp>&& __a, shared_ptr<_Tp>& __b) -    { __a.swap(__b); } - -  template<typename _Tp> -    inline void -    swap(shared_ptr<_Tp>& __a, shared_ptr<_Tp>&& __b) -    { __a.swap(__b); } -    // 20.8.13.2.10 shared_ptr casts.    template<typename _Tp, typename _Tp1>      inline shared_ptr<_Tp> diff --git a/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_bvector.h b/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_bvector.h index 0e60b7f..87dbb0b 100644 --- a/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_bvector.h +++ b/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_bvector.h @@ -743,11 +743,7 @@ template<typename _Alloc>      }      void -#ifdef __GXX_EXPERIMENTAL_CXX0X__ -    swap(vector&& __x) -#else      swap(vector& __x) -#endif      {        std::swap(this->_M_impl._M_start, __x._M_impl._M_start);        std::swap(this->_M_impl._M_finish, __x._M_impl._M_finish); diff --git a/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_deque.h b/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_deque.h index 1c20e27..932ad7d 100644 --- a/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_deque.h +++ b/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_deque.h @@ -1395,11 +1395,7 @@ _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_D)         *  std::swap(d1,d2) will feed to this function.         */        void -#ifdef __GXX_EXPERIMENTAL_CXX0X__ -      swap(deque&& __x) -#else        swap(deque& __x) -#endif        {  	std::swap(this->_M_impl._M_start, __x._M_impl._M_start);  	std::swap(this->_M_impl._M_finish, __x._M_impl._M_finish); diff --git a/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_iterator.h b/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_iterator.h index 129552f..645fd0f 100644 --- a/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_iterator.h +++ b/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_iterator.h @@ -913,7 +913,7 @@ _GLIBCXX_BEGIN_NAMESPACE(std)        reference        operator*() const -      { return *_M_current; } +      { return std::move(*_M_current); }        pointer        operator->() const diff --git a/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_list.h b/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_list.h index 66a50b8..8206c84 100644 --- a/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_list.h +++ b/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_list.h @@ -1106,11 +1106,7 @@ _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_D)         *  function.         */        void -#ifdef __GXX_EXPERIMENTAL_CXX0X__ -      swap(list&& __x) -#else        swap(list& __x) -#endif        {  	_List_node_base::swap(this->_M_impl._M_node, __x._M_impl._M_node); @@ -1160,6 +1156,12 @@ _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_D)  	  }        } +#ifdef __GXX_EXPERIMENTAL_CXX0X__ +      void +      splice(iterator __position, list& __x) +      { splice(__position, std::move(__x)); } +#endif +        /**         *  @brief  Insert element from another %list.         *  @param  position  Iterator referencing the element to insert before. @@ -1187,6 +1189,12 @@ _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_D)  	this->_M_transfer(__position, __i, __j);        } +#ifdef __GXX_EXPERIMENTAL_CXX0X__ +      void +      splice(iterator __position, list& __x, iterator __i) +      { splice(__position, std::move(__x), __i); } +#endif +        /**         *  @brief  Insert range from another %list.         *  @param  position  Iterator referencing the element to insert before. @@ -1217,6 +1225,13 @@ _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_D)  	  }        } +#ifdef __GXX_EXPERIMENTAL_CXX0X__ +      void +      splice(iterator __position, list& __x, iterator __first, +	     iterator __last) +      { splice(__position, std::move(__x), __first, __last); } +#endif +        /**         *  @brief  Remove all elements equal to value.         *  @param  value  The value to remove. @@ -1287,6 +1302,10 @@ _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_D)        void  #ifdef __GXX_EXPERIMENTAL_CXX0X__        merge(list&& __x); + +      void +      merge(list& __x) +      { merge(std::move(__x)); }  #else        merge(list& __x);  #endif @@ -1307,6 +1326,11 @@ _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_D)          void  #ifdef __GXX_EXPERIMENTAL_CXX0X__          merge(list&&, _StrictWeakOrdering); + +      template<typename _StrictWeakOrdering> +        void +        merge(list& __l, _StrictWeakOrdering __comp) +        { merge(std::move(__l), __comp); }  #else          merge(list&, _StrictWeakOrdering);  #endif diff --git a/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_map.h b/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_map.h index 90e5239..c9f3e71 100644 --- a/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_map.h +++ b/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_map.h @@ -608,11 +608,7 @@ _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_D)         *  that std::swap(m1,m2) will feed to this function.         */        void -#ifdef __GXX_EXPERIMENTAL_CXX0X__ -      swap(map&& __x) -#else        swap(map& __x) -#endif        { _M_t.swap(__x._M_t); }        /** diff --git a/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_multimap.h b/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_multimap.h index 484537c..f2be477 100644 --- a/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_multimap.h +++ b/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_multimap.h @@ -544,11 +544,7 @@ _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_D)         *  std::swap(m1,m2) will feed to this function.         */        void -#ifdef __GXX_EXPERIMENTAL_CXX0X__ -      swap(multimap&& __x) -#else        swap(multimap& __x) -#endif        { _M_t.swap(__x._M_t); }        /** diff --git a/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_multiset.h b/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_multiset.h index b5c710f..9f89573 100644 --- a/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_multiset.h +++ b/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_multiset.h @@ -376,11 +376,7 @@ _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_D)         *  std::swap(s1,s2) will feed to this function.         */        void -#ifdef __GXX_EXPERIMENTAL_CXX0X__ -      swap(multiset&& __x) -#else        swap(multiset& __x) -#endif        { _M_t.swap(__x._M_t); }        // insert/erase diff --git a/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_pair.h b/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_pair.h index fd395ad..f56fec1 100644 --- a/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_pair.h +++ b/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_pair.h @@ -84,10 +84,21 @@ _GLIBCXX_BEGIN_NAMESPACE(std)        : first(__a), second(__b) { }  #ifdef __GXX_EXPERIMENTAL_CXX0X__ -      template<class _U1, class _U2> +      template<class _U1, class = typename +	       std::enable_if<std::is_convertible<_U1, _T1>::value>::type> +	pair(_U1&& __x, const _T2& __y) +	: first(std::forward<_U1>(__x)), second(__y) { } + +      template<class _U2, class = typename +	       std::enable_if<std::is_convertible<_U2, _T2>::value>::type> +	pair(const _T1& __x, _U2&& __y) +	: first(__x), second(std::forward<_U2>(__y)) { } + +      template<class _U1, class _U2, class = typename +	       std::enable_if<std::is_convertible<_U1, _T1>::value +			      && std::is_convertible<_U2, _T2>::value>::type>          pair(_U1&& __x, _U2&& __y) -	: first(std::forward<_U1>(__x)), -	  second(std::forward<_U2>(__y)) { } +	: first(std::forward<_U1>(__x)), second(std::forward<_U2>(__y)) { }        pair(pair&& __p)        : first(std::move(__p.first)), @@ -107,11 +118,19 @@ _GLIBCXX_BEGIN_NAMESPACE(std)  	  second(std::move(__p.second)) { }        // http://gcc.gnu.org/ml/libstdc++/2007-08/msg00052.html + +#if 0 +      // This constructor is incompatible with libstdc++-4.6, and it +      // interferes with passing NULL pointers to the 2-argument +      // constructors, so we disable it.  map::emplace isn't +      // implemented in libstdc++-4.4 anyway, and that's what this +      // constructor was here for.        template<class _U1, class _Arg0, class... _Args>          pair(_U1&& __x, _Arg0&& __arg0, _Args&&... __args)  	: first(std::forward<_U1>(__x)),  	  second(std::forward<_Arg0>(__arg0),  		 std::forward<_Args>(__args)...) { } +#endif        pair&        operator=(pair&& __p) @@ -131,7 +150,7 @@ _GLIBCXX_BEGIN_NAMESPACE(std)  	}        void -      swap(pair&& __p) +      swap(pair& __p)        {  	using std::swap;  	swap(first, __p.first); diff --git a/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_queue.h b/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_queue.h index 7479469..0ebe257 100644 --- a/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_queue.h +++ b/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_queue.h @@ -249,7 +249,7 @@ _GLIBCXX_BEGIN_NAMESPACE(std)  #ifdef __GXX_EXPERIMENTAL_CXX0X__        void -      swap(queue&& __q) +      swap(queue& __q)        { c.swap(__q.c); }  #endif      }; @@ -550,7 +550,7 @@ _GLIBCXX_BEGIN_NAMESPACE(std)  #ifdef __GXX_EXPERIMENTAL_CXX0X__        void -      swap(priority_queue&& __pq) +      swap(priority_queue& __pq)        {  	using std::swap;  	c.swap(__pq.c); diff --git a/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_set.h b/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_set.h index f06fe03..d746407 100644 --- a/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_set.h +++ b/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_set.h @@ -383,11 +383,7 @@ _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_D)         *  std::swap(s1,s2) will feed to this function.         */        void -#ifdef __GXX_EXPERIMENTAL_CXX0X__ -      swap(set&& __x) -#else        swap(set& __x)	 -#endif        { _M_t.swap(__x._M_t); }        // insert/erase diff --git a/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_stack.h b/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_stack.h index da301d4..87aa718 100644 --- a/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_stack.h +++ b/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_stack.h @@ -213,7 +213,7 @@ _GLIBCXX_BEGIN_NAMESPACE(std)  #ifdef __GXX_EXPERIMENTAL_CXX0X__        void -      swap(stack&& __s) +      swap(stack& __s)        { c.swap(__s.c); }  #endif      }; diff --git a/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_tree.h b/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_tree.h index e2cc151..7f38c55 100644 --- a/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_tree.h +++ b/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_tree.h @@ -715,11 +715,7 @@ _GLIBCXX_BEGIN_NAMESPACE(std)        { return _M_get_Node_allocator().max_size(); }        void -#ifdef __GXX_EXPERIMENTAL_CXX0X__ -      swap(_Rb_tree&& __t); -#else        swap(_Rb_tree& __t);       -#endif        // Insert/erase.        pair<iterator, bool> @@ -1144,11 +1140,7 @@ _GLIBCXX_BEGIN_NAMESPACE(std)             typename _Compare, typename _Alloc>      void      _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>:: -#ifdef __GXX_EXPERIMENTAL_CXX0X__ -    swap(_Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>&& __t) -#else      swap(_Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>& __t) -#endif      {        if (_M_root() == 0)  	{ diff --git a/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_vector.h b/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_vector.h index 6871bb0..363c630 100644 --- a/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_vector.h +++ b/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/stl_vector.h @@ -939,11 +939,7 @@ _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_D)         *  std::swap(v1,v2) will feed to this function.         */        void -#ifdef __GXX_EXPERIMENTAL_CXX0X__ -      swap(vector&& __x) -#else        swap(vector& __x) -#endif        {  	std::swap(this->_M_impl._M_start, __x._M_impl._M_start);  	std::swap(this->_M_impl._M_finish, __x._M_impl._M_finish); diff --git a/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/unique_ptr.h b/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/unique_ptr.h index b686d11..c1185f2 100644 --- a/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/unique_ptr.h +++ b/8/sources/cxx-stl/gnu-libstdc++/4.4.3/include/bits/unique_ptr.h @@ -204,7 +204,7 @@ _GLIBCXX_BEGIN_NAMESPACE(std)        }        void -      swap(unique_ptr&& __u) +      swap(unique_ptr& __u)        {  	using std::swap;  	swap(_M_t, __u._M_t); @@ -350,7 +350,7 @@ _GLIBCXX_BEGIN_NAMESPACE(std)          void reset(_Up) = delete;        void -      swap(unique_ptr&& __u) +      swap(unique_ptr& __u)        {  	using std::swap;  	swap(_M_t, __u._M_t); @@ -389,18 +389,6 @@ _GLIBCXX_BEGIN_NAMESPACE(std)  	 unique_ptr<_Tp, _Tp_Deleter>& __y)      { __x.swap(__y); } -  template<typename _Tp, typename _Tp_Deleter>  -    inline void -    swap(unique_ptr<_Tp, _Tp_Deleter>&& __x, -	 unique_ptr<_Tp, _Tp_Deleter>& __y) -    { __x.swap(__y); } - -  template<typename _Tp, typename _Tp_Deleter>  -    inline void -    swap(unique_ptr<_Tp, _Tp_Deleter>& __x, -	 unique_ptr<_Tp, _Tp_Deleter>&& __y) -    { __x.swap(__y); } -      template<typename _Tp, typename _Tp_Deleter,  	   typename _Up, typename _Up_Deleter>      inline bool | 
