2
3
6
7
8
9
10
11
12
14#include <so_5/disp/prio_one_thread/quoted_round_robin/pub.hpp>
16#include <so_5/disp/prio_one_thread/quoted_round_robin/impl/demand_queue.hpp>
17#include <so_5/disp/prio_one_thread/reuse/work_thread.hpp>
19#include <so_5/disp/reuse/actual_work_thread_factory_to_use.hpp>
20#include <so_5/disp/reuse/data_source_prefix_helpers.hpp>
21#include <so_5/disp/reuse/make_actual_dispatcher.hpp>
23#include <so_5/stats/repository.hpp>
24#include <so_5/stats/messages.hpp>
25#include <so_5/stats/std_names.hpp>
27#include <so_5/send_functions.hpp>
54send_thread_activity_stats(
55 const so_5::mbox_t & mbox,
74
75
76
77
78
79
80template<
typename Work_Thread >
83 friend class disp_data_source_t;
88 const std::string_view name_base,
100 outliving_mutable(*
this)
128 agent_t & agent )
noexcept override
140 agent_t & agent )
noexcept override
149
150
151
152
153
164 const std::string_view name_base,
179 std::size_t agents_count = 0;
181 disp.m_demand_queue.handle_stats_for_each_prio(
199 send_thread_activity_stats(
202 disp.m_work_thread );
211 std::size_t agents_count,
212 std::size_t demands_count )
214 std::ostringstream ss;
257 make( disp_binder_shptr_t binder )
noexcept
259 return { std::move( binder )
};
271 const std::string_view data_sources_name_base,
278 using dispatcher_no_activity_tracking_t =
279 impl::dispatcher_template_t<
282 using dispatcher_with_activity_tracking_t =
283 impl::dispatcher_template_t<
288 dispatcher_no_activity_tracking_t
,
289 dispatcher_with_activity_tracking_t
>(
291 data_sources_name_base
,
priority_t so_priority() const noexcept
Get the priority of the agent.
void so_bind_to_dispatcher(event_queue_t &queue) noexcept
Binding agent to the dispatcher.
const lock_factory_t & lock_factory() const
Getter for lock factory.
Alias for namespace with traits of event queue.
const queue_traits::queue_params_t & queue_params() const
Getter for queue parameters.
A handle for prio_one_thread::strictly_ordered dispatcher.
dispatcher_handle_t(disp_binder_shptr_t binder) noexcept
A demand queue for dispatcher with one common working thread and round-robin processing of prioritise...
void agent_unbound(priority_t priority)
Notification about detachment of an agent from the queue.
demand_queue_t(queue_traits::lock_unique_ptr_t lock, const quotes_t "es)
void agent_bound(priority_t priority)
Notification about attachment of yet another agent to the queue.
event_queue_t & event_queue_by_priority(priority_t priority)
Get queue for the priority specified.
void stop()
Set the shutdown signal.
static dispatcher_handle_t make(disp_binder_shptr_t binder) noexcept
Data source for run-time monitoring of whole dispatcher.
stats::prefix_t m_base_prefix
Basic prefix for data sources.
disp_data_source_t(const std::string_view name_base, outliving_reference_t< dispatcher_template_t > disp)
outliving_reference_t< dispatcher_template_t > m_dispatcher
Dispatcher to work with.
void distribute_value_for_priority(const mbox_t &mbox, priority_t priority, std::size_t quote, std::size_t agents_count, std::size_t demands_count)
void distribute(const mbox_t &mbox) override
Send appropriate notification about the current value.
void undo_preallocation(agent_t &) noexcept override
Undo resources allocation.
dispatcher_template_t(outliving_reference_t< environment_t > env, const std::string_view name_base, disp_params_t params, const quotes_t "es)
void preallocate_resources(agent_t &) override
Allocate resources in dispatcher for new agent.
void unbind(agent_t &agent) noexcept override
Unbind agent from dispatcher.
void bind(agent_t &agent) noexcept override
Bind agent to dispatcher.
~dispatcher_template_t() noexcept override
stats::auto_registered_source_holder_t< disp_data_source_t > m_data_source
Data source for run-time monitoring.
Work_Thread m_work_thread
Working thread for the dispatcher.
demand_queue_t m_demand_queue
Demand queue for the dispatcher.
A storage of quotes for priorities.
so_5::stats::work_thread_activity_stats_t take_activity_stats()
so_5::current_thread_id_t thread_id() const
Interface for dispatcher binders.
stats::repository_t & stats_repository()
Access to repository of data sources for run-time monitoring.
Helper class for indication of long-lived reference via its type.
A holder for data-souce that should be automatically registered and deregistered in registry.
A type for storing prefix of data_source name.
constexpr const char * c_str() const noexcept
Access to prefix value.
prefix_t(const std::string &value) noexcept(noexcept(value.c_str()))
Initializing constructor.
An interface of data source.
void send_thread_activity_stats(const so_5::mbox_t &, const stats::prefix_t &, so_5::disp::prio_one_thread::reuse::work_thread_no_activity_tracking_t< demand_queue_t > &)
Implementation details for dispatcher with round-robin policy of handling prioritized events.
Dispatcher which handles events of different priorities in round-robin maner.
SO_5_FUNC dispatcher_handle_t make_dispatcher(environment_t &env, const std::string_view data_sources_name_base, const quotes_t "es, disp_params_t params)
Create an instance of quoted_round_robin dispatcher.
Reusable code for dispatchers with one working thread for events of all priorities.
Dispatcher with one working thread for events of all priorities.
Reusable components for dispatchers.
work_thread_holder_t acquire_work_thread(const work_thread_factory_mixin_t< Params > ¶ms, environment_t &env)
Helper function for acquiring a new worker thread from an appropriate work thread factory.
so_5::stats::prefix_t make_disp_prefix(const std::string_view disp_type, const std::string_view data_sources_name_base, const void *disp_this_pointer)
Create basic prefix for dispatcher data source names.
std::unique_ptr< Disp_Iface_Type > make_actual_dispatcher(outliving_reference_t< environment_t > env, const std::string_view name_base, Disp_Params_Type disp_params, Args &&...args)
Helper function for creation of dispatcher instance with respect to work thread activity tracking fla...
Declarations of messages used by run-time monitoring and statistics.
Predefined suffixes of data-sources.
SO_5_FUNC suffix_t agent_count()
Suffix for data source with count of agents bound to some entity.
SO_5_FUNC suffix_t work_thread_queue_size()
Suffix for data source with count of demands in a working thread event queue.
SO_5_FUNC suffix_t work_thread_activity()
Suffix for data source with work thread activity statistics.
SO_5_FUNC suffix_t demand_quote()
Suffix for data source with size of quote for demands processing.
All stuff related to run-time monitoring and statistics.
Private part of message limit implementation.
std::size_t to_size_t(priority_t priority)
Helper function for conversion from priority to size_t.
priority_t
Definition of supported priorities.
void send(Target &&to, Args &&... args)
A utility function for creating and delivering a message or a signal.
outliving_reference_t< T > outliving_mutable(T &r)
Make outliving_reference wrapper for mutable reference.
Statistic about one subqueue.
std::size_t m_agents_count
std::size_t m_demands_count
A message with value of some quantity.
Information about one work thread activity.