diff options
Diffstat (limited to 'lib/Checker/PathDiagnostic.cpp')
| -rw-r--r-- | lib/Checker/PathDiagnostic.cpp | 13 | 
1 files changed, 3 insertions, 10 deletions
diff --git a/lib/Checker/PathDiagnostic.cpp b/lib/Checker/PathDiagnostic.cpp index 963923c9ad105..cf05a7df67f34 100644 --- a/lib/Checker/PathDiagnostic.cpp +++ b/lib/Checker/PathDiagnostic.cpp @@ -107,7 +107,7 @@ void PathDiagnosticClient::HandleDiagnostic(Diagnostic::Level DiagLevel,      new PathDiagnosticEventPiece(Info.getLocation(), StrC.str());    for (unsigned i = 0, e = Info.getNumRanges(); i != e; ++i) -    P->addRange(Info.getRange(i)); +    P->addRange(Info.getRange(i).getAsRange());    for (unsigned i = 0, e = Info.getNumFixItHints(); i != e; ++i)      P->addFixItHint(Info.getFixItHint(i));    D->push_front(P); @@ -181,15 +181,8 @@ PathDiagnosticRange PathDiagnosticLocation::asRange() const {        if (const ObjCMethodDecl *MD = dyn_cast<ObjCMethodDecl>(D))          return MD->getSourceRange();        if (const FunctionDecl *FD = dyn_cast<FunctionDecl>(D)) { -        // FIXME: We would like to always get the function body, even -        // when it needs to be de-serialized, but getting the -        // ASTContext here requires significant changes. -        if (Stmt *Body = FD->getBody()) { -          if (CompoundStmt *CS = dyn_cast<CompoundStmt>(Body)) -            return CS->getSourceRange(); -          else -            return cast<CXXTryStmt>(Body)->getSourceRange(); -        } +        if (Stmt *Body = FD->getBody()) +          return Body->getSourceRange();        }        else {          SourceLocation L = D->getLocation();  | 
