Salome HOME
CCAR: ajout des fichiers macros
[tools/eficas.git] / Noyau / N_MCSIMP.py
1 # -*- coding: utf-8 -*-
2 #@ MODIF N_MCSIMP Noyau  DATE 16/03/2004   AUTEUR GNICOLAS G.NICOLAS 
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     Ce module contient la classe MCSIMP qui sert à controler la valeur
24     d'un mot-clé simple par rapport à sa définition portée par un objet
25     de type ENTITE
26 """
27
28 import types
29 from copy import copy
30
31 from Noyau.N_ASSD import ASSD,assd
32 import N_OBJECT
33
34 class MCSIMP(N_OBJECT.OBJECT):
35    """
36    """
37    nature = 'MCSIMP'
38    def __init__(self,val,definition,nom,parent):
39       """
40          Attributs :
41
42           - val : valeur du mot clé simple
43
44           - definition
45
46           - nom
47
48           - parent
49
50         Autres attributs :
51
52           - valeur : valeur du mot-clé simple en tenant compte de la valeur par défaut
53
54       """
55       self.definition=definition
56       self.nom=nom
57       self.val = val
58       self.parent = parent
59       self.valeur = self.GETVAL(self.val)
60       if parent :
61          self.jdc = self.parent.jdc
62          self.niveau = self.parent.niveau
63          self.etape = self.parent.etape
64       else:
65          # Le mot cle simple a été créé sans parent
66          self.jdc = None
67          self.niveau = None
68          self.etape = None
69          
70    def GETVAL(self,val):
71       """ 
72           Retourne la valeur effective du mot-clé en fonction
73           de la valeur donnée. Defaut si val == None
74       """
75       if (val is None and hasattr(self.definition,'defaut')) :
76         return self.definition.defaut
77       else:
78         return val
79
80    def get_valeur(self):
81       """
82           Retourne la "valeur" d'un mot-clé simple.
83           Cette valeur est utilisée lors de la création d'un contexte 
84           d'évaluation d'expressions à l'aide d'un interpréteur Python
85       """
86       return self.valeur
87
88    def get_val(self):
89       """
90           Une autre méthode qui retourne une "autre" valeur du mot clé simple.
91           Elle est utilisée par la méthode get_mocle
92       """
93       return self.valeur
94
95    def accept(self,visitor):
96       """
97          Cette methode permet de parcourir l'arborescence des objets
98          en utilisant le pattern VISITEUR
99       """
100       visitor.visitMCSIMP(self)
101
102    def copy(self):
103       """ Retourne une copie de self """
104       objet = self.makeobjet()
105       # il faut copier les listes et les tuples mais pas les autres valeurs
106       # possibles (réel,SD,...)
107       if type(self.valeur) in (types.ListType,types.TupleType):
108          objet.valeur = copy(self.valeur)
109       else:
110          objet.valeur = self.valeur
111       objet.val = objet.valeur
112       return objet
113
114    def makeobjet(self):
115       return self.definition(val = None, nom = self.nom,parent = self.parent)
116
117    def reparent(self,parent):
118       """
119          Cette methode sert a reinitialiser la parente de l'objet
120       """
121       self.parent=parent
122       self.jdc=parent.jdc
123       self.etape=parent.etape
124
125    def get_sd_utilisees(self):
126       """ 
127           Retourne une liste qui contient la ou les SD utilisée par self si c'est le cas
128           ou alors une liste vide
129       """
130       l=[]
131       if type(self.valeur) == types.InstanceType:
132         #XXX Est ce différent de isinstance(self.valeur,ASSD) ??
133         if issubclass(self.valeur.__class__,ASSD) : l.append(self.valeur)
134       elif type(self.valeur) in (types.TupleType,types.ListType):
135         for val in self.valeur :
136            if type(val) == types.InstanceType:
137               if issubclass(val.__class__,ASSD) : l.append(val)
138       return l
139
140    def get_sd_mcs_utilisees(self):
141       """ 
142           Retourne la ou les SD utilisée par self sous forme d'un dictionnaire :
143           . Si aucune sd n'est utilisée, le dictionnaire est vide.
144           . Sinon, la clé du dictionnaire est le mot-clé simple ; la valeur est
145             la liste des sd attenante.
146             Exemple : { 'VALE_F': [ <Cata.cata.para_sensi instance at 0x9419854>,
147                                     <Cata.cata.para_sensi instance at 0x941a204> ] }
148       """
149       l=self.get_sd_utilisees()
150       dico = {}
151       if len(l) > 0 :
152         dico[self.nom] = l
153       return dico