Skip to content

Commit

Permalink
Don't lint comparison operators in arithmetic impls
Browse files Browse the repository at this point in the history
  • Loading branch information
flip1995 committed Mar 17, 2018
1 parent 03f4ae0 commit ad45918
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 1 deletion.
4 changes: 4 additions & 0 deletions clippy_lints/src/suspicious_trait_impl.rs
Expand Up @@ -61,6 +61,10 @@ impl<'a, 'tcx> LateLintPass<'a, 'tcx> for SuspiciousImpl {
fn check_expr(&mut self, cx: &LateContext<'a, 'tcx>, expr: &'tcx hir::Expr) {
use rustc::hir::BinOp_::*;
if let hir::ExprBinary(binop, _, _) = expr.node {
match binop.node {
BiEq | BiLt | BiLe | BiNe | BiGe | BiGt => return,
_ => {},
}
// Check if the binary expression is part of another bi/unary expression
// as a child node
let mut parent_expr = cx.tcx.hir.get_parent_node(expr.id);
Expand Down
6 changes: 5 additions & 1 deletion tests/ui/suspicious_arithmetic_impl.rs
Expand Up @@ -59,7 +59,11 @@ impl Sub for Bar {
type Output = Bar;

fn sub(self, other: Self) -> Self {
Bar(-(self.0 & other.0)) // OK: UnNeg part of BiExpr as parent node
if self.0 <= other.0 {
Bar(-(self.0 & other.0)) // OK: UnNeg part of BiExpr as parent node
} else {
Bar(0)
}
}
}

Expand Down

0 comments on commit ad45918

Please sign in to comment.