[LLVMbugs] [Bug 15715] New: False positive in interprocedural analysis of C++ destructors
bugzilla-daemon at llvm.org
bugzilla-daemon at llvm.org
Wed Apr 10 02:26:40 PDT 2013
http://llvm.org/bugs/show_bug.cgi?id=15715
Bug ID: 15715
Summary: False positive in interprocedural analysis of C++
destructors
Product: clang
Version: unspecified
Hardware: Macintosh
OS: MacOS X
Status: NEW
Severity: normal
Priority: P
Component: Static Analyzer
Assignee: kremenek at apple.com
Reporter: timac at timac.org
CC: llvmbugs at cs.uiuc.edu
Classification: Unclassified
Created attachment 10331
--> http://llvm.org/bugs/attachment.cgi?id=10331&action=edit
Xcode project
The Clang Static Analyzer (checker-273 and Xcode 4.6.1) reports a memory leak
for the following source code.
Steps to reproduce:
1- On 10.8.3 with Xcode 4.6.1, create a new CoreFoundation project with ARC
disabled.
2- Download the attached Xcode project or replace the main.c with a main.cpp
containing the following:
#include <CoreFoundation/CoreFoundation.h>
//
// MyCFString is a wrapper around CFStringRef.
//
class MyCFString
{
public:
static CFStringRef EmptyCFString()
{
static CFStringRef kEmptyCFString = CFSTR("Empty");
return kEmptyCFString;
}
MyCFString()
{
mRef = CFStringRef(CFRetain(EmptyCFString()));
}
~MyCFString()
{
if(mRef != NULL)
CFRelease(mRef);
}
// Adopt doesn't retain the passed CFStringRef
void Adopt(CFStringRef s)
{
if (s != mRef)
{
if(mRef != NULL)
CFRelease(mRef);
mRef = s;
}
}
private:
CFStringRef mRef;
};
int main(int argc, const char * argv[])
{
MyCFString theString;
// Create a CFStringRef
CFStringRef adoptedString = CFStringCreateCopy(kCFAllocatorDefault,
CFSTR("This is not a leak"));
// adoptedString is not retained by Adopt() but the MyCFString destructor
will release adoptedString
theString.Adopt(adoptedString);
return 0;
}
3- Run scan-build /usr/bin/xcodebuild -project InterproceduralBug.xcodeproj
-target "InterproceduralBug" build
Result:
The Clang static analyzer reports a memory leak.
--
You are receiving this mail because:
You are on the CC list for the bug.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-bugs/attachments/20130410/057c5814/attachment.html>
More information about the llvm-bugs
mailing list