summaryrefslogtreecommitdiff
path: root/modules/CIAO/connectors/dds4ccm/impl/ndds/DDS_StateListen_T.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'modules/CIAO/connectors/dds4ccm/impl/ndds/DDS_StateListen_T.cpp')
-rw-r--r--modules/CIAO/connectors/dds4ccm/impl/ndds/DDS_StateListen_T.cpp165
1 files changed, 165 insertions, 0 deletions
diff --git a/modules/CIAO/connectors/dds4ccm/impl/ndds/DDS_StateListen_T.cpp b/modules/CIAO/connectors/dds4ccm/impl/ndds/DDS_StateListen_T.cpp
new file mode 100644
index 00000000000..39161b25cd5
--- /dev/null
+++ b/modules/CIAO/connectors/dds4ccm/impl/ndds/DDS_StateListen_T.cpp
@@ -0,0 +1,165 @@
+// -*- C++ -*-
+// $Id$
+
+#include "dds4ccm/impl/ndds/DataReaderStateListener_T.h"
+#include "dds4ccm/impl/ndds/Reader_T.h"
+#include "dds4ccm/impl/ndds/StateListenerControl_T.h"
+#include "dds4ccm/impl/ndds/PortStatusListener_T.h"
+
+#include "ciao/Logger/Log_Macros.h"
+
+template <typename DDS_TYPE, typename CCM_TYPE>
+DDS_StateListen_T<DDS_TYPE, CCM_TYPE>::DDS_StateListen_T (void) :
+ data_control_ (new CCM_DDS_StateListenerControl_T
+ < ::CCM_DDS::CCM_StateListenerControl> ())
+{
+}
+
+template <typename DDS_TYPE, typename CCM_TYPE>
+DDS_StateListen_T<DDS_TYPE, CCM_TYPE>::~DDS_StateListen_T (void)
+{
+}
+
+template <typename DDS_TYPE, typename CCM_TYPE>
+void
+DDS_StateListen_T<DDS_TYPE, CCM_TYPE>::configuration_complete (
+ ::DDS::Topic_ptr topic,
+ ::DDS::Subscriber_ptr subscriber,
+ const char* library_name,
+ const char* profile_name)
+{
+ CIAO_TRACE ("DDS_StateListen_T<DDS_TYPE, CCM_TYPE>::configuration_complete");
+
+ try
+ {
+ if (CORBA::is_nil (this->data_reader_.in ()))
+ {
+ ::DDS::DataReader_var reader;
+ if (library_name && profile_name)
+ {
+ reader = subscriber->create_datareader_with_profile (
+ topic,
+ library_name,
+ profile_name,
+ ::DDS::DataReaderListener::_nil (),
+ 0);
+ }
+ else
+ {
+ ::DDS::DataReaderQos drqos;
+ reader = subscriber->create_datareader (
+ topic,
+ drqos,
+ ::DDS::DataReaderListener::_nil (),
+ 0);
+ }
+ ::CIAO::DDS4CCM::RTI::RTI_DataReader_i *rd =
+ dynamic_cast < ::CIAO::DDS4CCM::RTI::RTI_DataReader_i *> (reader.in ());
+ this->rti_reader_.set_impl (rd->get_impl ());
+ this->data_reader_ = ::DDS::CCM_DataReader::_narrow (reader);
+ this->dds_read_.set_impl (this->data_reader_.in ());
+ }
+ }
+ catch (...)
+ {
+ CIAO_ERROR (1, (LM_EMERGENCY, "DDS_StateListen_T::configuration_complete: Caught unknown c++ exception.\n"));
+ throw CORBA::INTERNAL ();
+ }
+}
+
+template <typename DDS_TYPE, typename CCM_TYPE>
+void
+DDS_StateListen_T<DDS_TYPE, CCM_TYPE>::activate (
+ typename CCM_TYPE::statelistener_type::_ptr_type listener,
+ ::CCM_DDS::PortStatusListener_ptr status)
+{
+ CIAO_TRACE ("DDS_StateListen_T<DDS_TYPE, CCM_TYPE>::activate");
+
+ try
+ {
+ if (CORBA::is_nil (this->data_listener_.in ()))
+ {
+ this->data_listener_ = new ::CIAO::DDS4CCM::RTI::DataReaderStateListener_T
+ <DDS_TYPE, CCM_TYPE> (
+ listener,
+ status,
+ data_control_.in ());
+ }
+ this->rti_reader_.set_listener (
+ this->data_listener_.in (),
+ 0);
+ }
+ catch (...)
+ {
+ CIAO_ERROR (1, (LM_EMERGENCY, "DDS_StateListen_T::activate: Caught unknown c++ exception.\n"));
+ throw CORBA::INTERNAL ();
+ }
+}
+
+template <typename DDS_TYPE, typename CCM_TYPE>
+void
+DDS_StateListen_T<DDS_TYPE, CCM_TYPE>::passivate (void)
+{
+ CIAO_TRACE ("DDS_StateListen_T<DDS_TYPE, CCM_TYPE>::passivate");
+ try
+ {
+ this->rti_reader_.set_listener (
+ ::DDS::DataReaderListener::_nil (),
+ 0);
+ this->data_listener_ = ::DDS::DataReaderListener::_nil ();
+ }
+ catch (...)
+ {
+ CIAO_ERROR (1, (LM_EMERGENCY, "DDS_StateListen_T::passivate: Caught unknown c++ exception.\n"));
+ throw CORBA::INTERNAL ();
+ }
+}
+
+template <typename DDS_TYPE, typename CCM_TYPE>
+void
+DDS_StateListen_T<DDS_TYPE, CCM_TYPE>::remove (
+ ::DDS::Subscriber_ptr subscriber)
+{
+ CIAO_TRACE ("DDS_StateListen_T<DDS_TYPE, CCM_TYPE>::remove");
+ try
+ {
+ subscriber->delete_datareader (this->data_reader_.in ());
+ this->rti_reader_.set_impl (0);
+ this->data_reader_ = ::DDS::CCM_DataReader::_nil ();
+ this->dds_read_.set_impl (0);
+ }
+ catch (...)
+ {
+ CIAO_ERROR (1, (LM_EMERGENCY, "DDS_StateListen_T::remove: Caught unknown c++ exception.\n"));
+ throw CORBA::INTERNAL ();
+ }
+}
+
+template <typename DDS_TYPE, typename CCM_TYPE>
+typename CCM_TYPE::reader_type::_ptr_type
+DDS_StateListen_T<DDS_TYPE, CCM_TYPE>::get_data (void)
+{
+ CIAO_TRACE ("DDS_StateListen_T<DDS_TYPE, CCM_TYPE>::get_data");
+
+ return &this->dds_read_;
+}
+
+template <typename DDS_TYPE, typename CCM_TYPE>
+::DDS::CCM_DataReader_ptr
+DDS_StateListen_T<DDS_TYPE, CCM_TYPE>::get_dds_entity (void)
+{
+ CIAO_TRACE ("DDS_StateListen_T<DDS_TYPE, CCM_TYPE>::get_dds_entity");
+
+ return &this->rti_reader_;
+}
+
+template <typename DDS_TYPE, typename CCM_TYPE>
+::CCM_DDS::CCM_StateListenerControl_ptr
+DDS_StateListen_T<DDS_TYPE, CCM_TYPE>::get_data_control (void)
+{
+ CIAO_TRACE ("DDS_StateListen_T<DDS_TYPE, CCM_TYPE>::get_data_control");
+
+ return ::CCM_DDS::CCM_StateListenerControl::_duplicate (
+ this->data_control_.in ());
+}
+