This commit is contained in:
Neil 2021-08-29 13:32:34 -07:00
parent d2bc0e161d
commit 47d7cb878a

View File

@ -52,10 +52,9 @@ static int name##_array_reserve(struct name##_array *const a, \
a->data = data, a->capacity = c0; \
return 1; \
} \
/** The capacity of `a` will be increased to at least `n` elements beyond the
size. It will invalidate pointers in `a` if `n` is greater than the buffer
space. @return The start of the buffered space at the back of the array. If
`a` is idle and `buffer` is zero, a null pointer is returned, otherwise null
/** Increases the capacity of `a` to at least `n` elements beyond the size.
@return The start of the buffered space at the back of the array. If `a` is
idle and `buffer` is zero, a null pointer is returned, otherwise null
indicates an error. @throws[realloc, ERANGE] */ \
static type *name##_array_buffer(struct name##_array *const a, \
const size_t n) { \
@ -64,8 +63,7 @@ static type *name##_array_buffer(struct name##_array *const a, \
return name##_array_reserve(a, a->size + n) && a->data \
? a->data + a->size : 0; \
} \
/** Adds `n` elements to the back of `a`. It will invalidate pointers in `a` if
`n` is greater than the buffer space. @return A pointer to the elements. If
/** Adds `n` elements to the back of `a`. @return A pointer to the elements. If
`a` is idle and `n` is zero, a null pointer will be returned, otherwise null
indicates an error. @throws[realloc, ERANGE] */ \
static type *name##_array_append(struct name##_array *const a, \
@ -75,8 +73,8 @@ static type *name##_array_append(struct name##_array *const a, \
assert(n <= a->capacity && a->size <= a->capacity - n); \
return a->size += n, buffer; \
} \
/** @return Adds (push back) one new element of `a`. The buffer holds an
element or it will invalidate pointers in `a`. @throws[realloc, ERANGE] */ \
/** @return Adds (push back) one new element of `a`.
@throws[realloc, ERANGE] */ \
static type *name##_array_new(struct name##_array *const a) \
{ return name##_array_append(a, 1); } \
/* It's perfectly valid that these functions are not used. */ \