Salome HOME
This commit was generated by cvs2git to track changes on a CVS vendor
[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
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
36
37 #
38 __version__="$Name:  $"
39 __Id__="$Id: compomacro.py,v 1.3 2002/04/05 06:32:38 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='Insérer 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.monmenu=Tkinter.Menu(self.parent.appli.menubar,tearoff=0)
72     #self.monmenu.add_command(label='Build',command=self.Build)
73     #self.monmenu.add_command(label='View',command=self.View)
74     #self.parent.appli.add_menu(label="Macro",menu=self.monmenu)    
75     self.affiche()
76
77   def Build(self):
78     print "Build"
79     self.node.item.object.Build()
80
81   def View(self):
82     print "View"
83     MacroDisplay(self.parent.appli,self.node.item.object,self.node.item.object.nom)
84
85   def makeFichierPage(self,page):
86     """\r
87     Affiche la page d'onglet correspondant au changement du fichier
88     dont a besoin la macro\r
89     """
90     titre = Tkinter.Label(page,text="La commande %s requiert un fichier " %self.node.item.get_nom())
91     titre.place(relx=0.5,rely=0.3,anchor='center')
92     Tkinter.Label(page,text="Fichier :").place(relx=0.1,rely=0.5,relwidth=0.2)
93     self.entry = Tkinter.Entry(page,relief='sunken',bg='white')
94     self.entry.place(relx=0.35,rely=0.5,relwidth=0.55)
95     Tkinter.Button(page,text='Valider',command = self.change_fichier_init).place(relx=0.3,rely=0.8)
96     Tkinter.Button(page,text='Browse',command = self.browse_fichier_init).place(relx=0.5,rely=0.8)
97     Tkinter.Button(page,text='Annuler',command = self.annule_fichier_init).place(relx=0.7,rely=0.8)
98     if hasattr(self.node.item.object,'fichier_init'):\r
99       if self.node.item.object.fichier_init :\r
100         self.entry.insert(0,self.node.item.object.fichier_init)
101     self.entry.focus()
102
103   def convert_file(self,file):
104      """
105          Methode pour convertir le fichier file dans le format courant
106      """
107      format=self.parent.appli.format_fichier.get()
108      if convert.plugins.has_key(format):
109          # Le convertisseur existe on l'utilise
110          p=convert.plugins[format]()
111          p.readfile(file)
112          text=p.convert('execnoparseur')
113          if not p.cr.estvide():
114             self.parent.appli.affiche_infos("Erreur à la conversion")
115             Fenetre(self,
116                     titre="compte-rendu d'erreurs, EFICAS ne sait pas convertir ce fichier",
117                     texte = str(p.cr))
118             return None
119          return text
120      else:
121          # Il n'existe pas c'est une erreur
122          self.parent.appli.affiche_infos("Type de fichier non reconnu")
123          showerror("Type de fichier non reconnu","EFICAS ne sait pas ouvrir ce type de fichier")
124          return None
125
126   def change_fichier_init(self,event=None):
127     """ 
128         Effectue le changement de fichier d'initialisation s'il est valide 
129     """
130     if not hasattr(self.node.item.object,'fichier_init'):
131        self.node.item.object.fichier_init=None
132     old_fic = self.node.item.object.fichier_init
133     new_fic = self.entry.get()
134     if not os.path.isfile(new_fic) :
135       showinfo("Fichier introuvable","Le fichier que vous avez saisi\n"+
136                "n'est pas un nom de fichier valide !")
137       self.parent.appli.affiche_infos("Fichier introuvable")
138       return
139     # On convertit le fichier
140     text=self.convert_file(new_fic)
141     if not text:return
142     try:
143       self.node.item.object.make_contexte(new_fic,text)
144       self.parent.appli.affiche_infos("Fichier %s modifié" %self.node.item.get_nom())
145     except:
146       #traceback.print_exc()
147       l=traceback.format_exception_only("Fichier invalide",sys.exc_info()[1])
148       showinfo("Fichier invalide",
149                "Erreur dans l'interprétation du nouveau fichier ...\n"+
150                "L'ancien va être restauré\n"+string.join(l))
151
152       self.entry.delete(0,Tkinter.END)
153       self.parent.appli.affiche_infos("Fichier invalide")
154
155       if old_fic:
156          # On convertit le fichier
157          #text=self.convert_file(old_fic)
158          #if not text:return
159          #self.node.item.object.make_contexte(old_fic,text)
160          self.node.item.object.fichier_init=old_fic
161          self.entry.insert(0,self.node.item.object.fichier_init)
162          self.parent.appli.affiche_infos("Fichier invalide ... Ancien fichier restauré")
163       return
164     # si on passe ici, c'est que le new_fic a bien été correctement 
165     #  interprété ...
166     self.node.item.object.fichier_init = new_fic
167     # il faut lancer la réévaluation de tout le jdc ... 
168     self.node.item.object.reevalue_sd_jdc()
169     self.node.racine.update()
170
171   def annule_fichier_init(self,event=None):
172     """ retaure dans self.entry le nom de fichier_init"""
173     self.entry.delete(0,Tkinter.END)
174     self.entry.insert(0,self.node.item.object.fichier_init)
175
176   def browse_fichier_init(self,event=None):
177     """ 
178          Propose à l'utilisateur une Bsf et retourne le fichier 
179          sélectionné dans self.entry 
180     """
181     file = askopenfilename(title="Choix du fichier %s" %self.node.item.get_nom(),
182                          #  filetypes = ( ("Aster", ".comm"),("Python", ".py")),
183                          #  defaultextension=".comm"
184                           )
185     if file != '' :
186       self.entry.delete(0,Tkinter.END)
187       self.entry.insert(0,file)
188     
189     
190 class MACROTreeItem(compooper.EtapeTreeItem):
191   panel=MACROPanel
192
193   def IsExpandable(self):
194       return 1
195
196   def GetIconName(self):
197       """
198       Retourne le nom de l'icône à afficher dans l'arbre
199       Ce nom dépend de la validité de l'objet
200       """
201       if self.object.isactif():
202         if self.object.state != 'unchanged':
203            # Si des modifications ont eu lieu on force le calcul des concepts de sortie
204            # et celui du contexte glissant
205            self.object.get_type_produit(force=1)
206            self.object.parent.reset_context()
207         if self.object.isvalid():
208           return "ast-green-square"
209         else:
210           return "ast-red-square"
211       else:
212         return "ast-white-square"
213
214   def GetLabelText(self):
215       """ Retourne 3 valeurs :
216       - le texte à afficher dans le noeud représentant l'item
217       - la fonte dans laquelle afficher ce texte
218       - la couleur du texte
219       """
220       if self.object.isactif():
221         # None --> fonte et couleur par défaut
222         return self.labeltext,None,None
223       else:
224         return self.labeltext,fontes.standard_italique,None
225       
226   def get_objet(self,name) :
227       for v in self.object.mc_liste:
228           if v.nom == name : return v
229       return None
230       
231   def additem(self,name,pos):
232       if isinstance(name,Objecttreeitem.ObjectTreeItem) :
233           mcent = self.object.addentite(name.object,pos)
234       else :
235           mcent = self.object.addentite(name,pos)
236       self.expandable=1
237       if mcent == 0 :
238           # on ne peut ajouter l'élément de nom name
239           return 0
240       def setfunction(value, object=mcent):
241           object.setval(value)
242       item = self.make_objecttreeitem(self.appli,mcent.nom + " : ", mcent, setfunction)
243       return item
244
245   def suppitem(self,item) :
246       # item : item du MOCLE de l'ETAPE à supprimer
247       # item.object = MCSIMP, MCFACT, MCBLOC ou MCList 
248       if item.object.isoblig() :
249           self.appli.affiche_infos('Impossible de supprimer un mot-clé obligatoire ')
250           print "Impossible de supprimer un mot-clé obligatoire"
251           return 0
252       else :
253           self.object.suppentite(item.object)
254           message = "Mot-clé " + item.object.nom + " supprimé"
255           self.appli.affiche_infos(message)
256           return 1
257
258   def GetText(self):
259       try:
260           return self.object.get_sdname()
261       except:
262           return ''
263
264   def keys(self):
265       keys=self.object.mc_dict.keys()
266       return keys
267
268   def GetSubList(self):
269       sublist=[]
270       for obj in self.object.mc_liste:
271         def setfunction(value, object=obj):
272           object.setval(value)
273         item = self.make_objecttreeitem(self.appli, obj.nom + " : ", obj, setfunction)
274         sublist.append(item)
275       return sublist
276
277   def isvalid(self):
278       return self.object.isvalid()
279
280   def iscopiable(self):
281       """
282       Retourne 1 si l'objet est copiable, 0 sinon
283       """
284       return 1
285
286   def isCommande(self):
287       """
288       Retourne 1 si l'objet pointé par self est une Commande, 0 sinon
289       """
290       return 1
291       
292   def verif_condition_bloc(self):
293       return self.object.verif_condition_bloc()
294
295   def get_noms_sd_oper_reentrant(self):
296       return self.object.get_noms_sd_oper_reentrant()
297
298 import Accas
299 treeitem=MACROTreeItem
300 objet=Accas.MACRO_ETAPE
301     
302 class MacroDisplay:
303   def __init__(self,appli,jdc,nom_jdc):
304     self.fenetre = Tkinter.Toplevel()
305     self.fenetre.configure(width = 800,height=500)
306     self.fenetre.protocol("WM_DELETE_WINDOW", self.quit)
307     self.fenetre.title("Visualisation Macro_Etape")
308     self.jdc=jdc
309     self.nom_jdc=nom_jdc
310     self.appli=appli
311     self.mainPart=Pmw.ScrolledCanvas(self.fenetre,
312                                      hull_width=600,
313                                      hull_height=500,
314                                      borderframe=1)
315     self.canvas=self.mainPart.component('canvas')
316     Pmw.Color.changecolor(self.canvas,background='gray95')
317     self.mainPart.pack(padx=10,pady=10,fill = 'both', expand = 1)
318     self.item=MACRO2TreeItem(self.appli,nom_jdc,jdc)
319     import treewidget
320     self.tree = treewidget.Tree(self.appli,self.item,self.mainPart,command=None)
321     self.tree.draw()
322     
323   def quit(self):
324     self.fenetre.destroy()
325