diff options
Diffstat (limited to 'tests/disabled/macro/run/macro-term-declared-in-implicit-class')
-rw-r--r-- | tests/disabled/macro/run/macro-term-declared-in-implicit-class/Impls_Macros_1.scala | 19 | ||||
-rw-r--r-- | tests/disabled/macro/run/macro-term-declared-in-implicit-class/Test_2.scala | 4 |
2 files changed, 23 insertions, 0 deletions
diff --git a/tests/disabled/macro/run/macro-term-declared-in-implicit-class/Impls_Macros_1.scala b/tests/disabled/macro/run/macro-term-declared-in-implicit-class/Impls_Macros_1.scala new file mode 100644 index 000000000..ef00f6ff3 --- /dev/null +++ b/tests/disabled/macro/run/macro-term-declared-in-implicit-class/Impls_Macros_1.scala @@ -0,0 +1,19 @@ +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 + } +}
\ No newline at end of file diff --git a/tests/disabled/macro/run/macro-term-declared-in-implicit-class/Test_2.scala b/tests/disabled/macro/run/macro-term-declared-in-implicit-class/Test_2.scala new file mode 100644 index 000000000..fd67062be --- /dev/null +++ b/tests/disabled/macro/run/macro-term-declared-in-implicit-class/Test_2.scala @@ -0,0 +1,4 @@ +object Test extends dotty.runtime.LegacyApp { + import Macros._ + println("2".toOptionOfInt) +}
\ No newline at end of file |