|List| -> List
Clears the list by removing all of its elements, and returns the cleared list.
x = [1, 2, 3]
x.clear()
# -> []
|List, value: Any| -> Bool
Returns true
if the list contains an element that matches the input value
.
Matching is performed with the ==
equality operator.
[1, 'hello', (99, -1)].contains 'hello'
# -> true
|List, new_elements: Iterable| -> List
Extends the list with the output of the iterator, and returns the list.
x = [1, 2, 3]
x.extend 'abc'
# -> [1, 2, 3, 'a', 'b', 'c']
x.last()
# -> c
x.extend [10, 20, 30]
# -> [1, 2, 3, 'a', 'b', 'c', 10, 20, 30]
x.last()
# -> 30
|List, value: Any| -> List
Fills the list with copies of the provided value, and returns the list.
x = [1, 2, 3]
x.fill 99
# -> [99, 99, 99]
x
# -> [99, 99, 99]
|List| -> Any?
Returns the first value in the list, or null
if the list is empty.
[99, -1, 42].first()
# -> 99
[].first()
# -> null
|List, index: Number| -> Any?
|List, index: Number, default: Any| -> Any?
Gets the element at the given index
in the list.
If the list doesn't contain a value at that position then the provided default
value is returned. If no default value is provided then null
is returned.
x = [99, -1, 42]
x.get 1
# -> -1
x.get -1
# -> null
x.get 5, 123
# -> 123
|List, position: Number, value: Any| -> List
Inserts the value into the list at the given index position, and returns the list.
Elements in the list at or after the given position will be shifted to make space for the new value.
An error is thrown if position
is negative or greater than the size of the
list.
x = [99, -1, 42]
x.insert 2, 'hello'
# -> [99, -1, 'hello', 42]
x
# -> [99, -1, 'hello', 42]
|List| -> Bool
Returns true
if the list has a size of zero, and false
otherwise.
[].is_empty()
# -> true
[1, 2, 3].is_empty()
# -> false
|List| -> Any?
Returns the last value in the list, or null
if the list is empty.
[99, -1, 42].last()
# -> 42
[].last()
# -> null
|List| -> Any?
Removes the last value from the list and returns it.
If the list is empty then null
is returned.
x = [99, -1, 42]
x.pop()
# -> 42
x
# -> [99, -1]
[].pop()
# -> null
|List, value: Any| -> List
Adds the value
to the end of the list, and returns the list.
x = [99, -1]
x.push 'hello'
# -> [99, -1, 'hello']
x
# -> [99, -1, 'hello']
|List, position: Number| -> Any
Removes the value at the given position from the list, and returns the removed value.
An error is thrown if the position isn't a valid index in the list.
[99, -1, 42].remove 1
# [99, 42]
|List, new_size: Number| -> List
|List, new_size: Number, default: Any| -> List
Grows or shrinks the list to the specified size, and returns the list.
If the new size is larger, then copies of the default
value (or null
if no
value is provided) are used to fill the new space.
x = [1, 2]
x.resize 4, 'x'
# -> [1, 2, 'x', 'x']
x.resize 3
# -> [1, 2, 'x']
x.resize 4
# -> [1, 2, 'x', null]
|List, new_size: Number, generator: || -> Any| -> List
Grows or shrinks the list to the specified size, and returns the list. If the new size is larger, then the provided function will be called repeatedly to fill the remaining space, with the result of the function being added to the end of the list.
new_entries = (5, 6, 7, 8).iter()
x = [1, 2]
x.resize_with 4, || new_entries.next().get()
# -> [1, 2, 5, 6]
x.resize_with 2, || new_entries.next().get()
# -> [1, 2]
|List, test: Any| -> List
Retains matching values in the list (discarding values that don't match), and returns the list.
If test
is a function, then the function will be called with each of
the list's values, and if the function returns true
then the value will be
retained, otherwise if the function returns false
then the value will be
discarded.
If the test value is not a function, then the list's values will be compared
using the ==
equality operator, and then retained if they match.
x = (1..10).to_list()
x.retain |n| n < 5
# -> [1, 2, 3, 4]
x
# -> [1, 2, 3, 4]
x = [1, 3, 8, 3, 9, -1]
x.retain 3
# -> [3, 3]
x
# -> [3, 3]
|List| -> List
Reverses the order of the list's contents, and returns the list.
x = ['hello', -1, 99, 'world']
x.reverse()
# -> ['world', 99, -1, 'hello']
x
# -> ['world', 99, -1, 'hello']
|List| -> List
Sorts the list in place, and returns the list.
|List, key: |Any| -> Any| -> List
Sorts the list in place, based on the output of calling a key
function for
each of the list's elements, and returns the list.
The key function's result is cached, so it's only called once per element.
x = [1, -1, 99, 42]
x.sort()
# -> [-1, 1, 42, 99]
x
# -> [-1, 1, 42, 99]
x = ['bb', 'ccc', 'a']
x.sort size
# -> ['a', 'bb', 'ccc']
x
# -> ['a', 'bb', 'ccc']
x = [2, 1, 3]
# Sort in reverse order by using a key function
x.sort |n| -n
# -> [3, 2, 1]
x
# -> [3, 2, 1]
|first: List, second: List| -> Null
Swaps the contents of the two input lists.
x = [1, 2, 3]
y = [7, 8, 9]
x.swap y
x
# -> [7, 8, 9]
y
# -> [1, 2, 3]
|List| -> Tuple
Returns a copy of the list data as a tuple.
[1, 2, 3].to_tuple()
# -> (1, 2, 3)
|List, transformer: |Any| -> Any| -> List
Transforms the list data in place by replacing each value with the result of
calling the provided transformer
function, and then returns the list.
x = ['aaa', 'bb', 'c']
x.transform size
# -> [3, 2, 1]
x
# -> [3, 2, 1]
x.transform |n| '{n}!'
# -> ['3!', '2!', '1!']
x
# -> ['3!', '2!', '1!']