diff options
author | Jordan Rose <jordan_rose@apple.com> | 2012-08-03 23:08:36 +0000 |
---|---|---|
committer | Jordan Rose <jordan_rose@apple.com> | 2012-08-03 23:08:36 +0000 |
commit | bf83e7cd7eaa1257ae8c2317b812fee17adcf919 (patch) | |
tree | 39e42cfafc043fc41231c076a0886476132f2c7b | |
parent | 51a0a94b841e64814e63f9f172c6c4ae5d8ff286 (diff) |
[analyzer] Add a test for copy-constructor inlining.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@161274 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | test/Analysis/ctor-inlining.mm | 32 |
1 files changed, 31 insertions, 1 deletions
diff --git a/test/Analysis/ctor-inlining.mm b/test/Analysis/ctor-inlining.mm index 586c09d304..54d51b46dc 100644 --- a/test/Analysis/ctor-inlining.mm +++ b/test/Analysis/ctor-inlining.mm @@ -1,4 +1,6 @@ -// RUN: %clang_cc1 -analyze -analyzer-checker=core -fobjc-arc -cfg-add-implicit-dtors -Wno-null-dereference -verify %s +// RUN: %clang_cc1 -analyze -analyzer-checker=core,debug.ExprInspection -fobjc-arc -cfg-add-implicit-dtors -Wno-null-dereference -verify %s + +void clang_analyzer_eval(bool); struct Wrapper { __strong id obj; @@ -9,3 +11,31 @@ void test() { // force a diagnostic *(char *)0 = 1; // expected-warning{{Dereference of null pointer}} } + + +struct IntWrapper { + int x; +}; + +void testCopyConstructor() { + IntWrapper a; + a.x = 42; + + IntWrapper b(a); + clang_analyzer_eval(b.x == 42); // expected-warning{{TRUE}} +} + +struct NonPODIntWrapper { + int x; + + virtual int get(); +}; + +void testNonPODCopyConstructor() { + NonPODIntWrapper a; + a.x = 42; + + NonPODIntWrapper b(a); + clang_analyzer_eval(b.x == 42); // expected-warning{{TRUE}} +} + |