llvm-project/clang/test/AST/ast-dump-invalid-initialized.cpp
Haojian Wu 8f7fdd94ef
[clang][AST] Invalidate DecompositionDecl if it has invalid initializer. (#72428)
Fix #67495, #72198

We build ill-formed AST nodes for invalid structured binding. For case
`int [_, b] = {0, 0};`, the `DecompositionDecl` is valid, and its
children `BindingDecl`s are valid but with a NULL type, this breaks
clang invariants in many places, and using these `BindingDecl`s can lead
to crashes. This patch fixes them by marking the DecompositionDecl and
its children invalid.
2024-01-17 12:11:16 +01:00

43 lines
999 B
C++

// RUN: not %clang_cc1 -triple x86_64-unknown-unknown -Wno-unused-value -fcxx-exceptions -std=gnu++17 -ast-dump %s | FileCheck -strict-whitespace %s
struct A { A(int, int) {} };
class ForwardDecl;
void test() {
// Verify the valid-bit of the VarDecl.
// CHECK: `-VarDecl {{.*}} a1 'A'
A a1;
// CHECK: `-VarDecl {{.*}} a2 'const A'
const A a2;
// CHECK: `-VarDecl {{.*}} a3 'A'
A a3 = garbage();
// CHECK: `-VarDecl {{.*}} a4 'const A &'
const A& a4;
// CHECK: `-VarDecl {{.*}} invalid b2 'ForwardDecl'
ForwardDecl b2;
// CHECK: `-VarDecl {{.*}} invalid b3 'auto'
auto b3 = garbage();
// CHECK: `-VarDecl {{.*}} invalid b4 'auto'
auto b4 = A(1);
// CHECK: `-VarDecl {{.*}} invalid b5 'auto'
auto b5 = A{1};
}
void GH72198() {
// CHECK: DecompositionDecl {{.*}} invalid 'int'
int [_, b] = {0, 0};
[b]{};
}
namespace GH67495 {
int get_point();
void f() {
// CHECK: DecompositionDecl {{.*}} invalid 'int &'
auto& [x, y] = get_point();
[x, y] {};
}
}