scala.reflect.macros.contexts.Parsers.scala Maven / Gradle / Ivy
The newest version!
/*
* Scala (https://www.scala-lang.org)
*
* Copyright EPFL and Lightbend, Inc.
*
* Licensed under Apache License 2.0
* (http://www.apache.org/licenses/LICENSE-2.0).
*
* See the NOTICE file distributed with this work for
* additional information regarding copyright ownership.
*/
package scala.reflect.macros
package contexts
import scala.reflect.internal.Reporter
import scala.reflect.internal.util.FreshNameCreator
import scala.tools.nsc.reporters.StoreReporter
import scala.tools.nsc.reporters.StoreReporter.Info
trait Parsers {
self: Context =>
import global._
def parse(code: String): Tree = {
val sreporter = new StoreReporter(globalSettings)
val oldReporter = global.reporter
try {
global.reporter = sreporter
val parser = newUnitParser(new global.CompilationUnit(newSourceFile(code, "")) {
override implicit val fresh: FreshNameCreator = currentFreshNameCreator
})
val tree = gen.mkTreeOrBlock(parser.parseStatsOrPackages())
sreporter.infos.foreach {
case Info(pos, msg, Reporter.ERROR, _) => throw ParseException(pos, msg)
case _ =>
}
tree
} finally global.reporter = oldReporter
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy