blob: e3ff9e532dd05bd291f8d9c27f06f159b1738f65 (
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
24
25
26
27
28
|
import scala.reflect.runtime.universe._
import scala.reflect.runtime.{universe => ru}
import scala.reflect.runtime.{currentMirror => cm}
import scala.tools.reflect.ToolBox
class ann(bar: List[String]) extends annotation.StaticAnnotation
object Test extends App {
// test 1: reify
val tree = reify{
@ann(bar=List("1a")) @ann(bar=List("1b")) class C[@ann(bar=List("2a")) @ann(bar=List("2b")) T](@ann(bar=List("3a")) @ann(bar=List("3b")) x: T @ann(bar=List("4a")) @ann(bar=List("4b"))) {
@ann(bar=List("5a")) @ann(bar=List("5b")) def f(x: Int @ann(bar=List("6a")) @ann(bar=List("6b"))) = {
@ann(bar=List("7a")) @ann(bar=List("7b")) val r = (x + 3): @ann(bar=List("8a")) @ann(bar=List("8b"))
val s = 4: Int @ann(bar=List("9a")) @ann(bar=List("9b"))
r + s
}
}
}.tree
println(tree.toString)
// test 2: import and typecheck
val toolbox = cm.mkToolBox()
val ttree = toolbox.typecheck(tree)
println(ttree.toString)
// test 3: import and compile
toolbox.eval(tree)
}
|