X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FTools%2FMGCleanerPlug%2FMGCleanerMonViewText.py;h=01c53069d800ac41fd37ef4e0ba6393f8e8ed5de;hb=9b504e486741f715fe6169a33418954712c314c2;hp=64179ae4c74fa9d4256f899b6fdd942d9fb437e5;hpb=251f8c052dd12dd29922210dc901b295fe999a0e;p=modules%2Fsmesh.git diff --git a/src/Tools/MGCleanerPlug/MGCleanerMonViewText.py b/src/Tools/MGCleanerPlug/MGCleanerMonViewText.py index 64179ae4c..01c53069d 100644 --- a/src/Tools/MGCleanerPlug/MGCleanerMonViewText.py +++ b/src/Tools/MGCleanerPlug/MGCleanerMonViewText.py @@ -1,5 +1,5 @@ # -*- coding: utf-8 -*- -# Copyright (C) 2013-2015 EDF R&D +# Copyright (C) 2013-2016 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 @@ -19,17 +19,27 @@ # # Modules Python -import string,types,os +import os +import sys +import string +import types +import tempfile import traceback +import pprint as PP #pretty print -from PyQt4 import * -from PyQt4.QtGui import * -from PyQt4.QtCore import * +from qtsalome import * # Import des panels from MGCleanerViewText_ui import Ui_ViewExe +verbose = True + +force = os.getenv("FORCE_DISTENE_LICENSE_FILE") +if force != None: + os.environ["DISTENE_LICENSE_FILE"] = force + os.environ["DLIM8VAR"] = "NOTHING" + class MGCleanerMonViewText(Ui_ViewExe, QDialog): """ Classe permettant la visualisation de texte @@ -39,50 +49,60 @@ class MGCleanerMonViewText(Ui_ViewExe, QDialog): 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.theClose ) - self.connect( self.PB_Save,SIGNAL("clicked()"), self.saveFile ) + self.PB_Ok.clicked.connect( self.theClose ) + self.PB_Save.clicked.connect( self.saveFile ) self.PB_Save.setToolTip("Save trace in log file") self.PB_Ok.setToolTip("Close view") self.monExe=QProcess(self) - self.connect(self.monExe, SIGNAL("readyReadStandardOutput()"), self.readFromStdOut ) - self.connect(self.monExe, SIGNAL("readyReadStandardError()"), self.readFromStdErr ) - - # Je n arrive pas a utiliser le setEnvironment du QProcess - # fonctionne hors Salome mais pas dans Salome ??? - cmds='' - try : - LICENCE_FILE=os.environ["DISTENE_LICENCE_FILE_FOR_MGCLEANER"] - except: - LICENCE_FILE='' - try : - PATH=os.environ["DISTENE_PATH_FOR_MGCLEANER"] - except: - PATH='' - if LICENCE_FILE != '': - cmds+='source '+LICENCE_FILE+'\n' - else: - cmds+="# $DISTENE_LICENCE_FILE_FOR_MGCLEANER NOT SET\n" - if PATH != '': - cmds+='export PATH='+PATH+':$PATH\n' + self.monExe.readyReadStandardOutput.connect( self.readFromStdOut ) + self.monExe.readyReadStandardError.connect( self.readFromStdErr ) + self.monExe.finished.connect( self.finished ) + + """ for test set environment + env = QProcessEnvironment().systemEnvironment() + env.insert("HELLO", "bonjour") #Add an environment variable for debug + self.monExe.setProcessEnvironment(env) + if verbose: + PP.pprint([str(i) for i in sorted(self.monExe.processEnvironment().toStringList()) if 'DISTENE' in i]) + """ + + cmds = '' + ext = '' + if sys.platform == "win32": + if os.path.exists(self.parent().fichierOut): + cmds += 'del %s\n' % self.parent().fichierOut + ext = '.bat' else: - cmds+="# $DISTENE_PATH_FOR_MGCLEANER NOT SET\n" - #cmds+='env\n' - cmds+='rm -f '+self.parent().fichierOut+'\n' - cmds+=txt+'\n' - cmds+='echo END_OF_MGCleaner\n' - pid=self.monExe.pid() - nomFichier='/tmp/MGCleaner_'+str(pid)+'.sh' - f=open(nomFichier,'w') - f.write(cmds) - f.close() + cmds += '#!/bin/bash\n' + cmds += 'pwd\n' + #cmds += 'which mg-cleaner.exe\n' + cmds += 'echo "DISTENE_LICENSE_FILE="$DISTENE_LICENSE_FILE\n' + cmds += 'echo "DLIM8VAR="$DLIM8VAR\n' + cmds += 'rm -f %s\n' % self.parent().fichierOut + ext = '.bash' - maBidouille='sh ' + nomFichier - self.monExe.start(maBidouille) + cmds += 'echo %s\n' % txt #to see what is compute command + cmds += txt+'\n' + cmds += 'echo "END_OF_MGCleaner"\n' + + nomFichier = os.path.splitext(self.parent().fichierOut)[0] + ext + with open(nomFichier, 'w') as f: + f.write(cmds) + self.make_executable(nomFichier) + + if verbose: print("INFO: MGCleaner launch script file: %s" % nomFichier) + + self.monExe.start(nomFichier) self.monExe.closeWriteChannel() self.enregistreResultatsDone=False self.show() + def make_executable(self, path): + mode = os.stat(path).st_mode + mode |= (mode & 0o444) >> 2 # copy R bits to X + os.chmod(path, mode) + def saveFile(self): #recuperation du nom du fichier savedir=os.environ['HOME'] @@ -100,16 +120,16 @@ class MGCleanerMonViewText(Ui_ViewExe, QDialog): def readFromStdErr(self): a=self.monExe.readAllStandardError() - self.TB_Exe.append(QString.fromUtf8(a.data(),len(a))) + self.TB_Exe.append(unicode(a.data())) def readFromStdOut(self) : a=self.monExe.readAllStandardOutput() - aa=QString.fromUtf8(a.data(),len(a)) + aa=unicode(a.data()) self.TB_Exe.append(aa) - if "END_OF_MGCleaner" in aa: - self.parent().enregistreResultat() - self.enregistreResultatsDone=True - #self.theClose() + + def finished(self): + self.parent().enregistreResultat() + self.enregistreResultatsDone=True def theClose(self): if not self.enregistreResultatsDone: