From: Ted Kremenek Date: Fri, 4 Dec 2009 20:34:31 +0000 (+0000) Subject: Teach 'ExecutionContinues' (part of BugReporter's diagnostic generation) about BlockD... X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=4f1db537722e8d46146cd95f5962a6dcf6e44e54;p=clang Teach 'ExecutionContinues' (part of BugReporter's diagnostic generation) about BlockDecls. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@90584 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Analysis/BugReporter.cpp b/lib/Analysis/BugReporter.cpp index c26a60af9c..e6482698dd 100644 --- a/lib/Analysis/BugReporter.cpp +++ b/lib/Analysis/BugReporter.cpp @@ -204,10 +204,19 @@ PathDiagnosticBuilder::ExecutionContinues(llvm::raw_string_ostream& os, os << "Execution continues on line " << getSourceManager().getInstantiationLineNumber(Loc.asLocation()) << '.'; - else - os << "Execution jumps to the end of the " - << (isa(N->getLocationContext()->getDecl()) ? - "method" : "function") << '.'; + else { + os << "Execution jumps to the end of the "; + const Decl *D = N->getLocationContext()->getDecl(); + if (isa(D)) + os << "method"; + else if (isa(D)) + os << "function"; + else { + assert(isa(D)); + os << "anonymous block"; + } + os << '.'; + } return Loc; }