summaryrefslogtreecommitdiff
path: root/test/files/pos/t7776.scala
diff options
context:
space:
mode:
authorEugene Burmako <xeno.by@gmail.com>2013-10-18 22:12:16 +0200
committerEugene Burmako <xeno.by@gmail.com>2013-11-05 16:15:35 +0100
commit086702d8a74d6642622c6b5bb3524bd6d9abbf7e (patch)
tree07a2c9abc9b8b8471a8856d934252ebcdf1a8374 /test/files/pos/t7776.scala
parent4a6882e7729ab010848fe0744c55f096164e1853 (diff)
downloadscala-086702d8a74d6642622c6b5bb3524bd6d9abbf7e.tar.gz
scala-086702d8a74d6642622c6b5bb3524bd6d9abbf7e.tar.bz2
scala-086702d8a74d6642622c6b5bb3524bd6d9abbf7e.zip
SI-7776 post-erasure signature clashes are now macro-aware
"double definition: macro this and method that have same type after erasure" This error doesn't make sense when macros are involved, because macros expand at compile-time, where we're not affected by erasure. Moreover, macros produce no bytecode, which means that we're safe from VerifyErrors.
Diffstat (limited to 'test/files/pos/t7776.scala')
-rw-r--r--test/files/pos/t7776.scala20
1 files changed, 20 insertions, 0 deletions
diff --git a/test/files/pos/t7776.scala b/test/files/pos/t7776.scala
new file mode 100644
index 0000000000..e0584b70e2
--- /dev/null
+++ b/test/files/pos/t7776.scala
@@ -0,0 +1,20 @@
+import scala.language.experimental.macros
+import scala.reflect.macros.Context
+
+class MacroErasure {
+ def app(f: Any => Any, x: Any): Any = macro MacroErasure.appMacro
+ def app[A](f: A => Any, x: Any): Any = macro MacroErasure.appMacroA[A]
+}
+
+object MacroErasure {
+ def appMacro(c: Context)(
+ f: c.Expr[Any => Any], x: c.Expr[Any]): c.Expr[Any] = {
+ import c.universe._
+ c.Expr(q"$f($x)")
+ }
+ def appMacroA[A](c: Context)(f: c.Expr[A => Any], x: c.Expr[Any])(
+ implicit tt: c.WeakTypeTag[A]): c.Expr[Any] = {
+ import c.universe._
+ c.Expr(q"$f[${tt.tpe}]($x)")
+ }
+} \ No newline at end of file