4684ddb6aa
- import libcxx - reduce targets to the one when compiled as a tools Change-Id: Iabb8427f80ff8e89463559a28bcb8b4f2bdbc496
46 lines
1.5 KiB
C++
46 lines
1.5 KiB
C++
//===----------------------------------------------------------------------===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is dual licensed under the MIT and the University of Illinois Open
|
|
// Source Licenses. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// <iterator>
|
|
|
|
// move_iterator
|
|
|
|
// template <InputIterator Iter1, InputIterator Iter2>
|
|
// requires HasEqualTo<Iter1, Iter2>
|
|
// bool
|
|
// operator!=(const move_iterator<Iter1>& x, const move_iterator<Iter2>& y);
|
|
|
|
#include <iterator>
|
|
#include <cassert>
|
|
|
|
#include "test_iterators.h"
|
|
|
|
template <class It>
|
|
void
|
|
test(It l, It r, bool x)
|
|
{
|
|
const std::move_iterator<It> r1(l);
|
|
const std::move_iterator<It> r2(r);
|
|
assert((r1 != r2) == x);
|
|
}
|
|
|
|
int main()
|
|
{
|
|
char s[] = "1234567890";
|
|
test(input_iterator<char*>(s), input_iterator<char*>(s), false);
|
|
test(input_iterator<char*>(s), input_iterator<char*>(s+1), true);
|
|
test(forward_iterator<char*>(s), forward_iterator<char*>(s), false);
|
|
test(forward_iterator<char*>(s), forward_iterator<char*>(s+1), true);
|
|
test(bidirectional_iterator<char*>(s), bidirectional_iterator<char*>(s), false);
|
|
test(bidirectional_iterator<char*>(s), bidirectional_iterator<char*>(s+1), true);
|
|
test(random_access_iterator<char*>(s), random_access_iterator<char*>(s), false);
|
|
test(random_access_iterator<char*>(s), random_access_iterator<char*>(s+1), true);
|
|
test(s, s, false);
|
|
test(s, s+1, true);
|
|
}
|