8

scala 2.9.xではtools.nsc.Global、特定の文字列をクラスにコンパイルして実行するために直接使用していました。

scala 2.10では、次のようなものに置き換えることができます。

import scala.reflect.runtime._;
val cm = universe.runtimeMirror(getClass.getClassLoader)
import scala.tools.reflect.ToolBox;
val tb = cm.mkToolBox()
tb.eval(tb.parse("class C; new C"))

そしてそれは完璧に動作します。唯一の問題は、古い(非推奨の)アプローチでは、StoreReporterを使用してすべてのコンパイルエラーの非常にきれいな要約(エラーメッセージ、行番号を含む)を取得でき、新しいアプローチではコンパイルエラーで例外がスローされることです。

それを具体化する方法はありますか?

4

1 に答える 1

2
scala> import scala.reflect.runtime._
import scala.reflect.runtime._

scala> val cm = universe.runtimeMirror(getClass.getClassLoader)
cm: reflect.runtime.universe.Mirror = JavaMirror with ...

scala> import scala.tools.reflect.ToolBox
import scala.tools.reflect.ToolBox

scala> val tb = cm.mkToolBox()
tb: scala.tools.reflect.ToolBox[reflect.runtime.universe.type] = scala.tools.reflect.ToolBoxFactory$ToolBoxImpl@712fe0c0

scala> tb.eval(tb.parse("class C; new D"))
scala.tools.reflect.ToolBoxError: reflective compilation has failed: 

not found: type D
  at scala.tools.reflect.ToolBoxFactory$ToolBoxImpl$ToolBoxGlobal.throwIfErrors(ToolBoxFactory.scala:312)
  at scala.tools.reflect.ToolBoxFactory$ToolBoxImpl$ToolBoxGlobal.compile(ToolBoxFactory.scala:248)
  at scala.tools.reflect.ToolBoxFactory$ToolBoxImpl.compile(ToolBoxFactory.scala:407)
  at scala.tools.reflect.ToolBoxFactory$ToolBoxImpl.eval(ToolBoxFactory.scala:410)
  ...

scala> tb.frontEnd.infos
res1: ... = Set(Info(NoPosition,not found: type D,ERROR))
于 2013-01-14T22:26:59.387 に答える