使用反射获取在Scala中实现特征的所有类

Yad*_*nan 9 reflection scala traits

我想列出实现特定特征的所有案例类.我目前正在使用Clapper ClassUtil来做到这一点.我能够获得直接实现特征的案例类.但是,我无法获得其他没有直接实现特征的类.如何获得直接或间接实现特征的所有类.?

val finder = ClassFinder()
finder.getClasses().filter(_.isConcrete).filter(_.implements("com.myapp.MyTrait"))
Run Code Online (Sandbox Code Playgroud)

Scala版本: 2.11

Clapper Class Util版本: 1.0.6

有没有其他方法可以获得这些信息?有人能指出我正确的方向吗?我尝试使用scala.reflect但无法理解如何获取信息.

EDIT:
Run Code Online (Sandbox Code Playgroud)

样本特征和用法:

trait BaseEntity
trait NamedEntity{ val name:String}
trait MasterDataEntity extends NamedEntity

case class Department(id:Long, override val name:String) extends MasterDataEntity
case class Employee(id:Long, name:String) extends BaseEntity
case class User(id:Long, override val name:String) extends NamedEntity
Run Code Online (Sandbox Code Playgroud)

现在,如果我给出特征NamedEntity,我应该能够同时获得两者Department,User因为它们都直接或间接地实现了NamedEntity.使用implements方法,它只会给用户.我也试过使用interfaces方法,它也只提供直接超类.

0__*_*0__ 4

查看源代码,问题似乎是它不遵循接口层次结构。如果这样做,您将找到所有实例:

package foo

import java.io.File

import org.clapper.classutil.{ClassFinder, ClassInfo}

object Main extends App {
  val jar     = new File("target/scala-2.11/class_test_2.11-0.1.0.jar")
  val finder  = ClassFinder(jar :: Nil)
  val classes = ClassFinder.classInfoMap(finder.getClasses().iterator)
  val impl    = find("foo.NamedEntity", classes)
  impl.foreach(println)

  def find(ancestor: String, classes: Map[String, ClassInfo]): List[ClassInfo] =
    classes.get(ancestor).fold(List.empty[ClassInfo]) { ancestorInfo =>
      val ancestorName = ancestorInfo.name

      def compare(info: ClassInfo): Boolean =
        info.name == ancestorName ||
        (info.superClassName :: info.interfaces).exists {
          n => classes.get(n).exists(compare)
        }

      val it = classes.valuesIterator
      it.filter { info => info.isConcrete && compare(info) } .toList
    }
}
Run Code Online (Sandbox Code Playgroud)