Dependents:   SNMPAgent HTTPServer think_speak_a cyassl-client ... more

Committer:
mamezu
Date:
Thu Dec 09 01:33:56 2010 +0000
Revision:
0:0f6c82fcde82

        

Who changed what in which revision?

UserRevisionLine numberNew contents of line
mamezu 0:0f6c82fcde82 1
mamezu 0:0f6c82fcde82 2 /*
mamezu 0:0f6c82fcde82 3 Copyright (c) 2010 Donatien Garnier (donatiengar [at] gmail [dot] com)
mamezu 0:0f6c82fcde82 4
mamezu 0:0f6c82fcde82 5 Permission is hereby granted, free of charge, to any person obtaining a copy
mamezu 0:0f6c82fcde82 6 of this software and associated documentation files (the "Software"), to deal
mamezu 0:0f6c82fcde82 7 in the Software without restriction, including without limitation the rights
mamezu 0:0f6c82fcde82 8 to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
mamezu 0:0f6c82fcde82 9 copies of the Software, and to permit persons to whom the Software is
mamezu 0:0f6c82fcde82 10 furnished to do so, subject to the following conditions:
mamezu 0:0f6c82fcde82 11
mamezu 0:0f6c82fcde82 12 The above copyright notice and this permission notice shall be included in
mamezu 0:0f6c82fcde82 13 all copies or substantial portions of the Software.
mamezu 0:0f6c82fcde82 14
mamezu 0:0f6c82fcde82 15 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
mamezu 0:0f6c82fcde82 16 IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
mamezu 0:0f6c82fcde82 17 FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
mamezu 0:0f6c82fcde82 18 AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
mamezu 0:0f6c82fcde82 19 LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
mamezu 0:0f6c82fcde82 20 OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
mamezu 0:0f6c82fcde82 21 THE SOFTWARE.
mamezu 0:0f6c82fcde82 22 */
mamezu 0:0f6c82fcde82 23
mamezu 0:0f6c82fcde82 24 /** \file
mamezu 0:0f6c82fcde82 25 Debugging helpers header file
mamezu 0:0f6c82fcde82 26 */
mamezu 0:0f6c82fcde82 27
mamezu 0:0f6c82fcde82 28 //#ifdef DBG_H
mamezu 0:0f6c82fcde82 29 //#define DBG_H
mamezu 0:0f6c82fcde82 30
mamezu 0:0f6c82fcde82 31 #ifdef __LWIP_DEBUG
mamezu 0:0f6c82fcde82 32 #define __DEBUG
mamezu 0:0f6c82fcde82 33 #endif
mamezu 0:0f6c82fcde82 34
mamezu 0:0f6c82fcde82 35 /*!
mamezu 0:0f6c82fcde82 36 \def __DEBUG
mamezu 0:0f6c82fcde82 37 To define to enable debugging in one file
mamezu 0:0f6c82fcde82 38 */
mamezu 0:0f6c82fcde82 39
mamezu 0:0f6c82fcde82 40 #ifdef __DEBUG
mamezu 0:0f6c82fcde82 41
mamezu 0:0f6c82fcde82 42 #ifndef __DEBUGSTREAM
mamezu 0:0f6c82fcde82 43 #define __DEBUGSTREAM
mamezu 0:0f6c82fcde82 44
mamezu 0:0f6c82fcde82 45
mamezu 0:0f6c82fcde82 46 class DebugStream
mamezu 0:0f6c82fcde82 47 {
mamezu 0:0f6c82fcde82 48 public:
mamezu 0:0f6c82fcde82 49 static void debug(const char* format, ...);
mamezu 0:0f6c82fcde82 50 static void release();
mamezu 0:0f6c82fcde82 51 static void breakPoint(const char* file, int line);
mamezu 0:0f6c82fcde82 52 private:
mamezu 0:0f6c82fcde82 53
mamezu 0:0f6c82fcde82 54 };
mamezu 0:0f6c82fcde82 55
mamezu 0:0f6c82fcde82 56 #undef DBG
mamezu 0:0f6c82fcde82 57 #undef DBG_END
mamezu 0:0f6c82fcde82 58 #undef BREAK
mamezu 0:0f6c82fcde82 59
mamezu 0:0f6c82fcde82 60 ///Debug output (if enabled), same syntax as printf, with heading info
mamezu 0:0f6c82fcde82 61 #define DBG(...) do{ DebugStream::debug("[%s:%s@%d] ", __FILE__, __FUNCTION__, __LINE__); DebugStream::debug(__VA_ARGS__); } while(0);
mamezu 0:0f6c82fcde82 62
mamezu 0:0f6c82fcde82 63 ///Debug output (if enabled), same syntax as printf, no heading info
mamezu 0:0f6c82fcde82 64 #define DBGL(...) do{ DebugStream::debug(__VA_ARGS__); } while(0);
mamezu 0:0f6c82fcde82 65 #define DBG_END DebugStream::release
mamezu 0:0f6c82fcde82 66
mamezu 0:0f6c82fcde82 67 ///Break point usin serial debug interface (if debug enbaled)
mamezu 0:0f6c82fcde82 68 #define BREAK() DebugStream::breakPoint(__FILE__, __LINE__)
mamezu 0:0f6c82fcde82 69 #endif
mamezu 0:0f6c82fcde82 70
mamezu 0:0f6c82fcde82 71 #else
mamezu 0:0f6c82fcde82 72 #undef DBG
mamezu 0:0f6c82fcde82 73 #undef DBG_END
mamezu 0:0f6c82fcde82 74 #undef BREAK
mamezu 0:0f6c82fcde82 75 #define DBG(...)
mamezu 0:0f6c82fcde82 76 #define DBG_END()
mamezu 0:0f6c82fcde82 77 #define BREAK()
mamezu 0:0f6c82fcde82 78 #endif
mamezu 0:0f6c82fcde82 79
mamezu 0:0f6c82fcde82 80 #ifdef __LWIP_DEBUG
mamezu 0:0f6c82fcde82 81 #ifndef __SNPRINTF
mamezu 0:0f6c82fcde82 82 #define __SNPRINTF
mamezu 0:0f6c82fcde82 83 #include "mbed.h"
mamezu 0:0f6c82fcde82 84
mamezu 0:0f6c82fcde82 85 //int snprintf(char *str, int size, const char *format, ...);
mamezu 0:0f6c82fcde82 86 #endif
mamezu 0:0f6c82fcde82 87 #endif
mamezu 0:0f6c82fcde82 88
mamezu 0:0f6c82fcde82 89 #ifdef __LWIP_DEBUG
mamezu 0:0f6c82fcde82 90 #undef __DEBUG
mamezu 0:0f6c82fcde82 91 #endif
mamezu 0:0f6c82fcde82 92
mamezu 0:0f6c82fcde82 93 //#endif
mamezu 0:0f6c82fcde82 94