mDot AT-Firmware for testing
Dependencies: MTS-Serial libmDot-mbed5
Fork of Dot-AT-Firmware by
Diff: CommandTerminal/CmdJoinRx1Offset.cpp
- Revision:
- 14:f9a77400b622
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/CommandTerminal/CmdJoinRx1Offset.cpp Fri Nov 04 14:25:43 2016 -0500 @@ -0,0 +1,57 @@ +#include "CmdJoinRx1Offset.h" +#include "CommandTerminal.h" + +CmdJoinRx1Offset::CmdJoinRx1Offset() +: + Command("Join Rx1 DR Offset", "AT+JRXO", "Join Rx1 datarate offset", "(US:0-3,AU:0-3,EU:0-5)") { + +} + +uint32_t CmdJoinRx1Offset::action(std::vector<std::string> args) { + + if (args.size() == 1) { + CommandTerminal::Serial()->writef("%d\r\n", CommandTerminal::Dot()->getJoinRx1DataRateOffset()); + } + else if (args.size() == 2) { + std::string dr = mts::Text::toUpper(args[1]); + + int offset = 0; + sscanf(dr.c_str(), "%d", &offset); + + if (CommandTerminal::Dot()->setJoinRx1DataRateOffset(offset) != mDot::MDOT_OK) { + CommandTerminal::setErrorMessage(CommandTerminal::Dot()->getLastError());; + return 1; + } + } + + return 0; +} + +bool CmdJoinRx1Offset::verify(std::vector<std::string> args) { + if (args.size() == 1) + return true; + + if (args.size() == 2) { + std::string dr = mts::Text::toUpper(args[1]); + + int offset = -1; + sscanf(dr.c_str(), "%d", &offset); + + if (CommandTerminal::Dot()->getFrequencyBand() == mDot::FB_US915 || CommandTerminal::Dot()->getFrequencyBand() == mDot::FB_AU915) { + if (offset < 0 || offset > 3) { + CommandTerminal::setErrorMessage("Invalid offset, expects (0-3)"); + return false; + } + } else { + if (offset < 0 || offset > 5) { + CommandTerminal::setErrorMessage("Invalid offset, expects (0-5)"); + return false; + } + } + + return true; + } + + CommandTerminal::setErrorMessage("Invalid arguments"); + return false; +}