aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorFrançois Dumont <fdumont@gcc.gnu.org>2018-10-18 05:36:02 +0000
committerFrançois Dumont <fdumont@gcc.gnu.org>2018-10-18 05:36:02 +0000
commit7702ab653a903d5131bf72244ae22424ffd2e6c7 (patch)
treea8dba8d07c66827a75c8a94144d149404e751bf1
parent7bed4de21bc9b45df88c0972cf58a52ab83cf1b6 (diff)
downloadgcc-7702ab653a903d5131bf72244ae22424ffd2e6c7.zip
gcc-7702ab653a903d5131bf72244ae22424ffd2e6c7.tar.gz
gcc-7702ab653a903d5131bf72244ae22424ffd2e6c7.tar.bz2
revert: [multiple changes]
2018-10-18 François Dumont <fdumont@gcc.gnu.org> Partial revert. 2018-10-08 François Dumont <fdumont@gcc.gnu.org> * include/debug/list (list<>::cbegin()): Use C++11 direct initialization. (list<>::cend()): Likewise. (list<>::erase(const_iterator, const_iterator)): Ensure consistent iterator comparisons. (list<>::splice(const_iterator, list&&, const_iterator, const_iterator)): Likewise. Partial revert. 2018-10-15 François Dumont <fdumont@gcc.gnu.org> * include/debug/vector (vector<>::cbegin()): Use C++11 direct initialization. (vector<>::cend()): Likewise. (vector<>::insert(const_iterator, const _Tp&)): Use consistent iterator comparison. (vector<>::erase(const_iterator)): Likewise. (vector<>::erase(const_iterator, const_iterator)): Likewise. From-SVN: r265259
-rw-r--r--libstdc++-v3/ChangeLog24
-rw-r--r--libstdc++-v3/include/debug/list26
-rw-r--r--libstdc++-v3/include/debug/vector13
3 files changed, 41 insertions, 22 deletions
diff --git a/libstdc++-v3/ChangeLog b/libstdc++-v3/ChangeLog
index 9dc705c..426c7d8 100644
--- a/libstdc++-v3/ChangeLog
+++ b/libstdc++-v3/ChangeLog
@@ -1,3 +1,27 @@
+2018-10-18 François Dumont <fdumont@gcc.gnu.org>
+
+ Partial revert.
+ 2018-10-08 François Dumont <fdumont@gcc.gnu.org>
+
+ * include/debug/list (list<>::cbegin()): Use C++11 direct
+ initialization.
+ (list<>::cend()): Likewise.
+ (list<>::erase(const_iterator, const_iterator)): Ensure consistent
+ iterator comparisons.
+ (list<>::splice(const_iterator, list&&, const_iterator,
+ const_iterator)): Likewise.
+
+ Partial revert.
+ 2018-10-15 François Dumont <fdumont@gcc.gnu.org>
+
+ * include/debug/vector (vector<>::cbegin()): Use C++11 direct
+ initialization.
+ (vector<>::cend()): Likewise.
+ (vector<>::insert(const_iterator, const _Tp&)): Use consistent
+ iterator comparison.
+ (vector<>::erase(const_iterator)): Likewise.
+ (vector<>::erase(const_iterator, const_iterator)): Likewise.
+
2018-10-17 Ville Voutilainen <ville.voutilainen@gmail.com>
PR libstdc++/87619
diff --git a/libstdc++-v3/include/debug/list b/libstdc++-v3/include/debug/list
index 879e117..aab146d 100644
--- a/libstdc++-v3/include/debug/list
+++ b/libstdc++-v3/include/debug/list
@@ -244,11 +244,11 @@ namespace __debug
#if __cplusplus >= 201103L
const_iterator
cbegin() const noexcept
- { return { _Base::begin(), this }; }
+ { return const_iterator(_Base::begin(), this); }
const_iterator
cend() const noexcept
- { return { _Base::end(), this }; }
+ { return const_iterator(_Base::end(), this); }
const_reverse_iterator
crbegin() const noexcept
@@ -521,14 +521,13 @@ namespace __debug
// _GLIBCXX_RESOLVE_LIB_DEFECTS
// 151. can't currently clear() empty container
__glibcxx_check_erase_range(__first, __last);
- for (__decltype(__first.base()) __victim = __first.base();
+ for (_Base_const_iterator __victim = __first.base();
__victim != __last.base(); ++__victim)
{
- _GLIBCXX_DEBUG_VERIFY(
- __victim != __first._M_get_sequence()->_M_base().end(),
- _M_message(__gnu_debug::__msg_valid_range)
- ._M_iterator(__first, "position")
- ._M_iterator(__last, "last"));
+ _GLIBCXX_DEBUG_VERIFY(__victim != _Base::end(),
+ _M_message(__gnu_debug::__msg_valid_range)
+ ._M_iterator(__first, "position")
+ ._M_iterator(__last, "last"));
this->_M_invalidate_if(_Equal(__victim));
}
@@ -622,14 +621,13 @@ namespace __debug
// We used to perform the splice_alloc check: not anymore, redundant
// after implementing the relevant bits of N1599.
- for (__decltype(__first.base()) __tmp = __first.base();
+ for (_Base_const_iterator __tmp = __first.base();
__tmp != __last.base(); ++__tmp)
{
- _GLIBCXX_DEBUG_VERIFY(
- __tmp != __first._M_get_sequence()->_M_base().end(),
- _M_message(__gnu_debug::__msg_valid_range)
- ._M_iterator(__first, "first")
- ._M_iterator(__last, "last"));
+ _GLIBCXX_DEBUG_VERIFY(__tmp != _Base::end(),
+ _M_message(__gnu_debug::__msg_valid_range)
+ ._M_iterator(__first, "first")
+ ._M_iterator(__last, "last"));
_GLIBCXX_DEBUG_VERIFY(std::__addressof(__x) != this
|| __tmp != __position.base(),
_M_message(__gnu_debug::__msg_splice_overlap)
diff --git a/libstdc++-v3/include/debug/vector b/libstdc++-v3/include/debug/vector
index c11ddbb..0b712ba 100644
--- a/libstdc++-v3/include/debug/vector
+++ b/libstdc++-v3/include/debug/vector
@@ -328,11 +328,11 @@ namespace __debug
#if __cplusplus >= 201103L
const_iterator
cbegin() const noexcept
- { return { _Base::begin(), this }; }
+ { return const_iterator(_Base::begin(), this); }
const_iterator
cend() const noexcept
- { return { _Base::end(), this }; }
+ { return const_iterator(_Base::end(), this); }
const_reverse_iterator
crbegin() const noexcept
@@ -542,8 +542,7 @@ namespace __debug
{
__glibcxx_check_insert(__position);
bool __realloc = this->_M_requires_reallocation(this->size() + 1);
- difference_type __offset
- = __position.base() - __position._M_get_sequence()->_M_base().begin();
+ difference_type __offset = __position.base() - _Base::begin();
_Base_iterator __res = _Base::insert(__position.base(), __x);
if (__realloc)
this->_M_invalidate_all();
@@ -662,8 +661,7 @@ namespace __debug
#endif
{
__glibcxx_check_erase(__position);
- difference_type __offset
- = __position.base() - __position._M_get_sequence()->_M_base().begin();
+ difference_type __offset = __position.base() - _Base::begin();
_Base_iterator __res = _Base::erase(__position.base());
this->_M_invalidate_after_nth(__offset);
return iterator(__res, this);
@@ -682,8 +680,7 @@ namespace __debug
if (__first.base() != __last.base())
{
- difference_type __offset =
- __first.base() - __first._M_get_sequence()->_M_base().begin();
+ difference_type __offset = __first.base() - _Base::begin();
_Base_iterator __res = _Base::erase(__first.base(),
__last.base());
this->_M_invalidate_after_nth(__offset);