All Downloads are FREE. Search and download functionalities are using the official Maven repository.

wartremover.warts.ToString.scala Maven / Gradle / Ivy

package org.brianmckenna.wartremover
package warts

import reflect.NameTransformer

object ToString extends WartTraverser {
  def apply(u: WartUniverse): u.Traverser = {
    import u.universe._

    val ToString: TermName = NameTransformer.encode("toString")

    def notOverridden(t: Type): Boolean = {
      val toString = t.member(ToString)
      !(t <:< typeOf[Boolean]) &&
        !(t <:< typeOf[Byte]) &&
        !(t <:< typeOf[Char]) &&
        !(t <:< typeOf[Double]) &&
        !(t <:< typeOf[Float]) &&
        !(t <:< typeOf[Int]) &&
        !(t <:< typeOf[Long]) &&
        !(t <:< typeOf[Short]) &&
        !(t <:< typeOf[String]) &&
        (toString.fullName == "scala.Any.toString" ||
          toString.fullName == "scala.AnyRef.toString" ||
          toString.fullName == "java.lang.Object.toString" ||
          toString.isSynthetic)
    }

    new Traverser {
      override def traverse(tree: Tree) = {
        tree match {
          // Ignore trees marked by SuppressWarnings
          case t if hasWartAnnotation(u)(t) =>

          case Apply(Select(lhs, ToString), _) if notOverridden(lhs.tpe) =>
            u.error(tree.pos, s"${lhs.tpe.baseClasses.head} does not override toString and automatic toString is disabled")

          case _ => super.traverse(tree)

        }
      }
    }
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy