]> SALOME platform Git repositories - tools/eficas.git/blob - Noyau/N_MCBLOC.py
Salome HOME
03d684401b00d4791857ff064e3d4df9a7fa5b75
[tools/eficas.git] / Noyau / N_MCBLOC.py
1 #@ MODIF N_MCBLOC Noyau  DATE 07/09/2009   AUTEUR COURTOIS M.COURTOIS 
2 # -*- coding: iso-8859-1 -*-
3 # RESPONSABLE COURTOIS M.COURTOIS
4 #            CONFIGURATION MANAGEMENT OF EDF VERSION
5 # ======================================================================
6 # COPYRIGHT (C) 1991 - 2002  EDF R&D                  WWW.CODE-ASTER.ORG
7 # THIS PROGRAM IS FREE SOFTWARE; YOU CAN REDISTRIBUTE IT AND/OR MODIFY
8 # IT UNDER THE TERMS OF THE GNU GENERAL PUBLIC LICENSE AS PUBLISHED BY
9 # THE FREE SOFTWARE FOUNDATION; EITHER VERSION 2 OF THE LICENSE, OR   
10 # (AT YOUR OPTION) ANY LATER VERSION.                                 
11 #
12 # THIS PROGRAM IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, BUT 
13 # WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF          
14 # MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. SEE THE GNU    
15 # GENERAL PUBLIC LICENSE FOR MORE DETAILS.                            
16 #
17 # YOU SHOULD HAVE RECEIVED A COPY OF THE GNU GENERAL PUBLIC LICENSE   
18 # ALONG WITH THIS PROGRAM; IF NOT, WRITE TO EDF R&D CODE_ASTER,       
19 #    1 AVENUE DU GENERAL DE GAULLE, 92141 CLAMART CEDEX, FRANCE.      
20 #                                                                       
21 #                                                                       
22 # ======================================================================
23
24
25 """ 
26     Ce module contient la classe MCBLOC qui sert à controler la valeur
27     d'un bloc de mots-clés par rapport à sa définition portée par un objet
28     de type ENTITE
29 """
30
31 import types
32
33 import N_MCCOMPO
34
35 class MCBLOC(N_MCCOMPO.MCCOMPO):
36    """
37       Classe support d'un bloc de mots-clés.
38   
39    """
40
41    nature = "MCBLOC"
42    def __init__(self,val,definition,nom,parent):
43       """
44          Attributs :
45
46           - val : valeur du bloc (dictionnaire dont les clés sont des noms de mots-clés et les valeurs
47                   les valeurs des mots-clés)
48
49           - definition : objet de définition de type BLOC associé au bloc (porte les attributs de définition)
50
51           - nom : nom du bloc. Ce nom lui est donné par celui qui crée le bloc de mot-clé
52
53           - parent : le créateur du bloc. Ce peut etre un mot-clé facteur ou un autre objet composite de type
54                      OBJECT. Si parent vaut None, le bloc ne possède pas de contexte englobant.
55
56           - mc_liste : liste des sous-objets du bloc construite par appel à la méthode build_mc
57
58       """
59       self.definition=definition
60       self.nom=nom
61       self.val = val
62       self.parent = parent
63       self.valeur = 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 a été créé sans parent
70          self.jdc = None
71          self.niveau = None
72          self.etape = None
73       self.mc_liste=self.build_mc()
74          
75    def get_valeur(self):
76       """
77          Retourne la "valeur" de l'objet bloc. Il s'agit d'un dictionnaire dont
78          les clés seront les noms des objets de self.mc_liste et les valeurs
79          les valeurs des objets de self.mc_liste obtenues par application de 
80          la méthode get_valeur.
81
82          Dans le cas particulier d'un objet bloc les éléments du dictionnaire
83          obtenu par appel de la méthode get_valeur sont intégrés au niveau
84          supérieur.
85           
86       """
87       dico={}
88       for mocle in self.mc_liste:
89         if mocle.isBLOC():
90            # Si mocle est un BLOC, on inclut ses items dans le dictionnaire
91            # représentatif de la valeur de self. Les mots-clés fils de blocs sont
92            # donc remontés au niveau supérieur.
93            dico.update(mocle.get_valeur())
94         else:
95            dico[mocle.nom]=mocle.get_valeur()
96
97       # On rajoute tous les autres mots-clés locaux possibles avec la valeur
98       # par défaut ou None
99       # Pour les mots-clés facteurs, on ne traite que ceux avec statut défaut ('d')
100       # et caché ('c')
101       # On n'ajoute aucune information sur les blocs. Ils n'ont pas de défaut seulement
102       # une condition.
103       for k,v in self.definition.entites.items():
104         if not dico.has_key(k):
105            if v.label == 'SIMP':
106               # Mot clé simple
107               dico[k]=v.defaut
108            elif v.label == 'FACT':
109                 if v.statut in ('c','d') :
110                    # Mot clé facteur avec défaut ou caché provisoire
111                    dico[k]=v(val=None,nom=k,parent=self)
112                    # On demande la suppression des pointeurs arrieres
113                    # pour briser les eventuels cycles
114                    dico[k].supprime()
115                 else:
116                    dico[k]=None
117
118       return dico
119
120    def isBLOC(self):
121       """
122           Indique si l'objet est un BLOC
123       """
124       return 1
125
126    def accept(self,visitor):
127       """
128          Cette methode permet de parcourir l'arborescence des objets
129          en utilisant le pattern VISITEUR
130       """
131       visitor.visitMCBLOC(self)
132
133    def makeobjet(self):
134       return self.definition(val = None,  nom = self.nom,parent = self.parent)