summaryrefslogtreecommitdiffstats
path: root/clang/lib
diff options
context:
space:
mode:
authorTed Kremenek <kremenek@apple.com>2009-02-20 00:05:35 +0000
committerTed Kremenek <kremenek@apple.com>2009-02-20 00:05:35 +0000
commitc537a6d3f1e1965fc2473fa2501cdb454cad17a1 (patch)
tree3855b640047447d400a3ddbccfaedaeb3607c631 /clang/lib
parentcf868c458c5dda487684fffac0a6afd528de5505 (diff)
downloadbcm5719-llvm-c537a6d3f1e1965fc2473fa2501cdb454cad17a1.tar.gz
bcm5719-llvm-c537a6d3f1e1965fc2473fa2501cdb454cad17a1.zip
Fix crash from <rdar://problem/6562655>: 'init' method only return a receiver alias if the return type is a location.
llvm-svn: 65084
Diffstat (limited to 'clang/lib')
-rw-r--r--clang/lib/Analysis/CFRefCount.cpp7
1 files changed, 5 insertions, 2 deletions
diff --git a/clang/lib/Analysis/CFRefCount.cpp b/clang/lib/Analysis/CFRefCount.cpp
index 36c1b79af31..8e120afecc2 100644
--- a/clang/lib/Analysis/CFRefCount.cpp
+++ b/clang/lib/Analysis/CFRefCount.cpp
@@ -915,8 +915,11 @@ RetainSummary*
RetainSummaryManager::getInitMethodSummary(ObjCMessageExpr* ME) {
assert(ScratchArgs.empty());
+ // 'init' methods only return an alias if the return type is a location type.
+ QualType T = ME->getType();
RetainSummary* Summ =
- getPersistentSummary(RetEffect::MakeReceiverAlias());
+ getPersistentSummary(Loc::IsLocType(T) ? RetEffect::MakeReceiverAlias()
+ : RetEffect::MakeNoRet());
ObjCMethodSummaries[ME] = Summ;
return Summ;
@@ -1608,7 +1611,7 @@ void CFRefCount::EvalSummary(ExplodedNodeSet<GRState>& Dst,
unsigned Count = Builder.getCurrentBlockCount();
SymbolRef Sym = Eng.getSymbolManager().getConjuredSymbol(Ex, Count);
- SVal X = Loc::IsLocType(Ex->getType())
+ SVal X = Loc::IsLocType(T)
? cast<SVal>(loc::SymbolVal(Sym))
: cast<SVal>(nonloc::SymbolVal(Sym));
OpenPOWER on IntegriCloud