From f4af2e6f4a7c04b314e01083d0fd31ca99f5f2f8 Mon Sep 17 00:00:00 2001 From: Derek Wickern Date: Mon, 10 Jun 2024 17:11:39 -0700 Subject: [PATCH 1/2] add failing test for scala.Enumeration --- .../test/scala/shapeless3/typeable/typeable.scala | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/modules/typeable/src/test/scala/shapeless3/typeable/typeable.scala b/modules/typeable/src/test/scala/shapeless3/typeable/typeable.scala index d267f29..8ebebcb 100644 --- a/modules/typeable/src/test/scala/shapeless3/typeable/typeable.scala +++ b/modules/typeable/src/test/scala/shapeless3/typeable/typeable.scala @@ -609,5 +609,18 @@ class TypeableTests: assertEquals(ti.describe, "Tree[Int]") assertEquals(ti.toString, "Typeable[Tree[Int]]") + @Test + def testEnumeration(): Unit = + val tc = Typeable[CaseClassWithEnumeration] + val cc = CaseClassWithEnumeration() + assert(tc.castable(cc)) + assert(tc.cast(cc).contains(cc)) + object TypeableTests: final case class Tree[+A](value: A, children: Vector[Tree[A]]) + + object E extends scala.Enumeration: + val A = Value("a") + val B = Value("b") + + case class CaseClassWithEnumeration(name: String = "", e: E.Value = E.A) From 35f6eaca0e620bea84378aca001bedd06a8e2f56 Mon Sep 17 00:00:00 2001 From: Derek Wickern Date: Tue, 11 Jun 2024 14:00:39 -0700 Subject: [PATCH 2/2] use simple typeable for simple case classes --- .../typeable/src/main/scala/shapeless3/typeable/typeable.scala | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/modules/typeable/src/main/scala/shapeless3/typeable/typeable.scala b/modules/typeable/src/main/scala/shapeless3/typeable/typeable.scala index bbfa547..bf2b75c 100644 --- a/modules/typeable/src/main/scala/shapeless3/typeable/typeable.scala +++ b/modules/typeable/src/main/scala/shapeless3/typeable/typeable.scala @@ -383,10 +383,10 @@ object TypeableMacros: val owner = normalizeModuleClass(sym.owner) qual match - case Some(_) if sym.flags.is(Flags.Case) => mkCaseClassTypeable case None => mkNamedSimpleTypeable case Some(tp: TypeRef) if normalizeModuleClass(tp.typeSymbol) == owner => mkNamedSimpleTypeable case Some(tp: TermRef) if normalizeModuleClass(tp.termSymbol) == owner => mkNamedSimpleTypeable + case Some(_) if sym.flags.is(Flags.Case) => mkCaseClassTypeable case Some(_) if sym.flags.is(Flags.Sealed) => mkSumTypeable case _ => report.errorAndAbort(s"No Typeable for type ${target.show} with a dependent prefix")