From f552a0ea788225d8fe80942d6e8bd6500f788393 Mon Sep 17 00:00:00 2001
From: zhangmeng <775834166@qq.com>
Date: 星期一, 11 四月 2022 09:08:20 +0800
Subject: [PATCH] add log
---
src/nng_wrap.cpp | 4 ++
src/interface_bus_api.cpp | 22 +++++++++--
src/nng_wrap.h | 1
src/bn_api.cpp | 36 ++++++++++++++++-
4 files changed, 56 insertions(+), 7 deletions(-)
diff --git a/src/bn_api.cpp b/src/bn_api.cpp
index 2ea2429..d63e96c 100644
--- a/src/bn_api.cpp
+++ b/src/bn_api.cpp
@@ -97,6 +97,10 @@
if (!topics || topics_len <= 0) return false;
const auto& url = get_url(URLRegTopic);
+ if (url.empty()) {
+ set_last_error("BHRegisterTopics url empty");
+ return false;
+ }
bhome_msg::MsgTopicList mtl;
if (!mtl.ParseFromArray(topics, topics_len)){
@@ -130,7 +134,10 @@
if (!topic || topic_len <= 0) return false;
auto url(get_url(URLQueryTopic));
-
+ if (url.empty()) {
+ set_last_error("BHQueryTopicAddress url empty");
+ return false;
+ }
// if (remote && remote_len > 0){
// BHAddress addr;
// if (addr.ParseFromArray(remote, remote_len)){
@@ -156,6 +163,10 @@
// if (!query || query_len <= 0) return false;
auto url(get_url(URLQueryProcs));
+ if (url.empty()) {
+ set_last_error("BHQueryProcs url empty");
+ return false;
+ }
// if (remote && remote_len > 0){
// BHAddress addr;
@@ -193,6 +204,10 @@
newPub.set_data(string{(const char*)msgpub, (const size_t)msgpub_len});
string msg(newPub.SerializeAsString());
+ if (pub.topic().empty()) {
+ set_last_error("BHPublish topic empty");
+ return false;
+ }
auto ret = publish(pub.topic(), msg.data(), msg.size());
if (ret == 0) return false;
return true;
@@ -226,12 +241,23 @@
// 璁㈤槄
int BHSubscribeTopics(const void *topics, const int topics_len, void **reply, int *reply_len, const int timeout_ms)
{
- return sub(get_url(URLSubLocal), topics, topics_len, reply, reply_len, timeout_ms);
+ const auto& url = get_url(URLSubLocal);
+ if (url.empty()) {
+ set_last_error("BHSubscribeTopics url empty");
+ return false;
+ }
+ return sub(url, topics, topics_len, reply, reply_len, timeout_ms);
}
// 璁㈤槄缃戠粶,涓嶅疄鐜�
int BHSubscribeNetTopics(const void *topics, const int topics_len, void **reply, int *reply_len, const int timeout_ms)
{
- return sub(get_url(URLSubNet), topics, topics_len, reply, reply_len, timeout_ms);
+ const auto& url = get_url(URLSubNet);
+ if (url.empty()) {
+ set_last_error("BHSubscribeNetTopics url empty");
+ return false;
+ }
+
+ return sub(url, topics, topics_len, reply, reply_len, timeout_ms);
}
// 璇诲彇璁㈤槄娑堟伅,proc_id鏆傛椂娌$敤锛岃繑鍥瀎ake msg
@@ -339,6 +365,10 @@
}
}
}
+ if (url.empty()) {
+ set_last_error("BHRequest url empty");
+ return false;
+ }
int rc = request2(url, request, request_len, reply, reply_len, timeout_ms);
if (rc < 0) return false;
diff --git a/src/interface_bus_api.cpp b/src/interface_bus_api.cpp
index 65dd669..638f31a 100644
--- a/src/interface_bus_api.cpp
+++ b/src/interface_bus_api.cpp
@@ -108,8 +108,12 @@
}
string msg(mtl2.SerializeAsString());
-
- return simple_request(get_url(URLRegTopic), msg.data(), msg.size(), reply, reply_len, timeout_ms);
+ const auto& url = get_url(URLRegTopic);
+ if (url.empty()) {
+ set_last_error("bus_register_topics url empty");
+ return false;
+ }
+ return simple_request(url, msg.data(), msg.size(), reply, reply_len, timeout_ms);
}
int bus_query_topic_address(void* handle, const void *remote,
@@ -132,6 +136,10 @@
}
auto url(get_url(URLQueryTopic));
+ if (url.empty()) {
+ set_last_error("bus_query_topic_address url empty");
+ return false;
+ }
// if (remote && remote_len > 0){
// BHAddress addr;
@@ -166,7 +174,10 @@
}
auto url(get_url(URLQueryProcs));
-
+ if (url.empty()) {
+ set_last_error("bus_query_procs url empty");
+ return false;
+ }
// if (remote && remote_len > 0){
// BHAddress addr;
// if (addr.ParseFromArray(remote, remote_len)){
@@ -344,7 +355,10 @@
}
}
}
-
+ if (url.empty()) {
+ set_last_error("bus_request url empty");
+ return false;
+ }
int rc = request2(url, request, request_len, reply, reply_len, timeout_ms);
if (rc < 0) return false;
copy_memory(proc_id, proc_id_len, procid.data(), procid.size());
diff --git a/src/nng_wrap.cpp b/src/nng_wrap.cpp
index 299ce88..785ef1d 100644
--- a/src/nng_wrap.cpp
+++ b/src/nng_wrap.cpp
@@ -69,6 +69,10 @@
*dest_len = src_len;
}
+void set_last_error(const std::string& emsg){
+ verbose_info += emsg;
+}
+
void get_last_error(int* ec, void** emsg, int* emsg_len){
*emsg = NULL;
*emsg_len = 0;
diff --git a/src/nng_wrap.h b/src/nng_wrap.h
index 10b318f..6d82afb 100644
--- a/src/nng_wrap.h
+++ b/src/nng_wrap.h
@@ -7,6 +7,7 @@
void copy_memory(void** dest, int *dest_len, const void* src, const int src_len);
+void set_last_error(const std::string& emsg);
void get_last_error(int* ec, void** emsg, int* emsg_len);
void free_nng(void* data, const int data_len);
--
Gitblit v1.8.0