A list is an ordered sequence of values.
class base readonly list[value element type]
namespace parameters
Wrapper of an array that implements on-demand resizing and copy-on-write semantics. The same list_state can be shared by multiple instances of base_readonly_lists.
protected class list state[value element type]
import idealmachineelementsarray
Specifies whether this instance of list_state is writable. A single non-writable copy can be shared among multiple instances of base_readonly_list.
var boolean writable
Construct a list state with an array of specified size.
overload list state(nonnegative initial size)
Construct a list state with an array of default size.
overload list state()
Construct a list state from a given array of elements. Assumes noone mutates the elements.
overload list state(array[element type] immutable elements)
Make sure the array is of at least the specified size.
void reserve(nonnegative reserve size)
Insert elements at the specified index.
void insert all(nonnegative index, readonly list[element type] new elements)
Insert an element at the specified index.
void insert(nonnegative index, element type element)
Helper method used to create space in the middle of an array.
private void reserve and move(nonnegative index, nonnegative extra size)
protected var list state[element type] state
protected overload base readonly list()
The number of elements in the collection.
implement nonnegative size
Specifies whether the collection has zero elements.
implement boolean is empty
Specifies whether the collection has more than zero elements. Shortcut for !is_empty.
implement boolean is not empty
Access the first element of the list. Assumes the list is not empty.
implement element type first()
Access the last element of the list. Assumes the list is not empty.
implement element type last()
Read the list's element for the specified index.
implement implicit readonly reference[element type] get(nonnegative index) pure
Enumerates elements in some collection-defined order. This method returns a snapshot of the collection state, so subsequent mutations of the collection do not cause changes in the returned list.
implement immutable list[element type] elements()
Returns an immutable copy of this list.
implement immutable list[element type] frozen copy()
Returns an immutable sublist with the given the starting and ending indices.
The starting index is inclusive, the ending is exclusive.
implement immutable list[element type] slice(nonnegative begin, nonnegative end)
Skips over the specified count of elements and returns an immutable slice that begins with count and ends with the end of this list.
implement immutable list[element type] skip(nonnegative count)
Check whether the list has at least one element that satisfies the predicate.
implement boolean has(predicate[element type] the predicate) pure