Skip to content

Commit

Permalink
Allow inner classes of universal traits
Browse files Browse the repository at this point in the history
Just forbid inner objects. This aligns with Scala 2 and
allows us to keep Seq's definition as in Scala 2.
  • Loading branch information
odersky committed Oct 30, 2023
1 parent 38559d7 commit 9fa6e04
Show file tree
Hide file tree
Showing 3 changed files with 3 additions and 11 deletions.
4 changes: 1 addition & 3 deletions compiler/src/dotty/tools/dotc/typer/Typer.scala
Original file line number Diff line number Diff line change
Expand Up @@ -2785,11 +2785,9 @@ class Typer(@constructorOnly nestingLevel: Int = 0) extends Namer
checkDerivedValueClass(cls, body1)

val effectiveOwner = cls.owner.skipWeakOwner
if !cls.isRefinementClass
&& !cls.isAllOf(PrivateLocal)
if cls.is(ModuleClass)
&& effectiveOwner.is(Trait)
&& !effectiveOwner.derivesFrom(defn.ObjectClass)
&& !ctx.settings.YcompileScala2Library.value // FIXME?: class PermutationsItr cannot be defined in universal trait SeqOps
then
report.error(em"$cls cannot be defined in universal $effectiveOwner", cdef.srcPos)

Expand Down
2 changes: 1 addition & 1 deletion tests/pos-special/stdlib/collection/IndexedSeq.scala
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@ trait IndexedSeq[+A] extends Seq[A]
object IndexedSeq extends SeqFactory.Delegate[IndexedSeq](immutable.IndexedSeq)

/** Base trait for indexed Seq operations */
trait IndexedSeqOps[+A, +CC[_], +C] extends AnyRef with SeqOps[A, CC, C] { self =>
trait IndexedSeqOps[+A, +CC[_], +C] extends Any with SeqOps[A, CC, C] { self =>

def iterator: Iterator[A] = view.iterator

Expand Down
8 changes: 1 addition & 7 deletions tests/pos-special/stdlib/collection/Seq.scala
Original file line number Diff line number Diff line change
Expand Up @@ -77,13 +77,7 @@ object Seq extends SeqFactory.Delegate[Seq](immutable.Seq)
* @define coll sequence
* @define Coll `Seq`
*/
trait SeqOps[+A, +CC[_], +C] extends AnyRef
// CC TODO: Our treechecker disallows classes in universal traits, but the typer accepts
// them. Since SeqOps contains nested classes, I changed it to be no longer a universal trait.
// Alternatively we could
// - Change TreeChecker to accept this
// - Move nested classes out of the trait
with IterableOps[A, CC, C] { self =>
trait SeqOps[+A, +CC[_], +C] extends Any with IterableOps[A, CC, C] { self =>

override def view: SeqView[A] = new SeqView.Id[A](this)

Expand Down

0 comments on commit 9fa6e04

Please sign in to comment.