mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-28 05:20:32 +05:00
Dump Python: set correct names to objects in study; provide correct setting of a name to a Group.
This commit is contained in:
parent
dd52ec47d0
commit
3072473087
@ -226,6 +226,7 @@ Engines::TMPFile* SMESH_Gen_i::DumpPython (CORBA::Object_ptr theStudy,
|
|||||||
|
|
||||||
// Map study entries to object names
|
// Map study entries to object names
|
||||||
Resource_DataMapOfAsciiStringAsciiString aMap;
|
Resource_DataMapOfAsciiStringAsciiString aMap;
|
||||||
|
Resource_DataMapOfAsciiStringAsciiString aMapNames;
|
||||||
TCollection_AsciiString s ("qwertyuioplkjhgfdsazxcvbnmQWERTYUIOPLKJHGFDSAZXCVBNM0987654321_");
|
TCollection_AsciiString s ("qwertyuioplkjhgfdsazxcvbnmQWERTYUIOPLKJHGFDSAZXCVBNM0987654321_");
|
||||||
|
|
||||||
SALOMEDS::ChildIterator_var Itr = aStudy->NewChildIterator(aSO);
|
SALOMEDS::ChildIterator_var Itr = aStudy->NewChildIterator(aSO);
|
||||||
@ -233,7 +234,9 @@ Engines::TMPFile* SMESH_Gen_i::DumpPython (CORBA::Object_ptr theStudy,
|
|||||||
SALOMEDS::SObject_var aValue = Itr->Value();
|
SALOMEDS::SObject_var aValue = Itr->Value();
|
||||||
|
|
||||||
TCollection_AsciiString aName (aValue->GetName());
|
TCollection_AsciiString aName (aValue->GetName());
|
||||||
|
TCollection_AsciiString aGUIName (aName);
|
||||||
if (aName.Length() > 0) {
|
if (aName.Length() > 0) {
|
||||||
|
aMapNames.Bind(TCollection_AsciiString(aValue->GetID()), aGUIName);
|
||||||
int p, p2 = 1, e = aName.Length();
|
int p, p2 = 1, e = aName.Length();
|
||||||
while ((p = aName.FirstLocationNotInSet(s, p2, e))) {
|
while ((p = aName.FirstLocationNotInSet(s, p2, e))) {
|
||||||
aName.SetValue(p, '_');
|
aName.SetValue(p, '_');
|
||||||
@ -254,9 +257,8 @@ Engines::TMPFile* SMESH_Gen_i::DumpPython (CORBA::Object_ptr theStudy,
|
|||||||
|
|
||||||
// Add trace of API methods calls and replace study entries by names
|
// Add trace of API methods calls and replace study entries by names
|
||||||
bool aValidScript;
|
bool aValidScript;
|
||||||
//TCollection_AsciiString aScript = myGen.DumpPython
|
|
||||||
TCollection_AsciiString aScript = DumpPython_impl
|
TCollection_AsciiString aScript = DumpPython_impl
|
||||||
(aStudy->StudyId(), aMap, isPublished, aValidScript, aSavedTrace);
|
(aStudy->StudyId(), aMap, aMapNames, isPublished, aValidScript, aSavedTrace);
|
||||||
|
|
||||||
int aLen = aScript.Length();
|
int aLen = aScript.Length();
|
||||||
unsigned char* aBuffer = new unsigned char[aLen+1];
|
unsigned char* aBuffer = new unsigned char[aLen+1];
|
||||||
@ -417,6 +419,7 @@ Handle(TColStd_HSequenceOfInteger) FindEntries (TCollection_AsciiString& theStri
|
|||||||
TCollection_AsciiString SMESH_Gen_i::DumpPython_impl
|
TCollection_AsciiString SMESH_Gen_i::DumpPython_impl
|
||||||
(int theStudyID,
|
(int theStudyID,
|
||||||
Resource_DataMapOfAsciiStringAsciiString& theObjectNames,
|
Resource_DataMapOfAsciiStringAsciiString& theObjectNames,
|
||||||
|
Resource_DataMapOfAsciiStringAsciiString& theNames,
|
||||||
bool isPublished,
|
bool isPublished,
|
||||||
bool& aValidScript,
|
bool& aValidScript,
|
||||||
const TCollection_AsciiString& theSavedTrace)
|
const TCollection_AsciiString& theSavedTrace)
|
||||||
@ -430,8 +433,9 @@ TCollection_AsciiString SMESH_Gen_i::DumpPython_impl
|
|||||||
aScript += "import string\n";
|
aScript += "import string\n";
|
||||||
aScript += "import os\n";
|
aScript += "import os\n";
|
||||||
aScript += "import sys\n";
|
aScript += "import sys\n";
|
||||||
|
aScript += "import re\n";
|
||||||
aScript += "sys.path.append( os.path.dirname(__file__) )\n";
|
aScript += "sys.path.append( os.path.dirname(__file__) )\n";
|
||||||
aScript += "exec(\"from \"+string.replace(__name__,\"SMESH\",\"GEOM\")+\" import *\")\n\n";
|
aScript += "exec(\"from \"+re.sub(\"SMESH$\",\"GEOM\",__name__)+\" import *\")\n\n";
|
||||||
|
|
||||||
aScript += "def RebuildData(theStudy):";
|
aScript += "def RebuildData(theStudy):";
|
||||||
aScript += "\n\tsmesh = salome.lcc.FindOrLoadComponent(\"FactoryServer\", \"SMESH\")";
|
aScript += "\n\tsmesh = salome.lcc.FindOrLoadComponent(\"FactoryServer\", \"SMESH\")";
|
||||||
@ -516,26 +520,29 @@ TCollection_AsciiString SMESH_Gen_i::DumpPython_impl
|
|||||||
anUpdatedScript += seqRemoved.Value(ir);
|
anUpdatedScript += seqRemoved.Value(ir);
|
||||||
anUpdatedScript += "))\n\tif SO is not None: aStudyBuilder.RemoveObjectWithChildren(SO)";
|
anUpdatedScript += "))\n\tif SO is not None: aStudyBuilder.RemoveObjectWithChildren(SO)";
|
||||||
}
|
}
|
||||||
anUpdatedScript += "\n";
|
|
||||||
|
|
||||||
// Set object names
|
// Set object names
|
||||||
anUpdatedScript += "\n\tisGUIMode = ";
|
anUpdatedScript += "\n\n\tisGUIMode = ";
|
||||||
anUpdatedScript += isPublished;
|
anUpdatedScript += isPublished;
|
||||||
anUpdatedScript += "\n\tif isGUIMode:";
|
anUpdatedScript += "\n\tif isGUIMode:";
|
||||||
anUpdatedScript += "\n\t\tsmeshgui = salome.ImportComponentGUI(\"SMESH\")";
|
anUpdatedScript += "\n\t\tsmeshgui = salome.ImportComponentGUI(\"SMESH\")";
|
||||||
anUpdatedScript += "\n\t\tsmeshgui.Init(theStudy._get_StudyId())";
|
anUpdatedScript += "\n\t\tsmeshgui.Init(theStudy._get_StudyId())";
|
||||||
anUpdatedScript += "\n";
|
anUpdatedScript += "\n";
|
||||||
|
|
||||||
|
TCollection_AsciiString aGUIName;
|
||||||
Resource_DataMapOfAsciiStringAsciiString mapEntries;
|
Resource_DataMapOfAsciiStringAsciiString mapEntries;
|
||||||
for (Standard_Integer i = 1; i <= aLen; i += 2) {
|
for (Standard_Integer i = 1; i <= aLen; i += 2) {
|
||||||
anEntry = aScript.SubString(aSeq->Value(i), aSeq->Value(i + 1));
|
anEntry = aScript.SubString(aSeq->Value(i), aSeq->Value(i + 1));
|
||||||
if (theObjectNames.IsBound(anEntry) &&
|
aName = geom->GetDumpName( anEntry.ToCString() );
|
||||||
!mapEntries.IsBound(anEntry) &&
|
if (aName.IsEmpty() && // Not a GEOM object
|
||||||
!mapRemoved.IsBound(anEntry)) {
|
theNames.IsBound(anEntry) &&
|
||||||
|
!mapEntries.IsBound(anEntry) && // Not yet processed
|
||||||
|
!mapRemoved.IsBound(anEntry)) { // Was not removed
|
||||||
aName = theObjectNames.Find(anEntry);
|
aName = theObjectNames.Find(anEntry);
|
||||||
|
aGUIName = theNames.Find(anEntry);
|
||||||
mapEntries.Bind(anEntry, aName);
|
mapEntries.Bind(anEntry, aName);
|
||||||
anUpdatedScript += "\n\t\tsmeshgui.SetName(salome.ObjectToID(";
|
anUpdatedScript += "\n\t\tsmeshgui.SetName(salome.ObjectToID(";
|
||||||
anUpdatedScript += aName + "), \"" + aName + "\")";
|
anUpdatedScript += aName + "), \"" + aGUIName + "\")";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
anUpdatedScript += "\n\n\t\tsalome.sg.updateObjBrowser(0)";
|
anUpdatedScript += "\n\n\t\tsalome.sg.updateObjBrowser(0)";
|
||||||
|
@ -296,6 +296,7 @@ public:
|
|||||||
|
|
||||||
TCollection_AsciiString DumpPython_impl (int theStudyID,
|
TCollection_AsciiString DumpPython_impl (int theStudyID,
|
||||||
Resource_DataMapOfAsciiStringAsciiString& theObjectNames,
|
Resource_DataMapOfAsciiStringAsciiString& theObjectNames,
|
||||||
|
Resource_DataMapOfAsciiStringAsciiString& theNames,
|
||||||
bool isPublished,
|
bool isPublished,
|
||||||
bool& aValidScript,
|
bool& aValidScript,
|
||||||
const TCollection_AsciiString& theSavedTrace);
|
const TCollection_AsciiString& theSavedTrace);
|
||||||
|
@ -119,6 +119,14 @@ SMESHDS_GroupBase* SMESH_GroupBase_i::GetGroupDS() const
|
|||||||
|
|
||||||
void SMESH_GroupBase_i::SetName( const char* theName )
|
void SMESH_GroupBase_i::SetName( const char* theName )
|
||||||
{
|
{
|
||||||
|
// Update Python script
|
||||||
|
TCollection_AsciiString aStr, aStrName ((char*)theName);
|
||||||
|
SMESH_Gen_i::AddObject(aStr, _this()) += ".SetName(\"";
|
||||||
|
aStr += aStrName + ")";
|
||||||
|
|
||||||
|
SMESH_Gen_i::AddToCurrentPyScript(aStr);
|
||||||
|
|
||||||
|
// Perform renaming
|
||||||
::SMESH_Group* aGroup = GetSmeshGroup();
|
::SMESH_Group* aGroup = GetSmeshGroup();
|
||||||
if (aGroup) {
|
if (aGroup) {
|
||||||
aGroup->SetName(theName);
|
aGroup->SetName(theName);
|
||||||
|
Loading…
Reference in New Issue
Block a user