From: Ted Kremenek Date: Wed, 13 May 2009 07:12:33 +0000 (+0000) Subject: Fix crasher in CFRefCount.cpp reported by Nikita Zhuk due to recently added autorelea... X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=2033a95c9b2692441ce0de790f0d8bbe01722c7f;p=clang Fix crasher in CFRefCount.cpp reported by Nikita Zhuk due to recently added autorelease tracking. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@71647 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Analysis/CFRefCount.cpp b/lib/Analysis/CFRefCount.cpp index fc6de60032..c31a8cd53d 100644 --- a/lib/Analysis/CFRefCount.cpp +++ b/lib/Analysis/CFRefCount.cpp @@ -2154,6 +2154,9 @@ PathDiagnosticPiece* CFRefReport::VisitNode(const ExplodedNode* N, const ExplodedNode* PrevN, BugReporterContext& BRC) { + if (!isa(N->getLocation())) + return NULL; + // Check if the type state has changed. GRStateManager &StMgr = BRC.getStateManager(); GRStateRef PrevSt(PrevN->getState(), StMgr); @@ -2373,8 +2376,8 @@ PathDiagnosticPiece* CFRefReport::VisitNode(const ExplodedNode* N, if (os.str().empty()) return 0; // We have nothing to say! - - Stmt* S = cast(N->getLocation()).getStmt(); + + Stmt* S = cast(N->getLocation()).getStmt(); PathDiagnosticLocation Pos(S, BRC.getSourceManager()); PathDiagnosticPiece* P = new PathDiagnosticEventPiece(Pos, os.str()); diff --git a/test/Analysis/NSString.m b/test/Analysis/NSString.m index d5a7870a99..44d0a5d962 100644 --- a/test/Analysis/NSString.m +++ b/test/Analysis/NSString.m @@ -183,6 +183,33 @@ void f13(void) { NSString *str = [[NSString alloc] init]; return [str autorelease]; // no-warning } +- (void)m1 +{ + NSString *s = [[NSString alloc] init]; // expected-warning{{leak}} + [s retain]; + [s autorelease]; +} +- (void)m2 +{ + NSString *s = [[[NSString alloc] init] autorelease]; // expected-warning{{leak}} + [s retain]; +} +- (void)m3 +{ + NSString *s = [[[NSString alloc] init] autorelease]; + [s retain]; + [s autorelease]; +} +- (void)m4 +{ + NSString *s = [[NSString alloc] init]; // expected-warning{{leak}} + [s retain]; +} +- (void)m5 +{ + NSString *s = [[NSString alloc] init]; + [s autorelease]; +} @end @interface C1 : NSObject {} @@ -298,8 +325,6 @@ void test_isTrackedObjectType(void) { return CFStringCreateWithFormat(kCFAllocatorDefault, ((void*)0), ((CFStringRef) __builtin___CFStringMakeConstantString ("" "%d" "")), 100); // expected-warning{{leak}} } - - // Test @synchronized void test_synchronized(id x) { @synchronized(x) { @@ -307,4 +332,4 @@ void test_synchronized(id x) { } } -// Test return from method starting with 'new' or 'copy' +