summaryrefslogblamecommitdiff
path: root/test/files/run/macro-term-declared-in-implicit-class/Impls_Macros_1.scala
blob: ef00f6ff322df291a7ee4a3ccace4fc1fdfcbd4a (plain) (tree)
1
2
3
4
5
6
7
8
9
                                            

              
                                   
                               
                       

                                                                                                                                                  
                             








                                                 
 
import scala.reflect.macros.blackbox.Context

object Impls {
  def toOptionOfInt(c: Context) = {
    import c.{prefix => prefix}
    import c.universe._
    val printPrefix = Apply(Select(Ident(definitions.PredefModule), TermName("println")), List(Literal(Constant("prefix = " + prefix))))
    val body = Block(List(printPrefix), Apply(Ident(definitions.SomeModule), List(Select(Select(prefix.tree, TermName("x")), TermName("toInt")))))
    c.Expr[Option[Int]](body)
  }
}

object Macros {
  implicit def foo(x: String): Foo = new Foo(x)

  class Foo(val x: String) {
    def toOptionOfInt = macro Impls.toOptionOfInt
  }
}