2019-03-18 05:52:32 +00:00
|
|
|
// Copyright 2019, Collabora, Ltd.
|
|
|
|
// SPDX-License-Identifier: BSL-1.0
|
|
|
|
/*!
|
|
|
|
* @file
|
|
|
|
* @brief Very small misc utils.
|
|
|
|
* @author Jakob Bornecrantz <jakob@collabora.com>
|
2019-04-06 11:28:56 +00:00
|
|
|
* @ingroup aux_util
|
2019-03-18 05:52:32 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2019-06-18 19:09:16 +00:00
|
|
|
#include <stdlib.h> // for calloc
|
2019-06-18 18:51:23 +00:00
|
|
|
#include <string.h> // for memset
|
2019-04-03 16:57:05 +00:00
|
|
|
|
2019-03-18 05:52:32 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2019-04-10 11:33:28 +00:00
|
|
|
|
|
|
|
/*!
|
|
|
|
* Allocate and zero the give size and casts the memory into a pointer of the
|
|
|
|
* given type.
|
|
|
|
*
|
2019-06-18 19:09:16 +00:00
|
|
|
* Use instead of a bare calloc, but only when U_TYPED_CALLOC and
|
|
|
|
* U_TYPED_ARRAY_CALLOC do not meet your needs.
|
|
|
|
*
|
2020-08-26 16:26:46 +00:00
|
|
|
* - If you are using `U_CALLOC_WITH_CAST(struct MyStruct, sizeof(MyStruct))` to
|
|
|
|
* allocate a single structure of fixed size, you should actually use
|
|
|
|
* `U_TYPED_CALLOC(struct MyStruct)`.
|
|
|
|
*
|
|
|
|
* - If you are using `U_CALLOC_WITH_CAST(struct MyStruct, sizeof(MyStruct) *
|
|
|
|
* n)` to allocate an array, you should actually use
|
|
|
|
* `U_TYPED_ARRAY_CALLOC(struct MyStruct, n)`.
|
|
|
|
*
|
2019-04-10 11:33:28 +00:00
|
|
|
* @ingroup aux_util
|
|
|
|
*/
|
|
|
|
#define U_CALLOC_WITH_CAST(TYPE, SIZE) ((TYPE *)calloc(1, SIZE))
|
|
|
|
|
2019-03-21 20:18:44 +00:00
|
|
|
/*!
|
|
|
|
* Allocate and zero the space required for some type, and cast the return type
|
|
|
|
* appropriately.
|
2019-04-06 11:28:56 +00:00
|
|
|
*
|
2019-06-18 19:09:16 +00:00
|
|
|
* Use instead of a bare calloc when allocating a single structure.
|
|
|
|
*
|
2019-04-06 11:28:56 +00:00
|
|
|
* @ingroup aux_util
|
2019-03-21 20:18:44 +00:00
|
|
|
*/
|
|
|
|
#define U_TYPED_CALLOC(TYPE) ((TYPE *)calloc(1, sizeof(TYPE)))
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Allocate and zero the space required for some type, and cast the return type
|
|
|
|
* appropriately.
|
2019-04-06 11:28:56 +00:00
|
|
|
*
|
2019-06-18 19:09:16 +00:00
|
|
|
* Use instead of a bare calloc when allocating an array of a type.
|
|
|
|
* This includes allocating C strings: pass char as the type.
|
|
|
|
*
|
2019-04-06 11:28:56 +00:00
|
|
|
* @ingroup aux_util
|
2019-03-21 20:18:44 +00:00
|
|
|
*/
|
|
|
|
#define U_TYPED_ARRAY_CALLOC(TYPE, COUNT) \
|
|
|
|
((TYPE *)calloc((COUNT), sizeof(TYPE)))
|
2019-03-18 05:52:32 +00:00
|
|
|
|
2019-06-18 18:51:23 +00:00
|
|
|
/*!
|
|
|
|
* Zeroes the correct amount of memory based on the type pointed-to by the
|
|
|
|
* argument.
|
2019-06-18 19:09:16 +00:00
|
|
|
*
|
2019-06-18 18:51:23 +00:00
|
|
|
* Use instead of memset(..., 0, ...) on a structure or pointer to structure.
|
|
|
|
*
|
|
|
|
* @ingroup aux_util
|
|
|
|
*/
|
|
|
|
#define U_ZERO(PTR) memset((PTR), 0, sizeof(*(PTR)))
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Zeroes the correct amount of memory based on the type and size of the static
|
|
|
|
* array named in the argument.
|
2019-06-18 19:09:16 +00:00
|
|
|
*
|
2019-06-18 18:51:23 +00:00
|
|
|
* Use instead of memset(..., 0, ...) on an array.
|
|
|
|
*
|
|
|
|
* @ingroup aux_util
|
|
|
|
*/
|
|
|
|
#define U_ZERO_ARRAY(ARRAY) memset((ARRAY), 0, sizeof(ARRAY))
|
2019-03-18 05:52:32 +00:00
|
|
|
|
2019-12-02 23:15:12 +00:00
|
|
|
/*!
|
|
|
|
* Reallocates or frees dynamically-allocated memory.
|
|
|
|
*
|
|
|
|
* Just wraps realloc with a return value check, freeing the provided memory if
|
|
|
|
* it is NULL, to avoid leaks. Use U_ARRAY_REALLOC_OR_FREE() instead.
|
|
|
|
*
|
|
|
|
* @ingroup aux_util
|
|
|
|
*/
|
|
|
|
static inline void *
|
|
|
|
u_realloc_or_free(void *ptr, size_t new_size)
|
|
|
|
{
|
|
|
|
void *ret = realloc(ptr, new_size);
|
|
|
|
if (ret == NULL) {
|
|
|
|
free(ptr);
|
|
|
|
}
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Re-allocate the space required for some type, and update the pointer -
|
|
|
|
* freeing the allocation instead if it can't be resized.
|
|
|
|
*
|
|
|
|
* Use instead of a bare realloc when allocating an array of a type.
|
|
|
|
* This includes reallocating C strings: pass char as the type.
|
|
|
|
*
|
|
|
|
* Be sure not to parenthesize the type! It will cause an error like "expression
|
|
|
|
* expected".
|
|
|
|
*
|
|
|
|
* On the other hand, if you get an incompatible types error in assignment,
|
|
|
|
* that's a type mismatch, a real bug.
|
|
|
|
*
|
|
|
|
* @ingroup aux_util
|
|
|
|
*/
|
|
|
|
#define U_ARRAY_REALLOC_OR_FREE(VAR, TYPE, COUNT) \
|
|
|
|
(VAR) = ((TYPE *)u_realloc_or_free((VAR), sizeof(TYPE) * (COUNT)))
|
|
|
|
|
2019-03-18 05:52:32 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|