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@13:ed6276c0afb7, 2017-04-09 (annotated)
- Committer:
- Volodymyr Shymanskyy
- Date:
- Sun Apr 09 14:50:30 2017 +0300
- Revision:
- 13:ed6276c0afb7
- Parent:
- 9:7369ec77a3ea
- Child:
- 14:76d8fd871a4d
Update version
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 |
Volodymyr Shymanskyy |
9:7369ec77a3ea | 38 | #include <Arduino.h> |
vshymanskyy | 0:58b20b438383 | 39 | #else |
Volodymyr Shymanskyy |
9:7369ec77a3ea | 40 | #include <WProgram.h> |
vshymanskyy | 0:58b20b438383 | 41 | #endif |
vshymanskyy | 0:58b20b438383 | 42 | #endif |
vshymanskyy | 0:58b20b438383 | 43 | |
Volodymyr Shymanskyy |
13:ed6276c0afb7 | 44 | #if defined(LINUX) |
Volodymyr Shymanskyy |
13:ed6276c0afb7 | 45 | #if defined(RASPBERRY) |
Volodymyr Shymanskyy |
13:ed6276c0afb7 | 46 | #include <wiringPi.h> |
Volodymyr Shymanskyy |
13:ed6276c0afb7 | 47 | #else |
Volodymyr Shymanskyy |
13:ed6276c0afb7 | 48 | #define _POSIX_C_SOURCE 200809L |
Volodymyr Shymanskyy |
13:ed6276c0afb7 | 49 | #include <time.h> |
Volodymyr Shymanskyy |
13:ed6276c0afb7 | 50 | #include <unistd.h> |
Volodymyr Shymanskyy |
13:ed6276c0afb7 | 51 | |
Volodymyr Shymanskyy |
13:ed6276c0afb7 | 52 | static inline |
Volodymyr Shymanskyy |
13:ed6276c0afb7 | 53 | void delay(unsigned long ms) |
Volodymyr Shymanskyy |
13:ed6276c0afb7 | 54 | { |
Volodymyr Shymanskyy |
13:ed6276c0afb7 | 55 | usleep(ms * 1000); |
Volodymyr Shymanskyy |
13:ed6276c0afb7 | 56 | } |
Volodymyr Shymanskyy |
13:ed6276c0afb7 | 57 | |
Volodymyr Shymanskyy |
13:ed6276c0afb7 | 58 | static |
Volodymyr Shymanskyy |
13:ed6276c0afb7 | 59 | millis_time_t millis() |
Volodymyr Shymanskyy |
13:ed6276c0afb7 | 60 | { |
Volodymyr Shymanskyy |
13:ed6276c0afb7 | 61 | struct timespec ts; |
Volodymyr Shymanskyy |
13:ed6276c0afb7 | 62 | clock_gettime(CLOCK_MONOTONIC, &ts ); |
Volodymyr Shymanskyy |
13:ed6276c0afb7 | 63 | return ( ts.tv_sec * 1000 + ts.tv_nsec / 1000000L ); |
Volodymyr Shymanskyy |
13:ed6276c0afb7 | 64 | } |
Volodymyr Shymanskyy |
13:ed6276c0afb7 | 65 | #endif |
Volodymyr Shymanskyy |
13:ed6276c0afb7 | 66 | #endif |
Volodymyr Shymanskyy |
13:ed6276c0afb7 | 67 | |
vshymanskyy | 0:58b20b438383 | 68 | #if !defined(ARDUINO) || (ARDUINO < 151) |
vshymanskyy | 0:58b20b438383 | 69 | #define BLYNK_NO_YIELD |
vshymanskyy | 0:58b20b438383 | 70 | #endif |
vshymanskyy | 0:58b20b438383 | 71 | |
Volodymyr Shymanskyy |
9:7369ec77a3ea | 72 | #if !defined(BLYNK_RUN_YIELD) |
Volodymyr Shymanskyy |
9:7369ec77a3ea | 73 | #if defined(BLYNK_NO_YIELD) |
Volodymyr Shymanskyy |
9:7369ec77a3ea | 74 | #define BLYNK_RUN_YIELD() {} |
Volodymyr Shymanskyy |
9:7369ec77a3ea | 75 | #elif defined(SPARK) || defined(PARTICLE) |
Volodymyr Shymanskyy |
9:7369ec77a3ea | 76 | #define BLYNK_RUN_YIELD() { Particle.process(); } |
Volodymyr Shymanskyy |
9:7369ec77a3ea | 77 | #else |
Volodymyr Shymanskyy |
9:7369ec77a3ea | 78 | #define BLYNK_RUN_YIELD() { ::delay(0); } |
Volodymyr Shymanskyy |
9:7369ec77a3ea | 79 | #endif |
Volodymyr Shymanskyy |
9:7369ec77a3ea | 80 | #endif |
vshymanskyy | 0:58b20b438383 | 81 | |
vshymanskyy | 0:58b20b438383 | 82 | #if defined(__AVR__) |
vshymanskyy | 0:58b20b438383 | 83 | #include <avr/pgmspace.h> |
vshymanskyy | 0:58b20b438383 | 84 | #define BLYNK_HAS_PROGMEM |
vshymanskyy | 0:58b20b438383 | 85 | #define BLYNK_PROGMEM PROGMEM |
vshymanskyy | 0:58b20b438383 | 86 | #define BLYNK_F(s) F(s) |
vshymanskyy | 0:58b20b438383 | 87 | #define BLYNK_PSTR(s) PSTR(s) |
vshymanskyy | 0:58b20b438383 | 88 | #else |
vshymanskyy | 0:58b20b438383 | 89 | #define BLYNK_PROGMEM |
vshymanskyy | 0:58b20b438383 | 90 | #define BLYNK_F(s) s |
vshymanskyy | 0:58b20b438383 | 91 | #define BLYNK_PSTR(s) s |
vshymanskyy | 0:58b20b438383 | 92 | #endif |
vshymanskyy | 0:58b20b438383 | 93 | |
Volodymyr Shymanskyy |
9:7369ec77a3ea | 94 | #ifdef ARDUINO_AVR_DIGISPARK |
Volodymyr Shymanskyy |
9:7369ec77a3ea | 95 | typedef fstr_t __FlashStringHelper; |
Volodymyr Shymanskyy |
9:7369ec77a3ea | 96 | #endif |
Volodymyr Shymanskyy |
9:7369ec77a3ea | 97 | |
Volodymyr Shymanskyy |
9:7369ec77a3ea | 98 | #if defined(BLYNK_DEBUG_ALL) && !(__cplusplus >= 201103L || defined(__GXX_EXPERIMENTAL_CXX0X__)) |
Volodymyr Shymanskyy |
9:7369ec77a3ea | 99 | #warning "Compiler features not enabled -> please contact yor board vendor to enable c++0x" |
vshymanskyy | 0:58b20b438383 | 100 | #endif |
vshymanskyy | 0:58b20b438383 | 101 | |
vshymanskyy | 0:58b20b438383 | 102 | // Diagnostic defines |
vshymanskyy | 0:58b20b438383 | 103 | |
vshymanskyy | 0:58b20b438383 | 104 | size_t BlynkFreeRam(); |
vshymanskyy | 0:58b20b438383 | 105 | void BlynkReset() BLYNK_NORETURN; |
vshymanskyy | 0:58b20b438383 | 106 | void BlynkFatal() BLYNK_NORETURN; |
vshymanskyy | 0:58b20b438383 | 107 | |
vshymanskyy | 0:58b20b438383 | 108 | #define BLYNK_FATAL(msg) { BLYNK_LOG1(msg); BlynkFatal(); } |
vshymanskyy | 0:58b20b438383 | 109 | #define BLYNK_LOG_RAM() { BLYNK_LOG2(BLYNK_F("Free RAM: "), BlynkFreeRam()); } |
vshymanskyy | 0:58b20b438383 | 110 | #define BLYNK_LOG_FN() BLYNK_LOG3(BLYNK_F(__FUNCTION__), '@', __LINE__); |
vshymanskyy | 0:58b20b438383 | 111 | #define BLYNK_LOG_TROUBLE(t) BLYNK_LOG2(BLYNK_F("Trouble detected: http://docs.blynk.cc/#troubleshooting-"), t) |
vshymanskyy | 0:58b20b438383 | 112 | |
vshymanskyy | 0:58b20b438383 | 113 | #ifndef BLYNK_PRINT |
vshymanskyy | 0:58b20b438383 | 114 | #undef BLYNK_DEBUG |
vshymanskyy | 0:58b20b438383 | 115 | #endif |
vshymanskyy | 0:58b20b438383 | 116 | |
vshymanskyy | 0:58b20b438383 | 117 | #ifdef BLYNK_PRINT |
vshymanskyy | 0:58b20b438383 | 118 | |
vshymanskyy | 0:58b20b438383 | 119 | #if defined(ARDUINO) || defined(SPARK) || defined(PARTICLE) |
vshymanskyy | 0:58b20b438383 | 120 | |
vshymanskyy | 0:58b20b438383 | 121 | #if defined(ARDUINO_ARCH_ARC32) |
vshymanskyy | 0:58b20b438383 | 122 | // This will cause error - on purpose |
vshymanskyy | 0:58b20b438383 | 123 | #define BLYNK_LOG(msg, ...) BLYNK_LOG_UNAVAILABLE(msg, ##__VA_ARGS__) |
vshymanskyy | 0:58b20b438383 | 124 | #else |
vshymanskyy | 0:58b20b438383 | 125 | #define BLYNK_LOG(msg, ...) blynk_dbg_print(BLYNK_PSTR(msg), ##__VA_ARGS__) |
vshymanskyy | 0:58b20b438383 | 126 | #endif |
vshymanskyy | 0:58b20b438383 | 127 | |
vshymanskyy | 0:58b20b438383 | 128 | #define BLYNK_LOG1(p1) { BLYNK_LOG_TIME(); BLYNK_PRINT.println(p1); } |
vshymanskyy | 0:58b20b438383 | 129 | #define BLYNK_LOG2(p1,p2) { BLYNK_LOG_TIME(); BLYNK_PRINT.print(p1); BLYNK_PRINT.println(p2); } |
vshymanskyy | 0:58b20b438383 | 130 | #define BLYNK_LOG3(p1,p2,p3) { BLYNK_LOG_TIME(); BLYNK_PRINT.print(p1); BLYNK_PRINT.print(p2); BLYNK_PRINT.println(p3); } |
vshymanskyy | 0:58b20b438383 | 131 | #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 | 132 | #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 | 133 | #define BLYNK_LOG_IP(msg, ip) { BLYNK_LOG_TIME(); BLYNK_PRINT.print(BLYNK_F(msg)); \ |
vshymanskyy | 0:58b20b438383 | 134 | BLYNK_PRINT.print(ip[0]); BLYNK_PRINT.print('.'); \ |
vshymanskyy | 0:58b20b438383 | 135 | BLYNK_PRINT.print(ip[1]); BLYNK_PRINT.print('.'); \ |
vshymanskyy | 0:58b20b438383 | 136 | BLYNK_PRINT.print(ip[2]); BLYNK_PRINT.print('.'); \ |
vshymanskyy | 0:58b20b438383 | 137 | BLYNK_PRINT.println(ip[3]); } |
vshymanskyy | 0:58b20b438383 | 138 | #define BLYNK_LOG_IP_REV(msg, ip) { BLYNK_LOG_TIME(); BLYNK_PRINT.print(BLYNK_F(msg)); \ |
vshymanskyy | 0:58b20b438383 | 139 | BLYNK_PRINT.print(ip[3]); BLYNK_PRINT.print('.'); \ |
vshymanskyy | 0:58b20b438383 | 140 | BLYNK_PRINT.print(ip[2]); BLYNK_PRINT.print('.'); \ |
vshymanskyy | 0:58b20b438383 | 141 | BLYNK_PRINT.print(ip[1]); BLYNK_PRINT.print('.'); \ |
vshymanskyy | 0:58b20b438383 | 142 | BLYNK_PRINT.println(ip[0]); } |
vshymanskyy | 0:58b20b438383 | 143 | |
vshymanskyy | 0:58b20b438383 | 144 | static |
vshymanskyy | 0:58b20b438383 | 145 | void BLYNK_LOG_TIME() { |
vshymanskyy | 0:58b20b438383 | 146 | BLYNK_PRINT.print('['); |
vshymanskyy | 0:58b20b438383 | 147 | BLYNK_PRINT.print(millis()); |
vshymanskyy | 0:58b20b438383 | 148 | BLYNK_PRINT.print(BLYNK_F("] ")); |
vshymanskyy | 0:58b20b438383 | 149 | } |
vshymanskyy | 0:58b20b438383 | 150 | |
vshymanskyy | 0:58b20b438383 | 151 | #ifdef BLYNK_DEBUG |
vshymanskyy | 0:58b20b438383 | 152 | #include <ctype.h> |
vshymanskyy | 0:58b20b438383 | 153 | #define BLYNK_DBG_BREAK() { for(;;); } |
vshymanskyy | 0:58b20b438383 | 154 | #define BLYNK_ASSERT(expr) { if(!(expr)) { BLYNK_LOG2(BLYNK_F("Assertion failed: "), BLYNK_F(#expr)); BLYNK_DBG_BREAK() } } |
vshymanskyy | 0:58b20b438383 | 155 | |
vshymanskyy | 0:58b20b438383 | 156 | static |
vshymanskyy | 0:58b20b438383 | 157 | void BLYNK_DBG_DUMP(const char* msg, const void* addr, size_t len) { |
vshymanskyy | 0:58b20b438383 | 158 | if (len) { |
vshymanskyy | 0:58b20b438383 | 159 | BLYNK_LOG_TIME(); |
vshymanskyy | 0:58b20b438383 | 160 | BLYNK_PRINT.print(msg); |
vshymanskyy | 0:58b20b438383 | 161 | int l2 = len; |
vshymanskyy | 0:58b20b438383 | 162 | const uint8_t* octets = (const uint8_t*)addr; |
vshymanskyy | 0:58b20b438383 | 163 | bool prev_print = true; |
vshymanskyy | 0:58b20b438383 | 164 | while (l2--) { |
vshymanskyy | 0:58b20b438383 | 165 | const uint8_t c = *octets++ & 0xFF; |
Volodymyr Shymanskyy |
13:ed6276c0afb7 | 166 | if (c >= 32 && c < 127) { |
vshymanskyy | 0:58b20b438383 | 167 | if (!prev_print) { BLYNK_PRINT.print(']'); } |
vshymanskyy | 0:58b20b438383 | 168 | BLYNK_PRINT.print((char)c); |
vshymanskyy | 0:58b20b438383 | 169 | prev_print = true; |
vshymanskyy | 0:58b20b438383 | 170 | } else { |
vshymanskyy | 0:58b20b438383 | 171 | BLYNK_PRINT.print(prev_print?'[':'|'); |
vshymanskyy | 0:58b20b438383 | 172 | if (c < 0x10) { BLYNK_PRINT.print('0'); } |
vshymanskyy | 0:58b20b438383 | 173 | BLYNK_PRINT.print(c, HEX); |
vshymanskyy | 0:58b20b438383 | 174 | prev_print = false; |
vshymanskyy | 0:58b20b438383 | 175 | } |
vshymanskyy | 0:58b20b438383 | 176 | } |
Volodymyr Shymanskyy |
9:7369ec77a3ea | 177 | if (!prev_print) { |
Volodymyr Shymanskyy |
9:7369ec77a3ea | 178 | BLYNK_PRINT.print(']'); |
Volodymyr Shymanskyy |
9:7369ec77a3ea | 179 | } |
Volodymyr Shymanskyy |
3:31e4b850b126 | 180 | BLYNK_PRINT.println(); |
vshymanskyy | 0:58b20b438383 | 181 | } |
vshymanskyy | 0:58b20b438383 | 182 | } |
vshymanskyy | 0:58b20b438383 | 183 | #endif |
vshymanskyy | 0:58b20b438383 | 184 | |
vshymanskyy | 0:58b20b438383 | 185 | #if !defined(ARDUINO_ARCH_ARC32) |
vshymanskyy | 0:58b20b438383 | 186 | #include <stdio.h> |
vshymanskyy | 0:58b20b438383 | 187 | #include <stdarg.h> |
vshymanskyy | 0:58b20b438383 | 188 | |
Volodymyr Shymanskyy |
7:8879692d4e6c | 189 | BLYNK_UNUSED |
vshymanskyy | 0:58b20b438383 | 190 | void blynk_dbg_print(const char* BLYNK_PROGMEM fmt, ...) |
vshymanskyy | 0:58b20b438383 | 191 | { |
vshymanskyy | 0:58b20b438383 | 192 | va_list ap; |
vshymanskyy | 0:58b20b438383 | 193 | va_start(ap, fmt); |
vshymanskyy | 0:58b20b438383 | 194 | char buff[128]; |
vshymanskyy | 0:58b20b438383 | 195 | BLYNK_PRINT.print('['); |
vshymanskyy | 0:58b20b438383 | 196 | BLYNK_PRINT.print(millis()); |
Volodymyr Shymanskyy |
7:8879692d4e6c | 197 | BLYNK_PRINT.print(BLYNK_F("] ")); |
vshymanskyy | 0:58b20b438383 | 198 | #if defined(__AVR__) |
vshymanskyy | 0:58b20b438383 | 199 | vsnprintf_P(buff, sizeof(buff), fmt, ap); |
vshymanskyy | 0:58b20b438383 | 200 | #else |
vshymanskyy | 0:58b20b438383 | 201 | vsnprintf(buff, sizeof(buff), fmt, ap); |
vshymanskyy | 0:58b20b438383 | 202 | #endif |
vshymanskyy | 0:58b20b438383 | 203 | BLYNK_PRINT.println(buff); |
vshymanskyy | 0:58b20b438383 | 204 | va_end(ap); |
vshymanskyy | 0:58b20b438383 | 205 | } |
vshymanskyy | 0:58b20b438383 | 206 | #endif // ARDUINO_ARCH_ARC32 |
Volodymyr Shymanskyy |
2:c5b857d4f9f6 | 207 | |
Volodymyr Shymanskyy |
9:7369ec77a3ea | 208 | #elif defined(MBED_LIBRARY_VERSION) |
Volodymyr Shymanskyy |
9:7369ec77a3ea | 209 | |
Volodymyr Shymanskyy |
9:7369ec77a3ea | 210 | //TODO |
vshymanskyy | 6:b942afadf9be | 211 | |
vshymanskyy | 4:fa1450a7dd08 | 212 | #elif defined(LINUX) |
vshymanskyy | 0:58b20b438383 | 213 | |
vshymanskyy | 0:58b20b438383 | 214 | #include <assert.h> |
vshymanskyy | 0:58b20b438383 | 215 | #include <stdio.h> |
vshymanskyy | 0:58b20b438383 | 216 | #include <string.h> |
vshymanskyy | 0:58b20b438383 | 217 | #include <errno.h> |
vshymanskyy | 0:58b20b438383 | 218 | #include <signal.h> |
vshymanskyy | 0:58b20b438383 | 219 | |
vshymanskyy | 0:58b20b438383 | 220 | #include <iostream> |
vshymanskyy | 0:58b20b438383 | 221 | using namespace std; |
vshymanskyy | 0:58b20b438383 | 222 | #define BLYNK_LOG(msg, ...) { fprintf(BLYNK_PRINT, "[%ld] " msg "\n", millis(), ##__VA_ARGS__); } |
vshymanskyy | 0:58b20b438383 | 223 | #define BLYNK_LOG1(p1) { BLYNK_LOG_TIME(); cout << p1 << endl; } |
vshymanskyy | 0:58b20b438383 | 224 | #define BLYNK_LOG2(p1,p2) { BLYNK_LOG_TIME(); cout << p1 << p2 << endl; } |
vshymanskyy | 0:58b20b438383 | 225 | #define BLYNK_LOG3(p1,p2,p3) { BLYNK_LOG_TIME(); cout << p1 << p2 << p3 << endl; } |
vshymanskyy | 0:58b20b438383 | 226 | #define BLYNK_LOG4(p1,p2,p3,p4) { BLYNK_LOG_TIME(); cout << p1 << p2 << p3 << p4 << endl; } |
vshymanskyy | 0:58b20b438383 | 227 | #define BLYNK_LOG6(p1,p2,p3,p4,p5,p6) { BLYNK_LOG_TIME(); cout << p1 << p2 << p3 << p4 << p5 << p6 << endl; } |
vshymanskyy | 0:58b20b438383 | 228 | |
vshymanskyy | 0:58b20b438383 | 229 | #define BLYNK_LOG_TIME() cout << '[' << millis() << "] "; |
vshymanskyy | 0:58b20b438383 | 230 | |
vshymanskyy | 0:58b20b438383 | 231 | #ifdef BLYNK_DEBUG |
vshymanskyy | 0:58b20b438383 | 232 | #define BLYNK_DBG_BREAK() raise(SIGTRAP); |
vshymanskyy | 0:58b20b438383 | 233 | #define BLYNK_ASSERT(expr) assert(expr) |
vshymanskyy | 0:58b20b438383 | 234 | |
vshymanskyy | 0:58b20b438383 | 235 | static |
vshymanskyy | 0:58b20b438383 | 236 | void BLYNK_DBG_DUMP(const char* msg, const void* addr, size_t len) { |
vshymanskyy | 0:58b20b438383 | 237 | BLYNK_LOG_TIME(); |
vshymanskyy | 0:58b20b438383 | 238 | fprintf(BLYNK_PRINT, msg); |
vshymanskyy | 0:58b20b438383 | 239 | int l2 = len; |
vshymanskyy | 0:58b20b438383 | 240 | const uint8_t* octets = (const uint8_t*)addr; |
vshymanskyy | 0:58b20b438383 | 241 | bool prev_print = true; |
vshymanskyy | 0:58b20b438383 | 242 | while (l2--) { |
vshymanskyy | 0:58b20b438383 | 243 | const uint8_t c = *octets++ & 0xFF; |
vshymanskyy | 0:58b20b438383 | 244 | if (c > 31) { |
vshymanskyy | 0:58b20b438383 | 245 | if (!prev_print) { fputc(']', BLYNK_PRINT); } |
vshymanskyy | 0:58b20b438383 | 246 | fputc((char)c, BLYNK_PRINT); |
vshymanskyy | 0:58b20b438383 | 247 | prev_print = true; |
vshymanskyy | 0:58b20b438383 | 248 | } else { |
vshymanskyy | 0:58b20b438383 | 249 | fputc(prev_print?'[':'|', BLYNK_PRINT); |
vshymanskyy | 0:58b20b438383 | 250 | fprintf(BLYNK_PRINT, "%02x", c); |
vshymanskyy | 0:58b20b438383 | 251 | prev_print = false; |
vshymanskyy | 0:58b20b438383 | 252 | } |
vshymanskyy | 0:58b20b438383 | 253 | } |
vshymanskyy | 0:58b20b438383 | 254 | fprintf(BLYNK_PRINT, "%s\n", prev_print?"":"]"); |
vshymanskyy | 0:58b20b438383 | 255 | } |
vshymanskyy | 0:58b20b438383 | 256 | #endif |
vshymanskyy | 0:58b20b438383 | 257 | |
vshymanskyy | 0:58b20b438383 | 258 | #else |
vshymanskyy | 0:58b20b438383 | 259 | |
Volodymyr Shymanskyy |
9:7369ec77a3ea | 260 | #warning "Cannot detect platform" |
vshymanskyy | 0:58b20b438383 | 261 | |
vshymanskyy | 0:58b20b438383 | 262 | #endif |
vshymanskyy | 0:58b20b438383 | 263 | |
vshymanskyy | 0:58b20b438383 | 264 | #endif |
vshymanskyy | 0:58b20b438383 | 265 | |
vshymanskyy | 0:58b20b438383 | 266 | #ifndef BLYNK_LOG |
vshymanskyy | 0:58b20b438383 | 267 | #define BLYNK_LOG(...) |
vshymanskyy | 0:58b20b438383 | 268 | #define BLYNK_LOG1(p1) |
vshymanskyy | 0:58b20b438383 | 269 | #define BLYNK_LOG2(p1,p2) |
vshymanskyy | 0:58b20b438383 | 270 | #define BLYNK_LOG3(p1,p2,p3) |
vshymanskyy | 0:58b20b438383 | 271 | #define BLYNK_LOG4(p1,p2,p3,p4) |
vshymanskyy | 0:58b20b438383 | 272 | #define BLYNK_LOG6(p1,p2,p3,p4,p5,p6) |
vshymanskyy | 0:58b20b438383 | 273 | #define BLYNK_LOG_IP(msg, ip) |
vshymanskyy | 0:58b20b438383 | 274 | #define BLYNK_LOG_IP_REV(msg, ip) |
vshymanskyy | 0:58b20b438383 | 275 | #endif |
vshymanskyy | 0:58b20b438383 | 276 | |
vshymanskyy | 0:58b20b438383 | 277 | #ifndef BLYNK_DBG_BREAK |
vshymanskyy | 0:58b20b438383 | 278 | #define BLYNK_DBG_BREAK() |
vshymanskyy | 0:58b20b438383 | 279 | #define BLYNK_ASSERT(expr) |
vshymanskyy | 0:58b20b438383 | 280 | #define BLYNK_DBG_DUMP(msg, addr, len) |
vshymanskyy | 0:58b20b438383 | 281 | #endif |
vshymanskyy | 0:58b20b438383 | 282 | |
vshymanskyy | 0:58b20b438383 | 283 | #endif |