vectors: Add new macro and a string vector definition.

* AST_VECTOR_STEAL_ELEMENTS - steal the array of elements for use
  with non-vector code.
* struct ast_vector_string - a vector of 'char *'.

Change-Id: I104d1b204be03fccf67e02a195596adcb5ab1e42
This commit is contained in:
Corey Farrell 2017-11-07 15:00:33 -05:00
parent 9eacd55c71
commit 4930404715
1 changed files with 23 additions and 0 deletions

View File

@ -51,6 +51,9 @@
/*! \brief Integer vector definition */
AST_VECTOR(ast_vector_int, int);
/*! \brief String vector definition */
AST_VECTOR(ast_vector_string, char *);
/*!
* \brief Define a vector structure with a read/write lock
*
@ -90,6 +93,26 @@ AST_VECTOR(ast_vector_int, int);
(alloc_size == 0 || (vec)->elems != NULL) ? 0 : -1; \
})
/*!
* \brief Steal the elements from a vector and reinitialize.
*
* \param vec Vector to operate on.
*
* This allows you to use vector.h to construct a list and use the
* data as a bare array.
*
* \note The stolen array must eventually be released using ast_free.
*
* \warning AST_VECTOR_SIZE and AST_VECTOR_MAX_SIZE are both reset
* to 0. If either are needed they must be saved to a local
* variable before stealing the elements.
*/
#define AST_VECTOR_STEAL_ELEMENTS(vec) ({ \
typeof((vec)->elems) __elems = (vec)->elems; \
AST_VECTOR_INIT((vec), 0); \
(__elems); \
})
/*!
* \brief Initialize a vector with a read/write lock
*