From 773aa58270746491a1b11e4ef367d2a076a7f456 Mon Sep 17 00:00:00 2001 From: Anna Zaks Date: Tue, 14 Aug 2012 00:36:12 +0000 Subject: [PATCH] [analyzer] Add getStackFrame() to CheckerContext and ExplodedNode. llvm-svn: 161819 --- .../clang/StaticAnalyzer/Core/PathSensitive/CheckerContext.h | 4 ++-- .../clang/StaticAnalyzer/Core/PathSensitive/ExplodedGraph.h | 4 ++++ clang/lib/StaticAnalyzer/Checkers/DynamicTypePropagation.cpp | 2 +- 3 files changed, 7 insertions(+), 3 deletions(-) diff --git a/clang/include/clang/StaticAnalyzer/Core/PathSensitive/CheckerContext.h b/clang/include/clang/StaticAnalyzer/Core/PathSensitive/CheckerContext.h index 0669b0557064..8c8e82ce20dd 100644 --- a/clang/include/clang/StaticAnalyzer/Core/PathSensitive/CheckerContext.h +++ b/clang/include/clang/StaticAnalyzer/Core/PathSensitive/CheckerContext.h @@ -92,8 +92,8 @@ public: return Pred->getLocationContext(); } - const StackFrameContext *getCurrentStackFrame() const { - return getLocationContext()->getCurrentStackFrame(); + const StackFrameContext *getStackFrame() const { + return Pred->getStackFrame(); } BugReporter &getBugReporter() { diff --git a/clang/include/clang/StaticAnalyzer/Core/PathSensitive/ExplodedGraph.h b/clang/include/clang/StaticAnalyzer/Core/PathSensitive/ExplodedGraph.h index 40969d3fa244..1052d9491a96 100644 --- a/clang/include/clang/StaticAnalyzer/Core/PathSensitive/ExplodedGraph.h +++ b/clang/include/clang/StaticAnalyzer/Core/PathSensitive/ExplodedGraph.h @@ -133,6 +133,10 @@ public: return getLocation().getLocationContext(); } + const StackFrameContext *getStackFrame() const { + return getLocationContext()->getCurrentStackFrame(); + } + const Decl &getCodeDecl() const { return *getLocationContext()->getDecl(); } CFG &getCFG() const { return *getLocationContext()->getCFG(); } diff --git a/clang/lib/StaticAnalyzer/Checkers/DynamicTypePropagation.cpp b/clang/lib/StaticAnalyzer/Checkers/DynamicTypePropagation.cpp index f22d7404c042..fea57337bbda 100644 --- a/clang/lib/StaticAnalyzer/Checkers/DynamicTypePropagation.cpp +++ b/clang/lib/StaticAnalyzer/Checkers/DynamicTypePropagation.cpp @@ -125,7 +125,7 @@ DynamicTypePropagation::getObjectTypeForAllocAndNew(const ObjCMessageExpr *MsgE, RecE= RecE->IgnoreParenImpCasts(); if (const DeclRefExpr *DRE = dyn_cast(RecE)) { - const StackFrameContext *SFCtx = C.getCurrentStackFrame(); + const StackFrameContext *SFCtx = C.getStackFrame(); // Are we calling [self alloc]? If this is self, get the type of the // enclosing ObjC class. if (DRE->getDecl() == SFCtx->getSelfDecl()) { -- GitLab