[clang][modules] Don't prevent translation of FW_Private includes when explicitly...
[llvm-project.git] / clang / test / Analysis / cxx-member-initializer-const-field.cpp
blob98076124d82b76d1bb7477d49e22466add380c4c
1 // RUN: %clang_analyze_cc1 -analyzer-checker=core -verify %s
3 // This tests false-positive issues related to PR48534.
4 //
5 // Essentially, having a default member initializer for a constant member does
6 // not necessarily imply the member will have the given default value.
8 struct WithConstructor {
9 int *const ptr = nullptr;
10 WithConstructor(int *x) : ptr(x) {}
12 static auto compliant() {
13 WithConstructor c(new int{});
14 return *(c.ptr); // no warning
17 static auto compliantWithParam(WithConstructor c) {
18 return *(c.ptr); // no warning
21 static auto issue() {
22 WithConstructor c(nullptr);
23 return *(c.ptr); // expected-warning{{Dereference of null pointer (loaded from field 'ptr')}}
27 struct RegularAggregate {
28 int *const ptr = nullptr;
30 static int compliant() {
31 RegularAggregate c{new int{}};
32 return *(c.ptr); // no warning
35 static int issue() {
36 RegularAggregate c;
37 return *(c.ptr); // expected-warning{{Dereference of null pointer (loaded from field 'ptr')}}
41 struct WithConstructorAndArithmetic {
42 int const i = 0;
43 WithConstructorAndArithmetic(int x) : i(x + 1) {}
45 static int compliant(int y) {
46 WithConstructorAndArithmetic c(0);
47 return y / c.i; // no warning
50 static int issue(int y) {
51 WithConstructorAndArithmetic c(-1);
52 return y / c.i; // expected-warning{{Division by zero}}
56 struct WithConstructorDeclarationOnly {
57 int const i = 0;
58 WithConstructorDeclarationOnly(int x); // definition not visible.
60 static int compliant1(int y) {
61 WithConstructorDeclarationOnly c(0);
62 return y / c.i; // no warning
65 static int compliant2(int y) {
66 WithConstructorDeclarationOnly c(-1);
67 return y / c.i; // no warning
71 // NonAggregateFP is not an aggregate (j is a private non-static field) and has no custom constructor.
72 // So we know i and j will always be 0 and 42, respectively.
73 // That being said, this is not implemented because it is deemed too rare to be worth the complexity.
74 struct NonAggregateFP {
75 public:
76 int const i = 0;
78 private:
79 int const j = 42;
81 public:
82 static int falsePositive1(NonAggregateFP c) {
83 return 10 / c.i; // FIXME: Currently, no warning.
86 static int falsePositive2(NonAggregateFP c) {
87 return 10 / (c.j - 42); // FIXME: Currently, no warning.
91 struct NonAggregate {
92 public:
93 int const i = 0;
95 private:
96 int const j = 42;
98 NonAggregate(NonAggregate const &); // not provided, could set i and j to arbitrary values.
100 public:
101 static int compliant1(NonAggregate c) {
102 return 10 / c.i; // no warning
105 static int compliant2(NonAggregate c) {
106 return 10 / (c.j - 42); // no warning
110 struct WithStaticMember {
111 static int const i = 0;
113 static int issue1(WithStaticMember c) {
114 return 10 / c.i; // expected-warning{{division by zero is undefined}} expected-warning{{Division by zero}}
117 static int issue2() {
118 return 10 / WithStaticMember::i; // expected-warning{{division by zero is undefined}} expected-warning{{Division by zero}}