mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-29 01:00:33 +05:00
Dump Python extension
This commit is contained in:
parent
18ef07bc79
commit
490a83efa8
@ -125,7 +125,7 @@ SMESH_2smeshpy::ConvertScript(const TCollection_AsciiString& theScript,
|
|||||||
{
|
{
|
||||||
theGen = new _pyGen( theEntry2AccessorMethod );
|
theGen = new _pyGen( theEntry2AccessorMethod );
|
||||||
|
|
||||||
SMESH_NoteBook * aNoteBook = new SMESH_NoteBook();
|
SMESH_NoteBook * aNoteBook = new SMESH_NoteBook( theGen );
|
||||||
|
|
||||||
// split theScript into separate commands
|
// split theScript into separate commands
|
||||||
int from = 1, end = theScript.Length(), to;
|
int from = 1, end = theScript.Length(), to;
|
||||||
@ -1916,7 +1916,8 @@ void _pyCommand::SetArg( int index, const TCollection_AsciiString& theArg)
|
|||||||
if ( pos < 1 ) // no index-th arg exist, append inexistent args
|
if ( pos < 1 ) // no index-th arg exist, append inexistent args
|
||||||
{
|
{
|
||||||
// find a closing parenthesis
|
// find a closing parenthesis
|
||||||
if ( int lastArgInd = GetNbArgs() ) {
|
if ( GetNbArgs() != 0 && index <= GetNbArgs() ) {
|
||||||
|
int lastArgInd = GetNbArgs();
|
||||||
pos = GetBegPos( ARG1_IND + lastArgInd - 1 ) + GetArg( lastArgInd ).Length();
|
pos = GetBegPos( ARG1_IND + lastArgInd - 1 ) + GetArg( lastArgInd ).Length();
|
||||||
while ( pos > 0 && pos <= Length() && myString.Value( pos ) != ')' )
|
while ( pos > 0 && pos <= Length() && myString.Value( pos ) != ')' )
|
||||||
++pos;
|
++pos;
|
||||||
|
@ -186,6 +186,7 @@ public:
|
|||||||
bool AddMeshAccessorMethod( Handle(_pyCommand) theCmd ) const;
|
bool AddMeshAccessorMethod( Handle(_pyCommand) theCmd ) const;
|
||||||
bool AddAlgoAccessorMethod( Handle(_pyCommand) theCmd ) const;
|
bool AddAlgoAccessorMethod( Handle(_pyCommand) theCmd ) const;
|
||||||
const char* AccessorMethod() const;
|
const char* AccessorMethod() const;
|
||||||
|
const std::map< _pyID, Handle(_pyMeshEditor) >& getMeshEditors() const { return myMeshEditors; }
|
||||||
private:
|
private:
|
||||||
std::map< _pyID, Handle(_pyMesh) > myMeshes;
|
std::map< _pyID, Handle(_pyMesh) > myMeshes;
|
||||||
std::map< _pyID, Handle(_pyMeshEditor) > myMeshEditors;
|
std::map< _pyID, Handle(_pyMeshEditor) > myMeshEditors;
|
||||||
|
@ -878,32 +878,28 @@ void SMESH_Gen_i::UpdateParameters(CORBA::Object_ptr theObject, const char* theP
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
SALOMEDS::StudyBuilder_var aStudyBuilder = aStudy->NewBuilder();
|
SALOMEDS::StudyBuilder_var aStudyBuilder = aStudy->NewBuilder();
|
||||||
SMESH::SMESH_Hypothesis_var aHyp = SMESH::SMESH_Hypothesis::_narrow( theObject );
|
|
||||||
|
|
||||||
if ( !aHyp->_is_nil() ) {
|
TCollection_AsciiString aNewParams;
|
||||||
CORBA::String_var objStr = aHyp->GetParameters();
|
TCollection_AsciiString anInputParams;
|
||||||
TCollection_AsciiString aNewParams;
|
SALOMEDS::ListOfListOfStrings_var aSections = aStudy->ParseVariables(theParameters);
|
||||||
TCollection_AsciiString anInputParams;
|
|
||||||
SALOMEDS::ListOfListOfStrings_var aSections = aStudy->ParseVariables(theParameters);
|
|
||||||
|
|
||||||
SALOMEDS::GenericAttribute_var anAttr;
|
SALOMEDS::GenericAttribute_var anAttr;
|
||||||
anAttr = aStudyBuilder->FindOrCreateAttribute( aSObj, "AttributeString");
|
anAttr = aStudyBuilder->FindOrCreateAttribute( aSObj, "AttributeString");
|
||||||
SALOMEDS::AttributeString_var aStringAttr = SALOMEDS::AttributeString::_narrow(anAttr);
|
SALOMEDS::AttributeString_var aStringAttr = SALOMEDS::AttributeString::_narrow(anAttr);
|
||||||
TCollection_AsciiString aOldParameters(aStringAttr->Value());
|
TCollection_AsciiString aOldParameters(aStringAttr->Value());
|
||||||
SALOMEDS::ListOfStrings aVars= aSections[0];
|
SALOMEDS::ListOfStrings aVars= aSections[0];
|
||||||
for(int i=0;i<aVars.length();i++ ) {
|
for(int i=0;i<aVars.length();i++ ) {
|
||||||
anInputParams += aStudy->IsVariable(aVars[i].in()) ?
|
anInputParams += aStudy->IsVariable(aVars[i].in()) ?
|
||||||
TCollection_AsciiString(aVars[i].in()) : TCollection_AsciiString("");
|
TCollection_AsciiString(aVars[i].in()) : TCollection_AsciiString("");
|
||||||
if(i != aVars.length()-1)
|
if(i != aVars.length()-1)
|
||||||
anInputParams+=":";
|
anInputParams+=":";
|
||||||
}
|
|
||||||
if(!aOldParameters.Length())
|
|
||||||
aNewParams = anInputParams;
|
|
||||||
else
|
|
||||||
aNewParams = aOldParameters+"|"+anInputParams;
|
|
||||||
|
|
||||||
aStringAttr->SetValue( aNewParams.ToCString() );
|
|
||||||
}
|
}
|
||||||
|
if(!aOldParameters.Length())
|
||||||
|
aNewParams = anInputParams;
|
||||||
|
else
|
||||||
|
aNewParams = aOldParameters+"|"+anInputParams;
|
||||||
|
|
||||||
|
aStringAttr->SetValue( aNewParams.ToCString() );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -917,12 +913,10 @@ char* SMESH_Gen_i::GetParameters(CORBA::Object_ptr theObject)
|
|||||||
|
|
||||||
SALOMEDS::Study_ptr aStudy = GetCurrentStudy();
|
SALOMEDS::Study_ptr aStudy = GetCurrentStudy();
|
||||||
SALOMEDS::SObject_var aSObj = ObjectToSObject(aStudy,theObject);
|
SALOMEDS::SObject_var aSObj = ObjectToSObject(aStudy,theObject);
|
||||||
SMESH::SMESH_Hypothesis_var aHyp = SMESH::SMESH_Hypothesis::_narrow( theObject );
|
|
||||||
|
|
||||||
if(!aStudy->_is_nil() &&
|
if(!aStudy->_is_nil() &&
|
||||||
!CORBA::is_nil(theObject) &&
|
!CORBA::is_nil(theObject) &&
|
||||||
!aSObj->_is_nil() &&
|
!aSObj->_is_nil()){
|
||||||
!aHyp->_is_nil()){
|
|
||||||
|
|
||||||
SALOMEDS::GenericAttribute_var anAttr;
|
SALOMEDS::GenericAttribute_var anAttr;
|
||||||
if ( aSObj->FindAttribute(anAttr, "AttributeString")) {
|
if ( aSObj->FindAttribute(anAttr, "AttributeString")) {
|
||||||
|
@ -2452,10 +2452,9 @@ void SMESH_MeshEditor_i::Translate(const SMESH::long_array & theIDsOfElements,
|
|||||||
CORBA::Boolean theCopy)
|
CORBA::Boolean theCopy)
|
||||||
{
|
{
|
||||||
if ( !myPreviewMode ) {
|
if ( !myPreviewMode ) {
|
||||||
TPythonDump() << "vector = " << theVector;
|
|
||||||
TPythonDump() << this << ".Translate( "
|
TPythonDump() << this << ".Translate( "
|
||||||
<< theIDsOfElements
|
<< theIDsOfElements << ", "
|
||||||
<< ", vector, "
|
<< theVector << ", "
|
||||||
<< theCopy << " )";
|
<< theCopy << " )";
|
||||||
}
|
}
|
||||||
translate(theIDsOfElements,
|
translate(theIDsOfElements,
|
||||||
@ -2475,8 +2474,8 @@ void SMESH_MeshEditor_i::TranslateObject(SMESH::SMESH_IDSource_ptr theObject,
|
|||||||
{
|
{
|
||||||
if ( !myPreviewMode ) {
|
if ( !myPreviewMode ) {
|
||||||
TPythonDump() << this << ".TranslateObject( "
|
TPythonDump() << this << ".TranslateObject( "
|
||||||
<< theObject
|
<< theObject << ", "
|
||||||
<< ", vector, "
|
<< theVector << ", "
|
||||||
<< theCopy << " )";
|
<< theCopy << " )";
|
||||||
}
|
}
|
||||||
SMESH::long_array_var anElementsId = theObject->GetIDs();
|
SMESH::long_array_var anElementsId = theObject->GetIDs();
|
||||||
@ -2497,12 +2496,11 @@ SMESH_MeshEditor_i::TranslateMakeGroups(const SMESH::long_array& theIDsOfElement
|
|||||||
{
|
{
|
||||||
SMESH::ListOfGroups * aGroups = translate(theIDsOfElements,theVector,true,true);
|
SMESH::ListOfGroups * aGroups = translate(theIDsOfElements,theVector,true,true);
|
||||||
if ( !myPreviewMode ) {
|
if ( !myPreviewMode ) {
|
||||||
TPythonDump() << "vector = " << theVector;
|
|
||||||
TPythonDump aPythonDump;
|
TPythonDump aPythonDump;
|
||||||
DumpGroupsList(aPythonDump,aGroups);
|
DumpGroupsList(aPythonDump,aGroups);
|
||||||
aPythonDump << this << ".TranslateMakeGroups( "
|
aPythonDump << this << ".TranslateMakeGroups( "
|
||||||
<< theIDsOfElements
|
<< theIDsOfElements << ", "
|
||||||
<< ", vector )";
|
<< theVector << " )";
|
||||||
}
|
}
|
||||||
return aGroups;
|
return aGroups;
|
||||||
}
|
}
|
||||||
@ -2521,12 +2519,11 @@ SMESH_MeshEditor_i::TranslateObjectMakeGroups(SMESH::SMESH_IDSource_ptr theObjec
|
|||||||
|
|
||||||
if ( !myPreviewMode ) {
|
if ( !myPreviewMode ) {
|
||||||
|
|
||||||
TPythonDump() << "vector = " << theVector;
|
|
||||||
TPythonDump aPythonDump;
|
TPythonDump aPythonDump;
|
||||||
DumpGroupsList(aPythonDump,aGroups);
|
DumpGroupsList(aPythonDump,aGroups);
|
||||||
aPythonDump << this << ".TranslateObjectMakeGroups( "
|
aPythonDump << this << ".TranslateObjectMakeGroups( "
|
||||||
<< theObject
|
<< theObject << ", "
|
||||||
<< ", vector )";
|
<< theVector << " )";
|
||||||
}
|
}
|
||||||
return aGroups;
|
return aGroups;
|
||||||
}
|
}
|
||||||
|
@ -2535,3 +2535,50 @@ SALOME_MED::MedFileInfo* SMESH_Mesh_i::GetMEDFileInfo()
|
|||||||
}
|
}
|
||||||
return res._retn();
|
return res._retn();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//=============================================================================
|
||||||
|
/*!
|
||||||
|
* \brief Sets list of notebook variables used for Mesh operations separated by ":" symbol
|
||||||
|
*/
|
||||||
|
//=============================================================================
|
||||||
|
void SMESH_Mesh_i::SetParameters(const char* theParameters)
|
||||||
|
{
|
||||||
|
SMESH_Gen_i::GetSMESHGen()->UpdateParameters(SMESH::SMESH_Mesh::_narrow(_this()),
|
||||||
|
CORBA::string_dup(theParameters));
|
||||||
|
}
|
||||||
|
|
||||||
|
//=============================================================================
|
||||||
|
/*!
|
||||||
|
* \brief Returns list of notebook variables used for Mesh operations separated by ":" symbol
|
||||||
|
*/
|
||||||
|
//=============================================================================
|
||||||
|
char* SMESH_Mesh_i::GetParameters()
|
||||||
|
{
|
||||||
|
SMESH_Gen_i *gen = SMESH_Gen_i::GetSMESHGen();
|
||||||
|
return CORBA::string_dup(gen->GetParameters(SMESH::SMESH_Mesh::_narrow(_this())));
|
||||||
|
}
|
||||||
|
|
||||||
|
//=============================================================================
|
||||||
|
/*!
|
||||||
|
* \brief Returns list of notebook variables used for last Mesh operation
|
||||||
|
*/
|
||||||
|
//=============================================================================
|
||||||
|
SMESH::string_array* SMESH_Mesh_i::GetLastParameters()
|
||||||
|
{
|
||||||
|
SMESH::string_array_var aResult = new SMESH::string_array();
|
||||||
|
SMESH_Gen_i *gen = SMESH_Gen_i::GetSMESHGen();
|
||||||
|
if(gen) {
|
||||||
|
char *aParameters = GetParameters();
|
||||||
|
SALOMEDS::Study_ptr aStudy = gen->GetCurrentStudy();
|
||||||
|
if(!aStudy->_is_nil()) {
|
||||||
|
SALOMEDS::ListOfListOfStrings_var aSections = aStudy->ParseVariables(aParameters);
|
||||||
|
if(aSections->length() > 0) {
|
||||||
|
SALOMEDS::ListOfStrings aVars = aSections[aSections->length()-1];
|
||||||
|
aResult->length(aVars.length());
|
||||||
|
for(int i = 0;i < aVars.length();i++)
|
||||||
|
aResult[i] = CORBA::string_dup( aVars[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return aResult._retn();
|
||||||
|
}
|
||||||
|
@ -446,6 +446,21 @@ public:
|
|||||||
*/
|
*/
|
||||||
virtual SALOME_MED::MedFileInfo* GetMEDFileInfo();
|
virtual SALOME_MED::MedFileInfo* GetMEDFileInfo();
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* Sets list of notebook variables used for Mesh operations separated by ":" symbol
|
||||||
|
*/
|
||||||
|
void SetParameters (const char* theParameters);
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* Returns list of notebook variables used for Mesh operations separated by ":" symbol
|
||||||
|
*/
|
||||||
|
char* GetParameters();
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* Returns list of notebook variables used for last Mesh operation
|
||||||
|
*/
|
||||||
|
SMESH::string_array* GetLastParameters();
|
||||||
|
|
||||||
std::map<int, SMESH_subMesh_i*> _mapSubMesh_i; //NRI
|
std::map<int, SMESH_subMesh_i*> _mapSubMesh_i; //NRI
|
||||||
std::map<int, ::SMESH_subMesh*> _mapSubMesh; //NRI
|
std::map<int, ::SMESH_subMesh*> _mapSubMesh; //NRI
|
||||||
|
|
||||||
|
@ -23,6 +23,7 @@
|
|||||||
#include "SMESH_2smeshpy.hxx"
|
#include "SMESH_2smeshpy.hxx"
|
||||||
#include "SMESH_NoteBook.hxx"
|
#include "SMESH_NoteBook.hxx"
|
||||||
#include "SMESH_Gen_i.hxx"
|
#include "SMESH_Gen_i.hxx"
|
||||||
|
#include "SMESH_PythonDump.hxx"
|
||||||
|
|
||||||
#include <Resource_DataMapOfAsciiStringAsciiString.hxx>
|
#include <Resource_DataMapOfAsciiStringAsciiString.hxx>
|
||||||
#include <TColStd_SequenceOfAsciiString.hxx>
|
#include <TColStd_SequenceOfAsciiString.hxx>
|
||||||
@ -118,7 +119,8 @@ TCollection_AsciiString ObjectStates::GetObjectType() const{
|
|||||||
* \brief Constructor
|
* \brief Constructor
|
||||||
*/
|
*/
|
||||||
//================================================================================
|
//================================================================================
|
||||||
SMESH_NoteBook::SMESH_NoteBook()
|
SMESH_NoteBook::SMESH_NoteBook(Handle(_pyGen) theGen):
|
||||||
|
myGen( theGen )
|
||||||
{
|
{
|
||||||
InitObjectMap();
|
InitObjectMap();
|
||||||
}
|
}
|
||||||
@ -149,24 +151,73 @@ TCollection_AsciiString SMESH_NoteBook::ReplaceVariables(const TCollection_Ascii
|
|||||||
_pyCommand aCmd( theString, -1);
|
_pyCommand aCmd( theString, -1);
|
||||||
TCollection_AsciiString aMethod = aCmd.GetMethod();
|
TCollection_AsciiString aMethod = aCmd.GetMethod();
|
||||||
TCollection_AsciiString aObject = aCmd.GetObject();
|
TCollection_AsciiString aObject = aCmd.GetObject();
|
||||||
|
TCollection_AsciiString aResultValue = aCmd.GetResultValue();
|
||||||
|
if(aMethod.IsEmpty())
|
||||||
|
return theString;
|
||||||
|
|
||||||
|
// check if method modifies the object itself
|
||||||
TVariablesMap::const_iterator it = _objectMap.find(aObject);
|
TVariablesMap::const_iterator it = _objectMap.find(aObject);
|
||||||
if(!aMethod.IsEmpty() && it != _objectMap.end() ) {
|
if(it == _objectMap.end()) // check if method returns a new object
|
||||||
|
it = _objectMap.find(aResultValue);
|
||||||
|
|
||||||
|
if(it == _objectMap.end()) { // check if method modifies a mesh using mesh editor
|
||||||
|
const std::map< _pyID, Handle(_pyMeshEditor) >& aMeshEditors = myGen->getMeshEditors();
|
||||||
|
std::map< _pyID, Handle(_pyMeshEditor) >::const_iterator meIt = aMeshEditors.find(aObject);
|
||||||
|
if(meIt != aMeshEditors.end()) {
|
||||||
|
Handle(_pyMeshEditor) aMeshEditor = (*meIt).second;
|
||||||
|
if(!aMeshEditor.IsNull()) {
|
||||||
|
Handle(_pyCommand) aCreationCommand = aMeshEditor->GetCreationCmd();
|
||||||
|
if(!aCreationCommand.IsNull()) {
|
||||||
|
TCollection_AsciiString aMesh = aCreationCommand->GetObject();
|
||||||
|
it = _objectMap.find(aMesh);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(it != _objectMap.end()) {
|
||||||
ObjectStates *aStates = (*it).second;
|
ObjectStates *aStates = (*it).second;
|
||||||
bool modified = false;
|
|
||||||
if(MYDEBUG)
|
if(MYDEBUG)
|
||||||
cout<<"SMESH_NoteBook::ReplaceVariables :Object Type : "<<aStates->GetObjectType()<<endl;
|
cout<<"SMESH_NoteBook::ReplaceVariables :Object Type : "<<aStates->GetObjectType()<<endl;
|
||||||
if(aStates->GetObjectType().IsEqual("LocalLength")) {
|
if(aStates->GetObjectType().IsEqual("LocalLength")) {
|
||||||
if(aMethod == "SetLength") {
|
if(aMethod.IsEqual("SetLength")) {
|
||||||
if(!aStates->GetCurrectState().at(0).IsEmpty() )
|
if(!aStates->GetCurrectState().at(0).IsEmpty() )
|
||||||
aCmd.SetArg(1,aStates->GetCurrectState().at(0));
|
aCmd.SetArg(1,aStates->GetCurrectState().at(0));
|
||||||
aStates->IncrementState();
|
aStates->IncrementState();
|
||||||
}
|
}
|
||||||
else if(aMethod == "SetPrecision") {
|
else if(aMethod.IsEqual("SetPrecision")) {
|
||||||
if(!aStates->GetCurrectState().at(1).IsEmpty() )
|
if(!aStates->GetCurrectState().at(1).IsEmpty() )
|
||||||
aCmd.SetArg(1,aStates->GetCurrectState().at(1));
|
aCmd.SetArg(1,aStates->GetCurrectState().at(1));
|
||||||
aStates->IncrementState();
|
aStates->IncrementState();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else if(aStates->GetObjectType().IsEqual("Mesh")) {
|
||||||
|
if(aMethod.IsEqual("Translate") ||
|
||||||
|
aMethod.IsEqual("TranslateMakeGroups") ||
|
||||||
|
aMethod.IsEqual("TranslateMakeMesh")) {
|
||||||
|
bool isVariableFound = false;
|
||||||
|
int anArgIndex = 0;
|
||||||
|
for(int i = 1, n = aCmd.GetNbArgs(); i <= n; i++) {
|
||||||
|
if(aCmd.GetArg(i).IsEqual("SMESH.PointStruct")) {
|
||||||
|
anArgIndex = i+1;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(anArgIndex > 0) {
|
||||||
|
for(int j = 0; j <= 2; j++) {
|
||||||
|
if(!aStates->GetCurrectState().at(j).IsEmpty()) {
|
||||||
|
isVariableFound = true;
|
||||||
|
aCmd.SetArg(anArgIndex+j, aStates->GetCurrectState().at(j));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(isVariableFound) {
|
||||||
|
aCmd.SetArg(anArgIndex - 1, TCollection_AsciiString(SMESH_2smeshpy::SmeshpyName())+".PointStructStr");
|
||||||
|
aCmd.SetArg(anArgIndex - 2, TCollection_AsciiString(SMESH_2smeshpy::SmeshpyName())+".DirStructStr");
|
||||||
|
}
|
||||||
|
aStates->IncrementState();
|
||||||
|
}
|
||||||
|
}
|
||||||
return aCmd.GetString();
|
return aCmd.GetString();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -58,7 +58,7 @@ private:
|
|||||||
class SMESH_NoteBook
|
class SMESH_NoteBook
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
SMESH_NoteBook();
|
SMESH_NoteBook(Handle(_pyGen) theGen);
|
||||||
~SMESH_NoteBook();
|
~SMESH_NoteBook();
|
||||||
TCollection_AsciiString ReplaceVariables(const TCollection_AsciiString& theString) const;
|
TCollection_AsciiString ReplaceVariables(const TCollection_AsciiString& theString) const;
|
||||||
|
|
||||||
@ -69,6 +69,7 @@ private:
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
TVariablesMap _objectMap;
|
TVariablesMap _objectMap;
|
||||||
|
Handle(_pyGen) myGen;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif //SMESH_NoteBook_HeaderFile
|
#endif //SMESH_NoteBook_HeaderFile
|
||||||
|
@ -158,6 +158,47 @@ PrecisionConfusion = 1e-07
|
|||||||
# Salome notebook variable separator
|
# Salome notebook variable separator
|
||||||
variable_separator = ":"
|
variable_separator = ":"
|
||||||
|
|
||||||
|
# Parametrized substitute for PointStruct
|
||||||
|
class PointStructStr:
|
||||||
|
|
||||||
|
x = 0
|
||||||
|
y = 0
|
||||||
|
z = 0
|
||||||
|
xStr = ""
|
||||||
|
yStr = ""
|
||||||
|
zStr = ""
|
||||||
|
|
||||||
|
def __init__(self, xStr, yStr, zStr):
|
||||||
|
self.xStr = xStr
|
||||||
|
self.yStr = yStr
|
||||||
|
self.zStr = zStr
|
||||||
|
if isinstance(xStr, str) and notebook.isVariable(xStr):
|
||||||
|
self.x = notebook.get(xStr)
|
||||||
|
else:
|
||||||
|
self.x = xStr
|
||||||
|
if isinstance(yStr, str) and notebook.isVariable(yStr):
|
||||||
|
self.y = notebook.get(yStr)
|
||||||
|
else:
|
||||||
|
self.y = yStr
|
||||||
|
if isinstance(zStr, str) and notebook.isVariable(zStr):
|
||||||
|
self.z = notebook.get(zStr)
|
||||||
|
else:
|
||||||
|
self.z = zStr
|
||||||
|
|
||||||
|
# Parametrized substitute for DirStruct
|
||||||
|
class DirStructStr:
|
||||||
|
|
||||||
|
def __init__(self, pointStruct):
|
||||||
|
self.pointStruct = pointStruct
|
||||||
|
|
||||||
|
# Returns list of variable values from salome notebook
|
||||||
|
def ParseDirStruct(Vector):
|
||||||
|
pntStr = Vector.pointStruct
|
||||||
|
pnt = PointStruct(pntStr.x, pntStr.y, pntStr.z)
|
||||||
|
Vector = DirStruct(pnt)
|
||||||
|
Parameters = str(pntStr.xStr) + ":" + str(pntStr.yStr) + ":" + str(pntStr.zStr)
|
||||||
|
return Vector, Parameters
|
||||||
|
|
||||||
def IsEqual(val1, val2, tol=PrecisionConfusion):
|
def IsEqual(val1, val2, tol=PrecisionConfusion):
|
||||||
if abs(val1 - val2) < tol:
|
if abs(val1 - val2) < tol:
|
||||||
return True
|
return True
|
||||||
@ -2463,13 +2504,17 @@ class Mesh:
|
|||||||
# @return list of created groups (SMESH_GroupBase) if MakeGroups=True, empty list otherwise
|
# @return list of created groups (SMESH_GroupBase) if MakeGroups=True, empty list otherwise
|
||||||
# @ingroup l2_modif_trsf
|
# @ingroup l2_modif_trsf
|
||||||
def Translate(self, IDsOfElements, Vector, Copy, MakeGroups=False):
|
def Translate(self, IDsOfElements, Vector, Copy, MakeGroups=False):
|
||||||
|
Parameters = ""
|
||||||
if IDsOfElements == []:
|
if IDsOfElements == []:
|
||||||
IDsOfElements = self.GetElementsId()
|
IDsOfElements = self.GetElementsId()
|
||||||
if ( isinstance( Vector, geompyDC.GEOM._objref_GEOM_Object)):
|
if ( isinstance( Vector, geompyDC.GEOM._objref_GEOM_Object)):
|
||||||
Vector = self.smeshpyD.GetDirStruct(Vector)
|
Vector = self.smeshpyD.GetDirStruct(Vector)
|
||||||
|
elif ( isinstance( Vector, DirStructStr ) ):
|
||||||
|
Vector,Parameters = ParseDirStruct(Vector)
|
||||||
if Copy and MakeGroups:
|
if Copy and MakeGroups:
|
||||||
return self.editor.TranslateMakeGroups(IDsOfElements, Vector)
|
return self.editor.TranslateMakeGroups(IDsOfElements, Vector)
|
||||||
self.editor.Translate(IDsOfElements, Vector, Copy)
|
self.editor.Translate(IDsOfElements, Vector, Copy)
|
||||||
|
self.mesh.SetParameters(Parameters)
|
||||||
return []
|
return []
|
||||||
|
|
||||||
## Creates a new mesh of translated elements
|
## Creates a new mesh of translated elements
|
||||||
@ -2480,11 +2525,15 @@ class Mesh:
|
|||||||
# @return instance of Mesh class
|
# @return instance of Mesh class
|
||||||
# @ingroup l2_modif_trsf
|
# @ingroup l2_modif_trsf
|
||||||
def TranslateMakeMesh(self, IDsOfElements, Vector, MakeGroups=False, NewMeshName=""):
|
def TranslateMakeMesh(self, IDsOfElements, Vector, MakeGroups=False, NewMeshName=""):
|
||||||
|
Parameters = ""
|
||||||
if IDsOfElements == []:
|
if IDsOfElements == []:
|
||||||
IDsOfElements = self.GetElementsId()
|
IDsOfElements = self.GetElementsId()
|
||||||
if ( isinstance( Vector, geompyDC.GEOM._objref_GEOM_Object)):
|
if ( isinstance( Vector, geompyDC.GEOM._objref_GEOM_Object)):
|
||||||
Vector = self.smeshpyD.GetDirStruct(Vector)
|
Vector = self.smeshpyD.GetDirStruct(Vector)
|
||||||
|
elif ( isinstance( Vector, DirStructStr ) ):
|
||||||
|
Vector,Parameters = ParseDirStruct(Vector)
|
||||||
mesh = self.editor.TranslateMakeMesh(IDsOfElements, Vector, MakeGroups, NewMeshName)
|
mesh = self.editor.TranslateMakeMesh(IDsOfElements, Vector, MakeGroups, NewMeshName)
|
||||||
|
mesh.SetParameters(Parameters)
|
||||||
return Mesh ( self.smeshpyD, self.geompyD, mesh )
|
return Mesh ( self.smeshpyD, self.geompyD, mesh )
|
||||||
|
|
||||||
## Translates the object
|
## Translates the object
|
||||||
|
Loading…
Reference in New Issue
Block a user