diff options
Diffstat (limited to 'TAO/orbsvcs/orbsvcs/Notify/Sequence/SequenceProxyPushSupplier.cpp')
-rw-r--r-- | TAO/orbsvcs/orbsvcs/Notify/Sequence/SequenceProxyPushSupplier.cpp | 84 |
1 files changed, 84 insertions, 0 deletions
diff --git a/TAO/orbsvcs/orbsvcs/Notify/Sequence/SequenceProxyPushSupplier.cpp b/TAO/orbsvcs/orbsvcs/Notify/Sequence/SequenceProxyPushSupplier.cpp new file mode 100644 index 00000000000..f92380f1260 --- /dev/null +++ b/TAO/orbsvcs/orbsvcs/Notify/Sequence/SequenceProxyPushSupplier.cpp @@ -0,0 +1,84 @@ +// $Id$ + +#include "SequenceProxyPushSupplier.h" + +#if ! defined (__ACE_INLINE__) +#include "SequenceProxyPushSupplier.inl" +#endif /* __ACE_INLINE__ */ + +ACE_RCSID(Notify, TAO_NS_SequenceProxyPushSupplier, "$id$") + +#include "tao/debug.h" +#include "SequencePushConsumer.h" +#include "../Proxy.h" +#include "../Admin.h" +#include "../EventChannel.h" +#include "../EventChannelFactory.h" +#include "../Notify_Service.h" + + +TAO_NS_SequenceProxyPushSupplier::TAO_NS_SequenceProxyPushSupplier (void) +{ +} + +TAO_NS_SequenceProxyPushSupplier::~TAO_NS_SequenceProxyPushSupplier () +{ +} + +void +TAO_NS_SequenceProxyPushSupplier::destroy (ACE_ENV_SINGLE_ARG_DECL) +{ + if (TAO_debug_level > 0) + ACE_DEBUG ((LM_DEBUG, "In TAO_NS_SequenceProxyPushConsumer::destroy \n")); + + this->inherited::destroy (this ACE_ENV_ARG_PARAMETER); +} + +void +TAO_NS_SequenceProxyPushSupplier::release (void) +{ + if (this->consumer_) + this->consumer_->release (); + + delete this; + //@@ inform factory +} + +void +TAO_NS_SequenceProxyPushSupplier::connect_sequence_push_consumer (CosNotifyComm::SequencePushConsumer_ptr push_consumer ACE_ENV_ARG_DECL) + ACE_THROW_SPEC (( + CORBA::SystemException + , CosEventChannelAdmin::AlreadyConnected + , CosEventChannelAdmin::TypeError + )) +{ + // Convert Consumer to Base Type + TAO_NS_SequencePushConsumer* consumer; + ACE_NEW_THROW_EX (consumer, + TAO_NS_SequencePushConsumer (this), + CORBA::NO_MEMORY ()); + + consumer->init (push_consumer, this->admin_properties_ ACE_ENV_ARG_PARAMETER); + ACE_CHECK; + + this->connect (consumer ACE_ENV_ARG_PARAMETER); +} + +void +TAO_NS_SequenceProxyPushSupplier::disconnect_sequence_push_supplier (ACE_ENV_SINGLE_ARG_DECL) + ACE_THROW_SPEC (( + CORBA::SystemException + )) + +{ + this->destroy (ACE_ENV_SINGLE_ARG_PARAMETER); +} + +CosNotifyChannelAdmin::ProxyType +TAO_NS_SequenceProxyPushSupplier::MyType (ACE_ENV_SINGLE_ARG_DECL_NOT_USED) + ACE_THROW_SPEC (( + CORBA::SystemException + )) +{ + return CosNotifyChannelAdmin::PUSH_SEQUENCE; +} |