为什么我的判别字段没有使用 circe 添加到我的编码案例对象中?



我有以下代码,我希望它打印要编码的对象的类型,但它只打印一个空对象:

import cats.syntax.functor._
import io.circe.generic.auto._
import io.circe.generic.extras.Configuration
import io.circe.syntax._
import io.circe.{Decoder, Encoder}
object Main extends App {
implicit val customConfig: Configuration = 
Configuration.default.withDefaults.withDiscriminator("type")
sealed trait Foo
final case object Bar extends Foo
final case object Boo extends Foo
implicit val encodeEvent: Encoder[Foo] = Encoder.instance {
case Bar => Bar.asJson
case Boo => Boo.asJson
}
implicit val decodeEvent: Decoder[Foo] =
List[Decoder[Foo]](
Decoder[Bar.type].widen,
Decoder[Boo.type].widen,
).reduceLeft(_ or _)
val bar = Bar
println((bar: Foo).asJson.noSpaces) // {}
}

为什么Configuration没有应用于我的Foo的编码?

以下操作确实有效:

import cats.syntax.functor._
import io.circe.generic.extras.semiauto._
import io.circe.generic.extras.Configuration
import io.circe.syntax._
import io.circe.{Decoder, Encoder}
object Main extends App {
implicit val customConfig: Configuration =
Configuration.default.withDefaults.withDiscriminator("type")
sealed trait Foo
final case object Bar extends Foo
final case object Boo extends Foo
implicit val eBar: Encoder[Bar.type] = deriveEncoder[Bar.type]
implicit val eBoo: Encoder[Boo.type] = deriveEncoder[Boo.type]

implicit val dBar: Decoder[Bar.type] = deriveDecoder[Bar.type]
implicit val dBoo: Decoder[Boo.type] = deriveDecoder[Boo.type]
implicit val encodeEvent: Encoder[Foo] = deriveEncoder[Foo]
implicit val decodeEvent: Decoder[Foo] =
List[Decoder[Foo]](
Decoder[Bar.type].widen,
Decoder[Boo.type].widen,
).reduceLeft(_ or _)
val foo: Foo = Boo: Foo
println(foo.asJson.noSpaces) // {"type":"Boo"}
}

需要注意的是:

  1. Configuration(据我所知(适用于io.circe.generic.extras.semiauto而非io.circe.generic.auto
  2. 您提供了一个Encoder,并且不允许它(半(自动派生。而配置是为(半(自动推导

最新更新