1 use crate::consts::{constant_simple, Constant};
3 use rustc::lint::{LateContext, LateLintPass, LintArray, LintPass};
4 use rustc::{declare_tool_lint, lint_array};
5 use syntax::source_map::Span;
6 use crate::utils::{in_macro, span_lint};
8 /// **What it does:** Checks for erasing operations, e.g. `x * 0`.
10 /// **Why is this bad?** The whole expression can be replaced by zero.
11 /// This is most likely not the intended outcome and should probably be
14 /// **Known problems:** None.
18 /// 0 / x; 0 * x; x & 0
20 declare_clippy_lint! {
23 "using erasing operations, e.g. `x * 0` or `y & 0`"
26 #[derive(Copy, Clone)]
29 impl LintPass for ErasingOp {
30 fn get_lints(&self) -> LintArray {
31 lint_array!(ERASING_OP)
35 impl<'a, 'tcx> LateLintPass<'a, 'tcx> for ErasingOp {
36 fn check_expr(&mut self, cx: &LateContext<'a, 'tcx>, e: &'tcx Expr) {
40 if let ExprKind::Binary(ref cmp, ref left, ref right) = e.node {
42 BinOpKind::Mul | BinOpKind::BitAnd => {
43 check(cx, left, e.span);
44 check(cx, right, e.span);
46 BinOpKind::Div => check(cx, left, e.span),
53 fn check(cx: &LateContext<'_, '_>, e: &Expr, span: Span) {
54 if let Some(Constant::Int(v)) = constant_simple(cx, cx.tables, e) {
60 "this operation will always return zero. This is likely not the intended outcome",