aboutsummaryrefslogtreecommitdiff
path: root/tests/disabled/macro/run/macro-expand-override/Impls_1.scala
blob: e6ce18f172e44dd2be1a14f030f2ce8965648ab2 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
import scala.reflect.macros.blackbox.Context

object Impls {
  def impl(c: Context)(tag: String, x: c.Expr[_]) = {
    import c.{prefix => prefix}
    import c.universe._
    val body = Apply(Select(Ident(definitions.PredefModule), TermName("println")), List(Literal(Constant(tag)), Literal(Constant(prefix.toString)), x.tree))
    c.Expr[Unit](body)
  }

  def fooBString(c: Context)(x: c.Expr[_]) = impl(c)("fooBString", x)
  def fooBInt(c: Context)(x: c.Expr[_]) = impl(c)("fooBInt", x)
  def fooDInt(c: Context)(x: c.Expr[_]) = impl(c)("fooDInt", x)
  def fooZString(c: Context)(x: c.Expr[_]) = impl(c)("fooZString", x)
}