- 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);
-
- actor::ActorImplPtr permanent_receiver_; // actor to which the mailbox is attached
- boost::circular_buffer_space_optimized<CommImplPtr> comm_queue_;
- boost::circular_buffer_space_optimized<CommImplPtr> done_comm_queue_; // messages already received in the permanent
- // receive mode
+ void clear(bool do_finish);
+ CommImplPtr iprobe(int type, const std::function<bool(void*, void*, CommImpl*)>& match_fun, void* data);
+ CommImplPtr find_matching_comm(CommImplType type, const std::function<bool(void*, void*, CommImpl*)>& match_fun,
+ void* this_user_data, const CommImplPtr& my_synchro, bool done, bool remove_matching);
+ bool is_permanent() const { return permanent_receiver_ != nullptr; }
+ actor::ActorImplPtr get_permanent_receiver() const { return permanent_receiver_; }
+ bool empty() const { return comm_queue_.empty(); }
+ size_t size() const { return comm_queue_.size(); }
+ const CommImplPtr& front() const { return comm_queue_.front(); }
+ bool has_some_done_comm() const { return not done_comm_queue_.empty(); }
+ const CommImplPtr& done_front() const { return done_comm_queue_.front(); }