1 # -*- coding: iso-8859-1 -*-
2 # Copyright (C) 2007-2013 EDF R&D
4 # This library is free software; you can redistribute it and/or
5 # modify it under the terms of the GNU Lesser General Public
6 # License as published by the Free Software Foundation; either
7 # version 2.1 of the License.
9 # This library is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 # Lesser General Public License for more details.
14 # You should have received a copy of the GNU Lesser General Public
15 # License along with this library; if not, write to the Free Software
16 # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
18 # See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
22 from determine import monEnvQT5
24 from PyQt5.QtWidgets import QApplication, QMainWindow, QBoxLayout, QMenu, QAction
25 from PyQt5.QtGui import QIcon
26 from PyQt5.QtCore import Qt
28 from PyQt4.QtGui import *
29 from PyQt4.QtCore import *
31 from Extensions.i18n import tr
32 from Extensions.eficas_exception import EficasException
34 from myMain import Ui_Eficas
35 from viewManager import MyTabview
36 from getVersion import getEficasVersion
37 from Editeur import session
40 class Appli(Ui_Eficas,QMainWindow):
42 Class implementing the main user interface.
44 def __init__(self,code=None,salome=0,parent=None,ssCode=None,multi=False,langue='fr',ssIhm=False):
48 QMainWindow.__init__(self,parent)
49 Ui_Eficas.__init__(self)
51 version=getEficasVersion()
52 self.VERSION_EFICAS="Eficas QT4 Salome "+version
53 if monEnvQT5 : self.VERSION_EFICAS="Eficas QT5 Salome "
57 self.top = self #(pour CONFIGURATION)
58 self.QWParent=None #(Pour lancement sans IHM)
62 if monEnvQT5 : self.recent = []
63 else : self.recent = QStringList()
66 self.ListeCode=['Aster','Carmel3D','Cuve2dg','Openturns_Study','Openturns_Wrapper','MAP','ZCracks', 'CarmelCND','MT']
67 self.repIcon=os.path.join( os.path.dirname(os.path.abspath(__file__)),'..','Editeur','icons')
72 Accas.SalomeEntry = eficasSalome.SalomeEntry
75 if self.multi == False :
76 self.definitCode(code,ssCode)
79 if not self.salome and hasattr(self.CONFIGURATION,'lang') : langue=self.CONFIGURATION.lang
80 if langue=='fr': self.langue=langue
81 else : self.langue="ang"
83 from Extensions import localisation
85 localisation.localise(app,langue)
88 if self.code in ['MAP',] : self.resize(1440,self.height())
89 else : self.resize(1800,self.height())
91 icon = QIcon(self.repIcon+"/parametres.png")
92 self.actionParametres.setIcon(icon)
95 self.myQtab.removeTab(0)
96 self.blEntete= QBoxLayout(0,self.frameEntete)
97 self.blEntete.insertWidget(0,self.toolBar)
98 self.blEntete.insertWidget(0,self.menubar)
101 eficas_root_dir = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
103 self.viewmanager = MyTabview(self)
104 self.recentMenu=QMenu(tr('&Recents'))
105 #self.menuFichier.insertMenu(self.actionOuvrir,self.recentMenu)
106 # actionARemplacer ne sert que pour l insert Menu
107 self.menuFichier.insertMenu(self.actionARemplacer ,self.recentMenu)
108 self.menuFichier.removeAction(self.actionARemplacer)
109 if monEnvQT5 : self.connecterSignaux()
110 else : self.connecterSignauxQT4()
111 self.toolBar.addSeparator()
112 if self.code != None : self.construitMenu()
114 self.setWindowTitle(self.VERSION_EFICAS)
117 except EficasException, exc:
121 def definitCode(self,code,ssCode) :
126 from monChoixCode import MonChoixCode
127 widgetChoix = MonChoixCode(self)
128 ret=widgetChoix.exec_()
130 if self.code == None:return # pour le cancel de la fenetre choix code
131 name='prefs_'+self.code
132 prefsCode=__import__(name)
134 self.repIni=prefsCode.repIni
136 self.format_fichier= ssCode #par defaut
137 prefsCode.NAME_SCHEME=ssCode
139 self.format_fichier="python" #par defaut
141 nameConf='configuration_'+self.code
142 configuration=__import__(nameConf)
143 self.CONFIGURATION = configuration.make_config(self,prefsCode.repIni)
144 self.CONFIGStyle = None
145 if hasattr(configuration,'make_config_style'):
146 self.CONFIGStyle = configuration.make_config_style(self,prefsCode.repIni)
147 if hasattr(prefsCode,'encoding'):
150 sys.setdefaultencoding(prefsCode.encoding)
152 def construitMenu(self):
156 for intituleMenu in ("menuTraduction","menuOptions","menuMesh","menuExecution"):
157 if hasattr(self,intituleMenu):
158 menu=getattr(self,intituleMenu)
159 menu.setAttribute(Qt.WA_DeleteOnClose)
161 delattr(self,intituleMenu)
162 for intituleAction in ("actionExecution","actionSaveRun",):
163 if hasattr(self,intituleAction):
164 action=getattr(self,intituleAction)
165 self.toolBar.removeAction(action)
166 if self.code.upper() in Appli.__dict__.keys():
167 listeTexte=apply(Appli.__dict__[self.code.upper()],(self,))
171 repAide=os.path.dirname(os.path.abspath(__file__))
172 fileName='index.html'
173 self.docPath=repAide+"/../Aide"
174 if hasattr(self,'CONFIGURATION') and hasattr(self.CONFIGURATION,'docPath') : self.docPath=self.CONFIGURATION.docPath
175 if hasattr(self,'CONFIGURATION') and hasattr(self.CONFIGURATION,'fileName'):fileName=self.CONFIGURATION.fileName
176 self.fileDoc=os.path.join(self.docPath,fileName)
177 self.actionCode.setText(tr("Aide specifique ")+str(self.code))
178 if not os.path.isfile(self.fileDoc) :
181 self.actionCode.setEnabled(False)
184 self.actionCode.setEnabled(True)
185 self.menuAide.addAction(self.actionCode)
188 def ajoutExecution(self):
189 self.menuExecution = self.menubar.addMenu(QApplication.translate("Eficas", "Execution", None, QApplication.UnicodeUTF8))
190 self.actionExecution = QAction(self)
191 if sys.platform[0:5]=="linux":
192 icon6 = QIcon(self.repIcon+"/roue.png")
193 self.actionExecution.setIcon(icon6)
195 self.actionExecution.setText(QApplication.translate("Eficas", "Run", None))
196 self.actionExecution.setObjectName("actionExecution")
197 self.menuExecution.addAction(self.actionExecution)
198 if not(self.actionExecution in self.toolBar.actions()):
199 self.toolBar.addAction(self.actionExecution)
200 self.actionExecution.setText(QApplication.translate("Eficas", "Execution ", None, QApplication.UnicodeUTF8))
201 if monEnvQT5 : self.actionExecution.triggered.connect(self.run)
202 else : self.connect(self.actionExecution,SIGNAL("triggered()"),self.run)
204 def ajoutSauveExecution(self):
205 self.actionSaveRun = QAction(self)
206 icon7 = QIcon(self.repIcon+"/export_MAP.png")
207 self.actionSaveRun.setIcon(icon7)
208 self.actionSaveRun.setObjectName("actionSaveRun")
209 self.menuExecution.addAction(self.actionSaveRun)
210 if not(self.actionSaveRun in self.toolBar.actions()):
211 self.toolBar.addAction(self.actionSaveRun)
212 self.actionSaveRun.setText(QApplication.translate("Eficas", "Save Run", None, QApplication.UnicodeUTF8))
213 if monEnvQT5 : self.actionSaveRun.triggered.connect(self.saveRun)
214 else : self.connect(self.actionSaveRun,SIGNAL("triggered()"),self.saveRun)
216 def griserActionsStructures(self):
217 self.actionCouper.setEnabled(False)
218 self.actionColler.setEnabled(False)
219 self.actionCopier.setEnabled(False)
220 self.actionSupprimer.setEnabled(False)
222 def enleverActionsStructures(self):
223 self.toolBar.removeAction(self.actionCopier)
224 self.toolBar.removeAction(self.actionColler)
225 self.toolBar.removeAction(self.actionCouper)
226 self.menuEdition.removeAction(self.actionCouper)
227 self.menuEdition.removeAction(self.actionCopier)
228 self.menuEdition.removeAction(self.actionColler)
231 def enleverParametres(self):
232 self.toolBar.removeAction(self.actionParametres)
233 self.menuJdC.removeAction(self.actionParametres)
236 def enleverNewInclude(self):
237 self.actionNouvel_Include.setVisible(False)
239 def enleverRechercherDsCatalogue(self):
240 self.actionRechercherDsCatalogue.setVisible(False)
243 self.enleverNewInclude()
244 self.toolBar.addSeparator()
245 self.ajoutExecution()
247 self.menuOptions = self.menubar.addMenu("menuOptions")
248 self.menuOptions.addAction(self.actionParametres_Eficas)
249 self.menuOptions.setTitle(tr("Options"))
252 self.enleverActionsStructures()
253 self.enleverNewInclude()
254 self.enleverRechercherDsCatalogue()
257 self.menuTraduction = self.menubar.addMenu("menuTraduction")
258 self.menuTraduction.addAction(self.actionTraduitV11V12)
259 self.menuTraduction.addAction(self.actionTraduitV10V11)
260 self.menuTraduction.addAction(self.actionTraduitV9V10)
261 self.menuTraduction.setTitle(tr("Traduction"))
263 self.menuFichier.addAction(self.actionSauveLigne)
265 self.menuOptions = self.menubar.addMenu("menuOptions")
266 self.menuOptions.addAction(self.actionParametres_Eficas)
267 self.menuOptions.addAction(self.actionLecteur_Pdf)
268 self.menuOptions.setTitle(tr("Options"))
271 #if self.salome == 0 : return
272 self.enleverNewInclude()
273 self.menuMesh = self.menubar.addMenu(tr("Gestion Maillage"))
274 self.menuMesh.setObjectName("Mesh")
275 self.menuMesh.addAction(self.actionChercheGrpMaille)
276 #self.griserActionsStructures()
279 self.enleverNewInclude()
280 self.enleverRechercherDsCatalogue()
281 self.ajoutExecution()
282 self.ajoutSauveExecution()
283 self.griserActionsStructures()
286 self.enleverNewInclude()
287 self.toolBar.addSeparator()
288 self.ajoutExecution()
289 self.ajoutSauveExecution()
290 self.menuOptions = self.menubar.addMenu("menuOptions")
291 self.menuOptions.addAction(self.actionParametres_Eficas)
292 self.menuOptions.setTitle(tr("Options"))
295 self.enleverActionsStructures()
296 self.enleverParametres()
297 self.enleverRechercherDsCatalogue()
298 self.enleverNewInclude()
299 self.ajoutExecution()
304 self.enleverActionsStructures()
305 self.enleverNewInclude()
307 def ajoutHelpPSEN(self):
308 self.actionParametres_Eficas.setText('Help PSEN')
310 #Oself.disconnect(self.actionParametres_Eficas)
311 if monEnvQT5 : self.actionParametres_Eficas.triggered.connect(self.aidePSEN)
312 else : self.connect(self.actionParametres_Eficas,SIGNAL("triggered()"),self.aidePSEN)
316 def ChercheGrpMesh(self):
317 Msg,listeGroup=self.ChercheGrpMeshInSalome()
319 self.viewmanager.handleAjoutGroup(listeGroup)
321 print "il faut gerer les erreurs"
323 def ChercheGrpMaille(self):
324 # Normalement la variable self.salome permet de savoir si on est ou non dans Salome
326 Msg,listeGroup=self.ChercheGrpMailleInSalome() # recherche dans Salomé
327 #Msg = None; listeGroup = None # recherche manuelle, i.e., sans Salomé si ligne précédente commentée
329 raise ValueError('Salome non ouvert')
331 self.viewmanager.handleAjoutGroup(listeGroup)
333 print "il faut gerer les erreurs"
336 def ChercheGrp(self):
337 #Msg,listeGroup=self.ChercheGrpMailleInSalome()
339 # self.viewmanager.handleAjoutGroup(listeGroup)
341 print "il faut gerer "
344 def ajoutIcones(self) :
345 # Pour pallier les soucis de repertoire d icone
347 icon = QIcon(self.repIcon+"/new_file.png")
348 self.action_Nouveau.setIcon(icon)
349 icon1 = QIcon(self.repIcon+"/ouvrir.png")
350 self.actionOuvrir.setIcon(icon1)
351 icon2 = QIcon(self.repIcon+"/save.png")
352 self.actionEnregistrer.setIcon(icon2)
353 icon6 = QIcon(self.repIcon+"/delete.png")
354 self.actionSupprimer.setIcon(icon6)
355 icon7 = QIcon(self.repIcon+"/roue.png")
356 self.actionExecution.setIcon(icon7)
361 def connecterSignauxQT4(self) :
362 self.connect(self.recentMenu,SIGNAL('aboutToShow()'),self.handleShowRecentMenu)
364 self.connect(self.action_Nouveau,SIGNAL("triggered()"),self.fileNew)
365 self.connect(self.actionNouvel_Include,SIGNAL("triggered()"),self.NewInclude)
366 self.connect(self.actionOuvrir,SIGNAL("triggered()"),self.fileOpen)
367 self.connect(self.actionEnregistrer,SIGNAL("triggered()"),self.fileSave)
368 self.connect(self.actionEnregistrer_sous,SIGNAL("triggered()"),self.fileSaveAs)
369 self.connect(self.actionFermer,SIGNAL("triggered()"),self.fileClose)
370 self.connect(self.actionFermer_tout,SIGNAL("triggered()"),self.fileCloseAll)
371 self.connect(self.actionQuitter,SIGNAL("triggered()"),self.fileExit)
373 self.connect(self.actionEficas,SIGNAL("triggered()"),self.aidePPal)
374 self.connect(self.actionVersion,SIGNAL("triggered()"),self.version)
375 self.connect(self.actionParametres,SIGNAL("triggered()"),self.gestionParam)
377 self.connect(self.actionCouper,SIGNAL("triggered()"),self.editCut)
378 self.connect(self.actionCopier,SIGNAL("triggered()"),self.editCopy)
379 self.connect(self.actionColler,SIGNAL("triggered()"),self.editPaste)
380 self.connect(self.actionSupprimer,SIGNAL("triggered()"),self.supprimer)
381 self.connect(self.actionRechercher,SIGNAL("triggered()"),self.rechercher)
382 self.connect(self.actionDeplier_replier,SIGNAL("triggered()"),self.Deplier)
384 self.connect(self.actionRapport_de_Validation,SIGNAL("triggered()"),self.jdcRapport)
385 self.connect(self.actionRegles_du_JdC,SIGNAL("triggered()"),self.jdcRegles)
386 self.connect(self.actionFichier_Source,SIGNAL("triggered()"),self.jdcFichierSource)
387 self.connect(self.actionFichier_Resultat,SIGNAL("triggered()"),self.visuJdcPy)
392 self.actionTraduitV9V10 = QAction(self)
393 self.actionTraduitV9V10.setObjectName("actionTraduitV9V10")
394 self.actionTraduitV9V10.setText(tr("TraduitV9V10"))
395 self.actionTraduitV10V11 = QAction(self)
396 self.actionTraduitV10V11.setObjectName("actionTraduitV10V11")
397 self.actionTraduitV10V11.setText(tr("TraduitV10V11"))
398 self.actionTraduitV11V12 = QAction(self)
399 self.actionTraduitV11V12.setObjectName("actionTraduitV11V12")
400 self.actionTraduitV11V12.setText(tr("TraduitV11V12"))
401 self.actionSauveLigne = QAction(self)
402 self.actionSauveLigne.setText(tr("Sauve Format Ligne"))
404 #self.connect(self.actionParametres_Eficas,SIGNAL("triggered()"),self.optionEditeur)
405 self.connect(self.actionLecteur_Pdf,SIGNAL("triggered()"),self.optionPdf)
406 self.connect(self.actionTraduitV9V10,SIGNAL("triggered()"),self.traductionV9V10)
407 self.connect(self.actionTraduitV10V11,SIGNAL("triggered()"),self.traductionV10V11)
408 self.connect(self.actionTraduitV11V12,SIGNAL("triggered()"),self.traductionV11V12)
409 self.connect(self.actionSauveLigne,SIGNAL("triggered()"),self.sauveLigne)
413 self.actionChercheGrpMaille = QAction(self)
414 self.actionChercheGrpMaille.setText(tr("Acquiert groupe mailles"))
415 self.connect(self.actionChercheGrpMaille,SIGNAL("triggered()"),self.ChercheGrpMaille)
418 self.actionChercheGrp = QAction(self)
419 self.actionChercheGrp.setText(tr("Acquisition Groupe Maille"))
420 self.connect(self.actionChercheGrp,SIGNAL("triggered()"),self.ChercheGrp)
423 self.actionCode = QAction(self)
424 self.actionCode.setText(tr("Specificites Maille"))
425 self.connect(self.actionCode,SIGNAL("triggered()"),self.aideCode)
427 def connecterSignaux(self) :
428 self.recentMenu.aboutToShow.connect(self.handleShowRecentMenu)
429 self.action_Nouveau.triggered.connect(self.fileNew)
430 self.actionNouvel_Include.triggered.connect(self.NewInclude)
431 self.actionOuvrir.triggered.connect(self.fileOpen)
432 self.actionEnregistrer.triggered.connect(self.fileSave)
433 self.actionEnregistrer_sous.triggered.connect(self.fileSaveAs)
434 self.actionFermer.triggered.connect(self.fileClose)
435 self.actionFermer_tout.triggered.connect(self.fileCloseAll)
436 self.actionQuitter.triggered.connect(self.fileExit)
438 self.actionEficas.triggered.connect(self.aidePPal)
439 self.actionVersion.triggered.connect(self.version)
440 self.actionParametres.triggered.connect(self.gestionParam)
442 self.actionCouper.triggered.connect(self.editCut)
443 self.actionCopier.triggered.connect(self.editCopy)
444 self.actionColler.triggered.connect(self.editPaste)
445 self.actionSupprimer.triggered.connect(self.supprimer)
446 self.actionRechercher.triggered.connect(self.rechercher)
447 self.actionDeplier_replier.triggered.connect(self.Deplier)
449 self.actionRapport_de_Validation.triggered.connect(self.jdcRapport)
450 self.actionRegles_du_JdC.triggered.connect(self.jdcRegles)
451 self.actionFichier_Source.triggered.connect(self.jdcFichierSource)
452 self.actionFichier_Resultat.triggered.connect(self.visuJdcPy)
456 self.actionTraduitV9V10 = QAction(self)
457 self.actionTraduitV9V10.setObjectName("actionTraduitV9V10")
458 self.actionTraduitV9V10.setText(tr("TraduitV9V10"))
459 self.actionTraduitV10V11 = QAction(self)
460 self.actionTraduitV10V11.setObjectName("actionTraduitV10V11")
461 self.actionTraduitV10V11.setText(tr("TraduitV10V11"))
462 self.actionTraduitV11V12 = QAction(self)
463 self.actionTraduitV11V12.setObjectName("actionTraduitV11V12")
464 self.actionTraduitV11V12.setText(tr("TraduitV11V12"))
465 self.actionSauveLigne = QAction(self)
466 self.actionSauveLigne.setText(tr("Sauve Format Ligne"))
468 #self.actionParametres_Eficas.triggered.connect(self.optionEditeur)
469 self.actionTraduitV9V10.triggered.connect(self.traductionV9V10)
470 self.actionTraduitV10V11.triggered.connect(self.traductionV10V11)
471 self.actionTraduitV11V12.triggered.connect(self.traductionV11V12)
472 self.actionSauveLigne.triggered.connect(self.sauveLigne)
475 self.actionChercheGrpMaille = QAction(self)
476 self.actionChercheGrpMaille.setText(tr("Acquiert Groupe Maille"))
479 self.actionChercheGrp = QAction(self)
480 self.actionChercheGrp.setText(tr("Accquisition Groupe Maille"))
481 self.actionChercheGrp.triggered.connect(self.ChercheGrp)
484 self.actionCode = QAction(self)
485 self.actionCode.setText(tr("Specificites Maille"))
486 self.actionCode.triggered.connect(self.aideCode)
490 self.viewmanager.handleDeplier()
492 def ouvreFichiers(self) :
493 # Ouverture des fichiers de commandes donnes sur la ligne de commande
496 for study in session.d_env.studies:
498 d=session.get_unit(study,self)
499 self.viewmanager.handleOpen(fichier=study["comm"],units=d)
502 def get_source(self,file):
503 # appele par Editeur/session.py
505 p=convert.plugins['python']()
507 texte=p.convert('execnoparseur')
510 def initPatrons(self) :
511 # Mise a jour du menu des fichiers recemment ouverts
512 from Editeur import listePatrons
513 if not(self.code in listePatrons.sous_menus.keys()) :
514 if hasattr(self,"menuPatrons"):
515 self.menuPatrons.setAttribute(Qt.WA_DeleteOnClose)
516 self.menuPatrons.close()
517 delattr(self,"menuPatrons")
519 if (not hasattr(self,"menuPatrons")):
520 self.menuPatrons = QMenu(self.menubar)
521 self.menuPatrons.setObjectName("menuPatrons")
522 self.menubar.addAction(self.menuPatrons.menuAction())
523 self.menuPatrons.setTitle(QApplication.translate("Eficas", "Patrons", None, QApplication.UnicodeUTF8))
525 self.menuPatrons.clear()
526 self.listePatrons = listePatrons.listePatrons(self.code)
528 for nomSsMenu in self.listePatrons.liste.keys():
529 ssmenu=self.menuPatrons.addMenu(nomSsMenu)
530 for fichier in self.listePatrons.liste[nomSsMenu]:
531 id = ssmenu.addAction(fichier)
532 self.ficPatrons[id]=fichier
533 if monEnvQT5 : self.id.triggered.connect(self.handleOpenPatrons)
534 else : self.connect(id, SIGNAL('triggered()'),self.handleOpenPatrons)
535 # self.Patrons.setItemParameter(id,idx)
538 def initRecents(self):
540 if sys.platform[0:5]=="linux" :
541 rep=os.path.join(os.environ['HOME'],'.config/Eficas',self.code)
543 rep=os.path.join('C:/','.config/Eficas',self.code)
544 monFichier=rep+"/listefichiers_"+self.code
550 l=(ligne.split("\n"))[0]
551 self.recent.append(l)
559 def addToRecentList(self, fn):
560 if not monEnvQT5 : self.addToRecentListQT4(fn); return
561 while fn in self.recent: self.recent.remove(fn)
562 self.recent.insert(0,fn)
563 if len(self.recent) > 9:
564 self.recent = self.recent[:9]
567 def addToRecentListQT4(self, fn):
569 Public slot to add a filename to the list of recently opened files.
571 @param fn name of the file to be added
573 self.recent.removeAll(fn)
574 self.recent.prepend(fn)
575 if len(self.recent) > 9:
576 self.recent = self.recent[:9]
580 def sauveRecents(self) :
582 rep=self.CONFIGURATION.rep_user
583 monFichier=rep+"/listefichiers_"+self.code
587 f=open(monFichier,'w')
588 if len(self.recent) == 0 : return
590 while ( index < len(self.recent)):
591 ligne=str(self.recent[index])+"\n"
603 def traductionV11V12(self):
604 from gereTraduction import traduction
605 traduction(self.CONFIGURATION.repIni,self.viewmanager,"V11V12")
607 def traductionV10V11(self):
608 from gereTraduction import traduction
609 traduction(self.CONFIGURATION.repIni,self.viewmanager,"V10V11")
611 def traductionV9V10(self):
612 from gereTraduction import traduction
613 traduction(self.CONFIGURATION.repIni,self.viewmanager,"V9V10")
616 from monVisu import DVisu
617 titre = tr("version ")
618 monVisuDialg=DVisu(parent=self,fl=0)
619 monVisuDialg.setWindowTitle(titre)
620 monVisuDialg.TB.setText(self.VERSION_EFICAS +tr(" pour ") + self.code)
621 monVisuDialg.adjustSize()
625 repAide=os.path.dirname(os.path.abspath(__file__))
626 maD=os.path.join( repAide,'..','Doc','html')
628 indexAide=os.path.join(maD,'index.html')
629 if sys.platform[0:5]=="linux" : cmd="xdg-open "+indexAide
630 else : cmd="start "+indexAide
633 QMessageBox.warning( self,tr( "Aide Indisponible"),tr( "l'aide n est pas installee "))
636 repAide=os.path.dirname(os.path.abspath(__file__))
637 maD=os.path.join( repAide,'..','Doc','html')
639 indexAide=os.path.join(maD,'index.html')
640 if sys.platform[0:5]=="linux" : cmd="xdg-open "+indexAide
641 else : cmd="start "+indexAide
644 QMessageBox.warning( self,tr( "Aide Indisponible"),tr( "l'aide n est pas installee "))
647 if self.code==None : return
650 if sys.platform[0:5]=="linux" : cmd="xdg-open "+self.fileDoc
651 else : cmd="start "+self.fileDoc
655 QMessageBox.warning( self,tr( "Aide Indisponible"),tr( "l'aide n est pas installee "))
658 def optionEditeur(self) :
660 name='monOptions_'+self.code
662 QMessageBox.critical( self,tr( "Parametrage"),tr( "Veuillez d abord choisir un code"))
666 optionCode=__import__(name)
669 QMessageBox.critical( self, tr("Parametrage"), tr("Pas de possibilite de personnalisation de la configuration "))
671 monOption=optionCode.Options(parent=self,modal = 0 ,configuration=self.CONFIGURATION)
674 def optionPdf(self) :
675 from monOptionsPdf import OptionPdf
676 monOption=OptionPdf(parent=self,modal = 0 ,configuration=self.CONFIGURATION)
679 def handleShowRecentMenu(self):
681 Private method to set up recent files menu.
683 self.recentMenu.clear()
685 for rp in self.recent:
686 id = self.recentMenu.addAction(rp)
687 self.ficRecents[id]=rp
688 if monEnvQT5 : id.triggered.connect(self.handleOpenRecent)
689 else : self.connect(id, SIGNAL('triggered()'),self.handleOpenRecent)
690 self.recentMenu.addSeparator()
691 self.recentMenu.addAction(tr('&Effacer'), self.handleClearRecent)
693 def handleOpenPatrons(self):
695 fichier=self.repIni+"/../Editeur/Patrons/"+self.code+"/"+self.ficPatrons[idx]
696 self.viewmanager.handleOpen(fichier=fichier, patron = 1)
698 def handleOpenRecent(self):
700 fichier=self.ficRecents[idx]
701 self.viewmanager.handleOpen(fichier=fichier, patron =0 )
703 def handleClearRecent(self):
704 self.recent = QStringList()
709 self.viewmanager.newEditor()
710 except EficasException, exc:
713 QMessageBox.warning(self, tr(u"Erreur"), msg)
717 self.viewmanager.handleOpen()
718 except EficasException, exc:
721 QMessageBox.warning(self, tr(u"Erreur"), msg)
723 def sauveLigne(self):
724 return self.viewmanager.sauveLigneCurrentEditor()
727 return self.viewmanager.saveCurrentEditor()
729 def fileSaveAs(self):
730 return self.viewmanager.saveAsCurrentEditor()
733 self.viewmanager.handleClose(texte='&Fermer')
735 def fileCloseAll(self):
736 self.viewmanager.handleCloseAll(texte='&Fermer')
739 # On peut sortir sur Abort
740 res=self.viewmanager.handleCloseAll()
746 self.viewmanager.handleEditCopy()
749 self.viewmanager.handleEditCut()
752 self.viewmanager.handleEditPaste()
754 def rechercher(self):
755 self.viewmanager.handleRechercher()
758 self.viewmanager.run()
761 self.viewmanager.saveRun()
765 self.viewmanager.handleSupprimer()
767 def jdcFichierSource(self):
768 self.viewmanager.handleViewJdcFichierSource()
770 def jdcRapport(self):
771 self.viewmanager.handleViewJdcRapport()
774 self.viewmanager.handleViewJdcRegles()
776 def gestionParam(self):
777 self.viewmanager.handlegestionParam()
780 self.viewmanager.handleViewJdcPy()
783 def NewInclude(self):
784 self.viewmanager.newIncludeEditor()
787 for pathCode in self.ListeCode:
789 aEnlever=os.path.abspath(os.path.join(os.path.dirname(__file__),'..',pathCode))
790 sys.path.remove(aEnlever)
793 for pathCode in self.listeAEnlever:
795 sys.path.remove(aEnlever)
800 def closeEvent(self,event):
802 if res==2 : event.ignore()
804 if __name__=='__main__':
807 rep=os.path.abspath(os.path.join(os.path.dirname(os.path.abspath(__file__),'..','ASTER')))
809 from Aster import prefsCode
810 if hasattr(prefsCode,'encoding'):
811 # Hack pour changer le codage par defaut des strings
814 sys.setdefaultencoding(prefsCode.encoding)
815 del sys.setdefaultencoding
818 from Editeur import import_code
819 from Editeur import session
821 # Analyse des arguments de la ligne de commande
822 options=session.parse(sys.argv)
826 app = QApplication(sys.argv)
827 #app.setMainWidget(mw) (qt3)