]> AND Private Git Repository - loba.git/blobdiff - messages.h
Logo AND Algorithmique Numérique Distribuée

Private GIT Repository
Use a lock-free synchronized queue for the message queue.
[loba.git] / messages.h
index 34e9248cdde56454c8dc997d56c81aa9283bef21..8de464ab8f390cb4fb77cc4a647b05f4d5e864e3 100644 (file)
@@ -5,6 +5,7 @@
 #include <string>
 #include <msg/msg.h>
 #include "synchro.h"
+#include "sync_queue.h"
 
 class message {
 public:
@@ -14,6 +15,7 @@ public:
 
     message_type get_type() const       { return type;   }
     double get_amount() const           { return amount; }
+    double get_size() const;
 
     std::string to_string();
 
@@ -27,7 +29,7 @@ public:
     // Push a message on queue
     void push(m_task_t task);
 
-    // Try to get a message.  Returns true on success.
+    // Try to pop a message.  Returns true on success.
     // Parameter "timeout" may be 0 for non-blocking operation, -1 for
     // infinite waiting, or any positive timeout.
     bool pop(message*& msg, m_host_t& from, double timeout);
@@ -38,7 +40,7 @@ public:
 private:
     mutex_t mutex;
     condition_t cond;
-    std::queue<m_task_t> queue;
+    sync_queue<m_task_t> queue;
 };
 
 #endif // !MESSAGES_H