]> SALOME platform Git repositories - modules/smesh.git/commitdiff
Salome HOME
best enregistreResultat
authorcvw <cvw>
Wed, 5 Jun 2013 10:54:50 +0000 (10:54 +0000)
committercvw <cvw>
Wed, 5 Jun 2013 10:54:50 +0000 (10:54 +0000)
src/Tools/YamsPlug/monViewText.py
src/Tools/YamsPlug/monYamsPlugDialog.py

index 2151fe9a11fc851106772102ef9419609f43cfbf..ce291033bc4186568c9ee5b1a289d33a889f448a 100644 (file)
@@ -1,4 +1,4 @@
-# -*- coding: iso-8859-1 -*-
+# -*- coding: utf-8 -*-
 # Copyright (C) 2007-2013  EDF R&D
 #
 # This library is free software; you can redistribute it and/or
@@ -30,19 +30,19 @@ from PyQt4.QtCore import *
 
 from ViewText import Ui_ViewExe
 
-class MonViewText(Ui_ViewExe,QDialog):
+class MonViewText(Ui_ViewExe, QDialog):
     """
     Classe permettant la visualisation de texte
     """
-    def __init__(self,parent,txt):
+    def __init__(self, parent, txt):
         QDialog.__init__(self,parent)
         self.setupUi(self)
         self.resize( QSize(1000,600).expandedTo(self.minimumSizeHint()) )
-        self.connect( self.PB_Ok,SIGNAL("clicked()"), self, SLOT("close()") )
+        #self.connect( self.PB_Ok,SIGNAL("clicked()"), self, SLOT("close()") )
+        self.connect( self.PB_Ok,SIGNAL("clicked()"), self.theClose )
         self.connect( self.PB_Save,SIGNAL("clicked()"), self.saveFile )
         self.monExe=QProcess(self)
 
-
         self.connect(self.monExe, SIGNAL("readyReadStandardOutput()"), self.readFromStdOut )
         self.connect(self.monExe, SIGNAL("readyReadStandardError()"), self.readFromStdErr )
       
@@ -66,7 +66,9 @@ class MonViewText(Ui_ViewExe,QDialog):
         else:
           cmds+="# $DISTENE_PATH_FOR_YAMS NOT SET\n"
         #cmds+='env\n'
+        cmds+='rm -f '+self.parent().fichierOut+'\n'
         cmds+=txt+'\n'
+        cmds+='echo END_OF_Yams\n'
         pid=self.monExe.pid()
         nomFichier='/tmp/Yams_'+str(pid)+'.sh'
         f=open(nomFichier,'w')
@@ -76,9 +78,9 @@ class MonViewText(Ui_ViewExe,QDialog):
         maBidouille='sh  ' + nomFichier
         self.monExe.start(maBidouille)
         self.monExe.closeWriteChannel()
+        self.enregistreResultatsDone=False
         self.show()
 
-        
     def saveFile(self):
         #recuperation du nom du fichier
         savedir=os.environ['HOME']
@@ -96,8 +98,19 @@ class MonViewText(Ui_ViewExe,QDialog):
 
     def readFromStdErr(self):
         a=self.monExe.readAllStandardError()
-        self.TB_Exe.append(QString.fromUtf8(a.data(),len(a))) ;
+        self.TB_Exe.append(QString.fromUtf8(a.data(),len(a)))
 
     def readFromStdOut(self) :
         a=self.monExe.readAllStandardOutput()
-        self.TB_Exe.append(QString.fromUtf8(a.data(),len(a))) ;
+        aa=QString.fromUtf8(a.data(),len(a))
+        self.TB_Exe.append(aa)
+        if "END_OF_Yams" in aa:
+          self.parent().enregistreResultat()
+          self.enregistreResultatsDone=True
+          #self.theClose()
+    
+    def theClose(self):
+      if not self.enregistreResultatsDone:
+        self.parent().enregistreResultat()
+        self.enregistreResultatsDone=True
+      self.close()
index d77b1b08a421c83a1f4dbc0d9f0edadb879c98dc..1518ae9f535f7f1db83ff27388a3e4c13113e67d 100644 (file)
@@ -97,15 +97,18 @@ class MonYamsPlugDialog(Ui_YamsPlugDialog,QWidget):
     try :
       mydir=os.environ["SMESH_ROOT_DIR"]
     except Exception:
-      QMessageBox.warning( self, "Help unavailable $SMESH_ROOT_DIR not found")
+      QMessageBox.warning(self, "Help", "Help unavailable $SMESH_ROOT_DIR not found")
+      return
     maDoc=mydir+"/share/doc/salome/gui/SMESH/yams/_downloads/YamsWhitePaper_3.2.pdf"
     command="xdg-open "+maDoc+";"
     subprocess.call(command, shell=True)
 
   def PBOKPressed(self):
-    if not(self.PrepareLigneCommande()) : return
+    if not(self.PrepareLigneCommande()):
+      #warning done yet
+      #QMessageBox.warning(self, "Compute", "Command not found")
+      return
     maFenetre=MonViewText(self,self.commande)
-    if os.path.isfile(self.fichierOut): self.enregistreResultat()
 
   def enregistreResultat(self):
     import smesh
@@ -113,6 +116,9 @@ class MonYamsPlugDialog(Ui_YamsPlugDialog,QWidget):
     import salome
     from salome.kernel import studyedit
 
+    if not os.path.isfile(self.fichierOut):
+      QMessageBox.warning(self, "Compute", "Result file "+self.fichierOut+" not found")
+
     maStudy=studyedit.getActiveStudy()
     smesh.SetCurrentStudy(maStudy)
     (outputMesh, status) = smesh.CreateMeshesFromGMF(self.fichierOut)
@@ -327,7 +333,7 @@ class MonYamsPlugDialog(Ui_YamsPlugDialog,QWidget):
       self.MeshIn=""
       self.LE_MeshSmesh.setText("")
       return
-    QMessageBox.warning( self, "Unknown File", "File doesn't exist")
+    QMessageBox.warning(self, "Mesh file", "File doesn't exist")
 
   def meshSmeshNameChanged(self):
     """only change by GUI mouse selection, otherwise clear"""
@@ -396,7 +402,7 @@ class MonYamsPlugDialog(Ui_YamsPlugDialog,QWidget):
     self.commande+=" -O "+self.style.toLatin1()
 
     deb=os.path.splitext(self.fichierIn)
-    self.fichierOut=deb[0]+".d.meshb"
+    self.fichierOut=deb[0] + ".d.meshb"
 
     if self.RB_Absolute.isChecked()==True :
         self.commande+=" -Dabsolute"