summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/compiler/scala/tools/nsc/typechecker/RefChecks.scala22
-rw-r--r--test/files/neg/t3757.check4
-rw-r--r--test/files/neg/t3757/A.java8
-rw-r--r--test/files/neg/t3757/B.scala3
4 files changed, 5 insertions, 32 deletions
diff --git a/src/compiler/scala/tools/nsc/typechecker/RefChecks.scala b/src/compiler/scala/tools/nsc/typechecker/RefChecks.scala
index 9f67d2730f..5c577d8af4 100644
--- a/src/compiler/scala/tools/nsc/typechecker/RefChecks.scala
+++ b/src/compiler/scala/tools/nsc/typechecker/RefChecks.scala
@@ -302,25 +302,14 @@ abstract class RefChecks extends InfoTransform {
if (typesOnly) checkOverrideTypes()
else {
- // todo: align accessibility implication checking with isAccessible in Contexts
if (member hasFlag PRIVATE) { // (1.1)
overrideError("has weaker access privileges; it should not be private")
}
- // o: public | protected | package-protected
- // ^-may be overridden by member with access privileges-v
- // m: public | public/protected | public/protected/package-protected-in-same-package-as-o
val mb = member.accessBoundary(member.owner)
val ob = other.accessBoundary(member.owner)
- // println("checking override in class "+ clazz +"\n other: "+ infoString(other) +" ab: "+ ob.ownerChain)
- // println(" overriding member: "+ infoString(member) +" ab: "+ mb.ownerChain)
- // todo: change
- if (mb != RootClass && // if mb is public, all is well (or is it? what if we're overriding something we can't access? -- see #3757 marker below)
- mb != NoSymbol && // if mb's access is unqualified, all is well
- ( ob == RootClass // if m is not public, but o is --> error
- || ob == NoSymbol // if m has qualified access, but o didn't --> error
- || !ob.hasTransOwner(mb) // if m has qualified access, but o's qualifier is not enclosed in m's --> error
- || (other hasFlag PROTECTED) && !(member hasFlag PROTECTED) // m must not be package-protected unless o is
- )) {
+ if (mb != RootClass && mb != NoSymbol && // todo: change
+ (ob == RootClass || ob == NoSymbol || !ob.hasTransOwner(mb) ||
+ (other hasFlag PROTECTED) && !(member hasFlag PROTECTED))) {
overrideAccessError()
}
else if (other.isClass || other.isModule) {
@@ -390,7 +379,7 @@ abstract class RefChecks extends InfoTransform {
// this overlaps somewhat with validateVariance
if(member.isAliasType) {
val kindErrors = typer.infer.checkKindBounds(List(member), List(memberTp.normalize), self, member.owner)
-
+2
if(!kindErrors.isEmpty)
unit.error(member.pos,
"The kind of the right-hand side "+memberTp.normalize+" of "+member.keyString+" "+
@@ -547,11 +536,10 @@ abstract class RefChecks extends InfoTransform {
inclazz != clazz && {
val isVarargs = hasRepeatedParam(member.tpe)
inclazz.info.nonPrivateDecl(member.name).filter { sym =>
- localTyper.context.isAccessible(sym, clazz.thisType, false) && ( // #3757: it's not enough to only look at the non-private members: might also be package-protected in another package, for example
!sym.isTerm || {
val symtpe = clazz.thisType.memberType(sym)
(member.tpe matches symtpe) || isVarargs && (toJavaRepeatedParam(member.tpe) matches symtpe)
- })
+ }
} != NoSymbol
}
diff --git a/test/files/neg/t3757.check b/test/files/neg/t3757.check
deleted file mode 100644
index f54e05abaf..0000000000
--- a/test/files/neg/t3757.check
+++ /dev/null
@@ -1,4 +0,0 @@
-B.scala:3: error: method foo overrides nothing
-class B extends a.A { override def foo = "B" }
- ^
-one error found
diff --git a/test/files/neg/t3757/A.java b/test/files/neg/t3757/A.java
deleted file mode 100644
index 25d771c538..0000000000
--- a/test/files/neg/t3757/A.java
+++ /dev/null
@@ -1,8 +0,0 @@
-package a;
-
-public abstract class A {
- abstract String foo(); // package protected!
- public void run() {
- System.out.println(foo());
- }
-} \ No newline at end of file
diff --git a/test/files/neg/t3757/B.scala b/test/files/neg/t3757/B.scala
deleted file mode 100644
index 599cde7a20..0000000000
--- a/test/files/neg/t3757/B.scala
+++ /dev/null
@@ -1,3 +0,0 @@
-package b
-
-class B extends a.A { override def foo = "B" } \ No newline at end of file