libxdot LESS version

Committer:
icarballeda
Date:
Fri May 03 21:37:43 2019 +0000
Revision:
15:e098cf00f502
Parent:
2:4569491293d7
CO2 is equal to -99 when it fails.; AppEUI, AppKEY & Radio Confs edited to work with Cisco Gateways (Multitech Compatible); Smartium: Added New message, alert string as in CDFS protocol.; Fixed: Accel & ux for errors

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 1 #ifndef MTSLOG_H
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 2 #define MTSLOG_H
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 3
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 4 #include <string>
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 5
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 6 inline const char* className(const std::string& prettyFunction)
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 7 {
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 8 size_t colons = prettyFunction.find_last_of("::");
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 9 if (colons == std::string::npos)
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 10 return "";
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 11 size_t begin = prettyFunction.substr(0,colons).rfind(" ") + 1;
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 12 size_t end = colons - begin;
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 13
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 14 return prettyFunction.substr(begin,end).c_str();
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 15 }
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 16
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 17 #define __CLASSNAME__ className(__PRETTY_FUNCTION__)
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 18
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 19
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 20 #ifdef MTS_DEBUG
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 21 #define logFatal(format, ...) \
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 22 mts::MTSLog::printMessage(mts::MTSLog::FATAL_LEVEL, "%s:%s:%d| [%s] " format "\r\n", __CLASSNAME__, __func__, __LINE__, mts::MTSLog::FATAL_LABEL, ##__VA_ARGS__)
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 23 #define logError(format, ...) \
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 24 mts::MTSLog::printMessage(mts::MTSLog::ERROR_LEVEL, "%s:%s:%d| [%s] " format "\r\n", __CLASSNAME__, __func__, __LINE__, mts::MTSLog::ERROR_LABEL, ##__VA_ARGS__)
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 25 #define logWarning(format, ...) \
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 26 mts::MTSLog::printMessage(mts::MTSLog::WARNING_LEVEL, "%s:%s:%d| [%s] " format "\r\n", __CLASSNAME__, __func__, __LINE__, mts::MTSLog::WARNING_LABEL, ##__VA_ARGS__)
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 27 #define logInfo(format, ...) \
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 28 mts::MTSLog::printMessage(mts::MTSLog::INFO_LEVEL, "%s:%s:%d| [%s] " format "\r\n", __CLASSNAME__, __func__, __LINE__, mts::MTSLog::INFO_LABEL, ##__VA_ARGS__)
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 29 #define logDebug(format, ...) \
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 30 mts::MTSLog::printMessage(mts::MTSLog::DEBUG_LEVEL, "%s:%s:%d| [%s] " format "\r\n", __CLASSNAME__, __func__, __LINE__, mts::MTSLog::DEBUG_LABEL, ##__VA_ARGS__)
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 31 #define logTrace(format, ...) \
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 32 mts::MTSLog::printMessage(mts::MTSLog::TRACE_LEVEL, "%s:%s:%d| [%s] " format "\r\n", __CLASSNAME__, __func__, __LINE__, mts::MTSLog::TRACE_LABEL, ##__VA_ARGS__)
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 33 #else
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 34 #define logFatal(format, ...) \
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 35 mts::MTSLog::printMessage(mts::MTSLog::FATAL_LEVEL, "[%s] " format "\r\n", mts::MTSLog::FATAL_LABEL, ##__VA_ARGS__)
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 36 #define logError(format, ...) \
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 37 mts::MTSLog::printMessage(mts::MTSLog::ERROR_LEVEL, "[%s] " format "\r\n", mts::MTSLog::ERROR_LABEL, ##__VA_ARGS__)
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 38 #define logWarning(format, ...) \
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 39 mts::MTSLog::printMessage(mts::MTSLog::WARNING_LEVEL, "[%s] " format "\r\n", mts::MTSLog::WARNING_LABEL, ##__VA_ARGS__)
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 40 #define logInfo(format, ...) \
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 41 mts::MTSLog::printMessage(mts::MTSLog::INFO_LEVEL, "[%s] " format "\r\n", mts::MTSLog::INFO_LABEL, ##__VA_ARGS__)
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 42 #define logDebug(format, ...) \
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 43 mts::MTSLog::printMessage(mts::MTSLog::DEBUG_LEVEL, "[%s] " format "\r\n", mts::MTSLog::DEBUG_LABEL, ##__VA_ARGS__)
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 44 #define logTrace(format, ...) \
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 45 mts::MTSLog::printMessage(mts::MTSLog::TRACE_LEVEL, "[%s] " format "\r\n", mts::MTSLog::TRACE_LABEL, ##__VA_ARGS__)
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 46 #endif
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 47
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 48 namespace mts {
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 49
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 50 class MTSLog
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 51 {
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 52 public:
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 53
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 54 /** Enum of log levels.
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 55 */
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 56 enum logLevel {
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 57 NONE_LEVEL = 0,
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 58 FATAL_LEVEL = 1,
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 59 ERROR_LEVEL = 2,
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 60 WARNING_LEVEL = 3,
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 61 INFO_LEVEL = 4,
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 62 DEBUG_LEVEL = 5,
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 63 TRACE_LEVEL = 6
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 64 };
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 65
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 66 /** Print log message.
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 67 */
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 68 static void printMessage(int level, const char* format, ...);
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 69
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 70 /** Determine if the given level is currently printable.
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 71 */
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 72 static bool printable(int level);
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 73
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 74 /** Set log level
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 75 * Messages with lower priority than the current level will not be printed.
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 76 * If the level is set to NONE, no messages will print.
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 77 */
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 78 static void setLogLevel(int level);
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 79
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 80 /** Get the current log level.
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 81 */
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 82 static int getLogLevel();
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 83
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 84 /** Get string representation of the current log level.
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 85 */
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 86 static const char* getLogLevelString();
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 87
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 88 static const char* NONE_LABEL;
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 89 static const char* FATAL_LABEL;
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 90 static const char* ERROR_LABEL;
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 91 static const char* WARNING_LABEL;
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 92 static const char* INFO_LABEL;
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 93 static const char* DEBUG_LABEL;
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 94 static const char* TRACE_LABEL;
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 95
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 96 private:
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 97
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 98 /** Constructor
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 99 */
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 100 MTSLog();
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 101
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 102 static int currentLevel;
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 103
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 104 };
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 105
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 106 }
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 107
Jenkins@KEILDM1.dc.multitech.prv 2:4569491293d7 108 #endif