diff options
Diffstat (limited to 'TAO/tao/PortableServer/RequestProcessingStrategyServantActivator.h')
-rw-r--r-- | TAO/tao/PortableServer/RequestProcessingStrategyServantActivator.h | 94 |
1 files changed, 94 insertions, 0 deletions
diff --git a/TAO/tao/PortableServer/RequestProcessingStrategyServantActivator.h b/TAO/tao/PortableServer/RequestProcessingStrategyServantActivator.h new file mode 100644 index 00000000000..7b4504180bf --- /dev/null +++ b/TAO/tao/PortableServer/RequestProcessingStrategyServantActivator.h @@ -0,0 +1,94 @@ +// -*- C++ -*- + +//============================================================================= +/** + * @file RequestProcessingStrategyServantActivator.h + * + * $Id$ + * + * @author Johnny Willemsen <jwillemsen@remedy.nl> + */ +//============================================================================= + +#ifndef TAO_REQUESTPROCESSINGSTRATEGYSERVANTACTIVATOR_H +#define TAO_REQUESTPROCESSINGSTRATEGYSERVANTACTIVATOR_H +#include /**/ "ace/pre.h" + +#include "tao/PortableServer/RequestProcessingStrategyServantManager.h" + +#if !defined (ACE_LACKS_PRAGMA_ONCE) +# pragma once +#endif /* ACE_LACKS_PRAGMA_ONCE */ + +#if (TAO_HAS_MINIMUM_POA == 0) && !defined (CORBA_E_COMPACT) && !defined (CORBA_E_MICRO) + +#include "tao/PortableServer/Servant_Location.h" +#include "tao/PortableServer/PortableServer.h" +#include "tao/PortableServer/ServantActivatorC.h" + +TAO_BEGIN_VERSIONED_NAMESPACE_DECL + +namespace TAO +{ + namespace Portable_Server + { + class RequestProcessingStrategyServantActivator + : public RequestProcessingStrategyServantManager + { + public: + RequestProcessingStrategyServantActivator (void); + + virtual void strategy_cleanup(void); + + PortableServer::ServantManager_ptr get_servant_manager (void); + + void set_servant_manager (PortableServer::ServantManager_ptr imgr + ); + + virtual TAO_SERVANT_LOCATION locate_servant ( + const PortableServer::ObjectId &system_id, + PortableServer::Servant &servant + ); + + virtual PortableServer::Servant locate_servant ( + const char *operation, + const PortableServer::ObjectId &system_id, + TAO::Portable_Server::Servant_Upcall &servant_upcall, + TAO::Portable_Server::POA_Current_Impl &poa_current_impl, + bool &wait_occurred_restart_call + ); + + virtual void cleanup_servant ( + PortableServer::Servant servant, + const PortableServer::ObjectId &user_id + ); + + virtual void etherealize_objects (CORBA::Boolean etherealize_objects); + + virtual void post_invoke_servant_cleanup( + const PortableServer::ObjectId &system_id, + const TAO::Portable_Server::Servant_Upcall &servant_upcall); + + private: + PortableServer::Servant incarnate_servant ( + const PortableServer::ObjectId& object_id + ); + + void etherealize_servant (const PortableServer::ObjectId& object_id, + PortableServer::Servant servant, + CORBA::Boolean cleanup_in_progress + ); + + private: + PortableServer::ServantActivator_var servant_activator_; + CORBA::Boolean etherealize_objects_; + }; + } +} + +TAO_END_VERSIONED_NAMESPACE_DECL + +#endif /* TAO_HAS_MINIMUM_POA == 0 */ + +#include /**/ "ace/post.h" +#endif /* TAO_REQUESTPROCESSINGSTRATEGYSERVANTACTIVATOR_H */ |