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 myrepr.maxstring = 100
28 from Noyau.N_utils import repr_float
30 # Attention : les classes ASSD,.... peuvent etre surchargées
31 # dans le package Accas. Il faut donc prendre des précautions si
32 # on utilise les classes du Noyau pour faire des tests (isxxxx, ...)
33 # Si on veut créer des objets comme des CO avec les classes du noyau
34 # ils n'auront pas les conportements des autres packages (pb!!!)
35 # Il vaut mieux les importer d'Accas mais problème d'import circulaire,
36 # on ne peut pas les importer au début.
37 # On fait donc un import local quand c'est nécessaire (peut occasionner
38 # des pbs de prformance).
39 from Noyau.N_ASSD import ASSD,assd
40 from Noyau.N_GEOM import GEOM,geom
41 from Noyau.N_CO import CO
44 from Extensions import parametre
47 class MCSIMP(I_OBJECT.OBJECT):
50 Retourne le texte à afficher dans l'arbre représentant la valeur de l'objet
53 if self.valeur == None :
55 elif type(self.valeur) == types.FloatType :
56 # Traitement d'un flottant isolé
57 #txt = repr_float(self.valeur)
58 # Normalement str fait un travail correct
59 txt = str(self.valeur)
60 elif type(self.valeur) in (types.ListType,types.TupleType) :
61 # Traitement des listes
64 for val in self.valeur:
65 if type(val) == types.FloatType :
66 # CCAR : Normalement str fait un travail correct
67 #txt=txt + i*',' + repr_float(val)
68 txt=txt + i*',' + str(val)
69 elif isinstance(val,ASSD):
70 txt = txt + i*',' + val.get_name()
73 elif type(val) == types.InstanceType and val.__class__.__name__ in ('PARAMETRE','PARAMETRE_EVAL'):
74 txt = txt + i*','+ str(val)
76 txt = txt + i*','+ myrepr.repr(val)
79 elif isinstance(self.valeur,ASSD):
82 elif type(self.valeur) == types.InstanceType and self.valeur.__class__.__name__ in ('PARAMETRE','PARAMETRE_EVAL'):
86 # Traitement des autres cas
87 txt = myrepr.repr(self.valeur)
89 # txt peut etre une longue chaine sur plusieurs lignes.
90 # Il est possible de tronquer cette chaine au premier \n et
91 # de limiter la longueur de la chaine a 30 caracteres. Cependant
92 # ceci provoque une perte d'information pour l'utilisateur
93 # Pour le moment on retourne la chaine telle que
98 Retourne une chaîne de caractère représentant la valeur de self
101 if type(val) != types.TupleType :
103 return val.get_name()
110 s=s+item.get_name()+','
118 Méthode booléenne qui retourne 1 si l'objet attend un objet ASSD
119 qui n'existe pas encore (type CO()), 0 sinon
121 for typ in self.definition.type:
122 if type(typ) == types.ClassType :
123 if issubclass(typ,CO) :
129 Méthode booléenne qui retourne 1 si le MCS attend un objet de type ASSD
132 for typ in self.definition.type:
133 if type(typ) == types.ClassType :
134 if issubclass(typ,ASSD) and not issubclass(typ,GEOM):
138 def wait_assd_or_geom(self):
140 Retourne 1 si le mot-clé simple attend un objet de type
141 assd, ASSD, geom ou GEOM
142 Retourne 0 dans le cas contraire
144 for typ in self.definition.type:
145 if type(typ) == types.ClassType :
146 if typ.__name__ in ("GEOM","ASSD","geom","assd") or issubclass(typ,GEOM) :
152 Retourne 1 si le mot-clé simple attend un objet de type GEOM
153 Retourne 0 dans le cas contraire
155 for typ in self.definition.type:
156 if type(typ) == types.ClassType :
157 if issubclass(typ,GEOM) : return 1
162 Retourne 1 si le mot-clé simple attend un objet de type TXM
163 Retourne 0 dans le cas contraire
165 for typ in self.definition.type:
166 if typ == 'TXM' :return 1
169 def get_liste_valeurs(self):
172 if self.valeur == None:
174 elif type(self.valeur) == types.TupleType:
175 return list(self.valeur)
176 elif type(self.valeur) == types.ListType:
182 return self.definition.statut=='o'
184 def set_valeur(self,new_valeur,evaluation='oui'):
186 self.valeur = new_valeur
187 self.val = new_valeur
191 def eval_valeur(self,new_valeur):
193 Essaie d'évaluer new_valeur comme une SD, une déclaration Python
194 ou un EVAL: Retourne la valeur évaluée (ou None) et le test de réussite (1 ou 0)
196 sd = self.jdc.get_contexte_avant(self.etape).get(new_valeur,None)
201 # On veut EVAL avec tous ses comportements. On utilise Accas. Perfs ??
202 from Accas import EVAL
205 objet = eval(new_valeur,d)
208 if CONTEXT.debug : traceback.print_exc()
211 def delete_concept(self,sd):
216 Met a jour la valeur du mot cle simple suite à la disparition
219 if type(self.valeur) == types.TupleType :
220 if sd in self.valeur:
221 self.valeur=list(self.valeur)
222 self.valeur.remove(sd)
224 elif type(self.valeur) == types.ListType:
225 if sd in self.valeur:
226 self.valeur.remove(sd)
229 if self.valeur == sd:
234 def replace_concept(self,old_sd,sd):
237 - old_sd=concept remplacé
240 Met a jour la valeur du mot cle simple suite au remplacement
243 if type(self.valeur) == types.TupleType :
244 if old_sd in self.valeur:
245 self.valeur=list(self.valeur)
246 i=self.valeur.index(old_sd)
249 elif type(self.valeur) == types.ListType:
250 if old_sd in self.valeur:
251 i=self.valeur.index(old_sd)
255 if self.valeur == old_sd:
260 def set_valeur_co(self,nom_co):
262 Affecte à self l'objet de type CO et de nom nom_co
264 step=self.etape.parent
265 if nom_co == None or nom_co == '':
268 # Pour le moment on importe en local le CO de Accas.
269 # Si problème de perfs, il faudra faire autrement
271 # Avant de créer un concept il faut s'assurer du contexte : step
273 sd= step.get_sd_autour_etape(nom_co,self.etape,avec='oui')
275 # Si un concept du meme nom existe deja dans la portée de l'étape
276 # on ne crée pas le concept
277 return 0,"un concept de meme nom existe deja"
278 # Il n'existe pas de concept de meme nom. On peut donc le créer
279 # Il faut néanmoins que la méthode NommerSdProd de step gère les
280 # contextes en mode editeur
281 # Normalement la méthode du Noyau doit etre surchargée
282 # On déclare l'étape du mot clé comme etape courante pour NommerSdprod
283 cs= CONTEXT.get_current_step()
284 CONTEXT.unset_current_step()
285 CONTEXT.set_current_step(step)
286 step.set_etape_context(self.etape)
287 new_objet = CO(nom_co)
288 CONTEXT.unset_current_step()
289 CONTEXT.set_current_step(cs)
291 self.valeur = new_objet
295 # On force l'enregistrement de new_objet en tant que concept produit
296 # de la macro en appelant get_type_produit avec force=1
297 self.etape.get_type_produit(force=1)
298 return 1,"Concept créé"
300 def verif_existence_sd(self):
302 Vérifie que les structures de données utilisées dans self existent bien dans le contexte
303 avant étape, sinon enlève la référence à ces concepts
305 l_sd_avant_etape = self.jdc.get_contexte_avant(self.etape).values()
306 if type(self.valeur) in (types.TupleType,types.ListType) :
308 for sd in self.valeur:
309 if isinstance(sd,ASSD) :
310 if sd in l_sd_avant_etape :
315 # Est ce init_modif ou init_modif_up
316 # Normalement init_modif va avec fin_modif
320 if isinstance(self.valeur,ASSD) :
321 if self.valeur not in l_sd_avant_etape :
326 def get_min_max(self):
328 Retourne les valeurs min et max admissibles pour la valeur de self
330 return self.definition.min,self.definition.max
335 Retourne le type attendu par le mot-clé simple
337 return self.definition.type
339 #--------------------------------------------------------------------------------
340 # PN : ajout pour Salome des methodes suivantes (jusqu aux méthodes surchargees)
341 #--------------------------------------------------------------------------------
342 def get_salome_valeurs(self):
344 if not hasattr(self,'list_salome_valeurs'):
345 self.list_salome_valeurs=[]
346 if self.list_salome_valeurs != [] :
347 for val in self.list_salome_valeurs:
351 def put_salome_valeurs(self,list):
352 self.list_salome_valeurs=[]
354 self.list_salome_valeurs.append(val)
356 def add_salome_valeurs(self,val):
357 if not hasattr(self,'list_salome_valeurs'):
358 self.list_salome_valeurs=[]
360 self.list_salome_valeurs.append(val)
364 self.list_salome_valeurs.append(uneval)
368 def has_salome_valeurs(self):
369 if not hasattr(self,'list_salome_valeurs'):
370 self.list_salome_valeurs=[]
371 if self.list_salome_valeurs != []:
376 #--------------------------------------------------------------------------------
377 # PN : fin ajout pour Salome
378 #--------------------------------------------------------------------------------
380 #ATTENTION SURCHARGE : toutes les methodes ci apres sont des surcharges du Noyau et de Validation
381 # Elles doivent etre reintegrees des que possible