diff options
Diffstat (limited to 'tests/disabled/macro/run/t5713')
-rw-r--r-- | tests/disabled/macro/run/t5713/Impls_Macros_1.scala | 28 | ||||
-rw-r--r-- | tests/disabled/macro/run/t5713/Test_2.scala | 5 |
2 files changed, 33 insertions, 0 deletions
diff --git a/tests/disabled/macro/run/t5713/Impls_Macros_1.scala b/tests/disabled/macro/run/t5713/Impls_Macros_1.scala new file mode 100644 index 000000000..7b04197cf --- /dev/null +++ b/tests/disabled/macro/run/t5713/Impls_Macros_1.scala @@ -0,0 +1,28 @@ +package m + +import language.experimental.macros +import scala.reflect.macros.blackbox.Context + +object Level extends Enumeration { + val Error = Value(5) +} + +object Logger { + def error(message: String): Unit = macro LoggerMacros.error +} + +private object LoggerMacros { + + type LoggerContext = Context { type PrefixType = Logger.type } + + def error(c: LoggerContext)(message: c.Expr[String]): c.Expr[Unit] = + log(c)(c.universe.reify(Level.Error), message) + + private def log(c: LoggerContext)(level: c.Expr[Level.Value], message: c.Expr[String]): c.Expr[Unit] = +// was: if (level.splice.id < 4) // TODO Remove hack! + if (c.eval(level).id < 4) // TODO Remove hack! + c.universe.reify(()) + else { + c.universe.reify(println(message.splice)) + } +}
\ No newline at end of file diff --git a/tests/disabled/macro/run/t5713/Test_2.scala b/tests/disabled/macro/run/t5713/Test_2.scala new file mode 100644 index 000000000..7e4d02a80 --- /dev/null +++ b/tests/disabled/macro/run/t5713/Test_2.scala @@ -0,0 +1,5 @@ +import m._ + +object Test extends dotty.runtime.LegacyApp { + Logger.error("err") +}
\ No newline at end of file |