2010-05-11 19:42:16 +00:00
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
2010-05-11 21:36:01 +00:00
|
|
|
// The LLVM Compiler Infrastructure
|
2010-05-11 19:42:16 +00:00
|
|
|
//
|
2010-11-16 22:09:02 +00:00
|
|
|
// This file is dual licensed under the MIT and the University of Illinois Open
|
|
|
|
// Source Licenses. See LICENSE.TXT for details.
|
2010-05-11 19:42:16 +00:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
// <iterator>
|
|
|
|
|
2010-08-22 00:29:01 +00:00
|
|
|
// template <InputIterator Iter>
|
2010-05-11 19:42:16 +00:00
|
|
|
// void advance(Iter& i, Iter::difference_type n);
|
2010-08-22 00:29:01 +00:00
|
|
|
//
|
|
|
|
// template <BidirectionalIterator Iter>
|
|
|
|
// void advance(Iter& i, Iter::difference_type n);
|
|
|
|
//
|
|
|
|
// template <RandomAccessIterator Iter>
|
2010-05-11 19:42:16 +00:00
|
|
|
// void advance(Iter& i, Iter::difference_type n);
|
|
|
|
|
|
|
|
#include <iterator>
|
|
|
|
#include <cassert>
|
|
|
|
|
|
|
|
#include "../../iterators.h"
|
|
|
|
|
|
|
|
template <class It>
|
|
|
|
void
|
|
|
|
test(It i, typename std::iterator_traits<It>::difference_type n, It x)
|
|
|
|
{
|
|
|
|
std::advance(i, n);
|
|
|
|
assert(i == x);
|
|
|
|
}
|
|
|
|
|
|
|
|
int main()
|
|
|
|
{
|
|
|
|
const char* s = "1234567890";
|
|
|
|
test(input_iterator<const char*>(s), 10, input_iterator<const char*>(s+10));
|
|
|
|
test(forward_iterator<const char*>(s), 10, forward_iterator<const char*>(s+10));
|
|
|
|
test(bidirectional_iterator<const char*>(s+5), 5, bidirectional_iterator<const char*>(s+10));
|
|
|
|
test(bidirectional_iterator<const char*>(s+5), -5, bidirectional_iterator<const char*>(s));
|
|
|
|
test(random_access_iterator<const char*>(s+5), 5, random_access_iterator<const char*>(s+10));
|
|
|
|
test(random_access_iterator<const char*>(s+5), -5, random_access_iterator<const char*>(s));
|
|
|
|
test(s+5, 5, s+10);
|
|
|
|
test(s+5, -5, s);
|
|
|
|
}
|