]> SALOME platform Git repositories - tools/yacsgen.git/commitdiff
Salome HOME
Sessionless mode for exe components. EMC2P_V_1_3_5-rc1 EMC2P_V_1_3_5-rc2 EMC2P_V_1_3_5-rc3
authorOvidiu Mircescu <ovidiu.mircescu@edf.fr>
Mon, 20 Dec 2021 15:41:23 +0000 (16:41 +0100)
committerOvidiu Mircescu <ovidiu.mircescu@edf.fr>
Mon, 20 Dec 2021 15:41:23 +0000 (16:41 +0100)
module_generator/cpp_tmpl.py

index d6d3a41739df27578a47505af669dff2656f5fe1..f3438f72241a35e551b23891a65dda63dfae3818 100644 (file)
@@ -31,6 +31,7 @@ cxxCompo="""
 #include <CalciumException.hxx>
 ${CalciumInterface}
 #include <signal.h>
+#include <SALOME_Embedded_NamingService_Client.hxx>
 #include <SALOME_NamingService.hxx>
 #include <Utils_SALOME_Exception.hxx>
 #include <pthread.h>
@@ -230,7 +231,6 @@ extern "C"
     CORBA::Object_var obj;
     try
       {
-        SALOME_NamingService * salomens = new SALOME_NamingService(orb);
         obj = orb->resolve_initial_references("RootPOA");
         PortableServer::POA_var  poa = PortableServer::POA::_narrow(obj);
         PortableServer::POAManager_var pman = poa->the_POAManager();
@@ -243,7 +243,18 @@ extern "C"
         obj=myEngine->POA_${module}_ORB::${component}::_this();
         Engines::EngineComponent_var component = Engines::EngineComponent::_narrow(obj);
         string component_registerName = containerName + "/" + instanceName;
-        salomens->Register(component,component_registerName.c_str());
+        Engines::EmbeddedNamingService_var embedded_NS = container->get_embedded_NS_if_ssl();
+        if( CORBA::is_nil(embedded_NS))
+        {
+          // Use the salome session to get the naming service
+          SALOME_NamingService salome_NS(orb);
+          salome_NS.Register(component,component_registerName.c_str());
+        }
+        else
+        {
+          SALOME_Embedded_NamingService_Client ns_client(embedded_NS);
+          ns_client.Register(component,component_registerName.c_str());
+        }
         orb->run();
         orb->destroy();
       }