summaryrefslogtreecommitdiff
path: root/test/files/run/t6135.scala
diff options
context:
space:
mode:
authorJason Zaugg <jzaugg@gmail.com>2012-12-03 13:14:22 +0100
committerJason Zaugg <jzaugg@gmail.com>2013-01-16 14:41:15 +0100
commit493197fce6c9c493dfa4dcdd8fd5e29bad82d49b (patch)
tree2c655aaa246d6cd8759a210f6fca12777f892330 /test/files/run/t6135.scala
parent766bb97114b5932b75340a9169558de61899997e (diff)
downloadscala-493197fce6c9c493dfa4dcdd8fd5e29bad82d49b.tar.gz
scala-493197fce6c9c493dfa4dcdd8fd5e29bad82d49b.tar.bz2
scala-493197fce6c9c493dfa4dcdd8fd5e29bad82d49b.zip
SI-6443 Widen dependent param types in uncurry
Bridge building operates on unusual method signatures: after uncurry, so parameter lists are collapsed; but before erasure, so dependently typed parameters are still around. Original: def foo(a: T)(b: a.type, c: a.U): Unit During computeBridges: (a: T, b: a.type, c: a.U)Unit This signature no longer appears to override the corresponding one in a superclass, because the types of `b` and `c` are dependent on method parameters. The root of the problem is uncurry, which leaves the trees in a poor state. This commit changes uncurry to remedy this. An example illustrates it best: // source def foo(a: A)(b: a.type): b.type = b // post uncurry before this patch. // not well typed code! def foo(a: A, b: a.type): a.type = { // post uncurry after this patch def foo(a: A, b: A): A = { val b$1 = b.asInstanceOf[a.type] b$1 }
Diffstat (limited to 'test/files/run/t6135.scala')
-rw-r--r--test/files/run/t6135.scala13
1 files changed, 13 insertions, 0 deletions
diff --git a/test/files/run/t6135.scala b/test/files/run/t6135.scala
new file mode 100644
index 0000000000..c0f8f3fd1d
--- /dev/null
+++ b/test/files/run/t6135.scala
@@ -0,0 +1,13 @@
+object Test extends App {
+ class A { class V }
+
+ abstract class B[S] {
+ def foo(t: S, a: A)(v: a.V)
+ }
+
+ val b1 = new B[String] {
+ def foo(t: String, a: A)(v: a.V) = () // Bridge method required here!
+ }
+
+ b1.foo("", null)(null)
+}