scala.meta.internal.transversers.traverser.scala Maven / Gradle / Ivy
package scala.meta
package internal
package transversers
import scala.annotation.StaticAnnotation
import scala.language.experimental.macros
import scala.reflect.macros.whitebox.Context
class traverser extends StaticAnnotation {
def macroTransform(annottees: Any*): Any = macro TraverserMacros.impl
}
class TraverserMacros(val c: Context) extends TransverserMacros {
import c.universe._
def leafHandler(l: Leaf, treeName: TermName): Tree = {
val relevantFields = l.fields
.filter(f => !(f.tpe =:= typeOf[Any]) && !PrimitiveTpe.unapply(f.tpe))
val recursiveTraversals = relevantFields.map(f => q"this.apply($treeName.${f.name})")
q"..$recursiveTraversals"
}
def leafHandlerType(): Tree = UnitClass
def generatedMethods(): Tree = q"""
def apply(treeopt: $OptionClass[$TreeClass]): $UnitClass = treeopt match {
case $SomeModule(tree) => apply(tree)
case $NoneModule => // do nothing
}
def apply(trees: $ListClass[$TreeClass]): $UnitClass = {
trees.foreach(apply(_))
}
def apply(trees: $SeqClass[$TreeClass]): $UnitClass = {
trees.foreach(apply(_))
}
def apply(treesopt: $OptionClass[$ListClass[$TreeClass]])(implicit hack: $Hack1Class): $UnitClass = treesopt match {
case $SomeModule(trees) => apply(trees)
case $NoneModule => // do nothing
}
def apply(treesopt: $OptionClass[$SeqClass[$TreeClass]])(implicit hack: $Hack3Class): $UnitClass =
treesopt match {
case $SomeModule(trees) => apply(trees)
case $NoneModule => // do nothing
}
def apply(treess: $ListClass[$ListClass[$TreeClass]])(implicit hack: $Hack2Class): $UnitClass = {
treess.foreach(apply(_))
}
def apply(treess: $SeqClass[$SeqClass[$TreeClass]])(implicit hack: $Hack4Class): $UnitClass = {
treess.foreach(apply(_))
}
"""
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy