summaryrefslogtreecommitdiff
path: root/test/files/run/t5713/Impls_Macros_1.scala
diff options
context:
space:
mode:
authorEugene Burmako <xeno.by@gmail.com>2012-04-27 13:27:49 +0300
committerEugene Burmako <xeno.by@gmail.com>2012-04-27 13:32:37 +0300
commit543df62aed1fcdcf3902b9b54ec4495a882b0fcc (patch)
treef1213bd11197d06431c9830260728f4708311698 /test/files/run/t5713/Impls_Macros_1.scala
parentb1aaf747754d40a721a2e3b4095b6eaf2384e770 (diff)
downloadscala-543df62aed1fcdcf3902b9b54ec4495a882b0fcc.tar.gz
scala-543df62aed1fcdcf3902b9b54ec4495a882b0fcc.tar.bz2
scala-543df62aed1fcdcf3902b9b54ec4495a882b0fcc.zip
fixes SI-5713
Diffstat (limited to 'test/files/run/t5713/Impls_Macros_1.scala')
-rw-r--r--test/files/run/t5713/Impls_Macros_1.scala27
1 files changed, 27 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