diff options
author | Dmitry Petrashko <dmitry.petrashko@gmail.com> | 2015-05-12 18:30:53 +0200 |
---|---|---|
committer | Dmitry Petrashko <dmitry.petrashko@gmail.com> | 2015-05-12 18:30:53 +0200 |
commit | 89bacb9c25a58454ff1878e67f7ea07ffc8c269f (patch) | |
tree | 51f1ff6c66aebe1b6109b1cffcc2bb8e4cf760a3 /tests/pending/run/macro-typecheck-macrosdisabled | |
parent | a0fa33deafbea1bf53edc068c5ed9db5592822f9 (diff) | |
download | dotty-89bacb9c25a58454ff1878e67f7ea07ffc8c269f.tar.gz dotty-89bacb9c25a58454ff1878e67f7ea07ffc8c269f.tar.bz2 dotty-89bacb9c25a58454ff1878e67f7ea07ffc8c269f.zip |
Run tests as they were in scala.
Diffstat (limited to 'tests/pending/run/macro-typecheck-macrosdisabled')
-rw-r--r-- | tests/pending/run/macro-typecheck-macrosdisabled/Impls_Macros_1.scala | 31 | ||||
-rw-r--r-- | tests/pending/run/macro-typecheck-macrosdisabled/Test_2.scala | 4 |
2 files changed, 35 insertions, 0 deletions
diff --git a/tests/pending/run/macro-typecheck-macrosdisabled/Impls_Macros_1.scala b/tests/pending/run/macro-typecheck-macrosdisabled/Impls_Macros_1.scala new file mode 100644 index 000000000..0e549f4ab --- /dev/null +++ b/tests/pending/run/macro-typecheck-macrosdisabled/Impls_Macros_1.scala @@ -0,0 +1,31 @@ +import scala.reflect.macros.blackbox.Context + +object Macros { + def impl_with_macros_enabled(c: Context) = { + import c.universe._ + + val ru = Select(Select(Select(Select(Ident(TermName("scala")), TermName("reflect")), TermName("runtime")), TermName("package")), TermName("universe")) + val tree1 = Apply(Select(ru, TermName("reify")), List(Literal(Constant(2)))) + val ttree1 = c.typecheck(tree1, withMacrosDisabled = false) + c.Expr[String](Literal(Constant(ttree1.toString))) + } + + def foo_with_macros_enabled = macro impl_with_macros_enabled + + def impl_with_macros_disabled(c: Context) = { + import c.universe._ + import internal._ + + val rupkg = c.mirror.staticModule("scala.reflect.runtime.package") + val rusym = reificationSupport.selectTerm(rupkg, "universe") + val NullaryMethodType(rutpe) = rusym.info + val ru = reificationSupport.newFreeTerm("ru", scala.reflect.runtime.universe) + reificationSupport.setInfo(ru, rutpe) + + val tree2 = Apply(Select(Ident(ru), TermName("reify")), List(Literal(Constant(2)))) + val ttree2 = c.typecheck(tree2, withMacrosDisabled = true) + c.Expr[String](Literal(Constant(ttree2.toString))) + } + + def foo_with_macros_disabled = macro impl_with_macros_disabled +}
\ No newline at end of file diff --git a/tests/pending/run/macro-typecheck-macrosdisabled/Test_2.scala b/tests/pending/run/macro-typecheck-macrosdisabled/Test_2.scala new file mode 100644 index 000000000..bdba39195 --- /dev/null +++ b/tests/pending/run/macro-typecheck-macrosdisabled/Test_2.scala @@ -0,0 +1,4 @@ +object Test extends App { + println(Macros.foo_with_macros_enabled) + println(Macros.foo_with_macros_disabled) +}
\ No newline at end of file |