firm newest
Dependencies: MTS-Serial libmDot-dev-mbed5-deprecated
Diff: CommandTerminal/CmdSerialClearOnError.cpp
- Revision:
- 0:3c869a8cb8f8
diff -r 000000000000 -r 3c869a8cb8f8 CommandTerminal/CmdSerialClearOnError.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/CommandTerminal/CmdSerialClearOnError.cpp Thu Oct 18 04:18:48 2018 +0000 @@ -0,0 +1,44 @@ +#include "CmdSerialClearOnError.h" + +CmdSerialClearOnError::CmdSerialClearOnError() : + Command("Clear On Error", "AT+SDCE", "Serial clear on error if enabled data that cannot be sent will be discarded", "(0:off,1:on)") +{ + _queryable = true; +} + +uint32_t CmdSerialClearOnError::action(std::vector<std::string> args) +{ + if (args.size() == 1) + { + CommandTerminal::Serial()->writef("%d\r\n", CommandTerminal::Dot()->getSerialClearOnError()); + } + else if (args.size() == 2) + { + bool enable = (args[1] == "1"); + + if (CommandTerminal::Dot()->setSerialClearOnError(enable) != mDot::MDOT_OK) { + CommandTerminal::setErrorMessage(CommandTerminal::Dot()->getLastError()); + return 1; + } + } + + return 0; +} + +bool CmdSerialClearOnError::verify(std::vector<std::string> args) +{ + if (args.size() == 1) + return true; + + if (args.size() == 2) { + if (args[1] != "1" && args[1] != "0") { + CommandTerminal::setErrorMessage("Invalid parameter, expects (0: off, 1: on)"); + return false; + } + + return true; + } + + CommandTerminal::setErrorMessage("Invalid arguments"); + return false; +}