generate_n.pass.cpp 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. //===----------------------------------------------------------------------===//
  2. //
  3. // The LLVM Compiler Infrastructure
  4. //
  5. // This file is dual licensed under the MIT and the University of Illinois Open
  6. // Source Licenses. See LICENSE.TXT for details.
  7. //
  8. //===----------------------------------------------------------------------===//
  9. // <algorithm>
  10. // template<class Iter, IntegralLike Size, Callable Generator>
  11. // requires OutputIterator<Iter, Generator::result_type>
  12. // && CopyConstructible<Generator>
  13. // void
  14. // generate_n(Iter first, Size n, Generator gen);
  15. #include <algorithm>
  16. #include <cassert>
  17. #include "test_macros.h"
  18. #include "test_iterators.h"
  19. #include "user_defined_integral.hpp"
  20. struct gen_test
  21. {
  22. int operator()() const {return 2;}
  23. };
  24. template <class Iter, class Size>
  25. void
  26. test2()
  27. {
  28. const unsigned n = 4;
  29. int ia[n] = {0};
  30. assert(std::generate_n(Iter(ia), Size(n), gen_test()) == Iter(ia+n));
  31. assert(ia[0] == 2);
  32. assert(ia[1] == 2);
  33. assert(ia[2] == 2);
  34. assert(ia[3] == 2);
  35. }
  36. template <class Iter>
  37. void
  38. test()
  39. {
  40. test2<Iter, int>();
  41. test2<Iter, unsigned int>();
  42. test2<Iter, long>();
  43. test2<Iter, unsigned long>();
  44. test2<Iter, UserDefinedIntegral<unsigned> >();
  45. test2<Iter, float>();
  46. test2<Iter, double>(); // this is PR#35498
  47. test2<Iter, long double>();
  48. }
  49. int main()
  50. {
  51. test<forward_iterator<int*> >();
  52. test<bidirectional_iterator<int*> >();
  53. test<random_access_iterator<int*> >();
  54. test<int*>();
  55. }