few changes for RTS/CTS control

Dependencies:   MTS-Serial libmDot mbed-rtos mbed

Fork of mDot_AT_firmware by MultiTech

Embed: (wiki syntax)

« Back to documentation index

Show/hide line numbers CmdLogLevel.cpp Source File

CmdLogLevel.cpp

00001 #include "CmdLogLevel.h"
00002 
00003 CmdLogLevel::CmdLogLevel(mDot* dot, mts::MTSSerial& serial) :
00004         Command(dot, "Debug Log Level", "AT+LOG", "Enable/disable debug logging. (0: off, 1:Fatal - 6:Trace)"), _serial(serial)
00005 {
00006     _help = std::string(text()) + ": " + std::string(desc());
00007     _usage = "(0-6)";
00008     _queryable = true;
00009 }
00010 
00011 uint32_t CmdLogLevel::action(std::vector<std::string> args)
00012 {
00013     if (args.size() == 1)
00014     {
00015         if (_dot->getVerbose())
00016             _serial.writef("Log Level: ");
00017 
00018         _serial.writef("%u\r\n", _dot->getLogLevel());
00019     }
00020     else if (args.size() == 2)
00021     {
00022         int32_t code;
00023         int level;
00024         sscanf(args[1].c_str(), "%d", &level);
00025 
00026         if ((code = _dot->setLogLevel(level)) != mDot::MDOT_OK)
00027         {
00028             
00029             setErrorMessage(_dot->getLastError());;
00030             return 1;
00031         }
00032     }
00033 
00034     return 0;
00035 }
00036 
00037 bool CmdLogLevel::verify(std::vector<std::string> args)
00038 {
00039     if (args.size() == 1)
00040         return true;
00041 
00042     if (args.size() == 2)
00043     {
00044         int level;
00045         if (sscanf(args[1].c_str(), "%d", &level) != 1) {
00046             setErrorMessage("Invalid argument");
00047             return false;
00048         }
00049 
00050         if (level < 0 || level > 6) {
00051             setErrorMessage("Invalid level, expects (0-6)");
00052             return false;
00053         }
00054 
00055         return true;
00056     }
00057 
00058     setErrorMessage("Invalid arguments");
00059     return false;
00060 }