VuoList interface.
Definition in file VuoList_VuoWave.h.
Go to the source code of this file.
Classes | |
struct | VuoList_VuoWave |
An ordered list of items, all of the same type. More... | |
Functions | |
VuoList_VuoWave | VuoListCreate_VuoWave (void) |
Creates a new list of VuoWave items. | |
VuoList_VuoWave | VuoListCreateWithCount_VuoWave (const unsigned long count, const VuoWave value) |
Creates a new list of count instances of value. | |
VuoList_VuoWave | VuoListCreateWithValueArray_VuoWave (const VuoWave *values, const unsigned long valueCount) |
Creates a new list containing the items in the C array values. | |
VuoList_VuoWave | VuoListCopy_VuoWave (const VuoList_VuoWave list) |
Makes a shallow copy of list — its items are retained (not copied) by the new list. | |
VuoWave | VuoListGetValue_VuoWave (const VuoList_VuoWave list, const unsigned long index) |
Returns the item at index. | |
VuoWave * | VuoListGetData_VuoWave (const VuoList_VuoWave list) |
Returns a pointer to a C array containing the list items. | |
void | VuoListForeach_VuoWave (const VuoList_VuoWave list, bool(^function)(const VuoWave value)) |
Applies function to each item in list, serially in order of index. | |
void | VuoListSetValue_VuoWave (const VuoList_VuoWave list, const VuoWave value, const unsigned long index, bool expandListIfNeeded) |
Changes the item at index. | |
void | VuoListInsertValue_VuoWave (const VuoList_VuoWave list, const VuoWave value, const unsigned long index) |
Inserts value immediately before index. | |
void | VuoListPrependValue_VuoWave (VuoList_VuoWave list, const VuoWave value) |
Prepends value to list. | |
void | VuoListAppendValue_VuoWave (VuoList_VuoWave list, const VuoWave value) |
Appends value to list. | |
void | VuoListExchangeValues_VuoWave (VuoList_VuoWave list, const unsigned long indexA, const unsigned long indexB) |
Swaps the value at indexA with the value at indexB. | |
void | VuoListShuffle_VuoWave (VuoList_VuoWave list, const double chaos) |
Generates a random permutation of list. | |
void | VuoListReverse_VuoWave (VuoList_VuoWave list) |
Reverses the order of the items in list. | |
VuoList_VuoWave | VuoListSubset_VuoWave (VuoList_VuoWave list, const signed long startIndex, const unsigned long itemCount) |
Returns a new list containing items from the original list in the range specified by startIndex and itemCount. | |
void | VuoListRemoveFirstValue_VuoWave (VuoList_VuoWave list) |
Removes the first item from list. | |
void | VuoListRemoveLastValue_VuoWave (VuoList_VuoWave list) |
Removes the last item from list. | |
void | VuoListRemoveAll_VuoWave (VuoList_VuoWave list) |
Removes all items from list. | |
void | VuoListRemoveValue_VuoWave (VuoList_VuoWave list, const unsigned long index) |
Removes the item at index. | |
unsigned long | VuoListGetCount_VuoWave (const VuoList_VuoWave list) |
Returns the number of items in list. | |
VuoList_VuoWave | VuoList_VuoWave_makeFromJson (struct json_object *js) |
Decodes the JSON object js to create a new list. | |
struct json_object * | VuoList_VuoWave_getJson (const VuoList_VuoWave list) |
Encodes list as a JSON object. | |
char * | VuoList_VuoWave_getSummary (const VuoList_VuoWave list) |
Produces a brief human-readable summary of list . | |
void | VuoList_VuoWave_retain (VuoList_VuoWave list) |
Retains the list. | |
void | VuoList_VuoWave_release (VuoList_VuoWave list) |
Releases the list. | |
char * | VuoList_VuoWave_getString (const VuoList_VuoWave list) |
Automatically generated function. | |
struct json_object * VuoList_VuoWave_getJson | ( | const VuoList_VuoWave | list | ) |
Encodes list as a JSON object.
char * VuoList_VuoWave_getString | ( | const VuoList_VuoWave | list | ) |
Automatically generated function.
char * VuoList_VuoWave_getSummary | ( | const VuoList_VuoWave | list | ) |
Produces a brief human-readable summary of list
.
VuoList_VuoWave VuoList_VuoWave_makeFromJson | ( | struct json_object * | js | ) |
Decodes the JSON object js to create a new list.
void VuoList_VuoWave_release | ( | VuoList_VuoWave | list | ) |
Releases the list.
This function is provided for use in polymorphism; it just calls VuoRelease()
.
void VuoList_VuoWave_retain | ( | VuoList_VuoWave | list | ) |
Retains the list.
This function is provided for use in polymorphism; it just calls VuoRetain()
.
void VuoListAppendValue_VuoWave | ( | VuoList_VuoWave | list, |
const VuoWave | value | ||
) |
Appends value to list.
VuoList_VuoWave VuoListCopy_VuoWave | ( | const VuoList_VuoWave | list | ) |
Makes a shallow copy of list — its items are retained (not copied) by the new list.
VuoList_VuoWave VuoListCreate_VuoWave | ( | void | ) |
Creates a new list of VuoWave
items.
VuoList_VuoWave VuoListCreateWithCount_VuoWave | ( | const unsigned long | count, |
const VuoWave | value | ||
) |
Creates a new list of count instances of value.
Use this in conjunction with VuoListGetData_VuoWave to quickly initialize a large list.
VuoList_VuoWave VuoListCreateWithValueArray_VuoWave | ( | const VuoWave * | values, |
const unsigned long | valueCount | ||
) |
Creates a new list containing the items in the C array values.
The list retains each item in values. The caller may discard values after this function returns.
void VuoListExchangeValues_VuoWave | ( | VuoList_VuoWave | list, |
const unsigned long | indexA, | ||
const unsigned long | indexB | ||
) |
Swaps the value at indexA with the value at indexB.
void VuoListForeach_VuoWave | ( | const VuoList_VuoWave | list, |
bool(^)(const VuoWave value) | function | ||
) |
Applies function to each item in list, serially in order of index.
If function returns false, visiting will stop immediately (possibly before all items have been visited).
unsigned long VuoListGetCount_VuoWave | ( | const VuoList_VuoWave | list | ) |
Returns the number of items in list.
VuoWave * VuoListGetData_VuoWave | ( | const VuoList_VuoWave | list | ) |
Returns a pointer to a C array containing the list items.
Use this if you need a fast way to get or change multiple list items.
You can modify values in the list by changing them in this array. Just don't attempt to access beyond the list size.
The pointer becomes invalid if you modify the list size using other functions (e.g., Insert, Prepend, Append, Cut, Remove); if you use those functions, just get a new pointer by calling this function again.
If the list has no items, returns NULL.
The pointer remains owned by the list; don't free it.
VuoWave VuoListGetValue_VuoWave | ( | const VuoList_VuoWave | list, |
const unsigned long | index | ||
) |
Returns the item at index.
Index values start at 1.
If the list has no items, returns a default value (an empty/zero value of VuoWave
).
Attempting to access an out-of-bounds index returns the first item in the list (if the index is 0), or last item in the list (if the index is greater than the list size).
If iterating over an entire list, consider using VuoListGetData_VuoWave or VuoListForeach_VuoWave.
void VuoListInsertValue_VuoWave | ( | const VuoList_VuoWave | list, |
const VuoWave | value, | ||
const unsigned long | index | ||
) |
Inserts value immediately before index.
Index values start at 1.
Inserting at index 0 prepends the value to the list. Inserting at an index beyond the last value in the list appends the value to the list.
void VuoListPrependValue_VuoWave | ( | VuoList_VuoWave | list, |
const VuoWave | value | ||
) |
Prepends value to list.
void VuoListRemoveAll_VuoWave | ( | VuoList_VuoWave | list | ) |
Removes all items from list.
void VuoListRemoveFirstValue_VuoWave | ( | VuoList_VuoWave | list | ) |
Removes the first item from list.
void VuoListRemoveLastValue_VuoWave | ( | VuoList_VuoWave | list | ) |
Removes the last item from list.
void VuoListRemoveValue_VuoWave | ( | VuoList_VuoWave | list, |
const unsigned long | index | ||
) |
Removes the item at index.
Index values start at 1.
Attempting to remove index 0 or an index beyond the last value in the list has no effect.
void VuoListReverse_VuoWave | ( | VuoList_VuoWave | list | ) |
Reverses the order of the items in list.
void VuoListSetValue_VuoWave | ( | const VuoList_VuoWave | list, |
const VuoWave | value, | ||
const unsigned long | index, | ||
bool | expandListIfNeeded | ||
) |
Changes the item at index.
Index values start at 1.
If expandListIfNeeded is false — If the list has no items, nothing is changed. Attempting to change an out-of-bounds index changes the first item in the list (if the index is 0), or last item in the list (if the index is greater than the list size).
If expandListIfNeeded is true — If the list has less than index items, it is expanded to accommodate the specified index. If index is 0, the list is resized to contain 1 item set to value.
void VuoListShuffle_VuoWave | ( | VuoList_VuoWave | list, |
const double | chaos | ||
) |
Generates a random permutation of list.
chaos ranges from 0 to 1. When chaos is 1, a full Fisher–Yates shuffle is performed. When less than 1, fewer iterations are performed.
VuoList_VuoWave VuoListSubset_VuoWave | ( | VuoList_VuoWave | list, |
const signed long | startIndex, | ||
const unsigned long | itemCount | ||
) |
Returns a new list containing items from the original list in the range specified by startIndex and itemCount.
Items in the new list are retained (not copied) from the original list.