Salome HOME
Merge branch 'master' of https://codev-tuleap.cea.fr/plugins/git/salome/gui
authorPaul RASCLE <paul.rascle@edf.fr>
Mon, 19 Mar 2018 09:05:15 +0000 (10:05 +0100)
committerPaul RASCLE <paul.rascle@edf.fr>
Mon, 19 Mar 2018 09:05:15 +0000 (10:05 +0100)
src/Session/Session_ServerThread.cxx

index ee1c1f6815f38c0aeaba02ad27afcd449436b96c..d98a39e468550cbc30bfc77c77b9bf5dabb59275 100755 (executable)
@@ -260,9 +260,19 @@ void Session_ServerThread::ActivateRegistry(int argc,
     RegistryService *ptrRegistry = new RegistryService;
     ptrRegistry->SessionName( ptrSessionName );
     ptrRegistry->SetOrb(_orb);
-    varComponents = ptrRegistry->_this();
-    ptrRegistry->_remove_ref(); //let poa manage registry service deletion
-    // The RegistryService must not already exist.
+    //
+    CORBA::PolicyList policies;
+    policies.length(1);
+    PortableServer::ThreadPolicy_var threadPol(_root_poa->create_thread_policy(PortableServer::SINGLE_THREAD_MODEL));
+    policies[0]=PortableServer::ThreadPolicy::_duplicate(threadPol);
+    PortableServer::POAManager_var manager = _root_poa->the_POAManager();
+    PortableServer::POA_var poa2(_root_poa->create_POA("SingleThreadPOA4RegistryEmbedded",manager,policies));
+    threadPol->destroy();
+    //
+    PortableServer::ObjectId_var id(poa2->activate_object(ptrRegistry));
+    CORBA::Object_var pipo=poa2->id_to_reference(id);
+    varComponents = Registry::Components::_narrow(pipo) ;
+    ptrRegistry->_remove_ref(); //let poa manage registryservice deletion
     
     try {
       CORBA::Object_var pipo = _NS->Resolve( registryName );