A list is an ordered sequence of values.
class base readonly list[value element type]
implement immutable list[element type] slice(nonnegative begin, nonnegative end)
implement immutable list[element type] skip(nonnegative count)
implements readonly list[element type]
namespace parameters
default size : 16
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 ideal • machine • elements • array
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
Specifies how many elements are stored in this list_state.
The size is less or equal to the_elements.size.
var nonnegative size
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()
this(parameters • default size)
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)
if the elements • size >= reserve size
if new size < reserve size
return
new size = reserve size
the elements = new elements
Insert elements at the specified index.
void insert all(nonnegative index, readonly list[element type] new elements)
Helper method used to create space in the middle of an array.
private void reserve and move(nonnegative index, nonnegative extra size)
void clear(nonnegative begin, nonnegative length)
protected overload base readonly list()
Specifies whether the collection has more than zero elements.
Shortcut for !is_empty.
implement boolean is not empty => state • size != 0
Access the first element of the list.
Assumes the list is not empty.
implement element type first()
assert is not empty
return state • the elements[0]
Access the last element of the list.
Assumes the list is not empty.
implement element type last()
assert is not empty
assert last index is nonnegative
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() => frozen copy()
Returns an immutable sublist with the given the starting and ending indices.
The starting index is inclusive, the ending is exclusive.
assert length is nonnegative
Skips over the specified count of elements and returns an immutable slice
that begins with count and ends with the end of this list.
Check whether the list has at least one element that satisfies the predicate.
implement boolean has(predicate[element type] the predicate) pure