return InvalidOperands(Loc, LHS, RHS);
// Check for division by zero.
- if (IsDiv &&
- RHS.get()->isNullPointerConstant(Context,
- Expr::NPC_ValueDependentIsNotNull))
- DiagRuntimeBehavior(Loc, RHS.get(), PDiag(diag::warn_division_by_zero)
- << RHS.get()->getSourceRange());
+ llvm::APSInt RHSValue;
+ if (IsDiv && !RHS.get()->isValueDependent() &&
+ RHS.get()->EvaluateAsInt(RHSValue, Context) && RHSValue == 0)
+ DiagRuntimeBehavior(Loc, RHS.get(),
+ PDiag(diag::warn_division_by_zero)
+ << RHS.get()->getSourceRange());
return compType;
}
return InvalidOperands(Loc, LHS, RHS);
// Check for remainder by zero.
- if (RHS.get()->isNullPointerConstant(Context,
- Expr::NPC_ValueDependentIsNotNull))
- DiagRuntimeBehavior(Loc, RHS.get(), PDiag(diag::warn_remainder_by_zero)
- << RHS.get()->getSourceRange());
+ llvm::APSInt RHSValue;
+ if (!RHS.get()->isValueDependent() &&
+ RHS.get()->EvaluateAsInt(RHSValue, Context) && RHSValue == 0)
+ DiagRuntimeBehavior(Loc, RHS.get(),
+ PDiag(diag::warn_remainder_by_zero)
+ << RHS.get()->getSourceRange());
return compType;
}
--- /dev/null
+// RUN: %clang_cc1 -verify %s
+// RUN: %clang_cc1 -std=c++11 -verify %s
+// RUN: %clang_cc1 -std=c++1y -verify %s
+
+void div() {
+ (void)(42 / 0); // expected-warning{{division by zero is undefined}}
+ (void)(42 / false); // expected-warning{{division by zero is undefined}}
+ (void)(42 / !1); // expected-warning{{division by zero is undefined}}
+ (void)(42 / (1 - 1)); // expected-warning{{division by zero is undefined}}
+ (void)(42 / !(1 + 1)); // expected-warning{{division by zero is undefined}}
+ (void)(42 / (int)(0.0)); // expected-warning{{division by zero is undefined}}
+}
+
+void rem() {
+ (void)(42 % 0); // expected-warning{{remainder by zero is undefined}}
+ (void)(42 % false); // expected-warning{{remainder by zero is undefined}}
+ (void)(42 % !1); // expected-warning{{remainder by zero is undefined}}
+ (void)(42 % (1 - 1)); // expected-warning{{remainder by zero is undefined}}
+ (void)(42 % !(1 + 1)); // expected-warning{{remainder by zero is undefined}}
+ (void)(42 % (int)(0.0)); // expected-warning{{remainder by zero is undefined}}
+}