blob: a715af986c2da4239fd5685651e76b8c3f29b715 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
package scala.reflect.macros
package contexts
import scala.reflect.runtime.{universe => ru}
import scala.tools.reflect.ToolBox
trait Evals {
self: Context =>
private lazy val evalMirror = ru.runtimeMirror(universe.analyzer.defaultMacroClassloader)
private lazy val evalToolBox = evalMirror.mkToolBox()
private lazy val evalImporter = ru.internal.createImporter(universe).asInstanceOf[ru.Importer { val from: universe.type }]
def eval[T](expr: Expr[T]): T = {
expr.tree match {
case global.Literal(global.Constant(value)) =>
value.asInstanceOf[T]
case _ =>
val imported = evalImporter.importTree(expr.tree)
evalToolBox.eval(imported).asInstanceOf[T]
}
}
}
|