diff options
author | Eugene Burmako <xeno.by@gmail.com> | 2013-12-27 22:29:54 +0300 |
---|---|---|
committer | Eugene Burmako <xeno.by@gmail.com> | 2013-12-28 21:05:13 +0300 |
commit | d92effc8a995086c1e0c4482f6163ef17b289ede (patch) | |
tree | fee3ba6e309abe1b6c488d62721b3ce991c5bc2e /test/files/neg/t6920.scala | |
parent | bbd03b26f1eeba5abf495f5e745c6623f0cc05b7 (diff) | |
download | scala-d92effc8a995086c1e0c4482f6163ef17b289ede.tar.gz scala-d92effc8a995086c1e0c4482f6163ef17b289ede.tar.bz2 scala-d92effc8a995086c1e0c4482f6163ef17b289ede.zip |
SI-8006 prevents infinite applyDynamicNamed desugarings
Since mkInvoke, the applyDynamic/selectDynamic/etc desugarer, is disconnected
from typedNamedApply, the applyDynamicNamed argument rewriter, the latter
doesn’t know whether it needs to apply the rewriting because the application
has just been desugared or it needs to hold on because it’s already performed
a desugaring on this tree.
This commit introduces the attachment that links these translation facilities,
preventing infinite applyDynamicNamed desugarings.
Diffstat (limited to 'test/files/neg/t6920.scala')
-rw-r--r-- | test/files/neg/t6920.scala | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/test/files/neg/t6920.scala b/test/files/neg/t6920.scala new file mode 100644 index 0000000000..b79d641698 --- /dev/null +++ b/test/files/neg/t6920.scala @@ -0,0 +1,10 @@ +import scala.language.dynamics + +class DynTest extends Dynamic { + def applyDynamicNamed(name: String)(values: Seq[(String, Any)]) = "test" +} + +class CompilerError { + val test = new DynTest + test.crushTheCompiler(a = 1, b = 2) +}
\ No newline at end of file |