diff options
author | Anna Zaks <ganna@apple.com> | 2011-08-29 21:10:00 +0000 |
---|---|---|
committer | Anna Zaks <ganna@apple.com> | 2011-08-29 21:10:00 +0000 |
commit | 065a4055f796c545cdcc89a490be2d3288426d57 (patch) | |
tree | c93692d9fb59f63ffb6c615d6be837c00c1552d2 /lib/StaticAnalyzer/Checkers/MacOSKeychainAPIChecker.cpp | |
parent | 8b6eb7ce4f6a7124babd4d7f6f4bb4bb5f6daddf (diff) |
[analyzer] MacOSKeychainAPIChecker: Simplify getSymbolForRegion by using existing API. Thanks Jordy.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@138765 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/StaticAnalyzer/Checkers/MacOSKeychainAPIChecker.cpp')
-rw-r--r-- | lib/StaticAnalyzer/Checkers/MacOSKeychainAPIChecker.cpp | 10 |
1 files changed, 3 insertions, 7 deletions
diff --git a/lib/StaticAnalyzer/Checkers/MacOSKeychainAPIChecker.cpp b/lib/StaticAnalyzer/Checkers/MacOSKeychainAPIChecker.cpp index 76d92874be..c2b547612c 100644 --- a/lib/StaticAnalyzer/Checkers/MacOSKeychainAPIChecker.cpp +++ b/lib/StaticAnalyzer/Checkers/MacOSKeychainAPIChecker.cpp @@ -198,14 +198,10 @@ unsigned MacOSKeychainAPIChecker::getTrackedFunctionIndex(StringRef Name, static SymbolRef getSymbolForRegion(CheckerContext &C, const MemRegion *R) { + // Implicit casts (ex: void* -> char*) can turn Symbolic region into element + // region, if that is the case, get the underlining region. + R = R->StripCasts(); if (!isa<SymbolicRegion>(R)) { - // Implicit casts (ex: void* -> char*) can turn Symbolic region into element - // region, if that is the case, get the underlining region. - if (const ElementRegion *ER = dyn_cast<ElementRegion>(R)) { - R = ER->getAsArrayOffset().getRegion(); - if (!R || !isa<SymbolicRegion>(R)) - return 0; - } else return 0; } return cast<SymbolicRegion>(R)->getSymbol(); |