]> SALOME platform Git repositories - tools/eficas.git/blob - Noyau/N_MCSIMP.py
Salome HOME
d85eda44b94ded7a1b2f9eb94692cff8be5a42ca
[tools/eficas.git] / Noyau / N_MCSIMP.py
1 #@ MODIF N_MCSIMP Noyau  DATE 16/05/2007   AUTEUR COURTOIS 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.                                 
10 #
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.                            
15 #
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.      
19 #                                                                       
20 #                                                                       
21 # ======================================================================
22
23
24 """ 
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
27     de type ENTITE
28 """
29
30 from copy import copy
31
32 from Noyau.N_ASSD import ASSD,assd
33 from Noyau.N_CO import CO
34 import N_OBJECT
35
36 class MCSIMP(N_OBJECT.OBJECT):
37    """
38    """
39    nature = 'MCSIMP'
40    def __init__(self,val,definition,nom,parent):
41       """
42          Attributs :
43
44           - val : valeur du mot clé simple
45
46           - definition
47
48           - nom
49
50           - parent
51
52         Autres attributs :
53
54           - valeur : valeur du mot-clé simple en tenant compte de la valeur par défaut
55
56       """
57       self.definition=definition
58       self.nom=nom
59       self.val = val
60       self.parent = parent
61       self.valeur = self.GETVAL(self.val)
62       if parent :
63          self.jdc = self.parent.jdc
64          self.niveau = self.parent.niveau
65          self.etape = self.parent.etape
66       else:
67          # Le mot cle simple a été créé sans parent
68          self.jdc = None
69          self.niveau = None
70          self.etape = None
71          
72    def GETVAL(self,val):
73       """ 
74           Retourne la valeur effective du mot-clé en fonction
75           de la valeur donnée. Defaut si val == None
76       """
77       if (val is None and hasattr(self.definition,'defaut')) :
78         return self.definition.defaut
79       else:
80         return val
81
82    def get_valeur(self):
83       """
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
87       """
88       return self.valeur
89
90    def get_val(self):
91       """
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
94       """
95       return self.valeur
96
97    def accept(self,visitor):
98       """
99          Cette methode permet de parcourir l'arborescence des objets
100          en utilisant le pattern VISITEUR
101       """
102       visitor.visitMCSIMP(self)
103
104    def copy(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 (list, tuple):
110          objet.valeur = copy(self.valeur)
111       else:
112          objet.valeur = self.valeur
113       objet.val = objet.valeur
114       return objet
115
116    def makeobjet(self):
117       return self.definition(val = None, nom = self.nom,parent = self.parent)
118
119    def reparent(self,parent):
120       """
121          Cette methode sert a reinitialiser la parente de l'objet
122       """
123       self.parent=parent
124       self.jdc=parent.jdc
125       self.etape=parent.etape
126
127    def get_sd_utilisees(self):
128       """ 
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
131       """
132       l=[]
133       if isinstance(self.valeur, ASSD):
134          l.append(self.valeur)
135       elif type(self.valeur) in (list, tuple):
136         for val in self.valeur :
137            if isinstance(val, ASSD):
138               l.append(val)
139       return l
140
141    def get_sd_mcs_utilisees(self):
142       """ 
143           Retourne la ou les SD utilisée par self sous forme d'un dictionnaire :
144             - Si aucune sd n'est utilisée, le dictionnaire est vide.
145             - Sinon, la clé du dictionnaire est le mot-clé simple ; la valeur est
146               la liste des sd attenante.
147
148               Exemple ::
149                       { 'VALE_F': [ <Cata.cata.para_sensi instance at 0x9419854>,
150                                     <Cata.cata.para_sensi instance at 0x941a204> ] }
151       """
152       l=self.get_sd_utilisees()
153       dico = {}
154       if len(l) > 0 :
155         dico[self.nom] = l
156       return dico
157
158    def get_mcs_with_co(self,co):
159       """
160           Cette methode retourne l'objet MCSIMP self s'il a le concept co
161           comme valeur.
162       """
163       lval=self.valeur
164       if type(self.valeur) not in (list, tuple):
165         lval=(self.valeur,)
166       if co in lval:return [self,]
167       return []
168
169    def get_all_co(self):
170       """
171           Cette methode retourne la liste de tous les concepts co
172           associés au mot cle simple
173       """
174       lval=self.valeur
175       if type(self.valeur) not in (list, tuple):
176         lval=(self.valeur,)
177       l=[]
178       for c in lval:
179         if isinstance(c,CO) or hasattr(c,"_etape"):l.append(c)
180       return l