+# -*- coding: utf-8 -*-
# CONFIGURATION MANAGEMENT OF EDF VERSION
# ======================================================================
# COPYRIGHT (C) 1991 - 2002 EDF R&D WWW.CODE-ASTER.ORG
import types
import Tkinter
import Pmw
-from tkFileDialog import *
-from tkMessageBox import showinfo,showerror,askyesno
import traceback
# Modules Eficas
import fontes
import compooper
import convert
+from widgets import askopenfilename
from widgets import Fenetre,FenetreYesNo
+from widgets import showinfo,showerror
#
__version__="$Name: $"
-__Id__="$Id: compomacro.py,v 1.10 2002/11/14 12:14:20 eficas Exp $"
+__Id__="$Id: compomacro.py,v 1.18 2005/04/18 14:21:08 eficas Exp $"
#
class MACROPanel(panels.OngletPanel):
"""
Effectue le changement de fichier d'initialisation s'il est valide
"""
- if not hasattr(self.node.item.object,'fichier_ini'):
- self.node.item.object.fichier_ini=None
- self.node.item.object.fichier_text=None
- self.node.item.object.fichier_err="Le fichier n'est pas defini"
- self.node.item.object.contexte_fichier_init={}
- self.node.item.object.recorded_units={}
- self.node.item.object.fichier_unite="PasDefini"
- import Extensions.jdc_include
- self.node.item.object.JdC_aux=Extensions.jdc_include.JdC_include
-
- old_fic = self.node.item.object.fichier_ini
- old_text = self.node.item.object.fichier_text
- old_err = self.node.item.object.fichier_err
- old_context=self.node.item.object.contexte_fichier_init
- old_units=self.node.item.object.recorded_units
- old_etapes=self.node.item.object.etapes
-
new_fic = self.entry.get()
if not os.path.isfile(new_fic) :
showinfo("Fichier introuvable","Le fichier que vous avez saisi\n"+
# Si probleme a la lecture-conversion on arrete le traitement
if not text:
return
- self.node.item.object.recorded_units={}
try:
- self.node.item.object.make_contexte_include(new_fic,text)
+ self.node.item.object.change_fichier_init(new_fic,text)
+ self.parent.appli.affiche_infos("Fichier %s modifié" %self.node.item.get_nom())
except:
# Erreurs lors de l'evaluation de text dans un JDC auxiliaire
self.parent.appli.affiche_infos("Fichier invalide")
if reponse:
# On retablit l'ancien fichier
self.entry.delete(0,Tkinter.END)
- self.node.item.object.fichier_ini=old_fic
- self.node.item.object.fichier_text=old_text
- self.node.item.object.fichier_err=old_err
- self.node.item.object.contexte_fichier_init=old_context
- self.node.item.object.recorded_units=old_units
- self.node.item.object.etapes=old_etapes
+ self.node.item.object.restore_fichier_init()
self.parent.appli.affiche_infos("Fichier invalide ... Ancien fichier restauré")
- if old_fic:
- self.entry.insert(0,self.node.item.object.fichier_ini)
+ fic=self.node.item.object.fichier_ini
+ if fic:
+ self.entry.insert(0,fic)
else:
- # On conserve la memoire du nouveau fichier
- # mais on n'utilise pas les concepts crees par ce fichier
- # on met l'etape en erreur : fichier_err=string.join(l)
- self.node.item.object.init_modif()
- self.node.item.object.fichier_ini=new_fic
- self.node.item.object.fichier_text=text
- self.node.item.object.fichier_err=string.join(l)
- # On enregistre la modification de fichier
- self.node.item.object.record_unite()
- #self.node.item.object.etapes=[]
- self.node.item.object.g_context={}
- # Le contexte du parent doit etre reinitialise car les concepts produits ont changé
- self.node.item.object.parent.reset_context()
-
- self.node.item.object.old_contexte_fichier_init=old_context
- self.node.item.object.contexte_fichier_init={}
- self.node.item.object.reevalue_sd_jdc()
-
- self.node.item.object.fin_modif()
+ self.node.item.object.force_fichier_init()
self.parent.appli.affiche_infos("Fichier invalide ... Nouveau fichier mémorisé")
- self.node.update()
- return
-
- # L'evaluation de text dans un JDC auxiliaire s'est bien passé
- # on peut poursuivre le traitement
- self.node.item.object.init_modif()
- self.node.item.object.fichier_ini = new_fic
- self.node.item.object.fichier_text=text
- self.node.item.object.fichier_err=None
- # On enregistre la modification de fichier
- self.node.item.object.record_unite()
- # Le contexte du parent doit etre reinitialise car les concepts produits ont changé
- self.node.item.object.parent.reset_context()
-
- # Si des concepts ont disparu lors du changement de fichier, on demande leur suppression
- self.node.item.object.old_contexte_fichier_init=old_context
- self.node.item.object.reevalue_sd_jdc()
-
- self.node.item.object.fin_modif()
- self.parent.appli.affiche_infos("Fichier %s modifié" %self.node.item.get_nom())
- self.node.update()
def annule_fichier_init(self,event=None):
""" Restaure dans self.entry le nom de fichier_init"""
sélectionné dans self.entry
"""
file = askopenfilename(title="Choix du fichier %s" %self.node.item.get_nom())
- if file != '' :
+ if file :
self.entry.delete(0,Tkinter.END)
self.entry.insert(0,file)
class MACROTreeItem(compooper.EtapeTreeItem):
+ """ Cette classe hérite d'une grande partie des comportements
+ de la classe compooper.EtapeTreeItem
+ """
panel=MACROPanel
- def IsExpandable(self):
- return 1
-
- def GetIconName(self):
- """
- Retourne le nom de l'icône à afficher dans l'arbre
- Ce nom dépend de la validité de l'objet
- """
- if not self.object.isactif():
- return "ast-white-square"
- else:
- if self.object.isvalid():
- return "ast-green-square"
- else:
- return "ast-red-square"
-
- def GetLabelText(self):
- """ Retourne 3 valeurs :
- - le texte à afficher dans le noeud représentant l'item
- - la fonte dans laquelle afficher ce texte
- - la couleur du texte
- """
- if self.object.isactif():
- # None --> fonte et couleur par défaut
- return self.labeltext,None,None
- else:
- return self.labeltext,fontes.standard_italique,None
-
- def get_objet(self,name) :
- for v in self.object.mc_liste:
- if v.nom == name : return v
- return None
-
- def additem(self,name,pos):
- if isinstance(name,Objecttreeitem.ObjectTreeItem) :
- mcent = self.object.addentite(name.object,pos)
- else :
- mcent = self.object.addentite(name,pos)
- self.expandable=1
- if mcent == 0 :
- # on ne peut ajouter l'élément de nom name
- return 0
- def setfunction(value, object=mcent):
- object.setval(value)
- item = self.make_objecttreeitem(self.appli,mcent.nom + " : ", mcent, setfunction)
- return item
-
- def suppitem(self,item) :
- # item : item du MOCLE de l'ETAPE à supprimer
- # item.object = MCSIMP, MCFACT, MCBLOC ou MCList
- if item.object.isoblig() :
- self.appli.affiche_infos('Impossible de supprimer un mot-clé obligatoire ')
- print "Impossible de supprimer un mot-clé obligatoire"
- return 0
- else :
- self.object.suppentite(item.object)
- message = "Mot-clé " + item.object.nom + " supprimé"
- self.appli.affiche_infos(message)
- return 1
-
- def GetText(self):
- try:
- return self.object.get_sdname()
- except:
- return ''
-
- def keys(self):
- keys=self.object.mc_dict.keys()
- return keys
-
- def GetSubList(self):
- sublist=[]
- for obj in self.object.mc_liste:
- def setfunction(value, object=obj):
- object.setval(value)
- item = self.make_objecttreeitem(self.appli, obj.nom + " : ", obj, setfunction)
- sublist.append(item)
- return sublist
+class INCLUDETreeItem(MACROTreeItem):
+ rmenu_specs=[("View","makeView"),
+ ("Edit","makeEdit"),
+ ]
- def isvalid(self):
- return self.object.isvalid()
+ def __init__(self,appli, labeltext, object, setfunction):
+ MACROTreeItem.__init__(self,appli, labeltext, object, setfunction)
def iscopiable(self):
"""
Retourne 1 si l'objet est copiable, 0 sinon
"""
- return 1
-
- def isCommande(self):
- """
- Retourne 1 si l'objet pointé par self est une Commande, 0 sinon
- """
- return 1
-
- def verif_condition_bloc(self):
- return self.object.verif_condition_bloc()
-
- def get_noms_sd_oper_reentrant(self):
- return self.object.get_noms_sd_oper_reentrant()
-
-class INCLUDETreeItem(MACROTreeItem):
- rmenu_specs=[("View","makeView")]
-
- def makeView(self,appli):
+ return 0
+
+ def makeEdit(self,appli,node):
+ #print "makeEdit",self.object,self.object.nom
+ #print "makeEdit",self.object.jdc_aux,self.object.jdc_aux.nom
+ #print "makeEdit",self.object.jdc_aux.context_ini
+ self.parent_node=node
+ # On cree un nouvel onglet dans le bureau
+ appli.bureau.ShowJDC(self.object.jdc_aux,self.object.jdc_aux.nom,
+ label_onglet=None,
+ JDCDISPLAY=macrodisplay.MACRODISPLAY)
+ self.myjdc=appli.bureau.JDCDisplay_courant
+ self.myjdc.fichier=self.object.fichier_ini
+
+ def makeView(self,appli,node):
nom=self.object.nom
if hasattr(self.object,'fichier_ini'):
if self.object.fichier_ini is None:
nom=nom+' '+"Fichier non défini"
else:
nom=nom+' '+self.object.fichier_ini
- macrodisplay.makeMacroDisplay(appli,self.object,nom)
+ macdisp=macrodisplay.makeMacroDisplay(appli,self,nom)
-class INCLUDE_MATERIAUTreeItem(INCLUDETreeItem): pass
class POURSUITETreeItem(INCLUDETreeItem): pass
-treeitem=MACROTreeItem
+class INCLUDE_MATERIAUTreeItem(INCLUDETreeItem):
+ rmenu_specs=[("View","makeView"),
+ ]
+ def iscopiable(self):
+ """
+ Retourne 1 si l'objet est copiable, 0 sinon
+ """
+ return 1
+
+
def treeitem(appli, labeltext, object, setfunction=None):
+ """ Factory qui retourne l'item adapté au type de macro :
+ INCLUDE, POURSUITE, MACRO
+ """
if object.nom == "INCLUDE_MATERIAU":
return INCLUDE_MATERIAUTreeItem(appli, labeltext, object, setfunction)
elif object.nom == "INCLUDE":