Salome HOME
This commit was generated by cvs2git to track changes on a CVS vendor
[tools/eficas.git] / Noyau / N_MCBLOC.py
1 #@ MODIF N_MCBLOC 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.                                 
9 #
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.                            
14 #
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.      
18 #                                                                       
19 #                                                                       
20 # ======================================================================
21 """ 
22     Ce module contient la classe MCBLOC qui sert à controler la valeur
23     d'un bloc de mots-clés par rapport à sa définition portée par un objet
24     de type ENTITE
25 """
26
27 import types
28
29 import N_MCCOMPO
30
31 class MCBLOC(N_MCCOMPO.MCCOMPO):
32    """
33       Classe support d'un bloc de mots-clés.
34   
35    """
36
37    nature = "MCBLOC"
38    def __init__(self,val,definition,nom,parent):
39       """
40          Attributs :
41
42           - val : valeur du bloc (dictionnaire dont les clés sont des noms de mots-clés et les valeurs
43                   les valeurs des mots-clés)
44
45           - definition : objet de définition de type BLOC associé au bloc (porte les attributs de définition)
46
47           - nom : nom du bloc. Ce nom lui est donné par celui qui crée le bloc de mot-clé
48
49           - parent : le créateur du bloc. Ce peut etre un mot-clé facteur ou un autre objet composite de type
50                      OBJECT. Si parent vaut None, le bloc ne possède pas de contexte englobant.
51
52           - mc_liste : liste des sous-objets du bloc construite par appel à la méthode build_mc
53
54       """
55       self.definition=definition
56       self.nom=nom
57       self.val = val
58       self.parent = parent
59       self.valeur = 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 a été créé sans parent
66          self.jdc = None
67          self.niveau = None
68          self.etape = None
69       self.mc_liste=self.build_mc()
70          
71    def get_valeur(self):
72       """
73          Retourne la "valeur" de l'objet bloc. Il s'agit d'un dictionnaire dont
74          les clés seront les noms des objets de self.mc_liste et les valeurs
75          les valeurs des objets de self.mc_liste obtenues par application de 
76          la méthode get_valeur.
77
78          Dans le cas particulier d'un objet bloc les éléments du dictionnaire
79          obtenu par appel de la méthode get_valeur sont intégrés au niveau
80          supérieur.
81           
82       """
83       dico={}
84       for v in self.mc_liste:
85         val = v.get_valeur()
86         if type(val)==types.DictionaryType:
87           for i,w in val.items():
88             dico[i]=w
89         else :
90           dico[v.nom]=val
91       return dico
92   
93    def isBLOC(self):
94       """
95           Indique si l'objet est un BLOC
96       """
97       return 1
98
99    def accept(self,visitor):
100       """
101          Cette methode permet de parcourir l'arborescence des objets
102          en utilisant le pattern VISITEUR
103       """
104       visitor.visitMCBLOC(self)
105
106    def makeobjet(self):
107       return self.definition(val = None,  nom = self.nom,parent = self.parent)