aboutsummaryrefslogtreecommitdiff
path: root/lib/StaticAnalyzer/Checkers/RetainCountChecker.cpp
diff options
context:
space:
mode:
authorTed Kremenek <kremenek@apple.com>2012-12-20 19:36:22 +0000
committerTed Kremenek <kremenek@apple.com>2012-12-20 19:36:22 +0000
commitbbf4d53343c2bbd082b7c1488f34650a7d07ae3b (patch)
tree2b3687fcf3f19c32e39683d3d2ece1f18d76106c /lib/StaticAnalyzer/Checkers/RetainCountChecker.cpp
parent5810f5c82788c79ca250cddd302c85300a3258ad (diff)
Update RetainCountChecker to understand attribute ns_returns_autoreleased.
Fixes <rdar://problem/12887356>. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@170724 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/StaticAnalyzer/Checkers/RetainCountChecker.cpp')
-rw-r--r--lib/StaticAnalyzer/Checkers/RetainCountChecker.cpp10
1 files changed, 6 insertions, 4 deletions
diff --git a/lib/StaticAnalyzer/Checkers/RetainCountChecker.cpp b/lib/StaticAnalyzer/Checkers/RetainCountChecker.cpp
index b38894ccfa..b57c6e2b4f 100644
--- a/lib/StaticAnalyzer/Checkers/RetainCountChecker.cpp
+++ b/lib/StaticAnalyzer/Checkers/RetainCountChecker.cpp
@@ -1306,13 +1306,14 @@ RetainSummaryManager::updateSummaryFromAnnotations(const RetainSummary *&Summ,
else if (FD->getAttr<CFReturnsRetainedAttr>()) {
Template->setRetEffect(RetEffect::MakeOwned(RetEffect::CF, true));
}
- else if (FD->getAttr<NSReturnsNotRetainedAttr>()) {
+ else if (FD->getAttr<NSReturnsNotRetainedAttr>() ||
+ FD->getAttr<NSReturnsAutoreleasedAttr>()) {
Template->setRetEffect(RetEffect::MakeNotOwned(RetEffect::ObjC));
}
- else if (FD->getAttr<CFReturnsNotRetainedAttr>()) {
+ else if (FD->getAttr<CFReturnsNotRetainedAttr>())
Template->setRetEffect(RetEffect::MakeNotOwned(RetEffect::CF));
}
- } else if (RetTy->getAs<PointerType>()) {
+ else if (RetTy->getAs<PointerType>()) {
if (FD->getAttr<CFReturnsRetainedAttr>()) {
Template->setRetEffect(RetEffect::MakeOwned(RetEffect::CF, true));
}
@@ -1359,7 +1360,8 @@ RetainSummaryManager::updateSummaryFromAnnotations(const RetainSummary *&Summ,
Template->setRetEffect(ObjCAllocRetE);
return;
}
- if (MD->getAttr<NSReturnsNotRetainedAttr>()) {
+ if (MD->getAttr<NSReturnsNotRetainedAttr>() ||
+ MD->getAttr<NSReturnsAutoreleasedAttr>()) {
Template->setRetEffect(RetEffect::MakeNotOwned(RetEffect::ObjC));
return;
}