/usr/share/pyshared/Noyau/N_MCBLOC.py is in eficas 6.4.0-1-2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 | #@ MODIF N_MCBLOC Noyau DATE 07/09/2009 AUTEUR COURTOIS M.COURTOIS
# -*- coding: iso-8859-1 -*-
# RESPONSABLE COURTOIS M.COURTOIS
# CONFIGURATION MANAGEMENT OF EDF VERSION
# ======================================================================
# COPYRIGHT (C) 1991 - 2002 EDF R&D WWW.CODE-ASTER.ORG
# THIS PROGRAM IS FREE SOFTWARE; YOU CAN REDISTRIBUTE IT AND/OR MODIFY
# IT UNDER THE TERMS OF THE GNU GENERAL PUBLIC LICENSE AS PUBLISHED BY
# THE FREE SOFTWARE FOUNDATION; EITHER VERSION 2 OF THE LICENSE, OR
# (AT YOUR OPTION) ANY LATER VERSION.
#
# THIS PROGRAM IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, BUT
# WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF
# MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. SEE THE GNU
# GENERAL PUBLIC LICENSE FOR MORE DETAILS.
#
# YOU SHOULD HAVE RECEIVED A COPY OF THE GNU GENERAL PUBLIC LICENSE
# ALONG WITH THIS PROGRAM; IF NOT, WRITE TO EDF R&D CODE_ASTER,
# 1 AVENUE DU GENERAL DE GAULLE, 92141 CLAMART CEDEX, FRANCE.
#
#
# ======================================================================
"""
Ce module contient la classe MCBLOC qui sert à controler la valeur
d'un bloc de mots-clés par rapport à sa définition portée par un objet
de type ENTITE
"""
import types
import N_MCCOMPO
class MCBLOC(N_MCCOMPO.MCCOMPO):
"""
Classe support d'un bloc de mots-clés.
"""
nature = "MCBLOC"
def __init__(self,val,definition,nom,parent):
"""
Attributs :
- val : valeur du bloc (dictionnaire dont les clés sont des noms de mots-clés et les valeurs
les valeurs des mots-clés)
- definition : objet de définition de type BLOC associé au bloc (porte les attributs de définition)
- nom : nom du bloc. Ce nom lui est donné par celui qui crée le bloc de mot-clé
- parent : le créateur du bloc. Ce peut etre un mot-clé facteur ou un autre objet composite de type
OBJECT. Si parent vaut None, le bloc ne possède pas de contexte englobant.
- mc_liste : liste des sous-objets du bloc construite par appel à la méthode build_mc
"""
self.definition=definition
self.nom=nom
self.val = val
self.parent = parent
self.valeur = val
if parent :
self.jdc = self.parent.jdc
self.niveau = self.parent.niveau
self.etape = self.parent.etape
else:
# Le mot cle a été créé sans parent
self.jdc = None
self.niveau = None
self.etape = None
self.mc_liste=self.build_mc()
def get_valeur(self):
"""
Retourne la "valeur" de l'objet bloc. Il s'agit d'un dictionnaire dont
les clés seront les noms des objets de self.mc_liste et les valeurs
les valeurs des objets de self.mc_liste obtenues par application de
la méthode get_valeur.
Dans le cas particulier d'un objet bloc les éléments du dictionnaire
obtenu par appel de la méthode get_valeur sont intégrés au niveau
supérieur.
"""
dico={}
for mocle in self.mc_liste:
if mocle.isBLOC():
# Si mocle est un BLOC, on inclut ses items dans le dictionnaire
# représentatif de la valeur de self. Les mots-clés fils de blocs sont
# donc remontés au niveau supérieur.
dico.update(mocle.get_valeur())
else:
dico[mocle.nom]=mocle.get_valeur()
# On rajoute tous les autres mots-clés locaux possibles avec la valeur
# par défaut ou None
# Pour les mots-clés facteurs, on ne traite que ceux avec statut défaut ('d')
# et caché ('c')
# On n'ajoute aucune information sur les blocs. Ils n'ont pas de défaut seulement
# une condition.
for k,v in self.definition.entites.items():
if not dico.has_key(k):
if v.label == 'SIMP':
# Mot clé simple
dico[k]=v.defaut
elif v.label == 'FACT':
if v.statut in ('c','d') :
# Mot clé facteur avec défaut ou caché provisoire
dico[k]=v(val=None,nom=k,parent=self)
# On demande la suppression des pointeurs arrieres
# pour briser les eventuels cycles
dico[k].supprime()
else:
dico[k]=None
return dico
def isBLOC(self):
"""
Indique si l'objet est un BLOC
"""
return 1
def accept(self,visitor):
"""
Cette methode permet de parcourir l'arborescence des objets
en utilisant le pattern VISITEUR
"""
visitor.visitMCBLOC(self)
def makeobjet(self):
return self.definition(val = None, nom = self.nom,parent = self.parent)
|