blob: 831dac6df507d9f3f1af257a12921ddc2c58c8fa (
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 = c.literalUnit
def poly[T: c.WeakTypeTag] = c.literal(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 = c.literalTrue
def poly[T: c.WeakTypeTag] = c.literal(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]
}
}
|