firm newest
Dependencies: MTS-Serial libmDot-dev-mbed5-deprecated
Diff: CommandTerminal/CmdSerialBaudRate.cpp
- Revision:
- 0:3c869a8cb8f8
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/CommandTerminal/CmdSerialBaudRate.cpp Thu Oct 18 04:18:48 2018 +0000 @@ -0,0 +1,56 @@ +#include "CmdSerialBaudRate.h" + +CmdSerialBaudRate::CmdSerialBaudRate() : +#if defined(TARGET_MTS_MDOT_F411RE) + Command("Serial Baud Rate", "AT+IPR", "Set serial baud rate, default: 115200 ", "(1200,2400,4800,9600,19200,38400,57600,115200,230400,460800,921600)") +#else + Command("Serial Baud Rate", "AT+IPR", "Set serial baud rate, default: 115200 ", "(1200,2400,4800,9600,19200,38400,57600,115200,230400)") +#endif +{ + _queryable = true; +} + +uint32_t CmdSerialBaudRate::action(std::vector<std::string> args) +{ + if (args.size() == 1) + { + CommandTerminal::Serial()->writef("%lu\r\n", CommandTerminal::Dot()->getBaud()); + } + else if (args.size() == 2) + { + + int baudrate = 0; + + sscanf(args[1].c_str(), "%d", &baudrate); + + if (CommandTerminal::Dot()->setBaud(baudrate) == mDot::MDOT_OK) { + CommandTerminal::Serial()->writef("Set Serial Baud Rate: %lu\r\n", baudrate); + } else { + + CommandTerminal::setErrorMessage(CommandTerminal::Dot()->getLastError());; + return 1; + } + } + + return 0; +} + +bool CmdSerialBaudRate::verify(std::vector<std::string> args) +{ + if (args.size() == 1) + return true; + + if (args.size() == 2) { + int baudrate; + + if (sscanf(args[1].c_str(), "%d", &baudrate) != 1) { + CommandTerminal::setErrorMessage("Invalid argument"); + return false; + } + + return true; + } + + CommandTerminal::setErrorMessage("Invalid arguments"); + return false; +}