From: Ted Kremenek Date: Mon, 11 May 2009 22:55:17 +0000 (+0000) Subject: When stripping element regions for invalidating region values, treat FieldRegions... X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=109bf47503a7c20e1ff98a7b112024e3ff75a49e;p=clang When stripping element regions for invalidating region values, treat FieldRegions and ObjCIvarRegions as "base" regions in addition to VarRegions. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@71488 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Analysis/CFRefCount.cpp b/lib/Analysis/CFRefCount.cpp index 29a28c1a19..bc140077dc 100644 --- a/lib/Analysis/CFRefCount.cpp +++ b/lib/Analysis/CFRefCount.cpp @@ -2673,10 +2673,13 @@ void CFRefCount::EvalSummary(ExplodedNodeSet& Dst, // approriately delegated to the respective StoreManagers while // still allowing us to do checker-specific logic (e.g., // invalidating reference counts), probably via callbacks. - if (ER->getElementType()->isIntegralType()) - if (const VarRegion *superReg = - dyn_cast(ER->getSuperRegion())) - R = superReg; + if (ER->getElementType()->isIntegralType()) { + const MemRegion *superReg = ER->getSuperRegion(); + if (isa(superReg) || isa(superReg) || + isa(superReg)) + R = cast(superReg); + } + // FIXME: What about layers of ElementRegions? }