diff options
author | nicm <nicm> | 2019-11-28 09:51:58 +0000 |
---|---|---|
committer | nicm <nicm> | 2019-11-28 09:51:58 +0000 |
commit | c416fe0da43f9caffd8b5f6c1a627c8f7a16f881 (patch) | |
tree | a8dada3909f6f8d21ddc1f1aa187e20cb897063a | |
parent | 9ea05b2fb32395d717ead5d7904acdfaa852b068 (diff) | |
download | rtmux-c416fe0da43f9caffd8b5f6c1a627c8f7a16f881.tar.gz rtmux-c416fe0da43f9caffd8b5f6c1a627c8f7a16f881.tar.bz2 rtmux-c416fe0da43f9caffd8b5f6c1a627c8f7a16f881.zip |
Add xrecallocarray.
-rw-r--r-- | xmalloc.c | 14 | ||||
-rw-r--r-- | xmalloc.h | 1 |
2 files changed, 15 insertions, 0 deletions
@@ -71,6 +71,20 @@ xreallocarray(void *ptr, size_t nmemb, size_t size) return new_ptr; } +void * +xrecallocarray(void *ptr, size_t oldnmemb, size_t nmemb, size_t size) +{ + void *new_ptr; + + if (nmemb == 0 || size == 0) + fatalx("xrecallocarray: zero size"); + new_ptr = recallocarray(ptr, oldnmemb, nmemb, size); + if (new_ptr == NULL) + fatalx("xrecallocarray: allocating %zu * %zu bytes: %s", + nmemb, size, strerror(errno)); + return new_ptr; +} + char * xstrdup(const char *str) { @@ -23,6 +23,7 @@ void *xmalloc(size_t); void *xcalloc(size_t, size_t); void *xrealloc(void *, size_t); void *xreallocarray(void *, size_t, size_t); +void *xrecallocarray(void *, size_t, size_t, size_t); char *xstrdup(const char *); char *xstrndup(const char *, size_t); int xasprintf(char **, const char *, ...) |