summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorJason Zaugg <jzaugg@gmail.com>2012-06-10 23:38:39 +0200
committerJason Zaugg <jzaugg@gmail.com>2012-06-11 00:07:24 +0200
commit617706644139d5731b10b3c77c647e3b70aa07b3 (patch)
tree86c90bc0192870477747adf38ff3f6daab57af2f /test
parent30ef129f322687cbc885d344ca73dd4877fbedd6 (diff)
downloadscala-617706644139d5731b10b3c77c647e3b70aa07b3.tar.gz
scala-617706644139d5731b10b3c77c647e3b70aa07b3.tar.bz2
scala-617706644139d5731b10b3c77c647e3b70aa07b3.zip
SI-5162 Exclude super.foo from the erasure cast of SI-4283
If the target method is defined in Java, treat the super reference as an error, otherwise allow it in the knowledge that Scala loosens the access restrictions on its generated classes. Moves the test for that bug out of pending-ville. It's sufficient to place Test in the empty package to exercise the right code paths.
Diffstat (limited to 'test')
-rw-r--r--test/files/neg/t4283b.check4
-rw-r--r--test/files/neg/t4283b/AbstractFoo.java5
-rw-r--r--test/files/neg/t4283b/ScalaBipp.scala (renamed from test/pending/run/t4283/ScalaBipp.scala)0
-rw-r--r--test/files/neg/t4283b/Test.scala3
-rw-r--r--test/files/run/t4283.check5
-rw-r--r--test/files/run/t4283/AbstractFoo.java (renamed from test/pending/run/t4283/AbstractFoo.java)0
-rw-r--r--test/files/run/t4283/ScalaBipp.scala5
-rw-r--r--test/files/run/t4283/Test.scala (renamed from test/pending/run/t4283/IllegalAccess.scala)5
-rw-r--r--test/files/run/t5162.scala19
9 files changed, 43 insertions, 3 deletions
diff --git a/test/files/neg/t4283b.check b/test/files/neg/t4283b.check
new file mode 100644
index 0000000000..30d03a310d
--- /dev/null
+++ b/test/files/neg/t4283b.check
@@ -0,0 +1,4 @@
+Test.scala:2: error: Unable to access method f in class AbstractFoo with a super reference.
+ override def f(): Int = super.f()
+ ^
+one error found
diff --git a/test/files/neg/t4283b/AbstractFoo.java b/test/files/neg/t4283b/AbstractFoo.java
new file mode 100644
index 0000000000..7abcd5e76b
--- /dev/null
+++ b/test/files/neg/t4283b/AbstractFoo.java
@@ -0,0 +1,5 @@
+package test;
+
+/* package private */ class AbstractFoo {
+ public int f() { return 2; }
+}
diff --git a/test/pending/run/t4283/ScalaBipp.scala b/test/files/neg/t4283b/ScalaBipp.scala
index 36dea9f4de..36dea9f4de 100644
--- a/test/pending/run/t4283/ScalaBipp.scala
+++ b/test/files/neg/t4283b/ScalaBipp.scala
diff --git a/test/files/neg/t4283b/Test.scala b/test/files/neg/t4283b/Test.scala
new file mode 100644
index 0000000000..0dc5636ff8
--- /dev/null
+++ b/test/files/neg/t4283b/Test.scala
@@ -0,0 +1,3 @@
+object Derived extends test.ScalaBipp {
+ override def f(): Int = super.f()
+}
diff --git a/test/files/run/t4283.check b/test/files/run/t4283.check
new file mode 100644
index 0000000000..0d27989761
--- /dev/null
+++ b/test/files/run/t4283.check
@@ -0,0 +1,5 @@
+2
+2
+1
+1
+1
diff --git a/test/pending/run/t4283/AbstractFoo.java b/test/files/run/t4283/AbstractFoo.java
index 0403271b74..0403271b74 100644
--- a/test/pending/run/t4283/AbstractFoo.java
+++ b/test/files/run/t4283/AbstractFoo.java
diff --git a/test/files/run/t4283/ScalaBipp.scala b/test/files/run/t4283/ScalaBipp.scala
new file mode 100644
index 0000000000..36dea9f4de
--- /dev/null
+++ b/test/files/run/t4283/ScalaBipp.scala
@@ -0,0 +1,5 @@
+package test
+
+class ScalaBipp extends AbstractFoo {
+ def make: Option[ScalaBipp] = Option(this)
+}
diff --git a/test/pending/run/t4283/IllegalAccess.scala b/test/files/run/t4283/Test.scala
index 33039c9350..af72fa62f9 100644
--- a/test/pending/run/t4283/IllegalAccess.scala
+++ b/test/files/run/t4283/Test.scala
@@ -1,8 +1,7 @@
-package other
+object Test {
-object IllegalAccess {
def main(args: Array[String]) {
- val x = (new test.ScalaBipp).make.get.asInstanceOf[test.ScalaBipp].f()
+ val x = (new test.ScalaBipp).make.get.asInstanceOf[test.ScalaBipp].f()
println(x)
val y = (new test.ScalaBipp).make.get.f()
println(y)
diff --git a/test/files/run/t5162.scala b/test/files/run/t5162.scala
new file mode 100644
index 0000000000..4f91932b6e
--- /dev/null
+++ b/test/files/run/t5162.scala
@@ -0,0 +1,19 @@
+// In run, rather than pos, to check for problems like SI-4283
+object O1 {
+ private[O1] class Base {
+ def foo: Int = 0
+ }
+ class Mediator extends Base
+}
+
+object O2 {
+ class Derived extends O1.Mediator {
+ override def foo: Int = super.foo
+ }
+}
+
+object Test {
+ def main(args: Array[String]) {
+ new O2.Derived().foo
+ }
+}