llvm-project/clang/test/Analysis/nil-receiver-undefined-larger-than-voidptr-ret-region.m
Dominic Chen 184c6242fa Reland 4: [analyzer] NFC: Update test infrastructure to support multiple constraint managers
Summary: Replace calls to %clang/%clang_cc1 with %clang_analyze_cc1 when invoking static analyzer, and perform runtime substitution to select the appropriate constraint manager, per D28952.

Reviewers: xazax.hun, NoQ, zaks.anna, dcoughlin

Subscribers: mgorny, rgov, mikhail.ramalho, a.sidorin, cfe-commits

Differential Revision: https://reviews.llvm.org/D30373

llvm-svn: 296895
2017-03-03 18:02:02 +00:00

33 lines
615 B
Objective-C

// RUN: %clang_analyze_cc1 -triple i386-apple-darwin8 -analyzer-checker=core,alpha.core -analyzer-store=region -verify -Wno-objc-root-class %s
// <rdar://problem/6888289> - This test case shows that a nil instance
// variable can possibly be initialized by a method.
@interface RDar6888289
{
id *x;
}
- (void) test:(id) y;
- (void) test2:(id) y;
- (void) invalidate;
@end
id *getVal(void);
@implementation RDar6888289
- (void) test:(id)y {
if (!x)
[self invalidate];
*x = y;
}
- (void) test2:(id)y {
if (!x) {}
*x = y; // expected-warning {{null}}
}
- (void) invalidate {
x = getVal();
}
@end