From ad598e48a6077884dd67cb316f5808cab12773b9 Mon Sep 17 00:00:00 2001 From: Johan Date: Tue, 29 Nov 2022 01:34:33 +0700 Subject: [PATCH] Reduce false positives on comparing unrelated types (#710) --- .../inspections/equality/ComparingUnrelatedTypes.scala | 5 +++++ .../equality/ComparingUnrelatedTypesTest.scala | 8 ++++++++ 2 files changed, 13 insertions(+) diff --git a/src/main/scala/com/sksamuel/scapegoat/inspections/equality/ComparingUnrelatedTypes.scala b/src/main/scala/com/sksamuel/scapegoat/inspections/equality/ComparingUnrelatedTypes.scala index 15457d19..b4f3e601 100644 --- a/src/main/scala/com/sksamuel/scapegoat/inspections/equality/ComparingUnrelatedTypes.scala +++ b/src/main/scala/com/sksamuel/scapegoat/inspections/equality/ComparingUnrelatedTypes.scala @@ -53,6 +53,11 @@ class ComparingUnrelatedTypes if integralLiteralFitsInType(lit, value.tpe) => case Apply(Select(lit @ Literal(_), TermName("$eq$eq" | "$bang$eq")), List(value)) if integralLiteralFitsInType(lit, value.tpe) => + // Comparing number types like BigDecimal to integer types causes boxing to promote + // the integer to Number to do the comparison. + case Apply(Select(lhs, TermName("$eq$eq" | "$bang$eq")), List(rhs)) + if (lhs.tpe <:< typeOf[Number] && rhs.tpe.typeSymbol.isNumericValueClass) || + (rhs.tpe <:< typeOf[Number] && lhs.tpe.typeSymbol.isNumericValueClass) => // -- End special cases ------------------------------------------------------------------ case Apply(Select(lhs, op @ TermName("$eq$eq" | "$bang$eq")), List(rhs)) => diff --git a/src/test/scala/com/sksamuel/scapegoat/inspections/equality/ComparingUnrelatedTypesTest.scala b/src/test/scala/com/sksamuel/scapegoat/inspections/equality/ComparingUnrelatedTypesTest.scala index 08031777..dbaf443f 100644 --- a/src/test/scala/com/sksamuel/scapegoat/inspections/equality/ComparingUnrelatedTypesTest.scala +++ b/src/test/scala/com/sksamuel/scapegoat/inspections/equality/ComparingUnrelatedTypesTest.scala @@ -73,6 +73,14 @@ class ComparingUnrelatedTypesTest extends InspectionTest { "for float" - { "compared to zero" in verifyNoWarnings("""object A { val f = 100f; val b = f == 0 }""") } + + "for numbers types comparing to number literals" - { + "number left hand side" in verifyNoWarnings("""object A { val a = BigDecimal(5); val b = a == 0 } """) + "number right hand side" in verifyNoWarnings( + """object A { val a = BigDecimal(5); val b = 0 != a } """ + ) + } + "for same enum values" in { val code = """object Main { def main(args: Array[String]): Unit = {