Scala解析器削减最后一个括号

And*_*wik 5 scala scala-compiler scala-2.11 scala-reflect scala-2.12

Welcome to Scala 2.12.1 (Java HotSpot(TM) 64-Bit Server VM, Java 1.8.0_121).
Type in expressions for evaluation. Or try :help.

scala> :paste
// Entering paste mode (ctrl-D to finish)

import scala.reflect.runtime._
import scala.reflect.runtime.universe._
import scala.tools.reflect.ToolBox

val mirror = universe.runtimeMirror(universe.getClass.getClassLoader)
val toolbox = mirror.mkToolBox(options = "-Yrangepos")
val text =
  """
    |libraryDependencies ++= Seq("org.scala-lang" % "scala-compiler" % "2.10.4") map {
    |    (dependency) =>{
    |        dependency
    |    }
    |}
  """.stripMargin
val parsed = toolbox.parse(text)

val parsedTrees = parsed match {
  case Block(stmt, expr) =>
    stmt :+ expr
  case t: Tree =>
    Seq(t)
}

val statements = parsedTrees.map { (t: Tree) =>
    text.substring(t.pos.start, t.pos.end)
}


// Exiting paste mode, now interpreting.

import scala.reflect.runtime._
import scala.reflect.runtime.universe._
import scala.tools.reflect.ToolBox
mirror: reflect.runtime.universe.Mirror = JavaMirror with primordial classloader with boot classpath...
scala> statements.head
res0: String =
libraryDependencies ++= Seq("org.scala-lang" % "scala-compiler" % "2.10.4") map {
    (dependency) =>{
        dependency
    }      
Run Code Online (Sandbox Code Playgroud)

结果是:

scala> statements.head
res1: String =
libraryDependencies ++= Seq("org.scala-lang" % "scala-compiler" % "2.10.4") map {
    (dependency) =>{
        dependency
    }
Run Code Online (Sandbox Code Playgroud)

我期望:

libraryDependencies ++= Seq("org.scala-lang" % "scala-compiler" % "2.10.4") map {
    (dependency) =>{
        dependency
    }
}
Run Code Online (Sandbox Code Playgroud)

}如果我使用Tree对象的位置,则缺少最后一个括号(和行尾):text.substring(t.pos.start, t.pos.end)

任何提议如何从scala.reflect.api.Trees#Tree对象中提取所有文本?

更新

受影响的scala版本:

  • 2.10.6 - sbt 0.13.x所需
  • 2.11.8
  • 2.12.7

对于scala 2.10.6/2.12.7,结果与上面的输出相同.

将项目添加到github

搜索解决方案的示例项目

som*_*ytt 0

只是为了将问题从未回答的列表中删除,可以参考为其预订的问题:

https://issues.scala-lang.org/browse/SI-8859