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/CmdData.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/CmdData.cpp')
| -rw-r--r-- | CommandTerminal/CmdData.cpp | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/CommandTerminal/CmdData.cpp b/CommandTerminal/CmdData.cpp new file mode 100644 index 0000000..4b31de6 --- /dev/null +++ b/CommandTerminal/CmdData.cpp @@ -0,0 +1,56 @@ +#include "CmdData.h" + +//SPECIAL NOTE: +Data is stored in the LoraConfig StartUpMode 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. +CmdData::CmdData(mDot* dot, mts::MTSSerial& serial) : + Command(dot, "Data", "AT+DATA", "Enable/disable sending survey data results packet to the network server upon each successful survey. (0: off, 1: on)"), _serial(serial) +{ + _help = std::string(text()) + ": " + std::string(desc()); + _usage = "(0,1)"; + _queryable = true; +} + +uint32_t CmdData::action(std::vector<std::string> args) +{ + if (args.size() == 1) + { + if (_dot->getVerbose()) + _serial.writef("%s: ", name()); + _serial.writef("%d\r\n", _dot->getStartUpMode()); + } + else if (args.size() == 2) + { + int32_t code; + bool enable = (args[1] == "1"); + + if ((code = _dot->setStartUpMode(enable)) != mDot::MDOT_OK) { + std::string error = mDot::getReturnCodeString(code) + " - " + _dot->getLastError(); + setErrorMessage(error); + return 1; + } + } + + return 0; + +} + +bool CmdData::verify(std::vector<std::string> args) +{ + if (args.size() == 1) + return true; + + if (args.size() == 2) + { + if (args[1] != "1" && args[1] != "0") { + setErrorMessage("Invalid parameter, expects (0: off, 1: on)"); + return false; + } + + return true; + } + + setErrorMessage("Invalid arguments"); + return false; + +} + |
