summaryrefslogtreecommitdiff
path: root/test/files/neg/t6013/Base.java
diff options
context:
space:
mode:
authorJason Zaugg <jzaugg@gmail.com>2012-07-03 23:59:39 +0200
committerJason Zaugg <jzaugg@gmail.com>2012-07-04 08:13:23 +0200
commit1a2ec87c0964ad3bf42d49bbdaebd66b45506210 (patch)
tree154301d14663acfc7420a2181370012364f1b71f /test/files/neg/t6013/Base.java
parent33936243bdf597e438de8d10ae7b3ed30454be9f (diff)
downloadscala-1a2ec87c0964ad3bf42d49bbdaebd66b45506210.tar.gz
scala-1a2ec87c0964ad3bf42d49bbdaebd66b45506210.tar.bz2
scala-1a2ec87c0964ad3bf42d49bbdaebd66b45506210.zip
SI-6013 Disallow deferred members from intermediate java parents.
76c76b28f allowed for the fact that a Java method can override a super class method without matching its type in a Scala sense; it need only match its type after erasure. However that change went too far, and considered a concrete method in a base class to override a deferred method in a subclass.
Diffstat (limited to 'test/files/neg/t6013/Base.java')
-rw-r--r--test/files/neg/t6013/Base.java10
1 files changed, 10 insertions, 0 deletions
diff --git a/test/files/neg/t6013/Base.java b/test/files/neg/t6013/Base.java
new file mode 100644
index 0000000000..b73d7fd821
--- /dev/null
+++ b/test/files/neg/t6013/Base.java
@@ -0,0 +1,10 @@
+abstract public class Base {
+ // This must considered to be overridden by Abstract#foo based
+ // on the erased signatures. This special case is handled by
+ // `javaErasedOverridingSym` in `RefChecks`.
+ public abstract void bar(java.util.List<java.lang.String> foo) { return; }
+
+ // But, a concrete method in a Java superclass must not excuse
+ // a deferred method in the Java subclass!
+ public boolean foo() { return true; }
+}