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

org.json4s.JsonDSL.scala Maven / Gradle / Ivy

/*
 * Copyright 2009-2011 WorldWide Conferencing, LLC
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.json4s

import JsonAST._

/**
 * Basic implicit conversions from primitive types into JSON.
 * Example:
 * import org.json4s.Implicits._
 * JObject(JField("name", "joe") :: Nil) == JObject(JField("name", JString("joe")) :: Nil)
 * 
*/ trait BigDecimalMode { self: Implicits ⇒ implicit def double2jvalue(x: Double): JValue = JDecimal(x) implicit def float2jvalue(x: Float): JValue = JDecimal(x.toDouble) implicit def bigdecimal2jvalue(x: BigDecimal): JValue = JDecimal(x) } object BigDecimalMode extends Implicits with BigDecimalMode trait DoubleMode { self: Implicits ⇒ implicit def double2jvalue(x: Double): JValue = JDouble(x) implicit def float2jvalue(x: Float): JValue = JDouble(x.toDouble) implicit def bigdecimal2jvalue(x: BigDecimal): JValue = JDouble(x.doubleValue()) } object DoubleMode extends Implicits with DoubleMode trait Implicits { implicit def short2jvalue(x: Short): JValue = JInt(x) implicit def byte2jvalue(x: Byte): JValue = JInt(x) implicit def char2jvalue(x: Char): JValue = JInt(x) implicit def int2jvalue(x: Int): JValue = JInt(x) implicit def long2jvalue(x: Long): JValue = JInt(x) implicit def bigint2jvalue(x: BigInt): JValue = JInt(x) implicit def double2jvalue(x: Double): JValue implicit def float2jvalue(x: Float): JValue implicit def bigdecimal2jvalue(x: BigDecimal): JValue implicit def boolean2jvalue(x: Boolean): JValue = JBool(x) implicit def string2jvalue(x: String): JValue = JString(x) } /** * A DSL to produce valid JSON. * Example:
 * import org.json4s.JsonDSL._
 * ("name", "joe") ~ ("age", 15) == JObject(JField("name",JString("joe")) :: JField("age",JInt(15)) :: Nil)
 * 
*/ object JsonDSL extends JsonDSL with DoubleMode { object WithDouble extends JsonDSL with DoubleMode object WithBigDecimal extends JsonDSL with BigDecimalMode } trait JsonDSL extends Implicits { implicit def seq2jvalue[A](s: Traversable[A])(implicit ev: A => JValue) = JArray(s.toList.map { a ⇒ val v: JValue = a; v }) implicit def map2jvalue[A](m: Map[String, A])(implicit ev: A => JValue) = JObject(m.toList.map { case (k, v) ⇒ JField(k, v) }) implicit def option2jvalue[A](opt: Option[A])(implicit ev: A => JValue): JValue = opt match { case Some(x) ⇒ x case None ⇒ JNothing } implicit def symbol2jvalue(x: Symbol) = JString(x.name) implicit def pair2jvalue[A](t: (String, A))(implicit ev: A => JValue) = JObject(List(JField(t._1, t._2))) implicit def list2jvalue(l: List[JField]) = JObject(l) implicit def jobject2assoc(o: JObject) = new JsonListAssoc(o.obj) implicit def pair2Assoc[A](t: (String, A))(implicit ev: A => JValue) = new JsonAssoc(t) class JsonAssoc[A](left: (String, A))(implicit ev: A => JValue) { def ~[B](right: (String, B))(implicit ev1: B => JValue) = { val l: JValue = left._2 val r: JValue = right._2 JObject(JField(left._1, l) :: JField(right._1, r) :: Nil) } def ~(right: JObject) = { val l: JValue = left._2 JObject(JField(left._1, l) :: right.obj) } def ~~[B](right: (String, B))(implicit ev: B => JValue) = this.~(right) def ~~(right: JObject) = this.~(right) } class JsonListAssoc(left: List[JField]) { def ~(right: (String, JValue)) = JObject(left ::: List(JField(right._1, right._2))) def ~(right: JObject) = JObject(left ::: right.obj) def ~~(right: (String, JValue)) = this.~(right) def ~~(right: JObject) = this.~(right) } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy