summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChristian Göttsche <cgzones@googlemail.com>2020-11-20 17:04:19 +0100
committerBenBE <BenBE@geshi.org>2021-01-11 21:08:58 +0100
commite6d536dd3f12bc7f5c56062a008d5c17e3417fa8 (patch)
tree91d01a06323a3c7c902963f113ac176fc010235a
parent37e186fd6626e83f51d0267052677355575964d4 (diff)
Add compiler hints on memory allocating utility functions
-rw-r--r--Macros.h6
-rw-r--r--XUtils.h22
2 files changed, 17 insertions, 11 deletions
diff --git a/Macros.h b/Macros.h
index 64aaefa5..31ba37b5 100644
--- a/Macros.h
+++ b/Macros.h
@@ -33,6 +33,9 @@
#define ATTR_NONNULL __attribute__((nonnull))
#define ATTR_NORETURN __attribute__((noreturn))
#define ATTR_UNUSED __attribute__((unused))
+#define ATTR_ALLOC_SIZE1(a) __attribute__((alloc_size (a)))
+#define ATTR_ALLOC_SIZE2(a, b) __attribute__((alloc_size (a, b)))
+#define ATTR_MALLOC __attribute__((malloc))
#else /* __GNUC__ */
@@ -40,6 +43,9 @@
#define ATTR_NONNULL
#define ATTR_NORETURN
#define ATTR_UNUSED
+#define ATTR_ALLOC_SIZE1(a)
+#define ATTR_ALLOC_SIZE2(a, b)
+#define ATTR_MALLOC
#endif /* __GNUC__ */
diff --git a/XUtils.h b/XUtils.h
index 5eb5d63d..e89d06e0 100644
--- a/XUtils.h
+++ b/XUtils.h
@@ -21,15 +21,15 @@ in the source distribution for its full text.
void fail(void) ATTR_NORETURN;
-void* xMalloc(size_t size);
+void* xMalloc(size_t size) ATTR_ALLOC_SIZE1(1) ATTR_MALLOC;
-void* xMallocArray(size_t nmemb, size_t size);
+void* xMallocArray(size_t nmemb, size_t size) ATTR_ALLOC_SIZE2(1, 2) ATTR_MALLOC;
-void* xCalloc(size_t nmemb, size_t size);
+void* xCalloc(size_t nmemb, size_t size) ATTR_ALLOC_SIZE2(1, 2) ATTR_MALLOC;
-void* xRealloc(void* ptr, size_t size);
+void* xRealloc(void* ptr, size_t size) ATTR_ALLOC_SIZE1(2);
-void* xReallocArray(void* ptr, size_t nmemb, size_t size);
+void* xReallocArray(void* ptr, size_t nmemb, size_t size) ATTR_ALLOC_SIZE2(2, 3);
/*
* String_startsWith gives better performance if strlen(match) can be computed
@@ -47,17 +47,17 @@ static inline bool String_eq(const char* s1, const char* s2) {
return strcmp(s1, s2) == 0;
}
-char* String_cat(const char* s1, const char* s2);
+char* String_cat(const char* s1, const char* s2) ATTR_MALLOC;
-char* String_trim(const char* in);
+char* String_trim(const char* in) ATTR_MALLOC;
char** String_split(const char* s, char sep, size_t* n);
void String_freeArray(char** s);
-char* String_getToken(const char* line, unsigned short int numMatch);
+char* String_getToken(const char* line, unsigned short int numMatch) ATTR_MALLOC;
-char* String_readLine(FILE* fd);
+char* String_readLine(FILE* fd) ATTR_MALLOC;
/* Always null-terminates dest. Caller must pass a strictly positive size. */
size_t String_safeStrncpy(char *restrict dest, const char *restrict src, size_t size);
@@ -68,10 +68,10 @@ int xAsprintf(char** strp, const char* fmt, ...);
ATTR_FORMAT(printf, 3, 4)
int xSnprintf(char* buf, size_t len, const char* fmt, ...);
-char* xStrdup(const char* str) ATTR_NONNULL;
+char* xStrdup(const char* str) ATTR_NONNULL ATTR_MALLOC;
void free_and_xStrdup(char** ptr, const char* str);
-char* xStrndup(const char* str, size_t len) ATTR_NONNULL;
+char* xStrndup(const char* str, size_t len) ATTR_NONNULL ATTR_MALLOC;
ssize_t xReadfile(const char* pathname, void* buffer, size_t count);
ssize_t xReadfileat(openat_arg_t dirfd, const char* pathname, void* buffer, size_t count);

© 2014-2024 Faster IT GmbH | imprint | privacy policy