From e4cb33f25012c534f0582d485c4f491f9dd3cd25 Mon Sep 17 00:00:00 2001
From: zhangmeng <775834166@qq.com>
Date: 星期日, 29 一月 2023 09:26:26 +0800
Subject: [PATCH] bug fixed query_proc

---
 src/interface_bus_api.cpp |   19 +++++++++++++------
 1 files changed, 13 insertions(+), 6 deletions(-)

diff --git a/src/interface_bus_api.cpp b/src/interface_bus_api.cpp
index ccb75c8..07f6db9 100644
--- a/src/interface_bus_api.cpp
+++ b/src/interface_bus_api.cpp
@@ -31,6 +31,7 @@
         bus *b = new bus;
         bhome_msg::ProcInfo pi;
         if (pi.ParseFromArray(proc_info, proc_info_len)) get<8>(*b) = pi.proc_id();
+        std::move(pi);
 
         const auto& url_hb = get_url(URLHeartBeat);
         respond_survey(url_hb,string{(char*)proc_info,(size_t)proc_info_len},&get<5>(*b));
@@ -106,8 +107,11 @@
     for(int i = 0; i < mtl.topic_list_size(); i++){
         mtl2.add_topic_list(mtl.topic_list(i));
     }
+    std::move(mtl);
 
     string msg(mtl2.SerializeAsString());
+    std::move(mtl2);
+
     const auto& url = get_url(URLRegTopic);
     if (url.empty()) {
         set_last_error("bus_register_topics url empty");
@@ -135,7 +139,7 @@
         return false;
     }
 
-    auto url(get_url(URLQueryTopic));
+    const auto& url = get_url(URLQueryTopic);
     if (url.empty()) {
         set_last_error("bus_query_topic_address url empty");
         return false;
@@ -168,12 +172,12 @@
         PRNTVITAG("handle is null");
         return false;
     }
-    if (!query || query_len <= 0) {
-        PRNTVITAG("query is null");
-        return false;
-    }
+    // if (!query || query_len <= 0) {
+    //     PRNTVITAG("query is null");
+    //     return false;
+    // }
 
-    auto url(get_url(URLQueryProcs));
+    const auto& url = get_url(URLQueryProcs);
     if (url.empty()) {
         set_last_error("bus_query_procs url empty");
         return false;
@@ -221,6 +225,7 @@
     for(int i = 0; i < mtl.topic_list_size(); i ++){
         subscribe_topic(mtl.topic_list(i), &get<2>(*b));
     }
+    std::move(mtl);
 
 ///////////////////////////////////////////////////
     auto ret = simple_request(url, topics, topics_len, reply, reply_len, timeout_ms);
@@ -283,6 +288,8 @@
     newPub.set_data(string{(const char*)msgpub, (const size_t)msgpub_len});
 
     string msg(newPub.SerializeAsString());
+    std::move(newPub);
+
     auto ret = publish(pub.topic(), msg.data(), msg.size(), &get<1>(*b));
     if (ret > 0) return true;
     return false;

--
Gitblit v1.8.0