Невозможно сгенерировать Circe Decoder при использовании с кошками и уточненными типами
Я написал этот код
import io.circe._
import io.circe.refined._
import cats.data._
import cats.implicits._
import eu.timepit.refined.auto._
final case class Translation(lang: LanguageCode, name: ProductName)
final case class Product(id: ProductId, names: List[Translation])
object Translation {
implicit val decode: Decoder[Translation] = Decoder.forProduct2("lang", "name")(Translation.apply)
implicit val encode: Encoder[Translation] = Encoder.forProduct2("lang", "name")(t => (t.lang, t.name))
}
object Product {
implicit val decode: Decoder[Product] = Decoder.forProduct2("id", "names")(Product.apply)
implicit val encode: Encoder[Product] = Encoder.forProduct2("id", "names")(p => (p.id, p.names))
}
Это отлично работает и компилируется. но если я изменю свой Тип продукта, чтобы использовать непустой набор кошек.
final case class Product(id: ProductId, names: NonEmptySet[Translation])
Я получаю ошибку времени компиляции
could not find implicit value for parameter decodeA1:
io.circe.Decoder[cats.data.NonEmptySet[com.abhi.models.Translation]]"
Что я могу сделать, чтобы он автоматически сгенерировал декодер для NonEmptySet, как он это делает для списка?
1 ответ
Глядя на исходный код circe, он предоставляетDecoder[NonEmptySet[A]]
если дать Decoder[A]
и Order[A]
.
implicit final def decodeNonEmptySet[A](implicit decodeA: Decoder[A], orderA: Order[A]): Decoder[NonEmptySet[A]] =
new NonEmptySeqDecoder[A, SortedSet, NonEmptySet[A]](decodeA) {
final protected def createBuilder(): Builder[A, SortedSet[A]] =
SortedSet.newBuilder[A](Order.catsKernelOrderingForOrder(orderA))
final protected val create: (A, SortedSet[A]) => NonEmptySet[A] =
(h, t) => NonEmptySet(h, t)
}
Я предполагаю, что вам не хватает неявного for Order[Translation]
.