Salome HOME
travail sur monPlusieurs
[tools/eficas.git] / Noyau / N_MCBLOC.py
1 # -*- coding: iso-8859-1 -*-
2 # Copyright (C) 2007-2013   EDF R&D
3 #
4 # This library is free software; you can redistribute it and/or
5 # modify it under the terms of the GNU Lesser General Public
6 # License as published by the Free Software Foundation; either
7 # version 2.1 of the License.
8 #
9 # This library is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12 # Lesser General Public License for more details.
13 #
14 # You should have received a copy of the GNU Lesser General Public
15 # License along with this library; if not, write to the Free Software
16 # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
17 #
18 # See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
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 mocle in self.mc_liste:
85         if mocle.isBLOC():
86            # Si mocle est un BLOC, on inclut ses items dans le dictionnaire
87            # représentatif de la valeur de self. Les mots-clés fils de blocs sont
88            # donc remontés au niveau supérieur.
89            dico.update(mocle.get_valeur())
90         else:
91            dico[mocle.nom]=mocle.get_valeur()
92
93       # On rajoute tous les autres mots-clés locaux possibles avec la valeur
94       # par défaut ou None
95       # Pour les mots-clés facteurs, on ne traite que ceux avec statut défaut ('d')
96       # et caché ('c')
97       # On n'ajoute aucune information sur les blocs. Ils n'ont pas de défaut seulement
98       # une condition.
99       for k,v in self.definition.entites.items():
100         if not dico.has_key(k):
101            if v.label == 'SIMP':
102               # Mot clé simple
103               dico[k]=v.defaut
104            elif v.label == 'FACT':
105                 if v.statut in ('c','d') :
106                    # Mot clé facteur avec défaut ou caché provisoire
107                    dico[k]=v(val=None,nom=k,parent=self)
108                    # On demande la suppression des pointeurs arrieres
109                    # pour briser les eventuels cycles
110                    dico[k].supprime()
111                 else:
112                    dico[k]=None
113
114       return dico
115
116    def isBLOC(self):
117       """
118           Indique si l'objet est un BLOC
119       """
120       return 1
121
122    def accept(self,visitor):
123       """
124          Cette methode permet de parcourir l'arborescence des objets
125          en utilisant le pattern VISITEUR
126       """
127       visitor.visitMCBLOC(self)
128
129    def makeobjet(self):
130       return self.definition(val = None,  nom = self.nom,parent = self.parent)