Próbuję serializować/deserializować niektóre klasy przypadków do/z Json ... i mam kłopoty, gdy mamy do czynienia z klasami przypadków z jednym polem (Używam Zagraj 2.1):Jak serializować/deserializować klasy przypadków do/z Json w grze 2.1
import play.api.libs.json._
import play.api.libs.functional.syntax._
case class MyType(type: String)
object MyType {
implicit val myTypeJsonWrite = new Writes[MyType] {
def writes(type: MyType): JsValue = {
Json.obj(
"type" -> MyType.type
)
}
}
implicit val myTypeJsonRead = (
(__ \ 'type).read[String]
)(MyType.apply _)
}
powyższy kod zawsze generuje następujący komunikat o błędzie:
[error] /home/j3d/Projects/test/app/models/MyType.scala:34: overloaded method value read with alternatives:
[error] (t: String)play.api.libs.json.Reads[String] <and>
[error] (implicit r: play.api.libs.json.Reads[String])play.api.libs.json.Reads[String]
[error] cannot be applied to (String => models.MyType)
[error] (__ \ 'method).read[String]
[error] ^
wiem ... klasę przypadek, który zawiera tylko ciąg nie ma sensu ... ale muszę serializować/deserializować klasę przypadków bardzo podobną do tej, którą opisałem powyżej, która pochodzi z externy l biblioteka.
Każdy pomysł? Czy czegoś brakuje? Każda pomoc będzie bardzo mile widziane ... Dostaję szalony :-(Dzięki.
zapoznaj http://stackoverflow.com/a/20130414/1435971 na przykład przekonwertować json Scala klasie przypadku – prarthan