mirror of
https://github.com/llvm/llvm-project.git
synced 2025-04-17 17:36:36 +00:00

This patch rewords the static assert diagnostic output. Failing a _Static_assert in C should not report that static_assert failed. This changes the wording to be more like GCC and uses "static assertion" when possible instead of hard coding the name. This also changes some instances of 'static_assert' to instead be based on the token in the source code. Differential Revision: https://reviews.llvm.org/D129048
23 lines
947 B
C++
23 lines
947 B
C++
// RUN: %clang_cc1 -fsyntax-only -verify %s -std=c++14
|
|
// RUN: %clang_cc1 -fsyntax-only -verify %s -std=c++17
|
|
|
|
void foo(int* a, int *b) {
|
|
a -= b; // expected-error {{incompatible integer to pointer conversion assigning to 'int *' from}}
|
|
}
|
|
|
|
template<typename T> T declval();
|
|
struct true_type { static const bool value = true; };
|
|
struct false_type { static const bool value = false; };
|
|
template<bool, typename T, typename U> struct select { using type = T; };
|
|
template<typename T, typename U> struct select<false, T, U> { using type = U; };
|
|
|
|
|
|
template<typename T>
|
|
typename select<(sizeof(declval<T>() -= declval<T>(), 1) != 1), true_type, false_type>::type test(...);
|
|
template<typename T> false_type test(...);
|
|
|
|
template<typename T>
|
|
static const auto has_minus_assign = decltype(test<T>())::value;
|
|
|
|
static_assert(has_minus_assign<int*>, "failed"); // expected-error {{static assertion failed due to requirement 'has_minus_assign<int *>': failed}}
|