X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/9e3b2f1d55a07271c05db2ed5b3fec27561097f9..09be3731dc0739ab7e4cdb00716335b60acb4331:/src/kernel/activity/MailboxImpl.hpp diff --git a/src/kernel/activity/MailboxImpl.hpp b/src/kernel/activity/MailboxImpl.hpp index 455991333c..29b561c5c4 100644 --- a/src/kernel/activity/MailboxImpl.hpp +++ b/src/kernel/activity/MailboxImpl.hpp @@ -11,47 +11,51 @@ #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; + 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); void set_receiver(s4u::ActorPtr actor); - void push(activity::CommImplPtr comm); - void remove(smx_activity_t activity); + void push(CommImplPtr comm); + void remove(const CommImplPtr& comm); + CommImplPtr iprobe(int type, int (*match_fun)(void*, void*, CommImpl*), void* data); + 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_; + s4u::Mailbox piface_; + xbt::string name_; public: - simgrid::kernel::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 + 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();