From dcfbcf5cce40b473afb8303245c035f37d72ac9b Mon Sep 17 00:00:00 2001 From: Eric Biggers Date: Sun, 12 Aug 2012 21:17:21 -0500 Subject: [PATCH] util.h: gcc printf format attribute --- src/util.h | 95 ++++++++++++++++++++++++++++++------------------------ 1 file changed, 52 insertions(+), 43 deletions(-) diff --git a/src/util.h b/src/util.h index 09a64db3..3d917bf5 100644 --- a/src/util.h +++ b/src/util.h @@ -8,6 +8,27 @@ #include #include "config.h" +#ifdef __GNUC__ +# define WIMLIBAPI __attribute__((visibility("default"))) +# define NOINLINE __attribute__((noinline)) +# define ALWAYS_INLINE inline __attribute__((always_inline)) +# define FORMAT(type, format_str, args_start) \ + __attribute__((format(type, format_str, args_start))) +# if __GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 4) +# define COLD __attribute__((cold)) +# define HOT __attribute__((hot)) +# else +# define COLD +# define HOT +# endif +#else +# define WIMLIBAPI +# define NOINLINE +# define ALWAYS_INLINE inline +# define FORMAT(type, format_str, args_start) +# define COLD +# define HOT +#endif /* __GNUC__ */ typedef uint8_t u8; typedef uint16_t u16; @@ -30,34 +51,36 @@ typedef unsigned uint; #ifdef ENABLE_ERROR_MESSAGES extern bool __wimlib_print_errors; -extern void wimlib_error(const char *format, ...); -extern void wimlib_warning(const char *format, ...); -# define ERROR wimlib_error -# define WARNING wimlib_warning +extern void wimlib_error(const char *format, ...) + FORMAT(printf, 1, 2) COLD; +extern void wimlib_warning(const char *format, ...) + FORMAT(printf, 1, 2) COLD; +# define ERROR wimlib_error +# define WARNING wimlib_warning #else -# define ERROR(format, ...) -# define WARNING(format, ...) +# define ERROR(format, ...) +# define WARNING(format, ...) #endif /* ENABLE_ERROR_MESSAGES */ #if defined(ENABLE_DEBUG) || defined(ENABLE_MORE_DEBUG) -#include -# define DEBUG(format, ...) \ -({ \ - int __errno_save = errno; \ - fprintf(stdout, "[%s %d] %s(): " format, \ - __FILE__, __LINE__, __func__, ## __VA_ARGS__); \ - fflush(stdout); \ - errno = __errno_save; \ +# include +# define DEBUG(format, ...) \ + ({ \ + int __errno_save = errno; \ + fprintf(stdout, "[%s %d] %s(): " format, \ + __FILE__, __LINE__, __func__, ## __VA_ARGS__); \ + fflush(stdout); \ + errno = __errno_save; \ }) #else -# define DEBUG(format, ...) +# define DEBUG(format, ...) #endif /* ENABLE_DEBUG || ENABLE_MORE_DEBUG */ #ifdef ENABLE_MORE_DEBUG -# define DEBUG2(format, ...) DEBUG(format, ## __VA_ARGS__) +# define DEBUG2(format, ...) DEBUG(format, ## __VA_ARGS__) #else -# define DEBUG2(format, ...) +# define DEBUG2(format, ...) #endif /* ENABLE_DEBUG */ #ifdef ENABLE_ASSERTIONS @@ -67,19 +90,6 @@ extern void wimlib_warning(const char *format, ...); # define wimlib_assert(expr) #endif -#ifdef __GNUC__ -# define WIMLIBAPI __attribute__((visibility("default"))) -# define NOINLINE __attribute__((noinline)) -# define ALWAYS_INLINE inline __attribute__((always_inline)) -# define COLD __attribute__((cold)) -# define HOT __attribute__((hot)) -#else -# define WIMLIBAPI -# define NOINLINE -# define ALWAYS_INLINE inline -# define COLD -# define HOT -#endif /* __GNUC__ */ #ifdef ENABLE_CUSTOM_MEMORY_ALLOCATOR extern void *(*wimlib_malloc_func)(size_t); @@ -87,19 +97,19 @@ extern void (*wimlib_free_func)(void *); extern void *(*wimlib_realloc)(void *, size_t); extern void *wimlib_calloc(size_t nmemb, size_t size); extern char *wimlib_strdup(const char *str); -# define MALLOC wimlib_malloc_func -# define FREE wimlib_free_func -# define REALLOC wimlib_realloc_func -# define CALLOC wimlib_calloc -# define STRDUP wimlib_strdup +# define MALLOC wimlib_malloc_func +# define FREE wimlib_free_func +# define REALLOC wimlib_realloc_func +# define CALLOC wimlib_calloc +# define STRDUP wimlib_strdup #else -#include -#include -# define MALLOC malloc -# define FREE free -# define REALLOC realloc -# define CALLOC calloc -# define STRDUP strdup +# include +# include +# define MALLOC malloc +# define FREE free +# define REALLOC realloc +# define CALLOC calloc +# define STRDUP strdup #endif /* ENABLE_CUSTOM_MEMORY_ALLOCATOR */ @@ -128,7 +138,6 @@ extern int get_num_path_components(const char *path); extern ssize_t full_write(int fd, const void *buf, size_t n); - static inline void print_byte_field(const u8 field[], size_t len) { while (len--) -- 2.43.0