From ad29ce89624470de6204b242f0c3ee75fde727a3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?S=C3=A9bastien=20Doeraene?= Date: Fri, 11 Aug 2023 15:57:51 +0200 Subject: [PATCH 1/2] Fix #17115: Try to normalize while computing `typeSize`. --- compiler/src/dotty/tools/dotc/core/Types.scala | 4 +++- tests/pos/i17115.scala | 9 +++++++++ 2 files changed, 12 insertions(+), 1 deletion(-) create mode 100644 tests/pos/i17115.scala diff --git a/compiler/src/dotty/tools/dotc/core/Types.scala b/compiler/src/dotty/tools/dotc/core/Types.scala index 576f9a6c64f6..c5f65c73f57c 100644 --- a/compiler/src/dotty/tools/dotc/core/Types.scala +++ b/compiler/src/dotty/tools/dotc/core/Types.scala @@ -6459,7 +6459,9 @@ object Types { seen += tp tp match { case tp: AppliedType => - foldOver(n + 1, tp) + val tpNorm = tp.tryNormalize + if tpNorm.exists then apply(n, tpNorm) + else foldOver(n + 1, tp) case tp: RefinedType => foldOver(n + 1, tp) case tp: TypeRef if tp.info.isTypeAlias => diff --git a/tests/pos/i17115.scala b/tests/pos/i17115.scala new file mode 100644 index 000000000000..5a7cac5d0dc1 --- /dev/null +++ b/tests/pos/i17115.scala @@ -0,0 +1,9 @@ +trait A[T <: Tuple] { val x: Int } +given empty: A[EmptyTuple] with { val x = 1 } +given inductive[Tup <: NonEmptyTuple](using A[Tuple.Tail[Tup]]): A[Tup] with { val x = summon[A[Tuple.Tail[Tup]]].x + 1 } + +object Test: + def main(args: Array[String]): Unit = + println(summon[A[(String, String, String)]].x) //this line is fine + println(summon[A[(String, String, String, String)]].x) //this line gives error +end Test From eb18e53aa67acf69d310b1183f2ac0a9ca94d352 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?S=C3=A9bastien=20Doeraene?= Date: Wed, 30 Aug 2023 17:35:28 +0200 Subject: [PATCH 2/2] Fix #18211: Add regression test. This is also fixed by the parent commit. --- .../test/dotc/pos-test-pickling.blacklist | 1 + tests/pos/i18211.scala | 39 +++++++++++++++++++ 2 files changed, 40 insertions(+) create mode 100644 tests/pos/i18211.scala diff --git a/compiler/test/dotc/pos-test-pickling.blacklist b/compiler/test/dotc/pos-test-pickling.blacklist index 6404444be87f..b4c9ec996e33 100644 --- a/compiler/test/dotc/pos-test-pickling.blacklist +++ b/compiler/test/dotc/pos-test-pickling.blacklist @@ -56,6 +56,7 @@ i15827.scala i17149.scala tuple-fold.scala mt-redux-norm.perspective.scala +i18211.scala # Opaque type i5720.scala diff --git a/tests/pos/i18211.scala b/tests/pos/i18211.scala new file mode 100644 index 000000000000..c5ec30ba5d61 --- /dev/null +++ b/tests/pos/i18211.scala @@ -0,0 +1,39 @@ +import scala.compiletime.ops.int.* + +type AnyInt[A <: Int] <: Int = A match { + case _ => A +} + +type IndexOf[A, T <: Tuple] <: Int = T match { + case EmptyTuple => -1 + case A *: t => 0 + case _ *: t => + IndexOf[A, t] match { + case -1 => -1 + case AnyInt[a] => S[a] + } +} + +type Indexes[A, T <: Tuple] +object Indexes { + given of[A, T <: Tuple](using IndexOf[A, T] >= 0 =:= true)(using + index: ValueOf[IndexOf[A, T]], + next: Indexes[A, Tuple.Drop[T, S[IndexOf[A, T]]]] + ): Indexes[A, T] = ??? + + given empty[A, T <: Tuple](using IndexOf[A, T] =:= -1): Indexes[A, T] = ??? +} + +class GetAll[A]: + def apply[T <: Tuple](t: T)(using indexes: Indexes[A, T]): List[A] = ??? + +def getAll[A]: GetAll[A] = new GetAll[A] + +def test = + // the code here is trying to get all values from a tuple that has type [X] as a list + + // this works if there are only two strings in the tuple + getAll[String](("str1", 1, "str2", false)) + + //but this not compiles if there are more than two strings in the tuple + getAll[String](("str1", 1, "str2", false, "str3"))