JsonCodecPlugin
をサブプロジェクトに追加すると、Contrabamd 型に対して sjson-new JSON コードが生成されます。
lazy val root = (project in file(".")).
enablePlugins(ContrabandPlugin, JsonCodecPlugin).
settings(
scalaVersion := "2.11.8",
libraryDependencies += "com.eed3si9n" %% "sjson-new-scalajson" % contrabandSjsonNewVersion.value
)
sjson-new はコーデックツールキットで、Spray JSON の AST、SLIP-28 Scala JSON、MessagePack をバックエンドとしてサポートするコードを定義できます。
コーデックのパッケージ名は @codecPackage
ディレクティブを使用して指定できます。
package com.example
@target(Scala)
@codecPackage("com.example.codec")
@codecTypeField("type")
@fullCodec("CustomJsonProtocol")
type Person {
name: String!
age: Int
}
JsonFormat 特性は com.example.codec
パッケージの下に生成され、すべての特性を混同した CustomJsonProtocol
という完全なコーデックと共に生成されます。
生成された JSON コーデックを使用する方法は次のとおりです。
scala> import sjsonnew.support.scalajson.unsafe.{ Converter, CompactPrinter, Parser }
import sjsonnew.support.scalajson.unsafe.{Converter, CompactPrinter, Parser}
scala> import com.example.codec.CustomJsonProtocol._
import com.example.codec.CustomJsonProtocol._
scala> import com.example.Person
import com.example.Person
scala> val p = Person("Bob", 20)
p: com.example.Person = Person(Bob, 20)
scala> val j = Converter.toJsonUnsafe(p)
j: scala.json.ast.unsafe.JValue = JObject([Lscala.json.ast.unsafe.JField;@6731ad72)
scala> val s = CompactPrinter(j)
s: String = {"name":"Bob","age":20}
scala> val x = Parser.parseUnsafe(s)
x: scala.json.ast.unsafe.JValue = JObject([Lscala.json.ast.unsafe.JField;@7331f7f8)
scala> val q = Converter.fromJsonUnsafe[Person](x)
q: com.example.Person = Person(Bob, 20)
scala> assert(p == q)
@generateCodec(false)
アノテーションを使用して、いくつかの型のコーデックの生成をスキップします。
interface MiddleInterface implements InterfaceExample
@generateCodec(false)
{
field: Int
}