有没有办法返回List一个TypeSymbol有没有办法使用宏为包下的每个类
我想要实现的是编写一个宏,它给出与此列表等效的内容:
scala> import scala.reflect.runtime.universe._
import scala.reflect.runtime.universe._
scala> case class MyClass1()
defined class MyClass1
scala> case class MyClass2()
defined class MyClass2
scala> val typeSymbols = List(typeOf[MyClass1].typeSymbol, typeOf[MyClass2].typeSymbol)
typeSymbols: List[reflect.runtime.universe.Symbol] = List(class MyClass1, class MyClass2)
这是我的设置:
我有一个名为 的包foo,在其中定义了这些:
trait FooTrait
case class Bar() extends FooTrait 
case class Bar() extends FooTrait
这是我的宏,它获取 foo 下扩展的类的所有类型符号FooTrait:
def allTypeSymbols_impl[T: c.WeakTypeTag](c: Context)(packageName: c.Expr[String]) = {
  import c.universe._
  // Get package name from the expression tree
  val Literal(Constant(name: String)) = packageName.tree
  // Get all classes under given package name
  val pkg = c.mirror.staticPackage(name)
  // Obtain type symbols for the classes - implementation omitted
  val types = getTypeSymbols(c.universe)(List(pkg))
  // Apply method for List. For easy readability in later applications
  val listApply = Select(reify(List).tree, newTermName("apply"))
  val result = types.map {
    t =>
      val typeName = c.Expr[TypeSymbol](Ident(t))
      println(s"Typename: $typeName, $t, ${t.toType}")
      reify(typeName.splice).tree
  }
  println(s"RESULT: ${showRaw(result)}")
  c.Expr[List[reflect.runtime.universe.TypeSymbol]](Apply(listApply, result.toList))
}
第一个println打印:
Typename: Expr[c.universe.TypeSymbol](Bar), class Bar, foo.Bar
Typename: Expr[c.universe.TypeSymbol](Baz), class Baz, foo.Baz
第二个打印:
RESULT: List(Ident(foo.Bar), Ident(foo.Baz))
但我收到此错误消息:
[error] no type parameters for method any2ArrowAssoc: (x: A)ArrowAssoc[A] exist so that it can be applied to arguments (<notype>)
[error]  --- because ---
[error] argument expression's type is not compatible with formal parameter type;
[error]  found   : <notype>
[error]  required: ?A
[error] Note that <none> extends Any, not AnyRef.
[error] Such types can participate in value classes, but instances
[error] cannot appear in singleton types or in reference comparisons.
我应该怎么做才能完成这项工作?我怀疑我必须写其他东西而不是Ident,但我不知道是什么。
使用 Scala 2.10.2。
提前致谢!