summaryrefslogtreecommitdiffstats
path: root/worker/util.h
blob: 5bf0541369c74daaa9efff13748fad69a89a77a5 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
#ifndef __WORKER_UTIL_H__
#define __WORKER_UTIL_H__

extern int debug_level;
void debug_fn(const char *format, ...);

#include <malloc.h>
#define MEMINFO do{ \
    struct mallinfo minfo; \
    minfo=mallinfo(); \
    DEBUG(5, ("---allocated space: %d-----\n",minfo.uordblks)); \
}while(0)

#define DEBUG(level, body) do { \
    if (level <= debug_level) { \
        debug_fn("DEBUG-%d (%s,%d): %s: ", level, __FILE__, __LINE__ , __FUNCTION__); \
        debug_fn body; \
    } \
} while(0)


#define CHECK(pointer, val, message, action) do { \
    if (pointer == (val)) { \
        DEBUG(0, message); \
        action; \
    } \
} while(0)

#define CHECK_NULL_FATAL(pointer, message) do { \
    if (pointer == NULL) { \
        DEBUG(0, message); \
        exit(1); \
    } \
} while(0)

#define CHECK_NULL_RETURN(pointer, message) do { \
    if (pointer == NULL) { \
        DEBUG(0, message); \
        return(-1); \
    } \
} while(0)

#define CHECK_MINUS_ONE_RETURN(pointer, message) do { \
    if (pointer == -1) { \
        DEBUG(0, message); \
        return(-1); \
    } \
} while(0)

#endif /* __WORKER_UTIL_H__ */