Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / clang / test / Analysis / inlining / inline-defensive-checks.cpp
blob6fb0e1cd70b053425fcb3089617ce206f58fb11b
1 // RUN: %clang_analyze_cc1 -analyzer-checker=core -verify %s
2 // expected-no-diagnostics
4 extern void __assert_fail (__const char *__assertion, __const char *__file,
5 unsigned int __line, __const char *__function)
6 __attribute__ ((__noreturn__));
7 #define assert(expr) \
8 ((expr) ? (void)(0) : __assert_fail (#expr, __FILE__, __LINE__, __func__))
10 class ButterFly {
11 private:
12 ButterFly() { }
13 public:
14 int triggerderef() {
15 return 0;
18 ButterFly *getInP();
19 class X{
20 ButterFly *p;
21 void setP(ButterFly *inP) {
22 if(inP)
24 p = inP;
26 void subtest1() {
27 ButterFly *inP = getInP();
28 setP(inP);
30 int subtest2() {
31 int c = p->triggerderef(); // no-warning
32 return c;
34 int test() {
35 subtest1();
36 return subtest2();
40 typedef const int *Ty;
41 extern
42 Ty notNullArg(Ty cf) __attribute__((nonnull));
43 typedef const void *CFTypeRef;
44 extern Ty getTyVal();
45 inline void radar13224271_callee(Ty def, Ty& result ) {
46 result = def;
47 // Clearly indicates that result cannot be 0 if def is not NULL.
48 assert( (result != 0) || (def == 0) );
50 void radar13224271_caller()
52 Ty value;
53 radar13224271_callee(getTyVal(), value );
54 notNullArg(value); // no-warning
57 struct Foo {
58 int *ptr;
59 Foo(int *p) {
60 *p = 1; // no-warning
63 void idc(int *p3) {
64 if (p3)
67 int *retNull() {
68 return 0;
70 void test(int *p1, int *p2) {
71 idc(p1);
72 Foo f(p1);
75 struct Bar {
76 int x;
78 void idcBar(Bar *b) {
79 if (b)
82 void testRefToField(Bar *b) {
83 idcBar(b);
84 int &x = b->x; // no-warning
85 x = 5;
88 namespace get_deref_expr_with_cleanups {
89 struct S {
90 ~S();
92 S *conjure();
93 // The argument won't be used, but it'll cause cleanups
94 // to appear around the call site.
95 S *get_conjured(S _) {
96 S *s = conjure();
97 if (s) {}
98 return s;
100 void test_conjured() {
101 S &s = *get_conjured(S()); // no-warning
103 } // namespace get_deref_expr_with_cleanups