All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.rojoma.json.v3.-impl.util.WrapperJsonCodecImpl.scala Maven / Gradle / Ivy

package com.rojoma.json.v3
package `-impl`.util

import ast._
import codec._

private[util] class WrapperDecode[U, T: JsonDecode](wrap: T => U) extends JsonDecode[U] {
  private def wrapHandler(j: JValue, x: T): Either[DecodeError, U] = {
    try {
      Right(wrap(x))
    } catch {
      case e: IllegalArgumentException =>
        Left(DecodeError.InvalidValue(j))
    }
  }

  def decode(x: JValue) =
    JsonDecode[T].decode(x) match {
      case Right(v) => wrapHandler(x, v)
      case Left(err) => Left(err)
    }
}

class WrapperJsonCodecImpl[U] {
  def apply[T : JsonEncode : JsonDecode](wrap: T => U, unwrap: U => T): JsonEncode[U] with JsonDecode[U] =
    new WrapperDecode(wrap) with JsonEncode[U] {
      def encode(x: U) = JsonEncode[T].encode(unwrap(x))
    }
}

class WrapperJsonEncodeImpl[U] {
  def apply[T : JsonEncode](unwrap: U => T): JsonEncode[U] =
    new JsonEncode[U] {
      def encode(x: U) = JsonEncode[T].encode(unwrap(x))
    }
}

class WrapperJsonDecodeImpl[U] {
  def apply[T : JsonDecode](wrap: T => U): JsonDecode[U] =
    new WrapperDecode(wrap)
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy