-// Copyright (C) 2014-20xx CEA/DEN, EDF R&D
-
-#include "NewGeom_DataModel.h"
-#include "NewGeom_Module.h"
+// Copyright (C) 2014-2017 CEA/DEN, EDF R&D
+//
+// This library is free software; you can redistribute it and/or
+// modify it under the terms of the GNU Lesser General Public
+// License as published by the Free Software Foundation; either
+// version 2.1 of the License, or (at your option) any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+// Lesser General Public License for more details.
+//
+// You should have received a copy of the GNU Lesser General Public
+// License along with this library; if not, write to the Free Software
+// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+//
+// See http://www.salome-platform.org/ or
+// email : webmaster.salome@opencascade.com<mailto:webmaster.salome@opencascade.com>
+//
+
+#include "SHAPERGUI_DataModel.h"
+#include "SHAPERGUI.h"
#include <XGUI_Workshop.h>
#include <ModelAPI_Session.h>
+#include <ModelAPI_AttributeString.h>
+#include <ExchangePlugin_Dump.h>
#include <LightApp_Study.h>
#include <CAM_Application.h>
#include <QFile>
#include <QDir>
+#include <QTextStream>
+
+#define DUMP_NAME "shaper_dump.py"
+
-NewGeom_DataModel::NewGeom_DataModel(NewGeom_Module* theModule)
+SHAPERGUI_DataModel::SHAPERGUI_DataModel(SHAPERGUI* theModule)
: LightApp_DataModel(theModule), myStudyPath(""), myModule(theModule)
{
}
-NewGeom_DataModel::~NewGeom_DataModel()
+SHAPERGUI_DataModel::~SHAPERGUI_DataModel()
{
}
-bool NewGeom_DataModel::open(const QString& thePath, CAM_Study* theStudy, QStringList theFiles)
+bool SHAPERGUI_DataModel::open(const QString& thePath, CAM_Study* theStudy, QStringList theFiles)
{
LightApp_DataModel::open( thePath, theStudy, theFiles );
if (theFiles.size() == 0)
// If the file is Multi(contain all module files inside), the open SALOME functionality creates
// these files in a temporary directory. After the open functionality is finished, it removes
// these files (in the full SALOME mode).
- // The postponed loading of the files is realized in the NewGEOM module. So, it is important do
+ // The postponed loading of the files is realized in the SHAPER module. So, it is important do
// not remove the opened files.
// The following code creates a new tmp directory with a copy of files.
QString aTmpDir = theFiles.first();
return true;
}
-bool NewGeom_DataModel::save(QStringList& theFiles)
+bool SHAPERGUI_DataModel::save(QStringList& theFiles)
{
LightApp_DataModel::save( theFiles );
XGUI_Workshop* aWorkShop = myModule->workshop();
return true;
}
-bool NewGeom_DataModel::saveAs(const QString& thePath, CAM_Study* theStudy, QStringList& theFiles)
+bool SHAPERGUI_DataModel::saveAs(const QString& thePath, CAM_Study* theStudy, QStringList& theFiles)
{
myStudyPath = thePath;
return save(theFiles);
}
-bool NewGeom_DataModel::close()
+bool SHAPERGUI_DataModel::close()
{
myModule->workshop()->closeDocument();
removeDirectory(myTmpDirectory);
return LightApp_DataModel::close();
}
-bool NewGeom_DataModel::create(CAM_Study* theStudy)
+bool SHAPERGUI_DataModel::create(CAM_Study* theStudy)
{
return true;
}
-bool NewGeom_DataModel::isModified() const
+bool SHAPERGUI_DataModel::isModified() const
{
SessionPtr aMgr = ModelAPI_Session::get();
return aMgr->isModified();
}
-bool NewGeom_DataModel::isSaved() const
+bool SHAPERGUI_DataModel::isSaved() const
{
return !isModified();
}
-void NewGeom_DataModel::update(LightApp_DataObject* theObj, LightApp_Study* theStudy)
+void SHAPERGUI_DataModel::update(LightApp_DataObject* theObj, LightApp_Study* theStudy)
{
// Nothing to do here: we always keep the data tree in the up-to-date state
// The only goal of this method is to hide default behavior from LightApp_DataModel
return;
}
-void NewGeom_DataModel::initRootObject()
+void SHAPERGUI_DataModel::initRootObject()
{
LightApp_Study* study = dynamic_cast<LightApp_Study*>( module()->application()->activeStudy() );
CAM_ModuleObject *aModelRoot = dynamic_cast<CAM_ModuleObject*>(root());
}
}
-void NewGeom_DataModel::removeDirectory(const QString& theDirectoryName)
+void SHAPERGUI_DataModel::removeDirectory(const QString& theDirectoryName)
{
Qtx::rmDir(theDirectoryName);
}
+bool SHAPERGUI_DataModel::dumpPython(const QString& thePath, CAM_Study* theStudy,
+ bool isMultiFile, QStringList& theListOfFiles)
+{
+ LightApp_Study* aStudy = dynamic_cast<LightApp_Study*>(theStudy);
+ if (!aStudy)
+ return false;
+
+ std::shared_ptr<ModelAPI_Document> aDoc = ModelAPI_Session::get()->activeDocument();
+ ModelAPI_Session::get()->startOperation(ExchangePlugin_Dump::ID());
+ FeaturePtr aFeature = aDoc->addFeature(ExchangePlugin_Dump::ID());
+ if (aFeature.get()) {
+ std::string aTmpDir = aStudy->GetTmpDir(thePath.toStdString().c_str(), isMultiFile);
+ std::string aFileName = aTmpDir + DUMP_NAME;
+
+ if (QFile::exists(aFileName.c_str())) {
+ QFile::remove(aFileName.c_str());
+ }
+
+ AttributeStringPtr aAttr = aFeature->string(ExchangePlugin_Dump::FILE_PATH_ID());
+ if (aAttr.get())
+ aAttr->setValue(aFileName);
+
+ aAttr = aFeature->string(ExchangePlugin_Dump::FILE_FORMAT_ID());
+ if (aAttr.get())
+ aAttr->setValue(".py");
+ ModelAPI_Session::get()->finishOperation();
+
+ if (QFile::exists(aFileName.c_str())) {
+ if (isMultiFile) {
+ QFile aInFile(aFileName.c_str());
+ if (!aInFile.open(QIODevice::ReadOnly | QIODevice::Text))
+ return false;
+ QTextStream aText(&aInFile);
+ QString aTrace(aText.readAll());
+ aInFile.close();
+
+ QStringList aBuffer;
+ aBuffer.push_back(QString("def RebuildData( theStudy ):"));
+ QStringList aList(aTrace.split("\n"));
+ foreach(QString aStr, aList) {
+ QString s = " " + aStr;
+ aBuffer.push_back(s);
+ }
+ aTrace = aBuffer.join("\n");
+
+ QFile aOutFile(aFileName.c_str());
+ if (!aOutFile.open(QIODevice::WriteOnly | QIODevice::Text | QIODevice::Truncate))
+ return false;
+
+ QTextStream aOut(&aOutFile);
+ aOut << aTrace.toStdString().c_str() << "\n";
+ aOut.flush();
+ aOutFile.close();
+ }
+ theListOfFiles.append(aTmpDir.c_str());
+ theListOfFiles.append(DUMP_NAME);
+ return true;
+ }
+ }
+ return false;
+}
+