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: libmDot-Custom MTS-Serial
Fork of mDot_AT_firmware_CUSTOM by
To change channel plans replace AS923 with AU915, EU868, KR920 or US915 on line 15
#define CHANNEL_PLAN CP_AS923
Diff: CommandTerminal/CmdSendBinary.cpp
- Revision:
- 14:e80ace5a6834
- Parent:
- 9:ff62b20f7000
--- a/CommandTerminal/CmdSendBinary.cpp Mon Aug 29 14:06:16 2016 +0000
+++ b/CommandTerminal/CmdSendBinary.cpp Mon Aug 29 10:05:41 2016 -0500
@@ -1,17 +1,15 @@
#include "CmdSendBinary.h"
#include "CommandTerminal.h"
-CmdSendBinary::CmdSendBinary(mDot* dot, mts::MTSSerial& serial)
+CmdSendBinary::CmdSendBinary()
:
- Command(dot, "Send Binary", "AT+SENDB", "Sends supplied binary (hex) packet data one time and return response"),
- _serial(serial) {
- _help = std::string(text()) + ": " + std::string(desc());
- _usage = "(hex:242)";
+ Command("Send Binary", "AT+SENDB", "Sends supplied binary (hex) packet data one time and return response", "(hex:242)")
+ {
}
uint32_t CmdSendBinary::action(std::vector<std::string> args) {
std::vector<uint8_t> data;
- int32_t code;
+
int temp;
uint32_t length = args[1].size();
@@ -21,23 +19,23 @@
data.push_back(temp);
}
- if ((code = _dot->send(data, _dot->getTxWait())) != mDot::MDOT_OK) {
- std::string error = mDot::getReturnCodeString(code);
-
- if (code != mDot::MDOT_NOT_JOINED)
- error += + " - " + _dot->getLastError();
-
- setErrorMessage(_dot->getLastError());;
+ if (CommandTerminal::Dot()->send(data, CommandTerminal::Dot()->getTxWait()) != mDot::MDOT_OK) {
+ CommandTerminal::setErrorMessage(CommandTerminal::Dot()->getLastError());;
return 1;
}
data.clear();
- if (_dot->getTxWait() && _dot->recv(data) == mDot::MDOT_OK) {
+ if (CommandTerminal::Dot()->getTxWait() && CommandTerminal::Dot()->recv(data) == mDot::MDOT_OK) {
if (!data.empty()) {
- if (_dot->getVerbose())
- _serial.writef("Packet data:\r\n");
- _serial.writef("%s\r\n", CommandTerminal::formatPacketData(data, _dot->getRxOutput()).c_str());
+ if (CommandTerminal::Dot()->getRxOutput() == mDot::HEXADECIMAL) {
+ for (size_t i = 0; i < data.size(); i++) {
+ CommandTerminal::Serial()->writef("%02x", data[i]);
+ }
+ CommandTerminal::Serial()->writef("\r\n");
+ } else {
+ CommandTerminal::Serial()->writef("%s\r\n", CommandTerminal::formatPacketData(data, CommandTerminal::Dot()->getRxOutput()).c_str());
+ }
}
}
@@ -47,14 +45,14 @@
bool CmdSendBinary::verify(std::vector<std::string> args) {
if (args.size() == 2) {
if (args[1].size() > 484 || !isHexString(args[1], args[1].size() / 2)) {
- setErrorMessage("Invalid hex string, (hex:242)");
+ CommandTerminal::setErrorMessage("Invalid hex string, (hex:242)");
return false;
}
return true;
}
- setErrorMessage("Invalid arguments");
+ CommandTerminal::setErrorMessage("Invalid arguments");
return false;
}
