1 #@ MODIF N_MCBLOC Noyau DATE 27/03/2002 AUTEUR DURAND C.DURAND
2 # CONFIGURATION MANAGEMENT OF EDF VERSION
3 # ======================================================================
4 # COPYRIGHT (C) 1991 - 2002 EDF R&D WWW.CODE-ASTER.ORG
5 # THIS PROGRAM IS FREE SOFTWARE; YOU CAN REDISTRIBUTE IT AND/OR MODIFY
6 # IT UNDER THE TERMS OF THE GNU GENERAL PUBLIC LICENSE AS PUBLISHED BY
7 # THE FREE SOFTWARE FOUNDATION; EITHER VERSION 2 OF THE LICENSE, OR
8 # (AT YOUR OPTION) ANY LATER VERSION.
10 # THIS PROGRAM IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, BUT
11 # WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF
12 # MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. SEE THE GNU
13 # GENERAL PUBLIC LICENSE FOR MORE DETAILS.
15 # YOU SHOULD HAVE RECEIVED A COPY OF THE GNU GENERAL PUBLIC LICENSE
16 # ALONG WITH THIS PROGRAM; IF NOT, WRITE TO EDF R&D CODE_ASTER,
17 # 1 AVENUE DU GENERAL DE GAULLE, 92141 CLAMART CEDEX, FRANCE.
20 # ======================================================================
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 v in self.mc_liste:
86 if type(val)==types.DictionaryType:
87 for i,w in val.items():
95 Indique si l'objet est un BLOC
99 def accept(self,visitor):
101 Cette methode permet de parcourir l'arborescence des objets
102 en utilisant le pattern VISITEUR
104 visitor.visitMCBLOC(self)