few changes for RTS/CTS control
Dependencies: MTS-Serial libmDot mbed-rtos mbed
Fork of mDot_AT_firmware by
CommandTerminal/CmdSendStringOnInterval.cpp@1:e52ae6584f1c, 2015-06-25 (annotated)
- Committer:
- Mike Fiore
- Date:
- Thu Jun 25 10:23:41 2015 -0500
- Revision:
- 1:e52ae6584f1c
- Child:
- 2:e5eebd74d36d
update debug, add command source files
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
Mike Fiore |
1:e52ae6584f1c | 1 | #include "CmdSendStringOnInterval.h" |
Mike Fiore |
1:e52ae6584f1c | 2 | #include "CommandTerminal.h" |
Mike Fiore |
1:e52ae6584f1c | 3 | |
Mike Fiore |
1:e52ae6584f1c | 4 | CmdSendStringOnInterval::CmdSendStringOnInterval(mDot* dot, mts::MTSSerial& serial) |
Mike Fiore |
1:e52ae6584f1c | 5 | : |
Mike Fiore |
1:e52ae6584f1c | 6 | Command(dot, "Send Continuous", "AT+SENDI", "Sends supplied packet data on interval between sends, output any recevied packets (escape sequence: +++)"), |
Mike Fiore |
1:e52ae6584f1c | 7 | _serial(serial) { |
Mike Fiore |
1:e52ae6584f1c | 8 | _help = std::string(text()) + ": " + std::string(desc()); |
Mike Fiore |
1:e52ae6584f1c | 9 | _usage = "(100-2147483647) ms,(string:242)"; |
Mike Fiore |
1:e52ae6584f1c | 10 | } |
Mike Fiore |
1:e52ae6584f1c | 11 | |
Mike Fiore |
1:e52ae6584f1c | 12 | uint32_t CmdSendStringOnInterval::action(std::vector<std::string> args) { |
Mike Fiore |
1:e52ae6584f1c | 13 | int32_t code; |
Mike Fiore |
1:e52ae6584f1c | 14 | uint32_t interval; |
Mike Fiore |
1:e52ae6584f1c | 15 | std::vector<uint8_t> data(args[2].begin(), args[2].end()); |
Mike Fiore |
1:e52ae6584f1c | 16 | |
Mike Fiore |
1:e52ae6584f1c | 17 | sscanf(args[1].c_str(), "%lu", &interval); |
Mike Fiore |
1:e52ae6584f1c | 18 | |
Mike Fiore |
1:e52ae6584f1c | 19 | while (true) { |
Mike Fiore |
1:e52ae6584f1c | 20 | if (_dot->getJoinMode() == mDot::AUTO_OTA) { |
Mike Fiore |
1:e52ae6584f1c | 21 | Timer timer; |
Mike Fiore |
1:e52ae6584f1c | 22 | timer.start(); |
Mike Fiore |
1:e52ae6584f1c | 23 | uint32_t backoff = 2000; |
Mike Fiore |
1:e52ae6584f1c | 24 | while (!_dot->getNetworkJoinStatus()) { |
Mike Fiore |
1:e52ae6584f1c | 25 | _serial.writef("Joining network... "); |
Mike Fiore |
1:e52ae6584f1c | 26 | if (_dot->joinNetworkOnce() == mDot::MDOT_OK) { |
Mike Fiore |
1:e52ae6584f1c | 27 | _serial.writef("Network Joined\r\n"); |
Mike Fiore |
1:e52ae6584f1c | 28 | } else { |
Mike Fiore |
1:e52ae6584f1c | 29 | _serial.writef("Join failed\r\n"); |
Mike Fiore |
1:e52ae6584f1c | 30 | } |
Mike Fiore |
1:e52ae6584f1c | 31 | |
Mike Fiore |
1:e52ae6584f1c | 32 | if (CommandTerminal::waitForEscape(backoff)) { |
Mike Fiore |
1:e52ae6584f1c | 33 | return 0; |
Mike Fiore |
1:e52ae6584f1c | 34 | } |
Mike Fiore |
1:e52ae6584f1c | 35 | |
Mike Fiore |
1:e52ae6584f1c | 36 | if (backoff < 60 * 60 * 1000) { |
Mike Fiore |
1:e52ae6584f1c | 37 | backoff *= 2; |
Mike Fiore |
1:e52ae6584f1c | 38 | } |
Mike Fiore |
1:e52ae6584f1c | 39 | } |
Mike Fiore |
1:e52ae6584f1c | 40 | } else if (!_dot->getNetworkJoinStatus()) { |
Mike Fiore |
1:e52ae6584f1c | 41 | setErrorMessage(mDot::getReturnCodeString(mDot::MDOT_NOT_JOINED)); |
Mike Fiore |
1:e52ae6584f1c | 42 | return 1; |
Mike Fiore |
1:e52ae6584f1c | 43 | } |
Mike Fiore |
1:e52ae6584f1c | 44 | |
Mike Fiore |
1:e52ae6584f1c | 45 | if ((code = _dot->send(data, _dot->getTxWait())) != mDot::MDOT_OK) { |
Mike Fiore |
1:e52ae6584f1c | 46 | std::string error = mDot::getReturnCodeString(code); |
Mike Fiore |
1:e52ae6584f1c | 47 | |
Mike Fiore |
1:e52ae6584f1c | 48 | if (code != mDot::MDOT_NOT_JOINED) |
Mike Fiore |
1:e52ae6584f1c | 49 | error += + " - " + _dot->getLastError(); |
Mike Fiore |
1:e52ae6584f1c | 50 | |
Mike Fiore |
1:e52ae6584f1c | 51 | if (code == mDot::MDOT_INVALID_PARAM) { |
Mike Fiore |
1:e52ae6584f1c | 52 | setErrorMessage(error); |
Mike Fiore |
1:e52ae6584f1c | 53 | return 1; |
Mike Fiore |
1:e52ae6584f1c | 54 | } else { |
Mike Fiore |
1:e52ae6584f1c | 55 | _serial.writef("%s\r\n", error.c_str()); |
Mike Fiore |
1:e52ae6584f1c | 56 | } |
Mike Fiore |
1:e52ae6584f1c | 57 | } |
Mike Fiore |
1:e52ae6584f1c | 58 | |
Mike Fiore |
1:e52ae6584f1c | 59 | if (code == mDot::MDOT_OK) { |
Mike Fiore |
1:e52ae6584f1c | 60 | if (CommandTerminal::waitForEscape(3000, _dot, CommandTerminal::WAIT_SEND)) { |
Mike Fiore |
1:e52ae6584f1c | 61 | return 0; |
Mike Fiore |
1:e52ae6584f1c | 62 | } |
Mike Fiore |
1:e52ae6584f1c | 63 | |
Mike Fiore |
1:e52ae6584f1c | 64 | if (_dot->getTxWait() || _dot->getAck() > 0) { |
Mike Fiore |
1:e52ae6584f1c | 65 | std::vector<uint8_t> rx_data; |
Mike Fiore |
1:e52ae6584f1c | 66 | |
Mike Fiore |
1:e52ae6584f1c | 67 | if (_dot->recv(rx_data) == mDot::MDOT_OK) { |
Mike Fiore |
1:e52ae6584f1c | 68 | if (!rx_data.empty()) { |
Mike Fiore |
1:e52ae6584f1c | 69 | if (_dot->getVerbose()) |
Mike Fiore |
1:e52ae6584f1c | 70 | _serial.writef("Packet data:\r\n"); |
Mike Fiore |
1:e52ae6584f1c | 71 | _serial.writef("%s\r\n", CommandTerminal::formatPacketData(rx_data, _dot->getRxOutput()).c_str()); |
Mike Fiore |
1:e52ae6584f1c | 72 | } |
Mike Fiore |
1:e52ae6584f1c | 73 | } |
Mike Fiore |
1:e52ae6584f1c | 74 | } |
Mike Fiore |
1:e52ae6584f1c | 75 | } |
Mike Fiore |
1:e52ae6584f1c | 76 | |
Mike Fiore |
1:e52ae6584f1c | 77 | if (CommandTerminal::waitForEscape(interval)) { |
Mike Fiore |
1:e52ae6584f1c | 78 | return 0; |
Mike Fiore |
1:e52ae6584f1c | 79 | } |
Mike Fiore |
1:e52ae6584f1c | 80 | } |
Mike Fiore |
1:e52ae6584f1c | 81 | |
Mike Fiore |
1:e52ae6584f1c | 82 | return 0; |
Mike Fiore |
1:e52ae6584f1c | 83 | } |
Mike Fiore |
1:e52ae6584f1c | 84 | |
Mike Fiore |
1:e52ae6584f1c | 85 | bool CmdSendStringOnInterval::verify(std::vector<std::string> args) { |
Mike Fiore |
1:e52ae6584f1c | 86 | if (args.size() == 3) { |
Mike Fiore |
1:e52ae6584f1c | 87 | uint32_t interval; |
Mike Fiore |
1:e52ae6584f1c | 88 | if (sscanf(args[1].c_str(), "%lu", &interval) != 1) { |
Mike Fiore |
1:e52ae6584f1c | 89 | setErrorMessage("Invalid argument"); |
Mike Fiore |
1:e52ae6584f1c | 90 | return false; |
Mike Fiore |
1:e52ae6584f1c | 91 | } |
Mike Fiore |
1:e52ae6584f1c | 92 | |
Mike Fiore |
1:e52ae6584f1c | 93 | if (interval < 100 || interval > INT_MAX) { |
Mike Fiore |
1:e52ae6584f1c | 94 | setErrorMessage("Invalid interval, expects (100-2147483647) ms"); |
Mike Fiore |
1:e52ae6584f1c | 95 | return false; |
Mike Fiore |
1:e52ae6584f1c | 96 | } |
Mike Fiore |
1:e52ae6584f1c | 97 | |
Mike Fiore |
1:e52ae6584f1c | 98 | if (args[2].size() > 242) { |
Mike Fiore |
1:e52ae6584f1c | 99 | setErrorMessage("Invalid packet, expects (string:242)"); |
Mike Fiore |
1:e52ae6584f1c | 100 | return false; |
Mike Fiore |
1:e52ae6584f1c | 101 | } |
Mike Fiore |
1:e52ae6584f1c | 102 | |
Mike Fiore |
1:e52ae6584f1c | 103 | return true; |
Mike Fiore |
1:e52ae6584f1c | 104 | } |
Mike Fiore |
1:e52ae6584f1c | 105 | |
Mike Fiore |
1:e52ae6584f1c | 106 | setErrorMessage("Invalid arguments"); |
Mike Fiore |
1:e52ae6584f1c | 107 | return false; |
Mike Fiore |
1:e52ae6584f1c | 108 | } |