2 Ce module contient la classe MCBLOC qui sert à controler la valeur
3 d'un bloc de mots-clés par rapport à sa définition portée par un objet
11 class MCBLOC(N_MCCOMPO.MCCOMPO):
13 Classe support d'un bloc de mots-clés.
18 def __init__(self,val,definition,nom,parent):
22 - val : valeur du bloc (dictionnaire dont les clés sont des noms de mots-clés et les valeurs
23 les valeurs des mots-clés)
25 - definition : objet de définition de type BLOC associé au bloc (porte les attributs de définition)
27 - nom : nom du bloc. Ce nom lui est donné par celui qui crée le bloc de mot-clé
29 - parent : le créateur du bloc. Ce peut etre un mot-clé facteur ou un autre objet composite de type
30 OBJECT. Si parent vaut None, le bloc ne possède pas de contexte englobant.
32 - mc_liste : liste des sous-objets du bloc construite par appel à la méthode build_mc
35 self.definition=definition
41 self.jdc = self.parent.jdc
42 self.niveau = self.parent.niveau
43 self.etape = self.parent.etape
45 # Le mot cle a été créé sans parent
49 self.mc_liste=self.build_mc()
53 Retourne la "valeur" de l'objet bloc. Il s'agit d'un dictionnaire dont
54 les clés seront les noms des objets de self.mc_liste et les valeurs
55 les valeurs des objets de self.mc_liste obtenues par application de
56 la méthode get_valeur.
58 Dans le cas particulier d'un objet bloc les éléments du dictionnaire
59 obtenu par appel de la méthode get_valeur sont intégrés au niveau
64 for v in self.mc_liste:
66 if type(val)==types.DictionaryType:
67 for i,w in val.items():
75 Indique si l'objet est un BLOC
79 def accept(self,visitor):
81 Cette methode permet de parcourir l'arborescence des objets
82 en utilisant le pattern VISITEUR
84 visitor.visitMCBLOC(self)