#include <iostream>
#include <time.h>
#include <ace/OS.h>
#include <ace/Time_Value.h>
class msg_hello_periodic
:
{
public:
std::string m_message;
};
class msg_stop_signal
:
{};
class a_hello_t
:
{
public:
:
base_type_t( env ),
m_evt_count( 0 ),
m_self_mbox( so_environment().create_local_mbox() )
{}
virtual ~a_hello_t()
{}
virtual void
virtual void
void
evt_hello_periodic(
void
evt_stop_signal(
private:
unsigned int m_evt_count;
};
void
a_hello_t::so_define_agent()
{
so_subscribe( m_self_mbox )
.event( &a_hello_t::evt_hello_periodic );
so_subscribe( m_self_mbox )
.event( &a_hello_t::evt_stop_signal );
}
void
a_hello_t::so_evt_start()
{
time_t t = time( 0 );
std::cout << asctime( localtime( &t ) )
<< "a_hello_t::so_evt_start()" << std::endl;
std::unique_ptr< msg_hello_periodic > msg( new msg_hello_periodic );
msg->m_message = "Hello, periodic!";
m_hello_timer_id =
so_environment()
.schedule_timer< msg_hello_periodic >(
std::move( msg ),
m_self_mbox,
1 * 1000,
1 * 1000 );
m_stop_timer_id =
so_environment()
.schedule_timer< msg_stop_signal >(
m_self_mbox,
2 * 1000,
0 );
}
void
a_hello_t::evt_hello_periodic(
{
time_t t = time( 0 );
std::cout << asctime( localtime( &t ) )
<< msg->m_message << std::endl;
if( 5 == ++m_evt_count )
{
m_hello_timer_id.release();
}
else
{
m_stop_timer_id =
so_environment()
.schedule_timer< msg_stop_signal >(
m_self_mbox,
2 * 1000,
0 );
}
}
void
a_hello_t::evt_stop_signal(
{
time_t t = time( 0 );
std::cout << asctime( localtime( &t ) )
<< "Stop SObjectizer..." << std::endl;
so_environment().stop();
}
void
{
new a_hello_t( env ) ) );
}
int
main( int, char ** )
{
try
{
}
catch( const std::exception & ex )
{
std::cerr << "Error: " << ex.what() << std::endl;
return 1;
}
return 0;
}