A small library that's provide helpers for programmers

Dependents:   PYRN

Committer:
clemounet
Date:
Fri Mar 27 16:48:12 2015 +0000
Revision:
2:6cc4c56940af
Child:
3:9d3aebd62b82
.MyDebug. Add the Debug macros and stuffs that print nice stuff on console; .MyThread. StackSize are customisable

Who changed what in which revision?

UserRevisionLine numberNew contents of line
clemounet 2:6cc4c56940af 1 /* dbg.h */
clemounet 2:6cc4c56940af 2 /* Copyright (C) 2012 mbed.org, MIT License
clemounet 2:6cc4c56940af 3 *
clemounet 2:6cc4c56940af 4 * Permission is hereby granted, free of charge, to any person obtaining a copy of this software
clemounet 2:6cc4c56940af 5 * and associated documentation files (the "Software"), to deal in the Software without restriction,
clemounet 2:6cc4c56940af 6 * including without limitation the rights to use, copy, modify, merge, publish, distribute,
clemounet 2:6cc4c56940af 7 * sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is
clemounet 2:6cc4c56940af 8 * furnished to do so, subject to the following conditions:
clemounet 2:6cc4c56940af 9 *
clemounet 2:6cc4c56940af 10 * The above copyright notice and this permission notice shall be included in all copies or
clemounet 2:6cc4c56940af 11 * substantial portions of the Software.
clemounet 2:6cc4c56940af 12 *
clemounet 2:6cc4c56940af 13 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING
clemounet 2:6cc4c56940af 14 * BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
clemounet 2:6cc4c56940af 15 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
clemounet 2:6cc4c56940af 16 * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
clemounet 2:6cc4c56940af 17 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
clemounet 2:6cc4c56940af 18 */
clemounet 2:6cc4c56940af 19
clemounet 2:6cc4c56940af 20 #ifndef DBG_H_
clemounet 2:6cc4c56940af 21 #define DBG_H_
clemounet 2:6cc4c56940af 22
clemounet 2:6cc4c56940af 23 #ifdef __cplusplus
clemounet 2:6cc4c56940af 24 extern "C" {
clemounet 2:6cc4c56940af 25 #endif
clemounet 2:6cc4c56940af 26
clemounet 2:6cc4c56940af 27 void debug_init(void);
clemounet 2:6cc4c56940af 28 void debug(int level, const char* module, int line, const char* fmt, ...);
clemounet 2:6cc4c56940af 29 void debug_set_newline(const char* newline);
clemounet 2:6cc4c56940af 30 void debug_set_speed(int speed);
clemounet 2:6cc4c56940af 31 void debug_error(const char* module, int line, int ret);
clemounet 2:6cc4c56940af 32 void debug_exact(const char* fmt, ...);
clemounet 2:6cc4c56940af 33 void debug_memdump(int level, const char* module, int line, const char* msg, const char* addr, int len);
clemounet 2:6cc4c56940af 34
clemounet 2:6cc4c56940af 35 #define DBG_INIT() do{ debug_init(); }while(0)
clemounet 2:6cc4c56940af 36
clemounet 2:6cc4c56940af 37 #define DBG_SET_NEWLINE( x ) do{ debug_set_newline(x); }while(0)
clemounet 2:6cc4c56940af 38
clemounet 2:6cc4c56940af 39 #define DBG_SET_SPEED( x ) do{ debug_set_speed(x); }while(0)
clemounet 2:6cc4c56940af 40
clemounet 2:6cc4c56940af 41 #if __DEBUG__ > 0
clemounet 2:6cc4c56940af 42 #ifndef __MODULE__
clemounet 2:6cc4c56940af 43 #error "__MODULE__ must be defined"
clemounet 2:6cc4c56940af 44 #endif
clemounet 2:6cc4c56940af 45 #endif
clemounet 2:6cc4c56940af 46
clemounet 2:6cc4c56940af 47 #if __DEBUG__ >= 1
clemounet 2:6cc4c56940af 48 #define ERR(...) do{ debug(1, __MODULE__, __LINE__, __VA_ARGS__); }while(0)
clemounet 2:6cc4c56940af 49 #else
clemounet 2:6cc4c56940af 50 #define ERR(...) do{ }while(0)
clemounet 2:6cc4c56940af 51 #endif
clemounet 2:6cc4c56940af 52
clemounet 2:6cc4c56940af 53 #if __DEBUG__ >= 2
clemounet 2:6cc4c56940af 54 #define WARN(...) do{ debug(2, __MODULE__, __LINE__, __VA_ARGS__); }while(0)
clemounet 2:6cc4c56940af 55 #else
clemounet 2:6cc4c56940af 56 #define WARN(...) do{ }while(0)
clemounet 2:6cc4c56940af 57 #endif
clemounet 2:6cc4c56940af 58
clemounet 2:6cc4c56940af 59 #if __DEBUG__ >= 3
clemounet 2:6cc4c56940af 60 #define INFO(...) do{ debug(3, __MODULE__, __LINE__, __VA_ARGS__); }while(0)
clemounet 2:6cc4c56940af 61 #define CHECK(ret) do{ if(ret){ debug_error(__MODULE__, __LINE__, ret); } }while(0)
clemounet 2:6cc4c56940af 62 #else
clemounet 2:6cc4c56940af 63 #define INFO(...) do{ }while(0)
clemounet 2:6cc4c56940af 64 #define CHECK(ret) do{ }while(0)
clemounet 2:6cc4c56940af 65 #endif
clemounet 2:6cc4c56940af 66
clemounet 2:6cc4c56940af 67 #if __DEBUG__ >= 4
clemounet 2:6cc4c56940af 68 #define DBG(...) do{ debug(4, __MODULE__, __LINE__, __VA_ARGS__); }while(0)
clemounet 2:6cc4c56940af 69 #define DBGX(...) do{ debug_exact(__VA_ARGS__); }while(0)
clemounet 2:6cc4c56940af 70 #define DBG_MEMDUMP(...) do { debug_memdump(4, __MODULE__, __LINE__,__VA_ARGS__); } while(0)
clemounet 2:6cc4c56940af 71 #else
clemounet 2:6cc4c56940af 72 #define DBG(...) do{ }while(0)
clemounet 2:6cc4c56940af 73 #define DBGX(...) do{ }while(0)
clemounet 2:6cc4c56940af 74 #define DBG_MEMDUMP(...) do { } while(0)
clemounet 2:6cc4c56940af 75 #endif
clemounet 2:6cc4c56940af 76
clemounet 2:6cc4c56940af 77 #ifdef __cplusplus
clemounet 2:6cc4c56940af 78 }
clemounet 2:6cc4c56940af 79 #endif
clemounet 2:6cc4c56940af 80
clemounet 2:6cc4c56940af 81 #endif /* DBG_H_ */