libguac 1.5.4
Loading...
Searching...
No Matches
Macros
mem.h File Reference

Provides convenience macros/functions for performing arithmetic on size_t values and for allocating memory, particularly memory related to images, audio, etc. More...

Go to the source code of this file.

Macros

#define guac_mem_alloc(...)
 Allocates a contiguous block of memory with the specified size, returning a pointer to the first byte of that block of memory.
 
#define guac_mem_zalloc(...)
 Allocates a contiguous block of memory with the specified size and with all bytes initialized to zero, returning a pointer to the first byte of that block of memory.
 
#define guac_mem_ckd_mul(result, ...)
 Multiplies together each of the given values, storing the result in a size_t variable via the provided pointer.
 
#define guac_mem_ckd_add(result, ...)
 Adds together each of the given values, storing the result in a size_t variable via the provided pointer.
 
#define guac_mem_ckd_sub(result, ...)
 Subtracts each of the given values from each other, storing the result in a size_t variable via the provided pointer.
 
#define guac_mem_ckd_mul_or_die(...)
 Multiplies together each of the given values, returning the result directly.
 
#define guac_mem_ckd_add_or_die(...)
 Adds together each of the given values, returning the result directly.
 
#define guac_mem_ckd_sub_or_die(...)
 Subtracts each of the given values from each other, returning the result directly.
 
#define guac_mem_realloc(mem, ...)
 Reallocates a contiguous block of memory that was previously allocated with guac_mem_alloc(), guac_mem_zalloc(), guac_mem_realloc(), or one of their *_or_die() variants, returning a pointer to the first byte of that reallocated block of memory.
 
#define guac_mem_realloc_or_die(mem, ...)
 Reallocates a contiguous block of memory that was previously allocated with guac_mem_alloc(), guac_mem_zalloc(), guac_mem_realloc(), or one of their *_or_die() variants, returning a pointer to the first byte of that reallocated block of memory.
 
#define guac_mem_free(mem)   (PRIV_guac_mem_free(mem), (mem) = NULL, (void) 0)
 Frees the memory block at the given pointer, which MUST have been allocated with guac_mem_alloc(), guac_mem_zalloc(), guac_mem_realloc(), or one of their *_or_die() variants.
 
#define guac_mem_free_const(mem)   PRIV_guac_mem_free((void*) (mem))
 Frees the memory block at the given const pointer, which MUST have been allocated with guac_mem_alloc(), guac_mem_zalloc(), guac_mem_realloc(), or one of their *_or_die() variants.
 

Detailed Description

Provides convenience macros/functions for performing arithmetic on size_t values and for allocating memory, particularly memory related to images, audio, etc.

where there are multiple factors affecting the final size.

Macro Definition Documentation

◆ guac_mem_alloc

#define guac_mem_alloc (   ...)
Value:
PRIV_guac_mem_alloc( \
sizeof((const size_t[]) { __VA_ARGS__ }) / sizeof(const size_t), \
(const size_t[]) { __VA_ARGS__ } \
)

Allocates a contiguous block of memory with the specified size, returning a pointer to the first byte of that block of memory.

If multiple sizes are provided, these sizes are multiplied together to produce the final size of the new block. If memory of the specified size cannot be allocated, or if multiplying the sizes would result in integer overflow, guac_error is set appropriately and NULL is returned.

This macro is analogous to the standard malloc(), but accepts a list of size factors instead of a single integer size.

The pointer returned by guac_mem_alloc() SHOULD be freed with a subsequent call to guac_mem_free(), but MAY instead be freed with a subsequent call to free().

Parameters
...A series of one or more size_t values that should be multiplied together to produce the desired block size. At least one value MUST be provided.
Returns
A pointer to the first byte of the allocated block of memory, or NULL if such a block could not be allocated. If a block of memory could not be allocated, guac_error is set appropriately.

◆ guac_mem_ckd_add

#define guac_mem_ckd_add (   result,
  ... 
)
Value:
PRIV_guac_mem_ckd_add( \
result, \
sizeof((const size_t[]) { __VA_ARGS__ }) / sizeof(const size_t), \
(const size_t[]) { __VA_ARGS__ } \
)

Adds together each of the given values, storing the result in a size_t variable via the provided pointer.

If the result of the addition overflows the limits of a size_t, non-zero is returned to signal failure.

If the addition operation fails, the nature of any result stored in the provided pointer is undefined, as is whether a result is stored at all.

For example, the following:

size_t some_result;
int failed = guac_mem_ckd_add(&some_result, a, b, c);
#define guac_mem_ckd_add(result,...)
Adds together each of the given values, storing the result in a size_t variable via the provided poin...
Definition: mem.h:164

is equivalent in principle to:

size_t some_result = a + b + c;

except that it is possible for interested callers to handle overflow.

Parameters
resultA pointer to the size_t variable that should receive the result of adding the given values.
...The size_t values that should be added together.
Returns
Zero if the addition was successful and did not overflow the limits of a size_t, non-zero otherwise.

◆ guac_mem_ckd_add_or_die

#define guac_mem_ckd_add_or_die (   ...)
Value:
PRIV_guac_mem_ckd_add_or_die( \
sizeof((const size_t[]) { __VA_ARGS__ }) / sizeof(const size_t), \
(const size_t[]) { __VA_ARGS__ } \
)

Adds together each of the given values, returning the result directly.

If the result of the addition overflows the limits of a size_t, execution of the current process is aborted entirely, and this function does not return.

For example, the following:

size_t some_result = guac_mem_ckd_add_or_die(a, b, c);
#define guac_mem_ckd_add_or_die(...)
Adds together each of the given values, returning the result directly.
Definition: mem.h:270

is equivalent in principle to:

size_t some_result = a + b + c;

except that an overflow condition will result in the process immediately terminating.

Parameters
...The size_t values that should be added together.
Returns
The result of the addition. If the addition operation would overflow the limits of a size_t, execution of the current process is aborted, and this function does not return.

◆ guac_mem_ckd_mul

#define guac_mem_ckd_mul (   result,
  ... 
)
Value:
PRIV_guac_mem_ckd_mul( \
result, \
sizeof((const size_t[]) { __VA_ARGS__ }) / sizeof(const size_t), \
(const size_t[]) { __VA_ARGS__ } \
)

Multiplies together each of the given values, storing the result in a size_t variable via the provided pointer.

If the result of the multiplication overflows the limits of a size_t, non-zero is returned to signal failure.

If the multiplication operation fails, the nature of any result stored in the provided pointer is undefined, as is whether a result is stored at all.

For example, the following:

size_t some_result;
int failed = guac_mem_ckd_mul(&some_result, a, b, c);
#define guac_mem_ckd_mul(result,...)
Multiplies together each of the given values, storing the result in a size_t variable via the provide...
Definition: mem.h:125

is equivalent in principle to:

size_t some_result = a * b * c;

except that it is possible for interested callers to handle overflow.

Parameters
resultA pointer to the size_t variable that should receive the result of multiplying the given values.
...The size_t values that should be multiplied together.
Returns
Zero if the multiplication was successful and did not overflow the limits of a size_t, non-zero otherwise.

◆ guac_mem_ckd_mul_or_die

#define guac_mem_ckd_mul_or_die (   ...)
Value:
PRIV_guac_mem_ckd_mul_or_die( \
sizeof((const size_t[]) { __VA_ARGS__ }) / sizeof(const size_t), \
(const size_t[]) { __VA_ARGS__ } \
)

Multiplies together each of the given values, returning the result directly.

If the result of the multiplication overflows the limits of a size_t, execution of the current process is aborted entirely, and this function does not return.

For example, the following:

size_t some_result = guac_mem_ckd_mul_or_die(a, b, c);
#define guac_mem_ckd_mul_or_die(...)
Multiplies together each of the given values, returning the result directly.
Definition: mem.h:238

is equivalent in principle to:

size_t some_result = a * b * c;

except that an overflow condition will result in the process immediately terminating.

Parameters
...The size_t values that should be multiplied together.
Returns
The result of the multiplication. If the multiplication operation would overflow the limits of a size_t, execution of the current process is aborted, and this function does not return.

◆ guac_mem_ckd_sub

#define guac_mem_ckd_sub (   result,
  ... 
)
Value:
PRIV_guac_mem_ckd_sub( \
result, \
sizeof((const size_t[]) { __VA_ARGS__ }) / sizeof(const size_t), \
(const size_t[]) { __VA_ARGS__ } \
)

Subtracts each of the given values from each other, storing the result in a size_t variable via the provided pointer.

If the result of the subtraction overflows the limits of a size_t (goes below zero), non-zero is returned to signal failure.

If the subtraction operation fails, the nature of any result stored in the provided pointer is undefined, as is whether a result is stored at all.

For example, the following:

size_t some_result;
int failed = guac_mem_ckd_sub(&some_result, a, b, c);
#define guac_mem_ckd_sub(result,...)
Subtracts each of the given values from each other, storing the result in a size_t variable via the p...
Definition: mem.h:204

is equivalent in principle to:

size_t some_result = a - b - c;

except that it is possible for interested callers to handle overflow.

Parameters
resultA pointer to the size_t variable that should receive the result of subtracting the given values from each other.
...The size_t values that should be subtracted from each other.
Returns
Zero if the subtraction was successful and did not overflow the limits of a size_t (did not go below zero), non-zero otherwise.

◆ guac_mem_ckd_sub_or_die

#define guac_mem_ckd_sub_or_die (   ...)
Value:
PRIV_guac_mem_ckd_sub_or_die( \
sizeof((const size_t[]) { __VA_ARGS__ }) / sizeof(const size_t), \
(const size_t[]) { __VA_ARGS__ } \
)

Subtracts each of the given values from each other, returning the result directly.

If the result of the subtraction overflows the limits of a size_t (goes below zero), execution of the current process is aborted entirely, and this function does not return.

For example, the following:

size_t some_result = guac_mem_ckd_sub_or_die(a, b, c);
#define guac_mem_ckd_sub_or_die(...)
Subtracts each of the given values from each other, returning the result directly.
Definition: mem.h:303

is equivalent in principle to:

size_t some_result = a - b - c;

except that an overflow condition will result in the process immediately terminating.

Parameters
...The size_t values that should be subtracted from each other.
Returns
The result of the subtraction. If the subtraction operation would overflow the limits of a size_t (go below zero), execution of the current process is aborted, and this function does not return.

◆ guac_mem_free

#define guac_mem_free (   mem)    (PRIV_guac_mem_free(mem), (mem) = NULL, (void) 0)

Frees the memory block at the given pointer, which MUST have been allocated with guac_mem_alloc(), guac_mem_zalloc(), guac_mem_realloc(), or one of their *_or_die() variants.

The pointer is automatically assigned a value of NULL after memory is freed. If the provided pointer is already NULL, this macro has no effect.

Parameters
memA pointer to the memory to be freed.

◆ guac_mem_free_const

#define guac_mem_free_const (   mem)    PRIV_guac_mem_free((void*) (mem))

Frees the memory block at the given const pointer, which MUST have been allocated with guac_mem_alloc(), guac_mem_zalloc(), guac_mem_realloc(), or one of their *_or_die() variants.

As the pointer is presumed constant, it is not automatically assigned a value of NULL after memory is freed. If the provided pointer is NULL, this macro has no effect.

The guac_mem_free() macro should be used in favor of this macro. This macro should only be used in cases where a constant pointer is absolutely necessary.

Parameters
memA pointer to the memory to be freed.

◆ guac_mem_realloc

#define guac_mem_realloc (   mem,
  ... 
)
Value:
PRIV_guac_mem_realloc( \
mem, \
sizeof((const size_t[]) { __VA_ARGS__ }) / sizeof(const size_t), \
(const size_t[]) { __VA_ARGS__ } \
)

Reallocates a contiguous block of memory that was previously allocated with guac_mem_alloc(), guac_mem_zalloc(), guac_mem_realloc(), or one of their *_or_die() variants, returning a pointer to the first byte of that reallocated block of memory.

If multiple sizes are provided, these sizes are multiplied together to produce the final size of the new block. If memory of the specified size cannot be allocated, or if multiplying the sizes would result in integer overflow, guac_error is set appropriately, the original block of memory is left untouched, and NULL is returned.

This macro is analogous to the standard realloc(), but accepts a list of size factors instead of a requiring exactly one integer size.

The returned pointer may be the same as the original pointer, but this is not guaranteed. If the returned pointer is different, the original pointer is automatically freed.

The pointer returned by guac_mem_realloc() SHOULD be freed with a subsequent call to guac_mem_free(), but MAY instead be freed with a subsequent call to free().

Parameters
...A series of one or more size_t values that should be multiplied together to produce the desired block size. At least one value MUST be provided.
Returns
A pointer to the first byte of the reallocated block of memory, or NULL if such a block could not be allocated. If a block of memory could not be allocated, guac_error is set appropriately and the original block of memory is left untouched.

◆ guac_mem_realloc_or_die

#define guac_mem_realloc_or_die (   mem,
  ... 
)
Value:
PRIV_guac_mem_realloc_or_die( \
mem, \
sizeof((const size_t[]) { __VA_ARGS__ }) / sizeof(const size_t), \
(const size_t[]) { __VA_ARGS__ } \
)

Reallocates a contiguous block of memory that was previously allocated with guac_mem_alloc(), guac_mem_zalloc(), guac_mem_realloc(), or one of their *_or_die() variants, returning a pointer to the first byte of that reallocated block of memory.

If multiple sizes are provided, these sizes are multiplied together to produce the final size of the new block. If memory of the specified size cannot be allocated, execution of the current process is aborted entirely, and this function does not return.

This macro is analogous to the standard realloc(), but accepts a list of size factors instead of a requiring exactly one integer size and does not return in the event a block cannot be allocated.

The returned pointer may be the same as the original pointer, but this is not guaranteed. If the returned pointer is different, the original pointer is automatically freed.

The pointer returned by guac_mem_realloc() SHOULD be freed with a subsequent call to guac_mem_free(), but MAY instead be freed with a subsequent call to free().

Parameters
...A series of one or more size_t values that should be multiplied together to produce the desired block size. At least one value MUST be provided.
Returns
A pointer to the first byte of the reallocated block of memory. If a block of memory could not be allocated, execution of the current process is aborted, and this function does not return.

◆ guac_mem_zalloc

#define guac_mem_zalloc (   ...)
Value:
PRIV_guac_mem_zalloc( \
sizeof((const size_t[]) { __VA_ARGS__ }) / sizeof(const size_t), \
(const size_t[]) { __VA_ARGS__ } \
)

Allocates a contiguous block of memory with the specified size and with all bytes initialized to zero, returning a pointer to the first byte of that block of memory.

If multiple sizes are provided, these sizes are multiplied together to produce the final size of the new block. If memory of the specified size cannot be allocated, or if multiplying the sizes would result in integer overflow, guac_error is set appropriately and NULL is returned.

This macro is analogous to the standard calloc(), but accepts a list of size factors instead of a requiring exactly two integer sizes.

The pointer returned by guac_mem_zalloc() SHOULD be freed with a subsequent call to guac_mem_free(), but MAY instead be freed with a subsequent call to free().

Parameters
...A series of one or more size_t values that should be multiplied together to produce the desired block size. At least one value MUST be provided.
Returns
A pointer to the first byte of the allocated block of memory, or NULL if such a block could not be allocated. If a block of memory could not be allocated, guac_error is set appropriately.