lichao
2021-04-06 3e9f5b869dd32441fdd3d77091cb33ef4301f244
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
/*
 * =====================================================================================
 *
 *       Filename:  center.cpp
 *
 *    Description:  
 *
 *        Version:  1.0
 *        Created:  2021年03月30日 16时19分37秒
 *       Revision:  none
 *       Compiler:  gcc
 *
 *         Author:  Li Chao (), 
 *   Organization:  
 *
 * =====================================================================================
 */
#include "center.h"
#include "defs.h"
#include "pubsub_center.h"
#include "reqrep_center.h"
#include "shm.h"
 
using namespace bhome_shm;
typedef BHCenter::MsgHandler Handler;
 
Handler Join(Handler h1, Handler h2)
{
    return [h1, h2](ShmSocket &socket, bhome_msg::MsgI &imsg, bhome::msg::BHMsg &msg) {
        return h1(socket, imsg, msg) || h2(socket, imsg, msg);
    };
}
 
SharedMemory &BHomeShm()
{
    static SharedMemory shm("bhome_default_shm_v0", 1024 * 1024 * 64);
    return shm;
}
 
BHCenter::CenterRecords &BHCenter::Centers()
{
    static CenterRecords rec;
    return rec;
}
bool BHCenter::Install(const std::string &name, MsgHandler handler, const std::string &mqid, const int mq_len)
{
    CenterRecords()[name] = CenterInfo{name, handler, mqid, mq_len};
}
 
BHCenter::BHCenter(Socket::Shm &shm)
{
    sockets_["center"] = std::make_shared<ShmSocket>(shm, &BHTopicCenterAddress(), 1000);
    sockets_["bus"] = std::make_shared<ShmSocket>(shm, &BHTopicBusAddress(), 1000);
    for (auto &kv : Centers()) {
        sockets_[kv.first] = std::make_shared<ShmSocket>(shm, kv.second.mqid_.data(), kv.second.mq_len_);
    }
}
 
BHCenter::BHCenter() :
    BHCenter(BHomeShm()) {}
 
bool BHCenter::Start()
{
    auto onCenter = MakeReqRepCenter();
    auto onBus = MakeBusCenter();
    sockets_["center"]->Start(onCenter);
    sockets_["bus"]->Start(onBus);
 
    for (auto &kv : Centers()) {
        sockets_[kv.first]->Start(kv.second.handler_);
    }
    return true;
    // socket_.Start(Join(onCenter, onBus));
}
 
bool BHCenter::Stop()
{
    for (auto &kv : sockets_) {
        kv.second->Stop();
    }
    return true;
}