davenverse / patchy

Circe Patch Support

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

patchy - Circe Patch Support Maven Central Code of Conduct

Quick Start

To use patchy in an existing SBT project with Scala 2.12 or a later version, add the following dependencies to your build.sbt depending on your needs:

libraryDependencies ++= Seq(
  "io.chrisdavenport" %% "patchy" % "<version>"
)

Examples

Patch Decoding with circe. currently cannot unset a value as absence of a value, and nulling of a value are both equivalent. Ideally this place can work out the details, and then contribute it back to circe.

The semantics are "key": null for an optional field will instead clear the field. The absence of the field will not effect the option. If the key is present in the patch it will be updated.

case class Foo(x: String, foo: Option[String])

{
  "foo": null
}

Clear The Field

Foo("bar", Some("baz")) -> Patch -> Foo("bar", None)

-----

{ 
  "x" : "zed"
}

Optional Field Absent

Foo("bar", Some("baz")) -> Patch -> Foo("zed", Some("baz"))

----

{
  "foo": "set by patch"
}

Set Optional Field

Foo("bar", Some("baz")) -> Patch -> Foo("bar", Some("set by patch"))

About

Circe Patch Support

License:MIT License


Languages

Language:Scala 99.5%Language:Ruby 0.5%