mirror of
https://git.salome-platform.org/gitpub/modules/geom.git
synced 2024-12-25 17:00:35 +05:00
Modif for salome gui without neither NS nor other servers.
This commit is contained in:
parent
064bf22985
commit
ee9734889c
@ -316,6 +316,7 @@ INSTALL(FILES ${_texture_files} DESTINATION ${SALOME_GEOM_INSTALL_RES_DATA}/text
|
|||||||
|
|
||||||
SALOME_CONFIGURE_FILE(GEOMCatalog.xml.in GEOMCatalog.xml INSTALL ${SALOME_GEOM_INSTALL_RES_DATA})
|
SALOME_CONFIGURE_FILE(GEOMCatalog.xml.in GEOMCatalog.xml INSTALL ${SALOME_GEOM_INSTALL_RES_DATA})
|
||||||
SALOME_CONFIGURE_FILE(SalomeApp.xml.in SalomeApp.xml INSTALL ${SALOME_GEOM_INSTALL_RES_DATA})
|
SALOME_CONFIGURE_FILE(SalomeApp.xml.in SalomeApp.xml INSTALL ${SALOME_GEOM_INSTALL_RES_DATA})
|
||||||
|
INSTALL(FILES ${CMAKE_CURRENT_BINARY_DIR}/SalomeApp.xml RENAME SalomeAppSL.xml DESTINATION ${SALOME_GEOM_INSTALL_RES_DATA})
|
||||||
SALOME_CONFIGURE_FILE(Plugin.in Plugin INSTALL ${SALOME_GEOM_INSTALL_RES_DATA})
|
SALOME_CONFIGURE_FILE(Plugin.in Plugin INSTALL ${SALOME_GEOM_INSTALL_RES_DATA})
|
||||||
|
|
||||||
|
|
||||||
|
@ -36,6 +36,7 @@ INCLUDE_DIRECTORIES(
|
|||||||
${PROJECT_SOURCE_DIR}/src/GEOMClient
|
${PROJECT_SOURCE_DIR}/src/GEOMClient
|
||||||
${PROJECT_SOURCE_DIR}/src/GEOMImpl
|
${PROJECT_SOURCE_DIR}/src/GEOMImpl
|
||||||
${PROJECT_SOURCE_DIR}/src/GEOMUtils
|
${PROJECT_SOURCE_DIR}/src/GEOMUtils
|
||||||
|
${PROJECT_SOURCE_DIR}/src/GEOM_I
|
||||||
${CMAKE_CURRENT_SOURCE_DIR}
|
${CMAKE_CURRENT_SOURCE_DIR}
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -55,6 +56,7 @@ SET(_link_LIBRARIES
|
|||||||
Material
|
Material
|
||||||
GEOMImpl
|
GEOMImpl
|
||||||
GEOMUtils
|
GEOMUtils
|
||||||
|
GEOMEngine
|
||||||
${KERNEL_SALOMELocalTrace}
|
${KERNEL_SALOMELocalTrace}
|
||||||
${KERNEL_SalomeDS}
|
${KERNEL_SalomeDS}
|
||||||
${KERNEL_SalomeDSClient}
|
${KERNEL_SalomeDSClient}
|
||||||
|
@ -41,6 +41,7 @@
|
|||||||
#include "GEOMUtils_XmlHandler.hxx"
|
#include "GEOMUtils_XmlHandler.hxx"
|
||||||
#include "GEOMGUI_AnnotationMgr.h"
|
#include "GEOMGUI_AnnotationMgr.h"
|
||||||
#include "GEOMGUI_TextTreeSelector.h"
|
#include "GEOMGUI_TextTreeSelector.h"
|
||||||
|
#include "GEOM_Component_Generator.hxx"
|
||||||
|
|
||||||
#include "GEOM_Actor.h"
|
#include "GEOM_Actor.h"
|
||||||
|
|
||||||
@ -87,6 +88,7 @@
|
|||||||
|
|
||||||
#include <SALOMEDSClient_ClientFactory.hxx>
|
#include <SALOMEDSClient_ClientFactory.hxx>
|
||||||
#include <SALOMEDSClient_IParameters.hxx>
|
#include <SALOMEDSClient_IParameters.hxx>
|
||||||
|
#include "SALOME_KernelServices.hxx"
|
||||||
|
|
||||||
#include <SALOMEDS_SObject.hxx>
|
#include <SALOMEDS_SObject.hxx>
|
||||||
|
|
||||||
@ -195,7 +197,7 @@ bool GeometryGUI::IsInGeomComponent( _PTR(SObject) sobject )
|
|||||||
//=======================================================================
|
//=======================================================================
|
||||||
SALOMEDS::Study_var GeometryGUI::getStudyServant()
|
SALOMEDS::Study_var GeometryGUI::getStudyServant()
|
||||||
{
|
{
|
||||||
SALOME_NamingService *aNamingService = SalomeApp_Application::namingService();
|
SALOME_NamingService_Abstract *aNamingService = SalomeApp_Application::namingService();
|
||||||
CORBA::Object_var aStudyObject = aNamingService->Resolve("/Study");
|
CORBA::Object_var aStudyObject = aNamingService->Resolve("/Study");
|
||||||
SALOMEDS::Study_var aStudy = SALOMEDS::Study::_narrow(aStudyObject);
|
SALOMEDS::Study_var aStudy = SALOMEDS::Study::_narrow(aStudyObject);
|
||||||
return aStudy._retn();
|
return aStudy._retn();
|
||||||
@ -216,14 +218,22 @@ void GeometryGUI::Modified (bool theIsUpdateActions)
|
|||||||
// function : GeometryGUI::GeometryGUI()
|
// function : GeometryGUI::GeometryGUI()
|
||||||
// purpose : Constructor
|
// purpose : Constructor
|
||||||
//=======================================================================
|
//=======================================================================
|
||||||
GeometryGUI::GeometryGUI() :
|
GeometryGUI::GeometryGUI() : SalomeApp_Module( "GEOM" )
|
||||||
SalomeApp_Module( "GEOM" ),
|
|
||||||
myTopLevelIOList()
|
|
||||||
{
|
{
|
||||||
if ( CORBA::is_nil( myComponentGeom ) )
|
if ( CORBA::is_nil( myComponentGeom ) )
|
||||||
{
|
{
|
||||||
Engines::EngineComponent_var comp =
|
SALOME_NamingService_Abstract *ns = SalomeApp_Application::namingService();
|
||||||
SalomeApp_Application::lcc()->FindOrLoad_Component( "FactoryServer", "GEOM" );
|
Engines::EngineComponent_var comp;
|
||||||
|
if( dynamic_cast<SALOME_NamingService *>(ns) )
|
||||||
|
{
|
||||||
|
comp = SalomeApp_Application::lcc()->FindOrLoad_Component( "FactoryServer", "GEOM" );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
comp = RetrieveGEOMInstance();
|
||||||
|
CORBA::Object_var comp2 = CORBA::Object::_narrow(comp);
|
||||||
|
KERNEL::RegisterCompo("GEOM",comp2);
|
||||||
|
}
|
||||||
myComponentGeom = GEOM::GEOM_Gen::_narrow( comp );
|
myComponentGeom = GEOM::GEOM_Gen::_narrow( comp );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -79,6 +79,7 @@ SET(GEOMEngine_HEADERS
|
|||||||
GEOM_Gen_No_Session_i.hh
|
GEOM_Gen_No_Session_i.hh
|
||||||
GEOM_GEOM_I.hxx
|
GEOM_GEOM_I.hxx
|
||||||
GEOM_wrap.hxx
|
GEOM_wrap.hxx
|
||||||
|
GEOM_Component_Generator.hxx
|
||||||
)
|
)
|
||||||
# --- sources ---
|
# --- sources ---
|
||||||
|
|
||||||
@ -104,6 +105,7 @@ SET(GEOMEngine_SOURCES
|
|||||||
GEOM_Gen_Session_i.cc
|
GEOM_Gen_Session_i.cc
|
||||||
GEOM_Gen_No_Session_i.cc
|
GEOM_Gen_No_Session_i.cc
|
||||||
GEOM_DumpPython.cc
|
GEOM_DumpPython.cc
|
||||||
|
GEOM_Component_Generator.cxx
|
||||||
)
|
)
|
||||||
|
|
||||||
# --- rules ---
|
# --- rules ---
|
||||||
|
57
src/GEOM_I/GEOM_Component_Generator.cxx
Normal file
57
src/GEOM_I/GEOM_Component_Generator.cxx
Normal file
@ -0,0 +1,57 @@
|
|||||||
|
// Copyright (C) 2021 CEA/DEN, EDF R&D, OPEN CASCADE
|
||||||
|
//
|
||||||
|
// This library is free software; you can redistribute it and/or
|
||||||
|
// modify it under the terms of the GNU Lesser General Public
|
||||||
|
// License as published by the Free Software Foundation; either
|
||||||
|
// version 2.1 of the License, or (at your option) any later version.
|
||||||
|
//
|
||||||
|
// This library is distributed in the hope that it will be useful,
|
||||||
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
// Lesser General Public License for more details.
|
||||||
|
//
|
||||||
|
// You should have received a copy of the GNU Lesser General Public
|
||||||
|
// License along with this library; if not, write to the Free Software
|
||||||
|
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
//
|
||||||
|
// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
|
||||||
|
//
|
||||||
|
|
||||||
|
#include "GEOM_Component_Generator.hxx"
|
||||||
|
|
||||||
|
#include "GEOM_Gen_No_Session_i.hh"
|
||||||
|
#include "SALOME_Container_i.hxx"
|
||||||
|
#include "SALOME_KernelServices.hxx"
|
||||||
|
|
||||||
|
#include <cstring>
|
||||||
|
|
||||||
|
static Engines::EngineComponent_var _unique_compo;
|
||||||
|
|
||||||
|
Engines::EngineComponent_var RetrieveGEOMInstance()
|
||||||
|
{
|
||||||
|
constexpr char COMPO_NAME[]="GEOM";
|
||||||
|
if (CORBA::is_nil(_unique_compo))
|
||||||
|
{
|
||||||
|
CORBA::ORB_var orb;
|
||||||
|
{
|
||||||
|
int argc(0);
|
||||||
|
orb = CORBA::ORB_init(argc, nullptr);
|
||||||
|
}
|
||||||
|
CORBA::Object_var obj = orb->resolve_initial_references("RootPOA");
|
||||||
|
PortableServer::POA_var poa = PortableServer::POA::_narrow(obj);
|
||||||
|
PortableServer::POAManager_var pman = poa->the_POAManager();
|
||||||
|
CORBA::PolicyList policies;
|
||||||
|
policies.length(0);
|
||||||
|
Engines_Container_i *cont(KERNEL::getContainerSA());
|
||||||
|
PortableServer::ObjectId *conId(cont->getCORBAId());
|
||||||
|
//
|
||||||
|
pman->activate();
|
||||||
|
//
|
||||||
|
GEOM_Gen_No_Session_i *servant = new GEOM_Gen_No_Session_i(orb, poa, conId, "GEOM_inst_2", COMPO_NAME);
|
||||||
|
PortableServer::ObjectId *zeId = servant->getId();
|
||||||
|
CORBA::Object_var zeRef = poa->id_to_reference(*zeId);
|
||||||
|
KERNEL::RegisterCompo(COMPO_NAME,zeRef);
|
||||||
|
_unique_compo = Engines::EngineComponent::_narrow(zeRef);
|
||||||
|
}
|
||||||
|
return _unique_compo;
|
||||||
|
}
|
28
src/GEOM_I/GEOM_Component_Generator.hxx
Normal file
28
src/GEOM_I/GEOM_Component_Generator.hxx
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
// Copyright (C) 2021 CEA/DEN, EDF R&D, OPEN CASCADE
|
||||||
|
//
|
||||||
|
// This library is free software; you can redistribute it and/or
|
||||||
|
// modify it under the terms of the GNU Lesser General Public
|
||||||
|
// License as published by the Free Software Foundation; either
|
||||||
|
// version 2.1 of the License, or (at your option) any later version.
|
||||||
|
//
|
||||||
|
// This library is distributed in the hope that it will be useful,
|
||||||
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
// Lesser General Public License for more details.
|
||||||
|
//
|
||||||
|
// You should have received a copy of the GNU Lesser General Public
|
||||||
|
// License along with this library; if not, write to the Free Software
|
||||||
|
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
//
|
||||||
|
// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
|
||||||
|
//
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include "GEOM_GEOM_I.hxx"
|
||||||
|
|
||||||
|
#include "SALOMEconfig.h"
|
||||||
|
|
||||||
|
#include CORBA_SERVER_HEADER(GEOM_Gen)
|
||||||
|
|
||||||
|
GEOM_I_EXPORT Engines::EngineComponent_var RetrieveGEOMInstance();
|
@ -19,38 +19,13 @@
|
|||||||
|
|
||||||
#include "GeomHelper.h"
|
#include "GeomHelper.h"
|
||||||
|
|
||||||
#include "GEOM_Gen_No_Session_i.hh"
|
|
||||||
#include "SALOME_Container_i.hxx"
|
|
||||||
#include "SALOME_KernelServices.hxx"
|
#include "SALOME_KernelServices.hxx"
|
||||||
|
|
||||||
#include <cstring>
|
#include "GEOM_Component_Generator.hxx"
|
||||||
|
|
||||||
std::string BuildGEOMInstance()
|
std::string BuildGEOMInstance()
|
||||||
{
|
{
|
||||||
CORBA::ORB_var orb;
|
Engines::EngineComponent_var zeRef = RetrieveGEOMInstance();
|
||||||
{ int argc(0); orb = CORBA::ORB_init(argc,nullptr); }
|
CORBA::String_var ior = KERNEL::getORB()->object_to_string(zeRef);
|
||||||
CORBA::Object_var obj = orb->resolve_initial_references("RootPOA");
|
return std::string(ior.in());
|
||||||
PortableServer::POA_var poa = PortableServer::POA::_narrow(obj);
|
|
||||||
PortableServer::POAManager_var pman = poa->the_POAManager();
|
|
||||||
CORBA::PolicyList policies;
|
|
||||||
policies.length(0);
|
|
||||||
PortableServer::ObjectId_var conId;
|
|
||||||
//
|
|
||||||
{
|
|
||||||
char *argv[4] = {"Container","FactoryServer","GEOM",nullptr};
|
|
||||||
Engines_Container_i *cont = new Engines_Container_i(orb,poa,"FactoryServer",2,argv,false,false);
|
|
||||||
conId = poa->activate_object(cont);
|
|
||||||
}
|
|
||||||
//
|
|
||||||
pman->activate();
|
|
||||||
//
|
|
||||||
GEOM_Gen_No_Session_i *servant = new GEOM_Gen_No_Session_i(orb,poa,const_cast<PortableServer::ObjectId*>(&conId.in()),"GEOM_inst_2","GEOM");
|
|
||||||
PortableServer::ObjectId *zeId = servant->getId();
|
|
||||||
CORBA::Object_var zeRef = poa->id_to_reference(*zeId);
|
|
||||||
char *interfaceName = servant->interfaceName();
|
|
||||||
std::string interfaceNameCpp(interfaceName);
|
|
||||||
CORBA::string_free(interfaceName);
|
|
||||||
KERNEL::RegisterCompo(interfaceNameCpp,zeRef);
|
|
||||||
CORBA::String_var ior = orb->object_to_string(zeRef);
|
|
||||||
return std::string(ior.in());
|
|
||||||
}
|
}
|
||||||
|
@ -19,4 +19,4 @@
|
|||||||
|
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
std::string BuildGEOMInstance();
|
std::string BuildGEOMInstance();
|
||||||
|
Loading…
Reference in New Issue
Block a user