X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/b9945098e2ba4e7b639e0c2245835d44800c1b29..a57327d86b9fb16acacc71a3359817acd2a2816b:/src/kernel/activity/MailboxImpl.hpp diff --git a/src/kernel/activity/MailboxImpl.hpp b/src/kernel/activity/MailboxImpl.hpp index 97b7576fe2..b176c76cea 100644 --- a/src/kernel/activity/MailboxImpl.hpp +++ b/src/kernel/activity/MailboxImpl.hpp @@ -17,13 +17,16 @@ namespace simgrid { namespace kernel { namespace activity { -/** @brief Implementation of the simgrid::s4u::Mailbox */ +/** @brief Implementation of the s4u::Mailbox */ class MailboxImpl { static constexpr size_t MAX_MAILBOX_SIZE = 10000000; + s4u::Mailbox piface_; + xbt::string name_; + friend s4u::Mailbox; - friend s4u::MailboxPtr s4u::Mailbox::by_name(const std::string& name); + friend s4u::Mailbox* s4u::Mailbox::by_name(const std::string& name); friend mc::CommunicationDeterminismChecker; explicit MailboxImpl(const std::string& name) @@ -32,7 +35,7 @@ class MailboxImpl { } public: - const simgrid::xbt::string& get_name() const { return name_; } + const xbt::string& get_name() const { return name_; } const char* get_cname() const { return name_.c_str(); } static MailboxImpl* by_name_or_null(const std::string& name); static MailboxImpl* by_name_or_create(const std::string& name); @@ -43,19 +46,14 @@ public: CommImplPtr find_matching_comm(CommImpl::Type type, int (*match_fun)(void*, void*, CommImpl*), void* this_user_data, const CommImplPtr& my_synchro, bool done, bool remove_matching); -private: - simgrid::s4u::Mailbox piface_; - simgrid::xbt::string name_; - -public: - simgrid::kernel::actor::ActorImplPtr permanent_receiver_; // actor to which the mailbox is attached + actor::ActorImplPtr permanent_receiver_; // actor to which the mailbox is attached boost::circular_buffer_space_optimized comm_queue_; boost::circular_buffer_space_optimized done_comm_queue_; // messages already received in the permanent // receive mode }; -} -} -} +} // namespace activity +} // namespace kernel +} // namespace simgrid XBT_PRIVATE void SIMIX_mailbox_exit();