mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2024-12-27 01:40:33 +05:00
0022291: EDF 2712 SMESH: Bad dump of QuadrangleParameters
This commit is contained in:
parent
106e7f5297
commit
6db4726fc4
@ -36,6 +36,7 @@
|
|||||||
|
|
||||||
#include <TColStd_HSequenceOfInteger.hxx>
|
#include <TColStd_HSequenceOfInteger.hxx>
|
||||||
#include <TCollection_AsciiString.hxx>
|
#include <TCollection_AsciiString.hxx>
|
||||||
|
#include <LDOMParser.hxx>
|
||||||
|
|
||||||
#ifdef _DEBUG_
|
#ifdef _DEBUG_
|
||||||
static int MYDEBUG = 0;
|
static int MYDEBUG = 0;
|
||||||
@ -846,6 +847,45 @@ namespace {
|
|||||||
}
|
}
|
||||||
return isValidName;
|
return isValidName;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//================================================================================
|
||||||
|
/*!
|
||||||
|
* \brief Return Python module names of available plug-ins.
|
||||||
|
*/
|
||||||
|
//================================================================================
|
||||||
|
|
||||||
|
std::vector<std::string> getPluginNames()
|
||||||
|
{
|
||||||
|
std::vector<std::string> pluginNames;
|
||||||
|
std::vector< std::string > xmlPaths = SMESH_Gen::GetPluginXMLPaths();
|
||||||
|
LDOMParser xmlParser;
|
||||||
|
for ( size_t i = 0; i < xmlPaths.size(); ++i )
|
||||||
|
{
|
||||||
|
bool error = xmlParser.parse( xmlPaths[i].c_str() );
|
||||||
|
if ( error )
|
||||||
|
{
|
||||||
|
TCollection_AsciiString data;
|
||||||
|
INFOS( xmlParser.GetError(data) );
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
// <meshers-group name="Standard Meshers"
|
||||||
|
// resources="StdMeshers"
|
||||||
|
// idl-module="StdMeshers"
|
||||||
|
// server-lib="StdMeshersEngine"
|
||||||
|
// gui-lib="StdMeshersGUI">
|
||||||
|
LDOM_Document xmlDoc = xmlParser.getDocument();
|
||||||
|
LDOM_NodeList nodeList = xmlDoc.getElementsByTagName( "meshers-group" );
|
||||||
|
for ( int i = 0; i < nodeList.getLength(); ++i )
|
||||||
|
{
|
||||||
|
LDOM_Node node = nodeList.item( i );
|
||||||
|
LDOM_Element& elem = (LDOM_Element&) node;
|
||||||
|
LDOMString idlModule = elem.getAttribute( "idl-module" );
|
||||||
|
if ( strlen( idlModule.GetString() ) > 0 )
|
||||||
|
pluginNames.push_back( idlModule.GetString() );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return pluginNames;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//=============================================================================
|
//=============================================================================
|
||||||
@ -873,6 +913,7 @@ TCollection_AsciiString SMESH_Gen_i::DumpPython_impl
|
|||||||
TCollection_AsciiString aScript;
|
TCollection_AsciiString aScript;
|
||||||
if( isMultiFile )
|
if( isMultiFile )
|
||||||
aScript += "def RebuildData(theStudy):";
|
aScript += "def RebuildData(theStudy):";
|
||||||
|
|
||||||
aScript += "\n\t";
|
aScript += "\n\t";
|
||||||
if ( isPublished )
|
if ( isPublished )
|
||||||
aScript += aSMESHGen + " = smeshBuilder.New(theStudy)\n\t";
|
aScript += aSMESHGen + " = smeshBuilder.New(theStudy)\n\t";
|
||||||
@ -881,17 +922,6 @@ TCollection_AsciiString SMESH_Gen_i::DumpPython_impl
|
|||||||
aScript += helper + "aFilterManager = " + aSMESHGen + ".CreateFilterManager()\n\t";
|
aScript += helper + "aFilterManager = " + aSMESHGen + ".CreateFilterManager()\n\t";
|
||||||
aScript += helper + "aMeasurements = " + aSMESHGen + ".CreateMeasurements()\n\t";
|
aScript += helper + "aMeasurements = " + aSMESHGen + ".CreateMeasurements()\n\t";
|
||||||
|
|
||||||
// This is not needed since entering a plug-in system to smesh.py
|
|
||||||
// import python files corresponding to plugins
|
|
||||||
// set<string> moduleNameSet;
|
|
||||||
// map<string, GenericHypothesisCreator_i*>::iterator hyp_creator = myHypCreatorMap.begin();
|
|
||||||
// for ( ; hyp_creator != myHypCreatorMap.end(); ++hyp_creator ) {
|
|
||||||
// string moduleName = hyp_creator->second->GetModuleName();
|
|
||||||
// bool newModule = moduleNameSet.insert( moduleName ).second;
|
|
||||||
// if ( newModule )
|
|
||||||
// aScript += helper + "\n\t" + "from salome." + (char*) moduleName.c_str() + " import " + (char*) moduleName.c_str() +"Builder";
|
|
||||||
// }
|
|
||||||
|
|
||||||
// Dump trace of restored study
|
// Dump trace of restored study
|
||||||
if (theSavedTrace.Length() > 0) {
|
if (theSavedTrace.Length() > 0) {
|
||||||
// For the convertion of IDL API calls -> smeshBuilder.py API, "smesh" standing for SMESH_Gen
|
// For the convertion of IDL API calls -> smeshBuilder.py API, "smesh" standing for SMESH_Gen
|
||||||
@ -924,6 +954,30 @@ TCollection_AsciiString SMESH_Gen_i::DumpPython_impl
|
|||||||
aScript += helper + "\n" + aNewLines;
|
aScript += helper + "\n" + aNewLines;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// import python files corresponding to plugins if they are used in aScript
|
||||||
|
{
|
||||||
|
TCollection_AsciiString importStr;
|
||||||
|
std::vector<std::string> pluginNames = getPluginNames();
|
||||||
|
for ( size_t i = 0; i < pluginNames.size(); ++i )
|
||||||
|
{
|
||||||
|
// Convert access to plugin members:
|
||||||
|
// e.g. StdMeshers.QUAD_REDUCED -> StdMeshersBuilder.QUAD_REDUCED
|
||||||
|
TCollection_AsciiString pluginAccess = (pluginNames[i] + ".").c_str() ;
|
||||||
|
int iFrom = 1, iPos;
|
||||||
|
while (( iPos = aScript.Location( pluginAccess, iFrom, aScript.Length() )))
|
||||||
|
{
|
||||||
|
aScript.Insert( iPos + pluginNames[i].size(), "Builder" );
|
||||||
|
iFrom = iPos + pluginNames[i].size() + 8;
|
||||||
|
}
|
||||||
|
// if any plugin member is used, import the plugin
|
||||||
|
if ( iFrom > 1 )
|
||||||
|
importStr += ( helper + "\n\t" + "from salome." + (char*) pluginNames[i].c_str() +
|
||||||
|
" import " + (char*) pluginNames[i].c_str() +"Builder" );
|
||||||
|
}
|
||||||
|
if ( !importStr.IsEmpty() )
|
||||||
|
aScript.Insert( 1, importStr + "\n\t" );
|
||||||
|
}
|
||||||
|
|
||||||
// Convert IDL API calls into smeshBuilder.py API.
|
// Convert IDL API calls into smeshBuilder.py API.
|
||||||
// Some objects are wrapped with python classes and
|
// Some objects are wrapped with python classes and
|
||||||
// Resource_DataMapOfAsciiStringAsciiString holds methods returning wrapped objects
|
// Resource_DataMapOfAsciiStringAsciiString holds methods returning wrapped objects
|
||||||
|
Loading…
Reference in New Issue
Block a user