summaryrefslogtreecommitdiff
path: root/test/files/neg/t1705.scala
diff options
context:
space:
mode:
authorMartin Odersky <odersky@gmail.com>2009-08-10 09:57:54 +0000
committerMartin Odersky <odersky@gmail.com>2009-08-10 09:57:54 +0000
commit1e15c075c1ae03cf1d356e45606894efdc57093a (patch)
treee0240cca1416d74cdf4bf47103f6acb2c87fb4a7 /test/files/neg/t1705.scala
parentdd8009b190fc1f53f98f1313b6292579af79e309 (diff)
downloadscala-1e15c075c1ae03cf1d356e45606894efdc57093a.tar.gz
scala-1e15c075c1ae03cf1d356e45606894efdc57093a.tar.bz2
scala-1e15c075c1ae03cf1d356e45606894efdc57093a.zip
fixed t1705.
Diffstat (limited to 'test/files/neg/t1705.scala')
-rwxr-xr-xtest/files/neg/t1705.scala35
1 files changed, 35 insertions, 0 deletions
diff --git a/test/files/neg/t1705.scala b/test/files/neg/t1705.scala
new file mode 100755
index 0000000000..fabdca0ec6
--- /dev/null
+++ b/test/files/neg/t1705.scala
@@ -0,0 +1,35 @@
+package trials
+object crashing {
+ trait C {
+ abstract class T[A] {
+ def f[Z] (a:T[Z]) : T[A]
+ }
+ }
+ abstract class Thing {
+ val c = new C{
+ class T[A](a:A) {
+ def f[Z](t:T[Z]) = new T(a)
+ }
+ }
+ val x1 = {
+ class C[T] { val x: T }
+ new C[String]
+ }
+ }
+}
+/*
+
+Infinite loop in Typer.addLocals. Printing all calls to it:
+
+addLocals: Unit
+addLocals: this.T[A]
+addLocals: java.lang.Object with crashing.C{ ... }
+addLocals: >: Nothing <: java.lang.Object with crashing.C{type T[A] <: java.lang.Object with ScalaObject{def f[Z](this.T[Z]): this.T[A]}}
+addLocals: >: Nothing <: java.lang.Object with ScalaObject{def f[Z](this.T[Z]): this.T[Z]}
+addLocals: >: Nothing <: java.lang.Object with ScalaObject{def f[Z](this.T[Z]): this.T[Z]}
+addLocals: >: Nothing <: java.lang.Object with ScalaObject{def f[Z](this.T[Z]): this.T[Z]}
+[...]
+*
+ C { type T[A] <: { def f[Z]: T[Z] => T[A] } }
+
+*/