1 #@ MODIF N_MCSIMP Noyau DATE 14/09/2004 AUTEUR MCOURTOI M.COURTOIS
2 # -*- coding: iso-8859-1 -*-
3 # CONFIGURATION MANAGEMENT OF EDF VERSION
4 # ======================================================================
5 # COPYRIGHT (C) 1991 - 2002 EDF R&D WWW.CODE-ASTER.ORG
6 # THIS PROGRAM IS FREE SOFTWARE; YOU CAN REDISTRIBUTE IT AND/OR MODIFY
7 # IT UNDER THE TERMS OF THE GNU GENERAL PUBLIC LICENSE AS PUBLISHED BY
8 # THE FREE SOFTWARE FOUNDATION; EITHER VERSION 2 OF THE LICENSE, OR
9 # (AT YOUR OPTION) ANY LATER VERSION.
11 # THIS PROGRAM IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, BUT
12 # WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF
13 # MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. SEE THE GNU
14 # GENERAL PUBLIC LICENSE FOR MORE DETAILS.
16 # YOU SHOULD HAVE RECEIVED A COPY OF THE GNU GENERAL PUBLIC LICENSE
17 # ALONG WITH THIS PROGRAM; IF NOT, WRITE TO EDF R&D CODE_ASTER,
18 # 1 AVENUE DU GENERAL DE GAULLE, 92141 CLAMART CEDEX, FRANCE.
21 # ======================================================================
25 Ce module contient la classe MCSIMP qui sert à controler la valeur
26 d'un mot-clé simple par rapport à sa définition portée par un objet
33 from Noyau.N_ASSD import ASSD,assd
36 class MCSIMP(N_OBJECT.OBJECT):
40 def __init__(self,val,definition,nom,parent):
44 - val : valeur du mot clé simple
54 - valeur : valeur du mot-clé simple en tenant compte de la valeur par défaut
57 self.definition=definition
61 self.valeur = self.GETVAL(self.val)
63 self.jdc = self.parent.jdc
64 self.niveau = self.parent.niveau
65 self.etape = self.parent.etape
67 # Le mot cle simple a été créé sans parent
74 Retourne la valeur effective du mot-clé en fonction
75 de la valeur donnée. Defaut si val == None
77 if (val is None and hasattr(self.definition,'defaut')) :
78 return self.definition.defaut
84 Retourne la "valeur" d'un mot-clé simple.
85 Cette valeur est utilisée lors de la création d'un contexte
86 d'évaluation d'expressions à l'aide d'un interpréteur Python
92 Une autre méthode qui retourne une "autre" valeur du mot clé simple.
93 Elle est utilisée par la méthode get_mocle
97 def accept(self,visitor):
99 Cette methode permet de parcourir l'arborescence des objets
100 en utilisant le pattern VISITEUR
102 visitor.visitMCSIMP(self)
105 """ Retourne une copie de self """
106 objet = self.makeobjet()
107 # il faut copier les listes et les tuples mais pas les autres valeurs
108 # possibles (réel,SD,...)
109 if type(self.valeur) in (types.ListType,types.TupleType):
110 objet.valeur = copy(self.valeur)
112 objet.valeur = self.valeur
113 objet.val = objet.valeur
117 return self.definition(val = None, nom = self.nom,parent = self.parent)
119 def reparent(self,parent):
121 Cette methode sert a reinitialiser la parente de l'objet
125 self.etape=parent.etape
127 def get_sd_utilisees(self):
129 Retourne une liste qui contient la ou les SD utilisée par self si c'est le cas
130 ou alors une liste vide
133 if type(self.valeur) == types.InstanceType:
134 #XXX Est ce différent de isinstance(self.valeur,ASSD) ??
135 if issubclass(self.valeur.__class__,ASSD) : l.append(self.valeur)
136 elif type(self.valeur) in (types.TupleType,types.ListType):
137 for val in self.valeur :
138 if type(val) == types.InstanceType:
139 if issubclass(val.__class__,ASSD) : l.append(val)
142 def get_sd_mcs_utilisees(self):
144 Retourne la ou les SD utilisée par self sous forme d'un dictionnaire :
145 . Si aucune sd n'est utilisée, le dictionnaire est vide.
146 . Sinon, la clé du dictionnaire est le mot-clé simple ; la valeur est
147 la liste des sd attenante.
148 Exemple : { 'VALE_F': [ <Cata.cata.para_sensi instance at 0x9419854>,
149 <Cata.cata.para_sensi instance at 0x941a204> ] }
151 l=self.get_sd_utilisees()