| // RUN: %clang_cc1 -std=c++23 -fsyntax-only -fexperimental-new-constant-interpreter %s -verify=expected,both |
| // RUN: %clang_cc1 -std=c++23 -fsyntax-only %s -verify=ref,both |
| |
| namespace ConstEval { |
| constexpr int f() { |
| int i = 0; |
| if consteval { |
| i = 1; |
| } |
| return i; |
| } |
| static_assert(f() == 1, ""); |
| |
| constexpr int f2() { |
| int i = 0; |
| if !consteval { |
| i = 12; |
| if consteval { |
| i = i + 1; |
| } |
| } |
| return i; |
| } |
| static_assert(f2() == 0, ""); |
| }; |
| |
| namespace InitDecl { |
| constexpr bool f() { |
| if (int i = 5; i != 10) { |
| return true; |
| } |
| return false; |
| } |
| static_assert(f(), ""); |
| |
| constexpr bool f2() { |
| if (bool b = false; b) { |
| return true; |
| } |
| return false; |
| } |
| static_assert(!f2(), ""); |
| |
| |
| constexpr int attrs() { |
| if (1) [[likely]] {} |
| return 1; |
| } |
| static_assert(attrs() == 1, ""); |
| }; |
| |
| /// The faulty if statement creates a RecoveryExpr with contains-errors, |
| /// but the execution will never reach that. |
| constexpr char g(char const (&x)[2]) { |
| return 'x'; |
| if (auto [a, b] = x) // both-error {{an array type is not allowed here}} \ |
| // both-warning {{ISO C++17 does not permit structured binding declaration in a condition}} |
| ; |
| } |
| static_assert(g("x") == 'x'); |