data:image/s3,"s3://crabby-images/02ace/02ace956f9868cf2a1a780bd2c0a517cd3a46077" alt="JAR search and dependency download from the Maven repository"
org.wartremover.contrib.warts.DiscardedFuture.scala Maven / Gradle / Ivy
The newest version!
package org.wartremover
package contrib.warts
import scala.concurrent.Future
object DiscardedFuture extends WartTraverser {
val message: String =
"""andThen discards the return value of callback.
|To chain the result of Future to other Future, use flatMap.
|""".stripMargin
def apply(u: WartUniverse): u.Traverser = {
import u.universe._
val andThenMethodName: TermName = TermName("andThen")
val futureSymbol = typeOf[Future[Any]]
val andThenMethod = futureSymbol.member(andThenMethodName)
val futureTypeSymbol = futureSymbol.typeSymbol
require(andThenMethod != NoSymbol)
require(futureTypeSymbol != NoSymbol)
new Traverser {
override def traverse(tree: Tree): Unit = {
tree match {
// Ignore trees marked by SuppressWarnings
case t if hasWartAnnotation(u)(t) =>
case Apply(Apply(method, List(callback)), _)
if method.symbol == andThenMethod && callback.tpe.typeArgs(1).typeSymbol == futureTypeSymbol =>
error(u)(tree.pos, message)
super.traverse(tree)
case _ =>
super.traverse(tree)
}
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy