diff options
Diffstat (limited to 'TAO/tao/PortableServer/RequestProcessingStrategyServantActivatorFI.cpp')
-rw-r--r-- | TAO/tao/PortableServer/RequestProcessingStrategyServantActivatorFI.cpp | 87 |
1 files changed, 87 insertions, 0 deletions
diff --git a/TAO/tao/PortableServer/RequestProcessingStrategyServantActivatorFI.cpp b/TAO/tao/PortableServer/RequestProcessingStrategyServantActivatorFI.cpp new file mode 100644 index 00000000000..00f26e37559 --- /dev/null +++ b/TAO/tao/PortableServer/RequestProcessingStrategyServantActivatorFI.cpp @@ -0,0 +1,87 @@ +// $Id$ + +#include "tao/orbconf.h" + +ACE_RCSID (PortableServer, + RequestProcessingStrategyServantActivatorFactoryImpl, + "$Id$") + +#if (TAO_HAS_MINIMUM_POA == 0) && !defined (CORBA_E_COMPACT) && !defined (CORBA_E_MICRO) + +#include "tao/PortableServer/RequestProcessingStrategyServantActivatorFI.h" +#include "tao/PortableServer/RequestProcessingStrategy.h" +#include "tao/PortableServer/RequestProcessingStrategyServantActivator.h" +#include "ace/Dynamic_Service.h" +#include "ace/Log_Msg.h" + +TAO_BEGIN_VERSIONED_NAMESPACE_DECL + +namespace TAO +{ + namespace Portable_Server + { + RequestProcessingStrategy* + RequestProcessingStrategyServantActivatorFactoryImpl::create ( + ::PortableServer::RequestProcessingPolicyValue value, + ::PortableServer::ServantRetentionPolicyValue srvalue) + { + RequestProcessingStrategy* strategy = 0; + + switch (value) + { + case ::PortableServer::USE_SERVANT_MANAGER : + { + switch (srvalue) + { + case ::PortableServer::RETAIN : + { + ACE_NEW_RETURN (strategy, RequestProcessingStrategyServantActivator, 0); + break; + } + case ::PortableServer::NON_RETAIN : + { + ACE_ERROR ((LM_ERROR, "Incorrect type in RequestProcessingStrategyServantActivatorFactoryImpl")); + break; + } + } + break; + } + default : + { + ACE_ERROR ((LM_ERROR, "Incorrect type in RequestProcessingStrategyServantActivatorFactoryImpl")); + break; + } + } + + return strategy; + } + + void + RequestProcessingStrategyServantActivatorFactoryImpl::destroy ( + RequestProcessingStrategy *strategy + ) + { + strategy->strategy_cleanup (); + + delete strategy; + } + } +} + +TAO_END_VERSIONED_NAMESPACE_DECL + +ACE_STATIC_SVC_DEFINE ( + RequestProcessingStrategyServantActivatorFactoryImpl, + ACE_TEXT ("RequestProcessingStrategyServantActivatorFactory"), + ACE_SVC_OBJ_T, + &ACE_SVC_NAME (RequestProcessingStrategyServantActivatorFactoryImpl), + ACE_Service_Type::DELETE_THIS | ACE_Service_Type::DELETE_OBJ, + 0) + +ACE_FACTORY_NAMESPACE_DEFINE ( + ACE_Local_Service, + RequestProcessingStrategyServantActivatorFactoryImpl, + TAO::Portable_Server::RequestProcessingStrategyServantActivatorFactoryImpl) + + +#endif /* TAO_HAS_MINIMUM_POA == 0 */ |