]> git.kaiwu.me - klib.git/commitdiff
Prevent unused function warnings in khash.h, klist.h
authorJohn Marshall <jm18@sanger.ac.uk>
Tue, 24 Mar 2015 09:37:12 +0000 (09:37 +0000)
committerJohn Marshall <jm18@sanger.ac.uk>
Thu, 23 Jul 2015 10:31:17 +0000 (11:31 +0100)
Recent versions of Clang warn about unused static inline functions
in .c files (though they suppress this warning for such definitions
in header files).  Definitions via KHASH_INIT etc are effectively in
the .c file, and it's impractical to make these inline other than
static inline; so add attributes to suppress these warnings.

khash.h
klist.h

diff --git a/khash.h b/khash.h
index 5e55088b2ac125fb52d38d76df9681a1decf6acd..06fc7a3318f26fca340349bcb97bc78e44606a48 100644 (file)
--- a/khash.h
+++ b/khash.h
@@ -151,6 +151,14 @@ typedef unsigned long long khint64_t;
 #endif
 #endif /* kh_inline */
 
+#ifndef klib_unused
+#if (defined __clang__ && __clang_major__ >= 3) || (defined __GNUC__ && __GNUC__ >= 3)
+#define klib_unused __attribute__ ((__unused__))
+#else
+#define klib_unused
+#endif
+#endif /* klib_unused */
+
 typedef khint32_t khint_t;
 typedef khint_t khiter_t;
 
@@ -355,7 +363,7 @@ static const double __ac_HASH_UPPER = 0.77;
        __KHASH_IMPL(name, SCOPE, khkey_t, khval_t, kh_is_map, __hash_func, __hash_equal)
 
 #define KHASH_INIT(name, khkey_t, khval_t, kh_is_map, __hash_func, __hash_equal) \
-       KHASH_INIT2(name, static kh_inline, khkey_t, khval_t, kh_is_map, __hash_func, __hash_equal)
+       KHASH_INIT2(name, static kh_inline klib_unused, khkey_t, khval_t, kh_is_map, __hash_func, __hash_equal)
 
 /* --- BEGIN OF HASH FUNCTIONS --- */
 
diff --git a/klist.h b/klist.h
index 8b33f271e14ecf8365738e773f2f7b49a25249b5..adc3db1e9dc4460e45877eb21003566f255f066d 100644 (file)
--- a/klist.h
+++ b/klist.h
 
 #include <stdlib.h>
 
-#define KMEMPOOL_INIT(name, kmptype_t, kmpfree_f)                                              \
+#ifndef klib_unused
+#if (defined __clang__ && __clang_major__ >= 3) || (defined __GNUC__ && __GNUC__ >= 3)
+#define klib_unused __attribute__ ((__unused__))
+#else
+#define klib_unused
+#endif
+#endif /* klib_unused */
+
+#define KMEMPOOL_INIT2(SCOPE, name, kmptype_t, kmpfree_f)                              \
        typedef struct {                                                                                                        \
                size_t cnt, n, max;                                                                                             \
                kmptype_t **buf;                                                                                                \
        } kmp_##name##_t;                                                                                                       \
-       static inline kmp_##name##_t *kmp_init_##name(void) {                           \
+       SCOPE kmp_##name##_t *kmp_init_##name(void) {                                           \
                return calloc(1, sizeof(kmp_##name##_t));                                               \
        }                                                                                                                                       \
-       static inline void kmp_destroy_##name(kmp_##name##_t *mp) {                     \
+       SCOPE void kmp_destroy_##name(kmp_##name##_t *mp) {                                     \
                size_t k;                                                                                                               \
                for (k = 0; k < mp->n; ++k) {                                                                   \
                        kmpfree_f(mp->buf[k]); free(mp->buf[k]);                                        \
                }                                                                                                                               \
                free(mp->buf); free(mp);                                                                                \
        }                                                                                                                                       \
-       static inline kmptype_t *kmp_alloc_##name(kmp_##name##_t *mp) {         \
+       SCOPE kmptype_t *kmp_alloc_##name(kmp_##name##_t *mp) {                         \
                ++mp->cnt;                                                                                                              \
                if (mp->n == 0) return calloc(1, sizeof(kmptype_t));                    \
                return mp->buf[--mp->n];                                                                                \
        }                                                                                                                                       \
-       static inline void kmp_free_##name(kmp_##name##_t *mp, kmptype_t *p) { \
+       SCOPE void kmp_free_##name(kmp_##name##_t *mp, kmptype_t *p) {          \
                --mp->cnt;                                                                                                              \
                if (mp->n == mp->max) {                                                                                 \
                        mp->max = mp->max? mp->max<<1 : 16;                                                     \
                mp->buf[mp->n++] = p;                                                                                   \
        }
 
+#define KMEMPOOL_INIT(name, kmptype_t, kmpfree_f)                                              \
+       KMEMPOOL_INIT2(static inline klib_unused, name, kmptype_t, kmpfree_f)
+
 #define kmempool_t(name) kmp_##name##_t
 #define kmp_init(name) kmp_init_##name()
 #define kmp_destroy(name, mp) kmp_destroy_##name(mp)
 #define kmp_alloc(name, mp) kmp_alloc_##name(mp)
 #define kmp_free(name, mp, p) kmp_free_##name(mp, p)
 
-#define KLIST_INIT(name, kltype_t, kmpfree_t)                                                  \
+#define KLIST_INIT2(SCOPE, name, kltype_t, kmpfree_t)                                  \
        struct __kl1_##name {                                                                                           \
                kltype_t data;                                                                                                  \
                struct __kl1_##name *next;                                                                              \
        };                                                                                                                                      \
        typedef struct __kl1_##name kl1_##name;                                                         \
-       KMEMPOOL_INIT(name, kl1_##name, kmpfree_t)                                                      \
+       KMEMPOOL_INIT2(SCOPE, name, kl1_##name, kmpfree_t)                                      \
        typedef struct {                                                                                                        \
                kl1_##name *head, *tail;                                                                                \
                kmp_##name##_t *mp;                                                                                             \
                size_t size;                                                                                                    \
        } kl_##name##_t;                                                                                                        \
-       static inline kl_##name##_t *kl_init_##name(void) {                                     \
+       SCOPE kl_##name##_t *kl_init_##name(void) {                                                     \
                kl_##name##_t *kl = calloc(1, sizeof(kl_##name##_t));                   \
                kl->mp = kmp_init(name);                                                                                \
                kl->head = kl->tail = kmp_alloc(name, kl->mp);                                  \
                kl->head->next = 0;                                                                                             \
                return kl;                                                                                                              \
        }                                                                                                                                       \
-       static inline void kl_destroy_##name(kl_##name##_t *kl) {                       \
+       SCOPE void kl_destroy_##name(kl_##name##_t *kl) {                                       \
                kl1_##name *p;                                                                                                  \
                for (p = kl->head; p != kl->tail; p = p->next)                                  \
                        kmp_free(name, kl->mp, p);                                                                      \
                kmp_destroy(name, kl->mp);                                                                              \
                free(kl);                                                                                                               \
        }                                                                                                                                       \
-       static inline kltype_t *kl_pushp_##name(kl_##name##_t *kl) {            \
+       SCOPE kltype_t *kl_pushp_##name(kl_##name##_t *kl) {                            \
                kl1_##name *q, *p = kmp_alloc(name, kl->mp);                                    \
                q = kl->tail; p->next = 0; kl->tail->next = p; kl->tail = p;    \
                ++kl->size;                                                                                                             \
                return &q->data;                                                                                                \
        }                                                                                                                                       \
-       static inline int kl_shift_##name(kl_##name##_t *kl, kltype_t *d) { \
+       SCOPE int kl_shift_##name(kl_##name##_t *kl, kltype_t *d) {                     \
                kl1_##name *p;                                                                                                  \
                if (kl->head->next == 0) return -1;                                                             \
                --kl->size;                                                                                                             \
                return 0;                                                                                                               \
        }
 
+#define KLIST_INIT(name, kltype_t, kmpfree_t)                                                  \
+       KLIST_INIT2(static inline klib_unused, name, kltype_t, kmpfree_t)
+
 #define kliter_t(name) kl1_##name
 #define klist_t(name) kl_##name##_t
 #define kl_val(iter) ((iter)->data)