summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTed Kremenek <kremenek@apple.com>2009-02-23 02:51:29 +0000
committerTed Kremenek <kremenek@apple.com>2009-02-23 02:51:29 +0000
commite73f282213af5f7f9d705f512fb384ff1395edd5 (patch)
tree11d7c32b2d8f5d7889369bb7e75a9bb202278554
parente6d2b40bcc97d440df84abb4492e2b2c3a1e1fcb (diff)
downloadbcm5719-llvm-e73f282213af5f7f9d705f512fb384ff1395edd5.tar.gz
bcm5719-llvm-e73f282213af5f7f9d705f512fb384ff1395edd5.zip
retain/release checker: For now don't track the retain count of NSWindow objects (opt for false negatives).
llvm-svn: 65304
-rw-r--r--clang/lib/Analysis/CFRefCount.cpp6
-rw-r--r--clang/test/Analysis/NSWindow.m3
2 files changed, 7 insertions, 2 deletions
diff --git a/clang/lib/Analysis/CFRefCount.cpp b/clang/lib/Analysis/CFRefCount.cpp
index 0d5752d55bc..3816c560b3b 100644
--- a/clang/lib/Analysis/CFRefCount.cpp
+++ b/clang/lib/Analysis/CFRefCount.cpp
@@ -1130,8 +1130,12 @@ void RetainSummaryManager::InitializeMethodSummaries() {
addNSObjectMethSummary(GetNullarySelector("autorelease", Ctx), Summ);
// For NSWindow, allocated objects are (initially) self-owned.
+ // FIXME: For now we opt for false negatives with NSWindow, as these objects
+ // self-own themselves. However, they only do this once they are displayed.
+ // Thus, we need to track an NSWindow's display status.
+ // This is tracked in <rdar://problem/6062711>.
RetainSummary *NSWindowSumm =
- getPersistentSummary(RetEffect::MakeReceiverAlias(), SelfOwn);
+ getPersistentSummary(RetEffect::MakeReceiverAlias(), StopTracking);
addInstMethSummary("NSWindow", NSWindowSumm, "initWithContentRect",
"styleMask", "backing", "defer", NULL);
diff --git a/clang/test/Analysis/NSWindow.m b/clang/test/Analysis/NSWindow.m
index 93ab871e16f..4cab918f50c 100644
--- a/clang/test/Analysis/NSWindow.m
+++ b/clang/test/Analysis/NSWindow.m
@@ -69,7 +69,8 @@ void f2() {
}
void f2b() {
- NSWindow *window = [[NSWindow alloc] // expected-warning{{leak}}
+ // FIXME: NSWindow doesn't own itself until it is displayed.
+ NSWindow *window = [[NSWindow alloc] // no-warning
initWithContentRect:NSMakeRect(0,0,100,100)
styleMask:NSTitledWindowMask|NSClosableWindowMask
backing:NSBackingStoreBuffered
OpenPOWER on IntegriCloud