Index: include/bits/cpp_type_traits.h =================================================================== --- include/bits/cpp_type_traits.h (revision 222751) +++ include/bits/cpp_type_traits.h (working copy) @@ -399,18 +399,6 @@ typedef __false_type __type; }; -#if __cplusplus >= 201103L - template - class move_iterator; - - template - struct __is_move_iterator< move_iterator<_Iterator> > - { - enum { __value = 1 }; - typedef __true_type __type; - }; -#endif - _GLIBCXX_END_NAMESPACE_VERSION } // namespace Index: include/bits/stl_algobase.h =================================================================== --- include/bits/stl_algobase.h (revision 222751) +++ include/bits/stl_algobase.h (working copy) @@ -277,17 +277,11 @@ __niter_base(_Iterator __it) { return __it; } - // If _Iterator is a move_iterator return its base otherwise return it - // untouched. See copy, fill, ... + // Likewise for move_iterator. template - struct _Miter_base - : _Iter_base<_Iterator, __is_move_iterator<_Iterator>::__value> - { }; - - template - inline typename _Miter_base<_Iterator>::iterator_type + inline _Iterator __miter_base(_Iterator __it) - { return std::_Miter_base<_Iterator>::_S_base(__it); } + { return __it; } // All of these auxiliary structs serve two purposes. (1) Replace // calls to copy with memmove whenever possible. (Memmove, not memcpy, Index: include/bits/stl_iterator.h =================================================================== --- include/bits/stl_iterator.h (revision 222751) +++ include/bits/stl_iterator.h (working copy) @@ -414,6 +414,17 @@ __niter_base(reverse_iterator<_Iterator> __it) -> decltype(__make_reverse_iterator(__niter_base(__it.base()))) { return __make_reverse_iterator(__niter_base(__it.base())); } + + template + struct __is_move_iterator > + : __is_move_iterator<_Iterator> + { }; + + template + auto + __miter_base(reverse_iterator<_Iterator> __it) + -> decltype(__make_reverse_iterator(__miter_base(__it.base()))) + { return __make_reverse_iterator(__miter_base(__it.base())); } #endif // 24.4.2.2.1 back_insert_iterator @@ -1202,6 +1213,19 @@ -> decltype(make_move_iterator(__niter_base(__it.base()))) { return make_move_iterator(__niter_base(__it.base())); } + template + struct __is_move_iterator > + { + enum { __value = 1 }; + typedef __true_type __type; + }; + + template + auto + __miter_base(move_iterator<_Iterator> __it) + -> decltype(__miter_base(__it.base())) + { return __miter_base(__it.base()); } + _GLIBCXX_END_NAMESPACE_VERSION } // namespace