Uso -Xprint:typer
(para volcar árboles después Typer) junto con -Yshow-trees-compact
(para volcar los árboles en formato de AST en bruto). Si también usa -Yshow-trees-stringified
, los AST se descartarán adicionalmente como código de pseudo Scala (nota: las últimas dos opciones requieren 2.10.0).
C:\Projects\Kepler\sandbox @ ticket/6356>cat Test.scala
class C {
def x = 2
}
C:\Projects\Kepler\sandbox @ ticket/6356>scalac -Xprint:typer -Yshow-trees-compact -Yshow-trees-stringified Test.scala
[[syntax trees at end of typer]]// Scala source: Test.scala
package <empty> {
class C extends scala.AnyRef {
def <init>(): C = {
C.super.<init>();
()
};
def x: Int = 2
}
}
PackageDef(
Ident(<empty>),
List(
ClassDef(Modifiers(), newTypeName("C"), List(),
Template(List(Select(Ident(scala), newTypeName("AnyRef"))), emptyValDef,
List(
DefDef(Modifiers(), nme.CONSTRUCTOR, List(), List(List()), TypeTree(), Block(List(Apply(Select(Super(This(newTypeName("C")), tpnme.EMPTY), nme.CONSTRUCTOR), List())), Literal(Constant(())))),
DefDef(Modifiers(), newTermName("x"), List(), List(), TypeTree(), Literal(Constant(2))))))))
Pero quiero decir, ¿cómo consigo AST dentro de mi programa en ejecución? Programáticamente? – Rogach
Huh. Ya veo. Déjame pensar. –
Usando 'Run.units map (_.body)' –