Package jsonvalues
Class JsArray
- java.lang.Object
- 
- jsonvalues.JsArray
 
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description static classJsArray.TYPEType of arrays: SET, MULTISET or LIST.
 - 
Field SummaryFields Modifier and Type Field Description static JsArrayEMPTYstatic intIDstatic JsOptics.JsArrayLenseslenslenses defined for a Json arraystatic JsOptics.JsArrayOptionalsoptionaloptionals defined for a Json arraystatic Prism<JsValue,JsArray>prismprism between the sum type JsValue and JsArray
 - 
Constructor SummaryConstructors Constructor Description JsArray()
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description JsArrayappend(JsValue e, JsValue... others)Adds one or more elements, starting from the first, to the back of this array.JsArrayappendAll(JsArray array)Adds all the elements of the given array, starting from the head, to the back of this array.booleancontainsValue(JsValue el)Returns true if this json contains the given element in the first level.JsArraydelete(int index)JsArraydelete(JsPath path)Removes the element in this json located at the given path, if it exists, returning the same this instance otherwisestatic JsArrayempty()booleanequals(java.lang.Object that)booleanequals(JsArray array, JsArray.TYPE ARRAY_AS)Returns true if this array is equal to the given as a parameter.JsArrayfilterAllKeys(java.util.function.Predicate<? super JsPair> filter)Filters all the keys of this json, removing those that don't ifPredicateElse the predicate.JsArrayfilterAllObjs(java.util.function.BiPredicate<? super JsPath,? super JsObj> filter)Filters all the pair of jsons of this json, removing those that don't ifPredicateElse the predicate.JsArrayfilterAllValues(java.util.function.Predicate<? super JsPair> filter)Filters all the pairs of elements of this json, removing those that don't ifPredicateElse the predicate.JsArrayfilterKeys(java.util.function.Predicate<? super JsPair> filter)Filters the keys in the first level of this json, removing those that don't ifPredicateElse the predicate.JsArrayfilterObjs(java.util.function.BiPredicate<? super JsPath,? super JsObj> filter)Filters the pair of jsons in the first level of this json, removing those that don't ifPredicateElse the predicate.JsArrayfilterValues(java.util.function.Predicate<? super JsPair> filter)Filters the pairs of elements in the first level of this json, removing those that don't ifPredicateElse the predicate.JsValueget(int i)returns the element located at the specified index or JsNothing if it doesn't exist.JsValueget(JsPath path)Returns the element located at the given path orJsNothingif it doesn't exist.inthashCode()equals method is inherited, so it's implemented.JsValuehead()Returns the first element of this array.intid()JsArrayinit()Returns all the elements of this array except the last one.JsArrayintersection(JsArray that, JsArray.TYPE ARRAY_AS)this.intersection(that, SET)returns an array with the elements that exist in boththisandthat.JsArrayintersectionAll(JsArray that)this.intersectionAll(that)behaves asthis.intersection(that, LIST), but for those elements that are containers of the same type and are located at the same position, the result is their intersection.booleanisArray()booleanisEmpty()return true if there's no element in this jsonjava.util.Iterator<JsValue>iterator()JsValuelast()Returns the last element of this array.JsArraymapAllKeys(java.util.function.Function<? super JsPair,java.lang.String> fn)Maps all the keys of this json.JsArraymapAllObjs(java.util.function.BiFunction<? super JsPath,? super JsObj,JsValue> fn)Maps all the jsons of this json.JsArraymapAllValues(java.util.function.Function<? super JsPair,? extends JsValue> fn)Maps all the values of this json.JsArraymapKeys(java.util.function.Function<? super JsPair,java.lang.String> fn)Maps the keys in the first level of this json.JsArraymapObjs(java.util.function.BiFunction<? super JsPath,? super JsObj,JsValue> fn)Maps the jsons in the first level of this json.JsArraymapValues(java.util.function.Function<? super JsPair,? extends JsValue> fn)Maps the values in the first level of this json.static JsArrayof(boolean bool, boolean... others)Returns an immutable array from one or more booleans.static JsArrayof(double number, double... others)Returns an immutable array from one or more doubles.static JsArrayof(int number, int... others)Returns an immutable array from one or more integers.static JsArrayof(long number, long... others)Returns an immutable array from one or more longs.static JsArrayof(java.lang.String str, java.lang.String... others)Returns an immutable array from one or more strings.static JsArrayof(java.math.BigInteger number, java.math.BigInteger... others)Returns an immutable array from one or more big integers.static JsArrayof(JsPair pair, JsPair... others)Returns an immutable array from one or more pairs.static JsArrayof(JsValue e)static JsArrayof(JsValue e, JsValue e1)Returns an immutable two-element array.static JsArrayof(JsValue e, JsValue e1, JsValue e2)Returns an immutable three-element array.static JsArrayof(JsValue e, JsValue e1, JsValue e2, JsValue e3)Returns an immutable four-element array.static JsArrayof(JsValue e, JsValue e1, JsValue e2, JsValue e3, JsValue e4)Returns an immutable five-element array.static JsArrayof(JsValue e, JsValue e1, JsValue e2, JsValue e3, JsValue e4, JsValue... rest)Returns an immutable array.static JsArrayofIterable(java.lang.Iterable<? extends JsValue> iterable)returns an immutable json array from an iterable of json elementsstatic JsArrayparse(java.lang.String str)Tries to parse the string into an immutable json array.JsArrayprepend(JsValue e, JsValue... others)Adds one or more elements, starting from the last, to the front of this array.JsArrayprependAll(JsArray array)Adds all the elements of the array, starting from the last, to the front of this array.<R> java.util.Optional<R>reduce(java.util.function.BinaryOperator<R> op, java.util.function.Function<? super JsPair,R> map, java.util.function.Predicate<? super JsPair> predicate)Performs a reduction on the values that satisfy the predicate in the first level of this json.<R> java.util.Optional<R>reduceAll(java.util.function.BinaryOperator<R> op, java.util.function.Function<? super JsPair,R> map, java.util.function.Predicate<? super JsPair> predicate)Performs a reduction on the values of this json that satisfy the predicate.JsArrayset(JsPath path, JsValue element)Inserts the element at the path in this json, replacing any existing element and filling withJsNullempty indexes in arrays when necessary.JsArrayset(JsPath path, JsValue value, JsValue padElement)Inserts the element at the path in this json, replacing any existing element and filling with padElement empty indexes in arrays when necessary.intsize()Returns the number of elements in the first level of this jsonjava.util.stream.Stream<JsPair>stream()Returns a stream over the pairs of elements in the first level of this json object.java.util.stream.Stream<JsPair>streamAll()Returns a stream over all the pairs of elements in this json object.JsArraytail()Returns a json array consisting of all elements of this array except the first one.java.lang.StringtoString()// Single-check idiom Item 83 from effective javaJsArrayunion(JsArray that, JsArray.TYPE ARRAY_AS)this.union(that, SET)returnsthisplus those elements fromthatthat don't exist inthis.JsArrayunionAll(JsArray that)returnsthisplus those elements fromthatwhich position is>= this.size(), and, at the positions where a container of the same type exists in boththisandthat, the result is their union.- 
Methods inherited from class java.lang.Objectclone, finalize, getClass, notify, notifyAll, wait, wait, wait
 - 
Methods inherited from interface jsonvalues.JsoncontainsPath, equals, getArray, getBigDec, getBigInt, getBinary, getBool, getDouble, getInstant, getInt, getLong, getObj, getStr, ifEmptyElse, isNotEmpty, map, serialize, serialize, sizeAll, times, timesAll, toPrettyString
 - 
Methods inherited from interface jsonvalues.JsValueifNothing, ifNull, isArray, isBigDec, isBigDec, isBigInt, isBigInt, isBinary, isBool, isDecimal, isDouble, isDouble, isFalse, isInstant, isInstant, isInt, isInt, isIntegral, isJson, isJson, isLong, isLong, isNothing, isNotJson, isNotNothing, isNotNull, isNotNumber, isNull, isNumber, isObj, isObj, isSameType, isStr, isStr, isTrue, toJsArray, toJsBigDec, toJsBigInt, toJsBinary, toJsBool, toJsDouble, toJsInstant, toJsInt, toJsLong, toJsNumber, toJsObj, toJson, toJsStr
 
- 
 
- 
- 
- 
Field Detail- 
IDpublic static final int ID - See Also:
- Constant Field Values
 
 - 
lenspublic static final JsOptics.JsArrayLenses lens lenses defined for a Json array
 - 
optionalpublic static final JsOptics.JsArrayOptionals optional optionals defined for a Json array
 - 
EMPTYpublic static JsArray EMPTY 
 
- 
 - 
Method Detail- 
emptypublic static JsArray empty() 
 - 
ofpublic static JsArray of(JsPair pair, JsPair... others) Returns an immutable array from one or more pairs.- Parameters:
- pair- a pair
- others- more optional pairs
- Returns:
- an immutable JsArray
- Throws:
- UserError- if an elem of a pair is mutable
 
 - 
ofpublic static JsArray of(JsValue e, JsValue e1, JsValue e2, JsValue e3, JsValue e4, JsValue... rest) Returns an immutable array.- Parameters:
- e- a JsValue
- e1- a JsValue
- e2- a JsValue
- e3- a JsValue
- e4- a JsValue
- rest- more optional JsValue
- Returns:
- an immutable JsArray
- Throws:
- UserError- if an elem is a mutable Json
 
 - 
ofpublic static JsArray of(JsValue e, JsValue e1, JsValue e2, JsValue e3, JsValue e4) Returns an immutable five-element array.- Parameters:
- e- a JsValue
- e1- a JsValue
- e2- a JsValue
- e3- a JsValue
- e4- a JsValue
- Returns:
- an immutable five-element JsArray
- Throws:
- UserError- if an elem is a mutable Json
 
 - 
appendpublic final JsArray append(JsValue e, JsValue... others) Adds one or more elements, starting from the first, to the back of this array.- Parameters:
- e- the JsValue to be added to the back.
- others- more optional JsValue to be added to the back
- Returns:
- a new JsArray
 
 - 
ofpublic static JsArray of(JsValue e, JsValue e1, JsValue e2, JsValue e3) Returns an immutable four-element array.- Parameters:
- e- a JsValue
- e1- a JsValue
- e2- a JsValue
- e3- a JsValue
- Returns:
- an immutable four-element JsArray
- Throws:
- UserError- if an elem is a mutable Json
 
 - 
ofpublic static JsArray of(JsValue e, JsValue e1, JsValue e2) Returns an immutable three-element array.- Parameters:
- e- a JsValue
- e1- a JsValue
- e2- a JsValue
- Returns:
- an immutable three-element JsArray
- Throws:
- UserError- if an elem is a mutable Json
 
 - 
ofpublic static JsArray of(JsValue e, JsValue e1) Returns an immutable two-element array.- Parameters:
- e- a JsValue
- e1- a JsValue
- Returns:
- an immutable two-element JsArray
- Throws:
- UserError- if an elem is a mutable Json
 
 - 
ofpublic static JsArray of(java.lang.String str, java.lang.String... others) Returns an immutable array from one or more strings.- Parameters:
- str- a string
- others- more optional strings
- Returns:
- an immutable JsArray
 
 - 
ofpublic static JsArray of(int number, int... others) Returns an immutable array from one or more integers.- Parameters:
- number- an integer
- others- more optional integers
- Returns:
- an immutable JsArray
 
 - 
ofpublic static JsArray of(boolean bool, boolean... others) Returns an immutable array from one or more booleans.- Parameters:
- bool- an boolean
- others- more optional booleans
- Returns:
- an immutable JsArray
 
 - 
ofpublic static JsArray of(long number, long... others) Returns an immutable array from one or more longs.- Parameters:
- number- a long
- others- more optional longs
- Returns:
- an immutable JsArray
 
 - 
ofpublic static JsArray of(java.math.BigInteger number, java.math.BigInteger... others) Returns an immutable array from one or more big integers.- Parameters:
- number- a big integer
- others- more optional big integers
- Returns:
- an immutable JsArray
 
 - 
ofpublic static JsArray of(double number, double... others) Returns an immutable array from one or more doubles.- Parameters:
- number- a double
- others- more optional doubles
- Returns:
- an immutable JsArray
 
 - 
ofIterablepublic static JsArray ofIterable(java.lang.Iterable<? extends JsValue> iterable) returns an immutable json array from an iterable of json elements- Parameters:
- iterable- the iterable of json elements
- Returns:
- an immutable json array
 
 - 
parsepublic static JsArray parse(java.lang.String str) throws MalformedJson Tries to parse the string into an immutable json array.- Parameters:
- str- the string to be parsed
- Returns:
- a JsArray
- Throws:
- MalformedJson- if the string doesnt represent a json array
 
 - 
appendAllpublic final JsArray appendAll(JsArray array) Adds all the elements of the given array, starting from the head, to the back of this array.- Parameters:
- array- the JsArray of elements to be added to the back
- Returns:
- a new JsArray
 
 - 
equalspublic boolean equals(JsArray array, JsArray.TYPE ARRAY_AS) Returns true if this array is equal to the given as a parameter. In the case of ARRAY_AS=LIST, this method is equivalent to JsArray.equals(Object).- Parameters:
- array- the given array
- ARRAY_AS- option to define if arrays are considered SETS, LISTS OR MULTISET
- Returns:
- true if both arrays are equals according to ARRAY_AS parameter
 
 - 
containsValuepublic final boolean containsValue(JsValue el) Description copied from interface:JsonReturns true if this json contains the given element in the first level.- Specified by:
- containsValuein interface- Json<JsArray>
- Parameters:
- el- the give element JsValue whose presence in this JsArray is to be tested
- Returns:
- true if this JsArray contains the JsValue
 
 - 
getpublic JsValue get(JsPath path) Description copied from interface:JsonReturns the element located at the given path orJsNothingif it doesn't exist.
 - 
filterValuespublic final JsArray filterValues(java.util.function.Predicate<? super JsPair> filter) Description copied from interface:JsonFilters the pairs of elements in the first level of this json, removing those that don't ifPredicateElse the predicate.- Specified by:
- filterValuesin interface- Json<JsArray>
- Parameters:
- filter- the predicate which takes as the input every JsPair in the first level of this json
- Returns:
- same this instance if all the pairs satisfy the predicate or a new filtered json of the same type T
- See Also:
- how to filter the pair of elements of the whole json and not only the first level
 
 - 
filterAllValuespublic final JsArray filterAllValues(java.util.function.Predicate<? super JsPair> filter) Description copied from interface:JsonFilters all the pairs of elements of this json, removing those that don't ifPredicateElse the predicate.- Specified by:
- filterAllValuesin interface- Json<JsArray>
- Parameters:
- filter- the predicate which takes as the input every JsPair of this json
- Returns:
- same this instance if all the pairs satisfy the predicate or a new filtered json of the same type T
- See Also:
- how to filter the pairs of values of only the first level
 
 - 
filterKeyspublic final JsArray filterKeys(java.util.function.Predicate<? super JsPair> filter) Description copied from interface:JsonFilters the keys in the first level of this json, removing those that don't ifPredicateElse the predicate.- Specified by:
- filterKeysin interface- Json<JsArray>
- Parameters:
- filter- the predicate which takes as the input every JsPair in the first level of this json
- Returns:
- same this instance if all the keys satisfy the predicate or a new filtered json of the same type T
- See Also:
- how to filter the keys of the whole json and not only the first level
 
 - 
filterAllKeyspublic final JsArray filterAllKeys(java.util.function.Predicate<? super JsPair> filter) Description copied from interface:JsonFilters all the keys of this json, removing those that don't ifPredicateElse the predicate.- Specified by:
- filterAllKeysin interface- Json<JsArray>
- Parameters:
- filter- the predicate which takes as the input every JsPair of this json
- Returns:
- same this instance if all the keys satisfy the predicate or a new filtered json of the same type T
- See Also:
- how to filter the keys of only the first level
 
 - 
filterObjspublic final JsArray filterObjs(java.util.function.BiPredicate<? super JsPath,? super JsObj> filter) Description copied from interface:JsonFilters the pair of jsons in the first level of this json, removing those that don't ifPredicateElse the predicate.- Specified by:
- filterObjsin interface- Json<JsArray>
- Parameters:
- filter- the predicate which takes as the input every JsPair in the first level of this json
- Returns:
- same this instance if all the pairs satisfy the predicate or a new filtered json of the same type T
- See Also:
- how to filter the pair of jsons of the whole json and not only the first level
 
 - 
filterAllObjspublic final JsArray filterAllObjs(java.util.function.BiPredicate<? super JsPath,? super JsObj> filter) Description copied from interface:JsonFilters all the pair of jsons of this json, removing those that don't ifPredicateElse the predicate.- Specified by:
- filterAllObjsin interface- Json<JsArray>
- Parameters:
- filter- the predicate which takes as the input every JsPair of this json
- Returns:
- same this instance if all the pairs satisfy the predicate or a new filtered json of the same type T
- See Also:
- how to filter the pair of jsons of only the first level
 
 - 
isEmptypublic final boolean isEmpty() Description copied from interface:Jsonreturn true if there's no element in this json
 - 
mapValuespublic final JsArray mapValues(java.util.function.Function<? super JsPair,? extends JsValue> fn) Description copied from interface:JsonMaps the values in the first level of this json.- Specified by:
- mapValuesin interface- Json<JsArray>
- Parameters:
- fn- the mapping function
- Returns:
- a new mapped json of the same type T
- See Also:
- to map jsons,- to map keys of json objects,- to map all the values and not only the first level
 
 - 
mapAllValuespublic JsArray mapAllValues(java.util.function.Function<? super JsPair,? extends JsValue> fn) Description copied from interface:JsonMaps all the values of this json.- Specified by:
- mapAllValuesin interface- Json<JsArray>
- Parameters:
- fn- the mapping function
- Returns:
- a new mapped json of the same type T
- See Also:
- to map jsons,- to map keys of json objects,- to map only the first level
 
 - 
mapKeyspublic final JsArray mapKeys(java.util.function.Function<? super JsPair,java.lang.String> fn) Description copied from interface:JsonMaps the keys in the first level of this json.- Specified by:
- mapKeysin interface- Json<JsArray>
- Parameters:
- fn- the mapping function
- Returns:
- a new mapped json of the same type T
- See Also:
- to map values,- to map jsons,- to map all the keys and not only the first level
 
 - 
mapAllKeyspublic final JsArray mapAllKeys(java.util.function.Function<? super JsPair,java.lang.String> fn) Description copied from interface:JsonMaps all the keys of this json.- Specified by:
- mapAllKeysin interface- Json<JsArray>
- Parameters:
- fn- the mapping function
- Returns:
- a new mapped json of the same type T
- See Also:
- to map values,- to map jsons,- to map only the first level
 
 - 
mapObjspublic final JsArray mapObjs(java.util.function.BiFunction<? super JsPath,? super JsObj,JsValue> fn) Description copied from interface:JsonMaps the jsons in the first level of this json.- Specified by:
- mapObjsin interface- Json<JsArray>
- Parameters:
- fn- the mapping function
- Returns:
- a new mapped json of the same type T
- See Also:
- to map values,- to map keys of json objects,- to map all the jsons and not only the first level
 
 - 
mapAllObjspublic final JsArray mapAllObjs(java.util.function.BiFunction<? super JsPath,? super JsObj,JsValue> fn) Description copied from interface:JsonMaps all the jsons of this json.- Specified by:
- mapAllObjsin interface- Json<JsArray>
- Parameters:
- fn- the mapping function
- Returns:
- a new mapped json of the same type T
- See Also:
- to map values,- to map keys of json objects,- to map only the first level
 
 - 
setpublic JsArray set(JsPath path, JsValue element) Description copied from interface:JsonInserts the element at the path in this json, replacing any existing element and filling withJsNullempty indexes in arrays when necessary.The same instance is returned when the head of the path is a key and this is an array or the head of the path is an index and this is an object or the element is JsNothing
 - 
setpublic final JsArray set(JsPath path, JsValue value, JsValue padElement) Description copied from interface:JsonInserts the element at the path in this json, replacing any existing element and filling with padElement empty indexes in arrays when necessary.The same instance is returned when the head of the path is a key and this is an array or the head of the path is an index and this is an object or the element is JsNothing- Specified by:
- setin interface- Json<JsArray>
- Parameters:
- path- the JsPath object where the element will be inserted at
- value- the JsValue that will be inserted
- padElement- the JsValue that will be inserted in arrays when padding is necessary
- Returns:
- the same instance or a new json of the same type T
 
 - 
reducepublic final <R> java.util.Optional<R> reduce(java.util.function.BinaryOperator<R> op, java.util.function.Function<? super JsPair,R> map, java.util.function.Predicate<? super JsPair> predicate)Description copied from interface:JsonPerforms a reduction on the values that satisfy the predicate in the first level of this json. The reduction is performed mapping each value with the mapping function and then applying the operator- Specified by:
- reducein interface- Json<JsArray>
- Type Parameters:
- R- the type of the operands of the operator
- Parameters:
- op- the operator upon two objects of type R
- map- the mapping function which produces an object of type R from a JsValue
- predicate- the predicate that determines what JsValue will be mapped and reduced
- Returns:
- an Optionaldescribing the of of the reduction
- See Also:
- to apply the reduction in all the Json and not only in the first level
 
 - 
reduceAllpublic final <R> java.util.Optional<R> reduceAll(java.util.function.BinaryOperator<R> op, java.util.function.Function<? super JsPair,R> map, java.util.function.Predicate<? super JsPair> predicate)Description copied from interface:JsonPerforms a reduction on the values of this json that satisfy the predicate. The reduction is performed mapping each value with the mapping function and then applying the operator- Specified by:
- reduceAllin interface- Json<JsArray>
- Type Parameters:
- R- the type of the operands of the operator
- Parameters:
- op- the operator upon two objects of type R
- map- the mapping function which produces an object of type R from a JsValue
- predicate- the predicate that determines what JsValue will be mapped and reduced
- Returns:
- an Optionaldescribing the result of the reduction
- See Also:
- to apply the reduction only in the first level
 
 - 
deletepublic final JsArray delete(JsPath path) Description copied from interface:JsonRemoves the element in this json located at the given path, if it exists, returning the same this instance otherwise
 - 
sizepublic final int size() Description copied from interface:JsonReturns the number of elements in the first level of this json
 - 
streamAllpublic java.util.stream.Stream<JsPair> streamAll() Description copied from interface:JsonReturns a stream over all the pairs of elements in this json object.
 - 
streampublic java.util.stream.Stream<JsPair> stream() Description copied from interface:JsonReturns a stream over the pairs of elements in the first level of this json object.
 - 
getpublic JsValue get(int i) returns the element located at the specified index or JsNothing if it doesn't exist. It never throws an exception, it's a total function.- Parameters:
- i- the index
- Returns:
- a JsValue
 
 - 
hashCodepublic final int hashCode() equals method is inherited, so it's implemented. The purpose of this method is to cache the hashcode once calculated. the object is immutable and it won't change Single-check idiom Item 83 from Effective Java- Overrides:
- hashCodein class- java.lang.Object
 
 - 
equalspublic final boolean equals(java.lang.Object that) - Overrides:
- equalsin class- java.lang.Object
 
 - 
toStringpublic final java.lang.String toString() // Single-check idiom Item 83 from effective java- Overrides:
- toStringin class- java.lang.Object
 
 - 
headpublic final JsValue head() Returns the first element of this array.- Returns:
- the first JsValue of this JsArray
- Throws:
- UserError- if this JsArray is empty
 
 - 
tailpublic final JsArray tail() Returns a json array consisting of all elements of this array except the first one.- Returns:
- a JsArray consisting of all the elements of this JsArray except the head
- Throws:
- UserError- if this JsArray is empty.
 
 - 
initpublic final JsArray init() Returns all the elements of this array except the last one.- Returns:
- JsArray with all the JsValue except the last one
- Throws:
- UserError- if this JsArray is empty
 
 - 
intersectionpublic final JsArray intersection(JsArray that, JsArray.TYPE ARRAY_AS) this.intersection(that, SET)returns an array with the elements that exist in boththisandthat.this.intersection(that, MULTISET)returns an array with the elements that exist in boththisandthat, being duplicates allowed.this.intersection(that, LIST)returns an array with the elements that exist in boththisandthatand are located at the same position.- Parameters:
- that- the other array
- ARRAY_AS- option to define if arrays are considered SETS, LISTS OR MULTISET
- Returns:
- a new JsArray of the same type as the inputs (mutable or immutable)
 
 - 
intersectionAllpublic JsArray intersectionAll(JsArray that) this.intersectionAll(that)behaves asthis.intersection(that, LIST), but for those elements that are containers of the same type and are located at the same position, the result is their intersection. So this operation is kind of a recursive intersection- Parameters:
- that- the other array
- Returns:
- a JsArray of the same type as the inputs (mutable or immutable)
 
 - 
isArraypublic boolean isArray() 
 - 
iteratorpublic final java.util.Iterator<JsValue> iterator() - Specified by:
- iteratorin interface- java.lang.Iterable<JsValue>
 
 - 
lastpublic final JsValue last() Returns the last element of this array.- Returns:
- the last JsValue of this JsArray
- Throws:
- UserError- if this JsArray is empty
 
 - 
prependpublic final JsArray prepend(JsValue e, JsValue... others) Adds one or more elements, starting from the last, to the front of this array.- Parameters:
- e- the JsValue to be added to the front.
- others- more optional JsValue to be added to the front
- Returns:
- a new JsArray
 
 - 
prependAllpublic final JsArray prependAll(JsArray array) Adds all the elements of the array, starting from the last, to the front of this array.- Parameters:
- array- the JsArray of elements to be added to the front
- Returns:
- a new JsArray
 
 - 
deletepublic final JsArray delete(int index) 
 - 
unionpublic final JsArray union(JsArray that, JsArray.TYPE ARRAY_AS) this.union(that, SET)returnsthisplus those elements fromthatthat don't exist inthis.this.union(that, MULTISET)returnsthisplus those elements fromthatappended to the back.this.union(that, LIST)returnsthisplus those elements fromthatwhich position is>= this.size().- Parameters:
- that- the other array
- ARRAY_AS- option to define if arrays are considered SETS, LISTS OR MULTISET
- Returns:
- a new json array of the same type as the inputs (mutable or immutable)
 
 - 
unionAllpublic final JsArray unionAll(JsArray that) returnsthisplus those elements fromthatwhich position is>= this.size(), and, at the positions where a container of the same type exists in boththisandthat, the result is their union. This operations doesn't make any sense if arrays are not considered lists, because there is no notion of order.- Parameters:
- that- the other array
- Returns:
- a new JsArray of the same type as the inputs (mutable or immutable)
 
 
- 
 
-