diff options
author | Ted Kremenek <kremenek@apple.com> | 2009-02-20 00:05:35 +0000 |
---|---|---|
committer | Ted Kremenek <kremenek@apple.com> | 2009-02-20 00:05:35 +0000 |
commit | c537a6d3f1e1965fc2473fa2501cdb454cad17a1 (patch) | |
tree | 3855b640047447d400a3ddbccfaedaeb3607c631 /clang/lib | |
parent | cf868c458c5dda487684fffac0a6afd528de5505 (diff) | |
download | bcm5719-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.cpp | 7 |
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)); |