implement (but leave commented out) the constexpr tests from P0202 for std::merge. merge requires std::copy, which isn't constexpr yet.

llvm-svn: 323070
This commit is contained in:
Marshall Clow 2018-01-22 00:11:44 +00:00
parent 79834a1fce
commit 85642c2bea
2 changed files with 47 additions and 2 deletions

View File

@ -15,15 +15,32 @@
// requires OutputIterator<OutIter, InIter1::reference>
// && OutputIterator<OutIter, InIter2::reference>
// && HasLess<InIter2::value_type, InIter1::value_type>
// OutIter
// constexpr OutIter // constexpr after C++17
// merge(InIter1 first1, InIter1 last1, InIter2 first2, InIter2 last2, OutIter result);
#include <algorithm>
#include <random>
#include <cassert>
#include "test_macros.h"
#include "test_iterators.h"
#if TEST_STD_VER > 17
TEST_CONSTEXPR bool test_constexpr() {
int ia[] = {0, 1, 2, 3, 4};
int ib[] = {2, 4, 6, 8};
int ic[] = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
const int expected[] = {0, 1, 2, 2, 3, 4, 4, 6, 8};
auto it = std::merge(std::begin(ia), std::end(ia), std::begin(ib), std::end(ib), std::begin(ic));
return std::distance(std::begin(ic), it) == (std::size(ia) + std::size(ib))
&& *it == 0
&& std::equal(std::begin(ic), it, std::begin(expected), std::end(expected))
;
}
#endif
std::mt19937 randomness;
template <class InIter1, class InIter2, class OutIter>
@ -224,4 +241,9 @@ int main()
test<const int*, const int*, bidirectional_iterator<int*> >();
test<const int*, const int*, random_access_iterator<int*> >();
test<const int*, const int*, int*>();
#if TEST_STD_VER > 17
// Not yet - waiting on std::copy
// static_assert(test_constexpr());
#endif
}

View File

@ -16,7 +16,7 @@
// requires OutputIterator<OutIter, InIter1::reference>
// && OutputIterator<OutIter, InIter2::reference>
// && CopyConstructible<Compare>
// OutIter
// constexpr OutIter // constexpr after C++17
// merge(InIter1 first1, InIter1 last1,
// InIter2 first2, InIter2 last2, OutIter result, Compare comp);
@ -25,9 +25,27 @@
#include <random>
#include <cassert>
#include "test_macros.h"
#include "test_iterators.h"
#include "counting_predicates.hpp"
#if TEST_STD_VER > 17
TEST_CONSTEXPR bool test_constexpr() {
int ia[] = {0, 1, 2, 3, 4};
int ib[] = {2, 4, 6, 8};
int ic[] = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
const int expected[] = {0, 1, 2, 2, 3, 4, 4, 6, 8};
auto it = std::merge(std::begin(ia), std::end(ia),
std::begin(ib), std::end(ib),
std::begin(ic), [](int a, int b) {return a == b; });
return std::distance(std::begin(ic), it) == (std::size(ia) + std::size(ib))
&& *it == 0
&& std::equal(std::begin(ic), it, std::begin(expected), std::end(expected))
;
}
#endif
std::mt19937 randomness;
template <class InIter1, class InIter2, class OutIter>
@ -234,4 +252,9 @@ int main()
test<const int*, const int*, bidirectional_iterator<int*> >();
test<const int*, const int*, random_access_iterator<int*> >();
test<const int*, const int*, int*>();
#if TEST_STD_VER > 17
// Not yet - waiting on std::copy
// static_assert(test_constexpr());
#endif
}