1 #@ MODIF N_ENTITE Noyau DATE 07/09/2009 AUTEUR COURTOIS M.COURTOIS
2 # -*- coding: iso-8859-1 -*-
3 # RESPONSABLE COURTOIS M.COURTOIS
4 # CONFIGURATION MANAGEMENT OF EDF VERSION
5 # ======================================================================
6 # COPYRIGHT (C) 1991 - 2002 EDF R&D WWW.CODE-ASTER.ORG
7 # THIS PROGRAM IS FREE SOFTWARE; YOU CAN REDISTRIBUTE IT AND/OR MODIFY
8 # IT UNDER THE TERMS OF THE GNU GENERAL PUBLIC LICENSE AS PUBLISHED BY
9 # THE FREE SOFTWARE FOUNDATION; EITHER VERSION 2 OF THE LICENSE, OR
10 # (AT YOUR OPTION) ANY LATER VERSION.
12 # THIS PROGRAM IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, BUT
13 # WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF
14 # MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. SEE THE GNU
15 # GENERAL PUBLIC LICENSE FOR MORE DETAILS.
17 # YOU SHOULD HAVE RECEIVED A COPY OF THE GNU GENERAL PUBLIC LICENSE
18 # ALONG WITH THIS PROGRAM; IF NOT, WRITE TO EDF R&D CODE_ASTER,
19 # 1 AVENUE DU GENERAL DE GAULLE, 92141 CLAMART CEDEX, FRANCE.
22 # ======================================================================
26 Ce module contient la classe ENTITE qui est la classe de base
27 de toutes les classes de definition d'EFICAS.
35 Classe de base pour tous les objets de definition : mots cles et commandes
36 Cette classe ne contient que des methodes utilitaires
37 Elle ne peut etre instanciee et doit d abord etre specialisee
40 factories={'validator':N_VALIDATOR.validatorFactory}
42 def __init__(self,validators=None):
44 Initialise les deux attributs regles et entites d'une classe dérivée
45 à : pas de règles et pas de sous-entités.
47 L'attribut regles doit contenir la liste des regles qui s'appliquent
50 L'attribut entités doit contenir le dictionnaires des sous-entités
51 (clé = nom, valeur=objet)
56 self.validators=self.factories['validator'](validators)
58 self.validators=validators
60 def affecter_parente(self):
62 Cette methode a pour fonction de donner un nom et un pere aux
63 sous entités qui n'ont aucun moyen pour atteindre leur parent
65 Il s'agit principalement des mots cles
67 for k,v in self.entites.items():
73 Cette methode sert à valider les attributs de l'objet de définition
75 raise "La méthode verif_cata de la classe %s doit etre implémentée" % self.__class__.__name__
79 Cette methode doit retourner un objet dérivé de la classe OBJECT
81 raise "La méthode __call__ de la classe %s doit etre implémentée" % self.__class__.__name__
85 Cette méthode construit pour tous les objets dérivés de ENTITE un
86 rapport de validation de la définition portée par cet objet
90 for k,v in self.entites.items() :
93 cr.debut = "Début "+v.__class__.__name__+ ' : ' + k
94 cr.fin = "Fin "+v.__class__.__name__+ ' : ' + k
97 self.cr.fatal("Impossible d'obtenir le rapport de %s %s" %(k,`v`))
98 print "Impossible d'obtenir le rapport de %s %s" %(k,`v`)
102 def verif_cata_regles(self):
104 Cette méthode vérifie pour tous les objets dérivés de ENTITE que
105 les objets REGLES associés ne portent que sur des sous-entités
108 for regle in self.regles :
110 for mc in regle.mcs :
111 if not self.entites.has_key(mc) :
115 self.cr.fatal("Argument(s) non permis : %s pour la règle : %s" %(`l`,txt))