2 # ======================================================================
3 # COPYRIGHT (C) 1991 - 2017 EDF R&D WWW.CODE-ASTER.ORG
4 # THIS PROGRAM IS FREE SOFTWARE; YOU CAN REDISTRIBUTE IT AND/OR MODIFY
5 # IT UNDER THE TERMS OF THE GNU GENERAL PUBLIC LICENSE AS PUBLISHED BY
6 # THE FREE SOFTWARE FOUNDATION; EITHER VERSION 2 OF THE LICENSE, OR
7 # (AT YOUR OPTION) ANY LATER VERSION.
9 # THIS PROGRAM IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, BUT
10 # WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF
11 # MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. SEE THE GNU
12 # GENERAL PUBLIC LICENSE FOR MORE DETAILS.
14 # YOU SHOULD HAVE RECEIVED A COPY OF THE GNU GENERAL PUBLIC LICENSE
15 # ALONG WITH THIS PROGRAM; IF NOT, WRITE TO EDF R&D CODE_ASTER,
16 # 1 AVENUE DU GENERAL DE GAULLE, 92141 CLAMART CEDEX, FRANCE.
19 # ======================================================================
23 Ce module contient la classe ENTITE qui est la classe de base
24 de toutes les classes de definition d'EFICAS.
27 from __future__ import absolute_import
28 from __future__ import print_function
30 from builtins import str
31 from builtins import object
37 from . import N_VALIDATOR
40 stringTypes = (str, six.text_type)
46 Classe de base pour tous les objets de definition : mots cles et commandes
47 Cette classe ne contient que des methodes utilitaires
48 Elle ne peut être instanciee et doit d abord être specialisee
51 factories = {'validator': N_VALIDATOR.validatorFactory}
53 def __init__(self, validators=None):
55 Initialise les deux attributs regles et entites d'une classe dérivée
56 à : pas de règles et pas de sous-entités.
58 L'attribut regles doit contenir la liste des regles qui s'appliquent
61 L'attribut entités doit contenir le dictionnaires des sous-entités
62 (clé = nom, valeur=objet)
67 self.validators = self.factories['validator'](validators)
69 self.validators = validators
70 #self.doitSenregistrerComme = None
74 def affecter_parente(self):
76 Cette methode a pour fonction de donner un nom et un pere aux
77 sous entités qui n'ont aucun moyen pour atteindre leur parent
79 Il s'agit principalement des mots cles
81 for k, v in list(self.entites.items()):
88 Cette methode sert à valider les attributs de l'objet de définition
90 raise NotImplementedError("La méthode verifCata de la classe %s doit être implémentée"
91 % self.__class__.__name__)
95 Cette methode doit retourner un objet dérivé de la classe OBJECT
98 raise NotImplementedError("La méthode __call__ de la classe %s doit être implémentée"
99 % self.__class__.__name__)
103 Cette méthode construit pour tous les objets dérivés de ENTITE un
104 rapport de validation de la définition portée par cet objet
108 for k, v in list(self.entites.items()):
111 cr.debut = u"Début " + v.__class__.__name__ + ' : ' + k
112 cr.fin = u"Fin " + v.__class__.__name__ + ' : ' + k
115 self.cr.fatal("Impossible d'obtenir le rapport de %s %s" % (k, repr(v)))
116 print(("Impossible d'obtenir le rapport de %s %s" % (k, repr(v))))
117 print(("père =", self))
120 def verifCataRegles(self):
122 Cette méthode vérifie pour tous les objets dérivés de ENTITE que
123 les objets REGLES associés ne portent que sur des sous-entités
126 for regle in self.regles:
129 if not mc in self.entites :
134 _(u"Argument(s) non permis : %r pour la règle : %s"), l, txt)
136 def checkDefinition(self, parent):
137 """Verifie la definition d'un objet composite (commande, fact, bloc)."""
138 args = self.entites.copy()
140 for nom, val in list(args.items()):
141 if val.label == 'SIMP':
144 # if val.max != 1 and val.type == 'TXM':
145 # print "#CMD", parent, nom
146 elif val.label == 'FACT':
147 val.checkDefinition(parent)
149 # assert self.label != 'FACT', \
150 #'Commande %s : Mot-clef facteur present sous un mot-clef facteur : interdit !' \
155 # seuls les blocs peuvent entrer en conflit avec les mcs du plus haut
157 for nom, val in list(args.items()):
158 if val.label == 'BLOC':
159 mcbloc = val.checkDefinition(parent)
161 # print "#BLOC", parent, re.sub('\s+', ' ', val.condition)
162 assert mcs.isdisjoint(mcbloc), "Commande %s : Mot(s)-clef(s) vu(s) plusieurs fois : %s" \
163 % (parent, tuple(mcs.intersection(mcbloc)))
166 def checkOp(self, valmin=-9999, valmax=9999):
167 """Vérifie l'attribut op."""
168 if self.op is not None and \
169 (type(self.op) is not int or self.op < valmin or self.op > valmax):
170 self.cr.fatal(_(u"L'attribut 'op' doit être un entier "
171 u"compris entre %d et %d : %r"), valmin, valmax, self.op)
174 """Vérifie l'attribut proc."""
175 if self.proc is not None and not isinstance(self.proc, N_OPS.OPS):
177 _(u"L'attribut op doit être une instance d'OPS : %r"), self.proc)
179 def checkRegles(self):
180 """Vérifie l'attribut regles."""
181 if type(self.regles) is not tuple:
182 self.cr.fatal(_(u"L'attribut 'regles' doit être un tuple : %r"),
186 """Vérifie l'attribut fr."""
187 if type(self.fr) not in stringTypes:
189 _(u"L'attribut 'fr' doit être une chaine de caractères : %r"),
193 """Vérifie l'attribut docu."""
194 if type(self.docu) not in stringTypes:
196 _(u"L'attribut 'docu' doit être une chaine de caractères : %r"),
200 """Vérifie l'attribut proc."""
201 if type(self.nom) is not str:
203 _(u"L'attribut 'nom' doit être une chaine de caractères : %r"),
206 def checkReentrant(self):
207 """Vérifie l'attribut reentrant."""
208 if self.reentrant not in ('o', 'n', 'f'):
210 _(u"L'attribut 'reentrant' doit valoir 'o','n' ou 'f' : %r"),
213 def checkStatut(self, into=('o', 'f', 'c', 'd')):
214 """Vérifie l'attribut statut."""
215 if self.statut not in into:
216 self.cr.fatal(_(u"L'attribut 'statut' doit être parmi %s : %r"),
219 def checkCondition(self):
220 """Vérifie l'attribut condition."""
221 if self.condition != None:
222 if type(self.condition) is not str:
224 _(u"L'attribut 'condition' doit être une chaine de caractères : %r"),
227 self.cr.fatal(_(u"La condition ne doit pas valoir None !"))
229 def checkMinMax(self):
230 """Vérifie les attributs min/max."""
231 if type(self.min) != int:
232 if self.min != '**'and self.min != float('-inf'):
234 _(u"L'attribut 'min' doit être un entier : %r"), self.min)
235 if type(self.max) != int:
236 if self.max != '**' and self.max != float('inf'):
238 _(u"L'attribut 'max' doit être un entier : %r"), self.max)
239 if self.min > self.max:
241 _(u"Nombres d'occurrence min et max invalides : %r %r"),
244 def checkValidators(self):
245 """Vérifie les validateurs supplémentaires"""
246 if self.validators and not self.validators.verifCata():
247 self.cr.fatal(_(u"Un des validateurs est incorrect. Raison : %s"),
248 self.validators.cata_info)
251 """Vérifie l'attribut homo."""
252 if self.homo != 0 and self.homo != 1:
254 _(u"L'attribut 'homo' doit valoir 0 ou 1 : %r"), self.homo)
257 """Vérifie l'attribut into."""
258 if self.into != None:
259 if (type(self.into) not in (list, tuple)) and (type(self.into) != types.FunctionType) :
261 _(u"L'attribut 'into' doit être un tuple : %r"), self.into)
263 def checkPosition(self):
264 """Vérifie l'attribut position."""
265 if self.position not in ('local', 'global', 'global_jdc'):
266 self.cr.fatal(_(u"L'attribut 'position' doit valoir 'local', 'global' "
267 u"ou 'global_jdc' : %r"), self.position)
269 def nomComplet(self):
270 if self.txtNomComplet != '' : return self.txtNomComplet
272 while hasattr(qui, 'pere' ):
273 self.txtNomComplet+='_'+qui.nom
275 self.txtNomComplet+='_'+qui.nom
276 return self.txtNomComplet
278 def addDefinitionMC(self,listeMCAvant,**args):
280 for mot in listeMCAvant:
282 ouChercher=ouChercher.entites[mot]
284 print ('impossible de trouver : ',mot,' ',listeMCAvant)
285 (nomMC,defMC)=args.items()[0]
286 defMC.pere = ouChercher
287 defMC.pere.propageRedefinit()
289 cata = CONTEXT.getCurrentCata()
291 ouChercher.entites[nomMC]=defMC
293 def changeDefinitionMC(self,listeMCAvant,**args):
295 for mot in listeMCAvant:
297 ouChercher=ouChercher.entites[mot]
299 print ('impossible de trouver : ',mot,' ',listeMCAvant)
301 for (nomAttributDef,valeurAttributDef) in args.items():
302 if hasattr(monSIMP, nomAttributDef) :
303 setattr(monSIMP, nomAttributDef, valeurAttributDef)
305 print ('pb avec ', nomAttributdef,valeurAttributMC)
306 monSIMP.propageRedefinit()
308 def propageRedefinit(self):
311 # PNPN il faut remonter a l etape
315 def makeObjetPourVerifSignature(self,**args):
316 etape = self.class_instance(oper=self, args=args)