Salome HOME
mise a jour Noyau+Validation v8.0.16
[tools/eficas.git] / Noyau / N_MCBLOC.py
1 #@ MODIF N_MCBLOC Noyau  DATE 14/09/2004   AUTEUR MCOURTOI 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 MCBLOC qui sert à controler la valeur
26     d'un bloc de mots-clés par rapport à sa définition portée par un objet
27     de type ENTITE
28 """
29
30 import types
31
32 import N_MCCOMPO
33
34 class MCBLOC(N_MCCOMPO.MCCOMPO):
35    """
36       Classe support d'un bloc de mots-clés.
37   
38    """
39
40    nature = "MCBLOC"
41    def __init__(self,val,definition,nom,parent):
42       """
43          Attributs :
44
45           - val : valeur du bloc (dictionnaire dont les clés sont des noms de mots-clés et les valeurs
46                   les valeurs des mots-clés)
47
48           - definition : objet de définition de type BLOC associé au bloc (porte les attributs de définition)
49
50           - nom : nom du bloc. Ce nom lui est donné par celui qui crée le bloc de mot-clé
51
52           - parent : le créateur du bloc. Ce peut etre un mot-clé facteur ou un autre objet composite de type
53                      OBJECT. Si parent vaut None, le bloc ne possède pas de contexte englobant.
54
55           - mc_liste : liste des sous-objets du bloc construite par appel à la méthode build_mc
56
57       """
58       self.definition=definition
59       self.nom=nom
60       self.val = val
61       self.parent = parent
62       self.valeur = val
63       if parent :
64          self.jdc = self.parent.jdc
65          self.niveau = self.parent.niveau
66          self.etape = self.parent.etape
67       else:
68          # Le mot cle a été créé sans parent
69          self.jdc = None
70          self.niveau = None
71          self.etape = None
72       self.mc_liste=self.build_mc()
73          
74    def get_valeur(self):
75       """
76          Retourne la "valeur" de l'objet bloc. Il s'agit d'un dictionnaire dont
77          les clés seront les noms des objets de self.mc_liste et les valeurs
78          les valeurs des objets de self.mc_liste obtenues par application de 
79          la méthode get_valeur.
80
81          Dans le cas particulier d'un objet bloc les éléments du dictionnaire
82          obtenu par appel de la méthode get_valeur sont intégrés au niveau
83          supérieur.
84           
85       """
86       dico={}
87       for mocle in self.mc_liste:
88         if mocle.isBLOC():
89            # Si mocle est un BLOC, on inclut ses items dans le dictionnaire
90            # représentatif de la valeur de self. Les mots-clés fils de blocs sont
91            # donc remontés au niveau supérieur.
92            dico.update(mocle.get_valeur())
93         else:
94            dico[mocle.nom]=mocle.get_valeur()
95
96       # On rajoute tous les autres mots-clés locaux possibles avec la valeur
97       # par défaut ou None
98       # Pour les mots-clés facteurs, on ne traite que ceux avec statut défaut ('d')
99       # et caché ('c')
100       # On n'ajoute aucune information sur les blocs. Ils n'ont pas de défaut seulement
101       # une condition.
102       for k,v in self.definition.entites.items():
103         if not dico.has_key(k):
104            if v.label == 'SIMP':
105               # Mot clé simple
106               dico[k]=v.defaut
107            elif v.label == 'FACT':
108                 if v.statut in ('c','d') :
109                    # Mot clé facteur avec défaut ou caché provisoire
110                    dico[k]=v(val=None,nom=k,parent=self)
111                    # On demande la suppression des pointeurs arrieres
112                    # pour briser les eventuels cycles
113                    dico[k].supprime()
114                 else:
115                    dico[k]=None
116
117       return dico
118
119    def isBLOC(self):
120       """
121           Indique si l'objet est un BLOC
122       """
123       return 1
124
125    def accept(self,visitor):
126       """
127          Cette methode permet de parcourir l'arborescence des objets
128          en utilisant le pattern VISITEUR
129       """
130       visitor.visitMCBLOC(self)
131
132    def makeobjet(self):
133       return self.definition(val = None,  nom = self.nom,parent = self.parent)