2 Ce module contient la classe ENTITE qui est la classe de base
3 de toutes les classes de definition d'EFICAS.
10 Classe de base pour tous les objets de definition : mots cles et commandes
11 Cette classe ne contient que des methodes utilitaires
12 Elle ne peut etre instanciee et doit d abord etre specialisee
18 Initialise les deux attributs regles et entites d'une classe dérivée
19 à : pas de règles et pas de sous-entités.
21 L'attribut regles doit contenir la liste des regles qui s'appliquent
24 L'attribut entités doit contenir le dictionnaires des sous-entités
25 (clé = nom, valeur=objet)
30 def affecter_parente(self):
32 Cette methode a pour fonction de donner un nom et un pere aux
33 sous entités qui n'ont aucun moyen pour atteindre leur parent
35 Il s'agit principalement des mots cles
37 for k,v in self.entites.items():
43 Cette methode sert à valider les attributs de l'objet de définition
45 raise "La méthode verif_cata de la classe %s doit etre implémentée" % self.__class__.__name__
49 Cette methode doit retourner un objet dérivé de la classe OBJECT
51 raise "La méthode __call__ de la classe %s doit etre implémentée" % self.__class__.__name__
55 Cette méthode construit pour tous les objets dérivés de ENTITE un
56 rapport de validation de la définition portée par cet objet
60 for k,v in self.entites.items() :
63 cr.debut = "Début "+v.__class__.__name__+ ' : ' + k
64 cr.fin = "Fin "+v.__class__.__name__+ ' : ' + k
67 self.cr.fatal("Impossible d'obtenir le rapport de %s %s" %(k,`v`))
68 print "Impossible d'obtenir le rapport de %s %s" %(k,`v`)
72 def verif_cata_regles(self):
74 Cette méthode vérifie pour tous les objets dérivés de ENTITE que
75 les objets REGLES associés ne portent que sur des sous-entités
78 for regle in self.regles :
81 if not self.entites.has_key(mc) :
85 self.cr.fatal("Argument(s) non permis : %s pour la règle : %s" %(`l`,txt))