blob: e81fd0dbd60a12340088ffc300e1e0c1cd9eeea0 (
plain) (
tree)
|
|
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](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 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](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 Enclosing.Impl.mono
def poly[T] = macro Enclosing.Impl.poly[T]
}
}
|