X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/fbecf54f013a2c4171160f4aad8a4d8377bee1f9..9b5c287fbf93c2ae7c3d18c8584647ef9920fe87:/src/kernel/activity/MailboxImpl.hpp diff --git a/src/kernel/activity/MailboxImpl.hpp b/src/kernel/activity/MailboxImpl.hpp index b88d28d22e..b176c76cea 100644 --- a/src/kernel/activity/MailboxImpl.hpp +++ b/src/kernel/activity/MailboxImpl.hpp @@ -11,27 +11,31 @@ #include "simgrid/s4u/Mailbox.hpp" #include "src/kernel/activity/CommImpl.hpp" -#include "src/simix/ActorImpl.hpp" +#include "src/kernel/actor/ActorImpl.hpp" -#define MAX_MAILBOX_SIZE 10000000 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(std::string name) - : piface_(this), name_(std::move(name)), comm_queue_(MAX_MAILBOX_SIZE), done_comm_queue_(MAX_MAILBOX_SIZE) + explicit MailboxImpl(const std::string& name) + : piface_(this), name_(name), comm_queue_(MAX_MAILBOX_SIZE), done_comm_queue_(MAX_MAILBOX_SIZE) { } 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); @@ -42,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();