structured_consumer.cpp
来自「这是广泛使用的通信开源项目,对于大容量,高并发的通讯要求完全能够胜任,他广泛可用」· C++ 代码 · 共 263 行
CPP
263 行
// Structured_Consumer.cpp,v 1.5 2003/07/03 02:16:27 pradeep Exp
// ******************************************************************
// Include Section
// ******************************************************************
#include "ace/Get_Opt.h"
#include "orbsvcs/CosNotifyChannelAdminC.h"
#include "orbsvcs/CosNotifyCommC.h"
#include "orbsvcs/CosNamingC.h"
#include "controlC.h"
#include "Notify_Push_Consumer.h"
#include "Notify_Test_Client.h"
#include "tao/debug.h"
// ******************************************************************
// Data Section
// ******************************************************************
static CORBA::Boolean isFilter = 0;
static CORBA::Boolean sFilter = 0; // supplier has filters
static CORBA::Short num_events = 0;
static CORBA::Short num_consumers = 0;
static CORBA::Short op = 0; // 0 = AND_OP; 1 = OR_OP
#define GRAMMAR "TCL"
// ******************************************************************
// Subroutine Section
// ******************************************************************
class Consumer_Client : public Notify_Test_Client
{
public:
virtual int parse_args (int argc, char* argv[]);
};
int
Consumer_Client::parse_args (int argc, char *argv[])
{
ACE_Get_Opt get_opts (argc, argv, "fsn:c:o:");
int x;
while ((x = get_opts ()) != -1)
switch (x)
{
case 'f':
isFilter = 1;
break;
case 'n':
num_events = atoi (get_opts.optarg);
break;
case 'c':
num_consumers = atoi (get_opts.optarg);
break;
case 'o':
if (!ACE_OS::strcmp ("OR_OP", get_opts.optarg))
op = 1;
break;
case 's':
sFilter = 1;
break;
default:
ACE_ERROR_RETURN ((LM_ERROR,
"usage: %s "
"[-f] [-s] -n <num events> -c <num consumers> "
"-o <AND_OP | OR_OP>"
"\n",
argv [0]),
-1);
}
return 0; // successful parse
}
static void
create_consumers (CosNotifyChannelAdmin::ConsumerAdmin_ptr admin,
CosNotifyChannelAdmin::EventChannel_ptr ec,
Notify_Test_Client* client
ACE_ENV_ARG_DECL)
{
Notify_Push_Consumer* consumer = 0;
ACE_NEW_THROW_EX (consumer,
Notify_Push_Consumer ("Consumer"),
CORBA::NO_MEMORY ());
consumer->init (client->root_poa () ACE_ENV_ARG_PARAMETER);
ACE_CHECK;
consumer->_connect (admin, ec, isFilter ACE_ENV_ARG_PARAMETER);
ACE_CHECK;
}
// ******************************************************************
// Main Section
// ******************************************************************
int main (int argc, char * argv[])
{
int status = 0;
ACE_TRY_NEW_ENV;
{
Consumer_Client client;
status = client.init (argc, argv ACE_ENV_ARG_PARAMETER);
ACE_TRY_CHECK;
if (status == 0)
{
CosNotifyChannelAdmin::EventChannel_var ec =
client.create_event_channel ("NotifyEventChannelFactory",
1
ACE_ENV_ARG_PARAMETER);
CosNotifyChannelAdmin::AdminID adminid = 0;
CosNotifyChannelAdmin::ConsumerAdmin_var consumer_admin =
ec->new_for_consumers ((op ? CosNotifyChannelAdmin::OR_OP :
CosNotifyChannelAdmin::AND_OP),
adminid
ACE_ENV_ARG_PARAMETER);
ACE_TRY_CHECK;
// Filter Section
if (isFilter)
{
CosNotifyFilter::FilterFactory_var ffact =
ec->default_filter_factory (ACE_ENV_SINGLE_ARG_PARAMETER);
ACE_TRY_CHECK;
CosNotifyFilter::Filter_var filter =
ffact->create_filter (GRAMMAR ACE_ENV_ARG_PARAMETER);
ACE_TRY_CHECK;
if (CORBA::is_nil (filter.in ()))
{
ACE_ERROR ((LM_ERROR,
" (%P|%t) Consumer unable to initialize filter.\n"));
return 1;
}
CosNotifyFilter::ConstraintExpSeq constraint_list (1);
constraint_list.length (1);
constraint_list[0].event_types.length (0);
constraint_list[0].constraint_expr = CORBA::string_dup ("Number == 50");
filter->add_constraints (constraint_list ACE_ENV_ARG_PARAMETER);
ACE_TRY_CHECK;
// apply filter
consumer_admin->add_filter (filter.in ());
}
// End Filter Section
// start server
CosNaming::Name ctrl_name;
ctrl_name.length (1);
ctrl_name[0].id = CORBA::string_dup ("Supplier");
CosNaming::NamingContext_ptr naming_context = client.naming_context ();
CORBA::Object_var ctrl_obj = naming_context->resolve (ctrl_name
ACE_ENV_ARG_PARAMETER);
ACE_TRY_CHECK;
if (CORBA::is_nil (ctrl_obj.in ()))
{
ACE_ERROR ((LM_ERROR,
"(%P|%T) Consumer unable to find "
"Supplier Naming Context.\n"));
return 1;
}
supplier_ctrl_var supplier = supplier_ctrl::_narrow (ctrl_obj.in ());
if (!CORBA::is_nil (consumer_admin.in ()))
{
for ( int ctr = 0; ctr < num_consumers; ctr ++)
create_consumers (consumer_admin.in (),
ec.in (),
&client
ACE_ENV_ARG_PARAMETER);
ACE_TRY_CHECK;
// Start Supplier
supplier->ctrl (1, num_events);
// wait for Supplier
ACE_OS::sleep (5);
CORBA::ORB_ptr orb = client.orb ();
while (!client.done ())
{
if (orb->work_pending ())
{
orb->perform_work ();
if (isFilter || sFilter)
{
if (!op)
{
if ((num_events / 6 * num_consumers) ==
Notify_Push_Consumer::get_count ())
client.done () = 1;
}
else
{
if ((num_events / 3 * num_consumers) ==
Notify_Push_Consumer::get_count ())
client.done () = 1;
}
}
else
{
if (num_events * num_consumers == Notify_Push_Consumer::get_count ())
client.done () = 1;
}
if (TAO_debug_level)
ACE_DEBUG ((LM_DEBUG,
"Consumer received event #%d\n",
Notify_Push_Consumer::get_count ()));
}
}
// Are there any more events
num_events = Notify_Push_Consumer::get_count ();
ACE_OS::sleep (5);
if (orb->work_pending ())
orb->perform_work ();
if (num_events != Notify_Push_Consumer::get_count ())
status = 1;
// cleanup
ec->destroy ();
orb->destroy ();
}
}
}
ACE_CATCH (CORBA::Exception, e)
{
ACE_PRINT_EXCEPTION (e, "Consumer Exception:");
status = 1;
}
ACE_ENDTRY;
return status;
}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?