blob: 8605d4a8befa706f4f7d7472cdda3329375870d5 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
import scala.reflect.makro.{Context => Ctx}
object Impls {
def toOptionOfInt(c: Ctx) = {
import c.{prefix => prefix}
import c.mirror._
val printPrefix = Apply(Select(Ident(definitions.PredefModule), newTermName("println")), List(Literal(Constant("prefix = " + prefix))))
val body = Block(printPrefix, Apply(Ident(definitions.SomeModule), List(Select(Select(prefix.tree, newTermName("x")), newTermName("toInt")))))
Expr[Option[Int]](body)
}
}
object Macros {
implicit def foo(x: String): Foo = new Foo(x)
class Foo(val x: String) {
def toOptionOfInt = macro Impls.toOptionOfInt
}
}
|