summaryrefslogtreecommitdiff
path: root/TAO/tao/PortableServer/RequestProcessingStrategyAOMOnly.h
diff options
context:
space:
mode:
Diffstat (limited to 'TAO/tao/PortableServer/RequestProcessingStrategyAOMOnly.h')
-rw-r--r--TAO/tao/PortableServer/RequestProcessingStrategyAOMOnly.h107
1 files changed, 107 insertions, 0 deletions
diff --git a/TAO/tao/PortableServer/RequestProcessingStrategyAOMOnly.h b/TAO/tao/PortableServer/RequestProcessingStrategyAOMOnly.h
new file mode 100644
index 00000000000..96d79641ce9
--- /dev/null
+++ b/TAO/tao/PortableServer/RequestProcessingStrategyAOMOnly.h
@@ -0,0 +1,107 @@
+// -*- C++ -*-
+
+//=============================================================================
+/**
+ * @file RequestProcessingStrategyAOMOnly.h
+ *
+ * $Id$
+ *
+ * @author Johnny Willemsen <jwillemsen@remedy.nl>
+ */
+//=============================================================================
+
+#ifndef TAO_REQUESTPROCESSINGSTRATEGYAOMONLY_H
+#define TAO_REQUESTPROCESSINGSTRATEGYAOMONLY_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_Location.h"
+#include "tao/PortableServer/PortableServer.h"
+
+TAO_BEGIN_VERSIONED_NAMESPACE_DECL
+
+namespace TAO
+{
+ namespace Portable_Server
+ {
+ /**
+ * @class RequestProcessingStrategyAOMOnly
+ *
+ * Request Processing Strategy which only uses the Active Object Map (AOM)
+ */
+ class RequestProcessingStrategyAOMOnly
+ : public RequestProcessingStrategy
+ {
+ public:
+ RequestProcessingStrategyAOMOnly (void);
+
+#if (TAO_HAS_MINIMUM_POA == 0)
+
+ PortableServer::ServantManager_ptr
+ get_servant_manager (void);
+
+ void
+ set_servant_manager (PortableServer::ServantManager_ptr imgr
+ );
+
+ void
+ set_servant (PortableServer::Servant servant
+ );
+
+#endif /* TAO_HAS_MINIMUM_POA == 0 */
+
+ PortableServer::Servant
+ get_servant (void);
+
+ 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;
+ };
+ }
+}
+
+TAO_END_VERSIONED_NAMESPACE_DECL
+
+#include /**/ "ace/post.h"
+#endif /* TAO_REQUESTPROCESSINGSTRATEGYAOMONLY_H */