summaryrefslogtreecommitdiff
path: root/TAO/orbsvcs/performance-tests/RTEvent/lib/Client_Group.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'TAO/orbsvcs/performance-tests/RTEvent/lib/Client_Group.cpp')
-rw-r--r--TAO/orbsvcs/performance-tests/RTEvent/lib/Client_Group.cpp76
1 files changed, 76 insertions, 0 deletions
diff --git a/TAO/orbsvcs/performance-tests/RTEvent/lib/Client_Group.cpp b/TAO/orbsvcs/performance-tests/RTEvent/lib/Client_Group.cpp
new file mode 100644
index 00000000000..7daaf4ae6b4
--- /dev/null
+++ b/TAO/orbsvcs/performance-tests/RTEvent/lib/Client_Group.cpp
@@ -0,0 +1,76 @@
+/**
+ * @file Client_Group.cpp
+ *
+ * $Id$
+ *
+ * @author Carlos O'Ryan <coryan@uci.edu>
+ */
+
+#include "Client_Group.h"
+#include "Auto_Disconnect.h"
+
+#if !defined(__ACE_INLINE__)
+#include "Client_Group.inl"
+#endif /* __ACE_INLINE__ */
+
+ACE_RCSID (TAO_PERF_RTEC,
+ Client_Group,
+ "$Id$")
+
+void
+Client_Group::init (CORBA::Long experiment_id,
+ CORBA::Long base_event_type,
+ CORBA::ULong iterations,
+ CORBA::Long workload_in_usecs,
+ ACE_UINT32 gsf,
+ PortableServer::POA_ptr supplier_poa,
+ PortableServer::POA_ptr consumer_poa)
+{
+ this->init (experiment_id, base_event_type, 1,
+ iterations, workload_in_usecs, gsf,
+ supplier_poa, consumer_poa);
+}
+
+void
+Client_Group::init (CORBA::Long experiment_id,
+ CORBA::Long base_event_type,
+ CORBA::Long event_type_range,
+ CORBA::ULong iterations,
+ CORBA::Long workload_in_usecs,
+ ACE_UINT32 gsf,
+ PortableServer::POA_ptr supplier_poa,
+ PortableServer::POA_ptr consumer_poa)
+{
+ this->client_pair_.init (experiment_id,
+ base_event_type,
+ event_type_range,
+ iterations,
+ workload_in_usecs,
+ gsf,
+ supplier_poa,
+ consumer_poa);
+ this->loopback_pair_.init (experiment_id, base_event_type,
+ supplier_poa, consumer_poa);
+}
+
+void
+Client_Group::connect (RtecEventChannelAdmin::EventChannel_ptr ec
+ ACE_ENV_ARG_DECL)
+{
+ this->client_pair_.connect (ec ACE_ENV_ARG_PARAMETER);
+ Auto_Disconnect<Client_Pair> client_pair_disconnect (&this->client_pair_);
+
+ this->loopback_pair_.connect (ec ACE_ENV_ARG_PARAMETER);
+ ACE_CHECK;
+ Auto_Disconnect<Loopback_Pair> loopback_pair_disconnect (&this->loopback_pair_);
+
+ loopback_pair_disconnect.release ();
+ client_pair_disconnect.release ();
+}
+
+void
+Client_Group::disconnect (ACE_ENV_SINGLE_ARG_DECL_NOT_USED)
+{
+ Auto_Disconnect<Client_Pair> client_pair_disconnect (&this->client_pair_);
+ Auto_Disconnect<Loopback_Pair> loopback_pair_disconnect (&this->loopback_pair_);
+}