From 5a039031c165fd9116749f28e9d9e6a0b6d5b0e6 Mon Sep 17 00:00:00 2001 From: Martin Odersky Date: Mon, 25 Mar 2013 21:45:20 +0100 Subject: More fixes to classfile reading. Can now read entire contents of scala distribution. --- src/dotty/tools/dotc/core/transform/Erasure.scala | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) (limited to 'src/dotty/tools/dotc/core/transform/Erasure.scala') diff --git a/src/dotty/tools/dotc/core/transform/Erasure.scala b/src/dotty/tools/dotc/core/transform/Erasure.scala index d10415829..330442408 100644 --- a/src/dotty/tools/dotc/core/transform/Erasure.scala +++ b/src/dotty/tools/dotc/core/transform/Erasure.scala @@ -109,7 +109,13 @@ object Erasure { else paramSignature(sym.info) case tp: RefinedType => val parent = tp.parent - if (parent.dealias.typeSymbol == defn.ArrayClass) paramSignature(eraseArray(tp)) + if (parent.dealias.typeSymbol == defn.ArrayClass) + eraseArray(tp) match { + case tp1: RefinedType if tp1.parent.dealias.typeSymbol == defn.ArrayClass => + paramSignature(tp1.parent) ++ "[]" + case tp1 => + paramSignature(tp1) + } else paramSignature(parent) case tp: TypeProxy => paramSignature(tp.underlying) -- cgit v1.2.3