Skip to content

"AssertionError: duplicate type ..." when importing traits from 2.13.4 compiled library #11173

Closed
@marcinzh

Description

@marcinzh

Minimized code

This is peculiar case to minimize, because of the dependency. Scastie seems like the best option to me, I hope it's ok.

Now Scala 3 code. Some import statements trigger the error, some don't:

import turbolift.std_effects.Except      /* ERROR */
import turbolift.std_effects.ExceptK     /* OK */
import turbolift.std_effects.Validation  /* ERROR */
import turbolift.std_effects.ValidationK /* ERROR */

Wildcard import does not trigger the error. But using the imported trait does:

import turbolift.std_effects._             /* OK */

case object MyExcept extends Except[Int]   /* ERROR */

I modified the imported 2.13.4 library by putting cloned definitions of troublesome traits inside object DottyBug {‥}. Now importing works fine:

import turbolift.std_effects.DottyBug.Except       /* OK */
import turbolift.std_effects.DottyBug.ExceptK      /* OK */
import turbolift.std_effects.DottyBug.Validation   /* OK */
import turbolift.std_effects.DottyBug.ValidationK  /* OK */

Output (click arrow to expand)

This output comes from 3.0.0-RC1-bin-20210117-65b17af-NIGHTLY.

For 3.0.0-M3 output, please see provided Scastie link.

java.lang.AssertionError: assertion failed: duplicate type E#7824; previous was type E#7817
    scala.runtime.Scala3RunTime$.assertFailed(Scala3RunTime.scala:8)
    dotty.tools.dotc.core.Scopes$MutableScope.enter(Scopes.scala:275)
    dotty.tools.dotc.core.SymDenotations$ClassDenotation.enterNoReplace(SymDenotations.scala:1867)
    dotty.tools.dotc.core.SymDenotations$ClassDenotation.enter(SymDenotations.scala:1858)
    dotty.tools.dotc.core.unpickleScala2.Scala2Unpickler.finishSym$1(Scala2Unpickler.scala:493)
    dotty.tools.dotc.core.unpickleScala2.Scala2Unpickler.readDisambiguatedSymbol(Scala2Unpickler.scala:546)
    dotty.tools.dotc.core.unpickleScala2.Scala2Unpickler.readSymbol(Scala2Unpickler.scala:327)
    dotty.tools.dotc.core.unpickleScala2.Scala2Unpickler.run(Scala2Unpickler.scala:182)
    dotty.tools.dotc.core.classfile.ClassfileParser.unpickleScala$1(ClassfileParser.scala:860)
    dotty.tools.dotc.core.classfile.ClassfileParser.unpickleOrParseInnerClasses(ClassfileParser.scala:966)
    dotty.tools.dotc.core.classfile.ClassfileParser.parseClass(ClassfileParser.scala:165)
    dotty.tools.dotc.core.classfile.ClassfileParser.run$$anonfun$1(ClassfileParser.scala:87)
    dotty.tools.dotc.core.classfile.ClassfileParser.run(ClassfileParser.scala:82)
    dotty.tools.dotc.core.ClassfileLoader.load(SymbolLoaders.scala:414)
    dotty.tools.dotc.core.ClassfileLoader.doComplete(SymbolLoaders.scala:409)
    dotty.tools.dotc.core.SymbolLoader.complete(SymbolLoaders.scala:343)
    dotty.tools.dotc.core.SymDenotations$SymDenotation.completeFrom(SymDenotations.scala:167)
    dotty.tools.dotc.core.Denotations$Denotation.completeInfo$1(Denotations.scala:188)
    dotty.tools.dotc.core.Denotations$Denotation.info(Denotations.scala:190)
    dotty.tools.dotc.core.SymDenotations$SymDenotation.ensureCompleted(SymDenotations.scala:369)
    dotty.tools.dotc.core.SymDenotations$SymDenotation.flags(SymDenotations.scala:65)
    dotty.tools.dotc.core.SymDenotations$SymDenotation.is(SymDenotations.scala:106)
    dotty.tools.dotc.sbt.ExtractDependencies.recordDependency(ExtractDependencies.scala:156)
    dotty.tools.dotc.sbt.ExtractDependencies.run$$anonfun$4(ExtractDependencies.scala:100)
    scala.runtime.function.JProcedure1.apply(JProcedure1.java:15)
    scala.runtime.function.JProcedure1.apply(JProcedure1.java:10)
    scala.collection.mutable.HashSet$Node.foreach(HashSet.scala:435)
    scala.collection.mutable.HashSet.foreach(HashSet.scala:361)
    dotty.tools.dotc.sbt.ExtractDependencies.run(ExtractDependencies.scala:100)
    dotty.tools.dotc.core.Phases$Phase.runOn$$anonfun$1(Phases.scala:300)
    scala.collection.immutable.List.map(List.scala:246)
    dotty.tools.dotc.core.Phases$Phase.runOn(Phases.scala:301)
    dotty.tools.dotc.Run.runPhases$4$$anonfun$4(Run.scala:185)
    scala.runtime.function.JProcedure1.apply(JProcedure1.java:15)
    scala.runtime.function.JProcedure1.apply(JProcedure1.java:10)
    scala.collection.ArrayOps$.foreach$extension(ArrayOps.scala:1323)
    dotty.tools.dotc.Run.runPhases$5(Run.scala:195)
    dotty.tools.dotc.Run.compileUnits$$anonfun$1(Run.scala:203)
    scala.runtime.java8.JFunction0$mcV$sp.apply(JFunction0$mcV$sp.scala:18)
    dotty.tools.dotc.util.Stats$.maybeMonitored(Stats.scala:67)
    dotty.tools.dotc.Run.compileUnits(Run.scala:210)
    dotty.tools.dotc.Run.compileSources(Run.scala:146)
    dotty.tools.dotc.Run.compile(Run.scala:130)
    dotty.tools.dotc.Driver.doCompile(Driver.scala:39)
    dotty.tools.xsbt.CompilerBridgeDriver.run(CompilerBridgeDriver.java:88)
    dotty.tools.xsbt.CompilerBridge.run(CompilerBridge.java:22)
    sbt.internal.inc.AnalyzingCompiler.compile(AnalyzingCompiler.scala:92)
    sbt.internal.inc.MixedAnalyzingCompiler.$anonfun$compile$7(MixedAnalyzingCompiler.scala:186)
    scala.runtime.java8.JFunction0$mcV$sp.apply(JFunction0$mcV$sp.java:23)
    sbt.internal.inc.MixedAnalyzingCompiler.timed(MixedAnalyzingCompiler.scala:241)
    sbt.internal.inc.MixedAnalyzingCompiler.$anonfun$compile$4(MixedAnalyzingCompiler.scala:176)
    sbt.internal.inc.MixedAnalyzingCompiler.$anonfun$compile$4$adapted(MixedAnalyzingCompiler.scala:157)
    sbt.internal.inc.JarUtils$.withPreviousJar(JarUtils.scala:239)
    sbt.internal.inc.MixedAnalyzingCompiler.compileScala$1(MixedAnalyzingCompiler.scala:157)
    sbt.internal.inc.MixedAnalyzingCompiler.compile(MixedAnalyzingCompiler.scala:204)
    sbt.internal.inc.IncrementalCompilerImpl.$anonfun$compileInternal$1(IncrementalCompilerImpl.scala:573)
    sbt.internal.inc.IncrementalCompilerImpl.$anonfun$compileInternal$1$adapted(IncrementalCompilerImpl.scala:573)
    sbt.internal.inc.Incremental$.$anonfun$apply$5(Incremental.scala:174)
    sbt.internal.inc.Incremental$.$anonfun$apply$5$adapted(Incremental.scala:172)
    sbt.internal.inc.Incremental$$anon$2.run(Incremental.scala:459)
    sbt.internal.inc.IncrementalCommon$CycleState.next(IncrementalCommon.scala:116)
    sbt.internal.inc.IncrementalCommon$$anon$1.next(IncrementalCommon.scala:56)
    sbt.internal.inc.IncrementalCommon$$anon$1.next(IncrementalCommon.scala:52)
    sbt.internal.inc.IncrementalCommon.cycle(IncrementalCommon.scala:261)
    sbt.internal.inc.Incremental$.$anonfun$incrementalCompile$8(Incremental.scala:414)
    sbt.internal.inc.Incremental$.withClassfileManager(Incremental.scala:499)
    sbt.internal.inc.Incremental$.incrementalCompile(Incremental.scala:401)
    sbt.internal.inc.Incremental$.apply(Incremental.scala:166)
    sbt.internal.inc.IncrementalCompilerImpl.compileInternal(IncrementalCompilerImpl.scala:573)
    sbt.internal.inc.IncrementalCompilerImpl.$anonfun$compileIncrementally$1(IncrementalCompilerImpl.scala:491)
    sbt.internal.inc.IncrementalCompilerImpl.handleCompilationError(IncrementalCompilerImpl.scala:332)
    sbt.internal.inc.IncrementalCompilerImpl.compileIncrementally(IncrementalCompilerImpl.scala:420)
    sbt.internal.inc.IncrementalCompilerImpl.compile(IncrementalCompilerImpl.scala:137)
    sbt.Defaults$.compileIncrementalTaskImpl(Defaults.scala:2177)
    sbt.Defaults$.$anonfun$compileIncrementalTask$2(Defaults.scala:2134)
    sbt.internal.io.Retry$.apply(Retry.scala:40)
    sbt.internal.io.Retry$.apply(Retry.scala:23)
    sbt.internal.server.BspCompileTask$.compute(BspCompileTask.scala:31)
    sbt.Defaults$.$anonfun$compileIncrementalTask$1(Defaults.scala:2130)
    scala.Function1.$anonfun$compose$1(Function1.scala:49)
    sbt.internal.util.$tilde$greater.$anonfun$$u2219$1(TypeFunctions.scala:62)
    sbt.std.Transform$$anon$4.work(Transform.scala:68)
    sbt.Execute.$anonfun$submit$2(Execute.scala:282)
    sbt.internal.util.ErrorHandling$.wideConvert(ErrorHandling.scala:23)
    sbt.Execute.work(Execute.scala:291)
    sbt.Execute.$anonfun$submit$1(Execute.scala:282)
    sbt.ConcurrentRestrictions$$anon$4.$anonfun$submitValid$1(ConcurrentRestrictions.scala:265)
    sbt.CompletionService$$anon$2.call(CompletionService.scala:64)
    java.util.concurrent.FutureTask.run(FutureTask.java:266)
    java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511)
    java.util.concurrent.FutureTask.run(FutureTask.java:266)
    java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
    java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
    java.lang.Thread.run(Thread.java:748)

The imported 2.13.4 dependency is:

resolvers += Resolver.jcenterRepo
libraryDependencies += ("com.github.marcinzh" %% "turbolift-core" % "0.8.0").withDottyCompat(scalaVersion.value)

Metadata

Metadata

Assignees

No one assigned

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions