From 9cf3ddc288193e2fe645f34388322f9586ee043d Mon Sep 17 00:00:00 2001
From: lichao <lichao@aiotlink.com>
Date: 星期三, 24 三月 2021 16:23:24 +0800
Subject: [PATCH] change mq id from int to uuid.

---
 src/shm.h |   11 ++++++-----
 1 files changed, 6 insertions(+), 5 deletions(-)

diff --git a/src/shm.h b/src/shm.h
index 94ead7f..0ba4e8c 100644
--- a/src/shm.h
+++ b/src/shm.h
@@ -21,9 +21,11 @@
 
 #include <boost/interprocess/managed_shared_memory.hpp>
 #include <boost/interprocess/sync/interprocess_condition.hpp>
+#include <boost/interprocess/containers/string.hpp>
 #include <boost/circular_buffer.hpp>
 #include <boost/noncopyable.hpp>
 #include <boost/date_time/posix_time/posix_time.hpp>
+#include <boost/uuid/uuid.hpp>
 
 namespace bhome_shm {
 
@@ -98,7 +100,7 @@
 
 template <class D> using Circular = boost::circular_buffer<D, Allocator<D> >;
 
-typedef int MQId;
+typedef boost::uuids::uuid MQId;
 template <class D>
 class SyncedQueue : private Circular<D>
 {
@@ -120,7 +122,7 @@
     template <class...T> SyncedQueue(MQId id, T&&...t):Super(t...), id_(id) {}
     using Super::size;
     using Super::capacity;
-    MQId id() const { return id_; }
+    MQId Id() const { return id_; }
     bool Write(D buf, const int timeout_ms) {
         Guard lock(mutex());
         if (cond_write_.timed_wait(lock, MSFromNow(timeout_ms), [&]() { return !this->full(); })) {
@@ -152,21 +154,20 @@
     size_t size_;
 };
 
-
 class ShmMsgQueue : private ShmObject<SyncedQueue<Msg> >
 {
     typedef ShmObject<SyncedQueue<Msg> > SharedQueue;
     typedef SharedQueue::Data Queue;
-    ShmMsgQueue(MQId id, ShmType &segment, const std::string &name, const uint32_t len);
     bool Write(const Msg &buf, const int timeout_ms) { return data()->Write(buf, timeout_ms); }
     bool Read(Msg &buf, const int timeout_ms) { return data()->Read(buf, timeout_ms); }
 public:
     ShmMsgQueue(MQId id, ShmType &segment, const uint32_t len);
+    ShmMsgQueue(ShmType &segment, const uint32_t len);
     ~ShmMsgQueue();
     bool Send(MQId remote_id, const void *data, const size_t size, const int timeout_ms);
     bool Recv(MQId &source_id, void *&data, size_t &size, const int timeout_ms);
     using SharedQueue::Remove;
-    MQId id() const { return data()->id(); }
+    MQId Id() const { return data()->Id(); }
 };
 
 } // namespace bhome_shm

--
Gitblit v1.8.0