Salome HOME
commentaire
[tools/eficas.git] / Noyau / N_MCBLOC.py
1 # coding=utf-8
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 from __future__ import absolute_import
28 import types
29
30 from . import N_MCCOMPO
31
32
33 class MCBLOC(N_MCCOMPO.MCCOMPO):
34
35     """
36        Classe support d'un bloc de mots-clés.
37
38     """
39
40     nature = "MCBLOC"
41
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 list(self.definition.entites.items()):
104             if not k in dico:
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)