Commit c773adee authored by Stefano Sabatini's avatar Stefano Sabatini

lavu/mem: extend documentation for av_dynarray_add()

In particular, mention the fact that the amortized element addition cost
is constant.
parent c67bca2b
...@@ -199,9 +199,20 @@ void av_freep(void *ptr); ...@@ -199,9 +199,20 @@ void av_freep(void *ptr);
/** /**
* Add an element to a dynamic array. * Add an element to a dynamic array.
* *
* @param tab_ptr Pointer to the array. * The array to grow is supposed to be an array of pointers to
* @param nb_ptr Pointer to the number of elements in the array. * structures, and the element to add must be a pointer to an already
* @param elem Element to be added. * allocated structure.
*
* The array is reallocated when its sizes reaches powers of 2.
* Therefore, the amortized cost of adding an element is constant.
*
* In case of success, the pointer to the array is updated in order to
* point to the new grown array, and the number pointed to by nb_ptr
* is incremented.
*
* @param tab_ptr pointer to the array to grow
* @param nb_ptr pointer to the number of elements in the array
* @param elem element to add
*/ */
void av_dynarray_add(void *tab_ptr, int *nb_ptr, void *elem); void av_dynarray_add(void *tab_ptr, int *nb_ptr, void *elem);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment