Dependents:   RTnoV3 RTnoV3_LED RTnoV3_Template RTnoV3_ADC ... more

Committer:
sherckuith
Date:
Sat Dec 31 11:25:27 2011 +0000
Revision:
0:479ce5546098
Ethernet

Who changed what in which revision?

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