diff options
author | huangming <huangming@ae88bc3d-4319-0410-8dbf-d08b4c9d3795> | 2003-10-15 18:07:27 +0000 |
---|---|---|
committer | huangming <huangming@ae88bc3d-4319-0410-8dbf-d08b4c9d3795> | 2003-10-15 18:07:27 +0000 |
commit | 662c4caae556d3e18e5ae5005408cd0160bc3a63 (patch) | |
tree | 61542bcbc54047e055552f487ce0ba38f4212ebe /TAO/orbsvcs/orbsvcs/FtRtEvent/EventChannel/FTEC_ProxyConsumer.h | |
parent | 428f7766fbdf80c24552dabbd4b49f241a1d055b (diff) | |
download | ATCD-662c4caae556d3e18e5ae5005408cd0160bc3a63.tar.gz |
Wed Oct 15 13:00:24 2003 Huang-Ming Huang <hh1@cse.wustl.edu>
Diffstat (limited to 'TAO/orbsvcs/orbsvcs/FtRtEvent/EventChannel/FTEC_ProxyConsumer.h')
-rw-r--r-- | TAO/orbsvcs/orbsvcs/FtRtEvent/EventChannel/FTEC_ProxyConsumer.h | 62 |
1 files changed, 62 insertions, 0 deletions
diff --git a/TAO/orbsvcs/orbsvcs/FtRtEvent/EventChannel/FTEC_ProxyConsumer.h b/TAO/orbsvcs/orbsvcs/FtRtEvent/EventChannel/FTEC_ProxyConsumer.h new file mode 100644 index 00000000000..63a3c49548d --- /dev/null +++ b/TAO/orbsvcs/orbsvcs/FtRtEvent/EventChannel/FTEC_ProxyConsumer.h @@ -0,0 +1,62 @@ +// -*- C++ -*- + +//============================================================================= +/** + * @file FTEC_ProxyPushConsumer.h + * + * $Id$ + * + * @author Huang-Ming Huang <hh1@cse.wustl.edu> + */ +//============================================================================= +#ifndef TAO_FTEC_PROXYCONSUMER_H +#define TAO_FTEC_PROXYCONSUMER_H + +#include "orbsvcs/Event/EC_Default_ProxyConsumer.h" +#include "ace/SString.h" +#include "orbsvcs/FtRtecEventChannelAdminC.h" +#include "Request_Context_Repository.h" + +#if !defined (ACE_LACKS_PRAGMA_ONCE) +# pragma once +#endif /* ACE_LACKS_PRAGMA_ONCE */ + +class TAO_FTEC_ProxyPushConsumer : public TAO_EC_Default_ProxyPushConsumer +{ + typedef TAO_EC_Default_ProxyPushConsumer Inherited; +public: + typedef RtecEventChannelAdmin::ProxyPushConsumer Interface; + typedef FtRtecEventChannelAdmin::ProxyPushConsumerStat State; + typedef POA_RtecEventChannelAdmin::ProxyPushConsumer_ptr Skeleton; + + TAO_FTEC_ProxyPushConsumer (TAO_EC_Event_Channel_Base* event_channel); + + virtual void activate ( + RtecEventChannelAdmin::ProxyPushConsumer_ptr &proxy + ACE_ENV_ARG_DECL) + ACE_THROW_SPEC ((CORBA::SystemException)); + + + // = The RtecEventChannelAdmin::ProxyPushConsumer methods... + virtual void connect_push_supplier ( + RtecEventComm::PushSupplier_ptr push_supplier, + const RtecEventChannelAdmin::SupplierQOS& qos + ACE_ENV_ARG_DECL_NOT_USED) + ACE_THROW_SPEC ((CORBA::SystemException, + RtecEventChannelAdmin::AlreadyConnected)); + virtual void disconnect_push_consumer (ACE_ENV_SINGLE_ARG_DECL_NOT_USED) + ACE_THROW_SPEC ((CORBA::SystemException)); + + const PortableServer::ObjectId& id() const; + void get_state(FtRtecEventChannelAdmin::ProxyPushConsumerStat& state); + void set_state(const FtRtecEventChannelAdmin::ProxyPushConsumerStat& state); + + typedef void (FtRtecEventChannelAdmin::EventChannelFacade::*RollbackOperation) + (const FtRtecEventChannelAdmin::ObjectId& ACE_ENV_ARG_DECL_WITH_DEFAULTS); + + static const RollbackOperation rollback_obtain; +private: + PortableServer::ObjectId_var object_id_; +}; + +#endif |