]> SALOME platform Git repositories - tools/eficas.git/blob - Editeur/compomacro.py
Salome HOME
F.R: fin correction bug copier/coller
[tools/eficas.git] / Editeur / compomacro.py
1 #@ MODIF compomacro Editeur  DATE 02/07/2001   AUTEUR D6BHHJP J.P.LEFEBVRE 
2 #            CONFIGURATION MANAGEMENT OF EDF VERSION
3 # ======================================================================
4 # COPYRIGHT (C) 1991 - 2001  EDF R&D                  WWW.CODE-ASTER.ORG
5 #              SEE THE FILE "LICENSE.TERMS" FOR INFORMATION ON USAGE AND
6 #              REDISTRIBUTION OF THIS FILE.
7 # ======================================================================
8 # Modules Python
9 import os,sys,string
10 import types
11 import Tkinter
12 import Pmw
13 from tkFileDialog import *
14 from tkMessageBox import showinfo,showerror
15 import traceback
16
17 # Modules Eficas
18 import Objecttreeitem
19 import panels
20 import fontes
21 import compooper
22 import convert
23 from widgets import Fenetre
24
25 #
26 __version__="$Name:  $"
27 __Id__="$Id: compomacro.py,v 1.2 2002/04/03 11:35:12 eficas Exp $"
28 #
29
30 class MACROPanel(panels.OngletPanel):
31   def init(self):
32     nb = Pmw.NoteBook(self,raisecommand=self.raisecmd)
33     nb.pack(fill = 'both', expand = 1)
34     self.nb=nb
35     nb.add('Mocles', tab_text='Ajouter mots-clés')
36     typsd=self.node.item.object.get_type_produit()
37     ficini = self.node.item.wait_fichier_init()
38     if typsd != None:
39       nb.add('Concept', tab_text='Nommer concept')
40     if ficini == 1:
41       nb.add('Fichierinit',tab_text = 'Fichier %s' %self.node.item.get_nom())
42     nb.add('Commande', tab_text='Insérer Commande')
43     nb.add('Commentaire',tab_text='Paramètre/Commentaire')
44     panneau=Pmw.PanedWidget(nb.page("Mocles"),
45                             orient='horizontal')
46     panneau.add('left',min=0.4,max=0.6,size=0.5)
47     panneau.add('right',min=0.4,max=0.6,size=0.5)
48     panneau.pack(expand=1,fill='both')
49     self.makeCommandePage(nb.page("Commande"))
50     if typsd != None:
51       self.makeConceptPage(nb.page("Concept"))
52     if ficini == 1 :
53       self.makeFichierPage(nb.page('Fichierinit'))
54     self.makeMoclesPage(panneau.pane('left'))
55     self.makeReglesPage(panneau.pane('right'))
56     self.makeParamCommentPage_for_etape(nb.page("Commentaire"))
57     nb.tab('Mocles').focus_set()
58     nb.setnaturalsize()
59     #self.monmenu=Tkinter.Menu(self.parent.appli.menubar,tearoff=0)
60     #self.monmenu.add_command(label='Build',command=self.Build)
61     #self.monmenu.add_command(label='View',command=self.View)
62     #self.parent.appli.add_menu(label="Macro",menu=self.monmenu)    
63     self.affiche()
64
65   def Build(self):
66     print "Build"
67     self.node.item.object.Build()
68
69   def View(self):
70     print "View"
71     MacroDisplay(self.parent.appli,self.node.item.object,self.node.item.object.nom)
72
73   def makeFichierPage(self,page):
74     """\r
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_init'):\r
87       if self.node.item.object.fichier_init :\r
88         self.entry.insert(0,self.node.item.object.fichier_init)
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_init'):
119        self.node.item.object.fichier_init=None
120     old_fic = self.node.item.object.fichier_init
121     new_fic = self.entry.get()
122     if not os.path.isfile(new_fic) :
123       showinfo("Fichier introuvable","Le fichier que vous avez saisi\n"+
124                "n'est pas un nom de fichier valide !")
125       self.parent.appli.affiche_infos("Fichier introuvable")
126       return
127     # On convertit le fichier
128     text=self.convert_file(new_fic)
129     if not text:return
130     try:
131       self.node.item.object.make_contexte(new_fic,text)
132       self.parent.appli.affiche_infos("Fichier %s modifié" %self.node.item.get_nom())
133     except:
134       #traceback.print_exc()
135       l=traceback.format_exception_only("Fichier invalide",sys.exc_info()[1])
136       showinfo("Fichier invalide",
137                "Erreur dans l'interprétation du nouveau fichier ...\n"+
138                "L'ancien va être restauré\n"+string.join(l))
139
140       self.entry.delete(0,Tkinter.END)
141       self.parent.appli.affiche_infos("Fichier invalide")
142
143       if old_fic:
144          # On convertit le fichier
145          #text=self.convert_file(old_fic)
146          #if not text:return
147          #self.node.item.object.make_contexte(old_fic,text)
148          self.node.item.object.fichier_init=old_fic
149          self.entry.insert(0,self.node.item.object.fichier_init)
150          self.parent.appli.affiche_infos("Fichier invalide ... Ancien fichier restauré")
151       return
152     # si on passe ici, c'est que le new_fic a bien été correctement 
153     #  interprété ...
154     self.node.item.object.fichier_init = new_fic
155     # il faut lancer la réévaluation de tout le jdc ... 
156     self.node.item.object.reevalue_sd_jdc()
157     self.node.racine.update()
158
159   def annule_fichier_init(self,event=None):
160     """ retaure dans self.entry le nom de fichier_init"""
161     self.entry.delete(0,Tkinter.END)
162     self.entry.insert(0,self.node.item.object.fichier_init)
163
164   def browse_fichier_init(self,event=None):
165     """ 
166          Propose à l'utilisateur une Bsf et retourne le fichier 
167          sélectionné dans self.entry 
168     """
169     file = askopenfilename(title="Choix du fichier %s" %self.node.item.get_nom(),
170                          #  filetypes = ( ("Aster", ".comm"),("Python", ".py")),
171                          #  defaultextension=".comm"
172                           )
173     if file != '' :
174       self.entry.delete(0,Tkinter.END)
175       self.entry.insert(0,file)
176     
177     
178 class MACROTreeItem(compooper.EtapeTreeItem):
179   panel=MACROPanel
180
181   def IsExpandable(self):
182       return 1
183
184   def GetIconName(self):
185       """
186       Retourne le nom de l'icône à afficher dans l'arbre
187       Ce nom dépend de la validité de l'objet
188       """
189       if self.object.isactif():
190         if self.object.state != 'unchanged':
191            # Si des modifications ont eu lieu on force le calcul des concepts de sortie
192            # et celui du contexte glissant
193            self.object.get_type_produit(force=1)
194            self.object.parent.reset_context()
195         if self.object.isvalid():
196           return "ast-green-square"
197         else:
198           return "ast-red-square"
199       else:
200         return "ast-white-square"
201
202   def GetLabelText(self):
203       """ Retourne 3 valeurs :
204       - le texte à afficher dans le noeud représentant l'item
205       - la fonte dans laquelle afficher ce texte
206       - la couleur du texte
207       """
208       if self.object.isactif():
209         # None --> fonte et couleur par défaut
210         return self.labeltext,None,None
211       else:
212         return self.labeltext,fontes.standard_italique,None
213       
214   def get_objet(self,name) :
215       for v in self.object.mc_liste:
216           if v.nom == name : return v
217       return None
218       
219   def additem(self,name,pos):
220       if isinstance(name,Objecttreeitem.ObjectTreeItem) :
221           mcent = self.object.addentite(name.object,pos)
222       else :
223           mcent = self.object.addentite(name,pos)
224       self.expandable=1
225       if mcent == 0 :
226           # on ne peut ajouter l'élément de nom name
227           return 0
228       def setfunction(value, object=mcent):
229           object.setval(value)
230       item = self.make_objecttreeitem(self.appli,mcent.nom + " : ", mcent, setfunction)
231       return item
232
233   def suppitem(self,item) :
234       # item : item du MOCLE de l'ETAPE à supprimer
235       # item.object = MCSIMP, MCFACT, MCBLOC ou MCList 
236       if item.object.isoblig() :
237           self.appli.affiche_infos('Impossible de supprimer un mot-clé obligatoire ')
238           print "Impossible de supprimer un mot-clé obligatoire"
239           return 0
240       else :
241           self.object.suppentite(item.object)
242           message = "Mot-clé " + item.object.nom + " supprimé"
243           self.appli.affiche_infos(message)
244           return 1
245
246   def GetText(self):
247       try:
248           return self.object.get_sdname()
249       except:
250           return ''
251
252   def keys(self):
253       keys=self.object.mc_dict.keys()
254       return keys
255
256   def GetSubList(self):
257       sublist=[]
258       for obj in self.object.mc_liste:
259         def setfunction(value, object=obj):
260           object.setval(value)
261         item = self.make_objecttreeitem(self.appli, obj.nom + " : ", obj, setfunction)
262         sublist.append(item)
263       return sublist
264
265   def isvalid(self):
266       return self.object.isvalid()
267
268   def iscopiable(self):
269       """
270       Retourne 1 si l'objet est copiable, 0 sinon
271       """
272       return 1
273
274   def isCommande(self):
275       """
276       Retourne 1 si l'objet pointé par self est une Commande, 0 sinon
277       """
278       return 1
279       
280   def verif_condition_bloc(self):
281       return self.object.verif_condition_bloc()
282
283   def get_noms_sd_oper_reentrant(self):
284       return self.object.get_noms_sd_oper_reentrant()
285
286 import Accas
287 treeitem=MACROTreeItem
288 objet=Accas.MACRO_ETAPE
289     
290 class MacroDisplay:
291   def __init__(self,appli,jdc,nom_jdc):
292     self.fenetre = Tkinter.Toplevel()
293     self.fenetre.configure(width = 800,height=500)
294     self.fenetre.protocol("WM_DELETE_WINDOW", self.quit)
295     self.fenetre.title("Visualisation Macro_Etape")
296     self.jdc=jdc
297     self.nom_jdc=nom_jdc
298     self.appli=appli
299     self.mainPart=Pmw.ScrolledCanvas(self.fenetre,
300                                      hull_width=600,
301                                      hull_height=500,
302                                      borderframe=1)
303     self.canvas=self.mainPart.component('canvas')
304     Pmw.Color.changecolor(self.canvas,background='gray95')
305     self.mainPart.pack(padx=10,pady=10,fill = 'both', expand = 1)
306     self.item=MACRO2TreeItem(self.appli,nom_jdc,jdc)
307     import treewidget
308     self.tree = treewidget.Tree(self.appli,self.item,self.mainPart,command=None)
309     self.tree.draw()
310     
311   def quit(self):
312     self.fenetre.destroy()
313