zhangmeng
2022-04-11 f552a0ea788225d8fe80942d6e8bd6500f788393
add log
4个文件已修改
63 ■■■■ 已修改文件
src/bn_api.cpp 36 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/interface_bus_api.cpp 22 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/nng_wrap.cpp 4 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/nng_wrap.h 1 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
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暂时没用,返回fake 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;
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());
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;
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);