Blynk library for embedded hardware. Works with Arduino, ESP8266, Raspberry Pi, Intel Edison/Galileo, LinkIt ONE, Particle Core/Photon, Energia, ARM mbed, etc. http://www.blynk.cc/
Dependents: Blynk_RBL_BLE_Nano Blynk_MicroBit Blynk_Serial Blynk_RBL_BLE_Nano
Blynk/BlynkDebug.h@7:8879692d4e6c, 2016-10-12 (annotated)
- Committer:
- Volodymyr Shymanskyy
- Date:
- Wed Oct 12 09:18:39 2016 +0300
- Revision:
- 7:8879692d4e6c
- Parent:
- 6:b942afadf9be
- Child:
- 9:7369ec77a3ea
Update library
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
vshymanskyy | 0:58b20b438383 | 1 | /** |
vshymanskyy | 0:58b20b438383 | 2 | * @file BlynkDebug.h |
vshymanskyy | 0:58b20b438383 | 3 | * @author Volodymyr Shymanskyy |
vshymanskyy | 0:58b20b438383 | 4 | * @license This project is released under the MIT License (MIT) |
vshymanskyy | 0:58b20b438383 | 5 | * @copyright Copyright (c) 2015 Volodymyr Shymanskyy |
vshymanskyy | 0:58b20b438383 | 6 | * @date Jan 2015 |
vshymanskyy | 0:58b20b438383 | 7 | * @brief Debug utilities |
vshymanskyy | 0:58b20b438383 | 8 | * |
vshymanskyy | 0:58b20b438383 | 9 | */ |
vshymanskyy | 0:58b20b438383 | 10 | |
vshymanskyy | 0:58b20b438383 | 11 | #ifndef BlynkDebug_h |
vshymanskyy | 0:58b20b438383 | 12 | #define BlynkDebug_h |
vshymanskyy | 0:58b20b438383 | 13 | |
vshymanskyy | 0:58b20b438383 | 14 | #include <Blynk/BlynkConfig.h> |
vshymanskyy | 0:58b20b438383 | 15 | #include <stddef.h> |
vshymanskyy | 0:58b20b438383 | 16 | #ifdef ESP8266 |
vshymanskyy | 0:58b20b438383 | 17 | extern "C" { |
vshymanskyy | 0:58b20b438383 | 18 | #include "ets_sys.h" |
vshymanskyy | 0:58b20b438383 | 19 | #include "os_type.h" |
vshymanskyy | 0:58b20b438383 | 20 | #include "mem.h" |
vshymanskyy | 0:58b20b438383 | 21 | } |
vshymanskyy | 0:58b20b438383 | 22 | #else |
vshymanskyy | 0:58b20b438383 | 23 | #include <inttypes.h> |
vshymanskyy | 0:58b20b438383 | 24 | #endif |
vshymanskyy | 0:58b20b438383 | 25 | |
vshymanskyy | 0:58b20b438383 | 26 | #if defined(ARDUINO_ARCH_ARC32) |
vshymanskyy | 0:58b20b438383 | 27 | typedef uint64_t millis_time_t; |
vshymanskyy | 0:58b20b438383 | 28 | #else |
vshymanskyy | 0:58b20b438383 | 29 | typedef uint32_t millis_time_t; |
vshymanskyy | 0:58b20b438383 | 30 | #endif |
vshymanskyy | 0:58b20b438383 | 31 | |
vshymanskyy | 0:58b20b438383 | 32 | #if defined(SPARK) || defined(PARTICLE) |
vshymanskyy | 0:58b20b438383 | 33 | #include "application.h" |
vshymanskyy | 0:58b20b438383 | 34 | #endif |
vshymanskyy | 0:58b20b438383 | 35 | |
vshymanskyy | 0:58b20b438383 | 36 | #if defined(ARDUINO) |
vshymanskyy | 0:58b20b438383 | 37 | #if ARDUINO >= 100 |
vshymanskyy | 0:58b20b438383 | 38 | #include "Arduino.h" |
vshymanskyy | 0:58b20b438383 | 39 | #else |
vshymanskyy | 0:58b20b438383 | 40 | #include "WProgram.h" |
vshymanskyy | 0:58b20b438383 | 41 | #endif |
vshymanskyy | 0:58b20b438383 | 42 | #endif |
vshymanskyy | 0:58b20b438383 | 43 | |
vshymanskyy | 0:58b20b438383 | 44 | #if !defined(ARDUINO) || (ARDUINO < 151) |
vshymanskyy | 0:58b20b438383 | 45 | #define BLYNK_NO_YIELD |
vshymanskyy | 0:58b20b438383 | 46 | #endif |
vshymanskyy | 0:58b20b438383 | 47 | |
vshymanskyy | 0:58b20b438383 | 48 | // General defines |
vshymanskyy | 0:58b20b438383 | 49 | |
vshymanskyy | 0:58b20b438383 | 50 | #define STRINGIFY(x) #x |
vshymanskyy | 0:58b20b438383 | 51 | #define TOSTRING(x) STRINGIFY(x) |
vshymanskyy | 0:58b20b438383 | 52 | #define COUNT_OF(x) ((sizeof(x)/sizeof(0[x])) / ((size_t)(!(sizeof(x) % sizeof(0[x]))))) |
vshymanskyy | 0:58b20b438383 | 53 | #define BLYNK_ATTR_PACKED __attribute__ ((__packed__)) |
vshymanskyy | 0:58b20b438383 | 54 | #define BLYNK_NORETURN __attribute__ ((noreturn)) |
Volodymyr Shymanskyy |
7:8879692d4e6c | 55 | #define BLYNK_UNUSED __attribute__((__unused__)) |
vshymanskyy | 0:58b20b438383 | 56 | |
vshymanskyy | 0:58b20b438383 | 57 | // Causes problems on some platforms |
vshymanskyy | 0:58b20b438383 | 58 | #define BLYNK_FORCE_INLINE inline //__attribute__((always_inline)) |
vshymanskyy | 0:58b20b438383 | 59 | |
vshymanskyy | 0:58b20b438383 | 60 | #if defined(__AVR__) |
vshymanskyy | 0:58b20b438383 | 61 | #include <avr/pgmspace.h> |
vshymanskyy | 0:58b20b438383 | 62 | #define BLYNK_HAS_PROGMEM |
vshymanskyy | 0:58b20b438383 | 63 | #define BLYNK_PROGMEM PROGMEM |
vshymanskyy | 0:58b20b438383 | 64 | #define BLYNK_F(s) F(s) |
vshymanskyy | 0:58b20b438383 | 65 | #define BLYNK_PSTR(s) PSTR(s) |
vshymanskyy | 0:58b20b438383 | 66 | #else |
vshymanskyy | 0:58b20b438383 | 67 | #define BLYNK_PROGMEM |
vshymanskyy | 0:58b20b438383 | 68 | #define BLYNK_F(s) s |
vshymanskyy | 0:58b20b438383 | 69 | #define BLYNK_PSTR(s) s |
vshymanskyy | 0:58b20b438383 | 70 | #endif |
vshymanskyy | 0:58b20b438383 | 71 | |
vshymanskyy | 0:58b20b438383 | 72 | #ifndef LED_BUILTIN |
vshymanskyy | 0:58b20b438383 | 73 | # define LED_BUILTIN 2 |
vshymanskyy | 0:58b20b438383 | 74 | #endif |
vshymanskyy | 0:58b20b438383 | 75 | |
vshymanskyy | 0:58b20b438383 | 76 | // Diagnostic defines |
vshymanskyy | 0:58b20b438383 | 77 | |
vshymanskyy | 0:58b20b438383 | 78 | size_t BlynkFreeRam(); |
vshymanskyy | 0:58b20b438383 | 79 | void BlynkReset() BLYNK_NORETURN; |
vshymanskyy | 0:58b20b438383 | 80 | void BlynkFatal() BLYNK_NORETURN; |
vshymanskyy | 0:58b20b438383 | 81 | |
vshymanskyy | 0:58b20b438383 | 82 | #define BLYNK_FATAL(msg) { BLYNK_LOG1(msg); BlynkFatal(); } |
vshymanskyy | 0:58b20b438383 | 83 | #define BLYNK_LOG_RAM() { BLYNK_LOG2(BLYNK_F("Free RAM: "), BlynkFreeRam()); } |
vshymanskyy | 0:58b20b438383 | 84 | #define BLYNK_LOG_FN() BLYNK_LOG3(BLYNK_F(__FUNCTION__), '@', __LINE__); |
vshymanskyy | 0:58b20b438383 | 85 | #define BLYNK_LOG_TROUBLE(t) BLYNK_LOG2(BLYNK_F("Trouble detected: http://docs.blynk.cc/#troubleshooting-"), t) |
vshymanskyy | 0:58b20b438383 | 86 | |
vshymanskyy | 0:58b20b438383 | 87 | #ifndef BLYNK_PRINT |
vshymanskyy | 0:58b20b438383 | 88 | #undef BLYNK_DEBUG |
vshymanskyy | 0:58b20b438383 | 89 | #endif |
vshymanskyy | 0:58b20b438383 | 90 | |
vshymanskyy | 0:58b20b438383 | 91 | #ifdef BLYNK_PRINT |
vshymanskyy | 0:58b20b438383 | 92 | |
vshymanskyy | 0:58b20b438383 | 93 | #if defined(ARDUINO) || defined(SPARK) || defined(PARTICLE) |
vshymanskyy | 0:58b20b438383 | 94 | |
vshymanskyy | 0:58b20b438383 | 95 | #if defined(ARDUINO_ARCH_ARC32) |
vshymanskyy | 0:58b20b438383 | 96 | // This will cause error - on purpose |
vshymanskyy | 0:58b20b438383 | 97 | #define BLYNK_LOG(msg, ...) BLYNK_LOG_UNAVAILABLE(msg, ##__VA_ARGS__) |
vshymanskyy | 0:58b20b438383 | 98 | #else |
vshymanskyy | 0:58b20b438383 | 99 | #define BLYNK_LOG(msg, ...) blynk_dbg_print(BLYNK_PSTR(msg), ##__VA_ARGS__) |
vshymanskyy | 0:58b20b438383 | 100 | #endif |
vshymanskyy | 0:58b20b438383 | 101 | |
vshymanskyy | 0:58b20b438383 | 102 | #define BLYNK_LOG1(p1) { BLYNK_LOG_TIME(); BLYNK_PRINT.println(p1); } |
vshymanskyy | 0:58b20b438383 | 103 | #define BLYNK_LOG2(p1,p2) { BLYNK_LOG_TIME(); BLYNK_PRINT.print(p1); BLYNK_PRINT.println(p2); } |
vshymanskyy | 0:58b20b438383 | 104 | #define BLYNK_LOG3(p1,p2,p3) { BLYNK_LOG_TIME(); BLYNK_PRINT.print(p1); BLYNK_PRINT.print(p2); BLYNK_PRINT.println(p3); } |
vshymanskyy | 0:58b20b438383 | 105 | #define BLYNK_LOG4(p1,p2,p3,p4) { BLYNK_LOG_TIME(); BLYNK_PRINT.print(p1); BLYNK_PRINT.print(p2); BLYNK_PRINT.print(p3); BLYNK_PRINT.println(p4); } |
vshymanskyy | 0:58b20b438383 | 106 | #define BLYNK_LOG6(p1,p2,p3,p4,p5,p6) { BLYNK_LOG_TIME(); BLYNK_PRINT.print(p1); BLYNK_PRINT.print(p2); BLYNK_PRINT.print(p3); BLYNK_PRINT.print(p4); BLYNK_PRINT.print(p5); BLYNK_PRINT.println(p6); } |
vshymanskyy | 0:58b20b438383 | 107 | #define BLYNK_LOG_IP(msg, ip) { BLYNK_LOG_TIME(); BLYNK_PRINT.print(BLYNK_F(msg)); \ |
vshymanskyy | 0:58b20b438383 | 108 | BLYNK_PRINT.print(ip[0]); BLYNK_PRINT.print('.'); \ |
vshymanskyy | 0:58b20b438383 | 109 | BLYNK_PRINT.print(ip[1]); BLYNK_PRINT.print('.'); \ |
vshymanskyy | 0:58b20b438383 | 110 | BLYNK_PRINT.print(ip[2]); BLYNK_PRINT.print('.'); \ |
vshymanskyy | 0:58b20b438383 | 111 | BLYNK_PRINT.println(ip[3]); } |
vshymanskyy | 0:58b20b438383 | 112 | #define BLYNK_LOG_IP_REV(msg, ip) { BLYNK_LOG_TIME(); BLYNK_PRINT.print(BLYNK_F(msg)); \ |
vshymanskyy | 0:58b20b438383 | 113 | BLYNK_PRINT.print(ip[3]); BLYNK_PRINT.print('.'); \ |
vshymanskyy | 0:58b20b438383 | 114 | BLYNK_PRINT.print(ip[2]); BLYNK_PRINT.print('.'); \ |
vshymanskyy | 0:58b20b438383 | 115 | BLYNK_PRINT.print(ip[1]); BLYNK_PRINT.print('.'); \ |
vshymanskyy | 0:58b20b438383 | 116 | BLYNK_PRINT.println(ip[0]); } |
vshymanskyy | 0:58b20b438383 | 117 | |
vshymanskyy | 0:58b20b438383 | 118 | static |
vshymanskyy | 0:58b20b438383 | 119 | void BLYNK_LOG_TIME() { |
vshymanskyy | 0:58b20b438383 | 120 | BLYNK_PRINT.print('['); |
vshymanskyy | 0:58b20b438383 | 121 | BLYNK_PRINT.print(millis()); |
vshymanskyy | 0:58b20b438383 | 122 | BLYNK_PRINT.print(BLYNK_F("] ")); |
vshymanskyy | 0:58b20b438383 | 123 | } |
vshymanskyy | 0:58b20b438383 | 124 | |
vshymanskyy | 0:58b20b438383 | 125 | #ifdef BLYNK_DEBUG |
vshymanskyy | 0:58b20b438383 | 126 | #include <ctype.h> |
vshymanskyy | 0:58b20b438383 | 127 | #define BLYNK_DBG_BREAK() { for(;;); } |
vshymanskyy | 0:58b20b438383 | 128 | #define BLYNK_ASSERT(expr) { if(!(expr)) { BLYNK_LOG2(BLYNK_F("Assertion failed: "), BLYNK_F(#expr)); BLYNK_DBG_BREAK() } } |
vshymanskyy | 0:58b20b438383 | 129 | |
vshymanskyy | 0:58b20b438383 | 130 | static |
vshymanskyy | 0:58b20b438383 | 131 | void BLYNK_DBG_DUMP(const char* msg, const void* addr, size_t len) { |
vshymanskyy | 0:58b20b438383 | 132 | if (len) { |
vshymanskyy | 0:58b20b438383 | 133 | BLYNK_LOG_TIME(); |
vshymanskyy | 0:58b20b438383 | 134 | BLYNK_PRINT.print(msg); |
vshymanskyy | 0:58b20b438383 | 135 | int l2 = len; |
vshymanskyy | 0:58b20b438383 | 136 | const uint8_t* octets = (const uint8_t*)addr; |
vshymanskyy | 0:58b20b438383 | 137 | bool prev_print = true; |
vshymanskyy | 0:58b20b438383 | 138 | while (l2--) { |
vshymanskyy | 0:58b20b438383 | 139 | const uint8_t c = *octets++ & 0xFF; |
vshymanskyy | 0:58b20b438383 | 140 | if (isprint(c)) { |
vshymanskyy | 0:58b20b438383 | 141 | if (!prev_print) { BLYNK_PRINT.print(']'); } |
vshymanskyy | 0:58b20b438383 | 142 | BLYNK_PRINT.print((char)c); |
vshymanskyy | 0:58b20b438383 | 143 | prev_print = true; |
vshymanskyy | 0:58b20b438383 | 144 | } else { |
vshymanskyy | 0:58b20b438383 | 145 | BLYNK_PRINT.print(prev_print?'[':'|'); |
vshymanskyy | 0:58b20b438383 | 146 | if (c < 0x10) { BLYNK_PRINT.print('0'); } |
vshymanskyy | 0:58b20b438383 | 147 | BLYNK_PRINT.print(c, HEX); |
vshymanskyy | 0:58b20b438383 | 148 | prev_print = false; |
vshymanskyy | 0:58b20b438383 | 149 | } |
vshymanskyy | 0:58b20b438383 | 150 | } |
Volodymyr Shymanskyy |
3:31e4b850b126 | 151 | if (!prev_print) |
Volodymyr Shymanskyy |
3:31e4b850b126 | 152 | BLYNK_PRINT.print(']'); |
Volodymyr Shymanskyy |
3:31e4b850b126 | 153 | BLYNK_PRINT.println(); |
vshymanskyy | 0:58b20b438383 | 154 | } |
vshymanskyy | 0:58b20b438383 | 155 | } |
vshymanskyy | 0:58b20b438383 | 156 | #endif |
vshymanskyy | 0:58b20b438383 | 157 | |
vshymanskyy | 0:58b20b438383 | 158 | #if !defined(ARDUINO_ARCH_ARC32) |
vshymanskyy | 0:58b20b438383 | 159 | #include <stdio.h> |
vshymanskyy | 0:58b20b438383 | 160 | #include <stdarg.h> |
vshymanskyy | 0:58b20b438383 | 161 | |
Volodymyr Shymanskyy |
7:8879692d4e6c | 162 | BLYNK_UNUSED |
vshymanskyy | 0:58b20b438383 | 163 | void blynk_dbg_print(const char* BLYNK_PROGMEM fmt, ...) |
vshymanskyy | 0:58b20b438383 | 164 | { |
vshymanskyy | 0:58b20b438383 | 165 | va_list ap; |
vshymanskyy | 0:58b20b438383 | 166 | va_start(ap, fmt); |
vshymanskyy | 0:58b20b438383 | 167 | char buff[128]; |
vshymanskyy | 0:58b20b438383 | 168 | BLYNK_PRINT.print('['); |
vshymanskyy | 0:58b20b438383 | 169 | BLYNK_PRINT.print(millis()); |
Volodymyr Shymanskyy |
7:8879692d4e6c | 170 | BLYNK_PRINT.print(BLYNK_F("] ")); |
vshymanskyy | 0:58b20b438383 | 171 | #if defined(__AVR__) |
vshymanskyy | 0:58b20b438383 | 172 | vsnprintf_P(buff, sizeof(buff), fmt, ap); |
vshymanskyy | 0:58b20b438383 | 173 | #else |
vshymanskyy | 0:58b20b438383 | 174 | vsnprintf(buff, sizeof(buff), fmt, ap); |
vshymanskyy | 0:58b20b438383 | 175 | #endif |
vshymanskyy | 0:58b20b438383 | 176 | BLYNK_PRINT.println(buff); |
vshymanskyy | 0:58b20b438383 | 177 | va_end(ap); |
vshymanskyy | 0:58b20b438383 | 178 | } |
vshymanskyy | 0:58b20b438383 | 179 | #endif // ARDUINO_ARCH_ARC32 |
Volodymyr Shymanskyy |
2:c5b857d4f9f6 | 180 | |
vshymanskyy | 6:b942afadf9be | 181 | #elif defined(MBED_LIBRARY_VERSION) |
vshymanskyy | 6:b942afadf9be | 182 | |
vshymanskyy | 6:b942afadf9be | 183 | //TODO |
vshymanskyy | 6:b942afadf9be | 184 | |
vshymanskyy | 4:fa1450a7dd08 | 185 | #elif defined(LINUX) |
vshymanskyy | 0:58b20b438383 | 186 | |
vshymanskyy | 0:58b20b438383 | 187 | #include <assert.h> |
vshymanskyy | 0:58b20b438383 | 188 | #include <stdio.h> |
vshymanskyy | 0:58b20b438383 | 189 | #include <string.h> |
vshymanskyy | 0:58b20b438383 | 190 | #include <errno.h> |
vshymanskyy | 0:58b20b438383 | 191 | #include <signal.h> |
vshymanskyy | 0:58b20b438383 | 192 | |
vshymanskyy | 0:58b20b438383 | 193 | #include <iostream> |
vshymanskyy | 0:58b20b438383 | 194 | using namespace std; |
vshymanskyy | 0:58b20b438383 | 195 | #define BLYNK_LOG(msg, ...) { fprintf(BLYNK_PRINT, "[%ld] " msg "\n", millis(), ##__VA_ARGS__); } |
vshymanskyy | 0:58b20b438383 | 196 | #define BLYNK_LOG1(p1) { BLYNK_LOG_TIME(); cout << p1 << endl; } |
vshymanskyy | 0:58b20b438383 | 197 | #define BLYNK_LOG2(p1,p2) { BLYNK_LOG_TIME(); cout << p1 << p2 << endl; } |
vshymanskyy | 0:58b20b438383 | 198 | #define BLYNK_LOG3(p1,p2,p3) { BLYNK_LOG_TIME(); cout << p1 << p2 << p3 << endl; } |
vshymanskyy | 0:58b20b438383 | 199 | #define BLYNK_LOG4(p1,p2,p3,p4) { BLYNK_LOG_TIME(); cout << p1 << p2 << p3 << p4 << endl; } |
vshymanskyy | 0:58b20b438383 | 200 | #define BLYNK_LOG6(p1,p2,p3,p4,p5,p6) { BLYNK_LOG_TIME(); cout << p1 << p2 << p3 << p4 << p5 << p6 << endl; } |
vshymanskyy | 0:58b20b438383 | 201 | |
vshymanskyy | 0:58b20b438383 | 202 | #define BLYNK_LOG_TIME() cout << '[' << millis() << "] "; |
vshymanskyy | 0:58b20b438383 | 203 | |
vshymanskyy | 0:58b20b438383 | 204 | #ifdef BLYNK_DEBUG |
vshymanskyy | 0:58b20b438383 | 205 | #define BLYNK_DBG_BREAK() raise(SIGTRAP); |
vshymanskyy | 0:58b20b438383 | 206 | #define BLYNK_ASSERT(expr) assert(expr) |
vshymanskyy | 0:58b20b438383 | 207 | |
vshymanskyy | 0:58b20b438383 | 208 | static |
vshymanskyy | 0:58b20b438383 | 209 | void BLYNK_DBG_DUMP(const char* msg, const void* addr, size_t len) { |
vshymanskyy | 0:58b20b438383 | 210 | BLYNK_LOG_TIME(); |
vshymanskyy | 0:58b20b438383 | 211 | fprintf(BLYNK_PRINT, msg); |
vshymanskyy | 0:58b20b438383 | 212 | int l2 = len; |
vshymanskyy | 0:58b20b438383 | 213 | const uint8_t* octets = (const uint8_t*)addr; |
vshymanskyy | 0:58b20b438383 | 214 | bool prev_print = true; |
vshymanskyy | 0:58b20b438383 | 215 | while (l2--) { |
vshymanskyy | 0:58b20b438383 | 216 | const uint8_t c = *octets++ & 0xFF; |
vshymanskyy | 0:58b20b438383 | 217 | if (c > 31) { |
vshymanskyy | 0:58b20b438383 | 218 | if (!prev_print) { fputc(']', BLYNK_PRINT); } |
vshymanskyy | 0:58b20b438383 | 219 | fputc((char)c, BLYNK_PRINT); |
vshymanskyy | 0:58b20b438383 | 220 | prev_print = true; |
vshymanskyy | 0:58b20b438383 | 221 | } else { |
vshymanskyy | 0:58b20b438383 | 222 | fputc(prev_print?'[':'|', BLYNK_PRINT); |
vshymanskyy | 0:58b20b438383 | 223 | fprintf(BLYNK_PRINT, "%02x", c); |
vshymanskyy | 0:58b20b438383 | 224 | prev_print = false; |
vshymanskyy | 0:58b20b438383 | 225 | } |
vshymanskyy | 0:58b20b438383 | 226 | } |
vshymanskyy | 0:58b20b438383 | 227 | fprintf(BLYNK_PRINT, "%s\n", prev_print?"":"]"); |
vshymanskyy | 0:58b20b438383 | 228 | } |
vshymanskyy | 0:58b20b438383 | 229 | #endif |
vshymanskyy | 0:58b20b438383 | 230 | |
vshymanskyy | 0:58b20b438383 | 231 | #else |
vshymanskyy | 0:58b20b438383 | 232 | |
vshymanskyy | 0:58b20b438383 | 233 | #warning Could not detect platform |
vshymanskyy | 0:58b20b438383 | 234 | |
vshymanskyy | 0:58b20b438383 | 235 | #endif |
vshymanskyy | 0:58b20b438383 | 236 | |
vshymanskyy | 0:58b20b438383 | 237 | #endif |
vshymanskyy | 0:58b20b438383 | 238 | |
vshymanskyy | 0:58b20b438383 | 239 | #ifndef BLYNK_LOG |
vshymanskyy | 0:58b20b438383 | 240 | #define BLYNK_LOG(...) |
vshymanskyy | 0:58b20b438383 | 241 | #define BLYNK_LOG1(p1) |
vshymanskyy | 0:58b20b438383 | 242 | #define BLYNK_LOG2(p1,p2) |
vshymanskyy | 0:58b20b438383 | 243 | #define BLYNK_LOG3(p1,p2,p3) |
vshymanskyy | 0:58b20b438383 | 244 | #define BLYNK_LOG4(p1,p2,p3,p4) |
vshymanskyy | 0:58b20b438383 | 245 | #define BLYNK_LOG6(p1,p2,p3,p4,p5,p6) |
vshymanskyy | 0:58b20b438383 | 246 | #define BLYNK_LOG_IP(msg, ip) |
vshymanskyy | 0:58b20b438383 | 247 | #define BLYNK_LOG_IP_REV(msg, ip) |
vshymanskyy | 0:58b20b438383 | 248 | #endif |
vshymanskyy | 0:58b20b438383 | 249 | |
vshymanskyy | 0:58b20b438383 | 250 | #ifndef BLYNK_DBG_BREAK |
vshymanskyy | 0:58b20b438383 | 251 | #define BLYNK_DBG_BREAK() |
vshymanskyy | 0:58b20b438383 | 252 | #define BLYNK_ASSERT(expr) |
vshymanskyy | 0:58b20b438383 | 253 | #define BLYNK_DBG_DUMP(msg, addr, len) |
vshymanskyy | 0:58b20b438383 | 254 | #endif |
vshymanskyy | 0:58b20b438383 | 255 | |
vshymanskyy | 0:58b20b438383 | 256 | #endif |