Files
clang-p2996/clang/test/AST/ast-dump-invalid-initialized.cpp
Haojian Wu 89d9912cbf [AST] dont invaliate VarDecl when the initializer contains errors.
Summary:
This patch contains 2 separate changes:
1) the initializer of a variable should play no part in decl "invalid" bit;
2) preserve the invalid initializer via recovery exprs;

With 1), we will regress the diagnostics (one big regression is that we loose
the "selected 'begin' function with iterator type" diagnostic in for-range stmt;
but with 2) together, we don't have regressions (the new diagnostics seems to be
improved).

Reviewers: sammccall

Reviewed By: sammccall

Subscribers: cfe-commits

Tags: #clang

Differential Revision: https://reviews.llvm.org/D78116
2020-04-21 10:53:35 +02:00

27 lines
754 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 {{.*}} invalid b1 'const A &'
const A& b1;
// 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};
}