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

org.danielnixon.playwarts.ClassMultiWart.scala Maven / Gradle / Ivy

The newest version!
package org.danielnixon.playwarts

import org.wartremover.{ WartTraverser, WartUniverse }

abstract class ClassMultiWart(
    wartClassName: String,
    targetClassName: String,
    methods: List[(String, String)]
) extends WartTraverser {

  class Op(name: String, error: String) extends WartTraverser {
    override lazy val className: String = wartClassName

    def apply(u: WartUniverse): u.Traverser = {
      import u.universe._

      val symbol = rootMirror.staticClass(targetClassName)
      val Name = TermName(name)

      new u.Traverser {
        override def traverse(tree: Tree): Unit = {
          tree match {
            // Ignore trees marked by SuppressWarnings
            case t if hasWartAnnotation(u)(t) =>
            case Select(left, Name) if left.tpe.baseType(symbol) != NoType ⇒
              error(u)(tree.pos, error)
            // TODO: This ignores a lot
            case LabelDef(_, _, _) if isSynthetic(u)(tree) ⇒
            case _ ⇒
              super.traverse(tree)
          }
        }
      }
    }
  }

  def apply(u: WartUniverse): u.Traverser =
    WartTraverser.sumList(u)(methods.map(method => new Op(method._1, method._2)))
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy