1 // RUN: rm -rf %t && mkdir %t
2 // RUN: mkdir -p %t/ctudir
3 // RUN: %clang_cc1 -std=c++14 -triple x86_64-pc-linux-gnu \
4 // RUN: -emit-pch -o %t/ctudir/ctu-other.cpp.ast %S/Inputs/ctu-other.cpp
5 // RUN: %clang_cc1 -std=c++14 -triple x86_64-pc-linux-gnu \
6 // RUN: -emit-pch -o %t/ctudir/ctu-chain.cpp.ast %S/Inputs/ctu-chain.cpp
7 // RUN: cp %S/Inputs/ctu-other.cpp.externalDefMap.ast-dump.txt %t/ctudir/externalDefMap.txt
9 // RUN: %clang_analyze_cc1 -std=c++14 -triple x86_64-pc-linux-gnu \
10 // RUN: -analyzer-checker=core,debug.ExprInspection \
11 // RUN: -analyzer-config eagerly-assume=false \
12 // RUN: -analyzer-config experimental-enable-naive-ctu-analysis=true \
13 // RUN: -analyzer-config ctu-dir=%t/ctudir \
14 // RUN: -analyzer-config ctu-phase1-inlining=none \
15 // RUN: -verify=newctu %s
17 // Simulate the behavior of the previous CTU implementation by inlining all
18 // functions during the first phase. This way, the second phase is a noop.
19 // RUN: %clang_analyze_cc1 -std=c++14 -triple x86_64-pc-linux-gnu \
20 // RUN: -analyzer-checker=core,debug.ExprInspection \
21 // RUN: -analyzer-config eagerly-assume=false \
22 // RUN: -analyzer-config experimental-enable-naive-ctu-analysis=true \
23 // RUN: -analyzer-config ctu-dir=%t/ctudir \
24 // RUN: -analyzer-config ctu-phase1-inlining=all \
25 // RUN: -verify=oldctu %s
27 // RUN: %clang_analyze_cc1 -std=c++14 -triple x86_64-pc-linux-gnu \
28 // RUN: -analyzer-checker=core,debug.ExprInspection \
29 // RUN: -analyzer-config experimental-enable-naive-ctu-analysis=true \
30 // RUN: -analyzer-config ctu-dir=%t/ctudir \
31 // RUN: -analyzer-config display-ctu-progress=true 2>&1 %s | FileCheck %s
33 // CHECK: CTU loaded AST file: {{.*}}ctu-other.cpp.ast
34 // CHECK: CTU loaded AST file: {{.*}}ctu-chain.cpp.ast
38 void clang_analyzer_eval(int);
44 int callback_to_main(int x
) { return x
+ 1; }
62 virtual int fvcl(int x
);
63 static int fscl(int x
);
71 class derived
: public mycls
{
73 virtual int fvcl(int x
) override
;
80 int fun_using_anon_struct(int);
81 int other_macro_diag(int);
83 extern const int extInt
;
85 extern const int extInt
;
91 extern S extNonConstS
;
94 // User declaring a dtor makes it non-trivial.
97 extern const NonTrivialS extNTS
;
98 extern const int extHere
;
99 const int extHere
= 6;
106 extern const SC extSC
;
108 static const struct SC sc
;
115 extern SCNest extSCN
;
116 extern const SCNest::SCN extSubSCN
;
124 const unsigned int b
;
128 void test_virtual_functions(mycls
* obj
) {
129 // The dynamic type is known.
130 clang_analyzer_eval(mycls().fvcl(1) == 8); // newctu-warning{{TRUE}} ctu
131 // newctu-warning@-1{{UNKNOWN}} stu
132 // oldctu-warning@-2{{TRUE}}
133 clang_analyzer_eval(derived().fvcl(1) == 9); // newctu-warning{{TRUE}} ctu
134 // newctu-warning@-1{{UNKNOWN}} stu
135 // oldctu-warning@-2{{TRUE}}
136 // We cannot decide about the dynamic type.
137 clang_analyzer_eval(obj
->fvcl(1) == 8); // newctu-warning{{TRUE}} ctu
138 // newctu-warning@-1{{UNKNOWN}} ctu, stu
139 // oldctu-warning@-2{{TRUE}}
140 // oldctu-warning@-3{{UNKNOWN}}
143 class TestAnonUnionUSR
{
145 inline float f(int value
) {
153 static const int Test
;
156 extern int testImportOfIncompleteDefaultParmDuringImport(int);
158 extern int testImportOfDelegateConstructor(int);
161 clang_analyzer_eval(f(3) == 2); // newctu-warning{{TRUE}} ctu
162 // newctu-warning@-1{{UNKNOWN}} stu
163 // oldctu-warning@-2{{TRUE}}
164 clang_analyzer_eval(f(4) == 3); // newctu-warning{{TRUE}} ctu
165 // newctu-warning@-1{{UNKNOWN}} stu
166 // oldctu-warning@-2{{TRUE}}
167 clang_analyzer_eval(f(5) == 3); // newctu-warning{{FALSE}} ctu
168 // newctu-warning@-1{{UNKNOWN}} stu
169 // oldctu-warning@-2{{FALSE}}
170 clang_analyzer_eval(g(4) == 6); // newctu-warning{{TRUE}} ctu
171 // newctu-warning@-1{{UNKNOWN}} stu
172 // oldctu-warning@-2{{TRUE}}
173 clang_analyzer_eval(h(2) == 8); // newctu-warning{{TRUE}} ctu
174 // newctu-warning@-1{{UNKNOWN}} stu
175 // oldctu-warning@-2{{TRUE}}
177 clang_analyzer_eval(myns::fns(2) == 9); // newctu-warning{{TRUE}} ctu
178 // newctu-warning@-1{{UNKNOWN}} stu
179 // oldctu-warning@-2{{TRUE}}
180 clang_analyzer_eval(myns::embed_ns::fens(2) == -1); // newctu-warning{{TRUE}} ctu
181 // newctu-warning@-1{{UNKNOWN}} stu
182 // oldctu-warning@-2{{TRUE}}
183 clang_analyzer_eval(mycls().fcl(1) == 6); // newctu-warning{{TRUE}} ctu
184 // newctu-warning@-1{{UNKNOWN}} stu
185 // oldctu-warning@-2{{TRUE}}
186 clang_analyzer_eval(mycls::fscl(1) == 7); // newctu-warning{{TRUE}} ctu
187 // newctu-warning@-1{{UNKNOWN}} stu
188 // oldctu-warning@-2{{TRUE}}
189 clang_analyzer_eval(myns::embed_cls().fecl(1) == -6); // newctu-warning{{TRUE}} ctu
190 // newctu-warning@-1{{UNKNOWN}} stu
191 // oldctu-warning@-2{{TRUE}}
192 clang_analyzer_eval(mycls::embed_cls2().fecl2(0) == -11); // newctu-warning{{TRUE}} ctu
193 // newctu-warning@-1{{UNKNOWN}} stu
194 // oldctu-warning@-2{{TRUE}}
196 clang_analyzer_eval(chns::chf1(4) == 12); // newctu-warning{{TRUE}} ctu
197 // newctu-warning@-1{{UNKNOWN}} stu
198 // oldctu-warning@-2{{TRUE}}
199 clang_analyzer_eval(fun_using_anon_struct(8) == 8); // newctu-warning{{TRUE}} ctu
200 // newctu-warning@-1{{UNKNOWN}} stu
201 // oldctu-warning@-2{{TRUE}}
203 clang_analyzer_eval(other_macro_diag(1) == 1); // newctu-warning{{TRUE}} ctu
204 // newctu-warning@-1{{UNKNOWN}} stu
205 // oldctu-warning@-2{{TRUE}}
206 // newctu-warning@Inputs/ctu-other.cpp:93{{REACHABLE}}
207 // oldctu-warning@Inputs/ctu-other.cpp:93{{REACHABLE}}
208 MACRODIAG(); // newctu-warning{{REACHABLE}}
209 // oldctu-warning@-1{{REACHABLE}}
211 // FIXME we should report an UNKNOWN as well for all external variables!
212 clang_analyzer_eval(extInt
== 2); // newctu-warning{{TRUE}}
213 // oldctu-warning@-1{{TRUE}}
214 clang_analyzer_eval(intns::extInt
== 3); // newctu-warning{{TRUE}}
215 // oldctu-warning@-1{{TRUE}}
216 clang_analyzer_eval(extS
.a
== 4); // newctu-warning{{TRUE}}
217 // oldctu-warning@-1{{TRUE}}
218 clang_analyzer_eval(extNonConstS
.a
== 4); // newctu-warning{{UNKNOWN}}
219 // oldctu-warning@-1{{UNKNOWN}}
220 // Do not import non-trivial classes' initializers.
221 clang_analyzer_eval(extNTS
.a
== 4); // newctu-warning{{UNKNOWN}}
222 // oldctu-warning@-1{{UNKNOWN}}
223 clang_analyzer_eval(extHere
== 6); // newctu-warning{{TRUE}}
224 // oldctu-warning@-1{{TRUE}}
225 clang_analyzer_eval(A::a
== 3); // newctu-warning{{TRUE}}
226 // oldctu-warning@-1{{TRUE}}
227 clang_analyzer_eval(extSC
.a
== 8); // newctu-warning{{TRUE}}
228 // oldctu-warning@-1{{TRUE}}
229 clang_analyzer_eval(ST::sc
.a
== 2); // newctu-warning{{TRUE}}
230 // oldctu-warning@-1{{TRUE}}
231 // clang_analyzer_eval(extSCN.scn.a == 9); // TODO
232 clang_analyzer_eval(extSubSCN
.a
== 1); // newctu-warning{{TRUE}}
233 // oldctu-warning@-1{{TRUE}}
234 // clang_analyzer_eval(extSCC.a == 7); // TODO
235 clang_analyzer_eval(extU
.a
== 4); // newctu-warning{{TRUE}}
236 // oldctu-warning@-1{{TRUE}}
237 clang_analyzer_eval(TestAnonUnionUSR::Test
== 5); // newctu-warning{{TRUE}}
238 // oldctu-warning@-1{{TRUE}}
240 clang_analyzer_eval(testImportOfIncompleteDefaultParmDuringImport(9) == 9);
241 // newctu-warning@-1{{TRUE}} ctu
242 // newctu-warning@-2{{UNKNOWN}} stu
243 // oldctu-warning@-3{{TRUE}}
245 clang_analyzer_eval(testImportOfDelegateConstructor(10) == 10);
246 // newctu-warning@-1{{TRUE}} ctu
247 // newctu-warning@-2{{UNKNOWN}} stu
248 // oldctu-warning@-3{{TRUE}}