From ccf2f81b023cbc4d82b207b95ebd3ba65bbe6259 Mon Sep 17 00:00:00 2001 From: Nicolas Stucki Date: Tue, 9 May 2023 08:54:12 +0200 Subject: [PATCH] Revert "Include top-level symbols from same file in outer ambiguity error" This reverts commit 7d4e103a941a30306ddde28a11f8bc3a8841acf8. Closes #17433 --- .../src/dotty/tools/dotc/typer/Typer.scala | 19 ++++------------ tests/neg/ambiref.check | 16 -------------- tests/neg/ambiref.scala | 22 +------------------ tests/pos-special/fatal-warnings/i9260.scala | 2 +- tests/run/protectedacc.scala | 2 +- 5 files changed, 7 insertions(+), 54 deletions(-) diff --git a/compiler/src/dotty/tools/dotc/typer/Typer.scala b/compiler/src/dotty/tools/dotc/typer/Typer.scala index 7eb8519739c6..4bc012b5b226 100644 --- a/compiler/src/dotty/tools/dotc/typer/Typer.scala +++ b/compiler/src/dotty/tools/dotc/typer/Typer.scala @@ -408,16 +408,11 @@ class Typer(@constructorOnly nestingLevel: Int = 0) extends Namer // Does reference `tp` refer only to inherited symbols? def isInherited(denot: Denotation) = def isCurrent(mbr: SingleDenotation): Boolean = - !mbr.symbol.exists || mbr.symbol.owner == ctx.owner || ctx.owner.is(Package) + !mbr.symbol.exists || mbr.symbol.owner == ctx.owner denot match case denot: SingleDenotation => !isCurrent(denot) case denot => !denot.hasAltWith(isCurrent) - /* It is an error if an identifier x is available as an inherited member in an inner scope - * and the same name x is defined in an outer scope in the same source file, unless - * the inherited member (has an overloaded alternative that) coincides with - * (an overloaded alternative of) the definition x. - */ def checkNoOuterDefs(denot: Denotation, last: Context, prevCtx: Context): Unit = def sameTermOrType(d1: SingleDenotation, d2: Denotation) = d2.containsSym(d1.symbol) || d2.hasUniqueSym && { @@ -434,15 +429,9 @@ class Typer(@constructorOnly nestingLevel: Int = 0) extends Namer val owner = outer.owner if (owner eq last.owner) && (outer.scope eq last.scope) then checkNoOuterDefs(denot, outer, prevCtx) - else if !owner.isRoot then - val found = - if owner.is(Package) then - owner.denot.asClass.membersNamed(name) - .filterWithPredicate(d => !d.symbol.is(Package) && d.symbol.source == denot.symbol.source) - else - val scope = if owner.isClass then owner.info.decls else outer.scope - scope.denotsNamed(name) - val competing = found.filterWithFlags(required, excluded | Synthetic) + else if !owner.is(Package) then + val scope = if owner.isClass then owner.info.decls else outer.scope + val competing = scope.denotsNamed(name).filterWithFlags(required, excluded) if competing.exists then val symsMatch = competing .filterWithPredicate(sd => sameTermOrType(sd, denot)) diff --git a/tests/neg/ambiref.check b/tests/neg/ambiref.check index 32b4078f1346..5d701b3b3b71 100644 --- a/tests/neg/ambiref.check +++ b/tests/neg/ambiref.check @@ -30,19 +30,3 @@ | and inherited subsequently in class E | | longer explanation available when compiling with `-explain` --- [E049] Reference Error: tests/neg/ambiref.scala:43:10 --------------------------------------------------------------- -43 | println(global) // error - | ^^^^^^ - | Reference to global is ambiguous. - | It is both defined in package - | and inherited subsequently in object D - | - | longer explanation available when compiling with `-explain` --- [E049] Reference Error: tests/neg/ambiref.scala:49:16 --------------------------------------------------------------- -49 | def t = new T { } // error - | ^ - | Reference to T is ambiguous. - | It is both defined in package p - | and inherited subsequently in class C - | - | longer explanation available when compiling with `-explain` diff --git a/tests/neg/ambiref.scala b/tests/neg/ambiref.scala index bb48997cd465..e7a5d5efbd7e 100644 --- a/tests/neg/ambiref.scala +++ b/tests/neg/ambiref.scala @@ -40,24 +40,4 @@ val global = 0 class C: val global = 1 object D extends C: - println(global) // error - -package p: - class T - trait P { trait T } - class C extends P: - def t = new T { } // error - -package scala: - trait P { trait Option[+A] } - class C extends P: - def t = new Option[String] { } // OK, competing scala.Option is not defined in the same compilation unit - -object test5: - class Mu // generates a synthetic companion object with an apply method - trait A { - val Mu = 1 - } - trait B extends A { - def t = Mu // don't warn about synthetic companion - } + println(global) // OK, since global is defined in package \ No newline at end of file diff --git a/tests/pos-special/fatal-warnings/i9260.scala b/tests/pos-special/fatal-warnings/i9260.scala index 0392c1c96fa8..df548f393eea 100644 --- a/tests/pos-special/fatal-warnings/i9260.scala +++ b/tests/pos-special/fatal-warnings/i9260.scala @@ -10,7 +10,7 @@ end AstImpl object untpd extends AstImpl[Null]: - def DefDef(ast: this.Ast): DefDef = ast match + def DefDef(ast: Ast): DefDef = ast match case ast: DefDef => ast end untpd diff --git a/tests/run/protectedacc.scala b/tests/run/protectedacc.scala index 85aa3438faa3..a08e7201fd15 100644 --- a/tests/run/protectedacc.scala +++ b/tests/run/protectedacc.scala @@ -134,7 +134,7 @@ package p { abstract class X[T] extends PolyA[T] { - trait Inner extends this.B { + trait Inner extends B { def self: T; def self2: Node; def getB: Inner;