From f2158c1beb2f90e4f118cb992784e04b130ed3c6 Mon Sep 17 00:00:00 2001 From: Martin Odersky Date: Tue, 11 Jul 2017 14:56:28 +0200 Subject: [PATCH] Fix crash when compiling collection strawman. A computation of `ptNorm` was done too early, and failed on NoContext. --- compiler/src/dotty/tools/dotc/core/SymDenotations.scala | 2 +- compiler/src/dotty/tools/dotc/typer/Implicits.scala | 5 +++-- 2 files changed, 4 insertions(+), 3 deletions(-) diff --git a/compiler/src/dotty/tools/dotc/core/SymDenotations.scala b/compiler/src/dotty/tools/dotc/core/SymDenotations.scala index 2b3563cd9b27..d0c50e4d6e41 100644 --- a/compiler/src/dotty/tools/dotc/core/SymDenotations.scala +++ b/compiler/src/dotty/tools/dotc/core/SymDenotations.scala @@ -791,7 +791,7 @@ object SymDenotations { */ /** The class implementing this module, NoSymbol if not applicable. */ final def moduleClass(implicit ctx: Context): Symbol = { - def notFound = { println(s"missing module class for $name: $myInfo"); NoSymbol } + def notFound = { completions.println(s"missing module class for $name: $myInfo"); NoSymbol } if (this is ModuleVal) myInfo match { case info: TypeRef => info.symbol diff --git a/compiler/src/dotty/tools/dotc/typer/Implicits.scala b/compiler/src/dotty/tools/dotc/typer/Implicits.scala index ada94c477692..10cfcf87cf15 100644 --- a/compiler/src/dotty/tools/dotc/typer/Implicits.scala +++ b/compiler/src/dotty/tools/dotc/typer/Implicits.scala @@ -60,7 +60,6 @@ object Implicits { /** Return those references in `refs` that are compatible with type `pt`. */ protected def filterMatching(pt: Type)(implicit ctx: Context): List[Candidate] = track("filterMatching") { - val ptNorm = normalize(pt, pt) // `pt` could be implicit function types, check i2749 def refMatches(ref: TermRef)(implicit ctx: Context) = /*ctx.traceIndented(i"refMatches $ref $pt")*/ { @@ -124,8 +123,10 @@ object Implicits { record("discarded eligible") false } - else + else { + val ptNorm = normalize(pt, pt) // `pt` could be implicit function types, check i2749 NoViewsAllowed.isCompatible(normalize(ref, pt), ptNorm) + } } }