mirror of https://github.com/xzeldon/htop.git
Add assert and __attribute__((nonnull)) on xStrdup
__attribute__((nonnull)) will help catching "calling with NULL" mistake on compile time. I also convert xStrdup into a macro, that will do assert() inline when the code is *not* built with -DNDEBUG . For release builds (with -DNDEBUG), preprocessor trick will ensure that generated code remains the same.
This commit is contained in:
parent
e288f690af
commit
3297616efa
15
XAlloc.c
15
XAlloc.c
|
@ -5,6 +5,7 @@
|
||||||
#ifndef _GNU_SOURCE
|
#ifndef _GNU_SOURCE
|
||||||
#define _GNU_SOURCE
|
#define _GNU_SOURCE
|
||||||
#endif
|
#endif
|
||||||
|
#include <assert.h>
|
||||||
#include <err.h>
|
#include <err.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
@ -43,7 +44,19 @@ void* xRealloc(void* ptr, size_t size) {
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
|
|
||||||
char* xStrdup(const char* str) {
|
#undef xStrdup
|
||||||
|
#undef xStrdup_
|
||||||
|
#ifdef NDEBUG
|
||||||
|
# define xStrdup_ xStrdup
|
||||||
|
#else
|
||||||
|
# define xStrdup(str_) (assert(str_), xStrdup_(str_))
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if ((__GNUC__ > 3) || (__GNUC__ == 3 && __GNUC_MINOR__ >= 3))
|
||||||
|
char* xStrdup_(const char* str) __attribute__((nonnull));
|
||||||
|
#endif // GNU C 3.3 or later
|
||||||
|
|
||||||
|
char* xStrdup_(const char* str) {
|
||||||
char* data = strdup(str);
|
char* data = strdup(str);
|
||||||
if (!data) {
|
if (!data) {
|
||||||
fail();
|
fail();
|
||||||
|
|
14
XAlloc.h
14
XAlloc.h
|
@ -15,6 +15,18 @@ void* xCalloc(size_t nmemb, size_t size);
|
||||||
|
|
||||||
void* xRealloc(void* ptr, size_t size);
|
void* xRealloc(void* ptr, size_t size);
|
||||||
|
|
||||||
char* xStrdup(const char* str);
|
#undef xStrdup
|
||||||
|
#undef xStrdup_
|
||||||
|
#ifdef NDEBUG
|
||||||
|
# define xStrdup_ xStrdup
|
||||||
|
#else
|
||||||
|
# define xStrdup(str_) (assert(str_), xStrdup_(str_))
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if ((__GNUC__ > 3) || (__GNUC__ == 3 && __GNUC_MINOR__ >= 3))
|
||||||
|
char* xStrdup_(const char* str) __attribute__((nonnull));
|
||||||
|
#endif // GNU C 3.3 or later
|
||||||
|
|
||||||
|
char* xStrdup_(const char* str);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in New Issue