forked from OSchip/llvm-project
Don't construct two CFGs just to run -Wuninitialized. While this causes new warnings to be flagged under -Wconditional-uninitialized, this is something we
can improve over time. llvm-svn: 127802
This commit is contained in:
parent
b4d763b37d
commit
2551fbe928
|
@ -611,24 +611,7 @@ AnalysisBasedWarnings::IssueWarnings(sema::AnalysisBasedWarnings::Policy P,
|
|||
!= Diagnostic::Ignored ||
|
||||
Diags.getDiagnosticLevel(diag::warn_maybe_uninit_var, D->getLocStart())
|
||||
!= Diagnostic::Ignored) {
|
||||
ASTContext &ctx = D->getASTContext();
|
||||
llvm::OwningPtr<CFG> tmpCFG;
|
||||
bool useAlternateCFG = false;
|
||||
if (ctx.getLangOptions().CPlusPlus) {
|
||||
// Temporary workaround: implicit dtors in the CFG can confuse
|
||||
// the path-sensitivity in the uninitialized values analysis.
|
||||
// For now create (if necessary) a separate CFG without implicit dtors.
|
||||
// FIXME: We should not need to do this, as it results in multiple
|
||||
// CFGs getting constructed.
|
||||
CFG::BuildOptions B;
|
||||
B.AddEHEdges = false;
|
||||
B.AddImplicitDtors = false;
|
||||
B.AddInitializers = true;
|
||||
tmpCFG.reset(CFG::buildCFG(D, AC.getBody(), &ctx, B));
|
||||
useAlternateCFG = true;
|
||||
}
|
||||
CFG *cfg = useAlternateCFG ? tmpCFG.get() : AC.getCFG();
|
||||
if (cfg) {
|
||||
if (CFG *cfg = AC.getCFG()) {
|
||||
UninitValsDiagReporter reporter(S);
|
||||
runUninitializedVariablesAnalysis(*cast<DeclContext>(D), *cfg, AC,
|
||||
reporter);
|
||||
|
|
|
@ -0,0 +1,23 @@
|
|||
// RUN: %clang_cc1 -fsyntax-only -Wconditional-uninitialized -fsyntax-only %s -verify
|
||||
|
||||
class Foo {
|
||||
public:
|
||||
Foo();
|
||||
~Foo();
|
||||
operator bool();
|
||||
};
|
||||
|
||||
int bar();
|
||||
int baz();
|
||||
int init(double *);
|
||||
|
||||
// This case flags a false positive under -Wconditional-uninitialized because
|
||||
// the destructor in Foo fouls about the minor bit of path-sensitivity in
|
||||
// -Wuninitialized.
|
||||
double test() {
|
||||
double x; // expected-note {{variable 'x' is declared here}} expected-note{{add initialization to silence this warning}}
|
||||
if (bar() || baz() || Foo() || init(&x)) {
|
||||
return x; // expected-warning {{variable 'x' is possibly uninitialized when used here}}
|
||||
}
|
||||
return 1.0;
|
||||
}
|
Loading…
Reference in New Issue