blob: 79597ec4e59f6e660bce102b901b01e3770ff895 (
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
29
30
31
|
import scala.reflect.macros.Context
import scala.reflect.macros.Macro
import scala.language.experimental.macros
object Enclosing {
trait Impl extends Macro {
def mono = { import c.universe._; c.Expr[Unit](Literal(Constant(()))) }
def poly[T: c.WeakTypeTag] = { import c.universe._; c.Expr[String](Literal(Constant(c.weakTypeOf[T].toString))) }
def weird = macro mono
}
}
object Macros {
def mono = macro Enclosing.Impl.mono
def poly[T] = macro Enclosing.Impl.poly[T]
}
package pkg {
object Enclosing {
trait Impl extends Macro {
def mono = { import c.universe._; c.Expr[Boolean](Literal(Constant(true))) }
def poly[T: c.WeakTypeTag] = { import c.universe._; c.Expr[String](Literal(Constant(c.weakTypeOf[T].toString + c.weakTypeOf[T].toString))) }
def weird = macro mono
}
}
object Macros {
def mono = macro Enclosing.Impl.mono
def poly[T] = macro Enclosing.Impl.poly[T]
}
}
|