aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRichard Smith <richard-llvm@metafoo.co.uk>2012-07-17 01:27:33 +0000
committerRichard Smith <richard-llvm@metafoo.co.uk>2012-07-17 01:27:33 +0000
commit6cfa78f6bd4e7d5e23366a0907f8f8792366bc4c (patch)
tree54020b0c5ce9d7ae14a94829dfeb54e435cb1bda
parent3df9a756d619dd6c560da97b514b3859c296b9a0 (diff)
Uninitialized variables: two little changes:
* Treat compound assignment as a use, at Jordy's request. * Always add compound assignments into the CFG, so we can correctly diagnose the use in 'return x += 1;' git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@160334 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--lib/Analysis/UninitializedValues.cpp4
-rw-r--r--lib/Sema/AnalysisBasedWarnings.cpp1
-rw-r--r--test/Sema/uninit-variables.c21
3 files changed, 17 insertions, 9 deletions
diff --git a/lib/Analysis/UninitializedValues.cpp b/lib/Analysis/UninitializedValues.cpp
index 1b37c29990..acf695a1e9 100644
--- a/lib/Analysis/UninitializedValues.cpp
+++ b/lib/Analysis/UninitializedValues.cpp
@@ -447,7 +447,9 @@ void ClassifyRefs::VisitBinaryOperator(BinaryOperator *BO) {
// when TransferFunctions visits it. A compound-assignment does not affect
// whether a variable is uninitialized, and there's no point counting it as a
// use.
- if (BO->isAssignmentOp())
+ if (BO->isCompoundAssignmentOp())
+ classify(BO->getLHS(), Use);
+ else if (BO->getOpcode() == BO_Assign)
classify(BO->getLHS(), Ignore);
}
diff --git a/lib/Sema/AnalysisBasedWarnings.cpp b/lib/Sema/AnalysisBasedWarnings.cpp
index d696283f7f..19a7d6f35c 100644
--- a/lib/Sema/AnalysisBasedWarnings.cpp
+++ b/lib/Sema/AnalysisBasedWarnings.cpp
@@ -1220,6 +1220,7 @@ AnalysisBasedWarnings::IssueWarnings(sema::AnalysisBasedWarnings::Policy P,
else {
AC.getCFGBuildOptions()
.setAlwaysAdd(Stmt::BinaryOperatorClass)
+ .setAlwaysAdd(Stmt::CompoundAssignOperatorClass)
.setAlwaysAdd(Stmt::BlockExprClass)
.setAlwaysAdd(Stmt::CStyleCastExprClass)
.setAlwaysAdd(Stmt::DeclRefExprClass)
diff --git a/test/Sema/uninit-variables.c b/test/Sema/uninit-variables.c
index 4e3d74b3ea..9257751e47 100644
--- a/test/Sema/uninit-variables.c
+++ b/test/Sema/uninit-variables.c
@@ -33,8 +33,8 @@ int test5() {
int test6() {
int x; // expected-note{{initialize the variable 'x' to silence this warning}}
- x += 2;
- return x; // expected-warning{{variable 'x' is uninitialized when used here}}
+ x += 2; // expected-warning{{variable 'x' is uninitialized when used here}}
+ return x;
}
int test7(int y) {
@@ -489,12 +489,17 @@ int returns_twice() {
int compound_assign(int *arr, int n) {
int sum; // expected-note {{initialize}}
for (int i = 0; i < n; ++i)
- sum += arr[i];
- return sum / n; // expected-warning {{variable 'sum' is uninitialized}}
+ sum += arr[i]; // expected-warning {{variable 'sum' is uninitialized}}
+ return sum / n;
}
-void compound_assign_2(int n) {
- volatile int ignore;
- for (int j = 0; j < n; ++j)
- ignore += test1(); // ok
+int compound_assign_2() {
+ int x; // expected-note {{initialize}}
+ return x += 1; // expected-warning {{variable 'x' is uninitialized}}
+}
+
+int compound_assign_3() {
+ int x; // expected-note {{initialize}}
+ x *= 0; // expected-warning {{variable 'x' is uninitialized}}
+ return x;
}