diff options
author | Eugene Burmako <xeno.by@gmail.com> | 2012-04-27 13:27:49 +0300 |
---|---|---|
committer | Eugene Burmako <xeno.by@gmail.com> | 2012-04-27 13:32:37 +0300 |
commit | 543df62aed1fcdcf3902b9b54ec4495a882b0fcc (patch) | |
tree | f1213bd11197d06431c9830260728f4708311698 /test/files/run/t5713 | |
parent | b1aaf747754d40a721a2e3b4095b6eaf2384e770 (diff) | |
download | scala-543df62aed1fcdcf3902b9b54ec4495a882b0fcc.tar.gz scala-543df62aed1fcdcf3902b9b54ec4495a882b0fcc.tar.bz2 scala-543df62aed1fcdcf3902b9b54ec4495a882b0fcc.zip |
fixes SI-5713
Diffstat (limited to 'test/files/run/t5713')
-rw-r--r-- | test/files/run/t5713/Impls_Macros_1.scala | 27 | ||||
-rw-r--r-- | test/files/run/t5713/Test_2.scala | 5 |
2 files changed, 32 insertions, 0 deletions
diff --git a/test/files/run/t5713/Impls_Macros_1.scala b/test/files/run/t5713/Impls_Macros_1.scala new file mode 100644 index 0000000000..b499bc7e4e --- /dev/null +++ b/test/files/run/t5713/Impls_Macros_1.scala @@ -0,0 +1,27 @@ +package m + +import language.experimental.macros +import scala.reflect.makro.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.reify(Level.Error), message) + + private def log(c: LoggerContext)(level: c.Expr[Level.Value], message: c.Expr[String]): c.Expr[Unit] = + if (level.eval.id < 4) // TODO Remove hack! + c.reify(()) + else { + c.reify(println(message.eval)) + } +}
\ No newline at end of file diff --git a/test/files/run/t5713/Test_2.scala b/test/files/run/t5713/Test_2.scala new file mode 100644 index 0000000000..24f9e79b11 --- /dev/null +++ b/test/files/run/t5713/Test_2.scala @@ -0,0 +1,5 @@ +import m._ + +object Test extends App { + Logger.error("err") +}
\ No newline at end of file |