Arthur O'Dwyer ee95c7020c [libc++] Remove _LIBCPP_CONSTEXPR_AFTER_CXX17_WITH_IS_CONSTANT_EVALUATED.
Zoe Carver says: "We decided that libc++ only supports C++20 constexpr algorithms
when `is_constant_evaluated` is also supported. Here's a link to the discussion."
https://reviews.llvm.org/D65721#inline-735682

Remove _LIBCPP_HAS_NO_BUILTIN_IS_CONSTANT_EVALUATED from tests, too.
See Louis's 5911e6a8857f146fb5a8f23af1d768aba25e7c3e if needed to fix bots.
I've applied `UNSUPPORTED: clang-8` preemptively to the altered tests;
I don't know for sure that this was needed, because no clang-8 buildbots
are triggered on pull requests.
2020-11-24 11:04:21 -05:00

90 lines
3.2 KiB
C++

//===----------------------------------------------------------------------===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
// UNSUPPORTED: clang-8
// <algorithm>
// template<InputIterator InIter, OutputIterator<auto, InIter::reference> OutIter>
// constexpr OutIter // constexpr after C++17
// copy(InIter first, InIter last, OutIter result);
#include <algorithm>
#include <cassert>
#include "test_macros.h"
#include "test_iterators.h"
template <class InIter, class OutIter>
TEST_CONSTEXPR_CXX20 void
test_copy()
{
const unsigned N = 1000;
int ia[N] = {};
for (unsigned i = 0; i < N; ++i)
ia[i] = i;
int ib[N] = {0};
OutIter r = std::copy(InIter(ia), InIter(ia+N), OutIter(ib));
assert(base(r) == ib+N);
for (unsigned i = 0; i < N; ++i)
assert(ia[i] == ib[i]);
}
TEST_CONSTEXPR_CXX20 bool
test()
{
test_copy<input_iterator<const int*>, output_iterator<int*> >();
test_copy<input_iterator<const int*>, input_iterator<int*> >();
test_copy<input_iterator<const int*>, forward_iterator<int*> >();
test_copy<input_iterator<const int*>, bidirectional_iterator<int*> >();
test_copy<input_iterator<const int*>, random_access_iterator<int*> >();
test_copy<input_iterator<const int*>, int*>();
test_copy<forward_iterator<const int*>, output_iterator<int*> >();
test_copy<forward_iterator<const int*>, input_iterator<int*> >();
test_copy<forward_iterator<const int*>, forward_iterator<int*> >();
test_copy<forward_iterator<const int*>, bidirectional_iterator<int*> >();
test_copy<forward_iterator<const int*>, random_access_iterator<int*> >();
test_copy<forward_iterator<const int*>, int*>();
test_copy<bidirectional_iterator<const int*>, output_iterator<int*> >();
test_copy<bidirectional_iterator<const int*>, input_iterator<int*> >();
test_copy<bidirectional_iterator<const int*>, forward_iterator<int*> >();
test_copy<bidirectional_iterator<const int*>, bidirectional_iterator<int*> >();
test_copy<bidirectional_iterator<const int*>, random_access_iterator<int*> >();
test_copy<bidirectional_iterator<const int*>, int*>();
test_copy<random_access_iterator<const int*>, output_iterator<int*> >();
test_copy<random_access_iterator<const int*>, input_iterator<int*> >();
test_copy<random_access_iterator<const int*>, forward_iterator<int*> >();
test_copy<random_access_iterator<const int*>, bidirectional_iterator<int*> >();
test_copy<random_access_iterator<const int*>, random_access_iterator<int*> >();
test_copy<random_access_iterator<const int*>, int*>();
test_copy<const int*, output_iterator<int*> >();
test_copy<const int*, input_iterator<int*> >();
test_copy<const int*, forward_iterator<int*> >();
test_copy<const int*, bidirectional_iterator<int*> >();
test_copy<const int*, random_access_iterator<int*> >();
test_copy<const int*, int*>();
return true;
}
int main(int, char**)
{
test();
#if TEST_STD_VER > 17
static_assert(test());
#endif
return 0;
}