LWG 1278
git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@111532 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
4a23e1e060
commit
ba590bdc97
@ -942,7 +942,7 @@ typename forward_list<_Tp, _Alloc>::iterator
|
||||
forward_list<_Tp, _Alloc>::insert_after(const_iterator __p, size_type __n,
|
||||
const value_type& __v)
|
||||
{
|
||||
__node_pointer const __r = const_cast<__node_pointer>(__p.__ptr_);
|
||||
__node_pointer __r = const_cast<__node_pointer>(__p.__ptr_);
|
||||
if (__n > 0)
|
||||
{
|
||||
__node_allocator& __a = base::__alloc();
|
||||
@ -977,6 +977,7 @@ forward_list<_Tp, _Alloc>::insert_after(const_iterator __p, size_type __n,
|
||||
#endif
|
||||
__last->__next_ = __r->__next_;
|
||||
__r->__next_ = __first;
|
||||
__r = __last;
|
||||
}
|
||||
return iterator(__r);
|
||||
}
|
||||
@ -991,7 +992,7 @@ typename enable_if
|
||||
forward_list<_Tp, _Alloc>::insert_after(const_iterator __p,
|
||||
_InputIterator __f, _InputIterator __l)
|
||||
{
|
||||
__node_pointer const __r = const_cast<__node_pointer>(__p.__ptr_);
|
||||
__node_pointer __r = const_cast<__node_pointer>(__p.__ptr_);
|
||||
if (__f != __l)
|
||||
{
|
||||
__node_allocator& __a = base::__alloc();
|
||||
@ -1026,6 +1027,7 @@ forward_list<_Tp, _Alloc>::insert_after(const_iterator __p,
|
||||
#endif
|
||||
__last->__next_ = __r->__next_;
|
||||
__r->__next_ = __first;
|
||||
__r = __last;
|
||||
}
|
||||
return iterator(__r);
|
||||
}
|
||||
|
@ -27,14 +27,14 @@ int main()
|
||||
assert(distance(c.begin(), c.end()) == 0);
|
||||
|
||||
i = c.insert_after(c.cbefore_begin(), {0, 1, 2});
|
||||
assert(i == c.before_begin());
|
||||
assert(i == next(c.before_begin(), 3));
|
||||
assert(distance(c.begin(), c.end()) == 3);
|
||||
assert(*next(c.begin(), 0) == 0);
|
||||
assert(*next(c.begin(), 1) == 1);
|
||||
assert(*next(c.begin(), 2) == 2);
|
||||
|
||||
i = c.insert_after(c.begin(), {3, 4});
|
||||
assert(i == c.begin());
|
||||
assert(i == next(c.begin(), 2));
|
||||
assert(distance(c.begin(), c.end()) == 5);
|
||||
assert(*next(c.begin(), 0) == 0);
|
||||
assert(*next(c.begin(), 1) == 3);
|
||||
|
@ -32,14 +32,14 @@ int main()
|
||||
assert(distance(c.begin(), c.end()) == 0);
|
||||
|
||||
i = c.insert_after(c.cbefore_begin(), J(t), J(t+3));
|
||||
assert(i == c.before_begin());
|
||||
assert(i == next(c.before_begin(), 3));
|
||||
assert(distance(c.begin(), c.end()) == 3);
|
||||
assert(*next(c.begin(), 0) == 0);
|
||||
assert(*next(c.begin(), 1) == 1);
|
||||
assert(*next(c.begin(), 2) == 2);
|
||||
|
||||
i = c.insert_after(c.begin(), J(t+3), J(t+5));
|
||||
assert(i == c.begin());
|
||||
assert(i == next(c.begin(), 2));
|
||||
assert(distance(c.begin(), c.end()) == 5);
|
||||
assert(*next(c.begin(), 0) == 0);
|
||||
assert(*next(c.begin(), 1) == 3);
|
||||
|
@ -27,14 +27,14 @@ int main()
|
||||
assert(distance(c.begin(), c.end()) == 0);
|
||||
|
||||
i = c.insert_after(c.cbefore_begin(), 3, 3);
|
||||
assert(i == c.before_begin());
|
||||
assert(i == next(c.before_begin(), 3));
|
||||
assert(distance(c.begin(), c.end()) == 3);
|
||||
assert(*next(c.begin(), 0) == 3);
|
||||
assert(*next(c.begin(), 1) == 3);
|
||||
assert(*next(c.begin(), 2) == 3);
|
||||
|
||||
i = c.insert_after(c.begin(), 2, 2);
|
||||
assert(i == c.begin());
|
||||
assert(i == next(c.begin(), 2));
|
||||
assert(distance(c.begin(), c.end()) == 5);
|
||||
assert(*next(c.begin(), 0) == 3);
|
||||
assert(*next(c.begin(), 1) == 2);
|
||||
|
Loading…
x
Reference in New Issue
Block a user