final case class JsObj(map: Map[String, JsValue] = HashMap.empty) extends AbstractJsObj with IterableOnce[(String, JsValue)] with Json[JsObj] with Product with Serializable

represents an immutable Json object. There are several ways of creating a Json object, being the most common the following:

  • From a string, array of bytes or an input stream of bytes, using the parse functions of the companion object
  • From the apply function of the companion object:
JsObj("a" -> 1,
      "b" -> "hi",
      "c" -> JsArray(1,2),
      "d" -> JsObj("e" -> 1,
                   "f" -> true
                  )
      )

// alternative way, from a set of pairs (path,value)

JsObj(
      ("a", 1),
      ("b", "hi"),
      ("c" / 0, 1),
      ("c" / 1, 2),
      ("d" / "e", 1),
      ("d" / "f", true)
     )
map

immutable map of JsValue

Linear Supertypes
Serializable, Product, Equals, Json[JsObj], JsValue, IterableOnce[(String, JsValue)], AbstractJsObj, AnyRef, Any
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. JsObj
  2. Serializable
  3. Product
  4. Equals
  5. Json
  6. JsValue
  7. IterableOnce
  8. AbstractJsObj
  9. AnyRef
  10. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Instance Constructors

  1. new JsObj(map: Map[String, JsValue] = HashMap.empty)

    map

    immutable map of JsValue

Value Members

  1. final def !=(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  2. final def ##(): Int
    Definition Classes
    AnyRef → Any
  3. final def ==(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  4. final def apply(path: JsPath): JsValue

    Returns the element located at a specified path.

    Returns the element located at a specified path. This function is total on its argument. If no element is found, JsNothing is returned

    path

    the path

    returns

    the json value found at the path

    Definition Classes
    Json
  5. def apply(key: String): JsValue

    Retrieves the value which is associated with the given key.

    Retrieves the value which is associated with the given key. If there is no mapping from the given key to a value, JsNothing is returned.

    key

    the key

    returns

    the value associated with the given key

    Definition Classes
    AbstractJsObj
  6. final def asInstanceOf[T0]: T0
    Definition Classes
    Any
  7. def clone(): AnyRef
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.CloneNotSupportedException]) @native()
  8. def containsKey(key: String): Boolean

    Tests whether this json object contains a binding for a key.

    Tests whether this json object contains a binding for a key.

    key

    the key

    returns

    true if there is a binding for key in this map, false otherwise.

    Definition Classes
    AbstractJsObj
  9. def containsPath(path: JsPath): Boolean

    Returns true if there is an element at the specified path

    Returns true if there is an element at the specified path

    path

    the path

    returns

    true if the path exists, false otherwise

    Definition Classes
    Json
  10. def count(p: ((JsPath, JsValue)) => Boolean = (_: (JsPath, JsValue)) => true): Int

    Returns the number of elements that satisfy the given predicate

    Returns the number of elements that satisfy the given predicate

    p

    the predicate to test each path/value pair

    returns

    number of elements that satisfy the predicate

    Definition Classes
    Json
  11. final def eq(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  12. def equals(that: Any): Boolean
    Definition Classes
    JsObj → Equals → AnyRef → Any
  13. def exists(p: ((JsPath, JsValue)) => Boolean): Boolean

    Tests whether a predicate holds for at least one element of this Json

    Tests whether a predicate holds for at least one element of this Json

    p

    the predicate to test each path/value pair

    returns

    true if the given predicate is satisfied by at least one path/value pair, otherwise false

    Definition Classes
    Json
  14. def filter(p: (JsPrimitive) => Boolean): JsObj
    Definition Classes
    AbstractJsObj
  15. def filter(p: (JsPath, JsPrimitive) => Boolean): JsObj

    Selects all elements of this Json object which satisfy a predicate.

    Selects all elements of this Json object which satisfy a predicate.

    returns

    a new Json object consisting of all elements of this Json object that satisfy the given predicate p. The order of the elements is preserved.

    Definition Classes
    AbstractJsObj
  16. def filterJsObj(p: (JsObj) => Boolean): JsObj
    Definition Classes
    AbstractJsObj
  17. def filterJsObj(p: (JsPath, JsObj) => Boolean): JsObj
    Definition Classes
    AbstractJsObj
  18. def filterKeys(p: (String) => Boolean): JsObj
    Definition Classes
    AbstractJsObj
  19. def filterKeys(p: (JsPath, JsValue) => Boolean): JsObj
    Definition Classes
    AbstractJsObj
  20. def finalize(): Unit
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.Throwable])
  21. def flatten: LazyList[(JsPath, JsValue)]

    Flatten this Json object into a LazyList of pairs of (JsPath,JsValue) traversing recursively every noe-empty Json found along the way:

    Flatten this Json object into a LazyList of pairs of (JsPath,JsValue) traversing recursively every noe-empty Json found along the way:

    val obj = JsObj("a" -> 1,
                    "b" -> "hi",
                    "c" -> JsArray(1,2,),
                    "d" -> JsObj("e" -> 1,
                                 "f" -> true
                                )
                    )
    
    val pairs = obj.toLazyList
    
    pairs.foreach { println }
    
    //prints out the following:
    
    (a,1)
    (b,"hi")
    (c/0,1)
    (c/1,2)
    (d/e,{})
    (d/f,true)
    returns

    a LazyList of pairs of JsPath and JsValue

    Definition Classes
    AbstractJsObj
  22. final def getClass(): Class[_ <: AnyRef]
    Definition Classes
    AnyRef → Any
    Annotations
    @native()
  23. def head: (String, JsValue)

    Selects the next element of the iterator of this Json object, throwing a NoSuchElementException if the Json object is empty

    Selects the next element of the iterator of this Json object, throwing a NoSuchElementException if the Json object is empty

    returns

    the next element of the iterator of this Json object.

    Definition Classes
    AbstractJsObj
  24. def headOption: Option[(String, JsValue)]

    Optionally selects the next element of the iterator of this Json object.

    Optionally selects the next element of the iterator of this Json object.

    returns

    the first element of this Json object if it is nonempty. None if it is empty.

    Definition Classes
    AbstractJsObj
  25. def id: Int

    Every implementation of this trait has an unique identifier.

    Every implementation of this trait has an unique identifier.

    returns

    unique identifier of the type

    Definition Classes
    JsObjJsValue
  26. def init: JsObj
    Definition Classes
    AbstractJsObj
  27. def inserted(path: JsPath, value: JsValue, padWith: JsValue = JsNull): JsObj

    Creates a new Json obtained by inserting a given path/value pair into this Json.

    Creates a new Json obtained by inserting a given path/value pair into this Json. The given element is always inserted at the given path, even if it requires to create new Json or padding arrays.

    JsObj.empty.inserted(path,value)(path) == value //always true
    path

    the path

    value

    the value

    returns

    A new Json with the new path/value mapping added to this Json.

    Definition Classes
    JsObjJson
    Note

    inserted function unless updated, always inserts the given path/value pair

  28. def isArr(predicate: (JsArray) => Boolean): Boolean

    returns true if this is an array that satisfies a predicate

    returns true if this is an array that satisfies a predicate

    predicate

    the predicate

    Definition Classes
    JsValue
  29. def isArr: Boolean

    returns true if this is an array

    returns true if this is an array

    Definition Classes
    AbstractJsObj
  30. def isBigDec: Boolean

    return false

    return false

    returns

    false

    Definition Classes
    JsonJsValue
  31. def isBigInt: Boolean

    return false

    return false

    returns

    false

    Definition Classes
    JsonJsValue
  32. def isBool: Boolean

    return false

    return false

    returns

    false

    Definition Classes
    JsonJsValue
  33. def isDecimal(predicate: (BigDecimal) => Boolean): Boolean

    returns true if this is a big decimal that satisfies a predicate

    returns true if this is a big decimal that satisfies a predicate

    predicate

    the predicate

    returns

    true if this is a big decimal that satisfies the predicate. If this is a double, it returns false

    Definition Classes
    JsValue
  34. def isDecimal: Boolean

    returns true if this type is a decimal number

    returns true if this type is a decimal number

    returns

    isDouble || isBigDec
    Definition Classes
    JsValue
  35. def isDouble: Boolean

    return false

    return false

    returns

    false

    Definition Classes
    JsonJsValue
  36. def isDouble(predicate: (Double) => Boolean): Boolean

    returns true if this is a double that satisfies a predicate

    returns true if this is a double that satisfies a predicate

    predicate

    the predicate

    returns

    true if this is a double that satisfies the predicate

    Definition Classes
    JsValue
  37. def isEmpty: Boolean

    Tests whether the Json object is empty.

    Tests whether the Json object is empty.

    returns

    true if the Json object contains no elements, false otherwise.

    Definition Classes
    AbstractJsObj
  38. final def isInstanceOf[T0]: Boolean
    Definition Classes
    Any
  39. def isInt: Boolean

    return false

    return false

    returns

    false

    Definition Classes
    JsonJsValue
  40. def isInt(predicate: (Int) => Boolean): Boolean

    returns true if this is an integer that satisfies a predicate

    returns true if this is an integer that satisfies a predicate

    predicate

    the predicate

    Definition Classes
    JsValue
  41. def isIntegral(predicate: (BigInt) => Boolean): Boolean

    returns true if this is a big integer that satisfies a predicate

    returns true if this is a big integer that satisfies a predicate

    predicate

    the predicate

    returns

    true if this is a big integer that satisfies the predicate. If this is either an integer or a long, it returns false.

    Definition Classes
    JsValue
  42. def isIntegral: Boolean

    returns true if this type is an integral number

    returns true if this type is an integral number

    returns

    isInt || isLong || isBigInt
    Definition Classes
    JsValue
  43. def isJson(predicate: (Json[_]) => Boolean): Boolean

    returns true if this is a json that satisfy a predicate

    returns true if this is a json that satisfy a predicate

    predicate

    the predicate

    Definition Classes
    JsValue
  44. def isJson: Boolean

    returns true is this type is an array or an object

    returns true is this type is an array or an object

    Definition Classes
    JsValue
  45. def isLong: Boolean

    return false

    return false

    returns

    false

    Definition Classes
    JsonJsValue
  46. def isLong(predicate: (Long) => Boolean): Boolean

    returns true if this is a long that satisfies a predicate

    returns true if this is a long that satisfies a predicate

    predicate

    the predicate

    returns

    true if this is a long that satisfies the predicate and false otherwise. If this is an integer, it returns false.

    Definition Classes
    JsValue
  47. def isNotEmpty: Boolean
    Definition Classes
    Json
  48. def isNotJson: Boolean

    returns true if this is neither an object nor an array

    returns true if this is neither an object nor an array

    Definition Classes
    JsValue
  49. def isNotNull: Boolean

    returns true if this is not null

    returns true if this is not null

    returns

    true if this is not null, false otherwise

    Definition Classes
    JsValue
  50. def isNotNumber: Boolean

    returns true if this is not a number

    returns true if this is not a number

    Definition Classes
    JsValue
  51. def isNothing: Boolean

    return false

    return false

    returns

    false

    Definition Classes
    JsonJsValue
  52. def isNull: Boolean

    return false

    return false

    returns

    false

    Definition Classes
    JsonJsValue
  53. def isNumber: Boolean

    return false

    return false

    returns

    false

    Definition Classes
    JsonJsValue
  54. def isObj(predicate: (JsObj) => Boolean): Boolean

    returns true if this is an object that satisfies a predicate

    returns true if this is an object that satisfies a predicate

    predicate

    the predicate

    Definition Classes
    JsValue
  55. def isObj: Boolean

    returns true if this is an object

    returns true if this is an object

    Definition Classes
    AbstractJsObj
  56. def isStr: Boolean

    return false

    return false

    returns

    false

    Definition Classes
    JsonJsValue
  57. def isStr(predicate: (String) => Boolean): Boolean

    returns true if this is a string that satisfies a predicate

    returns true if this is a string that satisfies a predicate

    predicate

    the predicate

    Definition Classes
    JsValue
  58. def iterator: Iterator[(String, JsValue)]

    Returns an iterator of this Json object.

    Returns an iterator of this Json object. Can be used only once

    returns

    an iterator

    Definition Classes
    AbstractJsObj
  59. def keySet: Set[String]

    Collects all keys of this map in a set.

    Collects all keys of this map in a set.

    returns

    a set containing all keys of this map.

    Definition Classes
    AbstractJsObj
  60. def keys: Iterable[String]

    Collects all keys of this Json object in an iterable collection.

    Collects all keys of this Json object in an iterable collection.

    returns

    the keys of this Json object as an iterable.

    Definition Classes
    AbstractJsObj
  61. def knownSize: Int
    Definition Classes
    IterableOnce
  62. def last: (String, JsValue)

    Selects the last element of the iterator of this Json object, throwing a NoSuchElementException if the Json object is empty

    Selects the last element of the iterator of this Json object, throwing a NoSuchElementException if the Json object is empty

    returns

    the last element of the iterator of this Json object.

    Definition Classes
    AbstractJsObj
  63. def lastOption: Option[(String, JsValue)]

    Optionally selects the last element of the iterator of this Json object.

    Optionally selects the last element of the iterator of this Json object.

    returns

    the last element of the iterator of this Json object, None if it is empty.

    Definition Classes
    AbstractJsObj
  64. def map[J <: JsValue](m: (JsPath, JsPrimitive) => J, p: (JsPath, JsPrimitive) => Boolean = (_, _) => true): JsObj
    Definition Classes
    AbstractJsObj
  65. def map[J <: JsValue](m: (JsPrimitive) => J): JsObj
    Definition Classes
    AbstractJsObj
  66. def mapKeys(m: (String) => String): JsObj
    Definition Classes
    AbstractJsObj
  67. def mapKeys(m: (JsPath, JsValue) => String, p: (JsPath, JsValue) => Boolean = (_, _) => true): JsObj
    Definition Classes
    AbstractJsObj
  68. final def ne(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  69. final def nonEmpty: Boolean

    returns true if the Json is non empty

    returns true if the Json is non empty

    returns

    true if non empty, false otherwise

    Definition Classes
    Json
  70. final def notify(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native()
  71. final def notifyAll(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native()
  72. def productElementNames: Iterator[String]
    Definition Classes
    Product
  73. def reduce[V](p: (JsPath, JsPrimitive) => Boolean = (_, _) => true, m: (JsPath, JsPrimitive) => V, r: (V, V) => V): Option[V]
    Definition Classes
    AbstractJsObj
  74. def removed(path: JsPath): JsObj

    Removes a path from this Json

    Removes a path from this Json

    path

    the path to be removed

    returns

    If this Json does not contain a binding for path it is returned unchanged. Otherwise, returns a new Json without a binding for path

    Definition Classes
    JsObjJson
  75. def removedAll(xs: IterableOnce[JsPath]): JsObj

    Creates a new Json from this Json by removing all paths of another collection

    Creates a new Json from this Json by removing all paths of another collection

    xs

    the collection containing the paths to remove

    returns

    a new Json with the given paths removed.

    Definition Classes
    JsObjJson
  76. def serialize: Array[Byte]

    Serialize this Json into an array of bytes.

    Serialize this Json into an array of bytes. When possible, it's more efficient to work on byte level that with strings

    returns

    this Json serialized into an array of bytes

    Definition Classes
    Json
  77. def serialize(outputStream: OutputStream): () => Unit

    Returns a zero-argument function that when called, it serializes this Json into the given output stream, no returning anything

    Returns a zero-argument function that when called, it serializes this Json into the given output stream, no returning anything

    outputStream

    the output stream

    returns

    () => Unit function that serializes this Json into the given output stream

    Definition Classes
    Json
  78. def size: Int

    The size of this Json object.

    The size of this Json object. *

    returns

    the number of elements in this Json object.

    Definition Classes
    AbstractJsObj
  79. def stepper[S <: Stepper[_]](implicit shape: StepperShape[(String, JsValue), S]): S
    Definition Classes
    IterableOnce
  80. final def synchronized[T0](arg0: => T0): T0
    Definition Classes
    AnyRef
  81. def tail: JsObj
    Definition Classes
    AbstractJsObj
  82. def toJsArray: JsArray

    Throws an UserError exception

    Throws an UserError exception

    returns

    Throws an UserError exception

    Definition Classes
    AbstractJsObj
  83. def toJsBigDec: JsBigDec

    throws an UserError exception

    throws an UserError exception

    returns

    this value as a JsBigDec

    Definition Classes
    JsonJsValue
  84. def toJsBigInt: JsBigInt

    throws an UserError exception

    throws an UserError exception

    returns

    this value as a JsBigInt

    Definition Classes
    JsonJsValue
  85. def toJsBool: JsBool

    throws an UserError exception

    throws an UserError exception

    returns

    this value as a JsBool

    Definition Classes
    JsonJsValue
  86. def toJsDouble: JsDouble

    throws an UserError exception

    throws an UserError exception

    Definition Classes
    JsonJsValue
  87. def toJsInt: JsInt

    throws an UserError exception

    throws an UserError exception

    returns

    this value as a JsInt

    Definition Classes
    JsonJsValue
  88. def toJsLong: JsLong

    throws an UserError exception

    throws an UserError exception

    returns

    this value as a JsLong

    Definition Classes
    JsonJsValue
  89. def toJsNull: JsNull.type

    throws an UserError exception

    throws an UserError exception

    returns

    this value as a JsNull

    Definition Classes
    JsonJsValue
  90. def toJsNumber: JsNumber

    throws an UserError exception

    throws an UserError exception

    returns

    this value as a JsNumber

    Definition Classes
    JsonJsValue
  91. def toJsObj: JsObj

    Returns this Json object

    Returns this Json object

    returns

    this Json object as a JsObj

    Definition Classes
    JsObjJsValue
  92. def toJsStr: JsStr

    throws an UserError exception

    throws an UserError exception

    returns

    this value as a JsStr

    Definition Classes
    JsonJsValue
  93. def toJson: Json[_]

    Returns this Json object as a Json

    Returns this Json object as a Json

    returns

    this Json object as a Json

    Definition Classes
    JsObjJsValue
  94. def toPrettyString: String

    Converts the string representation of this Json to a pretty print version

    Converts the string representation of this Json to a pretty print version

    returns

    pretty print version of the string representation of this Json

    Definition Classes
    Json
  95. def toString(): String

    string representation of this Json array.

    string representation of this Json array. It's a lazy value which is only computed once.

    returns

    string representation of this Json array

    Definition Classes
    JsObjJson → AnyRef → Any
  96. def validate(spec: JsObjSpec): LazyList[(JsPath, Invalid)]
  97. final def wait(): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.InterruptedException])
  98. final def wait(arg0: Long, arg1: Int): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.InterruptedException])
  99. final def wait(arg0: Long): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.InterruptedException]) @native()

Inherited from Serializable

Inherited from Product

Inherited from Equals

Inherited from Json[JsObj]

Inherited from JsValue

Inherited from IterableOnce[(String, JsValue)]

Inherited from AbstractJsObj

Inherited from AnyRef

Inherited from Any

Ungrouped