X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/8b0ff1210013395dca41357e553888693f4f6816..ccc3b6ac54d65bf59be965f90ea657deea9bafa8:/include/simgrid/s4u/mailbox.hpp diff --git a/include/simgrid/s4u/mailbox.hpp b/include/simgrid/s4u/mailbox.hpp index c76a4d9ec2..88206d6328 100644 --- a/include/simgrid/s4u/mailbox.hpp +++ b/include/simgrid/s4u/mailbox.hpp @@ -6,9 +6,12 @@ #ifndef SIMGRID_S4U_MAILBOX_HPP #define SIMGRID_S4U_MAILBOX_HPP -#include +#include -#include "simgrid/s4u/process.hpp" +#include + +#include +#include namespace simgrid { namespace s4u { @@ -20,26 +23,49 @@ namespace s4u { * You can access any mailbox without any latency. The network delay are only related to the location of the * sender and receiver. */ -class Mailbox { - friend Process; +XBT_PUBLIC_CLASS Mailbox { + friend Comm; + friend simgrid::s4u::Engine; + friend simgrid::simix::Mailbox; -private: - Mailbox(const char*name, smx_rdv_t inferior); -public: - ~Mailbox(); - -protected: - smx_rdv_t getInferior() { return p_inferior; } + simgrid::simix::Mailbox *pimpl_; + + Mailbox(smx_mailbox_t mbox): pimpl_(mbox) {} + // We don't have to manage the lifetime of mailboxes: + friend void intrusive_ptr_add_ref(Mailbox*) {} + friend void intrusive_ptr_release(Mailbox*) {} public: - /** Retrieve the mailbox associated to the given string */ - static Mailbox *byName(const char *name); + smx_mailbox_t getImpl() { return pimpl_; } // FIXME: make me protected + + + /** Get the name of that mailbox */ + const char *getName(); + + /** Retrieve the mailbox associated to the given string (as a C string) */ + static MailboxPtr byName(const char *name); -private: - std::string p_name; - smx_rdv_t p_inferior; - static boost::unordered_map *channels; + /** Retrieve the mailbox associated to the given string (as a C++ string) */ + static MailboxPtr byName(std::string name); + + /** Returns whether the mailbox contains queued communications */ + bool empty(); + + /** Returns the first element in the queue, or nullptr if none is there */ + smx_activity_t front(); + + /** Declare that the specified process is a permanent receiver on that mailbox + * + * It means that the communications sent to this mailbox will start flowing to + * its host even before he does a recv(). This models the real behavior of TCP + * and MPI communications, amongst other. + */ + void setReceiver(ActorPtr process); + + /** Return the process declared as permanent receiver, or nullptr if none **/ + ActorPtr receiver(); }; + }} // namespace simgrid::s4u #endif /* SIMGRID_S4U_MAILBOX_HPP */