aboutsummaryrefslogtreecommitdiff
path: root/libstdc++-v3
diff options
context:
space:
mode:
authorFrançois Dumont <fdumont@gcc.gnu.org>2015-05-20 19:02:22 +0000
committerFrançois Dumont <fdumont@gcc.gnu.org>2015-05-20 19:02:22 +0000
commitfd2ef1171407340dbb09935ab535debf40f56376 (patch)
tree8344fafd34f2f367574607fe9040390e943c2549 /libstdc++-v3
parent91767ed11af18ab39fc7a85850ff4908036e416b (diff)
downloadgcc-fd2ef1171407340dbb09935ab535debf40f56376.zip
gcc-fd2ef1171407340dbb09935ab535debf40f56376.tar.gz
gcc-fd2ef1171407340dbb09935ab535debf40f56376.tar.bz2
2015-05-20 François Dumont <fdumont@gcc.gnu.org>
* include/bits/cpp_type_traits.h (std::move_iterator): Delete declaration. (std::__is_move_iterator<move_iterator>): Move partial specialization... * include/bits/stl_iterator.h: ... here. (std::__miter_base): Overloads for std::reverse_iterator and std::move_iterator. * include/bits/stl_algobase.h (std::__miter_base): Provide default implementation. From-SVN: r223453
Diffstat (limited to 'libstdc++-v3')
-rw-r--r--libstdc++-v3/ChangeLog11
-rw-r--r--libstdc++-v3/include/bits/cpp_type_traits.h12
-rw-r--r--libstdc++-v3/include/bits/stl_algobase.h12
-rw-r--r--libstdc++-v3/include/bits/stl_iterator.h24
4 files changed, 38 insertions, 21 deletions
diff --git a/libstdc++-v3/ChangeLog b/libstdc++-v3/ChangeLog
index ce5573c..773c1dd 100644
--- a/libstdc++-v3/ChangeLog
+++ b/libstdc++-v3/ChangeLog
@@ -1,3 +1,14 @@
+2015-05-20 François Dumont <fdumont@gcc.gnu.org>
+
+ * include/bits/cpp_type_traits.h
+ (std::move_iterator): Delete declaration.
+ (std::__is_move_iterator<move_iterator>): Move partial specialization...
+ * include/bits/stl_iterator.h: ... here.
+ (std::__miter_base): Overloads for std::reverse_iterator and
+ std::move_iterator.
+ * include/bits/stl_algobase.h (std::__miter_base): Provide default
+ implementation.
+
2015-05-20 Jonathan Wakely <jwakely@redhat.com>
* testsuite/util/testsuite_fs.h (nonexistent_path): Don't use tempnam.
diff --git a/libstdc++-v3/include/bits/cpp_type_traits.h b/libstdc++-v3/include/bits/cpp_type_traits.h
index 2142917..f7b76bf 100644
--- a/libstdc++-v3/include/bits/cpp_type_traits.h
+++ b/libstdc++-v3/include/bits/cpp_type_traits.h
@@ -399,18 +399,6 @@ __INT_N(__GLIBCXX_TYPE_INT_N_3)
typedef __false_type __type;
};
-#if __cplusplus >= 201103L
- template<typename _Iterator>
- class move_iterator;
-
- template<typename _Iterator>
- struct __is_move_iterator< move_iterator<_Iterator> >
- {
- enum { __value = 1 };
- typedef __true_type __type;
- };
-#endif
-
_GLIBCXX_END_NAMESPACE_VERSION
} // namespace
diff --git a/libstdc++-v3/include/bits/stl_algobase.h b/libstdc++-v3/include/bits/stl_algobase.h
index 630b3a0..409ef36 100644
--- a/libstdc++-v3/include/bits/stl_algobase.h
+++ b/libstdc++-v3/include/bits/stl_algobase.h
@@ -277,17 +277,11 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
__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<typename _Iterator>
- struct _Miter_base
- : _Iter_base<_Iterator, __is_move_iterator<_Iterator>::__value>
- { };
-
- template<typename _Iterator>
- 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,
diff --git a/libstdc++-v3/include/bits/stl_iterator.h b/libstdc++-v3/include/bits/stl_iterator.h
index b8e79df..58b9aab 100644
--- a/libstdc++-v3/include/bits/stl_iterator.h
+++ b/libstdc++-v3/include/bits/stl_iterator.h
@@ -414,6 +414,17 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
__niter_base(reverse_iterator<_Iterator> __it)
-> decltype(__make_reverse_iterator(__niter_base(__it.base())))
{ return __make_reverse_iterator(__niter_base(__it.base())); }
+
+ template<typename _Iterator>
+ struct __is_move_iterator<reverse_iterator<_Iterator> >
+ : __is_move_iterator<_Iterator>
+ { };
+
+ template<typename _Iterator>
+ 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
@@ -1211,6 +1222,19 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
-> decltype(make_move_iterator(__niter_base(__it.base())))
{ return make_move_iterator(__niter_base(__it.base())); }
+ template<typename _Iterator>
+ struct __is_move_iterator<move_iterator<_Iterator> >
+ {
+ enum { __value = 1 };
+ typedef __true_type __type;
+ };
+
+ template<typename _Iterator>
+ auto
+ __miter_base(move_iterator<_Iterator> __it)
+ -> decltype(__miter_base(__it.base()))
+ { return __miter_base(__it.base()); }
+
_GLIBCXX_END_NAMESPACE_VERSION
} // namespace