diff options
author | Eugene Burmako <xeno.by@gmail.com> | 2013-11-07 23:46:43 -0800 |
---|---|---|
committer | Eugene Burmako <xeno.by@gmail.com> | 2013-11-07 23:46:43 -0800 |
commit | f0cee6a244a999908f2aba1c8b59b6fd568f3c4b (patch) | |
tree | 93f47480115518105d86bd84e353af862e72f35b /test/files/pos | |
parent | e5ccdb0ebf37d07f764f903d73abcfe1fec5436b (diff) | |
parent | 086702d8a74d6642622c6b5bb3524bd6d9abbf7e (diff) | |
download | scala-f0cee6a244a999908f2aba1c8b59b6fd568f3c4b.tar.gz scala-f0cee6a244a999908f2aba1c8b59b6fd568f3c4b.tar.bz2 scala-f0cee6a244a999908f2aba1c8b59b6fd568f3c4b.zip |
Merge pull request #3101 from xeno-by/ticket/7776
SI-7776 post-erasure signature clashes are now macro-aware
Diffstat (limited to 'test/files/pos')
-rw-r--r-- | test/files/pos/t7776.check | 0 | ||||
-rw-r--r-- | test/files/pos/t7776.scala | 20 |
2 files changed, 20 insertions, 0 deletions
diff --git a/test/files/pos/t7776.check b/test/files/pos/t7776.check new file mode 100644 index 0000000000..e69de29bb2 --- /dev/null +++ b/test/files/pos/t7776.check 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 |