mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-13 02:00:34 +05:00
Add "global" status for SMESH objects
This commit is contained in:
parent
49c4f67f30
commit
6c74df3093
@ -31,6 +31,7 @@
|
|||||||
|
|
||||||
#include <TColStd_HSequenceOfInteger.hxx>
|
#include <TColStd_HSequenceOfInteger.hxx>
|
||||||
#include <TCollection_AsciiString.hxx>
|
#include <TCollection_AsciiString.hxx>
|
||||||
|
#include <Resource_DataMapIteratorOfDataMapOfAsciiStringAsciiString.hxx>
|
||||||
|
|
||||||
|
|
||||||
#ifdef _DEBUG_
|
#ifdef _DEBUG_
|
||||||
@ -61,7 +62,7 @@ namespace SMESH
|
|||||||
SMESH_Gen_i* aSMESHGen = SMESH_Gen_i::GetSMESHGen();
|
SMESH_Gen_i* aSMESHGen = SMESH_Gen_i::GetSMESHGen();
|
||||||
SALOMEDS::Study_ptr aStudy = aSMESHGen->GetCurrentStudy();
|
SALOMEDS::Study_ptr aStudy = aSMESHGen->GetCurrentStudy();
|
||||||
if(!aStudy->_is_nil()){
|
if(!aStudy->_is_nil()){
|
||||||
std::string aString = myStream.str();
|
string aString = myStream.str();
|
||||||
TCollection_AsciiString aCollection(Standard_CString(aString.c_str()));
|
TCollection_AsciiString aCollection(Standard_CString(aString.c_str()));
|
||||||
aSMESHGen->AddToPythonScript(aStudy->StudyId(),aCollection);
|
aSMESHGen->AddToPythonScript(aStudy->StudyId(),aCollection);
|
||||||
if(MYDEBUG) MESSAGE(aString);
|
if(MYDEBUG) MESSAGE(aString);
|
||||||
@ -171,11 +172,12 @@ namespace SMESH
|
|||||||
SMESH_Gen_i* aSMESHGen = SMESH_Gen_i::GetSMESHGen();
|
SMESH_Gen_i* aSMESHGen = SMESH_Gen_i::GetSMESHGen();
|
||||||
SALOMEDS::Study_ptr aStudy = aSMESHGen->GetCurrentStudy();
|
SALOMEDS::Study_ptr aStudy = aSMESHGen->GetCurrentStudy();
|
||||||
SALOMEDS::SObject_var aSObject = SMESH_Gen_i::ObjectToSObject(aStudy,theArg);
|
SALOMEDS::SObject_var aSObject = SMESH_Gen_i::ObjectToSObject(aStudy,theArg);
|
||||||
if(!aSObject->_is_nil()) {
|
if(!aSObject->_is_nil())
|
||||||
myStream << aSObject->GetID();
|
myStream << aSObject->GetID();
|
||||||
} else if ( !CORBA::is_nil(theArg)) {
|
else if ( !CORBA::is_nil(theArg)) {
|
||||||
if ( aSMESHGen->CanPublishInStudy( theArg )) // not published SMESH object
|
if ( aSMESHGen->CanPublishInStudy( theArg )) { // not published SMESH object
|
||||||
myStream << "smeshObj_" << size_t(theArg);
|
myStream << "smeshObj_" << size_t(theArg);
|
||||||
|
}
|
||||||
else
|
else
|
||||||
myStream << NotPublishedObjectName();
|
myStream << NotPublishedObjectName();
|
||||||
}
|
}
|
||||||
@ -440,6 +442,34 @@ Engines::TMPFile* SMESH_Gen_i::DumpPython (CORBA::Object_ptr theStudy,
|
|||||||
aScript += DumpPython_impl(aStudy->StudyId(), aMap, aMapNames,
|
aScript += DumpPython_impl(aStudy->StudyId(), aMap, aMapNames,
|
||||||
isPublished, isValidScript, aSavedTrace);
|
isPublished, isValidScript, aSavedTrace);
|
||||||
|
|
||||||
|
//inserting export for Object Names
|
||||||
|
TCollection_AsciiString def = "def RebuildData(theStudy):\n";
|
||||||
|
int pos = aScript.Search( def );
|
||||||
|
if ( pos != -1 )
|
||||||
|
{
|
||||||
|
//insert global definition
|
||||||
|
TCollection_AsciiString glob;
|
||||||
|
for( Resource_DataMapIteratorOfDataMapOfAsciiStringAsciiString It(aMap);
|
||||||
|
It.More(); It.Next() )
|
||||||
|
{
|
||||||
|
TCollection_AsciiString name = It.Value();
|
||||||
|
//check valid name
|
||||||
|
if ( !name.IsEmpty() && name.Search(' ') == -1 && name.Search( ':' ) == -1
|
||||||
|
&& !name.IsIntegerValue() && !name.IsEqual("Hypotheses") && !name.IsEqual("Algorithms") )
|
||||||
|
{
|
||||||
|
if ( glob.Length() > 0 )
|
||||||
|
glob += ',';
|
||||||
|
glob += name;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if ( glob.Length() > 0 )
|
||||||
|
{
|
||||||
|
glob.Prepend( "\tglobal " );
|
||||||
|
glob += '\n';
|
||||||
|
}
|
||||||
|
|
||||||
|
aScript.Insert( pos + def.Length(), glob );
|
||||||
|
}
|
||||||
int aLen = aScript.Length();
|
int aLen = aScript.Length();
|
||||||
unsigned char* aBuffer = new unsigned char[aLen+1];
|
unsigned char* aBuffer = new unsigned char[aLen+1];
|
||||||
strcpy((char*)aBuffer, aScript.ToCString());
|
strcpy((char*)aBuffer, aScript.ToCString());
|
||||||
|
Loading…
Reference in New Issue
Block a user