Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependencies: MTS-Serial libmDot-mbed5
Fork of Dot-AT-Firmware by
Diff: CommandTerminal/CmdTxDataRate.cpp
- Revision:
- 16:d5cf2af81a6d
- Parent:
- 14:f9a77400b622
--- a/CommandTerminal/CmdTxDataRate.cpp Fri Nov 04 17:04:54 2016 -0500
+++ b/CommandTerminal/CmdTxDataRate.cpp Mon Jun 19 14:33:21 2017 -0500
@@ -4,14 +4,14 @@
CmdTxDataRate::CmdTxDataRate()
-: Command("Tx Data Rate", "AT+TXDR", "Set the Tx data rate for all channels", "US:(7-10|DR0-DR4|DR8-DR13)) EU:(7-12|DR0-DR7))") {
+: Command("Tx Data Rate", "AT+TXDR", "Set the Tx data rate for all channels", "7-10|DR0-DR15, Depends on Channel Plan") {
_queryable = true;
}
uint32_t CmdTxDataRate::action(std::vector<std::string> args) {
if (args.size() == 1)
{
- CommandTerminal::Serial()->writef("DR%d - %s\r\n", CommandTerminal::Dot()->getTxDataRate(), CommandTerminal::Dot()->getDateRateDetails(CommandTerminal::Dot()->getTxDataRate()).c_str());
+ CommandTerminal::Serial()->writef("DR%d - %s\r\n", CommandTerminal::Dot()->getTxDataRate(), CommandTerminal::Dot()->getDataRateDetails(CommandTerminal::Dot()->getTxDataRate()).c_str());
} else if (args.size() == 2) {
std::string dr = mts::Text::toUpper(args[1]);
@@ -27,18 +27,6 @@
break;
}
}
- } else {
- if (datarate > 6) {
- // Convert SF to DR
-
- if (CommandTerminal::Dot()->getFrequencyBand() == mDot::FB_US915) {
- datarate = 10 - datarate;
- } else if (CommandTerminal::Dot()->getFrequencyBand() == mDot::FB_AU915) {
- datarate = 10 - datarate;
- } else {
- datarate = 12 - datarate;
- }
- }
}
if (CommandTerminal::Dot()->setTxDataRate(datarate) != mDot::MDOT_OK) {
@@ -55,78 +43,6 @@
return true;
if (args.size() == 2) {
- std::string dr = mts::Text::toUpper(args[1]);
-
- uint8_t i;
- int datarate = -1;
-
- int res = sscanf(dr.c_str(), "%d", &datarate);
-
- if (res == 0) {
- for (i = 0; i < 24; i++) {
-
- if (mDot::DataRateStr(i).find(dr) != std::string::npos) {
- uint8_t _dr = i;
-
- if (_dr > 15) {
- _dr = 12 + (mDot::SF_12 - _dr);
-
- if (CommandTerminal::Dot()->getFrequencyBand() == mDot::FB_EU868) {
- if (_dr == mDot::SF_7H) {
- _dr = mDot::DR6;
- } else if (_dr == mDot::SF_FSK) {
- _dr = mDot::DR7;
- } else {
- _dr = 12 - _dr;
- }
- } else if (CommandTerminal::Dot()->getFrequencyBand() == mDot::FB_AU915) {
- _dr = 10 - _dr;
- } else {
- _dr = 10 - _dr;
- }
- }
-
- datarate = _dr;
- break;
- }
- }
- } else {
-
- if ((CommandTerminal::Dot()->getFrequencyBand() == mDot::FB_US915) && datarate > 10) {
- datarate = -1;
- } else if (datarate > 12) {
- datarate = -1;
- } else if (datarate > 6) {
- // Convert SF to DR
- if (CommandTerminal::Dot()->getFrequencyBand() == mDot::FB_US915) {
- datarate = 10 - datarate;
- } else if (CommandTerminal::Dot()->getFrequencyBand() == mDot::FB_AU915) {
- datarate = 10 - datarate;
- } else {
- datarate = 12 - datarate;
- }
- }
- }
-
- if (CommandTerminal::Dot()->getFrequencyBand() == mDot::FB_US915) {
- // DR8-13 used for P2P modes
- if (datarate < 0 || datarate > 13 || (datarate >= 5 && datarate <= 7)) {
- CommandTerminal::setErrorMessage("Invalid data rate, expects (7-10|DR0-DR4|DR8-DR13)");
- return false;
- }
- } else if (CommandTerminal::Dot()->getFrequencyBand() == mDot::FB_AU915) {
- // DR8-13 used for P2P modes
- if (datarate < 0 || datarate > 13 || (datarate >= 5 && datarate <= 7)) {
- CommandTerminal::setErrorMessage("Invalid data rate, expects (7-10|DR0-DR4|DR8-DR13)");
- return false;
- }
- } else {
- if (datarate < 0 || datarate > 7) {
- CommandTerminal::setErrorMessage("Invalid data rate, expects (7-12|DR0-DR7)");
- return false;
- }
- }
-
return true;
}
