From 998b5b91d87b8e3f26fd6c529bfa99bd1347f6ff Mon Sep 17 00:00:00 2001 From: dragonmux Date: Tue, 31 Oct 2023 07:03:32 +0000 Subject: [PATCH] windows/serialInterface: Implemented serialInterface_t::readPacket() --- src/windows/serialInterface.cxx | 24 +++++++++++++++++++++++- 1 file changed, 23 insertions(+), 1 deletion(-) diff --git a/src/windows/serialInterface.cxx b/src/windows/serialInterface.cxx index c3d9393..3bc36df 100644 --- a/src/windows/serialInterface.cxx +++ b/src/windows/serialInterface.cxx @@ -251,5 +251,27 @@ void serialInterface_t::writePacket(const std::string_view &packet) const std::string serialInterface_t::readPacket() const { - return ""; + std::array packet{}; + DWORD read = 0; + size_t length{0}; + for (; length < packet.size(); length += read) + { + // Due to the protocol's structure, best we can do is reading a single byte at a time. + if (!ReadFile(device, packet.data() + length, 1U, &read, nullptr)) + { + console.error("Read from device failed ("sv, GetLastError(), "), read "sv, length, " bytes"); + throw bmpCommsError_t{}; + } + if (read && packet[length] == '#') + break; + } + + // Adjust the length to remove the beginning '&' (the ending '#' is already taken care of in the read loop) + --length; + // Make a new std::string of an appropriate length + std::string result(length + 1U, '\0'); + // And copy the result string in, returning it + std::memcpy(result.data(), packet.data() + 1U, length); + console.debug("Remote read: "sv, result); + return result; }