//===----------------------------------------------------------------------===// // // 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. // //===----------------------------------------------------------------------===// // <algorithm> // template<class Iter, IntegralLike Size, class T> // requires OutputIterator<Iter, const T&> // OutputIterator // fill_n(Iter first, Size n, const T& value); #include <algorithm> #include <cassert> #include "test_iterators.h" #include "user_defined_integral.hpp" typedef UserDefinedIntegral<unsigned> UDI; template <class Iter> void test_char() { const unsigned n = 4; char ca[n] = {0}; assert(std::fill_n(Iter(ca), UDI(n), char(1)) == std::next(Iter(ca), n)); assert(ca[0] == 1); assert(ca[1] == 1); assert(ca[2] == 1); assert(ca[3] == 1); } template <class Iter> void test_int() { const unsigned n = 4; int ia[n] = {0}; assert(std::fill_n(Iter(ia), UDI(n), 1) == std::next(Iter(ia), n)); assert(ia[0] == 1); assert(ia[1] == 1); assert(ia[2] == 1); assert(ia[3] == 1); } void test_int_array() { const unsigned n = 4; int ia[n] = {0}; assert(std::fill_n(ia, UDI(n), static_cast<char>(1)) == std::next(ia, n)); assert(ia[0] == 1); assert(ia[1] == 1); assert(ia[2] == 1); assert(ia[3] == 1); } struct source { source() : i(0) { } operator int() const { return i++; } mutable int i; }; void test_int_array_struct_source() { const unsigned n = 4; int ia[n] = {0}; assert(std::fill_n(ia, UDI(n), source()) == std::next(ia, n)); assert(ia[0] == 0); assert(ia[1] == 1); assert(ia[2] == 2); assert(ia[3] == 3); } struct test1 { test1() : c(0) { } test1(char c) : c(c + 1) { } char c; }; void test_struct_array() { const unsigned n = 4; test1 test1a[n] = {0}; assert(std::fill_n(test1a, UDI(n), static_cast<char>(10)) == std::next(test1a, n)); assert(test1a[0].c == 11); assert(test1a[1].c == 11); assert(test1a[2].c == 11); assert(test1a[3].c == 11); } class A { char a_; public: A() {} explicit A(char a) : a_(a) {} operator unsigned char() const {return 'b';} friend bool operator==(const A& x, const A& y) {return x.a_ == y.a_;} }; void test5() { A a[3]; assert(std::fill_n(&a[0], UDI(3), A('a')) == a+3); assert(a[0] == A('a')); assert(a[1] == A('a')); assert(a[2] == A('a')); } struct Storage { union { unsigned char a; unsigned char b; }; }; void test6() { Storage foo[5]; std::fill_n(&foo[0], UDI(5), Storage()); } int main() { test_char<forward_iterator<char*> >(); test_char<bidirectional_iterator<char*> >(); test_char<random_access_iterator<char*> >(); test_char<char*>(); test_int<forward_iterator<int*> >(); test_int<bidirectional_iterator<int*> >(); test_int<random_access_iterator<int*> >(); test_int<int*>(); test_int_array(); test_int_array_struct_source(); test_struct_array(); test5(); test6(); }