Salome HOME
CCAR: rabattre la version V1_15a4 dans la branche principale
[tools/eficas.git] / Noyau / N_MCSIMP.py
1 #@ MODIF N_MCSIMP Noyau  DATE 13/10/2008   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 from N_CONVERT import ConversionFactory
36
37 class MCSIMP(N_OBJECT.OBJECT):
38    """
39    """
40    nature = 'MCSIMP'
41    def __init__(self,val,definition,nom,parent):
42       """
43          Attributs :
44
45           - val : valeur du mot clé simple
46
47           - definition
48
49           - nom
50
51           - parent
52
53         Autres attributs :
54
55           - valeur : valeur du mot-clé simple en tenant compte de la valeur par défaut
56
57       """
58       self.definition=definition
59       self.nom=nom
60       self.val = val
61       self.parent = parent
62       self.convProto = ConversionFactory('type', typ=self.definition.type)
63       self.valeur = self.GETVAL(self.val)
64       if parent :
65          self.jdc = self.parent.jdc
66          self.niveau = self.parent.niveau
67          self.etape = self.parent.etape
68       else:
69          # Le mot cle simple a été créé sans parent
70          self.jdc = None
71          self.niveau = None
72          self.etape = None
73
74    def GETVAL(self,val):
75       """ 
76           Retourne la valeur effective du mot-clé en fonction
77           de la valeur donnée. Defaut si val == None
78       """
79       if (val is None and hasattr(self.definition,'defaut')) :
80          val = self.definition.defaut
81       if self.convProto:
82          val = self.convProto.convert(val)
83       return val
84
85    def get_valeur(self):
86       """
87           Retourne la "valeur" d'un mot-clé simple.
88           Cette valeur est utilisée lors de la création d'un contexte 
89           d'évaluation d'expressions à l'aide d'un interpréteur Python
90       """
91       v = self.valeur
92       # Singleton : on retourne l'element
93       # Permet aussi d'ignorer l'erreur : concept=COMMANDE(),
94       # ou 'concept' est un tuple de longueur 1 a cause de la virgule.
95       if type(v) in (list, tuple) and len(v) == 1:
96          v = v[0]
97       return v
98
99    def get_val(self):
100       """
101           Une autre méthode qui retourne une "autre" valeur du mot clé simple.
102           Elle est utilisée par la méthode get_mocle
103       """
104       return self.valeur
105
106    def accept(self,visitor):
107       """
108          Cette methode permet de parcourir l'arborescence des objets
109          en utilisant le pattern VISITEUR
110       """
111       visitor.visitMCSIMP(self)
112
113    def copy(self):
114       """ Retourne une copie de self """
115       objet = self.makeobjet()
116       # il faut copier les listes et les tuples mais pas les autres valeurs
117       # possibles (réel,SD,...)
118       if type(self.valeur) in (list, tuple):
119          objet.valeur = copy(self.valeur)
120       else:
121          objet.valeur = self.valeur
122       objet.val = objet.valeur
123       return objet
124
125    def makeobjet(self):
126       return self.definition(val = None, nom = self.nom,parent = self.parent)
127
128    def reparent(self,parent):
129       """
130          Cette methode sert a reinitialiser la parente de l'objet
131       """
132       self.parent=parent
133       self.jdc=parent.jdc
134       self.etape=parent.etape
135
136    def get_sd_utilisees(self):
137       """ 
138           Retourne une liste qui contient la ou les SD utilisée par self si c'est le cas
139           ou alors une liste vide
140       """
141       l=[]
142       if isinstance(self.valeur, ASSD):
143          l.append(self.valeur)
144       elif type(self.valeur) in (list, tuple):
145         for val in self.valeur :
146            if isinstance(val, ASSD):
147               l.append(val)
148       return l
149
150    def get_sd_mcs_utilisees(self):
151       """ 
152           Retourne la ou les SD utilisée par self sous forme d'un dictionnaire :
153             - Si aucune sd n'est utilisée, le dictionnaire est vide.
154             - Sinon, la clé du dictionnaire est le mot-clé simple ; la valeur est
155               la liste des sd attenante.
156
157               Exemple ::
158                       { 'VALE_F': [ <Cata.cata.para_sensi instance at 0x9419854>,
159                                     <Cata.cata.para_sensi instance at 0x941a204> ] }
160       """
161       l=self.get_sd_utilisees()
162       dico = {}
163       if len(l) > 0 :
164         dico[self.nom] = l
165       return dico
166
167    def get_mcs_with_co(self,co):
168       """
169           Cette methode retourne l'objet MCSIMP self s'il a le concept co
170           comme valeur.
171       """
172       lval=self.valeur
173       if type(self.valeur) not in (list, tuple):
174         lval=(self.valeur,)
175       if co in lval:return [self,]
176       return []
177
178    def get_all_co(self):
179       """
180           Cette methode retourne la liste de tous les concepts co
181           associés au mot cle simple
182       """
183       lval=self.valeur
184       if type(self.valeur) not in (list, tuple):
185         lval=(self.valeur,)
186       l=[]
187       for c in lval:
188         if isinstance(c,CO) or hasattr(c,"_etape"):l.append(c)
189       return l