diff options
author | Johnny Willemsen <jwillemsen@remedy.nl> | 2005-02-18 09:07:14 +0000 |
---|---|---|
committer | Johnny Willemsen <jwillemsen@remedy.nl> | 2005-02-18 09:07:14 +0000 |
commit | 6505e0e66092f5c22ab656946a800138897ddf4c (patch) | |
tree | 91ba7fc4584511f31379702bdcf543da966f7f78 /TAO/tao/PortableServer/RequestProcessingStrategyServantLocator.h | |
parent | 088f6e83bd2ffc10f050df15282f9795ddbb02f6 (diff) | |
download | ATCD-6505e0e66092f5c22ab656946a800138897ddf4c.tar.gz |
ChangeLogTag: Fri Feb 18 17:04:12 UTC 2005 Johnny Willemsen <jwillemsen@remedy.nl>
Diffstat (limited to 'TAO/tao/PortableServer/RequestProcessingStrategyServantLocator.h')
-rw-r--r-- | TAO/tao/PortableServer/RequestProcessingStrategyServantLocator.h | 95 |
1 files changed, 95 insertions, 0 deletions
diff --git a/TAO/tao/PortableServer/RequestProcessingStrategyServantLocator.h b/TAO/tao/PortableServer/RequestProcessingStrategyServantLocator.h new file mode 100644 index 00000000000..6c9fd9c7439 --- /dev/null +++ b/TAO/tao/PortableServer/RequestProcessingStrategyServantLocator.h @@ -0,0 +1,95 @@ +// -*- C++ -*- + +//============================================================================= +/** + * @file RequestProcessingStrategyServantLocator.h + * + * $Id$ + * + * @author Johnny Willemsen <jwillemsen@remedy.nl> + */ +//============================================================================= + +#ifndef TAO_REQUESTPROCESSINGSTRATEGYSERVANTLOCATOR_H +#define TAO_REQUESTPROCESSINGSTRATEGYSERVANTLOCATOR_H +#include /**/ "ace/pre.h" + +#include "portableserver_export.h" + +#if !defined (ACE_LACKS_PRAGMA_ONCE) +# pragma once +#endif /* ACE_LACKS_PRAGMA_ONCE */ + +#include "RequestProcessingStrategyServantManager.h" +#include "Servant_Location.h" +#include "PortableServer.h" + +#if (TAO_HAS_MINIMUM_POA == 0) + +namespace PortableServer +{ + class ServantLocator; + + typedef ServantLocator *ServantLocator_ptr; + typedef TAO_Objref_Var_T<ServantLocator> ServantLocator_var; +} + +namespace TAO +{ + namespace Portable_Server + { + class TAO_PortableServer_Export RequestProcessingStrategyServantLocator + : public virtual RequestProcessingStrategyServantManager + { + public: + RequestProcessingStrategyServantLocator (void); + + virtual ~RequestProcessingStrategyServantLocator (void); + + virtual void strategy_cleanup(ACE_ENV_SINGLE_ARG_DECL); + + PortableServer::ServantManager_ptr get_servant_manager ( + ACE_ENV_SINGLE_ARG_DECL) + ACE_THROW_SPEC ((CORBA::SystemException, + PortableServer::POA::WrongPolicy)); + + void set_servant_manager ( + PortableServer::ServantManager_ptr imgr + ACE_ENV_ARG_DECL) + ACE_THROW_SPEC ((CORBA::SystemException, + PortableServer::POA::WrongPolicy)); + + virtual TAO_SERVANT_LOCATION locate_servant ( + const PortableServer::ObjectId &system_id, + PortableServer::Servant &servant + ACE_ENV_ARG_DECL); + + virtual void post_invoke_servant_cleanup( + const PortableServer::ObjectId &system_id, + const TAO::Portable_Server::Servant_Upcall &servant_upcall); + + 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, + int &wait_occurred_restart_call + ACE_ENV_ARG_DECL); + + virtual void cleanup_servant ( + PortableServer::Servant servant, + const PortableServer::ObjectId &user_id + ACE_ENV_ARG_DECL); + + virtual void etherealize_objects (CORBA::Boolean etherealize_objects); + + private: + PortableServer::ServantLocator_var servant_locator_; + }; + } +} + +#endif /* TAO_HAS_MINIMUM_POA == 0 */ + +#include /**/ "ace/post.h" +#endif /* TAO_REQUESTPROCESSINGSTRATEGYSERVANTLOCATOR_H */ |