Ich möchte (statisch) eine Probe Klasse wie folgt reflektieren:Der beste Weg, Fallklassenfelder in scala 2.11 zu reflektieren?
case class Foo[T,U](stuff:T, more:U, age:Int) {
val ignore:Boolean = false
}
ich so begonnen:
val symbol = currentMirror.classSymbol(clazz) // symbol is universe.ClassSymbol
// I want to know about type placeholders T and U
val typeParamArgs = symbol.typeParams.map(tp => tp.name.toString)
if(symbol.isCaseClass) {
val tsig = symbol.typeSignature
println(tsig)
}
Ok an dieser Stelle, wenn ich tsig drucke ich sehen:
[T, U]scala.AnyRef
with scala.Product
with scala.Serializable {
val stuff: T
private[this] val stuff: T
val more: U
private[this] val more: U
val age: scala.Int
private[this] val age: scala.Int
def <init>(stuff: T,more: U,age: scala.Int): co.blocke.Foo[T,U]
val ignore: scala.Boolean
private[this] val ignore: scala.Boolean
def copy[T, U](stuff: T,more: U,age: scala.Int): co.blocke.Foo[T,U]
def copy$default$1[T, U]: T @scala.annotation.unchecked.uncheckedVariance
def copy$default$2[T, U]: U @scala.annotation.unchecked.uncheckedVariance
def copy$default$3[T, U]: scala.Int @scala.annotation.unchecked.uncheckedVariance
override def productPrefix: java.lang.String
def productArity: scala.Int
def productElement(x$1: scala.Int): scala.Any
override def productIterator: Iterator[scala.Any]
def canEqual(x$1: scala.Any): scala.Boolean
override def hashCode(): scala.Int
override def toString(): java.lang.String
override def equals(x$1: scala.Any): scala.Boolean
}
Sehen Sie diese Zeile in der Mitte mit <init>? Das ist die Erklärung, die ich inspizieren möchte. Es hat was ich brauche.
Wie kann ich auseinander tsig (universum.Type) auswählen, um Informationen über <init> zu erhalten? (Ich will nicht, Informationen über ‚ignorieren‘.)