diff options
Diffstat (limited to 'tests/disabled/macro/run/macro-reflective-mamd-normal-mi')
-rw-r--r-- | tests/disabled/macro/run/macro-reflective-mamd-normal-mi/Impls_1.scala | 9 | ||||
-rw-r--r-- | tests/disabled/macro/run/macro-reflective-mamd-normal-mi/Macros_Test_2.scala | 20 |
2 files changed, 29 insertions, 0 deletions
diff --git a/tests/disabled/macro/run/macro-reflective-mamd-normal-mi/Impls_1.scala b/tests/disabled/macro/run/macro-reflective-mamd-normal-mi/Impls_1.scala new file mode 100644 index 000000000..e62db783b --- /dev/null +++ b/tests/disabled/macro/run/macro-reflective-mamd-normal-mi/Impls_1.scala @@ -0,0 +1,9 @@ +import scala.reflect.macros.blackbox.Context + +object Impls { + def foo(c: Context)(x: c.Expr[Int]) = { + import c.universe._ + val body = Apply(Select(x.tree, TermName("$plus")), List(Literal(Constant(1)))) + c.Expr[Int](body) + } +} diff --git a/tests/disabled/macro/run/macro-reflective-mamd-normal-mi/Macros_Test_2.scala b/tests/disabled/macro/run/macro-reflective-mamd-normal-mi/Macros_Test_2.scala new file mode 100644 index 000000000..0b867e787 --- /dev/null +++ b/tests/disabled/macro/run/macro-reflective-mamd-normal-mi/Macros_Test_2.scala @@ -0,0 +1,20 @@ +//object Macros { +// def foo(x: Int) = macro Impls.foo +//} + +object Test extends dotty.runtime.LegacyApp { + import scala.reflect.runtime.universe._ + import scala.reflect.runtime.universe.Flag._ + import scala.reflect.runtime.{currentMirror => cm} + import scala.tools.reflect.ToolBox + + val macrobody = Select(Ident(TermName("Impls")), TermName("foo")) + val macroparam = ValDef(NoMods, TermName("x"), TypeTree(definitions.IntClass.toType), EmptyTree) + val macrodef = DefDef(Modifiers(MACRO), TermName("foo"), Nil, List(List(macroparam)), Ident(TypeName("Int")), macrobody) + val modulector = DefDef(NoMods, termNames.CONSTRUCTOR, Nil, List(List()), TypeTree(), Block(List(Apply(Select(Super(This(typeNames.EMPTY), typeNames.EMPTY), termNames.CONSTRUCTOR), List())), Literal(Constant(())))) + val module = ModuleDef(NoMods, TermName("Macros"), Template(Nil, noSelfType, List(modulector, macrodef))) + val macroapp = Apply(Select(Ident(TermName("Macros")), TermName("foo")), List(Literal(Constant(42)))) + val tree = Block(List(macrodef, module), macroapp) + val toolbox = cm.mkToolBox(options = "-language:experimental.macros") + println(toolbox.eval(tree)) +} |