OpenHiva::TopicOptions类型定义
用户在调用OpenHiva::Node::CreatePublisher和OpenHiva::Node::CreateSubscriber时都需要TopicOptions, TopicOptions是Topic消息一系列属性值的集合,包括话题通信方式以及各个通信方式下的属性配置。
除了通过yaml文件进行参数配置,可以通过一系列Build接口进行参数配置,定义如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 | namespace OpenHiva { using TransportOptions = std::unordered_map<std::string, std::string>; class TopicOptions { public: TopicOptions(); ~TopicOptions(); template <typename M> TopicOptions &BuildMessageTraits(); // maxMsgSize在SHM通信模式下,不能超过30000000,单位是bytes TopicOptions &BuildShmOptions(const uint32_t maxMsgSize, const uint32_t blockNum); TopicOptions &BuildQueueOptions(const uint32_t queueSize, const bool overwrite = false, const bool queueFCFlag = false, const uint16_t queueTTL = 0U); TopicOptions &BuildGroupName(const std::string &groupName); TopicOptions &BuildTransportOptions(const std::string &transType, const TransportOptions &opts); TopicOptions &BuildTopicName(const std::string &topicName); template <typename M, enable_if_t_self_topic_options<!is_shared_ptr_topic_options<M>::value, int> = 0> TopicOptions &BuildCallback(const std::function<void(M)> &callback); // 设置回调函数,本模板函数中M必须为普通消息类型 template <typename M, enable_if_t_self_topic_options<is_shared_ptr_topic_options<M>::value, int> = 0> TopicOptions &BuildCallback(const std::function<void(M)> &callback); // 设置回调函数,本模板函数中M必须为std::shared_ptr消息类型 const std::vector<std::string> &GetTransportTypes(); const std::unordered_map<std::string, OpenHiva::TransportOptions> &GetTransportOptions() const; Hiva::AdvertiseOptions CreateAdvertiseOps() const; Hiva::SubscribeOptions CreateSubscribeOps() const; }; } |
父主题: 类型定义