1 #@ MODIF N_MCSIMP Noyau DATE 03/09/2002 AUTEUR GNICOLAS G.NICOLAS
2 # CONFIGURATION MANAGEMENT OF EDF VERSION
3 # ======================================================================
4 # COPYRIGHT (C) 1991 - 2002 EDF R&D WWW.CODE-ASTER.ORG
5 # THIS PROGRAM IS FREE SOFTWARE; YOU CAN REDISTRIBUTE IT AND/OR MODIFY
6 # IT UNDER THE TERMS OF THE GNU GENERAL PUBLIC LICENSE AS PUBLISHED BY
7 # THE FREE SOFTWARE FOUNDATION; EITHER VERSION 2 OF THE LICENSE, OR
8 # (AT YOUR OPTION) ANY LATER VERSION.
10 # THIS PROGRAM IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, BUT
11 # WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF
12 # MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. SEE THE GNU
13 # GENERAL PUBLIC LICENSE FOR MORE DETAILS.
15 # YOU SHOULD HAVE RECEIVED A COPY OF THE GNU GENERAL PUBLIC LICENSE
16 # ALONG WITH THIS PROGRAM; IF NOT, WRITE TO EDF R&D CODE_ASTER,
17 # 1 AVENUE DU GENERAL DE GAULLE, 92141 CLAMART CEDEX, FRANCE.
20 # ======================================================================
22 Ce module contient la classe MCSIMP qui sert à controler la valeur
23 d'un mot-clé simple par rapport à sa définition portée par un objet
30 from Noyau.N_ASSD import ASSD,assd
33 class MCSIMP(N_OBJECT.OBJECT):
37 def __init__(self,val,definition,nom,parent):
41 - val : valeur du mot clé simple
51 - valeur : valeur du mot-clé simple en tenant compte de la valeur par défaut
54 self.definition=definition
58 self.valeur = self.GETVAL(self.val)
60 self.jdc = self.parent.jdc
61 self.niveau = self.parent.niveau
62 self.etape = self.parent.etape
64 # Le mot cle simple a été créé sans parent
71 Retourne la valeur effective du mot-clé en fonction
72 de la valeur donnée. Defaut si val == None
74 if (val is None and hasattr(self.definition,'defaut')) :
75 return self.definition.defaut
81 Retourne la "valeur" d'un mot-clé simple.
82 Cette valeur est utilisée lors de la création d'un contexte
83 d'évaluation d'expressions à l'aide d'un interpréteur Python
89 Une autre méthode qui retourne une "autre" valeur du mot clé simple.
90 Elle est utilisée par la méthode get_mocle
94 def accept(self,visitor):
96 Cette methode permet de parcourir l'arborescence des objets
97 en utilisant le pattern VISITEUR
99 visitor.visitMCSIMP(self)
102 """ Retourne une copie de self """
103 objet = self.makeobjet()
104 # il faut copier les listes et les tuples mais pas les autres valeurs
105 # possibles (réel,SD,...)
106 if type(self.valeur) in (types.ListType,types.TupleType):
107 objet.valeur = copy(self.valeur)
109 objet.valeur = self.valeur
110 objet.val = objet.valeur
114 return self.definition(val = None, nom = self.nom,parent = self.parent)
116 def reparent(self,parent):
118 Cette methode sert a reinitialiser la parente de l'objet
122 self.etape=parent.etape
124 def get_sd_utilisees(self):
126 Retourne une liste qui contient la SD utilisée par self si c'est le cas
127 ou alors une liste vide
130 if type(self.valeur) == types.InstanceType:
131 #XXX Est ce différent de isinstance(self.valeur,ASSD) ??
132 if issubclass(self.valeur.__class__,ASSD) : l.append(self.valeur)
133 elif type(self.valeur) in (types.TupleType,types.ListType):
134 for val in self.valeur :
135 if type(val) == types.InstanceType:
136 if issubclass(val.__class__,ASSD) : l.append(val)