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