1 # -*- coding: iso-8859-1 -*-
2 # Copyright (C) 2007-2013 EDF R&D
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.
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.
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
18 # See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
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
31 class MCBLOC(N_MCCOMPO.MCCOMPO):
33 Classe support d'un bloc de mots-clés.
38 def __init__(self,val,definition,nom,parent):
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)
45 - definition : objet de définition de type BLOC associé au bloc (porte les attributs de définition)
47 - nom : nom du bloc. Ce nom lui est donné par celui qui crée le bloc de mot-clé
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.
52 - mc_liste : liste des sous-objets du bloc construite par appel à la méthode build_mc
55 self.definition=definition
61 self.jdc = self.parent.jdc
62 self.niveau = self.parent.niveau
63 self.etape = self.parent.etape
65 # Le mot cle a été créé sans parent
69 self.mc_liste=self.build_mc()
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.
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
84 for mocle in self.mc_liste:
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())
91 dico[mocle.nom]=mocle.get_valeur()
93 # On rajoute tous les autres mots-clés locaux possibles avec la valeur
95 # Pour les mots-clés facteurs, on ne traite que ceux avec statut défaut ('d')
97 # On n'ajoute aucune information sur les blocs. Ils n'ont pas de défaut seulement
99 for k,v in self.definition.entites.items():
100 if not dico.has_key(k):
101 if v.label == 'SIMP':
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
118 Indique si l'objet est un BLOC
122 def accept(self,visitor):
124 Cette methode permet de parcourir l'arborescence des objets
125 en utilisant le pattern VISITEUR
127 visitor.visitMCBLOC(self)
130 return self.definition(val = None, nom = self.nom,parent = self.parent)