forked from OSchip/llvm-project
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;' llvm-svn: 160334
This commit is contained in:
parent
514410ba07
commit
b21dd02e61
|
@ -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);
|
||||
}
|
||||
|
||||
|
|
|
@ -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)
|
||||
|
|
|
@ -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;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue