mirror of
https://github.com/llvm/llvm-project.git
synced 2025-04-28 01:56:05 +00:00

GCC from 11 onwards defaults to -std=gnu++17 for C++ source files. We want to do the same (https://discourse.llvm.org/t/c-objc-switch-to-gnu-17-as-the-default-dialect/64360). Split RUN lines, adjust `-verify`, or add `__cplusplus < 201703L` or `-Wno-dynamic-exception-spec`, so that tests will pass regardless of gnu++14/gnu++17 default. We have a desire to mark a test compatible with multiple language standards. There are ongoing discussions how to add markers in the long term: * https://discourse.llvm.org/t/iterating-lit-run-lines/62596 * https://discourse.llvm.org/t/lit-run-a-run-line-multiple-times-with-different-replacements/64932 As a workaround in the short term, add lit substitutions `%std_cxx98-`, `%std_cxx11-14`, etc. They can be used for tests which work across multiple language standards. If a range has `n` standards, run lit multiple times, with `LIT_CLANG_STD_GROUP=0`, `LIT_CLANG_STD_GROUP=1`, etc to cover all `n` standards. Reviewed By: #clang-language-wg, aaron.ballman Differential Revision: https://reviews.llvm.org/D131464
38 lines
1.7 KiB
C++
38 lines
1.7 KiB
C++
// RUN: %clang_cc1 %std_cxx98-14 -fsyntax-only -verify=expected,precxx17 -Wno-constant-conversion %s
|
|
// RUN: %clang_cc1 %std_cxx98-14 -fsyntax-only -verify=expected,precxx17 -Wno-constant-conversion -Wno-deprecated -Wdeprecated-increment-bool %s
|
|
// RUN: %clang_cc1 %std_cxx17- -fsyntax-only -verify=expected,cxx17 -Wno-constant-conversion -Wno-deprecated -Wdeprecated-increment-bool %s
|
|
|
|
// Bool literals can be enum values.
|
|
enum {
|
|
ReadWrite = false,
|
|
ReadOnly = true
|
|
};
|
|
|
|
// bool cannot be decremented, and gives a warning on increment
|
|
void test(bool b)
|
|
{
|
|
++b; // precxx17-warning {{incrementing expression of type bool is deprecated}} \
|
|
cxx17-error {{ISO C++17 does not allow incrementing expression of type bool}}
|
|
b++; // precxx17-warning {{incrementing expression of type bool is deprecated}} \
|
|
cxx17-error {{ISO C++17 does not allow incrementing expression of type bool}}
|
|
--b; // expected-error {{cannot decrement expression of type bool}}
|
|
b--; // expected-error {{cannot decrement expression of type bool}}
|
|
|
|
bool *b1 = (int *)0; // expected-error{{cannot initialize}}
|
|
}
|
|
|
|
// static_assert_arg_is_bool(x) compiles only if x is a bool.
|
|
template <typename T>
|
|
void static_assert_arg_is_bool(T x) {
|
|
bool* p = &x;
|
|
}
|
|
|
|
void test2() {
|
|
int n = 2;
|
|
static_assert_arg_is_bool(n && 4); // expected-warning {{use of logical '&&' with constant operand}} \
|
|
// expected-note {{use '&' for a bitwise operation}} \
|
|
// expected-note {{remove constant to silence this warning}}
|
|
static_assert_arg_is_bool(n || 5); // expected-warning {{use of logical '||' with constant operand}} \
|
|
// expected-note {{use '|' for a bitwise operation}}
|
|
}
|