Salome HOME
Issue #1713: Provide Dump for Shaper module
authorvsv <vitaly.smetannikov@opencascade.com>
Mon, 5 Sep 2016 13:54:23 +0000 (16:54 +0300)
committervsv <vitaly.smetannikov@opencascade.com>
Mon, 5 Sep 2016 13:54:46 +0000 (16:54 +0300)
src/SHAPERGUI/CMakeLists.txt
src/SHAPERGUI/SHAPERGUI_DataModel.cpp
src/SHAPERGUI/SHAPERGUI_DataModel.h

index a7546df0b6c8fb0359b0afba2e850b62e8a3fd36..cc819f8b67fd37d2abb1350f76f35b62e212d744 100644 (file)
@@ -53,6 +53,7 @@ INCLUDE_DIRECTORIES(${PROJECT_SOURCE_DIR}/src/XGUI
                     ${PROJECT_SOURCE_DIR}/src/ModelAPI
                     ${PROJECT_SOURCE_DIR}/src/GeomAPI
                     ${PROJECT_SOURCE_DIR}/src/Config
+                                       ${PROJECT_SOURCE_DIR}/src/ExchangePlugin
                                        ${SALOME_GUI_INCLUDE}
                                        ${SALOME_KERNEL_INCLUDE}
                     ${CAS_INCLUDE_DIRS}
index df6a6ae3fc9e2b57234cb7bda2df30b36812afe5..ac9a06edc83aca8e048e79dc0aed2db0ee98d145 100644 (file)
@@ -6,6 +6,8 @@
 #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"
+
 
 SHAPERGUI_DataModel::SHAPERGUI_DataModel(SHAPERGUI* theModule)
     : LightApp_DataModel(theModule), myStudyPath(""), myModule(theModule)
@@ -153,3 +159,65 @@ 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;
+}
+
index 2383f832bd9bbb99ec989a85c51d5b7678a29d63..5672caae7e77b8b157d9ea39df0d236c43a0de02 100644 (file)
@@ -61,6 +61,9 @@ class SHAPERGUI_EXPORT SHAPERGUI_DataModel : public LightApp_DataModel
   /// \param theStudy a current study
   virtual void update(LightApp_DataObject* theObj = 0, LightApp_Study* theStudy = 0);
 
+  /// Redefinition of virtual method: include the module dump in the common SALOME dump
+  virtual bool dumpPython( const QString&, CAM_Study*, bool,  QStringList& );
+
 protected:
   /**
    * Removes the directory with content if it exists