diff options
| author | Mike Fiore <mfiore@multitech.com> | 2015-11-18 15:46:37 -0600 |
|---|---|---|
| committer | Mike Fiore <mfiore@multitech.com> | 2015-11-18 15:46:37 -0600 |
| commit | d48510e9c3a57753ff4b33b00e0c61a2b39ff9a1 (patch) | |
| tree | f04f39f7287a6bca826a6c22179b0542cd16f36f /CommandTerminal/CmdMaximumSize.cpp | |
| parent | 94990163d2b694373eb5b2b8ccc4d002aad4ecd9 (diff) | |
| parent | ce5c78c53be8d66da4a2cccdf18b622c0b77e773 (diff) | |
| download | mtdot-box-evb-factory-firmware-d48510e9c3a57753ff4b33b00e0c61a2b39ff9a1.tar.gz mtdot-box-evb-factory-firmware-d48510e9c3a57753ff4b33b00e0c61a2b39ff9a1.tar.bz2 mtdot-box-evb-factory-firmware-d48510e9c3a57753ff4b33b00e0c61a2b39ff9a1.zip | |
Merge branch 'atcommands'
configuration needs to be pulled out of main and implemented as a Mode object
Conflicts:
main.cpp
Diffstat (limited to 'CommandTerminal/CmdMaximumSize.cpp')
| -rw-r--r-- | CommandTerminal/CmdMaximumSize.cpp | 68 |
1 files changed, 68 insertions, 0 deletions
diff --git a/CommandTerminal/CmdMaximumSize.cpp b/CommandTerminal/CmdMaximumSize.cpp new file mode 100644 index 0000000..3679c72 --- /dev/null +++ b/CommandTerminal/CmdMaximumSize.cpp @@ -0,0 +1,68 @@ +#include "CmdMaximumSize.h" + +//SPECIAL NOTE: Maximum size is stored in the LoraConfig WakeDelay field. We decided to use 5 LoRaConfig locations, +// that are not used for the DotBox, for the 5 DotBox settings... +minsize, +maxsize, +minpwr, +maxpwr and +data. +CmdMaximumSize::CmdMaximumSize(mDot* dot, mts::MTSSerial& serial) : + Command(dot, "Maximum Size", "AT+MAXSIZE", "Set the maximum payload size for sweep survey mode"), _serial(serial) +{ + _help = std::string(text()) + ": " + std::string(desc()); + _usage = "(11-242)"; + _queryable = true; +} + +uint32_t CmdMaximumSize::action(std::vector<std::string> args) +{ + if (args.size() == 1) + { + if (_dot->getVerbose()) + _serial.writef("Maximum Size: "); + _serial.writef("%lu\r\n", _dot->getWakeDelay()); + } + else if (args.size() == 2) + { + int32_t code; + uint32_t size = 0; + sscanf(args[1].c_str(), "%lu", &size); + + if ((code = _dot->setWakeDelay(size)) != mDot::MDOT_OK) + { + std::string error = mDot::getReturnCodeString(code) + " - " + _dot->getLastError(); + setErrorMessage(error); + return 1; + } + } + + return 0; +} + +bool CmdMaximumSize::verify(std::vector<std::string> args) +{ + if (args.size() == 1) + return true; + + if (args.size() == 2) + { + uint32_t size = 0; + if (sscanf(args[1].c_str(), "%lu", &size) != 1) { + setErrorMessage("Invalid argument"); + return false; + } + + if (size < 11 || size > 242) + { + setErrorMessage("Invalid maximum payload size, expects (11-242)"); + return false; + } + if (size < _dot->getWakeInterval()) //WakeInterval holds the MinSize setting. + { + setErrorMessage("+MAXSIZE cannot be less than +MINSIZE. Please decrease +MINSIZE first."); + return false; + } + + return true; + } + + setErrorMessage("Invalid arguments"); + return false; +} + |
