Salome HOME
864f16b43b4e96051cb0f7d27bcdf755ccb50b2d
[tools/eficas.git] / Editeur / compomacro.py
1 #            CONFIGURATION MANAGEMENT OF EDF VERSION
2 # ======================================================================
3 # COPYRIGHT (C) 1991 - 2002  EDF R&D                  WWW.CODE-ASTER.ORG
4 # THIS PROGRAM IS FREE SOFTWARE; YOU CAN REDISTRIBUTE IT AND/OR MODIFY
5 # IT UNDER THE TERMS OF THE GNU GENERAL PUBLIC LICENSE AS PUBLISHED BY
6 # THE FREE SOFTWARE FOUNDATION; EITHER VERSION 2 OF THE LICENSE, OR
7 # (AT YOUR OPTION) ANY LATER VERSION.
8 #
9 # THIS PROGRAM IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, BUT
10 # WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF
11 # MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. SEE THE GNU
12 # GENERAL PUBLIC LICENSE FOR MORE DETAILS.
13 #
14 # YOU SHOULD HAVE RECEIVED A COPY OF THE GNU GENERAL PUBLIC LICENSE
15 # ALONG WITH THIS PROGRAM; IF NOT, WRITE TO EDF R&D CODE_ASTER,
16 #    1 AVENUE DU GENERAL DE GAULLE, 92141 CLAMART CEDEX, FRANCE.
17 #
18 #
19 # ======================================================================
20 # Modules Python
21 import os,sys,string
22 import types
23 import Tkinter
24 import Pmw
25 from tkFileDialog import *
26 from tkMessageBox import showinfo,showerror,askyesno
27 import traceback
28
29 # Modules Eficas
30 import Objecttreeitem
31 import panels
32 import fontes
33 import compooper
34 import convert
35 from widgets import Fenetre,FenetreYesNo
36
37 #
38 __version__="$Name:  $"
39 __Id__="$Id: compomacro.py,v 1.7 2002/11/12 12:25:01 eficas Exp $"
40 #
41
42 class MACROPanel(panels.OngletPanel):
43   def init(self):
44     nb = Pmw.NoteBook(self,raisecommand=self.raisecmd)
45     nb.pack(fill = 'both', expand = 1)
46     self.nb=nb
47     nb.add('Mocles', tab_text='Ajouter mots-clés')
48     typsd=self.node.item.object.get_type_produit()
49     ficini = self.node.item.wait_fichier_init()
50     if typsd != None:
51       nb.add('Concept', tab_text='Nommer concept')
52     if ficini == 1:
53       nb.add('Fichierinit',tab_text = 'Fichier %s' %self.node.item.get_nom())
54     nb.add('Commande', tab_text='Nouvelle Commande')
55     nb.add('Commentaire',tab_text='Paramètre/Commentaire')
56     panneau=Pmw.PanedWidget(nb.page("Mocles"),
57                             orient='horizontal')
58     panneau.add('left',min=0.4,max=0.6,size=0.5)
59     panneau.add('right',min=0.4,max=0.6,size=0.5)
60     panneau.pack(expand=1,fill='both')
61     self.makeCommandePage(nb.page("Commande"))
62     if typsd != None:
63       self.makeConceptPage(nb.page("Concept"))
64     if ficini == 1 :
65       self.makeFichierPage(nb.page('Fichierinit'))
66     self.makeMoclesPage(panneau.pane('left'))
67     self.makeReglesPage(panneau.pane('right'))
68     self.makeParamCommentPage_for_etape(nb.page("Commentaire"))
69     nb.tab('Mocles').focus_set()
70     nb.setnaturalsize()
71     self.affiche()
72
73   def makeFichierPage(self,page):
74     """
75     Affiche la page d'onglet correspondant au changement du fichier
76     dont a besoin la macro\r
77     """
78     titre = Tkinter.Label(page,text="La commande %s requiert un fichier " %self.node.item.get_nom())
79     titre.place(relx=0.5,rely=0.3,anchor='center')
80     Tkinter.Label(page,text="Fichier :").place(relx=0.1,rely=0.5,relwidth=0.2)
81     self.entry = Tkinter.Entry(page,relief='sunken',bg='white')
82     self.entry.place(relx=0.35,rely=0.5,relwidth=0.55)
83     Tkinter.Button(page,text='Valider',command = self.change_fichier_init).place(relx=0.3,rely=0.8)
84     Tkinter.Button(page,text='Browse',command = self.browse_fichier_init).place(relx=0.5,rely=0.8)
85     Tkinter.Button(page,text='Annuler',command = self.annule_fichier_init).place(relx=0.7,rely=0.8)
86     if hasattr(self.node.item.object,'fichier_ini'):
87       if self.node.item.object.fichier_ini :
88         self.entry.insert(0,self.node.item.object.fichier_ini)
89     self.entry.focus()
90
91   def convert_file(self,file):
92      """
93          Methode pour convertir le fichier file dans le format courant
94      """
95      format=self.parent.appli.format_fichier.get()
96      if convert.plugins.has_key(format):
97          # Le convertisseur existe on l'utilise
98          p=convert.plugins[format]()
99          p.readfile(file)
100          text=p.convert('execnoparseur')
101          if not p.cr.estvide():
102             self.parent.appli.affiche_infos("Erreur à la conversion")
103             Fenetre(self,
104                     titre="compte-rendu d'erreurs, EFICAS ne sait pas convertir ce fichier",
105                     texte = str(p.cr))
106             return None
107          return text
108      else:
109          # Il n'existe pas c'est une erreur
110          self.parent.appli.affiche_infos("Type de fichier non reconnu")
111          showerror("Type de fichier non reconnu","EFICAS ne sait pas ouvrir ce type de fichier")
112          return None
113
114   def change_fichier_init(self,event=None):
115     """ 
116         Effectue le changement de fichier d'initialisation s'il est valide 
117     """
118     if not hasattr(self.node.item.object,'fichier_ini'):
119        self.node.item.object.fichier_ini=None
120        self.node.item.object.fichier_text=None
121        self.node.item.object.fichier_err="Le fichier n'est pas defini"
122        self.node.item.object.contexte_fichier_init={}
123        self.node.item.object.recorded_units={}
124
125     old_fic = self.node.item.object.fichier_ini
126     old_text = self.node.item.object.fichier_text
127     old_err = self.node.item.object.fichier_err
128     old_context=self.node.item.object.contexte_fichier_init
129     old_units=self.node.item.object.recorded_units
130     old_etapes=self.node.item.object.etapes
131
132     new_fic = self.entry.get()
133     if not os.path.isfile(new_fic) :
134       showinfo("Fichier introuvable","Le fichier que vous avez saisi\n"+
135                "n'est pas un nom de fichier valide !")
136       self.parent.appli.affiche_infos("Fichier introuvable")
137       return
138     # On convertit le fichier
139     text=self.convert_file(new_fic)
140     # Si probleme a la lecture-conversion on arrete le traitement
141     if not text:
142        return
143     self.node.item.object.recorded_units={}
144
145     try:
146       self.node.item.object.make_contexte_include(new_fic,text)
147     except:
148       # Erreurs lors de l'evaluation de text dans un JDC auxiliaire
149       self.parent.appli.affiche_infos("Fichier invalide")
150       l=traceback.format_exception_only("Fichier invalide",sys.exc_info()[1])
151       f=FenetreYesNo(self.parent.appli,titre="Fichier invalide : voulez vous retablir l ancien fichier ?",
152                              texte="Erreur dans l'interprétation du nouveau fichier ...\n\n"+string.join(l),
153                              yes="Retablir",no="Changer")
154       f.wait()
155       reponse=f.result
156       if reponse:
157          # On retablit l'ancien fichier
158          self.entry.delete(0,Tkinter.END)
159          self.node.item.object.fichier_ini=old_fic
160          self.node.item.object.fichier_text=old_text
161          self.node.item.object.fichier_err=old_err
162          self.node.item.object.contexte_fichier_init=old_context
163          self.node.item.object.recorded_units=old_units
164          self.node.item.object.etapes=old_etapes
165          self.parent.appli.affiche_infos("Fichier invalide ... Ancien fichier restauré")
166          if old_fic:
167              self.entry.insert(0,self.node.item.object.fichier_ini)
168       else:
169          # On conserve la memoire du nouveau fichier
170          # mais on n'utilise pas les concepts crees par ce fichier
171          # on met l'etape en erreur : fichier_err=string.join(l)
172          self.node.item.object.init_modif()
173          self.node.item.object.fichier_ini=new_fic
174          self.node.item.object.fichier_text=text
175          self.node.item.object.fichier_err=string.join(l)
176          # On enregistre la modification de fichier
177          self.node.item.object.record_unite()  
178          #self.node.item.object.etapes=[]
179          self.node.item.object.g_context={}
180          # Le contexte du parent doit etre reinitialise car les concepts produits ont changé
181          self.node.item.object.parent.reset_context()
182
183          self.node.item.object.old_contexte_fichier_init=old_context
184          self.node.item.object.contexte_fichier_init={}
185          self.node.item.object.reevalue_sd_jdc()
186
187          self.node.item.object.fin_modif()
188          self.parent.appli.affiche_infos("Fichier invalide ... Nouveau fichier mémorisé")
189          self.node.update()
190       return
191
192     # L'evaluation de text dans un JDC auxiliaire s'est bien passé
193     # on peut poursuivre le traitement
194     self.node.item.object.init_modif() 
195     self.node.item.object.fichier_ini = new_fic
196     self.node.item.object.fichier_text=text
197     self.node.item.object.fichier_err=None
198     # On enregistre la modification de fichier
199     self.node.item.object.record_unite()  
200     # Le contexte du parent doit etre reinitialise car les concepts produits ont changé
201     self.node.item.object.parent.reset_context()
202
203     # Si des concepts ont disparu lors du changement de fichier, on demande leur suppression
204     self.node.item.object.old_contexte_fichier_init=old_context
205     self.node.item.object.reevalue_sd_jdc()
206
207     self.node.item.object.fin_modif()
208     self.parent.appli.affiche_infos("Fichier %s modifié" %self.node.item.get_nom())
209     self.node.update()
210
211   def annule_fichier_init(self,event=None):
212     """ Restaure dans self.entry le nom de fichier_init"""
213     self.entry.delete(0,Tkinter.END)
214     self.entry.insert(0,self.node.item.object.fichier_ini)
215
216   def browse_fichier_init(self,event=None):
217     """ 
218          Propose à l'utilisateur une Bsf et retourne le fichier 
219          sélectionné dans self.entry 
220     """
221     file = askopenfilename(title="Choix du fichier %s" %self.node.item.get_nom())
222     if file != '' :
223       self.entry.delete(0,Tkinter.END)
224       self.entry.insert(0,file)
225     
226     
227 class MACROTreeItem(compooper.EtapeTreeItem):
228   panel=MACROPanel
229
230   def IsExpandable(self):
231       return 1
232
233   def GetIconName(self):
234       """
235       Retourne le nom de l'icône à afficher dans l'arbre
236       Ce nom dépend de la validité de l'objet
237       """
238       if not self.object.isactif():
239         return "ast-white-square"
240       else:
241         if self.object.isvalid():
242           return "ast-green-square"
243         else:
244           return "ast-red-square"
245
246   def GetLabelText(self):
247       """ Retourne 3 valeurs :
248       - le texte à afficher dans le noeud représentant l'item
249       - la fonte dans laquelle afficher ce texte
250       - la couleur du texte
251       """
252       if self.object.isactif():
253         # None --> fonte et couleur par défaut
254         return self.labeltext,None,None
255       else:
256         return self.labeltext,fontes.standard_italique,None
257       
258   def get_objet(self,name) :
259       for v in self.object.mc_liste:
260           if v.nom == name : return v
261       return None
262       
263   def additem(self,name,pos):
264       if isinstance(name,Objecttreeitem.ObjectTreeItem) :
265           mcent = self.object.addentite(name.object,pos)
266       else :
267           mcent = self.object.addentite(name,pos)
268       self.expandable=1
269       if mcent == 0 :
270           # on ne peut ajouter l'élément de nom name
271           return 0
272       def setfunction(value, object=mcent):
273           object.setval(value)
274       item = self.make_objecttreeitem(self.appli,mcent.nom + " : ", mcent, setfunction)
275       return item
276
277   def suppitem(self,item) :
278       # item : item du MOCLE de l'ETAPE à supprimer
279       # item.object = MCSIMP, MCFACT, MCBLOC ou MCList 
280       if item.object.isoblig() :
281           self.appli.affiche_infos('Impossible de supprimer un mot-clé obligatoire ')
282           print "Impossible de supprimer un mot-clé obligatoire"
283           return 0
284       else :
285           self.object.suppentite(item.object)
286           message = "Mot-clé " + item.object.nom + " supprimé"
287           self.appli.affiche_infos(message)
288           return 1
289
290   def GetText(self):
291       try:
292           return self.object.get_sdname()
293       except:
294           return ''
295
296   def keys(self):
297       keys=self.object.mc_dict.keys()
298       return keys
299
300   def GetSubList(self):
301       sublist=[]
302       for obj in self.object.mc_liste:
303         def setfunction(value, object=obj):
304           object.setval(value)
305         item = self.make_objecttreeitem(self.appli, obj.nom + " : ", obj, setfunction)
306         sublist.append(item)
307       return sublist
308
309   def isvalid(self):
310       return self.object.isvalid()
311
312   def iscopiable(self):
313       """
314       Retourne 1 si l'objet est copiable, 0 sinon
315       """
316       return 1
317
318   def isCommande(self):
319       """
320       Retourne 1 si l'objet pointé par self est une Commande, 0 sinon
321       """
322       return 1
323       
324   def verif_condition_bloc(self):
325       return self.object.verif_condition_bloc()
326
327   def get_noms_sd_oper_reentrant(self):
328       return self.object.get_noms_sd_oper_reentrant()
329
330 class INCLUDETreeItem(MACROTreeItem):
331   rmenu_specs=[("View","makeView")]
332
333   def makeView(self,appli):
334     nom=self.object.nom
335     if hasattr(self.object,'fichier_ini'):nom=nom+' '+self.object.fichier_ini
336     macrodisplay.makeMacroDisplay(appli,self.object,nom)
337
338 class INCLUDE_MATERIAUTreeItem(INCLUDETreeItem): pass
339 class POURSUITETreeItem(INCLUDETreeItem): pass
340
341 treeitem=MACROTreeItem
342 def treeitem(appli, labeltext, object, setfunction=None):
343    if object.nom == "INCLUDE_MATERIAU":
344       return INCLUDE_MATERIAUTreeItem(appli, labeltext, object, setfunction)
345    elif object.nom == "INCLUDE":
346       return INCLUDETreeItem(appli, labeltext, object, setfunction)
347    elif object.nom == "POURSUITE":
348       return POURSUITETreeItem(appli, labeltext, object, setfunction)
349    else:
350       return MACROTreeItem(appli, labeltext, object, setfunction)
351
352 import Accas
353 objet=Accas.MACRO_ETAPE
354     
355 import macrodisplay