diff options
author | Jordan Rose <jordan_rose@apple.com> | 2013-03-04 23:21:32 +0000 |
---|---|---|
committer | Jordan Rose <jordan_rose@apple.com> | 2013-03-04 23:21:32 +0000 |
commit | 85707b28e865b7b5baef750418f587956035ffe5 (patch) | |
tree | de6fd49d922de9ffd59b0e7b9b60750810dc2ad2 /clang/lib/StaticAnalyzer/Checkers/RetainCountChecker.cpp | |
parent | 658fd5798bbd7f9b085f2fa9f2a5eeebb440194f (diff) | |
download | bcm5719-llvm-85707b28e865b7b5baef750418f587956035ffe5.tar.gz bcm5719-llvm-85707b28e865b7b5baef750418f587956035ffe5.zip |
[analyzer] Don't let cf_audited_transfer override CFRetain semantics.
We weren't treating a cf_audited_transfer CFRetain as returning +1 because
its name doesn't contain "Create" or "Copy". Oops! Fortunately, the
standard definitions of these functions are not marked audited.
<rdar://problem/13339601>
llvm-svn: 176463
Diffstat (limited to 'clang/lib/StaticAnalyzer/Checkers/RetainCountChecker.cpp')
-rw-r--r-- | clang/lib/StaticAnalyzer/Checkers/RetainCountChecker.cpp | 12 |
1 files changed, 6 insertions, 6 deletions
diff --git a/clang/lib/StaticAnalyzer/Checkers/RetainCountChecker.cpp b/clang/lib/StaticAnalyzer/Checkers/RetainCountChecker.cpp index 3edc997503d..856463a981a 100644 --- a/clang/lib/StaticAnalyzer/Checkers/RetainCountChecker.cpp +++ b/clang/lib/StaticAnalyzer/Checkers/RetainCountChecker.cpp @@ -1133,12 +1133,7 @@ RetainSummaryManager::getFunctionSummary(const FunctionDecl *FD) { if (S) break; - if (RetTy->isPointerType()) { - if (FD->getAttr<CFAuditedTransferAttr>()) { - S = getCFCreateGetRuleSummary(FD); - break; - } - + if (RetTy->isPointerType()) { // For CoreFoundation ('CF') types. if (cocoa::isRefType(RetTy, "CF", FName)) { if (isRetain(FD, FName)) @@ -1169,6 +1164,11 @@ RetainSummaryManager::getFunctionSummary(const FunctionDecl *FD) { break; } + if (FD->getAttr<CFAuditedTransferAttr>()) { + S = getCFCreateGetRuleSummary(FD); + break; + } + break; } |