diff options
author | Ted Kremenek <kremenek@apple.com> | 2009-05-13 07:12:33 +0000 |
---|---|---|
committer | Ted Kremenek <kremenek@apple.com> | 2009-05-13 07:12:33 +0000 |
commit | 051a03d6987bee541f3a92cd2091d3938bb0f65c (patch) | |
tree | 5c53cdb76cfc5f3c51d5ab948b50b7fb1f192360 /clang | |
parent | fce7bc924e190d83d58ea1336310b8b9bdd9cc03 (diff) | |
download | bcm5719-llvm-051a03d6987bee541f3a92cd2091d3938bb0f65c.tar.gz bcm5719-llvm-051a03d6987bee541f3a92cd2091d3938bb0f65c.zip |
Fix crasher in CFRefCount.cpp reported by Nikita Zhuk due to recently added autorelease tracking.
llvm-svn: 71647
Diffstat (limited to 'clang')
-rw-r--r-- | clang/lib/Analysis/CFRefCount.cpp | 7 | ||||
-rw-r--r-- | clang/test/Analysis/NSString.m | 31 |
2 files changed, 33 insertions, 5 deletions
diff --git a/clang/lib/Analysis/CFRefCount.cpp b/clang/lib/Analysis/CFRefCount.cpp index fc6de600321..c31a8cd53d9 100644 --- a/clang/lib/Analysis/CFRefCount.cpp +++ b/clang/lib/Analysis/CFRefCount.cpp @@ -2154,6 +2154,9 @@ PathDiagnosticPiece* CFRefReport::VisitNode(const ExplodedNode<GRState>* N, const ExplodedNode<GRState>* PrevN, BugReporterContext& BRC) { + if (!isa<PostStmt>(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<GRState>* N, if (os.str().empty()) return 0; // We have nothing to say! - - Stmt* S = cast<PostStmt>(N->getLocation()).getStmt(); + + Stmt* S = cast<PostStmt>(N->getLocation()).getStmt(); PathDiagnosticLocation Pos(S, BRC.getSourceManager()); PathDiagnosticPiece* P = new PathDiagnosticEventPiece(Pos, os.str()); diff --git a/clang/test/Analysis/NSString.m b/clang/test/Analysis/NSString.m index d5a7870a993..44d0a5d962d 100644 --- a/clang/test/Analysis/NSString.m +++ b/clang/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' + |