PAL16617 (Modification/Transformation operations with copy don't create a new mesh)

+  QString UniqueMeshName(const char* theBaseName, const char* thePostfix);
This commit is contained in:
eap 2007-12-19 15:05:55 +00:00
parent 0ebaadef38
commit 92c5811d43
2 changed files with 27 additions and 0 deletions

View File

@ -20,6 +20,7 @@
#include "SMESHGUI_MeshUtils.h" #include "SMESHGUI_MeshUtils.h"
#include "SMESHGUI_Utils.h" #include "SMESHGUI_Utils.h"
#include "SALOMEDSClient_Study.hxx"
#include "SALOMEconfig.h" #include "SALOMEconfig.h"
#include CORBA_SERVER_HEADER(SMESH_Group) #include CORBA_SERVER_HEADER(SMESH_Group)
@ -44,4 +45,27 @@ namespace SMESH
return SMESH_Mesh::_nil(); return SMESH_Mesh::_nil();
} }
QString UniqueMeshName(const char* theBaseName, const char* thePostfix)
{
QString baseName = theBaseName;
if ( thePostfix/* && !name.contains( postfix )*/) { // add postfix
baseName += "_";
baseName += thePostfix;
}
if(_PTR(Study) aStudy = GetActiveStudyDocument()) {
QString name = baseName;
while ( !aStudy->FindObjectByName( name.latin1(), "SMESH" ).empty() ) {
int nb = 0;
if ( name[ name.length()-1 ].isNumber() ) {
int nbBeg = name.findRev("_");
nb = name.right( name.length() - nbBeg - 1 ).toInt();
name = name.left( nbBeg );
}
name += QString("_%1").arg( nb+1 );
}
return name;
}
return QString("");
}
} }

View File

@ -27,12 +27,15 @@
#include "SALOMEconfig.h" #include "SALOMEconfig.h"
#include CORBA_SERVER_HEADER(SMESH_Mesh) #include CORBA_SERVER_HEADER(SMESH_Mesh)
#include <qstring.h>
namespace SMESH{ namespace SMESH{
SMESHGUI_EXPORT SMESHGUI_EXPORT
SMESH_Mesh_var GetMeshByIO(const Handle(SALOME_InteractiveObject)& theIO); SMESH_Mesh_var GetMeshByIO(const Handle(SALOME_InteractiveObject)& theIO);
QString UniqueMeshName(const char* theBaseName, const char* thePostfix);
} }