From dd557b5a21d64cd49b1179ac891ffb2c63dee6d8 Mon Sep 17 00:00:00 2001 From: Leon Lindenfelser Date: Fri, 13 Nov 2015 08:14:28 -0600 Subject: Added CommandTerminal with unneccessary commands removed --- CommandTerminal/CmdTxDataRate.cpp | 89 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 89 insertions(+) create mode 100644 CommandTerminal/CmdTxDataRate.cpp (limited to 'CommandTerminal/CmdTxDataRate.cpp') diff --git a/CommandTerminal/CmdTxDataRate.cpp b/CommandTerminal/CmdTxDataRate.cpp new file mode 100644 index 0000000..2d38f42 --- /dev/null +++ b/CommandTerminal/CmdTxDataRate.cpp @@ -0,0 +1,89 @@ +#include "CmdTxDataRate.h" + +CmdTxDataRate::CmdTxDataRate(mDot* dot, mts::MTSSerial& serial) : + Command(dot, "Tx Data Rate", "AT+TXDR", "Set the Tx data rate for all channels"), _serial(serial) +{ + _help = std::string(text()) + ": " + std::string(desc()); + + if (_dot->getFrequencyBand() == mDot::FB_915) + _usage = "(7-10)"; + else + _usage = "(7-12)"; + _queryable = true; +} + +uint32_t CmdTxDataRate::action(std::vector args) +{ + if (args.size() == 1) + { + if (_dot->getVerbose()) + _serial.writef("Tx Data Rate: "); + + _serial.writef("%s\r\n", mDot::DataRateStr(_dot->getTxDataRate()).c_str()); + } + else if (args.size() == 2) + { + int32_t code; + uint8_t datarate = 0; + uint8_t i; + + for (i = 0; i < 8; i++) + { + if (mDot::DataRateStr(i).find(args[1].c_str()) != std::string::npos) + { + datarate = i; + break; + } + } + + if ((code = _dot->setTxDataRate(datarate)) != mDot::MDOT_OK) + { + std::string error = mDot::getReturnCodeString(code) + " - " + _dot->getLastError(); + setErrorMessage(error); + return 1; + } + } + + return 0; +} + +bool CmdTxDataRate::verify(std::vector args) +{ + if (args.size() == 1) + return true; + + if (args.size() == 2) + { + uint8_t i; + int datarate = -1; + for (i = 0; i < 8; i++) + { + if (mDot::DataRateStr(i).find(args[1].c_str()) != std::string::npos) + { + datarate = i; + break; + } + } + + if (datarate < 0) + { + if (_dot->getFrequencyBand() == mDot::FB_915) + setErrorMessage("Invalid data rate, expects (7-10)"); + else + setErrorMessage("Invalid data rate, expects (7-12)"); + return false; + } + + if (_dot->getFrequencyBand() == mDot::FB_915) { + if (datarate < 2) { + setErrorMessage("Invalid data rate, expects (7-10)"); + return false; + } + } + + return true; + } + + setErrorMessage("Invalid arguments"); + return false; +} -- cgit v1.2.3