vector: Add AST_VECTOR_COMPACT() to reclaim wasted space

This might be useful in situations where you are loading an undetermined number
of items into a vector and don't want to keep (potentially) 2x the necessary
memory around indefinitely.

Change-Id: I9711daa0fe01783fc6f04c5710eba84f2676d7b9
This commit is contained in:
Sean Bright 2019-03-14 10:55:30 -04:00
parent 0426e0fede
commit 057c7380be
1 changed files with 28 additions and 0 deletions

View File

@ -619,6 +619,34 @@ int ast_vector_string_split(struct ast_vector_string *dest,
(vec)->current = 0; \
})
/*!
* \brief Resize a vector so that its capacity is the same as its size.
*
* \param vec Vector to compact.
*
* \return 0 on success.
* \return Non-zero on failure.
*/
#define AST_VECTOR_COMPACT(vec) ({ \
int res = 0; \
do { \
if ((vec)->max > (vec)->current) { \
size_t new_max = (vec)->current; \
typeof((vec)->elems) new_elems = ast_realloc( \
(vec)->elems, \
new_max * sizeof(*new_elems)); \
if (new_elems || (vec)->current == 0) { \
(vec)->elems = new_elems; \
(vec)->max = new_max; \
} else { \
res = -1; \
break; \
} \
} \
} while(0); \
res; \
})
/*!
* \brief Get an address of element in a vector.
*