From 50e40fffa866e5b41c5df93b3635165ab20e04b1 Mon Sep 17 00:00:00 2001 From: Nicolas Stucki Date: Fri, 3 Feb 2017 10:57:54 +0100 Subject: Fix #1916: fix erasure of implicit xxl closures This commit extends the fix done in #1920 to implicit closures. --- compiler/src/dotty/tools/dotc/core/TypeErasure.scala | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) (limited to 'compiler/src/dotty/tools/dotc/core/TypeErasure.scala') diff --git a/compiler/src/dotty/tools/dotc/core/TypeErasure.scala b/compiler/src/dotty/tools/dotc/core/TypeErasure.scala index 91e37d440..2a341390b 100644 --- a/compiler/src/dotty/tools/dotc/core/TypeErasure.scala +++ b/compiler/src/dotty/tools/dotc/core/TypeErasure.scala @@ -44,7 +44,7 @@ object TypeErasure { val sym = tp.symbol sym.isClass && sym != defn.AnyClass && sym != defn.ArrayClass && - !defn.isUnimplementedFunctionClass(sym) && !defn.isImplicitFunctionClass(sym) + !defn.isXXLFunctionClass(sym) && !defn.isImplicitFunctionClass(sym) case _: TermRef => true case JavaArrayType(elem) => @@ -358,7 +358,7 @@ class TypeErasure(isJava: Boolean, semiEraseVCs: Boolean, isConstructor: Boolean if (!sym.isClass) this(tp.info) else if (semiEraseVCs && isDerivedValueClass(sym)) eraseDerivedValueClassRef(tp) else if (sym == defn.ArrayClass) apply(tp.appliedTo(TypeBounds.empty)) // i966 shows that we can hit a raw Array type. - else if (defn.isUnimplementedFunctionClass(sym)) defn.FunctionXXLType + else if (defn.isXXLFunctionClass(sym)) defn.FunctionXXLType else if (defn.isImplicitFunctionClass(sym)) apply(defn.FunctionType(sym.name.functionArity)) else eraseNormalClassRef(tp) case tp: RefinedType => -- cgit v1.2.3