5

我正在使用以下代码生成 scala AST:

  val setting = new Settings(error) 
  val reporter = new ConsoleReporter(setting, in, out) {
         override def displayPrompt = ()
  }

  val compiler = new Global(setting, reporter) with ASTExtractor{
        override def onlyPresentation = true
  }
  //setting.PhasesSetting("parser", "parserPhase")
  val run = new compiler.Run
  val sourceFiles:List[String] = List("Test.scala")
  run.compile(sourceFiles.toList)

我猜这是用于在代码中运行编译器并生成要使用的 AST 的标准代码。到目前为止,上面的代码对于 Test.scala 中的任何有效 scala 代码都可以正常工作。当我在 Test.scala 中使用递归函数时,比如

def xMethod(x:Int):Int = if(x == 0) -1 else xMethod(x-1)

它给了我一个 java.lang.NullPointerException。堆栈跟踪的前几行如下所示

at scala.tools.nsc.typechecker.Typers$Typer.checkNoDoubleDefsAndAddSynthetics$1(Typers.scala:2170)
at scala.tools.nsc.typechecker.Typers$Typer.typedStats(Typers.scala:2196)
at scala.tools.nsc.typechecker.Typers$Typer.typedBlock(Typers.scala:1951)
at scala.tools.nsc.typechecker.Typers$Typer.typed1(Typers.scala:3815)
at scala.tools.nsc.typechecker.Typers$Typer.typed(Typers.scala:4124)
at scala.tools.nsc.typechecker.Typers$Typer.typed(Typers.scala:4177)
at scala.tools.nsc.transform.TailCalls$TailCallElimination.transform(TailCalls.scala:199)

该代码适用于类似的方法

def aMethod(c:Int):Int = { bMethod(c) }
def bMethod(x:Int):Int = aMethod(x)

如果递归函数需要任何其他设置,请告诉我。

4

1 回答 1

1

我不能告诉你你做错了什么,但我曾经compiler.typedTree在我的项目中得到一个 AST。也许这也适用于你。

有关更多上下文,请参阅http://scala.ifs.hsr.ch/browser/src/scala/tools/refactoring/util/CompilerProvider.scala

于 2010-04-11T11:32:09.310 回答