// $Id$ // ****************************************************************** // Include Section // ****************************************************************** #include "ace/Get_Opt.h" #include "ace/OS_NS_unistd.h" #include "orbsvcs/CosNotifyCommC.h" #include "orbsvcs/CosNamingC.h" #include "Notify_Sequence_Push_Consumer.h" #include "goC.h" #include "Notify_Test_Client.h" // ****************************************************************** // Data Section // ****************************************************************** static const char* ior = "file://supplier.ior"; static CORBA::Short discard_policy = CosNotification::FifoOrder; static unsigned int low = 2; static unsigned int high = 4; // ****************************************************************** // 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, "k:l:h:d:"); int c; while ((c = get_opts ()) != -1) switch (c) { case 'k': ior = get_opts.optarg; break; case 'l': low = ACE_OS::atoi (get_opts.optarg); break; case 'h': high = ACE_OS::atoi (get_opts.optarg); break; case 'd': { const char* discard = get_opts.optarg; if (ACE_OS::strcmp (discard, "fifo") == 0) { discard_policy = CosNotification::FifoOrder; } else if (ACE_OS::strcmp (discard, "priority") == 0) { discard_policy = CosNotification::PriorityOrder; } else if (ACE_OS::strcmp (discard, "lifo") == 0) { discard_policy = CosNotification::LifoOrder; } else if (ACE_OS::strcmp (discard, "deadline") == 0) { discard_policy = CosNotification::DeadlineOrder; #if !defined (ACE_HAS_TIMED_MESSAGE_BLOCKS) ACE_ERROR_RETURN ((LM_ERROR, "This order policy requires timed message " "blocks.\nPlease #define " "ACE_HAS_TIMED_MESSAGE_BLOCKS in your " "config.h\n"), -1); #endif } else { ACE_ERROR_RETURN ((LM_ERROR, "Unknown discard policy: %s\n", discard_policy), -1); } break; } default: ACE_ERROR_RETURN ((LM_ERROR, "usage: %s " "-k " "-l " "-h " "-d " "\n", argv [0]), -1); } // Indicates sucessful parsing of the command line return 0; } static CosNotifyChannelAdmin::ConsumerAdmin_ptr create_consumeradmin (CosNotifyChannelAdmin::EventChannel_ptr ec ACE_ENV_ARG_DECL) { CosNotifyChannelAdmin::AdminID adminid = 0; CosNotifyChannelAdmin::ConsumerAdmin_var admin = ec->new_for_consumers (CosNotifyChannelAdmin::OR_OP, adminid ACE_ENV_ARG_PARAMETER); ACE_CHECK_RETURN (0); return CosNotifyChannelAdmin::ConsumerAdmin::_duplicate (admin.in ()); } static void create_consumers (CosNotifyChannelAdmin::ConsumerAdmin_ptr admin, Notify_Test_Client* client ACE_ENV_ARG_DECL) { // startup the consumer Notify_Sequence_Push_Consumer* consumer_1; ACE_NEW_THROW_EX (consumer_1, Notify_Sequence_Push_Consumer ("consumer1", discard_policy, low, high, client->done ()), CORBA::NO_MEMORY ()); consumer_1->init (client->root_poa () ACE_ENV_ARG_PARAMETER); ACE_CHECK; consumer_1->_connect (admin 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 ("MyEventChannel", 1 ACE_ENV_ARG_PARAMETER); ACE_TRY_CHECK; CORBA::ORB_ptr orb = client.orb (); CORBA::Object_var object = orb->string_to_object (ior ACE_ENV_ARG_PARAMETER); ACE_TRY_CHECK; sig_var sig = sig::_narrow (object.in () ACE_ENV_ARG_PARAMETER); ACE_TRY_CHECK; if (CORBA::is_nil (sig.in ())) { ACE_ERROR_RETURN ((LM_ERROR, "Object reference <%s> is nil\n", ior), 1); } CosNotifyChannelAdmin::ConsumerAdmin_var admin = create_consumeradmin (ec.in () ACE_ENV_ARG_PARAMETER); ACE_TRY_CHECK; if (!CORBA::is_nil (admin.in ())) { create_consumers (admin.in (), &client ACE_ENV_ARG_PARAMETER); ACE_TRY_CHECK; // Tell the supplier to go sig->go (ACE_ENV_SINGLE_ARG_PARAMETER); ACE_TRY_CHECK; unsigned int try_count = 0; unsigned int try_max = (high - low) * 2; while (true) { // See if we can get any more events if (client.done ()) { ACE_OS::sleep (1); try_count++; if (try_count >= try_max) break; } if (orb->work_pending ()) { orb->perform_work (); } } } } } ACE_CATCH (CORBA::Exception, e) { ACE_PRINT_EXCEPTION (e, "Consumer exception: "); status = 1; } ACE_ENDTRY; return status; }