diff options
Diffstat (limited to 'trunk/TAO/orbsvcs/orbsvcs/Notify/Builder.h')
-rw-r--r-- | trunk/TAO/orbsvcs/orbsvcs/Notify/Builder.h | 175 |
1 files changed, 175 insertions, 0 deletions
diff --git a/trunk/TAO/orbsvcs/orbsvcs/Notify/Builder.h b/trunk/TAO/orbsvcs/orbsvcs/Notify/Builder.h new file mode 100644 index 00000000000..7ed2c219c65 --- /dev/null +++ b/trunk/TAO/orbsvcs/orbsvcs/Notify/Builder.h @@ -0,0 +1,175 @@ +/* -*- C++ -*- */ +/** + * @file Builder.h + * + * $Id$ + * + * @author Pradeep Gore <pradeep@oomworks.com> + * + * + */ + +#ifndef TAO_Notify_BUILDER_H +#define TAO_Notify_BUILDER_H + +#include /**/ "ace/pre.h" + +#include "orbsvcs/Notify/notify_serv_export.h" + +#if !defined (ACE_LACKS_PRAGMA_ONCE) +# pragma once +#endif /* ACE_LACKS_PRAGMA_ONCE */ + +#include "orbsvcs/CosNotifyChannelAdminC.h" +#include "orbsvcs/NotifyExtC.h" + +#include "orbsvcs/Notify/AdminProperties.h" +#include "orbsvcs/Notify/Topology_Object.h" + +#include "tao/PortableServer/PortableServer.h" + +TAO_BEGIN_VERSIONED_NAMESPACE_DECL + +class TAO_Notify_EventChannelFactory; +class TAO_Notify_EventChannel; +class TAO_Notify_SupplierAdmin; +class TAO_Notify_ConsumerAdmin; +class TAO_Notify_ProxyConsumer; +class TAO_Notify_ProxySupplier; +class TAO_Notify_FilterFactory; +class TAO_Notify_Object; + +/** + * @class TAO_Notify_Builder + * + * @brief Helper class to create and activate CORBA objects. + * + */ +class TAO_Notify_Serv_Export TAO_Notify_Builder +{ +public: + TAO_Notify_Builder (void); + + virtual ~TAO_Notify_Builder (); + + ///= Factory Methods + + /// Build EventChannel Factory. + virtual CosNotifyChannelAdmin::EventChannelFactory_ptr + build_event_channel_factory (PortableServer::POA_ptr poa ACE_ENV_ARG_DECL); + + /// Build the Filter Factory. + virtual CosNotifyFilter::FilterFactory_ptr build_filter_factory ( + ACE_ENV_SINGLE_ARG_DECL + ); + + /// Build EventChannel. + virtual CosNotifyChannelAdmin::EventChannel_ptr + build_event_channel (TAO_Notify_EventChannelFactory* ecf + , const CosNotification::QoSProperties & initial_qos + , const CosNotification::AdminProperties & initial_admin + , CosNotifyChannelAdmin::ChannelID_out id + ACE_ENV_ARG_DECL); + + + virtual TAO_Notify_EventChannel * + build_event_channel (TAO_Notify_EventChannelFactory* ecf + , const CosNotifyChannelAdmin::ChannelID id + ACE_ENV_ARG_DECL); + + + /// Build ConsumerAdmin + virtual CosNotifyChannelAdmin::ConsumerAdmin_ptr + build_consumer_admin (TAO_Notify_EventChannel* ec + , CosNotifyChannelAdmin::InterFilterGroupOperator op + , CosNotifyChannelAdmin::AdminID_out id + ACE_ENV_ARG_DECL); + + /// Build ConsumerAdmin during topology restore + /// TODO: this returns a reference to the actual type + /// to accomodate loadable builder/factory there should + /// be an appropriate base class for it to return. + virtual TAO_Notify_ConsumerAdmin * + build_consumer_admin (TAO_Notify_EventChannel* ec + , const CosNotifyChannelAdmin::AdminID id //CORBA::Long id // note: an in parameter! + ACE_ENV_ARG_DECL); + + /// Build SupplierAdmin + virtual CosNotifyChannelAdmin::SupplierAdmin_ptr + build_supplier_admin (TAO_Notify_EventChannel * ec + , CosNotifyChannelAdmin::InterFilterGroupOperator op + , CosNotifyChannelAdmin::AdminID_out id + ACE_ENV_ARG_DECL); + + /// Build ConsumerAdmin during topology restore + /// TODO: this returns a reference to the actual type + /// to accomodate loadable builder/factory there should + /// be an appropriate base class for it to return. + virtual TAO_Notify_SupplierAdmin * + build_supplier_admin (TAO_Notify_EventChannel * ec + , const CosNotifyChannelAdmin::AdminID id //CORBA::Long id // note: an in parameter! + ACE_ENV_ARG_DECL); + + /// Build ProxyConsumer + virtual CosNotifyChannelAdmin::ProxyConsumer_ptr + build_proxy (TAO_Notify_SupplierAdmin* sa + , CosNotifyChannelAdmin::ClientType ctype + , CosNotifyChannelAdmin::ProxyID_out proxy_id + , const CosNotification::QoSProperties & initial_qos + ACE_ENV_ARG_DECL); + + /// Reload ProxyConsumer + virtual TAO_Notify_ProxyConsumer * + build_proxy (TAO_Notify_SupplierAdmin* sa + , CosNotifyChannelAdmin::ClientType ctype + , const CosNotifyChannelAdmin::ProxyID proxy_id + ACE_ENV_ARG_DECL); + + /// Build ProxySupplier. + virtual CosNotifyChannelAdmin::ProxySupplier_ptr + build_proxy (TAO_Notify_ConsumerAdmin* ca + , CosNotifyChannelAdmin::ClientType ctype + , CosNotifyChannelAdmin::ProxyID_out proxy_id + , const CosNotification::QoSProperties & initial_qos + ACE_ENV_ARG_DECL); + + /// Reload ProxySupplier. + virtual TAO_Notify_ProxySupplier * + build_proxy (TAO_Notify_ConsumerAdmin* ca + , CosNotifyChannelAdmin::ClientType ctype + , const CosNotifyChannelAdmin::ProxyID proxy_id + ACE_ENV_ARG_DECL); + + /// Build CosEC style ProxySupplier. + virtual CosEventChannelAdmin::ProxyPushSupplier_ptr + build_proxy (TAO_Notify_ConsumerAdmin* ca ACE_ENV_ARG_DECL); + + /// Build CosEC style ProxyConsumer. + virtual CosEventChannelAdmin::ProxyPushConsumer_ptr + build_proxy (TAO_Notify_SupplierAdmin* sa ACE_ENV_ARG_DECL); + + /// Apply Reactive concurrency. + virtual void apply_reactive_concurrency ( + TAO_Notify_Object& object ACE_ENV_ARG_DECL + ); + + /// Apply Thread Pools. + virtual void apply_thread_pool_concurrency ( + TAO_Notify_Object& object, + const NotifyExt::ThreadPoolParams& tp_params + ACE_ENV_ARG_DECL + ); + + /// Apply Thread Pools with Lanes. + virtual void apply_lane_concurrency ( + TAO_Notify_Object& object, + const NotifyExt::ThreadPoolLanesParams& tpl_params + ACE_ENV_ARG_DECL + ); +}; + +TAO_END_VERSIONED_NAMESPACE_DECL + +#include /**/ "ace/post.h" + +#endif /* TAO_Notify_BUILDER_H */ |