MultiTech / Mbed OS MTDOT-BOX-EVB-Factory-Firmware-Custom

Dependencies:   DOGS102 GpsParser ISL29011 MMA845x MPL3115A2 MTS-Serial NCP5623B libmDot-Custom mDot_Channel_Plans

Fork of MTDOT-BOX-EVB-Factory-Firmware by MultiTech

Committer:
jreiss
Date:
Wed Nov 30 01:58:34 2016 +0000
Revision:
12:5b5e076b5f01
Parent:
7:a31236c2e75c
converted to custom channel plan library

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Mike Fiore 1:71125aa00e33 1 /* Copyright (c) <2016> <MultiTech Systems>, MIT License
Mike Fiore 1:71125aa00e33 2 *
Mike Fiore 1:71125aa00e33 3 * Permission is hereby granted, free of charge, to any person obtaining a copy of this software
Mike Fiore 1:71125aa00e33 4 * and associated documentation files (the "Software"), to deal in the Software without restriction,
Mike Fiore 1:71125aa00e33 5 * including without limitation the rights to use, copy, modify, merge, publish, distribute,
Mike Fiore 1:71125aa00e33 6 * sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is
Mike Fiore 1:71125aa00e33 7 * furnished to do so, subject to the following conditions:
Mike Fiore 1:71125aa00e33 8 *
Mike Fiore 1:71125aa00e33 9 * The above copyright notice and this permission notice shall be included in all copies or
Mike Fiore 1:71125aa00e33 10 * substantial portions of the Software.
Mike Fiore 1:71125aa00e33 11 *
Mike Fiore 1:71125aa00e33 12 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING
Mike Fiore 1:71125aa00e33 13 * BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
Mike Fiore 1:71125aa00e33 14 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
Mike Fiore 1:71125aa00e33 15 * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
Mike Fiore 1:71125aa00e33 16 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
Mike Fiore 1:71125aa00e33 17 */
Mike Fiore 1:71125aa00e33 18 #include "CmdTxDataRate.h"
Mike Fiore 7:a31236c2e75c 19 #include "MTSText.h"
Mike Fiore 7:a31236c2e75c 20 #include "MTSLog.h"
Mike Fiore 1:71125aa00e33 21
Mike Fiore 7:a31236c2e75c 22 CmdTxDataRate::CmdTxDataRate(mDot* dot, mts::MTSSerial& serial)
Mike Fiore 7:a31236c2e75c 23 :
Mike Fiore 7:a31236c2e75c 24 Command(dot, "Tx Data Rate", "AT+TXDR", "Set the Tx data rate for all channels"),
Mike Fiore 7:a31236c2e75c 25 _serial(serial)
Mike Fiore 1:71125aa00e33 26 {
Mike Fiore 1:71125aa00e33 27 _help = std::string(text()) + ": " + std::string(desc());
Mike Fiore 1:71125aa00e33 28 _queryable = true;
Mike Fiore 1:71125aa00e33 29 }
Mike Fiore 1:71125aa00e33 30
Mike Fiore 7:a31236c2e75c 31 uint32_t CmdTxDataRate::action(std::vector<std::string> args) {
Mike Fiore 1:71125aa00e33 32 if (args.size() == 1)
Mike Fiore 7:a31236c2e75c 33 {
Mike Fiore 1:71125aa00e33 34 if (_dot->getVerbose())
Mike Fiore 1:71125aa00e33 35 _serial.writef("Tx Data Rate: ");
Mike Fiore 1:71125aa00e33 36
Mike Fiore 7:a31236c2e75c 37 _serial.writef("DR%d - %s\r\n", _dot->getTxDataRate(), _dot->getDateRateDetails(_dot->getTxDataRate()).c_str());
Mike Fiore 7:a31236c2e75c 38 } else if (args.size() == 2) {
Mike Fiore 7:a31236c2e75c 39 std::string dr = mts::Text::toUpper(args[1]);
Mike Fiore 1:71125aa00e33 40 int32_t code;
Mike Fiore 7:a31236c2e75c 41 int datarate = -1;
Mike Fiore 1:71125aa00e33 42 uint8_t i;
Mike Fiore 1:71125aa00e33 43
Mike Fiore 7:a31236c2e75c 44 int res = sscanf(dr.c_str(), "%d", &datarate);
Mike Fiore 7:a31236c2e75c 45
Mike Fiore 7:a31236c2e75c 46 if (res == 0) {
Mike Fiore 7:a31236c2e75c 47 for (i = 0; i < 24; i++) {
Mike Fiore 7:a31236c2e75c 48 if (mDot::DataRateStr(i).find(dr) != std::string::npos) {
Mike Fiore 7:a31236c2e75c 49 datarate = i;
Mike Fiore 7:a31236c2e75c 50 break;
Mike Fiore 7:a31236c2e75c 51 }
Mike Fiore 7:a31236c2e75c 52 }
Mike Fiore 1:71125aa00e33 53 }
Mike Fiore 1:71125aa00e33 54
Mike Fiore 7:a31236c2e75c 55 if ((code = _dot->setTxDataRate(datarate)) != mDot::MDOT_OK) {
Mike Fiore 7:a31236c2e75c 56 setErrorMessage(_dot->getLastError());
Mike Fiore 1:71125aa00e33 57 return 1;
Mike Fiore 1:71125aa00e33 58 }
Mike Fiore 1:71125aa00e33 59 }
Mike Fiore 1:71125aa00e33 60
Mike Fiore 1:71125aa00e33 61 return 0;
Mike Fiore 1:71125aa00e33 62 }
Mike Fiore 1:71125aa00e33 63
Mike Fiore 7:a31236c2e75c 64 bool CmdTxDataRate::verify(std::vector<std::string> args) {
Mike Fiore 1:71125aa00e33 65 if (args.size() == 1)
Mike Fiore 1:71125aa00e33 66 return true;
Mike Fiore 1:71125aa00e33 67
Mike Fiore 7:a31236c2e75c 68 if (args.size() == 2) {
Mike Fiore 7:a31236c2e75c 69 std::string dr = mts::Text::toUpper(args[1]);
Mike Fiore 7:a31236c2e75c 70
Mike Fiore 1:71125aa00e33 71 uint8_t i;
Mike Fiore 1:71125aa00e33 72 int datarate = -1;
Mike Fiore 7:a31236c2e75c 73
Mike Fiore 7:a31236c2e75c 74 int res = sscanf(dr.c_str(), "%d", &datarate);
Mike Fiore 7:a31236c2e75c 75
Mike Fiore 7:a31236c2e75c 76 if (res == 0) {
Mike Fiore 7:a31236c2e75c 77 for (i = 0; i < 24; i++) {
Mike Fiore 7:a31236c2e75c 78
Mike Fiore 7:a31236c2e75c 79 if (mDot::DataRateStr(i).find(dr) != std::string::npos) {
Mike Fiore 7:a31236c2e75c 80 uint8_t _dr = i;
Mike Fiore 7:a31236c2e75c 81 datarate = _dr;
Mike Fiore 7:a31236c2e75c 82 break;
Mike Fiore 7:a31236c2e75c 83 }
Mike Fiore 7:a31236c2e75c 84 }
Mike Fiore 1:71125aa00e33 85 }
Mike Fiore 1:71125aa00e33 86
Mike Fiore 1:71125aa00e33 87 return true;
Mike Fiore 1:71125aa00e33 88 }
Mike Fiore 1:71125aa00e33 89
Mike Fiore 1:71125aa00e33 90 setErrorMessage("Invalid arguments");
Mike Fiore 1:71125aa00e33 91 return false;
Mike Fiore 1:71125aa00e33 92 }