diff options
Diffstat (limited to 'TAO/tao/CSD_Framework/CSD_Object_Adapter_Factory.cpp')
-rw-r--r-- | TAO/tao/CSD_Framework/CSD_Object_Adapter_Factory.cpp | 96 |
1 files changed, 96 insertions, 0 deletions
diff --git a/TAO/tao/CSD_Framework/CSD_Object_Adapter_Factory.cpp b/TAO/tao/CSD_Framework/CSD_Object_Adapter_Factory.cpp new file mode 100644 index 00000000000..fa06817ec2c --- /dev/null +++ b/TAO/tao/CSD_Framework/CSD_Object_Adapter_Factory.cpp @@ -0,0 +1,96 @@ +// $Id$ + +#include "tao/CSD_Framework/CSD_Object_Adapter_Factory.h" +#include "tao/CSD_Framework/CSD_Strategy_Repository.h" +#include "tao/CSD_Framework/CSD_Object_Adapter.h" +#include "tao/CSD_Framework/CSD_ORBInitializer.h" +#include "tao/CSD_Framework/CSD_Default_Servant_Dispatcher.h" +#include "tao/ORB_Core.h" +#include "tao/ORBInitializer_Registry.h" +#include "ace/Dynamic_Service.h" + +ACE_RCSID (CSD_Framework, + CSD_Object_Adapter_Factory, + "$Id$") + + +TAO_BEGIN_VERSIONED_NAMESPACE_DECL + +TAO_CSD_Object_Adapter_Factory::TAO_CSD_Object_Adapter_Factory (void) +{ +} + +TAO_Adapter* +TAO_CSD_Object_Adapter_Factory::create (TAO_ORB_Core *oc) +{ + // Create the CSD object adapter. + TAO_CSD_Object_Adapter *object_adapter = 0; + ACE_NEW_RETURN (object_adapter, + TAO_CSD_Object_Adapter (oc->server_factory ()-> + active_object_map_creation_parameters (), + *oc), + 0); + + // Create and register the CSD servant dispatcher. + TAO_CSD_Default_Servant_Dispatcher * csd_servant_dispatcher = 0; + ACE_NEW_RETURN (csd_servant_dispatcher, + TAO_CSD_Default_Servant_Dispatcher, + 0); + object_adapter->servant_dispatcher (csd_servant_dispatcher); + + return object_adapter; +} + +int +TAO_CSD_Object_Adapter_Factory::init (int /* argc */, + ACE_TCHAR* /* argv */ []) +{ + TAO_CSD_Strategy_Repository *repo = + ACE_Dynamic_Service<TAO_CSD_Strategy_Repository>::instance ("TAO_CSD_Strategy_Repository"); + + if (repo != 0) + repo->init(0,0); + + ACE_DECLARE_NEW_CORBA_ENV; + ACE_TRY + { + /// Register the Messaging ORBInitializer. + PortableInterceptor::ORBInitializer_ptr temp_orb_initializer = + PortableInterceptor::ORBInitializer::_nil (); + + ACE_NEW_THROW_EX (temp_orb_initializer, + TAO_CSD_ORBInitializer, + CORBA::NO_MEMORY ( + CORBA::SystemException::_tao_minor_code ( + TAO::VMCID, + ENOMEM), + CORBA::COMPLETED_NO)); + ACE_TRY_CHECK; + + PortableInterceptor::ORBInitializer_var orb_initializer = + temp_orb_initializer; + + PortableInterceptor::register_orb_initializer (orb_initializer.in () + ACE_ENV_ARG_PARAMETER); + ACE_TRY_CHECK; + } + ACE_CATCHANY + { + ACE_PRINT_EXCEPTION (ACE_ANY_EXCEPTION, + "Caught exception:"); + return -1; + } + ACE_ENDTRY; + + return 0; +} + +TAO_END_VERSIONED_NAMESPACE_DECL + +ACE_FACTORY_DEFINE (TAO_CSD_FW, TAO_CSD_Object_Adapter_Factory) +ACE_STATIC_SVC_DEFINE (TAO_CSD_Object_Adapter_Factory, + ACE_TEXT ("TAO_CSD_Object_Adapter_Factory"), + ACE_SVC_OBJ_T, + &ACE_SVC_NAME (TAO_CSD_Object_Adapter_Factory), + ACE_Service_Type::DELETE_THIS | ACE_Service_Type::DELETE_OBJ, + 0) |