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.
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.
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.
19 # ======================================================================
25 from tkFileDialog import *
26 from tkMessageBox import showinfo,showerror
35 from widgets import Fenetre
38 __version__="$Name: $"
39 __Id__="$Id: compomacro.py,v 1.4 2002/05/15 15:31:58 eficas Exp $"
42 class MACROPanel(panels.OngletPanel):
44 nb = Pmw.NoteBook(self,raisecommand=self.raisecmd)
45 nb.pack(fill = 'both', expand = 1)
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()
51 nb.add('Concept', tab_text='Nommer concept')
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"),
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"))
63 self.makeConceptPage(nb.page("Concept"))
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()
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)
79 self.node.item.object.Build()
83 MacroDisplay(self.parent.appli,self.node.item.object,self.node.item.object.nom)
85 def makeFichierPage(self,page):
87 Affiche la page d'onglet correspondant au changement du fichier
88 dont a besoin la macro
\r
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)
103 def convert_file(self,file):
105 Methode pour convertir le fichier file dans le format courant
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]()
112 text=p.convert('execnoparseur')
113 if not p.cr.estvide():
114 self.parent.appli.affiche_infos("Erreur à la conversion")
116 titre="compte-rendu d'erreurs, EFICAS ne sait pas convertir ce fichier",
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")
126 def change_fichier_init(self,event=None):
128 Effectue le changement de fichier d'initialisation s'il est valide
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")
139 # On convertit le fichier
140 text=self.convert_file(new_fic)
143 self.node.item.object.make_contexte(new_fic,text)
144 self.parent.appli.affiche_infos("Fichier %s modifié" %self.node.item.get_nom())
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))
152 self.entry.delete(0,Tkinter.END)
153 self.parent.appli.affiche_infos("Fichier invalide")
156 # On convertit le fichier
157 #text=self.convert_file(old_fic)
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é")
164 # si on passe ici, c'est que le new_fic a bien été correctement
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()
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)
176 def browse_fichier_init(self,event=None):
178 Propose à l'utilisateur une Bsf et retourne le fichier
179 sélectionné dans self.entry
181 file = askopenfilename(title="Choix du fichier %s" %self.node.item.get_nom(),
182 # filetypes = ( ("Aster", ".comm"),("Python", ".py")),
183 # defaultextension=".comm"
186 self.entry.delete(0,Tkinter.END)
187 self.entry.insert(0,file)
190 class MACROTreeItem(compooper.EtapeTreeItem):
193 def IsExpandable(self):
196 def GetIconName(self):
198 Retourne le nom de l'icône à afficher dans l'arbre
199 Ce nom dépend de la validité de l'objet
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"
210 return "ast-red-square"
212 return "ast-white-square"
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
220 if self.object.isactif():
221 # None --> fonte et couleur par défaut
222 return self.labeltext,None,None
224 return self.labeltext,fontes.standard_italique,None
226 def get_objet(self,name) :
227 for v in self.object.mc_liste:
228 if v.nom == name : return v
231 def additem(self,name,pos):
232 if isinstance(name,Objecttreeitem.ObjectTreeItem) :
233 mcent = self.object.addentite(name.object,pos)
235 mcent = self.object.addentite(name,pos)
238 # on ne peut ajouter l'élément de nom name
240 def setfunction(value, object=mcent):
242 item = self.make_objecttreeitem(self.appli,mcent.nom + " : ", mcent, setfunction)
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"
253 self.object.suppentite(item.object)
254 message = "Mot-clé " + item.object.nom + " supprimé"
255 self.appli.affiche_infos(message)
260 return self.object.get_sdname()
265 keys=self.object.mc_dict.keys()
268 def GetSubList(self):
270 for obj in self.object.mc_liste:
271 def setfunction(value, object=obj):
273 item = self.make_objecttreeitem(self.appli, obj.nom + " : ", obj, setfunction)
278 return self.object.isvalid()
280 def iscopiable(self):
282 Retourne 1 si l'objet est copiable, 0 sinon
286 def isCommande(self):
288 Retourne 1 si l'objet pointé par self est une Commande, 0 sinon
292 def verif_condition_bloc(self):
293 return self.object.verif_condition_bloc()
295 def get_noms_sd_oper_reentrant(self):
296 return self.object.get_noms_sd_oper_reentrant()
299 treeitem=MACROTreeItem
300 objet=Accas.MACRO_ETAPE
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")
311 self.mainPart=Pmw.ScrolledCanvas(self.fenetre,
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)
320 self.tree = treewidget.Tree(self.appli,self.item,self.mainPart,command=None)
324 self.fenetre.destroy()