#include <iostream>
#include <stdexcept>
#include <string>
class logger_t
{
public :
logger_t()
{
std::cout << "[log] -- logger created --" << std::endl;
}
~logger_t()
{
std::cout << "[log] -- logger destroyed --" << std::endl;
}
void
log( const std::string & what )
{
std::cout << "[log] " << what << std::endl;
}
};
{
public :
a_child_t(
context_t ctx,
std::string agent_name,
logger_t & logger )
, m_agent_name( std::move( agent_name ) )
, m_parent_mbox( std::move( parent_mbox ) )
, m_logger( logger )
{
m_logger.log( m_agent_name + ": created" );
}
~a_child_t() override
{
m_logger.log( m_agent_name + ": destroyed" );
}
{
m_logger.log( m_agent_name + ": finishing" );
so_5::send< msg_child_finished >( m_parent_mbox );
}
private :
const std::string m_agent_name;
logger_t & m_logger;
};
{
public :
a_parent_t(
context_t ctx,
logger_t & logger,
size_t child_count )
, m_logger( logger )
, m_child_count( child_count )
, m_child_finished( 0 )
{
m_logger.log( "parent created" );
}
~a_parent_t() override
{
m_logger.log( "parent destroyed" );
}
{
&a_parent_t::evt_child_finished );
}
{
m_logger.log( "creating child cooperation..." );
register_child_coop();
m_logger.log( "child cooperation created" );
}
void evt_child_finished( mhood_t< msg_child_finished > )
{
m_logger.log( "child_finished notification received" );
++m_child_finished;
if( m_child_finished >= m_child_count )
{
m_logger.log( "stopping so_environment..." );
}
}
private :
logger_t & m_logger;
const size_t m_child_count;
size_t m_child_finished;
void register_child_coop()
{
{
for( size_t i = 0; i != m_child_count; ++i )
"a_child_" + std::to_string(i+1),
so_direct_mbox(), m_logger );
} );
}
};
{
} );
}
int main()
{
try
{
}
catch( const std::exception & ex )
{
std::cerr << "Error: " << ex.what() << std::endl;
return 1;
}
return 0;
}