Vuo  2.4.1
Classes | Macros | Typedefs | Functions
VuoList_VuoFace

Description

A list of VuoFace elements.

Classes

struct  VuoList_VuoFace_struct
 A list of VuoFace elements. More...
 

Typedefs

typedef const struct VuoList_VuoFace_structVuoList_VuoFace
 A list of VuoFace elements. More...
 

Functions

VuoList_VuoFace VuoListCreate_VuoFace (void)
 Creates a new list of VuoFace elements. More...
 
VuoList_VuoFace VuoListCreateWithCount_VuoFace (const unsigned long count, const VuoFace value)
 Creates a new list of count instances of value. More...
 
VuoList_VuoFace VuoListCreateWithValueArray_VuoFace (const VuoFace *values, const unsigned long valueCount)
 Creates a new list containing the items in the C array values. More...
 
VuoList_VuoFace VuoListCopy_VuoFace (const VuoList_VuoFace list)
 Makes a shallow copy of list — its items are retained (not copied) by the new list. More...
 
static unsigned long VuoListIndexToCArrayIndex (long index, unsigned long listCount) __attribute__((const))
 Converts a Vuo-style [1..n] list index into a C-style [0..n-1] list index. More...
 
VuoFace VuoListGetValue_VuoFace (const VuoList_VuoFace list, const unsigned long index)
 Returns the VuoFace at index. More...
 
VuoFaceVuoListGetData_VuoFace (const VuoList_VuoFace list)
 Returns a pointer to a C array containing the list items. More...
 
void VuoListForeach_VuoFace (const VuoList_VuoFace list, bool(^function)(const VuoFace value))
 Applies function to each of list's items, serially in order of index. More...
 
void VuoListSetValue_VuoFace (const VuoList_VuoFace list, const VuoFace value, const unsigned long index, bool expandListIfNeeded)
 Changes the VuoFace at index. More...
 
void VuoListInsertValue_VuoFace (const VuoList_VuoFace list, const VuoFace value, const unsigned long index)
 Inserts the VuoFace immediately before index. More...
 
void VuoListPrependValue_VuoFace (VuoList_VuoFace list, const VuoFace value)
 Prepends value to list. More...
 
void VuoListAppendValue_VuoFace (VuoList_VuoFace list, const VuoFace value)
 Appends value to list. More...
 
void VuoListExchangeValues_VuoFace (VuoList_VuoFace list, const unsigned long indexA, const unsigned long indexB)
 Swaps the value at indexA with the value at indexB. More...
 
void VuoListShuffle_VuoFace (VuoList_VuoFace list, const double chaos)
 Generates a random permutation of list. More...
 
void VuoListReverse_VuoFace (VuoList_VuoFace list)
 Reverses the order of the items in list. More...
 
VuoList_VuoFace VuoListSubset_VuoFace (VuoList_VuoFace 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. More...
 
void VuoListRemoveFirstValue_VuoFace (VuoList_VuoFace list)
 Removes the first value from list. More...
 
void VuoListRemoveLastValue_VuoFace (VuoList_VuoFace list)
 Removes the last value from list. More...
 
void VuoListRemoveAll_VuoFace (VuoList_VuoFace list)
 Removes all values from list. More...
 
void VuoListRemoveValue_VuoFace (VuoList_VuoFace list, const unsigned long index)
 Removes the VuoFace at index. More...
 
unsigned long VuoListGetCount_VuoFace (const VuoList_VuoFace list)
 Returns the number of elements in list. More...
 
VuoList_VuoFace VuoList_VuoFace_makeFromJson (struct json_object *js)
 Decodes the JSON object js to create a new value. More...
 
struct json_objectVuoList_VuoFace_getJson (const VuoList_VuoFace value)
 Encodes value as a JSON object. More...
 
char * VuoList_VuoFace_getSummary (const VuoList_VuoFace value)
 Produces a brief human-readable summary of value. More...
 
void VuoList_VuoFace_retain (VuoList_VuoFace value)
 Retains the list. More...
 
void VuoList_VuoFace_release (VuoList_VuoFace value)
 Releases the list. More...
 
char * VuoList_VuoFace_getString (const VuoList_VuoFace value)
 Automatically generated function. More...
 

Class Documentation

◆ VuoList_VuoFace_struct

struct VuoList_VuoFace_struct
Class Members
void * l

Macro Definition Documentation

◆ VUO_LIST_INDEX_TO_C_ARRAY_INDEX

#define VUO_LIST_INDEX_TO_C_ARRAY_INDEX

Definition at line 63 of file VuoList_VuoFace.h.

Typedef Documentation

◆ VuoList_VuoFace

typedef const struct VuoList_VuoFace_struct * VuoList_VuoFace

A list of VuoFace elements.

Function Documentation

◆ VuoList_VuoFace_getJson()

struct json_object * VuoList_VuoFace_getJson ( const VuoList_VuoFace  value)

Encodes value as a JSON object.

Definition at line 84 of file VuoList_VuoFace.cc.

◆ VuoList_VuoFace_getString()

char * VuoList_VuoFace_getString ( const VuoList_VuoFace  value)

Automatically generated function.

◆ VuoList_VuoFace_getSummary()

char * VuoList_VuoFace_getSummary ( const VuoList_VuoFace  value)

Produces a brief human-readable summary of value.

Definition at line 119 of file VuoList_VuoFace.cc.

◆ VuoList_VuoFace_makeFromJson()

VuoList_VuoFace VuoList_VuoFace_makeFromJson ( struct json_object js)

Decodes the JSON object js to create a new value.

Example:
["uno", "dos", "tres", "catorce"]

Definition at line 63 of file VuoList_VuoFace.cc.

◆ VuoList_VuoFace_release()

void VuoList_VuoFace_release ( VuoList_VuoFace  value)

Releases the list.

This function is provided for use in polymorphism; it just calls VuoRelease().

Definition at line 580 of file VuoList_VuoFace.cc.

◆ VuoList_VuoFace_retain()

void VuoList_VuoFace_retain ( VuoList_VuoFace  value)

Retains the list.

This function is provided for use in polymorphism; it just calls VuoRetain().

Definition at line 575 of file VuoList_VuoFace.cc.

◆ VuoListAppendValue_VuoFace()

void VuoListAppendValue_VuoFace ( VuoList_VuoFace  list,
const VuoFace  value 
)

Appends value to list.

Definition at line 321 of file VuoList_VuoFace.cc.

◆ VuoListCopy_VuoFace()

VuoList_VuoFace VuoListCopy_VuoFace ( const VuoList_VuoFace  list)

Makes a shallow copy of list — its items are retained (not copied) by the new list.

Definition at line 187 of file VuoList_VuoFace.cc.

◆ VuoListCreate_VuoFace()

VuoList_VuoFace VuoListCreate_VuoFace ( void  )

Creates a new list of VuoFace elements.

Definition at line 154 of file VuoList_VuoFace.cc.

◆ VuoListCreateWithCount_VuoFace()

VuoList_VuoFace VuoListCreateWithCount_VuoFace ( const unsigned long  count,
const VuoFace  value 
)

Creates a new list of count instances of value.

Use this in conjunction with VuoListGetData_VuoFace to quickly initialize a large list.

Definition at line 161 of file VuoList_VuoFace.cc.

◆ VuoListCreateWithValueArray_VuoFace()

VuoList_VuoFace VuoListCreateWithValueArray_VuoFace ( const VuoFace 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.

Definition at line 174 of file VuoList_VuoFace.cc.

◆ VuoListExchangeValues_VuoFace()

void VuoListExchangeValues_VuoFace ( VuoList_VuoFace  list,
const unsigned long  indexA,
const unsigned long  indexB 
)

Swaps the value at indexA with the value at indexB.

Definition at line 331 of file VuoList_VuoFace.cc.

◆ VuoListForeach_VuoFace()

void VuoListForeach_VuoFace ( const VuoList_VuoFace  list,
bool(^)(const VuoFace value)  function 
)

Applies function to each of list's items, serially in order of index.

If function returns false, visiting will stop immediately (possibly before all items have been visited).

Changed in Vuo 2.0.0:
New.

Definition at line 242 of file VuoList_VuoFace.cc.

◆ VuoListGetCount_VuoFace()

unsigned long VuoListGetCount_VuoFace ( const VuoList_VuoFace  list)

Returns the number of elements in list.

Definition at line 566 of file VuoList_VuoFace.cc.

◆ VuoListGetData_VuoFace()

VuoFace * VuoListGetData_VuoFace ( const VuoList_VuoFace  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.

Definition at line 232 of file VuoList_VuoFace.cc.

◆ VuoListGetValue_VuoFace()

VuoFace VuoListGetValue_VuoFace ( const VuoList_VuoFace  list,
const unsigned long  index 
)

Returns the VuoFace at index.

Index values start at 1. If the list has no items, returns a default value. 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_VuoFace or VuoListForeach_VuoFace.

Definition at line 216 of file VuoList_VuoFace.cc.

◆ VuoListIndexToCArrayIndex()

static unsigned long VuoListIndexToCArrayIndex ( long  index,
unsigned long  listCount 
) const
inlinestatic

Converts a Vuo-style [1..n] list index into a C-style [0..n-1] list index.

If the index is less than 1, or larger than the size of the list, the returned index is clamped.

Definition at line 70 of file VuoList_VuoFace.h.

◆ VuoListInsertValue_VuoFace()

void VuoListInsertValue_VuoFace ( const VuoList_VuoFace  list,
const VuoFace  value,
const unsigned long  index 
)

Inserts the VuoFace 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.

Definition at line 289 of file VuoList_VuoFace.cc.

◆ VuoListPrependValue_VuoFace()

void VuoListPrependValue_VuoFace ( VuoList_VuoFace  list,
const VuoFace  value 
)

Prepends value to list.

Definition at line 311 of file VuoList_VuoFace.cc.

◆ VuoListRemoveAll_VuoFace()

void VuoListRemoveAll_VuoFace ( VuoList_VuoFace  list)

Removes all values from list.

Definition at line 540 of file VuoList_VuoFace.cc.

◆ VuoListRemoveFirstValue_VuoFace()

void VuoListRemoveFirstValue_VuoFace ( VuoList_VuoFace  list)

Removes the first value from list.

Definition at line 512 of file VuoList_VuoFace.cc.

◆ VuoListRemoveLastValue_VuoFace()

void VuoListRemoveLastValue_VuoFace ( VuoList_VuoFace  list)

Removes the last value from list.

Definition at line 526 of file VuoList_VuoFace.cc.

◆ VuoListRemoveValue_VuoFace()

void VuoListRemoveValue_VuoFace ( VuoList_VuoFace  list,
const unsigned long  index 
)

Removes the VuoFace 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.

Definition at line 549 of file VuoList_VuoFace.cc.

◆ VuoListReverse_VuoFace()

void VuoListReverse_VuoFace ( VuoList_VuoFace  list)

Reverses the order of the items in list.

Definition at line 435 of file VuoList_VuoFace.cc.

◆ VuoListSetValue_VuoFace()

void VuoListSetValue_VuoFace ( const VuoList_VuoFace  list,
const VuoFace  value,
const unsigned long  index,
bool  expandListIfNeeded 
)

Changes the VuoFace 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 elements, it is expanded to accommodate the specified index. If index is 0, the list is resized to contain 1 item set to value.

Definition at line 254 of file VuoList_VuoFace.cc.

◆ VuoListShuffle_VuoFace()

void VuoListShuffle_VuoFace ( VuoList_VuoFace  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.

Definition at line 414 of file VuoList_VuoFace.cc.

◆ VuoListSubset_VuoFace()

VuoList_VuoFace VuoListSubset_VuoFace ( VuoList_VuoFace  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.

Definition at line 444 of file VuoList_VuoFace.cc.