AT Command Set mDot firmware with updated libmDot, to fix endian problem with joining LoRaWAN network
Dependencies: MTS-Serial libmDot mbed-rtos mbed-src
Fork of mDot_AT_firmware by
CommandTerminal/CmdLogLevel.cpp
- Committer:
- ruairisdad
- Date:
- 2015-08-07
- Revision:
- 3:321cf5e5b89b
- Parent:
- 1:e52ae6584f1c
File content as of revision 3:321cf5e5b89b:
#include "CmdLogLevel.h"
CmdLogLevel::CmdLogLevel(mDot* dot, mts::MTSSerial& serial) :
Command(dot, "Debug Log Level", "AT+LOG", "Enable/disable debug logging. (0: off, 1:Fatal - 6:Trace)"), _serial(serial)
{
_help = std::string(text()) + ": " + std::string(desc());
_usage = "(0-6)";
_queryable = true;
}
uint32_t CmdLogLevel::action(std::vector<std::string> args)
{
if (args.size() == 1)
{
if (_dot->getVerbose())
_serial.writef("Log Level: ");
_serial.writef("%u\r\n", _dot->getLogLevel());
}
else if (args.size() == 2)
{
int32_t code;
int32_t level;
sscanf(args[1].c_str(), "%ld", &level);
if ((code = _dot->setLogLevel(level)) != mDot::MDOT_OK)
{
std::string error = mDot::getReturnCodeString(code) + " - " + _dot->getLastError();
setErrorMessage(error);
return 1;
}
}
return 0;
}
bool CmdLogLevel::verify(std::vector<std::string> args)
{
if (args.size() == 1)
return true;
if (args.size() == 2)
{
int32_t level;
if (sscanf(args[1].c_str(), "%ld", &level) != 1) {
setErrorMessage("Invalid argument");
return false;
}
if (level < 0 || level > 6) {
setErrorMessage("Invalid level, expects (0-6)");
return false;
}
return true;
}
setErrorMessage("Invalid arguments");
return false;
}
