2005-03-24 14:37:16 +00:00
|
|
|
// File : SMESH_Gen_i_DumpPython.cxx
|
|
|
|
// Created : Thu Mar 24 17:17:59 2005
|
|
|
|
// Author : Julia DOROVSKIKH
|
|
|
|
// Module : SMESH
|
|
|
|
// $Header : $
|
|
|
|
|
|
|
|
#include "SMESH_Gen_i.hxx"
|
|
|
|
|
|
|
|
#include <TColStd_HSequenceOfInteger.hxx>
|
|
|
|
|
|
|
|
//=======================================================================
|
|
|
|
//function : DumpPython
|
|
|
|
//purpose :
|
|
|
|
//=======================================================================
|
2005-03-28 10:11:37 +00:00
|
|
|
Engines::TMPFile* SMESH_Gen_i::DumpPython (CORBA::Object_ptr theStudy,
|
|
|
|
CORBA::Boolean isPublished,
|
2005-03-24 14:37:16 +00:00
|
|
|
CORBA::Boolean& isValidScript)
|
|
|
|
{
|
|
|
|
SALOMEDS::Study_var aStudy = SALOMEDS::Study::_narrow(theStudy);
|
|
|
|
if (CORBA::is_nil(aStudy))
|
2005-03-28 10:11:37 +00:00
|
|
|
return new Engines::TMPFile(0);
|
2005-03-24 14:37:16 +00:00
|
|
|
|
|
|
|
SALOMEDS::SObject_var aSO = aStudy->FindComponent(ComponentDataType());
|
|
|
|
if (CORBA::is_nil(aSO))
|
2005-03-28 10:11:37 +00:00
|
|
|
return new Engines::TMPFile(0);
|
2005-03-24 14:37:16 +00:00
|
|
|
|
|
|
|
// Map study entries to object names
|
|
|
|
Resource_DataMapOfAsciiStringAsciiString aMap;
|
|
|
|
TCollection_AsciiString s ("qwertyuioplkjhgfdsazxcvbnmQWERTYUIOPLKJHGFDSAZXCVBNM0987654321_");
|
|
|
|
|
|
|
|
SALOMEDS::ChildIterator_var Itr = aStudy->NewChildIterator(aSO);
|
|
|
|
for (Itr->InitEx(true); Itr->More(); Itr->Next()) {
|
|
|
|
SALOMEDS::SObject_var aValue = Itr->Value();
|
|
|
|
|
|
|
|
TCollection_AsciiString aName (aValue->GetName());
|
2005-03-28 10:11:37 +00:00
|
|
|
if (aName.Length() > 0) {
|
|
|
|
int p, p2 = 1, e = aName.Length();
|
|
|
|
while ((p = aName.FirstLocationNotInSet(s, p2, e))) {
|
|
|
|
aName.SetValue(p, '_');
|
|
|
|
p2 = p;
|
|
|
|
}
|
|
|
|
aMap.Bind(TCollection_AsciiString(aValue->GetID()), aName);
|
|
|
|
}
|
2005-03-24 14:37:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Get trace of restored study
|
|
|
|
//SALOMEDS::SObject_var aSO = SMESH_Gen_i::ObjectToSObject(theStudy, _this());
|
|
|
|
SALOMEDS::StudyBuilder_var aStudyBuilder = aStudy->NewBuilder();
|
|
|
|
SALOMEDS::GenericAttribute_var anAttr =
|
|
|
|
aStudyBuilder->FindOrCreateAttribute(aSO, "AttributePythonObject");
|
|
|
|
|
|
|
|
char* oldValue = SALOMEDS::AttributePythonObject::_narrow(anAttr)->GetObject();
|
|
|
|
TCollection_AsciiString aSavedTrace (oldValue);
|
|
|
|
|
|
|
|
// Add trace of API methods calls and replace study entries by names
|
|
|
|
bool aValidScript;
|
|
|
|
//TCollection_AsciiString aScript = myGen.DumpPython
|
|
|
|
TCollection_AsciiString aScript = DumpPython_impl
|
|
|
|
(aStudy->StudyId(), aMap, isPublished, aValidScript, aSavedTrace);
|
|
|
|
|
|
|
|
int aLen = aScript.Length();
|
|
|
|
unsigned char* aBuffer = new unsigned char[aLen+1];
|
|
|
|
strcpy((char*)aBuffer, aScript.ToCString());
|
|
|
|
|
|
|
|
CORBA::Octet* anOctetBuf = (CORBA::Octet*)aBuffer;
|
|
|
|
Engines::TMPFile_var aStreamFile = new Engines::TMPFile(aLen+1, aLen+1, anOctetBuf, 1);
|
|
|
|
isValidScript = aValidScript;
|
|
|
|
|
|
|
|
return aStreamFile._retn();
|
|
|
|
}
|
|
|
|
|
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* AddToPythonScript
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
void SMESH_Gen_i::AddToPythonScript (int theStudyID, const TCollection_AsciiString& theString)
|
|
|
|
{
|
|
|
|
if (myPythonScripts.find(theStudyID) == myPythonScripts.end()) {
|
|
|
|
myPythonScripts[theStudyID] = new TColStd_HSequenceOfAsciiString;
|
|
|
|
}
|
|
|
|
myPythonScripts[theStudyID]->Append(theString);
|
|
|
|
}
|
|
|
|
|
2005-03-28 10:11:37 +00:00
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* RemoveLastFromPythonScript
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
void SMESH_Gen_i::RemoveLastFromPythonScript (int theStudyID)
|
|
|
|
{
|
|
|
|
if (myPythonScripts.find(theStudyID) != myPythonScripts.end()) {
|
|
|
|
int aLen = myPythonScripts[theStudyID]->Length();
|
|
|
|
myPythonScripts[theStudyID]->Remove(aLen);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2005-03-28 08:08:52 +00:00
|
|
|
//=======================================================================
|
|
|
|
//function : AddToCurrentPyScript
|
|
|
|
//purpose :
|
|
|
|
//=======================================================================
|
|
|
|
|
|
|
|
void SMESH_Gen_i::AddToCurrentPyScript (const TCollection_AsciiString& theString)
|
|
|
|
{
|
|
|
|
SMESH_Gen_i* aSMESHGen = SMESH_Gen_i::GetSMESHGen();
|
2005-03-28 14:26:59 +00:00
|
|
|
SALOMEDS::Study_ptr aStudy = aSMESHGen->GetCurrentStudy();
|
|
|
|
if (aStudy->_is_nil()) return;
|
|
|
|
aSMESHGen->AddToPythonScript(aStudy->StudyId(), theString);
|
2005-03-28 08:08:52 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//=======================================================================
|
|
|
|
//function : AddObject
|
|
|
|
//purpose : add object to script string
|
|
|
|
//=======================================================================
|
|
|
|
|
|
|
|
TCollection_AsciiString& SMESH_Gen_i::AddObject(TCollection_AsciiString& theStr,
|
|
|
|
CORBA::Object_ptr theObject)
|
|
|
|
{
|
2005-03-29 09:27:31 +00:00
|
|
|
SMESH_Gen_i* aSMESHGen = SMESH_Gen_i::GetSMESHGen();
|
|
|
|
SALOMEDS::SObject_var aSO =
|
|
|
|
aSMESHGen->ObjectToSObject(aSMESHGen->GetCurrentStudy(), theObject);
|
|
|
|
if ( !aSO->_is_nil() )
|
|
|
|
theStr += aSO->GetID();
|
|
|
|
else if ( !CORBA::is_nil( theObject ) )
|
|
|
|
theStr += GetORB()->object_to_string( theObject );
|
|
|
|
else
|
|
|
|
theStr += "None";
|
|
|
|
|
2005-03-28 08:08:52 +00:00
|
|
|
return theStr;
|
|
|
|
}
|
|
|
|
|
2005-03-24 14:37:16 +00:00
|
|
|
//=======================================================================
|
|
|
|
//function : SavePython
|
|
|
|
//purpose :
|
|
|
|
//=======================================================================
|
|
|
|
void SMESH_Gen_i::SavePython (SALOMEDS::Study_ptr theStudy)
|
|
|
|
{
|
|
|
|
// Dump trace of API methods calls
|
|
|
|
TCollection_AsciiString aScript = GetNewPythonLines(theStudy->StudyId());
|
|
|
|
|
|
|
|
// Check contents of PythonObject attribute
|
|
|
|
SALOMEDS::SObject_var aSO = theStudy->FindComponent(ComponentDataType());
|
|
|
|
//SALOMEDS::SObject_var aSO = SMESH_Gen_i::ObjectToSObject(theStudy, _this());
|
|
|
|
SALOMEDS::StudyBuilder_var aStudyBuilder = theStudy->NewBuilder();
|
|
|
|
SALOMEDS::GenericAttribute_var anAttr =
|
|
|
|
aStudyBuilder->FindOrCreateAttribute(aSO, "AttributePythonObject");
|
|
|
|
|
|
|
|
char* oldValue = SALOMEDS::AttributePythonObject::_narrow(anAttr)->GetObject();
|
|
|
|
TCollection_AsciiString oldScript (oldValue);
|
|
|
|
|
|
|
|
if (oldScript.Length() > 0) {
|
|
|
|
oldScript += "\n";
|
|
|
|
oldScript += aScript;
|
|
|
|
} else {
|
|
|
|
oldScript = aScript;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Store in PythonObject attribute
|
|
|
|
SALOMEDS::AttributePythonObject::_narrow(anAttr)->SetObject(oldScript.ToCString(), 1);
|
|
|
|
|
|
|
|
// Clean trace of API methods calls
|
|
|
|
CleanPythonTrace(theStudy->StudyId());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// impl
|
|
|
|
|
|
|
|
|
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* FindEntries: Returns a sequence of start/end positions of entries in the string
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
Handle(TColStd_HSequenceOfInteger) FindEntries (TCollection_AsciiString& theString)
|
|
|
|
{
|
|
|
|
Handle(TColStd_HSequenceOfInteger) aSeq = new TColStd_HSequenceOfInteger;
|
|
|
|
Standard_Integer aLen = theString.Length();
|
|
|
|
Standard_Boolean isFound = Standard_False;
|
|
|
|
|
|
|
|
char* arr = theString.ToCString();
|
|
|
|
Standard_Integer i = 0, j;
|
|
|
|
|
|
|
|
while(i < aLen) {
|
|
|
|
int c = (int)arr[i];
|
|
|
|
j = i+1;
|
|
|
|
if(c >= 48 && c <= 57) { //Is digit?
|
|
|
|
|
|
|
|
isFound = Standard_False;
|
|
|
|
while((j < aLen) && ((c >= 48 && c <= 57) || c == 58) ) { //Check if it is an entry
|
|
|
|
c = (int)arr[j++];
|
|
|
|
if(c == 58) isFound = Standard_True;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isFound) {
|
|
|
|
int prev = (i < 1) ? 0 : (int)arr[i - 1];
|
|
|
|
// last char should be a diggit,
|
|
|
|
// previous char should not be '"'.
|
|
|
|
if (arr[j-2] != 58 && prev != 34) {
|
|
|
|
aSeq->Append(i+1); // +1 because AsciiString starts from 1
|
|
|
|
aSeq->Append(j-1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
i = j;
|
|
|
|
}
|
|
|
|
|
|
|
|
return aSeq;
|
|
|
|
}
|
|
|
|
|
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* DumpPython
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
TCollection_AsciiString SMESH_Gen_i::DumpPython_impl
|
|
|
|
(int theStudyID,
|
|
|
|
Resource_DataMapOfAsciiStringAsciiString& theObjectNames,
|
|
|
|
bool isPublished,
|
|
|
|
bool& aValidScript,
|
|
|
|
const TCollection_AsciiString& theSavedTrace)
|
|
|
|
{
|
|
|
|
TCollection_AsciiString aScript;
|
|
|
|
aScript += "import salome\n";
|
|
|
|
aScript += "import geompy\n\n";
|
|
|
|
aScript += "import SMESH\n";
|
|
|
|
aScript += "import StdMeshers\n\n";
|
2005-03-29 09:27:31 +00:00
|
|
|
aScript += "#import GEOM module\n";
|
|
|
|
aScript += "import string\n";
|
|
|
|
aScript += "import os\n";
|
|
|
|
aScript += "import sys\n";
|
|
|
|
aScript += "sys.path.append( os.path.dirname(__file__) )\n";
|
|
|
|
aScript += "exec(\"from \"+string.replace(__name__,\"SMESH\",\"GEOM\")+\" import *\")\n\n";
|
|
|
|
|
2005-03-24 14:37:16 +00:00
|
|
|
aScript += "def RebuildData(theStudy):";
|
|
|
|
aScript += "\n\tsmesh = salome.lcc.FindOrLoadComponent(\"FactoryServer\", \"SMESH\")";
|
2005-03-29 09:27:31 +00:00
|
|
|
if ( isPublished )
|
|
|
|
aScript += "\n\tsmesh.SetCurrentStudy(theStudy)";
|
|
|
|
else
|
|
|
|
aScript += "\n\tsmesh.SetCurrentStudy(None)";
|
|
|
|
|
|
|
|
Standard_Integer posToInertGlobalVars = aScript.Length();
|
|
|
|
TCollection_AsciiString globalVars;
|
2005-03-24 14:37:16 +00:00
|
|
|
|
|
|
|
// Dump trace of restored study
|
|
|
|
if (theSavedTrace.Length() > 0) {
|
|
|
|
aScript += "\n";
|
|
|
|
aScript += theSavedTrace;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Dump trace of API methods calls
|
|
|
|
TCollection_AsciiString aNewLines = GetNewPythonLines(theStudyID);
|
|
|
|
if (aNewLines.Length() > 0) {
|
|
|
|
aScript += "\n";
|
|
|
|
aScript += aNewLines;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Find entries to be replaced by names
|
|
|
|
Handle(TColStd_HSequenceOfInteger) aSeq = FindEntries(aScript);
|
|
|
|
Standard_Integer aLen = aSeq->Length();
|
|
|
|
|
|
|
|
if (aLen == 0)
|
|
|
|
return aScript;
|
|
|
|
|
|
|
|
// Replace entries by the names
|
2005-03-29 09:27:31 +00:00
|
|
|
GEOM::GEOM_Gen_ptr geom = GetGeomEngine();
|
2005-03-28 10:11:37 +00:00
|
|
|
TColStd_SequenceOfAsciiString seqRemoved;
|
|
|
|
Resource_DataMapOfAsciiStringAsciiString mapRemoved;
|
2005-03-24 14:37:16 +00:00
|
|
|
Resource_DataMapOfAsciiStringAsciiString aNames;
|
|
|
|
Standard_Integer objectCounter = 0, aStart = 1, aScriptLength = aScript.Length();
|
2005-03-28 10:11:37 +00:00
|
|
|
TCollection_AsciiString anUpdatedScript, anEntry, aName, aBaseName("smeshObj_");
|
2005-03-24 14:37:16 +00:00
|
|
|
|
|
|
|
for (Standard_Integer i = 1; i <= aLen; i += 2) {
|
|
|
|
anUpdatedScript += aScript.SubString(aStart, aSeq->Value(i) - 1);
|
|
|
|
anEntry = aScript.SubString(aSeq->Value(i), aSeq->Value(i + 1));
|
|
|
|
if (theObjectNames.IsBound(anEntry)) {
|
|
|
|
aName = theObjectNames.Find(anEntry);
|
|
|
|
if (theObjectNames.IsBound(aName) && anEntry != theObjectNames(aName)) {
|
|
|
|
// diff objects have same name - make a new name
|
|
|
|
TCollection_AsciiString aName2;
|
|
|
|
Standard_Integer i = 0;
|
|
|
|
do {
|
|
|
|
aName2 = aName + "_" + ++i;
|
|
|
|
} while (theObjectNames.IsBound(aName2) && anEntry != theObjectNames(aName2));
|
|
|
|
aName = aName2;
|
|
|
|
theObjectNames(anEntry) = aName;
|
|
|
|
}
|
|
|
|
} else {
|
2005-03-29 09:27:31 +00:00
|
|
|
// is a GEOM object?
|
|
|
|
aName = geom->GetDumpName( anEntry.ToCString() );
|
|
|
|
if ( aName.IsEmpty() ) {
|
2005-03-28 10:11:37 +00:00
|
|
|
// ? Removed Object ?
|
2005-03-29 09:27:31 +00:00
|
|
|
do {
|
|
|
|
aName = aBaseName + TCollection_AsciiString(++objectCounter);
|
|
|
|
} while (theObjectNames.IsBound(aName));
|
|
|
|
seqRemoved.Append(aName);
|
|
|
|
mapRemoved.Bind(anEntry, "1");
|
|
|
|
}
|
2005-03-24 14:37:16 +00:00
|
|
|
theObjectNames.Bind(anEntry, aName);
|
|
|
|
}
|
|
|
|
theObjectNames.Bind(aName, anEntry); // to detect same name of diff objects
|
|
|
|
|
|
|
|
anUpdatedScript += aName;
|
|
|
|
aNames.Bind(aName, "1");
|
|
|
|
aStart = aSeq->Value(i + 1) + 1;
|
|
|
|
}
|
|
|
|
|
2005-03-28 10:11:37 +00:00
|
|
|
// add final part of aScript
|
2005-03-24 14:37:16 +00:00
|
|
|
if (aSeq->Value(aLen) < aScriptLength)
|
|
|
|
anUpdatedScript += aScript.SubString(aSeq->Value(aLen) + 1, aScriptLength);
|
|
|
|
|
2005-03-28 10:11:37 +00:00
|
|
|
// Remove removed objects
|
|
|
|
anUpdatedScript += "\n\taStudyBuilder = theStudy.NewBuilder()";
|
|
|
|
for (int ir = 1; ir <= seqRemoved.Length(); ir++) {
|
|
|
|
anUpdatedScript += "\n\tSO = theStudy.FindObjectIOR(theStudy.ConvertObjectToIOR(";
|
|
|
|
anUpdatedScript += seqRemoved.Value(ir);
|
|
|
|
anUpdatedScript += "))\n\tif SO is not None: aStudyBuilder.RemoveObjectWithChildren(SO)";
|
|
|
|
}
|
|
|
|
anUpdatedScript += "\n";
|
|
|
|
|
2005-03-24 14:37:16 +00:00
|
|
|
// Set object names
|
|
|
|
anUpdatedScript += "\n\tisGUIMode = 1";
|
|
|
|
anUpdatedScript += "\n\tif isGUIMode:";
|
|
|
|
anUpdatedScript += "\n\t\tsmeshgui = salome.ImportComponentGUI(\"SMESH\")";
|
|
|
|
anUpdatedScript += "\n\t\tsmeshgui.Init(theStudy._get_StudyId())";
|
|
|
|
anUpdatedScript += "\n";
|
|
|
|
|
|
|
|
Resource_DataMapOfAsciiStringAsciiString mapEntries;
|
|
|
|
for (Standard_Integer i = 1; i <= aLen; i += 2) {
|
|
|
|
anEntry = aScript.SubString(aSeq->Value(i), aSeq->Value(i + 1));
|
2005-03-28 10:11:37 +00:00
|
|
|
if (theObjectNames.IsBound(anEntry) &&
|
|
|
|
!mapEntries.IsBound(anEntry) &&
|
|
|
|
!mapRemoved.IsBound(anEntry)) {
|
2005-03-24 14:37:16 +00:00
|
|
|
aName = theObjectNames.Find(anEntry);
|
|
|
|
mapEntries.Bind(anEntry, aName);
|
|
|
|
anUpdatedScript += "\n\t\tsmeshgui.SetName(salome.ObjectToID(";
|
|
|
|
anUpdatedScript += aName + "), \"" + aName + "\")";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
anUpdatedScript += "\n\n\t\tsalome.sg.updateObjBrowser(0)";
|
|
|
|
|
|
|
|
anUpdatedScript += "\n\n\tpass\n";
|
|
|
|
|
|
|
|
aValidScript = true;
|
|
|
|
|
|
|
|
return anUpdatedScript;
|
|
|
|
}
|
|
|
|
|
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* GetNewPythonLines
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
TCollection_AsciiString SMESH_Gen_i::GetNewPythonLines (int theStudyID)
|
|
|
|
{
|
|
|
|
TCollection_AsciiString aScript;
|
|
|
|
|
|
|
|
// Dump trace of API methods calls
|
|
|
|
if (myPythonScripts.find(theStudyID) != myPythonScripts.end()) {
|
|
|
|
Handle(TColStd_HSequenceOfAsciiString) aPythonScript = myPythonScripts[theStudyID];
|
|
|
|
Standard_Integer istr, aLen = aPythonScript->Length();
|
|
|
|
for (istr = 1; istr <= aLen; istr++) {
|
|
|
|
aScript += "\n\t";
|
|
|
|
aScript += aPythonScript->Value(istr);
|
|
|
|
}
|
|
|
|
aScript += "\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
return aScript;
|
|
|
|
}
|
|
|
|
|
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* CleanPythonTrace
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
void SMESH_Gen_i::CleanPythonTrace (int theStudyID)
|
|
|
|
{
|
|
|
|
TCollection_AsciiString aScript;
|
|
|
|
|
|
|
|
// Clean trace of API methods calls
|
|
|
|
if (myPythonScripts.find(theStudyID) != myPythonScripts.end()) {
|
|
|
|
myPythonScripts[theStudyID]->Clear();
|
|
|
|
}
|
|
|
|
}
|