
Because of this, we would previously emit NO path notes when a parameter is constrained to null (because there are no stores). Now we show where we made the assumption, which is much more useful. llvm-svn: 161280
37 lines
1.6 KiB
C++
37 lines
1.6 KiB
C++
// RUN: %clang_cc1 -analyze -analyzer-checker=core -analyzer-ipa=inlining -analyzer-output=text -verify %s
|
|
|
|
// Test warning about null or uninitialized pointer values used as instance member
|
|
// calls.
|
|
class TestInstanceCall {
|
|
public:
|
|
void foo() {}
|
|
};
|
|
|
|
void test_ic() {
|
|
TestInstanceCall *p; // expected-note {{Variable 'p' declared without an initial value}}
|
|
p->foo(); // expected-warning {{Called C++ object pointer is uninitialized}} expected-note {{Called C++ object pointer is uninitialized}}
|
|
}
|
|
|
|
void test_ic_null() {
|
|
TestInstanceCall *p = 0; // expected-note {{Variable 'p' initialized to a null pointer value}}
|
|
p->foo(); // expected-warning {{Called C++ object pointer is null}} expected-note {{Called C++ object pointer is null}}
|
|
}
|
|
|
|
void test_ic_set_to_null() {
|
|
TestInstanceCall *p;
|
|
p = 0; // expected-note {{Null pointer value stored to 'p'}}
|
|
p->foo(); // expected-warning {{Called C++ object pointer is null}} expected-note {{Called C++ object pointer is null}}
|
|
}
|
|
|
|
void test_ic_null(TestInstanceCall *p) {
|
|
if (!p) // expected-note {{Assuming pointer value is null}} expected-note {{Taking true branch}}
|
|
p->foo(); // expected-warning {{Called C++ object pointer is null}} expected-note{{Called C++ object pointer is null}}
|
|
}
|
|
|
|
void test_ic_member_ptr() {
|
|
TestInstanceCall *p = 0; // expected-note {{Variable 'p' initialized to a null pointer value}}
|
|
typedef void (TestInstanceCall::*IC_Ptr)();
|
|
IC_Ptr bar = &TestInstanceCall::foo;
|
|
(p->*bar)(); // expected-warning {{Called C++ object pointer is null}} expected-note{{Called C++ object pointer is null}}
|
|
}
|