few changes for RTS/CTS control

Dependencies:   MTS-Serial libmDot mbed-rtos mbed

Fork of mDot_AT_firmware by MultiTech

Committer:
Mike Fiore
Date:
Mon Apr 04 09:00:31 2016 -0500
Revision:
9:ff62b20f7000
Parent:
1:e52ae6584f1c
update to version 1.0.8 of AT firmware

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Mike Fiore 1:e52ae6584f1c 1 #include "CmdLogLevel.h"
Mike Fiore 1:e52ae6584f1c 2
Mike Fiore 1:e52ae6584f1c 3 CmdLogLevel::CmdLogLevel(mDot* dot, mts::MTSSerial& serial) :
Mike Fiore 1:e52ae6584f1c 4 Command(dot, "Debug Log Level", "AT+LOG", "Enable/disable debug logging. (0: off, 1:Fatal - 6:Trace)"), _serial(serial)
Mike Fiore 1:e52ae6584f1c 5 {
Mike Fiore 1:e52ae6584f1c 6 _help = std::string(text()) + ": " + std::string(desc());
Mike Fiore 1:e52ae6584f1c 7 _usage = "(0-6)";
Mike Fiore 1:e52ae6584f1c 8 _queryable = true;
Mike Fiore 1:e52ae6584f1c 9 }
Mike Fiore 1:e52ae6584f1c 10
Mike Fiore 1:e52ae6584f1c 11 uint32_t CmdLogLevel::action(std::vector<std::string> args)
Mike Fiore 1:e52ae6584f1c 12 {
Mike Fiore 1:e52ae6584f1c 13 if (args.size() == 1)
Mike Fiore 1:e52ae6584f1c 14 {
Mike Fiore 1:e52ae6584f1c 15 if (_dot->getVerbose())
Mike Fiore 1:e52ae6584f1c 16 _serial.writef("Log Level: ");
Mike Fiore 1:e52ae6584f1c 17
Mike Fiore 1:e52ae6584f1c 18 _serial.writef("%u\r\n", _dot->getLogLevel());
Mike Fiore 1:e52ae6584f1c 19 }
Mike Fiore 1:e52ae6584f1c 20 else if (args.size() == 2)
Mike Fiore 1:e52ae6584f1c 21 {
Mike Fiore 1:e52ae6584f1c 22 int32_t code;
Mike Fiore 9:ff62b20f7000 23 int level;
Mike Fiore 9:ff62b20f7000 24 sscanf(args[1].c_str(), "%d", &level);
Mike Fiore 1:e52ae6584f1c 25
Mike Fiore 1:e52ae6584f1c 26 if ((code = _dot->setLogLevel(level)) != mDot::MDOT_OK)
Mike Fiore 1:e52ae6584f1c 27 {
Mike Fiore 9:ff62b20f7000 28
Mike Fiore 9:ff62b20f7000 29 setErrorMessage(_dot->getLastError());;
Mike Fiore 1:e52ae6584f1c 30 return 1;
Mike Fiore 1:e52ae6584f1c 31 }
Mike Fiore 1:e52ae6584f1c 32 }
Mike Fiore 1:e52ae6584f1c 33
Mike Fiore 1:e52ae6584f1c 34 return 0;
Mike Fiore 1:e52ae6584f1c 35 }
Mike Fiore 1:e52ae6584f1c 36
Mike Fiore 1:e52ae6584f1c 37 bool CmdLogLevel::verify(std::vector<std::string> args)
Mike Fiore 1:e52ae6584f1c 38 {
Mike Fiore 1:e52ae6584f1c 39 if (args.size() == 1)
Mike Fiore 1:e52ae6584f1c 40 return true;
Mike Fiore 1:e52ae6584f1c 41
Mike Fiore 1:e52ae6584f1c 42 if (args.size() == 2)
Mike Fiore 1:e52ae6584f1c 43 {
Mike Fiore 9:ff62b20f7000 44 int level;
Mike Fiore 9:ff62b20f7000 45 if (sscanf(args[1].c_str(), "%d", &level) != 1) {
Mike Fiore 1:e52ae6584f1c 46 setErrorMessage("Invalid argument");
Mike Fiore 1:e52ae6584f1c 47 return false;
Mike Fiore 1:e52ae6584f1c 48 }
Mike Fiore 1:e52ae6584f1c 49
Mike Fiore 1:e52ae6584f1c 50 if (level < 0 || level > 6) {
Mike Fiore 1:e52ae6584f1c 51 setErrorMessage("Invalid level, expects (0-6)");
Mike Fiore 1:e52ae6584f1c 52 return false;
Mike Fiore 1:e52ae6584f1c 53 }
Mike Fiore 1:e52ae6584f1c 54
Mike Fiore 1:e52ae6584f1c 55 return true;
Mike Fiore 1:e52ae6584f1c 56 }
Mike Fiore 1:e52ae6584f1c 57
Mike Fiore 1:e52ae6584f1c 58 setErrorMessage("Invalid arguments");
Mike Fiore 1:e52ae6584f1c 59 return false;
Mike Fiore 1:e52ae6584f1c 60 }