summaryrefslogtreecommitdiff
path: root/TAO/tao/PortableServer/RequestProcessingStrategyDefaultServant.h
diff options
context:
space:
mode:
Diffstat (limited to 'TAO/tao/PortableServer/RequestProcessingStrategyDefaultServant.h')
-rw-r--r--TAO/tao/PortableServer/RequestProcessingStrategyDefaultServant.h109
1 files changed, 109 insertions, 0 deletions
diff --git a/TAO/tao/PortableServer/RequestProcessingStrategyDefaultServant.h b/TAO/tao/PortableServer/RequestProcessingStrategyDefaultServant.h
new file mode 100644
index 00000000000..f536a91a970
--- /dev/null
+++ b/TAO/tao/PortableServer/RequestProcessingStrategyDefaultServant.h
@@ -0,0 +1,109 @@
+// -*- C++ -*-
+
+//=============================================================================
+/**
+ * @file RequestProcessingStrategyDefaultServant.h
+ *
+ * $Id$
+ *
+ * @author Johnny Willemsen <jwillemsen@remedy.nl>
+ */
+//=============================================================================
+
+#ifndef TAO_REQUESTPROCESSINGSTRATEGYDEFAULTSERVANT_H
+#define TAO_REQUESTPROCESSINGSTRATEGYDEFAULTSERVANT_H
+#include /**/ "ace/pre.h"
+
+#include "tao/PortableServer/RequestProcessingStrategy.h"
+
+#if !defined (ACE_LACKS_PRAGMA_ONCE)
+# pragma once
+#endif /* ACE_LACKS_PRAGMA_ONCE */
+
+#include "tao/PortableServer/Servant_Base.h"
+
+#include "tao/PortableServer/Servant_Location.h"
+#include "tao/PortableServer/PortableServer.h"
+
+#if (TAO_HAS_MINIMUM_POA == 0) && !defined (CORBA_E_COMPACT) && !defined (CORBA_E_MICRO)
+
+TAO_BEGIN_VERSIONED_NAMESPACE_DECL
+
+class TAO_Root_POA;
+
+namespace TAO
+{
+ namespace Portable_Server
+ {
+ class RequestProcessingStrategyDefaultServant
+ : public RequestProcessingStrategy
+ {
+ public:
+ RequestProcessingStrategyDefaultServant (void);
+
+ virtual void strategy_cleanup(void);
+
+ PortableServer::ServantManager_ptr
+ get_servant_manager (void);
+
+ void set_servant_manager (
+ PortableServer::ServantManager_ptr imgr
+ );
+
+ PortableServer::Servant get_servant (void);
+
+ void set_servant (
+ PortableServer::Servant servant
+ );
+
+ 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 PortableServer::Servant system_id_to_servant (
+ const PortableServer::ObjectId &system_id
+ );
+
+ virtual PortableServer::Servant id_to_servant (
+ const PortableServer::ObjectId &id
+ );
+
+ virtual void cleanup_servant (
+ PortableServer::Servant servant,
+ const PortableServer::ObjectId &user_id
+ );
+
+ virtual void etherealize_objects (CORBA::Boolean etherealize_objects);
+
+ virtual PortableServer::ObjectId *servant_to_id (
+ PortableServer::Servant servant
+ );
+
+ virtual void post_invoke_servant_cleanup(
+ const PortableServer::ObjectId &system_id,
+ const TAO::Portable_Server::Servant_Upcall &servant_upcall);
+
+ virtual ::PortableServer::RequestProcessingPolicyValue type() const;
+
+ private:
+ PortableServer::ServantBase_var default_servant_;
+ };
+
+ }
+}
+
+TAO_END_VERSIONED_NAMESPACE_DECL
+
+#endif /* TAO_HAS_MINIMUM_POA == 0 */
+
+#include /**/ "ace/post.h"
+#endif /* TAO_REQUESTPROCESSINGSTRATEGYDEFAULTSERVANT_H */