A small library that's provide helpers for programmers

Dependents:   PYRN

Committer:
clemounet
Date:
Tue Apr 14 13:07:53 2015 +0000
Revision:
4:eef83534b19e
Parent:
3:9d3aebd62b82
.add CallBack

Who changed what in which revision?

UserRevisionLine numberNew contents of line
clemounet 2:6cc4c56940af 1
clemounet 2:6cc4c56940af 2 #ifndef DBG_H_
clemounet 2:6cc4c56940af 3 #define DBG_H_
clemounet 2:6cc4c56940af 4
clemounet 2:6cc4c56940af 5 #ifdef __cplusplus
clemounet 2:6cc4c56940af 6 extern "C" {
clemounet 2:6cc4c56940af 7 #endif
clemounet 2:6cc4c56940af 8
clemounet 2:6cc4c56940af 9 void debug_init(void);
clemounet 2:6cc4c56940af 10 void debug(int level, const char* module, int line, const char* fmt, ...);
clemounet 2:6cc4c56940af 11 void debug_set_newline(const char* newline);
clemounet 2:6cc4c56940af 12 void debug_set_speed(int speed);
clemounet 2:6cc4c56940af 13 void debug_error(const char* module, int line, int ret);
clemounet 2:6cc4c56940af 14 void debug_exact(const char* fmt, ...);
clemounet 2:6cc4c56940af 15 void debug_memdump(int level, const char* module, int line, const char* msg, const char* addr, int len);
clemounet 2:6cc4c56940af 16
clemounet 2:6cc4c56940af 17 #define DBG_INIT() do{ debug_init(); }while(0)
clemounet 2:6cc4c56940af 18
clemounet 2:6cc4c56940af 19 #define DBG_SET_NEWLINE( x ) do{ debug_set_newline(x); }while(0)
clemounet 2:6cc4c56940af 20
clemounet 2:6cc4c56940af 21 #define DBG_SET_SPEED( x ) do{ debug_set_speed(x); }while(0)
clemounet 2:6cc4c56940af 22
clemounet 2:6cc4c56940af 23 #if __DEBUG__ > 0
clemounet 2:6cc4c56940af 24 #ifndef __MODULE__
clemounet 2:6cc4c56940af 25 #error "__MODULE__ must be defined"
clemounet 2:6cc4c56940af 26 #endif
clemounet 2:6cc4c56940af 27 #endif
clemounet 2:6cc4c56940af 28
clemounet 2:6cc4c56940af 29 #if __DEBUG__ >= 1
clemounet 2:6cc4c56940af 30 #define ERR(...) do{ debug(1, __MODULE__, __LINE__, __VA_ARGS__); }while(0)
clemounet 2:6cc4c56940af 31 #else
clemounet 2:6cc4c56940af 32 #define ERR(...) do{ }while(0)
clemounet 2:6cc4c56940af 33 #endif
clemounet 2:6cc4c56940af 34
clemounet 2:6cc4c56940af 35 #if __DEBUG__ >= 2
clemounet 2:6cc4c56940af 36 #define WARN(...) do{ debug(2, __MODULE__, __LINE__, __VA_ARGS__); }while(0)
clemounet 2:6cc4c56940af 37 #else
clemounet 2:6cc4c56940af 38 #define WARN(...) do{ }while(0)
clemounet 2:6cc4c56940af 39 #endif
clemounet 2:6cc4c56940af 40
clemounet 2:6cc4c56940af 41 #if __DEBUG__ >= 3
clemounet 2:6cc4c56940af 42 #define INFO(...) do{ debug(3, __MODULE__, __LINE__, __VA_ARGS__); }while(0)
clemounet 2:6cc4c56940af 43 #define CHECK(ret) do{ if(ret){ debug_error(__MODULE__, __LINE__, ret); } }while(0)
clemounet 2:6cc4c56940af 44 #else
clemounet 2:6cc4c56940af 45 #define INFO(...) do{ }while(0)
clemounet 2:6cc4c56940af 46 #define CHECK(ret) do{ }while(0)
clemounet 2:6cc4c56940af 47 #endif
clemounet 2:6cc4c56940af 48
clemounet 2:6cc4c56940af 49 #if __DEBUG__ >= 4
clemounet 2:6cc4c56940af 50 #define DBG(...) do{ debug(4, __MODULE__, __LINE__, __VA_ARGS__); }while(0)
clemounet 2:6cc4c56940af 51 #define DBGX(...) do{ debug_exact(__VA_ARGS__); }while(0)
clemounet 2:6cc4c56940af 52 #define DBG_MEMDUMP(...) do { debug_memdump(4, __MODULE__, __LINE__,__VA_ARGS__); } while(0)
clemounet 2:6cc4c56940af 53 #else
clemounet 2:6cc4c56940af 54 #define DBG(...) do{ }while(0)
clemounet 2:6cc4c56940af 55 #define DBGX(...) do{ }while(0)
clemounet 2:6cc4c56940af 56 #define DBG_MEMDUMP(...) do { } while(0)
clemounet 2:6cc4c56940af 57 #endif
clemounet 2:6cc4c56940af 58
clemounet 2:6cc4c56940af 59 #ifdef __cplusplus
clemounet 2:6cc4c56940af 60 }
clemounet 2:6cc4c56940af 61 #endif
clemounet 2:6cc4c56940af 62
clemounet 2:6cc4c56940af 63 #endif /* DBG_H_ */