- About Scala
- Documentation
- Code Examples
- Software
- Scala Developers
2.9.0 compiler crash with scala.tools.nsc.symtab.Symbols$CyclicReference: illegal cyclic reference involving method reset
Wed, 2011-05-18, 18:43
Hi scala-users,
I've managed to make the compiler crash again! Unfortunately the code
that causes it is part of a large project, and so far I've failed to
create a minimal example of the problem. I've run the compiler with
"-verbose -Ylog:icode -Ydebug". The stack trace at the crash is
immediately below, and the entire compiler output appears at the end
of this email.
If anyone has a guess as to what's causing this, maybe that will help
me find a minimal example, so I can create an issue.
best regards,
Scott Morrison
(ps -- is this is preferred mailing list for this?)
Ah, I found a minimal example, and have created an issue at
.
best regards,
Scott Morrison
On Wed, May 18, 2011 at 10:43, Scott Morrison wrote:
> Hi scala-users,
>
> I've managed to make the compiler crash again! Unfortunately the code
> that causes it is part of a large project, and so far I've failed to
> create a minimal example of the problem. I've run the compiler with
> "-verbose -Ylog:icode -Ydebug". The stack trace at the crash is
> immediately below, and the entire compiler output appears at the end
> of this email.
>
> If anyone has a guess as to what's causing this, maybe that will help
> me find a minimal example, so I can create an issue.
>
> best regards,
> Scott Morrison
>
> (ps -- is this is preferred mailing list for this?)
>
> ----- stacktrace from compiler -----
>
> [info] [running phase typer on DirectedFusionGraph.scala]
> [info] [loaded class file
> /System/Library/Java/JavaVirtualMachines/1.6.0.jdk/Contents/Classes/classes.jar(java/lang/UnsupportedOperationException.class)
> in 1ms]
> ... trying to complete method reset
> scala.tools.nsc.symtab.Symbols$CyclicReference: illegal cyclic
> reference involving method reset
> at scala.tools.nsc.symtab.Symbols$Symbol$$anonfun$info$3.apply(Symbols.scala:722)
> at scala.tools.nsc.symtab.Symbols$Symbol$$anonfun$info$3.apply(Symbols.scala:720)
> at scala.Function0$class.apply$mcV$sp(Function0.scala:34)
> at scala.runtime.AbstractFunction0.apply$mcV$sp(AbstractFunction0.scala:12)
> at scala.tools.nsc.symtab.Symbols$Symbol.lock(Symbols.scala:308)
> at scala.tools.nsc.symtab.Symbols$Symbol.info(Symbols.scala:720)
> at scala.tools.nsc.symtab.Symbols$Symbol.tpe(Symbols.scala:704)
> at scala.tools.nsc.symtab.Symbols$Symbol.tpeHK(Symbols.scala:891)
> at scala.tools.nsc.symtab.Types$Type.computeMemberType(Types.scala:569)
> at scala.tools.nsc.symtab.Symbols$MethodSymbol.typeAsMemberOf(Symbols.scala:1867)
> at scala.tools.nsc.symtab.Types$Type.memberType(Types.scala:564)
> at scala.tools.nsc.symtab.Types$Type.findMember(Types.scala:907)
> at scala.tools.nsc.symtab.Types$Type.nonPrivateMember(Types.scala:507)
> at scala.tools.nsc.symtab.Types$class.refines$1(Types.scala:5194)
> at scala.tools.nsc.symtab.Types$$anonfun$37$$anonfun$apply$14.apply(Types.scala:5203)
> at scala.tools.nsc.symtab.Types$$anonfun$37$$anonfun$apply$14.apply(Types.scala:5203)
> at scala.collection.LinearSeqOptimized$class.forall(LinearSeqOptimized.scala:69)
> at scala.collection.immutable.List.forall(List.scala:45)
> at scala.tools.nsc.symtab.Types$$anonfun$37.apply(Types.scala:5203)
> at scala.tools.nsc.symtab.Types$$anonfun$37.apply(Types.scala:5200)
> at scala.collection.LinearSeqOptimized$class.foreach(LinearSeqOptimized.scala:59)
> at scala.collection.immutable.List.foreach(List.scala:45)
> at scala.tools.nsc.symtab.Types$class.lub1$1(Types.scala:5200)
> at scala.tools.nsc.symtab.Types$class.lub0$1(Types.scala:5154)
> at scala.tools.nsc.symtab.Types$class.lub(Types.scala:5224)
> at scala.tools.nsc.symtab.SymbolTable.lub(SymbolTable.scala:13)
> at scala.tools.nsc.symtab.Types$$anonfun$51.apply(Types.scala:5419)
> at scala.tools.nsc.symtab.Types$$anonfun$51.apply(Types.scala:5410)
> at scala.Tuple2$Zipped$$anonfun$map$1.apply(Tuple2.scala:65)
> at scala.Tuple2$Zipped$$anonfun$map$1.apply(Tuple2.scala:63)
> at scala.collection.LinearSeqOptimized$class.foreach(LinearSeqOptimized.scala:59)
> at scala.collection.immutable.List.foreach(List.scala:45)
> at scala.Tuple2$Zipped.map(Tuple2.scala:63)
> at scala.tools.nsc.symtab.Types$class.mergePrefixAndArgs(Types.scala:5409)
> at scala.tools.nsc.symtab.SymbolTable.mergePrefixAndArgs(SymbolTable.scala:13)
> at scala.tools.nsc.symtab.BaseTypeSeqs$BaseTypeSeq.apply(BaseTypeSeqs.scala:59)
> at scala.tools.nsc.symtab.Types$CompoundType.baseType(Types.scala:1361)
> at scala.tools.nsc.symtab.Types$SimpleTypeProxy$class.baseType(Types.scala:196)
> at scala.tools.nsc.symtab.Types$SingletonType.baseType(Types.scala:1033)
> at scala.tools.nsc.symtab.Types$AsSeenFromMap.toInstance$1(Types.scala:3393)
> at scala.tools.nsc.symtab.Types$AsSeenFromMap.apply(Types.scala:3413)
> at scala.tools.nsc.symtab.Types$AsSeenFromMap.apply(Types.scala:3282)
> at scala.tools.nsc.symtab.Types$TypeMap.mapOver(Types.scala:3026)
> at scala.tools.nsc.symtab.Types$AsSeenFromMap.apply(Types.scala:3415)
> at scala.tools.nsc.symtab.Types$Type.asSeenFrom(Types.scala:544)
> at scala.tools.nsc.symtab.Types$Type.computeMemberType(Types.scala:573)
> at scala.tools.nsc.symtab.Symbols$MethodSymbol.typeAsMemberOf(Symbols.scala:1867)
> at scala.tools.nsc.symtab.Types$Type.memberType(Types.scala:564)
> at scala.tools.nsc.typechecker.Namers$Namer$$anonfun$overriddenSymbol$1$1.apply(Namers.scala:889)
> at scala.tools.nsc.typechecker.Namers$Namer$$anonfun$overriddenSymbol$1$1.apply(Namers.scala:882)
> at scala.tools.nsc.symtab.Symbols$Symbol.filter(Symbols.scala:1060)
> at scala.tools.nsc.typechecker.Namers$Namer.overriddenSymbol$1(Namers.scala:882)
> at scala.tools.nsc.typechecker.Namers$Namer.methodSig(Namers.scala:897)
> at scala.tools.nsc.typechecker.Namers$Namer.typeSig(Namers.scala:1187)
> at scala.tools.nsc.typechecker.Namers$Namer$$anonfun$typeCompleter$1.apply(Namers.scala:551)
> at scala.tools.nsc.typechecker.Namers$Namer$$anonfun$typeCompleter$1.apply(Namers.scala:549)
> at scala.tools.nsc.typechecker.Namers$$anon$1.complete(Namers.scala:1376)
> at scala.tools.nsc.typechecker.Namers$$anon$1.complete(Namers.scala:1372)
> at scala.tools.nsc.symtab.Symbols$Symbol.info(Symbols.scala:732)
> at scala.tools.nsc.symtab.Symbols$Symbol.tpe(Symbols.scala:704)
> at scala.tools.nsc.symtab.Symbols$Symbol.tpeHK(Symbols.scala:891)
> at scala.tools.nsc.symtab.Types$Type.computeMemberType(Types.scala:569)
> at scala.tools.nsc.symtab.Symbols$MethodSymbol.typeAsMemberOf(Symbols.scala:1867)
> at scala.tools.nsc.symtab.Types$Type.memberType(Types.scala:564)
> at scala.tools.nsc.symtab.Types$Type.findMember(Types.scala:907)
> at scala.tools.nsc.symtab.Types$Type.nonLocalMember(Types.scala:518)
> at scala.tools.nsc.typechecker.Typers$Typer.member(Typers.scala:604)
> at scala.tools.nsc.typechecker.Typers$Typer.typedSelect$1(Typers.scala:3529)
> at scala.tools.nsc.typechecker.Typers$Typer.typed1(Typers.scala:4120)
> at scala.tools.nsc.typechecker.Typers$Typer.typed(Typers.scala:4214)
> at scala.tools.nsc.typechecker.Typers$Typer.typedQualifier(Typers.scala:4282)
> at scala.tools.nsc.typechecker.Typers$Typer.typedQualifier(Typers.scala:4288)
> at scala.tools.nsc.typechecker.Typers$Typer.typed1(Typers.scala:4099)
> at scala.tools.nsc.typechecker.Typers$Typer.typed(Typers.scala:4214)
> at scala.tools.nsc.typechecker.Typers$Typer.typed(Typers.scala:4276)
> at scala.tools.nsc.typechecker.Typers$Typer.computeType(Typers.scala:4353)
> at scala.tools.nsc.typechecker.Namers$Namer.typeSig(Namers.scala:1198)
> at scala.tools.nsc.typechecker.Namers$Namer$$anonfun$typeCompleter$1.apply(Namers.scala:551)
> at scala.tools.nsc.typechecker.Namers$Namer$$anonfun$typeCompleter$1.apply(Namers.scala:549)
> at scala.tools.nsc.typechecker.Namers$$anon$1.complete(Namers.scala:1376)
> at scala.tools.nsc.typechecker.Namers$$anon$1.complete(Namers.scala:1372)
> at scala.tools.nsc.symtab.Symbols$Symbol.info(Symbols.scala:732)
> at scala.tools.nsc.symtab.Symbols$Symbol.initialize(Symbols.scala:844)
> at scala.tools.nsc.typechecker.Typers$Typer.typed1(Typers.scala:3852)
> at scala.tools.nsc.typechecker.Typers$Typer.typed(Typers.scala:4214)
> at scala.tools.nsc.typechecker.Typers$Typer.typedStat$1(Typers.scala:2094)
> at scala.tools.nsc.typechecker.Typers$Typer$$anonfun$24.apply(Typers.scala:2178)
> at scala.tools.nsc.typechecker.Typers$Typer$$anonfun$24.apply(Typers.scala:2178)
> at scala.collection.immutable.List.loop$1(List.scala:117)
> at scala.collection.immutable.List.mapConserve(List.scala:133)
> at scala.tools.nsc.typechecker.Typers$Typer.typedStats(Typers.scala:2178)
> at scala.tools.nsc.typechecker.Typers$Typer.typedBlock(Typers.scala:1913)
> at scala.tools.nsc.typechecker.Typers$Typer.typed1(Typers.scala:3906)
> at scala.tools.nsc.typechecker.Typers$Typer.typed(Typers.scala:4214)
> at scala.tools.nsc.typechecker.Typers$Typer.typedArg(Typers.scala:2185)
> at scala.tools.nsc.typechecker.Typers$Typer$$anonfun$typedArgs$3.apply(Typers.scala:2198)
> at scala.tools.nsc.typechecker.Typers$Typer$$anonfun$typedArgs$3.apply(Typers.scala:2197)
> at scala.Tuple3$Zipped$$anonfun$map$1.apply(Tuple3.scala:66)
> at scala.Tuple3$Zipped$$anonfun$map$1.apply(Tuple3.scala:64)
> at scala.collection.LinearSeqOptimized$class.foreach(LinearSeqOptimized.scala:59)
> at scala.collection.immutable.List.foreach(List.scala:45)
> at scala.Tuple3$Zipped.map(Tuple3.scala:64)
> at scala.tools.nsc.typechecker.Typers$Typer.typedArgs(Typers.scala:2197)
> at scala.tools.nsc.typechecker.Typers$Typer.doTypedApply(Typers.scala:2415)
> at scala.tools.nsc.typechecker.Typers$Typer$$anonfun$tryTypedApply$1$1.apply(Typers.scala:3282)
> at scala.tools.nsc.typechecker.Typers$Typer$$anonfun$tryTypedApply$1$1.apply(Typers.scala:3282)
> at scala.tools.nsc.typechecker.Typers$Typer.silent(Typers.scala:623)
> at scala.tools.nsc.typechecker.Typers$Typer.tryTypedApply$1(Typers.scala:3282)
> at scala.tools.nsc.typechecker.Typers$Typer.typedApply$1(Typers.scala:3342)
> at scala.tools.nsc.typechecker.Typers$Typer.typed1(Typers.scala:4059)
> at scala.tools.nsc.typechecker.Typers$Typer.typed(Typers.scala:4214)
> at scala.tools.nsc.typechecker.Typers$Typer.typed(Typers.scala:4276)
> at scala.tools.nsc.typechecker.Typers$Typer.computeType(Typers.scala:4353)
> at scala.tools.nsc.typechecker.Namers$Namer.methodSig(Namers.scala:947)
> at scala.tools.nsc.typechecker.Namers$Namer.typeSig(Namers.scala:1187)
> at scala.tools.nsc.typechecker.Namers$Namer$$anonfun$typeCompleter$1.apply(Namers.scala:551)
> at scala.tools.nsc.typechecker.Namers$Namer$$anonfun$typeCompleter$1.apply(Namers.scala:549)
> at scala.tools.nsc.typechecker.Namers$$anon$1.complete(Namers.scala:1376)
> at scala.tools.nsc.typechecker.Namers$$anon$1.complete(Namers.scala:1372)
> at scala.tools.nsc.symtab.Symbols$Symbol.info(Symbols.scala:732)
> at scala.tools.nsc.symtab.Symbols$Symbol.initialize(Symbols.scala:844)
> at scala.tools.nsc.typechecker.Typers$Typer.typed1(Typers.scala:3852)
> at scala.tools.nsc.typechecker.Typers$Typer.typed(Typers.scala:4214)
> at scala.tools.nsc.typechecker.Typers$Typer.typedStat$1(Typers.scala:2094)
> at scala.tools.nsc.typechecker.Typers$Typer$$anonfun$24.apply(Typers.scala:2178)
> at scala.tools.nsc.typechecker.Typers$Typer$$anonfun$24.apply(Typers.scala:2178)
> at scala.collection.immutable.List.loop$1(List.scala:117)
> at scala.collection.immutable.List.mapConserve(List.scala:133)
> at scala.tools.nsc.typechecker.Typers$Typer.typedStats(Typers.scala:2178)
> at scala.tools.nsc.typechecker.Typers$Typer.typedTemplate(Typers.scala:1506)
> at scala.tools.nsc.typechecker.Typers$Typer.typedClassDef(Typers.scala:1271)
> at scala.tools.nsc.typechecker.Typers$Typer.typed1(Typers.scala:3865)
> at scala.tools.nsc.typechecker.Typers$Typer.typed(Typers.scala:4214)
> at scala.tools.nsc.typechecker.Typers$Typer.typedStat$1(Typers.scala:2094)
> at scala.tools.nsc.typechecker.Typers$Typer$$anonfun$24.apply(Typers.scala:2178)
> at scala.tools.nsc.typechecker.Typers$Typer$$anonfun$24.apply(Typers.scala:2178)
> at scala.collection.immutable.List.loop$1(List.scala:117)
> at scala.collection.immutable.List.mapConserve(List.scala:133)
> at scala.tools.nsc.typechecker.Typers$Typer.typedStats(Typers.scala:2178)
> at scala.tools.nsc.typechecker.Typers$Typer.typed1(Typers.scala:3861)
> at scala.tools.nsc.typechecker.Typers$Typer.typed(Typers.scala:4214)
> at scala.tools.nsc.typechecker.Typers$Typer.typed(Typers.scala:4263)
> at scala.tools.nsc.typechecker.Analyzer$typerFactory$$anon$3.apply(Analyzer.scala:94)
> at scala.tools.nsc.Global$GlobalPhase$$anonfun$applyPhase$1.apply(Global.scala:326)
> at scala.tools.nsc.Global$GlobalPhase$$anonfun$applyPhase$1.apply(Global.scala:326)
> at scala.tools.nsc.reporters.Reporter.withSource(Reporter.scala:47)
> at scala.tools.nsc.Global$GlobalPhase.applyPhase(Global.scala:326)
> at scala.tools.nsc.typechecker.Analyzer$typerFactory$$anon$3$$anonfun$run$1.apply(Analyzer.scala:86)
> at scala.tools.nsc.typechecker.Analyzer$typerFactory$$anon$3$$anonfun$run$1.apply(Analyzer.scala:86)
> at scala.collection.Iterator$class.foreach(Iterator.scala:652)
> at scala.collection.mutable.ListBuffer$$anon$1.foreach(ListBuffer.scala:311)
> at scala.tools.nsc.typechecker.Analyzer$typerFactory$$anon$3.run(Analyzer.scala:86)
> at scala.tools.nsc.Global$Run.compileSources(Global.scala:949)
> at scala.tools.nsc.Global$Run.compile(Global.scala:1034)
> at xsbt.CompilerInterface.run(CompilerInterface.scala:81)
> at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
> at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
> at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
> at java.lang.reflect.Method.invoke(Method.java:597)
> at xsbt.AnalyzingCompiler.call(AnalyzingCompiler.scala:40)
> at xsbt.AnalyzingCompiler.apply(AnalyzingCompiler.scala:18)
> at sbt.Compile.processScala(Compile.scala:76)
> at sbt.CompilerCore$$anonfun$1.apply(Compile.scala:27)
> at sbt.CompilerCore$$anonfun$1.apply(Compile.scala:27)
> at sbt.CompilerCore$$anonfun$process$1$1.apply(Compile.scala:22)
> at sbt.CompilerCore$$anonfun$process$1$1.apply(Compile.scala:22)
> at sbt.CompilerCore$$anonfun$doCompile$3.apply(Compile.scala:45)
> at sbt.CompilerCore$$anonfun$doCompile$3.apply(Compile.scala:42)
> at scala.Option.orElse(Option.scala:102)
> at sbt.CompilerCore.doCompile(Compile.scala:41)
> at sbt.CompilerCore.apply(Compile.scala:29)
> at sbt.AbstractCompileConditional.run$1(Conditional.scala:341)
> at sbt.AbstractCompileConditional$$anonfun$3.apply(Conditional.scala:344)
> at sbt.AbstractCompileConditional$$anonfun$3.apply(Conditional.scala:344)
> at sbt.classfile.Analyze$.apply(Analyze.scala:110)
> at sbt.AbstractCompileConditional.execute(Conditional.scala:344)
> at sbt.Conditional$class.run(Conditional.scala:43)
> at sbt.AbstractCompileConditional.run(Conditional.scala:231)
> at sbt.BasicScalaProject.sbt$BasicScalaProject$$doCompile(DefaultProject.scala:259)
> at sbt.BasicScalaProject$$anonfun$compileAction$1.apply(DefaultProject.scala:273)
> at sbt.BasicScalaProject$$anonfun$compileAction$1.apply(DefaultProject.scala:273)
> at sbt.TaskManager$Task.invoke(TaskManager.scala:62)
> at sbt.impl.RunTask.doRun$1(RunTask.scala:77)
> at sbt.impl.RunTask.runTask(RunTask.scala:85)
> at sbt.impl.RunTask.run(RunTask.scala:32)
> at sbt.impl.RunTask$.apply(RunTask.scala:17)
> at sbt.impl.RunTask$.apply(RunTask.scala:16)
> at sbt.Project$class.run(Project.scala:98)
> at sbt.Project$class.act(Project.scala:129)
> at sbt.BasicScalaProject.act(DefaultProject.scala:21)
> at sbt.xMain$$anonfun$8.apply(Main.scala:512)
> at sbt.xMain$$anonfun$8.apply(Main.scala:512)
> at sbt.xMain.withAction(Main.scala:545)
> at sbt.xMain.sbt$xMain$$handleAction(Main.scala:512)
> at sbt.xMain.handleCommand(Main.scala:502)
> at sbt.xMain.processAction(Main.scala:441)
> at sbt.xMain.process$1(Main.scala:257)
> at sbt.xMain.processArguments(Main.scala:266)
> at sbt.xMain.startProject(Main.scala:107)
> at sbt.xMain.run(Main.scala:84)
> at sbt.xMain.run0$1(Main.scala:35)
> at sbt.xMain.run(Main.scala:42)
> at xsbt.boot.Launch$.run(Launch.scala:53)
> at xsbt.boot.Launch$$anonfun$explicit$1.apply(Launch.scala:42)
> at xsbt.boot.Launch$$anonfun$explicit$1.apply(Launch.scala:42)
> at xsbt.boot.Launch$.launch(Launch.scala:57)
> at xsbt.boot.Launch$.explicit(Launch.scala:42)
> at xsbt.boot.Launch$.initialized(Launch.scala:38)
> at xsbt.boot.Launch$.parsed(Launch.scala:31)
> at xsbt.boot.Launch$.configured(Launch.scala:21)
> at xsbt.boot.Launch$.apply(Launch.scala:16)
> at xsbt.boot.Launch$.apply(Launch.scala:13)
> at xsbt.boot.Boot$.runImpl(Boot.scala:24)
> at xsbt.boot.Boot$.run(Boot.scala:19)
> at xsbt.boot.Boot$.main(Boot.scala:15)
> at xsbt.boot.Boot.main(Boot.scala)
>