From 46ab616e7c323619e68fdadb50638b04b51388f9 Mon Sep 17 00:00:00 2001 From: Georgi Krastev Date: Wed, 10 Jan 2024 11:33:36 +0200 Subject: [PATCH] Expose ReflectionUtils - use at your own peril It's still in the internal package, but public. Made everything inside it private except for `Mirror`. --- .../deriving/internals/reflectionutils.scala | 10 +++++----- .../scala/shapeless3/typeable/reflectionutils.scala | 6 +++--- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/modules/deriving/src/main/scala/shapeless3/deriving/internals/reflectionutils.scala b/modules/deriving/src/main/scala/shapeless3/deriving/internals/reflectionutils.scala index e0a3709..9dfdd61 100644 --- a/modules/deriving/src/main/scala/shapeless3/deriving/internals/reflectionutils.scala +++ b/modules/deriving/src/main/scala/shapeless3/deriving/internals/reflectionutils.scala @@ -20,8 +20,8 @@ import scala.annotation.tailrec import scala.deriving.* import scala.quoted.* -private[shapeless3] class ReflectionUtils[Q <: Quotes & Singleton](val q: Q): - private given q.type = q +class ReflectionUtils[Q <: Quotes & Singleton](val q: Q): + given q.type = q import q.reflect.* case class Mirror( @@ -51,17 +51,17 @@ private[shapeless3] class ReflectionUtils[Q <: Quotes & Singleton](val q: Q): case _: ImplicitSearchFailure => None instance.flatMap(Mirror(_)) - def tupleTypeElements(tp: TypeRepr): List[TypeRepr] = + private def tupleTypeElements(tp: TypeRepr): List[TypeRepr] = @tailrec def loop(tp: TypeRepr, acc: List[TypeRepr]): List[TypeRepr] = tp match case AppliedType(_, List(hd: TypeRepr, tl: TypeRepr)) => loop(tl, hd :: acc) case _ => acc loop(tp, Nil).reverse - def low(tp: TypeRepr): TypeRepr = tp match + private def low(tp: TypeRepr): TypeRepr = tp match case tp: TypeBounds => tp.low case tp => tp - def findMemberType(tp: TypeRepr, name: String): Option[TypeRepr] = tp match + private def findMemberType(tp: TypeRepr, name: String): Option[TypeRepr] = tp match case Refinement(_, `name`, tp) => Some(low(tp)) case Refinement(parent, _, _) => findMemberType(parent, name) case AndType(left, right) => findMemberType(left, name).orElse(findMemberType(right, name)) diff --git a/modules/typeable/src/main/scala/shapeless3/typeable/reflectionutils.scala b/modules/typeable/src/main/scala/shapeless3/typeable/reflectionutils.scala index 221ce87..42e36f3 100644 --- a/modules/typeable/src/main/scala/shapeless3/typeable/reflectionutils.scala +++ b/modules/typeable/src/main/scala/shapeless3/typeable/reflectionutils.scala @@ -51,17 +51,17 @@ class ReflectionUtils[Q <: Quotes & Singleton](val q: Q): case _: ImplicitSearchFailure => None instance.flatMap(Mirror(_)) - def tupleTypeElements(tp: TypeRepr): List[TypeRepr] = + private def tupleTypeElements(tp: TypeRepr): List[TypeRepr] = @tailrec def loop(tp: TypeRepr, acc: List[TypeRepr]): List[TypeRepr] = tp match case AppliedType(_, List(hd: TypeRepr, tl: TypeRepr)) => loop(tl, hd :: acc) case _ => acc loop(tp, Nil).reverse - def low(tp: TypeRepr): TypeRepr = tp match + private def low(tp: TypeRepr): TypeRepr = tp match case tp: TypeBounds => tp.low case tp => tp - def findMemberType(tp: TypeRepr, name: String): Option[TypeRepr] = tp match + private def findMemberType(tp: TypeRepr, name: String): Option[TypeRepr] = tp match case Refinement(_, `name`, tp) => Some(low(tp)) case Refinement(parent, _, _) => findMemberType(parent, name) case AndType(left, right) => findMemberType(left, name).orElse(findMemberType(right, name))