X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/691d7c891da0352a6fa38507a482b287c7e086de..149c63f36e15b8500b1e826bda5138318ff7ba2b:/src/kernel/activity/MailboxImpl.hpp diff --git a/src/kernel/activity/MailboxImpl.hpp b/src/kernel/activity/MailboxImpl.hpp index 0c8246bd5c..956b021032 100644 --- a/src/kernel/activity/MailboxImpl.hpp +++ b/src/kernel/activity/MailboxImpl.hpp @@ -1,10 +1,10 @@ -/* Copyright (c) 2007-2019. The SimGrid Team. All rights reserved. */ +/* Copyright (c) 2007-2020. The SimGrid Team. All rights reserved. */ /* This program is free software; you can redistribute it and/or modify it * under the terms of the license (GNU LGPL) which comes with this package. */ -#ifndef SIMIX_MAILBOXIMPL_H -#define SIMIX_MAILBOXIMPL_H +#ifndef SIMGRID_KERNEL_ACTIVITY_MAILBOX_HPP +#define SIMGRID_KERNEL_ACTIVITY_MAILBOX_HPP #include #include @@ -17,46 +17,41 @@ 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::Mailbox* s4u::Mailbox::by_name(const std::string& name); friend mc::CommunicationDeterminismChecker; - explicit MailboxImpl(const std::string& name) - : piface_(this), name_(name), comm_queue_(MAX_MAILBOX_SIZE), done_comm_queue_(MAX_MAILBOX_SIZE) - { - } + explicit MailboxImpl(const std::string& name) : piface_(this), name_(name) {} 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(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, + CommImplPtr iprobe(int type, bool (*match_fun)(void*, void*, CommImpl*), void* data); + CommImplPtr find_matching_comm(CommImpl::Type type, bool (*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 - 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_{MAX_MAILBOX_SIZE}; + // messages already received in the permanent receive mode + boost::circular_buffer_space_optimized done_comm_queue_{MAX_MAILBOX_SIZE}; }; -} -} -} +} // namespace activity +} // namespace kernel +} // namespace simgrid XBT_PRIVATE void SIMIX_mailbox_exit(); -#endif /* SIMIX_MAILBOXIMPL_H */ +#endif