X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=libmemcached%2Fwatchpoint.h;h=822101e9b3334d90e07ade3dc9683713059fb2f6;hb=462de46ceddc9846bbefe91dca9915c5c538308d;hp=b4fa50e6e8e6e914693ea83f04bc632e91c1c552;hpb=f0cc25810bfd089de866bd0d1e35c3157e86a930;p=awesomized%2Flibmemcached diff --git a/libmemcached/watchpoint.h b/libmemcached/watchpoint.h index b4fa50e6..822101e9 100644 --- a/libmemcached/watchpoint.h +++ b/libmemcached/watchpoint.h @@ -37,74 +37,15 @@ #pragma once -/* Some personal debugging functions */ -#if defined(DEBUG) - -#ifdef TARGET_OS_LINUX -static inline void libmemcached_stack_dump(void) -{ - void *array[10]; - int size; - char **strings; - - size= backtrace(array, 10); - strings= backtrace_symbols(array, size); - - fprintf(stderr, "Found %d stack frames.\n", size); - - for (int x= 0; x < size; x++) - fprintf(stderr, "%s\n", strings[x]); - - free (strings); - - fflush(stderr); -} - -#elif defined(__sun) -#include - -static inline void libmemcached_stack_dump(void) -{ - fflush(stderr); - printstack(fileno(stderr)); -} - -#else - -static inline void libmemcached_stack_dump(void) -{ } - -#endif // libmemcached_stack_dump() - -#include - -#define WATCHPOINT do { fprintf(stderr, "\nWATCHPOINT %s:%d (%s)\n", __FILE__, __LINE__,__func__);fflush(stdout); } while (0) -#define WATCHPOINT_ERROR(A) do {fprintf(stderr, "\nWATCHPOINT %s:%d %s\n", __FILE__, __LINE__, memcached_strerror(NULL, A));fflush(stdout); } while (0) -#define WATCHPOINT_IFERROR(A) do { if(A != MEMCACHED_SUCCESS)fprintf(stderr, "\nWATCHPOINT %s:%d %s\n", __FILE__, __LINE__, memcached_strerror(NULL, A));fflush(stdout); } while (0) -#define WATCHPOINT_STRING(A) do { fprintf(stderr, "\nWATCHPOINT %s:%d (%s) %s\n", __FILE__, __LINE__,__func__,A);fflush(stdout); } while (0) -#define WATCHPOINT_STRING_LENGTH(A,B) do { fprintf(stderr, "\nWATCHPOINT %s:%d (%s) %.*s\n", __FILE__, __LINE__,__func__,(int)B,A);fflush(stdout); } while (0) -#define WATCHPOINT_NUMBER(A) do { fprintf(stderr, "\nWATCHPOINT %s:%d (%s) %lu\n", __FILE__, __LINE__,__func__,(unsigned long)(A));fflush(stdout); } while (0) -#define WATCHPOINT_LABELED_NUMBER(A,B) do { fprintf(stderr, "\nWATCHPOINT %s:%d (%s) %s:%lu\n", __FILE__, __LINE__,__func__,(A),(unsigned long)(B));fflush(stdout); } while (0) -#define WATCHPOINT_IF_LABELED_NUMBER(A,B,C) do { if(A) {fprintf(stderr, "\nWATCHPOINT %s:%d (%s) %s:%lu\n", __FILE__, __LINE__,__func__,(B),(unsigned long)(C));fflush(stdout);} } while (0) -#define WATCHPOINT_ERRNO(A) do { fprintf(stderr, "\nWATCHPOINT %s:%d (%s) %s\n", __FILE__, __LINE__,__func__, strerror(A));fflush(stdout); } while (0) -#define WATCHPOINT_ASSERT_PRINT(A,B,C) do { if(!(A)){fprintf(stderr, "\nWATCHPOINT ASSERT %s:%d (%s) ", __FILE__, __LINE__,__func__);fprintf(stderr, (B),(C));fprintf(stderr,"\n");fflush(stdout); libmemcached_stack_dump(); } assert((A)); } while (0) -#define WATCHPOINT_ASSERT(A) do { if (! (A)) {libmemcached_stack_dump();} assert((A)); } while (0) -#define WATCHPOINT_ASSERT_INITIALIZED(A) do { if (! (A)) { libmemcached_stack_dump(); } assert(memcached_is_initialized((A))); } while (0); -#define WATCHPOINT_SET(A) do { A; } while(0); - -#else - #define WATCHPOINT #define WATCHPOINT_ERROR(A) -#define WATCHPOINT_IFERROR(A) +#define WATCHPOINT_IFERROR(__memcached_return_t) (void)(__memcached_return_t) #define WATCHPOINT_STRING(A) #define WATCHPOINT_NUMBER(A) #define WATCHPOINT_LABELED_NUMBER(A,B) #define WATCHPOINT_IF_LABELED_NUMBER(A,B,C) #define WATCHPOINT_ERRNO(A) #define WATCHPOINT_ASSERT_PRINT(A,B,C) -#define WATCHPOINT_ASSERT(A) +#define WATCHPOINT_ASSERT(A) (void)(A) #define WATCHPOINT_ASSERT_INITIALIZED(A) #define WATCHPOINT_SET(A) - -#endif /* DEBUG */