blob: 5e1b11895d2b7cd273276abdb879c5a155eeac5a (
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
|
import scala.language.experimental.macros
import scala.reflect.macros.whitebox.Context
class Impl(val c: Context) {
def mono = { import c.universe._; c.Expr[Unit](q"()") }
def poly[T: c.WeakTypeTag] = { import c.universe._; c.Expr[String](q"${c.weakTypeOf[T].toString}") }
def weird = macro mono
}
object Macros {
def mono = macro Impl.mono
def poly[T] = macro Impl.poly[T]
}
package pkg {
class Impl(val c: Context) {
def mono = { import c.universe._; c.Expr[Boolean](q"true") }
def poly[T: c.WeakTypeTag] = { import c.universe._; c.Expr[String](q"${c.weakTypeOf[T].toString + c.weakTypeOf[T].toString}") }
def weird = macro mono
}
object Macros {
def mono = macro Impl.mono
def poly[T] = macro Impl.poly[T]
}
}
|