Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / clang / test / Analysis / copypaste / functions.cpp
blob2bfe591a50bcdc6bc5640519c6fae753489ba3e5
1 // RUN: %clang_analyze_cc1 -std=c++11 -analyzer-checker=alpha.clone.CloneChecker -analyzer-config alpha.clone.CloneChecker:MinimumCloneComplexity=10 -verify %s
3 // This tests if we search for clones in functions.
5 void log();
7 int max(int a, int b) { // expected-warning{{Duplicate code detected}}
8 log();
9 if (a > b)
10 return a;
11 return b;
14 int maxClone(int x, int y) { // expected-note{{Similar code here}}
15 log();
16 if (x > y)
17 return x;
18 return y;
21 // Functions below are not clones and should not be reported.
23 // The next two functions test that statement classes are still respected when
24 // checking for clones in expressions. This will show that the statement
25 // specific data of all base classes is collected, and not just the data of the
26 // first base class.
27 int testBaseClass(int a, int b) { // no-warning
28 log();
29 if (a > b)
30 return true ? a : b;
31 return b;
33 int testBaseClass2(int a, int b) { // no-warning
34 log();
35 if (a > b)
36 return __builtin_choose_expr(true, a, b);
37 return b;
40 // No clone because of the different comparison operator.
41 int min1(int a, int b) { // no-warning
42 log();
43 if (a < b)
44 return a;
45 return b;
48 // No clone because of the different pattern in which the variables are used.
49 int min2(int a, int b) { // no-warning
50 log();
51 if (a > b)
52 return b;
53 return a;
56 int foo(int a, int b) { // no-warning
57 return a + b;