//===----------------------------------------------------------------------===// // // 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. // //===----------------------------------------------------------------------===// // // template // requires OutputIterator // OutputIterator // fill_n(Iter first, Size n, const T& value); #include #include #include "test_iterators.h" template void test_char() { const unsigned n = 4; char ca[n] = {0}; assert(std::fill_n(Iter(ca), 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 void test_int() { const unsigned n = 4; int ia[n] = {0}; assert(std::fill_n(Iter(ia), 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, n, static_cast(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, 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, n, static_cast(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); } int main() { test_char >(); test_char >(); test_char >(); test_char(); test_int >(); test_int >(); test_int >(); test_int(); test_int_array(); test_int_array_struct_source(); test_struct_array(); }