From d021b844de073446c3e78cba541379732021807a Mon Sep 17 00:00:00 2001 From: Fanda Vacek Date: Fri, 15 Nov 2024 21:05:20 +0100 Subject: [PATCH 1/3] Change FrameWriter::addFrame() to move its argument. This can prevent copy frame data since c++23 --- .../include/shv/chainpack/rpcdriver.h | 2 +- .../include/shv/chainpack/rpcmessage.h | 1 + .../include/shv/chainpack/socketrpcdriver.h | 2 +- libshvchainpack/src/rpcdriver.cpp | 10 ++++++---- libshvchainpack/src/rpcmessage.cpp | 10 ++++++++-- libshvchainpack/src/socketrpcdriver.cpp | 8 +++++--- .../include/shv/iotqt/rpc/serialportsocket.h | 3 ++- libshviotqt/include/shv/iotqt/rpc/socket.h | 10 ++++++---- .../include/shv/iotqt/rpc/socketrpcconnection.h | 2 +- libshviotqt/src/rpc/serialportsocket.cpp | 4 ++-- libshviotqt/src/rpc/socket.cpp | 17 ++++++++++++++--- libshviotqt/src/rpc/socketrpcconnection.cpp | 4 ++-- libshviotqt/tests/test_frame_reader.cpp | 4 ++-- 13 files changed, 51 insertions(+), 26 deletions(-) diff --git a/libshvchainpack/include/shv/chainpack/rpcdriver.h b/libshvchainpack/include/shv/chainpack/rpcdriver.h index 960fc8148..4b9817b8f 100644 --- a/libshvchainpack/include/shv/chainpack/rpcdriver.h +++ b/libshvchainpack/include/shv/chainpack/rpcdriver.h @@ -26,7 +26,7 @@ class SHVCHAINPACK_DECL_EXPORT RpcDriver protected: virtual bool isOpen() = 0; - virtual void writeFrameData(const std::string &frame_data) = 0; + virtual void writeFrame(RpcFrame &&frame) = 0; void processRpcFrame(RpcFrame &&frame); virtual void onRpcFrameReceived(RpcFrame &&frame); diff --git a/libshvchainpack/include/shv/chainpack/rpcmessage.h b/libshvchainpack/include/shv/chainpack/rpcmessage.h index 2937df771..79b8bc0bb 100644 --- a/libshvchainpack/include/shv/chainpack/rpcmessage.h +++ b/libshvchainpack/include/shv/chainpack/rpcmessage.h @@ -26,6 +26,7 @@ struct SHVCHAINPACK_DECL_EXPORT RpcFrame RpcFrame(Rpc::ProtocolType protocol, RpcValue::MetaData &&meta, std::string &&data) : protocol(protocol), meta(std::move(meta)), data(std::move(data)) {} bool isValid() const { return !meta.isEmpty() && !data.empty(); } RpcMessage toRpcMessage(std::string *errmsg = nullptr) const; + std::string toFrameHead() const; std::string toFrameData() const; static RpcFrame fromFrameData(const std::string &frame_data); }; diff --git a/libshvchainpack/include/shv/chainpack/socketrpcdriver.h b/libshvchainpack/include/shv/chainpack/socketrpcdriver.h index e77f1cdfa..48aaa2abd 100644 --- a/libshvchainpack/include/shv/chainpack/socketrpcdriver.h +++ b/libshvchainpack/include/shv/chainpack/socketrpcdriver.h @@ -20,7 +20,7 @@ class SHVCHAINPACK_DECL_EXPORT SocketRpcDriver : public RpcDriver void sendNotify(std::string &&method, const RpcValue &result); protected: bool isOpen() override; - void writeFrameData(const std::string &frame_data) override; + void writeFrame(RpcFrame &&frame) override; virtual void onFrameDataRead(const std::string &frame_data); virtual void idleTaskOnSelectTimeout(); diff --git a/libshvchainpack/src/rpcdriver.cpp b/libshvchainpack/src/rpcdriver.cpp index bee3d2211..d0c122e3e 100644 --- a/libshvchainpack/src/rpcdriver.cpp +++ b/libshvchainpack/src/rpcdriver.cpp @@ -46,11 +46,13 @@ void RpcDriver::sendRpcFrame(RpcFrame &&frame) if (!errmsg.empty()) { throw std::runtime_error("Cannot convert RPC frame to message: " + errmsg); } - frame = msg.toRpcFrame(m_clientProtocolType); + auto frame2 = msg.toRpcFrame(m_clientProtocolType); + writeFrame(std::move(frame2)); + } + else { + //logRpcData().nospace() << "FRAME DATA WRITE " << frame_data.size() << " bytes of data:\n" << shv::chainpack::utils::hexDump(frame_data); + writeFrame(std::move(frame)); } - auto frame_data = frame.toFrameData(); - //logRpcData().nospace() << "FRAME DATA WRITE " << frame_data.size() << " bytes of data:\n" << shv::chainpack::utils::hexDump(frame_data); - writeFrameData(frame_data); } catch (const std::exception &e) { nError() << "ERROR send frame:" << e.what(); diff --git a/libshvchainpack/src/rpcmessage.cpp b/libshvchainpack/src/rpcmessage.cpp index ffa2d88fd..27e44354b 100644 --- a/libshvchainpack/src/rpcmessage.cpp +++ b/libshvchainpack/src/rpcmessage.cpp @@ -96,7 +96,7 @@ RpcMessage RpcFrame::toRpcMessage(std::string *errmsg) const return {}; } -std::string RpcFrame::toFrameData() const +std::string RpcFrame::toFrameHead() const { switch (protocol) { case Rpc::ProtocolType::ChainPack: { @@ -118,7 +118,6 @@ std::string RpcFrame::toFrameData() const } auto ret = out.str(); ret = static_cast(protocol) + ret; - ret += data; return ret; } default: { @@ -127,6 +126,13 @@ std::string RpcFrame::toFrameData() const } } +std::string RpcFrame::toFrameData() const +{ + auto ret = toFrameHead(); + ret += data; + return ret; +} + RpcFrame RpcFrame::fromFrameData(const std::string &frame_data) { std::istringstream in(frame_data); diff --git a/libshvchainpack/src/socketrpcdriver.cpp b/libshvchainpack/src/socketrpcdriver.cpp index 6fec2cd31..a8302a916 100644 --- a/libshvchainpack/src/socketrpcdriver.cpp +++ b/libshvchainpack/src/socketrpcdriver.cpp @@ -56,14 +56,16 @@ void SocketRpcDriver::idleTaskOnSelectTimeout() { } -void SocketRpcDriver::writeFrameData(const std::string &frame_data) +void SocketRpcDriver::writeFrame(RpcFrame &&frame) { if(!isOpen()) { nInfo() << "Write to closed socket"; return; } - if (m_writeBuffer.size() + frame_data.size() < m_maxWriteBufferLength) { - m_writeBuffer += frame_data; + auto frame_head = frame.toFrameHead(); + if (m_writeBuffer.size() + frame_head.size() + frame.data.size() < m_maxWriteBufferLength) { + m_writeBuffer += frame_head; + m_writeBuffer += frame.data; flush(); } } diff --git a/libshviotqt/include/shv/iotqt/rpc/serialportsocket.h b/libshviotqt/include/shv/iotqt/rpc/serialportsocket.h index 332e8977b..4cfaf6e0c 100644 --- a/libshviotqt/include/shv/iotqt/rpc/serialportsocket.h +++ b/libshviotqt/include/shv/iotqt/rpc/serialportsocket.h @@ -43,8 +43,9 @@ class SHVIOTQT_DECL_EXPORT SerialFrameWriter : public FrameWriter SerialFrameWriter(CrcCheck crc); ~SerialFrameWriter() override = default; - void addFrame(const std::string &frame_data) override; void resetCommunication() override; +protected: + void addFrameData(std::string &&frame_data) override; private: bool m_withCrcCheck = true; }; diff --git a/libshviotqt/include/shv/iotqt/rpc/socket.h b/libshviotqt/include/shv/iotqt/rpc/socket.h index 6c023d530..cb75e4ef7 100644 --- a/libshviotqt/include/shv/iotqt/rpc/socket.h +++ b/libshviotqt/include/shv/iotqt/rpc/socket.h @@ -45,13 +45,15 @@ class SHVIOTQT_DECL_EXPORT FrameWriter { public: virtual ~FrameWriter() = default; - virtual void addFrame(const std::string &frame_data) = 0; + void addFrame(shv::chainpack::RpcFrame &&frame); virtual void resetCommunication() {} void flushToDevice(QIODevice *device); void clear(); #ifdef WITH_SHV_WEBSOCKETS void flushToWebSocket(QWebSocket *socket); #endif +protected: + virtual void addFrameData(std::string &&frame_data) = 0; protected: QList m_messageDataToWrite; }; @@ -70,8 +72,8 @@ class SHVIOTQT_DECL_EXPORT StreamFrameWriter : public FrameWriter { public: ~StreamFrameWriter() override = default; - - void addFrame(const std::string &frame_data) override; +protected: + void addFrameData(std::string &&frame_data) override; }; /// wrapper class for QTcpSocket and QWebSocket @@ -103,7 +105,7 @@ class SHVIOTQT_DECL_EXPORT Socket : public QObject virtual quint16 peerPort() const = 0; std::vector takeFrames(); - void writeFrameData(const std::string &frame_data); + void writeFrame(chainpack::RpcFrame &&frame); virtual void ignoreSslErrors() = 0; diff --git a/libshviotqt/include/shv/iotqt/rpc/socketrpcconnection.h b/libshviotqt/include/shv/iotqt/rpc/socketrpcconnection.h index 6938d921a..563cf20cb 100644 --- a/libshviotqt/include/shv/iotqt/rpc/socketrpcconnection.h +++ b/libshviotqt/include/shv/iotqt/rpc/socketrpcconnection.h @@ -50,7 +50,7 @@ class SHVIOTQT_DECL_EXPORT SocketRpcConnection : public QObject, public shv::cha protected: // RpcDriver interface bool isOpen() Q_DECL_OVERRIDE; - void writeFrameData(const std::string &frame_data) override; + void writeFrame(shv::chainpack::RpcFrame &&frame) override; Socket* socket(); void onReadyRead(); diff --git a/libshviotqt/src/rpc/serialportsocket.cpp b/libshviotqt/src/rpc/serialportsocket.cpp index 116f24dad..4c02f9e07 100644 --- a/libshviotqt/src/rpc/serialportsocket.cpp +++ b/libshviotqt/src/rpc/serialportsocket.cpp @@ -177,7 +177,7 @@ SerialFrameWriter::SerialFrameWriter(CrcCheck crc) { } -void SerialFrameWriter::addFrame(const std::string &frame_data) +void SerialFrameWriter::addFrameData(string &&frame_data) { QByteArray data_to_write; auto write_escaped = [&data_to_write](uint8_t b) { @@ -213,7 +213,7 @@ void SerialFrameWriter::resetCommunication() QByteArray data_to_write; data_to_write.append(static_cast(00)); - addFrame(data_to_write.toStdString()); + addFrameData(data_to_write.toStdString()); } //====================================================== diff --git a/libshviotqt/src/rpc/socket.cpp b/libshviotqt/src/rpc/socket.cpp index 130ae3802..9d21316f6 100644 --- a/libshviotqt/src/rpc/socket.cpp +++ b/libshviotqt/src/rpc/socket.cpp @@ -24,6 +24,17 @@ namespace shv::iotqt::rpc { //====================================================== // FrameWriter //====================================================== +void FrameWriter::addFrame(chainpack::RpcFrame &&frame) +{ + try { + auto frame_data = frame.toFrameHead(); + frame_data += frame.data; + addFrameData(std::move(frame_data)); + } catch (const std::runtime_error &e) { + shvWarning() << "Error converting frame to data:" << e.what(); + } +} + void FrameWriter::flushToDevice(QIODevice *device) { while (!m_messageDataToWrite.isEmpty()) { @@ -160,7 +171,7 @@ QList StreamFrameReader::addData(std::string_view data) //====================================================== // StreamFrameWriter //====================================================== -void StreamFrameWriter::addFrame(const std::string &frame_data) +void StreamFrameWriter::addFrameData(std::string &&frame_data) { using namespace shv::chainpack; std::ostringstream out; @@ -245,10 +256,10 @@ std::vector Socket::takeFrames() return m_frameReader->takeFrames(); } -void Socket::writeFrameData(const std::string &frame_data) +void Socket::writeFrame(shv::chainpack::RpcFrame &&frame) { Q_ASSERT(m_frameWriter); - m_frameWriter->addFrame(frame_data); + m_frameWriter->addFrame(std::move(frame)); flushWriteBuffer(); } diff --git a/libshviotqt/src/rpc/socketrpcconnection.cpp b/libshviotqt/src/rpc/socketrpcconnection.cpp index a873c03dc..0936468f2 100644 --- a/libshviotqt/src/rpc/socketrpcconnection.cpp +++ b/libshviotqt/src/rpc/socketrpcconnection.cpp @@ -111,9 +111,9 @@ bool SocketRpcConnection::isOpen() return isSocketConnected(); } -void SocketRpcConnection::writeFrameData(const std::string &frame_data) +void SocketRpcConnection::writeFrame(chainpack::RpcFrame &&frame) { - socket()->writeFrameData(frame_data); + socket()->writeFrame(std::move(frame)); } void SocketRpcConnection::sendRpcMessage(const shv::chainpack::RpcMessage &rpc_msg) diff --git a/libshviotqt/tests/test_frame_reader.cpp b/libshviotqt/tests/test_frame_reader.cpp index c098dfe4b..ea4b566fa 100644 --- a/libshviotqt/tests/test_frame_reader.cpp +++ b/libshviotqt/tests/test_frame_reader.cpp @@ -36,7 +36,7 @@ vector msg_to_raw_data(const vector &cpons) auto rv = RpcValue::fromCpon(cpon); auto msg = RpcMessage(rv); StreamFrameWriter wr; - wr.addFrame(msg.toRpcFrame().toFrameData()); + wr.addFrame(msg.toRpcFrame()); QByteArray ba; { QBuffer buffer(&ba); @@ -54,7 +54,7 @@ vector msg_to_raw_data_serial(const vector &cpons, SerialFrameWr auto rv = RpcValue::fromCpon(cpon); auto msg = RpcMessage(rv); SerialFrameWriter wr(crc_check); - wr.addFrame(msg.toRpcFrame().toFrameData()); + wr.addFrame(msg.toRpcFrame()); QByteArray ba; { QBuffer buffer(&ba); From 2aa758a59a6baeb562138624db599792181a033c Mon Sep 17 00:00:00 2001 From: Fanda Vacek Date: Mon, 18 Nov 2024 14:59:40 +0100 Subject: [PATCH 2/3] Rewrite FrameWriter::addFrame() from move to const reference --- libshvchainpack/src/socketrpcdriver.cpp | 11 ++++++++++- .../include/shv/iotqt/rpc/serialportsocket.h | 2 +- libshviotqt/include/shv/iotqt/rpc/socket.h | 9 +++++---- libshviotqt/src/rpc/serialportsocket.cpp | 7 +++++-- libshviotqt/src/rpc/socket.cpp | 14 +++++++------- libshviotqt/src/rpc/socketrpcconnection.cpp | 2 +- 6 files changed, 29 insertions(+), 16 deletions(-) diff --git a/libshvchainpack/src/socketrpcdriver.cpp b/libshvchainpack/src/socketrpcdriver.cpp index a8302a916..d59fc945d 100644 --- a/libshvchainpack/src/socketrpcdriver.cpp +++ b/libshvchainpack/src/socketrpcdriver.cpp @@ -1,6 +1,7 @@ #include #include +#include #include #include @@ -62,8 +63,16 @@ void SocketRpcDriver::writeFrame(RpcFrame &&frame) nInfo() << "Write to closed socket"; return; } + using namespace shv::chainpack; auto frame_head = frame.toFrameHead(); - if (m_writeBuffer.size() + frame_head.size() + frame.data.size() < m_maxWriteBufferLength) { + std::ostringstream out; + { + ChainPackWriter wr(out); + wr.writeUIntData(frame_head.size() + frame.data.size()); + } + auto len_data = out.str(); + if (m_writeBuffer.size() + len_data.size() + frame_head.size() + frame.data.size() < m_maxWriteBufferLength) { + m_writeBuffer += len_data; m_writeBuffer += frame_head; m_writeBuffer += frame.data; flush(); diff --git a/libshviotqt/include/shv/iotqt/rpc/serialportsocket.h b/libshviotqt/include/shv/iotqt/rpc/serialportsocket.h index 4cfaf6e0c..137df5a2d 100644 --- a/libshviotqt/include/shv/iotqt/rpc/serialportsocket.h +++ b/libshviotqt/include/shv/iotqt/rpc/serialportsocket.h @@ -45,7 +45,7 @@ class SHVIOTQT_DECL_EXPORT SerialFrameWriter : public FrameWriter void resetCommunication() override; protected: - void addFrameData(std::string &&frame_data) override; + void addFrameData(const std::string &frame_head, const std::string &frame_data) override; private: bool m_withCrcCheck = true; }; diff --git a/libshviotqt/include/shv/iotqt/rpc/socket.h b/libshviotqt/include/shv/iotqt/rpc/socket.h index cb75e4ef7..03bd054ad 100644 --- a/libshviotqt/include/shv/iotqt/rpc/socket.h +++ b/libshviotqt/include/shv/iotqt/rpc/socket.h @@ -45,7 +45,7 @@ class SHVIOTQT_DECL_EXPORT FrameWriter { public: virtual ~FrameWriter() = default; - void addFrame(shv::chainpack::RpcFrame &&frame); + void addFrame(const shv::chainpack::RpcFrame &frame); virtual void resetCommunication() {} void flushToDevice(QIODevice *device); void clear(); @@ -53,7 +53,7 @@ class SHVIOTQT_DECL_EXPORT FrameWriter void flushToWebSocket(QWebSocket *socket); #endif protected: - virtual void addFrameData(std::string &&frame_data) = 0; + virtual void addFrameData(const std::string &frame_head, const std::string &frame_data) = 0; protected: QList m_messageDataToWrite; }; @@ -72,8 +72,9 @@ class SHVIOTQT_DECL_EXPORT StreamFrameWriter : public FrameWriter { public: ~StreamFrameWriter() override = default; + protected: - void addFrameData(std::string &&frame_data) override; + void addFrameData(const std::string &frame_head, const std::string &frame_data) override; }; /// wrapper class for QTcpSocket and QWebSocket @@ -105,7 +106,7 @@ class SHVIOTQT_DECL_EXPORT Socket : public QObject virtual quint16 peerPort() const = 0; std::vector takeFrames(); - void writeFrame(chainpack::RpcFrame &&frame); + void writeFrame(const chainpack::RpcFrame &frame); virtual void ignoreSslErrors() = 0; diff --git a/libshviotqt/src/rpc/serialportsocket.cpp b/libshviotqt/src/rpc/serialportsocket.cpp index 4c02f9e07..c3cf6adb5 100644 --- a/libshviotqt/src/rpc/serialportsocket.cpp +++ b/libshviotqt/src/rpc/serialportsocket.cpp @@ -177,7 +177,7 @@ SerialFrameWriter::SerialFrameWriter(CrcCheck crc) { } -void SerialFrameWriter::addFrameData(string &&frame_data) +void SerialFrameWriter::addFrameData(const std::string &frame_head, const std::string &frame_data) { QByteArray data_to_write; auto write_escaped = [&data_to_write](uint8_t b) { @@ -190,6 +190,9 @@ void SerialFrameWriter::addFrameData(string &&frame_data) } }; data_to_write += static_cast(STX); + for(uint8_t b : frame_head) { + write_escaped(b); + } for(uint8_t b : frame_data) { write_escaped(b); } @@ -213,7 +216,7 @@ void SerialFrameWriter::resetCommunication() QByteArray data_to_write; data_to_write.append(static_cast(00)); - addFrameData(data_to_write.toStdString()); + addFrameData(data_to_write.toStdString(), {}); } //====================================================== diff --git a/libshviotqt/src/rpc/socket.cpp b/libshviotqt/src/rpc/socket.cpp index 9d21316f6..9b61fbea7 100644 --- a/libshviotqt/src/rpc/socket.cpp +++ b/libshviotqt/src/rpc/socket.cpp @@ -24,12 +24,11 @@ namespace shv::iotqt::rpc { //====================================================== // FrameWriter //====================================================== -void FrameWriter::addFrame(chainpack::RpcFrame &&frame) +void FrameWriter::addFrame(const chainpack::RpcFrame &frame) { try { - auto frame_data = frame.toFrameHead(); - frame_data += frame.data; - addFrameData(std::move(frame_data)); + auto frame_head = frame.toFrameHead(); + addFrameData(frame_head, frame.data); } catch (const std::runtime_error &e) { shvWarning() << "Error converting frame to data:" << e.what(); } @@ -171,7 +170,7 @@ QList StreamFrameReader::addData(std::string_view data) //====================================================== // StreamFrameWriter //====================================================== -void StreamFrameWriter::addFrameData(std::string &&frame_data) +void StreamFrameWriter::addFrameData(const std::string &frame_head, const std::string &frame_data) { using namespace shv::chainpack; std::ostringstream out; @@ -181,6 +180,7 @@ void StreamFrameWriter::addFrameData(std::string &&frame_data) } auto len_data = out.str(); QByteArray data(len_data.data(), len_data.size()); + data.append(frame_head.data(), frame_head.size()); data.append(frame_data.data(), frame_data.size()); m_messageDataToWrite.append(data); } @@ -256,10 +256,10 @@ std::vector Socket::takeFrames() return m_frameReader->takeFrames(); } -void Socket::writeFrame(shv::chainpack::RpcFrame &&frame) +void Socket::writeFrame(const shv::chainpack::RpcFrame &frame) { Q_ASSERT(m_frameWriter); - m_frameWriter->addFrame(std::move(frame)); + m_frameWriter->addFrame(frame); flushWriteBuffer(); } diff --git a/libshviotqt/src/rpc/socketrpcconnection.cpp b/libshviotqt/src/rpc/socketrpcconnection.cpp index 0936468f2..57bf3ec67 100644 --- a/libshviotqt/src/rpc/socketrpcconnection.cpp +++ b/libshviotqt/src/rpc/socketrpcconnection.cpp @@ -113,7 +113,7 @@ bool SocketRpcConnection::isOpen() void SocketRpcConnection::writeFrame(chainpack::RpcFrame &&frame) { - socket()->writeFrame(std::move(frame)); + socket()->writeFrame(frame); } void SocketRpcConnection::sendRpcMessage(const shv::chainpack::RpcMessage &rpc_msg) From 26f42818dccf13b63f23750a22ca0825aa9d4b0f Mon Sep 17 00:00:00 2001 From: Fanda Vacek Date: Mon, 18 Nov 2024 15:11:57 +0100 Subject: [PATCH 3/3] Rewrite RpcDriver::writeFrame() from move to const reference --- libshvchainpack/include/shv/chainpack/rpcdriver.h | 2 +- libshvchainpack/include/shv/chainpack/socketrpcdriver.h | 2 +- libshvchainpack/src/rpcdriver.cpp | 4 ++-- libshvchainpack/src/socketrpcdriver.cpp | 2 +- libshviotqt/include/shv/iotqt/rpc/socketrpcconnection.h | 2 +- libshviotqt/src/rpc/socket.cpp | 2 +- libshviotqt/src/rpc/socketrpcconnection.cpp | 2 +- 7 files changed, 8 insertions(+), 8 deletions(-) diff --git a/libshvchainpack/include/shv/chainpack/rpcdriver.h b/libshvchainpack/include/shv/chainpack/rpcdriver.h index 4b9817b8f..f0323a234 100644 --- a/libshvchainpack/include/shv/chainpack/rpcdriver.h +++ b/libshvchainpack/include/shv/chainpack/rpcdriver.h @@ -26,7 +26,7 @@ class SHVCHAINPACK_DECL_EXPORT RpcDriver protected: virtual bool isOpen() = 0; - virtual void writeFrame(RpcFrame &&frame) = 0; + virtual void writeFrame(const RpcFrame &frame) = 0; void processRpcFrame(RpcFrame &&frame); virtual void onRpcFrameReceived(RpcFrame &&frame); diff --git a/libshvchainpack/include/shv/chainpack/socketrpcdriver.h b/libshvchainpack/include/shv/chainpack/socketrpcdriver.h index 48aaa2abd..2df62c4c2 100644 --- a/libshvchainpack/include/shv/chainpack/socketrpcdriver.h +++ b/libshvchainpack/include/shv/chainpack/socketrpcdriver.h @@ -20,7 +20,7 @@ class SHVCHAINPACK_DECL_EXPORT SocketRpcDriver : public RpcDriver void sendNotify(std::string &&method, const RpcValue &result); protected: bool isOpen() override; - void writeFrame(RpcFrame &&frame) override; + void writeFrame(const RpcFrame &frame) override; virtual void onFrameDataRead(const std::string &frame_data); virtual void idleTaskOnSelectTimeout(); diff --git a/libshvchainpack/src/rpcdriver.cpp b/libshvchainpack/src/rpcdriver.cpp index d0c122e3e..bba535aba 100644 --- a/libshvchainpack/src/rpcdriver.cpp +++ b/libshvchainpack/src/rpcdriver.cpp @@ -47,11 +47,11 @@ void RpcDriver::sendRpcFrame(RpcFrame &&frame) throw std::runtime_error("Cannot convert RPC frame to message: " + errmsg); } auto frame2 = msg.toRpcFrame(m_clientProtocolType); - writeFrame(std::move(frame2)); + writeFrame(frame2); } else { //logRpcData().nospace() << "FRAME DATA WRITE " << frame_data.size() << " bytes of data:\n" << shv::chainpack::utils::hexDump(frame_data); - writeFrame(std::move(frame)); + writeFrame(frame); } } catch (const std::exception &e) { diff --git a/libshvchainpack/src/socketrpcdriver.cpp b/libshvchainpack/src/socketrpcdriver.cpp index d59fc945d..39aacc687 100644 --- a/libshvchainpack/src/socketrpcdriver.cpp +++ b/libshvchainpack/src/socketrpcdriver.cpp @@ -57,7 +57,7 @@ void SocketRpcDriver::idleTaskOnSelectTimeout() { } -void SocketRpcDriver::writeFrame(RpcFrame &&frame) +void SocketRpcDriver::writeFrame(const RpcFrame &frame) { if(!isOpen()) { nInfo() << "Write to closed socket"; diff --git a/libshviotqt/include/shv/iotqt/rpc/socketrpcconnection.h b/libshviotqt/include/shv/iotqt/rpc/socketrpcconnection.h index 563cf20cb..90d47b6cf 100644 --- a/libshviotqt/include/shv/iotqt/rpc/socketrpcconnection.h +++ b/libshviotqt/include/shv/iotqt/rpc/socketrpcconnection.h @@ -50,7 +50,7 @@ class SHVIOTQT_DECL_EXPORT SocketRpcConnection : public QObject, public shv::cha protected: // RpcDriver interface bool isOpen() Q_DECL_OVERRIDE; - void writeFrame(shv::chainpack::RpcFrame &&frame) override; + void writeFrame(const shv::chainpack::RpcFrame &frame) override; Socket* socket(); void onReadyRead(); diff --git a/libshviotqt/src/rpc/socket.cpp b/libshviotqt/src/rpc/socket.cpp index 9b61fbea7..dfea52194 100644 --- a/libshviotqt/src/rpc/socket.cpp +++ b/libshviotqt/src/rpc/socket.cpp @@ -176,7 +176,7 @@ void StreamFrameWriter::addFrameData(const std::string &frame_head, const std::s std::ostringstream out; { ChainPackWriter wr(out); - wr.writeUIntData(frame_data.size()); + wr.writeUIntData(frame_head.size() + frame_data.size()); } auto len_data = out.str(); QByteArray data(len_data.data(), len_data.size()); diff --git a/libshviotqt/src/rpc/socketrpcconnection.cpp b/libshviotqt/src/rpc/socketrpcconnection.cpp index 57bf3ec67..b513342eb 100644 --- a/libshviotqt/src/rpc/socketrpcconnection.cpp +++ b/libshviotqt/src/rpc/socketrpcconnection.cpp @@ -111,7 +111,7 @@ bool SocketRpcConnection::isOpen() return isSocketConnected(); } -void SocketRpcConnection::writeFrame(chainpack::RpcFrame &&frame) +void SocketRpcConnection::writeFrame(const chainpack::RpcFrame &frame) { socket()->writeFrame(frame); }