1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68
|
// RUN: %clang_cc1 -fcxx-exceptions -std=c++20 -fexperimental-new-constant-interpreter -verify %s
// RUN: %clang_cc1 -fcxx-exceptions -std=c++20 -verify=ref %s
namespace Throw {
constexpr int ConditionalThrow(bool t) {
if (t)
throw 4; // expected-note {{subexpression not valid in a constant expression}} \
// ref-note {{subexpression not valid in a constant expression}}
return 0;
}
static_assert(ConditionalThrow(false) == 0, "");
static_assert(ConditionalThrow(true) == 0, ""); // expected-error {{not an integral constant expression}} \
// expected-note {{in call to 'ConditionalThrow(true)'}} \
// ref-error {{not an integral constant expression}} \
// ref-note {{in call to 'ConditionalThrow(true)'}}
constexpr int Throw() { // expected-error {{never produces a constant expression}} \
// ref-error {{never produces a constant expression}}
throw 5; // expected-note {{subexpression not valid in a constant expression}} \
// ref-note {{subexpression not valid in a constant expression}}
return 0;
}
constexpr int NoSubExpr() { // ref-error {{never produces a constant expression}} \
// expected-error {{never produces a constant expression}}
throw; // ref-note 2{{subexpression not valid}} \
// expected-note 2{{subexpression not valid}}
return 0;
}
static_assert(NoSubExpr() == 0, ""); // ref-error {{not an integral constant expression}} \
// ref-note {{in call to}} \
// expected-error {{not an integral constant expression}} \
// expected-note {{in call to}}
}
namespace Asm {
constexpr int ConditionalAsm(bool t) {
if (t)
asm(""); // expected-note {{subexpression not valid in a constant expression}} \
// ref-note {{subexpression not valid in a constant expression}}
return 0;
}
static_assert(ConditionalAsm(false) == 0, "");
static_assert(ConditionalAsm(true) == 0, ""); // expected-error {{not an integral constant expression}} \
// expected-note {{in call to 'ConditionalAsm(true)'}} \
// ref-error {{not an integral constant expression}} \
// ref-note {{in call to 'ConditionalAsm(true)'}}
constexpr int Asm() { // expected-error {{never produces a constant expression}} \
// ref-error {{never produces a constant expression}}
__asm volatile(""); // expected-note {{subexpression not valid in a constant expression}} \
// ref-note {{subexpression not valid in a constant expression}}
return 0;
}
}
namespace Casts {
constexpr int a = reinterpret_cast<int>(12); // expected-error {{must be initialized by a constant expression}} \
// expected-note {{reinterpret_cast is not allowed}} \
// ref-error {{must be initialized by a constant expression}} \
// ref-note {{reinterpret_cast is not allowed}}
}
|